/* ═══════════════════════════════════════════════
   ZIVIRO — CSS Design System v3
   Redesigned sections: editorial, asymmetric, motion
   ═══════════════════════════════════════════════ */

/* ── Variables ────────────────────────────── */
:root {
  --gradient-color-1: #7A2038;
  --gradient-color-2: #C4566A;
  --gradient-color-3: #4A1528;
  --gradient-color-4: #A8445C;

  --accent: #7A2048;
  --accent-hover: #8E2854;
  --accent-light: rgba(122,32,72,.08);
  --accent-border: rgba(122,32,72,.15);
  --accent-glow: rgba(122,32,72,.25);

  --navy: #142244;
  --navy-light: rgba(20,34,68,.08);
  --navy-border: rgba(20,34,68,.15);
  --navy-hover: #1A2E5A;

  --dark-bg: #0E1628;
  --dark-bg-2: #121A30;
  --dark-surface: rgba(255,255,255,.05);
  --dark-border: rgba(255,255,255,.08);

  --text-1: #0A0A0A;
  --text-2: #525252;
  --text-3: #8A8A8A;
  --text-4: #B8B8B8;

  --bg: #F8F6F2;
  --bg-alt: #F2F0EB;
  --border: #E8E8E8;
  --border-light: #F2F2F2;

  --font-d: 'Ranade', sans-serif;
  --font-b: 'Instrument Sans', sans-serif;

  --ease: cubic-bezier(.25,1,.5,1);
  --ease-out: cubic-bezier(.2,1,.2,1);

  --max-w: 1200px;
  --nav-h: 68px;
}

/* ── Reset ────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:var(--font-b);font-size:17px;line-height:1.6;color:var(--text-2);background:var(--bg);overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;border:none;background:none;cursor:pointer}
ul,ol{list-style:none}

/* ── Typography ───────────────────────────── */
h1,h2,h3{font-family:var(--font-d);font-weight:300;color:var(--text-1);letter-spacing:-.02em;line-height:1.08;text-wrap:pretty}
h1{font-size:clamp(40px,5vw,64px);letter-spacing:-.03em}
h2{font-size:clamp(32px,3.5vw,48px)}
h3{font-size:clamp(22px,2vw,28px)}
.text-muted{color:var(--text-3)}
.section-dark .text-muted{color:rgba(255,255,255,.4)}

/* ── Layout ───────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 32px;width:100%}
.section{padding:140px 0}
.section-dark{background:var(--dark-bg);color:rgba(255,255,255,.75)}

/* ── Logo Gradient Animation ─────────────── */
.nav-logo{background:linear-gradient(135deg,var(--text-1) 0%,var(--accent) 50%,var(--text-1) 100%) !important;background-size:200% 200% !important;-webkit-background-clip:text !important;background-clip:text !important;-webkit-text-fill-color:transparent !important;animation:logoGradient 4s ease-in-out infinite}
@keyframes logoGradient{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ── Grain Texture Overlay ───────────────── */
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:0.028;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}

/* ── Wireframe Grid (Stripe-style) ────────── */
.wireframe-grid{position:fixed;top:0;bottom:0;left:50%;transform:translateX(-50%);width:1200px;max-width:calc(100% - 64px);pointer-events:none;z-index:99;border-left:1px solid rgba(0,0,0,.07);border-right:1px solid rgba(0,0,0,.07)}
.section,.hero,.site-nav,.hero-int{border-bottom:1px solid rgba(0,0,0,.07)}
.section-dark,.section-dark.section,.article-cta-dark,.keep-reading{border-bottom-color:rgba(255,255,255,.07)}

/* ── Ambient Paths System ─────────────── */
.ambient-paths{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.ambient-paths svg{position:absolute;width:100%;height:100%}
.ambient-line{fill:none;stroke-width:1;opacity:0;animation:pathDraw 4s cubic-bezier(.25,1,.5,1) forwards,pathFloat 8s ease-in-out infinite}
@keyframes pathDraw{0%{opacity:0;stroke-dasharray:0 1200}50%{opacity:1}100%{opacity:1;stroke-dasharray:1200 0}}
@keyframes pathFloat{0%,100%{transform:translateY(0) translateX(0)}25%{transform:translateY(-6px) translateX(3px)}50%{transform:translateY(-3px) translateX(-5px)}75%{transform:translateY(-8px) translateX(2px)}}
.ambient-glow{position:absolute;border-radius:50%;pointer-events:none;animation:glowPulse 6s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.08)}}
.article-cta-dark .ambient-line:nth-child(1){stroke:rgba(122,32,72,.3);animation-delay:0s,0s}
.article-cta-dark .ambient-line:nth-child(2){stroke:rgba(122,32,72,.2);animation-delay:.5s,.5s}
.article-cta-dark .ambient-line:nth-child(3){stroke:rgba(122,32,72,.15);animation-delay:1s,1s}
.article-cta-dark .ambient-line:nth-child(4){stroke:rgba(255,255,255,.04);animation-delay:1.5s,1.5s}
.article-cta-dark .ambient-line:nth-child(5){stroke:rgba(122,32,72,.1);animation-delay:2s,2s}
.article-cta-dark .ambient-glow{width:500px;height:500px;background:radial-gradient(circle,rgba(122,32,72,.15) 0%,transparent 70%);top:-150px;right:-80px}
.section-dark h1,.section-dark h2,.section-dark h3{color:#FFF}

/* ── Buttons ──────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-b);font-weight:600;font-size:15px;padding:12px 28px;border-radius:6px;transition:transform .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);will-change:transform;cursor:pointer}
.btn svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-accent{background:var(--accent);color:#FFF;border:1px solid transparent}
.btn-accent:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}
.btn-outline{background:transparent;color:var(--text-1);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--text-3);transform:translateY(-1px)}
.btn-lg{padding:16px 36px;font-size:16px;border-radius:8px}
.btn-ghost{background:transparent;color:var(--accent);padding:12px 0;border:none}
.btn-ghost:hover{opacity:.7}
.section-dark .btn-outline{color:#FFF;border-color:rgba(255,255,255,.2)}
.section-dark .btn-outline:hover{border-color:rgba(255,255,255,.5)}
.section-dark .btn-accent{background:var(--accent);color:#FFF}
.section-dark .btn-accent:hover{background:var(--accent-hover)}

/* ═══════════════════════════════════════════
   NAVIGATION
   ═══════════════════════════════════════════ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);display:flex;align-items:center;background:rgba(248,246,242,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background .3s var(--ease),box-shadow .3s var(--ease)}
.site-nav.scrolled{box-shadow:0 1px 0 var(--border)}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 32px;width:100%;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--font-d);font-weight:600;font-size:22px;color:var(--text-1);letter-spacing:-.01em}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-link{position:relative;font-size:14px;font-weight:500;color:var(--text-2);padding:10px 16px;border-radius:6px;transition:color .3s var(--ease),background .3s var(--ease)}
.nav-link::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--accent);border-radius:2px;transition:width .35s var(--ease),box-shadow .35s var(--ease);box-shadow:none}
.nav-link:hover::after,.nav-link.active::after{width:24px;box-shadow:0 0 12px var(--accent-glow),0 0 4px var(--accent)}
.nav-link:hover{color:var(--text-1);background:var(--navy-light)}
.nav-actions{display:flex;align-items:center;gap:16px}
.nav-phone{font-size:14px;font-weight:500;color:var(--text-3);transition:color .3s var(--ease)}
.nav-phone:hover{color:var(--accent)}
.nav-cta{font-size:14px;font-weight:600;padding:8px 20px;border-radius:20px;background:var(--navy);color:#FFF;transition:all .3s var(--ease)}
.nav-cta:hover{transform:translateY(-1px);background:var(--navy-hover)}

/* Mega Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.dropdown-chevron{display:inline-block;transition:transform .3s var(--ease);margin-top:1px}
.nav-dropdown.open .dropdown-chevron{transform:rotate(180deg)}
.nav-mega{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:8px;width:580px;box-shadow:0 20px 60px rgba(0,0,0,.10),0 1px 3px rgba(0,0,0,.06);opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);z-index:200}
.nav-dropdown.open .nav-mega{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.mega-col{padding:16px 12px}
.mega-col:first-child{border-right:1px solid var(--border-light)}
.mega-label{font-family:var(--font-b);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-4);padding:0 12px;margin-bottom:10px}
.mega-item{display:block;padding:10px 12px;border-radius:8px;transition:background .2s var(--ease)}
.mega-item:hover{background:var(--bg-alt)}
.mega-name{display:block;font-size:14px;font-weight:500;color:var(--text-1);line-height:1.3;margin-bottom:2px}
.mega-desc{display:block;font-size:12px;color:var(--text-3);line-height:1.4}

/* ═══════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--bg);padding:calc(var(--nav-h) + 40px) 0 100px}
.hero-canvas-wrap{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
#hero-webgl{width:100%;height:100%;display:block}
#hero-webgl canvas{display:block;width:100%!important;height:100%!important}
.hero-inner{position:relative;z-index:10;max-width:var(--max-w);margin:0 auto;padding:0 32px;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.hero-text{pointer-events:none}
.hero-text h1{color:var(--text-1);margin-bottom:24px}
.hero-text h1 .text-muted{color:var(--text-3)}
.hero-label{font-family:var(--font-b);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:24px}
.hero-sub{font-size:18px;line-height:1.65;color:var(--text-2);max-width:520px;margin-bottom:40px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;pointer-events:auto}
.hero .btn-accent{background:var(--accent);color:#FFF}
.hero .btn-accent:hover{background:var(--accent-hover);box-shadow:0 4px 24px var(--accent-glow)}
.hero .btn-outline{color:var(--text-1);border-color:rgba(122,32,72,.25)}
.hero .btn-outline:hover{border-color:rgba(122,32,72,.5);background:rgba(122,32,72,.04)}
/* Hero integrations carousel — anchored to bottom of hero */
.hero-integrations{position:absolute;bottom:0;left:0;right:0;z-index:10;border-top:1px solid var(--border-light);background:rgba(248,246,242,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero-int-inner{max-width:var(--max-w);margin:0 auto;padding:20px 32px}
.hero-int-label{font-family:var(--font-b);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-4);margin-bottom:14px}
.hero-int-carousel{overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent)}
.hero-int-track{display:flex;align-items:center;gap:48px;width:max-content;animation:hero-int-scroll 35s linear infinite}
.hero-int-logo{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;color:#94a3b8;opacity:.7;transition:opacity .3s var(--ease);white-space:nowrap;font-family:var(--font-b);font-size:14px;font-weight:600;letter-spacing:-.01em}
.hero-int-logo svg{flex-shrink:0;display:block}
.hero-int-logo:hover{opacity:1}
.hero-int-logo--wordmark{font-weight:800;font-size:15px;letter-spacing:-.02em;color:#94a3b8}
.hero-int-logo--stripe{font-size:0}
.hero-int-logo--stripe svg{color:#94a3b8}
@keyframes hero-int-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.hero-proof{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-3);margin-top:32px;pointer-events:auto}
.hero-proof-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.8}
.hero-proof a{color:var(--text-2);font-weight:500;transition:color .3s var(--ease)}
.hero-proof a:hover{color:var(--text-1)}

/* 3D Floating Objects (hidden by default, shown via JS) */
.hero-floaters{display:none}
.float-obj{position:absolute;transform-style:preserve-3d;will-change:transform;width:var(--s);height:var(--s)}
.float-obj-inner{width:var(--s);height:var(--s);transform-style:preserve-3d;position:relative}
.obj-face{position:absolute;width:var(--s);height:var(--s);border-radius:6px;display:flex;align-items:center;justify-content:center}
.obj-face svg{width:50%;height:50%;opacity:.9}
.obj-face.f-fr{transform:translateZ(calc(var(--s)/2));background:var(--sh-front)}
.obj-face.f-bk{transform:translateZ(calc(var(--s)/-2)) rotateY(180deg);background:var(--sh-back)}
.obj-face.f-rt{transform:translateX(calc(var(--s)/2)) rotateY(90deg);background:var(--sh-right)}
.obj-face.f-lt{transform:translateX(calc(var(--s)/-2)) rotateY(-90deg);background:var(--sh-left)}
.obj-face.f-tp{transform:translateY(calc(var(--s)/-2)) rotateX(90deg);background:var(--sh-top)}
.obj-face.f-bt{transform:translateY(calc(var(--s)/2)) rotateX(-90deg);background:var(--sh-bottom)}
.fo-phone{--s:56px;top:20%;left:7%;--sh-front:oklch(42% .13 350);--sh-right:oklch(36% .10 350);--sh-top:oklch(40% .12 350);--sh-left:oklch(28% .07 350);--sh-back:oklch(22% .05 350);--sh-bottom:oklch(24% .06 350)}
.fo-calendar{--s:48px;top:15%;right:18%;--sh-front:oklch(44% .11 350);--sh-right:oklch(37% .09 350);--sh-top:oklch(41% .10 350);--sh-left:oklch(29% .06 350);--sh-back:oklch(23% .04 350);--sh-bottom:oklch(25% .05 350)}
.fo-message{--s:44px;bottom:28%;left:14%;--sh-front:oklch(40% .14 350);--sh-right:oklch(34% .11 350);--sh-top:oklch(38% .13 350);--sh-left:oklch(26% .08 350);--sh-back:oklch(20% .05 350);--sh-bottom:oklch(22% .06 350)}
.fo-check{--s:40px;bottom:20%;right:10%;--sh-front:oklch(46% .12 350);--sh-right:oklch(39% .10 350);--sh-top:oklch(43% .11 350);--sh-left:oklch(30% .07 350);--sh-back:oklch(24% .05 350);--sh-bottom:oklch(26% .06 350)}

/* ═══════════════════════════════════════════
   2. INTEGRATIONS STRIP
   Scrolling logo carousel with SVG icons
   ═══════════════════════════════════════════ */
/* (integrations moved into hero)

/* ═══════════════════════════════════════════
   3. PROBLEM — Editorial Ledger
   Left-aligned, horizontal rows, no cards/icons
   ═══════════════════════════════════════════ */
.pain-section{padding:120px 0 100px}
.pain-headline{margin-bottom:80px;max-width:640px}
.pain-ledger{display:flex;flex-direction:column}
.pain-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:32px 0;border-top:1px solid var(--border);align-items:baseline}
.pain-row:last-child{border-bottom:1px solid var(--border)}
.pain-title{font-family:var(--font-d);font-weight:400;font-size:clamp(20px,2.2vw,26px);color:var(--text-1);letter-spacing:-.01em;line-height:1.25}
.pain-desc{font-size:16px;color:var(--text-3);line-height:1.55}
.pain-row:hover .pain-title{color:var(--accent)}
.pain-row .pain-title{transition:color .4s var(--ease)}

/* ═══════════════════════════════════════════
   4. HEAR IT LIVE
   ═══════════════════════════════════════════ */
.live-inner{text-align:center;max-width:700px;margin:0 auto}
.live-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.5);margin-bottom:20px}
.live-inner h2{margin-bottom:20px}
.live-inner p{font-size:18px;color:rgba(255,255,255,.5);margin-bottom:48px}
.live-number{font-family:var(--font-d);font-weight:300;font-size:clamp(36px,5vw,56px);color:#FFF;letter-spacing:.02em;display:inline-block;border-bottom:2px solid rgba(255,255,255,.15);padding-bottom:8px;transition:all .4s var(--ease)}
.live-number:hover{border-color:var(--accent);color:var(--accent)}

/* ═══════════════════════════════════════════
   5. SOLUTION CARDS — Staggered Layout
   Wide → Pair (offset) → Wide
   ═══════════════════════════════════════════ */
.sol-section{padding:140px 0;background:var(--bg)}
.sol-header{max-width:560px;margin-bottom:80px}
.sol-eyebrow{font-family:var(--font-b);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.sol-header h2{margin-bottom:16px}
.sol-header h2 em{font-style:italic;color:var(--accent)}
.sol-sub{font-size:17px;color:var(--text-3);line-height:1.6}

.sol-stack{display:flex;flex-direction:column;gap:24px}
.sol-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px}

.sol-card{border:1px solid var(--border);border-radius:16px;padding:0;position:relative;overflow:hidden;will-change:transform;transform-style:preserve-3d;background:var(--bg);transition:box-shadow .5s var(--ease)}
.sol-card::after{content:'';position:absolute;inset:0;border-radius:16px;background:radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%),rgba(122,32,72,.04) 0%,transparent 60%);pointer-events:none;opacity:0;transition:opacity .4s var(--ease)}
.sol-card:hover::after{opacity:1}
.sol-card:hover{box-shadow:0 24px 80px rgba(0,0,0,.07)}
.sol-card-inner{padding:40px 44px}
.sol-card h3{font-family:var(--font-d);font-weight:400;font-size:clamp(22px,2.4vw,30px);color:var(--text-1);letter-spacing:-.01em;line-height:1.2;margin-bottom:16px}
.sol-card > .sol-card-inner > p{font-size:16px;color:var(--text-3);line-height:1.65;margin-bottom:24px}
.sol-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.sol-tag{font-family:var(--font-b);font-size:13px;font-weight:500;padding:5px 14px;border-radius:20px;border:1px solid var(--accent-border);color:var(--accent);background:var(--accent-light)}
.sol-link{font-family:var(--font-b);font-size:14px;font-weight:600;color:var(--accent);transition:opacity .3s var(--ease)}
.sol-link:hover{opacity:.6}

/* Featured cards get a left accent bar */
.sol-featured{display:grid;grid-template-columns:1fr 4px}
.sol-card-accent{background:linear-gradient(180deg,var(--accent) 0%,rgba(122,32,72,.2) 100%);border-radius:0 16px 16px 0}
.sol-featured .sol-card-inner{padding-right:40px}

/* Offset the second card in the pair */
.sol-lifted{transform:translateY(32px)}

/* Card variations */
.sol-card-warm{background:var(--bg-alt);border-color:var(--border-light)}
.sol-tag-navy{background:var(--navy-light);color:var(--navy);border-color:var(--navy-border)}
.sol-tag-muted{background:var(--bg-alt);color:var(--text-2);border-color:var(--border)}

/* Pain row hover */
.pain-row{transition:padding-left .4s var(--ease)}
.pain-row:hover{padding-left:12px}

/* Accordion smooth open/close */
.accordion-body{transition:max-height .45s var(--ease)}
.accordion-trigger{transition:color .3s var(--ease),padding-left .3s var(--ease)}
.accordion-item.open .accordion-trigger{padding-left:8px;color:var(--accent)}

/* Process dot hover */
.proc-dot{transition:background .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease)}
.proc-step:hover .proc-dot{background:var(--accent);transform:scale(1.4);box-shadow:0 0 0 4px var(--accent-light)}

/* Trust block hover */
.trust-block{transition:background .3s var(--ease)}
.trust-block:hover{background:var(--dark-bg-2)}

/* Live number pulse */
.live-number{position:relative}
.live-number::before{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.live-number:hover::before{transform:scaleX(1)}

/* ═══════════════════════════════════════════
   6. ACCORDION — Split Layout
   Sticky header left, accordion right
   ═══════════════════════════════════════════ */
.acc-section{padding:140px 0}
.acc-layout{display:grid;grid-template-columns:340px 1fr;gap:80px;align-items:start}
.acc-sticky{position:sticky;top:calc(var(--nav-h) + 48px)}
.acc-sticky h2{margin-bottom:16px}
.acc-sticky p{font-size:16px;color:var(--text-3);line-height:1.6}

.accordion-item{border-bottom:1px solid var(--border)}
.accordion-item:first-child{border-top:1px solid var(--border)}
.accordion-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:24px 0;cursor:pointer;text-align:left;transition:color .3s var(--ease)}
.accordion-trigger:hover{color:var(--accent)}
.accordion-trigger h3{font-family:var(--font-b);font-size:17px;font-weight:500;color:inherit;letter-spacing:0;line-height:1.4}
.accordion-icon{width:28px;height:28px;position:relative;flex-shrink:0}
.accordion-icon::before,.accordion-icon::after{content:'';position:absolute;background:var(--text-3);border-radius:1px;transition:transform .35s var(--ease)}
.accordion-icon::before{width:14px;height:1.5px;top:50%;left:50%;transform:translate(-50%,-50%)}
.accordion-icon::after{width:1.5px;height:14px;top:50%;left:50%;transform:translate(-50%,-50%)}
.accordion-item.open .accordion-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.accordion-body-inner{padding:0 0 24px;color:var(--text-3);font-size:15px;line-height:1.65;max-width:540px}

/* ═══════════════════════════════════════════
   7. PROCESS — Vertical Timeline
   Left line + dots, content right
   ═══════════════════════════════════════════ */
.proc-section{padding:140px 0;background:var(--bg)}
.proc-layout{max-width:640px;margin:0 auto}
.proc-timeline{display:flex;flex-direction:column;gap:0}
.proc-step{display:grid;grid-template-columns:48px 1fr;gap:24px;position:relative}
.proc-marker{display:flex;flex-direction:column;align-items:center}
.proc-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--accent);background:var(--bg);flex-shrink:0;position:relative;z-index:2;transition:background .3s var(--ease),transform .3s var(--ease)}
.proc-step:hover .proc-dot{background:var(--accent);transform:scale(1.3)}
.proc-line{width:2px;flex:1;background:var(--border);margin-top:4px}
.proc-step:last-child .proc-line{display:none}
.proc-content{padding-bottom:56px}
.proc-step:last-child .proc-content{padding-bottom:0}
.proc-label{font-family:var(--font-b);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:block}
.proc-content h3{font-family:var(--font-d);font-weight:400;font-size:clamp(24px,2.5vw,32px);color:var(--text-1);letter-spacing:-.01em;margin-bottom:10px;line-height:1.15}
.proc-content p{font-size:16px;color:var(--text-3);line-height:1.6}

/* ═══════════════════════════════════════════
   8. TRUST STRIP + FINAL CTA
   Combined dark section
   ═══════════════════════════════════════════ */
/* Trust blocks — asymmetric, no container */
.trust-blocks{display:flex;gap:48px;flex-wrap:wrap;margin-bottom:100px;align-items:flex-start}
.trust-block{flex:1;min-width:180px}
.trust-block:first-child{flex:1.4}
.trust-block:first-child .trust-headline{font-size:22px}
.trust-headline{font-family:var(--font-d)!important;font-weight:300!important;font-style:italic!important;letter-spacing:-.01em!important}
.trust-headline{font-family:var(--font-b);font-size:16px;font-weight:600;color:#FFF;margin-bottom:6px}
.trust-detail{font-size:14px;color:rgba(255,255,255,.35);line-height:1.5}

/* Final CTA — split layout */
.final-cta-split{display:grid;grid-template-columns:1fr auto;gap:80px;align-items:start}
.cta-left h2{margin-bottom:20px}
.cta-left p{font-size:18px;color:rgba(255,255,255,.5);max-width:480px}
.cta-right{display:flex;flex-direction:column;gap:16px;align-items:flex-start;padding-top:8px}
.cta-number{font-family:var(--font-d);font-size:20px;font-weight:300;color:rgba(255,255,255,.4);letter-spacing:.02em;margin-top:8px}
.cta-number a{color:rgba(255,255,255,.6);border-bottom:1px solid rgba(255,255,255,.15);transition:color .3s var(--ease),border-color .3s var(--ease)}
.cta-number a:hover{color:#FFF;border-color:var(--accent)}

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
/* Full footer — light background */
.site-footer-full{background:var(--bg-alt);color:var(--text-2);padding:32px 0 24px;border-top:1px solid var(--border)}
.footer-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding-bottom:20px;border-bottom:1px solid var(--border);margin-bottom:16px}
.footer-bar-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.footer-bar-left .footer-logo{font-family:var(--font-d);font-weight:600;font-size:20px;color:var(--text-1)}
.footer-bar-sep{font-size:13px;color:var(--text-3)}
.footer-bar-sep a{color:var(--text-2);transition:color .3s var(--ease)}
.footer-bar-sep a:hover{color:var(--accent)}
.footer-bar-right{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-bar-right a{font-size:13px;color:var(--text-3);transition:color .3s var(--ease)}
.footer-bar-right a:hover{color:var(--text-1)}
.footer-copy{font-size:13px;color:var(--text-4)}
.footer-sms-row{text-align:center}
.footer-sms{font-size:11px;color:var(--text-4);line-height:1.6;max-width:900px;margin:0 auto}
.footer-sms a{color:var(--text-3);text-decoration:underline}
.footer-sms a:hover{color:var(--text-1)}
.site-footer-full{position:relative;overflow:hidden}
.footer-watermark{font-family:var(--font-d);font-weight:200;font-size:clamp(100px,14vw,180px);color:var(--border);letter-spacing:-.04em;line-height:1;text-align:center;pointer-events:none;user-select:none;margin-top:-20px;padding-bottom:8px;opacity:.6}

/* ═══════════════════════════════════════════
   TWEAKS PANEL
   ═══════════════════════════════════════════ */
.tweaks-toggle{position:fixed;bottom:24px;right:24px;z-index:200;width:44px;height:44px;border-radius:12px;background:var(--dark-bg);color:#FFF;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(0,0,0,.25);transition:transform .3s var(--ease)}
.tweaks-toggle:hover{transform:scale(1.08)}
.tweaks-toggle svg{width:20px;height:20px}
.tweaks-drawer{position:fixed;bottom:80px;right:24px;z-index:200;background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:20px;width:220px;box-shadow:0 16px 48px rgba(0,0,0,.12);opacity:0;transform:translateY(8px) scale(.96);pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.tweaks-drawer.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.tweaks-title{font-family:var(--font-b);font-weight:600;font-size:14px;color:var(--text-1);margin-bottom:16px}
.tweaks-label{font-size:12px;color:var(--text-3);margin-bottom:8px}
.tweaks-swatches{display:flex;gap:10px}
.tweak-swatch{width:36px;height:36px;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:all .2s var(--ease)}
.tweak-swatch:hover{transform:scale(1.1)}
.tweak-swatch.active{border-color:var(--text-1);box-shadow:0 0 0 2px #FFF,0 0 0 4px var(--text-1)}

/* ═══════════════════════════════════════════
   SCROLL REVEAL — Progressive Enhancement
   Content visible by default. JS adds .js-reveal
   to body, which hides elements until scrolled.
   ═══════════════════════════════════════════ */
.reveal{opacity:1;transform:none}

/* ═══════════════════════════════════════════
   REDUCED MOTION
   ═══════════════════════════════════════════ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .float-obj{display:none}
  .scroll-indicator{animation:none;opacity:.3}
  .hero-int-track{animation:none;flex-wrap:wrap;justify-content:center;gap:16px}
  .hero-integrations{position:static;backdrop-filter:none;-webkit-backdrop-filter:none;background:transparent;border:none}
  .trust-blocks{grid-template-columns:1fr 1fr;gap:32px}
  .final-cta-split{grid-template-columns:1fr;gap:40px}
  .footer-bar{flex-direction:column;align-items:flex-start}
  .footer-bar-right{gap:12px}
  #hero-canvas{display:none}
  .hero{background:linear-gradient(135deg,var(--gradient-color-3),var(--gradient-color-1),var(--gradient-color-4))}
}

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media(max-width:900px){
  .acc-layout{grid-template-columns:1fr;gap:48px}
  .acc-sticky{position:static}
  .sol-pair{grid-template-columns:1fr}
  .sol-lifted{transform:none}
  .sol-featured{grid-template-columns:1fr}
  .sol-card-accent{display:none}
}
@media(max-width:768px){
  .hero-inner{text-align:center;align-items:center}
  .hero-sub{margin:0 auto 40px}
  .hero-ctas{justify-content:center}
  .hero-proof{justify-content:center}
  .hero-canvas-wrap{opacity:.3}
  .pain-row{grid-template-columns:1fr;gap:8px}
  .pain-headline{max-width:100%}
  .trust-strip{flex-direction:column;gap:12px}
  .trust-dot{display:none}
  .nav-phone{display:none}
  .footer-inner{flex-direction:column;gap:16px;text-align:center}
}
@media(max-width:600px){
  .section{padding:80px 0}
  .sol-section,.acc-section,.proc-section{padding:80px 0}
  .pain-section{padding:80px 0 60px}
  .container{padding:0 20px}
  h1{font-size:36px}h2{font-size:28px}
  .hero{padding-top:calc(var(--nav-h) + 20px)}
  .hero-ctas{flex-direction:column;align-items:center}
  .btn-lg{width:100%}
  .sol-card-inner{padding:28px}
  .proc-content{padding-bottom:40px}
}

/* ═══════════════════════════════════════════
   MOBILE HAMBURGER
   ═══════════════════════════════════════════ */
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;cursor:pointer;z-index:101}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-1);border-radius:2px;transition:transform .3s var(--ease),opacity .3s var(--ease)}
@media(max-width:768px){
  .nav-hamburger{display:flex}
  .nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;background:rgba(248,246,242,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:16px 32px 24px;border-bottom:1px solid var(--border);box-shadow:0 8px 32px rgba(0,0,0,.06)}
  .nav-links .nav-link{padding:12px 0;font-size:16px}
  .nav-links .nav-link::after{display:none}
  body.nav-open .nav-links{display:flex}
  body.nav-open .nav-hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .nav-hamburger span:nth-child(2){opacity:0}
  body.nav-open .nav-hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
