/* ================================================================
   CareerPortal — Complete Stylesheet  (Plus Jakarta Sans theme)
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap');

:root {
  --primary:       #1e88e5;
  --primary-d:     #1565c0;
  --primary-l:     #42a5f5;
  --accent:        #0288d1;
  --bg:            #ffffff;
  --bg-2:          #f5f8ff;
  --bg-3:          #eef4ff;
  --border:        #dde5f0;
  --border-l:      #edf2f8;
  --text:          #1a2332;
  --text-m:        #4a6080;
  --text-s:        #7a90a8;
  --shadow-s:      0 2px 8px rgba(30,136,229,.08);
  --shadow-m:      0 4px 16px rgba(30,136,229,.12);
  --shadow-l:      0 8px 32px rgba(30,136,229,.16);
  --radius:        12px;
  --radius-l:      16px;
  --mono:          'DM Mono', monospace;
  --sans:          'Plus Jakarta Sans', system-ui, sans-serif;
  --t:             all 0.25s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.65;
  font-size: 15px;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; }
button { font-family: var(--sans); cursor: pointer; }
ul { list-style: none; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg-2); }
::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 3px; }

/* Cursor */
#cursor { position:fixed;width:9px;height:9px;background:var(--primary);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);opacity:.7;transition:width .2s,height .2s; }
#cursor-ring { position:fixed;width:28px;height:28px;border:1.5px solid var(--primary-l);border-radius:50%;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);transition:all .16s ease-out;opacity:.45; }
.cursor-grow #cursor { width:16px;height:16px; }
.cursor-grow #cursor-ring { width:42px;height:42px;opacity:.25; }

/* ── Keyframes ──────────────────────────────────── */
@keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes pulse    { 0%,100%{opacity:1} 50%{opacity:.35} }
@keyframes slideUp  { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }

/* ── Layout ─────────────────────────────────────── */
.container { max-width:1140px;margin:0 auto;padding:0 1.5rem; }
.reveal { opacity:1;transform:translateY(0);transition:opacity .6s ease,transform .6s ease; }
.reveal.animate-ready { opacity:0;transform:translateY(18px); }
.reveal.visible { opacity:1;transform:translateY(0); }

/* ── Shared typography ──────────────────────────── */
.section-eyebrow {
  font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.14em;
  color:var(--primary);text-align:center;margin-bottom:.65rem;text-transform:uppercase;
}
.section-title {
  text-align:center;font-size:2rem;font-weight:800;color:var(--text);
  margin-bottom:.65rem;line-height:1.25;letter-spacing:-.02em;
}
.section-sub {
  text-align:center;font-size:.9rem;color:var(--text-m);
  margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto;line-height:1.7;
}

/* ── Buttons ─────────────────────────────────────── */
.btn-primary {
  display:inline-block;padding:.65rem 1.75rem;border-radius:8px;
  background:var(--primary);color:#fff;font-size:.85rem;font-weight:700;
  border:none;box-shadow:var(--shadow-s);transition:var(--t);
}
.btn-primary:hover { transform:translateY(-2px);background:var(--primary-d);box-shadow:var(--shadow-m); }
.btn-outline {
  display:inline-block;padding:.65rem 1.75rem;border-radius:8px;
  background:transparent;color:var(--primary);font-size:.85rem;font-weight:700;
  border:2px solid var(--primary);transition:var(--t);
}
.btn-outline:hover { background:var(--primary);color:#fff;transform:translateY(-2px); }
.btn-outline-white {
  display:inline-block;padding:.65rem 1.75rem;border-radius:8px;
  background:transparent;color:#fff;font-size:.85rem;font-weight:700;
  border:2px solid rgba(255,255,255,.7);transition:var(--t);
}
.btn-outline-white:hover { background:#fff;color:var(--primary-d); }
.btn-lg { padding:.78rem 2rem;font-size:.9rem; }

/* ── NAV ─────────────────────────────────────────── */
nav {
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,.95);border-bottom:1px solid var(--border);
  backdrop-filter:blur(14px);transition:box-shadow .25s;
}
nav.scrolled { box-shadow:var(--shadow-m); }
.nav-inner {
  max-width:1140px;margin:0 auto;padding:.7rem 1.5rem;
  display:flex;align-items:center;gap:1.25rem;
}
.nav-logo { display:flex;align-items:center;gap:.5rem; }
.nav-logo-box {
  width:32px;height:32px;border-radius:8px;background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:#fff;box-shadow:var(--shadow-s);transition:var(--t);
}
.nav-logo-box:hover { transform:scale(1.07);box-shadow:var(--shadow-m); }
.nav-logo-name { font-size:.95rem;font-weight:800;color:var(--text);letter-spacing:-.02em; }
.nav-links { display:flex;align-items:center;gap:1.1rem;margin-left:auto; }
.nav-links a {
  font-size:.75rem;font-weight:600;color:var(--text-m);
  transition:var(--t);position:relative;padding:.25rem 0;
}
.nav-links a::after {
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:2px;background:var(--primary);transform:scaleX(0);transition:transform .22s;
}
.nav-links a:hover,.nav-links a.active { color:var(--text); }
.nav-links a:hover::after,.nav-links a.active::after { transform:scaleX(1); }
.btn-nav-cta {
  padding:.42rem 1rem;border-radius:7px;background:var(--primary);color:#fff;
  font-size:.75rem;font-weight:700;border:none;box-shadow:var(--shadow-s);
  transition:var(--t);white-space:nowrap;
}
.btn-nav-cta:hover { transform:translateY(-2px);background:var(--primary-d);box-shadow:var(--shadow-m); }
.nav-hamburger { display:none;background:none;border:none;color:var(--primary);font-size:1.3rem;margin-left:auto; }

/* ── TICKER ─────────────────────────────────────── */
.ticker-bar {
  position:fixed;top:53px;left:0;right:0;z-index:999;overflow:hidden;
  border-bottom:1px solid var(--border-l);background:var(--bg-2);padding:.22rem 0;
}
.ticker-track {
  display:flex;white-space:nowrap;
  animation:marquee 32s linear infinite;
  font-family:var(--mono);font-size:.5rem;font-weight:600;
  letter-spacing:.14em;color:var(--primary);
}
.tick-item { margin-right:2.5rem;display:inline-flex;align-items:center;gap:.4rem; }
.tick-dot { width:4px;height:4px;background:var(--primary);border-radius:50%;opacity:.5; }

/* ── TRUST BADGES ───────────────────────────────── */
.hero-trust-badges { display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap; }
.trust-badge {
  font-size:.72rem;font-weight:600;padding:.3rem .85rem;border-radius:99px;
  background:var(--bg-3);border:1px solid var(--border);color:var(--text-m);
}

/* ── HERO ────────────────────────────────────────── */
.hero {
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:7rem 0 4rem;position:relative;
  background:linear-gradient(140deg,#fff 0%,#eef4ff 55%,#e8f2fd 100%);overflow:hidden;
}
.hero-bg { position:absolute;inset:0;overflow:hidden;pointer-events:none; }
.blob {
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.13;
  animation:float 9s ease-in-out infinite;
}
.blob1 { width:380px;height:380px;background:var(--primary-l);top:8%;left:4%; }
.blob2 { width:480px;height:480px;background:var(--accent);bottom:8%;right:4%;animation-delay:2.5s; }
.blob3 { width:320px;height:320px;background:var(--primary-d);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:5s; }
.hero-content { position:relative;z-index:10;text-align:center;max-width:860px;padding:0 2rem; }
.hero-badge {
  display:inline-flex;align-items:center;gap:.5rem;background:#fff;
  border:1px solid var(--border);padding:.38rem 1rem;border-radius:99px;
  font-size:.65rem;font-weight:700;letter-spacing:.08em;color:var(--primary-d);
  margin-bottom:1.5rem;box-shadow:var(--shadow-s);
}
.badge-pulse { width:6px;height:6px;background:var(--primary);border-radius:50%;animation:pulse 2s infinite; }
.hero-title { font-size:3.4rem;font-weight:800;line-height:1.15;margin-bottom:1rem;letter-spacing:-.03em; }
.ht-line { display:block; }
.ht-1 { color:var(--primary); }
.ht-2 { color:var(--text); }
.hero-sub { font-size:.95rem;color:var(--text-m);line-height:1.75;margin-bottom:2rem;max-width:640px;margin-left:auto;margin-right:auto; }
.hero-ctas { display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem; }
.hero-stats { display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;align-items:center; }
.hero-stat { text-align:center; }
.hs-num { display:block;font-size:2rem;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:.2rem; }
.hs-lbl { display:block;font-size:.68rem;font-weight:600;color:var(--text-s);text-transform:uppercase;letter-spacing:.08em; }
.stat-div { width:1px;height:36px;background:var(--border); }

/* ── ROLES SECTION ──────────────────────────────── */
.roles-section { padding:5rem 0;background:#fff; }
.roles-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem; }
.role-card {
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);
  padding:2rem 1.5rem;cursor:pointer;transition:var(--t);position:relative;overflow:hidden;
}
.role-card:hover { transform:translateY(-6px);border-color:var(--primary);box-shadow:var(--shadow-l); }
.role-card--featured { border-color:var(--primary);background:linear-gradient(135deg,#eef4ff,#fff); }
.role-featured-pill {
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:var(--primary);color:#fff;font-size:.58rem;font-weight:700;
  padding:.22rem .75rem;border-radius:0 0 8px 8px;white-space:nowrap;font-family:var(--mono);
}
.role-icon-wrap {
  width:56px;height:56px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;font-size:1.7rem;margin-bottom:1rem;
}
.role-title { font-size:1.1rem;font-weight:800;color:var(--text);margin-bottom:.5rem;letter-spacing:-.01em; }
.role-desc { font-size:.82rem;color:var(--text-m);line-height:1.65;margin-bottom:1.25rem; }
.role-list { display:flex;flex-direction:column;gap:.42rem; }
.role-list li { font-size:.75rem;color:var(--text-m);display:flex;align-items:flex-start;gap:.5rem; }
.role-list li::before { content:'✓';color:var(--primary);font-weight:700;flex-shrink:0;margin-top:.05rem; }
.role-cta { display:block;font-size:.78rem;font-weight:700;color:var(--primary);margin-top:1.25rem; }

/* ── HIGHLIGHTS SECTION ─────────────────────────── */
.highlights-section { padding:5rem 0;background:var(--bg-2); }
.highlights-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem; }
.hl-card {
  background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);
  padding:1.75rem 1.5rem;transition:var(--t);
}
.hl-card:hover { transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-m); }
.hl-icon { font-size:2rem;margin-bottom:.9rem;display:block; }
.hl-card h4 { font-size:.92rem;font-weight:700;color:var(--text);margin-bottom:.5rem; }
.hl-card p { font-size:.78rem;color:var(--text-m);line-height:1.7;margin-bottom:1rem; }
.hl-link { font-size:.75rem;font-weight:700;color:var(--primary); }

/* ── TECH SECTION ───────────────────────────────── */
.tech-section { padding:4.5rem 0;background:#fff; }
.tech-grid { display:grid;grid-template-columns:repeat(8,1fr);gap:1rem; }
.tech-card {
  background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.25rem .9rem;text-align:center;transition:var(--t);display:flex;
  flex-direction:column;align-items:center;gap:.4rem;
}
.tech-card:hover { transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-m); }
.tech-icon { font-size:1.8rem;display:block; }
.tech-name { font-size:.72rem;font-weight:700;color:var(--text); }
.tech-sub { font-size:.6rem;color:var(--text-s);font-family:var(--mono); }

/* ── CTA BANNER ─────────────────────────────────── */
.cta-banner {
  padding:5.5rem 0;
  background:linear-gradient(135deg,var(--primary),var(--primary-d));
  position:relative;overflow:hidden;text-align:center;
}
.cta-blob1,.cta-blob2 { position:absolute;border-radius:50%;filter:blur(100px);opacity:.13; }
.cta-blob1 { width:500px;height:500px;background:#fff;top:-120px;left:-120px; }
.cta-blob2 { width:400px;height:400px;background:#fff;bottom:-100px;right:-100px; }
.cta-inner { position:relative;z-index:1; }
.cta-title { font-size:2.2rem;font-weight:800;color:#fff;margin-bottom:.75rem;letter-spacing:-.02em; }
.cta-sub { font-size:.95rem;color:rgba(255,255,255,.88);margin-bottom:2rem; }
.cta-btns { display:flex;gap:1rem;justify-content:center;flex-wrap:wrap; }

/* ── FOOTER ─────────────────────────────────────── */
footer { background:#0d1b2a;border-top:1px solid rgba(255,255,255,.08);padding:3rem 0 2rem; }
.footer-top { display:grid;grid-template-columns:200px 1fr;gap:3rem;margin-bottom:2.5rem; }
.footer-tagline { font-size:.8rem;color:rgba(255,255,255,.45);line-height:1.6;margin-top:.75rem; }
.footer-links-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:2rem; }
.footer-col { display:flex;flex-direction:column;gap:.65rem; }
.footer-col-title { font-size:.72rem;font-weight:700;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem; }
.footer-col a { font-size:.8rem;color:rgba(255,255,255,.5);transition:.2s; }
.footer-col a:hover { color:var(--primary); }
.footer-bottom { display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08); }
.footer-copy { font-size:.82rem;color:rgba(255,255,255,.55);font-family:var(--sans);font-weight:500; }

/* ── PAGE HERO ──────────────────────────────────── */
.page-hero {
  padding:7rem 0 4rem;text-align:center;position:relative;
  background:linear-gradient(140deg,#fff 0%,#eef4ff 100%);overflow:hidden;
}
.page-hero-title { font-size:2.75rem;font-weight:800;color:var(--text);margin-bottom:.75rem;line-height:1.2;letter-spacing:-.03em; }
.page-hero-sub { font-size:.93rem;color:var(--text-m);max-width:580px;margin:0 auto 2rem;line-height:1.75; }
.page-hero-tabs { display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap; }
.page-tab {
  padding:.45rem 1.25rem;border-radius:99px;font-size:.78rem;font-weight:700;
  background:#fff;border:1.5px solid var(--border);color:var(--text-m);transition:var(--t);
}
.page-tab:hover { border-color:var(--primary);color:var(--primary); }

/* ── FEATURES PAGE ──────────────────────────────── */
.features-section { padding:4rem 0; }
.feat-role-header { margin-bottom:2rem; }
.feat-role-badge {
  display:inline-block;font-family:var(--mono);font-size:.65rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;padding:.35rem .9rem;border-radius:6px;
}
.feature-block {
  display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;
  margin-bottom:5rem;padding-bottom:4rem;border-bottom:1px solid var(--border-l);
}
.feature-block:last-child { border-bottom:none; }
.feature-block--reverse { direction:rtl; }
.feature-block--reverse > * { direction:ltr; }
.feature-content h3 { font-size:1.55rem;font-weight:800;color:var(--text);margin-bottom:.75rem;letter-spacing:-.02em; }
.feature-content p { font-size:.85rem;color:var(--text-m);line-height:1.75;margin-bottom:1.25rem; }
.feat-list { display:flex;flex-direction:column;gap:.5rem; }
.feat-list li { font-size:.8rem;color:var(--text-m);display:flex;align-items:flex-start;gap:.5rem;line-height:1.55; }
.feat-list li::before { content:'✓';color:var(--primary);font-weight:700;flex-shrink:0;margin-top:.05rem; }
.feat-visual {
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);
  padding:1.75rem;position:relative;overflow:hidden;
}
.feat-label {
  position:absolute;top:.75rem;right:.75rem;font-family:var(--mono);font-size:.52rem;
  font-weight:700;letter-spacing:.1em;color:var(--primary);
  background:var(--bg-3);padding:.22rem .6rem;border-radius:4px;
}
.feat-tag-row { display:flex;gap:.5rem;flex-wrap:wrap; }
.feat-tag { font-size:.62rem;font-weight:700;padding:.22rem .62rem;border-radius:4px;font-family:var(--mono);background:var(--bg-3);color:var(--primary);border:1px solid var(--border); }

/* Resume form mock */
.feat-mock-form { display:flex;flex-direction:column;gap:.5rem; }
.mock-section-title { font-size:.62rem;font-weight:700;color:var(--primary);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--border-l);padding-bottom:.3rem;margin-bottom:.3rem; }
.mock-field-row { display:grid;grid-template-columns:1fr 1fr;gap:.4rem; }
.mock-field { background:#fff;border:1px solid var(--border);border-radius:5px;padding:.38rem .65rem;font-size:.65rem;color:var(--text-s); }
.mock-textarea { background:#fff;border:1px solid var(--border);border-radius:5px;padding:.5rem .65rem;font-size:.65rem;color:var(--text-s);line-height:1.5; }
.mock-tag { font-size:.58rem;background:var(--primary);color:#fff;padding:.12rem .45rem;border-radius:4px; }
.mock-exp-row { display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--border);border-radius:5px;padding:.4rem .65rem; }
.mock-exp-title { font-size:.65rem;font-weight:700;color:var(--text); }
.mock-exp-date { font-size:.58rem;color:var(--text-s);font-family:var(--mono); }

/* ATS score preview */
.ats-score-preview { text-align:center;padding:1rem 0; }
.ats-preview-score { font-size:3rem;font-weight:800;color:var(--primary);letter-spacing:-.03em;line-height:1; }
.ats-preview-score span { font-size:1.2rem;color:var(--text-s); }
.ats-preview-label { font-size:.85rem;font-weight:700;color:#16a34a;margin-top:.4rem; }
.ats-bars { display:flex;flex-direction:column;gap:.55rem; }
.ats-bar-row { display:flex;align-items:center;gap:.65rem; }
.ats-bar-label { font-size:.65rem;color:var(--text-m);width:68px;flex-shrink:0; }
.ats-bar-track { flex:1;height:7px;background:var(--border-l);border-radius:4px;overflow:hidden; }
.ats-bar-fill { height:100%;border-radius:4px;background:var(--primary);transition:width 1.2s ease; }
.ats-bar-val { font-size:.62rem;font-weight:700;color:var(--primary);width:30px;flex-shrink:0;font-family:var(--mono); }

/* Job cards mock */
.mock-job-cards { display:flex;flex-direction:column;gap:.6rem; }
.mock-job-card { background:#fff;border:1px solid var(--border);border-radius:8px;padding:.9rem; }
.mock-job-header { display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem; }
.mock-job-title { font-size:.75rem;font-weight:700;color:var(--text); }
.mock-job-badge { font-size:.55rem;padding:.18rem .5rem;background:rgba(30,136,229,.1);color:var(--primary);border-radius:4px;font-weight:700;font-family:var(--mono); }
.mock-job-badge--hybrid { background:rgba(2,119,189,.1);color:#0277bd; }
.mock-job-meta { font-size:.62rem;color:var(--text-s);margin-bottom:.5rem; }
.mock-job-footer { display:flex;align-items:center;gap:.4rem;flex-wrap:wrap; }
.mock-job-tag { font-size:.58rem;background:var(--bg-2);border:1px solid var(--border);color:var(--text-m);padding:.15rem .45rem;border-radius:3px; }
.mock-job-apply { margin-left:auto;font-size:.65rem;font-weight:700;color:var(--primary); }

/* AI interview mock */
.ai-interview-mock { display:flex;flex-direction:column;gap:.75rem; }
.ai-avatar-row { display:flex;gap:.75rem;align-items:flex-start; }
.ai-avatar { width:44px;height:44px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0; }
.ai-speech-bubble { background:#fff;border:1px solid var(--border);border-radius:12px;padding:.7rem .9rem;font-size:.73rem;color:var(--text-m);line-height:1.55;flex:1; }
.ai-q-meta { font-size:.6rem;color:var(--text-s);font-family:var(--mono); }
.ai-score-row { display:flex;gap:.5rem; }
.ai-score-item { display:flex;flex-direction:column;align-items:center;background:#fff;border:1px solid var(--border);border-radius:6px;padding:.4rem .6rem;font-size:.6rem;color:var(--text-s);gap:.15rem; }
.ai-score-item strong { font-size:.82rem;font-weight:800;color:var(--text); }
.ai-score-item--active { border-color:var(--primary);background:var(--bg-3); }
.ai-score-item--active strong { color:var(--primary); }

/* Proctoring mock */
.proctor-mock { display:flex;flex-direction:column;gap:.5rem; }
.proctor-status { font-size:.72rem;padding:.45rem .7rem;border-radius:6px;font-weight:600; }
.proctor-status--ok { background:rgba(22,163,74,.08);color:#15803d; }
.proctor-status--warn { background:rgba(245,158,11,.1);color:#b45309; }
.proctor-credibility { font-size:.72rem;font-weight:700;color:var(--text);margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-l); }

/* Dashboard mock */
.dashboard-mock { display:flex;flex-direction:column;gap:.75rem; }
.dash-stat-row { display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem; }
.dash-stat { background:#fff;border:1px solid var(--border);border-radius:8px;padding:.7rem;text-align:center; }
.dash-stat-num { display:block;font-size:1.3rem;font-weight:800;color:var(--text);letter-spacing:-.02em; }
.dash-stat-lbl { display:block;font-size:.58rem;color:var(--text-s);margin-top:.15rem;font-family:var(--mono); }
.dash-app-list { display:flex;flex-direction:column;gap:.4rem; }
.dash-app { display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--border);border-radius:6px;padding:.45rem .7rem; }
.dash-app-name { font-size:.72rem;color:var(--text-m);font-weight:600; }
.dash-app-status { font-size:.58rem;font-weight:700;padding:.18rem .5rem;border-radius:4px;font-family:var(--mono); }
.dash-status--shortlisted { background:rgba(22,163,74,.1);color:#15803d; }
.dash-status--reviewing { background:rgba(30,136,229,.1);color:var(--primary); }
.dash-status--pending { background:rgba(245,158,11,.1);color:#b45309; }

/* ── ABOUT PAGE ─────────────────────────────────── */
.about-section { padding:5rem 0; }
.about-split { display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center; }
.about-mission h2 { font-size:2rem;font-weight:800;color:var(--text);margin-bottom:1rem;line-height:1.25;letter-spacing:-.02em; }
.about-mission p { font-size:.85rem;color:var(--text-m);line-height:1.8;margin-bottom:.85rem; }
.about-ctas { display:flex;gap:1rem;margin-top:1.75rem;flex-wrap:wrap; }
.about-stats-box {
  display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);padding:2rem;
}
.about-stat-item { text-align:center; }
.about-stat-num { display:block;font-size:2.5rem;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:.3rem; }
.about-stat-lbl { font-size:.68rem;font-weight:600;color:var(--text-s);text-transform:uppercase;letter-spacing:.08em; }
.values-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem; }
.value-card {
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);
  padding:1.75rem 1.5rem;transition:var(--t);
}
.value-card:hover { transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-m); }
.value-icon { font-size:1.9rem;margin-bottom:.85rem;display:block; }
.value-card h4 { font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.5rem; }
.value-card p { font-size:.8rem;color:var(--text-m);line-height:1.7; }

/* Timeline */
.timeline { padding-left:2.5rem;position:relative; }
.timeline::before { content:'';position:absolute;left:.9rem;top:0;bottom:0;width:2px;background:var(--border); }
.tl-item { display:grid;grid-template-columns:120px 1fr;gap:1.5rem;margin-bottom:2.5rem;position:relative; }
.tl-marker { display:flex;flex-direction:column;align-items:flex-start;gap:.4rem; }
.tl-dot { width:14px;height:14px;border-radius:50%;background:var(--primary-l);border:3px solid #fff;box-shadow:0 0 0 2px var(--primary-l);position:absolute;left:-1.85rem;top:.25rem; }
.tl-dot--active { background:var(--primary);box-shadow:0 0 0 2px var(--primary); }
.tl-date { font-family:var(--mono);font-size:.62rem;font-weight:600;color:var(--primary);padding-left:1rem; }
.tl-content h4 { font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:.4rem; }
.tl-content p { font-size:.8rem;color:var(--text-m);line-height:1.7; }

/* Team */
.team-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem; }
.team-card {
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);
  padding:2rem 1.5rem;text-align:center;transition:var(--t);
}
.team-card:hover { transform:translateY(-4px);border-color:var(--primary);box-shadow:var(--shadow-m); }
.team-avatar { width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-d));display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto .9rem; }
.team-name { font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:.25rem; }
.team-role { font-size:.68rem;color:var(--primary);font-weight:600;font-family:var(--mono);margin-bottom:.75rem; }
.team-bio { font-size:.78rem;color:var(--text-m);line-height:1.65; }
.about-cta-box {
  background:linear-gradient(135deg,var(--bg-3),#fff);border:1.5px solid var(--border);
  border-radius:var(--radius-l);padding:3rem;text-align:center;margin-top:5rem;
}
.about-cta-box h3 { font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:.65rem;letter-spacing:-.02em; }
.about-cta-box p { font-size:.88rem;color:var(--text-m);margin-bottom:1.5rem;line-height:1.7; }
.about-cta-btns { display:flex;gap:1rem;justify-content:center;flex-wrap:wrap; }

/* ── HOW IT WORKS PAGE ──────────────────────────── */
.hiw-section { padding:4rem 0; }
.hiw-role-block {
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);
  padding:2.25rem;margin-bottom:2.5rem;
}
.hiw-role-title { font-size:1.2rem;font-weight:800;color:var(--text);margin-bottom:2rem;display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid var(--border-l);letter-spacing:-.01em; }
.hiw-steps { display:grid;grid-template-columns:repeat(6,1fr);gap:1rem; }
.hiw-step {
  background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;transition:var(--t);
}
.hiw-step:hover { transform:translateY(-3px);border-color:var(--primary);box-shadow:var(--shadow-m); }
.step-num { display:block;font-size:1.5rem;font-weight:800;color:var(--primary);font-family:var(--mono);margin-bottom:.6rem;letter-spacing:-.02em; }
.hiw-step h4 { font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:.4rem; }
.hiw-step p { font-size:.73rem;color:var(--text-m);line-height:1.6; }

/* ── PRICING PAGE ───────────────────────────────── */
.pricing-section { padding:4rem 0; }
.pricing-toggle { display:flex;gap:.75rem;justify-content:center;margin-bottom:3rem; }
.ptog-btn { padding:.52rem 1.5rem;border-radius:8px;border:2px solid var(--border);background:#fff;color:var(--text-m);font-size:.8rem;font-weight:700;transition:var(--t); }
.ptog-btn.active { background:var(--primary);color:#fff;border-color:var(--primary); }
.ptog-btn:hover:not(.active) { border-color:var(--primary);color:var(--primary); }
.pricing-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:920px;margin:0 auto; }
.pricing-grid.rec { grid-template-columns:repeat(4,1fr);max-width:1100px; }
.plan-card {
  background:var(--bg-2);border:2px solid var(--border);border-radius:var(--radius-l);
  padding:2rem 1.5rem;position:relative;transition:var(--t);
}
.plan-card:hover { transform:translateY(-5px);border-color:var(--primary);box-shadow:var(--shadow-l); }
.plan-card--featured { border-color:var(--primary);background:linear-gradient(135deg,#eef4ff,#fff); }
.plan-hot { position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;font-size:.58rem;font-weight:700;padding:.22rem .75rem;border-radius:99px;white-space:nowrap;font-family:var(--mono); }
.plan-name { font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem; }
.plan-price { font-size:2.2rem;font-weight:800;color:var(--text);line-height:1;margin-bottom:.25rem;letter-spacing:-.03em; }
.plan-price span { font-size:.9rem;font-weight:400;color:var(--text-s); }
.plan-period { font-size:.68rem;color:var(--text-s);margin-bottom:1.5rem;font-family:var(--mono); }
.plan-features { display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem; }
.plan-features li { font-size:.75rem;color:var(--text-m);display:flex;gap:.5rem;align-items:flex-start; }
.plan-features li::before { content:'✓';color:var(--primary);font-weight:700;flex-shrink:0; }
.plan-btn { width:100%;padding:.65rem;border-radius:8px;border:2px solid;font-size:.8rem;font-weight:700;font-family:var(--sans);transition:var(--t); }
.plan-btn.primary { background:var(--primary);color:#fff;border-color:var(--primary); }
.plan-btn.primary:hover { transform:translateY(-2px);background:var(--primary-d); }
.plan-btn.ghost { background:transparent;color:var(--primary);border-color:var(--primary); }
.plan-btn.ghost:hover { background:var(--primary);color:#fff; }
.pricing-note { text-align:center;padding:2rem 0;font-size:.8rem;color:var(--text-s); }

/* ── ATS INFO PAGE ──────────────────────────────── */
.ats-info-section { padding:4rem 0 5rem; }
.ats-what-box { display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center;background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);padding:3rem;margin-bottom:5rem; }
.ats-what-left h2 { font-size:1.75rem;font-weight:800;color:var(--text);margin-bottom:1rem;line-height:1.3;letter-spacing:-.02em; }
.ats-what-left p { font-size:.84rem;color:var(--text-m);line-height:1.78;margin-bottom:.8rem; }
.ats-big-score { display:flex;flex-direction:column;align-items:center;gap:.75rem; }
.ats-big-ring { position:relative;width:120px;height:120px; }
.ats-big-ring svg { transform:rotate(-90deg); }
.ats-big-ring-inner { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center; }
.ats-big-num { font-size:2.2rem;font-weight:800;color:var(--primary);line-height:1;letter-spacing:-.03em; }
.ats-big-lbl { font-size:.6rem;color:var(--text-s);font-family:var(--mono); }
.ats-big-label { font-size:.85rem;font-weight:700;color:#16a34a; }

/* ATS categories grid */
.ats-cats-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1rem; }
.ats-cat-card {
  background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);
  padding:1.25rem;transition:var(--t);
}
.ats-cat-card:hover { border-color:var(--primary);box-shadow:var(--shadow-m); }
.ats-cat-card--large { grid-column:span 2;grid-row:span 1; }
.ats-cat-header { display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem; }
.ats-cat-icon { font-size:1.5rem; }
.ats-cat-weight { font-size:1.4rem;font-weight:800;color:var(--primary);font-family:var(--mono);letter-spacing:-.02em; }
.ats-cat-name { font-size:.88rem;font-weight:700;color:var(--text);margin-bottom:.4rem; }
.ats-cat-desc { font-size:.75rem;color:var(--text-m);line-height:1.65;margin-bottom:.5rem; }
.ats-cat-tip { font-size:.7rem;color:var(--primary);font-weight:600;font-family:var(--mono); }

/* Score bands */
.ats-bands-box { background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);padding:2.5rem;margin:3rem 0; }
.ats-bands-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem; }
.ats-band { border-radius:var(--radius);padding:1.5rem;text-align:center; }
.ats-band--red { background:rgba(239,68,68,.06);border:1.5px solid rgba(239,68,68,.2); }
.ats-band--yellow { background:rgba(245,158,11,.06);border:1.5px solid rgba(245,158,11,.2); }
.ats-band--green { background:rgba(22,163,74,.06);border:1.5px solid rgba(22,163,74,.2); }
.ats-band-range { font-size:1.6rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.3rem; }
.ats-band--red .ats-band-range { color:#dc2626; }
.ats-band--yellow .ats-band-range { color:#d97706; }
.ats-band--green .ats-band-range { color:#16a34a; }
.ats-band-label { font-size:.9rem;font-weight:700;margin-bottom:.5rem; }
.ats-band-desc { font-size:.75rem;line-height:1.65; }
.ats-band--red .ats-band-desc { color:#991b1b; }
.ats-band--yellow .ats-band-desc { color:#92400e; }
.ats-band--green .ats-band-desc { color:#166534; }

/* Demo CTA section */
.ats-demo-cta { background:linear-gradient(135deg,var(--bg-3),#fff);border:2px solid var(--primary);border-radius:var(--radius-l);padding:3rem;margin-top:3.5rem; }
.ats-demo-cta-inner { display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center; }
.ats-demo-cta-left h2 { font-size:1.75rem;font-weight:800;color:var(--text);margin-bottom:.85rem;letter-spacing:-.02em; }
.ats-demo-cta-left p { font-size:.85rem;color:var(--text-m);line-height:1.75;margin-bottom:1rem; }
.ats-demo-features { display:flex;flex-direction:column;gap:.45rem; }
.ats-demo-features li { font-size:.8rem;color:var(--text-m);font-weight:500; }

/* Preview card */
.ats-demo-preview-card { background:#fff;border:1.5px solid var(--border);border-radius:var(--radius-l);padding:1.5rem;box-shadow:var(--shadow-m); }
.adp-header { display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem; }
.adp-title { font-size:.82rem;font-weight:700;color:var(--text); }
.adp-badge { font-size:.6rem;font-weight:700;background:rgba(22,163,74,.1);color:#16a34a;padding:.2rem .5rem;border-radius:4px;font-family:var(--mono); }
.adp-score-row { display:flex;align-items:center;gap:1rem;margin-bottom:1rem; }
.adp-score-circle { position:relative;width:80px;height:80px;flex-shrink:0; }
.adp-score-circle svg { transform:rotate(-90deg); }
.adp-score-inner { position:absolute;inset:0;display:flex;align-items:center;justify-content:center; }
.adp-score-inner span { font-size:1.5rem;font-weight:800;color:var(--primary);letter-spacing:-.02em; }
.adp-bars { display:flex;flex-direction:column;gap:.4rem; }
.adp-bar-row { display:grid;grid-template-columns:60px 1fr 32px;gap:.4rem;align-items:center;font-size:.62rem;color:var(--text-s); }
.adp-bar-track { height:5px;background:var(--border-l);border-radius:3px;overflow:hidden; }
.adp-bar-track div { height:100%;border-radius:3px; }
.adp-footer { margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-l); }
.adp-launch-btn { display:block;text-align:center;padding:.55rem;background:var(--primary);color:#fff;border-radius:7px;font-size:.78rem;font-weight:700; }
.adp-launch-btn:hover { background:var(--primary-d); }

/* ── ATS LIVE DEMO PAGE ─────────────────────────── */
.ats-demo-section { padding:3rem 0 5rem; }
.ats-tool-grid { display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start; }
.ats-input-panel { background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);padding:2rem;position:sticky;top:100px; }
.ats-input-title { font-size:1rem;font-weight:800;color:var(--text);margin-bottom:.3rem; }
.ats-input-sub { font-size:.75rem;color:var(--text-m);margin-bottom:1.5rem; }
.ats-form-section-label { font-size:.62rem;font-weight:700;color:var(--primary);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--border-l);padding-bottom:.3rem;margin-bottom:.65rem; }
.ats-form-group { margin-bottom:.75rem; }
.ats-label { font-size:.62rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.28rem;font-family:var(--mono); }
.ats-input, .ats-textarea {
  width:100%;background:#fff;border:1.5px solid var(--border);border-radius:7px;
  color:var(--text);padding:.52rem .8rem;font-size:.8rem;font-family:var(--sans);
  outline:none;transition:var(--t);
}
.ats-input:focus, .ats-textarea:focus { border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,136,229,.1); }
.ats-textarea { resize:vertical;min-height:56px; }
.ats-score-btn {
  width:100%;padding:.72rem;border-radius:8px;border:none;
  background:var(--primary);color:#fff;font-size:.85rem;font-weight:700;
  font-family:var(--sans);box-shadow:var(--shadow-s);transition:var(--t);
}
.ats-score-btn:hover { transform:translateY(-2px);background:var(--primary-d);box-shadow:var(--shadow-m); }
.ats-sample-btn:hover { border-color:var(--primary);color:var(--primary); }
.ats-results-panel, .ats-results-placeholder {
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);
  padding:2rem;
}
.ats-placeholder-inner { text-align:center;padding:2rem 1rem; }
.ats-placeholder-inner h3 { font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.5rem; }
.ats-placeholder-inner p { font-size:.8rem;color:var(--text-m);line-height:1.65;margin-bottom:1.5rem; }
.ats-placeholder-cats { display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center; }
.ats-placeholder-cats span { font-size:.62rem;background:#fff;border:1px solid var(--border);color:var(--text-s);padding:.2rem .55rem;border-radius:4px;font-family:var(--mono); }
.ats-overall { display:flex;align-items:center;gap:1.5rem;background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem; }
.ats-ring { position:relative;width:110px;height:110px;flex-shrink:0; }
.ats-ring svg { transform:rotate(-90deg); }
.ats-ring-score { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center; }
.ats-ring-num { font-size:1.8rem;font-weight:800;color:var(--primary);line-height:1;letter-spacing:-.03em; }
.ats-ring-lbl { font-size:.58rem;color:var(--text-s);font-family:var(--mono); }
.ats-msg h3 { font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.4rem; }
.ats-msg p { font-size:.78rem;color:var(--text-m);line-height:1.65; }
.ats-category-list { display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.5rem; }
.ats-cat-header-row { display:flex;justify-content:space-between;margin-bottom:.28rem; }
.ats-cat-lbl { font-size:.75rem;font-weight:600;color:var(--text); }
.ats-cat-track { height:8px;background:var(--border-l);border-radius:4px;overflow:hidden; }
.ats-cat-bar { height:100%;border-radius:4px;background:var(--primary);transition:width 1s ease; }
.ats-feedback { display:grid;grid-template-columns:1fr 1fr;gap:1rem; }
.ats-fb-box { background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);padding:1rem; }
.ats-fb-title { font-size:.72rem;font-weight:700;color:var(--text);margin-bottom:.6rem;font-family:var(--mono); }
.ats-fb-list { display:flex;flex-direction:column;gap:.4rem; }
.ats-fb-list li { font-size:.72rem;color:var(--text-m);line-height:1.5; }

/* ── CONTACT PAGE ───────────────────────────────── */
.contact-section { padding:4rem 0 5rem; }
.contact-grid { display:grid;grid-template-columns:1fr 1.4fr;gap:3.5rem;align-items:start; }
.contact-info-col h3 { font-size:1.35rem;font-weight:800;color:var(--text);margin-bottom:.65rem;letter-spacing:-.02em; }
.contact-info-col p { font-size:.83rem;color:var(--text-m);line-height:1.75;margin-bottom:1.75rem; }
.contact-items { display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem; }
.contact-item { display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius);transition:var(--t); }
.contact-item:hover { border-color:var(--primary);box-shadow:var(--shadow-s); }
.ci-icon { width:36px;height:36px;border-radius:8px;background:rgba(30,136,229,.1);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0; }
.ci-label { font-size:.58rem;font-weight:700;color:var(--text-s);font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.1rem; }
.ci-val { font-size:.78rem;color:var(--text-m);font-weight:600; }
.contact-faq { background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);padding:1.5rem; }
.faq-title { font-size:.75rem;font-weight:700;color:var(--text);margin-bottom:1rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em; }
.faq-item { margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-l); }
.faq-item:last-child { margin-bottom:0;padding-bottom:0;border-bottom:none; }
.faq-q { font-size:.8rem;font-weight:700;color:var(--text);margin-bottom:.3rem; }
.faq-a { font-size:.75rem;color:var(--text-m);line-height:1.65; }
.contact-form-box { background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-l);padding:2.25rem; }
.cf-title { font-size:1.1rem;font-weight:800;color:var(--text);margin-bottom:1.5rem;letter-spacing:-.01em; }
.cf-row { display:grid;grid-template-columns:1fr 1fr;gap:1rem; }
.cf-group { margin-bottom:.9rem; }
.cf-label { font-size:.62rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.3rem;font-family:var(--mono); }
.cf-input, .cf-textarea, .cf-select {
  width:100%;background:#fff;border:1.5px solid var(--border);border-radius:7px;
  color:var(--text);padding:.58rem .85rem;font-size:.82rem;font-family:var(--sans);
  outline:none;transition:var(--t);
}
.cf-input:focus, .cf-textarea:focus, .cf-select:focus { border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,136,229,.1); }
.cf-textarea { resize:vertical;min-height:120px; }
.cf-submit { width:100%;padding:.72rem;border-radius:8px;border:none;background:var(--primary);color:#fff;font-size:.88rem;font-weight:700;font-family:var(--sans);box-shadow:var(--shadow-s);transition:var(--t); }
.cf-submit:hover { transform:translateY(-2px);background:var(--primary-d);box-shadow:var(--shadow-m); }
.cf-success { display:none;text-align:center;padding:2.5rem 1rem; }
.cf-success.show { display:block; }
.cf-success-icon { font-size:3rem;margin-bottom:.75rem; }
.cf-success h3 { font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.5rem; }
.cf-success p { font-size:.82rem;color:var(--text-m);line-height:1.7; }

/* ── RESPONSIVE ─────────────────────────────────── */
@media(max-width:1100px) {
  .tech-grid { grid-template-columns:repeat(4,1fr); }
  .highlights-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:900px) {
  .roles-grid { grid-template-columns:1fr 1fr; }
  .feature-block { grid-template-columns:1fr;gap:2.5rem; }
  .feature-block--reverse { direction:ltr; }
  .hiw-steps { grid-template-columns:repeat(3,1fr); }
  .ats-tool-grid, .contact-grid { grid-template-columns:1fr; }
  .ats-input-panel { position:static; }
  .pricing-grid.rec { grid-template-columns:repeat(2,1fr); }
  .about-split { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr 1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .ats-what-box { grid-template-columns:1fr; }
  .ats-demo-cta-inner { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .footer-links-grid { grid-template-columns:repeat(3,1fr); }
  .ats-cats-grid { grid-template-columns:repeat(2,1fr); }
  .ats-cat-card--large { grid-column:span 1; }
  .ats-bands-grid { grid-template-columns:1fr; }
}
@media(max-width:700px) {
  .nav-links, .btn-nav-cta { display:none; }
  .nav-hamburger { display:block; }
  .nav-links.open {
    display:flex;flex-direction:column;position:fixed;top:53px;left:0;right:0;
    background:rgba(255,255,255,.98);border-bottom:1px solid var(--border);
    padding:1.5rem;gap:1rem;z-index:998;box-shadow:var(--shadow-m);
  }
  .nav-links.open .btn-nav-cta-mob { display:inline-block;padding:.55rem 1.25rem;border-radius:7px;background:var(--primary);color:#fff;font-size:.78rem;font-weight:700;text-align:center; }
  .hero-title { font-size:2.5rem; }
  .page-hero-title { font-size:2.1rem; }
  .section-title { font-size:1.65rem; }
  .roles-grid { grid-template-columns:1fr; }
  .tech-grid { grid-template-columns:repeat(4,1fr); }
  .highlights-grid { grid-template-columns:1fr; }
  .hiw-steps { grid-template-columns:1fr 1fr; }
  .pricing-grid, .pricing-grid.rec { grid-template-columns:1fr; }
  .hero-stats { gap:1.25rem; }
  .ats-feedback { grid-template-columns:1fr; }
  .cf-row { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .tl-item { grid-template-columns:90px 1fr;gap:1rem; }
  .ats-cats-grid { grid-template-columns:1fr; }
  .footer-links-grid { grid-template-columns:1fr 1fr; }
}

/* ── ROLES GRID TWO-COL ─────────────────────────── */
.roles-grid--two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 820px;
  margin: 0 auto;
}
@media(max-width:700px) { .roles-grid--two { grid-template-columns:1fr; } }

/* ── FEEDBACK SECTION ───────────────────────────── */
.feedback-section {
  padding: 5rem 0 4rem;
  background: var(--bg-light);
  border-top: 1px solid var(--border);
}
.feedback-inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}
.feedback-title {
  font-size: 2rem;
  font-weight: 800;
  color: var(--text-dark);
  margin: .5rem 0 1rem;
  line-height: 1.2;
}
.feedback-desc {
  color: var(--text-medium);
  font-size: .95rem;
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.feedback-perks { display:flex; flex-direction:column; gap:.7rem; }
.fp-item { display:flex; align-items:center; gap:.6rem; font-size:.88rem; color:var(--text-medium); font-weight:500; }
.fp-icon { font-size:1rem; }
.feedback-form-box {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 2rem;
  box-shadow: var(--shadow-s);
}
.fb-row { display:grid; grid-template-columns:1fr 1fr; gap:.75rem; }
.fb-group { display:flex; flex-direction:column; gap:.3rem; margin-bottom:.85rem; }
.fb-label { font-size:.75rem; font-weight:700; color:var(--text-dark); text-transform:uppercase; letter-spacing:.04em; }
.fb-req { color:var(--primary); }
.fb-input, .fb-textarea {
  padding: .65rem .85rem;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-family: var(--serif);
  font-size: .88rem;
  color: var(--text-dark);
  background: var(--bg-light);
  transition: border-color .2s;
  outline: none;
  resize: vertical;
}
.fb-input:focus, .fb-textarea:focus { border-color: var(--primary); background:#fff; }
.fb-input.error, .fb-textarea.error, .fb-type-group.error { border-color: #e53935; }
.fb-error { font-size:.73rem; color:#e53935; display:none; }
.fb-error.visible { display:block; }
.fb-type-group { display:flex; flex-wrap:wrap; gap:.5rem; padding:.5rem 0; }
.fb-type-chip {
  display:flex; align-items:center; gap:.35rem;
  padding:.35rem .75rem;
  border-radius:20px;
  border:1.5px solid var(--border);
  font-size:.78rem; font-weight:600;
  cursor:pointer;
  transition:all .2s;
  color:var(--text-medium);
}
.fb-type-chip:has(input:checked) { border-color:var(--primary); background:rgba(30,136,229,.08); color:var(--primary); }
.fb-type-chip input { display:none; }
.fb-stars { display:flex; gap:.4rem; margin-top:.25rem; }
.fb-star { font-size:1.6rem; color:#d1d5db; cursor:pointer; transition:color .15s; line-height:1; }
.fb-star.active, .fb-star:hover { color:#f59e0b; }
.fb-submit {
  width:100%; padding:.75rem;
  background:var(--primary);
  color:#fff;
  border:none;
  border-radius:9px;
  font-family:var(--serif);
  font-size:.9rem; font-weight:700;
  cursor:pointer;
  transition:background .2s, transform .15s;
  margin-top:.25rem;
}
.fb-submit:hover { background:var(--primary-dark); transform:translateY(-1px); }
.fb-success { text-align:center; padding:2rem 1rem; }
.fb-success-icon { font-size:2.5rem; margin-bottom:.75rem; }
.fb-success h3 { font-size:1.3rem; font-weight:800; color:var(--text-dark); margin-bottom:.5rem; }
.fb-success p { color:var(--text-medium); font-size:.88rem; }
@media(max-width:900px) { .feedback-inner { grid-template-columns:1fr; gap:2rem; } }
@media(max-width:700px) { .fb-row { grid-template-columns:1fr; } }

/* ── CONTACT SOCIAL LOGOS ───────────────────────── */
.contact-social-row { display:flex; gap:.75rem; margin-top:1rem; }
.contact-social-btn {
  display:flex; align-items:center; justify-content:center;
  width:44px; height:44px;
  border-radius:10px;
  border:1.5px solid var(--border);
  color:#fff;
  text-decoration:none;
  transition:transform .2s, box-shadow .2s;
}
.contact-social-btn:hover { transform:translateY(-2px); box-shadow:var(--shadow-m); }
.contact-social-btn--linkedin { background:#0077b5; border-color:#0077b5; }
.contact-social-btn--github { background:#24292e; border-color:#24292e; }

/* ── ATS VALIDATION ─────────────────────────────── */
.ats-input.error, .ats-textarea.error { border-color:#e53935 !important; }
.ats-field-error { font-size:.72rem; color:#e53935; margin-top:.25rem; display:none; }
.ats-field-error.visible { display:block; }
.ats-validation-banner {
  background:#fef2f2; border:1.5px solid #fca5a5;
  border-radius:10px; padding:.85rem 1rem;
  font-size:.82rem; color:#dc2626; font-weight:600;
  margin-bottom:1rem; display:none;
}
.ats-validation-banner.visible { display:block; }

/* ── MERGED FEATURE BLOCK (AI Interview + Proctoring) ─── */
.feature-block-merged {
  background: var(--bg-light);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 2.5rem 2.5rem 2rem;
  margin: 2.5rem 0;
  box-shadow: var(--shadow-s);
}
.merged-header {
  text-align: center;
  margin-bottom: 2.25rem;
  padding-bottom: 1.75rem;
  border-bottom: 1px solid var(--border);
}
.merged-badge {
  display: inline-block;
  background: linear-gradient(135deg, rgba(30,136,229,.12), rgba(2,77,161,.1));
  color: var(--primary-dark);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .1em;
  padding: .35rem .9rem;
  border-radius: 20px;
  border: 1px solid rgba(30,136,229,.2);
  margin-bottom: .85rem;
}
.merged-title {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-dark);
  margin: 0 0 .6rem;
  line-height: 1.2;
}
.merged-sub {
  color: var(--text-medium);
  font-size: .93rem;
  line-height: 1.65;
  max-width: 640px;
  margin: 0 auto;
}
.merged-body {
  display: grid;
  grid-template-columns: 1fr 40px 1fr;
  gap: 0;
  align-items: start;
}
.merged-col { padding: 0 .5rem; }
.merged-col-eyebrow {
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .06em;
  color: var(--primary);
  text-transform: uppercase;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.merged-divider {
  width: 1px;
  background: var(--border);
  margin: 0 auto;
  min-height: 100%;
  align-self: stretch;
}
.merged-footer-note {
  margin-top: 1.75rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
  text-align: center;
  font-size: .83rem;
  color: var(--text-medium);
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
}
.mfn-icon { font-size: 1rem; }

@media(max-width:900px) {
  .merged-body { grid-template-columns: 1fr; gap: 2rem; }
  .merged-divider { width: 100%; height: 1px; min-height: unset; }
  .feature-block-merged { padding: 1.75rem 1.25rem; }
}

/* ── MERGED SECTION PAIR (inside feature-block) ── */
.merged-section-pair { display:flex; flex-direction:column; gap:0; }
.msp-block { }
.msp-eyebrow {
  font-size:.72rem; font-weight:800; letter-spacing:.08em;
  color:var(--primary); text-transform:uppercase;
  margin-bottom:.6rem; margin-top:.25rem;
}
.msp-divider {
  width:100%; height:1px;
  background:var(--border);
  margin:1.5rem 0;
}
.msp-footer-note {
  margin-top:1.25rem;
  padding:.75rem 1rem;
  background:rgba(30,136,229,.06);
  border:1px solid rgba(30,136,229,.15);
  border-radius:9px;
  font-size:.8rem; color:var(--text-medium); font-weight:500;
  line-height:1.5;
}

/* Tab switcher on visual panel */
.msp-tab-bar {
  display:flex; gap:.4rem;
  margin-bottom:.85rem;
}
.msp-tab {
  flex:1; padding:.45rem .6rem;
  border:1.5px solid var(--border);
  border-radius:8px;
  background:var(--bg-light);
  color:var(--text-medium);
  font-family:var(--serif);
  font-size:.75rem; font-weight:700;
  cursor:pointer;
  transition:all .18s;
}
.msp-tab:hover { border-color:var(--primary); color:var(--primary); }
.msp-tab--active {
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
}
/* ================================================================
   APTI CAREERS — Brand Overrides
   ================================================================ */

/* CSS Logo — "AC" monogram */
.nav-logo-box {
  background: linear-gradient(135deg, var(--primary) 0%, #0d47a1 100%) !important;
  border-radius: 10px !important;
  position: relative;
  overflow: hidden;
}
.nav-logo-box::before {
  content: 'AC';
  font-family: var(--sans);
  font-weight: 800;
  font-size: .72rem;
  color: #fff;
  letter-spacing: -.04em;
  line-height: 1;
}
/* Hero welcome section */
.hero-welcome {
  min-height: 60vh;
  background: linear-gradient(135deg, #0d47a1 0%, #1e88e5 45%, #42a5f5 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 5rem 1.5rem;
  position: relative;
  overflow: hidden;
}
.hero-welcome::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 20% 50%, rgba(255,255,255,.08) 0%, transparent 60%),
    radial-gradient(ellipse 50% 80% at 80% 30%, rgba(255,255,255,.05) 0%, transparent 60%);
}
.hero-welcome-inner { position: relative; z-index: 1; }
.hero-welcome-title {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.04em;
  line-height: 1.05;
  text-shadow: 0 4px 32px rgba(0,0,0,.18);
  margin-bottom: 1rem;
}
.hero-welcome-title .accent-word {
  background: linear-gradient(90deg, #fff 30%, #bbdefb 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-welcome-sub {
  font-size: 1.1rem;
  color: rgba(255,255,255,.82);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.6;
}
/* Counts from 0 note */
.hero-stat .hs-num[data-from-db="true"]::after {
  content: '+';
}

/* ============================================================
   MARQUEE STYLES — Team / Customers / Feedback
   ============================================================ */

/* Shared marquee wrapper */
.team-marquee-wrap, .customers-marquee-wrap, .feedback-marquee-wrap {
  overflow: hidden;
  position: relative;
  margin: 2.5rem 0 0;
  /* Fade edges */
  mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.team-marquee-wrap:hover .team-marquee-track,
.customers-marquee-wrap:hover .customers-marquee-track,
.feedback-marquee-wrap:hover .feedback-marquee-track {
  animation-play-state: paused;
}

/* Team marquee */
.team-marquee-track {
  display: flex;
  gap: 1.5rem;
  animation: marqueeRTL 40s linear infinite;
  width: max-content;
}
.team-card-m {
  background: #fff;
  border-radius: 18px;
  padding: 1.75rem 1.5rem;
  width: 260px;
  flex-shrink: 0;
  box-shadow: 0 4px 20px rgba(30,136,229,.09);
  border: 1.5px solid #e8f4fd;
  text-align: center;
  transition: transform .2s, box-shadow .2s;
}
.team-card-m:hover { transform: translateY(-6px); box-shadow: 0 12px 36px rgba(30,136,229,.15); }
.team-card-m .team-avatar {
  width: 80px; height: 80px;
  background: linear-gradient(135deg, #1e88e5, #42a5f5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1rem;
  overflow: hidden;
  border: 3px solid #e8f4fd;
  box-shadow: 0 4px 14px rgba(30,136,229,.2);
  flex-shrink: 0;
}
.team-card-m .team-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
.team-card-m .team-name { font-weight: 700; color: #1a1a2e; font-size: 1rem; margin-bottom: .3rem; }
.team-card-m .team-role { font-size: .75rem; font-weight: 600; color: #1e88e5; letter-spacing: .04em; margin-bottom: .75rem; }
.team-card-m .team-bio { font-size: .78rem; color: #64748b; line-height: 1.55; }

/* Customers marquee */
.customers-marquee-track {
  display: flex;
  gap: 1.5rem;
  animation: marqueeRTL 35s linear infinite;
  width: max-content;
}
.customer-card-m {
  background: #fff;
  border-radius: 18px;
  padding: 1.75rem 1.5rem;
  width: 260px;
  flex-shrink: 0;
  box-shadow: 0 4px 20px rgba(30,136,229,.09);
  border: 1.5px solid #e8f4fd;
  text-align: center;
  transition: transform .2s, box-shadow .2s;
}
.customer-card-m:hover { transform: translateY(-6px); box-shadow: 0 12px 36px rgba(30,136,229,.15); }
.customer-avatar {
  width: 64px; height: 64px;
  background: linear-gradient(135deg, #0d47a1, #1e88e5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  margin: 0 auto .9rem;
}
.customer-name { font-weight: 700; color: #1a1a2e; font-size: .95rem; margin-bottom: .3rem; }
.customer-role { font-size: .72rem; font-weight: 600; color: #1e88e5; letter-spacing: .04em; margin-bottom: .75rem; }
.customer-bio { font-size: .77rem; color: #64748b; line-height: 1.55; }

/* Feedback marquee */
.feedback-marquee-track {
  display: flex;
  gap: 1.5rem;
  animation: marqueeRTL 45s linear infinite;
  width: max-content;
  padding: 1rem 0 2rem;
}
.fb-marquee-card {
  background: #fff;
  border-radius: 18px;
  padding: 1.75rem;
  width: 300px;
  flex-shrink: 0;
  box-shadow: 0 4px 20px rgba(30,136,229,.08);
  border: 1.5px solid #e8f4fd;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  transition: transform .2s, box-shadow .2s;
}
.fb-marquee-card:hover { transform: translateY(-5px); box-shadow: 0 12px 36px rgba(30,136,229,.14); }
.fbm-stars { color: #f59e0b; font-size: 1rem; letter-spacing: 2px; }
.fbm-text { font-size: .82rem; color: #374151; line-height: 1.6; font-style: italic; flex: 1; }
.fbm-author {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding-top: .5rem;
  border-top: 1px solid #f0f4f8;
}
.fbm-avatar {
  width: 38px; height: 38px;
  background: linear-gradient(135deg, #1e88e5, #42a5f5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.fbm-name { font-weight: 700; font-size: .8rem; color: #1a1a2e; }
.fbm-role { font-size: .7rem; color: #94a3b8; }

/* Keyframe for right-to-left marquee */
@keyframes marqueeRTL {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Footer centered fix */
.footer-bottom {
  display: flex;
  justify-content: center !important;
  text-align: center !important;
}

/* WhatsApp FAB positioning relative to chatbot */
#wa-fab { bottom: 172px !important; }

/* Professional footer-bottom improvements */
.footer-bottom .footer-copy {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: rgba(255,255,255,.55);
  font-weight: 500;
}