/* ============================================================
   Omet Pharma — "Classification" design system
   Specimen-registry aesthetic · Swiss precision · Nordic calm
   Serif display + grotesque body + mono indices
   Orange = scarce punctuation only
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Hanken+Grotesk:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ink:#17211D;          /* near-black, faint pine */
  --ink-2:#43504A;
  --paper:#F2F3EF;        /* cool Nordic light */
  --surface:#FFFFFF;
  --sage:#BBD7D6;         /* primary colour surface (sampled) */
  --sage-2:#D2E2E0;       /* lighter sage tint */
  --sage-line:#9DBFBC;
  --pine:#2C4A42;         /* deep teal-green, secondary */
  --line:#D6D8D0;         /* hairline on paper */
  --line-2:#E4E5DF;
  --muted:#6B756F;
  --orange:#D9831A;       /* SCARCE accent only */

  --maxw:1280px;
  --pad:clamp(22px,5vw,80px);
  --gutter:clamp(20px,3vw,48px);

  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --f-mono:"IBM Plex Mono",ui-monospace,monospace;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);background:var(--paper);color:var(--ink);line-height:1.6;
  font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}

/* page-enter */
@keyframes pageIn{from{opacity:0}to{opacity:1}}
main{animation:pageIn .5s var(--ease) both}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:400;line-height:1.02;letter-spacing:-.018em}
.display{font-size:clamp(44px,7.5vw,108px);line-height:.96;letter-spacing:-.028em;font-weight:400}
.h-page{font-size:clamp(40px,6.5vw,88px);line-height:.98;letter-spacing:-.025em}
.h-sec{font-size:clamp(28px,4vw,46px);letter-spacing:-.02em}
.h-sub{font-size:clamp(22px,2.6vw,30px)}
.lead{font-size:clamp(16px,1.5vw,19px);color:var(--ink-2);max-width:58ch;line-height:1.65}
em{font-style:italic}
.serif-it{font-family:var(--f-display);font-style:italic;font-weight:400}

/* classification kicker — the recurring registry device */
.kicker{display:inline-flex;align-items:center;gap:12px;font-family:var(--f-mono);font-size:12px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--pine)}
.kicker .idx{color:var(--ink);border:1px solid var(--line);border-radius:2px;padding:3px 7px;
  font-size:11px;letter-spacing:.06em;background:var(--surface)}
.kicker .rule{flex:1;height:1px;background:var(--line);min-width:24px}
.mono{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;color:var(--muted)}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color .4s}
.site-header.scrolled{border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.brand{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--ink);white-space:nowrap}
.brand .logo-img{display:block;height:23px;width:auto}
.footer-top .brand .logo-img{height:28px}
.brand .b-omet{font-family:var(--f-display);font-weight:500;font-size:27px;letter-spacing:-.02em}
.brand .b-pharma{font-family:var(--f-body);font-weight:600;font-size:12.5px;letter-spacing:.26em;
  text-transform:lowercase;color:var(--ink);border-bottom:2px solid var(--orange);padding-bottom:3px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-family:var(--f-mono);font-size:12.5px;letter-spacing:.04em;text-decoration:none;
  color:var(--ink);position:relative;padding:6px 0;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--ink);
  transition:width .35s var(--ease)}
.nav-links a:hover::after{width:100%}
.nav-links a[aria-current="page"]{color:var(--ink)}
.nav-links a[aria-current="page"]::after{width:100%;background:var(--orange)}  /* scarce orange #1 */
.nav-links a:focus-visible{outline:2px solid var(--pine);outline-offset:4px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--ink)}

/* ---------- buttons / links ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--f-mono);font-size:13px;
  letter-spacing:.04em;text-decoration:none;cursor:pointer;padding:14px 24px;border-radius:2px;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);position:relative;overflow:hidden;
  isolation:isolate;transition:color .4s var(--ease)}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--pine);
  transform:translateY(101%);transition:transform .42s var(--ease)}
.btn:hover::before{transform:translateY(0)}
.btn:hover{border-color:var(--pine)}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn:focus-visible{outline:2px solid var(--pine);outline-offset:3px}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost::before{background:var(--ink)}
.btn.ghost:hover{color:var(--paper)}
.btn.on-dark{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn.on-dark::before{background:var(--sage)}
.btn.on-dark:hover{color:var(--ink);border-color:var(--sage)}
.link-arrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:13px;
  letter-spacing:.04em;text-decoration:none;color:var(--ink);transition:gap .3s var(--ease)}
.link-arrow .arr{transition:transform .3s var(--ease)}
.link-arrow:hover .arr{transform:translateX(5px)}
.link-arrow::before{content:"";width:18px;height:1px;background:var(--ink);transition:width .3s}
.link-arrow:hover::before{width:30px}

/* ---------- sections ---------- */
.section{padding:clamp(64px,9vw,124px) 0}
.section.tight{padding:clamp(48px,6vw,84px) 0}
.surface{background:var(--surface)}
.band-sage{background:var(--sage)}
.band-ink{background:var(--ink);color:var(--paper)}
.section-head{max-width:62ch;margin-bottom:clamp(34px,5vw,56px)}
.section-head .h-sec{margin-top:18px}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.09s}.d2{transition-delay:.18s}.d3{transition-delay:.27s}.d4{transition-delay:.36s}

/* ---------- hero (home) ---------- */
.hero{position:relative;padding:clamp(70px,11vw,140px) 0 clamp(50px,7vw,96px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.18fr .82fr;gap:clamp(30px,5vw,72px);align-items:center}
.hero h1{margin:26px 0 28px;max-width:13ch}
.hero .lead{max-width:46ch}
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.hero-anim>*{opacity:0;transform:translateY(16px);animation:heroUp .85s var(--ease) forwards}
.hero-anim>*:nth-child(1){animation-delay:.05s}
.hero-anim>*:nth-child(2){animation-delay:.16s}
.hero-anim>*:nth-child(3){animation-delay:.27s}
.hero-anim>*:nth-child(4){animation-delay:.38s}
@keyframes heroUp{to{opacity:1;transform:none}}

/* specimen card (replaces stock hero photo) */
.specimen{background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;
  opacity:0;transform:translateY(22px);animation:heroUp .9s .4s var(--ease) forwards}
.specimen .spec-top{display:flex;justify-content:space-between;align-items:center;
  padding:13px 18px;border-bottom:1px solid var(--line);font-family:var(--f-mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.specimen .spec-top .tick{width:7px;height:7px;border-radius:50%;background:var(--orange)} /* scarce orange #2 */
.specimen .key{padding:14px 18px 4px;background:linear-gradient(180deg,var(--sage-2),var(--surface))}
.specimen .spec-meta{padding:6px 18px 20px}
.spec-row{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line-2);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.02em}
.spec-row:last-child{border-bottom:none}
.spec-row .k{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:11px}
.spec-row .v{color:var(--ink);text-align:right}

/* taxonomic key svg */
.keysvg{width:100%;height:auto;display:block}
.keysvg .branch{fill:none;stroke:var(--pine);stroke-width:1.4;
  stroke-dasharray:600;stroke-dashoffset:600;animation:draw 2s .6s var(--ease) forwards}
.keysvg .node{fill:var(--sage);stroke:var(--pine);stroke-width:1.4;opacity:0;animation:pop .5s forwards}
.keysvg .node.term{fill:var(--orange);stroke:var(--orange)} /* scarce orange #3 */
.keysvg .nlabel{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.04em;fill:var(--ink-2);opacity:0;animation:fadein .6s forwards}
.keysvg .n1{animation-delay:.9s}.keysvg .n2{animation-delay:1.2s}.keysvg .n3{animation-delay:1.5s}.keysvg .n4{animation-delay:1.8s}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pop{to{opacity:1}}
@keyframes fadein{to{opacity:1}}

/* ---------- values grid (classified) ---------- */
.reg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);
  border-radius:4px;overflow:hidden;background:var(--line)}
.reg-cell{background:var(--paper);padding:28px 26px 30px;display:flex;flex-direction:column;gap:10px;min-height:190px}
.reg-cell .ci{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;color:var(--pine)}
.reg-cell h3{font-family:var(--f-display);font-weight:400;font-size:23px;margin-top:auto}
.reg-cell p{font-size:13.5px;color:var(--muted);line-height:1.5}

/* explore / nav cards */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter)}
.ncard{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:var(--surface);
  border:1px solid var(--line);border-radius:4px;padding:28px;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.ncard:hover{transform:translateY(-4px);box-shadow:0 18px 40px -26px rgba(23,33,29,.4)}
.ncard .ci{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;color:var(--pine);margin-bottom:auto}
.ncard h3{font-family:var(--f-display);font-weight:400;font-size:25px;margin:40px 0 8px}
.ncard p{font-size:14px;color:var(--muted);margin-bottom:18px}

/* ---------- therapeutic specimen grid (products) ---------- */
.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:4px;overflow:hidden}
.spec-card{background:var(--paper);padding:32px 30px;display:grid;grid-template-columns:auto 1fr;
  gap:24px;align-items:center;transition:background .4s var(--ease);min-height:170px}
.spec-card:hover{background:var(--surface)}
.spec-card .mark{width:74px;height:74px;flex:none}
.spec-card .meta .ci{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;color:var(--pine)}
.spec-card .meta h3{font-family:var(--f-display);font-weight:400;font-size:27px;margin-top:6px}
.gmark{fill:none;stroke:var(--ink);stroke-width:1.4}
.gmark .s{fill:var(--sage)}

.feature{padding:26px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:120px 1fr;gap:24px}
.feature:last-child{border-bottom:1px solid var(--line)}
.feature .fi{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;color:var(--pine);padding-top:5px}
.feature h3{font-family:var(--f-display);font-weight:400;font-size:22px;margin-bottom:8px}
.feature p{color:var(--ink-2);max-width:56ch}

/* ---------- accordion (safety) ---------- */
.accordion{border-top:1px solid var(--ink)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-trigger{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;
  align-items:center;gap:24px;padding:28px 4px;font-family:var(--f-display);font-weight:400;
  font-size:clamp(20px,2.5vw,29px);color:var(--ink);transition:color .3s}
.acc-trigger .ci{font-family:var(--f-mono);font-size:12px;letter-spacing:.1em;color:var(--pine);flex:none}
.acc-trigger .label{flex:1}
.acc-trigger .sign{position:relative;width:20px;height:20px;flex:none}
.acc-trigger .sign::before,.acc-trigger .sign::after{content:"";position:absolute;background:var(--ink);
  transition:transform .4s var(--ease),background .3s}
.acc-trigger .sign::before{left:0;top:9px;width:20px;height:2px}
.acc-trigger .sign::after{left:9px;top:0;width:2px;height:20px}
.acc-item.open .acc-trigger .sign::before{background:var(--orange)} /* scarce orange #4 */
.acc-item.open .acc-trigger .sign::after{transform:scaleY(0)}
.acc-trigger:hover{color:var(--pine)}
.acc-trigger:focus-visible{outline:2px solid var(--pine);outline-offset:3px}
.acc-panel{overflow:hidden;height:0;transition:height .45s var(--ease)}
.acc-inner{padding:0 4px 32px 64px;color:var(--ink-2);max-width:62ch}
.acc-inner p{margin-bottom:9px}
.acc-inner ol{margin:4px 0 14px 20px}
.acc-inner ol li{margin-bottom:5px}
.acc-inner a{color:var(--pine);text-decoration:underline;text-underline-offset:3px}
@media(max-width:600px){.acc-inner{padding-left:4px}}

/* ---------- team registry ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.2vw,32px)}
.member{display:flex;flex-direction:column}
.member .photo{position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--sage-2);border-radius:3px}
.member .photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.02);
  transition:transform .8s var(--ease)}
.member:hover .photo img{transform:scale(1.04)}
.member .ci{position:absolute;top:10px;left:10px;font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;
  background:var(--paper);color:var(--ink);padding:3px 7px;border-radius:2px}
.member .name{font-family:var(--f-display);font-weight:400;font-size:22px;margin-top:16px}
.member .role{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--pine);margin-top:5px}
.member .bio{font-size:13.5px;color:var(--muted);margin-top:11px;line-height:1.5}
.member .email{font-family:var(--f-mono);font-size:12px;margin-top:12px;display:inline-block;color:var(--ink);
  text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:2px;transition:border-color .3s,color .3s;word-break:break-all}
.member .email:hover{color:var(--pine);border-color:var(--pine)}

/* ---------- about ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,76px);align-items:center}
.split.lead-l{grid-template-columns:1.05fr .95fr}
.motto{background:var(--ink);color:var(--paper);border-radius:4px;padding:clamp(34px,5vw,60px);
  position:relative;overflow:hidden}
.motto .kicker{color:var(--sage)}.motto .kicker .idx{background:transparent;color:var(--sage);border-color:rgba(187,215,214,.4)}
.motto .latin{font-family:var(--f-display);font-style:italic;font-size:clamp(28px,4.4vw,52px);line-height:1.05;
  margin:18px 0 8px;color:var(--paper)}
.motto .trans{font-family:var(--f-mono);font-size:13px;letter-spacing:.06em;color:var(--sage)}
.motto .keysvg .branch{stroke:rgba(187,215,214,.55)}
.motto .keysvg .node{fill:var(--pine);stroke:var(--sage)}
.motto .keysvg .node.term{fill:var(--orange);stroke:var(--orange)}
.motto .keysvg .nlabel{fill:rgba(242,243,239,.7)}

.quote{font-family:var(--f-display);font-weight:300;font-size:clamp(19px,2.1vw,25px);line-height:1.5;
  color:var(--ink);max-width:64ch}
.quote .hl{font-style:italic;color:var(--pine)}
.quote-cite{font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;font-style:normal;
  margin-top:22px;display:block;color:var(--muted)}

/* timeline */
.timeline{position:relative;margin-top:46px}
.timeline .track{position:absolute;left:0;right:0;top:7px;height:1px;background:var(--line)}
.timeline .track-fill{position:absolute;left:0;top:7px;height:1px;width:0;background:var(--pine);
  transition:width 1.5s var(--ease)}
.timeline.in .track-fill{width:100%}
.tl-row{display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.tl-step{position:relative;padding-top:34px}
.tl-step .dot{position:absolute;top:1px;left:0;width:14px;height:14px;border-radius:50%;background:var(--paper);
  border:2px solid var(--pine);transform:scale(0);transition:transform .5s var(--ease)}
.timeline.in .tl-step .dot{transform:scale(1)}
.timeline.in .tl-step:nth-child(2) .dot{transition-delay:.3s}
.timeline.in .tl-step:nth-child(3) .dot{transition-delay:.6s}
.timeline.in .tl-step:nth-child(4) .dot{transition-delay:.9s}
.timeline.in .tl-step:nth-child(5) .dot{transition-delay:1.2s}
.tl-step:last-child .dot{border-color:var(--orange);background:var(--orange)} /* scarce orange: the 'now' */
.tl-step .yr{font-family:var(--f-display);font-size:30px}
.tl-step ul{list-style:none;margin-top:8px}
.tl-step li{font-family:var(--f-mono);font-size:12.5px;color:var(--ink-2);padding-left:16px;position:relative;margin-bottom:6px;line-height:1.4}
.tl-step li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;background:var(--sage-line)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,70px);align-items:start}
.contact-block{margin-bottom:30px}
.contact-block .lbl{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--pine);margin-bottom:10px}
.contact-block a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line);transition:border-color .3s,color .3s}
.contact-block a:hover{color:var(--pine);border-color:var(--pine)}
.contact-block p{color:var(--ink-2);margin:2px 0}
.offices{display:grid;grid-template-columns:1fr 1fr;gap:28px 34px;margin-top:20px}
.office h3{font-family:var(--f-display);font-weight:400;font-size:21px;margin-bottom:6px}
.office .code{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;color:var(--pine);margin-bottom:4px}
.office p{font-family:var(--f-mono);font-size:12.5px;color:var(--ink-2);margin:1px 0}

/* markets registry (replaces stock map) */
.markets{background:var(--sage);border-radius:4px;padding:clamp(26px,3vw,38px);position:relative;overflow:hidden}
.markets .kicker{color:var(--pine)}
.markets .grat{position:absolute;inset:0;opacity:.5;pointer-events:none}
.markets-list{list-style:none;position:relative;z-index:2;margin-top:18px}
.markets-list li{display:flex;align-items:baseline;gap:14px;padding:13px 0;border-bottom:1px solid var(--sage-line);
  font-family:var(--f-mono);font-size:13px;letter-spacing:.04em;color:var(--ink)}
.markets-list li:last-child{border-bottom:none}
.markets-list .iso{color:var(--pine);font-weight:500;width:34px}
.markets-list .nm{flex:1}
.markets-list .st{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.markets-list .st.live::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--pine);margin-right:7px;vertical-align:middle}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#A9B6B0;padding:clamp(54px,7vw,88px) 0 40px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-top .brand{color:var(--paper)}
.footer-top .brand .b-pharma{color:#8DA39D}
.footer-note{font-family:var(--f-mono);font-size:12px;color:#8DA39D;margin-top:18px;max-width:34ch;line-height:1.7}
.site-footer h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#7C928C;margin-bottom:16px}
.site-footer ul{list-style:none}.site-footer li{margin-bottom:9px}
.site-footer a{color:#A9B6B0;text-decoration:none;font-size:14px;transition:color .3s}
.site-footer a:hover{color:var(--sage)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:30px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:#7C928C}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .reg-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .tl-row{grid-template-columns:1fr 1fr;gap:30px}
  .timeline .track,.timeline .track-fill{display:none}
}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr}
  .specimen{max-width:440px}
  .cards3{grid-template-columns:1fr}
  .spec-grid{grid-template-columns:1fr}
  .split,.split.lead-l{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .nav-links{position:fixed;inset:78px 0 auto 0;background:var(--paper);flex-direction:column;gap:0;
    border-bottom:1px solid var(--line);transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity .3s,transform .3s;padding:6px 0}
  .nav-links.open{opacity:1;transform:none;pointer-events:auto}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:15px var(--pad);font-size:14px}
  .nav-links a::after{display:none}
  .nav-toggle{display:block}
}
@media(max-width:560px){
  .reg-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr;gap:16px}
  .offices{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .feature{grid-template-columns:1fr;gap:8px}
  .member .name{font-size:19px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero-anim>*,.specimen{opacity:1!important;transform:none!important}
  .keysvg .branch{stroke-dashoffset:0!important}.keysvg .node,.keysvg .nlabel{opacity:1!important}
  .timeline .track-fill{width:100%!important}.tl-step .dot{transform:scale(1)!important}
}
