:root{
  --c-yellow:#dcab3c;
  --c-green:#7e9b4e;
  --c-blue:#5b7bbf;
  --c-purple:#9a5ba6;
  --paper:#f6f2e9;
  --paper-2:#efe9db;
  --ink:#1a1813;
  --ink-soft:#4a463d;
  --ink-faint:#8c8678;
  --gold:#b08a3e;
  --line:#d8d0bf;
  --rule:#1a1813;
  --serif-display:'Playfair Display',Georgia,serif;
  --serif-body:'Newsreader',Georgia,serif;
  --sans:'Archivo',system-ui,sans-serif;
  --shell:1240px;
  --read:940px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--serif-body);color:var(--ink);background:var(--paper);font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased}
.shell{max-width:var(--shell);margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.read{max-width:var(--read);margin-left:auto;margin-right:auto}
.row{max-width:var(--read);margin-left:auto;margin-right:auto}
a{color:inherit}

/* HEADER */
.site-header{border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:50}
.site-header .shell{display:flex;align-items:center;justify-content:space-between;height:64px;gap:24px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand-name{font-family:var(--serif-display);font-weight:800;font-size:23px;letter-spacing:.01em}
.brand-logo{height:36px;width:auto;display:block;flex-shrink:0}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;color:var(--ink-soft);padding:4px 0;border-bottom:2px solid transparent;transition:border-color .15s,color .15s}
.nav a:hover{color:var(--ink);border-color:var(--gold)}
.nav a.active{color:var(--ink);border-color:var(--ink)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px;width:40px;align-items:center;justify-content:center}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);transition:transform .25s,opacity .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* HERO */
header.hero{padding:clamp(48px,7vw,82px) 0 clamp(40px,5vw,56px);border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:clamp(30px,5vw,64px);align-items:center}
.kicker{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:22px;display:flex;align-items:center;gap:14px}
.kicker::before{content:"";height:1px;width:36px;background:var(--gold)}
h1{font-family:var(--serif-display);font-weight:800;font-size:clamp(42px,7vw,82px);line-height:.96;letter-spacing:-.02em;margin-bottom:26px}
header.hero h1{font-size:clamp(34px,4vw,52px);line-height:1.06}
h1 em{font-style:italic;font-weight:700}
.dek{font-family:var(--serif-body);font-size:clamp(18px,2.2vw,22px);font-style:italic;color:var(--ink-soft);max-width:34ch;line-height:1.45;border-left:2px solid var(--gold);padding-left:20px}
.hero-cta{display:flex;flex-direction:column;gap:13px}
.hero-cta-card{border:2px solid var(--rule);padding:clamp(22px,3vw,32px);display:flex;flex-direction:column;gap:14px}
.hero-cta-date{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.hero-cta-no{font-family:var(--serif-display);font-weight:800;font-size:36px;line-height:1;letter-spacing:-.02em;padding-bottom:16px;border-bottom:1px solid var(--line)}
.btn-solid{background:var(--ink);color:var(--paper);border:2px solid var(--ink)}
.btn-solid:hover{background:var(--gold);border-color:var(--gold);color:var(--paper)}
.hero-archive-link{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;text-align:center;padding-top:2px;transition:color .15s}
.hero-archive-link:hover{color:var(--ink)}
.btn{font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.04em;text-decoration:none;padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;transition:transform .15s,background .15s,color .15s;cursor:pointer;border:2px solid var(--ink)}
.btn .arr{font-size:16px;transition:transform .15s}
.btn:hover .arr{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn small{display:block;font-weight:400;font-size:11px;letter-spacing:.04em;opacity:.7;text-transform:none;margin-top:2px}
.btn .btn-l{text-align:left;text-transform:uppercase}

/* SECTIONS */
section{padding:clamp(40px,5vw,60px) 0;border-bottom:1px solid var(--line)}
.sec-head{margin-bottom:32px}
.sec-num{font-family:var(--serif-display);font-style:italic;font-weight:600;font-size:17px;color:var(--gold);display:block;margin-bottom:5px}
h2{font-family:var(--serif-display);font-weight:700;font-size:clamp(28px,4vw,40px);line-height:1.04;letter-spacing:-.01em}
.sec-sub{font-family:var(--sans);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-top:11px}

/* TIME-ZONE NOTE (home only, when tomorrow is already live) */
.tz-note{max-width:var(--read);margin:26px auto 0;background:var(--paper-2);border-left:3px solid var(--gold);padding:16px 20px}
.tz-note p{font-family:var(--serif-body);font-size:16px;line-height:1.5;color:var(--ink-soft)}
.tz-note strong{color:var(--ink);font-weight:700;font-style:normal}
.tz-note a{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.03em;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--gold);white-space:nowrap}
.tz-note a:hover{color:var(--gold)}

/* HINTS */
.hint-block{display:grid;grid-template-columns:96px 1fr;gap:0;border-top:1px solid var(--line);padding:28px 0}
.hint-block:first-of-type{border-top:2px solid var(--rule)}
.hint-rail .lvl{font-family:var(--serif-display);font-style:italic;font-weight:700;font-size:32px;line-height:1}
.hint-rail .lvl-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-top:8px;display:block;max-width:74px}
.hint-rail .heat{display:flex;gap:3px;margin-top:13px}
.hint-rail .heat span{width:15px;height:5px;border-radius:1px;background:var(--paper-2)}
.l1 .heat span:nth-child(-n+1){background:var(--c-yellow)}
.l2 .heat span:nth-child(-n+2){background:var(--c-blue)}
.l3 .heat span:nth-child(-n+3){background:var(--c-purple)}
.hint-body{max-width:var(--read)}
.hint-body p.lede{font-size:15px;color:var(--ink-faint);font-style:italic;margin-bottom:14px}
.hint-list{list-style:none;display:grid;gap:11px}
.hint-list li{font-size:18px;padding-left:23px;position:relative;line-height:1.45}
.hint-list li::before{content:"\2014";position:absolute;left:0;color:var(--gold);font-weight:600}
.hint-list b{font-weight:600;font-style:italic}
.word-chip{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.06em;background:var(--ink);color:var(--paper);padding:2px 8px;border-radius:2px}

/* INTRO PARA */
.intro-para{font-family:var(--serif-body);font-size:clamp(16px,1.8vw,18px);color:var(--ink-soft);line-height:1.6;max-width:62ch;margin-top:clamp(24px,3vw,36px)}
/* TRAPS */
.trap-intro{font-style:italic;font-size:19px;color:var(--ink-soft);margin-bottom:28px;max-width:46ch}
.traps-list{max-width:var(--read);display:grid;grid-template-columns:max-content 1fr}
.trap{display:grid;grid-column:1/-1;grid-template-columns:subgrid;gap:24px;align-items:baseline;padding:20px 0;border-top:1px solid var(--line)}
.trap:first-of-type{border-top:2px solid var(--rule)}
.trap-word{font-family:var(--serif-display);font-weight:800;font-size:32px;letter-spacing:-.01em;line-height:1}
.trap-word::first-letter{color:var(--gold)}
.trap-why{font-size:17px;color:var(--ink-soft);line-height:1.5}
.trap-why b{color:var(--ink);font-weight:600;font-style:italic}

/* ANSWERS */
.ans-toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px;flex-wrap:wrap}
.ans-note{font-style:italic;font-size:16px;color:var(--ink-soft)}
.reveal-all{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;background:var(--ink);color:var(--paper);border:none;padding:12px 20px;cursor:pointer;transition:transform .15s}
.reveal-all:hover{transform:translateY(-2px)}
.reveal-all.showing{background:transparent;color:var(--ink);border:2px solid var(--ink);padding:10px 18px}
.ans-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.ans-group{border-radius:8px;padding:20px 22px;min-height:118px;display:flex;flex-direction:column;justify-content:center;cursor:pointer;position:relative;overflow:hidden;transition:transform .15s;color:#1a1813}
.ans-group:hover{transform:translateY(-2px)}
.ans-group.yellow{background:var(--c-yellow)}
.ans-group.green{background:var(--c-green)}
.ans-group.blue{background:var(--c-blue);color:#11203f}
.ans-group.purple{background:var(--c-purple);color:#fff}
.ans-group .gtag{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:9px;opacity:.9}
.ans-group .gwords{font-family:var(--serif-display);font-weight:700;font-size:19px;letter-spacing:.01em;line-height:1.25}
.ans-group .gtag,.ans-group .gwords{filter:blur(8px);transition:filter .3s;user-select:none}
.ans-group.revealed .gtag,.ans-group.revealed .gwords{filter:none;user-select:auto}
.ans-group .tap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:inherit;opacity:.85;transition:opacity .25s;pointer-events:none}
.ans-group.revealed .tap{opacity:0}

/* BREAKDOWN */
.breakdown{display:grid;gap:24px;max-width:var(--read)}
.bd-item{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:baseline}
.bd-rule{width:36px;height:3px;margin-top:11px}
.bd-rule.yellow{background:var(--c-yellow)}
.bd-rule.green{background:var(--c-green)}
.bd-rule.blue{background:var(--c-blue)}
.bd-rule.purple{background:var(--c-purple)}
.bd-name{font-family:var(--serif-display);font-weight:700;font-size:19px;margin-bottom:3px}
.bd-text{font-size:17px;color:var(--ink-soft);line-height:1.5}

/* ANALYSIS */
.analysis{display:grid;grid-template-columns:1.3fr 1fr 1fr;border:2px solid var(--rule)}
.an-cell{padding:26px;border-right:1px solid var(--line)}
.an-cell:last-child{border-right:none}
.an-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:13px}
.an-val{font-family:var(--serif-display);font-weight:800;font-size:40px;line-height:1}
.an-val small{font-size:18px;color:var(--ink-faint);font-weight:600}
.an-sub{font-style:italic;font-size:15px;color:var(--ink-soft);margin-top:7px}
.diffbar{height:6px;background:var(--paper-2);margin-top:17px;overflow:hidden}
.diffbar i{display:block;height:100%;background:linear-gradient(90deg,var(--c-green),var(--c-yellow),var(--c-purple))}

/* RECENT */
.recent{max-width:var(--read)}
.recent a{display:flex;align-items:baseline;justify-content:space-between;gap:16px;text-decoration:none;padding:18px 0;border-top:1px solid var(--line);transition:padding-left .18s}
.recent a:first-child{border-top:2px solid var(--rule)}
.recent a:hover{padding-left:8px}
.recent .r-left{display:flex;align-items:baseline;gap:14px}
.recent .r-date{font-family:var(--serif-display);font-weight:700;font-size:22px}
.recent .r-meta{font-family:var(--sans);font-size:12px;letter-spacing:.06em;color:var(--ink-faint);text-transform:uppercase}
.dotline{flex:1;border-bottom:1px dotted var(--line);align-self:flex-end;margin-bottom:6px}
.r-go{font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);font-weight:700}
.recent a.current .r-go{color:var(--ink-faint)}

/* FAQ */
.faq{max-width:var(--read)}
.faq details{border-top:1px solid var(--line)}
.faq details:first-child{border-top:2px solid var(--rule)}
.faq summary{list-style:none;cursor:pointer;padding:18px 0;display:flex;justify-content:space-between;align-items:baseline;gap:16px;font-family:var(--serif-display);font-weight:600;font-size:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{font-family:var(--sans);font-size:22px;color:var(--gold);transition:transform .2s;font-weight:500}
.faq details[open] summary .plus{transform:rotate(45deg)}
.faq .a{padding:0 0 20px;font-size:17px;color:var(--ink-soft);line-height:1.55}

/* FOOTER */
footer{background:var(--ink);color:var(--paper);padding:clamp(44px,6vw,68px) 0 40px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid #38342b}
.foot-brand .brand-name{color:var(--paper)}
.foot-brand p{font-style:italic;font-size:15px;color:#cfc7b5;margin-top:14px;max-width:34ch;line-height:1.5}
.foot-col-label{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8c8678;margin-bottom:14px}
.foot-col a{display:block;text-decoration:none;color:#cfc7b5;font-size:15px;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:var(--paper)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:24px}
.copyright{font-family:var(--sans);font-size:12px;color:#8c8678;letter-spacing:.02em}
.disclaim{font-family:var(--sans);font-size:11px;color:#6f6a5f;max-width:48ch;line-height:1.5}

/* WORD CLOUD */
.words-row{padding:26px 0;border-bottom:1px solid var(--line)}
.words-meta{font-family:var(--sans);font-size:14px;font-weight:700;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:5px}
.words-sub{font-family:var(--sans);font-size:12px;color:var(--ink-faint);margin-bottom:14px}
.words-cloud{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.wbtn{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;background:var(--paper-2);color:var(--ink);border:1px solid var(--line);padding:8px 6px;min-height:52px;border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s;width:100%;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.3;word-break:break-word;overflow-wrap:break-word}
.wbtn[data-note]:not([data-note=""]):hover{background:var(--line);border-color:var(--ink-faint)}
@media(max-width:480px){.wbtn{font-size:11px;letter-spacing:.02em}}

/* WORD MODAL */
.wmodal{display:none;position:fixed;inset:0;background:rgba(26,24,19,.55);z-index:200;align-items:center;justify-content:center}
.wmodal.open{display:flex}
.wmodal-box{background:var(--paper);max-width:340px;width:90%;position:relative;overflow:hidden;border-radius:4px;box-shadow:0 8px 32px rgba(0,0,0,.18)}
.wm-body{padding:26px 28px 30px}
.wm-word{font-family:var(--serif-display);font-weight:800;font-size:30px;line-height:1;margin-bottom:16px;letter-spacing:-.01em}
.wm-note{font-size:17px;color:var(--ink-soft);line-height:1.6;font-style:italic}
.wm-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--ink-soft);line-height:1;padding:4px 6px}
.wm-close:hover{color:var(--ink)}

/* RESPONSIVE */
@media(max-width:820px){
  .hero-grid{grid-template-columns:1fr;gap:32px;align-items:start}
  .hero-cta-card{width:100%}
  .hero-cta-no{font-size:28px}
  .analysis{grid-template-columns:1fr}
  .an-cell{border-right:none;border-bottom:1px solid var(--line)}
  .an-cell:last-child{border-bottom:none}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:560px){
  body{font-size:17px}
  .nav-toggle{display:flex}
  .nav{position:absolute;top:64px;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:2px solid var(--rule);padding:0 clamp(20px,4vw,56px);max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
  .nav.open{max-height:340px;padding-top:8px;padding-bottom:16px}
  .nav a{border-bottom:1px solid var(--line);padding:15px 0;font-size:14px;letter-spacing:.06em;border-top:none}
  .nav a:last-child{border-bottom:none}
  .ans-grid{grid-template-columns:1fr}
  .hint-block{grid-template-columns:60px 1fr}
  .trap{grid-template-columns:1fr;gap:6px}
  .foot-grid{grid-template-columns:1fr}
  h1{font-size:clamp(40px,12vw,56px)}
}

/* HUB — TODAY L1 HINTS (homepage) */
#today .hub-prose p{margin-bottom:10px}
.hub-l1-wrap{margin-top:36px}
.hub-l1-label{font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);line-height:1.6;margin-bottom:14px}
.hub-l1-cta{margin-top:22px}
.hub-l1-cta a{font-family:var(--sans);font-size:14px;font-weight:700;letter-spacing:.04em;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--gold);padding-bottom:2px;transition:color .15s}
.hub-l1-cta a:hover{color:var(--gold)}

/* HUB — FEATURE LIST (How Our Hint System Works) */
.hub-feature-list{display:grid;gap:28px;margin-top:12px}
.hub-feature-item h3{font-family:var(--serif-display);font-weight:700;font-size:20px;margin-bottom:10px}
.hub-feature-item p{font-size:17px;color:var(--ink-soft);line-height:1.65}
/* HUB — TERM LIST (difficulty factors, trap patterns) */
.hub-term-list{display:grid;gap:20px;margin-top:12px}
.hub-term-item h3{font-family:var(--serif-display);font-weight:700;font-size:18px;margin-bottom:6px}
.hub-term-item p{font-size:17px;color:var(--ink-soft);line-height:1.55}
/* HUB — CATEGORY LIST (Yellow/Green/Blue/Purple) */
.hub-cat-list{display:grid;gap:24px;margin-top:12px}
.hub-cat-item{padding-left:18px}
.hub-cat-item.yellow{border-left:3px solid var(--c-yellow)}
.hub-cat-item.green{border-left:3px solid var(--c-green)}
.hub-cat-item.blue{border-left:3px solid var(--c-blue)}
.hub-cat-item.purple{border-left:3px solid var(--c-purple)}
.hub-cat-item h3{font-family:var(--serif-display);font-weight:700;font-size:19px;margin-bottom:8px}
.hub-cat-item p{font-size:17px;color:var(--ink-soft);line-height:1.6;margin-bottom:8px}
.hub-cat-item p:last-child{margin-bottom:0}
/* HUB — HOME PAGE */
.hub-today-card{border:2px solid var(--rule);padding:clamp(20px,3vw,32px)}
.hub-today-meta{display:flex;gap:clamp(20px,4vw,40px);flex-wrap:wrap;margin-bottom:22px}
.hub-today-stat{display:flex;flex-direction:column;gap:5px}
.hub-today-label{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}
.hub-today-val{font-family:var(--serif-display);font-weight:800;font-size:30px;line-height:1}
.hub-today-word{font-size:22px;color:var(--c-purple)}
.hub-today-cta{text-decoration:none;border:2px solid var(--ink);padding:16px 22px;display:flex;align-items:center;justify-content:space-between;gap:14px;font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);transition:background .15s,color .15s}
.hub-today-cta:hover{background:var(--ink);color:var(--paper)}
.hub-today-cta .btn-l{text-align:left}
.hub-today-cta small{display:block;font-weight:400;font-size:11px;letter-spacing:.04em;opacity:.7;text-transform:none;margin-top:2px}
.hub-today-cta .arr{font-size:16px;transition:transform .15s}
.hub-today-cta:hover .arr{transform:translateX(4px)}
.hub-system-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,3vw,40px);margin-top:8px}
.hub-system-item{border-top:2px solid var(--rule);padding-top:22px}
.hub-system-item h3{font-family:var(--serif-display);font-weight:700;font-size:20px;line-height:1.2;margin-bottom:10px}
.hub-system-item p{font-size:17px;color:var(--ink-soft);line-height:1.65}
.hub-strategy-intro{font-size:18px;color:var(--ink-soft);line-height:1.65;margin-bottom:26px}
.hub-strategy-list{list-style:none}
.hub-strategy-item a{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;text-decoration:none;padding:18px 0;border-top:1px solid var(--line);transition:padding-left .18s}
.hub-strategy-item:first-child a{border-top:2px solid var(--rule)}
.hub-strategy-item a:hover{padding-left:8px}
.s-title{font-family:var(--serif-display);font-weight:700;font-size:20px;margin-bottom:5px;color:var(--ink)}
.s-desc{font-size:15px;color:var(--ink-soft);line-height:1.4}
.s-arr{font-family:var(--sans);font-size:18px;color:var(--gold);flex-shrink:0}
.hub-archive-link-wrap{margin-top:22px;text-align:right}
.hub-archive-link{font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}
.hub-archive-link:hover{border-color:var(--gold)}
.hub-prose p{font-size:18px;color:var(--ink-soft);line-height:1.72;margin-bottom:20px}
.hub-prose p:last-child{margin-bottom:0}
.sec-intro{font-size:18px;color:var(--ink-soft);line-height:1.65;margin-bottom:30px}
@media(min-width:700px){
  .hub-feature-list{grid-template-columns:repeat(2,1fr)}
  .hub-feature-list .hub-feature-item:last-child{grid-column:1/-1}
  .hub-term-list{grid-template-columns:repeat(2,1fr)}
  .hub-term-list .hub-term-item:last-child{grid-column:1/-1}
  .hub-cat-list{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:620px){.hub-system-grid{grid-template-columns:1fr}}

/* ARTICLE (strategy guides) */
.breadcrumb{font-family:var(--sans);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin:18px 0 0}
.breadcrumb + header.hero{padding-top:clamp(20px,3vw,32px)}
.breadcrumb a{color:var(--ink-faint);text-decoration:none}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb span{margin:0 8px}
.art-meta{font-family:var(--sans);font-size:13px;color:var(--ink-faint);margin-top:20px;display:flex;align-items:center;gap:10px}
.art-meta-sep{color:var(--line)}
.read h3{font-family:var(--serif-display);font-weight:700;font-size:22px;line-height:1.2;margin:40px 0 14px}
.read p{font-size:18px;color:var(--ink-soft);line-height:1.7;margin-bottom:18px}
.read strong{color:var(--ink)}
.read ul{list-style:none;display:grid;gap:10px;margin:0 0 22px}
.read ul li{font-size:17px;color:var(--ink-soft);padding-left:24px;position:relative;line-height:1.55}
.read ul li::before{content:"\2014";position:absolute;left:0;color:var(--gold);font-weight:600}
.callout{border-left:3px solid var(--gold);padding:18px 22px;background:var(--paper-2);margin:32px 0}
.callout p{margin:0;font-size:17px;font-style:italic;color:var(--ink-soft)}
/* Word Guide */
.word-guide{display:grid;grid-template-columns:120px 1fr;gap:6px 16px;margin-top:24px;font-size:14px;line-height:1.55}
.word-guide dt{font-family:var(--sans);font-weight:700;letter-spacing:.06em;color:var(--ink);padding-top:2px}
.word-guide dd{color:var(--ink-soft);margin:0}
/* Puzzle Design */
.puzzle-design-text{font-family:var(--serif-body);font-size:17px;color:var(--ink-soft);line-height:1.65}
.analysis+.puzzle-design-text{margin-top:28px}

/* ── STRANDS-SPECIFIC (classes not in connections templates) ── */

/* Nav — strands uses .logo / .nav-links / .nav-hamburger */
.logo{font-family:var(--serif-display);font-weight:800;font-size:23px;letter-spacing:.01em;text-decoration:none;color:var(--ink)}
.logo span{font-style:italic;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;color:var(--ink-soft);padding:4px 0;border-bottom:2px solid transparent;transition:border-color .15s,color .15s}
.nav-links a:hover{color:var(--ink);border-color:var(--gold)}
.nav-links a.active{color:var(--ink);border-color:var(--ink)}
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px;width:40px;align-items:center;justify-content:center}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--ink);transition:transform .25s,opacity .2s}

/* Footer — strands uses .footer-inner / .footer-brand / .footer-links-col / .footer-links / .footer-copy */
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid #38342b}
.footer-brand{font-family:var(--serif-display);font-weight:800;font-size:20px;color:var(--paper);margin-bottom:8px}
.footer-brand span{font-style:italic}
.footer-desc{font-style:italic;font-size:15px;color:#cfc7b5;margin-top:4px;max-width:30ch;line-height:1.5}
.footer-links-col{display:flex;gap:48px;align-items:flex-start}
.footer-links{display:flex;flex-direction:column;gap:10px;list-style:none}
.footer-links a{font-family:var(--sans);font-size:13px;color:#cfc7b5;text-decoration:none;padding:3px 0;transition:color .15s}
.footer-links a:hover{color:var(--paper)}
.footer-copy{font-family:var(--sans);font-size:11px;color:#6f6a5f;letter-spacing:.02em;padding-top:24px;line-height:1.6}

/* Detail hero — strands uses div.hero (full-width, outside shell) */
div.hero{padding:clamp(44px,6vw,72px) 0 clamp(36px,5vw,52px);border-bottom:1px solid var(--line)}
div.hero h1{font-size:clamp(34px,4vw,52px);line-height:1.06}
.hero-meta{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px}
.clue-official{font-family:var(--serif-body);font-size:15px;color:var(--ink-faint);margin-top:14px;font-style:italic}
.clue-official strong{color:var(--ink-soft);font-style:normal;font-weight:600}
.btn-main{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-main:hover{background:var(--gold);border-color:var(--gold);color:var(--paper)}

/* Spangram — badge, card */
.span-badge{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c-yellow);background:#fdf3d9;border:1px solid var(--c-yellow);padding:3px 9px;border-radius:100px}
.spangram-card{border:2px solid var(--c-yellow);background:#fdf3d9;padding:22px 26px;margin-bottom:22px;cursor:pointer;transition:background .2s;user-select:none}
.spangram-card:hover{background:#f9e9b0}
.spangram-card .sc-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--c-yellow);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.spangram-card .star{font-size:14px}
.spangram-card .sc-word{font-family:var(--serif-display);font-size:34px;font-weight:700;color:var(--c-yellow);letter-spacing:.08em;filter:blur(7px);transition:filter .35s;line-height:1;margin-bottom:6px}
.spangram-card.revealed .sc-word{filter:none}
.spangram-card .sc-tap{font-family:var(--sans);font-size:12px;color:var(--c-yellow);opacity:.65;margin-top:4px}
.spangram-card.revealed .sc-tap{display:none}

/* Word pills */
.words-label{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px;text-align:center}
.words-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.word-pill{display:flex;align-items:center;border:1.5px solid var(--line);padding:10px 22px;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:var(--paper);color:var(--ink-faint);transition:all .2s;user-select:none}
.word-pill:hover{border-color:var(--ink-soft)}
.word-pill .pill-text{filter:blur(5px);transition:filter .3s}
.word-pill.revealed{background:var(--paper-2);border-color:var(--ink);color:var(--ink)}
.word-pill.revealed .pill-text{filter:none}

/* Reveal all button (strands uses .reveal-all-btn, connections uses .reveal-all) */
.reveal-all-btn{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;background:var(--ink);color:var(--paper);border:none;padding:12px 20px;cursor:pointer;transition:transform .15s;margin-left:auto;flex-shrink:0}
.reveal-all-btn:hover{transform:translateY(-2px)}

/* Analysis extras */
.an-val.word-val{font-size:22px}
.breakdown-text{font-family:var(--serif-body);font-size:17px;color:var(--ink-soft);line-height:1.65;margin-top:22px}
.clue-reading-text{font-family:var(--serif-body);font-size:17px;color:var(--ink-soft);line-height:1.65}

/* Recent — strands detail uses ul.recent > li > a */
ul.recent{list-style:none}
ul.recent li:first-child a{border-top:2px solid var(--rule)}

/* Archive page */
.page-hero{border-bottom:1px solid var(--line);padding:clamp(48px,6vw,72px) 0 clamp(40px,5vw,56px)}
.ph-kicker{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:14px}
.ph-kicker::before{content:"";height:1px;width:36px;background:var(--gold)}
.ph-desc{font-family:var(--serif-body);font-style:italic;font-size:clamp(17px,2vw,20px);color:var(--ink-soft);line-height:1.5;margin-top:14px;max-width:48ch}
.archive-month{margin-bottom:36px}
.archive-month h3{font-family:var(--serif-display);font-size:20px;font-weight:700;color:var(--gold);padding-bottom:14px;border-bottom:2px solid var(--rule)}
.archive-list{list-style:none}
.archive-list a{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);font-family:var(--serif-display);font-size:18px;font-weight:600;transition:padding-left .15s,color .15s}
.archive-list a:hover{color:var(--gold);padding-left:6px}
.archive-list .a-no{font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);align-self:center}
.archive-filter{display:flex;align-items:center;gap:16px;margin-bottom:32px;flex-wrap:wrap}
.archive-filter-label{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
.archive-date-input{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--ink);background:var(--paper-2);border:1.5px solid var(--line);padding:8px 14px;cursor:pointer;transition:border-color .15s}
.archive-date-input:hover,.archive-date-input:focus{border-color:var(--gold);outline:none}

/* ANSWERS TWO-COL + PUZZLE BOARD */
.ans-layout{display:grid;grid-template-columns:1fr 294px;gap:32px;align-items:start}
.ans-left{min-width:0}
.ans-right{padding-top:2px}
.board-label{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px}
.board-outer{position:relative;display:inline-block;--bsz:min(44px,calc((100vw - 105px) / 6))}
.board-cells{display:grid;grid-template-columns:repeat(6,var(--bsz));gap:5px;position:relative;z-index:1}
.board-cell{width:var(--bsz);height:var(--bsz);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-weight:700;font-size:min(13px,calc(var(--bsz) * 0.32));letter-spacing:.04em;background:var(--paper-2);color:var(--ink-faint);border:2px solid transparent;transition:background .3s,color .3s,border-color .3s;user-select:none}
.board-cell.theme{background:#e8f0df;border-color:var(--c-green);color:var(--c-green)}
.board-cell.spangram{background:#fdf3d9;border-color:var(--c-yellow);color:var(--gold)}
.board-svg{position:absolute;top:0;left:0;pointer-events:none;z-index:0;overflow:visible}

/* WORD SHAPE HINTS */
.shape-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:20px;margin-top:8px}
.shape-card{border:1.5px solid var(--line);padding:22px 24px}
.shape-label{font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:14px}
.shape-val{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px;align-items:baseline}
.len-pill{font-family:var(--serif-display);font-weight:800;font-size:32px;line-height:1;color:var(--ink)}
.len-unit{font-family:var(--sans);font-size:16px;color:var(--ink-soft);align-self:flex-end;margin-bottom:4px}
.spangram-len{color:var(--c-yellow)}
.shape-note{font-family:var(--sans);font-size:12px;color:var(--ink-faint);letter-spacing:.04em}

@media(max-width:680px){
  .ans-layout{grid-template-columns:1fr}
  .ans-right{display:flex;flex-direction:column;align-items:center}
}

/* Mobile adjustments for strands-specific nav */
@media(max-width:560px){
  .nav-hamburger{display:flex}
  .nav-links{position:fixed;top:64px;left:0;right:0;flex-direction:column;gap:0;background:var(--paper);border-bottom:2px solid var(--rule);padding:0 clamp(20px,4vw,56px);max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;display:flex}
  .nav-links.open{max-height:340px;padding-top:8px;padding-bottom:16px}
  .nav-links li{border-bottom:1px solid var(--line)}
  .nav-links a{border-bottom:none;padding:15px 0;font-size:14px;letter-spacing:.06em}
  .footer-inner{grid-template-columns:1fr}
  .footer-links-col{flex-direction:column;gap:20px}
}
@media(max-width:820px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:30px}
}

/* TODAY PUZZLE CARD (homepage) */
.today-puzzle-card{border:2px solid var(--rule);padding:clamp(22px,3vw,34px);display:flex;flex-direction:column;gap:18px}
.today-puzzle-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.today-puzzle-sep{color:var(--line)}
.today-puzzle-no{color:var(--ink)}
.today-puzzle-diff strong{color:var(--ink)}
.today-puzzle-clue{font-family:var(--serif-body);font-size:18px;font-style:italic;color:var(--ink-soft);line-height:1.5;border-left:2px solid var(--gold);padding-left:16px}
.today-puzzle-clue strong{color:var(--ink);font-style:normal;font-weight:600}
.today-puzzle-teaser{font-family:var(--serif-body);font-size:17px;color:var(--ink-soft);line-height:1.65}
.today-puzzle-inside{background:var(--paper-2);padding:16px 20px}
.today-puzzle-inside span{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:10px}
.today-puzzle-inside ul{list-style:none;display:grid;gap:7px}
.today-puzzle-inside ul li{font-family:var(--sans);font-size:14px;color:var(--ink-soft);padding-left:18px;position:relative}
.today-puzzle-inside ul li::before{content:"\2014";position:absolute;left:0;color:var(--gold)}
.today-puzzle-cta{text-decoration:none}
