  :root{
    --brick:#8C1505; --brick-deep:#6c0f03; --gold:#C9962F;
    --char:#26160e; --clay:#4a2a1c; --cream:#FAF6EF; --cream2:#F1E7D8;
    --line:rgba(38,22,14,.12); --shadow:0 18px 50px -24px rgba(38,22,14,.5);
    --maxw:1180px;
  }
  *{box-sizing:border-box; margin:0; padding:0}
  html{scroll-behavior:smooth}
  body{font-family:"Inter",sans-serif; color:var(--char); background:var(--cream); line-height:1.55; -webkit-font-smoothing:antialiased}
  h1,h2,h3,.disp{font-family:"Inter",sans-serif; font-weight:800; letter-spacing:-.3px; line-height:1; text-transform:uppercase}
  .kicker{font-family:"Inter",sans-serif; text-transform:uppercase; letter-spacing:.22em; font-size:.74rem; font-weight:600; color:var(--brick)}
  a{color:inherit; text-decoration:none}
  img{max-width:100%; display:block}
  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
  .btn{font-family:"Inter",sans-serif; font-weight:700; text-transform:uppercase; letter-spacing:.08em; font-size:.86rem;
       border:2px solid var(--brick); background:var(--brick); color:#fff; padding:13px 24px; border-radius:999px; cursor:pointer; transition:.18s; display:inline-flex; align-items:center; gap:8px}
  .btn:hover{background:var(--brick-deep); border-color:var(--brick-deep); transform:translateY(-1px)}
  .btn.ghost{background:transparent; color:var(--brick)}
  .btn.ghost:hover{background:var(--brick); color:#fff}
  .btn.dark{background:var(--char); border-color:var(--char)}
  .btn.dark:hover{background:#000; border-color:#000}
  .btn.sm{padding:9px 16px; font-size:.76rem}
  .btn.gold{background:var(--gold); border-color:var(--gold); color:var(--char)}
  .btn.gold:hover{background:#b9851f; border-color:#b9851f; color:#fff}

  .ph{position:relative; background:linear-gradient(135deg,var(--clay),var(--brick)); border-radius:14px; overflow:hidden; color:#fff;}
  .ph::after{content:attr(data-label); position:absolute; inset:0; display:flex; align-items:flex-end; padding:14px 16px;
             font-family:"Inter",sans-serif; font-weight:600; letter-spacing:.04em; font-size:.95rem; text-shadow:0 2px 8px rgba(0,0,0,.4);
             background:linear-gradient(0deg,rgba(0,0,0,.45),transparent 55%)}
  .ph.g2{background:linear-gradient(135deg,#7a3b1e,#b06a2a)}
  .ph.g3{background:linear-gradient(135deg,#5a3320,#8C1505)}
  .ph.g4{background:linear-gradient(135deg,#3d2a1c,#a4742c)}
  /* Real photo fills any .ph placeholder box (data-driven via img: in data.js) */
  .ph-img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block}
  .ph.has-img::after{display:none}
  .rcover-img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block}

  .topbar{background:var(--char); color:rgba(250,246,239,.82); font-family:"Inter",sans-serif; font-weight:500; font-size:.76rem; letter-spacing:.04em}
  .topbar .tb-inner{display:flex; align-items:center; justify-content:space-between; gap:16px; height:38px}
  .topbar .tb-r{display:flex; align-items:center; gap:20px}
  .topbar a{color:var(--gold)}
  .topbar a:hover{color:#fff}
  header{position:sticky; top:0; z-index:50; background:rgba(250,246,239,.92); backdrop-filter:blur(8px); border-bottom:1px solid var(--line)}
  .nav{display:grid; grid-template-columns:1fr auto 1fr; align-items:center; column-gap:20px; height:72px}
  .logo{display:flex; align-items:center; gap:11px; justify-self:start; font-family:"Inter",sans-serif; font-weight:900; font-size:1.4rem; letter-spacing:-.3px; color:var(--brick); cursor:pointer; line-height:1; text-transform:uppercase; transition:color .25s ease}
  .logo-text{display:flex; flex-direction:column; white-space:nowrap}
  .logo-mark{flex:0 0 auto; width:48px; height:32px; display:block; order:2}
  .onggi-svg{width:100%; height:100%; overflow:visible; display:block}
  /* two onggi sit closed; lids lift & tilt OPEN on hover */
  .onggi-svg .lid{transform-box:fill-box; transform-origin:center bottom; transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
  .nav .logo:hover{color:var(--brick-deep)}
  .nav .logo:hover .lid-a{transform:translate(-1px,-7px) rotate(-13deg)}
  .nav .logo:hover .lid-b{transform:translate(2px,-6px) rotate(12deg)}
  .logo small{display:block; font-family:"Inter",sans-serif; font-size:.5rem; letter-spacing:.34em; color:var(--clay); margin-top:2px; transition:color .25s ease}
  .nav .logo:hover small{color:var(--gold)}
  .navlinks{justify-self:center; display:flex; gap:26px; flex-wrap:nowrap; white-space:nowrap}
  .navlinks a{font-family:"Inter",sans-serif; font-weight:600; text-transform:uppercase; font-size:.82rem; letter-spacing:.08em; color:var(--char); padding:6px 0; border-bottom:2px solid transparent; cursor:pointer; transition:.15s}
  .navlinks a:hover{color:var(--brick)}
  .navlinks a.active{color:var(--brick); border-color:var(--brick)}
  .nav-actions{justify-self:end; display:flex; align-items:center; gap:12px}
  .cartbtn{position:relative; background:none; border:none; cursor:pointer; font-size:1.25rem; color:var(--char)}
  .cartbtn .count{position:absolute; top:-6px; right:-8px; background:var(--brick); color:#fff; font-family:"Inter"; font-size:.6rem; min-width:16px; height:16px; border-radius:9px; display:flex; align-items:center; justify-content:center; padding:0 4px}
  .burger{display:none; background:none; border:none; font-size:1.5rem; cursor:pointer; color:var(--char)}
  .nav-order{display:none}  /* "Order Now" link, shown only inside the mobile ☰ dropdown */
  .navlinks.mobile .nav-order{display:block; color:var(--brick); font-weight:700}

  .page{display:none; animation:fade .35s ease}
  .page.active{display:block}
  @keyframes fade{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}
  section{padding:74px 0}
  .section-head{max-width:660px; margin-bottom:38px}
  .section-head h2{font-size:clamp(2rem,4.4vw,3.1rem); margin:10px 0 6px}
  .section-head p{color:var(--clay)}

  .hero{position:relative; min-height:560px; display:flex; align-items:center; color:#fff; overflow:hidden}
  .hero-bg{position:absolute; inset:0; background:
      radial-gradient(120% 120% at 80% 20%, rgba(201,150,47,.35), transparent 50%),
      linear-gradient(115deg,#3a1d10 0%, #6c0f03 55%, #8C1505 100%)}
  .hero-bg::after{content:""; position:absolute; inset:0; opacity:.07;
      background-image:radial-gradient(circle at 1px 1px, #fff 1px, transparent 0); background-size:22px 22px}
  .hero-inner{position:relative; max-width:680px}
  .hero h1{font-size:clamp(2.8rem,7vw,5.4rem); margin:14px 0}
  .hero p{font-size:1.18rem; max-width:520px; color:rgba(255,255,255,.9)}
  .hero-cta{display:flex; gap:14px; margin-top:30px; flex-wrap:wrap}
  .hero .btn.ghost{color:#fff; border-color:#fff}
  .hero .btn.ghost:hover{background:#fff; color:var(--brick)}

  .usp{background:var(--char); color:var(--cream)}
  .usp .grid{display:grid; grid-template-columns:repeat(4,1fr); gap:30px}
  .usp .item{display:flex; flex-direction:column; gap:8px}
  .usp .ic{font-size:1.7rem}
  .usp h4{font-family:"Inter"; text-transform:uppercase; letter-spacing:.05em; font-size:1rem; color:var(--gold)}
  .usp p{font-size:.92rem; color:rgba(250,246,239,.75)}

  .tband{background:var(--cream2)}
  .carousel{position:relative; overflow:hidden; margin-top:8px}
  .track{display:flex; transition:transform .5s cubic-bezier(.6,.05,.2,1); cursor:grab}
  .track.drag{cursor:grabbing; transition:none}
  .tcard{flex:0 0 33.333%; padding:0 12px}
  .tcard .inner{background:#fff; border:1px solid var(--line); border-radius:18px; padding:26px; height:100%; box-shadow:var(--shadow)}
  .tcard .top{display:flex; align-items:center; gap:13px; margin-bottom:14px}
  .avatar{width:48px; height:48px; border-radius:50%; flex:0 0 48px; display:flex; align-items:center; justify-content:center; color:#fff; font-family:"Inter"; font-weight:700; font-size:1.05rem}
  .tcard .who{line-height:1.2}
  .tcard .who b{font-family:"Inter"; font-size:1rem}
  .tcard .who span{font-size:.8rem; color:var(--clay); display:flex; align-items:center; gap:6px}
  .plat{font-size:.66rem; font-family:"Inter"; text-transform:uppercase; letter-spacing:.06em; padding:2px 7px; border-radius:6px; color:#fff}
  .stars{color:var(--gold); letter-spacing:2px; font-size:.95rem; margin-bottom:8px}
  .tcard .quote{font-size:1rem; color:var(--char)}
  .carousel-nav{display:flex; align-items:center; justify-content:space-between; margin-top:26px}
  .arrows{display:flex; gap:10px}
  .arrows button{width:44px; height:44px; border-radius:50%; border:2px solid var(--char); background:transparent; cursor:pointer; font-size:1.1rem; transition:.15s}
  .arrows button:hover{background:var(--char); color:var(--cream)}
  .dots{display:flex; gap:8px}
  .dots b{width:8px; height:8px; border-radius:50%; background:var(--line); cursor:pointer; transition:.2s}
  .dots b.on{background:var(--brick); width:22px; border-radius:5px}
  .count-note{font-family:"Inter"; text-transform:uppercase; letter-spacing:.1em; font-size:.74rem; color:var(--clay)}

  /* PRESS / "as featured in" carousel — fillable logo image slots */
  .pressbar{background:var(--cream2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:40px 0; overflow:hidden}
  .press-head{text-align:center; margin-bottom:22px}
  .press-mask{overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
  .press-track{display:flex; gap:24px; width:max-content; animation:marquee 32s linear infinite}
  .pressbar:hover .press-track{animation-play-state:paused}
  .press-item{flex:0 0 auto; width:208px; height:104px; background:#fff; border:1px solid var(--line); border-radius:16px;
              display:flex; align-items:center; justify-content:center; padding:18px; box-shadow:0 10px 28px -20px rgba(38,22,14,.55);
              text-decoration:none; transition:.2s}
  .press-item:hover{transform:translateY(-4px); border-color:var(--brick)}
  .press-logo{max-height:60px; max-width:172px; object-fit:contain}
  .press-ph{flex-direction:column; align-items:center; gap:7px; text-align:center; color:var(--clay)}
  .press-ph .pm{font-size:1.6rem; opacity:.85}
  .press-ph .nm{font-family:"Inter"; font-weight:600; text-transform:uppercase; letter-spacing:.05em; font-size:.8rem; color:var(--char)}
  .press-ph small{font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; opacity:.55}
  @keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* INSTAGRAM REELS carousel — smooth UX */
  .reels{background:var(--cream)}
  .reels-bar{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:24px}
  .reels-bar .arrows{display:flex; gap:10px}
  .reels-bar .arrows button{width:46px; height:46px; border-radius:50%; border:2px solid var(--char); background:transparent; cursor:pointer; font-size:1.15rem; transition:.15s}
  .reels-bar .arrows button:hover{background:var(--char); color:var(--cream)}
  .reels-track{display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
               padding:8px 2px 20px; cursor:grab; -ms-overflow-style:none; scrollbar-width:none}
  .reels-track::-webkit-scrollbar{display:none}
  .reels-track.drag{cursor:grabbing; scroll-snap-type:none; scroll-behavior:auto}
  .reel{flex:0 0 258px; scroll-snap-align:center; aspect-ratio:9/16; border-radius:20px; overflow:hidden;
        position:relative; box-shadow:var(--shadow); color:#fff; text-decoration:none; user-select:none;
        transition:transform .35s cubic-bezier(.2,.7,.2,1)}
  .reel:hover{transform:translateY(-7px) scale(1.018)}
  .reel .rcover{position:absolute; inset:0; transition:transform .6s ease}
  .reel:hover .rcover{transform:scale(1.06)}
  .reel .rgrad{position:absolute; inset:0; background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,transparent 26%,transparent 52%,rgba(0,0,0,.82) 100%)}
  .reel .ig-top{position:absolute; top:13px; left:14px; right:14px; display:flex; align-items:center; gap:8px; font-family:"Inter"; font-weight:600; font-size:.84rem}
  .reel .ig-av{width:24px; height:24px; border-radius:50%; background:linear-gradient(45deg,#f09433,#dc2743,#bc1888); flex:0 0 24px}
  .reel .ig-ico{margin-left:auto; font-size:1.1rem}
  .reel .play{position:absolute; inset:0; margin:auto; width:58px; height:58px; border-radius:50%;
              background:rgba(255,255,255,.2); backdrop-filter:blur(4px); border:2px solid rgba(255,255,255,.85);
              display:flex; align-items:center; justify-content:center; font-size:1.3rem; opacity:.85; transition:.25s; padding-left:4px}
  .reel:hover .play{opacity:1; transform:scale(1.08)}
  .reel .ig-bot{position:absolute; left:15px; right:15px; bottom:15px}
  .reel .cap{font-size:.86rem; line-height:1.32; margin-bottom:9px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
  .reel .stats{display:flex; gap:15px; font-family:"Inter"; font-size:.8rem; opacity:.96}
  .reel .stats span{display:flex; align-items:center; gap:5px}

  .cards{display:grid; gap:22px}
  .cards.c3{grid-template-columns:repeat(3,1fr)}
  .card{background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; transition:.2s; display:flex; flex-direction:column}
  .card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
  .card .ph{border-radius:0; height:180px}
  .card .body{padding:20px; flex:1; display:flex; flex-direction:column; gap:8px}
  .card h3{font-size:1.25rem}
  .card .desc{font-size:.9rem; color:var(--clay); flex:1}

  /* MENU page */
  .mcat{margin-bottom:42px}
  .mcat h3{font-size:1.7rem; color:var(--brick); border-bottom:2px solid var(--line); padding-bottom:10px; margin-bottom:6px; display:flex; align-items:baseline; gap:12px}
  .mcat h3 small{font-family:"Inter"; font-weight:400; font-size:.85rem; color:var(--clay); text-transform:none; letter-spacing:0}
  .mrow{display:flex; align-items:center; gap:16px; padding:15px 0; border-bottom:1px dashed var(--line)}
  .mrow .ph{width:74px; height:74px; flex:0 0 74px; border-radius:12px}
  .mrow .ph::after{display:none}
  .mrow .info{flex:1}
  .mrow .info b{font-family:"Inter"; font-size:1.05rem}
  .mrow .info .kr{color:var(--clay); font-size:.82rem; margin-left:6px}
  .mrow .info p{font-size:.85rem; color:var(--clay)}
  .price{font-family:"Inter"; font-weight:700; color:var(--brick); font-size:1.05rem; white-space:nowrap}
  .badge-incl{display:inline-block; background:var(--gold); color:var(--char); font-family:"Inter"; font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; padding:4px 10px; border-radius:6px}

  /* MENU page — left category nav + card grid */
  .menu-layout{display:grid; grid-template-columns:230px 1fr; gap:42px; align-items:start}
  .menu-nav{position:sticky; top:100px; display:flex; flex-direction:column; gap:4px}
  .mnav{text-align:left; border:none; background:none; cursor:pointer; padding:12px 14px; border-radius:10px; font-family:"Inter"; font-weight:600; text-transform:uppercase; letter-spacing:.04em; font-size:.92rem; color:var(--clay); border-left:3px solid transparent; transition:.15s}
  .mnav span{display:block; font-family:"Inter"; font-weight:400; font-size:.72rem; letter-spacing:0; text-transform:none; opacity:.7; margin-top:1px}
  .mnav:hover{background:var(--cream2); color:var(--char)}
  .mnav.on{background:var(--cream2); color:var(--brick); border-left-color:var(--brick)}
  .menu-banner{height:230px; border-radius:18px; margin-bottom:24px}
  .menu-chead{margin-bottom:22px}
  .menu-chead h2{font-size:clamp(1.8rem,3.5vw,2.6rem); margin-top:6px}
  .menu-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:22px}
  .dish{background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden; transition:.2s}
  .dish:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
  .dish > .ph{height:170px; border-radius:0}
  .dish > .ph::after{display:none}
  .dish-b{padding:16px 18px}
  .dish-top{display:flex; align-items:baseline; justify-content:space-between; gap:10px}
  .dish-top b{font-family:"Inter"; font-size:1.08rem}
  .dish-kr{color:var(--clay); font-size:.82rem; margin:2px 0 6px}
  .dish-b p{font-size:.86rem; color:var(--clay)}

  /* ORDER page — Chowbus-style */
  .storebar{background:#fff; border-bottom:1px solid var(--line); position:sticky; top:72px; z-index:30}
  .sb-inner{display:flex; align-items:center; justify-content:space-between; gap:20px; padding:18px 24px; flex-wrap:wrap}
  .sb-name{font-family:"Inter"; font-weight:800; letter-spacing:-.3px; font-size:1.55rem; color:var(--char); display:flex; align-items:center; gap:12px}
  .sb-open{font-family:"Inter"; font-size:.7rem; color:#1d6b3a; background:rgba(29,107,58,.12); padding:3px 10px; border-radius:999px; letter-spacing:.05em}
  .sb-sub{color:var(--clay); font-size:.9rem; margin-top:2px}
  .sb-order{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
  .otoggle{display:inline-flex; background:var(--cream2); border-radius:999px; padding:5px; gap:4px}
  .otoggle button{border:none; background:none; font-family:"Inter"; font-weight:600; text-transform:uppercase; letter-spacing:.06em; font-size:.8rem; padding:9px 20px; border-radius:999px; cursor:pointer; color:var(--clay)}
  .otoggle button.on{background:var(--brick); color:#fff}
  .sb-time{font-family:"Inter"; font-size:.82rem; padding:10px 14px; border:1px solid var(--line); border-radius:999px; background:#fff; cursor:pointer}
  .order-layout{display:grid; grid-template-columns:210px 1fr; gap:34px; padding-top:30px; padding-bottom:80px}
  .catnav{position:sticky; top:160px; align-self:start; display:flex; flex-direction:column; gap:2px; max-height:75vh; overflow:auto}
  .catnav a{font-family:"Inter"; font-weight:600; font-size:.9rem; color:var(--clay); padding:9px 12px; border-radius:8px; cursor:pointer; transition:.12s}
  .catnav a:hover{background:var(--cream2); color:var(--char)}
  .catnav a.on{background:var(--brick); color:#fff}
  .osearch{width:100%; padding:13px 16px; border:1px solid var(--line); border-radius:12px; font-family:inherit; font-size:.95rem; margin-bottom:14px; background:#fff}
  .ocat{margin-bottom:34px; scroll-margin-top:170px}
  .ocat > h3{font-size:1.45rem; color:var(--char); margin-bottom:4px}
  .ocard{display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--line); cursor:pointer}
  .ocard:hover .oc-name{color:var(--brick)}
  .oc-txt{flex:1}
  .oc-name{font-family:"Inter"; font-weight:600; font-size:1.05rem; transition:.12s}
  .oc-name .kr{color:var(--clay); font-weight:400; font-size:.82rem; margin-left:6px}
  .oc-desc{font-size:.86rem; color:var(--clay); margin:4px 0 8px; max-width:46ch}
  .oc-price{font-family:"Inter"; font-weight:700; color:var(--char)}
  .oc-img{position:relative; width:108px; height:108px; flex:0 0 108px}
  .oc-img .ph{height:100%; border-radius:12px}
  .oc-img .ph::after{display:none}
  .addbtn{position:absolute; right:-8px; bottom:-8px; width:36px; height:36px; border-radius:50%; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow); font-size:1.3rem; font-weight:700; color:var(--brick); cursor:pointer; display:flex; align-items:center; justify-content:center; line-height:1}
  .addbtn:hover{background:var(--brick); color:#fff}
  .spicy{color:#c0392b; font-size:.85rem}

  /* SHOP */
  .shopgrid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
  .pcard{background:#fff; border:1px solid var(--line); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; transition:.2s}
  .pcard:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
  .pcard .ph{height:160px; border-radius:0}
  .pcard .pb{padding:16px; display:flex; flex-direction:column; gap:6px; flex:1}
  .pcard b{font-family:"Inter"; font-size:1rem}
  .pcard .pp{color:var(--brick); font-family:"Inter"; font-weight:700}

  /* STORY */
  .story-hero{background:var(--char); color:var(--cream)}
  .story-hero .grid{display:grid; grid-template-columns:1.1fr 1fr; gap:46px; align-items:center}
  .story-hero h1{font-size:clamp(2.4rem,5vw,3.8rem); margin:12px 0}
  .story-hero .ph{height:380px; border-radius:18px}
  .timeline{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:30px}
  .tl{border-top:3px solid var(--brick); padding-top:14px}
  .tl b{font-family:"Inter"; font-weight:800; letter-spacing:-.3px; font-size:1.7rem; color:var(--brick); display:block}
  .pull{font-family:"Inter"; font-weight:800; letter-spacing:-.3px; text-transform:uppercase; font-size:clamp(1.6rem,3.5vw,2.6rem); line-height:1.08; color:var(--char); max-width:880px; margin:10px auto; text-align:center}
  .pull span{color:var(--brick)}

  /* CATERING — why-cater */
  .whycater{display:grid; grid-template-columns:repeat(2,1fr); gap:26px; max-width:920px}
  .wc{display:flex; gap:16px; align-items:flex-start}
  .wc .ic{font-size:1.7rem; flex:0 0 auto}
  .wc h4{font-family:"Inter"; text-transform:uppercase; letter-spacing:.04em; font-size:1.05rem; color:var(--brick); margin-bottom:4px}
  .wc p{color:var(--clay); font-size:.95rem}
  .callcard{background:#fff; border:1px solid var(--line); border-radius:20px; padding:40px; text-align:center; box-shadow:var(--shadow); max-width:560px; margin:0 auto}
  .callcard .num{font-family:"Inter"; font-weight:800; letter-spacing:-.5px; font-size:clamp(2rem,5vw,2.9rem); color:var(--brick); margin:8px 0 4px; display:block}

  .cta{background:linear-gradient(115deg,var(--brick),var(--brick-deep)); color:#fff; text-align:center}
  .cta h2{font-size:clamp(2rem,4.5vw,3rem)}
  .cta .btn.ghost{color:#fff; border-color:#fff} .cta .btn.ghost:hover{background:#fff;color:var(--brick)}
  .cta .hero-cta{justify-content:center}

  footer{background:var(--char); color:var(--cream); padding:54px 0 28px}
  .fgrid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:34px}
  footer h5{font-family:"Inter"; text-transform:uppercase; letter-spacing:.1em; color:var(--gold); margin-bottom:12px; font-size:.82rem}
  footer p,footer a{color:rgba(250,246,239,.78); font-size:.9rem; margin-bottom:6px; display:block}
  footer a:hover{color:#fff}
  .fmap{height:130px; border-radius:12px; margin-top:10px; background:repeating-linear-gradient(45deg,#3a2418,#3a2418 12px,#412a1c 12px,#412a1c 24px); display:flex; align-items:center; justify-content:center; color:rgba(250,246,239,.6); font-family:"Inter"; font-size:.8rem}
  .fbar{border-top:1px solid rgba(250,246,239,.15); margin-top:32px; padding-top:18px; font-size:.78rem; color:rgba(250,246,239,.6); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px}

  .scrim{position:fixed; inset:0; background:rgba(38,22,14,.5); opacity:0; pointer-events:none; transition:.25s; z-index:90}
  .scrim.show{opacity:1; pointer-events:auto}
  .drawer{position:fixed; top:0; right:0; height:100%; width:380px; max-width:90vw; background:var(--cream); z-index:100; transform:translateX(100%); transition:.3s cubic-bezier(.6,.05,.2,1); display:flex; flex-direction:column; box-shadow:-20px 0 60px -20px rgba(0,0,0,.5)}
  .drawer.open{transform:none}
  .drawer .dh{display:flex; align-items:center; justify-content:space-between; padding:20px; border-bottom:1px solid var(--line)}
  .drawer .dh h3{font-size:1.3rem}
  .drawer .items{flex:1; overflow:auto; padding:14px 20px}
  .citem{display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px dashed var(--line)}
  .citem .nm{flex:1; font-size:.9rem}
  .citem .nm b{font-family:"Inter"}
  .qty{display:flex; align-items:center; gap:8px}
  .qty button{width:26px; height:26px; border-radius:50%; border:1px solid var(--line); background:#fff; cursor:pointer; font-weight:700}
  .empty{text-align:center; color:var(--clay); padding:40px 0; font-size:.9rem}
  .dfoot{padding:20px; border-top:1px solid var(--line)}
  .totalrow{display:flex; justify-content:space-between; font-family:"Inter"; font-size:1.15rem; margin-bottom:14px}
  .totalrow b{color:var(--brick)}
  .confirm{background:#1d6b3a; color:#fff; padding:14px; border-radius:12px; text-align:center; font-size:.9rem; margin:14px 0; display:none}
  .confirm.show{display:block}

  @media(max-width:900px){
    .usp .grid{grid-template-columns:repeat(2,1fr)}
    .cards.c3,.shopgrid{grid-template-columns:repeat(2,1fr)}
    .tcard{flex-basis:50%}
    .story-hero .grid{grid-template-columns:1fr; gap:24px}
    .fgrid{grid-template-columns:1fr 1fr}
    .order-layout{grid-template-columns:1fr}
    .catnav{position:static; flex-direction:row; overflow-x:auto; max-height:none; gap:8px; padding-bottom:8px; margin-bottom:8px; border-bottom:1px solid var(--line)}
    .catnav a{white-space:nowrap}
    .whycater{grid-template-columns:1fr}
    .menu-layout{grid-template-columns:1fr; gap:20px}
    .menu-nav{position:static; flex-direction:row; overflow-x:auto; gap:8px; padding-bottom:8px; border-bottom:1px solid var(--line); -ms-overflow-style:none; scrollbar-width:none}
    .menu-nav::-webkit-scrollbar{display:none}
    .mnav{white-space:nowrap; border-left:none; border-bottom:3px solid transparent; border-radius:8px 8px 0 0}
    .mnav.on{border-left:none; border-bottom-color:var(--brick)}
    .mnav span{display:none}
  }
  @media(max-width:640px){
    .navlinks{display:none}
    .burger{display:block}
    .navlinks.mobile{display:flex; position:absolute; top:72px; left:0; right:0; transform:none; flex-direction:column; background:var(--cream); padding:16px 24px; gap:12px; border-bottom:1px solid var(--line); box-shadow:var(--shadow)}
    .tcard{flex-basis:100%}
    .cards.c3,.shopgrid,.usp .grid,.timeline{grid-template-columns:1fr}
    .menu-grid{grid-template-columns:1fr; gap:12px}
    /* compact list rows on phones: thumbnail to the side, more items per screen,
       full text column for long names (e.g. the combo items) */
    .dish{display:flex}
    .dish > .ph{flex:0 0 90px; width:90px; height:auto; min-height:90px; align-self:stretch; border-radius:0}
    .dish-b{flex:1; min-width:0; padding:12px 14px}
    .dish-top{flex-direction:column; align-items:flex-start; gap:2px}  /* price drops below the name */
    .dish-top b{font-size:1rem}
    .dish .price{font-size:.82rem; font-weight:600}  /* smaller, less shouty price */
    .dish-kr{margin:2px 0 4px}
    .dish-b p{font-size:.82rem}
    .topbar .tb-l{display:none}
    .topbar .tb-inner{justify-content:center}
    section{padding:52px 0}
    .storebar{top:72px}
    /* keep the logo + onggi mark compact so the nav doesn't overflow */
    .nav{column-gap:10px}
    .logo{gap:8px; font-size:1.2rem}
    .logo-mark{width:38px; height:25px}
  }
  /* on-site order add buttons + checkout fields */
  .oc-add{display:flex; gap:8px; flex-wrap:wrap; margin-top:8px}
  .addbtn2{font-family:"Inter"; font-weight:700; font-size:.8rem; border:1.5px solid var(--brick); color:var(--brick); background:#fff; padding:7px 13px; border-radius:999px; cursor:pointer; transition:.15s; min-height:38px}
  .addbtn2:hover{background:var(--brick); color:#fff}
  .addbtn2.disabled{border-color:var(--line); color:var(--clay); background:var(--cream2); cursor:not-allowed; opacity:.7}
  .addbtn2.disabled:hover{background:var(--cream2); color:var(--clay)}
  .co-field{width:100%; padding:11px 13px; border:1px solid var(--line); border-radius:10px; font-family:inherit; font-size:1rem; margin-bottom:8px; background:#fff}
  #viewCartBtn{white-space:nowrap}

  /* ---------- MOBILE + iPAD (<=1024px): simpler header, no onggi / Instagram ---------- */
  @media(max-width:1024px){
    .logo-mark{display:none}              /* remove the onggi mark on mobile + iPad */
    .reels{display:none}                  /* remove the Instagram reels section */
    .nav{display:flex; align-items:center; gap:12px}
    .navlinks{margin-left:auto; justify-self:auto}  /* push nav links to the right edge */
    .nav-actions{margin-left:auto}
    .hero p{font-size:1rem}               /* smaller hero subtext */
    .hero-cta{justify-content:center; gap:16px}  /* center the two hero buttons + more gap */
  }

  /* ---------- MOBILE OPTIMIZATION ---------- */
  @media(max-width:768px){
    .wrap{padding:0 18px}
    section{padding:50px 0}
    .hero{min-height:84vh; min-height:84svh}  /* fill the phone screen so the next section isn't visible */
    .hero p{font-size:.95rem}
    .hero h1{font-size:clamp(2rem,6vw,2.9rem); line-height:1.12; margin:12px 0}
    .hero-cta{justify-content:center; gap:16px}
    .hero-cta .btn{flex:0 0 auto; justify-content:center; padding:12px 18px}
    .pressbar{display:none}  /* hide "As featured in" marquee on mobile */
    .sb-inner{flex-direction:column; align-items:flex-start; gap:12px}
    .sb-order{width:100%}
    .sb-time{flex:1}
    .catnav{position:static; flex-direction:row; overflow-x:auto; gap:8px; padding-bottom:8px; border-bottom:1px solid var(--line); margin-bottom:8px; max-height:none; -ms-overflow-style:none; scrollbar-width:none}
    .catnav::-webkit-scrollbar{display:none}
    .catnav a{white-space:nowrap}
    .btn, .btn.sm{min-height:44px}
    .section-head h2{font-size:clamp(1.7rem,7vw,2.4rem)}
  }
  @media(max-width:480px){
    section{padding:42px 0}
    .wrap{padding:0 16px}
    .topbar .tb-inner{height:auto; padding:8px 0; font-size:.7rem; justify-content:center}
    .logo{font-size:1rem; gap:6px}
    .logo-mark{width:30px; height:20px}
    .logo small{font-size:.44rem; letter-spacing:.24em}
    .nav{column-gap:8px}
    .nav-actions{gap:8px}
    .nav-actions .btn.sm{padding:9px 12px; font-size:.72rem}
    .hero{min-height:88vh; min-height:88svh}
    .hero h1{font-size:2rem; line-height:1.14; margin:10px 0}
    .hero p{font-size:.9rem}
    .hero-cta .btn{padding:11px 16px}
    .drawer{width:100%; max-width:100%}
    .ocard{gap:12px}
    .oc-img{width:84px; height:84px; flex-basis:84px}
    .oc-name{font-size:1rem}
    .menu-banner{height:160px}
    .tcard .inner{padding:20px}
    .reel{flex-basis:80vw}
    .press-item{width:168px; height:88px}
    .pull{font-size:1.5rem}
    .callcard{padding:28px 20px}
    .whycater{gap:18px}
  }
  /* compact "Order Now" button in the nav bar on mobile + iPad (overrides the 44px touch min-height) */
  @media(max-width:1024px){
    .nav-actions .btn.sm{padding:7px 12px; font-size:.72rem; min-height:0; letter-spacing:.04em; margin-right:10px}
  }

/* ============================ CART + CHECKOUT ============================ */
.dish-add{margin-top:10px}
.dish-add.two{display:flex;gap:8px}
.dish-add .addbtn2{width:100%}
/* floating cart button */
.jdd-cart-btn{position:fixed;right:18px;bottom:18px;z-index:1200;display:none;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;background:var(--brick);color:#fff;box-shadow:var(--shadow);font-size:1.5rem;transition:transform .15s}
.jdd-cart-btn:hover{transform:translateY(-2px)}
.jdd-cart-btn.pulse{animation:jddpulse .4s ease}
@keyframes jddpulse{0%{transform:scale(1)}50%{transform:scale(1.18)}100%{transform:scale(1)}}
.jcb-badge{position:absolute;top:-4px;right:-4px;min-width:22px;height:22px;padding:0 5px;border-radius:11px;background:var(--gold);color:#1a1209;font-size:.78rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
/* overlay + drawer */
.jdd-cart-overlay{position:fixed;inset:0;background:rgba(20,12,5,.5);opacity:0;visibility:hidden;transition:.2s;z-index:1300}
.jdd-cart-overlay.show{opacity:1;visibility:visible}
.jdd-cart{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--cream);box-shadow:-12px 0 40px -16px rgba(0,0,0,.5);transform:translateX(100%);transition:transform .25s ease;z-index:1400;display:flex;flex-direction:column}
.jdd-cart.open{transform:translateX(0)}
.jdd-cart-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line);font-size:1.15rem;color:var(--char)}
.jdd-cart-head b{font-family:"Inter";font-weight:800;letter-spacing:-.3px}
.jdd-x{border:none;background:none;font-size:1.1rem;cursor:pointer;color:var(--clay);width:34px;height:34px;border-radius:50%}
.jdd-x:hover{background:var(--cream2)}
.jdd-cart-body{flex:1;overflow-y:auto;padding:14px 18px 24px}
.jdd-empty{text-align:center;padding:50px 10px;color:var(--clay)}
.jdd-empty .je-ico{font-size:2.4rem;margin-bottom:8px}
.jdd-lines{display:flex;flex-direction:column;gap:2px}
.jdd-line{display:grid;grid-template-columns:54px 1fr auto auto auto;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.jl-thumb{width:54px;height:54px;border-radius:10px;overflow:hidden;flex:0 0 54px;background:var(--cream2)}
.jl-thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.jl-thumb-ph{background:linear-gradient(135deg,var(--cream2),#e6dcc9)}
.jl-main{display:flex;flex-direction:column;gap:2px;min-width:0}
.jl-main b{font-family:"Inter";font-weight:600;font-size:.95rem;color:var(--char)}
.jl-tier{font-size:.72rem;color:var(--clay)}
.jl-unit{font-size:.74rem;color:var(--clay);opacity:.8}
.jl-qty{display:flex;align-items:center;gap:8px}
.jl-qty button{width:26px;height:26px;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:1rem;line-height:1;color:var(--brick)}
.jl-qty span{min-width:16px;text-align:center;font-weight:700}
.jl-tot{font-family:"Inter";font-weight:700;color:var(--char);white-space:nowrap}
.jl-rm{border:none;background:none;color:var(--clay);cursor:pointer;font-size:.85rem;opacity:.6}
.jl-rm:hover{opacity:1;color:var(--brick)}
.jdd-sum{margin-top:16px;border-top:2px solid var(--line);padding-top:12px;display:flex;flex-direction:column;gap:6px}
.jdd-sum-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--clay)}
.jdd-sum-row.total{font-size:1.15rem;color:var(--char);margin-top:4px}
.jdd-sum-row.total b{font-family:"Inter";font-weight:800}
.jdd-note{margin-top:10px;font-size:.78rem;color:var(--brick);background:#fbeee6;border-radius:8px;padding:8px 10px}
.jdd-checkout{margin-top:18px;display:flex;flex-direction:column;gap:11px}
.jdd-field{display:flex;flex-direction:column;gap:4px}
.jdd-field label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--clay)}
.jdd-field input,.jdd-field select{padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-family:"Inter";font-size:.95rem;background:#fff;color:var(--char)}
.jdd-field input:focus,.jdd-field select:focus{outline:none;border-color:var(--gold)}
.jdd-pay{margin-top:4px;width:100%;justify-content:center}
.jdd-pay:disabled{opacity:.6;cursor:default}
.jdd-secure{font-size:.74rem;color:var(--clay);text-align:center;margin-top:2px}
.jdd-err{background:#fbe3df;color:#8a2417;border-radius:8px;padding:9px 11px;font-size:.84rem}
@media(max-width:480px){.jdd-cart{width:100%;max-width:100vw}.jdd-cart-btn{width:54px;height:54px;font-size:1.3rem}}

/* ============================ ORDER STATUS PAGE ============================ */
.order-status{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:40px 30px;text-align:center;margin:20px auto}
.order-status h1{font-family:"Inter";font-weight:800;letter-spacing:-.4px;font-size:1.7rem;color:var(--char);margin:10px 0}
.order-status p{color:var(--clay)}
.order-status.paid{border-top:5px solid #2e7d4f}
.order-status.failed{border-top:5px solid var(--brick)}
.os-spinner{width:42px;height:42px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--gold);margin:0 auto 6px;animation:osspin 1s linear infinite}
@keyframes osspin{to{transform:rotate(360deg)}}
.os-details{margin-top:18px;text-align:left;border-top:1px solid var(--line);padding-top:14px}
.osl{display:flex;justify-content:space-between;padding:5px 0;font-size:.92rem;color:var(--char)}
.osl.total{border-top:1px solid var(--line);margin-top:6px;padding-top:10px;font-size:1.1rem}
.os-addr{margin-top:14px;font-size:.84rem;color:var(--clay)}
.os-actions{display:flex;gap:10px;justify-content:center;margin-top:22px;flex-wrap:wrap}
/* Add-to-cart toast (non-blocking confirmation) */
.jdd-toast{position:fixed;left:50%;bottom:90px;transform:translate(-50%,16px);z-index:1500;background:var(--char);color:var(--cream);padding:12px 20px;border-radius:999px;font-family:"Inter";font-weight:600;font-size:.9rem;box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;cursor:pointer;max-width:88vw;text-align:center}
.jdd-toast.show{opacity:1;visibility:visible;transform:translate(-50%,0)}
.jdd-toast::before{content:"✓ ";color:var(--gold);font-weight:800}
@media(max-width:480px){.jdd-toast{bottom:84px}}
/* ============================ GOOGLE REVIEW CTA ============================ */
.review-cta{background:linear-gradient(160deg,#fff,#f6efe3);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.review-inner{text-align:center;max-width:720px;margin:0 auto;padding:8px 0}
.review-cta .g-logo{font-family:"Inter",sans-serif;font-weight:700;font-size:1.9rem;letter-spacing:-1px;margin-bottom:6px}
.review-cta .g-b{color:#4285F4}.review-cta .g-r{color:#EA4335}.review-cta .g-y{color:#FBBC05}.review-cta .g-g{color:#34A853}
.review-cta .review-stars{color:#FBBC05;font-size:1.5rem;letter-spacing:3px;margin-bottom:10px}
.review-cta h2{margin-bottom:8px}
.review-cta p{color:var(--clay);max-width:560px;margin:0 auto 6px}
.review-cta .hero-cta{justify-content:center;margin-top:18px}