/* ─────────────────────────────────────────────────────────────────
   BINE LANDING — light-first themed redesign
   ───────────────────────────────────────────────────────────────── */

/* ============= TOKENS ============= */
:root{
  /* Brand (constant across themes) */
  --primary:#9109DF;
  --primary-light:#DC1FFF;
  --primary-dark:#7130F0;
  --grad-a:#DC1FFF;
  --grad-b:#9109DF;
  --grad-c:#7130F0;
  --accent-magenta:#DC1FFF;

  /* Light mode (default) */
  --bg:#FFFFFF;
  --bg-soft:#F7F6FB;
  --bg-2:#FAFAFC;
  --surface:#FFFFFF;
  --surface-2:#FBFAFD;

  --fg:#0B1020;
  --fg-2:#2E3548;
  --fg-3:#5A6379;
  --fg-4:#8A93A8;

  --border:rgba(15,20,40,.08);
  --border-strong:rgba(15,20,40,.14);
  --grid:rgba(15,20,40,.06);

  --card-bg:#FFFFFF;
  --card-border:rgba(15,20,40,.08);
  --card-shadow: 0 1px 2px rgba(15,20,40,.04), 0 14px 36px -16px rgba(15,20,40,.14);
  --card-shadow-lg: 0 1px 2px rgba(15,20,40,.04), 0 32px 60px -22px rgba(15,20,40,.20);
  --tip-bg:#FFFFFF;

  --eyebrow-bg:rgba(145,9,223,.10);
  --eyebrow-border:rgba(145,9,223,.28);
  --eyebrow-fg:#7C3AED;

  --nav-bg:rgba(255,255,255,.78);
  --nav-border:rgba(15,20,40,.10);

  --field-bg:#FFFFFF;
  --field-border:rgba(15,20,40,.12);

  --ambient-1:radial-gradient(900px 600px at 88% 8%,  rgba(220,31,255,.10), transparent 60%);
  --ambient-2:radial-gradient(900px 600px at 8% 100%, rgba(113,48,240,.10), transparent 60%);
  --ambient-3:radial-gradient(1200px 800px at 50% 50%, rgba(145,9,223,.06), transparent 70%);

  --r-sm:8px;
  --r-md:12px;
  --r-lg:16px;
  --r-xl:20px;
  --r-2xl:28px;

  --section-max:1180px;
  --gutter:clamp(20px, 4vw, 32px);
}

/* Dark mode */
[data-theme="dark"]{
  --bg:#0B1020;
  --bg-soft:#0E1326;
  --bg-2:#0B1020;
  --surface:#141938;
  --surface-2:#171C3D;

  --fg:#FFFFFF;
  --fg-2:#D8DEEC;
  --fg-3:#A6AEC2;
  --fg-4:#6E7791;

  --border:rgba(255,255,255,.10);
  --border-strong:rgba(255,255,255,.18);
  --grid:rgba(255,255,255,.06);

  --card-bg:rgba(255,255,255,.06);
  --card-border:rgba(255,255,255,.12);
  --card-shadow: 0 1px 2px rgba(0,0,0,.3), 0 14px 36px -16px rgba(0,0,0,.6);
  --card-shadow-lg: 0 30px 80px -30px rgba(0,0,0,.7);
  --tip-bg:rgba(11,16,32,.85);

  --eyebrow-bg:rgba(145,9,223,.14);
  --eyebrow-border:rgba(145,9,223,.32);
  --eyebrow-fg:#E9D5FF;

  --nav-bg:rgba(11,16,32,.65);
  --nav-border:rgba(255,255,255,.10);

  --field-bg:rgba(255,255,255,.05);
  --field-border:rgba(255,255,255,.14);

  --ambient-1:radial-gradient(1100px 700px at 88% 8%,  rgba(145,9,223,.22), transparent 60%);
  --ambient-2:radial-gradient(900px 600px at 8% 100%, rgba(113,48,240,.20), transparent 60%);
  --ambient-3:radial-gradient(1200px 800px at 50% 50%, rgba(113,48,240,.12), transparent 70%);
}

/* ============= BASE ============= */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; overflow-x:hidden; scroll-padding-top:96px; }
body{ overflow-x:hidden; }

html, body{ scrollbar-width:none; -ms-overflow-style:none; }
html::-webkit-scrollbar, body::-webkit-scrollbar{ width:0; height:0; display:none; }
.no-scrollbar{ scrollbar-width:none; -ms-overflow-style:none; }
.no-scrollbar::-webkit-scrollbar{ display:none; }

body{
  font-family:'Poppins', system-ui, -apple-system, Segoe UI, sans-serif;
  background:var(--bg);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background .25s ease, color .25s ease;
}

/* Arabic typography */
html[lang="ar"] body,
html[lang="ar"] input,
html[lang="ar"] button,
html[lang="ar"] textarea,
html[lang="ar"] select{
  font-family:'Cairo', 'Poppins', 'Segoe UI', Tahoma, Arial, sans-serif;
}

/* i18n line splitting — heading lines tagged with *.l1 / *.l2 each get their
   own row regardless of language. Inline-mixed titles use different suffixes. */
.hero-title > span[data-i18n],
.h2 > span[data-i18n$=".l1"],
.h2 > span[data-i18n$=".l2"]{ display:block; }
.hero-title{ text-wrap:balance; }

/* Banner is ALWAYS left-to-right, regardless of document language. */
.nav-wrap, .nav, .nav *{
  direction:ltr !important;
  text-align:left;
}
.nav .brand{ direction:ltr; }
/* Even when html is RTL, our fixed nav-wrap stays anchored to the visual left/right edges */
html[dir="rtl"] .nav-wrap{ direction:ltr; }

/* RTL: mirror horizontal-only flow where it matters */
/* Testimonials marquee always slides LTR regardless of document direction,
   but each card's INNER content inherits the document direction (so AR text
   inside cards reads RTL). */
.marquee, .marquee-track{ direction:ltr !important; }
html[dir="rtl"] .review{ direction:rtl; text-align:right; }
html[dir="rtl"] .gradient-text{ background-position:right center; }

.page-bg{
  position:fixed; inset:0; z-index:-1;
  background: var(--ambient-1), var(--ambient-2), var(--ambient-3), var(--bg);
  transition:background .3s ease;
}

.wrap{ max-width:var(--section-max); margin:0 auto; padding:0 var(--gutter); }

img, svg{ max-width:100%; }

/* ============= NAVBAR ============= */
.nav-wrap{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:14px var(--gutter);
  pointer-events:none;
}
.nav{
  max-width:var(--section-max); margin:0 auto;
  display:flex; align-items:center; gap:18px;
  height:62px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid var(--nav-border);
  background:var(--nav-bg);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 8px 28px -16px rgba(15,20,40,.12);
  pointer-events:auto;
  transition:transform .35s cubic-bezier(.4,.0,.2,1), box-shadow .25s ease, background .25s ease;
}
.nav.scrolled{
  box-shadow:0 14px 40px -18px rgba(15,20,40,.22);
}
/* Hero needs top padding so it doesn't slide under the fixed nav */
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:700; font-size:18px; letter-spacing:.2px;
  text-decoration:none; color:var(--fg);
}
.brand-mark{
  width:30px; height:30px; border-radius:8px;
  background:linear-gradient(135deg, #DC1FFF, #9109DF 55%, #7130F0);
  display:grid; place-items:center;
  box-shadow:0 8px 20px -8px rgba(145,9,223,.55), inset 0 1px 0 rgba(255,255,255,.25);
}
.brand-mark svg{ width:18px; height:18px; }
.brand-mark-img{ width:18px; height:18px; object-fit:contain; display:block; filter:brightness(0) invert(1); }
.nav-links{ display:flex; gap:2px; margin-left:14px; }
.nav-links a{
  color:var(--fg-2); text-decoration:none; font-size:14px; font-weight:500;
  padding:8px 12px; border-radius:10px;
  transition:color .2s ease, background .2s ease;
}
.nav-links a:hover{ color:var(--fg); background:rgba(145,9,223,.10); }
.nav-links a.active{
  color:var(--primary);
  background:rgba(145,9,223,.12);
}
[data-theme="dark"] .nav-links a.active{ color:#E9D5FF; background:rgba(145,9,223,.18); }
.nav-spacer{ flex:1; }
.nav-tools{ display:flex; align-items:center; gap:8px; }

.icon-btn{
  width:38px; height:38px; border-radius:11px;
  background:transparent;
  border:1px solid var(--border);
  display:grid; place-items:center;
  color:var(--fg-2); cursor:pointer;
  transition:background .2s ease, color .2s ease, border-color .2s ease;
}
.icon-btn:hover{ background:rgba(145,9,223,.10); color:var(--fg); border-color:var(--border-strong); }
.icon-btn svg{ width:16px; height:16px; }

/* Language toggle (EN / AR) */
.lang-toggle{
  position:relative;
  display:inline-flex; align-items:center;
  height:38px; padding:3px;
  border-radius:999px;
  background:var(--field-bg);
  border:1px solid var(--border);
  cursor:pointer;
  font-family:inherit;
  overflow:hidden;
  isolation:isolate;
}
.lang-toggle .lang-en, .lang-toggle .lang-ar{
  position:relative; z-index:2;
  display:grid; place-items:center;
  min-width:38px; height:30px; padding:0 10px;
  font-size:12px; font-weight:600; letter-spacing:.04em;
  color:var(--fg-3);
  transition:color .25s ease;
  user-select:none;
}
.lang-toggle .lang-ar{ font-family:'Poppins', 'Segoe UI', sans-serif; font-size:13px; letter-spacing:0; }
.lang-toggle .lang-sep{ display:none; }
.lang-toggle .lang-slider{
  position:absolute; z-index:1;
  top:3px; bottom:3px; left:3px;
  width:calc(50% - 3px);
  border-radius:999px;
  background:linear-gradient(135deg, #DC1FFF, #7C3AED);
  box-shadow:0 4px 12px -4px rgba(145,9,223,.6);
  transition:left .35s cubic-bezier(.4,.0,.2,1), width .35s cubic-bezier(.4,.0,.2,1);
}
.lang-toggle[data-lang="en"] .lang-en{ color:#fff; }
.lang-toggle[data-lang="ar"] .lang-ar{ color:#fff; }
.lang-toggle[data-lang="ar"] .lang-slider{ left:calc(50% + 0px); }
.lang-toggle:hover{ border-color:var(--border-strong); }

/* Hamburger toggle (visible on tablet/mobile only) */
.hamburger{
  display:none; /* shown by media query below */
  width:40px; height:40px;
  border-radius:11px;
  background:transparent;
  border:1px solid var(--border);
  align-items:center; justify-content:center;
  flex-direction:column; gap:5px;
  cursor:pointer;
  transition:background .2s ease, border-color .2s ease;
}
.hamburger:hover{ background:rgba(145,9,223,.10); border-color:var(--border-strong); }
.hamburger .hb-bar{
  display:block;
  width:18px; height:2px; border-radius:2px;
  background:var(--fg);
  transition:transform .3s cubic-bezier(.4,0,.2,1), opacity .25s ease;
  transform-origin:center;
}
.nav.menu-open .hamburger .hb-bar:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.menu-open .hamburger .hb-bar:nth-child(2){ opacity:0; transform:scaleX(.2); }
.nav.menu-open .hamburger .hb-bar:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Mobile dropdown menu */
.nav-mobile{
  max-width:var(--section-max);
  margin:8px auto 0;
  border-radius:18px;
  border:1px solid var(--nav-border);
  background:var(--nav-bg);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  box-shadow:0 18px 50px -20px rgba(15,20,40,.25);
  overflow:hidden;
  pointer-events:auto;
  /* hidden state */
  transform:translateY(-8px) scaleY(.96);
  transform-origin:top center;
  opacity:0;
  max-height:0;
  transition:opacity .25s ease, transform .3s cubic-bezier(.34,1.36,.64,1), max-height .35s ease;
}
.nav-mobile[hidden]{ display:none; }
.nav-mobile.open{
  opacity:1;
  transform:translateY(0) scaleY(1);
  max-height:540px;
}
.nav-mobile-inner{
  display:flex; flex-direction:column;
  padding:10px;
  gap:2px;
}
.nav-mobile-inner a{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px;
  border-radius:12px;
  color:var(--fg);
  text-decoration:none;
  font-size:15px; font-weight:500;
  transition:background .2s ease, color .2s ease, transform .2s ease;
}
.nav-mobile-inner a:hover{ background:rgba(145,9,223,.10); }
.nav-mobile-divider{
  height:1px; margin:8px 6px;
  background:var(--border);
}
.nav-mobile-inner .nm-secondary{
  color:var(--fg-2);
  background:var(--field-bg);
  margin-top:2px;
}
.nav-mobile-inner .nm-primary{
  background:linear-gradient(135deg, var(--primary-light) 0%, var(--primary) 60%, var(--primary-dark));
  color:#fff;
  font-weight:600;
  box-shadow:0 12px 28px -10px rgba(145,9,223,.55);
  margin-top:6px;
}
.nav-mobile-inner .nm-primary:hover{ background:linear-gradient(135deg, var(--primary-light) 0%, var(--primary) 50%, var(--primary-dark)); }
.nav-mobile-inner .nm-primary svg{ width:14px; height:14px; }
.nav-mobile-inner a svg{ width:14px; height:14px; opacity:.6; }
/* Sun/moon swap */
[data-theme="light"] .icon-btn .ic-sun{ display:none; }
[data-theme="light"] .icon-btn .ic-moon{ display:block; }
[data-theme="dark"]  .icon-btn .ic-sun{ display:block; }
[data-theme="dark"]  .icon-btn .ic-moon{ display:none; }

.ghost-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 14px; border-radius:11px;
  font-weight:500; font-size:14px; color:var(--fg);
  background:transparent; border:1px solid var(--border);
  text-decoration:none; cursor:pointer;
  transition:background .2s ease, border-color .2s ease, transform .15s ease;
}
.ghost-btn:hover{ background:rgba(145,9,223,.08); border-color:var(--border-strong); }
.ghost-btn.lg{ padding:13px 20px; font-size:15px; border-radius:13px; }

.cta-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:11px;
  font-weight:600; font-size:14px; color:#fff;
  background:linear-gradient(135deg, #DC1FFF, #7C3AED 60%, #7130F0);
  border:none; cursor:pointer; text-decoration:none;
  box-shadow:0 10px 24px -10px rgba(145,9,223,.55), inset 0 1px 0 rgba(255,255,255,.2);
  transition:transform .15s ease, box-shadow .2s ease, filter .2s ease;
}
.cta-btn:hover{ transform:translateY(-1px); box-shadow:0 16px 36px -12px rgba(145,9,223,.7); filter:brightness(1.04); }
.cta-btn.lg{ padding:14px 22px; font-size:15.5px; border-radius:13px; }
.cta-btn.lg svg{ width:16px; height:16px; }

/* Tablet & mobile: collapse desktop nav into hamburger menu */
@media (max-width: 980px){
  .nav-links{ display:none; }
  .nav .ghost-btn{ display:none; }
  .nav .cta-btn{ display:none; }
  .nav .nav-spacer{ display:none; }
  .hamburger{ display:inline-flex; }
  .nav{ padding:0 12px; gap:10px; }
}

/* ============= HERO ============= */
.hero{ position:relative; padding:128px 0 24px; isolation:isolate; }
.hero::before, .hero::after{
  content:""; position:absolute; pointer-events:none; z-index:-1;
  border-radius:50%; filter:blur(80px);
}
.hero::before{
  width:520px; height:520px;
  top:-100px; left:-160px;
  background:radial-gradient(circle, rgba(145,9,223,.22), transparent 65%);
}
.hero::after{
  width:600px; height:600px;
  top:60px; right:-200px;
  background:radial-gradient(circle, rgba(220,31,255,.18), transparent 65%);
}

.hero-inner{
  display:grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap:56px; align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 14px 6px 10px;
  border-radius:999px;
  background:var(--eyebrow-bg);
  border:1px solid var(--eyebrow-border);
  color:var(--eyebrow-fg);
  font-size:12.5px; font-weight:500;
  margin-bottom:22px;
}
.eyebrow .dot{
  width:7px; height:7px; border-radius:50%;
  background:#DC1FFF;
  box-shadow:0 0 0 4px rgba(145,9,223,.22);
}
.eyebrow .sep{ width:1px; height:12px; background:currentColor; opacity:.3; }
.eyebrow strong{ color:var(--eyebrow-fg); font-weight:700; }

h1.hero-title{
  font-size:clamp(38px, 5.4vw, 60px);
  line-height:1.05; letter-spacing:-.02em;
  font-weight:700; margin:0 0 22px;
  text-wrap:balance;
  color:var(--fg);
}
.gradient-text{
  background:linear-gradient(90deg, var(--grad-a), var(--grad-b) 50%, var(--grad-c));
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.hero-sub{
  color:var(--fg-3);
  font-size:17px; line-height:1.65;
  max-width:540px; margin:0 0 32px;
}
.cta-row{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:28px; align-items:center; }

.trust-row{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; color:var(--fg-3); font-size:13px; }
.avatars{ display:flex; }
.avatars .av{
  width:30px; height:30px; border-radius:50%;
  border:2px solid var(--bg);
  background-size:cover; background-position:center;
  margin-left:-8px;
}
.avatars .av:first-child{ margin-left:0; }
.stars{ color:#FBBF24; letter-spacing:1px; font-size:13px; }
.trust-row b{ color:var(--fg); font-weight:600; }

/* HERO CARDS GRID */
.hero-cards-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  align-items:start;
}

.hero-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-xl);
  padding:16px;
  box-shadow:var(--card-shadow);
}
[data-theme="dark"] .hero-card{
  background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
}

/* Overview card spans both columns */
.hc-overview{ grid-column:1 / -1; }

.hc-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.hc-title{ display:flex; align-items:center; gap:8px; font-weight:600; font-size:13.5px; }
.hc-pill{
  width:24px; height:24px; border-radius:7px;
  background:linear-gradient(135deg,var(--grad-a),var(--grad-c));
  display:grid; place-items:center;
}
.hc-pill svg{ width:13px; height:13px; }
.hc-tabs{ display:flex; gap:5px; font-size:11px; color:var(--fg-3); }
.hc-tabs span{ padding:4px 9px; border-radius:7px; background:var(--bg-soft); border:1px solid var(--border); }
.hc-tabs .on{ background:rgba(145,9,223,.14); border-color:rgba(145,9,223,.28); color:#7C3AED; }
[data-theme="dark"] .hc-tabs .on{ color:#E9D5FF; }
.hc-kpis{ display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-bottom:12px; }
.hc-kpi{ background:var(--bg-soft); border:1px solid var(--border); border-radius:10px; padding:9px 11px; }
.hc-kpi .lbl{ font-size:10px; color:var(--fg-3); font-weight:500; letter-spacing:.02em; text-transform:uppercase; }
.hc-kpi .val{ font-size:17px; font-weight:700; margin-top:3px; }
.hc-kpi .delta{ font-size:11px; font-weight:600; margin-top:2px; }
.hc-kpi .delta.up{ color:#10B981; }
.hc-kpi .delta.dn{ color:#EF4444; }
.hc-chart{ height:52px; border-radius:9px; overflow:hidden; }
.hc-chart svg{ width:100%; height:100%; display:block; }

/* Small stat cards (orders & revenue) */
.hc-label{ font-size:11px; color:var(--fg-3); font-weight:500; text-transform:uppercase; letter-spacing:.04em; margin-bottom:6px; }
.hc-num{ font-size:28px; font-weight:700; letter-spacing:-.02em; line-height:1; margin-bottom:8px; }
.hc-spark{ width:100%; height:38px; display:block; }
.hc-bars{ display:flex; align-items:flex-end; gap:4px; height:52px; margin-top:4px; }
.hc-bars i{ flex:1; border-radius:3px 3px 0 0; background:linear-gradient(to top,var(--grad-a),var(--grad-c)); display:block; }

/* Live feed card */
.hc-live-row{ display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.hc-pulse{
  width:8px; height:8px; border-radius:50%; flex-shrink:0;
  background:#10B981; box-shadow:0 0 0 3px rgba(16,185,129,.2);
  animation:pulse 2s infinite;
}
.hc-live-lbl{ font-size:13px; font-weight:600; color:var(--fg); flex:1; }
.hc-live-count{ font-size:12px; color:var(--fg-3); white-space:nowrap; }
.hc-live-count b{ color:var(--fg); }
.hc-events{ display:flex; flex-direction:column; gap:7px; }
.hc-ev{ display:flex; align-items:center; gap:8px; }
.hc-ev-ico{
  width:26px; height:26px; border-radius:8px; flex-shrink:0;
  background:rgba(147,51,234,.1); display:grid; place-items:center;
}
.hc-ev-ico.blue{ background:rgba(37,99,235,.1); }
.hc-ev-ico svg{ width:13px; height:13px; }
.hc-ev-txt{ font-size:12px; color:var(--fg-2); flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.hc-ev-amt{ font-size:12px; font-weight:600; color:#10B981; white-space:nowrap; }

/* HERO ART (legacy floating cards, kept for reference) */
.hero-art{ position:relative; height:520px; min-width:0; }
.float-card{
  position:absolute;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-xl);
  box-shadow:var(--card-shadow);
}
[data-theme="dark"] .float-card{
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
}
.dash{ top:30px; left:6%; right:6%; padding:18px; animation:float1 9s ease-in-out infinite; }
.dash-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.dash-title{ display:flex; align-items:center; gap:10px; font-weight:600; font-size:14px; }
.dash-title .pill{
  width:24px; height:24px; border-radius:7px;
  background:linear-gradient(135deg, var(--grad-a), var(--grad-c));
  display:grid; place-items:center;
}
.dash-title .pill svg{ width:13px; height:13px; }
.dash-tabs{ display:flex; gap:6px; font-size:11px; color:var(--fg-3); }
.dash-tabs span{ padding:5px 10px; border-radius:8px; background:var(--bg-soft); border:1px solid var(--border); }
.dash-tabs .on{ background:rgba(145,9,223,.14); border-color:rgba(145,9,223,.28); color:#7C3AED; }
[data-theme="dark"] .dash-tabs .on{ color:#E9D5FF; }
.kpis{ display:grid; grid-template-columns:repeat(3, 1fr); gap:10px; margin-bottom:14px; }
.kpi{ background:var(--bg-soft); border:1px solid var(--border); border-radius:12px; padding:10px 12px; }
.kpi .lbl{ font-size:10.5px; color:var(--fg-3); font-weight:500; letter-spacing:.02em; text-transform:uppercase; }
.kpi .val{ font-size:18px; font-weight:700; margin-top:4px; }
.kpi .delta{ font-size:11px; font-weight:600; margin-top:2px; }
.kpi .delta.up{ color:#10B981; }
.kpi .delta.dn{ color:#EF4444; }
.chart{
  position:relative; height:140px; border-radius:12px;
  background:linear-gradient(180deg, rgba(145,9,223,.04), rgba(113,48,240,.03));
  border:1px solid var(--border);
  padding:10px 12px 6px;
  overflow:hidden;
}
.chart svg{ width:100%; height:100%; display:block; }

.tile-orders{ width:200px; top:0; right:-10px; padding:14px; animation:float2 11s ease-in-out infinite; }
.tile-orders .ttl{ font-size:11px; color:var(--fg-3); font-weight:500; text-transform:uppercase; letter-spacing:.04em; }
.tile-orders .num{ font-size:26px; font-weight:700; margin-top:6px; line-height:1; letter-spacing:-.02em; }
.spark{ height:36px; margin-top:8px; }

.tile-live{ width:220px; bottom:30px; left:-10px; padding:14px; animation:float3 13s ease-in-out infinite; }
.live-row{ display:flex; align-items:center; gap:10px; }
.live-row .pulse{
  width:9px; height:9px; border-radius:50%;
  background:#10B981;
  box-shadow:0 0 0 0 rgba(16,185,129,.5);
  animation:pulse 2.2s ease-out infinite;
}
.live-row .lbl{ font-size:11px; color:var(--fg-3); text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
.live-row .right{ margin-left:auto; font-size:12px; color:var(--fg-3); }
.live-row .right b{ color:var(--fg); font-weight:600; }
.events{ margin-top:10px; display:flex; flex-direction:column; gap:6px; }
.ev{ display:flex; align-items:center; gap:8px; font-size:12px; }
.ev .ico{
  width:22px; height:22px; border-radius:7px; display:grid; place-items:center;
  background:rgba(145,9,223,.14); border:1px solid rgba(145,9,223,.25);
}
.ev .ico.ev-blue{ background:rgba(113,48,240,.14); border-color:rgba(113,48,240,.28); }
.ev .ico svg{ width:11px; height:11px; }
.ev .txt{ color:var(--fg-2); }
.ev .amt{ margin-left:auto; font-weight:600; font-size:11.5px; color:var(--fg); }

.tile-rev{ width:180px; bottom:-10px; right:14px; padding:14px; animation:float2 10s ease-in-out infinite reverse; }
.tile-rev .ttl{ font-size:11px; color:var(--fg-3); font-weight:500; text-transform:uppercase; letter-spacing:.04em; }
.tile-rev .num{
  font-size:22px; font-weight:700; margin-top:6px; line-height:1; letter-spacing:-.02em;
  background:linear-gradient(90deg, var(--grad-a), var(--grad-c));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.tile-rev .bars{ display:flex; align-items:flex-end; gap:5px; height:34px; margin-top:10px; }
.tile-rev .bars i{
  flex:1; display:block;
  background:linear-gradient(180deg, rgba(145,9,223,.85), rgba(113,48,240,.55));
  border-radius:3px;
}

@keyframes float1 { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-8px); } }
@keyframes float2 { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }
@keyframes float3 { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(10px); } }
@keyframes pulse { 0%{ box-shadow:0 0 0 0 rgba(16,185,129,.5);} 70%{ box-shadow:0 0 0 10px rgba(16,185,129,0);} 100%{ box-shadow:0 0 0 0 rgba(16,185,129,0);} }

@media (max-width: 980px){
  .hero{ padding-top:32px; }
  .hero-inner{ grid-template-columns:1fr; gap:36px; }
  .hero-art{ height:480px; }
  .tile-orders{ right:0; }
  .tile-rev{ right:0; }
  .hero-cards-grid{ grid-template-columns:1fr 1fr; }
  .hc-overview{ grid-column:1 / -1; }
}
@media (max-width: 600px){
  .hero-art{ height:440px; }
  .tile-orders{ width:170px; right:0; }
  .tile-rev{ width:155px; right:0; bottom:-4px; }
  .tile-live{ width:200px; left:0; }
  .hero-cards-grid{ grid-template-columns:1fr; }
  .hc-overview{ grid-column:auto; }
}

/* ============= SECTION SHELL ============= */
section{ padding:88px 0; position:relative; }
.section-head{ text-align:center; max-width:680px; margin:0 auto 48px; }
.kicker{
  display:inline-block;
  font-size:12px; font-weight:600;
  color:var(--eyebrow-fg);
  background:var(--eyebrow-bg);
  border:1px solid var(--eyebrow-border);
  padding:5px 12px; border-radius:999px;
  letter-spacing:.04em; text-transform:uppercase;
  margin-bottom:14px;
}
.h2{
  font-size:clamp(28px, 3.4vw, 42px);
  line-height:1.15; font-weight:700;
  letter-spacing:-.015em; margin:0 0 14px;
  text-wrap:balance;
}
.sub{ color:var(--fg-3); font-size:16px; line-height:1.6; max-width:560px; margin:0 auto; }

/* ============= ECOSYSTEM (image recreation) ============= */
.ecosystem{ padding-bottom:48px; }
.orbit{
  position:relative;
  width:100%;
  max-width:1100px;
  margin:0 auto;
  aspect-ratio: 1100 / 900;
}
.orbit-lines{
  position:absolute; inset:0; width:100%; height:100%;
  z-index:1; pointer-events:none;
  overflow:visible;
}
.orbit-lines .ol-path{
  fill:none;
  stroke:#E91FFF;
  stroke-width:2;
  stroke-dasharray:5 7;
  stroke-linecap:round;
  opacity:0;
  stroke-dashoffset:200;
  animation:olDraw 1.1s cubic-bezier(.4,.0,.2,1) forwards, olFlow 14s linear infinite;
  animation-delay:calc(.4s + var(--idx,0) * .12s), calc(1.5s + var(--idx,0) * .12s);
  filter:drop-shadow(0 0 6px rgba(233,31,255,.35));
}
.orbit-lines .ol-dot{
  fill:#fff;
  stroke:#E91FFF;
  stroke-width:2;
  opacity:0;
  transform-origin:center;
  transform-box:fill-box;
  animation:olDotIn .5s cubic-bezier(.34,1.56,.64,1) forwards, olPulse 2.6s ease-in-out infinite;
  animation-delay:calc(.6s + var(--idx,0) * .12s), calc(1.4s + var(--idx,0) * .25s);
  filter:drop-shadow(0 0 6px rgba(233,31,255,.45));
}
@keyframes olDraw{
  from{ opacity:0; stroke-dashoffset:200; }
  to  { opacity:.9; stroke-dashoffset:0; }
}
@keyframes olFlow{
  to{ stroke-dashoffset:-240; }
}
@keyframes olDotIn{
  from{ opacity:0; transform:scale(.2); }
  to  { opacity:1; transform:scale(1); }
}
@keyframes olPulse{
  0%,100% { transform:scale(1); }
  50%     { transform:scale(1.25); }
}
[data-theme="dark"] .orbit-lines .ol-path{ stroke:#F22FFF; }
[data-theme="dark"] .orbit-lines .ol-dot{ stroke:#F22FFF; fill:#1a0830; }

/* Cube (3D) */
.orbit-cube{
  --cube-size:168px;
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%, -50%);
  z-index:3;
  width:var(--cube-size); height:var(--cube-size);
  perspective:900px;
  perspective-origin:50% 30%;
}
.cube-shadow{
  position:absolute;
  left:50%; bottom:-26px;
  transform:translateX(-50%);
  width:80%; height:30px;
  border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(110,34,230,.45), transparent 70%);
  filter:blur(10px);
  z-index:0;
  animation:cubeShadow 6s ease-in-out infinite;
}
.cube-scene{
  position:relative; z-index:1;
  width:100%; height:100%;
  transform-style:preserve-3d;
  animation:cubeFloat 6s ease-in-out infinite, cubeSpin 22s linear infinite;
}
.cube{
  position:relative;
  width:100%; height:100%;
  transform-style:preserve-3d;
  transform:rotateX(-18deg) rotateY(-24deg);
}
.cube-face{
  position:absolute;
  inset:0;
  border-radius:34px;
  background:
    radial-gradient(140% 110% at 30% 10%, #D49BFF 0%, #DC1FFF 22%, #7C3AED 50%, #4F1FB8 100%);
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.45),
    inset 0 -8px 24px rgba(50,0,110,.55);
}
.cube-face.cf-front{
  transform:translateZ(calc(var(--cube-size) / 2));
  display:grid; place-items:center;
}
.cube-face.cf-back{
  transform:rotateY(180deg) translateZ(calc(var(--cube-size) / 2));
  background:
    radial-gradient(140% 110% at 70% 90%, #C684FF 0%, #9109DF 30%, #5F1FCB 70%, #3E0B95 100%);
}
.cube-face.cf-right{
  transform:rotateY(90deg) translateZ(calc(var(--cube-size) / 2));
  background:
    linear-gradient(135deg, #9109DF 0%, #5F1FCB 60%, #3E0B95 100%);
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.25),
    inset 0 -8px 24px rgba(40,0,90,.6);
}
.cube-face.cf-left{
  transform:rotateY(-90deg) translateZ(calc(var(--cube-size) / 2));
  background:
    linear-gradient(135deg, #DC1FFF 0%, #9109DF 50%, #5A1CC0 100%);
}
.cube-face.cf-top{
  transform:rotateX(90deg) translateZ(calc(var(--cube-size) / 2));
  background:
    radial-gradient(140% 110% at 50% 0%, #E0B6FF 0%, #DC1FFF 30%, #9109DF 70%);
  box-shadow:
    inset 0 4px 0 rgba(255,255,255,.55),
    inset 0 -6px 18px rgba(60,0,130,.4);
}
.cube-face.cf-bottom{
  transform:rotateX(-90deg) translateZ(calc(var(--cube-size) / 2));
  background:
    radial-gradient(140% 110% at 50% 100%, #5F1FCB 0%, #3E0B95 50%, #29066F 100%);
}
.cube-face.cf-front::before{
  content:"";
  position:absolute; inset:0;
  border-radius:inherit;
  background:
    radial-gradient(70% 50% at 28% 15%, rgba(255,220,255,.45), transparent 70%),
    radial-gradient(40% 30% at 82% 8%, rgba(255,255,255,.32), transparent 70%);
  pointer-events:none;
}
.cube-face.cf-front::after{
  content:"";
  position:absolute;
  top:7%; left:10%; right:10%; height:14%;
  background:linear-gradient(180deg, rgba(255,255,255,.55), transparent);
  border-radius:50%;
  filter:blur(6px);
  pointer-events:none;
}
.cube-face.cf-front svg{
  width:48%; height:48%;
  position:relative; z-index:1;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.18));
}
.cube-logo{
  position:absolute; inset:16px;
  width:calc(100% - 32px); height:calc(100% - 32px);
  object-fit:contain;
  border-radius:18px;
  z-index:1;
  filter:brightness(0) invert(1) drop-shadow(0 4px 10px rgba(0,0,0,.18));
}

@keyframes cubeFloat {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-10px); }
}
@keyframes cubeSpin {
  /* gentle continuous rotation — tilt stays via .cube transform; we wobble the scene */
  0%   { transform:translateY(0) rotateY(0deg); }
  50%  { transform:translateY(-10px) rotateY(8deg); }
  100% { transform:translateY(0) rotateY(0deg); }
}
@keyframes cubeShadow {
  0%,100% { transform:translateX(-50%) scale(1); opacity:.7; }
  50%     { transform:translateX(-50%) scale(.85); opacity:.5; }
}

/* Orbit cards — common */
.orbit-card{
  position:absolute;
  background:var(--surface);
  border:1px solid var(--card-border);
  border-radius:18px;
  box-shadow:var(--card-shadow-lg);
  padding:18px 18px 16px;
  z-index:2;
  width:min(28%, 320px);
  min-width:240px;
}
[data-theme="dark"] .orbit-card{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.orbit-card .oc-title{ font-size:14px; font-weight:600; color:var(--fg); margin-bottom:14px; }

/* Positions */
.oc-roas    { top:0;       left:23%;  width:30%; min-width:260px; animation:cardFloatA 7s ease-in-out infinite; }
.oc-flow    { top:0;       right:0;   width:30%; min-width:260px; animation:cardFloatB 8s ease-in-out infinite; }
.oc-best    { top:42%;     left:0;    width:26%; min-width:240px; animation:cardFloatA 9s ease-in-out infinite reverse; }
.oc-margin  { top:48%;     right:0;   width:24%; min-width:230px; animation:cardFloatB 7.5s ease-in-out infinite reverse; }
.oc-profit  { bottom:0;    left:30%;  width:40%; min-width:300px; animation:cardFloatA 8.5s ease-in-out infinite; }

@keyframes cardFloatA { 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-8px);} }
@keyframes cardFloatB { 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(8px);} }

/* ROAS card */
.oc-roas .oc-row{ display:flex; align-items:center; gap:10px; margin-top:8px; }
.oc-roas .oc-brand{ width:26px; height:26px; flex:none; border-radius:50%; overflow:hidden; }
.oc-roas .oc-brand svg{ width:100%; height:100%; display:block; }
.oc-roas .oc-name{ flex:1; font-size:13px; color:var(--fg-2); font-weight:500; }
.oc-roas .oc-val{ font-size:13.5px; font-weight:700; color:#7C3AED; }
[data-theme="dark"] .oc-roas .oc-val{ color:#C084FC; }
.oc-roas .oc-bar{ height:5px; border-radius:99px; background:var(--bg-soft); margin-top:6px; overflow:hidden; }
.oc-roas .oc-bar i{ display:block; height:100%; background:linear-gradient(90deg,#9109DF,#7C3AED); border-radius:99px; }

/* Order flow card */
.oc-flow .flow-row{
  display:flex; align-items:center; gap:12px;
  padding:6px 0;
}
.oc-flow .flow-ico{
  width:30px; height:30px; border-radius:50%;
  display:grid; place-items:center; flex:none;
}
.oc-flow .flow-ico svg{ width:15px; height:15px; }
.oc-flow .flow-name{ flex:1; font-size:13.5px; color:var(--fg-2); font-weight:500; }
.oc-flow .flow-pill{
  min-width:34px; padding:3px 8px; border-radius:9px;
  border:1px solid var(--border);
  font-size:12.5px; font-weight:600; text-align:center;
  color:var(--fg);
  background:var(--surface-2);
}

/* Best campaign card */
.oc-best .best-row{ display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.oc-best .best-av{ width:42px; height:42px; border-radius:50%; overflow:hidden; flex:none; }
.oc-best .best-av svg{ width:100%; height:100%; display:block; }
.oc-best .best-name{ font-size:13.5px; font-weight:600; color:var(--fg); }
.oc-best .best-sub{ font-size:11.5px; color:var(--fg-3); margin-top:2px; }
.oc-best .best-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px 18px; padding-top:8px; border-top:1px solid var(--border); }
.oc-best .best-lbl{ font-size:11px; color:var(--fg-3); }
.oc-best .best-val{ font-size:16px; font-weight:700; color:#7C3AED; margin-top:2px; letter-spacing:-.01em; }
[data-theme="dark"] .oc-best .best-val{ color:#C084FC; }

/* Profit Margin card */
.oc-margin .margin-head{ display:flex; align-items:baseline; gap:12px; }
.oc-margin .margin-val{ font-size:30px; font-weight:700; letter-spacing:-.02em; color:var(--fg); }
.oc-margin .margin-delta{ font-size:12.5px; font-weight:600; color:#10B981; }
.oc-margin .margin-sub{ font-size:11.5px; color:var(--fg-3); margin-top:2px; }
.oc-margin .margin-chart{ width:100%; height:62px; margin-top:8px; display:block; }

/* Total Profit card */
.oc-profit .margin-head{ display:flex; align-items:baseline; gap:14px; }
.oc-profit .profit-val{ font-size:32px; font-weight:700; letter-spacing:-.02em; color:var(--fg); }
.oc-profit .margin-delta{ font-size:13px; font-weight:600; color:#10B981; }
.oc-profit .margin-sub{ font-size:11.5px; color:var(--fg-3); margin-top:2px; }
.oc-profit .profit-chart-wrap{ position:relative; margin-top:8px; }
.oc-profit .profit-chart-wrap svg{ width:100%; height:72px; display:block; }
.oc-profit .profit-tip{
  position:absolute;
  right:0; top:-6px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  padding:5px 8px;
  font-size:10.5px;
  box-shadow:0 8px 22px -10px rgba(15,20,40,.16);
}
.oc-profit .profit-tip .t1{ color:var(--fg-3); }
.oc-profit .profit-tip .t2{ color:#7C3AED; font-weight:700; margin-top:1px; }
[data-theme="dark"] .oc-profit .profit-tip .t2{ color:#C084FC; }

/* Responsive orbit */
@media (max-width: 980px){
  .orbit{
    aspect-ratio:auto; height:auto; max-width:760px;
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:14px;
  }
  .orbit-lines{ display:none; }
  /* Hide the 3D cube on tablet/mobile — cards become the focus */
  .orbit-cube{ display:none; }
  .orbit-card{
    position:relative; inset:auto !important;
    width:100% !important; min-width:0 !important;
    margin-bottom:0;
    animation:none;
  }
  .oc-roas, .oc-flow, .oc-best, .oc-margin, .oc-profit{ left:auto; right:auto; top:auto; bottom:auto; }
  /* Total Profit card spans full row to hold its long chart */
  .oc-profit{ grid-column:1 / -1; }
}
@media (max-width: 560px){
  .orbit{ grid-template-columns:1fr; }
  .oc-profit{ grid-column:auto; }
}

/* ============= FEATURES ============= */
.features-grid{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:18px; }
@media (max-width: 900px){ .features-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width: 560px){ .features-grid{ grid-template-columns:1fr; } }
.feat{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-xl);
  padding:26px;
  box-shadow:var(--card-shadow);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.feat:hover{ transform:translateY(-4px); border-color:var(--border-strong); box-shadow:var(--card-shadow-lg); }
.feat-ico{
  width:52px; height:52px; border-radius:14px;
  background:linear-gradient(135deg, #DC1FFF, #7130F0);
  display:grid; place-items:center;
  margin-bottom:18px;
  box-shadow:0 10px 22px -10px rgba(145,9,223,.6);
}
.feat-ico svg{ width:22px; height:22px; color:#fff; }
.feat h3{ font-size:18px; font-weight:600; margin:0 0 8px; color:var(--fg); }
.feat p{ font-size:14.5px; color:var(--fg-3); line-height:1.6; margin:0; }

/* ============= ANALYTICS SHOWCASE ============= */
.showcase{ display:grid; grid-template-columns:1fr 1.05fr; gap:56px; align-items:center; }
@media (max-width: 900px){ .showcase{ grid-template-columns:1fr; gap:36px; } }
.showcase-text h2{ margin-top:0; }
.stat-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:28px; }
.stat{ background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--r-md); padding:14px; box-shadow:var(--card-shadow); }
.stat .v{ font-size:24px; font-weight:700; letter-spacing:-.02em;
  background:linear-gradient(90deg, var(--grad-a), var(--grad-c));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .l{ font-size:12px; color:var(--fg-3); margin-top:4px; }

.showcase-vis{
  position:relative;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  padding:22px;
  box-shadow:var(--card-shadow-lg);
}
.showcase-vis .head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.showcase-vis .head h4{ margin:0; font-size:15px; font-weight:600; color:var(--fg); }
.showcase-vis .head .legend{ display:flex; gap:12px; font-size:11.5px; color:var(--fg-3); }
.showcase-vis .head .legend span{ display:inline-flex; align-items:center; gap:6px; }
.showcase-vis .head .legend i{ width:9px; height:9px; border-radius:3px; }
.showcase-chart{ height:240px; border-radius:14px; background:var(--bg-soft); border:1px solid var(--border); padding:10px; }
.showcase-chart svg{ width:100%; height:100%; }
.minirow{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:14px; }
.mini{ background:var(--bg-soft); border:1px solid var(--border); border-radius:12px; padding:12px 14px; }
.mini .t{ font-size:11.5px; color:var(--fg-3); text-transform:uppercase; letter-spacing:.04em; font-weight:600; }
.mini .n{ font-size:18px; font-weight:700; margin-top:4px; color:var(--fg); }
.mini .delta{ font-size:11px; margin-top:2px; color:#10B981; font-weight:600; }

/* ============= INTEGRATIONS ============= */
.integrations .int-group{ margin-bottom:42px; }
.integrations .int-group:last-child{ margin-bottom:0; }
.int-head{ text-align:center; margin-bottom:22px; }
.int-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:999px;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  box-shadow:var(--card-shadow);
  font-size:13.5px; font-weight:600; color:var(--fg);
}
.int-pill svg{ width:15px; height:15px; color:#7C3AED; }
.int-sub{ font-size:14px; color:var(--fg-3); margin-top:10px; max-width:520px; margin-left:auto; margin-right:auto; }
.int-grid{
  display:grid;
  grid-template-columns:repeat(6, minmax(0,1fr));
  gap:14px;
}
@media (max-width: 900px){ .int-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width: 560px){ .int-grid{ grid-template-columns:repeat(2,1fr); } }
.int-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-lg);
  padding:18px 14px 16px;
  text-align:center;
  box-shadow:var(--card-shadow);
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.int-card:hover{ transform:translateY(-3px); border-color:var(--border-strong); box-shadow:var(--card-shadow-lg); }
.int-logo{ width:64px; height:40px; margin:0 auto 10px; }
.int-logo svg{ width:100%; height:100%; display:block; border-radius:8px; }
.int-logo img{ width:100%; height:100%; display:block; object-fit:contain; }
.int-name{ font-size:13.5px; font-weight:600; color:var(--fg); }

/* ============= CALCULATOR ============= */
.calc{ padding:64px 0; }
.calc-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  padding:40px clamp(24px, 4vw, 56px);
  box-shadow:var(--card-shadow-lg);
  display:grid; grid-template-columns:1fr 1fr; gap:42px;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.calc-card::before{
  content:"";
  position:absolute;
  top:-60px; right:-60px;
  width:280px; height:280px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(145,9,223,.18), transparent 70%);
  pointer-events:none;
}
.calc-cta-row{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.calc-note{ font-size:13px; color:var(--fg-3); }

.calc-mock{
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px;
}
.calc-mock-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.calc-mock-title{ font-size:13.5px; font-weight:600; color:var(--fg); }
.calc-mock-tag{
  font-size:10.5px; font-weight:600; color:#10B981;
  background:rgba(16,185,129,.12); padding:3px 8px; border-radius:99px;
  border:1px solid rgba(16,185,129,.22);
}
.calc-mock-grid{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.calc-field{
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 14px;
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:12px;
}
.calc-field span{ font-size:12px; color:var(--fg-3); }
.calc-field b{ font-size:14.5px; font-weight:700; color:var(--fg); }
.calc-mock-result{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:10px;
  background:linear-gradient(135deg, rgba(145,9,223,.10), rgba(113,48,240,.06));
  border:1px solid rgba(145,9,223,.20);
  border-radius:14px;
  padding:14px;
}
.calc-r-l{ font-size:11px; color:var(--fg-3); font-weight:500; }
.calc-r-v{ font-size:18px; font-weight:700; letter-spacing:-.01em; margin-top:2px;
  background:linear-gradient(90deg, var(--grad-a), var(--grad-c));
  -webkit-background-clip:text; background-clip:text; color:transparent; }
@media (max-width: 900px){ .calc-card{ grid-template-columns:1fr; padding:32px 24px; } }

/* ============= PRICING ============= */
.billing-toggle{
  display:inline-flex; gap:4px; padding:4px;
  background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:999px;
  margin-top:20px;
}
.bt-opt{
  padding:8px 16px; border-radius:99px;
  font-size:13px; font-weight:600;
  color:var(--fg-3); background:transparent;
  border:none; cursor:pointer;
  display:inline-flex; align-items:center; gap:6px;
  transition:color .2s ease, background .2s ease;
}
.bt-opt.on{ background:var(--surface); color:var(--fg); box-shadow:0 2px 8px rgba(15,20,40,.08); }
.bt-tag{ font-size:10px; font-weight:700; background:#10B981; color:#fff; padding:2px 6px; border-radius:99px; }

.pricing-grid{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr));
  gap:20px; align-items:start;
}
@media (max-width: 900px){ .pricing-grid{ grid-template-columns:1fr; max-width:440px; margin:0 auto; } }
.price-skel{
  height:520px; border-radius:var(--r-xl);
  background:var(--bg-soft);
  border:1px solid var(--border);
  animation:skel 1.5s ease-in-out infinite;
}
@keyframes skel{ 0%,100%{ opacity:.55; } 50%{ opacity:.8; } }

.price-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-xl);
  padding:28px 24px 24px;
  display:flex; flex-direction:column;
  box-shadow:var(--card-shadow);
  position:relative;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.price-card:hover{ transform:translateY(-3px); box-shadow:var(--card-shadow-lg); }

/* Header */
.price-name{ font-size:24px; font-weight:800; color:var(--fg); line-height:1.2; }
.price-tagline{ font-size:13px; font-weight:700; color:#22C55E; margin-top:5px; line-height:1.4; }
.price-desc{ font-size:13px; color:var(--fg-3); margin-top:2px; line-height:1.4; }

/* Price block */
.price-amount-block{ margin:20px 0 0; }
.price-amount-row{ display:flex; align-items:baseline; gap:6px; flex-wrap:wrap; }
.price-original{
  font-size:16px; font-weight:500;
  color:var(--fg-3);
  text-decoration:line-through;
  text-decoration-color:var(--fg-3);
}
.price-num-purple{
  font-size:52px; font-weight:900; letter-spacing:-.04em;
  color:#5B21B6; line-height:1;
}
.price-period-inline{ font-size:14px; color:var(--fg-3); padding-bottom:4px; }
.price-billed-yearly{ font-size:12px; color:var(--fg-3); margin-top:4px; }

/* Limits */
.price-limits{ display:flex; flex-direction:column; gap:8px; margin-top:16px; }
.price-limit-row{ display:flex; align-items:center; gap:8px; font-size:14px; color:var(--fg); }
.price-limit-row strong{ font-weight:600; }
.price-limit-row svg{ color:var(--fg-3); flex-shrink:0; }

/* CTA button */
.price-trial-btn{
  display:flex; align-items:center; justify-content:center;
  width:100%; padding:14px 20px;
  margin-top:20px;
  font-size:15px; font-weight:700; color:var(--fg);
  background:transparent;
  border:1.5px solid var(--border-strong);
  border-radius:12px;
  cursor:pointer; text-decoration:none;
  transition:background .2s ease, border-color .2s ease;
}
.price-trial-btn:hover{ background:rgba(0,0,0,.04); border-color:var(--fg-3); }

/* Divider */
.price-divider{ height:1px; background:var(--border); margin:20px 0 16px; opacity:.7; }

/* Feature groups */
.price-group{ margin-bottom:14px; }
.price-group-header{
  display:flex; align-items:center; gap:6px;
  font-size:13.5px; font-weight:700; color:var(--fg);
  margin-bottom:10px; line-height:1.3;
}
.price-group-header svg{ color:var(--fg-2); }
.price-features{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.price-features li{ display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--fg-3); line-height:1.45; }
.price-features li svg{ width:16px; height:16px; flex:none; margin-top:2px; }

/* ============= TESTIMONIALS ============= */
.marquee{
  position:relative; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track{ display:flex; gap:18px; width:max-content; animation:marquee 50s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ from{ transform:translateX(0); } to { transform:translateX(-50%); } }
.review{
  width:340px; flex:none;
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-xl);
  padding:22px;
  box-shadow:var(--card-shadow);
}
.review .stars{ color:#FBBF24; font-size:13px; margin-bottom:10px; letter-spacing:2px; }
.review p{ font-size:14.5px; line-height:1.6; color:var(--fg-2); margin:0 0 16px; min-height:88px; }
.review .who{ display:flex; align-items:center; gap:10px; }
.review .who .av{ width:36px; height:36px; border-radius:50%; background-size:cover; background-position:center; border:1px solid var(--border); }
.review .who .name{ font-weight:600; color:#7C3AED; font-size:14px; }
[data-theme="dark"] .review .who .name{ color:#C084FC; }
.review .who .role{ color:var(--fg-3); font-size:12px; }

/* ============= COMPANION APP ============= */
.app-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  padding:48px clamp(24px, 4vw, 56px);
  display:grid; grid-template-columns:1fr 1fr; gap:42px;
  align-items:center;
  box-shadow:var(--card-shadow-lg);
  position:relative;
  overflow:hidden;
}
.app-card::before{
  content:""; position:absolute;
  bottom:-80px; left:-80px;
  width:340px; height:340px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(113,48,240,.18), transparent 70%);
  pointer-events:none;
}
.store-btn{
  display:inline-flex; align-items:center; gap:12px;
  padding:12px 18px; border-radius:14px;
  background:#0B1020; color:#fff;
  text-decoration:none;
  box-shadow:0 10px 24px -10px rgba(0,0,0,.35);
  transition:transform .15s ease, box-shadow .2s ease;
}
.store-btn:hover{ transform:translateY(-2px); box-shadow:0 18px 38px -14px rgba(145,9,223,.45); }
.store-btn .glyph{ width:24px; height:24px; flex:none; }
.store-btn .glyph path[fill="#0B1020"]{ fill:#fff; }
.store-btn .labels{ display:flex; flex-direction:column; line-height:1.05; }
.store-btn .top{ font-size:10px; font-weight:400; color:#A6AEC2; text-transform:uppercase; letter-spacing:.06em; }
.store-btn .bot{ font-size:15px; font-weight:700; }

/* Phone mock */
.app-vis{ display:flex; justify-content:center; }
.phone{
  width:280px; height:560px;
  background:#0B1020;
  border-radius:42px;
  border:8px solid #1B2240;
  padding:14px 14px;
  position:relative;
  box-shadow:0 40px 60px -20px rgba(15,20,40,.4);
}
.phone-notch{
  position:absolute; top:18px; left:50%; transform:translateX(-50%);
  width:110px; height:24px; border-radius:99px;
  background:#000;
}
.phone-screen{
  background:linear-gradient(180deg, #9109DF 0%, #7130F0 100%);
  border-radius:28px;
  height:100%; padding:36px 18px 18px;
  display:flex; flex-direction:column;
  color:#fff; overflow:hidden;
}
.ph-head{ display:flex; align-items:center; justify-content:space-between; }
.ph-hello{ font-size:11.5px; color:rgba(255,255,255,.7); }
.ph-name{ font-size:17px; font-weight:600; }
.ph-bell{
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.16);
  display:grid; place-items:center; color:#fff;
  position:relative;
}
.ph-bell svg{ width:18px; height:18px; }
.ph-bell .ph-dot{
  position:absolute; top:8px; right:9px;
  width:8px; height:8px; border-radius:50%;
  background:#DC1FFF; border:2px solid rgba(76,29,149,1);
}
.ph-kpi{
  margin-top:18px; padding:16px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  position:relative;
}
.ph-kpi-l{ font-size:11.5px; color:rgba(255,255,255,.7); }
.ph-kpi-v{ font-size:26px; font-weight:700; letter-spacing:-.01em; }
.ph-kpi-d{ font-size:11px; color:#86EFAC; margin-top:2px; }
.ph-kpi svg{ width:100%; height:60px; margin-top:8px; }
.ph-list{ margin-top:14px; display:flex; flex-direction:column; gap:8px; }
.ph-row{
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:9px 12px;
}
.ph-ico{ width:28px; height:28px; border-radius:50%; flex:none; overflow:hidden; }
.ph-ico svg{ width:100%; height:100%; display:block; }
.ph-t{ font-size:12.5px; font-weight:600; }
.ph-s{ font-size:10.5px; color:rgba(255,255,255,.6); margin-top:1px; }
.ph-r{ margin-left:auto; font-size:12.5px; font-weight:700; }

@media (max-width: 900px){ .app-card{ grid-template-columns:1fr; padding:32px 24px; } .phone{ transform:scale(.92); transform-origin:top; } }

/* ============= FAQ ============= */
.faq{ max-width:800px; margin:0 auto; }
.faq-item{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-lg);
  margin-bottom:12px;
  overflow:hidden;
  box-shadow:var(--card-shadow);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-item[open]{ border-color:var(--border-strong); box-shadow:var(--card-shadow-lg); }
.faq-item summary{
  list-style:none; cursor:pointer;
  padding:18px 22px;
  display:flex; align-items:center; gap:14px;
  font-size:16px; font-weight:500; color:var(--fg);
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item .q{ flex:1; }
.faq-item .toggle{
  width:30px; height:30px; border-radius:50%;
  background:linear-gradient(135deg, var(--grad-a), var(--grad-c));
  display:grid; place-items:center; flex:none;
  transition:transform .25s ease;
  box-shadow:0 6px 16px -6px rgba(145,9,223,.6);
}
.faq-item[open] .toggle{ transform:rotate(45deg); }
.faq-item .toggle svg{ width:13px; height:13px; color:#fff; }
.faq-item .a{ padding:0 22px 20px 22px; color:var(--fg-3); font-size:14.5px; line-height:1.65; max-width:700px; }

/* ============= FOOTER ============= */
.footer{
  border-top:1px solid var(--border);
  padding:64px 0 28px;
  margin-top:48px;
  background:var(--bg);
}

/* Newsletter */
.nl-bar{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  padding:32px clamp(24px, 4vw, 48px);
  box-shadow:var(--card-shadow-lg);
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
  align-items:center;
  margin-bottom:56px;
}
.newsletter{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-2xl);
  padding:32px clamp(24px, 4vw, 48px);
  box-shadow:var(--card-shadow-lg);
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
  align-items:center;
  margin-bottom:56px;
  position:relative; overflow:hidden;
}
.newsletter::before{
  content:""; position:absolute; right:-100px; top:-100px;
  width:300px; height:300px; border-radius:50%;
  background:radial-gradient(circle, rgba(220,31,255,.16), transparent 70%);
}
.nl-text h3{ font-size:24px; font-weight:700; margin:0 0 6px; letter-spacing:-.01em; }
.nl-text p{ font-size:14.5px; color:var(--fg-3); margin:0; line-height:1.55; }
.nl-form{ display:flex; gap:10px; flex-wrap:wrap; position:relative; }
.nl-form input{
  flex:1; min-width:200px;
  padding:14px 16px;
  font-family:inherit; font-size:15px;
  background:var(--field-bg);
  border:1px solid var(--field-border);
  border-radius:12px;
  color:var(--fg);
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.nl-form input:focus{ border-color:#DC1FFF; box-shadow:0 0 0 4px rgba(145,9,223,.15); }
.nl-form .cta-btn{ padding:12px 22px; font-size:15px; }
.nl-status{
  position:absolute; left:0; bottom:-26px;
  font-size:12.5px; color:var(--fg-3);
  min-height:18px;
}
.nl-status.ok{ color:#10B981; }
.nl-status.err{ color:#EF4444; }
@media (max-width: 800px){ .newsletter, .nl-bar{ grid-template-columns:1fr; } }

.foot-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
@media (max-width: 880px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width: 520px){ .foot-grid{ grid-template-columns:1fr; } }
.foot-brand{ max-width:340px; }
.foot-brand .line{ display:flex; align-items:center; gap:10px; font-size:22px; font-weight:700; margin-bottom:12px; color:var(--fg); }
.foot-brand .line .brand-mark{ width:34px; height:34px; }
.foot-brand p{ color:var(--fg-3); font-size:13.5px; line-height:1.6; margin:0 0 18px; }
.foot-socials{ display:flex; gap:8px; }
.foot-socials a{
  width:36px; height:36px; border-radius:10px;
  background:var(--bg-soft); border:1px solid var(--border);
  display:grid; place-items:center; color:var(--fg-2);
  transition:background .2s ease, color .2s ease, transform .15s ease;
}
.foot-socials a:hover{ background:rgba(145,9,223,.14); color:#7C3AED; transform:translateY(-2px); }
.foot-socials svg{ width:15px; height:15px; }
.foot-col h5{ font-size:14px; font-weight:600; margin:0 0 14px; color:var(--fg); letter-spacing:.02em; }
.foot-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.foot-col a{ color:var(--fg-3); text-decoration:none; font-size:14px; transition:color .2s ease; }
.foot-col a:hover{ color:var(--fg); }

.legal{
  margin-top:48px; padding-top:22px;
  border-top:1px solid var(--border);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  color:var(--fg-4); font-size:12.5px;
}
.legal a{ color:inherit; text-decoration:none; }
.legal a:hover{ color:var(--fg-2); }

/* ============= REVEAL ============= */
.reveal{
  opacity:0;
  transform:translateY(32px) scale(.985);
  filter:blur(4px);
  transition:opacity .9s cubic-bezier(.22,1,.36,1),
             transform .9s cubic-bezier(.22,1,.36,1),
             filter .8s ease;
  will-change:transform, opacity, filter;
}
.reveal.in{
  opacity:1;
  transform:translateY(0) scale(1);
  filter:blur(0);
}

/* Staggered child reveals — when a parent .reveal-stagger lands "in",
   its children animate in sequence. */
.reveal-stagger > *{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.reveal-stagger.in > *{ opacity:1; transform:translateY(0); }
.reveal-stagger.in > *:nth-child(1){ transition-delay:.05s; }
.reveal-stagger.in > *:nth-child(2){ transition-delay:.14s; }
.reveal-stagger.in > *:nth-child(3){ transition-delay:.23s; }
.reveal-stagger.in > *:nth-child(4){ transition-delay:.32s; }
.reveal-stagger.in > *:nth-child(5){ transition-delay:.41s; }
.reveal-stagger.in > *:nth-child(6){ transition-delay:.50s; }
.reveal-stagger.in > *:nth-child(7){ transition-delay:.59s; }
.reveal-stagger.in > *:nth-child(8){ transition-delay:.68s; }

/* Orbit cards: dramatic entry — fly in from their resting direction.
   Float animations are paused until the orbit reveals so the entry tweens are visible. */
.orbit-card{
  opacity:0;
  animation-play-state:paused;
  transition:opacity .9s ease, transform .9s cubic-bezier(.22,1,.36,1);
}
.orbit.in .orbit-card{ opacity:1; animation-play-state:running; }
.orbit:not(.in) .oc-roas  { transform:translateY(-40px) scale(.92); }
.orbit:not(.in) .oc-flow  { transform:translate(40px,-30px) scale(.92); }
.orbit:not(.in) .oc-best  { transform:translateX(-40px) scale(.92); }
.orbit:not(.in) .oc-margin{ transform:translateX(40px) scale(.92); }
.orbit:not(.in) .oc-profit{ transform:translateY(40px) scale(.92); }
.orbit.in .oc-roas  { transition-delay:.25s, .25s; }
.orbit.in .oc-flow  { transition-delay:.35s, .35s; }
.orbit.in .oc-best  { transition-delay:.45s, .45s; }
.orbit.in .oc-margin{ transition-delay:.55s, .55s; }
.orbit.in .oc-profit{ transition-delay:.65s, .65s; }

/* Cube enters with a flourish */
.orbit-cube{ opacity:0; transition:opacity 1s ease, transform 1.1s cubic-bezier(.34,1.56,.64,1); }
.orbit:not(.in) .orbit-cube{ transform:translate(-50%, -50%) scale(.5) rotate(-30deg); }
.orbit.in .orbit-cube{ opacity:1; }
@media (max-width: 980px){
  .orbit:not(.in) .orbit-cube{ transform:scale(.5) rotate(-30deg); }
}

@media (prefers-reduced-motion: reduce){
  .reveal, .reveal-stagger > *, .orbit-card, .orbit-cube{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    transition:none !important;
  }
}

/* ============= SECONDARY PAGES ============= */

/* Page hero (sub-pages) */
.page-hero{
  padding:120px 0 60px;
  text-align:center;
}
.page-hero .kicker{ margin-bottom:16px; }
.page-hero h1{
  font-size:clamp(34px,5vw,56px);
  font-weight:700; line-height:1.08;
  letter-spacing:-.02em; margin:0 0 18px;
  color:var(--fg);
}
.page-hero p{
  color:var(--fg-3); font-size:17px;
  max-width:520px; margin:0 auto; line-height:1.65;
}
.page-updated{
  font-size:13px; color:var(--fg-4); margin:0;
}

/* Generic section */
.section{ padding:56px 0; }
.section-title{
  font-size:clamp(22px,3vw,32px);
  font-weight:700; letter-spacing:-.015em; margin:0 0 14px;
  color:var(--fg);
}
.section-sub{
  color:var(--fg-3); font-size:16px; line-height:1.65; margin:0;
}

/* Legal page content */
.page-content{ max-width:740px; }
.page-content h2{
  font-size:19px; font-weight:700;
  letter-spacing:-.01em; margin:44px 0 10px;
  color:var(--fg); padding-top:4px;
  border-top:1px solid var(--border);
}
.page-content h2:first-child{ margin-top:0; border-top:none; }
.page-content p{
  color:var(--fg-2); font-size:15px; line-height:1.78; margin:0 0 13px;
}
.page-content ul,.page-content ol{
  color:var(--fg-2); font-size:15px; line-height:1.78;
  margin:0 0 13px; padding-left:22px;
}
.page-content li{ margin-bottom:4px; }
.page-content a{ color:var(--eyebrow-fg); text-decoration:underline; }
.page-content a:hover{ opacity:.8; }

/* About — values grid */
.about-values{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:18px; margin-top:36px;
}
.about-value-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:var(--r-xl);
  padding:24px 22px;
  box-shadow:var(--card-shadow);
}
.avc-icon{
  width:42px; height:42px; border-radius:var(--r-md);
  background:var(--eyebrow-bg); border:1px solid var(--eyebrow-border);
  color:var(--eyebrow-fg);
  display:grid; place-items:center;
  margin-bottom:16px;
}
.about-value-card h3{
  font-size:15px; font-weight:700; margin:0 0 8px; color:var(--fg);
}
.about-value-card p{
  font-size:13.5px; color:var(--fg-3); line-height:1.6; margin:0;
}

/* About — CTA band */
.about-cta-band{
  padding:80px 0; text-align:center;
  background:linear-gradient(135deg,var(--grad-a) 0%,var(--grad-b) 50%,var(--grad-c) 100%);
  position:relative; isolation:isolate;
}
.about-cta-band::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(70% 120% at 50% 0%,rgba(255,255,255,.15),transparent 70%);
}
.about-cta-band h2{
  font-size:clamp(26px,4vw,42px); font-weight:700;
  color:#fff; margin:0 0 12px;
}
.about-cta-band p{
  font-size:17px; color:rgba(255,255,255,.82); margin:0 0 28px;
}
.about-cta-band .cta-btn{
  background:#fff; color:var(--primary);
  box-shadow:0 8px 28px -6px rgba(0,0,0,.28);
}
.about-cta-band .cta-btn:hover{ background:rgba(255,255,255,.92); }

/* Contact — two-column grid */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:48px; align-items:start;
}
.contact-form{ display:flex; flex-direction:column; gap:18px; }
.form-group{ display:flex; flex-direction:column; gap:6px; }
.form-group label{
  font-size:13.5px; font-weight:600; color:var(--fg-2);
}
.form-group input,
.form-group textarea{
  width:100%; padding:10px 14px;
  border:1px solid var(--border-strong); border-radius:var(--r-md);
  background:var(--bg); color:var(--fg);
  font-family:inherit; font-size:14px; line-height:1.5;
  transition:border-color .2s, box-shadow .2s;
  outline:none; box-sizing:border-box;
}
.form-group input:focus,
.form-group textarea:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(145,9,223,.12);
}
.form-group textarea{ resize:vertical; min-height:120px; }
.contact-form .cta-btn{ align-self:flex-start; }
.form-status{
  font-size:13.5px; padding:10px 14px;
  border-radius:var(--r-md); display:none;
}
.form-status.success{
  background:rgba(16,185,129,.1); color:#059669;
  border:1px solid rgba(16,185,129,.2); display:block;
}
.form-status.error{
  background:rgba(239,68,68,.1); color:#DC2626;
  border:1px solid rgba(239,68,68,.2); display:block;
}

/* Contact — info cards */
.contact-info{ display:flex; flex-direction:column; gap:14px; }
.contact-info-card{
  display:flex; align-items:flex-start; gap:14px;
  background:var(--card-bg); border:1px solid var(--card-border);
  border-radius:var(--r-xl); padding:18px 20px;
  box-shadow:var(--card-shadow);
}
.cic-icon{
  width:40px; height:40px; flex-shrink:0;
  background:var(--eyebrow-bg); border:1px solid var(--eyebrow-border);
  border-radius:var(--r-md); display:grid; place-items:center;
  color:var(--eyebrow-fg);
}
.cic-label{
  font-size:11px; font-weight:600; text-transform:uppercase;
  letter-spacing:.04em; color:var(--fg-4); margin-bottom:3px;
}
.cic-value{ font-size:14.5px; font-weight:600; color:var(--fg); }
.cic-value a{ color:var(--eyebrow-fg); text-decoration:none; }
.cic-value a:hover{ text-decoration:underline; }

@media (max-width:860px){
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width:600px){
  .page-hero{ padding-top:80px; }
  .about-values{ grid-template-columns:1fr; }
}
