/* ============================================================
   Curem marketing site. Layout + motion on top of brand tokens.
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;overflow-x:hidden;background:var(--curem-white)}
img,svg{max-width:100%;display:block}
a{color:var(--curem-blue);text-decoration:none}
.container{width:100%;max-width:1160px;margin:0 auto;padding:0 28px}
.skip{position:absolute;left:-9999px;top:0;background:var(--curem-blue);color:#fff;padding:10px 16px;border-radius:8px;z-index:60}
.skip:focus{left:16px;top:16px}

/* ---- Type ---- */
.display{font-family:var(--font-display);font-weight:300;letter-spacing:-.02em;font-size:clamp(2.05rem,7vw,4.4rem);line-height:1.04;margin:0;color:#fff}
h2{font-family:var(--font-display);font-weight:600;letter-spacing:-.015em;font-size:clamp(1.9rem,3.6vw,2.6rem);line-height:1.12;margin:0 0 20px;color:var(--curem-ink)}
h3{font-family:var(--font-sans);font-weight:600;font-size:1.1rem;margin:0;color:var(--curem-ink)}
.eyebrow,.label{font-family:var(--font-sans);font-weight:600;font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;margin:0 0 16px}
.eyebrow{color:var(--curem-signal-light)}
.label{color:var(--curem-blue)}
.lead{font-family:var(--font-display);font-weight:300;font-style:italic;font-size:clamp(1.25rem,2.2vw,1.6rem);line-height:1.4}
.prose{color:var(--curem-text);font-size:1.0625rem;line-height:1.65;max-width:54ch;margin:0}
.center-prose{margin-left:auto;margin-right:auto}
.ticks{list-style:none;margin:24px 0 0;padding:0}
.ticks li{position:relative;padding:9px 0 9px 30px;color:var(--curem-text);border-top:1px solid var(--curem-hair)}
.ticks li::before{content:"";position:absolute;left:2px;top:15px;width:9px;height:9px;border-radius:50%;background:var(--curem-signal);box-shadow:0 0 0 4px var(--curem-signal-50)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-weight:600;font-size:.95rem;line-height:1;padding:13px 22px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:transform var(--dur) var(--ease),background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.btn-sm{padding:9px 16px;font-size:.9rem}
.btn-lg{padding:16px 28px;font-size:1rem}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn-primary{background:var(--curem-blue);color:#fff;box-shadow:0 6px 18px rgba(21,69,126,.28)}
.btn-primary:hover{background:var(--curem-blue-700);box-shadow:0 10px 26px rgba(21,69,126,.34)}
.btn-ghost{background:rgba(255,255,255,.04);color:#fff;border-color:rgba(255,255,255,.26)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}

/* ---- Header ---- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),backdrop-filter var(--dur) var(--ease)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.lockup{display:inline-flex;align-items:center;gap:11px;color:#fff}
.lockup .mark{color:#fff}
.lockup span{font-family:var(--font-sans);font-weight:600;font-size:21px;letter-spacing:-.01em}
.header-nav{display:flex;align-items:center;gap:28px}
.header-nav a{color:rgba(255,255,255,.82);font-size:.95rem;font-weight:500}
.header-nav a:hover{color:#fff}
.header-nav .btn-primary{color:#fff}
.site-header.scrolled{background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(12px);box-shadow:0 1px 0 var(--curem-hair)}
.site-header.scrolled .lockup,.site-header.scrolled .lockup .mark{color:var(--curem-ink)}
.site-header.scrolled .header-nav a:not(.btn){color:var(--curem-text)}
.site-header.scrolled .header-nav a:not(.btn):hover{color:var(--curem-blue)}
.header-nav .btn-primary,.site-header.scrolled .header-nav .btn-primary{color:#fff}

/* ============ Hero ============ */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#0B2239 0%,#0C2945 60%,#0B2239 100%);padding:148px 0 96px;color:rgba(255,255,255,.86)}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5}
.orb-1{width:620px;height:620px;left:-160px;top:-180px;background:radial-gradient(circle at 30% 30%,#1E5FA8,transparent 70%);animation:float1 16s var(--ease) infinite alternate}
.orb-2{width:520px;height:520px;right:-120px;bottom:-160px;background:radial-gradient(circle at 60% 40%,#14A081,transparent 70%);opacity:.32;animation:float2 19s var(--ease) infinite alternate}
.grid-fade{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:30px 30px;-webkit-mask-image:radial-gradient(120% 90% at 70% 10%,#000 0%,transparent 70%);mask-image:radial-gradient(120% 90% at 70% 10%,#000 0%,transparent 70%)}
.rings{position:absolute;right:6%;top:34%;width:520px;height:520px;transform:translateY(-50%)}
.rings span{position:absolute;inset:0;margin:auto;border-radius:50%;border:1px solid rgba(255,255,255,.10)}
.rings span:nth-child(1){width:160px;height:160px}
.rings span:nth-child(2){width:300px;height:300px;border-style:dashed;border-color:rgba(95,203,180,.22);animation:spin 40s linear infinite}
.rings span:nth-child(3){width:440px;height:440px}
.rings span:nth-child(4){width:560px;height:560px;border-color:rgba(255,255,255,.05)}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float1{to{transform:translate(40px,30px)}}
@keyframes float2{to{transform:translate(-40px,-26px)}}

.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero-copy{max-width:560px}
.hero .eyebrow{color:var(--curem-signal-light)}
.hero-lead{color:#fff;margin:22px 0 0;max-width:30ch}
.hero-body{color:rgba(255,255,255,.72);font-size:1.0625rem;line-height:1.62;max-width:50ch;margin:20px 0 0}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero-trust{margin:22px 0 0;color:rgba(255,255,255,.5);font-size:.85rem}

/* ---- App mockup ---- */
.hero-visual{position:relative;perspective:1600px}
.app{transform:rotateY(-12deg) rotateX(5deg);transform-style:preserve-3d;border-radius:16px;overflow:hidden;background:#0E2740;border:1px solid rgba(255,255,255,.12);box-shadow:0 40px 90px -30px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.03);transition:transform .6s var(--ease)}
.hero-visual:hover .app{transform:rotateY(-6deg) rotateX(3deg)}
.app-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.08)}
.dots{display:inline-flex;gap:6px}.dots i{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.18)}
.app-title{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:600;font-size:.9rem}
.app-pill{margin-left:auto;font-size:.68rem;font-weight:600;letter-spacing:.04em;color:#5FCBB4;background:rgba(95,203,180,.14);padding:3px 9px;border-radius:999px}
.app-body{display:grid;grid-template-columns:120px 1fr}
.app-side{display:flex;flex-direction:column;gap:4px;padding:16px 10px;border-right:1px solid rgba(255,255,255,.07)}
.nav-i{font-size:.78rem;color:rgba(255,255,255,.55);padding:7px 10px;border-radius:7px}
.nav-i.is-active{color:#fff;background:rgba(95,203,180,.14)}
.app-main{padding:16px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.kpi{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:10px}
.kpi-l{display:block;font-size:.62rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.06em}
.kpi-v{display:block;font-weight:600;font-size:1.25rem;color:#fff;margin-top:4px;font-variant-numeric:tabular-nums}
.app-chart{margin-top:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:12px}
.chart-head{display:flex;justify-content:space-between;font-size:.72rem;color:rgba(255,255,255,.6);margin-bottom:6px}
.chart-tag{color:#5FCBB4}
.spark{width:100%;height:70px}
.app-feed{margin-top:12px;display:flex;flex-direction:column;gap:7px}
.feed-row{display:flex;align-items:center;gap:10px;font-size:.78rem;color:rgba(255,255,255,.8)}
.av{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#1E5FA8,#15457E);flex:none}
.av-2{background:linear-gradient(135deg,#5FCBB4,#14A081)}
.av-3{background:linear-gradient(135deg,#D99A2B,#B97e16)}
.feed-row .ft{flex:1}
.feed-row .badge{font-size:.64rem;padding:2px 8px}

/* ============ Pain strip ============ */
.strip{background:var(--curem-ink);color:#fff;border-top:1px solid rgba(255,255,255,.06)}
.strip .container{padding-top:34px;padding-bottom:34px}
.strip-text{font-family:var(--font-display);font-weight:300;font-size:clamp(1.1rem,2vw,1.45rem);line-height:1.5;color:rgba(255,255,255,.82);max-width:60ch;margin:0}
.strip-text em{font-style:italic;color:#5FCBB4}

/* ============ Feature sections ============ */
.feature{padding:104px 0}
.feature.alt{background:var(--curem-panel)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.reverse .feature-copy{order:2}
.section-head{margin-bottom:48px}
.section-head.center{text-align:center;max-width:720px;margin-left:auto;margin-right:auto}
.narrow{max-width:760px;margin:0 auto;text-align:center}
.center{text-align:center}

/* framed photo */
.feature-art{position:relative}
.shot{position:relative;margin:0;border-radius:16px;overflow:hidden;box-shadow:0 30px 60px -28px rgba(11,34,57,.4);border:1px solid var(--curem-hair)}
.shot img{width:100%;height:auto;display:block}
.shot::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,34,57,.06),rgba(11,34,57,.30));mix-blend-mode:multiply}
.shot-chip{position:absolute;left:14px;bottom:14px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:rgba(11,34,57,.62);backdrop-filter:blur(6px);color:#fff;font-size:.78rem;padding:6px 11px;border-radius:999px}
.dot-live{width:8px;height:8px;border-radius:50%;background:#5FCBB4;box-shadow:0 0 0 3px rgba(95,203,180,.3)}
.tilt{transition:transform .5s var(--ease)}
.tilt:hover{transform:translateY(-4px)}

/* ============ Statement band ============ */
.statement{position:relative;overflow:hidden;padding:140px 0;text-align:center;color:#fff}
.statement-bg{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,24,38,.86),rgba(8,24,38,.92)),url("https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=2000&q=72&auto=format&fit=crop") center/cover no-repeat;background-attachment:fixed}
.statement .container{position:relative;z-index:2}
.statement-line{font-family:var(--font-display);font-weight:300;font-size:clamp(1.7rem,3.6vw,2.9rem);line-height:1.18;margin:0 auto;max-width:20ch}
.statement-sub{font-family:var(--font-display);font-style:italic;font-weight:300;color:#5FCBB4;font-size:clamp(1.1rem,1.8vw,1.4rem);margin:18px 0 0}

/* ============ Profile card ============ */
.profile-card{background:#fff;border:1px solid var(--curem-hair);border-radius:16px;box-shadow:0 30px 60px -30px rgba(11,34,57,.34);padding:22px 24px;max-width:440px;margin:0 auto;transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.lift{transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.lift:hover{transform:translateY(-5px);box-shadow:0 26px 50px -24px rgba(11,34,57,.32)}
.pc-head{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--curem-hair)}
.pc-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#1E5FA8,#15457E);color:#fff;font-weight:600;font-size:.9rem;display:grid;place-items:center;flex:none}
.pc-name{font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--curem-ink)}
.pc-sub{font-size:.8125rem;color:var(--curem-muted);margin-top:1px}
.pc-head .badge{margin-left:auto}
.timeline{list-style:none;margin:8px 0 0;padding:0}
.timeline li{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--curem-panel-2)}
.timeline li:last-child{border-bottom:0}
.t-dot{width:9px;height:9px;border-radius:50%;background:var(--curem-blue-300);flex:none}
.t-live{background:var(--curem-signal);box-shadow:0 0 0 4px var(--curem-signal-50)}
.t-text{flex:1;color:var(--curem-text);font-size:.9375rem}
.t-meta{color:var(--curem-muted);font-size:.8125rem;font-variant-numeric:tabular-nums}

/* ============ Badges ============ */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-sans);font-size:.7rem;font-weight:600;letter-spacing:.02em;padding:4px 10px;border-radius:999px;white-space:nowrap}
.badge-live{background:var(--curem-signal-50);color:var(--curem-signal-dark)}
.badge-soon{background:var(--curem-blue-50);color:var(--curem-blue)}
.badge-warn{background:#FBF1DD;color:#9A6A12}
.badge-plan{background:var(--curem-panel-2);color:var(--curem-muted)}

/* ============ Modules ============ */
.modules{padding:104px 0;background:#fff}
.mod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.mod-card{background:#fff;border:1px solid var(--curem-hair);border-radius:16px;padding:26px 24px;box-shadow:var(--shadow-sm)}
.mod-ico{font-size:1.7rem;line-height:1;color:var(--curem-blue);margin-bottom:16px}
.mod-card .card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.mod-card p{margin:0;color:var(--curem-text);font-size:.9375rem;line-height:1.55}

/* ============ Connect viz ============ */
.connect-viz{position:relative;height:300px;max-width:420px;margin:0 auto}
.connect-viz .node{position:absolute;background:#fff;border:1px solid var(--curem-hair);border-radius:10px;padding:9px 14px;font-size:.85rem;font-weight:600;color:var(--curem-ink);box-shadow:var(--shadow-sm);z-index:2}
.connect-viz .n1{left:0;top:30px}.connect-viz .n2{right:0;top:30px}
.connect-viz .n3{left:0;bottom:30px}.connect-viz .n4{right:0;bottom:30px}
.connect-viz .hub{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:74px;height:74px;border-radius:50%;background:#fff;border:1px solid var(--curem-hair);display:grid;place-items:center;box-shadow:0 14px 30px -12px rgba(11,34,57,.3);z-index:3}
.connect-viz .wires{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.connect-viz .wires path{fill:none;stroke:var(--curem-blue-300);stroke-width:2;stroke-dasharray:5 6;opacity:.7;animation:dash 1.4s linear infinite}
@keyframes dash{to{stroke-dashoffset:-22}}

/* ============ Accountability ============ */
.acct-row{display:flex;justify-content:center;flex-wrap:wrap;gap:18px;margin-top:44px}
.acct{flex:1;min-width:180px;max-width:230px;background:#fff;border:1px solid var(--curem-hair);border-radius:14px;padding:24px;box-shadow:var(--shadow-sm)}
.acct-k{display:block;font-family:var(--font-display);font-weight:600;font-size:2.4rem;color:var(--curem-blue);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.acct-l{display:block;color:var(--curem-muted);font-size:.875rem;margin-top:6px}

/* ============ AI recovery ============ */
.ai{position:relative;overflow:hidden;background:linear-gradient(180deg,#0B2239,#0C2A47 55%,#0B2239);padding:104px 0}
.ai-orb{position:absolute;width:560px;height:560px;right:-160px;top:-150px;border-radius:50%;filter:blur(100px);opacity:.4;background:radial-gradient(circle at 50% 50%,#14A081,transparent 70%);pointer-events:none}
.ai-split{position:relative;z-index:2;align-items:center}
.ai-copy h2{color:#fff}
.ai-prose{color:rgba(255,255,255,.74);font-size:1.0625rem;line-height:1.65;max-width:52ch;margin:0 0 16px}
.ai-points{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.ai-points li{color:rgba(255,255,255,.82);font-size:.95rem;line-height:1.5;padding-left:24px;position:relative}
.ai-points li::before{content:"";position:absolute;left:0;top:7px;width:9px;height:9px;border-radius:50%;background:var(--curem-signal);box-shadow:0 0 0 4px rgba(20,160,129,.2)}
.ai-points b{color:#fff;font-weight:600}

.ai-panel{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:20px;box-shadow:0 44px 100px -40px rgba(0,0,0,.7)}
.ai-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ai-live{display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:600;font-size:.92rem}
.pulse{position:relative;width:9px;height:9px;border-radius:50%;background:#5FCBB4}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:#5FCBB4;animation:pulse 1.9s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.55}100%{transform:scale(3.6);opacity:0}}
.ai-now{color:rgba(255,255,255,.5);font-size:.76rem;font-variant-numeric:tabular-nums}
.ai-kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.ai-kpi{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:12px 14px}
.ai-kpi-l{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.55)}
.ai-kpi-v{display:block;font-weight:600;font-size:1.5rem;color:#fff;margin-top:5px;font-variant-numeric:tabular-nums}
.ai-kpi-v.teal{color:#5FCBB4}
.ai-chart{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:12px 14px;margin-bottom:14px}
.ai-chart-head{display:flex;justify-content:space-between;font-size:.74rem;color:rgba(255,255,255,.62);margin-bottom:8px}
.ai-chart-head .up{color:#5FCBB4;font-weight:600}
.trend{width:100%;height:108px;display:block}
.trend .grid{stroke:rgba(255,255,255,.07);stroke-width:1}
.trend-line{fill:none;stroke:#5FCBB4;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:440;stroke-dashoffset:440}
.ai-visual.in .trend-line{animation:draw 1.7s var(--ease) .25s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.trend-dot{opacity:0}
.ai-visual.in .trend-dot{animation:dotin .5s var(--ease) 1.55s forwards}
@keyframes dotin{to{opacity:1}}
.ai-flags{display:flex;flex-direction:column;gap:9px}
.ai-flag{display:flex;align-items:center;gap:10px;font-size:.82rem;color:rgba(255,255,255,.82)}
.fdot{width:8px;height:8px;border-radius:50%;flex:none}
.fdot.warn{background:#D99A2B;box-shadow:0 0 0 3px rgba(217,154,43,.18)}
.fdot.ok{background:#5FCBB4;box-shadow:0 0 0 3px rgba(95,203,180,.2)}
.ftxt{flex:1}
.fval{color:#fff;font-weight:600;font-variant-numeric:tabular-nums}
.fstate{font-size:.64rem;font-weight:600;letter-spacing:.04em;padding:3px 9px;border-radius:999px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.66)}
.fstate.recovering,.fstate.saved{background:rgba(95,203,180,.16);color:#5FCBB4}
@media (prefers-reduced-motion:reduce){.trend-line{stroke-dashoffset:0!important}.trend-dot{opacity:1!important}}

/* ============ Trust strip ============ */
.trust{position:relative;overflow:hidden;padding:96px 0;color:#fff}
.trust-bg{position:absolute;inset:0;background:linear-gradient(120deg,rgba(11,34,57,.95) 30%,rgba(11,34,57,.7)),url("https://images.unsplash.com/photo-1521737604893-d14cc237f11d?w=1800&q=70&auto=format&fit=crop") center/cover no-repeat}
.trust-inner{position:relative;z-index:2;max-width:720px}
.trust-label{color:var(--curem-signal-light)}
.trust-text{font-family:var(--font-display);font-weight:300;font-size:clamp(1.25rem,2.4vw,1.7rem);line-height:1.4;color:#fff;margin:0}
.trust-text a{color:#fff;text-decoration:underline;text-underline-offset:3px}

/* ============ Final CTA ============ */
.cta-final{background:linear-gradient(180deg,#0B2239,#0E3358);padding:108px 0;text-align:center}
.cta-line{font-family:var(--font-display);font-weight:300;font-style:italic;color:#fff;font-size:clamp(1.9rem,4vw,2.8rem);line-height:1.1;margin:0}
.cta-sub{color:rgba(255,255,255,.7);max-width:46ch;margin:18px auto 30px;font-size:1.0625rem}

/* ============ Footer ============ */
.site-footer{background:#081826;padding:46px 0}
.foot-grid{display:flex;align-items:flex-start;justify-content:space-between;gap:28px;flex-wrap:wrap}
.foot-right{text-align:right}
.foot-credit{margin:0;color:rgba(255,255,255,.88);font-size:.95rem}
.foot-credit a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.foot-note{margin:8px 0 0;color:rgba(255,255,255,.5);font-size:.85rem}
.foot-note em{font-family:var(--font-display);font-style:italic}
.foot-copy{margin:10px 0 0;color:rgba(255,255,255,.4);font-size:.8rem}
/* footer logo: dictionary-style etymology note, aligned under the wordmark */
.foot-brand{display:flex;flex-direction:column;gap:6px}
.etym{margin:0 0 0 37px;line-height:1.25}            /* 37px = mark (26) + lockup gap (11): sits under "Curem" */
.etym-tag{font-family:var(--font-sans);font-weight:600;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--curem-signal-light);margin-right:8px;vertical-align:.14em}
.etym-word{font-family:var(--font-display);font-style:italic;font-size:1.08rem;color:rgba(255,255,255,.92)}
.etym-def{display:block;margin-top:1px;color:rgba(255,255,255,.5);font-size:.82rem;letter-spacing:.01em}

/* ============ Reveal motion ============ */
html.js [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js [data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}
[data-reveal-delay="5"]{transition-delay:.40s}

/* ============ Responsive ============ */
@media (max-width:960px){
  .hero{padding:124px 0 72px}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-visual{max-width:540px;margin:0 auto}
  .app{transform:none}
  .split{grid-template-columns:1fr;gap:40px}
  .split.reverse .feature-copy{order:0}
  .mod-grid{grid-template-columns:repeat(2,1fr)}
  .header-nav a:not(.btn){display:none}
  .statement-bg{background-attachment:scroll}   /* iOS Safari ignores fixed bg */
  .feature{padding:84px 0}
}
@media (max-width:560px){
  .container{padding:0 20px}
  .header-inner{height:62px}
  .hero{padding:104px 0 58px}
  .rings{display:none}                 /* keep the hero calm on small screens */
  .orb-1,.orb-2{opacity:.34}
  .app-side{display:none}               /* full width for the dashboard mock */
  .app-body{grid-template-columns:1fr}
  .feature,.modules{padding:64px 0}
  .statement{padding:88px 0}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .mod-grid{grid-template-columns:1fr}
  .foot-grid{flex-direction:column}.foot-right{text-align:left}
  .cta-row,.cta-row .btn,.cta-final .btn{width:100%}
  .cta-row{flex-direction:column}
  .acct{min-width:0;width:100%;max-width:none}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  html.js [data-reveal]{opacity:1;transform:none}
}
