/* Pawon Nusantara PHP v6.3
   Modern restaurant storefront refinement. */

:root{
  --container:1280px;
  --surface-warm:#fffaf7;
  --surface-soft:#f8f5f1;
  --surface-green:#f2f7ef;
  --green:#174d22;
  --green-2:#2f7a36;
  --red-soft:#fff0ec;
  --shadow-card:0 10px 30px rgba(40,33,29,.08);
  --shadow-card-hover:0 22px 48px rgba(40,33,29,.14);
  --shadow-hero:0 28px 70px rgba(68,39,27,.12);
}

body{
  background:var(--surface-warm);
  color:#202939;
}

.container{width:min(calc(100% - 40px),var(--container))}
.section{padding:58px 0}
.section--tight{padding:40px 0}
.section--soft{background:linear-gradient(180deg,#f8f5f1 0%,#fbfaf8 100%)}
.section-header{margin-bottom:24px}
.section-copy{max-width:650px}
.section-header h2,.section-copy h2{font-size:clamp(27px,2.5vw,36px);line-height:1.12}
.section-header p,.section-copy>p{margin-top:9px;line-height:1.55}
.eyebrow{margin-bottom:8px;color:var(--primary);font-size:11px;letter-spacing:.14em}

/* Announcement */
.announcement{
  background:linear-gradient(90deg,var(--primary-dark),var(--primary));
  color:#fff;
  font-size:12px;
}
.announcement__inner{min-height:36px}
.announcement__message{display:flex;align-items:center;gap:8px;font-weight:650}
.announcement__message i{width:7px;height:7px;border-radius:50%;background:#ffd670;box-shadow:0 0 0 4px rgba(255,214,112,.15)}
.announcement__links{display:flex;gap:18px}
.announcement__links a{color:rgba(255,255,255,.88);text-decoration:none}
.announcement__links a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  border-bottom:1px solid rgba(226,217,211,.8);
  background:rgba(255,252,249,.93);
  box-shadow:0 4px 18px rgba(40,33,29,.035);
  backdrop-filter:blur(18px);
}
.header-main{min-height:82px;gap:26px}
.brand{gap:12px}
.brand__mark{
  width:46px;
  height:46px;
  overflow:hidden;
  border-radius:14px;
  background:transparent;
  box-shadow:0 8px 20px rgba(180,35,24,.18);
}
.brand__mark img{width:100%;height:100%}
.brand__copy strong{font-size:18px;letter-spacing:-.03em}
.brand__copy small{margin-top:4px;font-size:11px}
.desktop-nav{
  gap:4px;
  margin-left:auto;
  padding:5px;
  border:1px solid #ebe3dd;
  border-radius:999px;
  background:rgba(255,255,255,.78);
}
.desktop-nav a{
  padding:9px 15px;
  border-radius:999px;
  color:#475467;
  font-size:13px;
  font-weight:720;
  transition:.18s ease;
}
.desktop-nav a:hover,.desktop-nav a.is-active{background:#fff0ec;color:var(--primary)}
.header-actions{gap:8px}
.icon-button{
  display:inline-flex;
  width:auto;
  min-width:43px;
  height:43px;
  padding:0 12px;
  gap:8px;
  border-radius:13px;
  border-color:#e6ded8;
  background:#fff;
  box-shadow:0 4px 14px rgba(31,41,55,.04);
}
.icon-button:hover{border-color:#d4c8c0;background:#fff9f6;transform:translateY(-1px)}
.icon-button svg{width:18px;height:18px}
.action-label{font-size:12px;font-weight:750}
.cart-count{right:-5px;top:-6px}
.header-whatsapp{min-height:43px;padding-inline:17px;border-radius:13px;box-shadow:0 9px 22px rgba(180,35,24,.2)}
.header-whatsapp svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.menu-toggle{display:none;width:43px;padding:0}
.search-panel{border-top:1px solid #eee7e1;background:rgba(255,252,249,.98)}
.global-search{max-width:820px;border-radius:18px;box-shadow:0 18px 45px rgba(40,33,29,.11)}

/* Hero */
.hero{padding:30px 0 34px}
.hero-shell{
  position:relative;
  overflow:hidden;
  padding:48px;
  border:1px solid #eadfd7;
  border-radius:32px;
  background:
    radial-gradient(circle at 92% 8%,rgba(247,144,9,.12),transparent 25%),
    radial-gradient(circle at 12% 94%,rgba(180,35,24,.08),transparent 30%),
    linear-gradient(135deg,#fff5ef 0%,#fffdfb 52%,#f4f7ef 100%);
  box-shadow:var(--shadow-hero);
}
.hero-shell::before,.hero-shell::after{content:"";position:absolute;border-radius:50%;pointer-events:none}
.hero-shell::before{right:-90px;top:-120px;width:300px;height:300px;border:1px solid rgba(180,35,24,.08)}
.hero-shell::after{left:45%;bottom:-180px;width:320px;height:320px;background:rgba(255,255,255,.32)}
.hero-grid{position:relative;z-index:1;grid-template-columns:minmax(0,.92fr) minmax(420px,1.08fr);gap:46px;align-items:center}
.hero h1{max-width:620px;font-size:clamp(42px,4.5vw,58px);line-height:1.02;letter-spacing:-.055em}
.hero__lead{max-width:570px;margin-top:16px;font-size:16px;line-height:1.58}
.hero__actions{margin-top:23px}
.hero__actions .button{min-height:48px;border-radius:14px}
.hero__meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:25px;
  padding-top:0;
  border-top:0;
}
.hero__meta div{
  display:grid;
  grid-template-columns:29px 1fr;
  grid-template-rows:auto auto;
  gap:0 9px;
  padding:11px 12px;
  border:1px solid rgba(224,212,204,.85);
  border-radius:14px;
  background:rgba(255,255,255,.72);
}
.hero__meta span{grid-row:1/3;width:29px;height:29px;background:#fce1dc}
.hero__meta strong{font-size:12px;line-height:1.25}
.hero__meta small{color:#7a6d67;font-size:10px;line-height:1.3}
.hero-visual{position:relative;min-width:0}
.hero-visual__frame{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  border:7px solid rgba(255,255,255,.88);
  border-radius:28px;
  background:#fff;
  box-shadow:0 22px 50px rgba(44,29,21,.18);
}
.hero-visual__frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;background:#fff}
.hero-visual__card{
  left:-18px;
  bottom:20px;
  max-width:250px;
  padding:13px 15px;
  border:1px solid rgba(226,216,208,.92);
  border-radius:16px;
  background:rgba(255,255,255,.94);
  box-shadow:0 16px 36px rgba(40,33,29,.14);
}
.hero-visual__icon{width:42px;height:42px;border-radius:13px;font-size:13px}
.hero-visual__status{
  position:absolute;
  right:18px;
  top:18px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(22,63,24,.9);
  color:#fff;
  font-size:11px;
  font-weight:800;
  box-shadow:0 8px 22px rgba(14,49,20,.22);
}
.hero-visual__status i{width:7px;height:7px;border-radius:50%;background:#9ef0a8;box-shadow:0 0 0 4px rgba(158,240,168,.15)}

/* Service strip */
.service-strip{margin-top:-12px;border:0;background:transparent;position:relative;z-index:2}
.service-strip__grid{gap:12px}
.service-point{
  padding:18px 19px;
  border:1px solid #e8dfd8!important;
  border-radius:18px;
  background:#fff;
  box-shadow:0 10px 26px rgba(40,33,29,.065);
}
.service-point:first-child,.service-point:last-child{padding-left:19px;padding-right:19px}
.service-point__icon{width:40px;height:40px;border-radius:13px;background:#fff0ec}
.service-point strong{font-size:13px}
.service-point span{font-size:11px;line-height:1.45}

/* Categories */
.category-grid{gap:14px}
.category-card{
  min-height:86px;
  padding:15px 16px;
  border:1px solid #e4ddd7;
  border-radius:18px;
  background:linear-gradient(145deg,#fff 0%,#fffbf8 100%);
  box-shadow:0 8px 22px rgba(40,33,29,.04);
}
.category-card:hover{transform:translateY(-3px);border-color:#d9c7bc;box-shadow:0 16px 32px rgba(40,33,29,.09)}
.category-card__mark{width:46px;height:46px;border-radius:15px;background:linear-gradient(145deg,#f2f8ef,#e8f3e3)}
.category-card__arrow{display:grid;place-items:center;width:29px;height:29px;border-radius:50%;background:#f7f2ee;color:var(--primary)}

/* Product cards */
.product-grid{gap:18px}
.product-card{
  height:auto;
  align-self:start;
  overflow:hidden;
  border:1px solid #e5ddd7;
  border-radius:24px;
  background:linear-gradient(180deg,#fff 0%,#fffdfb 100%);
  box-shadow:var(--shadow-card);
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease;
}
.product-card:hover{transform:translateY(-5px);border-color:#d9c2b6;box-shadow:var(--shadow-card-hover)}
.product-card--spicy{border-color:#efc89f}
.product-card__image{
  position:relative;
  display:block;
  width:auto;
  aspect-ratio:4/3;
  margin:12px 12px 0;
  overflow:hidden;
  border:0;
  border-radius:18px;
  background:#fff;
  box-shadow:inset 0 0 0 1px rgba(31,41,55,.05);
}
.product-card__image img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  border-radius:inherit;
  background:#fff;
  transition:transform .32s ease;
}
.product-card:hover .product-card__image img{transform:scale(1.015)}
.product-card__badges{left:10px;top:10px}
.product-card__rating{right:10px;top:10px;min-height:31px;border:1px solid rgba(255,255,255,.8)}
.product-card__body{padding:15px 17px 17px}
.product-card__category{display:inline-flex;align-self:flex-start;margin:0 0 7px;padding:4px 8px;border-radius:999px;background:#f4f0ec;color:#6b5d55;font-size:9px;letter-spacing:.075em}
.product-card h3{font-size:17px;line-height:1.23}
.product-card h3 a:hover{color:var(--primary)}
.product-card p{min-height:38px;margin:8px 0 14px;font-size:12.5px;line-height:1.52}
.product-card__footer{align-items:center}
.price-stack strong{color:#194b22;font-size:18px}
.price-stack del{margin-top:1px}
.add-button{
  min-height:39px;
  padding:0 14px;
  border:1px solid #d9e5d5;
  border-radius:12px;
  background:linear-gradient(180deg,#f7fbf5,#eef6eb);
  color:#215e29;
  box-shadow:0 5px 13px rgba(35,102,43,.08);
}
.add-button:hover{border-color:var(--primary);background:var(--primary);box-shadow:0 9px 18px rgba(180,35,24,.18)}

/* Catalogue */
.catalog-intro{
  padding:42px 0 30px;
  background:linear-gradient(180deg,#fff9f5 0%,#fff 100%);
  border-bottom:1px solid #efe6df;
}
.catalog-intro__copy h1{color:#173d1d;font-size:clamp(40px,4vw,55px)}
.catalog-toolbar{margin-top:28px}
.catalog-search,.catalog-select{border-color:#e5ddd6;background:#fff;box-shadow:0 8px 20px rgba(40,33,29,.055)}
.catalog-search:focus-within{border-color:#c9ac9d;box-shadow:0 0 0 4px rgba(180,35,24,.07),0 10px 24px rgba(40,33,29,.08)}
.catalog-search svg,.catalog-select svg{stroke:var(--primary)}
.catalog-select select{color:#344054}
.catalog-content{padding:30px 0 70px;background:#fffdfb}
.catalog-groups{gap:38px}
.catalog-category__header{
  margin-bottom:16px;
  padding:19px 21px;
  border:1px solid #e4ddd7;
  border-radius:22px;
  background:linear-gradient(110deg,#fff 0%,#fff9f5 60%,#f4f8f1 100%);
  box-shadow:0 10px 28px rgba(40,33,29,.055);
}
.catalog-category__icon{width:52px;height:52px;border-radius:16px;background:#edf6e9;color:#347839}
.catalog-category__link{border-color:#ded4cd;background:#fff}

/* Supporting sections */
.split-panel{
  border:1px solid rgba(255,255,255,.06);
  border-radius:28px;
  background:linear-gradient(135deg,#1d2a1d 0%,#253826 56%,#472019 100%);
  box-shadow:0 22px 50px rgba(27,35,27,.18);
}
.split-panel__content{padding:48px}
.split-panel__media{padding:14px;background:transparent}
.split-panel__media img{width:100%;height:100%;max-height:none;border-radius:20px;object-fit:cover;background:#fff}
.step-card,.testimonial-card{
  border-color:#e6ddd7;
  border-radius:20px;
  box-shadow:0 9px 24px rgba(40,33,29,.045);
}
.step-card{position:relative;overflow:hidden}
.step-card::after{content:"";position:absolute;right:-35px;top:-35px;width:100px;height:100px;border-radius:50%;background:#fff1ec}
.step-card__number{position:relative;z-index:1;border-radius:13px;box-shadow:0 8px 18px rgba(180,35,24,.17)}
.testimonial-card{background:linear-gradient(145deg,#fff,#fffaf7)}
.faq-item{border-color:#e6ddd7}
.faq-item summary{padding:18px 0}
.cta-band{
  padding:34px 38px;
  border:1px solid #efd2ca;
  border-radius:26px;
  background:linear-gradient(110deg,#fff0ec,#fff8f5 60%,#f3f8ef);
  box-shadow:0 14px 34px rgba(50,34,25,.08);
}

/* Footer */
.site-footer{
  margin-top:32px;
  padding:0 0 22px;
  background:
    radial-gradient(circle at 12% 12%,rgba(247,144,9,.12),transparent 27%),
    linear-gradient(145deg,#171a18 0%,#202821 52%,#331b18 100%);
  color:#e9eee9;
}
.footer-cta{
  position:relative;
  top:-34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
  padding:30px 34px;
  border:1px solid rgba(255,255,255,.15);
  border-radius:26px;
  background:linear-gradient(120deg,var(--primary-dark),var(--primary) 60%,#d14d35);
  box-shadow:0 20px 48px rgba(96,25,18,.28);
}
.footer-cta__eyebrow{display:block;margin-bottom:6px;color:#ffd6cd;font-size:10px;font-weight:850;letter-spacing:.14em;text-transform:uppercase}
.footer-cta h2{margin:0;color:#fff;font-size:clamp(25px,2.8vw,36px);line-height:1.12;letter-spacing:-.035em}
.footer-cta p{margin:8px 0 0;color:rgba(255,255,255,.78);font-size:13px}
.footer-cta__actions{display:flex;flex:0 0 auto;gap:10px}
.button--light{background:#fff;color:var(--primary-dark)}
.button--outline-light{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.08);color:#fff}
.button--outline-light:hover{background:rgba(255,255,255,.16)}
.footer-grid{grid-template-columns:1.65fr repeat(3,1fr);gap:48px;padding-top:20px}
.brand--footer .brand__mark{box-shadow:none}
.brand--footer .brand__copy strong{color:#fff}
.brand--footer .brand__copy small{color:#aeb9ae}
.footer-brand p{max-width:390px;margin-top:17px;color:#aeb9ae;line-height:1.7}
.footer-service-pills{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}
.footer-service-pills span{padding:6px 9px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(255,255,255,.045);color:#c9d3c9!important;font-size:10px!important}
.footer-column{display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.footer-grid h3{margin-bottom:8px;color:#fff;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.footer-grid a,.footer-grid span{color:#aeb9ae;font-size:12px}
.footer-grid a:hover{color:#fff;transform:translateX(2px)}
.footer-contact__primary{color:#fff!important;font-weight:800}
.footer-bottom{margin-top:34px;padding-top:18px;border-color:rgba(255,255,255,.09);color:#7f8d80}
.whatsapp-float{width:54px;height:54px;font-size:0;box-shadow:0 14px 32px rgba(37,211,102,.35)}
.whatsapp-float svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* Other media */
.product-gallery{overflow:hidden;border-radius:24px;box-shadow:var(--shadow-card)}
.product-gallery img{border-radius:inherit}
.search-result img,.cart-line img,.checkout-item img{border-radius:10px}

@media(max-width:1120px){
  .action-label{display:none}
  .icon-button{width:43px;padding:0}
  .hero-shell{padding:38px}
  .hero-grid{grid-template-columns:minmax(0,.9fr) minmax(370px,1.1fr);gap:34px}
  .hero h1{font-size:46px}
  .hero__meta{grid-template-columns:1fr}
  .hero__meta div{grid-template-columns:29px 1fr}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr}
  .footer-contact{grid-column:2/-1}
}

@media(max-width:900px){
  .desktop-nav{display:none}
  .menu-toggle{display:inline-flex}
  .header-whatsapp{display:none}
  .hero-shell{padding:30px}
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-visual{order:-1;max-width:700px;margin-inline:auto}
  .hero__meta{grid-template-columns:repeat(3,minmax(0,1fr))}
  .footer-cta{align-items:flex-start;flex-direction:column}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr}
  .footer-contact{grid-column:auto}
}

@media(max-width:680px){
  .container{width:min(calc(100% - 26px),var(--container))}
  .section{padding:46px 0}
  .section--tight{padding:32px 0}
  .announcement__links{display:none}
  .header-main{min-height:68px}
  .brand__mark{width:40px;height:40px;border-radius:12px}
  .brand__copy strong{font-size:16px}
  .search-toggle{margin-left:auto}
  .hero{padding:18px 0 27px}
  .hero-shell{padding:22px;border-radius:24px}
  .hero h1{font-size:37px}
  .hero__lead{font-size:15px}
  .hero__actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .hero__actions .button{padding-inline:10px;font-size:12px}
  .hero__meta{grid-template-columns:1fr;gap:8px}
  .hero-visual__frame{border-width:5px;border-radius:21px}
  .hero-visual__card{left:10px;right:10px;bottom:10px;max-width:none}
  .hero-visual__status{right:11px;top:11px}
  .service-strip{margin-top:-5px}
  .service-strip__grid{grid-template-columns:1fr;gap:8px}
  .service-point{padding:14px 16px!important}
  .product-grid{gap:13px}
  .product-card{border-radius:20px}
  .product-card__image{margin:9px 9px 0;border-radius:15px}
  .product-card__body{padding:12px 14px 14px}
  .product-card p{min-height:36px;margin:7px 0 12px}
  .split-panel__content{padding:30px 24px}
  .split-panel__media{padding:10px}
  .footer-cta{top:-26px;padding:25px 22px;border-radius:22px}
  .footer-cta__actions{width:100%;flex-wrap:wrap}
  .footer-cta__actions .button{flex:1}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;padding-top:8px}
  .footer-brand{grid-column:1/-1}
  .footer-contact{grid-column:auto}
}

@media(max-width:480px){
  .hero__actions{grid-template-columns:1fr}
  .hero-visual__card{display:none}
  .category-grid,.product-grid{grid-template-columns:1fr}
  .product-card__image{margin:10px 10px 0;border-radius:16px}
  .product-card h3{font-size:18px}
  .product-card p{font-size:13px}
  .footer-cta__actions{flex-direction:column}
  .footer-cta__actions .button{width:100%}
  .footer-grid{grid-template-columns:1fr}
  .footer-brand,.footer-contact{grid-column:auto}
}
.hero-visual__frame img{aspect-ratio:auto}
/* Customer account entry */
.account-link{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:auto;min-width:42px;padding:0 11px;text-decoration:none}
.account-link__initials{display:grid;place-items:center;width:26px;height:26px;border-radius:9px;background:linear-gradient(145deg,#238118,#53a83c);color:#fff;font-size:10px;font-weight:900;letter-spacing:.04em}
.account-link.is-logged-in{border-color:#cfe3c9;background:#f6fbf3;color:#24651d}
@media(max-width:760px){.account-link{width:40px;min-width:40px;padding:0}.account-link .action-label{display:none}}
