/* =========================================================
   APPO FINANCE v3 — "Appo OS"
   Dark · glass · animated aurora · bento · vibrant accents
   ========================================================= */

:root {
  --bg:        #06070f;
  --bg-2:      #0a0c18;
  --panel:     rgba(255,255,255,0.035);
  --panel-2:   rgba(255,255,255,0.06);
  --glass-bd:  rgba(255,255,255,0.09);
  --glass-bd2: rgba(255,255,255,0.16);

  --white: #ffffff;
  --text:  #eef1fb;
  --muted: #97a0c0;
  --muted-2: #606a8c;

  /* AI mode (default) */
  --a1: #7c5cff;   /* violet */
  --a2: #c45cff;   /* magenta */
  --a1-rgb: 124,92,255;
  --a2-rgb: 196,92,255;

  --accent: var(--a1);
  --accent-2: var(--a2);
  --accent-rgb: var(--a1-rgb);
  --accent-2-rgb: var(--a2-rgb);

  --wa: #22c55e;
  --maxw: 1220px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --font-display: 'Space Grotesk', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --font-body: 'Plus Jakarta Sans', sans-serif;
}

body[data-mode="fin"] {
  --accent: #16d0e6;       /* electric cyan */
  --accent-2: #2b8fff;     /* electric blue */
  --accent-rgb: 22,208,230;
  --accent-2-rgb: 43,143,255;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
::selection { background: var(--accent); color: #05060d; }
a { color: inherit; text-decoration: none; }

/* ---------------- animated aurora background ---------------- */
.aurora { position: fixed; inset: -20%; z-index: 0; pointer-events: none; filter: blur(64px); opacity: 1; }
.aurora .blob { position: absolute; border-radius: 50%; mix-blend-mode: screen; opacity: .72; transition: background 1s var(--ease); will-change: transform; }
.aurora .b1 { width: 48vw; height: 48vw; left: 2%; top: -8%;  background: radial-gradient(circle, rgba(var(--accent-rgb),1), transparent 60%); animation: drift1 22s ease-in-out infinite; }
.aurora .b2 { width: 44vw; height: 44vw; right: -6%; top: 2%;  background: radial-gradient(circle, rgba(var(--accent-2-rgb),.95), transparent 60%); animation: drift2 26s ease-in-out infinite; }
.aurora .b3 { width: 52vw; height: 52vw; left: 22%; top: 34%; background: radial-gradient(circle, rgba(var(--accent-rgb),.7), transparent 62%); animation: drift3 30s ease-in-out infinite; }
@keyframes drift1 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(8vw,10vh) scale(1.15)} }
@keyframes drift2 { 0%,100%{transform:translate(0,0) scale(1.1)} 50%{transform:translate(-10vw,8vh) scale(.9)} }
@keyframes drift3 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-6vw,-10vh) scale(1.2)} }

.noise { position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: .035; mix-blend-mode: overlay;
  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='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.vignette { position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(ellipse 95% 85% at 50% 28%, transparent 46%, rgba(3,4,10,.62) 100%); }

/* ---------------- layout helpers ---------------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; position: relative; z-index: 3; }
section { position: relative; z-index: 3; }

.eyebrow { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--accent); display: inline-flex; align-items: center; gap: 11px; }
.eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--accent); }

.grad-text { background: linear-gradient(100deg, var(--accent), var(--accent-2)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ---------------- NAV ---------------- */
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 200; display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px; transition: background .4s var(--ease), border-color .4s, padding .4s var(--ease); border-bottom: 1px solid transparent; }
nav.scrolled { background: rgba(6,7,15,.7); backdrop-filter: blur(20px); border-bottom: 1px solid var(--glass-bd); padding: 12px 28px; }
.logo { font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; letter-spacing: -.02em; color: var(--white); display: flex; align-items: center; }
.logo b { color: var(--accent); }
.logo .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); margin-left: 6px; box-shadow: 0 0 14px var(--accent); }

.mode-toggle { display: flex; gap: 3px; border: 1px solid var(--glass-bd2); border-radius: 100px; padding: 4px; background: rgba(255,255,255,.04); backdrop-filter: blur(10px); position: relative; }
.mode-toggle .glider { position: absolute; top: 4px; bottom: 4px; width: calc(50% - 4px); border-radius: 100px; background: linear-gradient(100deg, var(--accent), var(--accent-2)); box-shadow: 0 4px 20px rgba(var(--accent-rgb),.5); transition: transform .45s var(--ease), background .5s; z-index: 0; }
body[data-mode="fin"] .mode-toggle .glider { transform: translateX(100%); }
.mode-btn { position: relative; z-index: 1; flex: 1; border: none; background: none; font-family: var(--font-mono); font-size: .73rem; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); padding: 9px 20px; border-radius: 100px; cursor: pointer; white-space: nowrap; transition: color .35s; }
.mode-btn.active { color: #05060d; font-weight: 700; }

.nav-right { display: flex; align-items: center; gap: 14px; }
.btn-wa { display: inline-flex; align-items: center; gap: 8px; background: var(--wa); color: #04130a; padding: 10px 18px; border-radius: 100px; font-weight: 700; font-size: .84rem; transition: transform .25s var(--ease), box-shadow .25s; }
.btn-wa:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(34,197,94,.4); }
.btn-wa svg { width: 16px; height: 16px; fill: #04130a; }

/* ---------------- buttons ---------------- */
.btn-primary { display: inline-flex; align-items: center; gap: 10px; background: linear-gradient(100deg, var(--accent), var(--accent-2)); color: #05060d; padding: 15px 26px; border-radius: 100px; font-weight: 700; font-size: .95rem; white-space: nowrap; transition: transform .25s var(--ease), box-shadow .3s; box-shadow: 0 10px 34px rgba(var(--accent-rgb),.35); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 46px rgba(var(--accent-rgb),.5); }
.btn-ghost { display: inline-flex; align-items: center; gap: 10px; padding: 15px 24px; border-radius: 100px; border: 1px solid var(--glass-bd2); color: var(--text); font-weight: 600; font-size: .95rem; white-space: nowrap; background: rgba(255,255,255,.03); transition: border-color .3s, color .3s, background .3s; }
.btn-ghost:hover { border-color: var(--accent); color: var(--white); background: rgba(var(--accent-rgb),.1); }

/* ---------------- glass primitive ---------------- */
.glass { background: var(--panel); border: 1px solid var(--glass-bd); border-radius: 20px; backdrop-filter: blur(14px); position: relative; overflow: hidden; }
.glass::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent); }

/* ---------------- HERO (bento) ---------------- */
.hero { min-height: 100vh; display: flex; align-items: center; padding: 124px 0 60px; }
.hero-bento { display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: minmax(0, auto); gap: 16px; width: 100%; }

.cell { border-radius: 20px; position: relative; overflow: hidden; }
.cell-hero { grid-column: span 7; padding: 8px 8px; display: flex; flex-direction: column; justify-content: center; }
.cell-hero .eyebrow { margin-bottom: 22px; }
.hero h1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.5rem, 5.4vw, 4.3rem); line-height: .98; letter-spacing: -.03em; color: var(--white); }
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .line > span { display: block; transform: translateY(110%); transition: transform .85s var(--ease); }
.mode-pane.show h1 .line > span { transform: translateY(0); }
.mode-pane.show h1 .line:nth-child(2) > span { transition-delay: .06s; }
.mode-pane.show h1 .line:nth-child(3) > span { transition-delay: .12s; }
.hero-sub { font-size: 1.08rem; line-height: 1.7; color: var(--muted); max-width: 480px; margin: 24px 0 30px; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }

/* hero side viz cells */
.cell-viz { grid-column: span 5; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 16px; }
.vz { padding: 22px; }
.vz .vh { font-family: var(--font-mono); font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 14px; display: flex; align-items: center; justify-content: space-between; }
.vz .live { color: var(--accent); display: inline-flex; align-items: center; gap: 6px; }
.vz .live::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent); animation: blink 1.6s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }
.vz-big { grid-column: span 2; }
.vz .num { font-family: var(--font-display); font-weight: 700; font-size: 2.3rem; letter-spacing: -.02em; color: var(--white); line-height: 1; }
.vz .sub { font-size: .8rem; color: var(--muted); margin-top: 6px; }
.eq { display: flex; align-items: flex-end; gap: 5px; height: 56px; margin-top: 14px; }
.eq span { flex: 1; background: linear-gradient(180deg, var(--accent), rgba(var(--accent-rgb),.15)); border-radius: 3px; animation: eq 1.3s ease-in-out infinite; transform-origin: bottom; }
.eq span:nth-child(2){animation-delay:.15s} .eq span:nth-child(3){animation-delay:.3s} .eq span:nth-child(4){animation-delay:.45s} .eq span:nth-child(5){animation-delay:.6s} .eq span:nth-child(6){animation-delay:.75s} .eq span:nth-child(7){animation-delay:.9s}
@keyframes eq { 0%,100%{transform:scaleY(.4)} 50%{transform:scaleY(1)} }
.ring { width: 74px; height: 74px; border-radius: 50%; background: conic-gradient(var(--accent), var(--accent-2), var(--accent)); -webkit-mask: radial-gradient(circle, transparent 56%, #000 57%); mask: radial-gradient(circle, transparent 56%, #000 57%); animation: spin 4.5s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.ring-wrap { display: flex; align-items: center; gap: 14px; }
.ring-wrap .rl .n { font-family: var(--font-display); font-weight: 700; font-size: 1.5rem; color: var(--white); line-height: 1; }
.ring-wrap .rl .t { font-size: .76rem; color: var(--muted); margin-top: 4px; }
.vz-tags { display: flex; flex-wrap: wrap; gap: 7px; align-content: center; }
.vz-tags span { font-family: var(--font-mono); font-size: .68rem; color: var(--text); border: 1px solid var(--glass-bd2); padding: 6px 11px; border-radius: 100px; background: rgba(255,255,255,.03); }

/* hero stat strip */
.cell-strip { grid-column: span 12; }
.cell-strip .glass { display: flex; }
.cell-strip .st { flex: 1; padding: 22px 26px; border-right: 1px solid var(--glass-bd); }
.cell-strip .st:last-child { border-right: none; }
.cell-strip .st .v { font-family: var(--font-display); font-weight: 700; font-size: 1.9rem; color: var(--white); letter-spacing: -.02em; }
.cell-strip .st .v .grad-text { font-size: inherit; }
.cell-strip .st .l { font-size: .82rem; color: var(--muted); margin-top: 5px; }

/* ---------------- marquee ---------------- */
.marquee { border-top: 1px solid var(--glass-bd); border-bottom: 1px solid var(--glass-bd); overflow: hidden; padding: 16px 0; white-space: nowrap; background: rgba(255,255,255,.012); }
.marquee-track { display: inline-flex; gap: 42px; animation: scroll-x 32s linear infinite; font-family: var(--font-display); font-size: 1.4rem; font-weight: 500; }
.marquee-track span { color: var(--muted-2); display: inline-flex; align-items: center; gap: 42px; }
.marquee-track span::after { content: '✳'; color: var(--accent); font-size: .85rem; }
@keyframes scroll-x { to { transform: translateX(-50%); } }

/* ---------------- section header ---------------- */
.sec { padding: 100px 0; }
.sec-head { max-width: 740px; margin-bottom: 48px; }
.sec-head h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(2rem, 4vw, 3.1rem); line-height: 1.05; letter-spacing: -.025em; color: var(--white); margin: 16px 0 16px; }
.sec-head p { color: var(--muted); font-size: 1.06rem; line-height: 1.7; }

/* ---------------- bento solutions ---------------- */
.bento { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.bcard { border: 1px solid var(--glass-bd); border-radius: 20px; background: var(--panel); backdrop-filter: blur(12px); padding: 28px; position: relative; overflow: hidden; transition: transform .4s var(--ease), border-color .4s, background .4s; display: flex; flex-direction: column; }
.bcard::after { content: ''; position: absolute; inset: 0; border-radius: 20px; padding: 1px; background: linear-gradient(120deg, transparent 30%, rgba(var(--accent-rgb),.5), transparent 70%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0; transition: opacity .4s; }
.bcard:hover { transform: translateY(-5px); background: var(--panel-2); border-color: var(--glass-bd2); }
.bcard:hover::after { opacity: 1; }
.bcard .num { font-family: var(--font-mono); font-size: .7rem; color: var(--muted-2); letter-spacing: .1em; margin-bottom: 20px; }
.bcard .ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 16px; color: var(--accent); background: rgba(var(--accent-rgb),.1); border: 1px solid rgba(var(--accent-rgb),.2); }
.bcard .ico svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 1.6; }
.bcard h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.16rem; color: var(--white); margin-bottom: 9px; line-height: 1.2; }
.bcard p { color: var(--muted); font-size: .92rem; line-height: 1.6; }
/* spans */
.b-2 { grid-column: span 2; }
.b-3 { grid-column: span 3; }
.b-4 { grid-column: span 4; }
.b-6 { grid-column: span 6; }
/* feature bento with built-in viz */
.bcard.feat { background: linear-gradient(150deg, rgba(var(--accent-rgb),.16), rgba(var(--accent-2-rgb),.06)); border-color: rgba(var(--accent-rgb),.3); }
.bcard .spark { display: flex; align-items: flex-end; gap: 6px; height: 64px; margin-top: auto; padding-top: 18px; }
.bcard .spark span { flex: 1; background: linear-gradient(180deg, var(--accent), rgba(var(--accent-rgb),.1)); border-radius: 4px; }
.bcard .flow { display: flex; align-items: center; gap: 10px; margin-top: auto; padding-top: 18px; flex-wrap: wrap; }
.bcard .node { font-family: var(--font-mono); font-size: .7rem; color: var(--text); padding: 7px 12px; border-radius: 8px; background: rgba(255,255,255,.05); border: 1px solid var(--glass-bd); }
.bcard .arrow { color: var(--accent); }
.bcard .big-stat { font-family: var(--font-display); font-weight: 700; font-size: 3rem; letter-spacing: -.03em; line-height: 1; margin-top: auto; }

/* ---------------- stats band ---------------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat-box { border: 1px solid var(--glass-bd); border-radius: 18px; background: var(--panel); backdrop-filter: blur(10px); padding: 32px 28px; transition: border-color .4s, transform .4s var(--ease); }
.stat-box:hover { border-color: var(--glass-bd2); transform: translateY(-4px); }
.stat-box .val { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.2rem,4vw,3rem); color: var(--white); line-height: 1; letter-spacing: -.02em; }
.stat-box .lbl { color: var(--muted); font-size: .9rem; margin-top: 12px; line-height: 1.5; }

/* ---------------- steps ---------------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; counter-reset: s; }
.step { border: 1px solid var(--glass-bd); border-radius: 18px; padding: 32px 28px; background: var(--panel); backdrop-filter: blur(10px); position: relative; transition: border-color .4s, transform .4s var(--ease); }
.step:hover { border-color: var(--glass-bd2); transform: translateY(-4px); }
.step .step-n { font-family: var(--font-mono); font-size: .8rem; color: var(--accent); letter-spacing: .15em; margin-bottom: 18px; }
.step h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.25rem; color: var(--white); margin-bottom: 11px; }
.step p { color: var(--muted); line-height: 1.65; font-size: .95rem; }

/* ---------------- plans ---------------- */
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; align-items: stretch; }
.plan { border: 1px solid var(--glass-bd); border-radius: 20px; padding: 34px 30px; background: var(--panel); backdrop-filter: blur(12px); display: flex; flex-direction: column; transition: border-color .4s, transform .4s var(--ease); }
.plan:hover { transform: translateY(-6px); border-color: var(--glass-bd2); }
.plan.feat { border-color: rgba(var(--accent-rgb),.4); background: linear-gradient(160deg, rgba(var(--accent-rgb),.12), var(--panel)); box-shadow: 0 30px 70px -40px rgba(var(--accent-rgb),.6); }
.plan-tag { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; display: flex; justify-content: space-between; align-items: center; }
.plan-tag .pop { background: linear-gradient(100deg,var(--accent),var(--accent-2)); color: #05060d; font-weight: 700; padding: 4px 11px; border-radius: 100px; letter-spacing: .06em; }
.plan h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.55rem; color: var(--white); margin-bottom: 10px; }
.plan .desc { color: var(--muted); font-size: .92rem; line-height: 1.6; margin-bottom: 24px; }
.plan ul { list-style: none; margin-bottom: 28px; flex-grow: 1; }
.plan li { padding: 11px 0; font-size: .92rem; color: var(--text); border-bottom: 1px solid var(--glass-bd); display: flex; gap: 11px; align-items: flex-start; }
.plan li:last-child { border-bottom: none; }
.plan li svg { width: 15px; height: 15px; stroke: var(--accent); fill: none; stroke-width: 2.6; flex-shrink: 0; margin-top: 4px; }
.plan-cta { display: block; text-align: center; padding: 14px; border-radius: 100px; font-weight: 700; font-size: .95rem; border: 1px solid var(--glass-bd2); color: var(--white); transition: background .3s, color .3s, border-color .3s; }
.plan-cta:hover { background: var(--white); color: #05060d; border-color: var(--white); }
.plan.feat .plan-cta { background: linear-gradient(100deg,var(--accent),var(--accent-2)); color: #05060d; border: none; }
.plan.feat .plan-cta:hover { box-shadow: 0 10px 30px rgba(var(--accent-rgb),.5); }

/* ---------------- band / why ---------------- */
.band { border: 1px solid var(--glass-bd); border-radius: 24px; padding: 52px; background: radial-gradient(ellipse 60% 100% at 88% 0%, rgba(var(--accent-rgb),.14), transparent 70%), var(--panel); backdrop-filter: blur(12px); display: grid; grid-template-columns: 1.1fr .9fr; gap: 44px; align-items: center; }
.band h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.7rem,3.2vw,2.5rem); line-height: 1.1; color: var(--white); margin: 16px 0; letter-spacing: -.02em; }
.band p { color: var(--muted); font-size: 1.04rem; line-height: 1.7; margin-bottom: 26px; }
.band-feats { display: flex; flex-direction: column; gap: 12px; }
.band-feat { display: flex; gap: 16px; align-items: flex-start; padding: 18px 20px; border: 1px solid var(--glass-bd); border-radius: 14px; background: rgba(255,255,255,.03); transition: border-color .3s, transform .3s; }
.band-feat:hover { border-color: var(--accent); transform: translateX(4px); }
.band-feat .bf-ico { color: var(--accent); flex-shrink: 0; }
.band-feat .bf-ico svg { width: 24px; height: 24px; stroke: currentColor; fill: none; stroke-width: 1.6; }
.band-feat strong { display: block; color: var(--white); font-size: 1rem; margin-bottom: 3px; font-family: var(--font-display); }
.band-feat span { color: var(--muted); font-size: .88rem; line-height: 1.5; }
.tech { display: flex; flex-wrap: wrap; gap: 9px; }
.tech span { font-family: var(--font-mono); font-size: .8rem; color: var(--text); border: 1px solid var(--glass-bd2); padding: 8px 14px; border-radius: 100px; background: rgba(255,255,255,.03); transition: border-color .3s, color .3s, background .3s; }
.tech span:hover { border-color: var(--accent); color: var(--accent); background: rgba(var(--accent-rgb),.1); }

/* ---------------- team ---------------- */
.team { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.member { display: flex; gap: 22px; align-items: center; padding: 26px; border: 1px solid var(--glass-bd); border-radius: 18px; background: var(--panel); backdrop-filter: blur(10px); transition: border-color .3s, transform .3s var(--ease); }
.member:hover { border-color: var(--glass-bd2); transform: translateY(-4px); }
.member-photo { width: 100px; height: 112px; border-radius: 14px; overflow: hidden; flex-shrink: 0; background: rgba(var(--accent-rgb),.1); border: 1px solid var(--glass-bd); }
.member-photo img { width: 100%; height: 100%; object-fit: cover; }
.member-body h3 { font-family: var(--font-display); font-weight: 600; color: var(--white); font-size: 1.16rem; margin-bottom: 5px; }
.member-role { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--accent); display: block; margin-bottom: 12px; }
.member-body p { color: var(--muted); font-size: .9rem; line-height: 1.6; }

/* ---------------- CTA ---------------- */
.cta { text-align: center; padding: 116px 0; }
.cta-inner { border: 1px solid var(--glass-bd); border-radius: 28px; padding: 80px 40px; background: radial-gradient(ellipse 70% 120% at 50% 0%, rgba(var(--accent-rgb),.18), transparent 70%), var(--panel); backdrop-filter: blur(14px); position: relative; overflow: hidden; }
.cta h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.3rem, 5.2vw, 4.2rem); line-height: 1.02; letter-spacing: -.03em; color: var(--white); margin: 20px 0; }
.cta .tagline { color: var(--accent); font-family: var(--font-mono); font-size: .92rem; letter-spacing: .04em; margin-bottom: 36px; }
.cta-contacts { display: flex; justify-content: center; flex-wrap: wrap; gap: 14px 32px; margin-top: 42px; }
.cta-contact { color: var(--muted); font-size: .9rem; display: inline-flex; align-items: center; gap: 9px; }
.cta-contact svg { width: 16px; height: 16px; stroke: var(--accent); fill: none; stroke-width: 1.7; }
.cta-contact b { color: var(--text); font-weight: 600; }

/* ---------------- footer ---------------- */
footer { border-top: 1px solid var(--glass-bd); padding: 36px 0; position: relative; z-index: 3; }
footer .wrap { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
footer p { color: var(--muted-2); font-size: .82rem; }

/* ---------------- floating whatsapp ---------------- */
.float-wa { position: fixed; bottom: 24px; right: 24px; width: 56px; height: 56px; border-radius: 50%; background: var(--wa); display: grid; place-items: center; z-index: 300; box-shadow: 0 10px 30px rgba(34,197,94,.45); transition: transform .3s var(--ease); }
.float-wa:hover { transform: scale(1.08); }
.float-wa svg { width: 27px; height: 27px; fill: #04130a; }

/* ---------------- panes + reveal ---------------- */
.mode-pane { display: none; }
.mode-pane.active { display: block; }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .75s var(--ease), transform .75s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .07s; } .reveal.d2 { transition-delay: .14s; } .reveal.d3 { transition-delay: .21s; } .reveal.d4 { transition-delay: .28s; } .reveal.d5 { transition-delay: .35s; }

/* ---------------- responsive ---------------- */
@media (max-width: 1080px) {
  .cell-hero { grid-column: span 12; }
  .cell-viz { grid-column: span 12; }
  .bento { grid-template-columns: repeat(4, 1fr); }
  .b-3 { grid-column: span 2; } .b-4 { grid-column: span 4; } .b-2 { grid-column: span 2; }
  .band { grid-template-columns: 1fr; gap: 32px; padding: 38px; }
  .team { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .wrap { padding: 0 18px; }
  nav { padding: 12px 16px; }
  .cell-viz { grid-template-columns: 1fr 1fr; }
  .cell-strip { grid-column: span 12; }
  .cell-strip .glass { flex-wrap: wrap; }
  .cell-strip .st { flex: 1 1 50%; border-bottom: 1px solid var(--glass-bd); }
  .bento { grid-template-columns: 1fr; }
  .b-2, .b-3, .b-4, .b-6 { grid-column: span 1; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: 1fr; }
  .plans { grid-template-columns: 1fr; }
  .member { flex-direction: column; align-items: flex-start; }
  .mode-btn { padding: 8px 13px; font-size: .66rem; }
  .btn-wa span { display: none; } .btn-wa { padding: 10px; }
}
