/* =================================================================
   ENGAGE 2030 — The Movement
   Shared design system  ·  bold movement energy
   ================================================================= */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
input,textarea{font:inherit}

/* ---------- Tokens ---------- */
:root{
  --ink:#15140F;
  --ink-soft:#403d33;
  --paper:#F1E9D8;
  --paper-2:#E6DCC2;
  --paper-card:#FBF7EA;
  --signal:#FF3B1F;
  --signal-2:#D62A10;
  --blue:#2A33E0;
  --green:#0C9A55;
  --tag:#15140F;            /* per-page product accent override */
  --maxw:1240px;
  --bd:2.5px solid var(--ink);
  --shadow:8px 8px 0 var(--ink);
  --shadow-sm:4px 4px 0 var(--ink);
  --ff-display:'Archivo',system-ui,sans-serif;
  --ff-body:'Inter',system-ui,sans-serif;
  --ff-mono:'Space Mono','SFMono-Regular',ui-monospace,monospace;
}
body.t-philotic{--tag:#15140F}
body.t-academy{--tag:var(--blue)}
body.t-nomad{--tag:var(--green)}

/* ---------- Base ---------- */
body{
  font-family:var(--ff-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--signal);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
@media(min-width:760px){.wrap{padding:0 40px}}
.sec{padding:clamp(60px,9vw,126px) 0}
.center{text-align:center}

/* ---------- Type ---------- */
h1,h2,h3,h4{
  font-family:var(--ff-display);font-weight:900;line-height:1;
  text-transform:uppercase;letter-spacing:-.022em;
}
.h-xl{font-size:clamp(2.7rem,7.4vw,6.7rem);line-height:.9}
.h-lg{font-size:clamp(2rem,4.7vw,3.8rem);line-height:.96}
.h-md{font-size:clamp(1.55rem,2.7vw,2.4rem);line-height:1.02}
h3{font-size:1.3rem;line-height:1.08}
p{max-width:64ch}
.lead{font-size:clamp(1.08rem,1.55vw,1.36rem);line-height:1.55;max-width:62ch}
.mono{font-family:var(--ff-mono)}
.hot{color:var(--signal)}
.eyebrow{
  font-family:var(--ff-mono);font-weight:700;font-size:.74rem;
  letter-spacing:.21em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:28px;height:3px;background:var(--signal);flex:none}
.eyebrow.on-dark::before{background:var(--signal)}

.section-head{max-width:760px;margin-bottom:clamp(34px,5vw,62px)}
.section-head .h-lg{margin:18px 0 16px}
.section-head p{font-size:1.1rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:.92rem;letter-spacing:.015em;
  padding:.95em 1.55em;border:var(--bd);
  box-shadow:var(--shadow-sm);
  transition:transform .12s ease,box-shadow .12s ease,background .15s ease;
}
.btn:hover{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.btn:active{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
.btn--hot{background:var(--signal);color:#fff}
.btn--hot:hover{background:var(--signal-2)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ghost{background:var(--paper-card);color:var(--ink)}
.btn--lg{font-size:1.04rem;padding:1.08em 1.9em}
.btn .arr{font-family:var(--ff-body);font-weight:700}
.btn-row{display:flex;flex-wrap:wrap;gap:16px}

.txtlink{
  font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:.92rem;letter-spacing:.02em;
  border-bottom:3px solid var(--signal);padding-bottom:2px;
  display:inline-flex;align-items:center;gap:.45em;transition:gap .15s ease;
}
.txtlink:hover{gap:.8em}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:90;
  background:var(--paper);border-bottom:var(--bd);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{
  display:flex;align-items:center;gap:9px;
  font-family:var(--ff-display);font-weight:900;font-size:1.3rem;
  letter-spacing:-.03em;text-transform:uppercase;
}
.brand-badge{
  font-family:var(--ff-mono);font-weight:700;font-size:.66rem;letter-spacing:.06em;
  background:var(--signal);color:#fff;padding:.3em .5em;
  border:2px solid var(--ink);
}
.nav-links{display:flex;align-items:center;gap:7px}
.nav-link{
  font-family:var(--ff-display);font-weight:700;text-transform:uppercase;
  font-size:.84rem;letter-spacing:.03em;padding:.55em .7em;
  border:2.5px solid transparent;transition:border-color .14s ease;
}
.nav-link:hover{border-color:var(--ink)}
.nav-link.active{border-color:var(--ink);background:var(--paper-card)}
.nav-cta{margin-left:10px}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:10px;border:var(--bd);background:var(--paper-card)}
.nav-toggle span{width:22px;height:3px;background:var(--ink);transition:.2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media(max-width:920px){
  .nav-toggle{display:flex}
  .nav-links{
    position:absolute;top:70px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:var(--bd);
    padding:10px 24px 24px;
    transform:translateY(-130%);transition:transform .26s cubic-bezier(.4,0,.2,1);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-link{padding:1em .2em;border:none;border-bottom:2px solid var(--paper-2)}
  .nav-link:hover{border-color:var(--paper-2)}
  .nav-cta{margin:18px 0 0}
  .btn.nav-cta{justify-content:center}
}

/* ---------- Marquee ---------- */
.marquee{
  background:var(--ink);color:var(--paper);
  border-top:var(--bd);border-bottom:var(--bd);
  overflow:hidden;padding:13px 0;
}
.marquee--hot{background:var(--signal);color:#fff}
.marquee-track{
  display:flex;width:max-content;white-space:nowrap;
  animation:scroll 38s linear infinite;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{
  font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  font-size:1.04rem;letter-spacing:.01em;
  display:flex;align-items:center;gap:1.5rem;padding:0 .75rem;
}
.marquee-track span::after{content:"\2738";color:var(--signal);font-size:.85rem}
.marquee--hot .marquee-track span::after{color:var(--ink)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(46px,7vw,92px) 0 clamp(54px,8vw,104px)}
.hero-bgnum{
  position:absolute;right:-3vw;bottom:-9vw;z-index:0;pointer-events:none;
  font-family:var(--ff-display);font-weight:900;font-size:43vw;line-height:.62;
  color:var(--ink);opacity:.05;letter-spacing:-.04em;
}
.hero .wrap{position:relative;z-index:1}
.hero-eyebrow{margin-bottom:26px}
.hero h1{margin-bottom:26px}
.hero h1 .blk{display:block}
.hero h1 em{font-style:normal;color:var(--signal)}
.hero-lead{margin-bottom:32px}
.hero-meta{
  margin-top:30px;display:flex;flex-wrap:wrap;gap:10px 26px;
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.04em;
}
.hero-meta span{display:flex;align-items:center;gap:.5em}
.hero-meta span::before{content:"";width:9px;height:9px;background:var(--signal);flex:none}

/* ---------- Counter band ---------- */
.countband{
  background:var(--ink);color:var(--paper);
  border-top:var(--bd);border-bottom:var(--bd);
}
.countband .wrap{padding:clamp(48px,7vw,94px) 24px}
@media(min-width:760px){.countband .wrap{padding-left:40px;padding-right:40px}}
.count-label{
  font-family:var(--ff-mono);font-weight:700;font-size:.78rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--signal);
  display:flex;align-items:center;gap:.7em;
}
.count-label::before,.count-label::after{content:"";height:3px;flex:1;background:#34322a;max-width:120px}
.count-stage{justify-content:center}
.count-num{
  font-family:var(--ff-display);font-weight:900;
  font-size:clamp(3.8rem,16vw,12rem);line-height:.82;
  color:var(--signal);letter-spacing:-.035em;
  font-variant-numeric:tabular-nums;
  margin:26px 0 6px;text-align:center;
}
.count-goal{
  text-align:center;font-family:var(--ff-display);font-weight:900;
  text-transform:uppercase;font-size:clamp(1.15rem,3.4vw,2.1rem);
  letter-spacing:-.01em;color:var(--paper);
}
.count-goal small{display:block;font-family:var(--ff-mono);font-weight:400;
  font-size:.8rem;letter-spacing:.06em;color:#9d9a8c;text-transform:none;margin-top:8px}
.bar{
  position:relative;height:34px;margin:34px 0 10px;
  background:#27261d;border:3px solid var(--paper);overflow:hidden;
}
.bar-fill{
  height:100%;width:0;background:var(--signal);
  background-image:repeating-linear-gradient(45deg,rgba(0,0,0,.18) 0 10px,transparent 10px 20px);
  transition:width 1.9s cubic-bezier(.22,1,.36,1);
}
.bar-ticks{
  display:flex;justify-content:space-between;
  font-family:var(--ff-mono);font-size:.72rem;color:#8f8c7f;
}
.cstats{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:3px solid var(--paper);margin-top:36px;
}
.cstat{padding:22px 20px;border-right:3px solid var(--paper)}
.cstat:last-child{border-right:none}
.cstat b{
  display:block;font-family:var(--ff-display);font-weight:900;
  font-size:clamp(1.5rem,3.4vw,2.3rem);color:var(--paper);line-height:1;
}
.cstat span{
  font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.06em;
  color:#9d9a8c;text-transform:uppercase;margin-top:8px;display:block;
}
@media(max-width:680px){
  .cstats{grid-template-columns:1fr}
  .cstat{border-right:none;border-bottom:3px solid var(--paper)}
  .cstat:last-child{border-bottom:none}
}

/* ---------- Generic blocks ---------- */
.band{border-top:var(--bd);border-bottom:var(--bd)}
.band--paper2{background:var(--paper-2)}
.band--ink{background:var(--ink);color:var(--paper)}
.band--ink .eyebrow::before{background:var(--signal)}
.band--ink p{color:#d9d2bf}

/* manifesto / why */
.manifesto p{font-size:clamp(1.15rem,2vw,1.6rem);line-height:1.45;max-width:24ch;font-weight:500}
.why-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,72px);align-items:start}
@media(max-width:860px){.why-grid{grid-template-columns:1fr;gap:34px}}
.why-body p+p{margin-top:20px}
.why-body p{font-size:1.12rem}

.principles{display:grid;gap:0;border:var(--bd);background:var(--paper-card)}
.principle{display:flex;gap:20px;padding:24px;border-bottom:var(--bd)}
.principle:last-child{border-bottom:none}
.principle .pn{font-family:var(--ff-mono);font-weight:700;color:var(--signal);flex:none}
.principle h3{margin-bottom:5px}
.principle p{font-size:.99rem}

/* steps */
.steps{display:grid;gap:0;border:var(--bd);background:var(--paper-card)}
.step{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  padding:clamp(22px,3vw,38px);border-bottom:var(--bd);
}
.step:last-child{border-bottom:none}
.step-num{
  font-family:var(--ff-display);font-weight:900;
  font-size:clamp(2.4rem,5vw,4.4rem);line-height:.8;color:var(--signal);
  -webkit-text-stroke:2px var(--ink);
}
.step-tag{
  display:inline-block;font-family:var(--ff-mono);font-weight:700;
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.35em .6em;border:2.5px solid var(--ink);margin-bottom:10px;
}
.step h3{font-size:clamp(1.3rem,2.4vw,1.95rem);margin-bottom:8px}
.step p{font-size:1.02rem}
.step-go{font-family:var(--ff-display);font-weight:900;font-size:1.6rem}
@media(max-width:720px){
  .step{grid-template-columns:auto 1fr;gap:16px 18px}
  .step-go{display:none}
}

/* product cards */
.pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:920px){.pcards{grid-template-columns:1fr;gap:22px}}
.pcard{
  display:flex;flex-direction:column;
  background:var(--paper-card);border:var(--bd);box-shadow:var(--shadow);
  padding:30px;transition:transform .14s ease,box-shadow .14s ease;
}
.pcard:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--ink)}
.pcard--philotic{--tag:#15140F}
.pcard--academy{--tag:var(--blue)}
.pcard--nomad{--tag:var(--green)}
.tag{
  align-self:flex-start;
  font-family:var(--ff-mono);font-weight:700;font-size:.7rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.45em .7em;background:var(--tag);color:#fff;border:2.5px solid var(--ink);
}
.pcard-name{font-size:clamp(1.7rem,2.6vw,2.15rem);margin:18px 0 6px}
.pcard-kick{font-family:var(--ff-mono);font-size:.82rem;color:var(--ink-soft);margin-bottom:14px}
.pcard p{font-size:1rem;margin-bottom:18px}
.pcard ul{margin-bottom:24px}
.pcard li{
  font-size:.95rem;padding:8px 0 8px 24px;position:relative;
  border-top:2px solid var(--paper-2);
}
.pcard li:first-child{border-top:none}
.pcard li::before{content:"\2192";position:absolute;left:0;color:var(--signal);font-weight:700}
.pcard .txtlink{margin-top:auto}

/* goals grid */
.goals{display:grid;grid-template-columns:repeat(4,1fr);border:var(--bd)}
.goal{padding:30px 24px;border-right:var(--bd)}
.goal:last-child{border-right:none}
.goal b{
  display:block;font-family:var(--ff-display);font-weight:900;
  font-size:clamp(2.2rem,4.4vw,3.4rem);line-height:.9;color:var(--signal);
  -webkit-text-stroke:1.5px var(--ink);
}
.goal span{display:block;margin-top:12px;font-size:.96rem;line-height:1.4}
@media(max-width:860px){
  .goals{grid-template-columns:1fr 1fr}
  .goal{border-bottom:var(--bd)}
  .goal:nth-child(odd){border-right:var(--bd)}
  .goal:nth-child(even){border-right:none}
  .goal:nth-last-child(-n+2){border-bottom:none}
}
@media(max-width:480px){
  .goals{grid-template-columns:1fr}
  .goal{border-right:none!important;border-bottom:var(--bd)}
  .goal:last-child{border-bottom:none}
}

/* feature list (product pages) */
.flist{display:grid;grid-template-columns:1fr 1fr;gap:0;border:var(--bd);background:var(--paper-card)}
@media(max-width:720px){.flist{grid-template-columns:1fr}}
.fitem{padding:28px;border-right:var(--bd);border-bottom:var(--bd)}
.flist .fitem:nth-child(even){border-right:none}
.fitem .fn{font-family:var(--ff-mono);font-weight:700;color:var(--signal);font-size:.8rem;letter-spacing:.1em}
.fitem h3{margin:12px 0 8px;font-size:1.22rem}
.fitem p{font-size:.99rem}
@media(max-width:720px){
  .fitem{border-right:none}
}

/* split / two-col */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,68px);align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:30px}}
.panel{
  background:var(--paper-card);border:var(--bd);box-shadow:var(--shadow);
  padding:clamp(26px,4vw,44px);
}
.panel--ink{background:var(--ink);color:var(--paper)}
.panel--ink p{color:#d9d2bf}

/* join */
.join-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:920px){.join-cols{grid-template-columns:1fr}}
.join-card{
  background:var(--paper-card);border:var(--bd);box-shadow:var(--shadow);
  padding:30px;display:flex;flex-direction:column;
}
.join-card .jn{
  font-family:var(--ff-display);font-weight:900;font-size:1.1rem;
  color:var(--signal);-webkit-text-stroke:1.5px var(--ink);
}
.join-card h3{font-size:1.5rem;margin:6px 0 10px}
.join-card p{font-size:.98rem;margin-bottom:20px}
.join-card .btn,.join-card form{margin-top:auto}

/* forms */
.field{margin-bottom:14px}
.field label{
  display:block;font-family:var(--ff-mono);font-weight:700;font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;
}
.field input{
  width:100%;padding:.85em .9em;background:var(--paper);
  border:var(--bd);color:var(--ink);
}
.field input:focus{outline:3px solid var(--signal);outline-offset:1px}
.form-note{font-family:var(--ff-mono);font-size:.72rem;color:var(--ink-soft);margin-top:10px}
.form-success{
  display:none;border:var(--bd);background:var(--signal);color:#fff;
  padding:18px;font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:.95rem;line-height:1.3;
}
.form-success.show{display:block}
.form.hide{display:none}

/* chip set (accessories etc.) */
.chipset{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  font-family:var(--ff-mono);font-weight:700;font-size:.74rem;
  letter-spacing:.05em;text-transform:uppercase;
  padding:.55em .8em;border:2.5px solid var(--ink);background:var(--paper);
}

/* explore list (join page) */
.explore-list li{
  position:relative;padding:11px 0 11px 26px;
  border-top:2px solid var(--paper-2);font-size:.98rem;
}
.explore-list li:first-child{border-top:none}
.explore-list li::before{content:"\2192";position:absolute;left:0;color:var(--signal);font-weight:700}
.explore-list a:hover{color:var(--signal)}

/* pledge */
.pledge-quote{
  font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(1.05rem,1.7vw,1.32rem);line-height:1.18;
  border-left:6px solid var(--signal);padding-left:18px;margin:4px 0 20px;
}
.stamp{
  display:none;margin-top:16px;align-self:flex-start;
  font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  color:var(--signal);border:3px solid var(--signal);
  padding:.5em .8em;font-size:1.05rem;transform:rotate(-7deg);letter-spacing:.02em;
}
.stamp.show{display:inline-block}

/* faq */
.faq{border:var(--bd);background:var(--paper-card)}
.faq details{border-bottom:var(--bd)}
.faq details:last-child{border-bottom:none}
.faq summary{
  list-style:none;cursor:pointer;padding:22px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:1.02rem;letter-spacing:-.01em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.6rem;font-weight:900;color:var(--signal);flex:none}
.faq details[open] summary::after{content:"\2013"}
.faq details[open] summary{background:var(--paper-2)}
.faq .ans{padding:0 24px 24px;font-size:1rem}
.faq .ans p{max-width:72ch}

/* cta strip */
.ctastrip{background:var(--signal);color:#fff;border-top:var(--bd);border-bottom:var(--bd)}
.ctastrip .wrap{padding:clamp(48px,7vw,92px) 24px;text-align:center}
.ctastrip h2{color:#fff;margin-bottom:18px}
.ctastrip p{color:#fff;margin:0 auto 28px;max-width:54ch;font-size:1.1rem}
.ctastrip .btn-row{justify-content:center}
.ctastrip .btn--ghost{background:var(--paper-card)}

/* page hero (interior pages) */
.phero{padding:clamp(46px,6vw,86px) 0 clamp(40px,5vw,64px);position:relative;overflow:hidden}
.phero .tag{margin-bottom:22px}
.phero h1{margin-bottom:22px}
.phero .lead{margin-bottom:0}
.crumb{font-family:var(--ff-mono);font-size:.76rem;letter-spacing:.06em;margin-bottom:20px;color:var(--ink-soft)}
.crumb a:hover{color:var(--signal)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:var(--paper);border-top:var(--bd)}
.footer a{transition:color .14s ease}
.footer a:hover{color:var(--signal)}
.footer-top{
  display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:34px;
  padding:clamp(48px,6vw,76px) 0 44px;
}
@media(max-width:860px){.footer-top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer .brand{color:var(--paper);margin-bottom:16px}
.footer-brand p{color:#b8b2a0;font-size:.96rem;max-width:34ch}
.footer h4{
  font-family:var(--ff-mono);font-weight:700;font-size:.74rem;
  letter-spacing:.16em;text-transform:uppercase;color:#8f8c7f;margin-bottom:16px;
}
.footer li{margin-bottom:10px;font-size:.95rem}
.footer-bottom{
  border-top:2.5px solid #34322a;padding:22px 0;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-family:var(--ff-mono);font-size:.74rem;color:#8f8c7f;
}
.footer-bottom .badge-row{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- Resources page ---------- */
.intro-line{
  font-family:var(--ff-mono);font-size:.92rem;line-height:1.6;
  border-left:5px solid var(--signal);padding-left:16px;max-width:70ch;
}
.jumpnav{display:flex;flex-wrap:wrap;gap:10px}
.jumpnav a{
  font-family:var(--ff-mono);font-weight:700;font-size:.75rem;
  letter-spacing:.04em;text-transform:uppercase;
  padding:.62em .85em;border:2.5px solid var(--ink);background:var(--paper-card);
  box-shadow:var(--shadow-sm);
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease,color .12s ease;
}
.jumpnav a:hover{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);background:var(--signal);color:#fff}

.topic{border-top:var(--bd);padding:clamp(46px,7vw,88px) 0}
.topic-head{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;margin-bottom:22px}
.topic-no{
  font-family:var(--ff-display);font-weight:900;font-size:clamp(2.3rem,5vw,4rem);
  line-height:.78;color:var(--signal);-webkit-text-stroke:2px var(--ink);
}
.topic-head h2{font-size:clamp(1.6rem,3.3vw,2.6rem)}
.topic-intro{font-size:1.08rem;max-width:72ch}
.topic-intro p+p{margin-top:14px}

.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
@media(max-width:900px){.rgrid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.rgrid{grid-template-columns:1fr}}
.rcard{
  display:flex;flex-direction:column;
  background:var(--paper-card);color:var(--ink);
  border:var(--bd);box-shadow:var(--shadow-sm);
  padding:22px;transition:transform .13s ease,box-shadow .13s ease;
}
.rcard:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--ink)}
.rtype{
  align-self:flex-start;font-family:var(--ff-mono);font-weight:700;
  font-size:.64rem;letter-spacing:.11em;text-transform:uppercase;
  padding:.38em .6em;border:2px solid var(--ink);margin-bottom:13px;
}
.t-course{background:var(--blue);color:#fff}
.t-cert{background:var(--green);color:#fff}
.t-video{background:var(--signal);color:#fff}
.t-guide{background:var(--ink);color:var(--paper)}
.t-tool{background:var(--paper-2);color:var(--ink)}
.rcard h3{font-size:1.12rem;line-height:1.13;margin-bottom:8px;color:var(--ink)}
.rcard p{font-size:.93rem;line-height:1.5;margin-bottom:16px;color:var(--ink)}
.rlink{
  margin-top:auto;align-self:flex-start;
  font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:.8rem;letter-spacing:.03em;
  display:inline-flex;align-items:center;gap:.4em;
  border-bottom:3px solid var(--signal);padding-bottom:2px;transition:gap .14s ease;
}
.rcard:hover .rlink{gap:.75em}

.gloss{display:grid;grid-template-columns:1fr 1fr;border:var(--bd);background:var(--paper-card);margin-top:28px}
@media(max-width:680px){.gloss{grid-template-columns:1fr}}
.gterm{padding:18px 20px;border-bottom:2px solid var(--paper-2);border-right:2px solid var(--paper-2)}
.gloss .gterm:nth-child(even){border-right:none}
.gterm b{
  font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  font-size:1rem;display:block;margin-bottom:4px;
}
.gterm span{font-size:.92rem;line-height:1.45}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  .bar-fill{transition:none}
}

/* ---------- Utility ---------- */
.mt-s{margin-top:14px}
.mt-m{margin-top:26px}
.mt-l{margin-top:44px}
.mb-m{margin-bottom:26px}
.maxw-720{max-width:720px}
.dim{color:var(--ink-soft)}
