/* ============ ALPRIVO v2 — REFINED DESIGN SYSTEM ============ */
:root{
  --bg:#060810;
  --bg-2:#0a0e18;
  --panel:#0d1220;
  --panel-2:#11182a;
  --line:rgba(130,160,220,.10);
  --line-strong:rgba(130,160,220,.20);
  --text:#eef2ف9;
  --text:#eef2f9;
  --muted:#94a1ba;
  --dim:#5f6c84;
  --r:20px;
  --r-sm:14px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --accent:#6e9bff;
  --accent-2:#4fd1c5;
  --accent-3:#a78bfa;
  --glow:rgba(110,155,255,.18);
}
body.product{
  --bg:#05090a;--bg-2:#091210;--panel:#0c1714;--panel-2:#0f1d18;
  --line:rgba(120,210,165,.10);--line-strong:rgba(120,210,165,.20);
  --text:#eef5f0;--muted:#9ab6a9;--dim:#5e7568;
  --accent:#43d98a;--accent-2:#9fe04f;--accent-3:#38bdf8;--glow:rgba(67,217,138,.18);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Familjen Grotesk',system-ui,sans-serif;
  font-size:17px;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* layered background */
.bg-layer{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%)}
.bg-glow{position:absolute;border-radius:50%;filter:blur(80px)}
.bg-glow.g1{top:-200px;right:-100px;width:600px;height:600px;background:var(--glow);opacity:.6}
.bg-glow.g2{bottom:-200px;left:-150px;width:550px;height:550px;
  background:color-mix(in srgb,var(--accent-3) 40%,transparent);opacity:.35}
body::after{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:3}
h1,h2,h3,.display{font-family:'Sora',sans-serif;letter-spacing:-.025em;line-height:1.07}
a{color:inherit;text-decoration:none}
.mono{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase}
.grad{background:linear-gradient(115deg,var(--accent),var(--accent-2) 55%,var(--accent-3));
  -webkit-background-clip:text;background-clip:text;color:transparent}
svg{display:block}

/* NAV */
header{position:fixed;top:0;left:0;right:0;z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;margin:14px auto;max-width:var(--maxw);
  padding:11px 16px 11px 20px;background:color-mix(in srgb,var(--bg) 60%,transparent);backdrop-filter:blur(20px) saturate(1.4);
  border:1px solid var(--line);border-radius:100px;box-shadow:0 8px 40px rgba(0,0,0,.45);transition:.4s var(--ease)}
header.scrolled .nav{margin-top:8px;background:color-mix(in srgb,var(--bg) 88%,transparent);box-shadow:0 12px 50px rgba(0,0,0,.6)}
.brand{display:flex;align-items:center;gap:11px}
.logo{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;color:#03101c;
  background:conic-gradient(from 210deg,var(--accent),var(--accent-3),var(--accent-2),var(--accent));
  box-shadow:0 0 0 1px rgba(255,255,255,.14) inset,0 6px 20px var(--glow)}
.logo svg{width:20px;height:20px}
.brand b{font-family:'Sora';font-weight:700;font-size:1rem;display:block;line-height:1.1;letter-spacing:-.02em}
.brand span{font-size:.72rem;color:var(--muted)}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a{padding:9px 14px;border-radius:100px;font-size:.91rem;color:var(--muted);transition:.25s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:rgba(255,255,255,.06)}
.nav-cta{padding:10px 18px !important;color:#03101c !important;font-weight:600;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:100px;margin-left:4px}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px var(--glow)}
.lang{display:flex;gap:2px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:100px;padding:3px;margin-left:6px}
.lang a{padding:5px 10px;border-radius:100px;font-size:.76rem;font-weight:600;color:var(--muted)}
.lang a.on{background:var(--accent);color:#03101c}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.burger span{width:22px;height:2px;background:var(--text);border-radius:2px}

/* HERO */
.hero{position:relative;padding:180px 0 90px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;padding:7px 15px;border-radius:100px;
  border:1px solid var(--line-strong);background:color-mix(in srgb,var(--accent) 7%,transparent);color:var(--accent);margin-bottom:28px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.65)}}
.hero h1{font-size:clamp(2.5rem,5.5vw,4.1rem);font-weight:800;margin-bottom:26px}
.hero p.lead{font-size:1.15rem;color:var(--muted);max-width:540px;margin-bottom:36px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 24px;border-radius:100px;
  font-family:'Sora';font-weight:600;font-size:.96rem;cursor:pointer;border:none;transition:.3s var(--ease)}
.btn svg{width:16px;height:16px}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#03101c;box-shadow:0 10px 36px var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 48px var(--glow)}
.btn-ghost{background:rgba(255,255,255,.04);color:var(--text);border:1px solid var(--line-strong)}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-2px)}
.hero-trust{display:flex;align-items:center;gap:22px;margin-top:46px}
.trust-item{display:flex;flex-direction:column}
.trust-item .ti-n{font-family:'Sora';font-weight:700;font-size:1.3rem;color:var(--text)}
.trust-item .ti-l{font-size:.8rem;color:var(--dim)}
.hero-trust .divider{width:1px;height:34px;background:var(--line-strong)}

/* orbit */
.hero-visual{position:relative;display:grid;place-items:center;min-height:420px}
.orbit{position:relative;width:360px;height:360px;display:grid;place-items:center}
.orbit-core{width:84px;height:84px;border-radius:22px;display:grid;place-items:center;color:#03101c;z-index:3;
  background:conic-gradient(from 210deg,var(--accent),var(--accent-3),var(--accent-2),var(--accent));
  box-shadow:0 0 60px var(--glow),0 0 0 1px rgba(255,255,255,.16) inset}
.orbit-ring{position:absolute;border:1px solid var(--line-strong);border-radius:50%}
.orbit-ring.r1{width:190px;height:190px;animation:spin 22s linear infinite}
.orbit-ring.r2{width:280px;height:280px;animation:spin 34s linear infinite reverse}
.orbit-ring.r3{width:360px;height:360px;border-style:dashed;opacity:.45;animation:spin 55s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.node{position:absolute;width:52px;height:52px;border-radius:15px;display:grid;place-items:center;color:var(--accent);
  background:var(--panel);border:1px solid var(--line-strong);box-shadow:0 10px 30px rgba(0,0,0,.45);z-index:2;animation:float 6s ease-in-out infinite}
.node svg{width:24px;height:24px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}
.node.n1{top:-12px;left:50%;margin-left:-26px}
.node.n2{right:-12px;top:50%;margin-top:-26px;animation-delay:1s;color:var(--accent-2)}
.node.n3{bottom:-12px;left:50%;margin-left:-26px;animation-delay:2s;color:var(--accent-3)}
.node.n4{left:-12px;top:50%;margin-top:-26px;animation-delay:1.5s;color:var(--accent-2)}

/* strip */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;position:relative;z-index:3}
.strip-inner{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.strip-item{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.95rem;font-weight:500}
.strip-item svg{width:20px;height:20px;color:var(--accent)}

/* sections */
section{position:relative;z-index:3}
.sec{padding:96px 0}
.sec-head{max-width:680px;margin-bottom:56px}
.sec-head .mono{color:var(--accent);display:block;margin-bottom:18px}
.sec-head h2{font-size:clamp(1.9rem,3.8vw,2.85rem);font-weight:700;margin-bottom:18px}
.sec-head p{color:var(--muted);font-size:1.06rem}

/* cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--r);padding:32px;position:relative;overflow:hidden;transition:.4s var(--ease)}
.card::after{content:"";position:absolute;inset:0;border-radius:var(--r);padding:1px;
  background:linear-gradient(140deg,color-mix(in srgb,var(--accent) 50%,transparent),transparent 45%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.4s}
.card:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.card:hover::after{opacity:1}
.card .ci{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px;color:var(--accent);
  background:color-mix(in srgb,var(--accent) 9%,transparent);border:1px solid var(--line-strong)}
.card .ci svg{width:24px;height:24px}
.card h3{font-size:1.28rem;font-weight:600;margin-bottom:10px}
.card p{color:var(--muted);font-size:.97rem}

/* feature product */
.feature{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;
  padding:54px;border-radius:28px;background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--line-strong);overflow:hidden}
.feat-glow{position:absolute;top:-40%;right:-12%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,var(--glow),transparent 62%)}
.feat-copy{position:relative;z-index:2}
.feat-copy h2{font-size:2.3rem;margin:12px 0 14px}
.feat-copy p{color:var(--muted);margin-bottom:22px;max-width:440px}
.feat-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.feat-list li{display:flex;align-items:center;gap:11px;color:var(--text);font-size:.97rem}
.feat-list svg{width:18px;height:18px;color:var(--accent);flex-shrink:0;
  background:color-mix(in srgb,var(--accent) 12%,transparent);border-radius:50%;padding:3px}
.feat-visual{position:relative;z-index:2;display:grid;place-items:center}

/* device mock */
.device{width:280px;border-radius:30px;background:linear-gradient(165deg,#121a28,#0a0f18);border:1px solid var(--line-strong);
  padding:18px 16px 20px;box-shadow:0 40px 90px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04) inset;transform:rotate(-3deg);position:relative}
body.product .device{background:linear-gradient(165deg,#101d18,#08110d)}
.dev-notch{width:60px;height:6px;border-radius:10px;background:rgba(255,255,255,.12);margin:0 auto 18px}
.dev-head{display:flex;align-items:center;gap:11px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line)}
.dev-dot{width:34px;height:34px;border-radius:11px;background:conic-gradient(from 210deg,var(--accent),var(--accent-2))}
.dev-t{font-family:'Sora';font-weight:700;font-size:.95rem}
.dev-s{font-size:.72rem;color:var(--muted)}
.dev-row{display:flex;align-items:center;gap:11px;padding:12px;border-radius:14px;margin-bottom:9px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.dev-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}
.dev-ico svg{width:19px;height:19px}
.dev-ico.green{background:rgba(67,217,138,.14);color:#43d98a}
.dev-ico.blue{background:rgba(56,189,248,.14);color:#38bdf8}
.dev-ico.gold{background:rgba(251,191,36,.14);color:#fbbf24}
.dr-t{font-family:'Sora';font-weight:600;font-size:.86rem}
.dr-s{font-size:.7rem;color:var(--muted)}
.dev-tag{margin-left:auto;font-size:.6rem;padding:4px 9px;border-radius:100px;font-family:'JetBrains Mono';
  background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.dev-tag.blue{background:rgba(56,189,248,.12);color:#38bdf8}
.dev-tag.gold{background:rgba(251,191,36,.12);color:#fbbf24}

/* flow */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{position:relative;padding:28px 24px;border-radius:var(--r);background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);transition:.4s var(--ease)}
.step:hover{transform:translateY(-4px);border-color:var(--line-strong)}
.step .num{font-family:'JetBrains Mono';font-size:1.5rem;color:var(--accent);margin-bottom:14px;display:block;font-weight:500}
.step h3{font-size:1.1rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.93rem}

/* cta */
.cta{position:relative;border-radius:32px;padding:74px 50px;text-align:center;overflow:hidden;
  background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--line-strong)}
.cta-glow{position:absolute;inset:0;background:radial-gradient(600px 320px at 50% -10%,var(--glow),transparent 60%)}
.cta h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:18px;position:relative;z-index:2}
.cta p{color:var(--muted);font-size:1.1rem;max-width:520px;margin:0 auto 32px;position:relative;z-index:2}
.cta .hero-cta{justify-content:center;position:relative;z-index:2}

/* generic doc pages */
.page-hero{padding:160px 0 40px}
.page-hero .mono{color:var(--accent);display:block;margin-bottom:14px}
.page-hero h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;margin-bottom:14px}
.page-hero p.sub{color:var(--muted);font-size:1.1rem;max-width:600px}
.doc{max-width:800px;margin:0 auto;padding:20px 0 70px}
.doc-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r);padding:34px;margin-bottom:18px}
.doc-card h3{font-size:1.28rem;margin-bottom:14px;display:flex;align-items:center;gap:11px}
.doc-card h3 .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}
.doc-card p{color:var(--muted);margin-bottom:10px}
.doc-card ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-top:6px}
.doc-card li{color:var(--muted);padding-left:26px;position:relative}
.doc-card li::before{content:"";position:absolute;left:0;top:10px;width:8px;height:8px;border-radius:2px;background:var(--accent);opacity:.6}
.doc-card b{color:var(--text)}
.doc-meta{color:var(--muted);font-size:.84rem;margin-bottom:24px;font-family:'JetBrains Mono'}
.doc-actions{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0 4px}
table.doc-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:.92rem}
table.doc-table th{text-align:left;padding:11px 12px;color:var(--accent);font-family:'JetBrains Mono';font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line-strong)}
table.doc-table td{padding:12px;color:var(--muted);border-bottom:1px solid var(--line);vertical-align:top}
table.doc-table tr:hover td{background:rgba(255,255,255,.02)}
.field{margin-bottom:18px}
.field label{display:block;font-family:'Sora';font-weight:600;font-size:.9rem;margin-bottom:8px}
.field input{width:100%;padding:14px 16px;border-radius:13px;background:rgba(255,255,255,.04);border:1px solid var(--line-strong);color:var(--text);font-size:1rem;font-family:inherit;transition:.25s}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}
.note{color:var(--muted);font-size:.9rem;padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--line);margin-top:14px}
.confirm{min-height:62vh;display:grid;place-items:center;text-align:center;padding:160px 0 60px}
.confirm-ico{width:92px;height:92px;border-radius:50%;display:grid;place-items:center;margin:0 auto 26px;color:var(--accent);
  background:color-mix(in srgb,var(--accent) 13%,transparent);border:1px solid var(--line-strong);box-shadow:0 0 50px var(--glow)}
.confirm-ico svg{width:44px;height:44px}

/* footer */
footer{border-top:1px solid var(--line);padding:56px 0 40px;margin-top:40px;position:relative;z-index:3}
.foot{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.foot-links{display:flex;gap:26px;flex-wrap:wrap}
.foot-links a{color:var(--muted);font-size:.92rem;transition:.25s}
.foot-links a:hover{color:var(--accent)}
.foot-social{display:flex;gap:10px}
.foot-social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:var(--muted);background:var(--panel);border:1px solid var(--line);transition:.3s}
.foot-social a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-3px)}
.foot-social svg{width:18px;height:18px}
.foot-bottom{margin-top:34px;padding-top:24px;border-top:1px solid var(--line);color:var(--dim);font-size:.84rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* reveal */
.reveal{opacity:0;transform:translateY(30px);transition:.85s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}

@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}.hero-visual{order:-1;min-height:340px}
  .grid-3{grid-template-columns:1fr}.flow{grid-template-columns:repeat(2,1fr)}
  .feature{grid-template-columns:1fr;padding:38px}.feat-visual{order:-1}
}
@media(max-width:640px){
  .nav-links{display:none}.burger{display:flex}
  .hero{padding:140px 0 60px}.flow{grid-template-columns:1fr}.cta{padding:50px 26px}
  .foot{flex-direction:column}.hero-trust{gap:16px}.doc-card{padding:24px}
}

/* ======================================================================
   ALPRIVO v3 — bold enhancement layer (appended by build; source untouched)
   ====================================================================== */

/* ---- accessibility: visible focus + skip link ---- */
a:focus-visible,button:focus-visible,input:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;border-radius:8px}
.skip-link{position:fixed;top:-60px;left:16px;z-index:200;padding:10px 16px;border-radius:12px;
  background:var(--accent);color:#03101c;font-family:'Sora';font-weight:600;transition:top .25s var(--ease)}
.skip-link:focus{top:14px}

/* ---- scroll progress bar ---- */
#scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--accent),var(--accent-2) 55%,var(--accent-3));
  box-shadow:0 0 14px var(--glow);transition:width .08s linear}

/* ---- cursor-reactive glow (desktop, fine pointer only) ---- */
#cursor-glow{position:fixed;top:0;left:0;width:520px;height:520px;border-radius:50%;z-index:2;
  margin:-260px 0 0 -260px;pointer-events:none;opacity:0;transition:opacity .4s;
  background:radial-gradient(circle,var(--glow),transparent 60%);mix-blend-mode:screen}

/* ---- living aurora background (animate existing glows + extra drift blob) ---- */
.bg-glow.g1{animation:drift1 26s ease-in-out infinite alternate}
.bg-glow.g2{animation:drift2 32s ease-in-out infinite alternate}
.bg-layer::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  top:30%;left:42%;filter:blur(90px);opacity:.28;
  background:color-mix(in srgb,var(--accent-2) 50%,transparent);animation:drift3 38s ease-in-out infinite alternate}
@keyframes drift1{from{transform:translate(0,0) scale(1)}to{transform:translate(-120px,80px) scale(1.18)}}
@keyframes drift2{from{transform:translate(0,0) scale(1)}to{transform:translate(140px,-70px) scale(1.12)}}
@keyframes drift3{from{transform:translate(0,0)}to{transform:translate(-160px,120px)}}

/* ---- kinetic gradient text shimmer ---- */
.grad{background:linear-gradient(115deg,var(--accent),var(--accent-2) 40%,var(--accent-3) 70%,var(--accent) 100%);
  background-size:260% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 7s linear infinite}
@keyframes shimmer{to{background-position:260% 0}}

/* ---- richer reveal (blur + slight scale) ---- */
.reveal{opacity:0;transform:translateY(34px) scale(.985);filter:blur(6px);
  transition:opacity .8s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.reveal.in{opacity:1;transform:none;filter:none}

/* ---- magnetic CTA smoothing (JS sets transform) ---- */
.btn-primary,.nav-cta{will-change:transform}

/* ---- bolder hero type ---- */
.hero h1{font-size:clamp(2.7rem,6.2vw,4.8rem);letter-spacing:-.03em}
.hero p.lead{font-size:1.18rem}

/* ---- FAQ (native <details>, zero-JS, accessible) ---- */
.faq{display:flex;flex-direction:column;gap:12px;max-width:820px}
.faq-item{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--r-sm);overflow:hidden;transition:.3s var(--ease)}
.faq-item[open]{border-color:var(--line-strong)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;display:flex;align-items:center;
  justify-content:space-between;gap:16px;font-family:'Sora';font-weight:600;font-size:1.04rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"";width:11px;height:11px;flex-shrink:0;border-right:2px solid var(--accent);
  border-bottom:2px solid var(--accent);transform:rotate(45deg);transition:.3s var(--ease)}
.faq-item[open] summary::after{transform:rotate(-135deg)}
.faq-item .faq-a{padding:0 24px 22px;color:var(--muted);font-size:.98rem}

/* ---- pricing calculator ---- */
.calc{background:linear-gradient(135deg,var(--panel),var(--panel-2));border:1px solid var(--line-strong);
  border-radius:var(--r);padding:30px 32px;margin-bottom:30px;display:grid;grid-template-columns:1.3fr .9fr;
  gap:30px;align-items:center}
.calc-head{font-family:'Sora';font-weight:600;font-size:1.05rem;margin-bottom:6px}
.calc-sub{color:var(--muted);font-size:.9rem;margin-bottom:20px}
.calc-val{font-family:'Sora';font-weight:800;font-size:2.4rem;color:var(--accent);line-height:1}
.calc-val small{font-size:.9rem;color:var(--muted);font-weight:500;font-family:'Familjen Grotesk'}
.calc input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:100px;margin-top:18px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));outline:none}
.calc input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;
  background:#fff;border:3px solid var(--accent);cursor:pointer;box-shadow:0 4px 14px var(--glow)}
.calc input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;
  border:3px solid var(--accent);cursor:pointer}
.calc-rec{background:color-mix(in srgb,var(--accent) 9%,transparent);border:1px solid var(--line-strong);
  border-radius:var(--r-sm);padding:20px 22px;text-align:center}
.calc-rec .rk{font-family:'JetBrains Mono';font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.calc-rec .rn{font-family:'Sora';font-weight:700;font-size:1.4rem;margin:6px 0 2px}
.calc-rec .rp{color:var(--accent);font-weight:600}
.price.rec{border-color:var(--accent);box-shadow:0 18px 50px var(--glow);transform:translateY(-4px)}

/* ---- store badges ---- */
.store-badges{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.store-badge{display:inline-flex;align-items:center;gap:11px;padding:11px 20px;border-radius:14px;
  background:#000;border:1px solid var(--line-strong);color:#fff;transition:.3s var(--ease)}
.store-badge:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 30px rgba(0,0,0,.5)}
.store-badge svg{width:26px;height:26px;flex-shrink:0}
.store-badge .sb-s{font-size:.62rem;line-height:1;opacity:.8;display:block}
.store-badge .sb-b{font-family:'Sora';font-weight:600;font-size:1.02rem;line-height:1.2}

/* ---- live phone demo: sequential row highlight ---- */
.ps-row,.dev-row{transition:.4s var(--ease)}
.ps-row.live,.dev-row.live{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);
  transform:translateX(3px)}

/* ---- cross-document view transitions (progressive) ---- */
@view-transition{navigation:auto}

/* ---- mobile nav dropdown (real working menu) ---- */
@media(max-width:640px){
  .nav{position:relative}
  header.nav-open .nav-links{display:flex;flex-direction:column;align-items:stretch;gap:6px;
    position:absolute;top:100%;left:16px;right:16px;margin-top:10px;padding:14px;border-radius:18px;
    background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(20px) saturate(1.4);
    border:1px solid var(--line-strong);box-shadow:0 24px 60px rgba(0,0,0,.6)}
  header.nav-open .nav-links a{padding:11px 14px}
  header.nav-open .nav-cta{text-align:center}
  header.nav-open .lang{margin-left:0;justify-content:center;margin-top:4px}
  .calc{grid-template-columns:1fr;gap:18px}
}

/* ---- reduced motion: calm everything ---- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.12s !important;scroll-behavior:auto !important}
  .reveal{filter:none;transform:none;opacity:1}
  #cursor-glow{display:none}
  .bg-glow.g1,.bg-glow.g2,.bg-layer::before{animation:none}
  .grad{animation:none}
}

/* ---- restraint & performance tuning ---- */
.bg-glow.g1{opacity:.42}.bg-glow.g2{opacity:.26}.bg-layer::before{opacity:.2}
#cursor-glow{width:400px;height:400px;margin:-200px 0 0 -200px}
.reveal{filter:blur(4px)}
.grad{animation-duration:9s}

/* ======================================================================
   ALPRIVO v4 — art direction overlay (premium / modern / editorial)
   Appended last so it wins the cascade. DOM-safe: pure restyle, no markup
   or text changes -> SEO + i18n + worker all unaffected.
   ====================================================================== */

:root{
  --r:24px; --r-sm:16px;
  --line:rgba(140,170,225,.12); --line-strong:rgba(140,170,225,.24);
  --shadow-1:0 2px 8px rgba(0,0,0,.25);
  --shadow-2:0 24px 70px rgba(0,0,0,.55);
  --ring:0 0 0 1px rgba(255,255,255,.07) inset;
}
body.product{ --line:rgba(120,210,165,.12); --line-strong:rgba(120,210,165,.26); }

/* base polish: refined rendering, vignette, selection, themed scrollbar */
html{ -webkit-text-size-adjust:100%; }
body{ font-size:17.5px; line-height:1.62; text-rendering:optimizeLegibility; letter-spacing:.002em; }
body::before{ content:""; position:fixed; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(120% 80% at 50% -10%, transparent 55%, rgba(0,0,0,.45) 100%); }
::selection{ background:color-mix(in srgb,var(--accent) 38%,transparent); color:#fff; }
*{ scrollbar-width:thin; scrollbar-color:var(--line-strong) transparent; }
::-webkit-scrollbar{ width:11px; height:11px; }
::-webkit-scrollbar-thumb{ background:color-mix(in srgb,var(--accent) 30%,#1a2233); border-radius:100px;
  border:3px solid var(--bg); }
::-webkit-scrollbar-thumb:hover{ background:color-mix(in srgb,var(--accent) 55%,#1a2233); }

/* typography — confident editorial scale */
h1,h2,h3,.display{ letter-spacing:-.035em; line-height:1.04; }
.hero h1{ font-size:clamp(2.9rem,6.8vw,5.4rem); font-weight:800; }
.hero p.lead{ font-size:clamp(1.1rem,1.6vw,1.28rem); color:var(--muted); max-width:560px; line-height:1.55; }
.page-hero h1{ font-size:clamp(2.3rem,6vw,3.8rem); }
.sec{ padding:clamp(72px,11vw,128px) 0; }
.sec-head h2{ font-size:clamp(2rem,4.2vw,3.15rem); letter-spacing:-.03em; }
.sec-head .mono,.page-hero .mono,.eyebrow .mono{ letter-spacing:.26em; }
.eyebrow{ padding:8px 16px; backdrop-filter:blur(8px); }

/* refined gradient text */
.grad{ background:linear-gradient(108deg,var(--accent),var(--accent-2) 42%,var(--accent-3) 72%,var(--accent));
  background-size:240% 100%; -webkit-background-clip:text; background-clip:text; color:transparent; }

/* glassy nav */
.nav{ border-radius:22px; padding:10px 14px 10px 18px; border:1px solid var(--line-strong);
  background:color-mix(in srgb,var(--bg) 55%,transparent); box-shadow:0 10px 44px rgba(0,0,0,.5),var(--ring); }
header.scrolled .nav{ background:color-mix(in srgb,var(--bg) 84%,transparent); }
.logo{ border-radius:13px; box-shadow:0 0 0 1px rgba(255,255,255,.18) inset,0 8px 24px var(--glow); }
.nav-links a{ font-size:.92rem; }
.nav-links a:hover,.nav-links a.active{ background:color-mix(in srgb,var(--accent) 12%,transparent); color:var(--text); }
.nav-cta{ box-shadow:0 8px 24px var(--glow),var(--ring); }

/* buttons — refined depth */
.btn{ padding:15px 26px; border-radius:16px; font-size:.98rem; letter-spacing:.005em; }
.btn-primary{ background:linear-gradient(135deg,var(--accent),var(--accent-2)); color:#03101c;
  box-shadow:0 12px 34px var(--glow),var(--ring); }
.btn-primary:hover{ box-shadow:0 20px 54px var(--glow),var(--ring); }
.btn-ghost{ border:1px solid var(--line-strong); background:color-mix(in srgb,#fff 4%,transparent);
  backdrop-filter:blur(8px); }
.btn-ghost:hover{ border-color:color-mix(in srgb,var(--accent) 50%,transparent); background:color-mix(in srgb,#fff 7%,transparent); }

/* cards & panels — layered glass with top highlight */
.card,.step,.doc-card,.feature,.cta,.price,.topic{
  background:linear-gradient(180deg,color-mix(in srgb,#fff 4%,var(--panel)),var(--panel-2));
  border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow-1),var(--ring); }
.card{ padding:34px; }
.card::after,.feature::after{ background:linear-gradient(140deg,color-mix(in srgb,var(--accent) 65%,transparent),transparent 42%); }
.card:hover,.step:hover{ transform:translateY(-6px); border-color:var(--line-strong); box-shadow:var(--shadow-2),var(--ring); }
.card .ci{ border-radius:15px; background:color-mix(in srgb,var(--accent) 12%,transparent);
  box-shadow:0 0 0 1px var(--line-strong) inset; }
.card h3,.step h3{ letter-spacing:-.02em; }

/* feature/cta hero materials */
.feature{ border-radius:30px; border-color:var(--line-strong); box-shadow:var(--shadow-2),var(--ring); }
.feat-copy h2{ font-size:clamp(1.9rem,3vw,2.5rem); letter-spacing:-.03em; }
.cta{ border-radius:34px; border-color:var(--line-strong); box-shadow:var(--shadow-2),var(--ring); }
.cta h2{ letter-spacing:-.03em; }

/* numbers / stats more confident */
.trust-item .ti-n,.hstat .n,.fc-n,.float-card .fc-n{ letter-spacing:-.02em; }

/* doc pages refinement */
.doc-card{ border-radius:var(--r); }
.doc-card h3{ letter-spacing:-.02em; }
table.doc-table th{ letter-spacing:.1em; }

/* footer refinement */
footer{ padding-top:64px; }
.foot-social a{ border-radius:14px; box-shadow:var(--ring); }
.foot-social a:hover{ box-shadow:0 10px 24px var(--glow),var(--ring); }

/* FAQ + calculator align to v4 radii/material */
.faq-item{ border-radius:var(--r-sm); box-shadow:var(--shadow-1),var(--ring); }
.calc{ border-radius:var(--r); box-shadow:var(--shadow-2),var(--ring); }
.calc-val{ font-size:2.6rem; }

/* tasteful focus + smoother transitions */
a,.btn,.card,.step,.faq-item,.foot-social a{ transition:.35s var(--ease); }

@media(max-width:640px){
  body{ font-size:16.5px; }
  .btn{ padding:14px 22px; }
}
