/* ============================================================
   GLOW LAB BANDUNG — Skin Formula Notebook
   Source Serif 4 + Manrope + IBM Plex Mono
   Clinical white + lab mint + neon pink + lilac
   ============================================================ */

:root{
  /* palette */
  --bg:            #fbfaf6;
  --paper:         #fdfdfa;
  --cream:         #f3eee2;
  --ink:           #0f1218;
  --ink-2:         #2a2f38;
  --gray:          #a4a8af;
  --line:          rgba(15,18,24,.12);
  --line-2:        rgba(15,18,24,.06);

  /* accents */
  --mint:          #7be0a3;
  --mint-deep:     #2eb877;
  --pink:          #f25f99;
  --pink-deep:     #c63f7d;
  --lilac:         #a48fe6;
  --lilac-soft:    #e8e2fb;
  --mint-soft:     #ddf6e7;
  --pink-soft:     #ffe3ee;

  /* typography */
  --serif:         'Source Serif 4', 'Times New Roman', serif;
  --sans:          'Manrope', system-ui, -apple-system, sans-serif;
  --mono:          'IBM Plex Mono', ui-monospace, monospace;

  /* layout */
  --container:     1240px;
  --gutter:        clamp(20px, 4vw, 56px);
  --radius:        16px;
  --radius-sm:     10px;
  --shadow:        0 16px 40px -22px rgba(15,18,24,.30);
  --shadow-soft:   0 4px 18px -10px rgba(15,18,24,.18);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--mint-deep);font-family:var(--serif);font-weight:500}
.display em, h1 em, h2 em, h3 em{color:var(--pink-deep)}
.kicker em, .ts-card em, .lede em, p em{color:var(--mint-deep)}

.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

/* ============== TYPOGRAPHY UTILITIES ============== */
.kicker{
  font-family:var(--mono);
  font-size:11.5px;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-2);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 18px;
}
.kicker .kdot{
  width:7px;height:7px;border-radius:50%;
  background:var(--mint);
  box-shadow:0 0 0 4px var(--mint-soft);
}
.kicker.light{color:rgba(255,255,255,.78)}
.kicker.light .kdot{background:var(--pink);box-shadow:0 0 0 4px rgba(242,95,153,.20)}

h1, h2, h3, .display{
  font-family:var(--serif);
  font-weight:500;
  letter-spacing:-.012em;
  color:var(--ink);
  line-height:1.06;
}
h1{font-size:clamp(36px, 5.4vw, 70px);margin:0 0 22px}
.display{font-size:clamp(28px, 3.6vw, 50px);margin:0 0 22px}
h3{font-size:22px;margin:0 0 10px;line-height:1.18}

.lede, .sec-lede{
  font-size:17px;
  color:var(--ink-2);
  max-width:62ch;
  margin:0 0 28px;
  line-height:1.6;
}

/* ============== TICKER ============== */
.ticker{
  background:var(--ink);
  color:var(--bg);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  position:relative;
}
.ticker::before, .ticker::after{
  content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.ticker::before{left:0;background:linear-gradient(90deg,var(--ink),transparent)}
.ticker::after{right:0;background:linear-gradient(-90deg,var(--ink),transparent)}
.ticker-track{
  display:flex;gap:48px;
  white-space:nowrap;
  padding:11px 0;
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  animation:tick 50s linear infinite;
}
.ticker-track span{display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.72)}
.ticker-track b{color:var(--mint);font-weight:600;letter-spacing:.18em}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============== NAV ============== */
.nav{
  position:sticky;top:0;z-index:40;
  background:rgba(251,250,246,.86);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid var(--line);
}
.nav-wrap{
  max-width:var(--container);margin:0 auto;
  padding:14px var(--gutter);
  display:flex;align-items:center;gap:24px;
}
.brand{
  display:flex;align-items:center;gap:12px;
  flex:0 0 auto;
}
.brand-flask{
  width:36px;height:36px;
  display:grid;place-items:center;
  border:1.5px solid var(--ink);
  border-radius:10px;
  background:var(--paper);
  color:var(--ink);
  position:relative;
}
.brand-flask::after{
  content:"";position:absolute;left:50%;bottom:6px;
  width:6px;height:6px;border-radius:50%;
  background:var(--mint);
  transform:translateX(-50%);
  box-shadow:0 0 0 3px var(--mint-soft);
}
.brand-flask svg{width:18px;height:20px}
.brand-txt{
  font-family:var(--serif);
  font-size:21px;font-weight:600;
  line-height:1;
  letter-spacing:-.015em;
  color:var(--ink);
}
.brand-txt em{color:var(--pink-deep);font-style:italic;margin-right:1px}
.brand-txt small{
  display:block;
  font-family:var(--mono);
  font-size:9.5px;
  font-weight:500;
  letter-spacing:.16em;
  color:var(--gray);
  margin-top:6px;
}

.nav-links{
  display:flex;align-items:center;gap:24px;
  margin-left:auto;
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.nav-links a{
  color:var(--ink-2);
  position:relative;
  padding:6px 0;
  transition:color .2s;
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:2px;background:var(--mint);border-radius:2px;
}
.book{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;
  background:var(--ink);color:var(--paper);
  border-radius:99px;
  font-family:var(--sans);font-weight:600;font-size:13px;
  letter-spacing:.01em;
  border:1.5px solid var(--ink);
  transition:.2s;
}
.book:hover{background:var(--mint);color:var(--ink);border-color:var(--mint);transform:translateY(-1px)}
.book .book-arr{font-family:var(--mono);font-weight:500}

/* ============== BUTTONS ============== */
.btn-mint{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  background:var(--mint);color:var(--ink);
  border-radius:99px;
  font-weight:700;font-size:14px;
  letter-spacing:.01em;
  border:1.5px solid var(--ink);
  box-shadow:4px 4px 0 var(--ink);
  transition:.18s;
}
.btn-mint:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn-mint.btn-big{padding:18px 32px;font-size:16px;border-radius:99px}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  border:1.5px solid var(--ink);
  border-radius:99px;
  font-weight:600;font-size:14px;color:var(--ink);
  background:transparent;
  transition:.2s;
}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* ============== HERO ============== */
.hero{
  position:relative;
  padding:80px 0 0;
  overflow:hidden;
  background:
    radial-gradient(60% 80% at 90% 0%, var(--lilac-soft), transparent 65%),
    radial-gradient(60% 80% at 0% 30%, var(--mint-soft), transparent 65%),
    var(--bg);
}
.hero-wrap{
  max-width:var(--container);margin:0 auto;
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:60px;
  align-items:start;
}
.hero-left .lede{margin-top:8px}
.hero h1 em{font-family:var(--serif);font-style:italic;color:var(--pink-deep);font-weight:500}

.hero-meta{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:22px;
  margin:32px 0 26px;
  padding:22px 24px;
  background:var(--paper);
  border:1px solid var(--line);
  border-left:3px solid var(--mint);
  border-radius:var(--radius);
}
.hero-meta > div{display:flex;flex-direction:column;gap:3px}
.hero-meta b{
  font-family:var(--serif);
  font-size:30px;font-weight:600;
  letter-spacing:-.01em;
  color:var(--ink);
}
.hero-meta b small{
  font-family:var(--mono);
  font-size:13px;font-weight:500;
  color:var(--mint-deep);
  margin-left:2px;
}
.hero-meta span{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--ink-2);
}

.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

/* formula card */
.formula-card{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:32px 30px 28px;
  box-shadow:var(--shadow);
  margin-bottom:60px;
}
.fc-corner{position:absolute;width:14px;height:14px;border:2px solid var(--ink)}
.fc-corner.tl{top:10px;left:10px;border-right:0;border-bottom:0}
.fc-corner.tr{top:10px;right:10px;border-left:0;border-bottom:0}
.fc-corner.bl{bottom:10px;left:10px;border-right:0;border-top:0}
.fc-corner.br{bottom:10px;right:10px;border-left:0;border-top:0}

.fc-head{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:14px;
  border-bottom:1px dashed var(--line);
  margin-bottom:18px;
}
.fc-no{
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.20em;color:var(--ink-2);
}
.fc-stamp{
  font-family:var(--mono);font-size:10px;font-weight:600;
  padding:4px 9px;
  background:var(--pink);color:#fff;
  border-radius:99px;letter-spacing:.18em;
}
.fc-title h2{
  font-size:30px;line-height:1.1;
  margin:0 0 8px;
}
.fc-title h2 em{color:var(--pink-deep)}
.fc-title p{margin:0;font-size:14.5px;color:var(--ink-2)}

.fc-inci{margin-top:22px}
.fc-h{
  font-family:var(--mono);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--mint-deep);
  margin:0 0 12px;
}
.fc-inci ol{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:9px;
}
.fc-inci li{
  display:grid;
  grid-template-columns:74px 1fr;
  gap:14px;align-items:center;
  font-family:var(--mono);font-size:12px;
  position:relative;
  padding:7px 0;
  border-bottom:1px dotted var(--line-2);
}
.fc-inci li:last-child{border-bottom:0}
.fc-pct{
  font-weight:600;
  color:var(--ink);
  letter-spacing:.04em;
}
.fc-pct small{font-size:10px;color:var(--gray);font-weight:500;margin-left:1px}
.fc-name{
  display:flex;align-items:center;gap:10px;
  color:var(--ink-2);
  font-weight:500;
  position:relative;
  padding-right:38px;
}
.fc-bar{
  display:block;
  position:relative;
  flex:1;height:6px;
  background:var(--cream);border-radius:99px;
  overflow:hidden;
}
.fc-bar::after{
  content:"";display:block;height:100%;
  width:var(--w,50%);
  background:linear-gradient(90deg, var(--pink) 0%, var(--pink-deep) 100%);
  border-radius:99px;
}
.fc-bar.mint::after{background:linear-gradient(90deg, var(--mint) 0%, var(--mint-deep) 100%)}

.fc-foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:22px;padding-top:18px;
  border-top:1px solid var(--line);
}
.fc-meta{display:flex;gap:14px;flex-wrap:wrap}
.fc-meta span{
  font-family:var(--mono);font-size:11px;
  color:var(--ink-2);
  display:inline-flex;align-items:center;gap:6px;
}
.fc-meta i{color:var(--mint-deep)}
.fc-price{display:flex;align-items:baseline;gap:6px}
.fc-price small{font-family:var(--mono);font-size:11px;color:var(--gray);letter-spacing:.12em;text-transform:uppercase}
.fc-price b{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--ink)}
.fc-price b small{font-family:var(--mono);font-size:14px;color:var(--mint-deep)}

.fc-ribbon{
  position:absolute;
  top:18px;right:-10px;
  background:var(--pink);color:#fff;
  font-family:var(--mono);font-size:10.5px;font-weight:600;
  letter-spacing:.20em;
  padding:6px 14px;
  border-radius:3px;
  box-shadow:0 8px 16px -8px rgba(242,95,153,.6);
}
.fc-ribbon::after{
  content:"";position:absolute;
  right:0;bottom:-6px;
  border:6px solid transparent;
  border-top-color:var(--pink-deep);
  border-right-color:var(--pink-deep);
}

.lab-strip{
  margin-top:40px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:18px var(--gutter);
  display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:14px;
  font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-2);
  background:var(--paper);
}
.lab-strip i{color:var(--mint-deep);margin-right:6px}

/* ============== SEC HEAD ============== */
.sec-head{margin-bottom:48px;max-width:760px}

/* ============== ACTIVES — INGREDIENT DECK ============== */
.actives{padding:100px 0;background:var(--bg)}
.deck-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:14px;
}
.ing{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:14px;
  padding:22px 18px 20px;
  transition:.2s;
}
.ing:hover{
  transform:translateY(-3px);
  border-color:var(--ink);
  box-shadow:var(--shadow-soft);
}
.ring{
  position:relative;
  width:78px;height:78px;
  margin:0 auto 12px;
  display:grid;place-items:center;
}
.ring svg{
  position:absolute;inset:0;width:100%;height:100%;
  transform:rotate(-90deg);
}
.ring .rt{fill:none;stroke:var(--cream);stroke-width:5}
.ring .rf{fill:none;stroke:var(--mint-deep);stroke-width:5;stroke-linecap:round}
.ring .rf.pink{stroke:var(--pink-deep)}
.ring b{
  position:relative;z-index:1;
  font-family:var(--serif);font-size:18px;font-weight:600;
  color:var(--ink);
}
.ring b small{font-family:var(--mono);font-size:10px;font-weight:500;color:var(--gray);margin-left:1px}

.ing-cas{
  font-family:var(--mono);font-size:9.5px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--gray);
  text-align:center;margin:0 0 4px;
}
.ing h3{
  font-size:16px;text-align:center;margin:0 0 8px;
  letter-spacing:-.005em;
}
.ing-fn{
  font-size:12.5px;line-height:1.5;color:var(--ink-2);
  text-align:center;margin:0 0 14px;
  min-height:55px;
}
.ing-tag{
  display:block;text-align:center;
  font-family:var(--mono);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--mint-deep);
  padding:5px 10px;
  border:1px solid var(--mint);
  border-radius:99px;
  background:var(--mint-soft);
}
.ing-tag.pink{
  color:var(--pink-deep);
  border-color:var(--pink);
  background:var(--pink-soft);
}

.deck-note{
  margin-top:32px;
  font-family:var(--mono);font-size:11.5px;
  color:var(--ink-2);text-align:center;
  letter-spacing:.04em;
}
.deck-note em{color:var(--pink-deep);font-family:var(--serif);font-size:14px;font-weight:600}

/* ============== FORMULA / SERVICES ============== */
.formula{
  padding:100px 0;
  background:linear-gradient(180deg, var(--bg) 0%, var(--cream) 100%);
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:18px;
}
.form{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px 24px;
  display:flex;flex-direction:column;
  transition:.2s;
}
.form:hover{
  transform:translateY(-4px);
  border-color:var(--ink);
  box-shadow:var(--shadow);
}
.form.fav{
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}
.form.fav h3{color:var(--paper)}
.form.fav h3 em{color:var(--mint)}
.form.fav .form-no{color:var(--mint)}
.form.fav .form-cat{color:rgba(255,255,255,.65);border-color:rgba(255,255,255,.20)}
.form.fav p{color:rgba(255,255,255,.78)}
.form.fav .form-ing li{border-color:rgba(255,255,255,.15)}
.form.fav .form-ing span{color:rgba(255,255,255,.85)}
.form.fav .form-ing .ing-pct{color:var(--mint)}
.form.fav footer{border-color:rgba(255,255,255,.18)}
.form.fav .form-time{color:rgba(255,255,255,.72)}
.form.fav .form-time i{color:var(--mint)}
.form.fav .form-price{color:var(--paper)}
.form.fav .form-price small{color:var(--mint)}
.form.fav .form-cta{color:var(--ink);background:var(--mint);border-color:var(--mint)}
.form.fav .form-cta:hover{background:var(--paper);border-color:var(--paper)}

.form header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;
}
.form-no{
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.18em;color:var(--ink);
}
.form-cat{
  font-family:var(--mono);font-size:9.5px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-2);
  padding:4px 10px;
  border:1px solid var(--line);
  border-radius:99px;
}
.form h3{font-size:24px;margin:0 0 10px}
.form > p{font-size:14px;color:var(--ink-2);margin:0 0 18px;line-height:1.55}

.form-ing{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:0}
.form-ing li{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0;
  border-bottom:1px dotted var(--line);
  font-family:var(--mono);font-size:11.5px;
  letter-spacing:.04em;
}
.form-ing li:last-child{border-bottom:0}
.form-ing span{color:var(--ink-2)}
.form-ing .ing-pct{
  color:var(--pink-deep);font-weight:600;
}

.form footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;
  border-top:1px solid var(--line);
  margin-top:auto;
}
.form-time{
  font-family:var(--mono);font-size:11px;color:var(--ink-2);
  display:inline-flex;align-items:center;gap:7px;
}
.form-time i{color:var(--mint-deep)}
.form-price{
  font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink);
}
.form-price small{font-family:var(--mono);font-size:12px;color:var(--mint-deep);margin-left:1px}

.form-cta{
  display:inline-flex;align-items:center;justify-content:center;
  margin-top:14px;
  padding:11px 16px;
  border:1.5px solid var(--ink);
  border-radius:99px;
  font-family:var(--sans);font-weight:600;font-size:13px;
  color:var(--ink);
  transition:.2s;
}
.form-cta:hover{background:var(--ink);color:var(--paper)}

.fav-rib{
  position:absolute;
  top:14px;right:-10px;
  background:var(--pink);color:#fff;
  font-family:var(--mono);font-size:10px;font-weight:600;
  letter-spacing:.20em;
  padding:5px 11px;
  border-radius:3px;
  box-shadow:0 6px 16px -8px rgba(242,95,153,.7);
}
.fav-rib::after{
  content:"";position:absolute;
  right:0;bottom:-5px;
  border:5px solid transparent;
  border-top-color:var(--pink-deep);
  border-right-color:var(--pink-deep);
}

/* ============== SKIN MATRIX ============== */
.matrix{padding:100px 0;background:var(--cream)}
.mtx-board{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:0;
  border:2px solid var(--ink);
  border-radius:var(--radius);
  background:var(--paper);
  overflow:visible;
}
.mtx-axis-x, .mtx-axis-y{
  position:absolute;
  font-family:var(--mono);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-2);
}
.mtx-axis-x{bottom:-28px;left:14px}
.mtx-axis-x.r{left:auto;right:14px}
.mtx-axis-y{
  top:14px;left:-46px;
  transform:rotate(-90deg);transform-origin:left top;
  white-space:nowrap;
}
.mtx-axis-y.b{top:auto;left:-30px;bottom:14px;transform:rotate(-90deg);transform-origin:left bottom}

.mtx-cell{
  padding:32px 30px;
  border-right:1.5px solid var(--ink);
  border-bottom:1.5px solid var(--ink);
  position:relative;
}
.mtx-cell:nth-child(2){border-right:0}
.mtx-cell:nth-child(3),.mtx-cell:nth-child(4){border-bottom:0}
.mtx-cell:nth-child(4){border-right:0}

.mtx-no{
  font-family:var(--mono);font-size:10.5px;font-weight:600;
  letter-spacing:.20em;color:var(--ink-2);
  margin:0 0 10px;
}
.mtx-cell h3{
  font-size:24px;margin:0 0 8px;
}
.mtx-fn{
  font-size:14px;color:var(--ink-2);
  margin:0 0 16px;line-height:1.5;
}
.mtx-cell ul{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:6px;
  font-family:var(--mono);font-size:12.5px;
  color:var(--ink);
}
.mtx-cell ul li em{font-size:13px}

.mtx-cell.q1{background:linear-gradient(135deg, var(--mint-soft) 0%, transparent 70%)}
.mtx-cell.q2{background:linear-gradient(225deg, var(--pink-soft) 0%, transparent 70%)}
.mtx-cell.q3{background:linear-gradient(45deg, var(--lilac-soft) 0%, transparent 70%)}
.mtx-cell.q4{background:linear-gradient(315deg, var(--cream) 0%, transparent 70%)}

.mtx-center{
  position:absolute;
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:36px;height:36px;
  background:var(--ink);color:var(--mint);
  border-radius:50%;
  display:grid;place-items:center;
  font-family:var(--mono);font-size:14px;
  z-index:2;
  box-shadow:0 0 0 6px var(--paper);
}

/* ============== ROUTINE ============== */
.routine{padding:100px 0;background:var(--bg)}
.rt-twin{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.rt-col{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:30px 28px;
}
.rt-col.am{border-top:4px solid var(--mint)}
.rt-col.pm{border-top:4px solid var(--pink)}

.rt-col header{
  display:flex;align-items:center;gap:14px;
  padding-bottom:18px;border-bottom:1px dashed var(--line);
  margin-bottom:18px;
}
.rt-icon{
  width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--mint-soft);color:var(--mint-deep);
  border:1.5px solid var(--mint);
  font-size:18px;
}
.rt-icon.pink{background:var(--pink-soft);color:var(--pink-deep);border-color:var(--pink)}
.rt-col header h3{flex:1;margin:0;font-size:24px}
.rt-mode{
  font-family:var(--mono);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 11px;
  background:var(--ink);color:var(--paper);
  border-radius:99px;
}

.rt-col ol{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:14px;
  position:relative;
}
.rt-col ol::before{
  content:"";
  position:absolute;
  left:18px;top:18px;bottom:18px;
  border-left:1.5px dashed var(--mint);
  z-index:0;
}
.rt-col.pm ol::before{border-color:var(--pink)}

.rt-col li{
  display:flex;gap:16px;align-items:flex-start;
  position:relative;z-index:1;
}
.rt-med{
  flex:0 0 38px;width:38px;height:38px;border-radius:50%;
  background:var(--paper);
  border:2px solid var(--mint);
  color:var(--mint-deep);
  display:grid;place-items:center;
  font-family:var(--mono);font-size:11.5px;font-weight:600;
  letter-spacing:.06em;
  box-shadow:0 0 0 5px var(--paper);
}
.rt-med.pink{border-color:var(--pink);color:var(--pink-deep)}

.rt-col li > div{display:flex;flex-direction:column;gap:2px}
.rt-col li b{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--ink)}
.rt-col li span{font-family:var(--mono);font-size:11.5px;color:var(--ink-2)}

.rt-foot{
  margin:18px 0 0;
  font-family:var(--mono);font-size:11.5px;
  color:var(--ink-2);
  padding-top:14px;border-top:1px solid var(--line);
}
.rt-foot i{color:var(--mint-deep);margin-right:6px}
.rt-col.pm .rt-foot i{color:var(--pink-deep)}
.rt-foot em{color:var(--pink-deep);font-family:var(--serif);font-size:13px}

/* ============== PROTOCOL TIMELINE ============== */
.protocol{padding:100px 0;background:var(--cream)}
.proto-line{
  list-style:none;padding:0;margin:0;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
  position:relative;
}
.proto-line::before{
  content:"";position:absolute;
  left:0;right:0;top:38px;height:1.5px;
  background:repeating-linear-gradient(90deg, var(--ink) 0 6px, transparent 6px 12px);
  z-index:0;
}
.proto-line li{
  position:relative;
  padding:90px 18px 18px;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  z-index:1;
}
.pl-no{
  position:absolute;left:50%;top:8px;
  transform:translateX(-50%);
  width:60px;height:60px;border-radius:50%;
  background:var(--bg);
  border:2px solid var(--ink);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:22px;font-weight:600;
  color:var(--ink);
  box-shadow:0 0 0 5px var(--cream);
}
.proto-line li:nth-child(odd) .pl-no{background:var(--mint-soft);border-color:var(--mint-deep);color:var(--mint-deep)}
.proto-line li:nth-child(even) .pl-no{background:var(--pink-soft);border-color:var(--pink-deep);color:var(--pink-deep)}

.proto-line h3{font-size:18px;margin:0 0 8px}
.proto-line p{font-size:13.5px;color:var(--ink-2);margin:0 0 12px;line-height:1.5}
.pl-tag{
  display:inline-block;
  font-family:var(--mono);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  padding:4px 9px;
  background:var(--ink);color:var(--mint);
  border-radius:99px;
}

/* ============== LAB / ABOUT ============== */
.lab{padding:100px 0;background:var(--bg)}
.lab-wrap{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:60px;
  align-items:center;
}
.lab-text p{font-size:16px;color:var(--ink-2);margin:0 0 16px;line-height:1.6}
.lab-list{
  list-style:none;padding:0;margin:24px 0 28px;
  display:flex;flex-direction:column;gap:10px;
}
.lab-list li{
  display:flex;align-items:center;gap:12px;
  font-size:14.5px;color:var(--ink);
}
.lab-list i{
  width:24px;height:24px;border-radius:50%;
  background:var(--mint);color:var(--ink);
  display:grid;place-items:center;
  font-size:11px;
}

.lab-mosaic{
  position:relative;
  display:grid;
  grid-template-columns:1.4fr 1fr;
  grid-template-rows:1.2fr .8fr;
  gap:14px;
  height:540px;
}
.lab-mosaic figure{
  position:relative;margin:0;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
}
.lab-mosaic img{width:100%;height:100%;object-fit:cover}
.lab-mosaic .lm-1{grid-row:1 / span 2}
.lab-mosaic figcaption{
  position:absolute;
  left:12px;bottom:12px;
  font-family:var(--mono);font-size:10px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:5px 10px;
  background:var(--ink);color:var(--mint);
  border-radius:4px;
}
.lm-corner{
  position:absolute;width:20px;height:20px;
  border:2px solid var(--ink);
  z-index:2;pointer-events:none;
}
.lm-corner.tl{top:-10px;left:-10px;border-right:0;border-bottom:0}
.lm-corner.tr{top:-10px;right:-10px;border-left:0;border-bottom:0}
.lm-corner.bl{bottom:-10px;left:-10px;border-right:0;border-top:0}
.lm-corner.br{bottom:-10px;right:-10px;border-left:0;border-top:0}

/* ============== RESULT — BEFORE/AFTER ============== */
.result{padding:100px 0;background:var(--cream)}
.score-board{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:36px 36px 28px;
}
.sb-row{
  display:grid;
  grid-template-columns:140px 1fr 76px;
  gap:24px;
  align-items:center;
  padding:18px 0;
  border-bottom:1px dashed var(--line);
}
.sb-row:last-of-type{border-bottom:0}
.sb-label{
  font-family:var(--serif);font-size:18px;font-weight:600;
  color:var(--ink);
}
.sb-bars{
  display:flex;flex-direction:column;gap:8px;
  position:relative;
}
.sb-before, .sb-after{
  display:flex;align-items:center;
  height:30px;
  border-radius:6px;
  font-family:var(--mono);
  position:relative;
  width:var(--w,50%);
  transition:width 1.2s ease;
  padding:0 12px;
  gap:10px;
}
.sb-before{
  background:var(--cream);
  border:1px solid var(--line);
  color:var(--ink-2);
}
.sb-after{
  background:linear-gradient(90deg, var(--mint) 0%, var(--mint-deep) 100%);
  color:var(--ink);
}
.sb-before b, .sb-after b{font-size:14px;font-weight:600}
.sb-before small, .sb-after small{font-size:9.5px;letter-spacing:.16em;font-weight:500;opacity:.78}

.sb-delta{
  font-family:var(--serif);font-size:24px;font-weight:600;
  color:var(--mint-deep);
  text-align:right;
  letter-spacing:-.01em;
}
.sb-delta.down{color:var(--pink-deep)}

.sb-foot{
  margin:24px 0 0;
  font-family:var(--mono);font-size:11px;
  color:var(--ink-2);text-align:center;
  padding-top:18px;border-top:1px solid var(--line);
}
.sb-foot em{color:var(--mint-deep);font-family:var(--serif);font-size:12.5px}

/* ============== COMPARISON ============== */
.compare{padding:100px 0;background:var(--bg)}
.cmp-table{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.cmp-row{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  align-items:center;
  border-bottom:1px solid var(--line);
}
.cmp-row:last-child{border-bottom:0}
.cmp-row > div{
  padding:18px 22px;
  font-size:14px;color:var(--ink);
  text-align:center;
  border-right:1px solid var(--line);
}
.cmp-row > div:last-child{border-right:0}
.cmp-row .cmp-l{
  text-align:left;
  font-weight:600;
  font-family:var(--serif);font-size:16px;
  color:var(--ink);
}
.cmp-row.cmp-head > div{
  font-family:var(--mono);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;
  background:var(--ink);
  color:var(--paper);
  padding:18px 22px;
  border-color:rgba(255,255,255,.10);
}
.cmp-row.cmp-head > div:first-child{background:var(--ink)}
.cmp-row.cmp-head .cmp-us{background:var(--mint);color:var(--ink)}
.cmp-row .cmp-us{
  background:var(--mint-soft);
  color:var(--mint-deep);
  font-weight:700;
}
.cmp-row .cmp-low{color:var(--mint-deep)}
.cmp-row .cmp-high{color:var(--pink-deep);font-weight:700}
.cmp-row .fa-check{color:var(--mint-deep);font-size:18px}
.cmp-row .fa-xmark{color:var(--gray);font-size:18px}
.cmp-row .fa-minus{color:var(--gray);font-size:14px}
.cmp-row.cmp-bot > div{
  font-family:var(--serif);font-size:18px;font-weight:600;
}
.cmp-row.cmp-bot small{font-family:var(--mono);font-size:11px;color:var(--mint-deep);margin-left:1px}

/* ============== TESTIMONIALS ============== */
.testi{padding:100px 0;background:var(--cream)}
.ts-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.ts-card{
  position:relative;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:38px 28px 24px;
  display:flex;flex-direction:column;
  transition:.2s;
}
.ts-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);border-color:var(--ink)}
.ts-quote{
  position:absolute;left:22px;top:-6px;
  font-family:var(--serif);font-style:italic;
  font-size:78px;line-height:1;
  color:var(--mint-deep);
  font-weight:600;
}
.ts-card p{
  font-family:var(--serif);font-size:17px;font-weight:400;
  line-height:1.55;color:var(--ink);
  margin:0 0 22px;
}
.ts-card p em{color:var(--pink-deep);font-weight:500}
.ts-card footer{
  margin-top:auto;
  padding-top:14px;border-top:1px dashed var(--line);
  display:flex;flex-direction:column;gap:3px;
}
.ts-name{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--ink)}
.ts-meta{
  font-family:var(--mono);font-size:11px;
  letter-spacing:.06em;color:var(--ink-2);
}
.ts-stars{color:var(--pink);letter-spacing:.18em;font-size:13px;margin-top:4px}

/* ============== CERTS ============== */
.certs{padding:80px 0;background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.certs-wrap{text-align:center}
.cert-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:24px;
}
.cert{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:24px 14px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:var(--paper);
  transition:.2s;
}
.cert:hover{border-color:var(--mint-deep)}
.cert-seal{
  width:96px;height:96px;border-radius:50%;
  background:var(--paper);
  border:2px dashed var(--ink);
  display:grid;place-items:center;
  position:relative;
}
.cert-seal::before{
  content:"";position:absolute;inset:6px;
  border:1.5px solid var(--ink);
  border-radius:50%;
}
.cert-seal span{
  font-family:var(--serif);font-size:18px;font-weight:600;
  color:var(--ink);letter-spacing:-.01em;
}
.cert-seal small{
  position:absolute;bottom:14px;
  font-family:var(--mono);font-size:8.5px;
  letter-spacing:.20em;color:var(--mint-deep);
  font-weight:600;
}
.cert p{
  font-size:13px;color:var(--ink-2);
  margin:0;line-height:1.5;
}

/* ============== FAQ ============== */
.faq{padding:100px 0;background:var(--cream)}
.faq-wrap{
  display:grid;grid-template-columns:.85fr 1.15fr;
  gap:60px;
  align-items:start;
}
.faq-side .display{margin-bottom:18px}
.faq-side p{color:var(--ink-2);margin:0 0 24px}

.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-list details{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  overflow:hidden;
  transition:.2s;
}
.faq-list details[open]{
  border-color:var(--ink);
  box-shadow:var(--shadow-soft);
}
.faq-list summary{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;
  cursor:pointer;
  list-style:none;
  font-family:var(--serif);font-weight:500;font-size:17px;
  color:var(--ink);
}
.faq-list summary::-webkit-details-marker{display:none}
.fq-mk{
  font-family:var(--mono);font-weight:500;font-size:22px;
  color:var(--mint-deep);
  width:28px;height:28px;
  border:1.5px solid var(--mint);
  border-radius:50%;
  display:grid;place-items:center;
  transition:.2s;
}
.faq-list details[open] .fq-mk{
  transform:rotate(45deg);
  background:var(--ink);color:var(--mint);
  border-color:var(--ink);
}
.faq-list details p{
  margin:0;padding:0 22px 22px;
  font-size:14.5px;color:var(--ink-2);
  line-height:1.6;
  border-top:1px dashed var(--line);
  padding-top:14px;
}

/* ============== CTA ============== */
.cta{
  padding:100px 0;
  background:
    radial-gradient(50% 80% at 80% 0%, rgba(123,224,163,.18), transparent 60%),
    radial-gradient(50% 80% at 20% 100%, rgba(242,95,153,.15), transparent 60%),
    var(--ink);
  color:var(--paper);
  text-align:center;
}
.cta-inner{max-width:780px;margin:0 auto}
.cta-h{color:var(--paper)}
.cta-h em{color:var(--mint)}
.cta p{color:rgba(255,255,255,.78);font-size:16px;margin:0 0 28px}
.cta-foot{
  margin-top:18px;
  font-family:var(--mono);font-size:11.5px;
  letter-spacing:.10em;
  color:rgba(255,255,255,.55) !important;
  text-transform:uppercase;
}

/* ============== FOOTER ============== */
.footer{
  background:var(--ink);color:var(--paper);
  padding:80px 0 50px;
  position:relative;
}
.footer .brand-flask{border-color:var(--mint);color:var(--mint);background:transparent}
.footer .brand-flask::after{background:var(--pink);box-shadow:0 0 0 3px rgba(242,95,153,.20)}
.footer .brand-txt{color:var(--paper)}
.footer .brand-txt em{color:var(--mint)}
.footer .brand-txt small{color:rgba(255,255,255,.55)}

.foot-top{
  display:flex;justify-content:space-between;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,255,255,.10);
  margin-bottom:40px;
}
.foot-tag{
  max-width:520px;
  color:rgba(255,255,255,.72);
  font-size:14.5px;line-height:1.6;
  margin:0;
}
.foot-tag em{color:var(--mint)}

.foot-cols{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:32px;
  padding-bottom:36px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.foot-cols h4{
  font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--mint);
  margin:0 0 14px;
}
.foot-cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.foot-cols li, .foot-cols a{
  font-size:13.5px;color:rgba(255,255,255,.72);
  transition:.2s;
}
.foot-cols a:hover{color:var(--mint)}

.foot-sign{
  margin:36px 0 0;
  font-family:var(--mono);font-size:11px;
  letter-spacing:.04em;
  color:rgba(255,255,255,.55);
  text-align:center;
}
.foot-sign em{color:var(--mint);font-family:var(--serif);font-size:12.5px}

/* ============== FAB ============== */
.fab{
  position:fixed;bottom:22px;right:22px;
  z-index:50;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 18px 14px 16px;
  background:#25D366;color:#fff;
  border-radius:99px;
  font-family:var(--sans);font-weight:700;font-size:14px;
  box-shadow:0 14px 30px -10px rgba(37,211,102,.55), 0 0 0 4px rgba(37,211,102,.18);
  transition:.2s;
}
.fab:hover{transform:translateY(-2px);box-shadow:0 18px 38px -10px rgba(37,211,102,.7), 0 0 0 6px rgba(37,211,102,.18)}
.fab i{font-size:22px}

/* ============== REVEAL ============== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ============== RESPONSIVE ============== */
@media (max-width:1080px){
  .deck-grid{grid-template-columns:repeat(3,1fr)}
  .form-grid{grid-template-columns:repeat(2,1fr)}
  .proto-line{grid-template-columns:repeat(3,1fr)}
  .proto-line::before{display:none}
}
@media (max-width:900px){
  .nav-links{display:none}
  .hero{padding:48px 0 0}
  .hero-wrap{grid-template-columns:1fr;gap:36px}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:18px}
  .lab-wrap{grid-template-columns:1fr;gap:36px}
  .lab-mosaic{height:auto;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;}
  .lab-mosaic .lm-1{grid-row:auto;grid-column:1 / -1;height:280px}
  .lab-mosaic .lm-2, .lab-mosaic .lm-3{height:220px}
  .ts-grid{grid-template-columns:1fr 1fr}
  .cert-row{grid-template-columns:repeat(2,1fr)}
  .foot-cols{grid-template-columns:repeat(2,1fr)}
  .foot-top{flex-direction:column;gap:24px}
  .rt-twin{grid-template-columns:1fr}
  .faq-wrap{grid-template-columns:1fr;gap:32px}
  .cmp-row{grid-template-columns:1.2fr .9fr .9fr .9fr}
  .cmp-row > div{padding:14px 12px;font-size:13px}
  .lab-strip{flex-direction:column;align-items:flex-start;gap:8px}
  .mtx-axis-y{left:-30px;font-size:9.5px}
  .mtx-axis-y.b{left:-20px}
}
@media (max-width:560px){
  :root{--gutter:18px}
  h1{font-size:38px}
  .display{font-size:28px}
  .deck-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .proto-line{grid-template-columns:1fr}
  .ts-grid{grid-template-columns:1fr}
  .cert-row{grid-template-columns:1fr 1fr;gap:14px}
  .foot-cols{grid-template-columns:1fr 1fr;gap:20px}
  .hero-meta{grid-template-columns:1fr 1fr;padding:16px 18px}
  .hero-meta b{font-size:24px}
  .formula-card{padding:24px 22px 22px}
  .fc-title h2{font-size:24px}
  .sb-row{grid-template-columns:90px 1fr 56px;gap:14px}
  .sb-label{font-size:14px}
  .cmp-row{grid-template-columns:1.1fr .9fr .9fr .9fr}
  .cmp-row > div{padding:12px 8px;font-size:12px}
  .cmp-row.cmp-head > div{font-size:9.5px;padding:12px 6px}
  .ticker-track{font-size:10.5px;gap:36px}
  .lab-mosaic{grid-template-columns:1fr}
  .lab-mosaic .lm-1, .lab-mosaic .lm-2, .lab-mosaic .lm-3{grid-column:1;height:220px;grid-row:auto}
  .mtx-board{grid-template-columns:1fr;grid-template-rows:auto auto auto auto}
  .mtx-cell{border-right:0 !important;border-bottom:1.5px solid var(--ink) !important}
  .mtx-cell:last-child{border-bottom:0 !important}
  .mtx-axis-x, .mtx-axis-y{display:none}
  .mtx-center{display:none}
  .fab span{display:none}
  .fab{padding:14px;border-radius:50%}
}
