/* ═══════════════════════════════════════════════════════════
   EvolvNXT Design System — Dark Sport-Tech (Premium)
   ═══════════════════════════════════════════════════════════ */

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

:root{
  --black: #0A0A0F;
  --black-raised: #101018;
  --black-card: #14141E;
  --black-card-hover: #1A1A26;
  --white: #FFFFFF;
  --primary: #3B82F6;
  --primary-dim: rgba(59,130,246,.08);
  --primary-glow: rgba(59,130,246,.35);
  --accent: #8B5CF6;
  --accent-dim: rgba(139,92,246,.08);
  --accent-glow: rgba(139,92,246,.35);
  --success: #22C55E;
  --success-dim: rgba(34,197,94,.08);
  --warning: #F59E0B;
  --warning-dim: rgba(245,158,11,.08);
  --danger: #EF4444;
  --danger-dim: rgba(239,68,68,.08);
  --gradient: linear-gradient(135deg, var(--primary), var(--accent));
  --gradient-warm: linear-gradient(135deg, #3B82F6, #8B5CF6, #A855F7);
  --gradient-subtle: linear-gradient(135deg, rgba(59,130,246,.06), rgba(139,92,246,.06));
  --border: rgba(255,255,255,.06);
  --border-light: rgba(255,255,255,.1);
  --border-hover: rgba(59,130,246,.3);
  --text-primary: #F4F4F5;
  --text-secondary: #A1A1AA;
  --text-muted: #63637A;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-2xl: 32px;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --transition: .3s cubic-bezier(.4,0,.2,1);
  --transition-fast: .15s cubic-bezier(.4,0,.2,1);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.3);
  --shadow-md: 0 8px 32px rgba(0,0,0,.4);
  --shadow-lg: 0 16px 64px rgba(0,0,0,.5);
  --shadow-glow-primary: 0 0 40px rgba(59,130,246,.15), 0 0 80px rgba(59,130,246,.05);
  --shadow-glow-accent: 0 0 40px rgba(139,92,246,.15), 0 0 80px rgba(139,92,246,.05);
}

html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{
  font-family:var(--font);background:var(--black);
  color:var(--text-primary);line-height:1.6;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 32px}

/* ── Gradient Text ──────────────────────────────────────── */
.gradient-text{
  background:var(--gradient-warm);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── Noise texture overlay ──────────────────────────────── */
body::before{
  content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.015;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}

/* ── Buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font);font-weight:600;
  border:none;border-radius:var(--radius);
  cursor:pointer;transition:all var(--transition);
  text-align:center;justify-content:center;white-space:nowrap;
  position:relative;overflow:hidden;
  letter-spacing:-.01em;
}
.btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 50%);
  opacity:0;transition:opacity var(--transition);
  pointer-events:none;
}
.btn:hover::before{opacity:1}
.btn--sm{padding:10px 22px;font-size:.85rem;border-radius:10px}
.btn--md{padding:12px 28px;font-size:.9rem}
.btn--lg{padding:16px 36px;font-size:1rem;border-radius:14px}
.btn--xl{padding:20px 44px;font-size:1.1rem;border-radius:16px}
.btn--full{width:100%}
.btn--primary{
  background:var(--gradient);color:#fff;
  box-shadow:0 2px 20px var(--primary-glow), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn--primary:hover{
  box-shadow:0 8px 40px var(--primary-glow), inset 0 1px 0 rgba(255,255,255,.2);
  transform:translateY(-2px);
}
.btn--primary:active{transform:translateY(0);box-shadow:0 2px 12px var(--primary-glow)}
.btn--glow{position:relative}
.btn--glow::after{
  content:'';position:absolute;inset:-3px;
  background:var(--gradient);border-radius:inherit;
  z-index:-1;opacity:0;filter:blur(24px);transition:opacity var(--transition);
}
.btn--glow:hover::after{opacity:.6}
.btn--ghost{
  background:rgba(255,255,255,.03);color:var(--text-secondary);
  border:1px solid var(--border-light);
  backdrop-filter:blur(8px);
}
.btn--ghost:hover{
  border-color:var(--border-hover);color:var(--text-primary);
  background:rgba(59,130,246,.05);
}
.btn--accent{
  background:linear-gradient(135deg, var(--accent), #7C3AED);color:#fff;
  box-shadow:0 2px 20px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn--accent:hover{
  box-shadow:0 8px 40px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.2);
  transform:translateY(-2px);
}
.btn--success{background:var(--success);color:#fff}
.btn__arrow{width:18px;height:18px;transition:transform .25s cubic-bezier(.4,0,.2,1)}
.btn:hover .btn__arrow{transform:translateX(4px)}

/* ── Navigation (shared) ────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:all .5s cubic-bezier(.22,1,.36,1);
}
.nav::before{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,15,.5);
  backdrop-filter:blur(32px) saturate(180%);
  border-bottom:1px solid transparent;
  transition:all .5s cubic-bezier(.22,1,.36,1);
  z-index:-1;
}
.nav--scrolled::before{
  border-bottom-color:var(--border);
  background:rgba(10,10,15,.92);
}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;position:relative;
}
.nav__logo{
  font-size:1.5rem;font-weight:900;letter-spacing:-.03em;
  transition:all var(--transition);position:relative;z-index:2;
}
.nav__logo:hover{opacity:.85;transform:scale(.97)}
.nav__logo span{
  background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.nav__logo-img{
  height:36px;width:auto;display:block;object-fit:contain;
  mix-blend-mode:screen;
}

/* ── Floating pill nav (desktop) ────────────────── */
.nav__links{
  display:flex;gap:2px;
  position:absolute;left:50%;transform:translateX(-50%);
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:100px;padding:4px;
  backdrop-filter:blur(12px);
}
.nav__links a{
  font-size:.8rem;color:var(--text-muted);transition:all .25s cubic-bezier(.22,1,.36,1);
  font-weight:500;padding:7px 16px;border-radius:100px;
  position:relative;letter-spacing:-.01em;
  white-space:nowrap;
}
.nav__links a:hover{color:var(--text-primary)}
.nav__links a.active{
  color:#fff;
  background:rgba(255,255,255,.08);
  box-shadow:0 1px 8px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.06);
}

/* ── Right side actions ─────────────────────────── */
.nav__actions{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.nav__login{
  font-size:.85rem;font-weight:500;color:var(--text-secondary);
  padding:8px 16px;border-radius:10px;
  transition:all var(--transition);
}
.nav__login:hover{color:var(--text-primary);background:rgba(255,255,255,.04)}
.nav__avatar{
  width:34px;height:34px;border-radius:50%;
  background:var(--gradient);display:flex;align-items:center;justify-content:center;
  font-size:.65rem;font-weight:700;color:#fff;cursor:pointer;
  transition:all .25s cubic-bezier(.22,1,.36,1);
  box-shadow:0 0 0 2px var(--black), 0 0 0 3px rgba(59,130,246,.2);
}
.nav__avatar:hover{transform:scale(1.1);box-shadow:0 0 0 2px var(--black), 0 0 0 3px rgba(59,130,246,.5)}

/* ── Hamburger (3‑line → X) ─────────────────────── */
.nav__mobile-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:40px;height:40px;border-radius:10px;
  position:relative;z-index:210;
  transition:background .25s;
}
.nav__mobile-toggle:hover{background:rgba(255,255,255,.04)}
.nav__mobile-toggle span{
  display:block;width:20px;height:1.5px;background:var(--text-primary);
  margin:4px auto;transition:all .35s cubic-bezier(.22,1,.36,1);border-radius:2px;
}
.nav__mobile-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.nav__mobile-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__mobile-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

/* ── Fullscreen mobile overlay ──────────────────── */
@media(max-width:768px){
  .nav__links{
    display:flex;flex-direction:column;gap:0;
    position:fixed;inset:0;
    transform:none;left:0;
    background:rgba(6,6,10,.98);
    backdrop-filter:blur(40px) saturate(200%);
    border:none;border-radius:0;padding:0;
    z-index:200;
    justify-content:center;align-items:center;
    opacity:0;pointer-events:none;
    transition:opacity .4s cubic-bezier(.22,1,.36,1);
  }
  .nav__links.open{opacity:1;pointer-events:auto}
  .nav__links a{
    font-size:2rem;font-weight:700;letter-spacing:-.02em;
    padding:14px 24px;border-radius:16px;
    color:var(--text-muted);
    transform:translateY(20px);opacity:0;
    transition:all .4s cubic-bezier(.22,1,.36,1);
  }
  .nav__links.open a{transform:translateY(0);opacity:1}
  .nav__links.open li:nth-child(1) a{transition-delay:.05s}
  .nav__links.open li:nth-child(2) a{transition-delay:.1s}
  .nav__links.open li:nth-child(3) a{transition-delay:.15s}
  .nav__links.open li:nth-child(4) a{transition-delay:.2s}
  .nav__links.open li:nth-child(5) a{transition-delay:.25s}
  .nav__links.open li:nth-child(6) a{transition-delay:.3s}
  .nav__links a:hover, .nav__links a.active{
    color:#fff;background:rgba(255,255,255,.04);
  }
  .nav__links a.active{
    background:linear-gradient(135deg, rgba(59,130,246,.1), rgba(139,92,246,.1));
    box-shadow:none;
  }
  /* Gradient line above links */
  .nav__links::before{
    content:'';position:absolute;top:72px;left:32px;right:32px;
    height:1px;
    background:linear-gradient(90deg, transparent, rgba(59,130,246,.3), rgba(139,92,246,.3), transparent);
  }
  /* "EvolvNXT" watermark */
  .nav__links::after{
    content:'EvolvNXT';position:absolute;bottom:48px;
    font-size:.7rem;font-weight:600;letter-spacing:.15em;
    text-transform:uppercase;color:rgba(255,255,255,.06);
  }
  .nav__mobile-toggle{display:flex;align-items:center;justify-content:center}
  .nav__actions .btn{display:none}
}

/* ── Page Shell ─────────────────────────────────────────── */
.page{padding-top:100px;min-height:100vh}
.page__header{margin-bottom:48px}
.page__title{font-size:2rem;font-weight:800;letter-spacing:-.03em;line-height:1.2}
.page__sub{font-size:1rem;color:var(--text-secondary);margin-top:8px;line-height:1.7}

/* ── Cards ──────────────────────────────────────────────── */
.card{
  background:var(--black-card);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:28px;
  transition:all var(--transition);
  position:relative;
}
.card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 40%);
  pointer-events:none;
}
.card:hover{
  border-color:var(--border-light);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.card--glow:hover{
  border-color:rgba(59,130,246,.25);
  box-shadow:var(--shadow-glow-primary);
}
.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.card__title{font-size:1rem;font-weight:700;letter-spacing:-.01em}
.card__label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}

/* ── Stat Bars ──────────────────────────────────────────── */
.stat-bar-group{display:flex;flex-direction:column;gap:16px}
.stat-bar-item{display:grid;grid-template-columns:110px 1fr 40px;gap:12px;align-items:center;font-size:.85rem}
.stat-bar-item span:first-child{color:var(--text-muted);font-weight:500}
.stat-bar-item span:last-child{color:var(--text-secondary);font-weight:700;text-align:right;font-variant-numeric:tabular-nums}
.stat-bar{height:6px;background:rgba(255,255,255,.04);border-radius:99px;overflow:hidden;position:relative}
.stat-bar::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06));
  border-radius:inherit;
}
.stat-bar__fill{height:100%;border-radius:99px;background:var(--gradient);width:var(--w);transition:width 1.2s cubic-bezier(.4,0,.2,1);position:relative}
.stat-bar__fill::after{
  content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);
  width:3px;height:3px;border-radius:50%;background:#fff;
  box-shadow:0 0 8px rgba(255,255,255,.5);
}
.stat-bar__fill--success{background:var(--success)}
.stat-bar__fill--warning{background:var(--warning)}
.stat-bar__fill--danger{background:var(--danger)}

/* ── Badges / Tags ──────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 14px;border-radius:999px;font-size:.7rem;font-weight:600;
  letter-spacing:.02em;backdrop-filter:blur(8px);
}
.badge--primary{background:var(--primary-dim);color:var(--primary);border:1px solid rgba(59,130,246,.15)}
.badge--accent{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(139,92,246,.15)}
.badge--success{background:var(--success-dim);color:var(--success);border:1px solid rgba(34,197,94,.15)}
.badge--warning{background:var(--warning-dim);color:var(--warning);border:1px solid rgba(245,158,11,.15)}
.badge--danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(239,68,68,.15)}

/* ── Section Defaults ───────────────────────────────────── */
.section{padding:120px 0}
.section__header{text-align:center;margin-bottom:72px}
.section__tag{
  display:inline-block;padding:5px 16px;border-radius:999px;
  background:var(--primary-dim);color:var(--primary);
  font-size:.7rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:20px;
  border:1px solid rgba(59,130,246,.12);
}
.section__title{
  font-size:clamp(2rem,4vw,3.25rem);font-weight:900;
  line-height:1.1;letter-spacing:-.03em;
}
.section__sub{
  margin-top:20px;font-size:1.1rem;color:var(--text-secondary);
  max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7;
}

/* ── Animations ─────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* Stagger children */
.fade-up:nth-child(2){transition-delay:.08s}
.fade-up:nth-child(3){transition-delay:.16s}
.fade-up:nth-child(4){transition-delay:.24s}

/* ── Icons (inline SVG helper) ──────────────────────────── */
.icon-check{width:18px;height:18px;color:var(--success);flex-shrink:0}
.icon-x{width:18px;height:18px;color:var(--danger);flex-shrink:0}

/* ── Form Elements ──────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:8px}
.form-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.form-input,.form-select,.form-textarea{
  background:var(--black-raised);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 18px;
  color:var(--text-primary);font-family:var(--font);font-size:.9rem;
  transition:all var(--transition);outline:none;width:100%;
}
.form-input:hover,.form-select:hover{border-color:var(--border-light)}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-dim), 0 0 20px rgba(59,130,246,.08);
}
.form-input::placeholder{color:var(--text-muted)}
.form-select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2363637A' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 6.146a.5.5 0 01.708 0L8 8.793l2.646-2.647a.5.5 0 01.708.708l-3 3a.5.5 0 01-.708 0l-3-3a.5.5 0 010-.708z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;
}
.form-select option{background:var(--black-card);color:var(--text-primary)}
.form-textarea{resize:vertical;min-height:80px}

/* ═══════════════════════════════════════════════════════════
   LANDING PAGE
   ═══════════════════════════════════════════════════════════ */

/* ── Hero ───────────────────────────────────────────────── */
.hero{
  min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;padding:120px 0 80px;
  position:relative;overflow:hidden;
}
.hero__bg-glow{
  position:absolute;top:-300px;left:50%;transform:translateX(-50%);
  width:1000px;height:1000px;
  background:radial-gradient(circle,rgba(59,130,246,.1) 0%,rgba(139,92,246,.05) 40%,transparent 70%);
  pointer-events:none;animation:pulse-glow 8s ease-in-out infinite;
}
@keyframes pulse-glow{0%,100%{opacity:.7;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.1)}}

.hero__inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative}
.hero__badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 18px;border-radius:999px;
  background:var(--primary-dim);border:1px solid rgba(59,130,246,.15);
  color:var(--primary);font-size:.78rem;font-weight:600;margin-bottom:28px;letter-spacing:.02em;
}
.hero__title{
  font-size:clamp(2.75rem,5.5vw,4.5rem);font-weight:900;
  line-height:1.05;letter-spacing:-.04em;margin-bottom:24px;
}
.hero__sub{
  font-size:1.15rem;color:var(--text-secondary);max-width:480px;
  margin-bottom:40px;line-height:1.75;
}
.hero__ctas{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:28px}
.hero__trust{font-size:.85rem;color:var(--text-muted)}
.hero__trust strong{color:var(--text-secondary)}

/* Hero AI Card */
.hero__card{
  background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);overflow:hidden;
  box-shadow:var(--shadow-lg), var(--shadow-glow-primary);
  transition:all .5s cubic-bezier(.16,1,.3,1);
}
.hero__card:hover{
  transform:translateY(-4px) rotate(.5deg);
  box-shadow:0 24px 80px rgba(0,0,0,.6), 0 0 60px rgba(59,130,246,.12);
}
.hero__card-header{
  display:flex;align-items:center;gap:10px;
  padding:14px 20px;border-bottom:1px solid var(--border);
  background:rgba(255,255,255,.02);
}
.hero__card-dot{width:7px;height:7px;border-radius:50%}
.hero__card-dot.green{background:var(--success);box-shadow:0 0 10px rgba(34,197,94,.6)}
.hero__card-label{font-size:.7rem;color:var(--text-muted);font-weight:500;letter-spacing:.04em}
.hero__card-body{padding:28px 24px}
.hero__stat-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.hero__stat-label{font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.06em}
.hero__stat-value{font-size:2.75rem;font-weight:900;font-variant-numeric:tabular-nums}

.hero__scroll-hint{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:var(--text-muted);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;
  animation:float-hint 2.5s ease-in-out infinite;
}
@keyframes float-hint{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
.scroll-dot{animation:scroll-bounce 1.5s ease-in-out infinite}
@keyframes scroll-bounce{0%{cy:8}50%{cy:16}100%{cy:8}}

@media(max-width:900px){
  .hero__inner{grid-template-columns:1fr;text-align:center;gap:48px}
  .hero__sub{margin-left:auto;margin-right:auto}
  .hero__ctas{justify-content:center}
  .hero__visual{max-width:420px;margin:0 auto}
  .hero__scroll-hint{display:none}
}

/* ── Visual Break ───────────────────────────────────────── */
.visual-break{
  padding:72px 0;text-align:center;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--black-raised);
  position:relative;overflow:hidden;
}
.visual-break::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(59,130,246,.04) 0%,transparent 70%);
}
.visual-break__caption{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:700;color:var(--text-secondary);position:relative}

/* ── Problem ────────────────────────────────────────────── */
.problem__body{max-width:700px;margin:0 auto;text-align:center}
.problem__lead{font-size:1.1rem;color:var(--text-secondary);margin-bottom:36px;line-height:1.8}
.problem__list{display:flex;flex-direction:column;gap:16px;margin-bottom:36px;text-align:left;max-width:460px;margin-left:auto;margin-right:auto}
.problem__list li{
  display:flex;align-items:center;gap:14px;font-size:1rem;
  color:var(--text-secondary);font-weight:500;
  padding:10px 16px;border-radius:var(--radius);
  background:rgba(239,68,68,.03);border:1px solid rgba(239,68,68,.06);
  transition:all var(--transition);
}
.problem__list li:hover{background:rgba(239,68,68,.06);transform:translateX(4px)}
.problem__closer{font-size:1.15rem;color:var(--text-primary);font-weight:600}

/* ── Features ───────────────────────────────────────────── */
.features{background:var(--black-raised);position:relative}
.features::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:800px;height:1px;
  background:linear-gradient(90deg,transparent,var(--primary),var(--accent),transparent);
  opacity:.3;
}
.features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.feature-card{
  padding:36px 32px;background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);transition:all .4s cubic-bezier(.16,1,.3,1);
  position:relative;overflow:hidden;
}
.feature-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 50%);
  pointer-events:none;
}
.feature-card::after{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(circle at center,rgba(59,130,246,.08) 0%,transparent 50%);
  opacity:0;transition:opacity .5s;pointer-events:none;
}
.feature-card:hover::after{opacity:1}
.feature-card:hover{
  border-color:rgba(59,130,246,.2);
  background:var(--black-card-hover);
  transform:translateY(-6px);
  box-shadow:0 16px 48px rgba(0,0,0,.3), 0 0 40px rgba(59,130,246,.06);
}
.feature-card__icon{
  width:52px;height:52px;display:flex;align-items:center;justify-content:center;
  border-radius:14px;background:var(--primary-dim);margin-bottom:24px;
  border:1px solid rgba(59,130,246,.1);
  transition:all var(--transition);
}
.feature-card:hover .feature-card__icon{
  background:rgba(59,130,246,.12);
  box-shadow:0 0 24px rgba(59,130,246,.15);
}
.feature-card__icon svg{width:24px;height:24px;color:var(--primary)}
.feature-card h3{font-size:1.15rem;font-weight:700;margin-bottom:12px;letter-spacing:-.01em}
.feature-card p{font-size:.9rem;color:var(--text-secondary);line-height:1.75}
.feature-card__list{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.feature-card__list li{font-size:.85rem;color:var(--text-muted);padding-left:18px;position:relative}
.feature-card__list li::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--primary)}

/* ── Differentiation ────────────────────────────────────── */
.diff__inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.diff__content .section__tag{margin-bottom:16px}
.diff__content .section__title{text-align:left;margin-bottom:24px}
.diff__content p{color:var(--text-secondary);font-size:1rem;margin-bottom:24px;line-height:1.8}
.diff__list{display:flex;flex-direction:column;gap:14px;margin-bottom:28px}
.diff__list li{display:flex;align-items:center;gap:12px;font-size:1rem;font-weight:500}
.diff__closer{font-size:1.05rem;color:var(--text-primary);font-weight:600}
.diff__compare{display:flex;flex-direction:column;gap:20px}
.diff__card{
  padding:28px;border-radius:var(--radius-xl);border:1px solid var(--border);
  transition:all var(--transition);
}
.diff__card:hover{transform:translateY(-2px)}
.diff__card h4{font-size:.85rem;font-weight:700;margin-bottom:14px;text-transform:uppercase;letter-spacing:.05em}
.diff__card ul{display:flex;flex-direction:column;gap:10px}
.diff__card ul li{font-size:.875rem;color:var(--text-secondary);padding-left:18px;position:relative}
.diff__card ul li::before{content:'';position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%}
.diff__card--old{background:rgba(239,68,68,.04);border-color:rgba(239,68,68,.1)}
.diff__card--old h4{color:var(--danger)}
.diff__card--old ul li::before{background:var(--danger)}
.diff__card--new{background:rgba(59,130,246,.04);border-color:rgba(59,130,246,.15)}
.diff__card--new h4{color:var(--primary)}
.diff__card--new ul li::before{background:var(--primary)}
@media(max-width:900px){
  .diff__inner{grid-template-columns:1fr}
  .diff__content .section__title{text-align:center}
  .diff__content{text-align:center}
  .diff__list{align-items:center}
}

/* ── Testimonials ───────────────────────────────────────── */
.testimonials{background:var(--black-raised);position:relative}
.testimonials__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.testimonial-card{
  padding:32px;background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);transition:all .4s cubic-bezier(.16,1,.3,1);
  position:relative;
}
.testimonial-card::before{
  content:'';position:absolute;top:24px;left:28px;
  font-size:4rem;line-height:1;color:rgba(59,130,246,.06);
  font-family:Georgia,serif;pointer-events:none;
}
.testimonial-card:hover{
  border-color:var(--border-light);
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.testimonial-card__stars{color:#FBBF24;font-size:.9rem;margin-bottom:18px;letter-spacing:3px}
.testimonial-card blockquote{
  font-size:1rem;color:var(--text-secondary);line-height:1.75;
  margin-bottom:24px;font-style:italic;position:relative;
}
.testimonial-card__author{display:flex;align-items:center;gap:14px}
.testimonial-card__avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--gradient);display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:700;color:#fff;
  box-shadow:0 0 0 2px var(--black-card), 0 0 0 3px rgba(59,130,246,.2);
}
.testimonial-card__author strong{display:block;font-size:.85rem;letter-spacing:-.01em}
.testimonial-card__author span{font-size:.75rem;color:var(--text-muted)}

/* ── How It Works ───────────────────────────────────────── */
.steps{display:flex;align-items:flex-start;justify-content:center;gap:0;flex-wrap:wrap}
.step{flex:0 1 280px;text-align:center;padding:24px}
.step__number{
  width:44px;height:44px;border-radius:50%;background:var(--gradient);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1rem;margin-bottom:20px;
  box-shadow:0 4px 16px rgba(59,130,246,.25);
}
.step__icon{
  width:68px;height:68px;margin:0 auto 20px;
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-lg);background:var(--primary-dim);
  border:1px solid rgba(59,130,246,.1);
  transition:all var(--transition);
}
.step:hover .step__icon{
  background:rgba(59,130,246,.1);
  box-shadow:0 0 24px rgba(59,130,246,.12);
  transform:translateY(-2px);
}
.step__icon svg{width:28px;height:28px;color:var(--primary)}
.step h3{font-size:1.1rem;font-weight:700;margin-bottom:10px;letter-spacing:-.01em}
.step p{font-size:.9rem;color:var(--text-secondary);line-height:1.7}
.step__connector{display:flex;align-items:center;padding-top:60px;color:var(--border-light)}
.step__connector svg{width:60px;height:20px}
.steps__cta{text-align:center;margin-top:56px}
@media(max-width:768px){.step__connector{display:none}}

/* ── Urgency ────────────────────────────────────────────── */
.urgency{background:linear-gradient(180deg,var(--black) 0%,rgba(59,130,246,.03) 100%)}
.urgency__inner{text-align:center;max-width:600px;margin:0 auto}
.urgency__inner p{font-size:1.1rem;color:var(--text-secondary);margin-top:20px;line-height:1.8}

/* ── Pricing ────────────────────────────────────────────── */
.pricing__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;max-width:720px;margin:0 auto}
.pricing__grid.pricing__grid--3{max-width:1100px;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:960px){.pricing__grid.pricing__grid--3{grid-template-columns:1fr;max-width:420px}}

.pricing-card{
  padding:40px 36px;background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-2xl);position:relative;
  transition:all .4s cubic-bezier(.16,1,.3,1);
  overflow:hidden;
}
.pricing-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 40%);
  pointer-events:none;
}
.pricing-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
}
.pricing-card--pro{
  border-color:rgba(59,130,246,.25);
  box-shadow:var(--shadow-glow-primary);
  background:linear-gradient(180deg,rgba(59,130,246,.04) 0%,var(--black-card) 40%);
}
.pricing-card--pro:hover{
  box-shadow:0 0 60px rgba(59,130,246,.2), 0 0 120px rgba(59,130,246,.06);
}
.pricing-card--elite{
  border-color:rgba(139,92,246,.25);
  box-shadow:var(--shadow-glow-accent);
  background:linear-gradient(180deg,rgba(139,92,246,.04) 0%,var(--black-card) 40%);
}
.pricing-card--elite:hover{
  box-shadow:0 0 60px rgba(139,92,246,.2), 0 0 120px rgba(139,92,246,.06);
}
.pricing-card__badge{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  padding:6px 20px;border-radius:0 0 12px 12px;background:var(--gradient);color:#fff;
  font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  box-shadow:0 4px 16px rgba(59,130,246,.25);
}
.pricing-card__header{margin-bottom:32px}
.pricing-card__header h3{font-size:1.15rem;font-weight:700;margin-bottom:10px;letter-spacing:-.01em}
.pricing-card__price{display:flex;align-items:baseline;gap:4px}
.pricing-card__amount{font-size:2.75rem;font-weight:900;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.pricing-card__price span:last-child{font-size:.875rem;color:var(--text-muted)}
.pricing-card__features{display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.pricing-card__features li{
  display:flex;align-items:center;gap:12px;
  font-size:.9rem;color:var(--text-secondary);line-height:1.5;
}
.pricing-card__features .icon-check{width:18px;height:18px}

/* ── Final CTA ──────────────────────────────────────────── */
.cta-final{
  padding:140px 0;
  background:radial-gradient(ellipse at center,rgba(59,130,246,.06) 0%,transparent 70%);
  position:relative;
}
.cta-final::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:600px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(59,130,246,.3),transparent);
}
.cta-final__inner{text-align:center}
.cta-final__title{font-size:clamp(2.5rem,5vw,4rem);font-weight:900;line-height:1.08;letter-spacing:-.04em;margin-bottom:20px}
.cta-final__sub{font-size:1.15rem;color:var(--text-secondary);margin-bottom:44px;line-height:1.7}

/* ── Footer ─────────────────────────────────────────────── */
.footer{
  border-top:1px solid var(--border);padding:72px 0 40px;
  background:var(--black-raised);
}
.footer__inner{display:grid;grid-template-columns:1fr;gap:48px}
.footer__links{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer__brand p{font-size:.875rem;color:var(--text-muted);margin-top:14px;line-height:1.7}
.footer__links h4{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}
.footer__links ul{display:flex;flex-direction:column;gap:10px}
.footer__links a{
  font-size:.875rem;color:var(--text-secondary);transition:all var(--transition);
  display:inline-block;
}
.footer__links a:hover{color:var(--text-primary);transform:translateX(2px)}
.footer__bottom{
  grid-column:1/-1;padding-top:32px;margin-top:8px;
  border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted);
}
@media(max-width:768px){.footer__inner{grid-template-columns:1fr;gap:32px}.footer__links{grid-template-columns:repeat(3,1fr);gap:24px}}


/* ═══════════════════════════════════════════════════════════
   DASHBOARD
   ═══════════════════════════════════════════════════════════ */

.dash{display:grid;grid-template-columns:1fr;gap:28px;padding-bottom:80px}

/* Evolv Score Hero */
.evolv-hero{
  text-align:center;padding:56px 40px;
  background:radial-gradient(ellipse at center,rgba(59,130,246,.05) 0%,var(--black-card) 70%);
  border:1px solid var(--border);border-radius:var(--radius-2xl);
  position:relative;overflow:hidden;
}
.evolv-hero__glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);
  opacity:.25;pointer-events:none;animation:pulse-glow 8s ease-in-out infinite;
}
.evolv-hero__score{
  font-size:clamp(5rem,10vw,8rem);font-weight:900;
  line-height:1;position:relative;z-index:1;
  font-variant-numeric:tabular-nums;
}
.evolv-hero__label{
  font-size:.8rem;color:var(--text-muted);text-transform:uppercase;
  letter-spacing:.12em;font-weight:600;margin-bottom:8px;position:relative;z-index:1;
}
.evolv-hero__projection{margin-top:20px;position:relative;z-index:1}

/* Dashboard grid */
.dash__row{display:grid;gap:28px}
.dash__row--2{grid-template-columns:1fr 1fr}
.dash__row--3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:900px){.dash__row--2,.dash__row--3{grid-template-columns:1fr}}

/* Radar chart placeholder */
.radar-chart{
  width:100%;max-width:300px;aspect-ratio:1;margin:0 auto;
  position:relative;
}
.radar-chart__bg{
  position:absolute;inset:0;
  border-radius:50%;
  background:conic-gradient(from 0deg,rgba(59,130,246,.02),rgba(139,92,246,.02),rgba(59,130,246,.02));
  border:1px solid var(--border);
}
.radar-chart canvas{position:relative;z-index:1;width:100%!important;height:100%!important}

/* Insight cards */
.insight{
  display:flex;gap:14px;padding:18px;
  background:var(--black-raised);border-radius:var(--radius);
  border:1px solid var(--border);
  transition:all var(--transition);
}
.insight:hover{border-color:var(--border-light);transform:translateX(4px)}
.insight__icon{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.insight__icon--up{background:var(--success-dim);border:1px solid rgba(34,197,94,.1)}
.insight__icon--up svg{color:var(--success)}
.insight__icon--warn{background:var(--warning-dim);border:1px solid rgba(245,158,11,.1)}
.insight__icon--warn svg{color:var(--warning)}
.insight__body h4{font-size:.875rem;font-weight:600;margin-bottom:4px;letter-spacing:-.01em}
.insight__body p{font-size:.8rem;color:var(--text-muted);line-height:1.6}

/* College suggestion cards */
.college-card{
  display:flex;align-items:center;gap:16px;
  padding:18px;background:var(--black-raised);
  border-radius:var(--radius-lg);border:1px solid var(--border);
  transition:all .4s cubic-bezier(.16,1,.3,1);cursor:pointer;
}
.college-card:hover{
  border-color:rgba(59,130,246,.2);
  background:var(--black-card-hover);
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(0,0,0,.3);
}
.college-card__logo{
  width:48px;height:48px;border-radius:14px;
  background:var(--primary-dim);display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:800;color:var(--primary);flex-shrink:0;
  border:1px solid rgba(59,130,246,.1);
}
.college-card__info{flex:1;min-width:0}
.college-card__info h4{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}
.college-card__info p{font-size:.75rem;color:var(--text-muted);margin-top:2px}
.college-card__fit{font-size:1.15rem;font-weight:800;color:var(--success);font-variant-numeric:tabular-nums}


/* ═══════════════════════════════════════════════════════════
   UPLOAD PAGE
   ═══════════════════════════════════════════════════════════ */

.upload-page{max-width:640px;margin:0 auto;padding-bottom:80px}

.upload-zone{
  border:2px dashed var(--border-light);border-radius:var(--radius-2xl);
  padding:72px 48px;text-align:center;cursor:pointer;
  transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;
  background:var(--black-card);
}
.upload-zone:hover,.upload-zone--active{
  border-color:var(--primary);
  background:rgba(59,130,246,.02);
  box-shadow:0 0 40px rgba(59,130,246,.06);
}
.upload-zone__icon{
  width:72px;height:72px;margin:0 auto 24px;
  border-radius:50%;background:var(--primary-dim);
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(59,130,246,.1);
  transition:all var(--transition);
}
.upload-zone:hover .upload-zone__icon{
  background:rgba(59,130,246,.12);
  box-shadow:0 0 32px rgba(59,130,246,.15);
  transform:translateY(-2px);
}
.upload-zone__icon svg{width:30px;height:30px;color:var(--primary)}
.upload-zone h3{font-size:1.15rem;font-weight:700;margin-bottom:8px;letter-spacing:-.01em}
.upload-zone p{font-size:.85rem;color:var(--text-muted)}
.upload-zone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer}

.upload-form{display:flex;flex-direction:column;gap:24px;margin-top:40px}
.upload-form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.upload-form__row{grid-template-columns:1fr}}

/* Analyzing overlay */
.analyzing{
  text-align:center;padding:100px 48px;
}
.analyzing__spinner{
  width:64px;height:64px;margin:0 auto 28px;
  border:3px solid var(--border);border-top-color:var(--primary);
  border-radius:50%;animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.analyzing h2{font-size:1.5rem;font-weight:800;margin-bottom:10px;letter-spacing:-.02em}
.analyzing p{color:var(--text-muted);font-size:.9rem}
.analyzing__progress{
  max-width:320px;margin:28px auto 0;height:4px;
  background:rgba(255,255,255,.04);border-radius:99px;overflow:hidden;
}
.analyzing__progress-bar{
  height:100%;background:var(--gradient);border-radius:99px;
  width:0%;transition:width .5s;
  box-shadow:0 0 12px rgba(59,130,246,.4);
}

.hidden{display:none!important}


/* ═══════════════════════════════════════════════════════════
   RESULTS PAGE
   ═══════════════════════════════════════════════════════════ */

.results{padding-bottom:80px}
.results__hero{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;margin-bottom:36px}
@media(max-width:900px){.results__hero{grid-template-columns:1fr}}

/* Video player area */
.video-player{
  background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);overflow:hidden;
  aspect-ratio:16/9;position:relative;
}
.video-player__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(10,10,15,.92));
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:28px;
}
.video-player__overlay-stats{display:flex;gap:10px;flex-wrap:wrap}
.video-player__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:68px;height:68px;border-radius:50%;
  background:rgba(59,130,246,.9);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 24px var(--primary-glow), 0 0 60px rgba(59,130,246,.15);
  transition:all .4s cubic-bezier(.16,1,.3,1);
  backdrop-filter:blur(8px);
}
.video-player__play:hover{
  transform:translate(-50%,-50%) scale(1.12);
  box-shadow:0 8px 40px var(--primary-glow), 0 0 80px rgba(59,130,246,.2);
}
.video-player__play svg{width:24px;height:24px;color:#fff;margin-left:3px}

/* Score sidebar */
.results__score-card{display:flex;flex-direction:column;gap:24px}
.results__big-score{
  text-align:center;padding:40px;
  background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);position:relative;overflow:hidden;
}
.results__big-score::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);
  opacity:.15;pointer-events:none;
}
.results__big-score-number{font-size:4.5rem;font-weight:900;line-height:1;position:relative;font-variant-numeric:tabular-nums}
.results__big-score-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:8px;position:relative}

/* Strengths / Weaknesses */
.sw-list{display:flex;flex-direction:column;gap:12px}
.sw-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 16px;border-radius:var(--radius);
  font-size:.85rem;font-weight:500;
  transition:all var(--transition);
}
.sw-item:hover{transform:translateX(4px)}
.sw-item--strength{background:var(--success-dim);color:var(--success);border:1px solid rgba(34,197,94,.08)}
.sw-item--weakness{background:var(--warning-dim);color:var(--warning);border:1px solid rgba(245,158,11,.08)}

/* Unlock CTA */
.unlock-cta{
  text-align:center;padding:56px 48px;
  background:var(--gradient-subtle);
  border:1px solid var(--border);border-radius:var(--radius-2xl);
  margin-top:40px;position:relative;overflow:hidden;
}
.unlock-cta::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.06) 0%,transparent 70%);
  pointer-events:none;
}
.unlock-cta h3{font-size:1.35rem;font-weight:800;margin-bottom:12px;letter-spacing:-.02em;position:relative}
.unlock-cta p{color:var(--text-secondary);font-size:.95rem;margin-bottom:28px;position:relative;line-height:1.7}


/* ═══════════════════════════════════════════════════════════
   COLLEGE MATCH PAGE
   ═══════════════════════════════════════════════════════════ */

.matches{padding-bottom:80px}
.matches__filters{
  display:flex;gap:10px;margin-bottom:36px;flex-wrap:wrap;
}
.filter-btn{
  padding:9px 20px;border-radius:999px;font-size:.8rem;font-weight:600;
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  color:var(--text-muted);cursor:pointer;transition:all var(--transition);
  letter-spacing:.01em;
}
.filter-btn:hover{
  background:rgba(59,130,246,.05);
  border-color:var(--border-light);
  color:var(--text-secondary);
}
.filter-btn--active{
  background:var(--primary-dim);
  border-color:rgba(59,130,246,.25);
  color:var(--primary);
  box-shadow:0 0 16px rgba(59,130,246,.1);
}

.match-card{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;
  align-items:center;padding:28px;
  background:var(--black-card);border:1px solid var(--border);
  border-radius:var(--radius-xl);margin-bottom:16px;
  transition:all .4s cubic-bezier(.16,1,.3,1);
  position:relative;overflow:hidden;
}
.match-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(59,130,246,.02) 0%,transparent 50%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.match-card:hover::before{opacity:1}
.match-card:hover{
  border-color:rgba(59,130,246,.2);
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(0,0,0,.3), 0 0 30px rgba(59,130,246,.05);
}

.match-card__school{display:flex;align-items:center;gap:18px}
.match-card__logo{
  width:56px;height:56px;border-radius:16px;
  background:var(--primary-dim);display:flex;align-items:center;justify-content:center;
  font-size:.95rem;font-weight:900;color:var(--primary);
  border:1px solid rgba(59,130,246,.1);
  transition:all var(--transition);
}
.match-card:hover .match-card__logo{
  box-shadow:0 0 20px rgba(59,130,246,.15);
}
.match-card__name{font-size:1.1rem;font-weight:700;letter-spacing:-.01em}
.match-card__meta{font-size:.8rem;color:var(--text-muted);margin-top:4px}

.match-card__reasons{display:flex;flex-direction:column;gap:8px}
.match-card__reason{
  display:flex;align-items:center;gap:10px;
  font-size:.85rem;color:var(--text-secondary);line-height:1.5;
}
.match-card__reason svg{width:16px;height:16px;color:var(--success);flex-shrink:0}

.match-card__score{text-align:center;min-width:90px}
.match-card__score-value{
  font-size:2.25rem;font-weight:900;
  background:linear-gradient(135deg,var(--success),#4ade80);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  font-variant-numeric:tabular-nums;
}
.match-card__score-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}

@media(max-width:768px){
  .match-card{grid-template-columns:1fr;gap:16px}
  .match-card__score{text-align:left}
}

/* ── Mobile (640px and below) ───────────────────────────── */
@media(max-width:640px){
  /* Container */
  .container{padding:0 20px}

  /* Nav */
  .nav__inner{padding:0 20px}
  .nav__logo-img{height:44px;width:44px}

  /* Hero */
  .hero{padding:90px 0 60px;min-height:unset}
  .hero__title{font-size:clamp(2rem,8vw,2.75rem)}
  .hero__sub{font-size:1rem;max-width:100%}
  .hero__ctas{flex-direction:column;align-items:stretch}
  .hero__ctas .btn{width:100%;text-align:center;justify-content:center;white-space:normal;word-break:break-word}
  .hero__visual{max-width:100%}
  .hero__card{margin:0}

  /* Buttons */
  .btn--lg{padding:14px 24px;font-size:.95rem}
  .btn--xl{padding:16px 28px;font-size:1rem}

  /* Section titles */
  .section__title{font-size:clamp(1.6rem,6vw,2.25rem)}
  .section__sub{font-size:.95rem}

  /* Features / Steps */
  .features__grid{grid-template-columns:1fr}
  .steps__grid{grid-template-columns:1fr}
  .step__connector{display:none}

  /* Pricing */
  .pricing__grid{grid-template-columns:1fr}
  .pricing__card--featured{transform:none}

  /* Upload form */
  .upload-form__row{grid-template-columns:1fr}
  .upload-zone{padding:40px 20px}

  /* Results */
  .results__hero{grid-template-columns:1fr}
  .score-ring-wrap{margin:0 auto}

  /* Stats */
  .stat-grid{grid-template-columns:1fr 1fr}

  /* Footer */
  .footer__inner{grid-template-columns:1fr;gap:24px}
  .footer__links{grid-template-columns:repeat(2,1fr)}

  /* CTA final */
  .cta-final__title{font-size:clamp(1.75rem,7vw,2.5rem)}
  .cta-final{padding:80px 0}
  .cta-final__sub{font-size:1rem}
  .cta-final .btn{width:100%;white-space:normal;word-break:break-word}

  /* All buttons — allow wrapping on mobile */
  .btn{white-space:normal;word-break:break-word}
}
