/* ============================================================
   Rossy's Place — "The Sweet Spot"
   Casual International Favorites · Charles Town, WV
   Elegant editorial structure with rationed brand moments —
   Tiffany Blue leads. Shared design system.
   ============================================================ */

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

:root{
  /* base — cream paper, forest ink */
  --cream:#faf3e6;        /* page base */
  --cream-2:#f3e8d2;      /* faint deeper cream for subtle bands */
  --paper:#fffdf7;        /* cards */
  --forest:#143430;       /* anchor: body text, dark bands, section headers */
  --ink:#143430;          /* alias → forest (legacy usages) */
  --ink-soft:#3d524f;
  --ink-faint:#7c8a86;

  /* brand — Tiffany Blue leads (client's official #17CFC8, from their logo) */
  --tiffany:#17cfc8;      /* THE color: logo, CTAs, perforation, stamps, active chip — a FILL */
  --tiffany-deep:#0e9499; /* text/prices/links on cream — Tiffany fails contrast at body sizes */
  --teal:#17cfc8;         /* alias → tiffany (legacy) */
  --teal-deep:#0e9499;    /* alias → tiffany-deep (legacy) */
  --teal-bright:#37d2de;
  --teal-ink:#0a3f3d;     /* dark text that sits on a tiffany fill */

  /* secondary accents — rationed */
  --gold:#d99a2b;         /* hairline rules, eyebrow ticks, secondary accents */
  --wood:#b08a4f;         /* faint rules / texture */
  --wood-deep:#6b5836;
  --paprika:#c2492c;      /* RARE — the — Rossy signature + at most one pinpoint dot per page */

  /* legacy warm aliases → repointed off red (global red purge) */
  --tomato:#0e9499;       /* alias → tiffany-deep */
  --tomato-deep:#0e9499;  /* alias → tiffany-deep */
  --marigold:#d99a2b;     /* alias → gold */
  --marigold-deep:#c2742a;
  --amber:#d99a2b;        /* alias → gold */
  --amber-deep:#c2742a;

  --line:rgba(20,48,45,.16);
  --line-2:rgba(20,48,45,.09);

  /* shadows — soft + editorial (retired the hard enamel-sign offset) */
  --shadow:0 26px 50px -28px rgba(20,48,45,.45);
  --shadow-sm:0 14px 28px -18px rgba(20,48,45,.4);
  --pop:0 14px 30px -16px rgba(20,48,45,.5);
  --pop-lg:0 22px 44px -22px rgba(20,48,45,.55);

  --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.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  position:relative;
}
/* warm, saturated atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(110% 80% at 8% -8%, rgba(23,207,200,.10), transparent 55%),
    radial-gradient(100% 80% at 100% 0%, rgba(217,154,43,.07), transparent 52%);
}
/* faint grain */
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  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:500;line-height:1.02;letter-spacing:-.02em;color:var(--ink)}
/* engraved eyebrow — gold rules + static tiffany diamonds (nothing moves) */
.eyebrow{
  display:flex;align-items:center;justify-content:center;gap:13px;
  font-family:var(--body);font-size:.75rem;font-weight:700;
  letter-spacing:.30em;text-transform:uppercase;color:var(--tiffany-deep);
}
.eyebrow .rule{width:30px;height:1px;background:var(--gold);flex:0 0 auto}
.eyebrow .dia{width:5px;height:5px;background:var(--tiffany-deep);transform:rotate(45deg);flex:0 0 auto}
.eyebrow--left{justify-content:flex-start}
.hand{font-family:var(--hand);font-weight:700;color:var(--paprika)}

/* ---------- buttons — tiffany fill (primary) + outline (secondary) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--body);font-weight:800;font-size:14.5px;letter-spacing:.01em;
  padding:14px 26px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .16s cubic-bezier(.2,.8,.2,1),box-shadow .18s,background .2s,color .2s;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-primary,.btn-amber,.btn-tomato{background:var(--tiffany);color:#0a3f3d;box-shadow:0 5px 14px -5px rgba(23,207,200,.7)}
.btn-primary:hover,.btn-amber:hover,.btn-tomato:hover{box-shadow:0 10px 22px -7px rgba(23,207,200,.85)}
.btn-ghost,.btn-secondary{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn-ghost:hover,.btn-secondary:hover{background:var(--forest);color:var(--cream)}
.btn-light{background:var(--paper);color:var(--teal-ink);border-color:rgba(20,48,45,.14)}
/* on dark sections: keep the outline button readable */
.on-ink .btn-ghost,.on-ink .btn-secondary{color:#fff;border-color:rgba(255,255,255,.55)}
.on-ink .btn-ghost:hover,.on-ink .btn-secondary:hover{background:#fff;color:var(--forest)}

/* ---------- "trust" pills — quieter, outlined ---------- */
.pill{
  display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;
  background:var(--paper);border:1.5px solid rgba(20,48,45,.16);border-radius:999px;
  padding:8px 15px;box-shadow:var(--shadow-sm);color:var(--forest);
}
.pill b{color:var(--tiffany-deep);font-weight:900}
.pill .dot{width:9px;height:9px;border-radius:50%;background:var(--tiffany)}
.pill .stars{color:var(--gold);letter-spacing:1px}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:var(--cream);border-bottom:3px solid var(--ink)}
.nav-inner{display:flex;align-items:center;gap:24px;height:148px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:132px;width:auto;filter:drop-shadow(0 5px 10px rgba(20,48,45,.28))}
.brand .bn{display:none;flex-direction:column;line-height:1}
.nav-links{display:flex;align-items:center;flex:1;justify-content:space-evenly;gap:10px;white-space:nowrap}
.nav-links a.link{font-size:17px;font-weight:800;color:var(--ink);position:relative;padding:10px 18px;border-radius:999px;border:2px solid transparent;transition:.18s}
.nav-links a.link:hover{border-color:var(--ink);background:var(--paper)}
.nav-links a.link.active{background:var(--tiffany);color:#0a3f3d;border-color:transparent}
.nav-cta{display:flex;align-items:center;gap:14px;white-space:nowrap}
.nav-cta .phone{font-weight:800;font-size:14.5px;color:var(--ink)}
.nav-cta .btn{padding:11px 20px;font-size:13.5px}
.nav-menu-btn{display:none} /* mobile-only quick-link; desktop already has Menu in the nav links */
.hamburger{display:none;background:var(--tiffany);border:1.5px solid var(--forest);border-radius:12px;color:#0a3f3d;cursor:pointer;padding:8px;box-shadow:var(--shadow-sm)}

/* ---------- signature beats: perforation band · hairline rule · origin rule ---------- */

/* P0 — perforation band (Menu masthead only). Scallop cream must match the NEIGHBOR bg. */
.perf-band{position:relative;background:var(--tiffany);padding:17px 0;text-align:center}
.perf-band span{font-family:var(--body);font-size:.72rem;font-weight:700;letter-spacing:.36em;text-transform:uppercase;color:#0a4f4c}
.perf-band::before,.perf-band::after{content:"";position:absolute;left:0;right:0;height:11px;
  background-image:radial-gradient(circle at 11px 0,var(--cream) 7.5px,transparent 8px);background-size:22px 11px}
.perf-band::before{top:0}
.perf-band::after{bottom:0;background-image:radial-gradient(circle at 11px 11px,var(--cream) 7.5px,transparent 8px)}

/* the quiet alternative — a single 4px tiffany hairline (Home / Our Story / Visit).
   .bunting is aliased here so any not-yet-updated markup degrades to the clean rule, not the old fiesta garland. */
.brand-rule,.bunting{height:4px;width:100%;background:var(--tiffany);border:none}

/* engraved origin rule — gold gradient hairlines flanking native place names */
.origin-rule{display:flex;align-items:center;justify-content:center;gap:14px;max-width:700px;margin:0 auto}
.origin-rule span:not(.r){font-size:.69rem;font-weight:700;letter-spacing:.16em;color:var(--tiffany-deep);white-space:nowrap}
.origin-rule .r{flex:1;height:1px}
.origin-rule .r:first-child{background:linear-gradient(90deg,transparent,#cdab6a)}
.origin-rule .r:last-child{background:linear-gradient(90deg,#cdab6a,transparent)}
@media(max-width:720px){
  /* let the place-name list wrap instead of overflowing the screen; drop the flanking rules */
  .origin-rule{flex-wrap:wrap;gap:6px 10px}
  .origin-rule .r{display:none}
  .origin-rule span:not(.r){white-space:normal;text-align:center;font-size:.62rem;line-height:1.7}
}

/* ---------- origin tag (passport motif) — quiet outlined ---------- */
.origin{
  display:inline-flex;align-items:center;
  font-family:var(--body);font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  color:var(--tiffany-deep);background:transparent;
  border:1px solid #b6e6e3;border-radius:4px;
  padding:2px 7px;line-height:1.5;white-space:nowrap;
}
.origin-ticker{font-family:var(--body);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--tiffany-deep);line-height:1.9}
.origin-ticker.on-dark{color:#7fd6d1}

/* ---------- passport stamp (signature dishes + Our Story photo only) ---------- */
.stamp{width:84px;height:84px;flex-shrink:0;border-radius:50%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;transform:rotate(-8deg);
  border:1.5px solid var(--tiffany-deep);color:var(--tiffany-deep);
  box-shadow:inset 0 0 0 4px var(--cream),inset 0 0 0 5px rgba(14,148,153,.3);
  font-family:var(--display)}
.stamp .country{font-family:var(--body);font-size:.47rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.stamp .label{font-family:var(--display);font-style:italic;font-size:.69rem;font-weight:600;line-height:1;margin:2px 0}
.stamp .stars{font-size:.4rem;letter-spacing:.08em;opacity:.75}
.stamp small{font-family:var(--body);font-style:normal;font-weight:800;letter-spacing:.1em;font-size:.47rem;text-transform:uppercase}
/* solid tiffany fill variant — Our Story hero photo / Home featured dish (clean flat disc, no inset ring) */
.stamp--fill,.stamp--teal{width:94px;height:94px;background:var(--tiffany);color:#0a3f3d;border:none;transform:rotate(-10deg);
  box-shadow:0 8px 18px -8px rgba(0,0,0,.4)}
.stamp--fill .label,.stamp--teal .label{font-style:italic;font-size:14px;line-height:1;color:#0a3f3d;margin:0}
.stamp--fill .country,.stamp--fill small,.stamp--teal .country,.stamp--teal small{font-family:var(--body);font-style:normal;font-size:7px;font-weight:800;letter-spacing:.14em;color:#0a4f4c;margin-top:3px;text-transform:uppercase}
.stamp--paprika{border-color:var(--paprika);color:var(--paprika);box-shadow:inset 0 0 0 4px var(--paper),inset 0 0 0 5px rgba(194,73,44,.25)}

/* ---------- section headers ---------- */
.shead{max-width:760px}
.shead h2{font-size:clamp(32px,4.8vw,56px);margin:16px 0 0;font-weight:500}
.shead p{color:var(--ink-soft);font-size:17.5px;margin-top:16px;line-height:1.7}
.center{text-align:center;margin-left:auto;margin-right:auto}
section{position:relative}
.pad{padding:92px 0}
.pad-sm{padding:60px 0}

/* recolor section heads on dark/colored blocks */
.on-ink h2,.on-ink h3,.on-ink .shead h2{color:#fff}
.on-ink .shead p{color:rgba(255,255,255,.82)}
.on-marigold h2,.on-marigold h3,.on-marigold .shead p{color:var(--ink)}
.on-marigold .shead p{color:var(--wood-deep)}

/* ---------- footer ---------- */
.foot{background:var(--forest);color:#dfeae7;padding:50px 0 30px;position:relative;overflow:hidden}
.foot .bunting,.foot .brand-rule{margin-bottom:46px}
.foot::before{content:"";position:absolute;inset:0;opacity:.5;background:
  radial-gradient(80% 120% at 0% 0%, rgba(23,207,200,.30), transparent 50%),
  radial-gradient(70% 120% at 100% 100%, rgba(217,154,43,.16), transparent 50%)}
.foot-grid{position:relative;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot img.flogo{height:74px;width:auto;margin-bottom:18px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.4))}
.foot h4{font-family:var(--body);font-weight:800;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#7fd6d1;margin-bottom:16px}
.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:25px;color:#7fd6d1;margin-top:6px}
.foot-bottom{position:relative;margin-top:52px;padding-top:24px;border-top:2px solid rgba(255,255,255,.18);
  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:980px){
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-inner{height:90px}
  .brand img{height:72px}
  .nav-links{gap:6px}
  .nav-links a.link{font-size:14.5px;padding:8px 14px}
}
@media(max-width:720px){
  .pad{padding:64px 0}
  .nav-inner{height:124px;gap:10px}
  .brand{margin-right:auto}
  .brand img{height:112px}
  /* off-canvas drawer — slides in from the right to match the right hamburger */
  .nav-links{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(82vw,320px);background:var(--cream);flex-direction:column;
    align-items:flex-start;justify-content:flex-start;gap:8px;padding:96px 26px 30px;overflow-y:auto;transform:translateX(100%);
    transition:transform .32s cubic-bezier(.2,.8,.2,1);border-left:3px solid var(--ink);box-shadow:var(--shadow);z-index:55}
  .nav-links a.link{font-size:20px;font-family:var(--display);font-weight:700;color:var(--ink);padding:10px 14px;width:100%}
  body.nav-open .nav-links{transform:none}
  .hamburger{display:block;z-index:60}
  .nav-cta{gap:8px}
  .nav-cta .phone{display:none}
  .nav-cta .btn{padding:9px 13px;font-size:12.5px}
  .nav-menu-btn{display:inline-flex}
  .ob-online{display:none}
  .foot-grid{grid-template-columns:1fr;gap:30px}
}
@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:900px;scroll-margin-top:210px}
.menu-section + .menu-section{margin-top:46px}
/* section head — forest card, content-left / count-right, gold hairline */
.menu-section-head{position:relative;background:var(--forest);border-radius:13px;padding:22px 26px;margin-bottom:10px;
  display:flex;align-items:flex-end;justify-content:space-between;box-shadow:none;border:none}
.menu-section-head h2{font-family:var(--display);font-size:36px;font-weight:500;color:var(--cream);margin:0;letter-spacing:-0.01em;line-height:1.05}
.menu-section-head .ms-intro{font-family:var(--display);font-style:italic;font-size:14.5px;color:#7fd6d1;margin:7px 0 0;line-height:1.4}
.menu-section-head .ms-count{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);white-space:nowrap;flex:0 0 auto}
.menu-section-head::after{content:"";position:absolute;left:26px;right:26px;bottom:16px;height:1px;background:rgba(217,154,43,.3)}
/* list — rows sit directly on cream, no paper card */
.menu-list{background:transparent;border:none;border-radius:0;padding:0;box-shadow:none}
.menu-item{padding:18px 6px;border-bottom:1px solid #ebdfc6}
.menu-item:last-child{border-bottom:none}
/* signature row: passport stamp on the left, the normal block on the right */
.menu-item--sig{padding:18px 6px;border-bottom:1px solid #ebdfc6}
.mi-sig{display:flex;gap:20px;align-items:center}
.mi-main{flex:1;min-width:0}
.mi-top{display:flex;align-items:baseline;gap:12px}
.mi-name{font-family:var(--display);font-size:23px;font-weight:600;color:var(--forest);display:inline-flex;align-items:center;gap:10px;line-height:1.2}
.mi-star{color:var(--gold);font-size:14px}
.mi-leader{flex:1;border-bottom:1.5px dotted #cdbf9f;transform:translateY(-4px);align-self:auto;margin-bottom:0;min-width:20px}
.mi-price{font-family:var(--display);font-weight:600;font-size:21px;color:var(--tiffany-deep);white-space:nowrap}
.mi-desc{font-size:14.5px;line-height:1.5;color:#7c8a86;margin-top:6px;max-width:66ch}
.menu-nav{position:sticky;top:148px;z-index:40;background:var(--cream);border-top:1px solid #efe4cd;border-bottom:1px solid #e7dcc5}
.menu-nav-inner{display:flex;justify-content:safe center;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:12.5px;font-weight:600;color:#56615f;padding:8px 15px;border-radius:20px;border:1px solid #ddd0b4;background:transparent;transition:.16s;white-space:nowrap}
.menu-nav a:hover{border-color:var(--forest);color:var(--forest)}
.menu-nav a.active{background:var(--tiffany);color:#0a3f3d;font-weight:700;border-color:transparent}
@media(max-width:980px){
  .menu-nav{top:90px}
}
@media(max-width:720px){
  .menu-item{padding:15px 6px}
  .mi-name{font-size:17.5px}
  .menu-nav{top:124px}
  .menu-section{scroll-margin-top:190px}
  .mi-sig{gap:14px}
  .stamp{width:72px;height:72px}
}
