/* =====================================================================
   Stackmatter v5 — dark (Semrush base) × HubSpot orange + teal
   Display: Bricolage Grotesque · UI: Inter · Prose: Newsreader · Data: JetBrains Mono
   ===================================================================== */
:root{
  --bg:#0F1217;
  --bg-2:#161B22;
  --bg-3:#1D232E;
  --bg-4:#232A37;
  --ink:#F2F5F9;
  --dim:#9AA6B5;
  --faint:#5E6B7C;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.15);
  --accent:#FF7A59;
  --accent-2:#FF9472;
  --data:#00BDA5;
  --data-2:#19D0B8;
  --blue:#18A0C4;
  --purple:#8B7BFF;
  --gold:#E8A11F;
  --shadow:0 20px 50px -26px rgba(0,0,0,.75);
  --shadow-lg:0 36px 80px -34px rgba(0,0,0,.85);
  --radius:8px;
  --wrap:1180px;
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --ui:"Inter",system-ui,sans-serif;
  --prose:"Newsreader",Georgia,serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--ui);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.04;margin:0;letter-spacing:-.025em}
img{max-width:100%;display:block}
.skip{position:absolute;left:-999px}
.skip:focus{left:24px;top:12px;background:var(--accent);color:#0F1217;padding:8px 14px;z-index:50;border-radius:var(--radius)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

.slash{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:9px}
.slash::before{content:"/";color:var(--accent);font-weight:700}
.slash--dim{color:var(--dim)}
.num{font-family:var(--mono);font-weight:500;color:var(--accent)}

.masthead{position:sticky;top:0;z-index:40;background:rgba(15,18,23,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.masthead__row{display:flex;align-items:center;justify-content:space-between;height:72px;position:relative}
.brand{display:flex;align-items:center;gap:10px}
.brand__mark{flex:none;display:block}
.brand__name{font-family:var(--display);font-weight:800;font-size:20px;letter-spacing:-.04em;color:var(--ink)}
.nav{display:flex;gap:30px;font-size:14px;font-weight:500;color:var(--dim);align-items:center}
.nav a{transition:color .15s}
.nav a:hover{color:var(--ink)}
.nav .nav__cta{font-family:var(--display);font-weight:600;color:#0F1217;background:var(--accent);padding:9px 18px;border-radius:99px;transition:.15s}
.nav .nav__cta:hover{background:var(--accent-2)}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:15px;padding:13px 24px;border-radius:99px;border:1px solid transparent;cursor:pointer;transition:transform .12s,background .15s,border-color .15s}
.btn--go{background:var(--accent);color:#0F1217}
.btn--go:hover{background:var(--accent-2);transform:translateY(-2px)}
.btn--ghost{border-color:var(--line-2);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--bg)}
.btn__arr{transition:transform .15s}
.btn:hover .btn__arr{transform:translateX(3px)}

.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::after{content:"";position:absolute;top:-26%;right:-10%;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,89,.12),transparent 66%);pointer-events:none}
.hero__inner{position:relative;padding:96px 0 88px;display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(42px,6vw,76px);font-weight:800;letter-spacing:-.045em;line-height:.98}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero__lead{margin:24px 0 32px;font-size:20px;line-height:1.5;color:var(--dim);max-width:40ch}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero__trust{font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--faint)}
.hero__trust b{color:var(--data);font-weight:500}

.hero__art{position:relative;display:flex;justify-content:center;align-items:center;min-height:400px}
.floatcard{position:absolute;bottom:18px;right:-4px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow-lg);padding:16px 18px;width:230px}
.floatcard__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.floatcard__name{font-family:var(--display);font-weight:700;font-size:15px}
.floatcard__score{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--data)}
.floatcard__bar{height:6px;border-radius:99px;background:var(--bg-4);overflow:hidden;margin-bottom:8px}
.floatcard__bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--data-2),var(--data))}
.floatcard__meta{font-family:var(--mono);font-size:10.5px;color:var(--faint);letter-spacing:.04em;margin-top:10px}

.reveal{opacity:0;transform:translateY(18px);animation:rise .7s cubic-bezier(.2,.8,.2,1) forwards}
.reveal.d1{animation-delay:.06s}.reveal.d2{animation-delay:.14s}.reveal.d3{animation-delay:.22s}.reveal.d4{animation-delay:.3s}
@keyframes rise{to{opacity:1;transform:none}}

.panel,.browser{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.panel{padding:22px}
.panel__top{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:13px;margin-bottom:16px}
.panel__label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.panel__live,.browser__live{font-family:var(--mono);font-size:11px;color:var(--data);display:flex;align-items:center;gap:7px;text-transform:uppercase;letter-spacing:.1em}
.panel__live::before,.browser__live::before{content:"";width:7px;height:7px;border-radius:99px;background:var(--data);box-shadow:0 0 0 0 rgba(0,189,165,.5);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 8px rgba(0,189,165,0)}100%{box-shadow:0 0 0 0 rgba(0,189,165,0)}}
.readout{display:flex;flex-direction:column;gap:13px}
.readout__row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:14px}
.readout__name{font-family:var(--ui);font-size:14.5px;color:var(--ink);font-weight:500}
.readout__name span{display:block;font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.08em;margin-top:3px;text-transform:uppercase}
.readout__bar{position:relative;width:120px;height:6px;background:var(--bg-4);border-radius:99px;overflow:hidden}
.readout__bar i{position:absolute;inset:0;width:var(--v);background:linear-gradient(90deg,var(--data-2),var(--data));border-radius:99px}
.readout__score{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--ink);min-width:36px;text-align:right}
.browser__bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line);background:var(--bg-3);border-radius:16px 16px 0 0}
.browser__dot{width:11px;height:11px;border-radius:50%;background:var(--line-2)}
.browser__url{margin-left:12px;font-family:var(--mono);font-size:11px;color:var(--faint);background:var(--bg);border:1px solid var(--line);padding:6px 14px;border-radius:7px;flex:1}
.browser__body{padding:22px}
.browser__row{display:flex;justify-content:space-between;align-items:center}

.toolstrip{display:flex;align-items:center;gap:13px;flex-wrap:wrap;justify-content:center;padding:30px 0}
.toolstrip__label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-right:6px}
.chip{font-family:var(--display);font-weight:600;font-size:15px;color:var(--dim);border:1px solid var(--line);border-radius:99px;padding:8px 18px;transition:.15s}
.chip:hover{color:var(--ink);border-color:var(--line-2)}

.section{padding:100px 0;position:relative}
.section--line{border-top:1px solid var(--line)}
.section--tint{background:var(--bg-2)}
.section__head{margin-bottom:48px;max-width:62ch}
.section__head h2{font-size:clamp(30px,4vw,46px);margin:16px 0 0;letter-spacing:-.035em}
.section__head p{color:var(--dim);margin:14px 0 0;font-size:18px;max-width:52ch}

.hubs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.hubcard{position:relative;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:30px 28px 26px;transition:transform .18s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column;min-height:228px}
.hubcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.hubcard__ic{margin-bottom:14px;color:var(--accent)}
.hubs .hubcard:nth-child(1) .hubcard__ic{color:var(--accent)}
.hubs .hubcard:nth-child(2) .hubcard__ic{color:var(--data)}
.hubs .hubcard:nth-child(3) .hubcard__ic{color:var(--blue)}
.hubcard h3{font-size:25px;margin:0 0 9px}
.hubcard p{color:var(--dim);font-size:15px;line-height:1.5;flex:1}
.hubcard__go{font-family:var(--display);font-weight:600;font-size:14px;color:var(--accent);margin-top:18px;display:inline-flex;gap:8px;align-items:center}
.hubcard:hover .hubcard__go .btn__arr{transform:translateX(4px)}

.method{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mcard{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:30px 28px;transition:box-shadow .2s,transform .18s,border-color .2s}
.mcard:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--line-2)}
.mcard__ic{color:var(--accent);margin-bottom:18px}
.method .mcard:nth-child(2) .mcard__ic{color:var(--data)}
.method .mcard:nth-child(3) .mcard__ic{color:var(--blue)}
.mcard h3{font-size:20px;margin:0 0 9px}
.mcard p{color:var(--dim);font-size:15px;line-height:1.5;margin:0}

.picks{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.pick{display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:24px 26px;transition:box-shadow .2s,border-color .2s}
.pick:hover{box-shadow:var(--shadow);border-color:var(--line-2)}
.pick__rank{font-family:var(--mono);font-weight:700;font-size:14px;color:var(--accent)}
.pick__name{font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.02em}
.pick__cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:4px}
.pick__meta{font-size:13.5px;color:var(--dim);margin-top:10px}
.pick__meta b{color:var(--ink);font-weight:600}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{display:flex;flex-direction:column;transition:transform .2s}
.card:hover{transform:translateY(-3px)}
.card__media{aspect-ratio:16/9;border-radius:14px;overflow:hidden;border:1px solid var(--line);margin-bottom:18px;background:var(--bg-2);box-shadow:var(--shadow)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.card:hover .card__media img{transform:scale(1.04)}
.card__kind{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.card h3{font-size:21px;margin:12px 0 10px;line-height:1.14}
.card__dek{color:var(--dim);font-size:15px;line-height:1.5;flex:1}
.card__foot{display:flex;gap:10px;align-items:center;font-family:var(--mono);font-size:11px;color:var(--faint);margin-top:16px;letter-spacing:.04em}

.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:0;background:var(--bg-2);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.feature__body{padding:46px 48px}
.feature h2{font-size:clamp(28px,3.6vw,42px);margin:16px 0 16px;letter-spacing:-.035em}
.feature p{color:var(--dim);font-size:17px;margin:0 0 26px}
.feature__cover{border-left:1px solid var(--line);overflow:hidden;background:var(--bg-3)}
.feature__cover img{width:100%;height:100%;object-fit:cover}

.article{max-width:740px;margin:0 auto;padding:60px 28px 50px}
.article__crumb{font-family:var(--mono);font-size:12px;letter-spacing:.05em;color:var(--faint);margin-bottom:22px}
.article__crumb a{color:var(--accent)}
.article h1{font-size:clamp(34px,4.6vw,52px);margin:16px 0 20px;letter-spacing:-.04em;line-height:1.02}
.article__dek{font-family:var(--prose);font-size:22px;line-height:1.5;color:var(--dim);margin:0 0 24px}
.article__by{display:flex;gap:14px;align-items:center;font-family:var(--mono);font-size:12px;color:var(--faint);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:15px 0;margin-bottom:30px}
.article__by b{color:var(--ink);font-weight:700}
.article__cover{aspect-ratio:16/9;border-radius:18px;overflow:hidden;border:1px solid var(--line);margin-bottom:34px;box-shadow:var(--shadow)}
.article__cover img{width:100%;height:100%;object-fit:cover}
.disclose{display:flex;gap:13px;background:var(--bg-2);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:0 var(--radius) var(--radius) 0;padding:14px 18px;font-size:13.5px;color:var(--dim);margin:0 0 32px}
.disclose b{color:var(--ink)}
.prose{font-family:var(--prose);font-size:19.5px;line-height:1.72;color:#C7D0DC}
.prose p{margin:0 0 24px}
.prose h2{font-family:var(--display);font-size:30px;margin:46px 0 16px;letter-spacing:-.03em;color:var(--ink)}
.prose h3{font-family:var(--display);font-size:22px;margin:34px 0 12px;color:var(--ink)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.prose .btn{text-decoration:none}.prose .btn--go{color:#0F1217}.prose .btn--ghost{color:var(--ink)}
.prose ul{margin:0 0 24px;padding-left:24px}
.prose li{margin:0 0 10px}
.prose strong{font-weight:600;color:var(--ink)}
.prose code{font-family:var(--mono);font-size:.85em;background:var(--bg-3);padding:2px 6px;border-radius:4px;color:var(--accent-2)}

.scorecard{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:28px 30px;margin:38px 0}
.scorecard__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}
.scorecard__head h3{font-family:var(--display);color:var(--ink);font-size:19px}
.scorecard__verdict{font-family:var(--mono);font-size:13px;color:var(--dim)}
.scorecard__verdict b{color:var(--data);font-size:24px}

.vbox{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;margin:32px 0;font-family:var(--ui);font-size:15.5px;background:var(--bg-2)}
.vbox__col{padding:22px 24px}
.vbox__col+.vbox__col{border-left:1px solid var(--line)}
.vbox h4{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin:0 0 14px}
.vbox--pro h4{color:var(--data)}
.vbox--con h4{color:var(--accent)}
.vbox ul{margin:0;padding:0;list-style:none}
.vbox li{padding-left:24px;position:relative;margin-bottom:10px;line-height:1.45;color:#BAC4D1}
.vbox--pro li::before{content:"+";position:absolute;left:0;color:var(--data);font-weight:700;font-family:var(--mono)}
.vbox--con li::before{content:"\2013";position:absolute;left:0;color:var(--accent);font-weight:700;font-family:var(--mono)}

.ptable{width:100%;border-collapse:collapse;margin:26px 0;font-size:15px}
.ptable th,.ptable td{text-align:left;padding:14px 14px;border-bottom:1px solid var(--line)}
.ptable th{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);font-weight:500}
.ptable td{color:#BAC4D1}.ptable td strong{color:var(--ink)}
.ptable td:last-child,.ptable th:last-child{text-align:right;font-family:var(--mono)}
.ptable tr:hover td{background:var(--bg-2)}

.cta{background:linear-gradient(135deg,var(--bg-3),var(--bg-2));border:1px solid var(--line);border-radius:18px;padding:36px 38px;margin:42px 0;display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap;box-shadow:var(--shadow)}
.cta__txt h3{font-family:var(--display);color:var(--ink);font-size:23px;margin-bottom:7px;letter-spacing:-.02em}
.cta__txt p{color:var(--dim);font-size:14.5px;margin:0}

.related{border-top:1px solid var(--line);margin-top:50px;padding-top:34px}
.related h4{margin-bottom:20px}

.hubhead{border-bottom:1px solid var(--line);padding:76px 0 62px;position:relative;overflow:hidden;background:var(--bg-2)}
.hubhead h1{font-size:clamp(38px,5.4vw,64px);margin:16px 0 14px;letter-spacing:-.04em}
.hubhead p{color:var(--dim);font-size:19px;max-width:50ch}

.page{max-width:740px;margin:0 auto;padding:76px 28px}
.page h1{font-size:clamp(34px,4.4vw,52px);margin:16px 0 0;letter-spacing:-.04em}
.page .prose{margin-top:28px}

.foot{border-top:1px solid var(--line);padding:64px 0 32px;background:var(--bg-2)}
.foot__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px;padding-bottom:38px}
.foot__brand .brand__name{font-size:22px}
.foot__tag{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--accent);margin:12px 0 18px}
.foot__disc{font-size:13px;line-height:1.55;color:var(--faint);max-width:46ch;margin:0}
.foot__col h4{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:500;margin-bottom:16px}
.foot__col a{display:block;font-size:14.5px;color:var(--dim);padding:6px 0;transition:color .15s}
.foot__col a:hover{color:var(--accent)}
.foot__base{display:flex;justify-content:space-between;align-items:center;gap:16px;border-top:1px solid var(--line);padding-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--faint);flex-wrap:wrap}

.band{border-top:1px solid var(--line);padding:92px 0;text-align:center;position:relative;overflow:hidden;background:var(--bg-2)}
.band::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:680px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,89,.10),transparent 62%);pointer-events:none}
.band h2{position:relative;font-size:clamp(32px,5vw,56px);letter-spacing:-.04em;max-width:18ch;margin:0 auto 28px}
.band .btn{position:relative}

/* ---- Scout mascot: inline + animated (premium float) ---- */
.scout{display:block;width:min(360px,86%);height:auto;overflow:visible;filter:drop-shadow(0 30px 50px rgba(0,0,0,.5))}
.scout--hero{margin:0 auto}
.scout__float{transform-box:fill-box;transform-origin:center;animation:scout-bob 5s ease-in-out infinite}
.scout__torso{transform-box:fill-box;transform-origin:center;animation:scout-bob 5s ease-in-out infinite;animation-delay:.25s}
.scout__hand-l{transform-box:fill-box;transform-origin:center;animation:scout-bob 5s ease-in-out infinite;animation-delay:.4s}
.scout__hand-r{transform-box:fill-box;transform-origin:center;animation:scout-bob 5s ease-in-out infinite;animation-delay:.5s}
.scout__eyes{transform-box:fill-box;transform-origin:center;animation:scout-blink 5.4s infinite}
.scout__glow{transform-box:fill-box;transform-origin:center;animation:scout-glow 3s ease-in-out infinite}
.scout__sensor{transform-box:fill-box;transform-origin:center;animation:scout-glow 2.6s ease-in-out infinite}
@keyframes scout-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes scout-blink{0%,93%,100%{transform:scaleY(1)}96%{transform:scaleY(.1)}}
@keyframes scout-glow{0%,100%{opacity:.55}50%{opacity:1}}
@media(prefers-reduced-motion:reduce){.scout__float,.scout__torso,.scout__hand-l,.scout__hand-r,.scout__eyes,.scout__glow,.scout__sensor{animation:none!important}}

@media(max-width:900px){
  .hero__inner{grid-template-columns:1fr;gap:40px;padding:64px 0 56px}
  .hero__art{min-height:auto;order:-1}
  .floatcard{right:0}
  .hubs,.method{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr 1fr}
  .picks{grid-template-columns:1fr}
  .feature{grid-template-columns:1fr}
  .feature__cover{border-left:none;border-top:1px solid var(--line);aspect-ratio:16/9}
  .nav{display:none}
  .foot__grid{grid-template-columns:1fr 1fr}.foot__brand{grid-column:1/-1}
}
@media(max-width:560px){
  body{font-size:16px}
  .grid{grid-template-columns:1fr}
  .vbox{grid-template-columns:1fr}.vbox__col+.vbox__col{border-left:none;border-top:1px solid var(--line)}
  .cta{flex-direction:column;align-items:flex-start}
  .readout__bar{width:84px}
  .floatcard{position:static;width:100%;margin-top:18px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

/* ---- mobile nav (hamburger) ---- */
.navtoggle{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;margin:-8px;z-index:30}
.hamburger span{display:block;width:24px;height:2px;background:var(--ink,#F2F5F9);border-radius:2px;transition:transform .2s,opacity .2s}
@media (max-width:900px){
  .hamburger{display:flex}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
       background:var(--panel,#161B22);border-bottom:1px solid var(--line,#222A33);padding:6px 28px 20px;box-shadow:0 18px 40px rgba(0,0,0,.45)}
  .navtoggle:checked ~ .nav{display:flex}
  .nav a{padding:15px 2px;border-bottom:1px solid var(--line,#222A33);font-size:16px}
  .nav .nav__cta{margin-top:16px;text-align:center;border-bottom:none}
  .navtoggle:checked ~ .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .navtoggle:checked ~ .hamburger span:nth-child(2){opacity:0}
  .navtoggle:checked ~ .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---- review hero: lead photo + scorecard ---- */
.reviewhero{margin:26px 0 12px}
.reviewhero__kicker{font-family:var(--mono);color:var(--accent);letter-spacing:.32em;font-size:12px;font-weight:700}
.reviewhero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:22px;margin-top:14px;align-items:stretch}
.reviewhero__grid--solo{grid-template-columns:1fr}
.reviewhero__photo{position:relative;margin:0;border-radius:16px;overflow:hidden;border:1px solid var(--line);min-height:300px;background:var(--bg-2)}
.reviewhero__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.reviewhero__photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 12px 9px;font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:rgba(255,255,255,.74);background:linear-gradient(transparent,rgba(0,0,0,.62))}
.reviewhero__photo figcaption a{color:inherit;text-decoration:none}
.reviewhero__score{display:flex}
.reviewhero__score .scorecard{width:100%;margin:0}
@media(max-width:760px){
  .reviewhero__grid{grid-template-columns:1fr;gap:16px}
  .reviewhero__photo{min-height:200px}
}
