/* ============================================================
   ICONS Longevity Programme — Freeage
   Replica stylesheet
   ============================================================ */

/* ------------------------------------------------------------
   BRAND FONT — Canela (licensed, Commercial Type).
   Drop the licensed files into  ./fonts/  and these @font-face
   rules activate the real font automatically (Canela is already
   first in --font-serif). Until then the page falls back to
   Newsreader, which ships via Google Fonts. Expected filenames:
     fonts/Canela-Light.woff2   (weight 300)
     fonts/Canela-Regular.woff2 (weight 400)
   ------------------------------------------------------------ */
@font-face{
  font-family:'Canela'; font-style:normal; font-weight:300; font-display:swap;
  src:url('../fonts/Canela-Light.woff2') format('woff2'),
      url('../fonts/Canela-Light.woff')  format('woff');
}
@font-face{
  font-family:'Canela'; font-style:normal; font-weight:400; font-display:swap;
  src:url('../fonts/Canela-Regular.woff2') format('woff2'),
      url('../fonts/Canela-Regular.woff')  format('woff');
}

:root{
  /* exact brand tokens taken from the XD CSS panel */
  --sand:         #eae3d9;   /* --sand */
  --tan:          #b8a089;   /* --unnamed-color-b8a089 */
  --terracotta:   #c46a3a;   /* --unnamed-color-c46a3a (ASCENT accent) */
  --gold:         #c6a86b;   /* --gold */
  --ink:          #0a0d13;   /* --unnamed-color-0a0d13 (heading/dark) */

  --cream:        #eae3d7;
  --cream-2:      #e6ded1;
  --dark:         #0a0d13;
  --dark-2:       #15161b;
  --dark-3:       #1b1c22;
  --ink-soft:     #3a3a38;
  --cream-text:   #ece6db;
  --muted-light:  #b7b0a3;
  --gold-light:   #c8a673;
  --gold-deep:    #9c7d46;
  --line:         rgba(181,142,88,.45);

  /* Canela (brand) first; Newsreader is a free fallback that ships with the page */
  --font-serif: 'Canela', 'Canela Trial', 'Newsreader', 'Cormorant Garamond', Georgia, serif;
  --font-sans:  'Inter', -apple-system, 'Segoe UI', Roboto, sans-serif;

  --container: 1240px;
  --pad: clamp(20px, 5vw, 80px);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  font-weight:400;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
ul{ list-style:none; }
sup{ font-size:.5em; vertical-align:super; }

.container{ max-width:var(--container); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); width:100%; }

/* ---------- shared type ---------- */
.serif-h2{
  font-family:var(--font-serif);
  font-weight:300;
  font-size:clamp(2rem, 4.2vw, 3.4rem);
  line-height:1.05;
  letter-spacing:.018em;  /* XD: 1.69px @ 54px */
  color:var(--ink);
}
.serif-h2.light-h{ color:var(--cream-text); }
/* XD: section labels = Inter Medium 26px, letter-spacing 0.81px, uppercase, gold */
.eyebrow{
  font-family:var(--font-sans);
  font-size:clamp(1.05rem, 1.35vw, 1.45rem); letter-spacing:.03em; font-weight:500;
  color:var(--gold); text-transform:uppercase; margin-bottom:1.2rem;
}
.center{ text-align:center; }
.gold{ color:var(--gold); }
.brand-inline{
  font-family:var(--font-serif); font-weight:600; letter-spacing:.18em;
  font-size:1.05em;
}
.brand-inline.sm{ font-size:1em; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-sans); font-size:.78rem; font-weight:600;
  letter-spacing:.13em; text-transform:uppercase;
  padding:.95em 1.8em; cursor:pointer; border:1px solid transparent;
  transition:.25s ease; white-space:nowrap;
}
.btn-gold{ background:var(--gold-deep); color:#fff; }
.btn-gold:hover{ background:var(--gold); }
.btn-gold.sm{ padding:.7em 1.3em; font-size:.72rem; }
.btn-gold-outline{ background:transparent; border-color:var(--gold); color:var(--gold); }
.btn-gold-outline:hover{ background:var(--gold); color:#fff; }
.btn-outline-light{ background:transparent; border-color:rgba(255,255,255,.55); color:#fff; }
.btn-outline-light:hover{ background:rgba(255,255,255,.12); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(14,15,18,.55);
  backdrop-filter:saturate(120%) blur(6px);
  transition:background .3s ease;
}
.site-header.scrolled{ background:rgba(10,11,13,.92); }
.nav-inner{
  max-width:1500px; margin:0 auto; padding:0 clamp(20px,4vw,56px);
  height:78px; display:flex; align-items:center; gap:2rem;
}
.brand-mark{
  font-family:var(--font-serif); font-weight:600;
  font-size:1.6rem; letter-spacing:.32em; color:#fff; padding-left:.2em;
}
.brand-logo{ height:30px; width:auto; display:block; }
.freeage-logo{ height:19px; width:auto; display:inline-block; transform:translateY(4px); margin-left:.15em; }
/* tight-cropped ICONS wordmark: caps sit on the baseline, so size to the cap height */
.inline-logo{ height:.66em; width:auto; display:inline-block; vertical-align:baseline; transform:translateY(.02em); margin:0 .42em; }
.inline-logo.sm{ height:.78em; margin:0 .3em; }
.main-nav{ display:flex; align-items:center; gap:clamp(1.4rem,3vw,3rem); margin:0 auto; }
.nav-link{
  color:#e9e4da; font-size:.78rem; font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; position:relative; padding:.4em 0;
}
.nav-link:hover{ color:#fff; }
.nav-link.is-active{ color:var(--gold-light); }
.nav-link.is-active::after{
  content:""; position:absolute; left:0; right:0; bottom:-3px; height:1.5px; background:var(--gold);
}
.nav-search{
  background:none; border:none; color:#e9e4da; cursor:pointer; display:flex; padding:.3em;
}
.nav-search:hover{ color:#fff; }
.btn-join{
  border:1px solid rgba(255,255,255,.6); color:#fff; background:transparent;
  font-size:.74rem; padding:.8em 1.7em;
}
.btn-join:hover{ background:#fff; color:var(--dark); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ width:24px; height:2px; background:#fff; transition:.3s; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:760px; height:100vh; max-height:880px; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero-bg{
  position:absolute; inset:0;
  background:url('../images/hero.jpg') center right/cover no-repeat;
}
.hero-overlay{
  position:absolute; inset:0;
  /* XD: Rectangle 95 — linear-gradient(133deg,#000 0%,#5B5D61 0% alpha 100%), 80%, multiply */
  background:linear-gradient(133deg, rgba(0,0,0,.8) 0%, rgba(91,93,97,0) 100%);
  mix-blend-mode:multiply;
}
/* subtle left wash purely to keep the hero copy legible (matches the artboard read) */
.hero::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(10,13,19,.55) 0%, rgba(10,13,19,.12) 42%, transparent 66%);
}
.hero-content{ position:relative; z-index:2; padding-top:70px; }
.hero-title{
  /* XD spec: Canela Light 74px / 92px, letter-spacing 2.31px, at 1920px artboard */
  font-family:var(--font-serif); font-weight:300;
  font-size:clamp(2rem, 3.85vw, 4.6rem); line-height:1.16; letter-spacing:.03em;
}
.powered{
  margin-top:1.6rem; font-size:.82rem; letter-spacing:.2em; font-weight:500; color:#d9d2c5;
  display:flex; align-items:baseline; gap:.6rem; text-transform:uppercase;
}
.powered .freeage{ font-family:var(--font-serif); font-size:1.5rem; letter-spacing:0; color:var(--gold-light); text-transform:none; font-style:italic; }
.hero-sub{ margin-top:1.6rem; font-size:1.02rem; line-height:1.55; color:#ece7dd; font-weight:300; }
.hero-actions{ margin-top:2.1rem; display:flex; gap:1rem; flex-wrap:wrap; }
.hero-note{ margin-top:2.4rem; font-size:.84rem; color:#d6d0c5; display:flex; align-items:center; gap:.5rem; font-weight:300; }

.presignup{
  position:absolute; z-index:2; right:max(4vw,40px); bottom:0;
  width:min(310px, 80vw);
  background:linear-gradient(180deg, rgba(196,170,118,.92), rgba(170,142,92,.92));
  color:#241d10; padding:1.6rem 1.5rem 2rem; font-size:.92rem; line-height:1.5;
}
.presignup strong{ font-weight:700; }

/* ============================================================
   BIOLOGY / DASHBOARD
   ============================================================ */
.biology{ background:var(--cream); padding:clamp(48px,7vw,96px) 0; }
.biology-grid{ display:grid; grid-template-columns:0.85fr 1.4fr; gap:clamp(28px,4vw,56px); align-items:center; }
.biology-intro h2{ margin-bottom:1.5rem; }
.biology-intro p{ font-size:.98rem; color:var(--ink-soft); font-weight:300; line-height:1.7; max-width:34ch; }

.dash-cards{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.dash-card{ background:#0c0c0f; border-radius:14px; padding:1.5rem 1.6rem; color:var(--cream-text); }
.dash-label{ font-size:.66rem; letter-spacing:.18em; color:#8c8678; font-weight:600; margin-bottom:1rem; }
.progress-body{ display:flex; gap:1rem; }
.chart{ flex:1.3; min-width:0; }
.chart svg{ width:100%; height:120px; display:block; }
.chart-line{ stroke:var(--gold-light); stroke-width:2; }
.chart-dots circle{ fill:var(--gold-light); }
.chart-axis{ display:flex; justify-content:space-between; font-size:.5rem; color:#6f6a5e; letter-spacing:.05em; margin-top:.4rem; }
.progress-stats{ flex:.9; display:flex; flex-direction:column; gap:.85rem; }
.progress-stats li{ display:flex; flex-direction:column; line-height:1.15; }
.ps-name{ font-size:.62rem; color:#9a9486; letter-spacing:.05em; }
.ps-val{ font-size:1.15rem; font-weight:700; color:var(--gold-light); }
.ps-val em{ font-style:normal; font-size:.7rem; font-weight:500; }
.ps-sub{ font-size:.55rem; color:#6f6a5e; }

.metrics-card{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem 1.2rem; align-content:center; }
.metric .m-name{ font-size:.74rem; color:#bdb7a8; font-weight:400; margin-bottom:.35rem; }
.metric .m-big{ font-family:var(--font-serif); font-size:2.5rem; line-height:1; font-weight:500; }
.metric .m-big span{ font-size:.95rem; }
.metric .m-word{ font-weight:600; font-size:2rem; }
.metric .m-unit{ font-size:.66rem; color:#8c8678; margin-top:.2rem; }
.metric .m-tag{ font-size:.74rem; color:var(--gold-light); margin-top:.5rem; }

/* ============================================================
   PATHS
   ============================================================ */
.paths{ background:var(--dark); color:var(--cream-text); padding:clamp(56px,8vw,110px) 0; }
.paths-title{ margin-top:.4rem; margin-bottom:clamp(36px,5vw,64px); color:var(--cream-text); }
.paths-title .brand-inline{ color:#fff; }
.path-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; align-items:start; }

.path-card{ position:relative; border-radius:6px; overflow:hidden; display:flex; flex-direction:column; }
/* card body colours are matched exactly to the strip at the bottom of the photo
   export so the baked-in 118px badge straddles the photo/body seam invisibly */
.path-card.light{ background:rgb(240,237,234); color:var(--ink); }
.path-card.dark{ background:#000; color:var(--cream-text); }
/* photo = top of the authoritative card export: image + 118px badge + body strip */
.path-photo{ aspect-ratio:534/320; background-size:100% 100%; }
.path-body{ padding:.7rem 1.9rem 2rem; text-align:center; display:flex; flex-direction:column; flex:1; }
/* per-card accent colours sampled from the brand card exports */
.path-grid > .path-card:nth-child(1){ --accent:var(--tan);        --btn-fg:#2c2218; }
.path-grid > .path-card:nth-child(2){ --accent:var(--terracotta); --btn-fg:#fff; }
.path-grid > .path-card:nth-child(3){ --accent:var(--gold);       --btn-fg:#16110a; }

.path-name{ font-family:var(--font-serif); font-weight:300; font-size:2.4rem; letter-spacing:.05em; margin-top:0; color:var(--accent); }
.path-tagline{ font-size:.74rem; color:inherit; opacity:.72; letter-spacing:.02em; margin:.55rem 0 0; }
.path-head{ position:relative; font-size:.82rem; font-weight:600; letter-spacing:.05em; line-height:1.5; color:var(--accent); margin:1.4rem 0 1.3rem; padding-top:1.4rem; }
.path-head::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px; background:var(--accent); opacity:.38; }
.path-list{ text-align:left; display:flex; flex-direction:column; gap:.62rem; margin-bottom:1.6rem; }
.path-list li{ font-size:.82rem; font-weight:400; padding-left:1.15rem; position:relative; line-height:1.45; }
.path-card.light .path-list li{ color:#3a352e; }
.path-card.dark .path-list li{ color:#cdc6ba; }
.path-list li::before{ content:""; position:absolute; left:.1rem; top:.6em; width:4px; height:4px; border-radius:50%; background:var(--accent); }
.path-foot{ margin-top:auto; }
.path-foot::before{ content:""; display:block; width:100%; height:1px; background:var(--accent); opacity:.38; margin:0 auto 1.3rem; }
.path-dur{ display:flex; align-items:center; justify-content:center; gap:.5rem; font-size:.72rem; letter-spacing:.12em; opacity:.7; margin-bottom:.7rem; }
.path-price{ font-family:var(--font-serif); font-size:2.7rem; font-weight:300; color:var(--accent); line-height:1; }
.path-pay{ font-size:.72rem; opacity:.66; margin:.4rem 0 1.4rem; }
.path-foot .btn{ width:100%; background:var(--accent); border-color:var(--accent); color:var(--btn-fg); }
.path-foot .btn:hover{ filter:brightness(1.07); background:var(--accent); }

/* feature row */
.feature-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:clamp(40px,5vw,70px); padding-top:clamp(30px,4vw,46px); }
.feature{ display:flex; align-items:center; gap:1.3rem; padding-left:clamp(0px,2vw,30px); position:relative; }
.feature + .feature::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:1px; height:64px; background:rgba(198,168,107,.32); }
/* XD: each feature icon sits inside a thin gold ring */
.feature-ic{
  width:84px; height:84px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(198,168,107,.5); color:var(--gold);
}
.feature-ic svg{ width:40px; height:40px; }
.feature-txt h4{ font-size:.9rem; letter-spacing:.14em; font-weight:600; color:var(--gold-light); margin-bottom:.35rem; }
.feature-txt p{ font-size:.82rem; font-weight:300; color:var(--muted-light); line-height:1.4; }

/* ============================================================
   EXPERTS
   ============================================================ */
.experts{ background:var(--cream); padding:clamp(56px,8vw,104px) 0; }
.experts-grid{ display:grid; grid-template-columns:1fr 1.32fr; gap:clamp(28px,4vw,52px); align-items:center; }
.experts-intro h2{ margin-bottom:1.5rem; }
.experts-intro p{ font-size:.95rem; color:var(--ink-soft); font-weight:300; line-height:1.7; margin-bottom:1.1rem; max-width:36ch; }
.gold-divider{ display:block; width:190px; height:1px; background:var(--line); margin-top:1.4rem; }

.experts-cards{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.expert{
  position:relative; aspect-ratio:5/6; background-size:cover; background-position:center;
  border-radius:3px; overflow:hidden; filter:grayscale(100%) contrast(1.02);
}
.expert::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 45%, rgba(0,0,0,.82) 100%); }
.expert figcaption{ position:absolute; z-index:2; left:.7rem; right:.7rem; bottom:.7rem; color:#fff; display:flex; flex-direction:column; gap:.15rem; }
.expert figcaption strong{ font-size:.66rem; font-weight:600; letter-spacing:.02em; }
.expert figcaption span{ font-size:.56rem; font-weight:300; line-height:1.3; color:#d9d3c8; }

/* ============================================================
   MEMBERSHIP
   ============================================================ */
.membership{ position:relative; background:var(--dark); color:var(--cream-text); padding:clamp(56px,8vw,100px) 0 clamp(40px,5vw,70px); overflow:hidden; }
.membership-bg{
  position:absolute; inset:0;
  background:url('../images/membership-bg.jpg') center/cover no-repeat;
  opacity:.55;
}
.membership-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,15,18,.85), rgba(14,15,18,.95)); }
.membership-grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.15fr 1fr; gap:clamp(30px,5vw,70px); align-items:center; }

.card-stack{ position:relative; display:flex; justify-content:center; }
.member-card-img{ width:100%; max-width:560px; height:auto; filter:drop-shadow(0 26px 60px rgba(0,0,0,.55)); }
.member-card{
  border-radius:14px; padding:1.5rem 1.5rem; aspect-ratio:1.586/1; width:54%;
  box-shadow:0 24px 60px rgba(0,0,0,.55);
}
.member-card.front{
  background:linear-gradient(150deg,#1b1c20,#0c0d10); border:1px solid rgba(181,142,88,.35);
  display:flex; flex-direction:column; position:relative; z-index:2;
}
.member-card.details{
  background:linear-gradient(150deg,#17181c,#0a0b0e); border:1px solid rgba(181,142,88,.25);
  margin-left:-7%; margin-top:34px; z-index:1; padding:1.2rem 1.3rem;
}
.mc-top{ display:flex; justify-content:space-between; align-items:flex-start; }
.mc-brand{ font-family:var(--font-serif); letter-spacing:.28em; font-size:1.05rem; color:#fff; }
.mc-mark{ font-family:var(--font-serif); font-style:italic; color:var(--gold-light); font-size:1rem; }
.mc-prog{ font-size:.46rem; letter-spacing:.2em; color:#8c8678; margin-top:.15rem; }
.mc-tier{ font-family:var(--font-serif); font-size:2rem; letter-spacing:.22em; color:var(--gold-light); margin-top:auto; }
.mc-tier-sub{ font-size:.5rem; letter-spacing:.35em; color:#b7b0a3; margin-top:-.2rem; }
.mc-name{ font-size:.7rem; letter-spacing:.12em; color:#e8e2d6; margin-top:.9rem; }
.mc-foot{ display:flex; justify-content:space-between; align-items:flex-end; margin-top:.5rem; font-size:.46rem; letter-spacing:.14em; color:#8c8678; }
.mc-foot span:last-child{ text-align:right; color:var(--gold-light); line-height:1.3; }

.mc-brand2{ font-family:var(--font-serif); letter-spacing:.2em; font-size:.8rem; color:#fff; margin-bottom:.8rem; }
.mc-brand2 span{ font-size:.55rem; letter-spacing:.05em; color:var(--gold-light); font-family:var(--font-sans); }
.mc-detail-grid{ display:grid; grid-template-columns:1fr 1fr; gap:.45rem .8rem; }
.mc-detail-grid div{ display:flex; flex-direction:column; }
.dl{ font-size:.4rem; letter-spacing:.1em; color:#7c766a; }
.dv{ font-size:.62rem; color:#e6e0d4; letter-spacing:.04em; font-weight:500; }
.mc-qr-row{ display:flex; align-items:center; gap:.6rem; margin-top:.9rem; }
.mc-helix{ color:var(--gold-light); }
.mc-qr-text{ display:flex; flex-direction:column; flex:1; }
.mc-qr{
  width:38px; height:38px; flex-shrink:0;
  background-image:
    linear-gradient(45deg,#ddd 25%,transparent 25%),
    linear-gradient(-45deg,#ddd 25%,transparent 25%),
    linear-gradient(45deg,transparent 75%,#ddd 75%),
    linear-gradient(-45deg,transparent 75%,#ddd 75%);
  background-size:6px 6px; background-color:#fff; border:2px solid #fff;
}
.mc-fine{ font-size:.38rem; letter-spacing:.08em; color:#6f6a5e; margin-top:.8rem; line-height:1.4; }

.membership-text h2{ margin-bottom:1.3rem; letter-spacing:.03em; font-size:clamp(1.9rem,3.1vw,2.75rem); }  /* XD: 44px */
.membership-text p{ font-size:.98rem; font-weight:300; color:#cfc9bd; line-height:1.7; max-width:40ch; }

.membership-cta{ position:relative; z-index:2; text-align:center; margin-top:clamp(48px,7vw,90px); }
.big-cta{ font-size:clamp(1.9rem,3.1vw,2.75rem); letter-spacing:.03em; }  /* XD: 44px */
.cta-line{ margin-top:2rem; font-size:.95rem; color:#cfc9bd; display:inline-flex; align-items:center; gap:.8rem; flex-wrap:wrap; justify-content:center; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--dark); color:var(--cream-text); padding:clamp(40px,5vw,64px) 0 2.4rem; }
.footer-inner{ text-align:center; display:flex; flex-direction:column; align-items:center; gap:1.6rem; }
.footer-brand{ font-size:1.5rem; }
.brand-logo.footer-brand{ height:34px; }
.footer-nav{ display:flex; gap:clamp(1.6rem,4vw,3rem); flex-wrap:wrap; justify-content:center; }
.footer-nav a{ font-size:.74rem; letter-spacing:.16em; color:#cfc9bd; }
.footer-nav a:hover{ color:#fff; }
.footer-nav a.is-active{ color:var(--gold-light); }
.footer-rule{ width:100%; max-width:760px; height:1px; background:rgba(181,142,88,.25); }
.copyright{ font-size:.7rem; letter-spacing:.08em; color:#7c766a; }

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu{
  position:fixed; inset:0; z-index:49; background:rgba(10,11,13,.98);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2rem;
  transform:translateY(-100%); transition:transform .4s ease; visibility:hidden;
}
.mobile-menu.open{ transform:translateY(0); visibility:visible; }
.mobile-menu a{ color:#ece6db; font-size:1.1rem; letter-spacing:.16em; }
.mobile-menu .btn{ margin-top:1rem; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1040px){
  .biology-grid{ grid-template-columns:1fr; }
  .experts-grid{ grid-template-columns:1fr; }
  .membership-grid{ grid-template-columns:1fr; }
  .experts-cards{ grid-template-columns:repeat(4,1fr); }
  .presignup{ position:static; width:100%; margin-top:2rem; }
}
@media (max-width:860px){
  .main-nav, .btn-join{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-inner{ justify-content:space-between; }
  .path-grid{ grid-template-columns:1fr; max-width:460px; margin:0 auto; }
  .feature-row{ grid-template-columns:1fr; gap:1.6rem; }
  .feature + .feature::before{ display:none; }
  .feature{ padding-left:0; }
  .hero{ height:auto; min-height:0; padding:120px 0 0; max-height:none; }
  .hero .container{ padding-bottom:2rem; }
}
@media (max-width:680px){
  .dash-cards{ grid-template-columns:1fr; }
  .progress-body{ flex-direction:column; }
  .experts-cards{ grid-template-columns:repeat(2,1fr); }
  .card-stack{ flex-direction:column; align-items:center; }
  .member-card{ width:84%; max-width:340px; }
  .member-card.details{ margin-left:0; margin-top:-30px; }
  .metrics-card{ grid-template-columns:1fr 1fr; }
}
@media (max-width:420px){
  .hero-actions{ flex-direction:column; align-items:flex-start; }
  .hero-actions .btn{ width:100%; }
}
