/* ================================================================
   PANDIA — Modern Landing inspired by AbacatePay
   Bento grid + dark hero + premium light sections
   ================================================================ */

:root {
  /* Backgrounds */
  --bg:      #faf8f4;
  --bg2:     #f3f0ea;
  --bg3:     #eceae3;
  /* Pandia navy (azul marinho da marca) */
  --dark:    #0f172a;
  --dark2:   #1e293b;
  --dark3:   #334155;

  /* Brand — Pandia official orange palette */
  --orange:      #f59e0b;   /* --orange-500 */
  --orange-dark: #ea8a08;   /* --orange-600 (hover) */
  --orange-darker: #d97706; /* --orange-700 */
  --amber:       #fbbf24;   /* highlight light */
  --blue:    #1d4ed8;
  --blue2:   #1e40af;
  --grad:    linear-gradient(135deg, #f59e0b 0%, #ea580c 100%);   /* Pandia canonical gradient (avatares/logos) */
  --grad-blue: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
  --grad-text: linear-gradient(90deg, #d97706 0%, #ea580c 100%);
  --grad-red:  linear-gradient(90deg, #ef4444 0%, #dc2626 100%);

  /* Text */
  --t1:  #18160f;
  --t2:  #5a554b;
  --t3:  #9c9487;
  --t1d: #faf6ee;
  --t2d: rgba(250,246,238,.65);
  --t3d: rgba(250,246,238,.35);

  /* Borders */
  --border:  #e0dbd0;
  --border2: #c8c1b2;
  --borderd: rgba(255,255,255,.08);

  /* Misc */
  --r:   12px;
  --rl:  16px;
  --rxl: 22px;
  --rxxl: 28px;
  --s1:  0 1px 3px rgba(0,0,0,.06), 0 6px 18px rgba(0,0,0,.07);
  --s2:  0 2px 6px rgba(0,0,0,.06), 0 16px 40px rgba(0,0,0,.1);
  --s3:  0 4px 12px rgba(0,0,0,.07), 0 28px 64px rgba(0,0,0,.14);
}

/* ============================================================
   RESET + BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  background: var(--bg);
  color: var(--t1);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img  { max-width: 100%; display: block; }
a    { text-decoration: none; color: inherit; }
ul   { list-style: none; }
button { cursor: pointer; font-family: inherit; background: none; border: none; }

/* Grain overlay */
body::after {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 9999;
}

.container    { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.container-sm { max-width: 760px;  margin: 0 auto; padding: 0 24px; }

/* ============================================================
   TYPOGRAPHY HELPERS
   ============================================================ */
.grad { background: var(--grad-text); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.grad-blue { background: var(--grad-blue); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.grad-red { background: var(--grad-red); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

.sec-label {
  display: inline-block;
  font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--orange);
  background: rgba(245,158,11,.08); border: 1px solid rgba(245,158,11,.18);
  padding: 4px 13px; border-radius: 50px; margin-bottom: 14px;
}
.sec-label.dark {
  color: var(--amber); background: rgba(245,158,11,.12); border-color: rgba(245,158,11,.25);
}
.sec-label.red {
  color: #dc2626; background: rgba(239,68,68,.08); border-color: rgba(239,68,68,.18);
}
.sec-title {
  font-size: clamp(1.85rem, 3.2vw, 2.85rem);
  font-weight: 800; line-height: 1.1; letter-spacing: -.035em;
  color: var(--t1); margin-bottom: 14px;
}
.sec-title.dark { color: var(--t1d); }
.sec-desc  { font-size: 1rem; color: var(--t2); line-height: 1.75; max-width: 520px; }
.sec-desc.dark { color: var(--t2d); }
.sec-desc.center { margin: 0 auto; text-align: center; }
.section-header { text-align: center; margin-bottom: 56px; }

/* ============================================================
   BADGE (live pill, AbacatePay style with NEW tag)
   ============================================================ */
.badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(250,246,238,.06); border: 1px solid rgba(245,158,11,.25);
  color: var(--t1d); font-size: .82rem; font-weight: 600;
  padding: 5px 14px 5px 5px; border-radius: 50px;
  position: relative; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  transition: all .25s;
}
.badge:hover { border-color: rgba(245,158,11,.45); transform: translateY(-1px); }
.badge.dark { background: rgba(245,158,11,.12); border-color: rgba(245,158,11,.28); color: var(--amber); padding:6px 14px; }
.badge-tag {
  background: var(--grad); color: #fff;
  font-size: .65rem; font-weight: 800; letter-spacing: .08em;
  padding: 4px 9px; border-radius: 50px;
}
.badge-text { color: var(--t1d); }
.badge svg { color: var(--amber); transition: transform .25s; }
.badge:hover svg { transform: translateX(3px); }
.badge::before {
  content: ''; position: absolute; inset: -4px; border-radius: 50px;
  background: var(--grad); opacity: 0;
  filter: blur(10px);
  animation: badge-glow 3s ease-in-out infinite;
}
@keyframes badge-glow { 0%,100%{opacity:.06} 50%{opacity:.18} }
.dot { width: 6px; height: 6px; background: currentColor; border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.65)} }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--grad); color: #fff;
  font-weight: 700; font-size: .9375rem;
  padding: 14px 28px; border-radius: 12px; border: none;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 4px 20px rgba(234,88,12,.3);
  white-space: nowrap; position: relative; overflow: hidden;
}
.btn-primary::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%);
  transform: translateX(-100%); transition: transform .5s;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(234,88,12,.42); }
.btn-primary:hover::after { transform: translateX(100%); }
.btn-primary.lg { font-size: 1.0625rem; padding: 16px 34px; border-radius: 14px; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 9px;
  background: rgba(255,255,255,.07); border: 1.5px solid rgba(255,255,255,.18);
  color: var(--t1d); font-weight: 600; font-size: .9375rem;
  padding: 13px 24px; border-radius: 12px; transition: all .2s; white-space: nowrap;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.btn-ghost:hover { background: rgba(255,255,255,.13); border-color: rgba(255,255,255,.3); transform: translateY(-1px); }
.btn-ghost.light {
  background: var(--bg); border-color: var(--border2);
  color: var(--t1);
}
.btn-ghost.light:hover { background: var(--bg2); border-color: var(--t3); }
.btn-ghost.full, .btn-primary.full { width: 100%; justify-content: center; }

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  padding: 0 24px; transition: background .35s, box-shadow .35s, backdrop-filter .35s;
  background: rgba(15,23,42,.78);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
}
.nav.scrolled {
  background: rgba(250,248,244,.95);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 1px 0 var(--border);
}
.nav-inner { height: 70px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }

.nav-logo { position: relative; height: 44px; width: 120px; }
.nav-logo-img {
  position: absolute; top: 0; left: 0; height: 44px; width: auto;
  transition: opacity .3s ease;
}
.logo-white { opacity: 1; pointer-events: none; }
.logo-color { opacity: 0; pointer-events: none; }
.nav.scrolled .logo-white { opacity: 0; }
.nav.scrolled .logo-color { opacity: 1; }
.nav-logo:hover .logo-white { opacity: 0; }
.nav-logo:hover .logo-color { opacity: 1; }

.nav-links { display: flex; align-items: center; gap: 2px; }
.nav-links a {
  font-size: .875rem; font-weight: 500;
  color: rgba(255,255,255,.75); padding: 7px 13px; border-radius: 8px; transition: all .15s;
}
.nav-links a:hover { color: #fff; background: rgba(255,255,255,.08); }
.nav.scrolled .nav-links a { color: var(--t2); }
.nav.scrolled .nav-links a:hover { color: var(--t1); background: var(--bg2); }

.nav-cta { display: flex; align-items: center; gap: 10px; }
.nav-login {
  font-size: .875rem; font-weight: 600; color: rgba(255,255,255,.7);
  padding: 8px 14px; border-radius: 8px; transition: color .15s;
}
.nav-login:hover { color: #fff; }
.nav.scrolled .nav-login { color: var(--t2); }
.nav.scrolled .nav-login:hover { color: var(--t1); }
.btn-nav {
  font-size: .875rem; font-weight: 700; background: var(--grad); color: #fff;
  padding: 9px 20px; border-radius: 10px; transition: all .2s;
  box-shadow: 0 2px 12px rgba(234,88,12,.25);
  white-space: nowrap;
}
.btn-nav:hover { transform: translateY(-1px); box-shadow: 0 4px 20px rgba(234,88,12,.4); }
.btn-nav.full { width: 100%; justify-content: center; display: flex; align-items: center; gap: 6px; }

/* Mobile burger */
.nav-burger {
  display: none; width: 32px; height: 32px;
  flex-direction: column; justify-content: center; gap: 5px;
  align-items: flex-end; padding: 0;
}
.nav-burger span {
  width: 22px; height: 2px; background: rgba(255,255,255,.85);
  border-radius: 2px; transition: all .3s;
}
.nav-burger span:nth-child(2) { width: 16px; }
.nav.scrolled .nav-burger span { background: var(--t1); }
.nav-burger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.active span:nth-child(2) { opacity: 0; }
.nav-burger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); width: 22px; }

.nav-mobile {
  position: fixed; top: 70px; left: 0; right: 0;
  background: rgba(15,23,42,.97);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 24px;
  display: none; flex-direction: column; gap: 4px;
  transform: translateY(-10px); opacity: 0; transition: all .25s;
  pointer-events: none;
}
.nav-mobile.open { display: flex; opacity: 1; transform: translateY(0); pointer-events: auto; }
.nav-mobile a {
  color: rgba(255,255,255,.85); font-weight: 500; font-size: .95rem;
  padding: 12px 14px; border-radius: 10px;
}
.nav-mobile a:hover { background: rgba(255,255,255,.06); color: #fff; }
.nav-mobile-divider { height: 1px; background: rgba(255,255,255,.08); margin: 8px 0; }
.nav-mobile-login { color: rgba(255,255,255,.7) !important; }
.nav.scrolled .nav-mobile {
  background: rgba(250,248,244,.97);
  border-bottom-color: var(--border);
}
.nav.scrolled .nav-mobile a { color: var(--t2); }
.nav.scrolled .nav-mobile a:hover { background: var(--bg2); color: var(--t1); }

/* ============================================================
   HERO — DARK
   ============================================================ */
.hero {
  background: var(--dark);
  padding: 140px 0 100px;
  position: relative; overflow: hidden;
  min-height: 100vh; display: flex; align-items: center;
}
.hero::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 30% 40%, rgba(245,158,11,.13) 0%, transparent 60%),
    radial-gradient(ellipse 40% 45% at 80% 30%, rgba(234,88,12,.09) 0%, transparent 55%),
    radial-gradient(ellipse 80% 30% at 50% 100%, rgba(245,158,11,.05) 0%, transparent 60%);
  pointer-events: none;
}
.hero::after {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 0%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, black 0%, transparent 100%);
}
.hero-orb { position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; z-index: 0; }
.orb-1 {
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(245,158,11,.2) 0%, transparent 70%);
  top: -150px; left: -100px;
  animation: orb1 11s ease-in-out infinite;
}
.orb-2 {
  width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(234,88,12,.13) 0%, transparent 70%);
  top: 80px; right: -80px;
  animation: orb2 14s ease-in-out infinite;
}
.orb-3 {
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(30,64,175,.1) 0%, transparent 70%);
  bottom: -60px; left: 45%;
  animation: orb3 9s ease-in-out infinite;
}
@keyframes orb1 {
  0%,100% { transform: translate(0,0) scale(1); }
  40%      { transform: translate(50px,-40px) scale(1.12); }
  70%      { transform: translate(-30px,25px) scale(.92); }
}
@keyframes orb2 {
  0%,100% { transform: translate(0,0) scale(1); }
  35%      { transform: translate(-60px,35px) scale(1.1); }
  70%      { transform: translate(40px,-50px) scale(.9); }
}
@keyframes orb3 {
  0%,100% { transform: translate(0,0) scale(1); }
  50%      { transform: translate(25px,45px) scale(1.15); }
}

.hero-particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.particle {
  position: absolute; border-radius: 50%; opacity: 0;
  animation: particle-rise linear infinite;
}
@keyframes particle-rise {
  0%   { opacity: 0; transform: translateY(0) scale(0); }
  12%  { opacity: .7; transform: translateY(-15px) scale(1); }
  85%  { opacity: .25; }
  100% { opacity: 0; transform: translateY(-200px) scale(.3); }
}
.particle:nth-child(1) { width:3px;height:3px;background:#f59e0b;left:7%;top:72%;animation-duration:7s;animation-delay:0s; }
.particle:nth-child(2) { width:5px;height:5px;background:#ea580c;left:17%;top:80%;animation-duration:9s;animation-delay:1.3s; }
.particle:nth-child(3) { width:3px;height:3px;background:#fbbf24;left:29%;top:68%;animation-duration:8s;animation-delay:2.6s; }
.particle:nth-child(4) { width:4px;height:4px;background:#f59e0b;left:43%;top:78%;animation-duration:10s;animation-delay:0.7s; }
.particle:nth-child(5) { width:3px;height:3px;background:#ea580c;left:57%;top:85%;animation-duration:7.5s;animation-delay:3.1s; }
.particle:nth-child(6) { width:5px;height:5px;background:#fbbf24;left:71%;top:72%;animation-duration:11s;animation-delay:1.8s; }
.particle:nth-child(7) { width:3px;height:3px;background:#f59e0b;left:83%;top:77%;animation-duration:8.5s;animation-delay:4.2s; }
.particle:nth-child(8) { width:4px;height:4px;background:#ea580c;left:92%;top:63%;animation-duration:9.5s;animation-delay:0.4s; }

.hero > .container { position: relative; z-index: 1; width: 100%; }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.hero-content { max-width: 580px; }
.hero-title {
  font-size: clamp(2.4rem, 4.8vw, 3.85rem);
  font-weight: 800; line-height: 1.04; letter-spacing: -.045em;
  color: var(--t1d); margin: 22px 0 22px;
}
.hero-desc { font-size: 1.125rem; color: var(--t2d); line-height: 1.75; margin-bottom: 36px; max-width: 520px; }
.hero-btns { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

/* Hero trust line */
.hero-trust { display: flex; align-items: center; gap: 14px; margin-top: 32px; }
.hero-trust-avs { display: flex; }
.hta {
  width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--dark);
  display: flex; align-items: center; justify-content: center;
  font-size: .65rem; font-weight: 700; color: #fff;
  margin-left: -8px;
}
.hta:first-child { margin-left: 0; }
.hero-trust-text { display: flex; flex-direction: column; gap: 2px; }
.hero-trust-stars { color: var(--amber); font-size: .82rem; letter-spacing: 1px; }
.hero-trust-stars strong { color: var(--t1d); margin-left: 4px; letter-spacing: 0; }
.hero-trust-label { font-size: .76rem; color: var(--t3d); }

/* ============================================================
   MOCKUP
   ============================================================ */
.hero-visual { position: relative; }
.mockup {
  border-radius: 20px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 8px 24px rgba(0,0,0,.4), 0 40px 80px rgba(0,0,0,.35);
  animation: float 7s ease-in-out infinite; background: #fff;
}
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.mockup-bar { background: #f5f4f2; padding: 10px 14px; display: flex; align-items: center; gap: 7px; border-bottom: 1px solid var(--border); }
.mbar-dot { width: 10px; height: 10px; border-radius: 50%; }
.mbar-url { flex:1; text-align:center; font-size:.68rem; color:var(--t3); background:#fff; border:1px solid var(--border); border-radius:6px; padding:3px 10px; }
.mockup-body { display: flex; height: 380px; }
.mside { width:170px;min-width:170px;border-right:1px solid var(--border);padding:8px 0;background:#faf9f7;display:flex;flex-direction:column; }
.mside-brand { display:flex;align-items:center;gap:7px;padding:8px 14px 12px;font-size:.8rem;font-weight:800;color:var(--t1);border-bottom:1px solid var(--border);margin-bottom:8px; }
.mside-brand-ico { width:22px;height:22px;border-radius:6px;background:var(--grad);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.mside-item { display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:.72rem;color:var(--t3);margin:1px 6px;border-radius:7px;font-weight:500;position:relative; }
.mside-item.active { background:rgba(245,158,11,.08);color:var(--orange);font-weight:700; }
.mside-badge { margin-left:auto;background:var(--grad);color:#fff;font-size:.55rem;font-weight:800;padding:1px 6px;border-radius:8px; }
.mchat { flex:1;display:flex;flex-direction:column;background:#fff; }
.mchat-header { padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px; }
.mav { width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:#fff;flex-shrink:0; }
.mname { font-size:.72rem;font-weight:700;color:var(--t1); }
.mphone { font-size:.62rem;color:var(--t3); }
.mpill { margin-left:auto;font-size:.6rem;font-weight:700;background:rgba(245,158,11,.1);color:var(--orange);padding:2px 8px;border-radius:10px;white-space:nowrap; }
.mchat-msgs { flex:1;padding:12px;display:flex;flex-direction:column;gap:8px;overflow:hidden;background:#faf9f7; }
.mmsg { max-width:72%;padding:7px 11px;border-radius:12px;font-size:.7rem;line-height:1.45;animation:msg-in .4s ease both; }
.mmsg.in { background:#fff;color:var(--t1);align-self:flex-start;border:1px solid var(--border);border-bottom-left-radius:3px;box-shadow:0 1px 2px rgba(0,0,0,.04); }
.mmsg.out { background:var(--grad);color:#fff;align-self:flex-end;border-bottom-right-radius:3px;box-shadow:0 2px 8px rgba(234,88,12,.22); }
@keyframes msg-in { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:none} }
.mtyping { display:inline-flex;gap:3px;align-self:flex-start;background:#fff;border:1px solid var(--border);padding:8px 12px;border-radius:12px;border-bottom-left-radius:3px; }
.mtyping span { width:5px;height:5px;background:var(--t3);border-radius:50%;animation:typingdot 1.4s infinite both; }
.mtyping span:nth-child(2) { animation-delay:.2s; }
.mtyping span:nth-child(3) { animation-delay:.4s; }
@keyframes typingdot { 0%,60%,100%{opacity:.3;transform:translateY(0)} 30%{opacity:1;transform:translateY(-3px)} }
.mchat-input { padding:8px 12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;background:#fff; }
.minput-field { flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:6px 10px;font-size:.7rem;color:var(--t3); }
.msend { width:28px;height:28px;background:var(--grad);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0; }

/* Float cards */
.float-card {
  position:absolute;background:rgba(255,255,255,.98);
  border:1px solid var(--border);border-radius:var(--rl);
  padding:12px 16px;box-shadow:var(--s2);
  display:flex;align-items:center;gap:10px;
  backdrop-filter: blur(10px);
}
.fc1 { bottom:-18px;left:-32px;animation:fc1a 5.5s ease-in-out infinite; }
.fc2 { top:28px;right:-32px;animation:fc2a 7s ease-in-out infinite; }
@keyframes fc1a { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
@keyframes fc2a { 0%,100%{transform:translateY(0)} 50%{transform:translateY(11px)} }
.fc-icon { width:32px;height:32px;border-radius:9px;background:rgba(16,185,129,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.fc-label { font-size:.67rem;color:var(--t3);margin-bottom:2px;font-weight:500; }
.fc-row { display:flex;align-items:center;gap:8px; }
.fc-val { font-size:1.05rem;font-weight:800;color:var(--t1);letter-spacing:-.02em; }
.fc-up { font-size:.65rem;color:#16a34a;font-weight:700;background:rgba(22,163,74,.1);padding:1px 6px;border-radius:6px; }
.fc-avs { display:flex;margin-bottom:4px; }
.fc-av { width:22px;height:22px;border-radius:50%;border:2px solid #fff;margin-left:-5px;display:flex;align-items:center;justify-content:center;font-size:.52rem;font-weight:700;color:#fff; }
.fc-av:first-child { margin-left:0; }

/* ============================================================
   CHANNELS / MULTI-CANAL — light section, contrast with dark hero
   ============================================================ */
.channels-section {
  padding: 72px 0 88px;
  background: var(--bg2);
  position: relative; overflow: hidden;
}
.channels-section::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 50% 0%, rgba(245,158,11,.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 50% 100%, rgba(30,41,59,.04) 0%, transparent 60%);
  pointer-events: none;
}
.channels-section::after {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(30,41,59,.05) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, black 0%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, black 0%, transparent 100%);
  opacity: .6;
}
.channels-label {
  text-align: center; font-size: .72rem; font-weight: 700;
  letter-spacing: .14em; color: var(--t3);
  margin-bottom: 32px; position: relative; z-index: 1;
}
.channels-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px;
  max-width: 980px; margin: 0 auto; position: relative; z-index: 1;
}
.channel-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rl);
  padding: 22px 18px;
  text-align: center;
  transition: all .25s;
  box-shadow: var(--s1);
}
.channel-card:hover {
  border-color: rgba(245,158,11,.35);
  transform: translateY(-3px);
  box-shadow: var(--s2), 0 0 0 1px rgba(245,158,11,.08);
}
.channel-ico {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,.12);
}
.channel-name { font-size: .92rem; font-weight: 700; color: var(--t1); margin-bottom: 3px; }
.channel-desc { font-size: .72rem; color: var(--t3); }

/* ============================================================
   STATS
   ============================================================ */
.stats-section { padding: 88px 0; background: #fff; position: relative; overflow: hidden; }
.stats-section::before {
  content: ''; position: absolute;
  width: 700px; height: 700px; border-radius: 50%;
  background: radial-gradient(circle, rgba(245,158,11,.06) 0%, transparent 70%);
  top: -250px; right: -100px; pointer-events: none;
}
.stats-grid { display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);border-radius:var(--rxl);overflow:hidden;background:#fff; }
.stat-card {
  padding:44px 28px;text-align:center;border-right:1px solid var(--border);
  background:#fff;position:relative;overflow:hidden;transition:background .2s;
}
.stat-card:last-child { border-right:none; }
.stat-card:hover { background: var(--bg); }
.stat-card::before {
  content:'';position:absolute;top:0;left:0;bottom:0;width:45%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
  transform:translateX(-120%) skewX(-15deg); pointer-events:none;
}
.stat-card:hover::before { animation: shimmer .7s ease; }
@keyframes shimmer { to { transform: translateX(280%) skewX(-15deg); } }
.stat-card::after {
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:0;height:3px;background:var(--grad);border-radius:3px 3px 0 0;
  transition:width .3s;
}
.stat-card:hover::after { width: 60%; }
.stat-num { font-size:2.9rem;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:9px; background:var(--grad-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.stat-label { font-size:.875rem;color:var(--t2);font-weight:500;line-height:1.45; }

/* ============================================================
   PROBLEM / SOLUTION
   ============================================================ */
.two-col-section { padding:88px 0;background:var(--bg2);position:relative;overflow:hidden; }
.two-col-section::after {
  content:'';position:absolute;bottom:-80px;left:-80px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.05) 0%,transparent 70%);pointer-events:none;
}
.two-col-grid { display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;position:relative;z-index:1; }
.check-list { margin-top:22px;display:flex;flex-direction:column;gap:10px; }
.check-list li { display:flex;align-items:flex-start;gap:11px;font-size:.9375rem;color:var(--t2);line-height:1.55;padding:13px 16px;border-radius:var(--r);transition:all .2s; }
.check-list.problem li { background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.1); }
.check-list.problem li:hover { background:rgba(239,68,68,.06);border-color:rgba(239,68,68,.18); }
.check-list.solution li { background:rgba(245,158,11,.04);border:1px solid rgba(245,158,11,.1); }
.check-list.solution li:hover { background:rgba(245,158,11,.07);border-color:rgba(245,158,11,.2); }
.chk { width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px; }
.chk.red { background:rgba(239,68,68,.1);color:#ef4444; }
.chk.amber { background:rgba(245,158,11,.12);color:var(--orange); }

/* ============================================================
   FEATURES — BENTO GRID (AbacatePay style)
   ============================================================ */
.features-section { padding:96px 0;background:#fff;position:relative; }
.features-section::before {
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(26,22,18,.05) 1px,transparent 1px);
  background-size:30px 30px;pointer-events:none;opacity:.55;
  mask-image:linear-gradient(180deg, black 0%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, black 0%, transparent 100%);
}

.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(220px, auto);
  grid-auto-flow: dense;
  gap: 18px;
  position: relative; z-index: 1;
}
.bento-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--rxl);
  padding: 28px;
  position: relative;
  overflow: hidden;
  transition: all .3s cubic-bezier(.4,0,.2,1);
  box-shadow: var(--s1);
  display: flex; flex-direction: column;
  isolation: isolate;
}
.bento-card::before {
  content:'';position:absolute;inset:0;border-radius:var(--rxl);
  padding:1.5px;background:var(--grad);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.bento-card:hover { transform: translateY(-4px); box-shadow: var(--s2); }
.bento-card:hover::before { opacity: 1; }

/* Bento sizes */
.bento-lg     { grid-column: span 2; grid-row: span 2; }
.bento-tall   { grid-column: span 1; grid-row: span 2; }
.bento-wide   { grid-column: span 2; grid-row: span 1; }
.bento-md     { grid-column: span 1; grid-row: span 1; }
.bento-wide-2 { grid-column: span 2; grid-row: span 1; }

.bento-content { display: flex; flex-direction: column; }
.bento-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.bento-tag {
  display: inline-block;
  font-size: .68rem; font-weight: 700; letter-spacing: .04em;
  padding: 4px 10px; border-radius: 50px;
  margin-bottom: 14px; align-self: flex-start;
}
.bento-title {
  font-size: 1.15rem; font-weight: 700;
  color: var(--t1); margin-bottom: 8px; letter-spacing: -.02em;
}
.bento-lg .bento-title { font-size: 1.4rem; }
.bento-desc {
  font-size: .9rem; color: var(--t2); line-height: 1.65;
}

/* Bento visuals */
.bento-visual { margin-top: auto; padding-top: 20px; }

/* Inbox visual */
.bento-visual-inbox .bv-list { display: flex; flex-direction: column; gap: 8px; }
.bv-item {
  display: flex; align-items: center; gap: 10px;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px 12px;
  transition: all .2s;
}
.bv-item.active { background: rgba(245,158,11,.05); border-color: rgba(245,158,11,.2); }
.bv-av { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .65rem; font-weight: 700; color: #fff; flex-shrink: 0; }
.bv-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; overflow: hidden; }
.bv-info strong { font-size: .8rem; font-weight: 700; color: var(--t1); }
.bv-info span { font-size: .72rem; color: var(--t3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.bv-time { font-size: .65rem; color: var(--t3); flex-shrink: 0; }

/* Bot visual */
.bento-visual-bot { display: flex; flex-direction: column; gap: 8px; align-items: stretch; }
.bv-msg {
  font-size: .78rem; padding: 9px 13px; border-radius: 12px;
  max-width: 85%;
}
.bv-msg.user { background: var(--bg2); color: var(--t1); align-self: flex-end; border-bottom-right-radius: 4px; }
.bv-msg.bot {
  background: linear-gradient(135deg, rgba(139,92,246,.08), rgba(139,92,246,.03));
  border: 1px solid rgba(139,92,246,.2);
  color: var(--t1);
  align-self: flex-start; border-bottom-left-radius: 4px;
}
.bv-bot-tag { font-size: .62rem; font-weight: 700; color: #8b5cf6; margin-bottom: 4px; letter-spacing: .04em; }
.bv-typing { display: flex; gap: 4px; align-self: flex-start; padding: 8px 14px; background: var(--bg2); border-radius: 12px; border-bottom-left-radius: 4px; }
.bv-typing span { width: 5px; height: 5px; background: var(--t3); border-radius: 50%; animation: typingdot 1.4s infinite both; }
.bv-typing span:nth-child(2) { animation-delay: .2s; }
.bv-typing span:nth-child(3) { animation-delay: .4s; }

/* Campaign visual */
.bento-visual-campaigns .bv-stat-row { display: flex; gap: 16px; margin-bottom: 12px; }
.bv-stat { flex: 1; }
.bv-stat-num { font-size: 1.5rem; font-weight: 800; color: var(--t1); letter-spacing: -.03em; line-height: 1; }
.bv-stat:last-child .bv-stat-num { background: var(--grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.bv-stat-lbl { font-size: .68rem; color: var(--t3); margin-top: 2px; font-weight: 500; }
.bv-bar { height: 8px; background: var(--bg2); border-radius: 50px; overflow: hidden; margin-top: 4px; }
.bv-bar-fill {
  height: 100%; background: var(--grad); border-radius: 50px;
  position: relative; animation: bar-grow 1.6s ease-out;
}
@keyframes bar-grow { from { width: 0 !important; } }
.bv-bar-fill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
  animation: bar-shimmer 2.4s linear infinite;
}
@keyframes bar-shimmer { from{transform:translateX(-100%)} to{transform:translateX(100%)} }
.bv-bar-label { font-size: .7rem; color: var(--t2); margin-top: 8px; font-weight: 600; }

/* Chart visual */
.bento-visual-chart { padding-top: 12px; }
.bv-chart { width: 100%; height: 80px; }

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how-section { padding:96px 0;background:var(--bg2);position:relative;overflow:hidden; }
.how-section::before {
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:300px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(245,158,11,.07) 0%,transparent 70%);pointer-events:none;
}
.how-grid { display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:start;position:relative;z-index:1;gap:8px; }
.how-step { text-align:center;padding:0 12px; }
.how-num-wrap { position: relative; width: 76px; height: 76px; margin: 0 auto 22px; }
.how-num {
  position: relative; z-index: 1;
  width:76px;height:76px;border-radius:50%;
  background:#fff;border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.65rem;font-weight:800;
  color:var(--orange);letter-spacing:-.03em;
  box-shadow:var(--s1);transition:all .3s;
}
.how-num-glow {
  position: absolute; inset: -8px; border-radius: 50%;
  background: var(--grad); opacity: 0; filter: blur(20px);
  transition: opacity .3s;
}
.how-step:hover .how-num { background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 0 28px rgba(234,88,12,.32); }
.how-step:hover .how-num-glow { opacity: .35; }
.how-title { font-size:1.1rem;font-weight:700;margin-bottom:9px;letter-spacing:-.015em; }
.how-desc { font-size:.9rem;color:var(--t2);line-height:1.68; }
.how-connector { display:flex;align-items:center;justify-content:center;padding-top:32px;color:var(--border2); }

/* ============================================================
   TESTIMONIALS — BENTO LAYOUT
   ============================================================ */
.testimonials-section { padding:96px 0;background:#fff;position:relative;overflow:hidden; }
.testimonials-section::before {
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent 0,transparent 39px,rgba(26,22,18,.025) 40px);
  pointer-events:none;
  mask-image:linear-gradient(180deg, transparent 0%, black 20%, black 80%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, black 20%, black 80%, transparent 100%);
}
.testi-bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  position: relative; z-index: 1;
}
.testi-card {
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--rl);padding:28px;transition:all .25s;
  display: flex; flex-direction: column;
}
.testi-card:hover {
  background:#fff;
  box-shadow:var(--s2),0 0 0 1px rgba(245,158,11,.12),0 16px 48px rgba(245,158,11,.06);
  transform:translateY(-3px);
}
.testi-feat {
  grid-column: span 2;
  background: linear-gradient(135deg, #fff 0%, var(--bg2) 100%);
  border-color: rgba(245,158,11,.15);
}
.testi-feat:hover { background: linear-gradient(135deg, #fff 0%, #fff 100%); }
.testi-quote { background: linear-gradient(135deg, rgba(245,158,11,.04), rgba(245,158,11,.02)); border-color: rgba(245,158,11,.18); position: relative; }
.testi-quote-ico { position: absolute; top: 24px; right: 24px; color: rgba(245,158,11,.18); }
.stars { color:var(--amber);font-size:.9375rem;letter-spacing:2px;margin-bottom:14px; }
.testi-text { font-size:.9375rem;color:var(--t2);line-height:1.78;margin-bottom:22px; flex: 1; }
.testi-text strong { color: var(--t1); font-weight: 700; }
.testi-text-lg { font-size: 1.15rem; line-height: 1.65; color: var(--t1); }
.testi-author { display:flex;align-items:center;gap:12px;margin-top:auto; }
.testi-av { width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8125rem;color:#fff;flex-shrink:0; }
.testi-info { display:flex;flex-direction:column;gap:2px; }
.testi-info strong { font-size:.9375rem;font-weight:700;color:var(--t1);line-height:1.3;display:block; }
.testi-info small { font-size:.78rem;color:var(--t3);line-height:1.3;display:block; }

/* ============================================================
   PRICING
   ============================================================ */
.pricing-section { padding:96px 0;background:var(--bg2);position:relative;overflow:hidden; }
.pricing-section::after {
  content:'';position:absolute;top:-80px;right:-80px;
  width:550px;height:550px;border-radius:50%;
  background:radial-gradient(circle,rgba(245,158,11,.07) 0%,transparent 70%);pointer-events:none;
}

.price-toggle {
  display: inline-flex; align-items: center;
  background: #fff; border: 1px solid var(--border);
  border-radius: 50px; padding: 4px;
  margin-top: 24px;
  box-shadow: var(--s1);
}
.pt-btn {
  font-size: .85rem; font-weight: 600; color: var(--t2);
  padding: 8px 22px; border-radius: 50px;
  transition: all .25s;
  display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.pt-btn:hover { color: var(--t1); }
.pt-btn.active {
  background: var(--grad); color: #fff;
  box-shadow: 0 2px 12px rgba(234,88,12,.3);
}
.pt-badge {
  background: rgba(255,255,255,.2);
  font-size: .65rem; font-weight: 800;
  padding: 2px 7px; border-radius: 50px;
  color: inherit;
}
.pt-btn:not(.active) .pt-badge {
  background: rgba(16,185,129,.12); color: #059669;
}

.price-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1000px;margin:0 auto;position:relative;z-index:1; }
.price-card { background:#fff;border:1.5px solid var(--border);border-radius:var(--rxl);padding:36px 30px;position:relative;transition:all .25s;box-shadow:var(--s1);display:flex;flex-direction:column; }
.price-card:hover { box-shadow:var(--s2);transform:translateY(-2px); }
.price-card.featured { border-color:var(--orange); }
@keyframes featured-pulse {
  0%,100% { box-shadow:0 0 0 4px rgba(245,158,11,.07),var(--s2); }
  50%      { box-shadow:0 0 0 7px rgba(245,158,11,.12),0 12px 36px rgba(245,158,11,.14); }
}
.price-card.featured { animation:featured-pulse 4s ease-in-out infinite; }
.price-card.featured:hover { animation:none;box-shadow:0 0 0 4px rgba(245,158,11,.18),var(--s3); }
.price-popular { position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;font-size:.7rem;font-weight:700;padding:5px 18px;border-radius:20px;white-space:nowrap;box-shadow:0 4px 14px rgba(234,88,12,.4); }
.price-plan { font-size:.75rem;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px; }
.price-tagline { font-size:.85rem;color:var(--t2);margin-bottom:16px;font-weight:500; }
.price-row { display:flex;align-items:flex-start;gap:2px;margin-bottom:2px; }
.price-cur { font-size:1.125rem;font-weight:700;color:var(--t2);padding-top:8px; }
.price-val { font-size:3rem;font-weight:800;color:var(--t1);line-height:1;letter-spacing:-.045em; transition: all .3s; }
.price-per { font-size:.85rem;color:var(--t3);font-weight:600;align-self:flex-end;padding-bottom:6px;margin-left:4px; }
.price-billed { font-size:.78rem;color:var(--t3);margin-bottom:22px;font-style:italic; }
.price-divider { height:1px;background:var(--border);margin-bottom:22px; }
.price-feats { display:flex;flex-direction:column;gap:11px;margin-bottom:28px;flex:1; }
.price-feats li { font-size:.875rem;color:var(--t2);display:flex;align-items:center;gap:9px; }
.price-feats li.ok::before { content:'✓';color:var(--orange);font-weight:800;flex-shrink:0;font-size:1rem; }
.price-feats li.no { color:var(--t3);text-decoration:line-through; }
.price-feats li.no::before { content:'–';color:var(--t3);flex-shrink:0; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-section { padding:96px 0;background:#fff; }
.faq-section .sec-desc { margin-top: 12px; }
.faq-list { display:flex;flex-direction:column;gap:8px; }
.faq-item { background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .2s; }
.faq-item:hover { border-color:var(--border2); }
.faq-item.open { border-color:var(--orange);background:#fff;box-shadow:0 0 0 3px rgba(245,158,11,.07); }
.faq-q { display:flex;align-items:center;justify-content:space-between;width:100%;padding:19px 22px;font-weight:600;font-size:.9375rem;color:var(--t1);gap:16px;text-align:left;letter-spacing:-.01em; }
.faq-icon { width:24px;height:24px;border-radius:50%;background:var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.125rem;color:var(--t2);transition:all .2s;line-height:1; }
.faq-item.open .faq-icon { background:rgba(245,158,11,.1);color:var(--orange);transform:rotate(45deg); }
.faq-a { max-height:0;overflow:hidden;transition:max-height .35s ease; }
.faq-item.open .faq-a { max-height:200px; }
.faq-a p { padding:0 22px 20px;font-size:.9375rem;color:var(--t2);line-height:1.78; }

/* ============================================================
   CTA DARK
   ============================================================ */
.cta-section { padding:88px 0 112px;background:var(--bg2); }
.cta-card {
  background:var(--dark);border-radius:32px;padding:88px 48px;text-align:center;
  position:relative;overflow:hidden;
}
.cta-card::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 65% 55% at 50% 0%,rgba(245,158,11,.2) 0%,transparent 65%);
  pointer-events:none;
}
.cta-card::after {
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg,transparent 0,transparent 18px,rgba(255,255,255,.013) 18px,rgba(255,255,255,.013) 19px);
  pointer-events:none;
}
.cta-card::before, .cta-card::after { z-index:0; }
.cta-orb { position:absolute;border-radius:50%;pointer-events:none;filter:blur(70px); }
.co1 { width:400px;height:400px;background:rgba(245,158,11,.14);top:-120px;left:-80px;animation:orb1 11s ease-in-out infinite; }
.co2 { width:400px;height:400px;background:rgba(245,158,11,.1);bottom:-120px;right:-80px;animation:orb2 14s ease-in-out infinite; }
.cta-dots {
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:28px 28px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 0%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 0%,transparent 100%);
}
.cta-content { position:relative;z-index:1; }
.cta-title { font-size:clamp(2rem,3.5vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.06;margin-bottom:16px;color:var(--t1d); }
.cta-desc { font-size:1.0625rem;color:var(--t2d);max-width:520px;margin:0 auto 36px;line-height:1.75; }
.cta-btns { display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap; }
.cta-features {
  display: flex; align-items: center; justify-content: center;
  gap: 18px; flex-wrap: wrap; margin-top: 28px;
}
.cta-features span {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .82rem; color: var(--t2d); font-weight: 500;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer { border-top:1px solid rgba(255,255,255,.06);padding:72px 0 36px;background:var(--dark); }
.footer-logo-img { height:40px;width:auto;margin-bottom:16px; }
.footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px; }
.footer-desc { font-size:.875rem;color:var(--t2d);line-height:1.72;max-width:300px;margin-bottom:22px; }
.footer-social { display:flex;gap:8px;margin-top:18px; }
.social-btn { width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--t2d);transition:all .2s; }
.social-btn:hover { color:#fff;border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.1);transform:translateY(-2px); }
.footer-col-title { font-size:.72rem;font-weight:700;color:var(--t1d);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px; }
.footer-links { display:flex;flex-direction:column;gap:11px; }
.footer-links a { font-size:.875rem;color:var(--t3d);transition:color .15s; }
.footer-links a:hover { color:var(--t1d); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap; }
.footer-copy { font-size:.8125rem;color:var(--t3d); }
.footer-legal { display:flex;gap:20px; }
.footer-legal a { font-size:.8125rem;color:var(--t3d);transition:color .15s; }
.footer-legal a:hover { color:var(--t1d); }

/* Footer newsletter */
.footer-news { margin-top: 8px; }
.footer-news-label {
  font-size: .76rem; color: var(--t2d); font-weight: 500;
  margin-bottom: 8px;
}
.footer-news-form {
  display: flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  padding: 4px;
  max-width: 320px;
  transition: all .2s;
}
.footer-news-form:focus-within {
  border-color: rgba(245,158,11,.4);
  background: rgba(255,255,255,.08);
}
.footer-news-form input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--t1d); font-family: inherit; font-size: .85rem;
  padding: 8px 12px;
}
.footer-news-form input::placeholder { color: var(--t3d); }
.footer-news-form button {
  background: var(--grad); color: #fff;
  width: 34px; height: 34px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all .2s;
}
.footer-news-form button:hover { transform: scale(1.05); box-shadow: 0 2px 12px rgba(234,88,12,.4); }
.fnews-ok {
  font-size: .76rem; color: #10b981; margin-top: 8px;
  opacity: 0; transform: translateY(-4px); transition: all .25s;
}
.fnews-ok.show { opacity: 1; transform: translateY(0); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal { opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s ease; }
.reveal.visible { opacity:1;transform:translateY(0); }
.d1 { transition-delay:.1s; }
.d2 { transition-delay:.2s; }
.d3 { transition-delay:.3s; }
.d4 { transition-delay:.4s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); }
  .bento-lg, .bento-wide, .bento-wide-2 { grid-column: span 2; }
  .bento-tall { grid-column: span 1; grid-row: span 2; }
  .bento-md { grid-column: span 1; }
  .channels-grid { grid-template-columns: repeat(3, 1fr); }
  .channels-grid .channel-card:nth-child(4),
  .channels-grid .channel-card:nth-child(5) { grid-column: span 1; }
}
@media (max-width:1024px) {
  .hero-inner { grid-template-columns:1fr; gap: 48px; }
  .hero-visual { display:none; }
  .hero-content { max-width:100%;text-align:center; }
  .hero-title { margin-left: auto; margin-right: auto; }
  .hero-desc { margin-left: auto; margin-right: auto; }
  .hero-btns { justify-content:center; }
  .hero-trust { justify-content: center; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-card:nth-child(2) { border-right: none; }
  .stat-card:nth-child(1), .stat-card:nth-child(2) { border-bottom: 1px solid var(--border); }
  .two-col-grid { grid-template-columns:1fr;gap:40px; }
  .how-grid { grid-template-columns:1fr; }
  .how-connector { display:none; }
  .testi-bento { grid-template-columns: repeat(2, 1fr); }
  .testi-feat, .testi-quote { grid-column: span 2; }
  .price-grid { grid-template-columns:1fr;max-width:420px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width:768px) {
  .nav-links, .nav-login, .btn-nav { display:none; }
  .nav-burger { display: flex; }
  .bento-grid { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .bento-lg, .bento-tall, .bento-wide, .bento-wide-2, .bento-md { grid-column: span 1; grid-row: span 1; }
  .bento-lg { min-height: 320px; }
  .channels-grid { grid-template-columns: repeat(2, 1fr); }
  .channels-section { padding: 48px 0; }
  .testi-bento { grid-template-columns: 1fr; }
  .testi-feat, .testi-quote { grid-column: span 1; }
  .footer-grid { grid-template-columns:1fr; gap: 32px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
  .cta-card { padding:56px 24px;border-radius:24px; }
  .hero { padding:120px 0 72px;min-height:auto; }
  .hero-title { font-size:clamp(2rem,7vw,2.8rem); }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .features-section, .how-section, .testimonials-section, .pricing-section, .faq-section { padding: 64px 0; }
  .section-header { margin-bottom: 40px; }
  .price-card { padding: 30px 24px; }
  .price-val { font-size: 2.5rem; }
}
@media (max-width:480px) {
  .channels-grid { grid-template-columns: 1fr 1fr; }
  .cta-features { gap: 10px; }
  .cta-features span { font-size: .76rem; }
  .hero-trust { flex-direction: column; gap: 8px; }
}
