/* =====================================================================
   AtomiverX Workspace — marketing site (Google-Workspace-style)
   Light, airy, colorful app icons. Brand family: Bricolage / Hanken / mono.
   ===================================================================== */
:root{
  --ink:#0E1020; --ink-2:#1A1D33;
  --tx:#15172A; --tx-soft:#525a72; --tx-faint:#878fa6;
  --paper:#FFFFFF; --paper-2:#F7F8FC; --canvas:#FBFBFE;
  --line:#E7E9F2; --line-2:#EFF1F8;
  --brand:#4F6BFF; --brand-ink:#2C3FB8; --aqua:#1FD1B5; --violet:#7C6BFF; --coral:#FF5C7A; --green:#1BA463;
  --shadow-sm:0 1px 2px rgba(20,23,42,.05),0 6px 18px rgba(20,23,42,.05);
  --shadow-md:0 12px 30px -10px rgba(20,23,42,.16);
  --shadow-lg:0 34px 64px -26px rgba(20,23,42,.34);
  --r:14px; --r-lg:22px; --r-xl:30px; --ease:cubic-bezier(.22,.61,.36,1);
  --font-disp:"Bricolage Grotesque","Hanken Grotesk",sans-serif;
  --font-body:"Hanken Grotesk",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
}
*{ box-sizing:border-box; margin:0; padding:0; }
[hidden]{ display:none !important; }
html{ scroll-behavior:smooth; }
body{ font-family:var(--font-body); background:var(--canvas); color:var(--tx); line-height:1.55; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a{ color:inherit; text-decoration:none; }
svg.ic,svg.chev{ width:1em; height:1em; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; display:inline-block; vertical-align:-.12em; }
.wrap{ width:min(100% - 40px, 1180px); margin-inline:auto; }

/* buttons */
.btn{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--font-body); font-weight:600; font-size:.94rem; padding:.66em 1.15em; border-radius:999px; border:1.5px solid transparent; cursor:pointer; transition:transform .22s var(--ease), box-shadow .22s, background .2s, border-color .2s, color .2s; white-space:nowrap; }
.btn:hover{ transform:translateY(-2px); }
.btn .ic{ transition:transform .22s var(--ease); }
.btn.solid{ background:var(--ink); color:#fff; box-shadow:var(--shadow-sm); }
.btn.solid:hover{ box-shadow:0 12px 26px -10px rgba(14,16,32,.5); }
.btn.solid:hover .ic{ transform:translateX(3px); }
.btn.line{ background:#fff; color:var(--tx); border-color:var(--line); }
.btn.line:hover{ border-color:var(--tx-faint); }
.btn.line-d{ background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn.line-d:hover{ border-color:#fff; background:rgba(255,255,255,.1); }
.btn.ghost{ color:var(--tx-soft); }
.btn.ghost:hover{ color:var(--tx); transform:none; }
.btn.lg{ font-size:1.02rem; padding:.82em 1.45em; }

/* atom mark */
.atom-mark{ position:relative; width:26px; height:26px; display:inline-block; flex:0 0 auto; }
.atom-mark .nucleus{ position:absolute; inset:0; margin:auto; width:6px; height:6px; border-radius:50%; background:radial-gradient(circle at 35% 35%,#fff,var(--aqua)); box-shadow:0 0 8px var(--aqua); }
.atom-mark .ring{ position:absolute; inset:0; border:1.4px solid rgba(31,209,181,.6); border-radius:50%; animation:spin 9s linear infinite; }
.atom-mark .ring-b{ transform:rotate(60deg); border-color:rgba(124,107,255,.6); animation-duration:7s; animation-direction:reverse; }
.atom-mark .ring-c{ transform:rotate(120deg); border-color:rgba(79,107,255,.6); animation-duration:11s; }
.atom-mark.sm{ width:22px; height:22px; }
@keyframes spin{ to{ transform:rotate(360deg); } }
@media (prefers-reduced-motion:reduce){ .atom-mark .ring{ animation:none; } }

/* ============================ HEADER ============================ */
.hd{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,.85); backdrop-filter:blur(14px) saturate(1.4); border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s; }
.hd.sc{ border-bottom-color:var(--line); box-shadow:0 6px 22px -18px rgba(20,23,42,.6); }
.hd-inner{ display:flex; align-items:center; gap:22px; height:64px; }
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--font-disp); font-weight:700; font-size:1.12rem; letter-spacing:-.01em; white-space:nowrap; }
.brand-word .x{ color:var(--aqua); } .brand-word b{ color:var(--brand); }
.nav{ display:flex; align-items:center; gap:2px; margin-left:8px; }
.nav-l{ font-weight:500; font-size:.93rem; color:var(--tx-soft); padding:.5em .8em; border-radius:9px; background:none; border:none; cursor:pointer; font-family:var(--font-body); display:inline-flex; align-items:center; gap:.3em; transition:color .18s, background .18s; }
.nav-l:hover{ color:var(--tx); background:var(--paper-2); }
.nav-l .chev{ font-size:.82em; transition:transform .2s; }
.nav-l[aria-expanded="true"] .chev{ transform:rotate(90deg); }
.hd-cta{ margin-left:auto; display:flex; align-items:center; gap:8px; }
.burger{ display:none; margin-left:auto; width:42px; height:42px; border:1px solid var(--line); border-radius:11px; background:#fff; cursor:pointer; font-size:1.4rem; color:var(--tx); align-items:center; justify-content:center; }
.burger .shut{ display:none; } .burger[aria-expanded="true"] .open{ display:none; } .burger[aria-expanded="true"] .shut{ display:inline-block; }

.mega{ position:absolute; left:0; right:0; top:100%; background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line); box-shadow:var(--shadow-lg); animation:fade .2s var(--ease); }
@keyframes fade{ from{ opacity:0; transform:translateY(-8px); } }
.mega-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:6px 22px; padding:24px 0; }
.mega-cat{ grid-column:1/-1; font-family:var(--font-mono); font-size:.66rem; letter-spacing:.16em; color:var(--tx-faint); padding:10px 8px 3px; }
.mega-i{ display:flex; align-items:center; gap:11px; padding:9px 10px; border-radius:11px; transition:background .15s; }
.mega-i:hover{ background:var(--paper-2); }
.mega-i .gl{ width:32px; height:32px; border-radius:9px; display:grid; place-items:center; color:#fff; flex:0 0 auto; }
.mega-i .gl svg{ width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.mega-i b{ font-size:.9rem; font-weight:600; display:block; } .mega-i span{ font-size:.76rem; color:var(--tx-faint); }

.drawer{ position:fixed; inset:64px 0 0; z-index:55; background:#fff; padding:24px 20px; display:flex; flex-direction:column; gap:2px; animation:fade .2s var(--ease); }
.drawer>a{ font-family:var(--font-disp); font-size:1.5rem; font-weight:600; padding:.4em 0; border-bottom:1px solid var(--line); }
.drawer-cta{ display:flex; gap:10px; margin-top:18px; } .drawer-cta .btn{ flex:1; justify-content:center; }

/* ============================ HERO ============================ */
.hero{ padding:64px 0 56px; background:radial-gradient(80% 60% at 80% -10%, rgba(79,107,255,.10), transparent 60%), radial-gradient(60% 50% at -5% 110%, rgba(31,209,181,.10), transparent 60%); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.eyebrow{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; color:var(--brand); font-weight:600; display:inline-flex; align-items:center; gap:.6em; margin-bottom:18px; }
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--aqua); box-shadow:0 0 8px var(--aqua); }
.hero-copy h1{ font-family:var(--font-disp); font-weight:700; font-size:clamp(2.3rem,4.6vw,3.7rem); line-height:1.03; letter-spacing:-.035em; }
.hero-copy h1 .hl{ background:linear-gradient(100deg,var(--brand),var(--violet)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.lede{ font-size:clamp(1.04rem,1.5vw,1.2rem); color:var(--tx-soft); max-width:540px; margin:20px 0 30px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; }
.hero-note{ margin-top:22px; font-size:.86rem; color:var(--tx-faint); display:flex; gap:.6em; flex-wrap:wrap; align-items:center; }
.hero-note .ic{ color:var(--green); }

/* hero visual */
.hero-visual{ position:relative; }
.hv-panel{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); box-shadow:var(--shadow-lg); overflow:hidden; }
.hv-bar{ display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--line-2); background:var(--paper-2); }
.hv-bar i{ width:11px; height:11px; border-radius:50%; background:var(--line); }
.hv-bar i:nth-child(1){ background:#FF5F57; } .hv-bar i:nth-child(2){ background:#FEBC2E; } .hv-bar i:nth-child(3){ background:#28C840; }
.hv-bar span{ margin-left:10px; font-family:var(--font-mono); font-size:.72rem; color:var(--tx-faint); }
.hv-apps{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; padding:26px; }
.hv-app{ display:flex; flex-direction:column; align-items:center; gap:8px; }
.hv-app .gl{ width:48px; height:48px; border-radius:14px; display:grid; place-items:center; color:#fff; box-shadow:0 8px 16px -7px var(--c); animation:bob 4s var(--ease) infinite; }
.hv-app .gl svg{ width:25px; height:25px; fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.hv-app span{ font-size:.68rem; color:var(--tx-faint); font-weight:500; }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-5px); } }
@media (prefers-reduced-motion:reduce){ .hv-app .gl{ animation:none; } }
.hv-float{ position:absolute; background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-md); padding:10px 14px 10px 10px; display:flex; align-items:center; gap:10px; animation:bob 5s var(--ease) infinite; }
.hv-float b{ font-size:.82rem; display:block; line-height:1.1; } .hv-float small{ font-size:.7rem; color:var(--tx-faint); }
.hvf-ic{ width:30px; height:30px; border-radius:9px; display:grid; place-items:center; color:#fff; }
.hvf-ic svg{ width:17px; height:17px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.hv-float.f1{ top:-22px; right:-10px; } .hv-float.f2{ bottom:30px; left:-32px; animation-delay:.6s; } .hv-float.f3{ bottom:-20px; right:24px; animation-delay:1.1s; }

/* ============================ STRIP ============================ */
.strip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; }
.strip-row{ display:grid; grid-template-columns:repeat(4,1fr); }
.strip-row>div{ padding:30px 18px; text-align:center; position:relative; }
.strip-row>div+div::before{ content:""; position:absolute; left:0; top:28%; height:44%; width:1px; background:var(--line); }
.strip-row b{ display:block; font-family:var(--font-disp); font-size:1.9rem; font-weight:700; letter-spacing:-.02em; color:var(--brand); }
.strip-row span{ font-size:.84rem; color:var(--tx-soft); }

/* ============================ SUITE ============================ */
.suite{ padding:84px 0 70px; }
.sec-head{ max-width:640px; margin-bottom:42px; }
.sec-head.center{ margin-inline:auto; text-align:center; }
.kicker{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.2em; color:var(--brand); font-weight:600; margin-bottom:14px; }
.kicker.light{ color:rgba(255,255,255,.6); }
.sec-head h2{ font-family:var(--font-disp); font-weight:700; font-size:clamp(1.9rem,3.6vw,2.8rem); line-height:1.06; letter-spacing:-.03em; }
.sec-lead{ margin-top:16px; font-size:1.06rem; color:var(--tx-soft); }
.suite-groups{ display:grid; gap:34px; }
.suite-cat{ font-family:var(--font-mono); font-size:.72rem; letter-spacing:.14em; color:var(--tx-faint); text-transform:uppercase; margin-bottom:16px; }
.suite-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.app-card{ position:relative; display:flex; flex-direction:column; gap:11px; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:20px 18px; overflow:hidden; transition:transform .26s var(--ease), box-shadow .26s, border-color .26s; }
.app-card::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 80% at 100% 0%, var(--ac-soft), transparent 55%); opacity:0; transition:opacity .3s; }
.app-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.app-card:hover::before{ opacity:1; }
.app-card:hover .ac-gl{ transform:scale(1.06) rotate(-4deg); }
.ac-gl{ position:relative; width:46px; height:46px; border-radius:13px; display:grid; place-items:center; color:#fff; background:var(--ac); box-shadow:0 8px 18px -6px var(--ac); transition:transform .3s var(--ease); }
.ac-gl svg{ width:24px; height:24px; fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.app-card b{ position:relative; font-family:var(--font-disp); font-size:1rem; font-weight:700; letter-spacing:-.01em; }
.app-card span{ position:relative; font-size:.8rem; color:var(--tx-soft); line-height:1.4; }
.app-card .ac-badge{ position:absolute; top:14px; right:14px; font-family:var(--font-mono); font-size:.56rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; padding:.3em .55em; border-radius:6px; background:var(--ac-soft); color:var(--ac-ink); }

/* ============================ FEATURES ============================ */
.features{ padding:30px 0 70px; }
.feat{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; padding:44px 0; }
.feat.rev .feat-copy{ order:2; }
.feat-tag{ display:inline-block; font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em; font-weight:600; color:var(--c); background:color-mix(in srgb, var(--c) 12%, white); padding:.4em .8em; border-radius:999px; margin-bottom:16px; }
.feat-copy h3{ font-family:var(--font-disp); font-weight:700; font-size:clamp(1.6rem,2.8vw,2.2rem); letter-spacing:-.025em; line-height:1.08; }
.feat-copy>p{ margin:14px 0 20px; color:var(--tx-soft); font-size:1.04rem; max-width:460px; }
.ticks{ list-style:none; display:grid; gap:10px; }
.ticks li{ display:flex; align-items:center; gap:10px; font-size:.96rem; color:var(--tx); }
.ticks .ic{ color:var(--green); }
.feat-visual{ border-radius:var(--r-xl); padding:26px; min-height:300px; box-shadow:var(--shadow-lg); border:1px solid var(--line); background:#fff; position:relative; overflow:hidden; }
/* mock doc */
.mock-doc{ background:var(--paper-2); }
.md-row{ display:flex; align-items:center; gap:10px; font-weight:600; font-size:.9rem; margin-bottom:18px; }
.md-row em{ margin-left:auto; font-style:normal; font-size:.72rem; color:var(--brand); background:rgba(79,107,255,.1); padding:.3em .6em; border-radius:999px; }
.md-app{ width:30px; height:30px; border-radius:8px; display:grid; place-items:center; color:#fff; } .md-app svg{ width:17px; height:17px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.md-line{ height:11px; border-radius:6px; background:#E4E7F1; margin:11px 0; }
.md-line.hl{ background:rgba(79,107,255,.25); }
.w90{ width:90%; } .w85{ width:85%; } .w80{ width:80%; } .w70{ width:70%; } .w60{ width:60%; } .w40{ width:40%; }
.md-cursors{ display:flex; gap:8px; margin-top:18px; }
.md-cursors .cur{ width:24px; height:24px; border-radius:50%; display:grid; place-items:center; color:#fff; font-size:.72rem; font-weight:700; background:var(--c); border:2px solid #fff; box-shadow:var(--shadow-sm); }
/* mock files */
.mock-files{ background:var(--paper-2); display:grid; place-items:center; }
.mf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; width:100%; }
.mf{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px 10px; display:flex; flex-direction:column; align-items:center; gap:9px; box-shadow:var(--shadow-sm); }
.mf svg{ width:26px; height:26px; color:var(--c); fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.mf span{ font-size:.78rem; color:var(--tx-soft); font-weight:500; }
/* mock security */
.mock-sec{ background:linear-gradient(150deg,#11152B,#0B0E1E); display:grid; place-items:center; border-color:transparent; }
.ms-card{ width:100%; max-width:300px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:20px; color:#EAEcf6; }
.ms-top{ display:flex; align-items:center; gap:10px; font-family:var(--font-disp); font-weight:700; margin-bottom:16px; }
.ms-ic{ width:32px; height:32px; border-radius:9px; background:linear-gradient(135deg,var(--green),#0E8C53); display:grid; place-items:center; } .ms-ic svg{ width:18px; height:18px; fill:none; stroke:#fff; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.ms-row{ display:flex; align-items:center; gap:9px; font-size:.88rem; padding:7px 0; color:#C7CCE2; }
.ms-row .ic{ color:var(--aqua); }
.ms-meter{ height:8px; border-radius:999px; background:rgba(255,255,255,.12); margin:14px 0 8px; overflow:hidden; } .ms-meter i{ display:block; height:100%; width:86%; border-radius:999px; background:linear-gradient(90deg,var(--aqua),var(--green)); }
.ms-card small{ font-size:.74rem; color:#8E96B4; }

/* ============================ SOLUTIONS ============================ */
.solutions{ padding:70px 0; background:#fff; border-top:1px solid var(--line); }
.sol-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.sol{ border:1px solid var(--line); border-radius:var(--r-lg); padding:30px 26px; transition:transform .26s var(--ease), box-shadow .26s; }
.sol:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.sol-ic{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center; color:#fff; background:var(--c); box-shadow:0 8px 18px -6px var(--c); margin-bottom:18px; }
.sol-ic svg{ width:26px; height:26px; fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.sol h3{ font-family:var(--font-disp); font-size:1.2rem; font-weight:700; letter-spacing:-.01em; margin-bottom:8px; }
.sol p{ font-size:.95rem; color:var(--tx-soft); margin-bottom:16px; }
.sol a{ font-weight:600; font-size:.9rem; color:var(--brand); display:inline-flex; align-items:center; gap:.4em; }
.sol a:hover .ic{ transform:translateX(3px); transition:transform .2s; }

/* ============================ SECURITY ============================ */
.security{ padding:84px 0; background:var(--ink); color:#E7E9F4; }
.sec-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:54px; align-items:center; }
.sec-copy h2{ font-family:var(--font-disp); font-weight:700; font-size:clamp(1.8rem,3.2vw,2.6rem); letter-spacing:-.03em; line-height:1.06; color:#fff; margin-bottom:16px; }
.sec-copy>p{ color:#9AA2C0; font-size:1.05rem; max-width:520px; margin-bottom:28px; }
.sec-points{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.sec-points>div{ display:flex; gap:13px; }
.sp-ic{ width:40px; height:40px; border-radius:11px; flex:0 0 auto; display:grid; place-items:center; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); color:var(--aqua); }
.sp-ic svg{ width:21px; height:21px; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.sec-points b{ display:block; font-size:.96rem; color:#fff; } .sec-points small{ font-size:.82rem; color:#9AA2C0; }
.sec-art{ display:grid; place-items:center; }
.sec-shield{ width:200px; height:200px; border-radius:50%; display:grid; place-items:center; background:radial-gradient(circle at 40% 35%, rgba(31,209,181,.3), transparent 60%); border:1px solid rgba(255,255,255,.12); position:relative; }
.sec-shield::before,.sec-shield::after{ content:""; position:absolute; inset:0; margin:auto; border:1px solid rgba(31,209,181,.25); border-radius:50%; }
.sec-shield::before{ width:150%; height:150%; } .sec-shield::after{ width:200%; height:200%; border-color:rgba(124,107,255,.18); }
.sec-shield svg{ width:84px; height:84px; color:var(--aqua); fill:none; stroke:currentColor; stroke-width:1.4; stroke-linecap:round; stroke-linejoin:round; }

/* ============================ PRICING ============================ */
.pricing{ padding:84px 0 90px; }
.bill-toggle{ display:inline-flex; gap:4px; margin:22px auto 8px; padding:5px; background:var(--paper-2); border:1px solid var(--line); border-radius:999px; }
.bill-toggle button{ font-family:var(--font-body); font-weight:600; font-size:.88rem; padding:.5em 1.1em; border-radius:999px; border:none; background:transparent; color:var(--tx-soft); cursor:pointer; display:inline-flex; align-items:center; gap:.5em; transition:background .2s, color .2s; }
.bill-toggle button.active{ background:#fff; color:var(--tx); box-shadow:var(--shadow-sm); }
.bill-toggle button span{ font-size:.66rem; color:var(--green); background:rgba(27,164,99,.12); padding:.2em .5em; border-radius:999px; }
.price-note{ font-size:.8rem; color:var(--tx-faint); }
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:32px; align-items:start; }
.plan{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); padding:30px 26px; position:relative; transition:transform .26s var(--ease), box-shadow .26s; }
.plan.pop{ border-color:var(--brand); box-shadow:var(--shadow-lg); transform:translateY(-6px); }
.plan.pop:hover{ transform:translateY(-9px); }
.plan:hover{ box-shadow:var(--shadow-md); }
.plan-flag{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); font-family:var(--font-mono); font-size:.64rem; letter-spacing:.1em; font-weight:600; text-transform:uppercase; color:#fff; background:var(--brand); padding:.4em .9em; border-radius:999px; }
.plan h3{ font-family:var(--font-disp); font-size:1.2rem; font-weight:700; }
.plan .ptag{ font-size:.85rem; color:var(--tx-faint); margin-bottom:18px; min-height:38px; }
.plan .price{ font-family:var(--font-disp); font-weight:700; letter-spacing:-.02em; line-height:1; }
.plan .price b{ font-size:2.5rem; } .plan .price span{ font-size:.86rem; color:var(--tx-faint); font-weight:500; }
.plan .btn{ width:100%; justify-content:center; margin:22px 0; }
.plan ul{ list-style:none; display:grid; gap:11px; }
.plan li{ display:flex; align-items:flex-start; gap:9px; font-size:.9rem; color:var(--tx-soft); }
.plan li svg{ width:17px; height:17px; flex:0 0 auto; margin-top:2px; fill:none; stroke:var(--green); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

/* ============================ CTA ============================ */
.cta{ padding:20px 0 80px; }
.cta-box{ background:linear-gradient(135deg,var(--brand),var(--violet) 60%,var(--coral)); border-radius:var(--r-xl); padding:64px 40px; text-align:center; color:#fff; position:relative; overflow:hidden; }
.cta-box::after{ content:""; position:absolute; inset:0; opacity:.5; mix-blend-mode:soft-light; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.cta-box h2{ position:relative; font-family:var(--font-disp); font-weight:700; font-size:clamp(1.8rem,3.4vw,2.7rem); letter-spacing:-.03em; }
.cta-box p{ position:relative; margin:14px auto 26px; font-size:1.08rem; color:rgba(255,255,255,.92); }
.cta-actions{ position:relative; display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.cta-box .btn.solid{ background:#fff; color:var(--ink); }

/* ============================ FOOTER ============================ */
.ft{ background:var(--ink); color:#9AA1BC; padding:56px 0 28px; }
.ft-top{ display:grid; grid-template-columns:1.3fr 2.7fr; gap:48px; padding-bottom:34px; border-bottom:1px solid rgba(255,255,255,.08); }
.ft-brand .brand{ color:#fff; margin-bottom:14px; }
.ft-brand p{ font-size:.9rem; max-width:300px; line-height:1.55; }
.ft-back{ display:inline-block; margin-top:14px; font-size:.86rem; color:var(--aqua); font-weight:600; }
.ft-cols{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.ft-col h4{ font-family:var(--font-mono); font-size:.66rem; letter-spacing:.14em; color:var(--tx-faint); text-transform:uppercase; margin-bottom:12px; }
.ft-col a{ display:block; font-size:.88rem; color:#9AA1BC; padding:4px 0; transition:color .15s; }
.ft-col a:hover{ color:#fff; }
.ft-bottom{ display:flex; align-items:center; justify-content:space-between; padding-top:22px; font-size:.83rem; gap:14px; flex-wrap:wrap; }
.ft-bottom nav{ display:flex; gap:18px; } .ft-bottom nav a:hover{ color:#fff; }

/* ============================ REVEAL ============================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } }

/* ============================ RESPONSIVE ============================ */
@media (max-width:1040px){ .suite-grid{ grid-template-columns:repeat(4,1fr); } .mega-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:900px){
  .nav,.hd-cta{ display:none; } .burger{ display:flex; }
  .hero-grid,.sec-grid{ grid-template-columns:1fr; gap:40px; }
  .feat,.feat.rev .feat-copy{ grid-template-columns:1fr; order:0; } .feat{ gap:30px; }
  .sol-grid,.plans{ grid-template-columns:1fr; } .plan.pop{ transform:none; }
  .sec-points{ grid-template-columns:1fr 1fr; }
  .ft-top{ grid-template-columns:1fr; gap:30px; } .ft-cols{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:620px){
  .suite-grid{ grid-template-columns:repeat(2,1fr); }
  .strip-row{ grid-template-columns:repeat(2,1fr); } .strip-row>div:nth-child(2)::before{ display:none; }
  .hv-float{ display:none; } .sec-points{ grid-template-columns:1fr; }
  .hero{ padding:40px 0; } .cta-box{ padding:44px 22px; }
}
@media (max-width:400px){ .suite-grid{ grid-template-columns:1fr; } .hv-apps{ grid-template-columns:repeat(3,1fr); } }
