/* =============================================================
   landing_v2.css  — Landing Page v2 (Paper feel + purple accent)
   ============================================================= */

/* ----------------------------------------------------------
   0. Page loader
   ---------------------------------------------------------- */
.lv2-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #f5f0ea;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}

[data-theme="dark"] .lv2-loader {
  background: hsl(224 12% 7%);
}

.lv2-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* Two-node connection animation — multi-layer */

/* Wrapper: entrance scale-in */
.lv2-loader__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  animation: lv2-entrance 0.55s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.lv2-loader__nodes {
  display: flex;
  align-items: center;
}

/* Node dots */
.lv2-loader__node {
  position: relative;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: hsl(270 85% 60%);
  flex-shrink: 0;
  animation: lv2-node-pulse 1.8s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

.lv2-loader__node:last-child {
  animation-delay: 0.9s;
}

/* Expanding ring emitted from each node */
.lv2-loader__node::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1.5px solid hsl(270 85% 60% / 0.7);
  animation: lv2-ring-expand 1.8s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

.lv2-loader__node:last-child::after {
  animation-delay: 0.9s;
}

/* Wire track */
.lv2-loader__wire {
  position: relative;
  width: 72px;
  height: 2px;
  background: hsl(270 85% 60% / 0.14);
  overflow: hidden;
  margin: 0 4px;
  border-radius: 1px;
}

/* Forward signal: left → right */
.lv2-loader__signal {
  position: absolute;
  top: 0;
  left: -40%;
  width: 40%;
  height: 100%;
  background: linear-gradient(
    to right,
    transparent 0%,
    hsl(270 85% 60% / 0.5) 35%,
    hsl(270 85% 72%) 50%,
    hsl(270 85% 60% / 0.5) 65%,
    transparent 100%
  );
  animation: lv2-signal-fwd 1.8s ease-in-out infinite;
}

/* Return signal: right → left — uses wire ::after pseudo */
.lv2-loader__wire::after {
  content: '';
  position: absolute;
  top: 0;
  right: -40%;
  width: 40%;
  height: 100%;
  background: linear-gradient(
    to left,
    transparent 0%,
    hsl(270 85% 60% / 0.5) 35%,
    hsl(270 85% 72%) 50%,
    hsl(270 85% 60% / 0.5) 65%,
    transparent 100%
  );
  animation: lv2-signal-return 1.8s ease-in-out 0.9s infinite;
}

/* Label below */
.lv2-loader__label {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: hsl(270 85% 60% / 0.65);
  animation: lv2-label-in 0.6s ease 0.5s both;
}

[data-theme="light"] .lv2-loader__label {
  color: hsl(224 12% 45%);
}

.lv2-loader__label.is-swapping {
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.lv2-loader__label:not(.is-swapping) {
  transition: opacity 0.2s ease, transform 0.2s ease;
}

/* ── Keyframes ─────────────────────────────────────── */

@keyframes lv2-entrance {
  from { opacity: 0; transform: scale(0.8) translateY(10px); }
  to   { opacity: 1; transform: scale(1)   translateY(0); }
}

@keyframes lv2-node-pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.55;
    box-shadow: 0 0 0 0 hsl(270 85% 60% / 0);
  }
  40% {
    transform: scale(1.3);
    opacity: 1;
    box-shadow: 0 0 0 6px hsl(270 85% 60% / 0.18);
  }
  70% {
    transform: scale(1.1);
    opacity: 0.85;
    box-shadow: 0 0 0 10px hsl(270 85% 60% / 0.06);
  }
}

@keyframes lv2-ring-expand {
  0%   { transform: scale(1);   opacity: 0.7; }
  100% { transform: scale(2.8); opacity: 0; }
}

@keyframes lv2-signal-fwd {
  0%   { left: -40%; }
  100% { left: 100%; }
}

@keyframes lv2-signal-return {
  0%   { right: -40%; }
  100% { right: 100%; }
}

@keyframes lv2-label-in {
  from { opacity: 0; transform: translateY(5px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Reduced motion: keep nodes visible, kill all animation */
@media (prefers-reduced-motion: reduce) {
  .lv2-loader__inner { animation: none; }
  .lv2-loader__node  { animation: none; opacity: 0.8; }
  .lv2-loader__node::after { animation: none; opacity: 0; }
  .lv2-loader__signal,
  .lv2-loader__wire::after { animation: none; opacity: 0; }
  .lv2-loader__label { animation: none; }
}

/* ----------------------------------------------------------
   1. Page-level custom properties
   ---------------------------------------------------------- */
[data-theme="light"] {
  --lv2-bg:             #f5f0ea;
  --lv2-hero-bg:        #f5f0ea;
  --lv2-surface:        #f5f0ea;
  --lv2-surface-raised: #ece7e0;
  --lv2-text-primary:   hsl(224 12% 12%);
  --lv2-text-secondary: hsl(224 8% 40%);
  --lv2-text-muted:     hsl(224 6% 55%);
  --lv2-border:         hsl(224 8% 85%);
  --lv2-divider:        hsl(224 8% 78%);
  --lv2-nav-bg:         #f5f0ea;
  --lv2-card-shadow:    0 2px 16px hsl(224 12% 12% / 0.06);
  --lv2-accent:         hsl(270 85% 60%);
  --lv2-accent-subtle:  hsl(270 85% 60% / 0.08);
  --lv2-accent-hover:   hsl(270 75% 46%);
  --lv2-accent-text:    #fff;
}

[data-theme="dark"] {
  --lv2-bg:             hsl(260 15% 7%);
  --lv2-hero-bg:        hsl(260 15% 7%);
  --lv2-surface:        hsl(260 12% 11%);
  --lv2-surface-raised: hsl(260 10% 15%);
  --lv2-text-primary:   #f0eef5;
  --lv2-text-secondary: hsl(260 10% 72%);
  --lv2-text-muted:     hsl(260 6% 50%);
  --lv2-border:         hsl(260 10% 20%);
  --lv2-divider:        hsl(260 10% 20%);
  --lv2-nav-bg:         hsl(260 15% 7%);
  --lv2-card-shadow:    0 4px 32px hsl(270 20% 4% / 0.6);
  --lv2-accent:         hsl(270 85% 68%);
  --lv2-accent-subtle:  hsl(270 85% 60% / 0.12);
  --lv2-accent-hover:   hsl(270 85% 75%);
  --lv2-accent-text:    #fff;
}

/* ----------------------------------------------------------
   1b. Dark mode circuit background
   ---------------------------------------------------------- */
.lv2-dark-bg {
  display: none;
}

[data-theme="dark"] .lv2-dark-bg {
  display: block;
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

[data-theme="dark"] .lv2-page,
[data-theme="dark"] .lv2-hero,
[data-theme="dark"] .lv2-pillars,
[data-theme="dark"] .lv2-letter__paper {
  background: transparent;
}

#circuit-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.5;
}

/* Fade div removed — circuit is subtle enough on its own */
.lv2-dark-bg__fade {
  display: none;
}

/* ----------------------------------------------------------
   2. Base reset
   ---------------------------------------------------------- */
html:has(.lv2-page) {
  background: var(--lv2-hero-bg);
}

.lv2-page {
  --font-sans:    'Inter Display', sans-serif;
  --font-display: 'Inter Display', sans-serif;
  background: var(--lv2-bg);
  color: var(--lv2-text-primary);
  font-family: var(--font-sans);
  min-height: 100vh;
  transition: background 0.3s ease, color 0.3s ease;
  position: relative;
  z-index: 1;
}

.lv2-page *,
.lv2-page *::before,
.lv2-page *::after {
  box-sizing: border-box;
}

.lv2-page button,
.lv2-page input,
.lv2-page select,
.lv2-page textarea {
  font-family: inherit;
}

.lv2-section-heading,
.lv2-hero__h1,
.lv2-stats-bar__number,
.lv2-pillars__heading,
.lv2-compare__heading,
.lv2-credentials__heading,
.lv2-steps__heading,
.lv2-ambassador__heading,
.lv2-closing__heading,
.lv2-letter__heading {
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.08;
}

/* ----------------------------------------------------------
   3. Shared layout helpers
   ---------------------------------------------------------- */
.lv2-section-inner {
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: var(--space-6, 24px);
}

.lv2-section-eyebrow {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--lv2-text-primary);
  margin-bottom: var(--space-3, 12px);
}

.lv2-section-heading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--lv2-text-primary);
  margin: 0 0 var(--space-4, 16px);
}

/* ----------------------------------------------------------
   4. Navbar
   ---------------------------------------------------------- */
.lv2-nav {
  position: static;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-4, 16px);
  padding: var(--space-4, 16px) var(--space-8, 32px);
  background: var(--lv2-nav-bg);
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s ease, background 0.3s ease;
}

.lv2-nav.scrolled {
  border-bottom-color: var(--lv2-border);
}

.lv2-nav__logo {
  display: flex;
  align-items: center;
  gap: var(--space-2, 8px);
  text-decoration: none;
  color: var(--lv2-text-primary);
  font-weight: 700;
  font-size: 1.15rem;
}

.lv2-nav__logo img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.lv2-nav__links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-8, 32px);
  list-style: none;
  margin: 0;
  padding: 0;
}

.lv2-nav__link {
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--lv2-text-secondary);
  transition: color 0.2s ease;
}

.lv2-nav__link:hover {
  color: var(--lv2-text-primary);
}

.lv2-nav__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3, 12px);
}

.lv2-theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--lv2-border);
  background: transparent;
  color: var(--lv2-text-secondary);
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
  flex-shrink: 0;
}

.lv2-theme-toggle:hover {
  background: var(--lv2-surface-raised, var(--lv2-surface));
  color: var(--lv2-text-primary);
}

.lv2-theme-toggle .ph-sun,
.lv2-theme-toggle .ph-moon {
  font-size: 1rem;
}

[data-theme="light"] .lv2-theme-toggle .icon-moon { display: block; }
[data-theme="light"] .lv2-theme-toggle .icon-sun  { display: none; }
[data-theme="dark"]  .lv2-theme-toggle .icon-sun  { display: block; }
[data-theme="dark"]  .lv2-theme-toggle .icon-moon { display: none; }

.lv2-nav__btn-login {
  background: transparent;
  border: 1px solid var(--lv2-border);
  color: var(--lv2-text-primary);
  padding: 0.45rem 1.1rem;
  border-radius: 100px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
  white-space: nowrap;
}

.lv2-nav__btn-login:hover {
  background: var(--lv2-surface-raised, hsl(0 0% 0% / 0.04));
  transform: translateY(-1px);
}

[data-theme="dark"] .lv2-nav__btn-login {
  background: hsl(0 0% 100% / 0.06);
  border-color: hsl(0 0% 100% / 0.12);
  color: hsl(30 10% 90%);
}

[data-theme="dark"] .lv2-nav__btn-login:hover {
  background: hsl(0 0% 100% / 0.12);
}

.lv2-nav__btn-signup {
  background: var(--lv2-accent);
  border: none;
  color: var(--lv2-accent-text);
  padding: 0.45rem 1.25rem;
  border-radius: 100px;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease;
  white-space: nowrap;
  box-shadow: 0 2px 12px hsl(270 85% 60% / 0.25);
}

.lv2-nav__btn-signup:hover {
  background: var(--lv2-accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 20px hsl(270 85% 60% / 0.35);
}

/* ----------------------------------------------------------
   5. Mobile menu
   ---------------------------------------------------------- */
.lv2-nav__hamburger {
  display: none;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--lv2-border);
  border-radius: 8px;
  color: var(--lv2-text-primary);
  cursor: pointer;
}

.lv2-mobile-menu {
  display: none;
  flex-direction: column;
  gap: var(--space-2, 8px);
  position: fixed;
  top: 65px;
  left: var(--space-4, 16px);
  right: var(--space-4, 16px);
  background: var(--lv2-bg);
  border: 1px solid var(--lv2-border);
  border-radius: 16px;
  padding: var(--space-4, 16px);
  z-index: 99;
  box-shadow: var(--lv2-card-shadow);
}

.lv2-mobile-menu.open {
  display: flex;
}

.lv2-mobile-menu__link {
  text-decoration: none;
  color: var(--lv2-text-secondary);
  font-size: 0.95rem;
  font-weight: 500;
  padding: var(--space-2, 8px) var(--space-3, 12px);
  border-radius: 8px;
  transition: background 0.15s ease, color 0.15s ease;
}

.lv2-mobile-menu__link:hover {
  background: var(--lv2-surface-raised, var(--lv2-surface));
  color: var(--lv2-text-primary);
}

.lv2-mobile-menu__divider {
  height: 1px;
  background: var(--lv2-border);
  margin: var(--space-2, 8px) 0;
}

.lv2-mobile-menu .lv2-nav__btn-login,
.lv2-mobile-menu .lv2-nav__btn-signup {
  width: 100%;
  text-align: center;
  padding: 0.6rem 1rem;
}

/* ----------------------------------------------------------
   6. Shared entrance keyframe
   ---------------------------------------------------------- */
@keyframes lv2-pop {
  from {
    opacity: 0;
    transform: translateY(40px) scale(0.94);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* ----------------------------------------------------------
   7. Hero section
   ---------------------------------------------------------- */
.lv2-hero {
  background: var(--lv2-hero-bg);
  padding-top: 72px;
  padding-bottom: 0;
  text-align: center;
  overflow: clip;
}

.lv2-hero__inner {
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: var(--space-6, 24px);
  padding-bottom: 56px;
  position: relative;
  isolation: isolate;
}

.lv2-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2, 8px);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--lv2-text-secondary);
  background: var(--lv2-surface-raised, var(--lv2-surface));
  padding: 0.3rem 0.9rem;
  border-radius: 100px;
  border: 1px solid var(--lv2-border);
  margin-bottom: var(--space-6, 24px);
}

.lv2-hero__h1 {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(3rem, 7.5vw, 5.5rem);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.045em;
  color: var(--lv2-text-primary);
  margin: 0 0 var(--space-6, 24px);
  max-width: 900px;
  margin-inline: auto;
}

.lv2-hero__h1 em {
  font-style: normal;
  font-weight: 800;
  color: var(--lv2-text-primary);
}

.lv2-hero__subtitle {
  font-size: clamp(1rem, 2vw, 1.15rem);
  color: var(--lv2-text-secondary);
  line-height: 1.7;
  max-width: 540px;
  margin: 0 auto var(--space-8, 32px);
}

.lv2-hero__cta-group {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3, 12px);
  flex-wrap: wrap;
  margin-bottom: var(--space-8, 32px);
}

.lv2-hero__cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--lv2-text-primary);
  color: var(--lv2-bg);
  border: none;
  padding: 14px 16px 14px 28px;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.15s ease;
}

.lv2-hero__cta-primary:hover {
  opacity: 0.88;
  transform: translateY(-2px);
}

/* Shared arrow circle for all CTAs */
.lv2-cta-arrow {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--lv2-accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

button:hover > .lv2-cta-arrow {
  transform: translateX(2px);
}

.lv2-cta-arrow--invert {
  background: var(--lv2-text-primary);
  color: var(--lv2-bg);
}

.lv2-hero__cta-secondary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2, 8px);
  background: transparent;
  color: var(--lv2-text-secondary);
  border: 1px solid var(--lv2-border);
  padding: 0.85rem 1.75rem;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.lv2-hero__cta-secondary:hover {
  background: var(--lv2-surface-raised, var(--lv2-surface));
  border-color: var(--lv2-divider);
  color: var(--lv2-text-primary);
}

/* Hero entrance animations */
.lv2-hero__h1       { animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.1s both; }
.lv2-hero__subtitle { animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.2s both; }
.lv2-hero__cta-group{ animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.3s both; }

/* Cursor-parallax glow orb */
.lv2-hero__glow {
  position: absolute;
  z-index: -1;
  width: 900px;
  height: 900px;
  left: calc(50% - 450px);
  top: calc(50% - 450px);
  border-radius: 50%;
  background: radial-gradient(circle, hsl(270 85% 60% / 0.11) 0%, transparent 62%);
  pointer-events: none;
  will-change: transform;
  transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

[data-theme="light"] .lv2-hero__glow {
  opacity: 0.45;
}


/* ----------------------------------------------------------
   8. Stats bar
   ---------------------------------------------------------- */
.lv2-stats-bar {
  padding: 72px 0;
  border-bottom: 1px solid var(--lv2-border);
}

.lv2-stats-bar__inner {
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: 24px;
  display: flex;
  justify-content: center;
  gap: 72px;
  flex-wrap: wrap;
}

.lv2-stats-bar__item {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.lv2-stats-bar__number {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 4.5rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--lv2-text-primary);
}

.lv2-stats-bar__label {
  font-size: 0.875rem;
  color: var(--lv2-text-secondary);
  font-weight: 500;
}

/* Staggered entrance */
.lv2-stats-bar__item:nth-child(1) { animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.1s both; }
.lv2-stats-bar__item:nth-child(2) { animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.2s both; }
.lv2-stats-bar__item:nth-child(3) { animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.3s both; }
.lv2-stats-bar__item:nth-child(4) { animation: lv2-pop 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.4s both; }

/* ----------------------------------------------------------
   9. School marquee — dimmed logo-strip style
   ---------------------------------------------------------- */
@keyframes lv2-marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-25%); }
}

.lv2-schools-heading {
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--lv2-text-muted, var(--lv2-text-secondary));
  text-align: center;
  margin: 0 0 24px;
  opacity: 0.6;
}

.lv2-schools-marquee {
  padding: 0 0 56px;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, black 120px, black calc(100% - 120px), transparent);
  mask-image: linear-gradient(to right, transparent, black 120px, black calc(100% - 120px), transparent);
}

.lv2-schools-marquee__track {
  display: flex;
  align-items: center;
  gap: 48px;
  width: max-content;
  animation: lv2-marquee 40s linear infinite;
}

.lv2-schools__name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--lv2-text-primary);
  white-space: nowrap;
  opacity: 0.25;
  flex-shrink: 0;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

/* ----------------------------------------------------------
   9b. Side-by-side pillars (Wone two-column style)
   ---------------------------------------------------------- */
.lv2-pillars {
  padding: 96px 0;
  background: var(--lv2-bg);
  border-top: 1px solid var(--lv2-border);
}

.lv2-pillars__inner {
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: 48px;
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 0 56px;
  align-items: start;
}

.lv2-pillars__divider {
  background: var(--lv2-divider);
  align-self: stretch;
}

.lv2-pillars__col {
  padding: 24px 0;
}

.lv2-pillars__heading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.12;
  color: var(--lv2-text-primary);
  margin: 0 0 20px;
}

.lv2-pillars__body {
  font-size: 1rem;
  color: var(--lv2-text-secondary);
  line-height: 1.7;
  margin: 0;
}

/* ----------------------------------------------------------
   10. Comparison graph (Wone rounded card)
   ---------------------------------------------------------- */
.lv2-compare {
  padding: 80px 0;
}

.lv2-compare__inner {
  max-width: 1100px;
  margin-inline: auto;
  padding: 56px;
  background: var(--lv2-surface-raised, var(--lv2-surface));
  border: 1px solid var(--lv2-border);
  border-radius: 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

.lv2-compare__heading {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.12;
  color: var(--lv2-text-primary);
  margin: 0 0 16px;
}

.lv2-compare__sub {
  font-size: 1rem;
  color: var(--lv2-text-secondary);
  line-height: 1.7;
  margin: 0;
}

.lv2-compare__bar-group {
  display: flex;
  align-items: flex-end;
  gap: 16px;
  width: 100%;
  height: 280px;
}

.lv2-compare__bar-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  height: 100%;
  justify-content: flex-end;
}

.lv2-compare__bar-label {
  font-size: 0.75rem;
  color: var(--lv2-text-secondary);
  font-weight: 500;
  text-align: center;
}

.lv2-compare__bar {
  width: 100%;
  border-radius: 8px 8px 4px 4px;
  background: var(--lv2-border);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 12px;
  transition: height 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}

.lv2-compare__bar-value {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--lv2-text-secondary);
  white-space: nowrap;
}

.lv2-compare__bar--tall   { height: 90%; }
.lv2-compare__bar--medium { height: 70%; }
.lv2-compare__bar--short  { height: 45%; }
.lv2-compare__bar--tiny   { height: 12%; }

.lv2-compare__bar-wrapper--brand .lv2-compare__bar {
  background: var(--lv2-accent);
}

.lv2-compare__bar-wrapper--brand .lv2-compare__bar-value {
  color: #fff;
}

.lv2-compare__bar-wrapper--brand .lv2-compare__bar-label {
  font-weight: 700;
  color: var(--lv2-text-primary);
}

/* ----------------------------------------------------------
   11. Credentials
   ---------------------------------------------------------- */
.lv2-credentials {
  padding: 96px 0;
  text-align: center;
}

.lv2-credentials__inner {
  max-width: 640px;
  margin-inline: auto;
  padding-inline: 24px;
}

.lv2-credentials__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3.25rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.08;
  color: var(--lv2-text-primary);
  margin: 0 0 20px;
}

.lv2-credentials__body {
  font-size: 1rem;
  color: var(--lv2-text-secondary);
  line-height: 1.65;
  margin: 0 0 36px;
}

.lv2-credentials__btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--lv2-text-primary);
  color: var(--lv2-bg);
  border: none;
  padding: 14px 16px 14px 28px;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.15s ease;
}

.lv2-credentials__btn:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}

/* ----------------------------------------------------------
   13. Feature Showcase cards (Wone feature-section style)
   ---------------------------------------------------------- */
.lv2-feat-showcase {
  padding: 60px 0 80px;
}

.lv2-feat-showcase__inner {
  max-width: 1400px;
  margin-inline: auto;
  padding-inline: var(--space-8, 32px);
  display: flex;
  flex-direction: column;
  gap: 96px;
}

.lv2-showcase-card {
  background: var(--lv2-surface-raised, var(--lv2-surface));
  border: 1px solid var(--lv2-border);
  border-radius: 28px;
  overflow: hidden;
}

.lv2-showcase-card--img {
  background-size: 100% auto;
  background-position: center 95%;
  background-color: transparent;
}

.lv2-showcase-card--img .lv2-showcase-card__header {
  background: hsl(30 15% 94% / 0.5);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid hsl(30 10% 80% / 0.3);
}

[data-theme="dark"] .lv2-showcase-card--img .lv2-showcase-card__header {
  background: hsl(30 5% 10% / 0.4);
  border-bottom-color: hsl(0 0% 100% / 0.06);
}

.lv2-showcase-card__header {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  column-gap: var(--space-8, 32px);
  padding: 44px 52px 40px;
}

.lv2-showcase-card__header-left {
  grid-column: 1;
  grid-row: 1 / 3;
  max-width: 520px;
}

.lv2-showcase-card__eyebrow {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--lv2-accent);
  margin: 0 0 14px;
}

.lv2-showcase-card__heading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.1;
  color: var(--lv2-text-primary);
  margin: 0 0 var(--space-4, 16px);
}

.lv2-showcase-card__body {
  font-size: 1rem;
  color: var(--lv2-text-secondary);
  line-height: 1.7;
  margin: 0;
}

/* Black pill CTA with arrow */
.lv2-showcase-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  background: var(--lv2-text-primary);
  color: var(--lv2-bg);
  border: none;
  border-radius: 999px;
  padding: 18px 20px 18px 28px;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  align-self: end;
  grid-column: 2;
  grid-row: 2;
  font-size: 0.9rem;
  font-weight: 600;
  transition: opacity 0.2s ease, transform 0.15s ease;
  text-align: left;
}

.lv2-showcase-card__cta:hover {
  opacity: 0.88;
  transform: translateY(-2px);
}

.lv2-showcase-card__cta-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.lv2-showcase-card__cta-title {
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1;
}

.lv2-showcase-card__cta-sub {
  font-size: 0.78rem;
  font-weight: 400;
  opacity: 0.5;
  line-height: 1.2;
}

/* Ensure subtitle is always visible */
.lv2-showcase-card__cta .lv2-showcase-card__cta-sub {
  display: block;
}

.lv2-showcase-card__cta-arrow {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--lv2-accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}

.lv2-showcase-card__cta:hover .lv2-showcase-card__cta-arrow {
  transform: translateX(3px);
}

.lv2-showcase-card__screen {
  margin: 0;
  border-radius: 0 0 28px 28px;
  overflow: hidden;
  padding: 64px 56px 0;
}

.lv2-showcase-card__screen img {
  width: 100%;
  border-radius: 12px 12px 0 0;
  display: block;
  box-shadow: 0 8px 40px hsl(30 10% 20% / 0.18);
}

.lv2-showcase-card__screen--img {
  background-size: cover;
  background-position: center 95%;
}

.lv2-showcase-card__screen--blue {
  background: linear-gradient(135deg, hsl(215 70% 55%) 0%, hsl(260 65% 50%) 50%, hsl(320 55% 55%) 100%);
}

.lv2-showcase-card__screen--purple {
  background: linear-gradient(135deg, hsl(270 75% 40%) 0%, hsl(210 70% 45%) 100%);
}

.lv2-showcase-card__screen--warm {
  background: linear-gradient(135deg, hsl(25 75% 52%) 0%, hsl(350 65% 48%) 60%, hsl(280 55% 45%) 100%);
}

/* ----------------------------------------------------------
   14. Ambassador — showcase card style
   ---------------------------------------------------------- */
.lv2-ambassador {
  padding: 80px 0;
}

.lv2-ambassador__inner {
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: var(--space-6, 24px);
  position: relative;
  background: hsl(270 55% 10%);
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid hsl(270 40% 25% / 0.4);
  box-shadow: 0 24px 64px hsl(270 60% 10% / 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 64px 48px;
  min-height: 560px;
}

.lv2-ambassador__inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('/static/images/meadows_form.png');
  background-size: cover;
  background-position: center top;
  filter: hue-rotate(-30deg) saturate(1.4) brightness(0.8) contrast(1.2);
  z-index: 0;
}

/* Floating panel centered over the image */
.lv2-ambassador__panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 780px;
  background: hsl(270 40% 6% / 0.55);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border: 1px solid hsl(270 60% 80% / 0.15);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 12px 56px hsl(270 60% 5% / 0.5), inset 0 1px 0 hsl(0 0% 100% / 0.08);
}

/* Header */
.lv2-ambassador__card-header {
  background: hsl(0 0% 100% / 0.04);
  border-bottom: 1px solid hsl(0 0% 100% / 0.08);
  padding: 32px 36px 28px;
}

.lv2-ambassador__card-body {
  padding: 28px 36px 32px;
}

.lv2-ambassador__eyebrow {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: hsl(140 50% 65%);
  margin-bottom: var(--space-3, 12px);
}

.lv2-ambassador__heading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin: 0 0 var(--space-3, 12px);
}

.lv2-ambassador__desc {
  color: hsl(270 15% 78%);
  font-size: 1rem;
  line-height: 1.7;
  margin: 0;
  max-width: 600px;
}

/* Consistent form spacing */
.lv2-ambassador .ambassador-form-card form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 12px);
}

.lv2-ambassador .ambassador-form-card .form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-3, 12px);
}

.lv2-ambassador .ambassador-form-card .form-group {
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Form fields on dark bg */
.lv2-ambassador .form-select,
.lv2-ambassador .form-input,
.lv2-ambassador .form-textarea {
  background: hsl(0 0% 100% / 0.06);
  border-color: hsl(0 0% 100% / 0.12);
  color: #fff;
}

.lv2-ambassador .form-select option {
  background: hsl(270 55% 18%);
  color: #fff;
}

.lv2-ambassador .form-select::placeholder,
.lv2-ambassador .form-input::placeholder,
.lv2-ambassador .form-textarea::placeholder {
  color: hsl(270 12% 55%);
}

.lv2-ambassador .form-select:focus,
.lv2-ambassador .form-input:focus,
.lv2-ambassador .form-textarea:focus {
  border-color: hsl(270 85% 65%);
  outline: none;
  box-shadow: 0 0 0 3px hsl(270 85% 60% / 0.2);
  background: hsl(0 0% 100% / 0.1);
}

.lv2-ambassador .form-label {
  color: hsl(270 15% 78%);
}

/* Form card */
.lv2-ambassador .ambassador-form-card {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
}

.lv2-ambassador .ambassador-submit {
  background: #fff;
  color: hsl(270 55% 22%);
  border: none;
  padding: 0.75rem 2rem;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.15s ease;
  margin-top: var(--space-2, 8px);
}

.lv2-ambassador .ambassador-submit:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}

.lv2-ambassador #ambassador-message.success {
  margin-top: var(--space-4, 16px);
  padding: var(--space-4, 16px);
  border-radius: 12px;
  background: hsl(142 50% 45% / 0.12);
  color: hsl(142 50% 65%);
  font-size: 0.875rem;
  border: 1px solid hsl(142 50% 45% / 0.18);
}

.lv2-ambassador #ambassador-message.error {
  margin-top: var(--space-4, 16px);
  padding: var(--space-4, 16px);
  border-radius: 12px;
  background: hsl(0 70% 50% / 0.1);
  color: hsl(0 70% 68%);
  font-size: 0.875rem;
  border: 1px solid hsl(0 70% 50% / 0.18);
}

/* Role explorer */
.lv2-ambassador .role-explorer {
  background: hsl(0 0% 100% / 0.04);
  border: 1px solid hsl(0 0% 100% / 0.08);
  border-radius: 16px;
  padding: var(--space-6, 24px);
  margin-bottom: var(--space-6, 24px);
}

.lv2-ambassador .role-explorer__header {
  display: flex;
  align-items: center;
  gap: var(--space-4, 16px);
  flex-wrap: wrap;
}

.lv2-ambassador .role-explorer__label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
}

.lv2-ambassador .role-details {
  margin-top: var(--space-4, 16px);
}

.lv2-ambassador .role-detail__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6, 24px);
}

.lv2-ambassador .role-detail__heading {
  font-size: 0.875rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 var(--space-3, 12px);
}

.lv2-ambassador .role-detail__list {
  padding-left: var(--space-4, 16px);
  margin: 0;
  font-size: 0.85rem;
  color: hsl(270 20% 75%);
  line-height: 1.7;
}

.lv2-ambassador .role-detail__list strong {
  color: hsl(270 15% 90%);
}

.lv2-ambassador .role-detail__note {
  margin-top: var(--space-4, 16px);
  padding: var(--space-3, 12px) var(--space-4, 16px);
  border-radius: 10px;
  background: hsl(270 85% 60% / 0.15);
  border: 1px solid hsl(270 85% 60% / 0.2);
  color: hsl(270 20% 80%);
  font-size: 0.8rem;
  display: flex;
  gap: var(--space-2, 8px);
  align-items: flex-start;
}

/* Ambassador responsive */
@media (max-width: 768px) {
  .lv2-ambassador__card-header,
  .lv2-ambassador__card-body {
    padding-inline: 24px;
  }
  .lv2-ambassador__card-header { padding-block: 32px 28px; }
  .lv2-ambassador__card-body   { padding-block: 28px 32px; }

  .lv2-ambassador .role-detail__grid {
    grid-template-columns: 1fr;
  }
}

/* ----------------------------------------------------------
   15. Letter from Our Team (Wone open letter style)
   ---------------------------------------------------------- */
.lv2-letter {
  padding: 96px 0;
}

.lv2-letter__inner {
  max-width: 780px;
  margin-inline: auto;
  padding-inline: 24px;
}

.lv2-letter__paper {
  background: var(--lv2-bg);
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  position: relative;
}

[data-theme="dark"] .lv2-letter__paper {
  box-shadow: none;
}

/* No decorative border — clean Wone style */
.lv2-letter__paper::before {
  display: none;
}

.lv2-letter__heading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.12;
  color: var(--lv2-text-primary);
  margin: 0 0 36px;
}

.lv2-letter__body {
  font-size: 1rem;
  color: var(--lv2-text-secondary);
  line-height: 1.8;
}

.lv2-letter__body p {
  margin: 0 0 24px;
}

.lv2-letter__body p:last-child {
  margin-bottom: 0;
}

.lv2-letter__subheading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--lv2-text-primary);
  margin: 40px 0 20px;
}

.lv2-letter__sign {
  font-weight: 600;
  color: var(--lv2-text-primary);
  font-style: italic;
  margin-top: 36px !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

/* ── Ink bleed-in reveal ── */
.lv2-letter__body p,
.lv2-letter__subheading {
  opacity: 0.12;
  filter: blur(5px);
  transform: translateY(6px);
  transition:
    opacity  0.75s cubic-bezier(0.16, 1, 0.3, 1),
    filter   0.75s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.75s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, filter, transform;
}

.lv2-letter__body p.is-ink-revealed,
.lv2-letter__subheading.is-ink-revealed {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* ── Pen signature SVG ── */
.lv2-letter__sig-wrap {
  display: block;
  line-height: 0;
}

.lv2-letter__sig-svg {
  width: 200px;
  height: 16px;
  color: hsl(270 85% 65%);
  opacity: 0.75;
}

.lv2-letter__sig-path {
  /* dasharray / dashoffset set precisely by JS via getTotalLength() */
  transition: stroke-dashoffset 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}

.lv2-letter__sign.is-signed .lv2-letter__sig-path {
  stroke-dashoffset: 0 !important;
}

/* Reduced motion — show everything static, signature pre-drawn */
@media (prefers-reduced-motion: reduce) {
  .lv2-letter__body p,
  .lv2-letter__subheading {
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
    transition: none !important;
  }

  .lv2-letter__sig-path {
    stroke-dasharray: none !important;
    stroke-dashoffset: 0 !important;
    transition: none !important;
  }
}

/* ----------------------------------------------------------
   16. End section (closing CTA + footer share one background)
   ---------------------------------------------------------- */
.lv2-end {
  position: relative;
  overflow: hidden;
  border-radius: 36px 36px 0 0;
  margin-top: 48px;
  border: 1px solid hsl(0 0% 100% / 0.1);
  border-bottom: none;
  background: hsl(224 12% 5%);
}

[data-theme="light"] .lv2-end {
  background: hsl(224 10% 8%);
}

.lv2-end__bg {
  position: absolute;
  inset: 0;
  background-image: url('/static/images/snowy peak.jpg');
  background-size: cover;
  background-position: center top;
  filter: hue-rotate(-25deg) saturate(1.6) brightness(0.78) contrast(1.3);
  z-index: 0;
}

.lv2-end__grain {
  position: absolute;
  inset: 0;
  background: hsl(0 0% 50%);
  filter: url('#closing-grain');
  opacity: 0.3;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 1;
}

.lv2-closing {
  position: relative;
  z-index: 2;
  min-height: 75vh;
  display: flex;
  align-items: center;
  padding: 80px 0 96px;
  text-align: center;
}

.lv2-closing__inner {
  position: relative;
  z-index: 1;
  max-width: 580px;
  width: 100%;
  margin-inline: auto;
  padding: var(--space-8, 32px) var(--space-8, 32px) 48px;
  background: hsl(270 40% 8% / 0.35);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid hsl(270 60% 80% / 0.15);
  border-radius: 28px;
  box-shadow: 0 8px 48px hsl(270 60% 5% / 0.4), inset 0 1px 0 hsl(0 0% 100% / 0.08);
}

.lv2-closing__heading {
  font-family: var(--font-display, 'Inter Display', sans-serif);
  font-size: clamp(2.5rem, 5vw, 3.75rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.08;
  letter-spacing: -0.04em;
  margin: 0 0 var(--space-4, 16px);
  text-shadow: 0 2px 12px hsl(0 0% 0% / 0.5);
}

.lv2-closing__sub {
  color: hsl(0 0% 85%);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0 0 var(--space-8, 32px);
  text-shadow: 0 1px 6px hsl(0 0% 0% / 0.45);
}

.lv2-closing__btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  color: hsl(270 60% 25%);
  border: none;
  padding: 14px 16px 14px 28px;
  border-radius: 100px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.15s ease;
  box-shadow: 0 4px 20px hsl(0 0% 0% / 0.3);
}

.lv2-closing__btn .lv2-cta-arrow--invert {
  background: hsl(270 85% 60%);
  color: #fff;
}

.lv2-closing__btn:hover {
  opacity: 0.9;
  transform: translateY(-2px);
}

[data-theme="light"] .lv2-closing__heading { color: #fff; }
[data-theme="light"] .lv2-closing__sub { color: hsl(30 8% 70%); }

/* ----------------------------------------------------------
   17. Footer
   ---------------------------------------------------------- */
.lv2-footer {
  position: relative;
  z-index: 2;
  padding: 64px 0 0;
}

.lv2-footer__inner {
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 64px;
  padding-bottom: 48px;
}

.lv2-footer__left {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.lv2-footer__brand {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 1.1rem;
}

.lv2-footer__brand img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.lv2-footer__tagline {
  font-size: 0.9rem;
  color: hsl(224 8% 55%);
  line-height: 1.5;
  margin: 0;
}

.lv2-footer__social {
  display: flex;
  gap: 12px;
  margin-top: 8px;
}

.lv2-footer__social a {
  color: hsl(224 8% 55%);
  font-size: 1.1rem;
  text-decoration: none;
  transition: color 0.2s ease;
}

.lv2-footer__social a:hover {
  color: #fff;
}

.lv2-footer__columns {
  display: flex;
  gap: 64px;
}

.lv2-footer__col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lv2-footer__col-title {
  font-size: 0.85rem;
  font-weight: 600;
  color: #fff;
  margin: 0 0 4px;
}

.lv2-footer__col-link {
  font-size: 0.85rem;
  color: hsl(224 8% 55%);
  text-decoration: none;
  transition: color 0.2s ease;
}

.lv2-footer__col-link:hover {
  color: #fff;
}

.lv2-footer__bottom {
  max-width: 1100px;
  margin-inline: auto;
  padding: 24px;
  border-top: 1px solid hsl(224 8% 20%);
}

.lv2-footer__copy {
  font-size: 0.8rem;
  color: hsl(224 8% 45%);
  margin: 0;
}

/* Light mode footer overrides (footer always on dark bg) */
[data-theme="light"] .lv2-footer__brand { color: #fff; }
[data-theme="light"] .lv2-footer__col-title { color: #fff; }
[data-theme="light"] .lv2-footer__col-link { color: hsl(224 8% 55%); }
[data-theme="light"] .lv2-footer__col-link:hover { color: #fff; }
[data-theme="light"] .lv2-footer__social a { color: hsl(224 8% 55%); }
[data-theme="light"] .lv2-footer__social a:hover { color: #fff; }

/* ----------------------------------------------------------
   17. Auth modal — coherent with design system
   ---------------------------------------------------------- */

/* Light mode modal */
[data-theme="light"] .auth-modal__backdrop {
  background: hsl(224 12% 10% / 0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

[data-theme="light"] .auth-modal__content {
  background: #fff;
  border: 1px solid hsl(224 8% 85%);
  border-radius: 24px;
  box-shadow: 0 24px 80px hsl(224 12% 10% / 0.18);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  color-scheme: light;
}

[data-theme="light"] .auth-modal__title {
  color: hsl(224 12% 12%);
}

[data-theme="light"] .auth-modal__subtitle {
  color: hsl(224 8% 40%);
}

[data-theme="light"] .auth-modal .form-label {
  color: hsl(224 8% 30%);
}

[data-theme="light"] .auth-modal .form-input,
[data-theme="light"] .auth-modal .form-select,
[data-theme="light"] .auth-modal .form-textarea {
  background: hsl(224 12% 97%);
  border-color: hsl(224 8% 85%);
  color: hsl(224 12% 12%);
}

[data-theme="light"] .auth-modal .form-input:focus,
[data-theme="light"] .auth-modal .form-select:focus,
[data-theme="light"] .auth-modal .form-textarea:focus {
  border-color: hsl(270 85% 60%);
  box-shadow: 0 0 0 3px hsl(270 85% 60% / 0.12);
}

[data-theme="light"] .auth-modal .btn-primary {
  background: hsl(224 12% 12%);
  color: #fff;
  border-color: hsl(224 12% 12%);
}

[data-theme="light"] .auth-modal .btn-primary:hover {
  background: hsl(224 12% 18%);
  border-color: hsl(224 12% 18%);
  box-shadow: none;
  transform: translateY(-1px);
}

[data-theme="light"] .auth-modal .btn-primary:focus-visible {
  outline: 3px solid hsl(270 85% 60% / 0.3);
  outline-offset: 2px;
}

[data-theme="light"] .auth-modal__footer {
  border-top-color: hsl(224 8% 88%);
  color: hsl(224 8% 40%);
}

[data-theme="light"] .auth-modal .text-btn {
  color: hsl(270 85% 55%);
}

[data-theme="light"] .auth-modal__close {
  color: hsl(224 6% 55%);
}

[data-theme="light"] .auth-modal__close:hover {
  background: hsl(224 8% 92%);
  color: hsl(224 12% 12%);
}

/* Dark mode modal */
[data-theme="dark"] .auth-modal__backdrop {
  background: hsl(260 20% 4% / 0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

[data-theme="dark"] .auth-modal__content {
  background: hsl(260 12% 12%);
  border: 1px solid hsl(270 20% 25% / 0.4);
  border-radius: 24px;
  box-shadow: 0 24px 80px hsl(270 30% 4% / 0.7), 0 0 0 1px hsl(270 30% 20% / 0.2);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

[data-theme="dark"] .auth-modal__title {
  color: hsl(260 20% 96%);
}

[data-theme="dark"] .auth-modal__subtitle {
  color: hsl(260 8% 62%);
}

[data-theme="dark"] .auth-modal .form-label {
  color: hsl(260 8% 70%);
}

[data-theme="dark"] .auth-modal .form-input,
[data-theme="dark"] .auth-modal .form-select,
[data-theme="dark"] .auth-modal .form-textarea {
  background: hsl(260 12% 8%);
  border-color: hsl(270 15% 24%);
  color: hsl(260 20% 96%);
}

[data-theme="dark"] .auth-modal .form-input::placeholder,
[data-theme="dark"] .auth-modal .form-textarea::placeholder {
  color: hsl(260 8% 40%);
}

[data-theme="dark"] .auth-modal .form-input:focus,
[data-theme="dark"] .auth-modal .form-select:focus,
[data-theme="dark"] .auth-modal .form-textarea:focus {
  border-color: hsl(270 85% 65%);
  box-shadow: 0 0 0 3px hsl(270 85% 60% / 0.18);
}

[data-theme="dark"] .auth-modal .btn-primary {
  background: hsl(270 85% 62%);
  color: #fff;
  border-color: hsl(270 85% 62%);
  box-shadow: 0 4px 20px hsl(270 85% 55% / 0.25);
}

[data-theme="dark"] .auth-modal .btn-primary:hover {
  background: hsl(270 85% 68%);
  border-color: hsl(270 85% 68%);
  box-shadow: 0 6px 28px hsl(270 85% 60% / 0.4);
  transform: translateY(-1px);
}

[data-theme="dark"] .auth-modal .btn-primary:focus-visible {
  outline: 3px solid hsl(270 85% 60% / 0.4);
  outline-offset: 2px;
}

[data-theme="dark"] .auth-modal__footer {
  border-top-color: hsl(270 15% 22%);
  color: hsl(260 8% 55%);
}

[data-theme="dark"] .auth-modal .text-btn {
  color: hsl(270 85% 75%);
}

[data-theme="dark"] .auth-modal__close {
  color: hsl(260 8% 50%);
}

[data-theme="dark"] .auth-modal__close:hover {
  background: hsl(270 15% 18%);
  color: hsl(260 20% 92%);
}

/* ----------------------------------------------------------
   17b. Dark mode polish — depth, glow, purple energy
   ---------------------------------------------------------- */

/* Nav gets slight blur over circuit bg */
[data-theme="dark"] .lv2-nav {
  background: hsl(260 15% 7% / 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Nav — subtle purple glow on signup */
[data-theme="dark"] .lv2-nav__btn-signup {
  box-shadow: 0 2px 16px hsl(270 85% 60% / 0.3);
}

[data-theme="dark"] .lv2-nav__btn-signup:hover {
  box-shadow: 0 4px 28px hsl(270 85% 60% / 0.45);
}

[data-theme="dark"] .lv2-nav__btn-login {
  background: hsl(270 30% 50% / 0.08);
  border-color: hsl(270 30% 50% / 0.2);
  color: hsl(260 20% 88%);
}

[data-theme="dark"] .lv2-nav__btn-login:hover {
  background: hsl(270 30% 50% / 0.15);
  border-color: hsl(270 30% 50% / 0.3);
}

/* Hero CTA — purple glow */
[data-theme="dark"] .lv2-hero__cta-primary {
  background: hsl(260 20% 96%);
  color: hsl(260 15% 7%);
  box-shadow: 0 4px 24px hsl(270 85% 60% / 0.2);
}

[data-theme="dark"] .lv2-hero__cta-primary:hover {
  box-shadow: 0 8px 36px hsl(270 85% 60% / 0.35);
}

/* Schools heading */
[data-theme="dark"] .lv2-schools-heading {
  color: hsl(270 40% 70%);
  opacity: 0.5;
}

/* School names — slightly more visible in dark */
[data-theme="dark"] .lv2-schools__name {
  opacity: 0.2;
  color: hsl(270 20% 70%);
}

/* Pillars — subtle purple border accent */
[data-theme="dark"] .lv2-pillars {
  border-top-color: hsl(270 30% 20% / 0.5);
}

[data-theme="dark"] .lv2-pillars__divider {
  background: hsl(270 30% 30% / 0.3);
}

/* Compare card — purple-tinted border glow */
[data-theme="dark"] .lv2-compare__inner {
  background: transparent;
  border-color: hsl(270 30% 25% / 0.3);
  box-shadow: none;
}

/* Showcase cards — purple-tinted border + subtle glow */
[data-theme="dark"] .lv2-showcase-card {
  border-color: hsl(270 25% 22% / 0.4);
  box-shadow: 0 8px 48px hsl(270 40% 8% / 0.5);
}

[data-theme="dark"] .lv2-showcase-card--img .lv2-showcase-card__header {
  background: hsl(260 15% 7% / 0.5);
  border-bottom-color: hsl(270 30% 30% / 0.15);
}

[data-theme="dark"] .lv2-showcase-card__screen img {
  box-shadow: 0 8px 40px hsl(270 30% 5% / 0.5);
}

/* Credentials — purple accent on button */
[data-theme="dark"] .lv2-credentials__btn {
  background: hsl(260 20% 96%);
  color: hsl(260 15% 7%);
}

/* Letter — subtle left accent bar in dark */
[data-theme="dark"] .lv2-letter__paper::before {
  display: block;
  background: hsl(270 85% 65% / 0.3);
}

[data-theme="dark"] .lv2-letter__subheading {
  color: hsl(270 60% 78%);
}

/* Theme toggle — purple tint */
[data-theme="dark"] .lv2-theme-toggle {
  border-color: hsl(270 30% 30% / 0.4);
}

[data-theme="dark"] .lv2-theme-toggle:hover {
  background: hsl(270 30% 20% / 0.3);
  border-color: hsl(270 30% 40% / 0.4);
  color: hsl(270 85% 75%);
}

/* ----------------------------------------------------------
   18. Responsive — 768px
   ---------------------------------------------------------- */
@media (max-width: 768px) {
  .lv2-nav__links {
    display: none;
  }

  .lv2-nav__btn-login,
  .lv2-nav__btn-signup {
    display: none;
  }

  .lv2-nav__hamburger {
    display: flex;
  }

  /* Pillars */
  .lv2-pillars__inner { grid-template-columns: 1fr; gap: 32px; }
  .lv2-pillars__divider { display: none; }

  /* School marquee — narrower fade edges on mobile */
  .lv2-schools-marquee {
    -webkit-mask-image: linear-gradient(to right, transparent, black 40px, black calc(100% - 40px), transparent);
    mask-image: linear-gradient(to right, transparent, black 40px, black calc(100% - 40px), transparent);
  }

  /* Showcase CTA goes full-width on mobile */
  .lv2-showcase-card__cta {
    width: 100%;
    justify-content: space-between;
  }

  /* Letter */
  .lv2-letter__paper { padding: 0; }

  /* Footer */
  .lv2-footer__inner { grid-template-columns: 1fr; gap: 40px; }
  .lv2-footer__columns { gap: 40px; }

  /* Stats bar */
  .lv2-stats-bar__inner { gap: 32px; }

  /* Comparison graph */
  .lv2-compare__inner { grid-template-columns: 1fr; padding: 32px; }
  .lv2-compare__bar-group { height: 200px; }

  /* Feature showcase cards */
  .lv2-showcase-card__header { grid-template-columns: 1fr; padding: 32px 28px; }
  .lv2-showcase-card__cta { grid-column: 1; grid-row: auto; margin-top: 16px; }
  .lv2-showcase-card__screen { padding: 32px 24px 0; }
}

/* ----------------------------------------------------------
   19. Responsive — 375px
   ---------------------------------------------------------- */
@media (max-width: 375px) {
  .lv2-hero__h1 {
    font-size: 2.4rem;
  }

  /* Stats bar */
  .lv2-stats-bar__inner { gap: 20px; }
  .lv2-stats-bar__number { font-size: 2.5rem; }
}

/* ----------------------------------------------------------
   20. Reduced motion
   ---------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .lv2-hero__h1,
  .lv2-hero__subtitle,
  .lv2-hero__cta-group,
  .lv2-stats-bar__item,
  .lv2-pillars,
  .lv2-compare__bar {
    animation: none !important;
    transition: none !important;
  }

  .lv2-hero__glow {
    transition: none;
  }

  .lv2-schools-marquee__track {
    animation: none !important;
  }

  .lv2-hero__cta-primary,
  .lv2-hero__cta-secondary,
  .lv2-closing__btn,
  .lv2-credentials__btn {
    transition: none;
  }
}
