/* =====================================================================
   MEDPHI Laboratory :: stylesheet
   Identity: deep ink base, disciplined tri-colour gradient (PWr red ->
   violet -> cyan), membrane-bilayer signature divider, computational
   typography (Space Grotesk / Inter / JetBrains Mono).
   ===================================================================== */

:root{
  /* surfaces */
  --ink:#05070e; --bg:#080b15; --bg2:#0c1122;
  --panel:rgba(255,255,255,.055); --panel-2:rgba(255,255,255,.09);
  --stroke:rgba(255,255,255,.12); --stroke-2:rgba(255,255,255,.2);

  /* text */
  --text:#f6f9ff; --soft:#e4ecff; --muted:#9aa4bd; --faint:#6b7593;

  /* identity */
  --red:#e30613; --violet:#7b2cff; --cyan:#00d4ff; --mint:#33df9a; --amber:#ffbc42;
  --grad:linear-gradient(115deg,var(--red),var(--violet) 50%,var(--cyan));

  /* type */
  --font-display:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;
  --font-body:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;

  --shadow:0 32px 80px rgba(0,0,0,.45);
  --radius:20px; --radius-lg:30px; --radius-xl:40px;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--text); background:var(--bg);
  font-family:var(--font-body); line-height:1.62; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
/* ambient field */
body::before{
  content:""; position:fixed; inset:0; z-index:-3;
  background:
    radial-gradient(60vw 50vh at 15% 8%, rgba(227,6,19,.18), transparent 55%),
    radial-gradient(55vw 45vh at 85% 12%, rgba(0,212,255,.18), transparent 52%),
    radial-gradient(60vw 55vh at 60% 92%, rgba(123,44,255,.16), transparent 55%),
    linear-gradient(160deg,#05070d,#0a0e1d 45%,#0e0a1c);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-2; opacity:.32;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:62px 62px;
  -webkit-mask-image:radial-gradient(circle at 50% 22%,#000,transparent 78%);
  mask-image:radial-gradient(circle at 50% 22%,#000,transparent 78%);
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.container{width:min(var(--max),calc(100% - 44px)); margin-inline:auto}
.section{padding:104px 0}
.section--tight{padding:64px 0}

/* ---------- type helpers ---------- */
h1,h2,h3,.display{font-family:var(--font-display); letter-spacing:-.03em; font-weight:700}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:.72rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--cyan);
}
.eyebrow::before{content:""; width:26px; height:2px; border-radius:99px; background:var(--grad)}
.gradient-text{
  background:linear-gradient(100deg,var(--red),#fff 32%,var(--cyan) 78%,#fff);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.lead{font-size:clamp(1.05rem,1.5vw,1.26rem); color:var(--soft); max-width:62ch}
.muted{color:var(--muted)}
.mono{font-family:var(--font-mono)}

/* ---------- membrane signature divider ---------- */
.membrane{display:block; width:100%; height:34px; opacity:.5; color:var(--cyan)}
.membrane svg{width:100%; height:100%; display:block}

/* ---------- nav ---------- */
.nav{position:fixed; top:16px; left:0; right:0; z-index:100}
.nav__inner{
  width:min(1230px,calc(100% - 28px)); margin:auto;
  padding:9px 10px 9px 16px; display:flex; align-items:center;
  justify-content:space-between; gap:14px;
  border:1px solid var(--stroke); border-radius:18px;
  background:rgba(7,10,19,.62); backdrop-filter:blur(20px);
  box-shadow:0 16px 50px rgba(0,0,0,.3); transition:background .25s ease;
}
.brand{display:flex; align-items:center; gap:12px; font-family:var(--font-display); font-weight:700; letter-spacing:-.02em}
.brand__mark{
  width:40px; height:40px; border-radius:12px; background:var(--grad);
  display:grid; place-items:center; box-shadow:0 0 30px rgba(0,212,255,.25); flex:0 0 auto;
}
.brand__mark span{
  background:var(--ink); border-radius:9px; width:32px; height:32px;
  display:grid; place-items:center; font-weight:700; font-size:1.05rem;
}
.brand__name{line-height:1}
.brand__sub{font-family:var(--font-mono); font-size:.66rem; color:var(--muted); display:block; margin-top:3px; letter-spacing:.02em; font-weight:500}
.nav__links{display:flex; gap:2px; align-items:center}
.nav__links a{padding:9px 13px; border-radius:11px; color:var(--soft); font-weight:600; font-size:.91rem; transition:background .18s}
.nav__links a:hover,.nav__links a[aria-current="page"]{background:rgba(255,255,255,.08)}
.nav__actions{display:flex; gap:8px; align-items:center}
.btn,.lang-btn{
  font-family:var(--font-body); border:1px solid var(--stroke-2);
  background:rgba(255,255,255,.06); color:var(--text); border-radius:12px;
  padding:11px 16px; font-weight:650; cursor:pointer; display:inline-flex;
  gap:9px; align-items:center; justify-content:center; transition:.18s ease;
}
.btn:hover,.lang-btn:hover{transform:translateY(-2px); background:rgba(255,255,255,.12); border-color:var(--stroke-2)}
.lang-btn{font-family:var(--font-mono); font-size:.8rem; letter-spacing:.05em; padding:10px 13px}
.btn--primary{border:0; background:var(--grad); box-shadow:0 12px 32px rgba(123,44,255,.34); font-weight:700}
.btn--ghost{background:transparent}
.btn--sm{padding:9px 13px; font-size:.86rem}
.menu{display:none; border:0; background:rgba(255,255,255,.09); width:42px; height:42px; border-radius:12px; color:var(--text); font-size:1.2rem; cursor:pointer}

/* ---------- hero ---------- */
.hero{min-height:100svh; padding:140px 0 64px; display:grid; align-items:center; position:relative}
.hero__grid{display:grid; grid-template-columns:1.08fr .92fr; gap:46px; align-items:center}
.hero h1{font-size:clamp(3.1rem,7.6vw,7.2rem); line-height:.9; margin:18px 0 14px}
.hero__subtitle{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(1.2rem,2.4vw,2.1rem); line-height:1.08; letter-spacing:-.02em;
  margin:0 0 20px; max-width:20ch;
}
.hero__cta{display:flex; gap:13px; flex-wrap:wrap; margin-top:30px}
.hero__meta{display:flex; gap:10px; flex-wrap:wrap; margin-top:34px}
.pill{
  font-family:var(--font-mono); font-size:.78rem; font-weight:500;
  border:1px solid var(--stroke); background:rgba(255,255,255,.05);
  padding:8px 12px; border-radius:10px; color:var(--soft);
}
.hero__visual{position:relative; min-height:540px}
.hero-card{
  position:absolute; z-index:1; border:1px solid var(--stroke);
  background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.04));
  box-shadow:var(--shadow); backdrop-filter:blur(16px);
  border-radius:var(--radius-xl); overflow:hidden;
}
.hero-card--main{inset:30px 0 auto 64px; height:430px}
.hero-card--main img{width:100%; height:100%; object-fit:cover; filter:saturate(1.05) contrast(1.06)}
.hero-card--main::after{content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(5,7,14,.82),transparent 56%),linear-gradient(90deg,rgba(5,7,14,.5),transparent 60%)}
.hero-card__caption{position:absolute; left:auto; right:14px; bottom:14px; z-index:4; max-width:52%; text-align:right;
  background:rgba(8,11,21,.9); backdrop-filter:blur(10px);
  padding:9px 13px; border-radius:13px; border:1px solid rgba(255,255,255,.12); box-shadow:0 10px 30px rgba(0,0,0,.45)}
.hero-card__caption strong{font-family:var(--font-display); font-size:1.0rem; line-height:1.14; display:block}
.hero-card__caption .muted{font-family:var(--font-mono); font-size:.72rem; margin-top:2px; display:block}
.floating{
  position:absolute; z-index:3; border:1px solid var(--stroke);
  background:rgba(7,10,19,.72); backdrop-filter:blur(16px);
  border-radius:18px; padding:16px; box-shadow:0 20px 56px rgba(0,0,0,.4);
}
.floating--protein{left:0; bottom:18px; width:256px}
.floating--protein img{filter:drop-shadow(0 18px 30px rgba(0,212,255,.26))}
.floating--protein .muted{font-family:var(--font-mono); font-size:.72rem; margin-top:4px}
.floating--metric{right:6px; top:0; width:212px}
.metric-number{font-family:var(--font-display); font-size:2.5rem; line-height:1; font-weight:700; letter-spacing:-.05em}
.floating--metric .muted{font-size:.82rem; margin-top:4px}
.orb{position:absolute; border-radius:50%; background:var(--grad); opacity:.85; z-index:0}
.orb--1{width:96px; height:96px; left:-24px; top:150px; filter:blur(2px)}
.orb--2{width:42px; height:42px; left:30px; top:14px}
.scroll-cue{position:absolute; left:50%; bottom:22px; transform:translateX(-50%); font-family:var(--font-mono); color:var(--muted); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase}
.scroll-cue::after{content:""; display:block; width:1px; height:38px; background:linear-gradient(var(--cyan),transparent); margin:9px auto 0}

/* ---------- logo strip ---------- */
.logo-strip{padding:22px 0; border-block:1px solid var(--stroke); background:rgba(255,255,255,.02)}
.logo-strip__inner{display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap}
.institution{display:flex; align-items:center; gap:13px; font-family:var(--font-display); font-weight:600}
.institution img{width:44px; height:44px; border-radius:11px}
.institution span{display:block; font-family:var(--font-body); color:var(--muted); font-size:.84rem; font-weight:500}
.mini-kpis{display:flex; gap:9px; flex-wrap:wrap}
.mini-kpi{font-family:var(--font-mono); font-size:.78rem; border:1px solid var(--stroke); padding:9px 13px; border-radius:11px; color:var(--soft); background:rgba(255,255,255,.04)}

/* ---------- section heads ---------- */
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:36px; margin-bottom:40px}
.section-head h2{font-size:clamp(2.1rem,4.4vw,3.9rem); line-height:.98; margin:12px 0 0; max-width:18ch}
.section-head p{max-width:38ch; color:var(--muted); margin:0}

/* ---------- cards / grids ---------- */
.grid{display:grid; gap:20px}
.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  position:relative; overflow:hidden; border:1px solid var(--stroke);
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.035));
  border-radius:var(--radius); padding:26px; box-shadow:0 18px 56px rgba(0,0,0,.22);
}
.card::before{
  content:""; position:absolute; inset:0; border-radius:inherit; opacity:0; transition:.28s;
  background:radial-gradient(circle at 18% 0,rgba(0,212,255,.16),transparent 34%),radial-gradient(circle at 84% 8%,rgba(227,6,19,.13),transparent 34%);
}
.card:hover::before{opacity:1}
.card>*{position:relative}
.card h3{font-size:1.3rem; line-height:1.2; margin:14px 0 10px}
.card p{color:var(--muted); margin:0}
.icon{
  width:48px; height:48px; border-radius:14px; background:var(--grad);
  display:grid; place-items:center; font-family:var(--font-mono); font-weight:600;
  font-size:.92rem; box-shadow:0 14px 34px rgba(0,212,255,.2);
}
.tag-row{display:flex; flex-wrap:wrap; gap:7px; margin-top:16px}
.tag{font-family:var(--font-mono); font-size:.72rem; font-weight:500; border:1px solid var(--stroke); background:rgba(255,255,255,.05); border-radius:8px; padding:6px 9px; color:var(--soft)}

/* ---------- about / feature ---------- */
.large-feature{display:grid; grid-template-columns:.92fr 1.08fr; gap:22px; align-items:stretch}
.feature-img{border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--stroke); min-height:420px; background:#0f1626}
.feature-img img{width:100%; height:100%; object-fit:cover}
.feature-copy{padding:34px}
.feature-copy h3{font-size:1.4rem; margin:22px 0 10px}

/* ---------- pipeline (real ordered sequence -> numbered) ---------- */
.pipeline{display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:12px; margin-top:22px; counter-reset:step}
.step{position:relative; min-height:158px; border:1px solid var(--stroke); border-radius:18px; background:rgba(255,255,255,.045); padding:20px; counter-increment:step}
.step::before{content:"0" counter(step); font-family:var(--font-mono); font-size:.74rem; color:var(--cyan); letter-spacing:.1em}
.step b{display:block; font-family:var(--font-mono); color:var(--soft); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin:8px 0 10px; font-weight:600}
.step strong{display:block; font-family:var(--font-display); font-weight:500; font-size:1.02rem; line-height:1.22}
.step:not(:last-child)::after{content:"→"; position:absolute; right:-13px; top:50%; transform:translateY(-50%); color:var(--cyan); font-weight:700; font-size:1.5rem; z-index:2}

/* ---------- programmes (NOT a sequence -> domain labels, no big numerals) ---------- */
.programme{display:flex; flex-direction:column; min-height:236px}
.programme__label{font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--cyan)}
.programme h3{font-size:1.32rem; margin:10px 0 8px}
.programme .tag-row{margin-top:auto; padding-top:18px}

/* ---------- outputs / publications ---------- */
.publication{display:flex; gap:15px; align-items:flex-start}
.publication__year{flex:0 0 auto; font-family:var(--font-mono); font-weight:600; font-size:.84rem; border:1px solid var(--stroke); background:rgba(255,255,255,.05); border-radius:11px; padding:9px 11px; color:var(--cyan)}
.publication h3{font-size:1.06rem; margin:0 0 6px; line-height:1.25}
.publication a.doi{font-family:var(--font-mono); font-size:.76rem; color:var(--cyan); display:inline-block; margin-top:8px}
.publication a.doi:hover{text-decoration:underline}

/* ---------- team grid (home + index) ---------- */
.team-lead{display:grid; grid-template-columns:340px 1fr; gap:24px; align-items:stretch; margin-bottom:20px}
.portrait{border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--stroke); background:rgba(255,255,255,.06); min-height:440px}
.portrait img{height:100%; width:100%; object-fit:cover; object-position:center}
.bio-card h3{font-size:clamp(1.8rem,2.6vw,2.7rem); line-height:1.02; margin:8px 0 6px}
.bio-card .role{font-family:var(--font-mono); color:var(--cyan); font-size:.9rem; margin:0 0 16px}

.people-grid{display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px}
.person{
  display:flex; flex-direction:column; gap:14px; padding:22px;
  border:1px solid var(--stroke); border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.03));
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease; position:relative; overflow:hidden;
}
.person:hover{transform:translateY(-4px); border-color:var(--stroke-2); box-shadow:0 22px 60px rgba(0,0,0,.36)}
.person:focus-visible{outline:2px solid var(--cyan); outline-offset:3px}
.person__top{display:flex; align-items:center; gap:14px}
.monogram{
  width:54px; height:54px; flex:0 0 auto; border-radius:15px; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:700; font-size:1.18rem; color:#fff;
  box-shadow:0 12px 28px rgba(0,0,0,.4);
}
.monogram--photo{padding:0; overflow:hidden}
.monogram--photo img{width:100%; height:100%; object-fit:cover}
.person__name{font-family:var(--font-display); font-weight:600; font-size:1.08rem; line-height:1.12}
.person__role{font-family:var(--font-mono); color:var(--muted); font-size:.76rem; margin-top:3px}
.person__tag{color:var(--muted); font-size:.92rem; line-height:1.45}
.person__cue{margin-top:auto; font-family:var(--font-mono); font-size:.74rem; color:var(--cyan); letter-spacing:.04em; display:inline-flex; align-items:center; gap:6px}
.person:hover .person__cue{gap:10px}

/* ---------- member page ---------- */
.member-hero{padding:128px 0 0}
.crumb{font-family:var(--font-mono); font-size:.78rem; color:var(--muted); display:inline-flex; gap:8px; align-items:center; margin-bottom:26px}
.crumb a{color:var(--cyan)}
.crumb a:hover{text-decoration:underline}
.member-head{display:grid; grid-template-columns:auto 1fr; gap:26px; align-items:center}
.member-portrait{
  width:160px; height:160px; flex:0 0 auto; border-radius:26px; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:700; font-size:3rem; color:#fff;
  box-shadow:0 24px 60px rgba(0,0,0,.5); overflow:hidden;
}
.member-portrait img{width:100%; height:100%; object-fit:cover}
.member-head h1{font-size:clamp(2.3rem,5vw,4rem); line-height:.98; margin:6px 0 10px}
.member-prefix{font-family:var(--font-mono); font-size:.84rem; color:var(--muted); letter-spacing:.04em}
.member-role{font-family:var(--font-mono); color:var(--cyan); font-size:.96rem; margin:0}
.member-tagline{font-family:var(--font-display); font-weight:500; font-size:clamp(1.05rem,1.8vw,1.4rem); color:var(--soft); margin:14px 0 0; max-width:40ch}

.member-grid{display:grid; grid-template-columns:1.55fr .85fr; gap:24px; align-items:start; margin-top:14px}
.prose p{color:var(--soft); margin:0 0 16px; font-size:1.04rem}
.prose p:last-child{margin-bottom:0}
.block-title{font-family:var(--font-mono); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cyan); margin:0 0 16px}

.facts{display:grid; gap:0}
.fact{display:flex; justify-content:space-between; gap:16px; padding:13px 0; border-bottom:1px solid var(--stroke)}
.fact:last-child{border-bottom:0}
.fact dt{font-family:var(--font-mono); font-size:.76rem; color:var(--muted); letter-spacing:.04em}
.fact dd{margin:0; text-align:right; font-weight:600; font-size:.94rem}

.links-list{display:flex; flex-direction:column; gap:9px}
.link-chip{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:13px 15px; border:1px solid var(--stroke); border-radius:13px;
  background:rgba(255,255,255,.04); transition:.18s; font-weight:600; font-size:.92rem;
}
.link-chip:hover{transform:translateY(-2px); border-color:var(--stroke-2); background:rgba(255,255,255,.08)}
.link-chip span.k{font-family:var(--font-mono); font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--cyan)}
.link-chip .v{color:var(--soft); font-family:var(--font-mono); font-size:.82rem; word-break:break-all}

.pub-list{display:flex; flex-direction:column; gap:14px; margin-top:6px}
.pub{padding:18px 20px; border:1px solid var(--stroke); border-radius:15px; background:rgba(255,255,255,.035)}
.pub p{margin:0; color:var(--soft); font-size:.96rem; line-height:1.5}
.pub a.doi{font-family:var(--font-mono); font-size:.76rem; color:var(--cyan); display:inline-block; margin-top:8px}
.pub a.doi:hover{text-decoration:underline}

.member-nav{display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; margin-top:8px}

/* ---------- alumni ---------- */
.alumni{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:16px}
.alumnus{padding:20px; border:1px dashed var(--stroke-2); border-radius:var(--radius); background:rgba(255,255,255,.025)}
.alumnus strong{font-family:var(--font-display); font-size:1.08rem}
.alumnus p{color:var(--muted); font-size:.9rem; margin:8px 0 0}

/* ---------- contact ---------- */
.contact-panel{display:grid; grid-template-columns:1.1fr .9fr; gap:20px}
.contact-cta{padding:42px; border-radius:var(--radius-xl); border:1px solid var(--stroke); background:linear-gradient(135deg,rgba(227,6,19,.15),rgba(123,44,255,.12),rgba(0,212,255,.13)); box-shadow:var(--shadow)}
.contact-cta h2{font-size:clamp(2.2rem,4.4vw,4rem); line-height:.96; margin:0 0 18px}
.contact-list{display:grid; gap:12px}
.contact-item{padding:18px; border:1px solid var(--stroke); border-radius:16px; background:rgba(255,255,255,.045)}
.contact-item b{display:block; font-family:var(--font-mono); color:var(--cyan); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:5px}
.contact-item a,.contact-item span{font-weight:600; color:var(--soft)}
.contact-item a:hover{text-decoration:underline}

/* ---------- footer ---------- */
.footer{padding:32px 0 46px; color:var(--muted); border-top:1px solid var(--stroke)}
.footer__inner{display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap}
.footer strong{font-family:var(--font-display)}
.footer a{color:var(--soft); font-weight:600}
.footer a:hover{text-decoration:underline}
.source-note{font-family:var(--font-mono); font-size:.78rem; color:var(--faint)}

/* ---------- reveal ---------- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1; transform:none}

/* ---------- focus ---------- */
:focus-visible{outline:2px solid var(--cyan); outline-offset:2px; border-radius:6px}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .hero__grid,.large-feature,.team-lead,.contact-panel,.member-grid,.member-head{grid-template-columns:1fr}
  .member-head{justify-items:start}
  .hero__visual{min-height:520px}
  .hero-card--main{left:18px}
  .grid--4,.people-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid--3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .pipeline{grid-template-columns:1fr}
  .step:not(:last-child)::after{display:none}
  .section-head{display:block}
  .section-head p{margin-top:16px}
  .fact dd{text-align:left}
  .nav__links{position:fixed; left:14px; right:14px; top:78px; display:none; flex-direction:column; padding:16px; border:1px solid var(--stroke); border-radius:18px; background:rgba(6,8,15,.95); backdrop-filter:blur(22px)}
  .nav__links.is-open{display:flex}
  .nav__links a{width:100%; text-align:center}
  .menu{display:block}
  .nav__actions .btn{display:none}
}
@media (max-width:680px){
  .container{width:min(100% - 28px,var(--max))}
  .section{padding:74px 0}
  .hero{padding-top:116px}
  .hero h1{font-size:3.6rem}
  .hero__visual{min-height:460px}
  .hero-card--main{inset:26px 0 auto 0; height:344px}
  .floating--protein{width:198px; bottom:14px}
  .floating--metric{width:182px}
  .grid--2,.grid--3,.grid--4,.people-grid{grid-template-columns:1fr}
  .card{padding:22px}
  .feature-copy,.contact-cta{padding:26px}
  .member-portrait{width:120px; height:120px; font-size:2.2rem}
  .brand__sub{display:none}
  .footer__inner{display:block}
  .footer__inner p{margin:8px 0}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important; transition:none!important; animation:none!important}
  .reveal{opacity:1; transform:none}
}
