/* ==========================================================================
   Equity Vault - Marketing Site Design System
   Distinct visual language for EV (premium ownership infrastructure).
   ========================================================================== */

/* --- Design tokens --- */
:root {
  --font-sans: "Manrope", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --font-display: "Source Serif 4", "Georgia", serif;

  --ink-900: #0b111b;
  --ink-800: #101827;
  --ink-700: #1b2434;
  --steel-500: #526079;
  --steel-400: #6b778c;
  --steel-300: #8b98ad;

  --surface: #ffffff;
  --surface-elevated: #fcfdff;
  --app-bg: #f4f6fb;

  --text: #0f172a;
  --text-secondary: #475569;
  --muted: #7a879a;

  --border: #e2e8f0;
  --border-light: #edf2f7;

  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.06);
  --shadow-md: 0 16px 40px rgba(15, 23, 42, 0.08);
  --shadow-lg: 0 30px 70px rgba(15, 23, 42, 0.14);

  --radius-sm: 0.45rem;
  --radius-md: 0.65rem;
  --radius-lg: 0.9rem;
  --radius-xl: 1.2rem;

  --accent-primary: #0f766e;
  --accent-strong: #0b5f59;
  --accent-soft: #d6f2ef;
  --accent-blue: #1d4ed8;
  --accent-green: #0f766e;
  --accent-amber: #d29b2f;
  --accent-purple: #5b5bd6;
  --accent-teal: #0f766e;

  --navy-dark: #0b111b;
  --navy-mid: #111a2a;
  --navy-light: #1b2a43;
  --topbar: #0b111b;

  --container-max: 1200px;
  --section-pad: 6rem;
}

/* --- Base --- */
* { box-sizing: border-box; }
body {
  font-family: var(--font-sans);
  font-size: 1.05rem;
  color: var(--text);
  background: var(--app-bg);
  line-height: 1.55;
  letter-spacing: -0.01em;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  letter-spacing: -0.015em;
  color: var(--text);
}

@media (min-width: 1400px) {
  .container { max-width: var(--container-max); }
}

/* --- Navbar --- */
.site-nav {
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid var(--border);
  box-shadow: none;
  backdrop-filter: blur(10px);
}
.site-nav--landing {
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid var(--border);
  box-shadow: none;
}
.site-nav .navbar-brand img { height: 36px; padding-bottom: 2px; }
.site-nav .nav-link {
  color: var(--text-secondary);
  font-weight: 500;
  font-size: 0.95rem;
  padding: 0.5rem 0.9rem;
  transition: color 0.15s ease;
}
.site-nav .nav-link:hover,
.site-nav .nav-link:focus {
  color: var(--text);
}
.site-nav .nav-link.active {
  color: var(--text);
  font-weight: 600;
}
.site-nav .navbar-toggler {
  border-color: rgba(15, 23, 42, 0.2);
}
.site-nav .navbar-toggler-icon {
  filter: none;
}
.site-nav .btn-lang {
  background: rgba(15, 23, 42, 0.06);
  border: 1px solid rgba(15, 23, 42, 0.12);
  color: var(--text-secondary);
  font-size: 0.85rem;
  font-weight: 500;
  padding: 0.35rem 0.75rem;
  border-radius: var(--radius-md);
}
.site-nav .btn-lang:hover {
  background: rgba(15, 23, 42, 0.1);
  color: var(--text);
}
.site-nav .btn-cta-login {
  border-color: rgba(15, 23, 42, 0.2);
  color: var(--text-secondary);
  font-size: 0.9rem;
  font-weight: 500;
  background: transparent;
}
.site-nav .btn-cta-login:hover {
  background: rgba(15, 23, 42, 0.05);
  border-color: rgba(15, 23, 42, 0.35);
  color: var(--text);
}
.site-nav .btn-cta-register {
  background: var(--ink-900);
  color: #ffffff;
  border: 1px solid var(--ink-900);
  font-size: 0.9rem;
  font-weight: 600;
}
.site-nav .btn-cta-register:hover {
  background: #0a0f18;
  border-color: #0a0f18;
  color: #ffffff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.18);
}

/* --- Hero sections --- */
.site-hero {
  background: linear-gradient(120deg, #f7f9fd 0%, #f1f4fb 45%, #edf2f8 100%);
  position: relative;
  overflow: hidden;
  padding: 6.5rem 0 5.5rem;
  border-bottom: 1px solid var(--border-light);
}
.site-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(900px circle at 85% 15%, rgba(15, 118, 110, 0.12), transparent 60%),
    radial-gradient(800px circle at 10% 10%, rgba(29, 78, 216, 0.08), transparent 55%),
    linear-gradient(rgba(15, 23, 42, 0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 23, 42, 0.02) 1px, transparent 1px);
  background-size: auto, auto, 140px 140px, 140px 140px;
  pointer-events: none;
}
.site-hero > .container { position: relative; z-index: 1; }
.site-hero--image,
.site-hero--pricing,
.site-hero--contact,
.site-hero--partners,
.site-hero--landing {
  background-image: none;
}
.site-hero__eyebrow {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--accent-primary);
  margin-bottom: 0.65rem;
}
.site-hero__title {
  font-size: clamp(2.6rem, 4vw, 3.75rem);
  font-weight: 600;
  color: var(--text);
  line-height: 1.1;
  margin-bottom: 1.25rem;
}
.site-hero__subtitle {
  font-size: 1.2rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 0;
  max-width: 620px;
}
.site-hero__trust {
  font-size: 0.88rem;
  color: var(--muted);
}
.site-hero__trust i { margin-right: 0.5rem; }

/* Floating feature card in hero */
.site-hero__card {
  background: rgba(255, 255, 255, 0.98);
  border-radius: var(--radius-xl);
  padding: 2rem;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border);
}
.site-hero__card h3 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 1rem;
}

.site-hero .btn-light {
  background: var(--ink-900);
  border-color: var(--ink-900);
  color: #fff !important;
}
.site-hero .btn-light:hover {
  background: #0a0f18;
  border-color: #0a0f18;
  color: #fff !important;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.18);
}
.site-hero .btn-outline-light {
  color: var(--text);
  border-color: rgba(15, 23, 42, 0.3);
  background: transparent;
}
.site-hero .btn-outline-light:hover {
  background: var(--ink-900);
  border-color: var(--ink-900);
  color: #fff;
}

/* --- Section layout --- */
.site-section {
  padding: var(--section-pad) 0;
}
.site-section--alt {
  background: var(--surface);
  border-top: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
}
.site-section__eyebrow {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent-primary);
  margin-bottom: 0.6rem;
}
.site-section__title {
  font-size: clamp(1.85rem, 2.6vw, 2.45rem);
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.65rem;
  line-height: 1.2;
}
.site-section__subtitle {
  font-size: 1.2rem;
  color: var(--text-secondary);
  line-height: 1.5;
  max-width: 700px;
}

/* --- Feature cards (benefits) --- */
.feature-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 1.9rem;
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  height: 100%;
}
.feature-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: rgba(15, 118, 110, 0.25);
}
.feature-card__icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  margin-bottom: 1rem;
  flex-shrink: 0;
}
.feature-card__icon--blue    { background: rgba(29, 78, 216, 0.12); color: #1d4ed8; }
.feature-card__icon--green   { background: rgba(15, 118, 110, 0.12); color: #0f766e; }
.feature-card__icon--amber   { background: rgba(210, 155, 47, 0.14); color: #b97f1c; }
.feature-card__icon--purple  { background: rgba(91, 91, 214, 0.12); color: #5b5bd6; }
.feature-card__icon--teal    { background: rgba(15, 118, 110, 0.12); color: #0f766e; }
.feature-card__icon--slate   { background: rgba(132, 148, 171, 0.12); color: #64748b; }
.feature-card__title {
  font-size: 1.06rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.feature-card__text {
  font-size: 0.95rem;
  color: var(--text-secondary);
  margin-bottom: 0;
  line-height: 1.65;
}

/* --- Step cards --- */
.step-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 1.8rem;
  box-shadow: var(--shadow-sm);
  height: 100%;
}
.step-card__number {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: var(--ink-900);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
}
.step-card__title {
  font-size: 1.08rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.step-card__text {
  font-size: 0.94rem;
  color: var(--text-secondary);
  margin-bottom: 0;
  line-height: 1.6;
}

/* --- Compliance info card --- */
.info-card {
  background: var(--surface-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
}
.info-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(29, 78, 216, 0.12);
  color: #1d4ed8;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

/* --- CTA banner --- */
.cta-section {
  background: linear-gradient(160deg, #3b5e64 0%, #274447 70%, #1b3566 100%);
  padding: 4.5rem 0;
  position: relative;
  overflow: hidden;
}
.cta-section::after {
  content: '';
  position: absolute;
  top: -40%;
  right: -10%;
  width: 50%;
  height: 180%;
  background: radial-gradient(ellipse, rgba(15, 118, 110, 0.22) 0%, transparent 70%);
  pointer-events: none;
}
.cta-section__title {
  font-size: 1.85rem;
  font-weight: 600;
  color: #fff;
  margin-bottom: 0.75rem;
}
.cta-section__subtitle {
  font-size: 1.2rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.72);
  margin-bottom: 0;
}

/* --- Plan cards (pricing) --- */
.plan-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 2rem;
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  height: 100%;
  position: relative;
}
.plan-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(15, 118, 110, 0.25);
}
.plan-card--featured {
  border-color: rgba(15, 118, 110, 0.6);
  border-width: 1.5px;
  box-shadow: 0 18px 40px rgba(15, 118, 110, 0.15);
}
.plan-card__badge {
  display: inline-block;
  background: rgba(15, 118, 110, 0.12);
  color: var(--accent-primary);
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  margin-bottom: 0.85rem;
}
.plan-card__audience {
  background: var(--app-bg);
  border-radius: var(--radius-lg);
  padding: 0.7rem 0.9rem;
  margin: -0.5rem -0.5rem 1rem -0.5rem;
}
.plan-card__audience-text {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin: 0;
}
.plan-card__name {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.45rem;
}
.plan-card__partner {
  font-size: 1.9rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.1;
  margin-bottom: 0.3rem;
}
.plan-card__price {
  font-size: 2.4rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.1;
  margin-bottom: 0.35rem;
}
.plan-card__price span {
  font-size: 1rem;
  font-weight: 400;
  color: var(--text-secondary);
}
.plan-card__billing {
  font-size: 0.85rem;
  color: var(--muted);
  margin-bottom: 0.85rem;
}
.plan-card__desc {
  font-size: 1rem;
  color: var(--text-secondary);
  margin-bottom: 1.2rem;
  line-height: 1.5;
}
.plan-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 1.3rem;
}
.plan-card__features li {
  font-size: 1rem;
  color: var(--text-secondary);
  padding: 0.35rem 0;
}
.plan-card__features li i {
  color: var(--accent-primary);
  margin-right: 0.5rem;
}
.plan-card__footer {
  font-size: 0.82rem;
  color: var(--muted);
  margin-top: 0.8rem;
}

/* Pricing diff strip (hero) */
.pricing-diff {
  max-width: 980px;
  margin: 0 auto;
  padding: 0.85rem 1.35rem;
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(8px);
}
.pricing-diff-item {
  color: #fff;
  font-size: 0.88rem;
  font-weight: 500;
}
.pricing-diff-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink-700);
  flex: 0 0 34px;
  font-size: 0.9rem;
}

.site-hero--pricing .pricing-diff {
  background: rgba(255, 255, 255, 0.68);
  border-color: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-sm);
}

.site-hero--pricing .pricing-diff-item {
  color: var(--text);
}

/* Pricing comparison table */
.pricing-compare {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 1.2rem 1.35rem;
  box-shadow: var(--shadow-sm);
}
.pricing-compare__label {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 0.6rem;
}
.pricing-compare .table {
  margin-bottom: 0;
}
.pricing-compare .table th,
.pricing-compare .table td {
  padding: 0.5rem 0.6rem;
  font-size: 0.9rem;
  vertical-align: middle;
  border-color: var(--border-light);
}
.pricing-compare .table thead th {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted);
  border-bottom-color: var(--border);
}

/* Mobile comparison cards */
.pricing-compare-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 0.9rem 1rem;
  background: var(--surface);
}
.pricing-compare-card h4 {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 0.5rem;
}
.pricing-compare-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  font-size: 0.88rem;
}
.pricing-compare-row + .pricing-compare-row { margin-top: 0.45rem; }

/* Billing toggle */
.billing-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}
.billing-toggle .badge {
  font-size: 0.7rem;
  font-weight: 600;
}

/* --- Contact form card --- */
.contact-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}
.contact-card__info {
  background: var(--app-bg);
  padding: 2rem;
}
.contact-card__form {
  padding: 2rem;
}

/* --- Footer --- */
.site-footer {
  background: #0b111b;
  padding: 3rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.site-footer__brand {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.88rem;
}
.site-footer a {
  color: rgba(255, 255, 255, 0.62);
  text-decoration: none;
  font-size: 0.88rem;
  transition: color 0.15s;
}
.site-footer a:hover {
  color: rgba(255, 255, 255, 0.95);
}
.site-footer__copy {
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.45);
}

/* --- Utilities --- */
.glass-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.82rem;
  font-weight: 500;
  padding: 0.35rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.15);
}

/* Form overrides */
.form-control, .form-select {
  border-color: var(--border);
  border-radius: var(--radius-md);
  padding: 0.6rem 0.9rem;
  font-size: 0.95rem;
  color: var(--text);
  background-color: #fff;
}
.form-control:focus, .form-select:focus {
  border-color: rgba(15, 118, 110, 0.5);
  box-shadow: 0 0 0 0.2rem rgba(15, 118, 110, 0.18);
}
.form-label {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 0.3rem;
}

/* Button overrides */
.btn {
  font-weight: 600;
  border-radius: var(--radius-md);
}
.btn-primary {
  background-color: var(--ink-900);
  border-color: var(--ink-900);
  color: #fff;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
}
.btn-primary:hover {
  background-color: #0a0f18;
  border-color: #0a0f18;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.16);
}
.btn-outline-primary {
  color: var(--ink-900);
  border-color: rgba(15, 23, 42, 0.3);
  background: transparent;
}
.btn-outline-primary:hover {
  background-color: var(--ink-900);
  border-color: var(--ink-900);
  color: #fff;
}
.btn-light {
  background: #fff;
  border-color: rgba(255, 255, 255, 0.35);
  color: var(--ink-900);
}

/* --- Responsive --- */
@media (max-width: 991.98px) {
  .site-hero { padding: 5rem 0 4.5rem; }
  .site-hero__title { font-size: 2.2rem; }
  .site-section { padding: 4.5rem 0; }
  .site-section__title { font-size: 1.7rem; }
  .cta-section { padding: 3.5rem 0; }
  .cta-section__title { font-size: 1.5rem; }

  /* Keep language menu visible in collapsed mobile nav */
  .site-nav .dropdown-menu-end,
  .site-nav--landing .dropdown-menu-end {
    right: auto;
    left: 0;
    --bs-position: start;
    max-width: calc(100vw - 2rem);
  }
}
@media (max-width: 767.98px) {
  .site-hero__title { font-size: 1.9rem; }
  .site-section__title { font-size: 1.45rem; }
  .plan-card__price { font-size: 2rem; }
  .feature-card { padding: 1.4rem; }
}

.site-footer__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
}

.site-footer__action-link {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
}

.site-footer__action-link:hover {
  color: #fff;
  text-decoration: underline;
}

.site-footer__action-link--primary {
  font-weight: 600;
}

.site-footer__utility {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  font-size: 14px;
}

.site-footer__utility-link {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  padding: 2px 0;
}

.site-footer__utility-link:hover {
  color: #fff;
  text-decoration: underline;
}

.site-footer__utility-link--primary {
  color: rgba(255, 255, 255, 0.95);
  font-weight: 600;
}

.site-footer__sep {
  color: rgba(255, 255, 255, 0.35);
}

.site-footer__social {
  display: none !important;
}

.site-footer__social-link {
  color: #9aa4b2;
  transition: color 0.2s ease, transform 0.15s ease;
}

.site-footer__social-link:hover {
  color: #ffffff;
  transform: translateY(-1px);
}

/* ============================================================
   Equity Vault v2 - Premium Design System
   New components for the redesigned marketing site
   ============================================================ */

/* --- Dark navigation variant --- */
.site-nav--dark {
  background: rgba(8, 15, 26, 0.88);
  border-bottom-color: rgba(255, 255, 255, 0.07);
}
.site-nav--dark .navbar-brand img {
  filter: brightness(0) invert(1);
}
.site-nav--dark .nav-link { color: rgba(255, 255, 255, 0.62); }
.site-nav--dark .nav-link:hover,
.site-nav--dark .nav-link.active { color: #ffffff; }
.site-nav--dark .navbar-toggler {
  border-color: rgba(255, 255, 255, 0.2);
  filter: invert(1);
}
.site-nav--dark .btn-cta-login {
  border-color: rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.72);
  background: transparent;
}
.site-nav--dark .btn-cta-login:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.35);
  color: #fff;
}
.site-nav--dark .btn-cta-register {
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink-900);
  border-color: transparent;
}
.site-nav--dark .btn-cta-register:hover {
  background: #ffffff;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}
/* Scrolled state - reverts to light nav */
.site-nav--dark.is-scrolled {
  background: rgba(255, 255, 255, 0.97);
  border-bottom-color: var(--border);
}
.site-nav--dark.is-scrolled .navbar-brand img { filter: none; }
.site-nav--dark.is-scrolled .navbar-toggler { filter: none; }
.site-nav--dark.is-scrolled .nav-link { color: var(--text-secondary); }
.site-nav--dark.is-scrolled .nav-link:hover,
.site-nav--dark.is-scrolled .nav-link.active { color: var(--text); }
.site-nav--dark.is-scrolled .btn-cta-login {
  border-color: rgba(15, 23, 42, 0.2);
  color: var(--text-secondary);
}
.site-nav--dark.is-scrolled .btn-cta-login:hover {
  background: rgba(15, 23, 42, 0.05);
  color: var(--text);
}
.site-nav--dark.is-scrolled .btn-cta-register {
  background: var(--ink-900);
  color: #fff;
  border-color: var(--ink-900);
}

/* --- Dark product hero --- */
.ev-hero {
  background: #080f1a;
  position: relative;
  overflow: hidden;
  padding: 7rem 0 0;
}
.ev-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 55% at 15% -5%, rgba(59, 130, 246, 0.13) 0%, transparent 60%),
    radial-gradient(ellipse 55% 40% at 88% 30%, rgba(15, 118, 110, 0.10) 0%, transparent 55%),
    radial-gradient(ellipse 40% 30% at 50% 85%, rgba(99, 102, 241, 0.06) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.ev-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.026) 1px, transparent 1px);
  background-size: 72px 72px;
  pointer-events: none;
  z-index: 0;
}
.ev-hero__inner { position: relative; z-index: 1; }

.ev-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.22);
  color: #93c5fd;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .38rem .9rem;
  border-radius: 999px;
  margin-bottom: 1.5rem;
}

.ev-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 5vw, 4.1rem);
  font-weight: 600;
  color: #ffffff;
  line-height: 1.06;
  letter-spacing: -0.022em;
  margin-bottom: 1.35rem;
}

.ev-hero__sub {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.5;
  max-width: 520px;
  margin-bottom: 2.25rem;
}

.ev-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-bottom: 2rem;
  align-items: center;
}

.ev-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.6rem;
  color: rgba(255, 255, 255, 0.35);
  font-size: .8rem;
}
.ev-hero__trust span {
  display: flex;
  align-items: center;
  gap: .4rem;
}
.ev-hero__trust i { color: rgba(52, 211, 153, 0.7); font-size: .78rem; }

/* Buttons for dark hero */
.ev-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: #ffffff;
  color: #0b111b !important;
  font-weight: 700;
  padding: .78rem 1.75rem;
  border-radius: var(--radius-md);
  font-size: .94rem;
  text-decoration: none !important;
  transition: all .2s ease;
  border: none;
  letter-spacing: -0.01em;
}
.ev-btn-primary:hover {
  background: #eef4ff;
  transform: translateY(-1px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.3);
  color: #0b111b !important;
}
.ev-btn-outline-dark {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: rgba(255, 255, 255, 0.7) !important;
  font-weight: 600;
  padding: .78rem 1.6rem;
  border-radius: var(--radius-md);
  font-size: .94rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  text-decoration: none !important;
  transition: all .2s ease;
  background: transparent;
}
.ev-btn-outline-dark:hover {
  color: #ffffff !important;
  border-color: rgba(255, 255, 255, 0.38);
  background: rgba(255, 255, 255, 0.06);
}

/* Browser frame for screenshots */
.ev-browser {
  background: #1a2535;
  border-radius: 12px 12px 0 0;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.07),
    0 -10px 60px rgba(0, 0, 0, 0.45),
    0 40px 80px rgba(0, 0, 0, 0.25);
}
.ev-browser__bar {
  background: #212f42;
  height: 36px;
  display: flex;
  align-items: center;
  padding: 0 14px;
  gap: 5px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  flex-shrink: 0;
}
.ev-browser__dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  flex-shrink: 0;
}
.ev-browser__dot:nth-child(1) { background: rgba(255, 95, 86, 0.4); }
.ev-browser__dot:nth-child(2) { background: rgba(255, 189, 46, 0.4); }
.ev-browser__dot:nth-child(3) { background: rgba(39, 201, 63, 0.4); }
.ev-browser__url {
  flex: 1;
  max-width: 260px;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 4px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10.5px;
  color: rgba(255, 255, 255, 0.28);
  letter-spacing: 0.01em;
}
.ev-browser img {
  display: block;
  width: 100%;
  height: auto;
}

/* --- Module strip --- */
.ev-strip {
  background: var(--surface);
  border-bottom: 1px solid var(--border-light);
  padding: 1.6rem 0;
}
.ev-strip__label {
  font-size: .78rem;
  color: var(--muted);
  font-weight: 500;
  margin-right: .75rem;
  white-space: nowrap;
}
.ev-chip {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  background: var(--app-bg);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .32rem .85rem;
  font-size: .8rem;
  color: var(--text-secondary);
  font-weight: 500;
  white-space: nowrap;
}
.ev-chip i { font-size: .72rem; color: var(--accent-primary); }

/* --- Feature sections --- */
.ev-feat {
  padding: 6rem 0;
  background: var(--app-bg);
}
.ev-feat--white {
  background: var(--surface);
  border-top: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
}
.ev-feat--dark {
  background: #2e3547;
  border: none;
  position: relative;
  overflow: hidden;
}
.ev-feat--dark::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 80% 50%, rgba(15, 118, 110, 0.12) 0%, transparent 65%),
    radial-gradient(ellipse 50% 40% at 10% 20%, rgba(59, 130, 246, 0.09) 0%, transparent 60%);
  pointer-events: none;
}
.ev-feat--dark .container { position: relative; z-index: 1; }

.ev-feat__label {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .15em;
  padding: .3rem .8rem;
  border-radius: 999px;
  margin-bottom: .9rem;
}
.ev-feat__label--teal  { background: rgba(15, 118, 110, 0.1);  color: #0f766e; }
.ev-feat__label--blue  { background: rgba(29, 78, 216, 0.1);   color: #1d4ed8; }
.ev-feat__label--purple{ background: rgba(91, 91, 214, 0.1);   color: #5b5bd6; }
.ev-feat__label--amber { background: rgba(210, 155, 47, 0.12); color: #b97f1c; }
.ev-feat__label--white { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.65); }

.ev-feat__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 2.6vw, 2.35rem);
  font-weight: 600;
  color: var(--text);
  line-height: 1.13;
  letter-spacing: -0.018em;
  margin-bottom: 1rem;
}
.ev-feat--dark .ev-feat__title { color: #ffffff; }

.ev-feat__body {
  font-size: 1.2rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 1.5rem;
  max-width: 460px;
}
.ev-feat--dark .ev-feat__body { color: rgba(255, 255, 255, 0.5); max-width: 520px; }

.ev-feat__list {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: flex;
  flex-direction: column;
  gap: .52rem;
}
.ev-feat__list li {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  font-size: 1.05rem;
  color: var(--text);
  font-weight: 500;
  line-height: 1.5;
}
.ev-feat--dark .ev-feat__list li { color: rgba(255, 255, 255, 0.72); }
.ev-feat__list li i { color: var(--accent-primary); margin-top: .1rem; flex-shrink: 0; }
.ev-feat--dark .ev-feat__list li i { color: #34d399; }

/* Screenshot wrapper */
.ev-ss {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.12), 0 0 0 1px var(--border);
}
.ev-ss img { display: block; width: 100%; height: auto; }
.ev-ss--lifted {
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.16), 0 0 0 1px var(--border);
  transform: perspective(1000px) rotateY(-2deg) rotateX(1deg);
  transition: transform 0.4s ease;
}
.ev-ss--lifted:hover {
  transform: perspective(1000px) rotateY(0deg) rotateX(0deg);
}

/* Trust cards for dark section */
.ev-trust-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
  height: 100%;
  transition: border-color 0.2s ease;
}
.ev-trust-card:hover {
  border-color: rgba(255, 255, 255, 0.14);
}
.ev-trust-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.15rem;
  margin-bottom: 1rem;
}
.ev-trust-card__icon--teal  { background: rgba(52, 211, 153, 0.12); color: #34d399; }
.ev-trust-card__icon--blue  { background: rgba(147, 197, 253, 0.12); color: #93c5fd; }
.ev-trust-card__icon--amber { background: rgba(252, 211, 77, 0.12);  color: #fcd34d; }
.ev-trust-card__icon--purple{ background: rgba(196, 181, 253, 0.12); color: #c4b5fd; }
.ev-trust-card__title {
  font-size: 1rem;
  font-weight: 600;
  color: #ffffff;
  margin-bottom: .45rem;
}
.ev-trust-card__text {
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.45);
  line-height: 1.5;
  margin: 0;
}

/* Pricing teaser on home */
.ev-pricing-teaser {
  background: var(--surface);
  border-top: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
  padding: 6rem 0;
}

/* Dark section section header */
.ev-section-eyebrow--light {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .15em;
  color: rgba(255,255,255,0.4);
  margin-bottom: .6rem;
}
.ev-section-title--light {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 2.6vw, 2.35rem);
  font-weight: 600;
  color: #ffffff;
  line-height: 1.13;
  letter-spacing: -0.018em;
  margin-bottom: 1rem;
}
.ev-section-sub--light {
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.5);
  line-height: 1.5;
  max-width: 600px;
}

/* Responsive */
@media (max-width: 991.98px) {
  .ev-hero { padding: 5rem 0 0; }
  .ev-hero__title { font-size: 2.4rem; }
  .ev-hero__sub { max-width: 100%; }
  .ev-feat { padding: 4.5rem 0; }
  .ev-feat__body { max-width: 100%; }
  .ev-ss--lifted { transform: none; }
}
@media (max-width: 767.98px) {
  .ev-hero { padding: 4rem 0 0; }
  .ev-hero__title { font-size: 2rem; }
  .ev-hero__ctas { gap: .65rem; }
  .ev-btn-primary, .ev-btn-outline-dark { justify-content: center; }
  .ev-feat { padding: 3.5rem 0; }
  .ev-feat__list { margin-bottom: 1.5rem; }
}

/* ============================================================
   EV v3 - Clean redesign (SeedBlink-inspired)
   Light hero · clean device frames · bigger bolder type
   ============================================================ */

/* --- Clean device frame (no browser chrome) --- */
.ev-device {
  border: none;
  border-radius: 12px;
  overflow: hidden;
  background: #0d1521;
  box-shadow:
    0 0 0 1px rgba(13,21,33,.05),
    0 24px 60px rgba(13,21,33,.12),
    0 4px 12px rgba(13,21,33,.06);
  display: block;
}
.ev-device img { display: block; width: 100%; height: auto; }
.ev-device--zoomable {
  position: relative;
  cursor: zoom-in;
  transition: transform .18s ease, box-shadow .18s ease;
}
.ev-device--zoomable::after {
  content: 'Expand';
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  padding: .45rem .7rem;
  border-radius: 999px;
  background: rgba(11, 17, 27, .82);
  color: #ffffff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  pointer-events: none;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .18s ease, transform .18s ease;
}
.ev-device--zoomable:hover,
.ev-device--zoomable:focus-visible {
  transform: translateY(-2px);
}
.ev-device--zoomable:hover::after,
.ev-device--zoomable:focus-visible::after,
.ev-device--zoomable:focus-within::after {
  opacity: 1;
  transform: translateY(0);
}
.ev-device--zoomable:focus-visible {
  outline: 3px solid rgba(59, 130, 246, .35);
  outline-offset: 6px;
}
.ev-device--hero {
  border-width: 0;
  border-radius: 14px;
  box-shadow:
    0 0 0 1px rgba(13,21,33,.06),
    0 40px 100px rgba(13,21,33,.16),
    0 6px 20px rgba(13,21,33,.08);
}
.ev-device--showcase {
  border-width: 0;
  border-radius: 16px 16px 0 0;
  box-shadow:
    0 0 0 1px rgba(13,21,33,.05),
    0 -20px 80px rgba(13,21,33,.18);
}

/* --- Light product hero v3 --- */
.ev-hero-v3 {
  background: #ffffff;
  padding: 5.5rem 0 5rem;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--border-light);
}
.ev-hero-v3::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 45% at 105% 0%, rgba(15,118,110,.07) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at -5% 105%, rgba(59,130,246,.05) 0%, transparent 55%);
  pointer-events: none;
}
.ev-hero-v3__inner { position: relative; z-index: 1; }

.ev-hero-v3__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(15,118,110,.08);
  border: 1px solid rgba(15,118,110,.18);
  color: var(--accent-primary);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .36rem .9rem;
  border-radius: 999px;
  margin-bottom: 1.75rem;
}
.ev-hero-v3__title {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 5.5vw, 4.5rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin-bottom: 1.4rem;
}
.ev-hero-v3__sub {
  font-size: 1.25rem;
  color: var(--text-secondary);
  line-height: 1.5;
  max-width: 460px;
  margin-bottom: 2.5rem;
}
.ev-hero-v3__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
  margin-bottom: 2rem;
}
.ev-hero-v3__trust {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem 1.5rem;
  color: var(--muted);
  font-size: .8rem;
}
.ev-hero-v3__trust span { display: flex; align-items: center; gap: .38rem; }
.ev-hero-v3__trust i { color: var(--accent-primary); font-size: .75rem; }

/* CTA buttons for light backgrounds */
.ev-cta-dark {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--ink-900);
  color: #ffffff !important;
  font-weight: 700;
  padding: .82rem 1.85rem;
  border-radius: var(--radius-md);
  font-size: .95rem;
  text-decoration: none !important;
  transition: all .18s ease;
  border: 1px solid var(--ink-900);
  letter-spacing: -0.01em;
}
.ev-cta-dark:hover {
  background: #0c1928;
  border-color: #0c1928;
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(15,23,42,.2);
  color: #ffffff !important;
}
.ev-cta-ghost {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: var(--text-secondary) !important;
  font-weight: 600;
  padding: .82rem 1.6rem;
  border-radius: var(--radius-md);
  font-size: .95rem;
  border: 1px solid rgba(15,23,42,.16);
  text-decoration: none !important;
  transition: all .18s ease;
  background: transparent;
}
.ev-cta-ghost:hover {
  border-color: rgba(15,23,42,.3);
  color: var(--text) !important;
  background: rgba(15,23,42,.03);
}

/* --- Feature sections v3 --- */
.ev-feat-v3 {
  padding: 6.5rem 0;
  background: var(--surface);
}
.ev-feat-v3--gray {
  background: #f6f9fb;
  border-top: 1px solid #edf1f7;
  border-bottom: 1px solid #edf1f7;
}

.ev-feat-v3__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .67rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
  margin-bottom: .85rem;
  padding: .26rem .72rem;
  border-radius: 999px;
}
.ev-feat-v3__eyebrow--teal   { background: rgba(15,118,110,.09);  color: #0c6760; }
.ev-feat-v3__eyebrow--blue   { background: rgba(29,78,216,.09);   color: #1d4ed8; }
.ev-feat-v3__eyebrow--purple { background: rgba(91,91,214,.09);   color: #5b5bd6; }
.ev-feat-v3__eyebrow--amber  { background: rgba(180,120,30,.1);   color: #9a6010; }

.ev-feat-v3__title {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.8vw, 2.6rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: .9rem;
}
.ev-feat-v3__sub {
  font-size: 1.2rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 1.6rem;
  max-width: 440px;
}
.ev-feat-v3__list {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: flex;
  flex-direction: column;
  gap: .55rem;
}
.ev-feat-v3__list li {
  display: flex;
  align-items: flex-start;
  gap: .62rem;
  font-size: 1.05rem;
  color: var(--text);
  font-weight: 500;
  line-height: 1.5;
}
.ev-feat-v3__list li i { color: var(--accent-primary); margin-top: .12rem; flex-shrink: 0; }
.ev-feat-v3__cta {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink-900);
  text-decoration: none;
  border-bottom: 1.5px solid rgba(15,23,42,.2);
  padding-bottom: 1px;
  transition: border-color .15s ease, gap .15s ease;
}
.ev-feat-v3__cta:hover { border-color: var(--ink-900); gap: .65rem; color: var(--ink-900); }

/* --- Showpiece: dark full-bleed screenshot section --- */
.ev-showpiece {
  background: #134b54;
  padding: 6.5rem 0 0;
  position: relative;
  overflow: hidden;
}
.ev-showpiece::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% -5%, rgba(59,130,246,.11) 0%, transparent 60%),
    radial-gradient(ellipse 40% 35% at 85% 90%, rgba(15,118,110,.09) 0%, transparent 55%);
  pointer-events: none;
}
.ev-showpiece .container { position: relative; z-index: 1; }

.ev-showpiece__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  background: rgba(52,211,153,.1);
  border: 1px solid rgba(52,211,153,.2);
  color: rgba(52,211,153,.85);
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .32rem .8rem;
  border-radius: 999px;
  margin-bottom: .8rem;
}
.ev-showpiece__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 3.1rem);
  font-weight: 700;
  color: #ffffff;
  line-height: 1.1;
  letter-spacing: -0.022em;
  margin-bottom: 1rem;
}
.ev-showpiece__sub {
  font-size: 1.2rem;
  color: rgba(255,255,255,.48);
  line-height: 1.5;
  max-width: 540px;
  margin: 0 auto 3.5rem;
}

body.ev-lightbox-open {
  overflow: hidden;
}

.ev-lightbox {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1rem, 3vw, 2rem);
}
.ev-lightbox[hidden] {
  display: none !important;
}
.ev-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(7, 12, 20, .82);
  backdrop-filter: blur(10px);
  opacity: 0;
  transition: opacity .18s ease;
}
.ev-lightbox__dialog {
  position: relative;
  z-index: 1;
  width: min(2000px, 100%);
  opacity: 0;
  transform: translateY(14px) scale(.98);
  transition: opacity .18s ease, transform .18s ease;
}
.ev-lightbox.is-open .ev-lightbox__backdrop,
.ev-lightbox.is-open .ev-lightbox__dialog {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.ev-lightbox__toolbar {
  display: flex;
  justify-content: flex-end;
  margin-bottom: .85rem;
}
.ev-lightbox__close {
  border: 1px solid rgba(255, 255, 255, .18);
  background: rgba(11, 17, 27, .7);
  color: #ffffff;
  border-radius: 999px;
  padding: .6rem .95rem;
  font-size: .88rem;
  font-weight: 600;
  line-height: 1;
}
.ev-lightbox__close:hover,
.ev-lightbox__close:focus-visible {
  background: rgba(11, 17, 27, .92);
  border-color: rgba(255, 255, 255, .34);
  color: #ffffff;
}
.ev-lightbox__figure {
  margin: 0;
  background: rgba(13, 21, 33, .96);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .35);
}
.ev-lightbox__image {
  display: block;
  width: 100%;
  height: auto;
  max-height: calc(100vh - 8rem);
  object-fit: contain;
  background: #0d1521;
}
.ev-lightbox__caption {
  margin: 0;
  padding: .95rem 1.1rem 1.1rem;
  border-top: 1px solid rgba(255, 255, 255, .08);
  color: rgba(255, 255, 255, .72);
  font-size: .95rem;
  line-height: 1.5;
}

/* Responsive v3 */
@media (max-width: 991.98px) {
  .ev-hero-v3 { padding: 4.5rem 0 4rem; }
  .ev-hero-v3__title { font-size: 2.4rem; }
  .ev-hero-v3__sub { max-width: 100%; }
  .ev-feat-v3 { padding: 4.5rem 0; }
  .ev-feat-v3__sub { max-width: 100%; }
  .ev-showpiece { padding: 5rem 0 0; }
}
@media (max-width: 767.98px) {
  .ev-hero-v3 { padding: 3.5rem 0 0; }
  .ev-hero-v3__title { font-size: 1.95rem; }
  .ev-hero-v3__ctas { flex-direction: column; align-items: stretch; }
  .ev-cta-dark, .ev-cta-ghost { justify-content: center; }
  .ev-feat-v3 { padding: 3.5rem 0; }
  .ev-showpiece { padding: 4rem 0 0; }
  .ev-device--zoomable::after {
    opacity: 1;
    transform: translateY(0);
    right: .75rem;
    bottom: .75rem;
  }
  .ev-lightbox {
    padding: .85rem;
  }
  .ev-lightbox__toolbar {
    margin-bottom: .65rem;
  }
  .ev-lightbox__image {
    max-height: calc(100vh - 6.75rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ev-device--zoomable,
  .ev-device--zoomable::after,
  .ev-lightbox__backdrop,
  .ev-lightbox__dialog {
    transition: none;
  }
}
