/* ============================================================
   AChA Knowledge Base — 2026 brand design system  (v3 — full-width editorial)
   Top nav · full-bleed hero · full-width composed section bands ·
   Neue Regrade + Helvetica + Brittany · B&W duotone photography · motion.
   Matches the design language of australianchristianarts.com.
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:'Neue Regrade';src:url('../fonts/NeueRegrade-Variable.ttf') format('truetype');font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:'Neue Regrade';src:url('../fonts/NeueRegrade-Semibold.otf') format('opentype');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Helvetica Now';src:url('../fonts/helvetica-light.woff2') format('woff2');font-weight:300;font-display:swap}
@font-face{font-family:'Helvetica Now';src:url('../fonts/helvetica-regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Helvetica Now';src:url('../fonts/helvetica-bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Brittany';src:url('../fonts/BrittanySignature.ttf') format('truetype');font-display:swap}

:root{
  --paper:#F5F0E8; --paper-deep:#EDE6D8; --paper-card:#FBF8F2;
  --white:#FFFFFF; --black:#16130F; --ink:#23201B;
  --teal:#6E9C9C; --teal-deep:#4F7B7B; --teal-dk:#314E4C;
  --taupe:#C5BDA2; --taupe-deep:#A99F80; --taupe-soft:#E7E0CF;
  --olive:#C9CE55; --crimson:#9B0D0D; --gray:#E2E2E2; --line:#E5DDCD; --muted:#7A756A;
  --display:'Neue Regrade','Helvetica Neue',Arial,sans-serif;
  --body:'Helvetica Now','Helvetica Neue',Helvetica,Arial,sans-serif;
  --script:'Brittany','Brush Script MT',cursive;
  --wrap:1280px; --gut:clamp(22px,5vw,72px);
  --dash:repeating-linear-gradient(135deg, rgba(110,156,156,.05) 0 1.5px, transparent 1.5px 13px);
  --shadow:0 1px 2px rgba(40,35,25,.04),0 10px 34px rgba(40,35,25,.08);
  --shadow-lg:0 6px 16px rgba(40,35,25,.09),0 30px 70px rgba(40,35,25,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);font-size:17px;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:var(--teal-deep);text-decoration:none}
::selection{background:var(--olive);color:var(--black)}
img{max-width:100%;height:auto}

/* ---------- Top navigation ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:74px;display:flex;align-items:center;gap:26px;
  padding:0 var(--gut);transition:background .3s,box-shadow .3s,border-color .3s;border-bottom:1px solid transparent}
.nav .brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.nav .logo{height:30px;width:auto;display:block;transition:filter .3s}
.nav .logo.sym{height:25px}
.brandword{font-family:var(--display);font-weight:700;font-size:15.5px;letter-spacing:-.01em;color:inherit;white-space:nowrap}
.nav .kb-label{font-family:var(--body);font-weight:600;font-size:9.5px;letter-spacing:.17em;text-transform:uppercase;
  border-left:1px solid currentColor;padding-left:13px;opacity:.7;white-space:nowrap}
.sitefoot .fbrand .brandword{color:#fff;font-size:17px}.sitefoot .logo.sym{height:26px}
.nav-menu{display:flex;align-items:center;gap:4px;margin-right:auto}
.navitem{position:relative}
.navitem>button{font-family:var(--body);font-size:14px;font-weight:500;color:inherit;background:none;border:0;cursor:pointer;
  padding:10px 14px;border-radius:9px;letter-spacing:.01em;display:flex;align-items:center;gap:6px}
.navitem>button svg{width:11px;height:11px;opacity:.6}
.navitem:hover>button,.navitem:focus-within>button{background:rgba(255,255,255,.14)}
.nav.stuck .navitem:hover>button{background:var(--paper-deep)}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:280px;background:var(--white);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-lg);padding:10px;opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .18s,transform .18s,visibility .18s}
.navitem:hover .dropdown,.navitem:focus-within .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown a{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:9px 13px;border-radius:9px;
  color:var(--ink);font-size:13.5px;line-height:1.3}
.dropdown a:hover{background:var(--paper-deep)}
.dropdown a .tag{font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:5px;padding:1px 5px}
.nav .tools{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav .search{position:relative}
.nav .search input{width:210px;height:38px;border:1px solid rgba(255,255,255,.4);border-radius:9px;background:rgba(255,255,255,.12);
  padding:0 14px 0 36px;font-family:var(--body);font-size:13.5px;color:inherit;transition:.2s}
.nav .search input::placeholder{color:currentColor;opacity:.65}
.nav.stuck .search input{border-color:var(--line);background:var(--white)}
.nav .search svg{position:absolute;left:12px;top:11px;width:15px;height:15px;opacity:.6}
.country{display:flex;gap:5px}
.country a{font-size:11px;font-weight:700;letter-spacing:.06em;border:1px solid currentColor;border-radius:7px;padding:7px 9px;opacity:.6;color:inherit}
.country a.on{opacity:1;background:var(--teal);border-color:var(--teal);color:#fff}
/* over-hero (transparent) vs scrolled (solid) */
.nav{color:#fff}
.nav .logo{filter:brightness(0) invert(1)}
.nav.stuck{background:rgba(245,240,232,.96);backdrop-filter:saturate(140%) blur(12px);border-bottom-color:var(--line);
  box-shadow:0 6px 24px rgba(40,35,25,.06);color:var(--ink)}
.nav.stuck .logo{filter:none}
.nav.stuck .country a{opacity:.55}.nav.stuck .country a.on{opacity:1;color:#fff}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;color:#fff;isolation:isolate}
.hero .hero-bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;filter:grayscale(1) contrast(1.04);transform:scale(1.05)}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:
  linear-gradient(180deg, rgba(20,18,14,.28) 0%, rgba(20,18,14,.08) 34%, rgba(20,18,14,.66) 100%),
  linear-gradient(118deg, rgba(79,123,123,.62) 0%, rgba(110,156,156,.30) 48%, rgba(201,206,85,.12) 100%)}
.hero.brand .hero-bg{background:linear-gradient(125deg,var(--teal) 0%,var(--teal-deep) 46%,var(--taupe-deep) 100%);filter:none;transform:none}
.hero.brand::after{background:var(--dash),linear-gradient(180deg,transparent 60%,rgba(20,18,14,.35));opacity:.9;mix-blend-mode:normal}
.hero-mark{position:absolute;right:-1vw;bottom:-3vh;z-index:-1;width:min(360px,32vw);opacity:.13;pointer-events:none}
.hero-in{max-width:var(--wrap);margin:0 auto;padding:150px var(--gut) 72px;min-height:clamp(440px,64vh,640px);display:flex;flex-direction:column;justify-content:flex-end}
.hero-corners{position:absolute;top:104px;left:0;right:0;z-index:1}
.hero-corners .row{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut);display:flex;justify-content:space-between;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.82)}
.hero .crumb{font-size:12.5px;letter-spacing:.03em;color:rgba(255,255,255,.85);margin-bottom:22px}
.hero .crumb a{color:rgba(255,255,255,.85)}.hero .crumb b{color:#fff;font-weight:600}
.hero .eyebrow{display:flex;align-items:center;gap:14px;font-size:12.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--olive);margin-bottom:18px}
.hero .eyebrow .rule{width:42px;height:3px;background:var(--olive);border-radius:2px}
.hero h1{font-family:var(--display);font-weight:300;font-size:clamp(42px,6.4vw,98px);line-height:1.0;letter-spacing:-.02em;margin:0;max-width:19ch;text-wrap:balance}
.hero h1 b,.hero h1 .em{font-weight:700}
.hero .lede{font-size:clamp(17px,1.7vw,22px);line-height:1.5;color:rgba(255,255,255,.92);max-width:62ch;font-weight:300;margin:24px 0 0}

/* ---------- Article = sticky TOC rail + generous content column ---------- */
.doc{width:100%}
.eyebrow{display:flex;align-items:center;gap:13px;font-size:11.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-deep);margin-bottom:16px}
.eyebrow .rule{width:38px;height:3px;background:var(--teal);border-radius:2px;flex-shrink:0}
.layout{max-width:var(--wrap);margin:0 auto;padding:clamp(44px,5vw,84px) var(--gut);display:grid;grid-template-columns:236px minmax(0,1fr);gap:clamp(40px,5vw,80px);align-items:start}
.layout.notoc{grid-template-columns:minmax(0,880px);justify-content:center}
.toc{position:sticky;top:104px;font-size:13.5px}
.toc-label{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--taupe-deep);margin-bottom:14px}
.toc nav{display:flex;flex-direction:column;border-left:2px solid var(--line)}
.toc nav a{color:var(--muted);padding:7px 0 7px 16px;margin-left:-2px;border-left:2px solid transparent;line-height:1.3;transition:color .2s,border-color .2s}
.toc nav a:hover{color:var(--ink)}
.toc nav a.active{color:var(--teal-deep);border-left-color:var(--teal);font-weight:600}
.content{min-width:0;max-width:840px}
.content .sec{scroll-margin-top:100px}
.content .sec+.sec{margin-top:clamp(40px,5vw,64px)}
.content>*:first-child,.sec>*:first-child{margin-top:0}

/* content typography */
.content h1,.content h2{font-family:var(--display);font-weight:700;font-size:clamp(27px,2.6vw,38px);line-height:1.12;margin:0 0 18px;letter-spacing:-.015em;color:var(--black)}
.content h3{font-family:var(--display);font-weight:600;font-size:22px;margin:34px 0 10px;color:var(--teal-deep)}
.content h4{font-family:var(--display);font-weight:600;font-size:16.5px;margin:24px 0 6px;color:var(--black)}
.content p{font-size:18px;line-height:1.8;margin:0 0 18px;color:#2c2820;max-width:72ch}
.content a{color:var(--teal-deep);border-bottom:1px solid rgba(79,123,123,.32)}
.content a:hover{border-bottom-color:var(--teal-deep)}
.content b,.content strong{font-weight:700;color:var(--black)}
.content ul,.content ol{margin:0 0 20px;padding-left:2px;list-style:none;max-width:70ch}
.content li{margin:0 0 12px;font-size:17.5px;line-height:1.62;padding-left:32px;position:relative}
.content ul li::before{content:"";position:absolute;left:6px;top:11px;width:7px;height:7px;background:var(--teal);border-radius:50%}
.content ol{counter-reset:n}.content ol li{counter-increment:n}
.content ol li::before{content:counter(n);position:absolute;left:0;top:0;width:24px;height:24px;background:var(--paper-deep);color:var(--teal-deep);
  font-family:var(--display);font-weight:700;font-size:12px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.content img{border-radius:16px;box-shadow:var(--shadow)}
/* standalone content images sized by intrinsic aspect (set in build post-pass) so badges/logos/seals don't blow up to column width */
.content img.img-square{display:block;width:auto;max-width:300px;margin:1.6rem auto;box-shadow:none}
.content img.img-wide{display:block;width:auto;max-width:700px;margin:1.6rem auto}
.content img.img-portrait{display:block;width:auto;max-width:400px;max-height:580px;margin:1.6rem auto}
.lesson .content img.img-square{max-width:300px}
.lesson .content img.img-wide{max-width:760px}
.lesson .content img.img-portrait{max-width:420px;max-height:600px}
.content figure{margin:28px 0}.content figure figcaption{font-family:var(--script);font-size:22px;color:var(--teal-deep);margin-top:8px}
.content blockquote{margin:32px 0;padding:6px 0 6px 30px;border-left:3px solid var(--teal);position:relative}
.content blockquote p{font-family:var(--display);font-weight:300;font-size:25px;line-height:1.4;color:var(--teal-dk);max-width:none;margin:0}

/* teal feature section (was a full Gamma teal card) */
.sec.feature{background:linear-gradient(150deg,var(--teal),var(--teal-deep));color:#fff;border-radius:24px;padding:clamp(30px,4vw,52px);margin:clamp(40px,5vw,64px) 0;position:relative;overflow:hidden}
.sec.feature::after{content:"";position:absolute;inset:0;background:var(--dash);opacity:.5;pointer-events:none}
.sec.feature>*{position:relative}
.sec.feature :is(h1,h2,h3,h4,p,li,strong,b){color:#fff}
.sec.feature a{color:#fff;border-bottom-color:rgba(255,255,255,.5)}
.sec.feature ul li::before{background:var(--olive)}
.sec.feature blockquote{border-left-color:var(--olive)}.sec.feature blockquote p{color:#fff}
.sec.feature .card{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);box-shadow:none}
.sec.feature .card .num{background:var(--olive);color:var(--teal-dk)}
.sec.feature .ico{filter:brightness(0) invert(1)}
.sec.feature .btn{background:#fff;color:var(--teal-dk)!important;box-shadow:0 8px 22px rgba(0,0,0,.18)}

/* ---------- component grids ---------- */
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:22px 0}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:22px 0}
.grid4{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:22px 0}
.card{background:var(--paper-card);border:1px solid var(--line);border-radius:18px;padding:26px 26px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card>*:first-child{margin-top:0}.card>*:last-child{margin-bottom:0}
.card .num{font-family:var(--display);font-weight:700;font-size:14px;color:#fff;background:var(--teal);width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;box-shadow:0 6px 14px rgba(79,123,123,.32)}
.cardplain{padding:2px}.cardplain img{border-radius:14px;margin-bottom:12px;width:100%}
.ico{display:block;width:30px;height:30px;object-fit:contain;margin-bottom:10px;filter:invert(38%) sepia(16%) saturate(700%) hue-rotate(130deg) brightness(92%)}
.iconcards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:22px 0}
.iconcards>div{background:var(--paper-card);border:1px solid var(--line);border-radius:18px;padding:24px 26px;box-shadow:var(--shadow)}
.iconcards>div>*:first-child{margin-top:0}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:18px;margin:24px 0}
.stats>div{background:linear-gradient(155deg,var(--teal),var(--teal-deep));color:#fff;border-radius:18px;padding:28px 26px;box-shadow:var(--shadow)}
.stats>div :is(h2,h3,h4){font-family:var(--display);font-weight:700;font-size:44px;line-height:1;color:#fff;margin:0 0 6px}
.stats>div p,.stats>div li{color:rgba(255,255,255,.92);font-size:14px;margin:0}
.timeline{position:relative;margin:24px 0;padding-left:36px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--teal),var(--taupe))}
.timeline>div{position:relative;margin-bottom:24px}.timeline>div>*:first-child{margin-top:0}
.timeline>div::before{content:"";position:absolute;left:-36px;top:5px;width:18px;height:18px;border-radius:50%;background:#fff;border:3px solid var(--teal);box-shadow:0 0 0 4px var(--paper)}
.steps{display:grid;gap:14px;margin:24px 0}
.steps>div{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;background:var(--paper-card);border:1px solid var(--line);border-radius:16px;padding:20px 24px;box-shadow:var(--shadow)}
.steps>div>div:last-child>*:first-child{margin-top:0}
.quotecards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:24px 0}
.quotecards>div{background:var(--paper-card);border:1px solid var(--line);border-left:4px solid var(--teal);border-radius:14px;padding:24px 26px;box-shadow:var(--shadow)}
.quotecards>div p{font-style:italic;color:var(--teal-dk)}
.cols{display:grid;gap:30px;margin:22px 0}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin:24px 0}
.gallery img{aspect-ratio:1/1;object-fit:cover;width:100%;border-radius:14px;filter:grayscale(1) contrast(1.04);transition:filter .5s}
.gallery img:hover,.band-body img:hover{filter:grayscale(0)}
.aside{background:var(--paper-card);border:1px solid var(--line);border-radius:16px;padding:22px 26px;margin:24px 0;box-shadow:var(--shadow)}
.aside.info{border-left:4px solid var(--teal)}.aside.warn{border-left:4px solid var(--crimson);background:#fbf1f0}
.aside>*:first-child{margin-top:0}.aside>*:last-child{margin-bottom:0}
.tbl{border-collapse:separate;border-spacing:0;width:100%;margin:24px 0;font-size:15.5px;background:var(--white);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.tbl td,.tbl th{border-bottom:1px solid var(--line);padding:13px 16px;text-align:left;vertical-align:top}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:first-child td,.tbl th{background:var(--teal);color:#fff;font-weight:600;font-family:var(--display)}
details{background:var(--paper-card);border:1px solid var(--line);border-radius:14px;padding:16px 22px;margin:16px 0;box-shadow:var(--shadow)}
details summary{font-weight:600;cursor:pointer;font-family:var(--display);color:var(--teal-deep)}
.btnrow{display:flex;flex-wrap:wrap;gap:12px;margin:22px 0}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:#fff!important;font-family:var(--display);font-weight:600;font-size:15px;
  padding:14px 28px;border-radius:40px;border:0!important;box-shadow:0 10px 24px rgba(79,123,123,.3);transition:transform .2s,box-shadow .2s,background .2s}
.btn:hover{background:var(--teal-deep);transform:translateY(-2px);box-shadow:0 14px 32px rgba(79,123,123,.4)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.chip{background:var(--paper-deep);border-radius:30px;padding:6px 14px;font-size:12.5px;color:var(--muted);font-weight:500}
iframe{max-width:100%;border:0;border-radius:16px;margin:22px 0;box-shadow:var(--shadow)}

.drow{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin:14px 0}
/* full-width stacked cards — used when a card layout contains an infographic/photo */
.stack{display:grid;grid-template-columns:1fr;gap:18px;margin:24px 0}
.stack>div{background:var(--paper-card);border:1px solid var(--line);border-radius:18px;padding:26px 30px;box-shadow:var(--shadow)}
.stack>div>*:first-child{margin-top:0}
.stack>div img{margin-top:16px;max-width:760px}
/* compact headings inside any card-like block (no section-divider rule, no big top gap) */
.content :is(.card,.cardplain,.iconcards,.steps,.quotecards,.stack) :is(h2,h3){font-size:18px;line-height:1.22;margin:0 0 8px;padding-top:0;color:var(--black)}
.content :is(.card,.cardplain,.iconcards,.steps,.quotecards,.stack) :is(h2,h3)::before{display:none}

/* full-bleed teal feature band */
.bandfull{width:100%;background:linear-gradient(150deg,var(--teal) 0%,var(--teal-deep) 100%);color:#fff;position:relative;overflow:hidden}
.bandfull::after{content:"";position:absolute;inset:0;background:var(--dash);opacity:.5;pointer-events:none}
.bandfull .band-in{position:relative;padding-block:clamp(48px,6vw,88px)}
.bandfull :is(h1,h2,h3,h4,p,li,strong,b){color:#fff}
.bandfull .eyebrow,.bandfull .band-title{color:#fff}.bandfull .eyebrow .rule{background:var(--olive)}
.bandfull a{color:#fff;border-bottom-color:rgba(255,255,255,.5)}
.bandfull ul li::before{background:var(--olive)}
.bandfull .card{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.22);backdrop-filter:blur(3px);box-shadow:none}
.bandfull .card:hover{background:rgba(255,255,255,.16)}
.bandfull .card .num{background:var(--olive);color:var(--teal-dk)}
.bandfull blockquote p{color:#fff}.bandfull blockquote{border-left-color:var(--olive)}
.bandfull .ico{filter:brightness(0) invert(1)}

/* prev / next + footer */
.pager{max-width:var(--wrap);margin:0 auto;padding:10px var(--gut) 60px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.pager a{flex:1 1 280px;background:var(--paper-card);border:1px solid var(--line);border-radius:16px;padding:20px 24px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.pager a:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.pager a span{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.pager a b{font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink)}
.pager a.next{text-align:right}
.sitefoot{background:var(--black);color:#cdc7bc}
.sitefoot .in{max-width:var(--wrap);margin:0 auto;padding:64px var(--gut) 50px;display:grid;grid-template-columns:1.7fr repeat(5,minmax(0,1fr));gap:36px}
.fbrand .tag{font-family:var(--script);font-size:24px;color:var(--olive);margin-top:8px}
.sitefoot h5{font-family:var(--body);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--taupe);margin:0 0 14px}
.sitefoot a{display:block;color:#cdc7bc;font-size:13.5px;padding:5px 0}.sitefoot a:hover{color:#fff}
.sitefoot .logo{height:30px;filter:brightness(0) invert(1);margin-bottom:16px}
.sitefoot .tag{font-family:var(--script);font-size:23px;color:var(--olive)}
.sitefoot .legal{max-width:var(--wrap);margin:0 auto;padding:22px var(--gut);border-top:1px solid rgba(255,255,255,.12);font-size:12px;color:#8c887e;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* ---------- search results dropdown ---------- */
.search-results{position:absolute;top:calc(100% + 8px);right:0;width:300px;background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;display:none;z-index:120}
.search-results.show{display:block}
.search-results a{display:block;padding:10px 13px;border-radius:9px;color:var(--ink);font-size:13.5px}
.search-results a:hover{background:var(--paper-deep)}
.search-results .nomatch{display:block;padding:11px 13px;color:var(--muted);font-size:13px}

/* ---------- landing hub ---------- */
.hero.home .hero-in{min-height:clamp(420px,58vh,580px)}
.hub{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hub-card{background:var(--paper-card);border:1px solid var(--line);border-radius:20px;padding:30px 32px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.hub-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.hub-card h3{font-family:var(--display);font-weight:700;font-size:21px;color:var(--teal-deep);margin:0 0 16px}
.hub-list a{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink)}
.hub-list a:last-child{border-bottom:0}.hub-list a:hover{color:var(--teal-deep)}
.hub-list .tag{font-size:8px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:5px;padding:1px 5px}
@media(max-width:980px){.hub{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.hub{grid-template-columns:1fr}}

/* ---------- motion ---------- */
.reveal{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js .reveal:not(.in){opacity:0;transform:translateY(26px)}
@media(prefers-reduced-motion:reduce){html.js .reveal:not(.in){opacity:1;transform:none}.reveal{transition:none}html{scroll-behavior:auto}}

/* ---------- responsive ---------- */
@media(max-width:1040px){
  .nav-menu{display:none}
  .band-in.two{grid-template-columns:1fr;gap:18px}.band-head{position:static}
}
@media(max-width:680px){
  .nav .search input{width:150px}.nav .kb-label{display:none}
  .grid2,.grid3,.grid4,.iconcards,.quotecards{grid-template-columns:1fr}
  .sitefoot .in{grid-template-columns:1fr 1fr}
}
