/* ════════════════════════════════════════════════════════════
   Medhive · one-pager
   Built on the Medhive design system tokens.
   ════════════════════════════════════════════════════════════ */

/* ── Fonts ─────────────────────────────────────────────────── */
@font-face { font-family:"Outfit"; font-weight:300; font-style:normal; font-display:swap; src:url("fonts/Outfit-Light.ttf") format("truetype"); }
@font-face { font-family:"Outfit"; font-weight:400; font-style:normal; font-display:swap; src:url("fonts/Outfit-Regular.ttf") format("truetype"); }
@font-face { font-family:"Outfit"; font-weight:500; font-style:normal; font-display:swap; src:url("fonts/Outfit-Medium.ttf") format("truetype"); }
@font-face { font-family:"Outfit"; font-weight:600; font-style:normal; font-display:swap; src:url("fonts/Outfit-SemiBold.ttf") format("truetype"); }
@font-face { font-family:"Outfit"; font-weight:700; font-style:normal; font-display:swap; src:url("fonts/Outfit-Bold.ttf") format("truetype"); }
@font-face { font-family:"Outfit"; font-weight:800; font-style:normal; font-display:swap; src:url("fonts/Outfit-ExtraBold.ttf") format("truetype"); }
@font-face { font-family:"Inter"; font-weight:100 900; font-style:normal; font-display:swap; src:url("fonts/Inter-Variable.ttf") format("truetype"); }

/* ── Tokens ────────────────────────────────────────────────── */
:root {
  --purple-50:#F3EFFE; --purple-100:#E4DEFA; --purple-200:#9075FF; --purple-300:#7C44FF;
  --purple-400:#6821FF; --purple-500:#5A0EC9; --purple-600:#47059B; --purple-700:#3A0084;
  --purple-800:#2C0066; --purple-900:#1B0040;
  --purple-mark:#7C1CF5; --purple-canvas:#400092;
  --mint-100:#DFFBF3; --mint-200:#B7F7E8; --mint-300:#65EDCD; --mint-400:#20C9A0;
  --mint-500:#0DB38C; --mint-600:#0A8C6E; --mint-700:#076B54;
  --neutral-0:#FFFFFF; --neutral-50:#FAFAFB; --neutral-100:#F6F6F7; --neutral-200:#ECEBEE;
  --neutral-300:#DAE1ED; --neutral-400:#BBC9DC; --neutral-500:#8F8E93; --neutral-600:#6B5C7D;
  --neutral-700:#394658; --neutral-800:#1E2A3A; --neutral-900:#0F172A;

  --brand:var(--purple-600); --brand-strong:var(--purple-700); --brand-bright:var(--purple-mark);
  --action:var(--purple-400); --action-hover:var(--purple-500); --action-press:var(--purple-600);
  --accent:var(--mint-500);
  --surface:var(--neutral-0); --surface-accent:var(--purple-50);
  --border:var(--neutral-300);
  --text-primary:var(--neutral-900); --text-secondary:var(--neutral-700);
  --text-muted:var(--neutral-600); --text-faint:var(--neutral-500);
  --brand-orphatrack:#1C74F8; --brand-vira:#00C496;

  --font-display:"Outfit",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --radius-md:12px; --radius-lg:16px; --radius-xl:24px; --radius-2xl:30px; --radius-pill:999px;
  --shadow-xs:0 1px 2px rgba(15,23,42,.05);
  --shadow-sm:0 2px 6px rgba(15,23,42,.06);
  --shadow-md:0 8px 24px rgba(15,23,42,.08);
  --shadow-lg:0 16px 20px rgba(0,0,0,.06),0 30px 76px rgba(0,0,0,.08);
  --shadow-purple:0 18px 50px rgba(71,5,155,.22);
  --ring-focus:0 0 0 3px rgba(104,33,255,.30);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur-fast:140ms; --dur-base:240ms; --dur-slow:520ms;

  /* tweakable */
  --site-accent:var(--purple-400);
  --site-accent-soft:var(--purple-50);

  --maxw:1180px;
  --pad:clamp(20px,5vw,44px);
}

/* ── Reset & base ──────────────────────────────────────────── */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--font-body); color:var(--text-primary);
  font-size:16px; line-height:1.6; background:var(--neutral-0);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:var(--purple-200); color:#fff; }

/* ── Layout ────────────────────────────────────────────────── */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(80px,11vw,140px); position:relative; }
.section--tight{ padding-block:clamp(64px,8vw,104px); }
.section--alt{ background:var(--neutral-50); }

/* ── Type helpers ──────────────────────────────────────────── */
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-body); font-weight:600; font-size:13px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--site-accent);
  margin:0 0 22px;
}
.eyebrow::before{ content:""; width:22px; height:2px; border-radius:2px; background:currentColor; opacity:.7; }
.eyebrow--center{ justify-content:center; }
.display{
  font-family:var(--font-display); font-weight:800; line-height:1.04;
  letter-spacing:-.025em; color:var(--text-primary); margin:0;
  font-size:clamp(40px,6vw,76px); text-wrap:balance;
}
h2.h2{
  font-family:var(--font-display); font-weight:700; line-height:1.08;
  letter-spacing:-.02em; color:var(--text-primary); margin:0;
  font-size:clamp(32px,4.6vw,56px); text-wrap:balance;
}
h3.h3{
  font-family:var(--font-display); font-weight:600; line-height:1.15;
  letter-spacing:-.015em; margin:0; font-size:clamp(22px,2.4vw,28px);
}
.lead{ font-size:clamp(18px,1.5vw,21px); line-height:1.62; color:var(--text-muted); margin:0; max-width:60ch; }
.measure{ max-width:62ch; }
.muted{ color:var(--text-muted); }

/* ── Buttons ───────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:50px; padding:0 24px; border-radius:var(--radius-md);
  font-family:var(--font-body); font-weight:600; font-size:15.5px; line-height:1;
  border:1.5px solid transparent; cursor:pointer; white-space:nowrap;
  transition:background var(--dur-fast) var(--ease-out),
             border-color var(--dur-fast), color var(--dur-fast),
             transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.btn .ico{ width:18px; height:18px; transition:transform var(--dur-base) var(--ease-out); }
.btn--primary{ background:var(--action); color:#fff; box-shadow:var(--shadow-purple); }
.btn--primary:hover{ background:var(--action-hover); transform:translateY(-2px); box-shadow:0 22px 56px rgba(71,5,155,.30); }
.btn--primary:active{ transform:translateY(0); background:var(--action-press); }
.btn--primary:hover .ico{ transform:translateX(3px); }
.btn--ghost{ background:transparent; color:var(--text-primary); border-color:var(--border); }
.btn--ghost:hover{ background:var(--surface-accent); border-color:var(--purple-200); color:var(--brand); transform:translateY(-2px); }
.btn--light{ background:#fff; color:var(--brand); }
.btn--light:hover{ transform:translateY(-2px); box-shadow:0 20px 50px rgba(0,0,0,.18); }
.btn--ondark-ghost{ background:rgba(255,255,255,.06); color:#fff; border-color:rgba(255,255,255,.28); }
.btn--ondark-ghost:hover{ background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.5); transform:translateY(-2px); }
.btn--sm{ height:42px; padding:0 18px; font-size:14.5px; }

/* ── Header / nav ──────────────────────────────────────────── */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60; height:74px;
  display:flex; align-items:center;
  transition:background var(--dur-base) var(--ease-out),
             box-shadow var(--dur-base) var(--ease-out),
             height var(--dur-base) var(--ease-out),
             border-color var(--dur-base);
  border-bottom:1px solid transparent;
}
.nav__inner{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad);
  display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav__logo{ position:relative; display:flex; align-items:center; }
.lock{ height:32px; width:auto; transition:opacity var(--dur-base); }
.nav__logo .lock--dark{ position:absolute; left:0; top:50%; transform:translateY(-50%); opacity:0; }
.nav__links{ display:flex; align-items:center; gap:6px; }
.nav__link{
  position:relative; padding:9px 14px; border-radius:10px;
  font-size:15px; font-weight:500; color:var(--text-secondary);
  transition:color var(--dur-fast), background var(--dur-fast);
}
.nav__link::after{
  content:""; position:absolute; left:14px; right:14px; bottom:5px; height:2px;
  background:var(--site-accent); border-radius:2px; transform:scaleX(0);
  transform-origin:left; transition:transform var(--dur-base) var(--ease-out);
}
.nav__link:hover{ color:var(--text-primary); }
.nav__link:hover::after{ transform:scaleX(1); }
.nav__cta{ display:flex; align-items:center; gap:12px; }

/* hamburger */
.nav__toggle{ display:none; width:44px; height:44px; padding:0; border:none; background:transparent;
  cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.nav__toggle span{ display:block; width:24px; height:2px; border-radius:2px; background:var(--text-primary);
  transition:transform var(--dur-base) var(--ease-out), opacity var(--dur-fast); }
body[data-hero="bold"] .nav:not(.is-scrolled) .nav__toggle span{ background:#fff; }
.nav__toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile menu panel */
.mobile-menu{ display:flex; flex-direction:column; gap:4px; padding:12px var(--pad) 24px;
  background:rgba(255,255,255,.96); -webkit-backdrop-filter:saturate(180%) blur(16px); backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--border); box-shadow:var(--shadow-md);
  position:fixed; left:0; right:0; top:74px; z-index:59;
  transform:translateY(-12px); opacity:0; pointer-events:none;
  transition:transform var(--dur-base) var(--ease-out), opacity var(--dur-base) var(--ease-out); }
.nav.is-scrolled .mobile-menu{ top:64px; }
.mobile-menu.is-open{ transform:none; opacity:1; pointer-events:auto; }
.mobile-menu__link{ padding:14px 6px; font-family:var(--font-display); font-weight:500; font-size:19px;
  color:var(--text-primary); border-bottom:1px solid var(--neutral-200); }
.mobile-menu__link:active{ color:var(--brand); }
.mobile-menu__cta{ margin-top:16px; height:50px; }
.nav.is-scrolled{
  height:64px; background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:saturate(180%) blur(16px); backdrop-filter:saturate(180%) blur(16px);
  border-bottom-color:var(--border); box-shadow:0 1px 0 rgba(15,23,42,.02),0 8px 30px rgba(15,23,42,.04);
}

/* nav on a bold (purple) hero, before scroll: white treatment */
body[data-hero="bold"] .nav:not(.is-scrolled) .lock--color{ opacity:0; }
body[data-hero="bold"] .nav:not(.is-scrolled) .lock--dark{ opacity:1; }
body[data-hero="bold"] .nav:not(.is-scrolled) .nav__link{ color:rgba(255,255,255,.82); }
body[data-hero="bold"] .nav:not(.is-scrolled) .nav__link:hover{ color:#fff; }
body[data-hero="bold"] .nav:not(.is-scrolled) .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.3); background:rgba(255,255,255,.06); }
body[data-hero="bold"] .nav:not(.is-scrolled) .btn--ghost:hover{ background:rgba(255,255,255,.14); }

/* ── Hero ──────────────────────────────────────────────────── */
.hero{ position:relative; padding-top:128px; padding-bottom:clamp(64px,8vw,108px); overflow:hidden; }
.hero__grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px);
  align-items:center;
}
.hero__copy{ max-width:640px; }
.hero__title .accentword{ color:var(--brand); }
.hero__lead{ margin-top:26px; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:38px; }
.hero__trust{ display:flex; align-items:center; gap:18px; margin-top:40px; color:var(--text-faint); font-size:14px; }
.hero__trust .dot{ width:5px; height:5px; border-radius:50%; background:var(--mint-500); }
.hero__trust strong{ color:var(--text-secondary); font-weight:600; }

/* hero visual */
.hero__visual{ position:relative; aspect-ratio:1/1; max-width:460px; justify-self:end; width:100%; }
.orbit{ position:absolute; inset:0; display:grid; place-items:center; }
.orbit__panel{
  position:relative; width:86%; aspect-ratio:1/1; border-radius:var(--radius-2xl);
  background:radial-gradient(120% 120% at 30% 20%, #fff 0%, var(--purple-50) 100%);
  border:1px solid var(--purple-100); box-shadow:var(--shadow-lg);
  display:grid; place-items:center; overflow:hidden;
}
.orbit__panel::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(rgba(104,33,255,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(104,33,255,.05) 1px,transparent 1px);
  background-size:38px 38px; mask-image:radial-gradient(70% 70% at 50% 50%,#000,transparent);
}
.orbit__mark{ width:62%; height:62%; position:relative; z-index:1; }
.orbit__ring{ position:absolute; border:1.5px dashed var(--purple-200); border-radius:50%; opacity:.5; }
.orbit__ring.r1{ inset:9%; }
.orbit__ring.r2{ inset:-3%; opacity:.3; }
.chip{
  position:absolute; display:flex; align-items:center; gap:10px;
  background:#fff; border:1px solid var(--border); border-radius:14px;
  padding:11px 14px; box-shadow:var(--shadow-md); z-index:3;
}
.chip__ic{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center; flex:none; }
.chip__ic svg{ width:19px; height:19px; }
.chip__t{ display:block; font-size:12px; color:var(--text-faint); line-height:1.2; }
.chip__v{ display:block; font-size:14.5px; font-weight:600; color:var(--text-primary); font-family:var(--font-display); }
.chip--a{ top:8%; left:-6%; }
.chip--b{ bottom:14%; right:-8%; }
.chip--c{ bottom:-2%; left:14%; }

/* bold hero variant */
body[data-hero="bold"] .hero{ background:var(--purple-canvas); }
body[data-hero="bold"] .hero .display,
body[data-hero="bold"] .hero__title .accentword{ color:#fff; }
body[data-hero="bold"] .hero .hero__title .accentword{ color:var(--purple-200); }
body[data-hero="bold"] .hero .eyebrow{ color:var(--mint-300); }
body[data-hero="bold"] .hero .lead{ color:rgba(255,255,255,.74); }
body[data-hero="bold"] .hero .hero__trust{ color:rgba(255,255,255,.5); }
body[data-hero="bold"] .hero .hero__trust strong{ color:rgba(255,255,255,.85); }
body[data-hero="bold"] .hero .btn--ghost{ background:rgba(255,255,255,.06); color:#fff; border-color:rgba(255,255,255,.28); }
body[data-hero="bold"] .hero .btn--ghost:hover{ background:rgba(255,255,255,.14); }
body[data-hero="bold"] .hero .orbit__panel{ background:radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.10) 0%, rgba(255,255,255,.03) 100%); border-color:rgba(255,255,255,.16); box-shadow:none; }
body[data-hero="bold"] .hero .orbit__panel::before{ background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px); }
body[data-hero="bold"] .hero .orbit__ring{ border-color:rgba(255,255,255,.3); }

/* split hero variant */
body[data-hero="split"] .hero__visual .orbit__panel{ background:radial-gradient(120% 120% at 30% 20%, var(--purple-50) 0%, var(--purple-100) 100%); }
body[data-hero="split"] .hero{ background:linear-gradient(180deg,var(--neutral-50),#fff 70%); }

/* ── Mission ───────────────────────────────────────────────── */
.mission__statement{
  font-family:var(--font-display); font-weight:700; letter-spacing:-.02em; line-height:1.18;
  font-size:clamp(26px,3.4vw,42px); color:var(--text-primary); margin:0; text-wrap:balance;
}
.mission__statement b{ color:var(--brand); font-weight:700; }
.mission__body{ margin-top:30px; max-width:64ch; }
.mission__body b{ color:var(--text-primary); font-weight:600; }
.outcomes{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:56px; }
.outcome{ padding:28px 26px; border-radius:var(--radius-lg); background:var(--surface); border:1px solid var(--border); }
.outcome__ic{ width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:var(--site-accent-soft); color:var(--site-accent); margin-bottom:18px; }
.outcome__ic svg{ width:22px; height:22px; }
.outcome h4{ font-family:var(--font-display); font-weight:600; font-size:18px; margin:0 0 6px; letter-spacing:-.01em; }
.outcome p{ margin:0; font-size:15px; color:var(--text-muted); line-height:1.55; }

/* ── Section head ──────────────────────────────────────────── */
.shead{ max-width:680px; }
.shead--center{ margin-inline:auto; text-align:center; }
.shead .lead{ margin-top:20px; }

/* ── Values ────────────────────────────────────────────────── */
.values-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:60px; }
.value{
  position:relative; padding:30px 28px 30px; border-radius:var(--radius-lg);
  background:var(--surface); border:1px solid var(--border);
  transition:transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base);
  overflow:hidden;
}
.value::after{ content:""; position:absolute; left:0; top:0; height:3px; width:100%; background:var(--site-accent); transform:scaleX(0); transform-origin:left; transition:transform var(--dur-slow) var(--ease-out); }
.value:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--purple-100); }
.value:hover::after{ transform:scaleX(1); }
.value__ic{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center; background:var(--site-accent-soft); color:var(--site-accent); margin-bottom:22px; }
.value__ic svg{ width:25px; height:25px; }
.value h3{ font-family:var(--font-display); font-weight:600; font-size:19.5px; letter-spacing:-.01em; margin:0 0 9px; }
.value p{ margin:0; font-size:15px; line-height:1.6; color:var(--text-muted); }

/* ── Solutions ─────────────────────────────────────────────── */
.sol-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:60px; }
.sol{
  --c:var(--action);
  display:flex; flex-direction:column; border-radius:var(--radius-xl); overflow:hidden;
  background:var(--surface); border:1px solid var(--border);
  transition:transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base);
}
.sol:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
.sol__top{ position:relative; height:128px; display:flex; align-items:center; padding:0 30px; overflow:hidden;
  background:color-mix(in srgb,var(--c) 9%,#fff); border-bottom:1px solid color-mix(in srgb,var(--c) 16%,#fff); }
.sol__top::before{ content:""; position:absolute; right:-30px; top:-40px; width:150px; height:150px; border-radius:50%;
  border:1.5px dashed color-mix(in srgb,var(--c) 40%,#fff); opacity:.6; }
.sol__top::after{ content:""; position:absolute; right:6px; bottom:-50px; width:110px; height:110px; border-radius:50%;
  border:1.5px dashed color-mix(in srgb,var(--c) 40%,#fff); opacity:.4; }
.sol__badge{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; background:var(--c); color:#fff;
  box-shadow:0 10px 24px color-mix(in srgb,var(--c) 36%,transparent); z-index:1; }
.sol__badge svg{ width:27px; height:27px; }
.sol__badge--logo{ width:auto; min-width:54px; padding:0 18px; background:#fff; box-shadow:var(--shadow-sm); }
.sol__badge--logo img{ height:23px; width:auto; max-width:188px; display:block; }
.sol__name:empty{ display:none; }
.sol__body{ padding:28px 30px 30px; display:flex; flex-direction:column; flex:1; }
.sol__name{ display:flex; align-items:center; gap:11px; margin-bottom:14px; }
.sol__name h3{ font-family:var(--font-display); font-weight:700; font-size:25px; letter-spacing:-.02em; margin:0; }
.sol__tag{ font-size:11.5px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--c);
  background:color-mix(in srgb,var(--c) 12%,#fff); padding:5px 10px; border-radius:var(--radius-pill); }
.sol__desc{ margin:0 0 24px; font-size:15.5px; line-height:1.62; color:var(--text-muted); flex:1; }
.sol__link{ display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:15px; color:var(--c); align-self:flex-start; }
.sol__link svg{ width:17px; height:17px; transition:transform var(--dur-base) var(--ease-out); }
.sol:hover .sol__link svg{ transform:translateX(4px); }

/* ── Agenda ────────────────────────────────────────────────── */
.agenda{ margin-top:56px; display:flex; flex-direction:column; }
.event{
  display:grid; grid-template-columns:118px 1fr auto; align-items:center; gap:28px;
  padding:28px 8px; border-top:1px solid var(--border);
  transition:padding-left var(--dur-base) var(--ease-out);
}
.event:last-child{ border-bottom:1px solid var(--border); }
.event:hover{ padding-left:18px; }
.event__date{ display:flex; flex-direction:column; }
.event__day{ font-family:var(--font-display); font-weight:700; font-size:38px; line-height:1; letter-spacing:-.02em; color:var(--brand); }
.event__mon{ font-size:13px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--text-faint); margin-top:6px; }
.event__main h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(19px,2vw,23px); letter-spacing:-.01em; margin:0 0 7px; }
.event__meta{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; font-size:14px; color:var(--text-muted); }
.event__meta .pill{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; letter-spacing:.03em;
  text-transform:uppercase; color:var(--site-accent); background:var(--site-accent-soft); padding:4px 11px; border-radius:var(--radius-pill); }
.event__meta .loc{ display:inline-flex; align-items:center; gap:6px; }
.event__meta .loc svg{ width:15px; height:15px; color:var(--text-faint); }
.event__cta{ display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:14.5px; color:var(--text-secondary); }
.event__cta svg{ width:16px; height:16px; transition:transform var(--dur-base) var(--ease-out); }
.event:hover .event__cta{ color:var(--brand); }
.event:hover .event__cta svg{ transform:translateX(3px); }
.event--soon .event__day{ color:var(--mint-600); }

/* ── Contact (dark) ────────────────────────────────────────── */
.contact{ position:relative; background:var(--purple-canvas); color:#fff; overflow:hidden; }
.contact::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(60% 80% at 88% 8%, rgba(124,28,245,.45), transparent 60%),
    radial-gradient(50% 60% at 6% 96%, rgba(13,179,140,.16), transparent 60%);
}
.contact .wrap{ position:relative; z-index:1; }
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,84px); align-items:end; }
.contact .eyebrow{ color:var(--mint-300); }
.contact h2.h2{ color:#fff; }
.contact__lead{ margin-top:20px; color:rgba(255,255,255,.72); font-size:18px; line-height:1.6; max-width:44ch; }
.contact__details{ margin-top:42px; margin-bottom:42px; display:flex; flex-direction:column; gap:20px; }
.cdetail{ display:flex; gap:15px; align-items:center; }
.cdetail__ic{ width:42px; height:42px; border-radius:12px; flex:none; display:grid; place-items:center;
  background:rgba(255,255,255,.08); color:var(--mint-300); border:1px solid rgba(255,255,255,.12); }
.cdetail__ic svg{ width:20px; height:20px; }
.cdetail__t{ font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.5); margin:0 0 4px; }
.cdetail__v{ font-size:16px; color:#fff; margin:0; line-height:1.5; }
.cdetail__v a:hover{ color:var(--mint-300); }

/* form */
.form-card{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--radius-xl);
  padding:clamp(26px,3vw,40px); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); margin-bottom:42px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-size:13.5px; font-weight:600; color:rgba(255,255,255,.8); }
.field .req{ color:var(--mint-300); }
.input,.select{
  height:50px; padding:0 16px; border-radius:var(--radius-md); width:100%;
  background:rgba(255,255,255,.07); border:1.5px solid rgba(255,255,255,.18); color:#fff;
  font-family:var(--font-body); font-size:15px; transition:border-color var(--dur-fast), box-shadow var(--dur-fast), background var(--dur-fast);
  appearance:none;
}
.input::placeholder{ color:rgba(255,255,255,.4); }
.input:focus,.select:focus{ outline:none; border-color:var(--purple-200); background:rgba(255,255,255,.12); box-shadow:0 0 0 3px rgba(144,117,255,.28); }
.select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; background-size:20px; padding-right:44px; cursor:pointer; }
.select option{ color:#1a1a1a; }
.form-actions{ display:flex; align-items:center; gap:18px; margin-top:8px; flex-wrap:wrap; }
.form-note{ font-size:13px; color:rgba(255,255,255,.5); }
.form-success{
  display:none; align-items:center; gap:12px; padding:16px 18px; border-radius:var(--radius-md);
  background:rgba(13,179,140,.16); border:1px solid rgba(101,237,205,.4); color:#fff; font-size:15px; margin-top:18px;
}
.form-success svg{ width:22px; height:22px; color:var(--mint-300); flex:none; }
.form-card.sent .form-success{ display:flex; }

/* ── Footer ────────────────────────────────────────────────── */
.footer{ background:var(--purple-900); color:rgba(255,255,255,.6); }
.footer__inner{ display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap;
  padding-block:38px; border-top:1px solid rgba(255,255,255,.08); }
.footer__logo img{ height:30px; width:auto; }
.footer__right{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; font-size:14px; }
.footer__right a:hover{ color:#fff; }
.footer__copy{ font-size:13px; color:rgba(255,255,255,.4); }

/* ── Reveal animation ──────────────────────────────────────── */
[data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); will-change:opacity,transform; }
[data-reveal].in{ opacity:1; transform:none; }
body[data-motion="off"] [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  [data-reveal]{ opacity:1 !important; transform:none !important; transition:none !important; }
  .chip{ animation:none !important; }
}
/* gentle float for hero chips (decorative; disabled w/ motion off & reduced-motion) */
@media (prefers-reduced-motion:no-preference){
  body[data-motion="on"] .chip--a{ animation:floaty 7s var(--ease-out) infinite; }
  body[data-motion="on"] .chip--b{ animation:floaty 8.5s var(--ease-out) infinite .6s; }
  body[data-motion="on"] .chip--c{ animation:floaty 7.8s var(--ease-out) infinite .3s; }
}
@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width:900px){
  .hero__grid{ grid-template-columns:1fr; gap:40px; }
  .hero__copy{ order:1; max-width:none; }
  .hero__visual{ order:2; justify-self:center; max-width:360px; }
}
@media (max-width:980px){
  .outcomes{ grid-template-columns:1fr; }
  .values-grid{ grid-template-columns:repeat(2,1fr); }
  .sol-grid{ grid-template-columns:1fr; max-width:560px; }
  .contact__grid{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .nav__links{ display:none; }
  .nav__cta-btn{ display:none; }
  .nav__toggle{ display:flex; }
  .values-grid{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .event{ grid-template-columns:74px 1fr; gap:18px; }
  .event__cta{ display:none; }
  .event__day{ font-size:30px; }
  .footer__inner{ flex-direction:column; align-items:flex-start; }
}
