/* ============ PROGENY — AI Phenotype Prediction ============ */
:root{
  --accent: #2dd4bf;
  --accent-bright: #5eead4;
  --accent-dim: #1f8a7f;
  --accent-glow: rgba(45,212,191,0.55);
  --bg: #060a0b;
  --bg-2: #0a1011;
  --panel: rgba(14,22,23,0.72);
  --panel-solid: #0c1314;
  --line: rgba(120,170,165,0.16);
  --line-strong: rgba(45,212,191,0.30);
  --ink: #eef4f3;
  --muted: #7e918e;
  --mono-dim: #4d6964;
  --warn: #ef5350;
  --warm: #e9b08a;
  --font-head: "Space Grotesk", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
html,body{ height:100%; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-mono);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
#root{ min-height:100dvh; position:relative; isolation:isolate; }

/* ambient canvas */
#cloud{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:0; pointer-events:none;
}
.vignette{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 12%, transparent 40%, rgba(0,0,0,0.55) 100%),
    radial-gradient(80% 60% at 50% 120%, var(--accent-glow) 0%, transparent 55%);
  opacity:.5;
  transition:opacity .8s ease;
}
.grid-bg{
  position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:44px 44px;
  mask-image:radial-gradient(120% 90% at 50% 40%, #000 30%, transparent 80%);
}

/* layout shell */
.stage{ position:relative; z-index:2; min-height:100dvh; display:flex; flex-direction:column; }
.screen{ flex:1; display:flex; flex-direction:column; opacity:1; animation:screenIn .5s cubic-bezier(.2,.8,.2,1); }
@keyframes screenIn{ from{ transform:translateY(12px);} to{ transform:none;} }
.screen.leaving{ animation:screenOut .35s ease forwards; }
@keyframes screenOut{ to{ opacity:0; transform:translateY(-6px) scale(.992); filter:blur(2px);} }

/* top chrome */
.topbar{
  position:relative; z-index:5; display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; gap:12px;
}
.iconbtn{
  width:40px; height:40px; border-radius:12px; display:grid; place-items:center;
  background:var(--panel); border:1px solid var(--line); color:var(--ink); cursor:pointer;
  backdrop-filter:blur(8px); transition:.2s;
}
.iconbtn:hover{ border-color:var(--line-strong); color:var(--accent); }
.topbar-right{ display:flex; gap:8px; align-items:center; }
.brandmark{ display:flex; align-items:center; gap:9px; font-family:var(--font-head); font-weight:700; letter-spacing:.14em; font-size:14px; }
.brandmark .dot{ width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 12px var(--accent-glow); animation:pulse 2.4s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1);} 50%{ opacity:.45; transform:scale(.8);} }

/* footer tag */
.footer-tag{
  position:relative; z-index:4; font-size:10.5px; letter-spacing:.12em; color:var(--mono-dim);
  padding:14px 18px; text-transform:uppercase;
}

/* ===== UPLOAD SCREEN ===== */
.upload-wrap{ padding:6px 18px 120px; max-width:1080px; margin:0 auto; width:100%; }
.eyebrow{ font-size:11px; letter-spacing:.34em; color:var(--accent); text-transform:uppercase; display:flex; align-items:center; gap:8px; }
.eyebrow::before{ content:""; width:18px; height:1px; background:var(--accent); }
h1.title{ font-family:var(--font-head); font-weight:700; font-size:clamp(30px,7.5vw,52px); line-height:1.02; letter-spacing:-.02em; margin:14px 0 12px; text-wrap:balance; }
.subtitle{ color:var(--muted); font-size:13.5px; line-height:1.6; max-width:46ch; }
.sample-link{ margin-top:12px; background:none; border:none; color:var(--accent); font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; cursor:pointer; opacity:.85; transition:.2s; padding:0; }
.sample-link:hover{ opacity:1; text-shadow:0 0 14px var(--accent-glow); }

.dropzones{ display:flex; align-items:stretch; gap:0; margin:34px auto 0; max-width:760px; }
.dz{
  flex:1; position:relative; border:1px solid var(--line); background:var(--panel);
  backdrop-filter:blur(10px); aspect-ratio:1/1; cursor:pointer; overflow:hidden;
  transition:border-color .25s, transform .25s, box-shadow .25s;
  display:flex; flex-direction:column;
}
.dz:hover{ border-color:var(--line-strong); box-shadow:0 0 0 1px var(--line-strong), 0 20px 60px -30px var(--accent-glow); }
.dz.dragover{ border-color:var(--accent); box-shadow:0 0 40px -8px var(--accent-glow); }
.dz.filled{ border-color:var(--line-strong); cursor:default; }
.dz .corner{ position:absolute; width:14px; height:14px; border:1.5px solid var(--accent); z-index:3; opacity:.85; }
.dz .corner.tl{ top:8px; left:8px; border-right:0; border-bottom:0; }
.dz .corner.tr{ top:8px; right:8px; border-left:0; border-bottom:0; }
.dz .corner.bl{ bottom:8px; left:8px; border-right:0; border-top:0; }
.dz .corner.br{ bottom:8px; right:8px; border-left:0; border-top:0; }
.dz-head{ position:absolute; top:12px; left:14px; z-index:4; }
.dz-head .role{ font-family:var(--font-head); font-weight:700; letter-spacing:.08em; font-size:13px; }
.dz-head .sub{ font-size:10px; color:var(--mono-dim); letter-spacing:.1em; margin-top:2px; }
.dz-empty{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; color:var(--muted); }
.dz-empty svg{ width:34px; height:34px; stroke:var(--muted); opacity:.7; }
.dz-empty .hint{ font-size:11px; letter-spacing:.1em; }
.dz img.photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; }
.dz .scrim{ position:absolute; inset:0; z-index:2; background:linear-gradient(180deg, rgba(6,10,11,.55) 0%, transparent 30%, transparent 60%, rgba(6,10,11,.55) 100%); }
.dz .ok-badge{ position:absolute; bottom:10px; right:10px; z-index:5; font-size:10px; letter-spacing:.1em; color:var(--accent); background:rgba(6,10,11,.7); border:1px solid var(--line-strong); padding:3px 7px; border-radius:6px; display:flex; gap:5px; align-items:center; }
.dz .remove{ position:absolute; bottom:10px; left:10px; z-index:5; font-size:10px; letter-spacing:.08em; color:var(--muted); background:rgba(6,10,11,.7); border:1px solid var(--line); padding:3px 8px; border-radius:6px; cursor:pointer; }
.dz .remove:hover{ color:var(--warn); border-color:var(--warn); }

.connector{ width:48px; display:flex; align-items:center; justify-content:center; position:relative; }
.connector .vline{ position:absolute; top:14%; bottom:14%; width:1px; background:linear-gradient(var(--line-strong), transparent, var(--line-strong)); }
.connector .xnode{ width:30px; height:30px; border-radius:50%; border:1px solid var(--line-strong); background:var(--bg-2); display:grid; place-items:center; color:var(--accent); font-size:13px; z-index:2; box-shadow:0 0 18px -6px var(--accent-glow); }

/* selectors */
.controls{ display:flex; flex-wrap:wrap; gap:26px 40px; justify-content:center; margin:32px auto 0; max-width:760px; }
.ctrl-group{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ctrl-label{ font-size:11px; letter-spacing:.2em; color:var(--mono-dim); text-transform:uppercase; }
.seg{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{
  border:1px solid var(--line); background:var(--panel); color:var(--muted);
  padding:9px 14px; border-radius:10px; font-family:var(--font-mono); font-size:12.5px; letter-spacing:.04em;
  cursor:pointer; transition:.18s; display:flex; align-items:center; gap:7px; backdrop-filter:blur(6px);
}
.chip:hover{ border-color:var(--line-strong); color:var(--ink); }
.chip.active{ border-color:var(--accent); color:var(--accent); background:rgba(45,212,191,.08); box-shadow:0 0 22px -10px var(--accent-glow); }
.chip svg{ width:14px; height:14px; }

/* generate CTA */
.cta-bar{ position:fixed; left:0; right:0; bottom:0; z-index:30; padding:16px 18px calc(16px + env(safe-area-inset-bottom)); display:flex; justify-content:flex-end; pointer-events:none;
  background:linear-gradient(transparent, rgba(6,10,11,.85) 40%); }
.cta-bar .inner{ pointer-events:auto; display:flex; align-items:center; gap:14px; width:100%; max-width:1080px; margin:0 auto; justify-content:flex-end; }
.generate{
  display:flex; align-items:center; gap:12px; font-family:var(--font-head); font-weight:700; letter-spacing:.1em;
  font-size:15px; padding:16px 26px; border-radius:14px; border:1px solid var(--accent);
  background:linear-gradient(180deg, rgba(45,212,191,.22), rgba(45,212,191,.07)); color:var(--accent-bright);
  cursor:pointer; transition:.2s; position:relative; overflow:hidden;
}
.generate:not(:disabled):hover{ box-shadow:0 0 40px -6px var(--accent-glow); transform:translateY(-1px); }
.generate:disabled{ opacity:.4; cursor:not-allowed; border-color:var(--line); color:var(--muted); background:var(--panel); }
.generate .free{ font-size:10px; letter-spacing:.16em; padding:3px 7px; border:1px solid var(--accent); border-radius:6px; }
.generate .arrow{ transition:transform .2s; }
.generate:not(:disabled):hover .arrow{ transform:translateX(4px); }
.generate .shine{ position:absolute; inset:0; background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%); transform:translateX(-120%); }
.generate:not(:disabled):hover .shine{ animation:shine 1s ease; }
@keyframes shine{ to{ transform:translateX(120%);} }

/* ===== SCAN SCREEN ===== */
.scan-wrap{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:24px 18px 90px; gap:30px; }
.scan-row{ display:flex; align-items:center; gap:0; }
.scan-card{ position:relative; width:min(38vw,260px); aspect-ratio:1/1; border:1px solid var(--line-strong); overflow:hidden; background:var(--bg-2); }
.scan-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(.85) contrast(1.05); }
.scan-card .tint{ position:absolute; inset:0; background:radial-gradient(circle at 50% 45%, transparent 40%, rgba(6,10,11,.45)); mix-blend-mode:multiply; }
.scan-card .role{ position:absolute; top:8px; left:10px; z-index:6; font-family:var(--font-head); font-weight:700; font-size:11px; letter-spacing:.1em; color:#fff; text-shadow:0 1px 4px #000; }
.scan-card .scanline{ position:absolute; left:0; right:0; height:60px; z-index:5;
  background:linear-gradient(180deg, transparent, var(--accent-glow) 50%, transparent);
  opacity:.8; filter:blur(.5px); mix-blend-mode:screen; }
.scan-card .corner{ position:absolute; width:16px; height:16px; border:2px solid var(--accent); z-index:7; }
.scan-card .corner.tl{ top:6px; left:6px; border-right:0; border-bottom:0; }
.scan-card .corner.tr{ top:6px; right:6px; border-left:0; border-bottom:0; }
.scan-card .corner.bl{ bottom:6px; left:6px; border-right:0; border-top:0; }
.scan-card .corner.br{ bottom:6px; right:6px; border-left:0; border-top:0; }
.scan-card svg.mesh{ position:absolute; inset:0; width:100%; height:100%; z-index:6; pointer-events:none; }
.scan-connector{ width:60px; display:flex; align-items:center; justify-content:center; color:var(--accent); }
.scan-connector .pulse-dot{ width:10px; height:10px; border-radius:50%; background:var(--accent); box-shadow:0 0 16px var(--accent-glow); animation:pulse 1.4s infinite; }

.scan-status{ display:flex; flex-direction:column; align-items:center; gap:14px; width:100%; max-width:420px; }
.status-line{ font-size:13px; letter-spacing:.06em; color:var(--accent-bright); display:flex; align-items:center; gap:10px; }
.status-line .blink{ width:7px; height:7px; border-radius:50%; background:var(--accent); animation:pulse 1s infinite; }
.scan-progress{ width:100%; height:2px; background:var(--line); border-radius:2px; overflow:hidden; }
.scan-progress .bar{ height:100%; background:linear-gradient(90deg, var(--accent-dim), var(--accent-bright)); box-shadow:0 0 10px var(--accent-glow); width:0; }
.scan-log{ font-size:10.5px; color:var(--mono-dim); letter-spacing:.08em; min-height:14px; text-align:center; }
.validating{ position:fixed; bottom:24px; right:22px; z-index:20; font-family:var(--font-head); font-weight:700; letter-spacing:.14em; color:var(--accent); font-size:13px; text-shadow:0 0 18px var(--accent-glow); }

/* ===== ANALYSIS SCREEN ===== */
.analysis-wrap{ width:100%; max-width:760px; margin:0 auto; padding:8px 18px 140px; }
.analysis-head{ display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--line); padding-bottom:12px; margin-bottom:6px; }
.analysis-head .ttl{ font-size:13px; letter-spacing:.26em; color:var(--accent); display:flex; align-items:center; gap:9px; }
.analysis-head .ttl .blink{ width:7px;height:7px;border-radius:50%;background:var(--accent); animation:pulse 1.2s infinite; }
.analysis-head .sess{ font-size:10.5px; letter-spacing:.14em; color:var(--mono-dim); }
.parent-block{ margin-top:30px; }
.parent-block .pb-label{ font-family:var(--font-head); font-weight:700; letter-spacing:.18em; font-size:13px; color:var(--accent); display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.parent-block .pb-label::before{ content:""; width:3px; height:15px; background:var(--accent); }
.pb-grid{ display:grid; grid-template-columns:96px 1fr; gap:18px; align-items:start; }
.pb-thumb{ width:96px; height:120px; object-fit:cover; border:1px solid var(--line-strong); filter:saturate(.85); }
.metrics{ display:flex; flex-direction:column; }
.metric{ display:flex; justify-content:space-between; align-items:baseline; padding:8px 0; border-bottom:1px solid var(--line); font-size:12px; opacity:0; transform:translateX(-6px); transition:opacity .4s ease, transform .4s ease; }
.metric.show{ opacity:1; transform:none; }
.metric .k{ letter-spacing:.12em; color:var(--mono-dim); text-transform:uppercase; }
.metric .v{ font-family:var(--font-head); font-weight:500; color:var(--ink); font-size:14px; }
.narrative{ margin-top:18px; display:flex; flex-direction:column; gap:14px; }
.narr{ font-size:12px; line-height:1.6; color:var(--muted); letter-spacing:.03em; padding-left:16px; position:relative; opacity:0; }
.narr{ transition:opacity .5s ease, transform .5s ease; transform:translateY(4px); }
.narr.show{ opacity:1; transform:none; }
.narr::before{ content:">"; position:absolute; left:0; color:var(--accent); }
.analyzing-tag{ position:fixed; bottom:24px; left:22px; z-index:20; display:flex; align-items:center; gap:9px; font-size:12px; letter-spacing:.14em; color:var(--accent); }
.analyzing-tag .spin{ width:12px; height:12px; border:1.5px solid var(--line-strong); border-top-color:var(--accent); border-radius:50%; animation:spin 1s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg);} }

/* continue floating btn */
.float-continue{ position:fixed; left:50%; transform:translateX(-50%); bottom:24px; z-index:25;
  display:flex; align-items:center; gap:10px; font-family:var(--font-head); font-weight:700; letter-spacing:.08em; font-size:14px;
  padding:14px 28px; border-radius:14px; border:1px solid var(--accent); color:var(--accent-bright);
  background:linear-gradient(180deg, rgba(45,212,191,.2), rgba(45,212,191,.06)); cursor:pointer; transition:.2s;
  backdrop-filter:blur(10px); animation:floatIn .5s ease both; }
.float-continue:hover{ box-shadow:0 0 36px -6px var(--accent-glow); transform:translateX(-50%) translateY(-2px); }
@keyframes floatIn{ from{ opacity:0; transform:translateX(-50%) translateY(14px);} }

/* ===== PAYWALL ===== */
.pay-wrap{ width:100%; max-width:1040px; margin:0 auto; padding:6px 18px 80px; }
.pay-hero{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:22px; align-items:stretch; }
.reveal-card{ position:relative; border:1px solid var(--line-strong); border-radius:16px; overflow:hidden; min-height:380px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  background:linear-gradient(160deg, #1a1410, #241a13 40%, #2e2018); }
.reveal-card .blurbaby{ position:absolute; inset:0; background:radial-gradient(circle at 50% 42%, rgba(233,176,138,.55), rgba(120,80,55,.35) 55%, rgba(20,14,10,.9)); filter:blur(8px); }
.reveal-card .lock{ position:relative; z-index:2; width:46px; height:46px; display:grid; place-items:center; }
.reveal-card .lock svg{ width:34px; height:34px; stroke:#fff; }
.reveal-card .rc-title{ position:relative; z-index:2; font-family:var(--font-head); font-weight:700; font-size:19px; color:#fff; text-align:center; }
.reveal-card .rc-sub{ position:relative; z-index:2; font-size:12px; color:rgba(255,255,255,.7); letter-spacing:.06em; }
.reveal-polas{ position:absolute; bottom:18px; left:50%; transform:translateX(-50%); z-index:3; display:flex; gap:8px; }
.pola{ width:88px; background:#f3efe7; padding:6px 6px 20px; border-radius:2px; box-shadow:0 14px 30px -10px rgba(0,0,0,.7); position:relative; }
.pola img{ width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }
.pola .cap{ position:absolute; bottom:5px; left:0; right:0; text-align:center; font-size:9px; letter-spacing:.14em; color:#1a1a1a; font-family:var(--font-head); font-weight:700; }
.pola.tilt-l{ transform:rotate(-7deg); } .pola.tilt-r{ transform:rotate(7deg); }

.pay-panel{ border:1px solid var(--line); border-radius:16px; background:var(--panel); backdrop-filter:blur(12px); padding:22px; display:flex; flex-direction:column; }
.pay-panel .almost{ font-size:10px; letter-spacing:.2em; color:var(--accent); text-transform:uppercase; border:1px solid var(--line-strong); align-self:flex-start; padding:4px 9px; border-radius:20px; display:flex; gap:7px; align-items:center; }
.pay-panel h2{ font-family:var(--font-head); font-weight:700; font-size:24px; line-height:1.15; margin:14px 0 8px; }
.pay-panel h2 b{ color:var(--accent); }
.pay-panel .lede{ font-size:12px; color:var(--muted); line-height:1.5; }
.social{ font-size:11px; color:var(--mono-dim); letter-spacing:.05em; margin-top:10px; display:flex; gap:7px; align-items:center; }
.social .d{ width:6px; height:6px; border-radius:50%; background:var(--accent); }
.tiers{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:18px; }
.tier{ border:1px solid var(--line); border-radius:12px; padding:14px; position:relative; cursor:pointer; transition:.2s; background:rgba(8,13,14,.5); }
.tier:hover{ border-color:var(--line-strong); }
.tier.sel{ border-color:var(--accent); box-shadow:0 0 30px -10px var(--accent-glow); background:rgba(45,212,191,.06); }
.tier .tag{ position:absolute; top:-9px; left:12px; font-size:9px; letter-spacing:.14em; padding:3px 8px; border-radius:6px; font-family:var(--font-head); font-weight:700; }
.tier .tag.pop{ background:var(--accent); color:#04110f; }
.tier .tag.best{ background:var(--warm); color:#2a1810; }
.tier .label{ font-size:10px; letter-spacing:.16em; color:var(--mono-dim); text-transform:uppercase; }
.tier .price{ font-family:var(--font-head); font-weight:700; font-size:30px; margin:6px 0 2px; }
.tier .preds{ font-size:11px; color:var(--muted); }
.tier ul{ list-style:none; margin-top:12px; display:flex; flex-direction:column; gap:7px; }
.tier li{ font-size:11px; color:var(--muted); display:flex; gap:7px; align-items:flex-start; line-height:1.35; }
.tier li svg{ width:13px; height:13px; flex-shrink:0; stroke:var(--accent); margin-top:1px; }
.tier li.strong{ color:var(--ink); }
.includes{ text-align:center; font-size:10px; letter-spacing:.16em; color:var(--mono-dim); text-transform:uppercase; margin:18px 0 12px; }
.reveal-btn{ width:100%; display:flex; align-items:center; justify-content:center; gap:10px; font-family:var(--font-head); font-weight:700; letter-spacing:.08em; font-size:15px;
  padding:17px; border-radius:13px; border:none; cursor:pointer; color:#04110f;
  background:linear-gradient(180deg, var(--accent-bright), var(--accent)); box-shadow:0 14px 40px -12px var(--accent-glow); transition:.2s; position:relative; overflow:hidden; }
.reveal-btn:hover{ transform:translateY(-2px); box-shadow:0 18px 50px -12px var(--accent-glow); }
.reveal-btn .shine{ position:absolute; inset:0; background:linear-gradient(110deg,transparent 35%, rgba(255,255,255,.4) 50%, transparent 65%); transform:translateX(-120%); animation:shine 3s ease-in-out infinite; }
.guarantee{ text-align:center; font-size:10px; letter-spacing:.1em; color:var(--mono-dim); margin-top:12px; }

/* examples */
.examples{ margin-top:80px; text-align:center; }
.examples .ex-eyebrow{ font-size:11px; letter-spacing:.3em; color:var(--accent); text-transform:uppercase; }
.examples h3{ font-family:var(--font-head); font-weight:700; font-size:clamp(24px,5vw,36px); margin:12px 0 50px; }
.family{ margin-bottom:64px; }
.family .fam-no{ font-size:11px; letter-spacing:.24em; color:var(--mono-dim); margin-bottom:22px; }
.trio{ display:flex; align-items:center; justify-content:center; gap:0; }
.fpola{ background:#f3efe7; padding:9px 9px 30px; border-radius:2px; box-shadow:0 24px 50px -18px rgba(0,0,0,.8); position:relative; }
.fpola img{ width:100%; display:block; object-fit:cover; }
.fpola .cap{ position:absolute; bottom:9px; left:0; right:0; text-align:center; font-size:9px; letter-spacing:.16em; color:#222; font-family:var(--font-head); font-weight:700; }
.fpola .ai-badge{ position:absolute; top:7px; right:7px; background:var(--accent); color:#04110f; font-size:8px; font-weight:700; letter-spacing:.1em; padding:2px 6px; border-radius:5px; font-family:var(--font-head); }
.trio .fpola.parent{ width:168px; z-index:1; }
.trio .fpola.parent img{ aspect-ratio:1/1; }
.trio .fpola.parent.left{ transform:rotate(-5deg) translateX(18px); }
.trio .fpola.parent.right{ transform:rotate(5deg) translateX(-18px); }
.trio .fpola.child{ width:196px; z-index:2; }
.trio .fpola.child img{ aspect-ratio:4/5; }

/* placeholder portrait */
.ph{ position:relative; overflow:hidden; background:linear-gradient(160deg,#243038,#3a4a50); display:grid; place-items:center; }
.ph svg{ width:46%; height:46%; opacity:.32; }
.ph.warm{ background:linear-gradient(160deg,#3a2a22,#5a3f30); }
.ph.cool{ background:linear-gradient(160deg,#22303a,#2f4654); }
.ph .grain{ position:absolute; inset:0; opacity:.5; background-image:radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px); background-size:3px 3px; }

/* responsive */
@media (max-width:720px){
  .pay-hero{ grid-template-columns:1fr; }
  .reveal-card{ min-height:300px; }
  .tiers{ grid-template-columns:1fr 1fr; }
  .controls{ flex-direction:column; gap:18px; align-items:flex-start; }
  .trio .fpola.parent{ width:96px; } .trio .fpola.child{ width:120px; }
  .scan-card{ width:40vw; }
}
@media (max-width:420px){
  .tier{ padding:11px; } .tier .price{ font-size:24px; }
  .pb-grid{ grid-template-columns:72px 1fr; gap:12px; }
  .pb-thumb{ width:72px; height:92px; }
}

/* toast */
.toast{ position:fixed; left:50%; bottom:30px; transform:translateX(-50%); z-index:200;
  background:var(--panel-solid); border:1px solid var(--line-strong); border-radius:12px;
  padding:14px 20px; display:flex; gap:10px; align-items:center; max-width:90vw;
  box-shadow:0 20px 50px -20px var(--accent-glow); font-size:12.5px; letter-spacing:.03em; color:var(--ink);
  animation:floatIn .4s ease both; }

/* warm payoff: shift vignette + reveal card warmth when enabled */
body.warm-payoff .reveal-card{ background:linear-gradient(160deg,#1f1610,#2c1f15 40%,#3a2818); }
body:not(.warm-payoff) .reveal-card{ background:linear-gradient(160deg,#0c1314,#0e1a1b 45%,#102225); }
body:not(.warm-payoff) .reveal-card .blurbaby{ background:radial-gradient(circle at 50% 42%, rgba(94,234,212,.4), rgba(45,140,130,.25) 55%, rgba(8,16,16,.92)); }
body:not(.warm-payoff) .ph.warm{ background:linear-gradient(160deg,#22303a,#2f4654); }

/* ===== real-face scan enhancements ===== */
.scan-card{ animation:cardLock 2.6s ease-in-out infinite; }
@keyframes cardLock{
  0%,100%{ box-shadow:0 0 0 1px var(--line-strong), 0 0 34px -14px var(--accent-glow); }
  50%{ box-shadow:0 0 0 1px var(--accent), 0 0 60px -8px var(--accent-glow); }
}
.scan-card .mesh-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:6; pointer-events:none; }

.scan-detect{ display:flex; align-items:center; gap:8px; font-size:10px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--mono-dim); }
.scan-detect .sep{ opacity:.4; }
.scan-detect .dok{ color:var(--accent); text-shadow:0 0 12px var(--accent-glow); }
.scan-detect .dwarn{ color:var(--warn); }
.scan-detect .dpending{ color:var(--muted); }

/* ===== upload: live face-detection feedback ===== */
.dz .ok-badge.detecting{ color:var(--muted); border-color:var(--line); }
.dz .ok-badge.detecting .spin{ width:9px; height:9px; border:1.5px solid var(--line-strong);
  border-top-color:var(--accent); border-radius:50%; animation:spin .8s linear infinite; display:inline-block; }
.dz .ok-badge.noface{ color:var(--warn); border-color:var(--warn); }
.dz.warn{ border-color:var(--warn); box-shadow:0 0 30px -10px rgba(239,83,80,.5); }
/* sweeping scanline while detection runs on the dropzone preview */
.dz .dz-scan{ position:absolute; left:0; right:0; top:0; height:38px; z-index:4; pointer-events:none;
  background:linear-gradient(180deg, transparent, var(--accent-glow) 50%, transparent);
  mix-blend-mode:screen; opacity:.85; animation:dzSweep 1.5s ease-in-out infinite; }
@keyframes dzSweep{ 0%{ transform:translateY(-40px);} 100%{ transform:translateY(calc(100% + 40px)); } }

/* adjust/replace affordance on a filled dropzone */
.dz .adjust{ position:absolute; bottom:10px; left:10px; z-index:5; font-size:10px; letter-spacing:.08em;
  color:var(--muted); background:rgba(6,10,11,.7); border:1px solid var(--line); padding:3px 8px; border-radius:6px; cursor:pointer; }
.dz .adjust:hover{ color:var(--accent); border-color:var(--line-strong); }

/* ============ CROP / ZOOM MODAL ============ */
.crop-overlay{ position:fixed; inset:0; z-index:1000; background:rgba(4,7,8,.86); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; padding:18px; animation:cropFade .2s ease; }
@keyframes cropFade{ from{ opacity:0; } }
.crop-modal{ width:100%; max-width:380px; background:var(--panel-solid); border:1px solid var(--line-strong);
  border-radius:18px; padding:18px; box-shadow:0 40px 90px -30px #000; animation:floatIn .35s ease both; }
.crop-head{ display:flex; flex-direction:column; gap:3px; margin-bottom:14px; }
.crop-head span{ font-family:var(--font-head); font-weight:700; letter-spacing:.04em; font-size:15px; }
.crop-hint{ font-size:10.5px; color:var(--mono-dim); letter-spacing:.04em; }
.crop-stage{ display:flex; justify-content:center; }
.crop-frame{ position:relative; width:300px; height:300px; max-width:74vw; max-height:74vw; overflow:hidden;
  background:#0b0f10; border:1px solid var(--line-strong); touch-action:none; user-select:none; cursor:grab; }
.crop-frame:active{ cursor:grabbing; }
.crop-frame img{ pointer-events:none; -webkit-user-drag:none; }
.crop-grid{ position:absolute; inset:0; pointer-events:none; opacity:.45;
  background-image:linear-gradient(rgba(120,170,165,.25) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,165,.25) 1px,transparent 1px);
  background-size:33.333% 33.333%; }
.crop-ring{ position:absolute; inset:12%; border-radius:50%; pointer-events:none;
  border:1px dashed rgba(94,234,212,.45); box-shadow:0 0 0 9999px rgba(4,7,8,.18); }
.crop-frame .corner{ position:absolute; width:18px; height:18px; border:2px solid var(--accent); z-index:3; }
.crop-frame .corner.tl{ top:8px; left:8px; border-right:0; border-bottom:0; }
.crop-frame .corner.tr{ top:8px; right:8px; border-left:0; border-bottom:0; }
.crop-frame .corner.bl{ bottom:8px; left:8px; border-right:0; border-top:0; }
.crop-frame .corner.br{ bottom:8px; right:8px; border-left:0; border-top:0; }
.crop-zoom{ display:flex; align-items:center; gap:12px; margin-top:16px; }
.crop-zoom svg{ stroke:var(--muted); flex-shrink:0; }
.crop-zoom input[type=range]{ flex:1; accent-color:var(--accent); height:4px; cursor:pointer; }
.crop-actions{ display:flex; gap:10px; margin-top:16px; }
.crop-btn{ flex:1; padding:13px; border-radius:11px; font-family:var(--font-head); font-weight:700;
  letter-spacing:.05em; font-size:13px; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px; transition:.2s; }
.crop-btn.ghost{ background:var(--panel); border:1px solid var(--line); color:var(--muted); }
.crop-btn.ghost:hover{ border-color:var(--line-strong); color:var(--ink); }
.crop-btn.primary{ background:linear-gradient(180deg,var(--accent-bright),var(--accent)); border:none; color:#04110f; }
.crop-btn.primary svg{ stroke:#04110f; }
.crop-btn.primary:hover{ transform:translateY(-1px); box-shadow:0 12px 34px -12px var(--accent-glow); }

/* ============ SALES PAGE (CRO rebuild) ============ */
/* urgency banner */
.urgency{ display:flex; align-items:center; justify-content:center; gap:9px; margin:0 auto 22px;
  max-width:560px; padding:10px 16px; border-radius:12px; font-size:12px; letter-spacing:.04em;
  color:var(--ink); background:linear-gradient(180deg, rgba(45,212,191,.10), rgba(45,212,191,.04));
  border:1px solid var(--line-strong); }
.urgency b{ font-family:var(--font-head); color:var(--accent); font-variant-numeric:tabular-nums; letter-spacing:.06em; }
.dot-live{ width:8px; height:8px; border-radius:50%; background:var(--warn);
  box-shadow:0 0 0 0 rgba(239,83,80,.6); animation:livep 1.4s infinite; }
@keyframes livep{ 0%{ box-shadow:0 0 0 0 rgba(239,83,80,.55);} 70%{ box-shadow:0 0 0 7px rgba(239,83,80,0);} 100%{ box-shadow:0 0 0 0 rgba(239,83,80,0);} }

/* reveal hero — DAD × locked BABY × MOM */
.reveal-card.pro{ position:relative; border:1px solid var(--line-strong); border-radius:18px; overflow:hidden;
  min-height:420px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  padding:26px 18px; background:linear-gradient(160deg,#15100c,#1f1610 45%,#2a1d14); }
body:not(.warm-payoff) .reveal-card.pro{ background:linear-gradient(160deg,#0b1213,#0e1a1b 45%,#102226); }
.reveal-card.pro .rc-grain{ position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px); background-size:3px 3px; }
.match-chip{ position:relative; z-index:2; display:inline-flex; align-items:center; gap:7px; align-self:center;
  font-size:10px; letter-spacing:.16em; color:var(--accent); border:1px solid var(--line-strong);
  background:rgba(6,10,11,.5); padding:5px 11px; border-radius:20px; margin-bottom:6px; }
.match-chip .d{ width:6px; height:6px; border-radius:50%; background:var(--accent); box-shadow:0 0 10px var(--accent-glow); }
.rc-trio{ position:relative; z-index:2; display:flex; align-items:center; justify-content:center; gap:0; }
.rc-trio .pola{ width:96px; }
.rc-trio .pola.baby{ width:118px; z-index:2; margin:0 -6px; position:relative; background:#0c1314; }
.rc-trio .pola.baby .baby-blur{ width:100%; aspect-ratio:1/1; display:block;
  background:radial-gradient(circle at 50% 42%, rgba(233,176,138,.7), rgba(150,95,60,.5) 55%, rgba(20,14,10,.9));
  filter:blur(9px); }
body:not(.warm-payoff) .rc-trio .pola.baby .baby-blur{ background:radial-gradient(circle at 50% 42%, rgba(94,234,212,.55), rgba(45,140,130,.4) 55%, rgba(8,16,16,.92)); }
.rc-trio .pola.baby .baby-scan{ position:absolute; top:6px; left:6px; right:6px; height:24px; z-index:2;
  background:linear-gradient(180deg,transparent,var(--accent-glow) 50%,transparent); mix-blend-mode:screen;
  animation:dzSweep 2.2s ease-in-out infinite; }
.rc-trio .pola.baby .baby-lock{ position:absolute; top:38%; left:50%; transform:translate(-50%,-50%); z-index:3;
  width:42px; height:42px; border-radius:50%; display:grid; place-items:center; color:#fff;
  background:rgba(6,10,11,.55); border:1px solid rgba(255,255,255,.25); backdrop-filter:blur(2px); }
.rc-trio .pola.baby .cap.accent{ color:var(--accent); }
.rc-trio .pola .ph{ width:100%; aspect-ratio:1/1; }
.reveal-card.pro .rc-title{ position:relative; z-index:2; font-family:var(--font-head); font-weight:700; font-size:22px; color:#fff; margin-top:14px; text-align:center; }
.reveal-card.pro .rc-sub{ position:relative; z-index:2; font-size:12px; color:rgba(255,255,255,.65); letter-spacing:.04em; }

/* pay panel additions */
.pay-panel .trust-pills{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.pay-panel .trust-pills span{ display:inline-flex; align-items:center; gap:6px; font-size:10.5px; letter-spacing:.04em;
  color:var(--muted); border:1px solid var(--line); border-radius:20px; padding:5px 10px; }
.pay-panel .trust-pills svg{ stroke:var(--accent); }

.tier .tier-top{ display:flex; align-items:center; gap:10px; }
.tier .radio{ width:18px; height:18px; border-radius:50%; border:1.5px solid var(--line-strong);
  display:grid; place-items:center; flex-shrink:0; color:#04110f; }
.tier.sel .radio{ background:var(--accent); border-color:var(--accent); }
.tier .price-row{ display:flex; align-items:baseline; gap:10px; margin:8px 0 2px; flex-wrap:wrap; }
.tier .anchor{ display:flex; flex-direction:column; line-height:1.1; }
.tier .anchor s{ font-size:12px; color:var(--mono-dim); }
.tier .anchor .save{ font-size:9px; letter-spacing:.1em; color:var(--accent); font-weight:700; }

.cta-sub{ text-align:center; font-size:11px; color:var(--mono-dim); letter-spacing:.04em; margin-top:10px; }
.cta-sub s{ color:var(--mono-dim); opacity:.8; }
.pay-icons{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-top:14px;
  padding-top:14px; border-top:1px solid var(--line); flex-wrap:wrap; }
.pay-icons .secure{ display:inline-flex; align-items:center; gap:6px; font-size:10.5px; color:var(--muted); }
.pay-icons .secure svg{ stroke:var(--accent); }
.pay-icons .cards{ font-size:9px; letter-spacing:.12em; color:var(--mono-dim); }

.reveal-btn svg{ stroke:#04110f; }

/* social bar */
.social-bar{ display:flex; align-items:center; justify-content:center; gap:8px; margin:34px auto 0; max-width:640px;
  padding:18px; border:1px solid var(--line); border-radius:14px; background:var(--panel); backdrop-filter:blur(10px); }
.social-bar .sb-item{ flex:1; text-align:center; }
.social-bar .big{ font-family:var(--font-head); font-weight:700; font-size:22px; color:var(--ink);
  display:flex; align-items:center; justify-content:center; gap:6px; }
.social-bar .sm{ font-size:10.5px; letter-spacing:.06em; color:var(--mono-dim); margin-top:3px; text-transform:uppercase; }
.social-bar .sb-div{ width:1px; align-self:stretch; background:var(--line); }
.stars{ display:inline-flex; gap:1px; color:#f5c451; }

/* testimonials */
.testimonials{ margin-top:70px; text-align:center; }
.testimonials h3, .faq h3{ font-family:var(--font-head); font-weight:700; font-size:clamp(22px,4.5vw,32px); margin:12px 0 34px; }
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; text-align:left; }
.review{ border:1px solid var(--line); border-radius:14px; padding:18px; background:var(--panel); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; gap:10px; }
.rev-head{ display:flex; align-items:center; gap:10px; }
.avatar{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center; flex-shrink:0;
  font-family:var(--font-head); font-weight:700; font-size:12px; color:#04110f;
  background:linear-gradient(180deg,var(--accent-bright),var(--accent)); }
.rname{ font-size:12.5px; color:var(--ink); font-weight:500; }
.rloc{ font-size:10px; color:var(--mono-dim); letter-spacing:.04em; }
.verified{ margin-left:auto; display:inline-flex; align-items:center; gap:4px; font-size:9px; letter-spacing:.06em;
  color:var(--accent); border:1px solid var(--line-strong); border-radius:20px; padding:3px 7px; }
.review p{ font-size:12.5px; line-height:1.6; color:var(--muted); }

/* faq */
.faq{ margin-top:70px; text-align:center; }
.faq-list{ max-width:680px; margin:0 auto; text-align:left; display:flex; flex-direction:column; gap:10px; }
.faq-item{ border:1px solid var(--line); border-radius:12px; background:var(--panel); cursor:pointer; overflow:hidden; transition:border-color .2s; }
.faq-item:hover{ border-color:var(--line-strong); }
.faq-item.open{ border-color:var(--line-strong); }
.faq-q{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 18px;
  font-size:13.5px; font-family:var(--font-head); font-weight:500; color:var(--ink); }
.faq-q .chev{ width:9px; height:9px; border-right:2px solid var(--accent); border-bottom:2px solid var(--accent);
  transform:rotate(45deg); transition:transform .25s; flex-shrink:0; }
.faq-item.open .chev{ transform:rotate(-135deg); }
.faq-a{ max-height:0; opacity:0; transition:max-height .3s ease, opacity .3s ease, padding .3s ease; padding:0 18px; }
.faq-item.open .faq-a{ max-height:240px; opacity:1; padding:0 18px 16px; }
.faq-a p{ font-size:12.5px; line-height:1.6; color:var(--muted); }

/* final cta */
.final-cta{ margin-top:70px; text-align:center; max-width:520px; margin-left:auto; margin-right:auto;
  padding:30px 22px; border:1px solid var(--line-strong); border-radius:18px;
  background:linear-gradient(180deg, rgba(45,212,191,.06), transparent); }
.final-cta h3{ font-family:var(--font-head); font-weight:700; font-size:26px; margin-bottom:6px; }
.final-cta p{ font-size:12.5px; color:var(--muted); margin-bottom:18px; }
.final-cta .reveal-btn{ max-width:420px; margin:0 auto; }
.final-cta .guarantee{ display:inline-flex; align-items:center; gap:6px; margin-top:14px; }
.final-cta .guarantee svg{ stroke:var(--accent); }

@media (max-width:720px){
  .reviews{ grid-template-columns:1fr; }
  .reveal-card.pro{ min-height:360px; }
  .rc-trio .pola{ width:84px; } .rc-trio .pola.baby{ width:104px; }
  .social-bar{ gap:4px; padding:14px 8px; }
  .social-bar .big{ font-size:18px; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001s !important; animation-iteration-count:1 !important; }
}
