/* ============================================================
   Rossy's Place — "The Neighborhood Passport"
   Casual International Favorites · Charles Town, WV
   Shared design system
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=Hanken+Grotesk:wght@400;500;600;700;800&family=Caveat:wght@500;600;700&display=swap');

:root{
  /* paper + ink */
  --cream:#faf3e6;
  --cream-2:#f4ead4;
  --paper:#fffdf7;
  --ink:#172a2b;
  --ink-soft:#445452;
  --ink-faint:#7c8a86;

  /* brand teal (from their logo) */
  --teal:#1796a2;
  --teal-deep:#0e6e78;
  --teal-bright:#2cc1ce;

  /* warmth */
  --amber:#e0913b;
  --amber-deep:#c2742a;
  --paprika:#c2492c;
  --wood:#7c4a28;
  --wood-deep:#522f17;

  --line:rgba(23,42,43,.12);
  --line-2:rgba(23,42,43,.07);
  --shadow:0 30px 60px -36px rgba(23,42,43,.42);
  --shadow-sm:0 14px 30px -20px rgba(23,42,43,.45);

  --display:'Fraunces',Georgia,serif;
  --body:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,sans-serif;
  --hand:'Caveat',cursive;

  --wrap:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  position:relative;
}
/* warm paper atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(120% 90% at 12% -10%, rgba(44,193,206,.10), transparent 55%),
    radial-gradient(120% 90% at 100% 0%, rgba(224,145,59,.10), transparent 50%),
    radial-gradient(140% 120% at 50% 120%, rgba(124,74,40,.08), transparent 55%);
}
/* faint grain */
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.45;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}

/* ---------- type ---------- */
.display{font-family:var(--display)}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.015em;color:var(--ink)}
.eyebrow{
  font-family:var(--body);font-size:12px;font-weight:700;letter-spacing:.28em;
  text-transform:uppercase;color:var(--teal-deep);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--amber);border-radius:2px}
.hand{font-family:var(--hand);font-weight:600;color:var(--amber-deep)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:700;font-size:14px;letter-spacing:.02em;
  padding:15px 28px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,background .22s,color .22s;
}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 14px 26px -16px rgba(15,110,120,.9)}
.btn-primary:hover{background:var(--teal-deep);transform:translateY(-2px);box-shadow:0 20px 34px -16px rgba(15,110,120,.95)}
.btn-amber{background:var(--amber);color:#3a2410;box-shadow:0 14px 26px -16px rgba(194,116,42,.9)}
.btn-amber:hover{background:var(--amber-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px)}
.btn-light{background:var(--paper);color:var(--teal-deep);border-color:var(--line)}
.btn-light:hover{border-color:var(--teal);color:var(--teal-deep);transform:translateY(-2px)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(250,243,230,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:24px;height:78px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:60px;width:auto;filter:drop-shadow(0 6px 13px rgba(23,42,43,.2))}
.brand .bn{display:none;flex-direction:column;line-height:1}
.nav-links{display:flex;align-items:center;gap:20px;margin-right:auto;white-space:nowrap}
.nav-links a.link{font-size:14.5px;font-weight:600;color:var(--ink-soft);position:relative;padding:4px 0}
.nav-links a.link::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--amber);transition:width .25s}
.nav-links a.link:hover{color:var(--ink)}
.nav-links a.link:hover::after,.nav-links a.link.active::after{width:100%}
.nav-links a.link.active{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:14px;white-space:nowrap}
.nav-cta .phone{font-weight:700;font-size:14.5px;color:var(--ink)}
.nav-cta .btn{padding:12px 22px;font-size:13.5px}
.hamburger{display:none;background:none;border:none;color:var(--ink);cursor:pointer;padding:8px}

/* ---------- origin chip (the passport motif) ---------- */
.origin{
  display:inline-flex;align-items:center;
  font-family:var(--body);font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  color:var(--teal-deep);background:transparent;
  border:1px solid color-mix(in srgb,var(--teal) 35%,var(--paper));border-radius:4px;
  padding:2px 7px;line-height:1;white-space:nowrap;
}
.origin-ticker{font-family:var(--body);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-deep);line-height:1.9}
.origin-ticker.on-dark{color:var(--teal-bright)}

/* ---------- letterpress stamp (hero + signature dishes only) ---------- */
.stamp{width:96px;height:96px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;border:2px solid var(--amber-deep);color:var(--amber-deep);background:var(--cream);
  box-shadow:inset 0 0 0 4px var(--cream),inset 0 0 0 5px color-mix(in srgb,var(--amber) 70%,transparent),0 8px 16px -7px rgba(0,0,0,.4);
  transform:rotate(-11deg);font-family:var(--display);font-style:italic;font-weight:600;font-size:15px;line-height:1.04}
.stamp small{font-family:var(--body);font-style:normal;font-weight:800;letter-spacing:.14em;font-size:7.5px;text-transform:uppercase;margin-top:4px;opacity:.92}
.stamp--paprika{border-color:var(--paprika);color:var(--paprika);box-shadow:inset 0 0 0 4px var(--cream),inset 0 0 0 5px color-mix(in srgb,var(--paprika) 65%,transparent),0 8px 16px -7px rgba(0,0,0,.4)}
.stamp--teal{border-color:var(--teal-deep);color:var(--teal-deep);box-shadow:inset 0 0 0 4px var(--cream),inset 0 0 0 5px color-mix(in srgb,var(--teal) 60%,transparent),0 8px 16px -7px rgba(0,0,0,.4)}

/* ---------- section headers ---------- */
.shead{max-width:720px}
.shead h2{font-size:clamp(30px,4.6vw,52px);margin:14px 0 0}
.shead p{color:var(--ink-soft);font-size:17px;margin-top:16px;line-height:1.7}
.center{text-align:center;margin-left:auto;margin-right:auto}
section{position:relative}
.pad{padding:96px 0}
.pad-sm{padding:64px 0}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:#d6e0dd;padding:72px 0 30px;position:relative;overflow:hidden}
.foot::before{content:"";position:absolute;inset:0;opacity:.5;background:
  radial-gradient(80% 120% at 0% 0%, rgba(23,150,162,.30), transparent 50%),
  radial-gradient(70% 120% at 100% 100%, rgba(224,145,59,.18), transparent 50%)}
.foot-grid{position:relative;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px}
.foot img.flogo{height:60px;width:auto;margin-bottom:18px}
.foot h4{font-family:var(--body);font-weight:800;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:18px}
.foot a{color:#cdd8d5;font-size:15px;display:block;padding:5px 0;transition:color .2s}
.foot a:hover{color:var(--teal-bright)}
.foot .tag{font-family:var(--hand);font-size:23px;color:var(--amber);margin-top:6px}
.foot-bottom{position:relative;margin-top:54px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:13px;color:#9fb0ac}
.foot-bottom a{display:inline;color:#9fb0ac}
.foot-bottom a:hover{color:#fff}

/* ---------- reveal-on-scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- mobile ---------- */
@media(max-width:860px){
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .pad{padding:68px 0}
  /* off-canvas drawer. NOTE: .nav has backdrop-filter, which makes it the containing block
     for this position:fixed child — so size with an explicit viewport height (vh is viewport-
     relative) rather than inset:bottom, which would otherwise collapse to the header's height. */
  .nav-links{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(80vw,310px);background:var(--paper);flex-direction:column;
    align-items:flex-start;justify-content:flex-start;gap:8px;padding:96px 30px 30px;overflow-y:auto;transform:translateX(100%);
    transition:transform .32s cubic-bezier(.2,.8,.2,1);border-left:1px solid var(--line);box-shadow:var(--shadow);z-index:55}
  .nav-links a.link{font-size:19px;font-family:var(--display);color:var(--ink);padding:10px 0}
  body.nav-open .nav-links{transform:none}
  .hamburger{display:block;z-index:60}
  .nav-cta .phone{display:none}
  .foot-grid{grid-template-columns:1fr;gap:32px}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none!important;scroll-behavior:auto}
}

/* ============================================================
   Menu components (shared: full menu page + home sample)
   ============================================================ */
.menu-section{margin:0 auto;max-width:880px;scroll-margin-top:160px}
.menu-section + .menu-section{margin-top:54px}
.menu-section-head{margin-bottom:10px;padding-bottom:13px;border-bottom:2px solid var(--ink)}
.menu-section-head .ms-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px}
.menu-section-head h2{font-size:clamp(25px,3.4vw,36px)}
.ms-count{font-family:var(--body);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--wood);white-space:nowrap;flex:0 0 auto}
.ms-intro{font-family:var(--display);font-style:italic;font-size:16px;color:var(--ink-faint);margin-top:8px;line-height:1.4}
.menu-item{padding:19px 16px;border-bottom:1px dashed var(--line);border-radius:12px;transition:background .2s}
.menu-item:hover{background:var(--paper)}
.menu-item:last-child{border-bottom:none}
.mi-top{display:flex;align-items:baseline;gap:12px}
.mi-name{font-family:var(--display);font-size:20px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;line-height:1.2}
.mi-star{color:var(--amber);font-size:14px}
.mi-leader{flex:1 1 24px;min-width:20px;align-self:flex-end;border-bottom:2px dotted color-mix(in srgb,var(--wood) 30%,var(--cream));margin-bottom:6px}
.mi-price{font-family:var(--display);font-weight:600;font-size:19px;color:var(--teal-deep);white-space:nowrap}
.mi-desc{color:var(--ink-soft);font-size:14.5px;margin-top:7px;max-width:66ch;line-height:1.6}
.menu-nav{position:sticky;top:77px;z-index:40;background:rgba(250,243,230,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.menu-nav-inner{display:flex;gap:9px;overflow-x:auto;scrollbar-width:none;padding:13px 0}
.menu-nav-inner::-webkit-scrollbar{display:none}
.menu-nav a{flex:0 0 auto;font-size:12px;font-weight:600;color:var(--ink-soft);padding:7px 13px;border-radius:999px;border:1px solid color-mix(in srgb,var(--wood) 25%,var(--cream));background:transparent;transition:.18s;white-space:nowrap}
.menu-nav a:hover{border-color:var(--teal);color:var(--teal-deep)}
.menu-nav a.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
@media(max-width:720px){
  .menu-item{padding:15px 8px}
  .mi-name{font-size:17.5px}
}
