/* =========================================================
   PRIME BURGER REVIEWS — styles
   Black · white · electric red. Bold editorial / award energy.
   ========================================================= */

:root{
  --bg:        #0a0a0b;
  --bg-2:      #0f0f11;
  --ink:       #ffffff;
  --muted:     #b9b4b4;
  --muted-2:   #9a9696;
  --red:       #ED1C24;
  --red-2:     #E30613;
  --red-deep:  #b30d14;
  --gold:      #FFB400;
  --green:     #34E0A1;
  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.18);
  --card:      #141416;
  --card-2:    #1a1a1d;
  --radius:    16px;
  --radius-sm: 10px;
  --maxw:      1180px;
  --shadow:    0 24px 60px -24px rgba(0,0,0,.8);
  --font-disp: "Archivo", system-ui, sans-serif;
  --font-body: "Inria Sans", system-ui, sans-serif;
  --font-script: "Pinyon Script", cursive;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:84px; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
strong{ font-weight:700; color:var(--ink); }

::selection{ background:var(--red); color:#fff; }

.skip-link{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--red); color:#fff; padding:.7em 1.2em; border-radius:0 0 8px 0; font-weight:700;
}
.skip-link:focus{ left:0; }

:focus-visible{ outline:2px solid var(--red); outline-offset:3px; border-radius:4px; }

/* ---------- Shared section scaffolding ---------- */
.section{ max-width:var(--maxw); margin:0 auto; padding:clamp(60px,8vw,104px) clamp(20px,5vw,40px); }
.section__head{ max-width:760px; margin-bottom:clamp(36px,5vw,60px); }

.kicker{
  display:inline-block; font-family:var(--font-disp); font-weight:800;
  font-size:.74rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--red); margin-bottom:18px; position:relative; padding-left:42px;
}
.kicker::before{ content:""; position:absolute; left:0; top:50%; width:30px; height:2px; background:var(--red); transform:translateY(-50%); }

.h2{
  font-family:var(--font-disp); font-weight:800;
  font-size:clamp(2rem,5.2vw,3.4rem); line-height:1.02;
  letter-spacing:-.02em; text-transform:uppercase;
}
.lede{ margin-top:20px; color:var(--muted); font-size:clamp(1.02rem,1.6vw,1.18rem); max-width:62ch; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-disp); font-weight:700; font-size:.96rem; letter-spacing:.02em;
  padding:.95em 1.7em; border-radius:50px; border:2px solid transparent; cursor:pointer;
  transition:transform .18s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn--red{ background:var(--red); color:#fff; box-shadow:0 10px 30px -10px var(--red); }
.btn--red:hover{ background:#ff2d35; transform:translateY(-2px); box-shadow:0 16px 40px -12px var(--red); }
.btn--grab{ background:#00b14f; color:#fff; box-shadow:0 10px 30px -10px rgba(0,177,79,.6); }
.btn--grab:hover{ background:#00c956; transform:translateY(-2px); box-shadow:0 16px 40px -12px rgba(0,177,79,.5); }
.btn--ghost{ border-color:var(--line-2); color:var(--ink); background:transparent; }
.btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.06); transform:translateY(-2px); }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; gap:24px;
  padding:16px clamp(20px,5vw,40px);
  background:rgba(10,10,11,.55); backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent; transition:background .3s ease, border-color .3s ease, padding .3s ease;
}
.nav.is-scrolled{ background:rgba(8,8,9,.9); border-bottom-color:var(--line); padding-top:12px; padding-bottom:12px; }

.brand{ display:flex; align-items:center; gap:11px; flex-shrink:0; }
.brand__mark{ color:var(--red); display:grid; place-items:center; transition:transform .4s cubic-bezier(.34,1.56,.64,1); }
.brand:hover .brand__mark{ transform:rotate(-8deg) scale(1.08); }
.brand__word{
  font-family:var(--font-disp); font-weight:900; font-size:1.18rem; letter-spacing:-.01em;
  line-height:1; color:#fff; position:relative; display:inline-flex; align-items:baseline;
}
.brand__red{ color:var(--red); }
.brand__sub{
  font-family:var(--font-script); font-style:normal; font-weight:400;
  font-size:1.05rem; color:var(--muted); margin-left:8px; transform:translateY(2px);
}
.brand__word--lg{ font-size:1.9rem; }
.brand__word--lg .brand__sub{ font-size:1.6rem; }

.nav__links{ display:flex; gap:26px; margin-left:auto; }
.nav__links a{
  font-size:.95rem; color:var(--muted); font-weight:400; position:relative; padding:4px 0;
  transition:color .2s ease;
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--red); transition:width .25s ease; }
.nav__links a:hover{ color:#fff; }
.nav__links a:hover::after{ width:100%; }
.nav__links a.is-current{ color:#fff; }
.nav__links a.is-current::after{ width:100%; }

.nav__cta{
  flex-shrink:0; font-family:var(--font-disp); font-weight:700; font-size:.9rem;
  background:var(--red); color:#fff; padding:.62em 1.25em; border-radius:50px;
  transition:transform .18s ease, background .2s ease;
}
.nav__cta:hover{ background:#ff2d35; transform:translateY(-2px); }
.nav__ctas{ display:flex; align-items:center; gap:10px; flex-shrink:0; }
.nav__cta--ghost{ background:transparent; border:1px solid var(--line-2); color:var(--ink); }
.nav__cta--ghost:hover{ background:rgba(255,255,255,.06); border-color:#fff; }
.nav__cta--grab{ background:#00b14f; }
.nav__cta--grab:hover{ background:#00c956; }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__burger span{ width:24px; height:2px; background:#fff; border-radius:2px; transition:transform .3s ease, opacity .3s ease; }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{
  position:fixed; top:0; right:0; z-index:99; width:min(80vw,320px); height:100dvh;
  background:var(--bg-2); border-left:1px solid var(--line);
  display:flex; flex-direction:column; gap:6px; padding:96px 28px 28px;
  transform:translateX(100%); transition:transform .35s cubic-bezier(.4,0,.2,1); visibility:hidden;
}
.mobile-menu.is-open{ transform:translateX(0); visibility:visible; }
.mobile-menu a{ font-family:var(--font-disp); font-weight:600; font-size:1.3rem; padding:12px 0; border-bottom:1px solid var(--line); color:var(--muted); }
.mobile-menu a:hover{ color:#fff; }
.mobile-menu__cta{ margin-top:18px; background:var(--red); color:#fff !important; text-align:center; border-radius:50px; border:0 !important; padding:14px !important; }
.mobile-menu__cta--grab{ margin-top:10px; background:#00b14f; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:120px clamp(20px,5vw,40px) 40px; overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% -10%, #1c1c20 0%, var(--bg) 55%);
}
.hero__glow{
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(50% 40% at 80% 20%, rgba(237,28,36,.20), transparent 70%),
    radial-gradient(40% 40% at 12% 85%, rgba(237,28,36,.14), transparent 70%);
}
.hero__grain{
  position:absolute; 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='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
}
.hero__inner{ position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; width:100%; }

.hero__eyebrow{ color:var(--muted); font-size:clamp(.9rem,1.5vw,1.05rem); letter-spacing:.01em; margin-bottom:24px; }
.hero__eyebrow strong{ color:var(--red); }

.hero__title{
  font-family:var(--font-disp); font-weight:900; text-transform:uppercase;
  font-size:clamp(2.9rem,9vw,6.6rem); line-height:.92; letter-spacing:-.025em;
}
.hero__title .line{ display:block; }
.hero__title .hl{ color:var(--red); position:relative; white-space:nowrap; }
.hero__title .hl::after{
  content:""; position:absolute; left:0; right:0; bottom:.06em; height:.12em;
  background:var(--red); opacity:.28; border-radius:4px; transform:scaleX(0); transform-origin:left;
  animation:underline 1s .9s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes underline{ to{ transform:scaleX(1); } }

.hero__script{
  font-family:var(--font-script); font-size:clamp(1.5rem,3.4vw,2.3rem);
  color:#fff; margin:22px 0 0; opacity:.92;
}

.hero__verdict{
  margin-top:clamp(30px,4vw,46px); display:grid; gap:24px; max-width:680px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--line); border-radius:var(--radius); padding:clamp(22px,3vw,30px);
  backdrop-filter:blur(6px);
}
.hero__score{ display:flex; align-items:center; gap:22px; }
.hero__num{
  font-family:var(--font-disp); font-weight:900; font-size:clamp(3.4rem,9vw,5rem);
  line-height:.85; color:#fff; letter-spacing:-.03em;
}
.hero__scoremeta{ display:flex; flex-direction:column; gap:8px; }
.hero__count{ color:var(--muted); font-size:.98rem; }
.hero__line{ color:var(--muted); font-size:clamp(1rem,1.6vw,1.12rem); }
.hero__line strong{ color:#fff; }
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; }

.hero__sources{
  position:relative; z-index:2; max-width:var(--maxw); margin:clamp(34px,5vw,48px) auto 0; width:100%;
  display:flex; align-items:center; gap:22px; flex-wrap:wrap;
  padding-top:26px; border-top:1px solid var(--line);
}
.hero__sourcelbl{ font-family:var(--font-disp); font-weight:700; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); }
.src{ display:inline-flex; align-items:center; gap:8px; color:var(--muted); font-size:.95rem; }
.src b{ color:#fff; font-weight:700; }

/* Stars */
.stars{ --pct:100%; display:inline-block; width:max-content; max-width:100%; align-self:flex-start; position:relative; font-size:1rem; line-height:1; white-space:nowrap; font-family:Arial, sans-serif; }
.stars::before{ content:"★★★★★"; color:rgba(255,255,255,.18); letter-spacing:2px; }
.stars::after{ content:"★★★★★"; color:var(--gold); letter-spacing:2px; position:absolute; left:0; top:0; width:var(--pct); overflow:hidden; }
.stars--lg{ font-size:1.5rem; }

/* =========================================================
   STATS BAR
   ========================================================= */
.stats{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#101012,#0c0c0d);
  display:grid; grid-template-columns:repeat(5,1fr);
}
.stats__item{
  padding:clamp(28px,4vw,46px) 20px; text-align:center;
  border-right:1px solid var(--line); display:flex; flex-direction:column; gap:8px;
}
.stats__item:last-child{ border-right:0; }
.stats__num{ font-family:var(--font-disp); font-weight:900; font-size:clamp(2rem,4.4vw,3rem); line-height:1; letter-spacing:-.02em; }
.stats__num i{ color:var(--red); font-style:normal; }
.stats__lbl{ color:var(--muted-2); font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; font-family:var(--font-disp); font-weight:600; }

/* =========================================================
   VERDICT
   ========================================================= */
.verdict__grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.vcard{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(26px,3.5vw,38px); position:relative; overflow:hidden;
}
.vcard::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:4px; }
.vcard--pro::before{ background:var(--green); }
.vcard--con::before{ background:var(--gold); }
.vcard__title{ font-family:var(--font-disp); font-weight:800; font-size:1.3rem; margin-bottom:22px; display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.vcard__tag{ font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; background:var(--green); color:#062; padding:.35em .7em; border-radius:50px; font-weight:800; }
.vcard__tag--amber{ background:var(--gold); color:#3a2700; }
.ticks{ list-style:none; display:grid; gap:15px; }
.ticks li{ position:relative; padding-left:32px; color:var(--muted); font-size:1.02rem; }
.ticks li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--green); font-weight:900; font-size:1.05rem; }
.ticks--amber li::before{ content:"!"; color:var(--gold); }

.bigquote{
  margin-top:42px; position:relative; max-width:900px;
  font-family:var(--font-disp); font-weight:700; font-size:clamp(1.5rem,3.6vw,2.4rem);
  line-height:1.2; letter-spacing:-.01em; padding:30px 0 0 clamp(48px,7vw,80px);
}
.bigquote__mark{ position:absolute; left:-6px; top:-26px; font-family:var(--font-disp); font-weight:900; font-size:clamp(6rem,14vw,9rem); color:var(--red); line-height:1; opacity:.9; }
.bigquote cite{ display:block; margin-top:20px; font-family:var(--font-body); font-style:normal; font-weight:400; font-size:.95rem; color:var(--muted-2); letter-spacing:0; }

/* =========================================================
   RATINGS
   ========================================================= */
.ratings__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,64px); align-items:stretch; }
.ratings__bars{ display:grid; align-content:space-between; gap:26px; }
.bar{ display:grid; grid-template-columns:1fr auto; gap:6px 14px; align-items:center; }
.bar__lbl{ font-family:var(--font-disp); font-weight:600; font-size:1.05rem; }
.bar__val{ font-family:var(--font-disp); font-weight:900; font-size:1.25rem; color:var(--gold); grid-row:1; grid-column:2; }
.bar__val--low{ color:var(--muted); }
.bar__track{ grid-column:1 / -1; height:12px; background:rgba(255,255,255,.08); border-radius:50px; overflow:hidden; }
.bar__fill{ display:block; height:100%; width:0; border-radius:50px; background:linear-gradient(90deg,var(--red-deep),var(--red)); transition:width 1.1s cubic-bezier(.2,.8,.2,1); }
.bar.is-in .bar__fill{ width:var(--val); }

.ratings__subh{ font-family:var(--font-disp); font-weight:800; text-transform:uppercase; letter-spacing:.04em; font-size:.95rem; color:var(--muted); margin-bottom:18px; }
.dist{ display:grid; grid-template-columns:32px 1fr 42px; gap:12px; align-items:center; margin-bottom:12px; }
.dist__star{ font-family:var(--font-disp); font-weight:700; font-size:.9rem; color:var(--muted); }
.dist__track{ height:9px; background:rgba(255,255,255,.08); border-radius:50px; overflow:hidden; }
.dist__fill{ display:block; height:100%; width:0; background:var(--gold); border-radius:50px; transition:width 1s cubic-bezier(.2,.8,.2,1); }
.dist.is-in .dist__fill{ width:var(--w); }
.dist__pct{ font-size:.85rem; color:var(--muted); text-align:right; font-variant-numeric:tabular-nums; }

.methodology{ display:flex; gap:12px; align-items:flex-start; margin-top:40px; padding:18px 22px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); color:var(--muted-2); font-size:.9rem; line-height:1.6; max-width:840px; }
.methodology svg{ color:var(--red); flex-shrink:0; margin-top:2px; }
.methodology strong{ color:var(--muted); }

.ratings__platforms{ margin-top:30px; padding-top:26px; border-top:1px solid var(--line); display:grid; gap:16px; }
.plat{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
a.plat{ padding:10px 14px; margin:0 -14px; border-radius:var(--radius-sm); transition:background .2s ease, transform .2s ease; }
a.plat:hover{ background:var(--card); transform:translateX(4px); }
a.plat:hover .plat__name{ color:var(--red); }
.plat__name{ font-family:var(--font-disp); font-weight:700; min-width:124px; transition:color .2s ease; }
.plat__n{ color:var(--muted-2); font-size:.9rem; font-variant-numeric:tabular-nums; }

/* =========================================================
   REVIEWS
   ========================================================= */
.filters{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:34px; }
.chip{
  font-family:var(--font-disp); font-weight:600; font-size:.9rem;
  background:transparent; color:var(--muted); border:1px solid var(--line-2);
  padding:.55em 1.15em; border-radius:50px; cursor:pointer; transition:all .2s ease;
}
.chip:hover{ color:#fff; border-color:#fff; }
.chip.is-active{ background:var(--red); border-color:var(--red); color:#fff; }

.review-grid{ columns:3 280px; column-gap:24px; }
.rcard{
  break-inside:avoid; margin-bottom:24px; background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius); padding:24px; transition:transform .3s ease, border-color .3s ease, opacity .3s ease;
  position:relative;
}
.rcard:hover{ transform:translateY(-4px); border-color:var(--line-2); }
.rcard.is-hidden{ display:none; }
.rcard__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.rcard__src{ font-family:var(--font-disp); font-weight:700; font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); border:1px solid var(--line); padding:.3em .6em; border-radius:50px; }
.rcard__body{ color:var(--ink); font-size:1.02rem; line-height:1.55; }
.rcard__foot{ display:flex; align-items:center; gap:12px; margin-top:18px; padding-top:16px; border-top:1px solid var(--line); }
.rcard__av{ width:38px; height:38px; flex-shrink:0; border-radius:50%; background:linear-gradient(135deg,var(--red),var(--red-deep)); display:grid; place-items:center; font-family:var(--font-disp); font-weight:800; color:#fff; }
.rcard__foot span{ display:flex; flex-direction:column; line-height:1.3; }
.rcard__foot small{ color:var(--muted-2); font-size:.82rem; }
.reviews__note{ margin-top:28px; color:var(--muted-2); font-size:.82rem; max-width:70ch; }

/* =========================================================
   PERSONAS
   ========================================================= */
.persona-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.pcard{
  background:linear-gradient(180deg,var(--card-2),var(--card)); border:1px solid var(--line);
  border-radius:var(--radius); padding:30px; transition:transform .3s ease, border-color .3s ease;
}
.pcard:hover{ transform:translateY(-5px); border-color:var(--red); }
.pcard__icon{ font-size:2rem; display:block; margin-bottom:16px; }
.pcard h3{ font-family:var(--font-disp); font-weight:800; font-size:1.2rem; margin-bottom:10px; }
.pcard p{ color:var(--muted); font-size:.98rem; }

/* =========================================================
   DISHES
   ========================================================= */
.dish-list{ list-style:none; display:grid; border-top:1px solid var(--line); }
.dish{ display:flex; gap:clamp(16px,2vw,26px); align-items:flex-start; padding:clamp(18px,2.4vw,24px) 0; border-bottom:1px solid var(--line); transition:padding-left .3s ease; }
@media (min-width:760px){
  .dish-list{ grid-template-columns:1fr 1fr; grid-template-rows:repeat(5,auto); grid-auto-flow:column; column-gap:clamp(32px,5vw,72px); }
  .dish-list .dish:nth-child(5),
  .dish-list .dish:nth-child(10){ border-bottom:0; }
}
.dish:hover{ padding-left:12px; }
.dish__rank{ font-family:var(--font-disp); font-weight:900; font-size:clamp(1.6rem,4vw,2.6rem); color:transparent; -webkit-text-stroke:1.5px var(--muted-2); line-height:1; flex-shrink:0; transition:-webkit-text-stroke-color .3s ease, color .3s ease; }
.dish:hover .dish__rank{ color:var(--red); -webkit-text-stroke-color:var(--red); }
.dish__body h3{ font-family:var(--font-disp); font-weight:800; font-size:clamp(1.2rem,2.5vw,1.6rem); margin-bottom:8px; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.dish__body p{ color:var(--muted); font-size:1rem; }
.badge{ font-family:var(--font-body); font-weight:700; font-size:.66rem; letter-spacing:.06em; text-transform:uppercase; padding:.35em .7em; border-radius:50px; background:rgba(255,255,255,.08); color:var(--muted); border:1px solid var(--line); }
.badge--gold{ background:rgba(255,180,0,.14); color:var(--gold); border-color:rgba(255,180,0,.3); }
.badge--green{ background:rgba(52,224,161,.12); color:var(--green); border-color:rgba(52,224,161,.3); }
.badge--red{ background:rgba(237,28,36,.14); color:#ff5a60; border-color:rgba(237,28,36,.35); }

.dishes__meta{ margin-top:38px; display:grid; gap:22px; }
.dishes__sizes{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.dishes__lbl{ font-family:var(--font-disp); font-weight:800; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; color:var(--muted-2); }
.sizepill{ border:1px solid var(--line-2); padding:.5em 1em; border-radius:50px; font-size:.9rem; color:var(--muted); }
.sizepill--rec{ border-color:var(--red); color:#fff; background:rgba(237,28,36,.1); }
.dishes__foot{ color:var(--muted); max-width:75ch; }

/* =========================================================
   AWARDS TIMELINE
   ========================================================= */
.timeline{ display:flex; gap:20px; flex-wrap:wrap; }
.tnode{ flex:1 1 220px; display:flex; flex-direction:column; gap:14px; }
.tnode__year{ font-family:var(--font-disp); font-weight:900; font-size:clamp(2rem,5vw,3.2rem); color:var(--red); line-height:1; letter-spacing:-.02em; position:relative; padding-bottom:16px; border-bottom:2px solid var(--red); }
.tnode__card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); padding:20px; display:flex; flex-direction:column; gap:6px; }
.tnode__card strong{ font-family:var(--font-disp); font-size:1.05rem; }
.tnode__card span{ color:var(--muted); font-size:.92rem; }

/* =========================================================
   BRANCHES
   ========================================================= */
.branch-search{
  display:flex; align-items:center; gap:12px; max-width:560px; margin-bottom:34px;
  background:var(--card); border:1px solid var(--line-2); border-radius:50px; padding:6px 6px 6px 20px;
  color:var(--muted-2); transition:border-color .2s ease;
}
.branch-search:focus-within{ border-color:var(--red); }
.branch-search input{ flex:1; background:none; border:0; color:#fff; font-family:var(--font-body); font-size:1rem; padding:12px 0; outline:none; }
.branch-search input::placeholder{ color:var(--muted-2); }
.branch-search__count{ font-size:.82rem; color:var(--muted-2); padding-right:14px; white-space:nowrap; }

.branch-cols{ columns:3 240px; column-gap:24px; }
.bcity{ break-inside:avoid; margin-bottom:24px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:24px; transition:border-color .3s ease, transform .3s ease; }
.bcity.is-dim{ display:none; }
.bcity__name{ font-family:var(--font-disp); font-weight:800; font-size:1.25rem; display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.bcity__name span{ font-size:.85rem; color:#fff; background:var(--red); width:28px; height:28px; border-radius:50%; display:grid; place-items:center; }
.bcity ul{ list-style:none; display:grid; gap:11px; }
.bcity li{ color:var(--muted); position:relative; padding-left:24px; font-size:.98rem; }
.bcity li::before{ content:""; position:absolute; left:2px; top:.45em; width:8px; height:8px; border-radius:50% 50% 50% 0; transform:rotate(45deg); background:var(--red); }
.bcity li small{ display:block; padding-left:0; color:var(--muted-2); font-size:.76rem; text-transform:uppercase; letter-spacing:.06em; margin-top:2px; }
.bcity__link{ color:var(--muted); background-image:linear-gradient(var(--red),var(--red)); background-size:0% 1px; background-position:0 100%; background-repeat:no-repeat; transition:color .2s ease, background-size .25s ease; }
.bcity__link:hover{ color:#fff; background-size:100% 1px; }
.bcity__link::after{ content:"→"; font-size:.8em; margin-left:5px; color:var(--muted-2); opacity:0; transition:opacity .2s ease, transform .2s ease; display:inline-block; }
.bcity__link:hover::after{ transform:translateX(3px); }
.bcity__link:hover::after{ opacity:1; color:var(--red); }
.branches__empty{ color:var(--muted); }
.linkbtn{ background:none; border:0; color:var(--red); font:inherit; cursor:pointer; text-decoration:underline; padding:0; }

/* =========================================================
   FAQ
   ========================================================= */
.faq__grid{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:clamp(30px,5vw,64px); align-items:start; }
.faq .section__head{ margin-bottom:0; position:sticky; top:104px; }
.faq-list{ width:100%; }
@media (max-width:860px){
  .faq__grid{ grid-template-columns:1fr; }
  .faq .section__head{ position:static; margin-bottom:clamp(28px,5vw,40px); }
}
.qa{ border-bottom:1px solid var(--line); }
.qa summary{
  list-style:none; cursor:pointer; padding:24px 0; display:flex; align-items:center; justify-content:space-between; gap:20px;
  font-family:var(--font-disp); font-weight:700; font-size:clamp(1.1rem,2vw,1.35rem); transition:color .2s ease;
}
.qa summary::-webkit-details-marker{ display:none; }
.qa summary:hover{ color:var(--red); }
.qa__plus{ position:relative; width:20px; height:20px; flex-shrink:0; }
.qa__plus::before,.qa__plus::after{ content:""; position:absolute; background:var(--red); border-radius:2px; transition:transform .3s ease; }
.qa__plus::before{ left:0; top:9px; width:20px; height:2px; }
.qa__plus::after{ left:9px; top:0; width:2px; height:20px; }
.qa[open] .qa__plus::after{ transform:scaleY(0); }
.qa__a{ overflow:hidden; }
.qa__a p{ color:var(--muted); padding:0 0 26px; max-width:72ch; font-size:1.05rem; }
.qa[open] .qa__a{ animation:fadeDown .35s ease; }
@keyframes fadeDown{ from{ opacity:0; transform:translateY(-8px);} to{ opacity:1; transform:translateY(0);} }

/* =========================================================
   CTA
   ========================================================= */
.cta{ position:relative; overflow:hidden; background:linear-gradient(135deg,var(--red-deep),var(--red)); margin:0; }
.cta::before{ content:""; position:absolute; inset:0; opacity:.4; 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='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E"); }
.cta__inner{ position:relative; max-width:var(--maxw); margin:0 auto; padding:clamp(70px,9vw,120px) clamp(20px,5vw,40px); text-align:center; }
.cta__script{ font-family:var(--font-script); font-size:clamp(1.6rem,4vw,2.6rem); color:rgba(255,255,255,.85); }
.cta__title{ font-family:var(--font-disp); font-weight:900; text-transform:uppercase; font-size:clamp(2rem,6vw,4rem); line-height:1; letter-spacing:-.02em; margin:8px 0 18px; }
.cta__sub{ color:rgba(255,255,255,.9); max-width:54ch; margin:0 auto 32px; font-size:clamp(1rem,1.7vw,1.18rem); }
.cta__btns{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta .btn--red{ background:#000; color:#fff; box-shadow:0 14px 40px -14px rgba(0,0,0,.7); }
.cta .btn--red:hover{ background:#1a1a1a; }
.cta .btn--ghost{ border-color:rgba(255,255,255,.6); color:#fff; }
.cta .btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.12); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:#060607; border-top:1px solid var(--line); }
.footer__inner{ max-width:var(--maxw); margin:0 auto; padding:clamp(50px,7vw,80px) clamp(20px,5vw,40px) 40px; display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.footer__tag{ color:var(--muted-2); margin-top:14px; max-width:36ch; font-size:.95rem; }
.footer__nav{ display:grid; grid-template-columns:1fr 1fr; gap:12px 48px; align-content:start; }
.footer__nav a{ color:var(--muted); font-size:.95rem; transition:color .2s ease; }
.footer__nav a:hover{ color:var(--red); }
.footer__legal{ max-width:var(--maxw); margin:0 auto; padding:28px clamp(20px,5vw,40px) 50px; border-top:1px solid var(--line); }
.footer__legal p{ color:var(--muted-2); font-size:.82rem; line-height:1.7; max-width:90ch; }
.footer__legal a{ color:var(--muted); text-decoration:underline; }
.footer__copy{ margin-top:16px; }

/* =========================================================
   BACK TO TOP
   ========================================================= */
.totop{
  position:fixed; right:24px; bottom:24px; z-index:90; width:48px; height:48px; border-radius:50%;
  background:var(--red); color:#fff; border:0; font-size:1.3rem; cursor:pointer; box-shadow:var(--shadow);
  opacity:0; visibility:hidden; pointer-events:none; transform:translateY(16px) scale(.8);
  transition:opacity .3s ease, transform .3s ease, visibility .3s ease;
}
.totop.is-show{ opacity:1; visibility:visible; pointer-events:auto; transform:translateY(0) scale(1); }
.totop:hover{ background:#ff2d35; transform:translateY(-3px); }

/* =========================================================
   STICKY MOBILE ACTION BAR
   ========================================================= */
.mobilebar{
  position:fixed; left:0; right:0; bottom:0; z-index:95; display:none; gap:10px;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:rgba(8,8,9,.92); backdrop-filter:blur(14px) saturate(140%);
  border-top:1px solid var(--line);
}
.mobilebar__btn{
  flex:1; text-align:center; font-family:var(--font-disp); font-weight:700; font-size:.95rem;
  padding:13px 10px; border-radius:50px; transition:transform .15s ease, background .2s ease;
}
.mobilebar__btn--ghost{ border:1px solid var(--line-2); color:#fff; }
.mobilebar__btn--red{ background:var(--red); color:#fff; }
.mobilebar__btn--grab{ background:#00b14f; color:#fff; }
.mobilebar__btn:active{ transform:scale(.97); }

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.is-in{ opacity:1; transform:none; }
.hero .reveal:nth-child(1){ transition-delay:.05s; }
.hero .reveal:nth-child(2){ transition-delay:.15s; }
.hero .reveal:nth-child(3){ transition-delay:.3s; }
.hero .reveal:nth-child(4){ transition-delay:.45s; }
.hero__sources.reveal{ transition-delay:.6s; }

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .bar__fill,.dist__fill{ transition:none; }
  .hero__title .hl::after{ animation:none; transform:scaleX(1); }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .stats{ grid-template-columns:repeat(3,1fr); }
  .stats__item:nth-child(3){ border-right:0; }
  .stats__item:nth-child(4),.stats__item:nth-child(5){ border-top:1px solid var(--line); }
}
@media (max-width:1000px){
  .nav__links{ display:none; }
  .nav__cta, .nav__ctas{ display:none; }
  .nav__burger{ display:flex; margin-left:auto; }
}
@media (max-width:860px){
  .verdict__grid{ grid-template-columns:1fr; }
  .ratings__grid{ grid-template-columns:1fr; }
  .persona-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .stats__item:nth-child(3){ border-right:1px solid var(--line); }
  .stats__item:nth-child(odd){ border-right:1px solid var(--line); }
  .stats__item:nth-child(even){ border-right:0; }
  .stats__item:nth-child(n+3){ border-top:1px solid var(--line); }
  .stats__item:last-child{ grid-column:1 / -1; }
  .hero__score{ flex-direction:row; align-items:center; }
  .review-grid{ columns:1; }
  .persona-grid{ grid-template-columns:1fr; }
  .dish{ gap:14px; }
  .footer__inner{ flex-direction:column; gap:28px; }
  .mobilebar{ display:flex; }
  body{ padding-bottom:74px; }
  .totop{ bottom:84px; right:16px; }
}
@media (max-width:420px){
  .hero__cta{ flex-direction:column; }
  .hero__cta .btn{ width:100%; }
}

/* =========================================================
   BRANCH REVIEW PAGES
   ========================================================= */
.breadcrumb{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; font-size:.85rem; color:var(--muted-2); font-family:var(--font-disp); font-weight:600; }
.breadcrumb a{ color:var(--muted); transition:color .2s ease; }
.breadcrumb a:hover{ color:var(--red); }
.breadcrumb span[aria-current]{ color:#fff; }
.breadcrumb .sep{ color:var(--muted-2); }

.bhero{ position:relative; overflow:hidden; padding:clamp(110px,14vw,150px) clamp(20px,5vw,40px) clamp(48px,7vw,76px); background:radial-gradient(120% 100% at 80% -10%, #1c1c20 0%, var(--bg) 60%); border-bottom:1px solid var(--line); }
.bhero__glow{ position:absolute; inset:0; pointer-events:none; background:radial-gradient(45% 45% at 88% 10%, rgba(237,28,36,.18), transparent 70%); }
.bhero__inner{ position:relative; max-width:var(--maxw); margin:0 auto; }
.bhero__eyebrow{ display:inline-flex; align-items:center; gap:8px; margin:20px 0 16px; font-family:var(--font-disp); font-weight:800; font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--red); }
.bhero__title{ font-family:var(--font-disp); font-weight:900; text-transform:uppercase; font-size:clamp(2.2rem,6.4vw,4.4rem); line-height:.98; letter-spacing:-.02em; max-width:16ch; }
.bhero__rating{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:26px; }
.bhero__score{ font-family:var(--font-disp); font-weight:900; font-size:clamp(2.4rem,5vw,3.2rem); line-height:1; }
.bhero__rmeta{ display:flex; flex-direction:column; gap:5px; }
.bhero__count{ color:var(--muted); font-size:.95rem; }
.bhero__lede{ margin-top:24px; max-width:64ch; color:var(--muted); font-size:clamp(1.02rem,1.6vw,1.16rem); }
.bhero__cta{ display:flex; gap:13px; flex-wrap:wrap; margin-top:30px; }

.quickfacts{ display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.qfact{ background:var(--card); padding:22px 24px; display:flex; flex-direction:column; gap:8px; }
.qfact__lbl{ display:flex; align-items:center; gap:8px; font-family:var(--font-disp); font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); }
.qfact__lbl svg{ color:var(--red); }
.qfact__val{ font-size:1.02rem; color:#fff; line-height:1.45; }
.qfact__val a{ color:var(--red); text-decoration:underline; text-underline-offset:3px; }

.branch-platforms{ display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; }
.bplat{ display:flex; align-items:center; gap:10px; background:var(--card); border:1px solid var(--line); border-radius:50px; padding:9px 18px; }
.bplat__name{ font-family:var(--font-disp); font-weight:700; }
.bplat__n{ color:var(--muted); font-size:.9rem; font-variant-numeric:tabular-nums; }

.nearby{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.nearby__card{ display:flex; align-items:center; justify-content:space-between; gap:14px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); padding:20px 22px; transition:border-color .25s ease, transform .25s ease; }
.nearby__card:hover{ border-color:var(--red); transform:translateY(-3px); }
.nearby__card strong{ font-family:var(--font-disp); font-weight:800; font-size:1.08rem; }
.nearby__card span{ display:block; color:var(--muted-2); font-size:.82rem; margin-top:3px; }
.nearby__arrow{ color:var(--red); font-size:1.2rem; flex-shrink:0; }

.allbranches-link{ display:inline-flex; align-items:center; gap:8px; margin-top:28px; font-family:var(--font-disp); font-weight:700; color:var(--red); }
.allbranches-link:hover{ text-decoration:underline; text-underline-offset:4px; }

.prose p{ color:var(--muted); font-size:1.05rem; line-height:1.7; margin-bottom:18px; max-width:72ch; }
.prose p strong{ color:#fff; }
.prose p:last-child{ margin-bottom:0; }
.bhero__note{ display:inline-flex; align-items:flex-start; gap:4px; margin-top:24px; padding:12px 18px; background:var(--card); border:1px solid var(--line); border-left:3px solid var(--red); border-radius:var(--radius-sm); color:var(--muted); font-size:.95rem; max-width:60ch; }

/* =========================================================
   COMPARISON PAGES  (/compare/)
   ========================================================= */
.bhero--vs .bhero__title{ max-width:22ch; }
.vs-badge{ display:inline-flex; align-items:center; gap:12px; margin-top:22px; flex-wrap:wrap; }
.vs-badge span{ font-family:var(--font-disp); font-weight:800; font-size:.86rem; text-transform:uppercase; letter-spacing:.04em; background:var(--card); border:1px solid var(--line-2); border-radius:50px; padding:9px 18px; }
.vs-badge span:first-child{ color:#fff; border-color:var(--red); box-shadow:0 0 0 1px var(--red) inset; }
.vs-badge em{ color:var(--red); font-style:normal; font-family:var(--font-disp); font-weight:900; font-size:1rem; }

.cmp{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--card); box-shadow:var(--shadow); }
.cmp__row{ display:grid; grid-template-columns:1.05fr 1fr 1fr; align-items:stretch; border-top:1px solid var(--line); }
.cmp__row:first-child{ border-top:0; }
.cmp__row--head{ background:var(--bg-2); }
.cmp__attr{ padding:15px 20px; font-family:var(--font-disp); font-weight:700; font-size:.92rem; color:#fff; display:flex; align-items:center; }
.cmp__row--head .cmp__attr{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); }
.cmp__cell{ position:relative; padding:15px 20px; color:var(--muted); font-size:.95rem; line-height:1.5; border-left:1px solid var(--line); display:flex; align-items:center; gap:8px; }
.cmp__cell--pb{ background:rgba(237,28,36,.06); color:#ededed; }
.cmp__cell.is-win{ color:#fff; }
.cmp__brand{ font-family:var(--font-disp); font-weight:800; font-size:1rem; color:#fff; }
.cmp__cell--pb .cmp__brand{ color:var(--red); }
.cmp__win{ color:var(--green); font-weight:900; flex-shrink:0; }
@media (max-width:640px){
  .cmp__row{ grid-template-columns:1fr 1fr; }
  .cmp__row--head{ display:none; }
  .cmp__attr{ grid-column:1 / -1; background:var(--bg-2); padding:11px 16px; font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--red); border-bottom:1px solid var(--line); }
  .cmp__cell{ flex-direction:column; align-items:flex-start; gap:5px; padding:13px 16px; font-size:.9rem; }
  .cmp__cell::before{ content:attr(data-lbl); font-family:var(--font-disp); font-weight:800; font-size:.64rem; letter-spacing:.07em; text-transform:uppercase; color:var(--muted-2); }
  .cmp__cell--pb::before{ color:var(--red); }
  .cmp__win{ position:absolute; top:12px; right:14px; }
}

/* category verdict cards */
.vwin-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.vwin{ background:var(--card); border:1px solid var(--line); border-top:3px solid var(--red); border-radius:var(--radius); padding:24px 24px 26px; }
.vwin__cat{ font-family:var(--font-disp); font-weight:700; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); }
.vwin__name{ display:block; font-family:var(--font-disp); font-weight:900; font-size:1.45rem; line-height:1.05; margin:8px 0 10px; }
.vwin__why{ color:var(--muted); font-size:.95rem; line-height:1.55; }
@media (max-width:760px){ .vwin-grid{ grid-template-columns:1fr; } }

/* compare hub cards */
.cmp-cardgrid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:18px; }
.cmp-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px 26px; display:flex; flex-direction:column; gap:8px; transition:border-color .25s ease, transform .25s ease; }
.cmp-card:hover{ border-color:var(--red); transform:translateY(-4px); }
.cmp-card__vs{ font-family:var(--font-disp); font-weight:700; font-size:.78rem; letter-spacing:.05em; text-transform:uppercase; color:var(--muted-2); }
.cmp-card__vs em{ color:var(--red); font-style:normal; }
.cmp-card__h{ font-family:var(--font-disp); font-weight:900; font-size:1.7rem; text-transform:uppercase; line-height:1; }
.cmp-card__go{ margin-top:6px; color:var(--red); font-family:var(--font-disp); font-weight:700; font-size:.9rem; }

/* =========================================================
   CITY / COUNTRY GUIDES  (/guides/)
   ========================================================= */
.gpick-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; }
.gpick{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:24px; display:flex; flex-direction:column; gap:10px; transition:border-color .25s ease, transform .25s ease; }
.gpick:hover{ border-color:var(--red); transform:translateY(-3px); }
.gpick__top{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.gpick__top strong{ font-family:var(--font-disp); font-weight:800; font-size:1.1rem; }
.gpick__city{ color:var(--muted-2); font-size:.78rem; font-family:var(--font-disp); font-weight:700; text-transform:uppercase; letter-spacing:.06em; flex-shrink:0; }
.gpick__rating{ display:flex; align-items:center; gap:8px; font-size:.9rem; color:var(--muted); font-variant-numeric:tabular-nums; }
.gpick__rating--new{ color:var(--gold); font-weight:700; }
.gpick__why{ color:var(--muted); font-size:.95rem; line-height:1.55; }
.gpick__go{ color:var(--red); font-family:var(--font-disp); font-weight:700; font-size:.86rem; margin-top:auto; }

.gcity-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:16px; }
.gcity{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:24px; }
.gcity__name{ font-family:var(--font-disp); font-weight:900; font-size:1.25rem; text-transform:uppercase; }
.gcity__blurb{ color:var(--muted); margin:8px 0 12px; font-size:.95rem; line-height:1.55; }
.gcity__links{ font-size:.92rem; color:var(--muted-2); line-height:1.7; }
.gcity__links a{ color:var(--red); }
.gcity__links a:hover{ text-decoration:underline; text-underline-offset:3px; }
.gcity__guide{ display:inline-block; margin-top:6px; font-family:var(--font-disp); font-weight:700; }

/* homepage compare strip */
.cmpstrip{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-top:8px; }
.cmpstrip__item{ display:flex; flex-direction:column; gap:3px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); padding:16px 18px; transition:border-color .2s ease, transform .2s ease; }
.cmpstrip__item:hover{ border-color:var(--red); transform:translateY(-3px); }
.cmpstrip__vs{ font-family:var(--font-disp); font-weight:900; font-size:1.05rem; text-transform:uppercase; }
.cmpstrip__vs em{ color:var(--red); font-style:normal; font-size:.8rem; }
.cmpstrip__go{ color:var(--muted-2); font-size:.8rem; }
