@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Serif+Display:ital@0;1&family=DM+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
:root{
  --bg:#F5F8FB;--card:#FFFFFF;--card2:#EDF2F7;
  --border:rgba(16,35,61,.10);--border2:rgba(16,35,61,.18);
  --text:#10233D;--muted:#5C7086;--dim:#93A3B8;
  --lime:#0E7C7B;--lime-dim:rgba(14,124,123,.10);--lime-b:rgba(14,124,123,.35);
  --violet:#6C4BC1;--violet-dim:rgba(108,75,193,.10);--violet-b:rgba(108,75,193,.35);
  --cyan:#0C7489;--cyan-dim:rgba(12,116,137,.10);--cyan-b:rgba(12,116,137,.35);
  --green:#1E8E6D;--green-dim:rgba(30,142,109,.10);--green-b:rgba(30,142,109,.35);
  --red:#DC3545;--red-dim:rgba(220,53,69,.08);--red-b:rgba(220,53,69,.30);
  --amber:#C6871F;--amber-dim:rgba(198,135,31,.10);--amber-b:rgba(198,135,31,.35);
  --pink:#C2478D;--pink-dim:rgba(194,71,141,.10);--pink-b:rgba(194,71,141,.32);
}
body{background:var(--bg);color:var(--text);font-family:'Outfit',sans-serif;min-height:100vh;overflow-x:hidden}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:.9rem 2rem;display:flex;align-items:center;justify-content:space-between;background:rgba(245,248,251,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav-logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.03em;text-decoration:none}
.nav-logo .orb{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#ec4899,#8b5cf6,#3b82f6);display:flex;align-items:center;justify-content:center;font-size:15px}
.nav-logo em{color:var(--lime);font-style:normal}
.nav-cta{padding:8px 20px;background:var(--lime);border:none;border-radius:100px;font-size:13px;font-weight:700;color:#fff;cursor:pointer;font-family:'Outfit',sans-serif;text-decoration:none;display:inline-block;transition:all .2s}
.nav-cta:hover{filter:brightness(1.1);transform:translateY(-1px)}

/* PAGE WRAPPER */
.page{max-width:620px;margin:0 auto;padding:6rem 1.5rem 4rem}
.page.wide{max-width:1100px}

/* STEPS BAR */
.step-bar{display:flex;gap:6px;margin-bottom:2rem}
.sb{height:3px;flex:1;border-radius:2px;background:var(--border);transition:background .4s}
.sb.done{background:var(--green)}.sb.act{background:var(--lime)}

/* EYEBROW + TITLE */
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:'DM Mono',monospace;display:block;margin-bottom:.4rem}
.page-title{font-family:'DM Serif Display',serif;font-size:clamp(2rem,5vw,2.8rem);font-weight:400;line-height:1.1;letter-spacing:-.02em;margin-bottom:.6rem}
.page-title em{font-style:italic;color:var(--lime)}
.page-sub{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:2rem}

/* CARD */
.card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:1.75rem;margin-bottom:1rem}
.card-title{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:1.25rem}
.card-title span{font-size:18px}
.card-section{font-size:13px;font-weight:700;color:var(--text);margin:1.25rem 0 .75rem;padding-top:1rem;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}

/* FORM */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ff{display:flex;flex-direction:column;gap:6px}
.ff.full{grid-column:1/-1}
.fl{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--dim);font-family:'DM Mono',monospace}
.fi{width:100%;background:var(--card2);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;outline:none;transition:border-color .2s}
.fi:focus{border-color:var(--lime-b)}.fi::placeholder{color:var(--dim);font-size:13px}
select.fi{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a4868' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
textarea.fi{resize:vertical;min-height:80px}
.chk{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer;padding:9px 12px;background:var(--card2);border:1px solid var(--border);border-radius:8px;transition:all .15s}
.chk:hover{border-color:var(--border2)}.chk input{accent-color:var(--lime);flex-shrink:0}
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.consent{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);line-height:1.6;cursor:pointer;padding:12px;background:var(--card2);border:1px solid var(--border);border-radius:10px;margin-bottom:8px}
.consent input{accent-color:var(--lime);margin-top:2px;flex-shrink:0}

/* OTP INPUT */
.otp-row{display:flex;gap:8px;align-items:center;margin-bottom:.75rem}
.otp-fields{display:flex;gap:8px;flex:1}
.otp-box{width:48px;height:56px;border:1.5px solid var(--border2);border-radius:12px;background:var(--card2);color:var(--text);font-size:22px;font-weight:700;font-family:'DM Mono',monospace;text-align:center;outline:none;transition:all .2s}
.otp-box:focus{border-color:var(--lime-b);background:var(--lime-dim)}
.otp-box.filled{border-color:var(--green-b);background:var(--green-dim);color:var(--green)}
.otp-box.error{border-color:var(--red-b);animation:shake .4s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.otp-verify-btn{padding:10px 18px;background:var(--lime);border:none;border-radius:10px;font-size:13px;font-weight:700;color:#fff;cursor:pointer;font-family:'Outfit',sans-serif;white-space:nowrap;flex-shrink:0}
.otp-verify-btn:disabled{opacity:.4;cursor:not-allowed}
.otp-status{display:flex;align-items:center;gap:6px;font-size:12px;font-family:'DM Mono',monospace;padding:6px 12px;border-radius:100px;margin-bottom:.75rem}
.otp-status.verified{background:var(--green-dim);color:var(--green);border:1px solid var(--green-b)}
.otp-status.pending{background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber-b)}
.resend-btn{background:none;border:none;color:var(--lime);font-size:12px;cursor:pointer;font-family:'DM Mono',monospace;padding:0;text-decoration:underline}
.resend-btn:disabled{color:var(--dim);text-decoration:none;cursor:not-allowed}

/* FEEDBACK */
.fb{padding:12px 16px;border-radius:10px;font-size:13px;font-weight:600;font-family:'DM Mono',monospace;margin-bottom:1rem;display:none}
.fb.ok{background:var(--green-dim);color:var(--green);border:1px solid var(--green-b);display:block}
.fb.err{background:var(--red-dim);color:var(--red);border:1px solid var(--red-b);display:block}
.fb.info{background:var(--violet-dim);color:var(--violet);border:1px solid var(--violet-b);display:block}

/* BUTTONS */
.btn-primary{width:100%;padding:15px;background:linear-gradient(135deg,var(--lime),#0a5958);color:#fff;border:none;border-radius:14px;font-family:'Outfit',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:-.01em;display:block;text-align:center;text-decoration:none}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 12px 30px rgba(14,124,123,.22)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-outline{width:100%;padding:13px;background:transparent;border:1px solid var(--border2);border-radius:14px;color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;display:block;text-align:center;text-decoration:none}
.btn-outline:hover{border-color:var(--lime-b);color:var(--lime)}
.btn-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);background:none;border:none;cursor:pointer;font-family:'Outfit',sans-serif;margin-bottom:1.5rem;transition:color .2s;padding:0;text-decoration:none}
.btn-back:hover{color:var(--text)}

/* BANNERS */
.banner{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:12px;font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:1.25rem}
.banner strong{color:var(--text);display:block;margin-bottom:3px}
.banner-blue{background:rgba(12,116,137,.08);border:1px solid var(--cyan-b)}
.banner-lime{background:var(--lime-dim);border:1px solid var(--lime-b);color:var(--lime)}
.banner-amber{background:var(--amber-dim);border:1px solid var(--amber-b)}
.banner-green{background:var(--green-dim);border:1px solid var(--green-b)}

/* DISCLAIMER */
.disclaimer{text-align:center;font-size:11px;color:var(--dim);margin-top:1rem;font-family:'DM Mono',monospace;line-height:1.6}

/* FACE VERIFY */
.fsc-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:1.5rem}
.fsc{background:var(--card2);border:1px solid var(--border);border-radius:12px;padding:10px 6px;text-align:center;font-size:10px;color:var(--dim);font-family:'DM Mono',monospace;transition:all .3s}
.fsc .fsc-ico{font-size:18px;display:block;margin-bottom:4px}
.fsc.act{border-color:var(--lime-b);color:var(--lime);background:var(--lime-dim)}
.fsc.done{border-color:var(--green-b);color:var(--green);background:var(--green-dim)}
.fp-row{display:flex;gap:8px;justify-content:center;margin-bottom:1.5rem}
.fp{width:44px;height:4px;border-radius:2px;background:var(--border);transition:background .4s}
.fp.act{background:var(--lime)}.fp.done{background:var(--green)}
.face-circle{position:relative;width:240px;height:240px;border-radius:50%;overflow:hidden;background:#000;border:2px solid var(--border2);margin:0 auto 1.25rem}
.face-circle video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.face-ring{position:absolute;inset:8px;border-radius:50%;border:3px solid rgba(14,124,123,.45);pointer-events:none;transition:all .3s}
.face-ring.ok{border-color:var(--green);box-shadow:0 0 24px rgba(74,222,128,.5);animation:rpulse .6s}
@keyframes rpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.face-dots{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 10px;pointer-events:none}
.fdot{width:12px;height:12px;border-radius:50%;background:rgba(14,124,123,.14);border:1.5px solid rgba(14,124,123,.32);transition:all .3s}
.fdot.lit{background:var(--lime);border-color:var(--lime);box-shadow:0 0 10px rgba(14,124,123,.55)}
.face-arrow{position:absolute;top:50%;transform:translateY(-50%);font-size:26px;font-weight:900;color:var(--lime);text-shadow:0 0 14px rgba(14,124,123,.55);opacity:0;transition:opacity .3s;pointer-events:none}
.face-arrow.L{left:10px}.face-arrow.R{right:10px}.face-arrow.show{opacity:1}
.face-lbl{text-align:center;font-size:14px;color:var(--muted);margin-bottom:1rem;min-height:22px;font-weight:500}

/* TEST SCREENS */
.meta-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:1.25rem}
.mc{background:var(--card2);border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center}
.mc-l{font-size:10px;font-family:'DM Mono',monospace;color:var(--dim);letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:3px}
.mc-v{font-size:16px;font-weight:700;color:var(--text);font-family:'DM Mono',monospace}
.prog-track{height:3px;background:var(--border);border-radius:2px;margin-bottom:1.5rem;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--lime),var(--cyan));border-radius:2px;transition:width .4s ease}
.dots-row{display:flex;gap:6px;justify-content:center;margin-bottom:1.25rem;flex-wrap:wrap}
.dot{width:26px;height:26px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;font-family:'DM Mono',monospace;color:var(--dim);transition:all .2s}
.dot.pass{background:var(--green-dim);border-color:var(--green-b);color:var(--green)}
.dot.fail{background:var(--red-dim);border-color:var(--red-b);color:var(--red)}
.dot.cur{border-color:var(--lime-b);color:var(--lime);background:var(--lime-dim)}
.inp-row{display:flex;gap:8px;margin-bottom:10px}
.l-input{flex:1;background:var(--card2);border:1px solid var(--border2);border-radius:10px;padding:13px 16px;color:var(--text);font-family:'DM Mono',monospace;font-size:17px;letter-spacing:.1em;outline:none;transition:border-color .2s;text-transform:uppercase}
.l-input:focus{border-color:var(--lime-b)}
.l-input::placeholder{color:var(--dim);letter-spacing:0;font-size:13px;font-family:'Outfit',sans-serif}
.btn-check{padding:13px 24px;background:linear-gradient(135deg,var(--lime),#0a5958);color:#fff;border:none;border-radius:10px;font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer}
.btn-skip{width:100%;padding:10px;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--muted);font-size:12px;font-family:'DM Mono',monospace;cursor:pointer;margin-top:8px}
.btn-skip:hover{border-color:var(--border2);color:var(--text)}
.chart-box{background:#fff;border:1px solid var(--border2);border-radius:16px;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:1.25rem;position:relative;padding:1.5rem;box-shadow:inset 0 0 0 1px rgba(16,35,61,.03)}
.chart-ltrs{font-family:'DM Mono',monospace;font-weight:700;color:#111;letter-spacing:.1em;line-height:1;text-align:center}
.chart-tag{position:absolute;bottom:10px;right:12px;font-size:10px;font-family:'DM Mono',monospace;color:#ccc}
.near-box{background:#fff;border:1px solid var(--border2);border-radius:16px;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:1.25rem;padding:2rem}
.near-text{font-family:Georgia,serif;color:#111;line-height:1.55;text-align:left;max-width:360px}
.contrast-box{border-radius:16px;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:1.25rem;padding:2rem;transition:background .3s}
.contrast-ltr{font-family:'DM Mono',monospace;font-weight:700;font-size:100px;line-height:1;transition:color .3s}
canvas{border-radius:50%;display:block;margin:0 auto 1.25rem;box-shadow:0 0 0 2px var(--border)}
.cv-choices{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.cch{padding:14px 6px;border:1px solid var(--border);border-radius:10px;background:var(--card2);color:var(--text);font-family:'DM Mono',monospace;font-size:20px;font-weight:700;text-align:center;cursor:pointer;transition:all .15s}
.cch:hover{border-color:var(--lime-b);background:var(--lime-dim);color:var(--lime)}
.cch.ok{border-color:var(--green-b);background:var(--green-dim);color:var(--green)}
.cch.bad{border-color:var(--red-b);background:var(--red-dim);color:var(--red)}
.btn-yes{width:100%;padding:13px;background:var(--green-dim);border:1px solid var(--green-b);border-radius:12px;color:var(--green);font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer}
.btn-no{width:100%;padding:13px;background:var(--red-dim);border:1px solid var(--red-b);border-radius:12px;color:var(--red);font-family:'Outfit',sans-serif;font-size:14px;font-weight:700;cursor:pointer}

/* RESULTS */
.sum-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:1.5rem}
.sum-card{background:var(--card2);border:1px solid var(--border);border-radius:16px;padding:1.25rem;display:flex;flex-direction:column;gap:8px}
.sc-title{font-size:10px;font-family:'DM Mono',monospace;color:var(--dim);letter-spacing:.1em;text-transform:uppercase}
.sc-val{font-size:2rem;font-weight:800;font-family:'DM Mono',monospace;line-height:1}
.res-badge{display:inline-block;padding:4px 12px;border-radius:100px;font-size:11px;font-weight:700;font-family:'DM Mono',monospace}
.rb-ok{background:var(--green-dim);color:var(--green);border:1px solid var(--green-b)}
.rb-mid{background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber-b)}
.rb-bad{background:var(--red-dim);color:var(--red);border:1px solid var(--red-b)}
.bd-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.bd-row:last-child{border-bottom:none}
.bd-lbl{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted);min-width:70px}
.bd-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.bd-bar{height:100%;border-radius:2px;transition:width .8s ease}
.bd-st{font-size:10px;font-family:'DM Mono',monospace;min-width:32px;text-align:right}

/* PLAN CARDS */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:1.5rem}
.plan-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:1.75rem;display:flex;flex-direction:column;gap:9px;position:relative;transition:all .2s;cursor:pointer}
.plan-card:hover{transform:translateY(-3px);border-color:var(--border2)}
.plan-card.hot{border-color:var(--lime-b);background:linear-gradient(160deg,rgba(212,255,71,.08),rgba(212,255,71,.02))}
.plan-hot-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--lime),#0a5958);color:#fff;font-size:9px;font-weight:800;letter-spacing:.1em;padding:3px 12px;border-radius:100px;white-space:nowrap;font-family:'DM Mono',monospace}
.plan-name{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:'DM Mono',monospace}
.plan-price{font-family:'DM Serif Display',serif;font-size:2.8rem;font-weight:400;line-height:1;color:var(--text)}
.plan-price em{font-size:13px;font-family:'Outfit',sans-serif;color:var(--muted);font-style:normal;font-weight:400}
.plan-desc{font-size:13px;color:var(--muted);line-height:1.5;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.plan-feats{display:flex;flex-direction:column;gap:8px;flex:1}
.pf{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--muted)}
.pf::before{content:'✓';color:var(--green);font-weight:700;font-size:11px;flex-shrink:0;margin-top:1px}
.pf.no::before{content:'–';color:var(--dim)}.pf.no{color:var(--dim)}
.plan-btn{margin-top:auto;width:100%;padding:11px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;font-family:'Outfit',sans-serif;text-decoration:none;display:block;text-align:center}
.pb-fill{background:linear-gradient(135deg,var(--lime),#0a5958);border:none;color:#fff}
.pb-outline{background:transparent;border:1px solid var(--border2);color:var(--text)}
.pb-outline:hover{border-color:var(--lime-b);color:var(--lime)}

/* PAYMENT */
.express-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1.25rem}
.xbtn{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 12px;border-radius:14px;background:var(--card2);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Outfit',sans-serif;border:1px solid var(--border2)}
.xbtn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(16,35,61,.14)}
.xbtn.paypal{border-color:rgba(0,156,222,.3)}.xbtn.apple{border-color:rgba(16,35,61,.35)}
.xbtn.google{border-color:rgba(66,133,244,.3)}.xbtn.samsung{border-color:rgba(91,142,255,.3)}
.divider{display:flex;align-items:center;gap:10px;margin:1.25rem 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}
.divider span{font-size:11px;color:var(--dim);font-family:'DM Mono',monospace;white-space:nowrap}
.secure-row{display:flex;align-items:center;justify-content:center;gap:6px;font-size:11px;color:var(--dim);font-family:'DM Mono',monospace;margin:1rem 0}
.card-wrap{position:relative}.card-wrap .fi{padding-right:90px}
.card-icons{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;gap:4px;align-items:center}

/* TEST SELECTOR */
.ts-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:1.5rem}
.ts-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:1.25rem;cursor:pointer;transition:all .2s;position:relative}
.ts-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.ts-card.on{border-color:var(--lime-b);background:var(--lime-dim)}
.ts-check{position:absolute;top:12px;right:12px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;transition:all .2s}
.ts-card.on .ts-check{background:var(--lime);border-color:var(--lime);color:#fff}
.ts-ico{font-size:24px;margin-bottom:.6rem;display:block}
.ts-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.ts-desc{font-size:12px;color:var(--muted);line-height:1.4}
.locked-badge{font-size:10px;background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber-b);padding:2px 8px;border-radius:100px;font-family:'DM Mono',monospace;display:inline-block;margin-top:6px}
.eye-sel{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:1.5rem}
.eye-opt{cursor:pointer}.eye-opt input{display:none}
.eye-opt span{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:1px solid var(--border);border-radius:12px;font-size:13px;font-weight:600;color:var(--muted);transition:all .2s;cursor:pointer}
.eye-opt input:checked+span{border-color:var(--lime-b);background:var(--lime-dim);color:var(--lime)}

/* HOME PAGE */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:140px 2rem 80px;position:relative;overflow:hidden}
.hero-glow{position:absolute;inset:0;pointer-events:none}
.glow-1{position:absolute;top:-10%;left:50%;transform:translateX(-50%);width:900px;height:900px;background:radial-gradient(circle,rgba(108,75,193,.10) 0%,transparent 60%)}
.glow-2{position:absolute;bottom:-20%;left:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(14,124,123,.08) 0%,transparent 60%)}
.glow-3{position:absolute;top:30%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(12,116,137,.08) 0%,transparent 60%)}
.grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(16,35,61,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(16,35,61,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 100%)}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--violet-dim);border:1px solid var(--violet-b);border-radius:100px;padding:7px 20px;font-size:12px;font-weight:600;color:var(--violet);letter-spacing:.06em;text-transform:uppercase;margin-bottom:2rem}
.hero-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--lime);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.75)}}
.hero h1{font-family:'DM Serif Display',serif;font-size:clamp(3rem,8vw,6.5rem);font-weight:400;line-height:1.02;letter-spacing:-.04em;margin-bottom:1.5rem}
.hero h1 .grad{background:linear-gradient(135deg,var(--lime) 0%,var(--cyan) 50%,var(--violet) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:clamp(1rem,2.2vw,1.2rem);color:var(--muted);max-width:580px;margin:0 auto 3rem;line-height:1.75}
.hero-cta{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.cta-p{padding:17px 38px;background:linear-gradient(135deg,var(--lime),#0a5958);color:#fff;border:none;border-radius:100px;font-family:'Outfit',sans-serif;font-size:16px;font-weight:800;cursor:pointer;transition:all .25s;text-decoration:none;display:inline-block;letter-spacing:-.02em}
.cta-p:hover{transform:translateY(-3px);box-shadow:0 24px 48px rgba(14,124,123,.32)}
.cta-g{padding:17px 38px;background:transparent;border:1px solid var(--border2);color:var(--text);border-radius:100px;font-family:'Outfit',sans-serif;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.cta-g:hover{border-color:var(--lime-b);color:var(--lime)}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);border-radius:20px;overflow:hidden;background:var(--border);gap:1px;margin:0 auto 6rem}
.stat-box{background:var(--card);padding:2rem 1.5rem;text-align:center}
.stat-num{font-family:'DM Serif Display',serif;font-size:3rem;font-weight:400;line-height:1;background:linear-gradient(135deg,var(--lime),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.stat-lbl{font-size:13px;color:var(--muted)}

/* SECTION */
.section{padding:5rem 2rem;max-width:1100px;margin:0 auto}
.sec-tag{display:inline-block;background:var(--lime-dim);border:1px solid var(--lime-b);border-radius:100px;padding:4px 16px;font-size:11px;font-weight:700;color:var(--lime);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem}
.sec-title{font-family:'DM Serif Display',serif;font-size:clamp(2rem,4.5vw,3rem);font-weight:400;line-height:1.12;letter-spacing:-.03em;margin-bottom:.75rem}
.sec-title em{font-style:italic;color:var(--lime)}
.sec-sub{font-size:16px;color:var(--muted);line-height:1.7;max-width:520px;margin-bottom:3rem}
.tests-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.tc{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:2rem;transition:all .3s;position:relative;overflow:hidden}
.tc:hover{transform:translateY(-5px);border-color:var(--border2)}
.tc-ico{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:1.25rem}
.tc-ico.c1{background:var(--lime-dim);border:1px solid var(--lime-b)}
.tc-ico.c2{background:var(--cyan-dim);border:1px solid var(--cyan-b)}
.tc-ico.c3{background:var(--violet-dim);border:1px solid var(--violet-b)}
.tc-ico.c4{background:var(--pink-dim);border:1px solid var(--pink-b)}
.tc h3{font-size:19px;font-weight:700;margin-bottom:.5rem;letter-spacing:-.02em}
.tc p{font-size:14px;color:var(--muted);line-height:1.65}
.tc-pill{display:inline-flex;align-items:center;margin-top:1.25rem;padding:4px 14px;border-radius:100px;font-size:11px;font-weight:600;font-family:'DM Mono',monospace}
.tp1{background:var(--lime-dim);color:var(--lime)}.tp2{background:var(--cyan-dim);color:var(--cyan)}
.tp3{background:var(--violet-dim);color:var(--violet)}.tp4{background:var(--pink-dim);color:var(--pink)}

/* HOW IT WORKS */
.how-section{padding:5rem 2rem;background:var(--card);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.how-inner{max-width:1100px;margin:0 auto}
.how-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:3.5rem;position:relative}
.how-steps::before{content:'';position:absolute;top:27px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,var(--violet),var(--lime),var(--cyan),transparent)}
.how-step{text-align:center;padding:0 .75rem}
.how-num{width:54px;height:54px;border-radius:50%;background:var(--card2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:'DM Mono',monospace;color:var(--lime);margin:0 auto 1.25rem}
.how-step h4{font-size:14px;font-weight:700;margin-bottom:.4rem;letter-spacing:-.01em}
.how-step p{font-size:12px;color:var(--muted);line-height:1.5}

/* FOOTER */
footer{background:var(--card);border-top:1px solid var(--border);padding:4rem 2rem 2rem}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand{font-size:22px;font-weight:800;letter-spacing:-.03em;margin-bottom:.75rem;display:flex;align-items:center;gap:10px}
.footer-tagline{font-size:13px;color:var(--muted);line-height:1.7}
footer h5{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:1rem;font-family:'DM Mono',monospace}
footer a{display:block;font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:7px;transition:color .2s}
footer a:hover{color:var(--lime)}
.footer-bottom{max-width:1100px;margin:0 auto;padding-top:2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--dim)}

/* RESPONSIVE */
@media(max-width:900px){.stats-grid{grid-template-columns:1fr 1fr}.tests-grid{grid-template-columns:1fr}.how-steps{grid-template-columns:1fr 1fr}.how-steps::before{display:none}.plan-grid{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.fg,.check-grid,.ts-grid,.sum-grid,.express-grid{grid-template-columns:1fr}.eye-sel{grid-template-columns:1fr}.cv-choices{grid-template-columns:repeat(2,1fr)}.fsc-cards{grid-template-columns:repeat(2,1fr)}.footer-inner{grid-template-columns:1fr}.page{padding:5.5rem 1rem 3rem}.card{padding:1.25rem}.hero h1{font-size:2.8rem}}

/* ═══ DESKTOP ENHANCEMENT ═══ */
/* Subtle side glow so the narrow centred layout looks intentional */
body {
  background:
    radial-gradient(ellipse 60% 50% at 10% 20%, rgba(108,75,193,.05) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 90% 70%, rgba(12,116,137,.05) 0%, transparent 60%),
    radial-gradient(ellipse 80% 40% at 50% 0%,  rgba(14,124,123,.04) 0%, transparent 55%),
    var(--bg);
}

/* Card depth on desktop */
@media (min-width: 768px) {
  .card {
    box-shadow: 0 4px 28px rgba(16,35,61,.10);
  }
  .page {
    padding-top: 7rem;
  }
  /* Subtle grid lines behind content */
  body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image:
      linear-gradient(rgba(16,35,61,.035) 1px, transparent 1px),
      linear-gradient(90deg, rgba(16,35,61,.035) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
    z-index: 0;
  }
  body > * { position: relative; z-index: 1; }

  /* Wider test area on desktop for eye charts */
  #pg-tests .card {
    max-width: 680px;
    margin-left: auto;
    margin-right: auto;
  }
  .chart-box    { min-height: 280px; }
  .near-box     { min-height: 260px; }
  .contrast-box { min-height: 260px; }
  canvas        { width: 320px; height: 320px; }
}

/* Progress bar glow */
.prog-fill {
  box-shadow: 0 0 8px rgba(14,124,123,.45);
}

/* Card hover lift on desktop */
@media (min-width: 768px) {
  .ts-card:hover { box-shadow: 0 8px 28px rgba(16,35,61,.14); }
}

/* ═══ MOBILE SAFETY HARDENING ═══ */
html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}
* {
  max-width: 100%;
}

/* ═══ FORCE NAV + SCROLL FIX ═══ */
html, body {
  height: auto !important;
  min-height: 100vh;
  overflow-y: auto !important;
  display: block !important;
}
.nav {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  z-index: 1000 !important;
}
.nav-logo {
  display: flex !important;
  align-items: center !important;
  position: static !important;
}
.nav-logo img {
  position: static !important;
  display: block !important;
}

/* ═══ LOGO CLIPPING FIX ═══ */
.nav {
  min-height: 68px;
  padding: 10px 2rem !important;
  overflow: visible !important;
}
.nav-logo {
  overflow: visible !important;
}
.nav-logo img {
  height: 40px !important;
  width: auto !important;
  max-height: none !important;
  display: block !important;
  overflow: visible !important;
}

/* ═══ PRICING TABS (Individual / Corporate) ═══ */
.ptabs{display:flex;justify-content:center;gap:8px;margin-bottom:2rem;flex-wrap:wrap}
.ptab{padding:10px 22px;border-radius:100px;border:1px solid var(--border2);background:var(--card2);color:var(--muted);font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.ptab:hover{border-color:var(--lime-b);color:var(--text)}
.ptab.active{background:linear-gradient(135deg,var(--lime),#0a5958);color:#fff;border-color:transparent}

/* 2-card centered variant used by both pricing tabs */
.plan-grid.cols-2{grid-template-columns:repeat(2,1fr);max-width:660px;margin-left:auto;margin-right:auto}
@media(max-width:900px){.plan-grid.cols-2{grid-template-columns:1fr}}
