/* ===================================================================
   The Funnel Five — Logo 3 / 02 Mesh · "Gradient Mesh"
   Dark theme · Outfit + Hanken Grotesk · saturated blue mesh
   =================================================================== */

:root{
  --bg:#0B0D14;
  --bg-2:#0F1220;
  --ink:#EAEEF6;
  --ink-soft:#AEB6CA;
  --ink-mute:#7C859C;
  --blue:#2C7BF2;
  --azure:#3FA0FF;
  --indigo:#6C5CE7;
  --violet:#9B5CFC;
  --cyan:#36D6E0;
  --line:rgba(255,255,255,.10);
  --line-2:rgba(255,255,255,.16);

  --glass:rgba(255,255,255,.045);
  --glass-2:rgba(255,255,255,.07);

  --radius-s:12px;
  --radius:20px;
  --radius-l:30px;

  --display:'Outfit', system-ui, sans-serif;
  --body:'Hanken Grotesk', system-ui, sans-serif;

  --shell:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.66;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4{
  font-family:var(--display);line-height:1.12;
  letter-spacing:-.022em;font-weight:700;
  overflow-wrap:break-word;
}

.shell{width:100%;max-width:var(--shell);margin:0 auto;padding:0 32px}

.skip-link{
  position:absolute;left:14px;top:-60px;z-index:200;
  background:var(--blue);color:#fff;padding:10px 18px;border-radius:8px;
  font-weight:700;transition:top .2s var(--ease);
}
.skip-link:focus{top:14px}
:focus-visible{outline:2.5px solid var(--azure);outline-offset:3px;border-radius:5px}

/* ---------- ambient base ---------- */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(680px 540px at 12% 4%, rgba(108,92,231,.20), transparent 70%),
    radial-gradient(620px 520px at 92% 100%, rgba(54,214,224,.10), transparent 72%),
    var(--bg);
}

/* ===================================================================
   MESH FIELD — large blurred multi-color blobs
   =================================================================== */
.mesh-field{
  position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none;
}
.blob{
  position:absolute;border-radius:50%;
  filter:blur(80px);opacity:.78;
}
.blob-1{width:560px;height:560px;left:-160px;top:-180px;
  background:radial-gradient(circle,#2C7BF2,transparent 68%)}
.blob-2{width:620px;height:620px;right:-200px;top:-120px;
  background:radial-gradient(circle,#6C5CE7,transparent 66%)}
.blob-3{width:520px;height:520px;left:30%;bottom:-260px;
  background:radial-gradient(circle,#3FA0FF,transparent 66%)}
.blob-4{width:420px;height:420px;right:18%;bottom:-160px;
  background:radial-gradient(circle,#36D6E0,transparent 68%);opacity:.55}

.sec-blob{
  position:absolute;border-radius:50%;filter:blur(110px);
  pointer-events:none;z-index:0;
}
.pb-blob{width:480px;height:480px;left:-200px;top:20%;
  background:radial-gradient(circle,rgba(44,123,242,.42),transparent 70%)}
.sys-blob{width:520px;height:520px;right:-220px;top:30%;
  background:radial-gradient(circle,rgba(108,92,231,.38),transparent 70%)}
.pr-blob{width:560px;height:560px;left:50%;top:-100px;transform:translateX(-50%);
  background:radial-gradient(circle,rgba(63,160,255,.30),transparent 72%)}

/* ===================================================================
   BUTTONS
   =================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--display);font-weight:600;font-size:.98rem;
  padding:14px 26px;border-radius:100px;
  letter-spacing:-.01em;line-height:1;position:relative;overflow:hidden;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease),
             background .25s var(--ease);
  white-space:nowrap;
}
.btn-lg{padding:17px 34px;font-size:1.05rem}
.btn-block{width:100%}

.btn-primary{
  background:linear-gradient(135deg,#3FA0FF 0%,#2C7BF2 48%,#6C5CE7 100%);
  color:#fff;
  box-shadow:0 8px 26px rgba(44,123,242,.42), inset 0 1px 0 rgba(255,255,255,.32);
}
.btn-primary::after{
  content:"";position:absolute;left:0;right:0;top:0;height:48%;
  background:linear-gradient(180deg,rgba(255,255,255,.34),transparent);
}
.btn-primary:hover{transform:translateY(-3px);
  box-shadow:0 14px 34px rgba(44,123,242,.55), inset 0 1px 0 rgba(255,255,255,.4)}

.btn-glass{
  background:var(--glass-2);color:var(--ink);
  border:1px solid var(--line-2);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12);
}
.btn-glass::after{
  content:"";position:absolute;left:0;right:0;top:0;height:46%;
  background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);
}
.btn-glass:hover{transform:translateY(-3px);background:rgba(255,255,255,.12);
  border-color:rgba(63,160,255,.5)}

/* ===================================================================
   HEADER
   =================================================================== */
.site-header{
  position:sticky;top:0;z-index:100;
  transition:background .3s var(--ease), box-shadow .3s var(--ease),
             border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(11,13,20,.78);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  border-bottom-color:var(--line);
  box-shadow:0 8px 30px rgba(0,0,0,.4);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;height:80px;
}
.brand{display:flex;align-items:center;gap:11px}
.brand-logo{height:42px;width:auto;flex:none;display:block;object-fit:contain;
  filter:drop-shadow(0 0 10px rgba(44,123,242,.5));}
.footer-brand .brand-logo{height:46px;}
.brand-name{
  font-family:var(--display);font-weight:700;font-size:1.18rem;
  letter-spacing:-.022em;color:#fff;
}
.primary-nav{display:flex;align-items:center;gap:4px}
.primary-nav>a:not(.btn){
  font-family:var(--display);font-weight:500;font-size:.96rem;
  color:var(--ink-soft);padding:9px 15px;border-radius:100px;
  transition:color .2s var(--ease), background .2s var(--ease);
}
.primary-nav>a:not(.btn):hover{color:#fff;background:var(--glass-2)}
.nav-cta{margin-left:10px}

.nav-toggle{
  display:none;width:46px;height:46px;border-radius:12px;
  background:var(--glass-2);border:1px solid var(--line-2);
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
}
.nav-toggle span{width:20px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .3s var(--ease), opacity .2s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===================================================================
   SECTION SCAFFOLD
   =================================================================== */
.section{padding:112px 0;position:relative}
.section-head{max-width:700px;margin:0 auto 56px;text-align:center;position:relative;z-index:1}
.kicker{
  display:inline-block;font-family:var(--display);font-weight:600;
  font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--azure);
  padding:7px 16px;border-radius:100px;
  background:rgba(63,160,255,.12);border:1px solid rgba(63,160,255,.24);
  margin-bottom:20px;
}
.section-title{
  font-size:clamp(1.85rem,3.5vw,2.7rem);
  font-weight:700;color:#fff;letter-spacing:-.028em;
}
.section-sub{margin-top:16px;color:var(--ink-soft);font-size:1.06rem}

/* ===================================================================
   1 · HERO — big mesh field + centered headline + orbs
   =================================================================== */
.hero{position:relative;padding:130px 0 132px;overflow:hidden;text-align:center}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:160px;
  background:linear-gradient(180deg,transparent,var(--bg));z-index:1;
}
.orb{
  position:absolute;border-radius:50%;z-index:1;
  box-shadow:inset -8px -10px 24px rgba(0,0,0,.35),
             inset 8px 10px 22px rgba(255,255,255,.32),
             0 20px 50px rgba(44,123,242,.4);
}
.orb-a{
  width:96px;height:96px;left:8%;top:30%;
  background:radial-gradient(circle at 32% 28%,#9CC4FF,#2C7BF2 62%,#1A4FB0);
  animation:float-a 9s var(--ease) infinite;
}
.orb-b{
  width:62px;height:62px;right:11%;top:24%;
  background:radial-gradient(circle at 34% 30%,#C7B6FF,#6C5CE7 60%,#3E2FA8);
  animation:float-b 11s var(--ease) infinite;
}
@keyframes float-a{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}
@keyframes float-b{0%,100%{transform:translateY(0)}50%{transform:translateY(22px)}}

.hero-inner{position:relative;z-index:2;max-width:920px}
.eyebrow{
  display:inline-block;font-family:var(--display);font-weight:600;
  font-size:.77rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);
  padding:9px 18px;border-radius:100px;
  background:var(--glass-2);border:1px solid var(--line-2);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  margin-bottom:26px;
}
.hero-title{
  font-size:clamp(2.5rem,5.6vw,4.4rem);
  font-weight:800;letter-spacing:-.035em;line-height:1.05;
  background:linear-gradient(180deg,#FFFFFF 36%,#A9C6FF 100%);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
}
.hero-sub{
  margin:24px auto 0;max-width:640px;
  font-size:1.14rem;color:var(--ink-soft);
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:34px}
.trust-strip{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:38px;
}
.trust-strip li{
  font-family:var(--display);font-weight:500;font-size:.86rem;
  color:var(--ink-soft);
  padding:8px 16px;border-radius:100px;
  background:var(--glass);border:1px solid var(--line);
  display:flex;align-items:center;gap:8px;
}
.trust-strip li::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--azure),var(--indigo));
  box-shadow:0 0 8px rgba(63,160,255,.7);
}

/* ===================================================================
   GLASS CARD base
   =================================================================== */
.glass-card{
  position:relative;
  background:linear-gradient(165deg,rgba(255,255,255,.085),rgba(255,255,255,.03));
  border:1px solid var(--line-2);
  border-radius:var(--radius-l);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  box-shadow:0 24px 60px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.14);
  overflow:hidden;
}
.card-gloss,.panel-gloss{
  position:absolute;left:0;right:0;top:0;height:42%;
  background:linear-gradient(180deg,rgba(255,255,255,.12),transparent);
  pointer-events:none;
}

/* ===================================================================
   2 · PROBLEM — two glass cards over mesh
   =================================================================== */
.problem-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;position:relative;z-index:1;
}
.pain-card{
  padding:40px 38px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease),
             border-color .35s var(--ease);
}
.pain-card:hover{transform:translateY(-7px);
  border-color:rgba(63,160,255,.4);
  box-shadow:0 32px 70px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.2),
             0 0 40px rgba(44,123,242,.2)}
.pain-top{
  display:flex;align-items:center;gap:14px;
  margin-bottom:18px;flex-wrap:wrap;
}
.pain-icon{
  display:flex;align-items:center;justify-content:center;
  width:50px;height:50px;border-radius:14px;flex:none;color:#fff;
  background:linear-gradient(150deg,var(--azure),var(--indigo));
  box-shadow:0 10px 24px rgba(44,123,242,.4);
}
.pain-icon svg{width:25px;height:25px}
.pain-tag{
  font-family:var(--display);font-weight:600;
  font-size:.73rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--azure);background:rgba(63,160,255,.12);
  border:1px solid rgba(63,160,255,.22);
  padding:6px 13px;border-radius:100px;
}
.pain-label{font-size:1.42rem;color:#fff;margin-bottom:10px}
.pain-lead{color:var(--ink);font-size:1.04rem;font-weight:500;margin-bottom:20px}
.pain-list{
  display:flex;flex-direction:column;gap:12px;
  padding-top:20px;border-top:1px solid var(--line);
}
.pain-list li{
  position:relative;padding-left:32px;
  font-size:.96rem;color:var(--ink-soft);
}
.pain-list li::before{
  content:"";position:absolute;left:0;top:1px;
  width:21px;height:21px;border-radius:50%;
  background:rgba(255,126,134,.13);
  border:1px solid rgba(255,126,134,.42);
}
.pain-list li::after{
  content:"\2715";position:absolute;left:0;top:1px;
  width:21px;height:21px;
  display:flex;align-items:center;justify-content:center;
  font-size:10.5px;font-weight:700;color:#FF7E86;
}

/* ===================================================================
   3 · SOLUTION — glowing gradient panel, 2 segments
   =================================================================== */
.solution-panel{
  position:relative;overflow:hidden;
  border-radius:var(--radius-l);
  padding:60px 58px;
  background:
    radial-gradient(520px 360px at 88% 8%, rgba(108,92,231,.5), transparent 68%),
    radial-gradient(480px 360px at 8% 96%, rgba(54,214,224,.32), transparent 68%),
    linear-gradient(150deg,#1C2A6E 0%,#1F4FC4 52%,#2C7BF2 100%);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 30px 80px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.22);
}
.solution-intro{max-width:680px;margin:0 auto 42px;text-align:center;position:relative;z-index:1}
.solution-panel .kicker{
  background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.26);color:#fff;
}
.solution-panel .section-title{color:#fff}
.solution-body{margin-top:15px;color:rgba(255,255,255,.9);font-size:1.1rem}
.solution-segments{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr auto 1fr;gap:46px;align-items:start;
}
.seg-split{width:1px;align-self:stretch;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.4),transparent)}
.seg-head{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.seg-icon{
  display:flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:13px;flex:none;color:#fff;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.3);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2);
}
.seg-icon svg{width:23px;height:23px}
.seg-mark{
  font-family:var(--display);font-weight:800;font-size:2.4rem;line-height:1;
  color:transparent;-webkit-text-stroke:1.6px rgba(255,255,255,.6);
}
.seg-title{font-size:1.42rem;color:#fff;margin-bottom:11px}
.segment p{color:rgba(255,255,255,.88);font-size:1.02rem}

/* ===================================================================
   4 · SYSTEM — 5 gradient nodes along an arc
   =================================================================== */
.arc-track{position:relative;padding-top:10px;z-index:1}
.arc-svg{
  position:absolute;left:0;right:0;top:0;width:100%;height:300px;z-index:0;
}
.arc-steps{
  position:relative;z-index:1;
  display:grid;grid-template-columns:repeat(5,1fr);gap:18px;
  align-items:start;
}
.arc-step{display:flex;flex-direction:column;align-items:center;text-align:center}
.as-1{margin-top:124px}
.as-2{margin-top:42px}
.as-3{margin-top:8px}
.as-4{margin-top:42px}
.as-5{margin-top:124px}
.arc-node{
  width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 34% 30%,#7FB0FF,#2C7BF2 58%,#1A3FA0);
  box-shadow:inset -4px -6px 14px rgba(0,0,0,.4),
             inset 4px 6px 14px rgba(255,255,255,.35),
             0 14px 30px rgba(44,123,242,.5);
  margin-bottom:18px;flex:none;
  transition:transform .35s var(--ease);
}
.arc-step:nth-child(2) .arc-node{background:radial-gradient(circle at 34% 30%,#9CB6FF,#5566E8 58%,#33308F)}
.arc-step:nth-child(3) .arc-node{background:radial-gradient(circle at 34% 30%,#B79CFF,#7C5CFC 58%,#4A2FB0)}
.arc-step:nth-child(4) .arc-node{background:radial-gradient(circle at 34% 30%,#8FD0FF,#3FA0FF 58%,#1F66C0)}
.arc-step:nth-child(5) .arc-node{background:radial-gradient(circle at 34% 30%,#7FE8EE,#36D6E0 58%,#1C8088)}
.arc-step:hover .arc-node{transform:scale(1.12) translateY(-4px)}
.arc-node span{font-family:var(--display);font-weight:800;font-size:1.42rem;color:#fff}
.arc-day{
  font-family:var(--display);font-weight:600;font-size:.73rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--azure);
  background:rgba(63,160,255,.12);border:1px solid rgba(63,160,255,.22);
  padding:4px 12px;border-radius:100px;margin-bottom:9px;display:inline-block;
}
.arc-title{font-size:1.16rem;color:#fff;margin-bottom:7px}
.arc-step p{font-size:.93rem;color:var(--ink-soft)}

/* ===================================================================
   5 · GUARANTEE — mesh-lit panel + stat chips
   =================================================================== */
.guarantee-panel{
  position:relative;overflow:hidden;
  border-radius:var(--radius-l);
  padding:58px 58px;
  background:linear-gradient(165deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border:1px solid var(--line-2);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  box-shadow:0 28px 70px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.16);
  display:grid;grid-template-columns:1.35fr 1fr;gap:50px;align-items:center;
}
.guar-blob{
  position:absolute;width:420px;height:420px;right:-120px;bottom:-160px;
  border-radius:50%;filter:blur(90px);
  background:radial-gradient(circle,rgba(108,92,231,.6),transparent 70%);
}
.guar-copy{position:relative;z-index:1}
.guar-copy p{margin-top:14px;color:var(--ink-soft);font-size:1.04rem}
.stat-chips{
  position:relative;z-index:1;
  display:flex;flex-wrap:wrap;gap:12px;
}
.stat-chips li{
  font-family:var(--display);font-weight:600;font-size:.92rem;color:#fff;
  padding:12px 18px;border-radius:100px;
  background:linear-gradient(135deg,rgba(63,160,255,.2),rgba(108,92,231,.16));
  border:1px solid rgba(255,255,255,.2);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2);
  display:flex;align-items:center;gap:9px;
}
.stat-chips li::before{
  content:"";width:9px;height:9px;border-radius:50%;
  background:radial-gradient(circle at 32% 30%,#9CC4FF,#2C7BF2);
  box-shadow:0 0 10px rgba(63,160,255,.8);
}

/* ===================================================================
   6 · PRICING — 3 glassy cards, middle strongest
   =================================================================== */
.price-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:26px;
  align-items:start;position:relative;z-index:1;
}
.price-card{
  padding:38px 32px 36px;
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease),
             border-color .35s var(--ease);
}
.price-card:hover{transform:translateY(-8px);
  border-color:rgba(63,160,255,.42);
  box-shadow:0 36px 80px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.2)}
.price-featured{
  background:
    radial-gradient(420px 340px at 50% -10%, rgba(108,92,231,.45), transparent 70%),
    linear-gradient(165deg,rgba(63,160,255,.22),rgba(108,92,231,.14));
  border:1.5px solid rgba(126,150,255,.5);
  box-shadow:0 36px 84px rgba(0,0,0,.6),
             inset 0 1px 0 rgba(255,255,255,.26),
             0 0 60px rgba(63,160,255,.3);
  padding-top:58px;
}
@media(min-width:1025px){
  .price-featured{transform:scale(1.05)}
  .price-featured:hover{transform:scale(1.05) translateY(-8px)}
}
.feat-glow{
  position:absolute;width:340px;height:340px;left:50%;top:-40%;
  transform:translateX(-50%);
  background:radial-gradient(circle,rgba(63,160,255,.45),transparent 65%);
  filter:blur(40px);pointer-events:none;
}
.price-flag{
  position:absolute;top:18px;left:50%;transform:translateX(-50%);
  font-family:var(--display);font-weight:700;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;color:#fff;white-space:nowrap;
  padding:8px 18px;border-radius:100px;
  background:linear-gradient(135deg,#3FA0FF,#6C5CE7);
  box-shadow:0 10px 24px rgba(44,123,242,.5);z-index:2;
}
.price-name{font-size:1.36rem;color:#fff;position:relative;z-index:1}
.price-best{margin-top:8px;font-size:.9rem;color:var(--ink-mute);
  min-height:42px;position:relative;z-index:1}
.price-amount{
  margin:18px 0;font-family:var(--display);font-weight:800;
  font-size:3.1rem;color:#fff;line-height:1;letter-spacing:-.03em;
  position:relative;z-index:1;
}
.pa-currency{
  font-size:1.5rem;vertical-align:super;margin-right:2px;
  background:linear-gradient(135deg,var(--azure),var(--violet));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.price-feats{
  display:flex;flex-direction:column;gap:12px;margin-bottom:28px;flex:1;
  padding-top:22px;border-top:1px solid var(--line);position:relative;z-index:1;
}
.price-feats li{
  position:relative;padding-left:30px;font-size:.95rem;color:var(--ink-soft);
}
.price-feats li::before{
  content:"";position:absolute;left:0;top:1px;width:20px;height:20px;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(63,160,255,.3),rgba(108,92,231,.25));
  border:1px solid rgba(255,255,255,.2);
}
.price-feats li::after{
  content:"";position:absolute;left:7px;top:5px;
  width:6px;height:10px;border:solid var(--azure);
  border-width:0 2px 2px 0;transform:rotate(45deg);
}
.price-card .btn{position:relative;z-index:1}

/* ===================================================================
   7 · FAQ — glass accordion
   =================================================================== */
.faq-shell{max-width:840px}
.faq-stack{display:flex;flex-direction:column;gap:16px}
.faq-item{transition:border-color .25s var(--ease)}
.faq-item:hover{border-color:rgba(63,160,255,.34)}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  gap:20px;padding:24px 28px;text-align:left;
  font-family:var(--display);font-weight:600;font-size:1.07rem;color:#fff;
}
.faq-icon{position:relative;width:22px;height:22px;flex:none;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(63,160,255,.3),rgba(108,92,231,.25));
  border:1px solid rgba(255,255,255,.22);
}
.faq-icon::before,.faq-icon::after{
  content:"";position:absolute;background:var(--azure);border-radius:2px;
  transition:transform .3s var(--ease)}
.faq-icon::before{left:5px;top:10px;width:12px;height:2.2px}
.faq-icon::after{left:10px;top:5px;width:2.2px;height:12px}
.faq-q[aria-expanded="true"] .faq-icon::after{transform:scaleY(0)}
.faq-q[aria-expanded="true"] .faq-icon{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding:0 28px 26px;color:var(--ink-soft);font-size:1rem}

/* ===================================================================
   8 · CTA — full mesh bloom
   =================================================================== */
.cta{padding:128px 0;overflow:hidden}
.cta-mesh .blob{opacity:.85}
.cta-mesh .blob-1{left:6%;top:-40%}
.cta-mesh .blob-2{right:0;top:-20%}
.cta-mesh .blob-3{left:38%;bottom:-50%}
.cta-inner{
  position:relative;z-index:2;max-width:760px;margin:0 auto;text-align:center;
}
.cta-title{
  font-size:clamp(2rem,4vw,3.1rem);font-weight:800;letter-spacing:-.032em;
  background:linear-gradient(180deg,#FFFFFF 40%,#AFC8FF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-body{
  margin:18px auto 30px;max-width:580px;
  color:var(--ink-soft);font-size:1.1rem;
}

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{
  background:linear-gradient(180deg,var(--bg),#070912);
  border-top:1px solid var(--line);
  padding:66px 0 30px;
}
.footer-grid{
  display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:44px;border-bottom:1px solid var(--line);
}
.footer-brand .brand-name{color:#fff}
.footer-tag{margin-top:14px;font-size:.94rem;color:var(--ink-mute);max-width:280px}
.footer-col h4{
  font-family:var(--display);font-weight:600;font-size:.78rem;
  letter-spacing:.13em;text-transform:uppercase;color:#fff;margin-bottom:16px;
}
.footer-col a{
  display:block;font-size:.95rem;color:var(--ink-mute);padding:5px 0;
  transition:color .2s var(--ease);
}
.footer-col a:hover{color:var(--azure)}
.footer-bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  padding-top:24px;font-size:.86rem;color:var(--ink-mute);
}

/* ===================================================================
   MOTION — reveal
   =================================================================== */
.reveal{opacity:0;transform:translateY(30px);
  transition:opacity .75s var(--ease), transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(max-width:1024px){
  .section{padding:92px 0}
  .hero{padding:108px 0 110px}
  .solution-panel,.guarantee-panel{padding:48px 42px}
  .solution-segments{gap:34px}
  .guarantee-panel{gap:36px}

  /* system → vertical timeline from tablet down */
  .arc-svg{display:none}
  .arc-steps{
    grid-template-columns:1fr;gap:16px;
    max-width:600px;margin:0 auto;
  }
  .as-1,.as-2,.as-3,.as-4,.as-5{margin-top:0}
  .arc-step{
    flex-direction:row;align-items:flex-start;text-align:left;gap:18px;
    padding:20px 22px;
    background:linear-gradient(165deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
    border:1px solid var(--line-2);border-radius:var(--radius);
    -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  }
  .arc-node{margin-bottom:0}

  /* pricing → single centered column on tablet */
  .price-grid{
    grid-template-columns:1fr;gap:24px;
    max-width:480px;margin:0 auto;
  }
  .price-featured{order:-1}
}

@media(max-width:768px){
  .shell{padding:0 22px}
  .section{padding:78px 0}
  .nav-toggle{display:flex}
  .primary-nav{
    position:fixed;inset:80px 0 auto 0;
    flex-direction:column;align-items:stretch;gap:4px;
    background:rgba(11,13,20,.97);
    -webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);
    padding:20px 22px 28px;border-bottom:1px solid var(--line);
    box-shadow:0 20px 50px rgba(0,0,0,.6);
    transform:translateY(-135%);transition:transform .42s var(--ease);
  }
  .primary-nav.open{transform:translateY(0)}
  .primary-nav>a:not(.btn){padding:14px 12px;font-size:1.04rem;border-radius:12px}
  .nav-cta{margin:8px 0 0;padding:15px}

  .hero{padding:84px 0 96px}
  .orb-a{width:70px;height:70px;left:4%;top:14%}
  .orb-b{width:48px;height:48px;right:5%;top:12%}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%}

  .problem-grid{grid-template-columns:1fr;gap:20px}

  .solution-segments{grid-template-columns:1fr;gap:30px}
  .seg-split{width:100%;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent)}

  .guarantee-panel{grid-template-columns:1fr;gap:28px;padding:42px 28px}

  .footer-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .footer-brand .brand{justify-content:center}
  .footer-tag{margin-left:auto;margin-right:auto}
  .footer-bottom{flex-direction:column;align-items:center;text-align:center}
}

@media(max-width:520px){
  .shell{padding:0 16px}
  .header-inner{height:70px}
  .primary-nav{inset:70px 0 auto 0}
  .hero{padding:64px 0 80px}
  .hero-title{font-size:clamp(1.75rem,7.2vw,2.7rem)}
  .section-title{font-size:clamp(1.45rem,5.8vw,2rem)}
  .pain-card,.solution-panel,.price-card{padding-left:24px;padding-right:24px}
  .price-amount{font-size:2.7rem}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important;
  }
  .reveal{opacity:1;transform:none}
  .orb-a,.orb-b{animation:none}
}
