/* ============================================================
   Bukkii AI — V2 Design System
   Brand: Twitter Blue #1DA1F2 (primary)  /  Coral #F05B72 (accent)
   White-first, soft surfaces, modern typography
   ============================================================ */

:root{
  /* Brand */
  --brand:        #1DA1F2;
  --brand-600:    #0E8FE0;
  --brand-700:    #0B73B5;
  --brand-50:     #E8F5FE;
  --brand-100:    #D1ECFD;
  --accent:       #F05B72;
  --accent-600:   #D9425C;
  --accent-50:    #FEEDF0;
  --accent-100:   #FCD8DE;

  /* Surfaces */
  --bg:           #FFFFFF;
  --bg-soft:      #F8FAFC;
  --bg-mesh:      #F1F6FB;
  --surface:      #FFFFFF;

  /* Lines */
  --line:         rgba(15,23,42,.07);
  --line-2:       rgba(15,23,42,.10);
  --line-brand:   rgba(29,161,242,.22);

  /* Text */
  --ink:          #0B1F33;
  --ink-2:        #4A5A6E;
  --ink-3:        #8A98A8;
  --ink-inv:      #FFFFFF;

  /* Status */
  --green:        #10B981;
  --amber:        #F59E0B;
  --rose:         #F43F5E;
  --violet:       #7B61FF;

  /* Effects */
  --shadow-xs:    0 1px 2px rgba(11,31,51,.04);
  --shadow-sm:    0 4px 12px rgba(11,31,51,.06);
  --shadow-md:    0 10px 28px rgba(11,31,51,.08);
  --shadow-lg:    0 24px 56px rgba(11,31,51,.10);
  --shadow-brand: 0 12px 32px rgba(29,161,242,.28);
  --shadow-accent:0 12px 32px rgba(240,91,114,.28);

  /* Geometry */
  --r-sm:  10px;
  --r:     16px;
  --r-lg:  22px;
  --r-xl:  28px;
  --r-pill:999px;
  --nav-h: 68px;

  /* Type */
  --font-sans:    'Inter','SF Pro Text',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --font-display: 'Inter','SF Pro Display',system-ui,sans-serif;
  --dur:          .22s;
  --ease:         cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"cv11","ss01","ss03";
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg,video{max-width:100%;display:block;height:auto}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}
input,textarea,select{font:inherit}
::selection{background:var(--brand-100);color:var(--brand-700)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}

/* ---------- Layout ---------- */
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:880px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section-sm{padding:64px 0}
.section-lg{padding:120px 0}

/* ---------- Type helpers ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);margin-bottom:18px;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--brand);display:inline-block}
.eyebrow.coral{color:var(--accent-600)}
.eyebrow.coral .dot{background:var(--accent)}

.h-display{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5vw,4rem);
  font-weight:900;line-height:1.04;letter-spacing:-.035em;color:var(--ink);
}
.h-section{
  font-family:var(--font-display);
  font-size:clamp(1.75rem,3.4vw,2.6rem);
  font-weight:900;line-height:1.12;letter-spacing:-.025em;color:var(--ink);
}
.h-card{
  font-size:1.1rem;font-weight:800;line-height:1.3;color:var(--ink);
}
.lede{
  font-size:clamp(1rem,1.4vw,1.15rem);color:var(--ink-2);line-height:1.7;
}
.muted{color:var(--ink-2)}
.faint{color:var(--ink-3)}

.text-brand{color:var(--brand)}
.text-accent{color:var(--accent)}
.text-grad-brand{
  background:linear-gradient(135deg,#1DA1F2 0%,#0B73B5 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}
.text-grad-accent{
  background:linear-gradient(135deg,#F05B72 0%,#D9425C 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:800;font-size:.95rem;text-decoration:none;
  padding:13px 24px;border-radius:var(--r-pill);border:1.5px solid transparent;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur),background var(--dur),border-color var(--dur),color var(--dur);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-brand)}
.btn-primary:hover{background:var(--brand-600);box-shadow:0 16px 36px rgba(29,161,242,.36)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}
.btn-accent:hover{background:var(--accent-600);box-shadow:0 16px 36px rgba(240,91,114,.36)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-soft{background:var(--brand-50);color:var(--brand-700);border-color:var(--line-brand)}
.btn-soft:hover{background:var(--brand-100)}
.btn-lg{padding:16px 30px;font-size:1rem}
.btn-sm{padding:10px 18px;font-size:.85rem}

/* ---------- Pill / chips ---------- */
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:var(--r-pill);
  font-size:.78rem;font-weight:700;
  background:var(--brand-50);color:var(--brand-700);border:1px solid var(--line-brand);
}
.chip.accent{background:var(--accent-50);color:var(--accent-600);border-color:rgba(240,91,114,.22)}
.chip .pulse{
  width:7px;height:7px;border-radius:50%;background:currentColor;
  animation:pulse 1.8s infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.85)}}

/* ---------- Cards ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px;box-shadow:var(--shadow-xs);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur),border-color var(--dur);
}
.card:hover{transform:translateY(-3px);border-color:var(--line-brand);box-shadow:var(--shadow-md)}
.card-flush{padding:0;overflow:hidden}
.card-icon{
  width:48px;height:48px;border-radius:14px;
  background:var(--brand-50);color:var(--brand);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:18px;
  border:1px solid var(--line-brand);
}
.card-icon.accent{background:var(--accent-50);color:var(--accent-600);border-color:rgba(240,91,114,.22)}

/* ---------- Navigation ---------- */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:60;height:var(--nav-h);
  background:rgba(255,255,255,.78);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
  backdrop-filter:saturate(160%) blur(16px);
  border-bottom:1px solid transparent;
  transition:border-color var(--dur),box-shadow var(--dur),background var(--dur);
}
#nav.scrolled{border-color:var(--line);box-shadow:var(--shadow-xs);background:rgba(255,255,255,.92)}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:900;font-size:1.05rem;color:var(--ink)}
.nav-logo img{width:34px;height:34px;border-radius:10px}
.nav-logo .ai{color:var(--brand)}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  display:inline-flex;align-items:center;
  padding:8px 14px;border-radius:10px;
  font-size:.88rem;font-weight:600;color:var(--ink-2);
  transition:color var(--dur),background var(--dur);
}
.nav-links a:hover{color:var(--brand);background:var(--brand-50)}
.nav-links a.active{color:var(--brand);background:var(--brand-50)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-cta{
  padding:10px 20px;border-radius:var(--r-pill);
  background:var(--brand);color:#fff;font-size:.85rem;font-weight:800;
  box-shadow:var(--shadow-brand);transition:all var(--dur);
}
.nav-cta:hover{background:var(--brand-600);transform:translateY(-1px)}
.nav-login{padding:10px 18px;border-radius:var(--r-pill);border:1.5px solid var(--line);color:var(--ink);font-size:.85rem;font-weight:700;transition:all var(--dur)}
.nav-login:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-50)}
.hamburger{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;color:var(--ink);border:1px solid var(--line)}
.hamburger:hover{background:var(--bg-soft)}
#mobile-nav{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;z-index:55;
  background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);
  padding:18px 24px 28px;
}
#mobile-nav.open{display:block;animation:slideDown .22s var(--ease)}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
#mobile-nav a{
  display:block;padding:14px 4px;font-weight:600;color:var(--ink);
  font-size:.95rem;border-bottom:1px solid var(--line);
}
#mobile-nav a:last-child{border-bottom:none;margin-top:14px;text-align:center;background:var(--brand);color:#fff;border-radius:14px;padding:16px}

/* ---------- Hero (homepage) ---------- */
.hero{
  position:relative;overflow:hidden;
  padding:calc(var(--nav-h) + 88px) 0 96px;
  background:#fff;
}
.hero-mesh{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60% 50% at 50% -10%, rgba(29,161,242,.14), transparent 70%),
    radial-gradient(40% 32% at 88% 22%, rgba(240,91,114,.10), transparent 70%),
    radial-gradient(36% 30% at 8% 68%, rgba(123,97,255,.08), transparent 70%);
}
.hero-grid{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(15,23,42,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(15,23,42,.045) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 0%,#000,transparent);
          mask-image:radial-gradient(ellipse 80% 70% at 50% 0%,#000,transparent);
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;
}
.hero-copy h1{margin:0 0 22px}
.hero-copy .lede{max-width:560px;margin-bottom:32px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}
.hero-trust{display:flex;flex-wrap:wrap;gap:18px;color:var(--ink-3);font-size:.82rem}
.hero-trust span{display:inline-flex;align-items:center;gap:7px}
.hero-trust svg{color:var(--green)}

/* AIVA hero portrait */
.aiva-stage{position:relative;display:flex;justify-content:center;padding:24px 70px}
.aiva-frame{
  position:relative;width:100%;max-width:460px;
  border-radius:var(--r-xl);overflow:visible;
  background:linear-gradient(180deg,#FFE4E6,#FFF1F2);
  padding:22px;
  box-shadow:0 28px 64px rgba(240,91,114,.18),0 0 0 1px rgba(240,91,114,.08);
}
.aiva-frame::before{
  content:"";position:absolute;inset:-12px;border-radius:34px;
  border:1.5px dashed rgba(240,91,114,.32);
  animation:rotate 36s linear infinite;pointer-events:none;
}
@keyframes rotate{to{transform:rotate(360deg)}}
.aiva-img{width:100%;border-radius:18px;display:block;background:#fff;aspect-ratio:1/1;object-fit:cover}
.aiva-tag{
  position:absolute;left:-14px;top:24px;z-index:2;
  background:var(--accent);color:#fff;
  padding:8px 14px;border-radius:var(--r-pill);
  font-size:.7rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  display:flex;align-items:center;gap:7px;
  box-shadow:var(--shadow-accent);
}
.aiva-tag .live-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.6s infinite}
.aiva-name{
  position:absolute;right:-14px;bottom:24px;z-index:2;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:12px 16px;box-shadow:var(--shadow-md);
}
.aiva-name .nm{font-weight:900;font-size:.95rem;color:var(--ink);line-height:1}
.aiva-name .role{font-size:.7rem;color:var(--ink-3);font-weight:700;margin-top:4px}
.float-badge{
  position:absolute;display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--line);
  padding:9px 14px;border-radius:14px;
  font-size:.78rem;font-weight:700;color:var(--ink);
  box-shadow:var(--shadow-md);
  animation:floatup 4.5s ease-in-out infinite;z-index:3;
}
.float-badge .d{width:7px;height:7px;border-radius:50%}
@keyframes floatup{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ---------- Logo strip ---------- */
.logo-strip{padding:48px 0;background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.logo-strip-label{text-align:center;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:800;margin-bottom:24px}
.logo-strip-row{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;opacity:.85}
.logo-strip-row span{font-weight:700;color:var(--ink-3);font-size:.95rem;letter-spacing:.04em}

/* ---------- Generic grid layouts ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

/* Feature card with color theming */
.feat-card{position:relative;overflow:hidden}
.feat-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 0% 0%,rgba(var(--c,29,161,242),.08),transparent 70%);
  pointer-events:none;
}
.feat-card .card-icon{
  background:rgba(var(--c,29,161,242),.10);
  color:rgb(var(--c,29,161,242));
  border-color:rgba(var(--c,29,161,242),.22);
}
.feat-card h3{margin-bottom:8px}
.feat-card p{color:var(--ink-2);font-size:.92rem;line-height:1.7}

/* ---------- Pain table ---------- */
.pain-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px;max-width:980px;margin-left:auto;margin-right:auto}
.pain-col{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-xs)}
.pain-col h3{font-size:1.05rem;font-weight:900;margin-bottom:18px}
.pain-col h3.bad{color:var(--accent-600)}
.pain-col h3.good{color:var(--green)}
.pain-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.pain-col li{display:flex;align-items:flex-start;gap:12px;font-size:.92rem;color:var(--ink-2);line-height:1.6;padding-left:0}
.pain-col li .ic{
  flex-shrink:0;width:20px;height:20px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:.7rem;margin-top:2px;
}
.pain-col.bad li .ic{background:rgba(244,63,94,.14);color:var(--rose);border:1px solid rgba(244,63,94,.28)}
.pain-col.good li .ic{background:rgba(16,185,129,.14);color:var(--green);border:1px solid rgba(16,185,129,.28)}

/* ---------- Channel cards ---------- */
.ch-card{
  background:linear-gradient(180deg,#fff,var(--bg-soft));
  border:1px solid var(--line);border-radius:var(--r-lg);
  padding:32px;text-align:center;box-shadow:var(--shadow-xs);
  transition:all var(--dur);
}
.ch-card:hover{transform:translateY(-4px);border-color:var(--line-brand);box-shadow:var(--shadow-md)}
.ch-card .ch-icon{
  width:64px;height:64px;border-radius:18px;margin:0 auto 18px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.7rem;
}

/* ---------- Steps / how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.step{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:30px 28px 28px;box-shadow:var(--shadow-xs);transition:all var(--dur);
}
.step:hover{border-color:var(--line-brand);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.step-num{
  position:absolute;top:-18px;left:24px;width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-700));color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;
  box-shadow:var(--shadow-brand);
}
.step h3{margin:10px 0 12px;font-size:1.05rem;font-weight:900}
.step p{color:var(--ink-2);font-size:.92rem;line-height:1.7}

/* ---------- Stats strip ---------- */
.stats-strip{
  padding:64px 0;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-700) 100%);
}
.stats-strip::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 0%,rgba(255,255,255,.18),transparent 60%);
  pointer-events:none;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;position:relative;z-index:1}
.stats-grid .num{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:900;line-height:1;letter-spacing:-.02em}
.stats-grid .lbl{font-size:.85rem;color:rgba(255,255,255,.88);margin-top:8px;font-weight:600}

/* ---------- Pricing ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start;max-width:1180px;margin:0 auto}
.price-card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:32px 28px;transition:all var(--dur);box-shadow:var(--shadow-xs);
}
.price-card:hover{transform:translateY(-4px);border-color:var(--line-brand);box-shadow:var(--shadow-md)}
.price-card.featured{
  background:linear-gradient(180deg,#fff,var(--brand-50));
  border-color:var(--brand);transform:scale(1.02);
  box-shadow:0 24px 56px rgba(29,161,242,.20);
}
.price-card.featured:hover{transform:scale(1.02) translateY(-4px)}
.price-badge{
  display:inline-block;font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 12px;border-radius:var(--r-pill);margin-bottom:14px;
}
.price-badge.basic{background:var(--bg-soft);color:var(--ink-2)}
.price-badge.popular{background:var(--brand);color:#fff}
.price-badge.biz{background:rgba(123,97,255,.14);color:var(--violet)}
.price-name{font-size:1.2rem;font-weight:900;margin-bottom:6px}
.price-desc{font-size:.85rem;color:var(--ink-2);margin-bottom:18px;line-height:1.55;min-height:40px}
.price-amount{display:flex;align-items:baseline;gap:6px;margin:14px 0 22px}
.price-amount .big{font-size:2.6rem;font-weight:900;line-height:1;letter-spacing:-.02em;color:var(--ink)}
.price-amount .unit{font-size:.85rem;color:var(--ink-2);font-weight:600}
.price-amount.brand .big{color:var(--brand)}
.price-features{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:22px}
.price-features li{display:flex;align-items:flex-start;gap:10px;font-size:.86rem;color:var(--ink-2)}
.price-features li .check{
  width:18px;height:18px;border-radius:50%;flex-shrink:0;margin-top:2px;
  background:var(--brand-50);color:var(--brand);
  display:inline-flex;align-items:center;justify-content:center;
}
.price-features li .check.green{background:rgba(16,185,129,.14);color:var(--green)}
.price-features li strong{color:var(--ink);font-weight:800}
.setup-fee{text-align:center;font-size:.74rem;color:var(--ink-3);font-weight:600;margin-bottom:14px}
.setup-fee strong{color:var(--ink-2)}
.btn-price{
  display:block;text-align:center;border-radius:var(--r-pill);padding:14px;
  font-weight:800;font-size:.95rem;text-decoration:none;
  transition:all var(--dur);border:1.5px solid transparent;
}
.btn-price.solid{background:var(--brand);color:#fff;box-shadow:var(--shadow-brand)}
.btn-price.solid:hover{background:var(--brand-600);transform:translateY(-1px)}
.btn-price.outline{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-price.outline:hover{border-color:var(--brand);color:var(--brand)}
.btn-price.coral{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent)}
.btn-price.coral:hover{background:var(--accent-600);transform:translateY(-1px)}

/* ---------- Testimonials ---------- */
.testi-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-xs);transition:all var(--dur)}
.testi-card:hover{border-color:var(--line-brand);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.testi-stars{display:flex;gap:3px;margin-bottom:14px;color:var(--amber);font-size:1rem}
.testi-text{font-size:.95rem;line-height:1.7;color:var(--ink);margin-bottom:20px}
.testi-author{display:flex;align-items:center;gap:12px}
.testi-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;flex-shrink:0;font-size:.95rem}
.testi-name{font-weight:800;font-size:.92rem}
.testi-salon{font-size:.75rem;color:var(--ink-3);margin-top:2px;font-weight:600}

/* ---------- Industry cards ---------- */
.ind-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:28px 22px;text-align:center;box-shadow:var(--shadow-xs);
  transition:all var(--dur);position:relative;overflow:hidden;
  text-decoration:none;color:var(--ink);display:block;
}
.ind-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(var(--ic,29,161,242),.13),transparent 70%);
  opacity:0;transition:opacity var(--dur);
}
.ind-card:hover{border-color:rgba(var(--ic,29,161,242),.4);transform:translateY(-4px);box-shadow:0 12px 32px rgba(var(--ic,29,161,242),.12)}
.ind-card:hover::before{opacity:1}
.ind-card .ic-emoji{font-size:2.2rem;margin-bottom:12px;display:block}
.ind-card .ic-name{font-weight:800;font-size:.98rem;color:var(--ink)}
.ind-card .ic-arrow{margin-top:10px;font-size:.78rem;font-weight:700;color:rgb(var(--ic,29,161,242));opacity:0;transition:opacity var(--dur)}
.ind-card:hover .ic-arrow{opacity:1}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px;margin:48px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  transition:all var(--dur);box-shadow:var(--shadow-xs);
}
.faq-item.open{border-color:var(--line-brand);box-shadow:var(--shadow-sm)}
.faq-q{
  width:100%;text-align:left;padding:20px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-size:.95rem;font-weight:700;color:var(--ink);
}
.faq-q svg{flex-shrink:0;transition:transform .25s var(--ease);color:var(--ink-2)}
.faq-item.open .faq-q svg{transform:rotate(180deg);color:var(--brand)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease),padding .35s;padding:0 24px;font-size:.9rem;color:var(--ink-2);line-height:1.75}
.faq-item.open .faq-a{max-height:500px;padding:0 24px 22px}

/* ---------- CTA banner ---------- */
.cta-banner{padding:96px 0;background:#fff;background-image:radial-gradient(ellipse 60% 100% at 50% 50%,rgba(29,161,242,.12),transparent)}
.cta-box{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-700) 100%);
  border-radius:var(--r-xl);padding:60px 44px;text-align:center;
  max-width:820px;margin:0 auto;color:#fff;
  box-shadow:0 28px 64px rgba(29,161,242,.30);position:relative;overflow:hidden;
}
.cta-box::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 0%,rgba(255,255,255,.20),transparent 60%);pointer-events:none;
}
.cta-box.coral{
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-600) 100%);
  box-shadow:0 28px 64px rgba(240,91,114,.30);
}
.cta-box .eyebrow{color:rgba(255,255,255,.92);justify-content:center}
.cta-box .eyebrow .dot{background:#fff}
.cta-box h2{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:900;margin-bottom:14px;line-height:1.15;color:#fff;letter-spacing:-.02em}
.cta-box p{font-size:1.05rem;color:rgba(255,255,255,.94);line-height:1.7;margin-bottom:30px;max-width:520px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.cta-btns .btn-primary{background:#fff;color:var(--brand-700);box-shadow:0 8px 24px rgba(0,0,0,.18)}
.cta-btns .btn-primary:hover{background:var(--brand-50)}
.cta-btns .btn-outline,.cta-btns .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-btns .btn-outline:hover,.cta-btns .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.cta-note{margin-top:18px;font-size:.8rem;color:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;gap:7px;position:relative;z-index:1}

/* ---------- Subpage hero ---------- */
.page-hero{padding:calc(var(--nav-h) + 72px) 0 64px;background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);text-align:center;position:relative;overflow:hidden}
.page-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 50% at 50% -10%,rgba(29,161,242,.10),transparent 70%);
}
.page-hero > .container{position:relative;z-index:1}
.page-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.4rem);font-weight:900;line-height:1.1;letter-spacing:-.03em;color:var(--ink);max-width:840px;margin:0 auto}
.page-sub{font-size:1.05rem;color:var(--ink-2);line-height:1.7;margin-top:22px;max-width:680px;margin-left:auto;margin-right:auto}

/* ---------- Feature blocks (alt rows) ---------- */
.feat-row{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;padding:64px 0;border-bottom:1px solid var(--line)}
.feat-row:last-child{border-bottom:none}
.feat-row.reverse .fb-copy{order:2}
.feat-row.reverse .fb-art{order:1}
.fb-copy h2{font-family:var(--font-display);font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:900;line-height:1.18;letter-spacing:-.025em;margin-bottom:18px;color:var(--ink)}
.fb-copy p{font-size:1rem;color:var(--ink-2);line-height:1.75;margin-bottom:22px}
.fb-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.fb-list li{display:flex;align-items:flex-start;gap:10px;font-size:.95rem;color:var(--ink);padding-left:0}
.fb-list li::before{content:"";flex-shrink:0;width:20px;height:20px;margin-top:1px;border-radius:50%;background:var(--brand-50);box-shadow:inset 0 0 0 1px var(--line-brand);position:relative}
.fb-list li{position:relative;padding-left:0}
.art-card{background:linear-gradient(180deg,#fff,var(--bg-soft));border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-md);min-height:240px}
.art-card .art-row{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--ink-3);font-weight:700;margin-bottom:12px}
.art-card .art-dot{width:8px;height:8px;border-radius:50%;background:var(--brand);animation:pulse 2s infinite}
.art-card .art-headline{font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:14px;line-height:1.55}
.art-card .art-ai{padding:12px 16px;background:linear-gradient(135deg,rgba(29,161,242,.12),rgba(123,97,255,.10));border:1px solid var(--line-brand);border-radius:14px;font-size:.88rem;color:var(--ink);font-weight:600;line-height:1.55}

/* ---------- Compare table ---------- */
.compare-section{padding:80px 0;background:var(--bg-soft)}
.compare-table{width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-xs);border-collapse:separate;border-spacing:0}
.compare-table th,.compare-table td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:.88rem;color:var(--ink-2)}
.compare-table th{background:var(--bg-soft);font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink)}
.compare-table tr:last-child td{border-bottom:none}
.compare-table .yes{color:var(--green);font-weight:800}
.compare-table .no{color:var(--ink-3)}
.compare-table .feat-name{color:var(--ink);font-weight:700}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:1080px;margin:0 auto}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-xs)}
.contact-card h3{font-size:1.15rem;font-weight:900;margin-bottom:8px}
.contact-card p{font-size:.92rem;color:var(--ink-2);line-height:1.7;margin-bottom:22px}
.contact-link{
  display:flex;align-items:center;gap:14px;padding:14px 16px;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;
  margin-bottom:10px;font-weight:600;font-size:.92rem;color:var(--ink);transition:all var(--dur);
}
.contact-link:hover{border-color:var(--line-brand);background:#fff;box-shadow:var(--shadow-xs)}
.contact-link .ic{
  width:40px;height:40px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--brand),var(--brand-700));color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.15rem;
}
.contact-link .meta{font-size:.74rem;color:var(--ink-3);font-weight:600;margin-top:2px;display:block}
.contact-form .field{margin-bottom:18px}
.contact-form label{display:block;font-size:.78rem;font-weight:700;color:var(--ink);margin-bottom:8px;letter-spacing:.02em}
.contact-form input,.contact-form textarea,.contact-form select{
  width:100%;padding:13px 15px;border:1.5px solid var(--line-2);border-radius:12px;
  font-size:.94rem;color:var(--ink);background:#fff;transition:border-color var(--dur),box-shadow var(--dur);
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px rgba(29,161,242,.14)}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form button{
  width:100%;padding:15px;border-radius:var(--r-pill);
  background:var(--brand);color:#fff;font-size:.95rem;font-weight:800;
  border:none;cursor:pointer;transition:all var(--dur);box-shadow:var(--shadow-brand);
}
.contact-form button:hover{background:var(--brand-600);transform:translateY(-1px)}

/* ---------- About / values / timeline ---------- */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:48px}
.value-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-xs);transition:all var(--dur)}
.value-card:hover{border-color:var(--line-brand);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.value-card .ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;margin-bottom:18px}
.value-card h3{font-size:1.05rem;font-weight:800;margin-bottom:10px}
.value-card p{font-size:.92rem;color:var(--ink-2);line-height:1.7}
.timeline{margin-top:48px;max-width:780px;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;gap:18px}
.tl-item{display:grid;grid-template-columns:100px 1fr;gap:24px;padding:22px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-xs)}
.tl-year{font-size:1rem;font-weight:900;color:var(--brand)}
.tl-text{font-size:.94rem;color:var(--ink);line-height:1.7}
.tl-text strong{font-weight:800;color:var(--ink)}

/* ---------- Legal pages ---------- */
.legal-section{padding:64px 0 96px;background:#fff}
.legal-content{max-width:780px;margin:0 auto;color:var(--ink-2);line-height:1.85;font-size:.95rem}
.legal-content h2{font-size:1.4rem;font-weight:800;color:var(--ink);margin:40px 0 14px;letter-spacing:-.01em}
.legal-content h3{font-size:1.05rem;font-weight:800;color:var(--ink);margin:24px 0 10px}
.legal-content p{margin-bottom:14px}
.legal-content ul{margin:8px 0 16px 22px}
.legal-content li{margin-bottom:6px}
.legal-content a{color:var(--brand);font-weight:600}

/* ---------- Blog ---------- */
.blog-hero{padding:calc(var(--nav-h) + 64px) 0 56px;background:linear-gradient(180deg,#fff,var(--bg-soft));text-align:center}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.blog-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;
  box-shadow:var(--shadow-xs);transition:all var(--dur);
}
.blog-card:hover{border-color:var(--line-brand);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.blog-card .thumb{
  aspect-ratio:16/9;background:linear-gradient(135deg,var(--brand-50),var(--accent-50));
  display:flex;align-items:center;justify-content:center;font-size:3rem;
}
.blog-card .body{padding:22px 24px 26px}
.blog-card .meta{font-size:.74rem;color:var(--ink-3);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}
.blog-card h3{font-size:1.1rem;font-weight:800;line-height:1.35;margin-bottom:10px;color:var(--ink)}
.blog-card p{font-size:.88rem;color:var(--ink-2);line-height:1.6}

.article-hero{padding:calc(var(--nav-h) + 56px) 0 32px;background:#fff}
.article-hero .container{max-width:780px}
.article-meta{display:flex;align-items:center;gap:14px;font-size:.78rem;color:var(--ink-3);font-weight:700;margin-bottom:16px;text-transform:uppercase;letter-spacing:.06em}
.article-meta .author{display:inline-flex;align-items:center;gap:8px;color:var(--brand)}
.article-h1{font-family:var(--font-display);font-size:clamp(1.9rem,3.4vw,2.8rem);font-weight:900;line-height:1.15;letter-spacing:-.025em;color:var(--ink);margin-bottom:18px}
.article-lede{font-size:1.1rem;color:var(--ink-2);line-height:1.65}
.article-body{padding:32px 0 80px;background:#fff}
.article-body .container{max-width:760px}
.article-body h2{font-size:1.5rem;font-weight:800;margin:40px 0 14px;color:var(--ink);letter-spacing:-.015em}
.article-body h3{font-size:1.15rem;font-weight:800;margin:28px 0 10px;color:var(--ink)}
.article-body p{font-size:1rem;color:var(--ink-2);line-height:1.85;margin-bottom:18px}
.article-body ul,.article-body ol{margin:8px 0 22px 24px}
.article-body li{margin-bottom:8px;font-size:1rem;color:var(--ink-2);line-height:1.7}
.article-body blockquote{border-left:3px solid var(--brand);padding:8px 0 8px 18px;margin:24px 0;color:var(--ink);font-style:italic;font-size:1.05rem}
.article-body code{background:var(--bg-soft);padding:2px 6px;border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:.9em}
.article-body a{color:var(--brand);text-decoration:underline;text-underline-offset:2px}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);background:var(--bg-soft);padding:64px 0 32px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand .logo{display:flex;align-items:center;gap:10px;font-size:1.05rem;font-weight:900;margin-bottom:16px;color:var(--ink)}
.footer-brand .logo img{width:34px;height:34px;border-radius:10px}
.footer-brand .logo .ai{color:var(--brand)}
.footer-brand p{font-size:.88rem;color:var(--ink-2);line-height:1.7;max-width:300px;margin-bottom:18px}
.footer-brand .contact-mini{font-size:.84rem;color:var(--ink-2);display:flex;flex-direction:column;gap:6px}
.footer-brand .contact-mini a:hover{color:var(--brand)}
.footer-col h4{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.10em;color:var(--ink);margin-bottom:18px}
.footer-col a{display:block;font-size:.88rem;color:var(--ink-2);margin-bottom:12px;transition:color var(--dur)}
.footer-col a:hover{color:var(--brand)}
.footer-bottom{
  border-top:1px solid var(--line);padding-top:28px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-size:.82rem;color:var(--ink-3);
}
.footer-social{display:flex;gap:10px}
.footer-social a{width:34px;height:34px;border-radius:10px;background:#fff;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2);transition:all var(--dur)}
.footer-social a:hover{color:var(--brand);border-color:var(--line-brand);background:var(--brand-50)}

/* ---------- Utilities ---------- */
.text-center{text-align:center}
.mb-0{margin-bottom:0!important}
.mt-0{margin-top:0!important}
.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}
.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.items-center{align-items:center}.justify-center{justify-content:center}
.relative{position:relative}.z-1{z-index:1}

/* ---------- Animations on scroll ---------- */
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade-up.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:64px;text-align:center}
  .hero-copy .lede{margin-left:auto;margin-right:auto}
  .hero-ctas,.hero-trust{justify-content:center}
  .grid-3,.steps,.values-grid{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1.4fr 1fr 1fr;gap:32px}
  .feat-row{grid-template-columns:1fr;gap:40px}
  .feat-row.reverse .fb-copy,.feat-row.reverse .fb-art{order:initial}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:32px}
}
@media(max-width:760px){
  .nav-links,.nav-cta{display:none}
  .hamburger{display:inline-flex}
  .section,.section-lg{padding:72px 0}
  .grid-3,.grid-2,.steps,.values-grid,.pain-grid,.pricing-grid,.contact-grid,.blog-grid{grid-template-columns:1fr;gap:18px}
  .grid-4{grid-template-columns:1fr 1fr;gap:14px}
  .footer-top{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center}
  .cta-box{padding:44px 24px}
  .cta-btns{flex-direction:column;align-items:stretch}
  .cta-btns .btn{justify-content:center}
  .price-card.featured{transform:none}
}
