/* ================================================================
   VOICE NIMBLE — Ultra-Modern Dark SaaS Landing Page
   Pure CSS — No External Dependencies
   ================================================================ */

/* ── CSS CUSTOM PROPERTIES ── */
:root {
  --bg: #06060e;
  --bg-raised: #0c0c1a;
  --bg-card: rgba(255,255,255,.025);
  --bg-card-hover: rgba(255,255,255,.05);

  --border: rgba(255,255,255,.06);
  --border-hover: rgba(255,255,255,.12);

  --text-1: #f1f5f9;
  --text-2: #94a3b8;
  --text-3: #64748b;

  --accent: #CF8A02;
  --accent-2: #E6A817;
  --accent-3: #D4A019;
  --amber: #CF8A02;
  --red: #ef4444;
  --green: #10b981;

  --gradient: linear-gradient(135deg, #CF8A02, #E6A817);
  --gradient-full: linear-gradient(135deg, #CF8A02 0%, #E6A817 50%, #D4A019 100%);
  --gradient-text: linear-gradient(135deg, #E6A817 0%, #CF8A02 50%, #D4A019 100%);
  --gradient-subtle: linear-gradient(135deg, rgba(207,138,2,.12), rgba(230,168,23,.08));

  --radius-sm: .5rem;
  --radius-md: .875rem;
  --radius-lg: 1.25rem;
  --radius-xl: 1.5rem;
  --radius-full: 99px;

  --shadow-glow: 0 0 40px rgba(207,138,2,.15), 0 0 80px rgba(230,168,23,.08);
  --transition: .3s cubic-bezier(.16,1,.3,1);
  --transition-slow: .6s cubic-bezier(.16,1,.3,1);
}

/* ── LIGHT MODE OVERRIDES ── */
[data-theme="light"] {
  --bg: #f8f9fc;
  --bg-raised: #ffffff;
  --bg-card: rgba(0,0,0,.03);
  --bg-card-hover: rgba(0,0,0,.06);

  --border: rgba(0,0,0,.08);
  --border-hover: rgba(0,0,0,.15);

  --text-1: #0f172a;
  --text-2: #475569;
  --text-3: #94a3b8;

  --gradient-subtle: linear-gradient(135deg, rgba(207,138,2,.08), rgba(230,168,23,.05));
  --shadow-glow: 0 0 40px rgba(207,138,2,.08), 0 0 80px rgba(230,168,23,.04);
}

/* Surfaces that use hardcoded dark colors */
[data-theme="light"] body {
  background: var(--bg);
}
/* Light mode header: transparent over hero, light bg when scrolled */
[data-theme="light"] .header {
  background: transparent;
  border-bottom-color: transparent;
}
/* Keep header text light while over the dark video hero */
[data-theme="light"] .header:not(.scrolled) .nav__link {
  color: rgba(255,255,255,.6);
}
[data-theme="light"] .header:not(.scrolled) .nav__link:hover {
  color: #fff;
  background: rgba(255,255,255,.08);
}
[data-theme="light"] .header:not(.scrolled) .logo__text {
  color: #fff;
}
[data-theme="light"] .header:not(.scrolled) .theme-toggle {
  color: rgba(255,255,255,.7);
}
[data-theme="light"] .header:not(.scrolled) .btn--primary {
  color: #fff;
}
/* Scrolled: switch to light theme header */
[data-theme="light"] .header.scrolled {
  background: rgba(248,249,252,.95);
  border-bottom-color: rgba(0,0,0,.08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
[data-theme="light"] .mobile-nav {
  background: var(--bg-raised);
}
[data-theme="light"] .section--alt {
  background: linear-gradient(180deg, var(--bg), rgba(0,0,0,.015) 50%, var(--bg));
}
/* Hero video section stays dark in both themes */
[data-theme="light"] .hero__overlay {
  background:
    linear-gradient(180deg,
      rgba(6,6,14,.65) 0%,
      rgba(6,6,14,.5) 40%,
      rgba(6,6,14,.6) 70%,
      rgba(248,249,252,1) 100%
    ),
    linear-gradient(135deg,
      rgba(207,138,2,.06) 0%,
      transparent 50%,
      rgba(230,168,23,.04) 100%
    );
}
[data-theme="light"] .glass-card {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .glow-card__inner {
  background: var(--bg-raised);
}
[data-theme="light"] .glow-card__border {
  opacity: .3;
}
[data-theme="light"] .fshow__preview {
  background: rgba(255,255,255,.92);
  border-color: var(--border);
}
[data-theme="light"] .fshow__tab:hover {
  background: rgba(0,0,0,.03);
}
[data-theme="light"] .fshow__tab--active {
  background: rgba(var(--fa-rgb), .06);
}
[data-theme="light"] .feat-ticker__item {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .use-card {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .hiw__chip {
  background: rgba(var(--step-rgb), .06);
  border-color: rgba(var(--step-rgb), .12);
}
[data-theme="light"] .intg__node svg {
  background: rgba(var(--n-rgb), .05);
  border-color: rgba(var(--n-rgb), .1);
}
[data-theme="light"] .price-card {
  background: var(--bg-raised);
  border-color: var(--border);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
[data-theme="light"] .price-card:hover {
  border-color: rgba(207,138,2,.2);
  box-shadow: 0 12px 40px rgba(0,0,0,.1), 0 0 30px rgba(207,138,2,.06);
}
[data-theme="light"] .price-card__inner {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .price-card--featured {
  box-shadow: 0 8px 40px rgba(207,138,2,.12);
}
[data-theme="light"] .price-card--featured:hover {
  box-shadow: 0 16px 50px rgba(207,138,2,.18), 0 0 60px rgba(230,168,23,.08);
}
[data-theme="light"] .price-card--featured .price-card__inner {
  background: #fff;
  border-color: rgba(207,138,2,.3);
}
/* Light mode buttons */
[data-theme="light"] .btn--outline {
  background: rgba(0,0,0,.02);
  border-color: rgba(0,0,0,.12);
  color: var(--text-1);
  backdrop-filter: none;
}
[data-theme="light"] .btn--outline:hover {
  background: rgba(207,138,2,.06);
  border-color: rgba(207,138,2,.4);
  color: #CF8A02;
  box-shadow: 0 0 20px rgba(207,138,2,.1), 0 4px 12px rgba(0,0,0,.06);
}
[data-theme="light"] .price-card .btn--outline {
  background: rgba(0,0,0,.02);
  border-color: rgba(0,0,0,.1);
  color: var(--text-1);
}
[data-theme="light"] .price-card .btn--outline:hover {
  background: rgba(207,138,2,.06);
  border-color: rgba(207,138,2,.45);
  color: #CF8A02;
  box-shadow: 0 0 20px rgba(207,138,2,.1), 0 4px 12px rgba(0,0,0,.08);
}
[data-theme="light"] .btn--glow {
  box-shadow: 0 4px 16px rgba(207,138,2,.2), 0 2px 8px rgba(0,0,0,.08);
}
[data-theme="light"] .btn--glow:hover {
  box-shadow: 0 8px 30px rgba(207,138,2,.3), 0 4px 12px rgba(0,0,0,.1);
}
[data-theme="light"] .btn--glass {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.1);
  color: var(--text-1);
}
[data-theme="light"] .btn--glass:hover {
  background: rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.15);
}
[data-theme="light"] .btn--ghost {
  border-color: rgba(0,0,0,.1);
  color: var(--text-1);
}
[data-theme="light"] .btn--ghost:hover {
  border-color: rgba(0,0,0,.2);
  color: var(--text-1);
}
[data-theme="light"] .billing-toggle {
  background: rgba(0,0,0,.03);
}
[data-theme="light"] .billing-toggle__switch {
  background: rgba(0,0,0,.08);
}
[data-theme="light"] .price-card__check {
  background: rgba(100,116,139,.06);
}
[data-theme="light"] .price-card__check--accent {
  background: rgba(207,138,2,.08);
}
[data-theme="light"] .pricing-orb--1 { background: rgba(207,138,2,.04); }
[data-theme="light"] .pricing-orb--2 { background: rgba(230,168,23,.03); }
[data-theme="light"] .testi-card {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .sec-hero__glow {
  background: radial-gradient(circle, rgba(207,138,2,.08) 0%, transparent 70%);
}
[data-theme="light"] .faq__item {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .faq__item[open] {
  background: rgba(207,138,2,.03);
  border-color: rgba(207,138,2,.15);
}
[data-theme="light"] .faq__item summary:hover {
  color: var(--accent);
}
[data-theme="light"] .faq__item summary::after {
  color: var(--text-2);
}
[data-theme="light"] .cta-section__inner::before {
  background: var(--bg-raised);
  border-color: var(--border);
}
[data-theme="light"] .footer {
  background: rgba(241,245,249,.8);
  border-top-color: var(--border);
}
[data-theme="light"] .vcall-bar {
  background: linear-gradient(135deg, rgba(207,138,2,.85), rgba(230,168,23,.85));
  border-color: rgba(207,138,2,.3);
  box-shadow: 0 8px 32px rgba(207,138,2,.2), 0 2px 8px rgba(0,0,0,.1);
}
[data-theme="light"] .vcall-modal {
  background: rgba(0,0,0,.35);
}
[data-theme="light"] .vcall-modal__card {
  background: linear-gradient(160deg, #f8f9fc 0%, #ffffff 100%);
  border: 1px solid var(--border);
  box-shadow: 0 24px 64px rgba(0,0,0,.15);
}
[data-theme="light"] .vcall-modal__close {
  background: rgba(0,0,0,.06);
  color: var(--text-2);
}
[data-theme="light"] .vcall-modal__close:hover {
  background: rgba(0,0,0,.1);
}
[data-theme="light"] .vcall-modal__title {
  color: var(--text-1);
}
[data-theme="light"] .vcall-modal__subtitle {
  color: var(--text-2);
}
[data-theme="light"] .vcall-modal__input {
  background: rgba(0,0,0,.04);
  border: 1px solid var(--border);
  color: var(--text-1);
}
[data-theme="light"] .vcall-modal__input:focus {
  box-shadow: 0 0 0 3px rgba(207,138,2,.15);
  border-color: var(--accent);
}
[data-theme="light"] .vcall-modal__phone-row {
  background: rgba(0,0,0,.04);
  border: 1px solid var(--border);
}
[data-theme="light"] .vcall-modal__phone-row .vcall-modal__input {
  border: none;
}
[data-theme="light"] .vcall-modal__prefix-btn {
  color: var(--text-1);
  border-right-color: var(--border);
}
[data-theme="light"] .vcall-modal__prefix-btn:hover {
  background: rgba(0,0,0,.04);
}
[data-theme="light"] .vcall-modal__mic {
  background: rgba(207,138,2,.1);
  color: var(--accent);
}
[data-theme="light"] .vcall-modal__mic:hover {
  background: rgba(207,138,2,.18);
}
[data-theme="light"] .vcall-modal__start {
  background: var(--gradient);
  color: #fff;
}
[data-theme="light"] .vcall-modal__start:hover {
  background: var(--gradient);
  opacity: .9;
}
[data-theme="light"] .vcall-modal__start svg {
  stroke: #fff;
}
[data-theme="light"] .vcall-modal__avatar {
  border-color: rgba(207,138,2,.2);
  background: rgba(207,138,2,.06);
}
[data-theme="light"] .vcall-modal__avatar-ring {
  border-color: rgba(207,138,2,.2);
  border-top-color: transparent;
  border-right-color: transparent;
}
[data-theme="light"] .vcall-modal__online-dot {
  border-color: #fff;
}
[data-theme="light"] .vcall-modal__powered {
  color: var(--text-3);
}
[data-theme="light"] .vcall-modal__powered strong {
  color: var(--text-1);
}
[data-theme="light"] .chat-widget {
  background: var(--bg-raised);
  border-color: var(--border);
  box-shadow: 0 8px 40px rgba(0,0,0,.1);
}
[data-theme="light"] .chat-widget__header {
  border-bottom-color: var(--border);
}
[data-theme="light"] .chat-widget__option {
  background: rgba(0,0,0,.03);
  border-color: var(--border);
}
[data-theme="light"] .country-drop {
  background: #fff;
  border-color: var(--border);
  box-shadow: 0 12px 40px rgba(0,0,0,.12);
}
[data-theme="light"] .country-drop__search {
  background: rgba(0,0,0,.03);
  border-bottom-color: var(--border);
  color: var(--text-1);
}
[data-theme="light"] .country-drop__search::placeholder {
  color: var(--text-3);
}
[data-theme="light"] .country-drop__item {
  color: var(--text-1);
}
[data-theme="light"] .country-drop__item span {
  color: var(--text-3);
}
[data-theme="light"] .country-drop__item:hover {
  background: rgba(207,138,2,.08);
}
[data-theme="light"] .country-drop__list {
  scrollbar-color: rgba(0,0,0,.1) transparent;
}
[data-theme="light"] .strip__card-inner {
  background: var(--bg-raised);
}
[data-theme="light"] .section__orb {
  opacity: .3;
}
/* Hero pill stays light-on-dark even in light mode */
[data-theme="light"] .tag {
  background: rgba(207,138,2,.08);
}
[data-theme="light"] .header.scrolled .nav__link:hover {
  background: rgba(0,0,0,.05);
}
[data-theme="light"] .burger:hover {
  background: rgba(0,0,0,.05);
}
[data-theme="light"] .mobile-nav__links a:hover {
  background: rgba(0,0,0,.05);
}

/* ── THEME TOGGLE BUTTON ── */
.theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--bg-card);
  cursor: pointer;
  color: var(--text-2);
  transition: var(--transition);
  position: relative;
}
.theme-toggle:hover {
  background: var(--bg-card-hover);
  border-color: var(--border-hover);
  color: var(--text-1);
}

/* Sun shown in dark mode, Moon shown in light mode */
.theme-toggle__sun { display: block; }
.theme-toggle__moon { display: none; }
[data-theme="light"] .theme-toggle__sun { display: none; }
[data-theme="light"] .theme-toggle__moon { display: block; }

/* Mobile variant */
.theme-toggle--mobile {
  width: 100%;
  border-radius: var(--radius-md);
  height: 44px;
  gap: .5rem;
}
.theme-toggle__label {
  font-size: .8125rem;
  font-weight: 500;
}

/* ── RESET ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: 5rem;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text-2);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

::selection {
  background: rgba(207,138,2,.3);
  color: #fff;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
ul { list-style: none; }

/* ── CONTAINER ── */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}
.container--narrow { max-width: 800px; }

/* ── TYPOGRAPHY ── */
h1, h2, h3, h4 {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  color: var(--text-1);
  line-height: 1.15;
}

.gradient-text {
  background: var(--gradient-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ── TAG / BADGE ── */
.tag {
  display: inline-block;
  padding: .375rem 1rem;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(207,138,2,.08);
  border: 1px solid rgba(207,138,2,.15);
  border-radius: var(--radius-full);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BUTTONS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  font-family: inherit;
  font-weight: 600;
  font-size: .875rem;
  padding: .75rem 1.5rem;
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: var(--transition);
  white-space: nowrap;
  letter-spacing: -.01em;
}

.btn--sm  { padding: .625rem 1.25rem; font-size: .875rem; border-radius: var(--radius-md); }
.btn--lg  { padding: .875rem 2rem; font-size: .9375rem; border-radius: var(--radius-md); }
.btn--full { width: 100%; }

.btn--primary {
  background: var(--gradient);
  color: #fff;
  box-shadow: 0 0 20px rgba(207,138,2,.2);
}
.btn--primary:hover {
  box-shadow: 0 0 30px rgba(207,138,2,.35);
  transform: translateY(-1px);
}

.btn--glow {
  background: var(--gradient);
  color: #fff;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 30px rgba(207,138,2,.25), 0 4px 15px rgba(0,0,0,.3);
}
.btn--glow::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.15), transparent);
  opacity: 0;
  transition: opacity .3s;
}
.btn--glow:hover {
  box-shadow: 0 0 50px rgba(207,138,2,.4), 0 8px 25px rgba(0,0,0,.3);
  transform: translateY(-2px);
}
.btn--glow:hover::before { opacity: 1; }

.btn--glass {
  background: rgba(255,255,255,.04);
  color: var(--text-1);
  border: 1px solid var(--border);
  backdrop-filter: blur(10px);
}
.btn--glass:hover {
  background: rgba(255,255,255,.08);
  border-color: var(--border-hover);
  transform: translateY(-2px);
}

.btn--outline {
  background: rgba(255,255,255,.03);
  color: var(--text-2);
  border: 1px solid var(--border);
  backdrop-filter: blur(6px);
}
.btn--outline:hover {
  border-color: rgba(207,138,2,.4);
  background: rgba(207,138,2,.06);
  color: var(--text-1);
  box-shadow: 0 0 20px rgba(207,138,2,.08);
}

.btn--ghost {
  background: transparent;
  color: var(--text-2);
  border: 1px solid var(--border);
}
.btn--ghost:hover {
  border-color: var(--border-hover);
  color: var(--text-1);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HEADER
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: rgba(6,6,14,.6);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: background var(--transition), border-color var(--transition);
}
.header.scrolled {
  background: rgba(6,6,14,.92);
  border-bottom-color: rgba(255,255,255,.08);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 4.5rem;
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: .625rem;
}
.logo__icon { display: flex; }
.logo__text {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-1);
}
.logo__accent {
  background: var(--gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Nav */
.nav {
  display: none;
  align-items: center;
  gap: .25rem;
}
.nav__link {
  padding: .5rem 1rem;
  font-size: .875rem;
  font-weight: 500;
  color: var(--text-3);
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.nav__link:hover {
  color: var(--text-1);
  background: rgba(255,255,255,.05);
}

.header__right {
  display: none;
  align-items: center;
  gap: .75rem;
}
.nav__link--login { color: var(--text-3); }
.nav__link--login:hover { color: var(--text-1); }

/* Burger */
.burger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 2.5rem;
  height: 2.5rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: .5rem;
  border-radius: var(--radius-sm);
  transition: background var(--transition);
}
.burger:hover { background: rgba(255,255,255,.05); }
.burger span {
  display: block;
  height: 2px;
  background: var(--text-2);
  border-radius: 2px;
  transition: var(--transition);
}
.burger span:nth-child(1) { width: 100%; }
.burger span:nth-child(2) { width: 100%; }
.burger span:nth-child(3) { width: 66%; }

.burger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.active span:nth-child(2) { opacity: 0; }
.burger.active span:nth-child(3) { width: 100%; transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav */
.mobile-nav {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s cubic-bezier(.16,1,.3,1);
  border-top: 1px solid transparent;
}
.mobile-nav.open {
  max-height: 500px;
  border-top-color: var(--border);
}
.mobile-nav__links {
  display: flex;
  flex-direction: column;
  padding: 1rem 1.5rem;
  gap: .25rem;
}
.mobile-nav__links a {
  display: block;
  padding: .875rem 1rem;
  font-size: 1rem;
  color: var(--text-2);
  border-radius: var(--radius-md);
  transition: var(--transition);
}
.mobile-nav__links a:hover {
  color: var(--text-1);
  background: rgba(255,255,255,.05);
}
.mobile-nav__actions {
  padding: 0 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

@media (min-width: 1024px) {
  .nav { display: flex; }
  .header__right { display: flex; }
  .burger { display: none; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HERO
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* ── HERO (Fullscreen Video) ── */
.hero {
  position: relative;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

/* Background Video */
.hero__video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Dark Overlay */
.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg,
      rgba(6,6,14,.6) 0%,
      rgba(6,6,14,.45) 35%,
      rgba(6,6,14,.5) 65%,
      rgba(6,6,14,.92) 100%
    );
}

/* Centered Content */
.hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 1.5rem;
  animation: heroFadeIn 1.2s cubic-bezier(.16,1,.3,1) both;
}

.hero__badge {
  display: inline-block;
  padding: .5rem 1.25rem;
  margin-bottom: 1.5rem;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--accent);
  background: rgba(207,138,2,.1);
  border: 1px solid rgba(207,138,2,.25);
  border-radius: var(--radius-full);
}

.hero__title {
  font-size: clamp(2.5rem, 9vw, 5rem);
  font-weight: 800;
  letter-spacing: -.035em;
  line-height: 1.1;
  color: #fff;
  margin: 0 0 1.5rem;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.hero__title-gradient {
  background: var(--gradient-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 40px rgba(207,138,2,.25));
}

.hero__desc {
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  color: rgba(255,255,255,.55);
  line-height: 1.7;
  margin: 0 auto;
  font-weight: 400;
  letter-spacing: .01em;
  max-width: 680px;
}

/* Hero entrance animation */
@keyframes heroFadeIn {
  from {
    opacity: 0;
    transform: translateY(24px) scale(.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FEATURE STRIP
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.strip {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 2.5rem 0;
  background: rgba(255,255,255,.01);
}

.strip__row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

/* card — animated gradient border via background trick */
.strip__card {
  position: relative;
  border-radius: var(--radius-md);
  padding: 1px;
  background: var(--border);
  cursor: default;
  transition: var(--transition);
  animation: strip-float 4s ease-in-out infinite;
  animation-delay: calc(var(--i, 0) * .35s);
}

.strip__card:hover {
  background: var(--gradient-full);
  box-shadow: 0 0 28px rgba(207,138,2,.2), 0 0 56px rgba(230,168,23,.1);
  transform: translateY(-4px) !important;
}

/* inner sits on top of gradient border */
.strip__card-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  padding: 1.35rem .75rem;
  border-radius: calc(var(--radius-md) - 1px);
  background: var(--bg-raised);
  text-align: center;
  transition: background var(--transition);
}

.strip__card:hover .strip__card-inner {
  background: rgba(12,12,26,.92);
}

/* icon circle */
.strip__card-icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--gradient-subtle);
  transition: var(--transition);
}

.strip__card:hover .strip__card-icon {
  background: linear-gradient(135deg, rgba(207,138,2,.2), rgba(230,168,23,.15));
  box-shadow: 0 0 20px rgba(207,138,2,.25);
}

/* label */
.strip__card-label {
  font-size: .85rem;
  font-weight: 700;
  color: var(--text-1);
  letter-spacing: .01em;
  transition: var(--transition);
}

.strip__card:hover .strip__card-label {
  background: var(--gradient-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* tag beneath label */
.strip__card-tag {
  font-size: .65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  padding: .15rem .6rem;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  transition: var(--transition);
}

.strip__card:hover .strip__card-tag {
  border-color: rgba(207,138,2,.3);
  color: var(--accent);
}

/* staggered float */
@keyframes strip-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}

@media (min-width: 600px) {
  .strip__row { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 960px) {
  .strip__row {
    grid-template-columns: repeat(5, 1fr);
    gap: 1.25rem;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SECTIONS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.section {
  position: relative;
  padding: 6rem 0;
}
.section--alt {
  background: linear-gradient(180deg, var(--bg), rgba(255,255,255,.01) 50%, var(--bg));
}

.section__orb {
  position: absolute;
  width: 500px; height: 500px;
  border-radius: 50%;
  pointer-events: none;
}
.section__orb--left {
  background: radial-gradient(circle, rgba(207,138,2,.06), transparent 70%);
  left: -15%; top: 30%;
}
.section__orb--right {
  background: radial-gradient(circle, rgba(230,168,23,.06), transparent 70%);
  right: -15%; top: 20%;
}

.section__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 4rem;
}
.section__title {
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 700;
  margin-top: 1rem;
}
.section__desc {
  font-size: 1.0625rem;
  color: var(--text-2);
  margin-top: 1.25rem;
  line-height: 1.7;
}
.section__sub {
  font-size: .9375rem;
  color: var(--text-3);
  margin-top: .75rem;
  letter-spacing: .01em;
}

/* ── CARDS GRID 3-col ── */
.cards-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
@media (max-width: 768px) {
  .cards-3 { grid-template-columns: 1fr; }
}

/* ── GLASS CARD ── */
.glass-card {
  padding: 2rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: var(--transition);
}
.glass-card:hover {
  background: var(--bg-card-hover);
  border-color: var(--border-hover);
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.glass-card__icon {
  width: 3.5rem; height: 3.5rem;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  transition: var(--transition);
}
.glass-card__icon--red    { background: rgba(239,68,68,.1); color: var(--red); }
.glass-card__icon--amber  { background: rgba(245,158,11,.1); color: var(--amber); }
.glass-card__icon--violet { background: rgba(207,138,2,.1); color: #CF8A02; }

.glass-card:hover .glass-card__icon--red   { background: rgba(239,68,68,.18); }
.glass-card:hover .glass-card__icon--amber { background: rgba(245,158,11,.18); }
.glass-card:hover .glass-card__icon--violet{ background: rgba(207,138,2,.18); }

.glass-card__title {
  font-size: 1.125rem;
  font-weight: 600;
  margin-bottom: .75rem;
}
.glass-card__text {
  font-size: .875rem;
  line-height: 1.7;
}

/* ── GLOW CARD ── */
.glow-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border);
  transition: var(--transition);
}
.glow-card__border {
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  padding: 1px;
  background: linear-gradient(135deg, rgba(207,138,2,.3), transparent, rgba(230,168,23,.3));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity .4s;
}
.glow-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 40px rgba(207,138,2,.1);
}
.glow-card:hover .glow-card__border { opacity: 1; }

.glow-card__inner {
  position: relative;
  z-index: 1;
  padding: 2rem;
}
.glow-card__icon {
  width: 3.5rem; height: 3.5rem;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  background: rgba(207,138,2,.08);
}
.glow-card__inner h3 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: .75rem;
}
.glow-card__inner p {
  font-size: .875rem;
  line-height: 1.7;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FEATURES — Bento Grid
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Grid */
/* ── Features — Animated Border Bento ── */
@keyframes fb-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(15px, -10px) scale(1.06); }
  66% { transform: translate(-10px, 8px) scale(.96); }
}
@keyframes fb-card-in {
  to { opacity: 1; transform: translateY(0); }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FEATURE SHOWCASE — Tabbed Interactive
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.fshow {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 2rem;
  margin-top: 3.5rem;
  align-items: start;
}

/* ── Left: Tabs ── */
.fshow__tabs {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.fshow__tab {
  position: relative;
  display: flex;
  align-items: center;
  gap: .875rem;
  padding: 1rem 1.25rem;
  border: none;
  border-radius: 14px;
  background: transparent;
  cursor: pointer;
  text-align: left;
  transition: all .3s ease;
  overflow: hidden;
  color: var(--text-2);
}
.fshow__tab:hover {
  background: rgba(255,255,255,.03);
}
.fshow__tab--active {
  background: rgba(var(--fa-rgb), .06);
  color: var(--text-1);
}

/* Number */
.fshow__tab-num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .75rem;
  font-weight: 700;
  color: rgba(var(--fa-rgb), .3);
  min-width: 1.5rem;
  transition: color .3s ease;
}
.fshow__tab--active .fshow__tab-num {
  color: var(--fa);
}

/* Tab info */
.fshow__tab-info {
  flex: 1;
  min-width: 0;
}
.fshow__tab-label {
  display: block;
  font-size: .65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(var(--fa-rgb), .4);
  margin-bottom: .15rem;
  transition: color .3s ease;
}
.fshow__tab--active .fshow__tab-label {
  color: var(--fa);
}
.fshow__tab-title {
  display: block;
  font-size: .875rem;
  font-weight: 600;
  color: var(--text-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color .3s ease;
}
.fshow__tab--active .fshow__tab-title {
  color: var(--text-1);
}

/* Arrow */
.fshow__tab-arrow {
  opacity: 0;
  transform: translateX(-6px);
  transition: all .3s ease;
  color: var(--fa);
  flex-shrink: 0;
}
.fshow__tab--active .fshow__tab-arrow {
  opacity: 1;
  transform: translateX(0);
}

/* Auto-progress bar */
.fshow__tab-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0;
  background: linear-gradient(90deg, var(--fa), rgba(var(--fa-rgb), .2));
  border-radius: 2px;
}
.fshow__tab--active .fshow__tab-progress {
  animation: fshow-progress 6s linear forwards;
}
@keyframes fshow-progress {
  from { width: 0; }
  to { width: 100%; }
}

/* Left accent bar on active tab */
.fshow__tab::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  bottom: 20%;
  width: 3px;
  border-radius: 3px;
  background: var(--fa);
  opacity: 0;
  transform: scaleY(0);
  transition: all .3s ease;
}
.fshow__tab--active::before {
  opacity: 1;
  transform: scaleY(1);
}

/* ── Right: Preview Panel ── */
.fshow__preview {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  background: rgba(12, 12, 26, .6);
  border: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  min-height: 480px;
}

/* Background glow */
.fshow__preview-glow {
  position: absolute;
  top: -100px;
  right: -100px;
  width: 350px;
  height: 350px;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .15;
  pointer-events: none;
  transition: background .6s ease;
  background: radial-gradient(circle, var(--fa, #CF8A02), transparent 70%);
}

/* Panel */
.fshow__panel {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: opacity .4s ease, transform .4s ease;
}
.fshow__panel--active {
  position: relative;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Panel image */
.fshow__panel-img {
  position: relative;
  height: 320px;
  overflow: hidden;
  background: rgba(var(--fa-rgb), .03);
}
.fshow__panel-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s cubic-bezier(.16,1,.3,1);
}
.fshow__preview:hover .fshow__panel--active .fshow__panel-img img {
  transform: scale(1.03);
}

/* Panel body */
.fshow__panel-body {
  padding: 1.75rem 2rem 2rem;
}
.fshow__panel-title {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: .5rem;
}
.fshow__panel-desc {
  font-size: .875rem;
  line-height: 1.7;
  color: var(--text-2);
  margin-bottom: 1rem;
}
.fshow__panel-list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .75rem;
}
.fshow__panel-list li {
  font-size: .775rem;
  color: var(--text-3);
  display: flex;
  align-items: center;
  gap: .4rem;
}
.fshow__panel-list li::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--fa);
  flex-shrink: 0;
  opacity: .6;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .fshow {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .fshow__tabs {
    flex-direction: row;
    overflow-x: auto;
    gap: 6px;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .fshow__tabs::-webkit-scrollbar { display: none; }
  .fshow__tab {
    flex-shrink: 0;
    padding: .75rem 1rem;
    border-radius: 10px;
    min-width: max-content;
  }
  .fshow__tab-title { display: none; }
  .fshow__tab-arrow { display: none; }
  .fshow__tab-num { display: none; }
  .fshow__tab::before {
    left: 20%; right: 20%; top: auto; bottom: 0;
    width: auto; height: 2px;
    transform: scaleX(0);
  }
  .fshow__tab--active::before { transform: scaleX(1); }
  .fshow__tab-progress { display: none; }
  .fshow__preview { min-height: auto; }
  .fshow__panel-img { height: 220px; }
  .fshow__panel-body { padding: 1.25rem 1.5rem 1.5rem; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FEATURES — Alternating Rows (legacy)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.feature {
  display: flex;
  flex-direction: column;
  gap: 3rem;
  padding: 4rem 0;
  border-bottom: 1px solid var(--border);
}
.feature:last-of-type { border-bottom: none; }

@media (min-width: 768px) {
  .feature {
    flex-direction: row;
    align-items: center;
    gap: 4rem;
  }
  .feature--reverse { flex-direction: row-reverse; }
}

.feature__content { flex: 1; }
.feature__visual  { flex: 1; display: flex; justify-content: center; }

.feature__tag {
  display: inline-block;
  padding: .25rem .75rem;
  font-size: .6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-radius: var(--radius-full);
  background: rgba(207,138,2,.1);
  color: var(--accent);
  border: 1px solid rgba(207,138,2,.2);
  margin-bottom: 1rem;
}
.feature__tag--cyan   { background: rgba(207,138,2,.1); color: var(--accent-3); border-color: rgba(207,138,2,.2); }
.feature__tag--violet { background: rgba(207,138,2,.1); color: #CF8A02; border-color: rgba(207,138,2,.2); }
.feature__tag--amber  { background: rgba(245,158,11,.1); color: var(--amber); border-color: rgba(245,158,11,.2); }
.feature__tag--rose   { background: rgba(244,63,94,.1); color: #f43f5e; border-color: rgba(244,63,94,.2); }

.feature__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  margin-bottom: .75rem;
}
.feature__lead {
  font-size: 1.0625rem;
  color: var(--text-2);
  margin-bottom: .5rem;
}
.feature__text {
  font-size: .875rem;
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.feature__list {
  display: flex;
  flex-direction: column;
  gap: .625rem;
}
.feature__list li {
  display: flex;
  align-items: flex-start;
  gap: .625rem;
  font-size: .875rem;
  color: var(--text-2);
}
.feature__list li::before {
  content: '';
  width: 18px; height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
  border-radius: 50%;
  background: rgba(207,138,2,.12);
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a855f7' stroke-width='3' stroke-linecap='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 10px;
}

/* Feature Visual */
.feature__img {
  width: 100%;
  max-width: 480px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: linear-gradient(135deg, rgba(207,138,2,.06), rgba(207,138,2,.02));
  border: 1px solid var(--border);
  position: relative;
  transition: transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s ease;
}
.feature__img:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(207,138,2,.15);
}
.feature__img img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-xl);
}
.feature__img::after {
  content: attr(data-label);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: .65rem 1rem;
  font-size: .7rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(to top, rgba(0,0,0,.6), transparent);
  text-align: center;
  opacity: 0;
  transition: opacity .3s ease;
  pointer-events: none;
}
.feature__img:hover::after {
  opacity: 1;
}
.feature__img--cyan   { background: linear-gradient(135deg, rgba(207,138,2,.06), rgba(207,138,2,.02)); }
.feature__img--cyan:hover   { box-shadow: 0 16px 48px rgba(207,138,2,.15); }
.feature__img--violet { background: linear-gradient(135deg, rgba(207,138,2,.06), rgba(207,138,2,.02)); }
.feature__img--violet:hover { box-shadow: 0 16px 48px rgba(207,138,2,.15); }
.feature__img--amber  { background: linear-gradient(135deg, rgba(245,158,11,.06), rgba(245,158,11,.02)); }
.feature__img--amber:hover  { box-shadow: 0 16px 48px rgba(245,158,11,.15); }
.feature__img--rose   { background: linear-gradient(135deg, rgba(244,63,94,.06), rgba(244,63,94,.02)); }
.feature__img--rose:hover   { box-shadow: 0 16px 48px rgba(244,63,94,.15); }

@media (max-width: 767px) {
  .feature__img { max-width: 100%; }
}

/* More Features */
/* ── Features Ticker (infinite marquee) ── */
@keyframes feat-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.feat-ticker {
  margin-top: 3.5rem;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.feat-ticker__track {
  display: flex;
  gap: 1rem;
  width: max-content;
  animation: feat-scroll 25s linear infinite;
  padding: 20px 0px;
}
.feat-ticker:hover .feat-ticker__track {
  animation-play-state: paused;
}
.feat-ticker__item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .75rem 1.25rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  font-size: .8125rem;
  font-weight: 500;
  color: var(--text-2);
  white-space: nowrap;
  transition: var(--transition);
  cursor: default;
}
.feat-ticker__item svg {
  color: var(--fa);
  flex-shrink: 0;
}
.feat-ticker__item:hover {
  background: var(--bg-card-hover);
  border-color: rgba(var(--fa-rgb, 168,85,247), .25);
  color: var(--text-1);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   USE CASES — Rotating-Border Bento
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@property --border-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
@keyframes uc-spin {
  to { --border-angle: 360deg; }
}
@keyframes uc-float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(12px, -8px) scale(1.05); }
  66% { transform: translate(-8px, 6px) scale(.97); }
}
@keyframes uc-bar-in {
  from { width: 0; }
  to   { width: var(--bar-w, 0%); }
}

/* Grid */
/* ── Use Cases v2 — Tab Navigation ── */
.uc2-tabs {
  display: flex;
  gap: .5rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 3rem;
}
.uc2-tab {
  padding: .55rem 1.25rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: var(--text-3);
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .3s cubic-bezier(.16,1,.3,1);
  position: relative;
  overflow: hidden;
}
.uc2-tab::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--gradient);
  opacity: 0;
  transition: opacity .3s ease;
}
.uc2-tab:hover {
  border-color: rgba(208,141,21,.4);
  background: rgba(208,141,21,.1);
  color: var(--text-1);
  transform: translateY(-1px);
}
.uc2-tab--active {
  border-color: transparent;
  color: #fff;
  background: linear-gradient(135deg, #d08d15, #b87a0f);
  box-shadow: 0 4px 24px rgba(208,141,21,.45), 0 0 0 1px rgba(208,141,21,.25);
}
.uc2-tab--active::before {
  opacity: 0;
}
.uc2-tab span,
.uc2-tab {
  position: relative;
  z-index: 1;
}
[data-theme="light"] .uc2-tab {
  border-color: rgba(0,0,0,.08);
  background: rgba(0,0,0,.02);
}
[data-theme="light"] .uc2-tab--active {
  color: #fff;
  background: linear-gradient(135deg, #d08d15, #b87a0f);
  border-color: transparent;
  box-shadow: 0 4px 24px rgba(208,141,21,.3), 0 2px 8px rgba(0,0,0,.1);
}

/* ── Grid ── */
.uc2-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

/* ── Card Base ── */
.uc2-item {
  position: relative;
  border-radius: 1.25rem;
  transition: opacity .25s ease, transform .25s ease;
  opacity: 1;
  transform: translateY(0);
}
.uc2-item.uc2-item--hidden {
  opacity: 0;
  transform: scale(.95) translateY(10px);
  pointer-events: none;
  position: absolute;
  visibility: hidden;
  transition: opacity .15s ease, transform .15s ease, visibility 0s .15s, position 0s .15s;
}
.uc2-item--featured {
  grid-column: 1 / -1;
}
.uc2-item--wide {
  grid-column: span 2;
}

/* Glow effect */
.uc2-item__glow {
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(135deg,
    rgba(var(--accent-rgb), .25),
    transparent 40%,
    transparent 60%,
    rgba(var(--accent-rgb), .15)
  );
  opacity: 0;
  transition: opacity .4s ease;
  z-index: 0;
}
.uc2-item:hover .uc2-item__glow {
  opacity: 1;
}

/* Body */
.uc2-item__body {
  position: relative;
  z-index: 1;
  border-radius: 1.2rem;
  padding: 2rem;
  background: rgba(12, 12, 26, .9);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.05);
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: all .4s cubic-bezier(.16,1,.3,1);
}
.uc2-item:hover .uc2-item__body {
  border-color: rgba(var(--accent-rgb), .2);
  transform: translateY(-6px);
  box-shadow:
    0 30px 80px rgba(0,0,0,.3),
    0 0 60px rgba(var(--accent-rgb), .08),
    inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .uc2-item__body {
  background: rgba(255,255,255,.88);
  border-color: rgba(0,0,0,.06);
}
[data-theme="light"] .uc2-item:hover .uc2-item__body {
  border-color: rgba(var(--accent-rgb), .25);
  box-shadow: 0 30px 80px rgba(0,0,0,.08), 0 0 40px rgba(var(--accent-rgb), .06);
}

/* ── Scene / Animated Icon Area ── */
.uc2-item__scene {
  position: relative;
  width: 100%;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  border-radius: .75rem;
  background: radial-gradient(ellipse at center, rgba(var(--accent-rgb), .06), transparent 70%);
  overflow: hidden;
}
.uc2-item__scene--sm {
  height: 120px;
  margin-bottom: 1.25rem;
}

/* Animated rings */
.uc2-scene-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(var(--accent-rgb), .12);
  animation: uc2-ring-pulse 4s ease-in-out infinite;
}
.uc2-scene-ring--1 {
  width: 80px; height: 80px;
  animation-delay: 0s;
}
.uc2-scene-ring--2 {
  width: 140px; height: 140px;
  animation-delay: .5s;
  border-style: dashed;
}
.uc2-scene-ring--3 {
  width: 200px; height: 200px;
  animation-delay: 1s;
}
@keyframes uc2-ring-pulse {
  0%, 100% { transform: scale(.9); opacity: .3; }
  50%      { transform: scale(1.1); opacity: .7; }
}
.uc2-item:hover .uc2-scene-ring {
  border-color: rgba(var(--accent-rgb), .3);
}

/* Animated sound wave */
.uc2-scene-wave {
  display: flex;
  align-items: center;
  gap: 4px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
}
.uc2-scene-wave span {
  display: block;
  width: 3px;
  border-radius: 99px;
  background: linear-gradient(180deg, var(--accent), rgba(var(--accent-rgb), .2));
  animation: uc2-wave 1.2s ease-in-out infinite;
}
.uc2-scene-wave span:nth-child(1) { height: 12px; animation-delay: 0s; }
.uc2-scene-wave span:nth-child(2) { height: 24px; animation-delay: .15s; }
.uc2-scene-wave span:nth-child(3) { height: 36px; animation-delay: .3s; }
.uc2-scene-wave span:nth-child(4) { height: 24px; animation-delay: .45s; }
.uc2-scene-wave span:nth-child(5) { height: 12px; animation-delay: .6s; }
@keyframes uc2-wave {
  0%, 100% { transform: scaleY(1); }
  50%      { transform: scaleY(1.8); }
}

/* Animated pulse (healthcare) */
.uc2-scene-pulse {
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: rgba(var(--accent-rgb), .12);
  animation: uc2-pulse 2s ease-in-out infinite;
}
.uc2-scene-pulse::before,
.uc2-scene-pulse::after {
  content: '';
  position: absolute;
  inset: -15px;
  border-radius: 50%;
  border: 1px solid rgba(var(--accent-rgb), .1);
  animation: uc2-pulse 2s ease-in-out infinite;
}
.uc2-scene-pulse::after {
  inset: -30px;
  animation-delay: .3s;
}
@keyframes uc2-pulse {
  0%, 100% { transform: scale(.85); opacity: .4; }
  50%      { transform: scale(1.15); opacity: .9; }
}

/* Animated dots grid */
.uc2-scene-dots {
  position: absolute;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  opacity: .3;
}
.uc2-scene-dots span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  animation: uc2-dot-blink 2.5s ease-in-out infinite;
}
.uc2-scene-dots span:nth-child(1) { animation-delay: 0s; }
.uc2-scene-dots span:nth-child(2) { animation-delay: .2s; }
.uc2-scene-dots span:nth-child(3) { animation-delay: .4s; }
.uc2-scene-dots span:nth-child(4) { animation-delay: .1s; }
.uc2-scene-dots span:nth-child(5) { animation-delay: .3s; }
.uc2-scene-dots span:nth-child(6) { animation-delay: .5s; }
.uc2-scene-dots span:nth-child(7) { animation-delay: .2s; }
.uc2-scene-dots span:nth-child(8) { animation-delay: .4s; }
.uc2-scene-dots span:nth-child(9) { animation-delay: .6s; }
@keyframes uc2-dot-blink {
  0%, 100% { opacity: .3; transform: scale(1); }
  50%      { opacity: 1; transform: scale(1.5); }
}

/* Animated bars chart */
.uc2-scene-bars {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  height: 50px;
  opacity: .3;
}
.uc2-scene-bars span {
  display: block;
  width: 8px;
  border-radius: 4px 4px 0 0;
  background: linear-gradient(180deg, var(--accent), rgba(var(--accent-rgb), .3));
  animation: uc2-bar-grow 2s ease-in-out infinite;
}
.uc2-scene-bars span:nth-child(1) { height: 20px; animation-delay: 0s; }
.uc2-scene-bars span:nth-child(2) { height: 35px; animation-delay: .2s; }
.uc2-scene-bars span:nth-child(3) { height: 28px; animation-delay: .4s; }
.uc2-scene-bars span:nth-child(4) { height: 42px; animation-delay: .6s; }
.uc2-scene-bars span:nth-child(5) { height: 32px; animation-delay: .8s; }
@keyframes uc2-bar-grow {
  0%, 100% { transform: scaleY(1); }
  50%      { transform: scaleY(1.4); }
}

/* Center icon */
.uc2-scene-icon {
  position: relative;
  z-index: 2;
  width: 64px;
  height: 64px;
  border-radius: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, rgba(var(--accent-rgb), .2), rgba(var(--accent-rgb), .05));
  border: 1px solid rgba(var(--accent-rgb), .15);
  color: var(--accent);
  transition: all .4s cubic-bezier(.16,1,.3,1);
  backdrop-filter: blur(8px);
}
.uc2-item__scene--sm .uc2-scene-icon {
  width: 52px;
  height: 52px;
  border-radius: .75rem;
}
.uc2-item:hover .uc2-scene-icon {
  transform: scale(1.1) rotate(-3deg);
  background: linear-gradient(145deg, rgba(var(--accent-rgb), .35), rgba(var(--accent-rgb), .1));
  box-shadow: 0 8px 32px rgba(var(--accent-rgb), .2), 0 0 0 1px rgba(var(--accent-rgb), .2);
}

/* ── Badge ── */
.uc2-item__badge {
  display: inline-block;
  padding: .3rem .9rem;
  border-radius: var(--radius-full);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  background: linear-gradient(135deg, rgba(var(--accent-rgb), .2), rgba(var(--accent-rgb), .05));
  color: var(--accent);
  border: 1px solid rgba(var(--accent-rgb), .15);
  margin-bottom: .75rem;
}

/* ── Typography ── */
.uc2-item__title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: .5rem;
}
.uc2-item__desc {
  font-size: .875rem;
  line-height: 1.7;
  color: var(--text-2);
  flex: 1;
}

/* ── Featured card — row layout ── */
.uc2-item--featured .uc2-item__body {
  flex-direction: row;
  gap: 2.5rem;
  align-items: center;
}
.uc2-item--featured .uc2-item__scene {
  flex-shrink: 0;
  width: 260px;
  height: 220px;
  margin-bottom: 0;
}
.uc2-item--featured .uc2-item__info {
  flex: 1;
}

/* ── Wide card — row layout ── */
.uc2-item--wide .uc2-item__body {
  flex-direction: row;
  align-items: center;
  gap: 1.5rem;
}
.uc2-item--wide .uc2-item__scene--sm {
  flex-shrink: 0;
  width: 120px;
  margin-bottom: 0;
}

/* ── Metrics ── */
.uc2-item__metrics {
  display: flex;
  gap: 2rem;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(var(--accent-rgb), .1);
}
.uc2-metric {
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.uc2-metric__num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
}
.uc2-metric__label {
  font-size: .7rem;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 500;
}

/* ── Progress Bar (small cards) ── */
.uc2-item__stat-row {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-top: 1rem;
  padding-top: .75rem;
  border-top: 1px solid rgba(var(--accent-rgb), .08);
}
.uc2-item__progress {
  flex: 1;
  height: 4px;
  border-radius: 99px;
  background: rgba(var(--accent-rgb), .1);
  overflow: hidden;
}
.uc2-item__progress-fill {
  height: 100%;
  width: 0;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--accent), rgba(var(--accent-rgb), .4));
  transition: width 1s cubic-bezier(.16,1,.3,1) .3s;
}
.uc2-item:hover .uc2-item__progress-fill {
  width: var(--pw, 0%);
}
.uc2-item__stat-val {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  color: var(--accent);
  white-space: nowrap;
}

/* ── Stagger entrance (initial load only) ── */
.uc2-grid:not(.uc2-grid--filtered) .uc2-item {
  animation: uc2-in .5s cubic-bezier(.16,1,.3,1) both;
}
.uc2-grid:not(.uc2-grid--filtered) .uc2-item:nth-child(1) { animation-delay: .05s; }
.uc2-grid:not(.uc2-grid--filtered) .uc2-item:nth-child(2) { animation-delay: .1s; }
.uc2-grid:not(.uc2-grid--filtered) .uc2-item:nth-child(3) { animation-delay: .15s; }
.uc2-grid:not(.uc2-grid--filtered) .uc2-item:nth-child(4) { animation-delay: .2s; }
.uc2-grid:not(.uc2-grid--filtered) .uc2-item:nth-child(5) { animation-delay: .25s; }
.uc2-grid:not(.uc2-grid--filtered) .uc2-item:nth-child(6) { animation-delay: .3s; }
@keyframes uc2-in {
  from { opacity: 0; transform: translateY(30px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .uc2-grid { grid-template-columns: repeat(2, 1fr); }
  .uc2-item--featured { grid-column: 1 / -1; }
  .uc2-item--wide { grid-column: 1 / -1; }
  .uc2-item--featured .uc2-item__body {
    flex-direction: column;
    gap: 1.5rem;
  }
  .uc2-item--featured .uc2-item__scene {
    width: 100%;
    height: 160px;
  }
  .uc2-item--featured .uc2-item__metrics {
    flex-wrap: wrap;
    gap: 1rem;
  }
}
@media (max-width: 640px) {
  .uc2-tabs {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: .5rem;
    scrollbar-width: none;
  }
  .uc2-tabs::-webkit-scrollbar { display: none; }
  .uc2-tab { white-space: nowrap; flex-shrink: 0; }
  .uc2-grid { grid-template-columns: 1fr; }
  .uc2-item--wide { grid-column: auto; }
  .uc2-item--wide .uc2-item__body {
    flex-direction: column;
  }
  .uc2-item--wide .uc2-item__scene--sm {
    width: 100%;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HOW IT WORKS — Timeline Steps
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.hiw {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 3.5rem;
  padding-left: 60px;
}

/* ── Vertical timeline line ── */
.hiw__line {
  display: none;
}

/* ── Step connector lines (1→2 and 2→3) ── */
.hiw__step + .hiw__step .hiw__node::before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: calc(100% + 4px);
  width: 2px;
  height: 235px;
  transform: translateX(-50%);
  background: rgba(var(--step-rgb), .2);
  border-radius: 2px;
}

/* ── Step row ── */
.hiw__step {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  padding: 2rem 0;
}

/* ── Node (left circle) ── */
.hiw__node {
  position: absolute;
  left: -60px;
  top: 2rem;
  width: 54px;
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.hiw__node-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(var(--step-rgb), .2);
  transition: all .4s ease;
}
.hiw__step:hover .hiw__node-ring {
  border-color: rgba(var(--step-rgb), .5);
  box-shadow: 0 0 20px rgba(var(--step-rgb), .15);
  transform: scale(1.1);
}
.hiw__node-icon {
  position: relative;
  z-index: 2;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(var(--step-rgb), .1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--step-color);
  transition: all .4s ease;
}
.hiw__step:hover .hiw__node-icon {
  background: rgba(var(--step-rgb), .2);
  transform: scale(1.08);
}
.hiw__node-num {
  position: absolute;
  top: -8px;
  right: -4px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: .6rem;
  font-weight: 800;
  color: var(--step-color);
  background: rgba(var(--step-rgb), .12);
  border: 1px solid rgba(var(--step-rgb), .2);
  border-radius: 6px;
  padding: 1px 5px;
  line-height: 1.4;
  z-index: 3;
}

/* ── Card ── */
.hiw__card {
  position: relative;
  flex: 1;
  padding: 2rem 2rem 1.75rem;
  border-radius: 16px;
  background: rgba(12, 12, 26, .5);
  border: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: all .4s ease;
  overflow: hidden;
}
.hiw__card:hover {
  border-color: rgba(var(--step-rgb), .2);
  transform: translateX(6px);
  box-shadow: 0 20px 50px rgba(0,0,0,.2), 0 0 30px rgba(var(--step-rgb), .05);
}

/* Top accent bar */
.hiw__card-accent {
  position: absolute;
  top: 0;
  left: 2rem;
  width: 50px;
  height: 3px;
  border-radius: 0 0 3px 3px;
  background: linear-gradient(90deg, var(--step-color), rgba(var(--step-rgb), .2));
  transition: width .4s ease;
}
.hiw__card:hover .hiw__card-accent {
  width: 80px;
}

/* Badge */
.hiw__badge {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--step-color);
  margin-bottom: .75rem;
  margin-top: .25rem;
}

/* Title */
.hiw__title {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: .5rem;
  line-height: 1.35;
}

/* Description */
.hiw__desc {
  font-size: .875rem;
  line-height: 1.75;
  color: var(--text-2);
  margin-bottom: 1.25rem;
}

/* Highlight chips */
.hiw__highlights {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.hiw__chip {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .7rem;
  font-weight: 500;
  color: var(--text-3);
  padding: .35rem .7rem;
  border-radius: 8px;
  background: rgba(var(--step-rgb), .05);
  border: 1px solid rgba(var(--step-rgb), .1);
  transition: all .3s ease;
}
.hiw__chip svg {
  color: var(--step-color);
  opacity: .7;
}
.hiw__step:hover .hiw__chip {
  background: rgba(var(--step-rgb), .1);
  border-color: rgba(var(--step-rgb), .2);
}

/* ── Light theme ── */
[data-theme="light"] .hiw__card {
  background: rgba(255,255,255,.8);
  border-color: var(--border);
}
[data-theme="light"] .hiw__step + .hiw__step .hiw__node::before {
  background: linear-gradient(180deg, rgba(var(--step-rgb), .06), rgba(var(--step-rgb), .2));
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .hiw {
    padding-left: 44px;
  }
  .hiw__step + .hiw__step .hiw__node::before {
    height: .5rem;
  }
  .hiw__node {
    left: -44px;
    width: 40px;
    height: 40px;
  }
  .hiw__node-icon {
    width: 32px;
    height: 32px;
  }
  .hiw__node-icon svg {
    width: 18px;
    height: 18px;
  }
  .hiw__node-num {
    font-size: .5rem;
    top: -6px;
    right: -6px;
  }
  .hiw__card {
    padding: 1.5rem;
  }
  .hiw__card:hover {
    transform: translateX(0) translateY(-4px);
  }
  .hiw__title {
    font-size: 1.15rem;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   INTEGRATIONS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* ── Orbit wrapper ── */
.intg {
  position: relative;
  width: 100%;
  max-width: 600px;
  aspect-ratio: 1;
  margin: 0 auto 3rem;
}

/* ── Center hub ── */
.intg__orbit {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.intg__hub {
  position: relative;
  z-index: 3;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(207,138,2,.08);
  border: 1.5px solid rgba(207,138,2,.2);
  display: flex;
  align-items: center;
  justify-content: center;
}
.intg__hub-pulse {
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  border: 1px solid rgba(207,138,2,.12);
  animation: secPulse 3s ease-out infinite;
}

/* ── Orbit rings ── */
.intg__ring {
  position: absolute;
  border-radius: 50%;
  border: 1px dashed rgba(255,255,255,.05);
  animation: intgSpin 60s linear infinite;
}
.intg__ring--1 {
  width: 65%;
  height: 65%;
  border-color: rgba(207,138,2,.08);
}
.intg__ring--2 {
  width: 92%;
  height: 92%;
  border-color: rgba(255,255,255,.04);
  animation-direction: reverse;
  animation-duration: 90s;
}
@keyframes intgSpin {
  to { transform: rotate(360deg); }
}

/* ── Floating nodes ── */
.intg__nodes {
  position: absolute;
  inset: 0;
}
.intg__node {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  color: var(--n-color);
  transition: all .4s ease;
  cursor: default;
  z-index: 2;
}
.intg__node svg {
  width: 42px;
  height: 42px;
  padding: 11px;
  border-radius: 14px;
  background: rgba(var(--n-rgb), .06);
  border: 1px solid rgba(var(--n-rgb), .14);
  transition: all .4s ease;
}
.intg__node:hover svg {
  background: rgba(var(--n-rgb), .14);
  border-color: rgba(var(--n-rgb), .3);
  transform: scale(1.12);
  box-shadow: 0 0 24px rgba(var(--n-rgb), .15);
}
.intg__node-label {
  font-family: 'Space Grotesk', sans-serif;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .03em;
  color: var(--text-2);
  white-space: nowrap;
  transition: color .3s ease;
}
.intg__node:hover .intg__node-label {
  color: var(--n-color);
}

/* ── Node positions (8 around a circle) ── */
.intg__node--1 { top: 2%;   left: 50%;  transform: translateX(-50%); }
.intg__node--2 { top: 14%;  right: 8%;  }
.intg__node--3 { top: 45%;  right: 0;   transform: translateY(-50%); }
.intg__node--4 { bottom: 14%; right: 8%; }
.intg__node--5 { bottom: 2%; left: 50%; transform: translateX(-50%); }
.intg__node--6 { bottom: 14%; left: 8%;  }
.intg__node--7 { top: 45%;  left: 0;    transform: translateY(-50%); }
.intg__node--8 { top: 14%;  left: 8%;   }

/* ── Connection lines (decorative beams) ── */
.intg__lines {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.intg__line {
  position: absolute;
  top: 50%;
  left: 50%;
  height: 1px;
  width: 38%;
  transform-origin: 0 0;
  background: linear-gradient(90deg, rgba(207,138,2,.15), transparent);
}
.intg__line--1 { transform: rotate(0deg); }
.intg__line--2 { transform: rotate(90deg); }
.intg__line--3 { transform: rotate(180deg); }
.intg__line--4 { transform: rotate(270deg); }

/* ── Detail chips ── */
.intg-chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .5rem;
  margin-bottom: 2rem;
}
.intg-chip {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .4rem .85rem;
  border-radius: 99px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  font-size: .7rem;
  font-weight: 500;
  color: var(--text-2);
  transition: all .3s ease;
}
.intg-chip:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  transform: translateY(-1px);
}
.intg-chip__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── CTA ── */
.int-cta {
  text-align: center;
  font-size: .875rem;
  color: var(--text-3);
  margin-top: 1.5rem;
}
.int-cta a {
  color: var(--accent);
  font-weight: 500;
  transition: color var(--transition);
}
.int-cta a:hover { color: #E6A817; }

/* ── Light theme ── */
[data-theme="light"] .intg__hub {
  background: rgba(207,138,2,.06);
}
[data-theme="light"] .intg__ring--1 { border-color: rgba(207,138,2,.06); }
[data-theme="light"] .intg__ring--2 { border-color: rgba(0,0,0,.04); }
[data-theme="light"] .intg-chip {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.06);
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .intg { max-width: 400px; }
  .intg__node svg { width: 36px; height: 36px; padding: 9px; border-radius: 10px; }
  .intg__node-label { font-size: .55rem; }
}
@media (max-width: 480px) {
  .intg { max-width: 300px; }
  .intg__node svg { width: 30px; height: 30px; padding: 7px; border-radius: 8px; }
  .intg__node-label { display: none; }
  .intg-chip { font-size: .6rem; padding: .3rem .65rem; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PRICING
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.pricing-section {
  position: relative;
  overflow: hidden;
}
.pricing-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
  z-index: 0;
}
.pricing-orb--1 {
  width: 500px; height: 500px;
  background: rgba(207,138,2,.08);
  top: -10%; left: -10%;
  animation: pricingFloat 12s ease-in-out infinite;
}
.pricing-orb--2 {
  width: 400px; height: 400px;
  background: rgba(230,168,23,.06);
  bottom: -10%; right: -10%;
  animation: pricingFloat 10s ease-in-out infinite reverse;
}
@keyframes pricingFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(30px, -20px) scale(1.05); }
}

/* Billing Toggle */
.billing-toggle {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  margin-top: 1.5rem;
  padding: .5rem 1.25rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
}
.billing-toggle__label {
  font-size: .8125rem;
  font-weight: 500;
  color: var(--text-3);
  cursor: pointer;
  transition: color var(--transition);
}
.billing-toggle__label--active {
  color: var(--text-1);
}
.billing-toggle__switch {
  position: relative;
  width: 44px; height: 24px;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: var(--transition);
  padding: 0;
}
.billing-toggle__switch:hover {
  border-color: var(--border-hover);
}
.billing-toggle__switch.active {
  background: var(--gradient);
  border-color: transparent;
}
.billing-toggle__thumb {
  position: absolute;
  top: 2px; left: 2px;
  width: 18px; height: 18px;
  background: #fff;
  border-radius: 50%;
  transition: transform var(--transition);
  box-shadow: 0 1px 4px rgba(0,0,0,.3);
}
.billing-toggle__switch.active .billing-toggle__thumb {
  transform: translateX(20px);
}
.billing-toggle__save {
  font-size: .6875rem;
  font-weight: 700;
  color: var(--green);
  background: rgba(16,185,129,.1);
  padding: .25rem .625rem;
  border-radius: var(--radius-full);
  letter-spacing: .02em;
}

/* Pricing Grid */
.pricing-grid {
  display: grid;
  grid-template-columns: 1fr 1.15fr 1fr;
  gap: 1.75rem;
  max-width: 1100px;
  margin: 0 auto;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px) {
  .pricing-grid { grid-template-columns: 1fr; max-width: 420px; }
}

/* Price Card */
.price-card {
  position: relative;
  border-radius: var(--radius-xl);
  transition: transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s ease, border-color .3s ease;
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border);
}
.price-card__glow {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  opacity: 0;
  transition: opacity .5s ease;
  background: radial-gradient(ellipse at 50% -20%, rgba(207,138,2,.1), transparent 65%);
  pointer-events: none;
  z-index: 0;
}
.price-card:hover .price-card__glow {
  opacity: 1;
}
.price-card:hover {
  border-color: rgba(207,138,2,.25);
  transform: translateY(-8px);
  box-shadow: 0 24px 64px rgba(0,0,0,.25), 0 0 40px rgba(207,138,2,.06);
}

/* Featured Card */
.price-card--featured {
  border: none;
  background: none;
  padding: 2px;
  background: linear-gradient(170deg, rgba(207,138,2,.65), rgba(230,168,23,.45), rgba(207,138,2,.35));
  box-shadow: 0 0 50px rgba(207,138,2,.12), 0 0 100px rgba(230,168,23,.06);
  transform: scale(1.02);
}
.price-card--featured .price-card__inner {
  background: var(--bg-raised);
  border-radius: calc(var(--radius-xl) - 2px);
}
.price-card--featured:hover {
  box-shadow: 0 0 70px rgba(207,138,2,.22), 0 0 120px rgba(230,168,23,.12);
  transform: scale(1.02) translateY(-8px);
}
.price-card__glow--featured {
  background: radial-gradient(ellipse at 50% -10%, rgba(207,138,2,.18), rgba(230,168,23,.08), transparent 65%);
}
.price-card--featured:hover .price-card__glow--featured {
  opacity: 1;
}

/* Ribbon */
.price-card__ribbon {
  position: absolute;
  top: 28px;
  right: -47px;
  padding: .3125rem 2.5rem;
  font-size: .625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #fff;
  background: var(--gradient);
  transform: rotate(45deg);
  z-index: 2;
  box-shadow: 0 2px 8px rgba(207,138,2,.3);
}

/* Card Inner */
.price-card__inner {
  padding: 2.75rem 2.25rem;
  position: relative;
  z-index: 1;
  border-radius: var(--radius-xl);
}

/* Card Icon */
.price-card__icon {
  width: 48px; height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--text-3);
  margin-bottom: 1.25rem;
  transition: var(--transition);
}
.price-card:hover .price-card__icon {
  border-color: var(--border-hover);
  color: var(--text-2);
}
.price-card__icon--featured {
  background: rgba(207,138,2,.08);
  border-color: rgba(207,138,2,.2);
  color: var(--accent);
}
.price-card--featured:hover .price-card__icon--featured {
  background: rgba(207,138,2,.12);
  border-color: rgba(207,138,2,.35);
  color: var(--accent);
}

/* Name & Description */
.price-card__name {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: .375rem;
  letter-spacing: -.01em;
}
.price-card__desc {
  font-size: .8125rem;
  color: var(--text-3);
  line-height: 1.5;
  margin-bottom: 1.25rem;
}

/* Price Display */
.price-card__price {
  display: flex;
  align-items: baseline;
  gap: .125rem;
  margin-bottom: 1.5rem;
}
.price-card__currency {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--text-2);
  align-self: flex-start;
  margin-top: .5rem;
}
.price-card__amount {
  font-size: 3.5rem;
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1;
  background: var(--gradient-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: var(--transition);
}
.price-card__amount--custom {
  font-size: 2.5rem;
  background: var(--gradient-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.price-card__period {
  font-size: .875rem;
  color: var(--text-3);
  font-weight: 500;
  margin-left: .25rem;
}

/* Divider */
.price-card__divider {
  height: 1px;
  background: var(--border);
  margin-bottom: 1.5rem;
}
.price-card__divider--featured {
  background: linear-gradient(90deg, transparent, rgba(207,138,2,.3), rgba(230,168,23,.2), transparent);
}

/* Feature List */
.price-card__list {
  margin-bottom: 2rem;
  list-style: none;
  padding: 0;
}
.price-card__list li {
  display: flex;
  align-items: center;
  gap: .75rem;
  font-size: .8125rem;
  padding: .5rem 0;
  color: var(--text-2);
  line-height: 1.4;
}
.price-card__check {
  width: 20px; height: 20px;
  flex-shrink: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(100,116,139,.1);
  position: relative;
}
.price-card__check::after {
  content: '';
  width: 10px; height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='3' stroke-linecap='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.price-card__check--accent {
  background: rgba(207,138,2,.12);
}
.price-card__check--accent::after {
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23a855f7' stroke-width='3' stroke-linecap='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
}

/* Pricing Card Buttons */
.price-card .btn {
  margin-top: auto;
  font-weight: 700;
  padding: .875rem 1.5rem;
  font-size: .875rem;
  border-radius: var(--radius-md);
  letter-spacing: .01em;
}
.price-card .btn--outline {
  background: rgba(255,255,255,.02);
  border: 1.5px solid var(--border);
}
.price-card .btn--outline:hover {
  border-color: rgba(207,138,2,.5);
  background: rgba(207,138,2,.08);
  color: #fff;
  box-shadow: 0 0 24px rgba(207,138,2,.12), 0 4px 12px rgba(0,0,0,.2);
  transform: translateY(-1px);
}
.price-card .btn--glow {
  padding: 1rem 1.5rem;
  font-size: .9375rem;
  box-shadow: 0 0 30px rgba(207,138,2,.3), 0 4px 20px rgba(0,0,0,.3);
}
.price-card .btn--glow:hover {
  box-shadow: 0 0 50px rgba(207,138,2,.45), 0 8px 30px rgba(0,0,0,.3);
  transform: translateY(-2px);
}

/* Money-back Guarantee */
.pricing-guarantee {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  margin-top: 2.5rem;
  font-size: .8125rem;
  color: var(--text-3);
  position: relative;
  z-index: 1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   TESTIMONIALS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
@media (max-width: 768px) { .testi-grid { grid-template-columns: 1fr; } }

.testi-card {
  padding: 2rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: var(--transition);
}
.testi-card:hover {
  background: var(--bg-card-hover);
  border-color: var(--border-hover);
  transform: translateY(-4px);
}
.testi-card__stars {
  color: var(--amber);
  font-size: 1rem;
  letter-spacing: .125rem;
  margin-bottom: 1rem;
}
.testi-card blockquote {
  font-size: .875rem;
  line-height: 1.7;
  color: var(--text-2);
  margin-bottom: 1.5rem;
}
.testi-card__author {
  display: flex;
  align-items: center;
  gap: .75rem;
}
.testi-card__avatar {
  width: 2.5rem; height: 2.5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  font-weight: 700;
  color: #fff;
  background: var(--gradient);
  flex-shrink: 0;
}
.testi-card__author strong {
  display: block;
  font-size: .8125rem;
  color: var(--text-1);
}
.testi-card__author span {
  font-size: .75rem;
  color: var(--text-3);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SECURITY
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* ── Bento grid layout ── */
.sec-bento {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto auto auto;
  gap: 1rem;
  max-width: 960px;
  margin: 0 auto;
}

/* ── Hero card (left, spans 2 rows) ── */
.sec-hero {
  grid-column: 1;
  grid-row: 1 / 3;
  position: relative;
  padding: 2.5rem 2rem;
  border-radius: 20px;
  background: linear-gradient(160deg, rgba(207,138,2,.06) 0%, rgba(12,12,26,.6) 50%, rgba(207,138,2,.03) 100%);
  border: 1px solid rgba(207,138,2,.12);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.sec-hero__glow {
  position: absolute;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(207,138,2,.15) 0%, transparent 70%);
  pointer-events: none;
}
.sec-hero__shield {
  position: relative;
  margin-bottom: 1.5rem;
}
.sec-hero__pulse {
  position: absolute;
  inset: -12px;
  border-radius: 50%;
  border: 1px solid rgba(207,138,2,.15);
  animation: secPulse 3s ease-out infinite;
}
.sec-hero__pulse--delay {
  animation-delay: 1.5s;
}
@keyframes secPulse {
  0%   { transform: scale(.8); opacity: .6; }
  100% { transform: scale(1.6); opacity: 0; }
}
.sec-hero__title {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text-1);
  line-height: 1.3;
  margin-bottom: .75rem;
}
.sec-hero__desc {
  font-size: .8125rem;
  color: var(--text-2);
  line-height: 1.6;
  max-width: 220px;
  margin-bottom: 1.25rem;
}
.sec-hero__status {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #10b981;
  background: rgba(16,185,129,.06);
  border: 1px solid rgba(16,185,129,.15);
  border-radius: 99px;
  padding: .4rem 1rem;
}
.sec-hero__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #10b981;
  animation: secDotBlink 2s ease-in-out infinite;
}
@keyframes secDotBlink {
  0%, 100% { opacity: 1; }
  50%      { opacity: .3; }
}

/* ── Feature cells (right side, numbered rows) ── */
.sec-cell {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  border-radius: 14px;
  background: rgba(12,12,26,.45);
  border: 1px solid rgba(255,255,255,.05);
  transition: all .35s ease;
  overflow: hidden;
}
.sec-cell::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(207,138,2,.04) 0%, transparent 60%);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}
.sec-cell:hover {
  border-color: rgba(207,138,2,.15);
  transform: translateX(4px);
}
.sec-cell:hover::after { opacity: 1; }

.sec-cell__num {
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #CF8A02;
  position: relative;
  transition: all .35s ease;
  box-shadow: 0 0 6px rgba(207,138,2,.3);
}
.sec-cell__num::before {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 1.5px dashed rgba(207,138,2,.2);
  animation: secOrbit 8s linear infinite;
}
@keyframes secOrbit {
  to { transform: rotate(360deg); }
}
.sec-cell:hover .sec-cell__num {
  background: #E6A817;
  box-shadow: 0 0 14px rgba(207,138,2,.45);
  transform: scale(1.3);
}
.sec-cell:hover .sec-cell__num::before {
  border-color: rgba(207,138,2,.35);
}
.sec-cell__body { flex: 1; min-width: 0; }
.sec-cell__title {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-size: .875rem;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: .2rem;
}
.sec-cell__desc {
  font-size: .75rem;
  color: var(--text-2);
  line-height: 1.5;
}
.sec-cell__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(207,138,2,.06);
  border: 1px solid rgba(207,138,2,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #CF8A02;
  transition: all .35s ease;
}
.sec-cell:hover .sec-cell__icon {
  background: rgba(207,138,2,.12);
  transform: scale(1.08);
}

/* ── Wide bottom cards ── */
.sec-wide {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.5rem;
  border-radius: 14px;
  background: rgba(12,12,26,.35);
  border: 1px solid rgba(255,255,255,.05);
  transition: all .35s ease;
}
.sec-wide:hover {
  border-color: rgba(207,138,2,.15);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
}
.sec-wide__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(207,138,2,.06);
  border: 1px solid rgba(207,138,2,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #CF8A02;
  transition: all .35s ease;
}
.sec-wide:hover .sec-wide__icon {
  background: rgba(207,138,2,.12);
}
.sec-wide__title {
  font-family: 'Space Grotesk', 'Inter', sans-serif;
  font-size: .875rem;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: .15rem;
}
.sec-wide__desc {
  font-size: .75rem;
  color: var(--text-2);
  line-height: 1.5;
}

/* ── Bento grid placement ── */
.sec-bento .sec-cell:nth-of-type(1) { grid-column: 2; grid-row: 1; }
.sec-bento .sec-cell:nth-of-type(2) { grid-column: 3; grid-row: 1; }
.sec-bento .sec-cell:nth-of-type(3) { grid-column: 2; grid-row: 2; }
.sec-bento .sec-cell:nth-of-type(4) { grid-column: 3; grid-row: 2; }
.sec-bento .sec-wide:nth-of-type(1) { grid-column: 1 / 2; grid-row: 3; }
.sec-bento .sec-wide:nth-of-type(2) { grid-column: 2 / 4; grid-row: 3; }

/* ── Light theme ── */
[data-theme="light"] .sec-hero {
  background: linear-gradient(160deg, rgba(207,138,2,.05) 0%, rgba(255,255,255,.85) 50%, rgba(207,138,2,.03) 100%);
  border-color: rgba(207,138,2,.12);
}
[data-theme="light"] .sec-cell,
[data-theme="light"] .sec-wide {
  background: rgba(255,255,255,.7);
  border-color: var(--border);
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .sec-bento {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }
  .sec-hero {
    grid-column: 1 / -1;
    grid-row: auto;
    padding: 2rem 1.5rem;
  }
  .sec-bento .sec-cell:nth-of-type(1) { grid-column: 1; grid-row: auto; }
  .sec-bento .sec-cell:nth-of-type(2) { grid-column: 2; grid-row: auto; }
  .sec-bento .sec-cell:nth-of-type(3) { grid-column: 1; grid-row: auto; }
  .sec-bento .sec-cell:nth-of-type(4) { grid-column: 2; grid-row: auto; }
  .sec-bento .sec-wide:nth-of-type(1) { grid-column: 1 / -1; grid-row: auto; }
  .sec-bento .sec-wide:nth-of-type(2) { grid-column: 1 / -1; grid-row: auto; }
}
@media (max-width: 480px) {
  .sec-bento { grid-template-columns: 1fr; }
  .sec-bento .sec-cell,
  .sec-bento .sec-wide { grid-column: 1 !important; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FAQ
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.faq {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.faq__item {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: var(--transition);
}
.faq__item[open] {
  border-color: var(--border-hover);
  background: var(--bg-card);
}
.faq__item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  font-size: .9375rem;
  font-weight: 500;
  color: var(--text-1);
  cursor: pointer;
  list-style: none;
  transition: color var(--transition);
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
  content: '+';
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--text-3);
  transition: transform var(--transition);
  flex-shrink: 0;
}
.faq__item[open] summary::after {
  transform: rotate(45deg);
}
.faq__item summary:hover { color: #fff; }
.faq__item p {
  padding: 0 1.5rem 1.25rem;
  font-size: .875rem;
  line-height: 1.7;
  color: var(--text-2);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FINAL CTA
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cta-section {
  position: relative;
  padding: 6rem 0;
  overflow: hidden;
}
.cta-section__orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.cta-section__orb--1 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(207,138,2,.1), transparent 70%);
  left: -10%; top: -20%;
  animation: float 8s ease-in-out infinite;
}
.cta-section__orb--2 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(230,168,23,.08), transparent 70%);
  right: -10%; bottom: -20%;
  animation: float 6s ease-in-out 3s infinite;
}

.cta-section__inner {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 4rem 2rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 2rem;
  overflow: hidden;
}
.cta-section__inner::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 2rem;
  padding: 1px;
  background: linear-gradient(135deg, rgba(207,138,2,.3), transparent 40%, transparent 60%, rgba(230,168,23,.3));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

.cta-section__title {
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 700;
  margin-bottom: 1.25rem;
}
.cta-section__desc {
  font-size: 1.0625rem;
  max-width: 640px;
  margin: 0 auto 2.5rem;
  line-height: 1.7;
}
.cta-section__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
.cta-section__trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  font-size: .8125rem;
  color: var(--text-3);
}
.cta-section__trust span {
  display: flex;
  align-items: center;
  gap: .375rem;
}
.cta-section__trust svg { color: var(--green); }

@media (max-width: 640px) {
  .cta-section__inner { padding: 3rem 1.5rem; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FOOTER
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.footer {
  border-top: 1px solid var(--border);
  background: rgba(12,12,26,.5);
  padding: 4rem 0 2rem;
}
.footer__top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
@media (max-width: 768px) {
  .footer__top {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}
@media (max-width: 480px) {
  .footer__top { grid-template-columns: 1fr; }
}

.footer__brand { }
.footer__tagline {
  font-size: .875rem;
  color: var(--text-3);
  margin-top: .75rem;
  margin-bottom: 1.5rem;
}
.footer__socials {
  display: flex;
  gap: .75rem;
}
.footer__socials a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem; height: 2.25rem;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  color: var(--text-3);
  transition: var(--transition);
}
.footer__socials a:hover {
  color: var(--text-1);
  background: rgba(255,255,255,.08);
}

.footer__col h4 {
  font-size: .6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-1);
  margin-bottom: 1rem;
}
.footer__col a {
  display: block;
  font-size: .875rem;
  color: var(--text-3);
  padding: .375rem 0;
  transition: color var(--transition);
}
.footer__col a:hover { color: var(--text-2); }

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 2rem;
  border-top: 1px solid var(--border);
  font-size: .75rem;
  color: var(--text-3);
}
@media (max-width: 640px) {
  .footer__bottom {
    flex-direction: column;
    gap: .75rem;
    text-align: center;
  }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SCROLL REVEAL
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   KEYFRAMES
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-20px); }
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: .4; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FLOATING VOICE CALL BAR
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.vcall-bar {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 999;
  display: flex;
  align-items: center;
  gap: 0;
  background: linear-gradient(135deg, rgba(207,138,2,.9), rgba(230,168,23,.9));
  border-radius: var(--radius-full);
  padding: .35rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 8px 32px rgba(207,138,2,.35), 0 2px 8px rgba(0,0,0,.3);
  border: 1px solid rgba(255,255,255,.2);
  animation: vcall-slideUp .6s cubic-bezier(.16,1,.3,1) both;
  animation-delay: 1s;
}

/* breathing pulse behind the bar */
.vcall-bar__pulse {
  position: absolute;
  inset: -4px;
  border-radius: var(--radius-full);
  background: linear-gradient(135deg, rgba(207,138,2,.4), rgba(230,168,23,.4));
  z-index: -1;
  animation: vcall-pulse 2.5s ease-in-out infinite;
}

@keyframes vcall-pulse {
  0%, 100% { opacity: .6; transform: scale(1); }
  50%      { opacity: 0; transform: scale(1.15); }
}

@keyframes vcall-slideUp {
  from { opacity: 0; transform: translateX(-50%) translateY(40px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.vcall-bar__wave {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition);
}

.vcall-bar__wave:hover {
  background: rgba(255,255,255,.85);
  transform: scale(1.08);
}

/* live dot on Voice Call button */
.vcall-bar__live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #10b981;
  animation: pulse 2s ease-in-out infinite;
}

.vcall-bar__call {
  display: flex;
  align-items: center;
  gap: .45rem;
  padding: .6rem 1.25rem;
  background: #fff;
  color: #1a1a2e;
  border: none;
  border-radius: var(--radius-full);
  font-family: inherit;
  font-size: .85rem;
  font-weight: 700;
  cursor: pointer;
  margin: 0 .35rem;
  transition: var(--transition);
  white-space: nowrap;
}

.vcall-bar__call:hover {
  background: #f1f5f9;
  transform: scale(1.03);
}

.vcall-bar__call svg { stroke: #1a1a2e; }

.vcall-bar__flag-wrap {
  position: relative;
}

.vcall-bar__flag {
  display: flex;
  align-items: center;
  gap: .25rem;
  padding: .5rem .65rem;
  background: rgba(255,255,255,.15);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  color: #fff;
  transition: var(--transition);
}

.vcall-bar__flag:hover {
  background: rgba(255,255,255,.3);
}

.vcall-bar__flag-emoji {
  font-size: 1.2rem;
  line-height: 1;
}

/* ── Country Dropdown ── */
.country-drop {
  position: absolute;
  bottom: calc(100% + .75rem);
  right: 0;
  width: 280px;
  max-height: 320px;
  background: #1a1a2e;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  box-shadow: 0 16px 48px rgba(0,0,0,.5);
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity .2s, transform .2s cubic-bezier(.16,1,.3,1);
  z-index: 1001;
}

.country-drop.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.country-drop__search {
  width: 100%;
  padding: .75rem 1rem;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: transparent;
  color: #fff;
  font-family: inherit;
  font-size: .85rem;
  outline: none;
}

.country-drop__search::placeholder { color: #64748b; }

.country-drop__list {
  max-height: 260px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.1) transparent;
}

.country-drop__item {
  display: flex;
  align-items: center;
  gap: .5rem;
  width: 100%;
  padding: .6rem 1rem;
  border: none;
  background: transparent;
  color: #e2e8f0;
  font-family: inherit;
  font-size: .8rem;
  cursor: pointer;
  transition: background .15s;
  text-align: left;
}

.country-drop__item:hover {
  background: rgba(207,138,2,.15);
}

.country-drop__item span {
  margin-left: auto;
  color: #64748b;
  font-size: .75rem;
  font-weight: 600;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CHAT BUBBLE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.chat-bubble {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 999;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--gradient);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(207,138,2,.4);
  transition: var(--transition);
  animation: vcall-slideUp .6s cubic-bezier(.16,1,.3,1) both;
  animation-delay: 1.2s;
}

/* ping ring animation */
.chat-bubble__ping {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(207,138,2,.6);
  animation: chat-ping 2s cubic-bezier(0,0,.2,1) infinite;
}

@keyframes chat-ping {
  0%   { transform: scale(1); opacity: .8; }
  75%  { transform: scale(1.6); opacity: 0; }
  100% { transform: scale(1.6); opacity: 0; }
}

/* online green dot */
.chat-bubble__online {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #10b981;
  border: 2px solid var(--bg);
  z-index: 2;
}

.chat-bubble:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 28px rgba(207,138,2,.5);
}

.chat-bubble.active {
  background: var(--text-3);
}

.chat-bubble.active .chat-bubble__ping { display: none; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   VOICE CALL MODAL
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.vcall-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(6,6,14,.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}

.vcall-modal.open {
  opacity: 1;
  pointer-events: auto;
}

.vcall-modal__card {
  position: relative;
  width: 90%;
  max-width: 380px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: linear-gradient(160deg, #CF8A02 0%, #CF8A02 30%, #E6A817 100%);
  box-shadow: 0 24px 64px rgba(0,0,0,.5);
  transform: translateY(20px) scale(.95);
  transition: transform .35s cubic-bezier(.16,1,.3,1);
}

.vcall-modal.open .vcall-modal__card {
  transform: translateY(0) scale(1);
}

.vcall-modal__close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.2);
  border: none;
  color: #fff;
  font-size: 1.25rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
}

.vcall-modal__close:hover {
  background: rgba(255,255,255,.35);
}

.vcall-modal__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem 1.5rem .75rem;
  gap: .35rem;
}

/* avatar with ring */
.vcall-modal__avatar-wrap {
  position: relative;
  margin-bottom: .5rem;
}

.vcall-modal__avatar-ring {
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.3);
  animation: modal-ring-spin 4s linear infinite;
  border-top-color: transparent;
  border-right-color: transparent;
}

@keyframes modal-ring-spin {
  to { transform: rotate(360deg); }
}

.vcall-modal__avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 3px solid rgba(255,255,255,.3);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.1);
}

.vcall-modal__online-dot {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #10b981;
  border: 3px solid #CF8A02;
}

.vcall-modal__title {
  color: #fff;
  font-size: 1.05rem;
  font-weight: 700;
}

.vcall-modal__subtitle {
  color: rgba(255,255,255,.6);
  font-size: .75rem;
}

.vcall-modal__form {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  padding: .75rem 1.5rem 0;
}

.vcall-modal__input {
  width: 100%;
  padding: .75rem 1rem;
  border-radius: var(--radius-md);
  border: none;
  background: #fff;
  font-family: inherit;
  font-size: .85rem;
  color: #1a1a2e;
  outline: none;
  transition: box-shadow .2s;
}

.vcall-modal__input::placeholder { color: #94a3b8; }
.vcall-modal__input:focus { box-shadow: 0 0 0 3px rgba(255,255,255,.3); }

.vcall-modal__phone-row {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* clickable prefix button in modal */
.vcall-modal__prefix-btn {
  display: flex;
  align-items: center;
  gap: .3rem;
  padding: .75rem .5rem .75rem .85rem;
  border: none;
  background: transparent;
  color: #1a1a2e;
  font-family: inherit;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  border-right: 1px solid #e2e8f0;
  white-space: nowrap;
  transition: background .15s;
}

.vcall-modal__prefix-btn:hover { background: #f1f5f9; }
.vcall-modal__prefix-btn svg { stroke: #94a3b8; }

.vcall-modal__phone-row .vcall-modal__input { border-radius: 0; }

.vcall-modal__actions {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: 1.25rem 0;
}

.vcall-modal__mic {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.2);
  border: none;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition);
}

.vcall-modal__mic:hover { background: rgba(255,255,255,.35); }

.vcall-modal__start {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 1.25rem;
  border-radius: var(--radius-full);
  background: #fff;
  border: none;
  color: #1a1a2e;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
}

.vcall-modal__start:hover { background: #f1f5f9; transform: scale(1.02); }
.vcall-modal__start svg { stroke: #1a1a2e; }

.vcall-modal__powered {
  text-align: center;
  padding: .75rem;
  font-size: .7rem;
  color: rgba(255,255,255,.6);
}

.vcall-modal__powered strong { color: #fff; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CHAT WIDGET
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.chat-widget {
  position: fixed;
  bottom: 5.5rem;
  right: 1.5rem;
  z-index: 1000;
  width: 340px;
  max-width: calc(100vw - 2rem);
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: 0 16px 48px rgba(0,0,0,.25);
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px) scale(.95);
  transition: opacity .25s ease, transform .25s cubic-bezier(.16,1,.3,1);
}

.chat-widget.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.chat-widget__header {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .85rem 1rem;
  background: #1a1a2e;
  color: #fff;
}

/* small avatar in chat header */
.chat-widget__avatar-sm {
  position: relative;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #CF8A02, #CF8A02);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chat-widget__avatar-sm svg { stroke: #fff; }

.chat-widget__online-dot {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #10b981;
  border: 2px solid #1a1a2e;
}

.chat-widget__header-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: .1rem;
}

.chat-widget__heading {
  font-size: .9rem;
  font-weight: 600;
}

.chat-widget__status {
  font-size: .7rem;
  color: #10b981;
  font-weight: 500;
}

.chat-widget__collapse {
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: .25rem;
  opacity: .7;
  transition: opacity .2s;
}

.chat-widget__collapse:hover { opacity: 1; }

.chat-widget__body {
  padding: 1.25rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.chat-widget__msg {
  display: flex;
  gap: .65rem;
  align-items: flex-start;
}

.chat-widget__msg-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #CF8A02, #CF8A02);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.chat-widget__msg-avatar svg { stroke: #fff; }

.chat-widget__msg-text {
  font-size: .85rem;
  color: #475569;
  line-height: 1.5;
  background: #f1f5f9;
  padding: .75rem 1rem;
  border-radius: var(--radius-md);
}

/* typing indicator */
.chat-widget__typing {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .5rem .75rem;
  background: #f1f5f9;
  border-radius: var(--radius-md);
  width: fit-content;
  margin-left: 2.65rem;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity .3s, max-height .3s;
}

.chat-widget.open .chat-widget__typing {
  opacity: 1;
  max-height: 40px;
  animation: typing-appear .4s .8s both;
}

@keyframes typing-appear {
  from { opacity: 0; max-height: 0; }
  to   { opacity: 1; max-height: 40px; }
}

.chat-widget__typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #94a3b8;
  animation: typing-bounce 1.4s infinite ease-in-out;
}

.chat-widget__typing span:nth-child(2) { animation-delay: .16s; }
.chat-widget__typing span:nth-child(3) { animation-delay: .32s; }

@keyframes typing-bounce {
  0%, 60%, 100% { transform: translateY(0); opacity: .4; }
  30%           { transform: translateY(-4px); opacity: 1; }
}

.chat-widget__option {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .85rem 1rem;
  border-radius: var(--radius-md);
  border: 1px solid #e2e8f0;
  text-decoration: none;
  color: #1a1a2e;
  font-size: .85rem;
  font-weight: 500;
  transition: var(--transition);
}

.chat-widget__option:hover {
  background: #f8fafc;
  border-color: #cbd5e1;
}

.chat-widget__option svg {
  flex-shrink: 0;
  stroke: #64748b;
}

.chat-widget__option--wa svg {
  stroke: none;
}

.chat-widget__powered {
  text-align: center;
  padding: .75rem;
  font-size: .7rem;
  color: #94a3b8;
  border-top: 1px solid #f1f5f9;
}

.chat-widget__powered a {
  color: var(--accent);
  text-decoration: none;
  font-weight: 600;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   WIDGET RESPONSIVE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 480px) {
  .vcall-bar { padding: .25rem; gap: .35rem; }
  .vcall-bar__call { padding: .5rem .85rem; font-size: .8rem; }
  .vcall-bar__wave { width: 38px; height: 38px; }
  .vcall-bar__label { display: none; }
  .country-drop { left: -1rem; min-width: 240px; }
  .chat-bubble { width: 48px; height: 48px; bottom: 1rem; right: 1rem; }
  .chat-widget { bottom: 4.5rem; right: 1rem; }
}
