/* ═══════════ LORVY · shared design system ═══════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{text-decoration:none;color:inherit}
:root{
  --bk:#fff9f6;
  --ink:#ffffff;
  --ink2:#f5f0ec;
  --ink3:#ede8e2;
  --line:rgba(0,0,0,.07);
  --line2:rgba(0,0,0,.11);
  --line3:rgba(0,0,0,.18);
  --tx:#1c1410;
  --tx2:#6b5e55;
  --mid:#a09088;
  --dim:#d4c8c0;
  --em:#1E7FB0;
  --emL:#4FAAD6;
  --emD:#13567A;
  --em2:#3D6FD0;
  --grad:linear-gradient(135deg,var(--em),var(--em2));
  --am:#1E7FB0;
  --gold:#13567A;
  --ok:#1a9648;
  --err:#d42020;
  --glow:rgba(126,200,227,.15);
  --r:22px;
  --rs:14px;
  --rp:999px;
  --fd:'Syne',sans-serif;
  --fb:'Inter',-apple-system,sans-serif;
  --fm:'Inter',-apple-system,sans-serif;
}
html{scroll-behavior:auto;scroll-padding-top:80px;background:var(--bk)}
#particles{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.25}
body{
  font-family:var(--fb);
  background:var(--bk);
  color:var(--tx);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-weight:300;
  letter-spacing:-.005em;
}
::selection{background:rgba(126,200,227,.2);color:#fff}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(126,200,227,.25);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:rgba(61,111,208,.35)}

/* ─── ATMOSPHERE ─── */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.atmos .vignette{display:none}
.atmos .aurora1,.atmos .aurora2,.atmos .aurora3{position:absolute;border-radius:50%;filter:blur(90px);mix-blend-mode:multiply;will-change:transform;contain:layout style}
.atmos .aurora1{top:-20vh;left:50%;width:90vw;height:65vh;background:radial-gradient(circle,rgba(126,200,227,.2),rgba(126,200,227,0) 65%);margin-left:-45vw;opacity:.55;animation:auroraFloat 24s ease-in-out infinite}
.atmos .aurora2{top:15vh;left:-15vw;width:55vw;height:55vw;background:radial-gradient(circle,rgba(61,111,208,.16),rgba(61,111,208,0) 65%);opacity:.5;animation:auroraFloat 28s ease-in-out infinite reverse}
.atmos .aurora3{top:55vh;right:-15vw;width:60vw;height:60vw;background:radial-gradient(circle,rgba(126,200,227,.12),rgba(126,200,227,0) 65%);opacity:.45;animation:auroraFloat 32s ease-in-out infinite}
@keyframes auroraFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(4vw,-3vh) scale(1.08)}66%{transform:translate(-3vw,4vh) scale(.95)}}
.atmos .grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.028) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse at 50% 15%,#000 15%,transparent 65%);-webkit-mask-image:radial-gradient(ellipse at 50% 15%,#000 15%,transparent 65%)}
.atmos .noise{position:absolute;inset:-50%;width:200%;height:200%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");opacity:.015;animation:noiseShift 7s steps(8) infinite;mix-blend-mode:multiply}
@keyframes noiseShift{0%,100%{transform:translate(0,0)}20%{transform:translate(-3%,-2%)}40%{transform:translate(2%,3%)}60%{transform:translate(-1%,1%)}80%{transform:translate(2%,-3%)}}
.cursor-glow{position:fixed;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(126,200,227,.06),rgba(61,111,208,0) 60%);pointer-events:none;z-index:2;transform:translate(-50%,-50%);mix-blend-mode:multiply}

/* ─── NAV ─── */
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%) translateY(-110%);z-index:100;display:flex;align-items:center;gap:4px;padding:7px 7px 7px 18px;background:rgba(255,249,246,.9);border:1px solid rgba(0,0,0,.1);border-radius:var(--rp);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);box-shadow:0 1px 0 rgba(255,255,255,.95) inset,0 4px 24px rgba(0,0,0,.08),0 1px 0 rgba(0,0,0,.06);animation:navDrop .9s cubic-bezier(.22,1,.36,1) .3s forwards;will-change:transform}
@keyframes navDrop{to{transform:translateX(-50%) translateY(0)}}
.nav-logo{display:flex;align-items:center;gap:9px;padding-right:14px;border-right:1px solid var(--line2);margin-right:6px;cursor:pointer;text-decoration:none;color:inherit}
.nav-logo .mark{width:28px;height:28px;border-radius:7px;display:block;filter:drop-shadow(0 2px 8px rgba(126,200,227,.2))}
.nav-logo .name{font-family:var(--fd);font-size:14.5px;font-weight:700;letter-spacing:-.04em;color:var(--tx)}
.nav-logo .name em{font-style:normal;color:var(--mid);font-weight:500;margin-left:1px}
.nav-links{display:flex;gap:0;align-items:center}
.nl{background:transparent;border:none;color:var(--tx2);font-family:var(--fb);font-size:12.5px;font-weight:500;padding:8px 14px;border-radius:var(--rp);cursor:pointer;transition:color .12s ease,background .12s ease;position:relative;letter-spacing:-.005em;text-decoration:none;display:inline-flex;align-items:center;white-space:nowrap}
.nl:hover{color:var(--tx);background:rgba(0,0,0,.05)}
.nl.on{color:var(--em)}
.nl.on::before{content:"";position:absolute;inset:0;border-radius:var(--rp);background:radial-gradient(circle at 50% 100%,rgba(126,200,227,.1),transparent 70%);z-index:-1}
.nav-cta{margin-left:6px;display:inline-flex;align-items:center;gap:7px;background:var(--grad);border:1px solid rgba(255,255,255,.25);border-radius:var(--rp);color:#fff;font-family:var(--fb);font-size:12.5px;font-weight:600;padding:9px 16px;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 4px 16px rgba(126,200,227,.25),0 2px 8px rgba(61,111,208,.15);transition:transform .15s ease,box-shadow .15s ease;text-decoration:none;white-space:nowrap}
.nav-cta:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 8px 24px rgba(126,200,227,.35),0 4px 12px rgba(61,111,208,.25)}
.nav-cta .dot{width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 8px rgba(255,255,255,.8)}
@media(max-width:760px){.nav-links{display:none}.nav{padding:6px 6px 6px 14px}.nav-logo{padding-right:10px;margin-right:0}}

/* ─── SHELL ─── */
.shell{position:relative;z-index:5;max-width:1320px;margin:0 auto;padding:0 32px}
@media(max-width:760px){.shell{padding:0 18px}}

/* ─── COMMON ─── */
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:5px 5px 5px 14px;background:rgba(126,200,227,.07);border:1px solid rgba(126,200,227,.2);border-radius:var(--rp);font-family:var(--fm);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--emD);box-shadow:0 1px 0 rgba(255,255,255,.9) inset}
.eyebrow .pip{display:inline-flex;align-items:center;gap:6px;background:rgba(126,200,227,.14);border-radius:var(--rp);padding:3px 10px;font-size:9.5px;letter-spacing:.12em;color:#13567A}
.eyebrow .pip::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--em);box-shadow:0 0 8px rgba(126,200,227,.45);animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}

.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--fb);font-size:14px;font-weight:500;padding:14px 24px;border-radius:var(--rp);cursor:pointer;border:1px solid transparent;transition:transform .18s cubic-bezier(.22,1,.36,1),box-shadow .18s ease,background .15s ease;position:relative;will-change:transform;white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--grad);color:#fff;border:1px solid rgba(255,255,255,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 4px 20px rgba(126,200,227,.28),0 2px 8px rgba(61,111,208,.18)}
.btn-primary:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.5),0 8px 32px rgba(126,200,227,.38),0 4px 16px rgba(61,111,208,.28);transform:translateY(-1px)}
.btn-primary .arr{width:14px;height:14px;transition:transform .18s ease}
.btn-primary:hover .arr{transform:translateX(3px)}
.btn-ghost{background:rgba(0,0,0,.04);color:var(--tx);border:1px solid var(--line2);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.btn-ghost:hover{background:rgba(0,0,0,.07);border-color:var(--line3)}

.sec{position:relative;z-index:5;padding:80px 0}
.sec-head{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:64px}
.sec-eye{font-family:var(--fm);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--em);margin-bottom:18px;display:inline-flex;align-items:center;gap:9px}
.sec-eye::before,.sec-eye::after{content:"";width:24px;height:1px;background:linear-gradient(90deg,transparent,var(--em),transparent)}
.sec-h{font-family:var(--fd);font-size:clamp(36px,5vw,68px);font-weight:700;letter-spacing:-.045em;line-height:1.02;max-width:18ch;color:var(--tx)}
.sec-h em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}
.sec-sub{max-width:540px;margin-top:18px;color:var(--tx2);font-size:16px;font-weight:300;line-height:1.65}

/* ─── PAGE HEADER ─── */
.page-head{position:relative;z-index:5;padding:100px 0 50px;text-align:center}
.page-h1{font-family:var(--fd);font-size:clamp(48px,7vw,108px);font-weight:700;letter-spacing:-.055em;line-height:.95;max-width:14ch;margin:24px auto 0}
.page-h1 .glass{background:linear-gradient(180deg,#1c1410 0%,#6b5e55 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-h1 .em{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 18px rgba(126,200,227,.22));font-style:normal;font-weight:600}
.page-sub{max-width:560px;margin:28px auto 0;font-size:clamp(15px,1.4vw,18px);font-weight:300;line-height:1.65;color:var(--tx2)}

/* ─── FOOTER ─── */
.foot{position:relative;z-index:5;padding:80px 0 40px;margin-top:60px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:48px;padding-bottom:60px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
.foot-brand{display:flex;flex-direction:column;gap:18px;max-width:340px}
.foot-brand .name{font-family:var(--fd);font-size:38px;font-weight:700;letter-spacing:-.055em}
.foot-brand .name em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}
.foot-brand p{font-size:13px;color:var(--tx2);line-height:1.6;font-weight:300}
.foot-col h5{font-family:var(--fm);font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:none;color:var(--em);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a{color:var(--tx2);font-size:13px;text-decoration:none;transition:color .2s,padding-left .25s ease;display:inline-flex;align-items:center;gap:7px;cursor:pointer}
.foot-col a:hover{color:var(--em);padding-left:4px}
.foot-bot{padding-top:30px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-bot .copy{font-family:var(--fm);font-size:11px;color:var(--dim);letter-spacing:.03em}
.foot-bot .status{display:inline-flex;align-items:center;gap:8px;font-family:var(--fm);font-size:11px;color:var(--mid);letter-spacing:.04em}
.foot-bot .status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px rgba(26,150,72,.3)}
.foot-bot .meta{display:flex;gap:18px}
.foot-bot .meta a{font-family:var(--fm);font-size:11px;color:var(--mid);text-decoration:none;letter-spacing:.04em;text-transform:uppercase;cursor:pointer}
.foot-bot .meta a:hover{color:var(--em)}
.mega{position:relative;z-index:1;font-family:var(--fd);font-size:clamp(120px,28vw,420px);font-weight:700;letter-spacing:-.08em;line-height:.85;text-align:center;margin-top:60px;margin-bottom:-80px;pointer-events:none;user-select:none;background:linear-gradient(135deg,rgba(126,200,227,.1) 0%,rgba(61,111,208,.07) 50%,rgba(126,200,227,0) 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ─── REVEAL ─── */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
[data-reveal].in{opacity:1;transform:translateY(0)}
[data-reveal-d="1"]{transition-delay:.1s}
[data-reveal-d="2"]{transition-delay:.2s}
[data-reveal-d="3"]{transition-delay:.3s}
[data-reveal-d="4"]{transition-delay:.4s}
