*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:  #0E0E16; --bg2: #131320; --bg3: #19192A; --bg4: #1F1F34;
  --txt: #EEEEF6; --dim: #7070A2; --dim2: #4A4A7A;
  --blue: #4080FF; --blueh: #5590FF;
  --bdim: rgba(64,128,255,.1); --bbrd: rgba(64,128,255,.22); --bglw: rgba(64,128,255,.18);
  --ln: rgba(255,255,255,.07); --ln2: rgba(255,255,255,.12);
  --shm: 0 8px 30px rgba(0,0,0,.4); --shl: 0 20px 60px rgba(0,0,0,.55);
  --r: 10px; --rl: 14px; --ff: 'Manrope',sans-serif; --fb: 'DM Sans',sans-serif;
}

html { scroll-behavior: smooth; overflow-x: hidden; }
body { background: var(--bg); color: var(--txt); font-family: var(--fb); font-size: 16px; line-height: 1.65; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
body::after { content:''; position:fixed; inset:0; pointer-events:none; z-index:9000; opacity:.02; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='150' height='150' filter='url(%23n)'/%3E%3C/svg%3E"); }
::-webkit-scrollbar{width:3px} ::-webkit-scrollbar-track{background:var(--bg)} ::-webkit-scrollbar-thumb{background:var(--blue);border-radius:2px}
svg { display:block; flex-shrink:0; }
h1,h2,h3,h4 { font-family:var(--ff); color:var(--txt); }

.label { display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); }
.label::before { content:''; display:block; width:16px; height:1.5px; background:var(--blue); }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:8px; padding:11px 22px; border-radius:var(--r); font-family:var(--fb); font-size:14px; font-weight:500; text-decoration:none; cursor:pointer; border:none; transition:all .2s ease; white-space:nowrap; line-height:1; }
.btn-lg { padding:13px 28px; font-size:15px; border-radius:var(--rl); }
.btn-primary { background:var(--blue); color:#fff; }
.btn-primary:hover { background:var(--blueh); transform:translateY(-1px); box-shadow:0 8px 28px var(--bglw); }
.btn-ghost { background:transparent; color:var(--txt); border:1px solid var(--ln2); }
.btn-ghost:hover { border-color:var(--bbrd); color:var(--blue); background:var(--bdim); }

/* NAV */
#nav { position:fixed; top:14px; left:50%; transform:translateX(-50%); z-index:500; width:calc(100% - 48px); max-width:1080px; background:rgba(14,14,22,.82); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); border:1px solid var(--ln2); border-radius:var(--rl); padding:10px 16px; display:flex; align-items:center; justify-content:space-between; gap:16px; transition:background .3s,box-shadow .3s; }
#nav.scrolled { background:rgba(14,14,22,.96); box-shadow:var(--shm); }
.logo { display:flex; align-items:center; gap:8px; text-decoration:none; flex-shrink:0; }
.logo img { width:26px; height:26px; object-fit:contain; border-radius:5px; display:block; }
.logo span { font-family:var(--ff); font-size:15px; font-weight:700; color:var(--txt); }
.nav-links { display:flex; list-style:none; gap:2px; flex:1; justify-content:center; }
.nav-links a { font-size:13.5px; font-weight:500; color:var(--dim); text-decoration:none; padding:6px 12px; border-radius:var(--r); transition:color .18s,background .18s; }
.nav-links a:hover { color:var(--txt); background:rgba(255,255,255,.07); }
.nav-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.nav-icon-btn { width:32px; height:32px; border-radius:var(--r); border:1px solid var(--ln2); display:flex; align-items:center; justify-content:center; color:var(--dim); text-decoration:none; transition:all .2s; background:transparent; cursor:pointer; }
.nav-icon-btn:hover { color:var(--txt); background:rgba(255,255,255,.07); }

/* HAMBURGER */
.hamburger { display:none; flex-direction:column; justify-content:center; align-items:center; gap:5px; background:transparent; border:1px solid var(--ln2); border-radius:var(--r); width:34px; height:34px; cursor:pointer; flex-shrink:0; }
.hamburger em { display:block; width:16px; height:2px; background:var(--txt); border-radius:2px; transition:all .28s ease; font-style:normal; }
.hamburger.open em:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open em:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open em:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* MOBILE MENU */
#mmenu { position:fixed; inset:0; z-index:400; background:var(--bg2); display:flex; flex-direction:column; padding:80px 22px 36px; transform:translateX(110%); transition:transform .34s cubic-bezier(.4,0,.2,1); overflow-y:auto; }
#mmenu.open { transform:translateX(0); }
#mmenu a.mlink { display:block; padding:14px 16px; font-family:var(--ff); font-size:21px; font-weight:700; color:var(--txt); text-decoration:none; border-radius:var(--r); letter-spacing:-.02em; transition:background .18s,color .18s; }
#mmenu a.mlink:hover { background:var(--bg3); color:var(--blue); }
#mmenu .mdiv { height:1px; background:var(--ln); margin:14px 0; }
#mmenu .mctas { display:flex; flex-direction:column; gap:10px; margin-top:18px; }
#mmenu .mctas .btn { justify-content:center; border-radius:var(--rl); padding:14px; font-size:15px; }
#mmenu .msoc { display:flex; gap:10px; padding:18px 16px 0; }
#mmenu .msoc a { width:44px; height:44px; border-radius:var(--r); border:1px solid var(--ln2); display:flex; align-items:center; justify-content:center; color:var(--dim); text-decoration:none; transition:all .2s; }
#mmenu .msoc a:hover { color:var(--txt); background:rgba(255,255,255,.07); }

/* HERO */
#hero { min-height:100vh; min-height:100dvh; display:flex; align-items:center; justify-content:center; text-align:center; padding:120px 20px 80px; position:relative; overflow:hidden; }
#hero::before { content:''; position:absolute; top:-20%; left:50%; transform:translateX(-50%); width:860px; height:740px; background:radial-gradient(ellipse at 50% 38%, rgba(64,128,255,.09) 0%, transparent 65%); pointer-events:none; }
#hcanvas { position:absolute; inset:0; width:100%; height:100%; }
.hero-in { position:relative; z-index:2; max-width:820px; width:100%; }
.hero-pill { display:inline-flex; align-items:center; gap:8px; background:var(--bdim); border:1px solid var(--bbrd); border-radius:100px; padding:5px 16px 5px 10px; font-size:11.5px; font-family:var(--ff); color:var(--blue); font-weight:700; letter-spacing:.06em; text-transform:uppercase; margin-bottom:28px; opacity:0; animation:fadeup .7s .1s forwards; }
.pdot { width:6px; height:6px; border-radius:50%; background:var(--blue); animation:pdot 2.2s infinite; flex-shrink:0; }
@keyframes pdot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.65)} }
.hero-h1 { font-size:clamp(36px,7vw,86px); font-weight:800; line-height:1.01; letter-spacing:-.045em; margin-bottom:22px; opacity:0; animation:fadeup .75s .3s forwards; }
.hero-h1 em { font-style:normal; color:var(--blue); }
.hero-sub { font-size:clamp(15px,2.2vw,18px); color:var(--dim); max-width:490px; margin:0 auto 40px; font-weight:400; line-height:1.78; opacity:0; animation:fadeup .75s .5s forwards; }
.hero-ctas { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; opacity:0; animation:fadeup .75s .7s forwards; }
.hero-stats { display:grid; grid-template-columns:repeat(4,1fr); margin-top:58px; background:var(--bg3); border:1px solid var(--ln2); border-radius:var(--rl); overflow:hidden; opacity:0; animation:fadeup .75s .95s forwards; }
.stat { padding:20px 12px; text-align:center; position:relative; }
.stat+.stat::before { content:''; position:absolute; left:0; top:20%; bottom:20%; width:1px; background:var(--ln2); }
.stat-n { font-family:var(--ff); font-size:28px; font-weight:800; color:var(--blue); line-height:1; margin-bottom:5px; }
.stat-l { font-size:10px; color:var(--dim); font-weight:600; letter-spacing:.05em; text-transform:uppercase; }
@keyframes fadeup { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }

/* TICKER */
#ticker { background:var(--bg2); border-top:1px solid var(--ln); border-bottom:1px solid var(--ln); overflow:hidden; }
.tick-wrap { display:flex; overflow:hidden; padding:13px 0; -webkit-mask-image:linear-gradient(to right,transparent,#000 50px,#000 calc(100% - 50px),transparent); mask-image:linear-gradient(to right,transparent,#000 50px,#000 calc(100% - 50px),transparent); }
.tick-belt { display:flex; width:max-content; animation:tickgo 38s linear infinite; }
.tick-belt:hover { animation-play-state:paused; }
.ti { display:inline-flex; align-items:center; gap:7px; padding:0 22px; font-family:var(--ff); font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.4); border-right:1px solid var(--ln); white-space:nowrap; }
.ti-dot { width:3.5px; height:3.5px; border-radius:50%; background:var(--blue); flex-shrink:0; }
@keyframes tickgo { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* LAYOUT */
.wrap { max-width:1140px; margin:0 auto; padding:0 60px; }
.sec { padding:108px 0; }
.sh { margin-bottom:50px; }
.sh h2 { font-size:clamp(26px,3.8vw,50px); font-weight:800; letter-spacing:-.03em; line-height:1.06; margin-top:12px; }
.gsep { height:1px; background:linear-gradient(90deg,transparent,var(--ln2) 30%,var(--ln2) 70%,transparent); }

/* ACCESS */
.acc-intro { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end; margin-bottom:50px; }
.acc-intro h2 { font-size:clamp(24px,3.8vw,46px); font-weight:800; letter-spacing:-.03em; line-height:1.06; margin-top:12px; }
.acc-intro-r { color:var(--dim); font-size:15px; line-height:1.78; }
.acc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.ac { background:var(--bg3); border:1px solid var(--ln); border-radius:var(--r); padding:24px 20px; position:relative; overflow:hidden; transition:border-color .25s,box-shadow .25s,transform .25s; }
.ac::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,var(--blue),#60A5FA); opacity:0; transition:opacity .25s; }
.ac:hover { border-color:var(--bbrd); box-shadow:0 6px 28px var(--bglw); transform:translateY(-2px); }
.ac:hover::before { opacity:1; }
.ac-ico { width:40px; height:40px; border-radius:9px; background:var(--bdim); border:1px solid var(--bbrd); display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.ac h3 { font-size:13.5px; font-weight:700; margin-bottom:5px; }
.ac p { font-size:12px; color:var(--dim); line-height:1.65; }
.ac-tag { display:inline-block; font-size:9.5px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--blue); margin-top:10px; opacity:.75; }

/* ─── RING STATS ─── */
#rings { background:var(--bg2); }
.rings-head { text-align:center; margin-bottom:60px; }
.rings-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.ring-card { background:var(--bg3); border:1px solid var(--ln); border-radius:var(--rl); padding:36px 20px 30px; text-align:center; transition:border-color .3s,transform .3s; }
.ring-card:hover { border-color:var(--bbrd); transform:translateY(-4px); }
.ring-wrap { position:relative; width:120px; height:120px; margin:0 auto 20px; }
.ring-bg { fill:none; stroke:rgba(64,128,255,.12); stroke-width:8; }
.ring-fill { fill:none; stroke:var(--blue); stroke-width:8; stroke-linecap:round; stroke-dasharray:282.74; stroke-dashoffset:282.74; transform:rotate(-90deg); transform-origin:50% 50%; transition:stroke-dashoffset 1.6s cubic-bezier(.4,0,.2,1); }
.ring-fill.go { stroke-dashoffset:var(--offset); }.ring-val { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--ff); font-size:26px; font-weight:800; color:var(--blue); }
.ring-label { font-family:var(--ff); font-size:15px; font-weight:700; margin-bottom:6px; }
.ring-desc { font-size:12.5px; color:var(--dim); line-height:1.6; }

/* ─── SPEED CHART ─── */
#speed { background:var(--bg); }
.speed-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:64px; align-items:center; }
.speed-txt .sh { margin-bottom:20px; }
.speed-txt > p { font-size:15px; color:var(--dim); line-height:1.8; }
.speed-kpis { display:flex; flex-direction:column; gap:16px; margin-top:32px; }
.skpi { display:flex; align-items:center; gap:16px; padding:16px 18px; background:var(--bg3); border:1px solid var(--ln); border-radius:var(--r); }
.skpi-n { font-family:var(--ff); font-size:32px; font-weight:800; color:var(--blue); line-height:1; min-width:72px; }
.skpi-l strong { display:block; font-family:var(--ff); font-size:14px; font-weight:700; margin-bottom:2px; }
.skpi-l span { font-size:12.5px; color:var(--dim); }

.bgroups { display:flex; flex-direction:column; gap:20px; }
.bgroup { background:var(--bg3); border:1px solid var(--ln); border-radius:var(--r); padding:22px; }
.bgroup-flag { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--dim2); margin-bottom:14px; }
.brow { display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.brow:last-child { margin-bottom:0; }
.brow-top { display:flex; justify-content:space-between; align-items:center; }
.brow-name { font-size:12px; font-weight:600; color:var(--dim); }
.brow-name.cf { color:var(--blue); }
.brow-time { font-size:11.5px; font-weight:700; color:var(--dim); }
.brow-time.cf { color:var(--blue); }
.brow-track { height:8px; background:rgba(255,255,255,.06); border-radius:4px; overflow:hidden; }
.bfill { height:100%; width:0; border-radius:4px; transition:width 1.3s cubic-bezier(.4,0,.2,1); }
.bfill.trad { background:rgba(255,255,255,.2); }
.bfill.cf { background:linear-gradient(90deg,var(--blue),var(--blueh)); box-shadow:0 0 12px var(--bglw); }

/* COMPARISON TABLE */
#compare { background:var(--bg2); }
.cmp-table { border:1px solid var(--ln2); border-radius:var(--rl); overflow:hidden; }
.cmp-head { display:grid; grid-template-columns:1fr 1fr 1fr; background:var(--bg4); border-bottom:1px solid var(--ln2); }
.cmp-feat-col { padding:18px 20px; }
.cmp-col { display:flex; align-items:center; gap:10px; padding:18px 20px; border-left:1px solid var(--ln2); }
.cmp-col-icon { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cmp-col.bad .cmp-col-icon  { background:rgba(239,68,68,.12); color:#EF4444; }
.cmp-col.good .cmp-col-icon { background:var(--bdim); color:var(--blue); }
.cmp-col-name { font-family:var(--ff); font-size:13px; font-weight:700; }
.cmp-col.bad  .cmp-col-name { color:#EF4444; }
.cmp-col.good .cmp-col-name { color:var(--blue); }

.cmp-row { display:grid; grid-template-columns:1fr 1fr 1fr; border-bottom:1px solid var(--ln); opacity:0; transform:translateX(-16px); transition:opacity .5s ease, transform .5s ease; }
.cmp-row:last-child { border-bottom:none; }
.cmp-row.in { opacity:1; transform:translateX(0); }
.cmp-row:hover .cmp-cell.good { background:rgba(64,128,255,.04); }

.cmp-feat { padding:16px 20px; font-size:13px; font-weight:600; color:var(--dim); display:flex; align-items:center; border-right:1px solid var(--ln); }
.cmp-cell { display:flex; align-items:center; gap:10px; padding:16px 20px; border-right:1px solid var(--ln); transition:background .2s; }
.cmp-cell:last-child { border-right:none; }
.cmp-x     { font-size:15px; color:#EF4444; flex-shrink:0; font-weight:700; }
.cmp-check { font-size:15px; color:#22C55E; flex-shrink:0; font-weight:700; }
.cmp-text  { font-size:12.5px; color:var(--dim); line-height:1.5; }
.cmp-cell.bad  .cmp-text { color:rgba(239,68,68,.7); }
.cmp-cell.good .cmp-text { color:var(--dim); }

@media (max-width:900px) {
  .cmp-head { grid-template-columns:1fr 1fr; }
  .cmp-feat-col { display:none; }
  .cmp-row { grid-template-columns:1fr 1fr; }
  .cmp-feat { display:none; }
  .cmp-col,.cmp-cell { padding:14px 12px; }
  .cmp-text { font-size:11.5px; }
  .cmp-col-name { font-size:12px; }
}

/* SERVICES */
#services { background:var(--bg2); }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.svc { background:var(--bg3); border:1px solid var(--ln); border-radius:var(--rl); padding:34px 28px; transition:box-shadow .3s,transform .3s,border-color .3s; display:flex; flex-direction:column; }
.svc:hover { box-shadow:var(--shl); transform:translateY(-5px); border-color:var(--bbrd); }
.svc-flag { font-size:28px; margin-bottom:14px; }
.svc-tag { display:inline-block; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); background:var(--bdim); border:1px solid var(--bbrd); padding:3px 10px; border-radius:4px; margin-bottom:12px; align-self:flex-start; }
.svc h3 { font-size:20px; font-weight:700; letter-spacing:-.02em; margin-bottom:8px; }
.svc-time { display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; color:var(--blue); letter-spacing:.06em; text-transform:uppercase; margin-bottom:20px; }
.svc-time::before { content:''; display:block; width:6px; height:6px; border-radius:50%; background:var(--blue); flex-shrink:0; animation:pdot 2s infinite; }
.feats { list-style:none; display:flex; flex-direction:column; gap:10px; flex:1; }
.feats li { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--dim); line-height:1.5; }
.feats li::before { content:''; display:block; width:15px; height:15px; flex-shrink:0; margin-top:2px; background:var(--bdim); border:1px solid var(--bbrd); border-radius:50%; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 15'%3E%3Cpath d='M3 7.5l3.5 3.5 5.5-7' stroke='%234080FF' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }

/* COMPLETE CONTROL */
#complete { background:var(--bg); }
.pkg-card { border-radius:20px; padding:52px; background:linear-gradient(var(--bg3),var(--bg3)) padding-box, linear-gradient(135deg,var(--blue),rgba(64,128,255,.3),rgba(64,128,255,.1)) border-box; border:1px solid transparent; position:relative; overflow:hidden; }
.pkg-glow { position:absolute; top:-80px; right:-80px; width:360px; height:360px; background:radial-gradient(circle,rgba(64,128,255,.12) 0%,transparent 65%); pointer-events:none; }
.pkg-top { display:grid; grid-template-columns:1fr auto; gap:32px; align-items:start; margin-bottom:40px; }
.pkg-badge { display:inline-flex; align-items:center; gap:6px; background:var(--blue); color:#fff; border-radius:6px; padding:5px 14px; font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:16px; }
.pkg-top h2 { font-size:clamp(20px,2.8vw,34px); font-weight:800; letter-spacing:-.03em; line-height:1.1; }
.pkg-top p { font-size:15px; color:var(--dim); line-height:1.78; margin-top:12px; max-width:540px; }
.pkg-btns { display:flex; flex-direction:column; gap:10px; flex-shrink:0; }
.pkg-features { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; padding-top:36px; border-top:1px solid var(--ln); }
.pkgf { background:var(--bg4); border:1px solid var(--ln); border-radius:var(--r); padding:24px 20px; transition:border-color .25s,transform .25s; }
.pkgf:hover { border-color:var(--bbrd); transform:translateY(-2px); }
.pkgf-ico { width:40px; height:40px; border-radius:9px; background:var(--bdim); border:1px solid var(--bbrd); display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.pkgf h4 { font-size:15px; font-weight:700; margin-bottom:6px; }
.pkgf p { font-size:13px; color:var(--dim); line-height:1.7; }

/* PROTECTION LAYERS */
#protect { background:var(--bg2); }
.protect-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.protect-txt h2 { font-size:clamp(26px,3.8vw,46px); font-weight:800; letter-spacing:-.03em; line-height:1.06; margin:12px 0 16px; }
.protect-txt > p { font-size:15px; color:var(--dim); line-height:1.8; margin-bottom:28px; }
.ppills { display:flex; flex-direction:column; gap:10px; }
.ppill { display:flex; align-items:flex-start; gap:14px; padding:16px 18px; background:var(--bg3); border:1px solid var(--ln); border-radius:var(--r); transition:border-color .25s; }
.ppill:hover { border-color:var(--bbrd); }
.ppill-ico { width:36px; height:36px; border-radius:8px; background:var(--bdim); border:1px solid var(--bbrd); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.ppill-body h4 { font-size:14px; font-weight:700; margin-bottom:3px; }
.ppill-body p { font-size:12.5px; color:var(--dim); line-height:1.6; }

/* NESTED LAYERS DIAGRAM */
.layers-viz { }
.lyr {
  border-radius: 14px;
  padding: 18px 18px 0;
  border: 1px solid transparent;
  transition: border-color .6s ease, background .6s ease;
}
.lyr .lyr-tag {
  font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 5px;
  opacity: .35; transition: opacity .5s ease;
}
.lyr .lyr-title {
  font-family: var(--ff); font-size: 15px; font-weight: 700;
  color: var(--txt); margin-bottom: 12px;
  opacity: .25; transition: opacity .5s ease;
}
.lyr.in .lyr-tag  { opacity: 1; }
.lyr.in .lyr-title { opacity: 1; }
.lyr-sp { height: 18px; }

.lyr1.in { border-color: rgba(64,128,255,.2);  background: rgba(64,128,255,.04); }
.lyr2.in { border-color: rgba(64,128,255,.32); background: rgba(64,128,255,.08); }
.lyr3.in { border-color: rgba(64,128,255,.5);  background: rgba(64,128,255,.13); }
.lyr4 { border-radius: 10px; padding: 18px; }
.lyr4 .lyr-sp { display: none; }
.lyr4.in { border-color: var(--blue); background: var(--blue); box-shadow: 0 0 32px var(--bglw); }
.lyr4.in .lyr-title { color: #fff; }
.lyr4.in .lyr-tag   { color: rgba(255,255,255,.7); }

/* WHY */
#why { background:var(--bg); }
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.wc { background:var(--bg3); border:1px solid var(--ln); border-radius:var(--rl); padding:34px 28px; position:relative; overflow:hidden; transition:border-color .3s,transform .3s,box-shadow .3s; }
.wc:hover { border-color:var(--bbrd); transform:translateY(-4px); box-shadow:0 12px 40px rgba(64,128,255,.1); }
.wc-num { font-family:var(--ff); font-size:60px; font-weight:800; color:var(--blue); opacity:.1; position:absolute; top:14px; right:18px; line-height:1; pointer-events:none; user-select:none; }
.wc-ico { width:46px; height:46px; border-radius:11px; background:var(--bdim); border:1px solid var(--bbrd); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.wc h3 { font-size:19px; font-weight:700; letter-spacing:-.02em; margin-bottom:10px; }
.wc p { font-size:14px; color:var(--dim); line-height:1.78; }
.wc-stat { margin-top:20px; padding-top:16px; border-top:1px solid var(--ln); font-size:11.5px; color:var(--blue); font-weight:700; letter-spacing:.04em; text-transform:uppercase; }

/* STEPS */
#how { background:var(--bg2); }
.steps { display:grid; grid-template-columns:repeat(4,1fr); position:relative; }
.steps::before { content:''; position:absolute; top:35px; left:calc(12.5% + 14px); right:calc(12.5% + 14px); height:1px; background:linear-gradient(90deg,var(--blue),rgba(64,128,255,.2) 50%,var(--blue)); }
.step { padding:0 20px 0 0; }
.step-n { width:70px; height:70px; border-radius:50%; background:var(--bg3); border:1px solid var(--ln2); display:flex; align-items:center; justify-content:center; font-family:var(--ff); font-size:18px; font-weight:800; color:var(--dim2); position:relative; z-index:1; margin-bottom:22px; transition:all .3s; }
.step:hover .step-n { background:var(--blue); border-color:var(--blue); color:#fff; box-shadow:0 0 24px var(--bglw); }
.step-day { display:inline-flex; background:var(--bdim); border:1px solid var(--bbrd); border-radius:4px; padding:3px 10px; font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--blue); margin-bottom:10px; }
.step h3 { font-size:15.5px; font-weight:700; margin-bottom:8px; }
.step p { font-size:13px; color:var(--dim); line-height:1.78; }

/* TESTIMONIALS */
#testimonials { background:var(--bg); }
.tgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tc { background:var(--bg3); border:1px solid var(--ln); border-radius:var(--rl); padding:28px; transition:box-shadow .3s,transform .3s,border-color .3s; }
.tc:hover { box-shadow:var(--shl); transform:translateY(-4px); border-color:var(--bbrd); }
.tc-q { font-family:Georgia,serif; font-size:38px; color:var(--blue); line-height:.85; margin-bottom:13px; opacity:.55; }
.tc-t { font-size:13.5px; line-height:1.82; color:var(--dim); margin-bottom:22px; }
.tc-a { display:flex; align-items:center; gap:12px; border-top:1px solid var(--ln); padding-top:18px; }
.av { width:34px; height:34px; border-radius:50%; background:var(--bdim); border:1px solid var(--bbrd); display:flex; align-items:center; justify-content:center; font-family:var(--ff); font-size:10.5px; font-weight:800; color:var(--blue); flex-shrink:0; }
.tc-name { font-size:13.5px; font-weight:700; }
.tc-role { font-size:11.5px; color:var(--dim); margin-top:2px; }

/* FAQ */
#faq { background:var(--bg2); }
.faq { max-width:760px; }
.fi { border-bottom:1px solid var(--ln); }
.fq { display:flex; align-items:center; justify-content:space-between; gap:20px; padding:20px 0; cursor:pointer; font-family:var(--ff); font-size:15.5px; font-weight:700; letter-spacing:-.015em; color:var(--txt); transition:color .2s; user-select:none; }
.fq:hover { color:var(--blue); }
.fq-ico { width:26px; height:26px; flex-shrink:0; border-radius:50%; background:var(--bg4); border:1px solid var(--ln2); display:flex; align-items:center; justify-content:center; transition:background .22s,border .22s; }
.fq-ico svg { transition:transform .3s; }
.fi.open .fq-ico { background:var(--blue); border-color:var(--blue); }
.fi.open .fq-ico svg { transform:rotate(45deg); }
.fa { max-height:0; overflow:hidden; transition:max-height .42s cubic-bezier(.4,0,.2,1); }
.fa-in { padding-bottom:20px; font-size:14px; color:var(--dim); line-height:1.82; }
.fi.open .fa { max-height:360px; }

/* CTA */
#cta { position:relative; overflow:hidden; text-align:center; padding:110px 24px; background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%); border-top:1px solid var(--ln); }
#cta::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:800px; height:800px; background:radial-gradient(circle,rgba(64,128,255,.12) 0%,transparent 62%); pointer-events:none; }
.cta-in { position:relative; z-index:1; max-width:560px; margin:0 auto; }
.cta-in h2 { font-size:clamp(30px,5.2vw,56px); font-weight:800; letter-spacing:-.04em; line-height:1.04; margin:16px 0 18px; }
.cta-in > p { color:var(--dim); font-size:16px; line-height:1.78; margin-bottom:38px; }
.cta-btns { display:flex; justify-content:center; gap:10px; flex-wrap:wrap; }
.cta-mail { margin-top:20px; font-size:13px; color:var(--dim2); }
.cta-mail a { color:var(--dim); text-decoration:none; transition:color .2s; }
.cta-mail a:hover { color:var(--txt); }

/* FOOTER */
footer { border-top:1px solid var(--ln); padding:28px 60px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.fl { display:flex; align-items:center; gap:8px; text-decoration:none; }
.fl img { width:22px; height:22px; object-fit:contain; border-radius:4px; display:block; }
.fl span { font-family:var(--ff); font-size:15px; font-weight:700; color:var(--txt); }
.flinks { display:flex; gap:20px; flex-wrap:wrap; }
.flinks a { font-size:13px; color:var(--dim); text-decoration:none; transition:color .2s; }
.flinks a:hover { color:var(--txt); }
.fcopy { font-size:12px; color:var(--dim2); }

/* REVEAL */
.rv  { opacity:0; transform:translateY(20px); transition:opacity .7s cubic-bezier(.22,.68,0,1.2),transform .7s cubic-bezier(.22,.68,0,1.2); }
.rvl { opacity:0; transform:translateX(-26px); transition:opacity .7s cubic-bezier(.22,.68,0,1.2),transform .7s cubic-bezier(.22,.68,0,1.2); }
.rvr { opacity:0; transform:translateX(26px); transition:opacity .7s cubic-bezier(.22,.68,0,1.2),transform .7s cubic-bezier(.22,.68,0,1.2); }
.rv.in,.rvl.in,.rvr.in { opacity:1; transform:translate(0); }
.d1{transition-delay:.07s} .d2{transition-delay:.14s} .d3{transition-delay:.21s} .d4{transition-delay:.28s}

/* MOBILE */
@media (max-width:900px) {
  #nav { width:calc(100% - 24px); top:10px; padding:9px 12px; }
  .nav-links,.nav-right .btn-ghost,.nav-right .nav-icon-btn { display:none; }
  .hamburger { display:flex; }
  .wrap { padding:0 18px; }
  .sec { padding:68px 0; }
  .sh h2 { font-size:clamp(22px,7vw,34px); }
  #hero { padding:96px 18px 52px; }
  .hero-h1 { font-size:clamp(32px,9.5vw,50px); letter-spacing:-.035em; }
  .hero-sub { font-size:15px; max-width:100%; }
  .hero-ctas { flex-direction:column; align-items:stretch; }
  .hero-ctas .btn { justify-content:center; width:100%; }
  .hero-stats { grid-template-columns:repeat(2,1fr); margin-top:40px; }
  .hero-stats .stat:nth-child(3)::before,.hero-stats .stat:nth-child(4)::before { top:0; bottom:auto; left:0; right:0; width:100%; height:1px; }
  .hero-stats .stat:nth-child(4)::before { left:0; right:auto; width:1px; height:100%; }
  .stat-n { font-size:24px; }
  .acc-intro { grid-template-columns:1fr; gap:14px; }
  .acc-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .ac { padding:16px 14px; }
  .ac-tag { display:none; }
  .rings-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .ring-card { padding:24px 16px 20px; }
  .ring-wrap { width:100px; height:100px; }
  .ring-wrap svg { width:100px; height:100px; }
  .ring-val { font-size:20px; }
  .speed-grid { grid-template-columns:1fr; gap:36px; }
  .speed-kpis { flex-direction:column; gap:12px; }
  .skpi { width:100%; }
  .svc-grid { grid-template-columns:1fr; gap:14px; }
  .svc { padding:26px 20px; }
  .pkg-card { padding:28px 20px; }
  .pkg-top { grid-template-columns:1fr; gap:20px; }
  .pkg-btns { flex-direction:row; flex-wrap:wrap; }
  .pkg-features { grid-template-columns:1fr; gap:12px; }
  .protect-grid { grid-template-columns:1fr; gap:36px; }
  .why-grid { grid-template-columns:1fr; gap:14px; }
  .steps { grid-template-columns:1fr; }
  .steps::before { display:none; }
  .step { position:relative; padding:0 0 30px 78px; }
  .step:last-child { padding-bottom:0; }
  .step::after { content:''; display:block; position:absolute; left:33px; top:70px; bottom:0; width:1px; background:var(--ln2); }
  .step:last-child::after { display:none; }
  .step-n { position:absolute; left:0; top:0; width:66px; height:66px; font-size:16px; margin-bottom:0; }
  .tgrid { grid-template-columns:1fr; gap:14px; }
  .faq { max-width:100%; }
  .fq { font-size:14px; padding:17px 0; }
  #cta { padding:76px 18px; }
  .cta-btns { flex-direction:column; align-items:stretch; }
  .cta-btns .btn { justify-content:center; }
  footer { padding:24px 18px; flex-direction:column; align-items:flex-start; gap:16px; }
  .flinks { gap:12px; }
}
@media (max-width:480px) {
  .acc-grid { grid-template-columns:1fr; }
  .hero-h1 { font-size:clamp(30px,9vw,42px); }
  .rings-grid { grid-template-columns:repeat(2,1fr); }
}
