/* ===== NAV ===== */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  height: 80px; padding: 0 48px;
  display: flex; align-items: center; justify-content: space-between;
  transition: background .3s, box-shadow .3s;
  background: transparent;
}
nav.s {
  background: rgba(247,252,249,.97);
  box-shadow: var(--sh-sm);
}
.nav-logo {
  display: flex; align-items: center; gap: 6px;
  text-decoration: none; color: var(--text);
}
.nav-logo-img { height: 36px; width: auto; flex-shrink: 0; display: block; }
.nav-right { display: flex; align-items: center; gap: 48px; }
.nav-links { display: flex; align-items: center; gap: 28px; list-style: none; }
.nav-links > li { display: flex; align-items: center; }
.nav-links a {
  text-decoration: none; color: var(--text2);
  font-size: 18px; font-weight: 500; transition: color .2s; line-height: 1;
}
.nav-links a:hover { color: var(--primary); }
.nav-links a.active { color: var(--primary); }

/* ===== NAV DROPDOWNS ===== */
.nav-dropdown { position: relative; }
.nav-dropdown-toggle { display: flex; align-items: center; gap: 5px; }
.nav-dropdown-toggle svg { transition: transform .2s ease; flex-shrink: 0; }
.nav-dropdown:hover .nav-dropdown-toggle svg { transform: rotate(180deg); }

.dropdown-menu {
  position: absolute; top: calc(100% + 10px); left: 0;
  transform: translateY(-4px);
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: var(--sh-md);
  padding: .4rem; min-width: 180px; list-style: none;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .18s ease, visibility 0s linear .18s, transform .18s ease;
}
.dropdown-menu::before {
  content: ''; position: absolute;
  top: -12px; left: 0; right: 0; height: 12px;
}
.nav-dropdown:hover .dropdown-menu {
  opacity: 1; visibility: visible; pointer-events: auto;
  transform: translateY(0);
  transition: opacity .18s ease, visibility 0s, transform .18s ease;
}
.dropdown-menu > li > a {
  display: flex; align-items: center; justify-content: space-between;
  padding: .55rem .875rem; border-radius: 8px;
  color: var(--text2); font-size: .875rem; font-weight: 500;
  white-space: nowrap;
  transition: background .15s, color .15s;
}
.dropdown-menu > li > a:hover { background: var(--surface2); color: var(--primary); }

.nav-badge {
  display: inline-block; font-size: .6rem; font-weight: 600;
  padding: 1px 6px; border-radius: 999px;
  background: var(--primary-l); color: var(--primary);
  margin-left: 6px; letter-spacing: .02em; text-transform: lowercase;
}

.dropdown-current {
  color: var(--primary) !important;
  cursor: default; pointer-events: none;
}
.dropdown-current:hover { background: none !important; }
.dropdown-group-label {
  font-size: .65rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--muted);
  padding: .5rem .875rem .2rem; pointer-events: none;
}
.dropdown-sub-item { padding-left: 1.25rem !important; }
.dropdown-divider {
  height: 1px; background: var(--border);
  margin: .35rem .875rem;
}

/* ===== LAYOUT ===== */
.container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.section    { padding: 7rem 0; }

/* ===== HERO ===== */
.hero {
  min-height: 100vh; padding-top: 80px;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  background: #ffffff;
}
.hero-copy  { padding: 0 0 0 80px; position: relative; z-index: 2; max-width: 580px; }
.hero h1    { font-size: clamp(2.6rem, 5.5vw, 6.2rem); margin-bottom: 24px; animation: fadeUp .7s ease .2s both; }
.hero h1 em { color: var(--primary); }
.hero-h1-nowrap { white-space: nowrap; }
.hero-sub   {
  font-size: 18px; color: var(--text2); line-height: 1.72;
  max-width: 460px; margin-bottom: 40px;
  animation: fadeUp .7s ease .3s both;
}
.hero-actions { display:flex; align-items:center; gap:12px; margin-bottom: 40px; animation: fadeUp .7s ease .4s both; }
.hero-tag { animation: fadeUp .6s ease .1s both; }

.hero-trust {
  display: flex; align-items: center; gap: 16px; flex-wrap: nowrap;
  padding-top: 24px; border-top: 1px solid var(--border);
  animation: fadeUp .7s ease .5s both;
}
.trust-item { display:flex; align-items:center; gap:7px; font-size:12px; font-weight:500; color:var(--muted); white-space:nowrap; }
.trust-icon { color: var(--primary); }

/* ===== HERO VISUAL (Spline — full bleed) ===== */
.hero-mockup::before {
  content:''; position:absolute; inset:0; z-index: 1; pointer-events:none;
  background: linear-gradient(to right, #ffffff 0%, transparent 50%);
}
.hero-mockup {
  position: absolute; top: 0px; left: 5%; right: -10px; bottom: 0; z-index: 0;
  overflow: hidden;
  animation: fadeIn 1.2s ease .2s both;
  pointer-events: none;
  will-change: transform;
  transform: translateZ(0);
}
.hero-mockup iframe {
  width: 100%; height: 100%;
  border: none; display: block;
  background: transparent;
}
.spline-fade-edge { display: none; }

/* ===== HERO MOBILE BACKGROUND IMAGE ===== */
.hero-mobile-bg { display: none; }


/* ===== TRUST BAR ===== */
.trust-bar {
  background: var(--surface);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  padding: 1.5rem 0;
}
.trust-bar-inner { display:flex; justify-content:center; align-items:center; }
.trust-logos { display:flex; align-items:center; justify-content:center; gap:3rem; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:8px; font-size:14px; font-weight:500; color:var(--text2); }
.trust-icon { color:var(--primary); display:flex; align-items:center; }
