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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --bg:#090C0C;--bg2:#0D1212;--surface:#131C1C;
  --border:rgba(255,255,255,0.06);--border-md:rgba(255,255,255,0.11);
  --text:#EDF2F1;--text-2:#7AA49E;--text-3:#3D5E58;
  --accent:#00C8A8;--accent-2:#00A88C;--accent-dim:rgba(0,200,168,0.09);
  --coral:#9B8AFB;--coral-2:#7C6CF0;--coral-dim:rgba(155,138,251,0.10);
  --nav-bg:rgba(9,12,12,0.90);
  --glow-teal:rgba(0,200,168,0.05);--glow-coral:rgba(155,138,251,0.05);
  --tag-amber-bg:rgba(234,160,40,0.12);--tag-amber-c:#E8A028;
  --tag-red-bg:rgba(220,60,60,0.12);--tag-red-c:#E05555;
  --tag-green-bg:rgba(0,200,168,0.10);--tag-green-c:#00C8A8;
  --font-display:'Clash Display',sans-serif;
  --font-serif:'Instrument Serif',serif;
  --font-body:'DM Sans',sans-serif;
  --radius:6px;--radius-lg:14px;--radius-xl:20px;
  --t:0.3s cubic-bezier(0.4,0,0.2,1)
}
html.light{
  --bg:#F5F6F4;--bg2:#ECEEE9;--surface:#FFFFFF;
  --border:rgba(0,0,0,0.06);--border-md:rgba(0,0,0,0.11);
  --text:#0D1A18;--text-2:#3D7069;--text-3:#8AADA8;
  --accent:#008F74;--accent-2:#006D59;--accent-dim:rgba(0,143,116,0.09);
  --coral:#7C6CF0;--coral-2:#6254D4;--coral-dim:rgba(124,108,240,0.10);
  --nav-bg:rgba(245,246,244,0.92);
  --glow-teal:rgba(0,143,116,0.04);--glow-coral:rgba(124,108,240,0.04);
}

/* CURSOR */
body{cursor:none}
#cursor{position:fixed;width:12px;height:12px;border-radius:50%;background:var(--accent);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,opacity .25s;mix-blend-mode:difference}
#cursor-ring{position:fixed;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--accent);pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .4s,height .4s,border-color .3s,opacity .3s;opacity:0.5}
body.cursor-hover #cursor{width:48px;height:48px;background:var(--coral);opacity:0.15}
body.cursor-hover #cursor-ring{width:56px;height:56px;border-color:var(--coral);opacity:0.8}

body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .4s,color .4s}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 52px;height:70px;display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background .4s}
.nav-logo{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.03em;text-decoration:none}
.nav-logo span{color:var(--coral)}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{font-size:12px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);text-decoration:none;transition:color var(--t)}
.nav-links a:hover,.nav-active{color:var(--text)!important}
.nav-cta{font-size:12px;font-weight:600;color:var(--bg)!important;background:var(--coral);padding:9px 22px;border-radius:30px;text-decoration:none;letter-spacing:.04em;transition:background var(--t),transform var(--t)}
.nav-cta:hover{background:var(--coral-2)!important;transform:translateY(-1px)}
.mode-toggle{background:none;border:1px solid var(--border-md);border-radius:20px;padding:6px 14px;cursor:none;display:flex;align-items:center;gap:7px;font-family:var(--font-body);font-size:12px;color:var(--text-3);transition:border-color var(--t),color var(--t)}
.mode-toggle:hover{border-color:var(--accent);color:var(--text)}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:14px;font-weight:600;color:#fff;background:var(--accent);padding:14px 30px;border-radius:30px;text-decoration:none;letter-spacing:.01em;transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,200,168,0.2)}
.btn-coral{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:14px;font-weight:600;color:#fff;background:var(--coral);padding:14px 30px;border-radius:30px;text-decoration:none;letter-spacing:.01em;transition:background var(--t),transform var(--t),box-shadow var(--t)}
.btn-coral:hover{background:var(--coral-2);transform:translateY(-2px);box-shadow:0 12px 32px rgba(232,133,106,0.25)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-2);text-decoration:none;transition:color var(--t)}
.btn-ghost:hover{color:var(--text)}
.btn-ghost svg{transition:transform var(--t)}
.btn-ghost:hover svg{transform:translateX(4px)}

/* SECTION */
section{padding:110px 52px;position:relative}
.section-inner{max-width:1180px;margin:0 auto}
.section-eyebrow{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--coral);display:inline-flex;align-items:center;gap:8px;margin-bottom:16px}
.section-eyebrow::before{content:'';width:20px;height:1.5px;background:var(--coral)}

/* FADE ANIMATIONS */
.fade-up{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up-2{opacity:0;transform:translateY(32px);transition:opacity .7s .15s ease,transform .7s .15s ease}
.fade-up-2.visible{opacity:1;transform:translateY(0)}
.fade-up-3{opacity:0;transform:translateY(32px);transition:opacity .7s .3s ease,transform .7s .3s ease}
.fade-up-3.visible{opacity:1;transform:translateY(0)}

/* FOOTER */
footer{padding:40px 52px;display:flex;align-items:center;justify-content:space-between}
.footer-logo{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-3);letter-spacing:-.02em}
.footer-logo span{color:var(--coral)}
.footer-copy{font-size:12px;color:var(--text-3)}

/* MODAL */
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:200;overflow-y:auto;padding:40px 24px;backdrop-filter:blur(12px)}
#modal-overlay.open{display:flex;align-items:flex-start;justify-content:center}
#modal-box{background:var(--bg2);border:1px solid var(--border-md);border-radius:20px;width:100%;max-width:880px;position:relative;padding:52px;transition:background .4s}
#modal-close{position:sticky;top:0;float:right;background:var(--surface);border:1px solid var(--border-md);border-radius:50%;width:36px;height:36px;font-size:18px;cursor:none;color:var(--text-2);display:flex;align-items:center;justify-content:center;transition:color var(--t),border-color var(--t);z-index:10;margin-bottom:8px}
#modal-close:hover{color:var(--text);border-color:var(--coral)}
.m-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);display:flex;align-items:center;gap:8px;margin-bottom:8px}
.m-eyebrow::before{content:'';width:18px;height:1.5px;background:var(--coral)}
.m-title{font-family:var(--font-display);font-size:clamp(26px,4vw,40px);font-weight:700;letter-spacing:-.02em;color:var(--text);margin-bottom:8px;line-height:1.05}
.m-subtitle{font-size:14px;color:var(--text-3);margin-bottom:28px}
.m-divider{height:1px;background:var(--border);margin:28px 0}
.m-section-title{font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text);margin-bottom:14px;letter-spacing:-.01em}
.m-body{font-size:14px;color:var(--text-2);line-height:1.8;margin-bottom:12px}
.m-health-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}
.m-health-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:background .4s}
.m-health-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.m-health-val{font-size:14px;font-weight:500;color:var(--text);margin-bottom:4px}
.m-health-note{font-size:12px;color:var(--text-2);line-height:1.5}
.m-status-amber{color:#E8A028}.m-status-red{color:#E05555}.m-status-green{color:#00C8A8}
.m-phase{border-left:2px solid var(--coral);padding-left:18px;margin-bottom:20px}
.m-phase-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}
.m-phase ul{font-size:13px;color:var(--text-2);line-height:1.9;padding-left:16px}
.m-outcomes{display:flex;gap:12px;flex-wrap:wrap;background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-top:8px}
.m-outcome-item{font-size:13px;color:var(--text-2)}
.m-outcome-item::before{content:'✦ ';color:var(--accent)}
.m-ebr{background:var(--surface);border-radius:var(--radius-lg);padding:20px;margin-top:8px}
.m-ebr-slide{padding:10px 0;border-bottom:1px solid var(--border)}
.m-ebr-slide:last-child{border-bottom:none}
.m-ebr-num{font-size:10px;color:var(--coral);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}
.m-ebr-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:4px}
.m-ebr-content{font-size:12px;color:var(--text-2);line-height:1.6}
.m-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}
.m-table th{text-align:left;font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:8px 12px;border-bottom:1px solid var(--border)}
.m-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-2)}
.m-table tr:last-child td{border-bottom:none}
.m-table td:first-child{color:var(--text)}
.m-screenshots{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:8px}
.m-screenshot{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-md);aspect-ratio:16/9;background:var(--surface);cursor:none;transition:border-color var(--t),transform var(--t)}
.m-screenshot:hover{border-color:var(--accent);transform:scale(1.02)}
.m-screenshot img{width:100%;height:100%;object-fit:cover;display:block}
.m-screenshot-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,0.65);padding:8px 12px;font-size:11px;color:rgba(255,255,255,0.85);backdrop-filter:blur(4px)}
.m-tag-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.cs-tag{font-size:11px;font-weight:500;letter-spacing:.03em;padding:3px 10px;border-radius:20px;background:var(--accent-dim);color:var(--accent)}
.cs-tag-amber{background:var(--tag-amber-bg);color:var(--tag-amber-c)}
.cs-tag-red{background:var(--tag-red-bg);color:var(--tag-red-c)}
.cs-tag-green{background:var(--tag-green-bg);color:var(--tag-green-c)}

/* LIGHTBOX */
#lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.94);z-index:300;align-items:center;justify-content:center}
#lightbox.open{display:flex}
#lightbox-img{max-width:90vw;max-height:88vh;border-radius:var(--radius-lg);object-fit:contain}
#lightbox-close{position:fixed;top:24px;right:24px;background:rgba(255,255,255,0.1);border:none;border-radius:50%;width:40px;height:40px;font-size:20px;cursor:none;color:#fff;display:flex;align-items:center;justify-content:center}

/* JOURNEY MAP */
.jm-wrap{margin:0 0 8px;overflow-x:auto}
.jm-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:12px;padding:8px 12px;background:var(--surface);border-radius:var(--radius);border-left:2px solid var(--tag-red-c)}
.jm-green{border-left-color:var(--accent);color:var(--accent);background:var(--accent-dim)}

@media(max-width:900px){
  nav{padding:0 24px}
  section{padding:80px 24px}
  footer{padding:28px 24px;flex-direction:column;gap:10px;text-align:center}
  .m-health-grid{grid-template-columns:1fr}
  .m-screenshots{grid-template-columns:1fr}
  #modal-box{padding:24px}
}
