/* ============================================================
   shell.css — App shell: left concierge panel + top nav
   Uses existing design tokens only. Wraps the frozen content
   stage; does not alter the dish page's internal design.
   ============================================================ */

/* two-zone frame: persistent panel | content column */
.appshell{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:var(--panel-w) 1fr;
  gap:16px;align-items:start}
.shell-main{min-width:0}  /* allow content/grids to shrink instead of overflowing */
/* Mobile bar + scrim are hidden on desktop/tablet; the ≤900px media query below
   re-enables them. These defaults MUST precede that media query so the mobile
   rule wins on source order at equal specificity. */
.mobile-bar{display:none}
.panel-scrim{display:none}

/* ---- Tablet tuning (~11" iPad): narrower panel, tighter hero, denser grids
        to reduce unnecessary scrolling without changing the design ---- */
@media(min-width:901px) and (max-width:1200px){
  :root{ --panel-w:300px; }
  .home-hero{padding:24px 26px}
  .home-hero h1{font-size:32px}
  .cardgrid{grid-template-columns:repeat(auto-fill,minmax(184px,1fr))}
}

/* ---- Mobile: left panel becomes an OFF-CANVAS DRAWER so it never buries
        the content. A compact mobile bar (menu + logo + search) sits on top. ---- */
@media(max-width:900px){
  body{padding:8px}
  .appshell{grid-template-columns:1fr;gap:0}
  .mobile-bar{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.9);
    border:1px solid var(--line);border-radius:14px;padding:8px 12px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
  .mobile-bar .mb-menu{background:var(--red);color:#fff;border:none;border-radius:10px;padding:9px 14px;
    font-weight:700;font-size:14px;cursor:pointer}
  .mobile-bar .mb-logo{height:34px;width:auto;background:#fff;border-radius:8px;padding:3px;cursor:pointer}
  .mobile-bar .mb-search{margin-left:auto;background:#fff;border:1px solid var(--line);border-radius:10px;
    padding:9px 12px;font-size:15px;cursor:pointer}

  .panel{position:fixed;top:0;left:0;height:100%;width:min(320px,86vw);z-index:90;border-radius:0;
    min-height:0;transform:translateX(-100%);transition:transform .28s ease;overflow-y:auto}
  .appshell.panel-open .panel{transform:translateX(0)}
  .panel-scrim{display:block;position:fixed;inset:0;background:rgba(31,31,31,.45);opacity:0;
    pointer-events:none;transition:opacity .25s ease;z-index:85}
  .appshell.panel-open .panel-scrim{opacity:1;pointer-events:auto}

  /* Top nav scrolls horizontally instead of wrapping (saves vertical space). */
  .topnav{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .topnav::-webkit-scrollbar{display:none}
  .topnav button{flex:none}
}

/* ---------- Left concierge panel ---------- */
.panel{background:var(--char);border-radius:var(--r-xl);overflow:hidden;position:sticky;top:18px;
  box-shadow:var(--shadow);color:#f4ece0;min-height:640px;display:flex;flex-direction:column}
.panel-hero{position:relative;padding:22px 20px 18px;background:
  linear-gradient(180deg,rgba(31,31,31,.15),rgba(31,31,31,.85)),center/cover no-repeat}
.panel-logo{display:block;width:118px;margin:0 auto 6px;background:#fff;border-radius:12px;padding:8px;box-shadow:var(--shadow-sm)}
.panel-tag{text-align:center;font-size:12px;color:#e9d6ad;letter-spacing:.05em}
.panel-body{padding:14px;display:flex;flex-direction:column;gap:8px;flex:1}
.panel-card{background:rgba(255,255,255,.06);border:1px solid rgba(212,166,74,.28);border-radius:13px;
  padding:12px 14px;cursor:pointer;transition:.15s;text-align:left;color:#f4ece0;display:flex;gap:10px;align-items:center}
.panel-card:hover{background:rgba(212,166,74,.16);border-color:var(--gold);transform:translateY(-1px)}
.panel-card .pc-ic{font-size:18px;line-height:1;flex:none}
.panel-card .pc-t{font-weight:700;font-size:14px}
.panel-card .pc-s{font-size:11.5px;color:#c7b48c;margin-top:1px}
.panel-card.accent{background:var(--red);border-color:var(--red)}
.panel-card.accent:hover{background:var(--burg)}
.panel-recent{margin-top:auto;padding-top:10px;border-top:1px solid rgba(212,166,74,.2)}
.panel-recent .rt{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#c7b48c;margin-bottom:6px}
.panel-recent a{display:block;color:#f4ece0;font-size:13px;padding:4px 0;cursor:pointer;text-decoration:none}
.panel-recent a:hover{color:var(--gold)}

/* ---------- Top nav ---------- */
.topnav{display:flex;gap:6px;align-items:center;flex-wrap:wrap;background:rgba(255,255,255,.7);
  border:1px solid var(--line);border-radius:16px;padding:8px 10px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.topnav button{background:transparent;border:none;border-radius:10px;padding:9px 13px;font-family:var(--font-body);
  font-weight:600;font-size:13.5px;color:var(--ink);cursor:pointer;transition:.15s}
.topnav button:hover{background:#fff;color:var(--red)}
.topnav button[aria-current="true"]{background:var(--red);color:#fff}
.topnav .nav-home{font-weight:700;color:var(--burg)}
.topnav .nav-home[aria-current="true"]{background:var(--burg);color:#fff}
.topnav .nav-spring{margin-left:auto}
.topnav .nav-search{background:#fff;border:1px solid var(--line)}

/* ---------- Content stage (routes render here) ---------- */
.stage-wrap{min-height:400px}

/* ---------- Home / collection grids ---------- */
.home-hero{background:linear-gradient(115deg,#fff8eb,#f4e5c9);border-radius:var(--r-xl);padding:30px 32px;
  box-shadow:var(--shadow);margin-bottom:16px;position:relative;overflow:hidden}
.home-hero h1{font-family:var(--font-display);font-size:38px;color:var(--burg);line-height:1.05}
.home-hero p{color:var(--ink);font-size:15.5px;margin-top:8px;max-width:520px}
.section{margin:22px 4px 8px}
.section h2{font-family:var(--font-display);font-size:24px;color:var(--char);display:flex;align-items:center;gap:12px}
.section h2::after{content:"";flex:1;height:1px;background:#e3d3a8;order:2}
/* "See all N →" on capped Home rows (sits to the right of the hairline). */
.section h2 .see-all{order:3;flex:none;margin-left:8px;font-family:var(--font-body);font-size:13px;
  font-weight:600;color:var(--burg);background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:8px}
.section h2 .see-all:hover{background:#fff;text-decoration:underline}
.section .sub{color:var(--mute);font-size:13px;margin-top:2px}

.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-top:12px}

/* dish/collection card (reuses frozen card language) */
.mcard{background:#fff;border:1px solid #ead4a4;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);cursor:pointer;transition:.15s;display:flex;flex-direction:column}
.mcard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.mcard .mc-img{height:130px;background-size:cover;background-position:center;background-color:#f4e5c9}
.mcard .mc-body{padding:12px 13px;display:flex;flex-direction:column;gap:6px;flex:1}
.mcard .mc-name{font-family:var(--font-display);font-size:18px;color:var(--char);line-height:1.1}
.mcard .mc-sub{font-size:12px;color:var(--mute);flex:1}
.mcard .mc-row{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.mcard .mc-price{font-family:var(--font-display);color:var(--red);font-weight:700;font-size:15px}
.mcard .mc-badges{display:flex;gap:4px;flex-wrap:wrap}

/* four-card First Time Here guide */
.ft-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:12px}
.ft-card{background:linear-gradient(160deg,#fff,#fbf1dd);border:1px solid #ead4a4;border-radius:var(--r-lg);
  padding:20px;cursor:pointer;transition:.15s;box-shadow:var(--shadow-sm)}
.ft-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}
.ft-card .ft-ic{font-size:26px}
.ft-card .ft-t{font-family:var(--font-display);font-size:20px;color:var(--burg);margin:8px 0 4px}
.ft-card .ft-s{font-size:13px;color:var(--ink)}

/* ---------- Search ---------- */
.search-wrap{background:#fff;border-radius:var(--r-xl);padding:24px 26px;box-shadow:var(--shadow);margin-bottom:16px}
.search-input{width:100%;font-size:18px;font-family:var(--font-body);padding:14px 16px;border:2px solid var(--line);
  border-radius:var(--r-md);color:var(--ink);outline:none}
.search-input:focus{border-color:var(--gold)}
.search-hint{color:var(--mute);font-size:13px;margin-top:8px}
.search-count{color:var(--mute);font-size:13px;margin:14px 4px 0}

/* ---------- Coming Soon ---------- */
.coming{background:linear-gradient(115deg,#fff8eb,#f4e5c9);border-radius:var(--r-xl);padding:60px 40px;
  text-align:center;box-shadow:var(--shadow)}
.coming .cs-ic{font-size:44px;opacity:.6}
.coming h2{font-family:var(--font-display);font-size:30px;color:var(--burg);margin:12px 0 6px}
.coming p{color:var(--ink);font-size:15px;max-width:460px;margin:0 auto 18px}
.coming .cs-back{background:var(--red);color:#fff;border:none;border-radius:var(--r-md);padding:13px 22px;
  font-weight:700;font-size:15px;cursor:pointer}
.coming .cs-back:hover{background:var(--burg)}

/* ---------- Concierge modal ---------- */
.concierge-overlay{position:fixed;inset:0;background:rgba(31,31,31,.5);display:none;z-index:80;
  align-items:center;justify-content:center;padding:20px}
.concierge-overlay.show{display:flex}
.concierge{background:var(--cream);border-radius:var(--r-xl);max-width:520px;width:100%;box-shadow:var(--shadow);overflow:hidden}
.concierge-head{background:var(--burg);color:#fff;padding:22px 24px}
.concierge-head h3{font-family:var(--font-display);font-size:26px}
.concierge-head p{font-size:13px;opacity:.9;margin-top:3px}
.concierge-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;padding:20px 22px}
.concierge-opt{background:#fff;border:1px solid #ead4a4;border-radius:13px;padding:15px;cursor:pointer;
  transition:.15s;text-align:left;display:flex;gap:11px;align-items:center}
.concierge-opt:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.concierge-opt .co-ic{font-size:20px}
.concierge-opt .co-t{font-weight:700;font-size:14px;color:var(--char)}
.concierge-foot{padding:0 22px 20px;text-align:center}
.concierge-close{background:none;border:1px solid var(--line);border-radius:11px;padding:10px 20px;
  font-weight:700;color:var(--ink);cursor:pointer}

/* ---------- Taste of India ---------- */
.taste-layout{display:grid;grid-template-columns:320px 1fr;gap:20px;margin-top:16px;align-items:start}
@media(max-width:900px){ .taste-layout{grid-template-columns:1fr} }
/* Left column stacks the map + region chips so it balances the detail card
   (eliminates the previous empty space under a short map). */
.taste-left{display:flex;flex-direction:column;gap:14px}
.taste-map{background:linear-gradient(160deg,#fff,#fbf1dd);border:1px solid #ead4a4;border-radius:var(--r-lg);
  padding:16px;box-shadow:var(--shadow-sm);display:flex;justify-content:center}
.india-map{width:100%;max-width:300px;height:auto}
.india-map .region{fill:#f0e0bf;stroke:#fff;stroke-width:2;stroke-linejoin:round;cursor:pointer;transition:.18s}
.india-map .region:hover{fill:var(--gold)}
.india-map .region.active{fill:var(--red)}
/* white letter with a thin burgundy outline reads on both cream and red fills */
.india-map .map-lab{font-family:var(--font-body);font-size:19px;font-weight:800;fill:#fff;
  stroke:var(--burg);stroke-width:.7px;paint-order:stroke;text-anchor:middle;pointer-events:none}
.taste-detail{background:#fff;border:1px solid #ead4a4;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.taste-detail .td-photo{height:190px;background-size:cover;background-position:center;background-color:#f4e5c9}
.taste-detail h2{font-family:var(--font-display);font-size:26px;color:var(--burg);margin:16px 20px 2px}
.taste-detail .td-tag{color:var(--softgold);font-weight:700;font-size:13px;margin:0 20px 10px;
  text-transform:uppercase;letter-spacing:.06em}
.taste-detail .td-fact{color:var(--ink);font-size:15px;line-height:1.6;margin:0 20px 14px}
.taste-detail .td-dishes{color:var(--ink);font-size:13.5px;margin:0 20px 20px;padding-top:12px;border-top:1px solid var(--line)}
.taste-detail .td-dishes b{color:var(--red)}
.taste-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.taste-chip{background:#fff;border:1.5px solid #e6ddcf;border-radius:999px;padding:9px 16px;font-weight:700;
  font-size:13.5px;color:var(--ink);cursor:pointer;transition:.15s}
.taste-chip:hover{border-color:var(--gold)}
.taste-chip[aria-current="true"]{background:var(--red);color:#fff;border-color:var(--red)}
