/* ═══════════════════════════════════════════
   DESK READY — Shared Styles (Light Theme)
   ═══════════════════════════════════════════ */
:root {
  --bg: #f8fafc;
  --surface: #ffffff;
  --card: #ffffff;
  --border: #e2e8f0;
  --border-dark: #cbd5e1;
  --text: #0f172a;
  --text-secondary: #475569;
  --muted: #94a3b8;
  --accent: #0369a1;
  --accent-light: #0ea5e9;
  --accent-bg: #f0f9ff;
  --violet: #7c3aed;
  --violet-bg: #f5f3ff;
  --gold: #d97706;
  --gold-bg: #fffbeb;
  --green: #059669;
  --green-bg: #ecfdf5;
  --red: #dc2626;
  --red-bg: #fef2f2;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}

/* ── NAVBAR ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.88);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-brand-text{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-0.3px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;padding:8px 14px;border-radius:8px;transition:all .15s}
.nav-link:hover{color:var(--text);background:var(--accent-bg)}
.nav-link.active{color:var(--accent);background:var(--accent-bg);font-weight:600}
.nav-cta{background:var(--accent);color:#fff;font-size:13px;font-weight:600;padding:8px 20px;border-radius:8px;text-decoration:none;transition:all .15s;margin-left:4px}
.nav-cta:hover{background:var(--accent-light);box-shadow:var(--shadow-md)}
.nav-hamburger{display:none;background:none;border:none;color:var(--text);font-size:24px;cursor:pointer;padding:4px}
@media(max-width:768px){
  .nav-links{position:fixed;top:64px;left:0;right:0;background:rgba(255,255,255,0.97);backdrop-filter:blur(16px);flex-direction:column;padding:12px;gap:2px;border-bottom:1px solid var(--border);transform:translateY(-120%);transition:transform .3s;z-index:999}
  .nav-links.open{transform:translateY(0)}
  .nav-hamburger{display:block}
}

/* ── DR LOGO (SVG inline) ── */
.dr-logo{width:38px;height:38px;flex-shrink:0}

/* ── PAGE HEADER ── */
.page-top{padding:100px 24px 40px;text-align:center;background:var(--surface);border-bottom:1px solid var(--border)}
.page-top .eyebrow{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.page-top h1{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-0.02em;margin-bottom:8px;color:var(--text)}
.page-top p{color:var(--text-secondary);font-size:15px;max-width:560px;margin:0 auto}

/* ── HERO (index only) ── */
.hero{position:relative;padding:120px 24px 72px;text-align:center;background:linear-gradient(180deg,var(--accent-bg) 0%,var(--bg) 100%);overflow:hidden}
.hero-grid{position:absolute;inset:0;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:32px 32px;opacity:0.4;pointer-events:none}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);color:var(--accent);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:8px 18px;border-radius:999px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
.hero h1{font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:900;line-height:1.1;letter-spacing:-0.03em;margin-bottom:20px;color:var(--text)}
.hero h1 .accent{color:var(--accent)}
.hero-sub{font-size:clamp(1rem,2vw,1.15rem);color:var(--text-secondary);max-width:620px;margin:0 auto 36px;line-height:1.75}
.hero-sub strong{color:var(--accent)}
.hero-ctas{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:56px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:10px;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s;border:none;cursor:pointer;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 12px rgba(3,105,161,0.2)}
.btn-primary:hover{background:var(--accent-light);box-shadow:0 4px 20px rgba(3,105,161,0.25);transform:translateY(-1px)}
.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-dark)}
.btn-secondary:hover{background:var(--bg);border-color:var(--text-secondary)}

/* ── STATS ── */
.stats-row{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.stat{text-align:center}
.stat-value{font-size:2.2rem;font-weight:800;letter-spacing:-0.02em;color:var(--accent)}
.stat-value.violet{color:var(--violet)}
.stat-value.gold{color:var(--gold)}
.stat-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}

/* ── SECTIONS ── */
.section{max-width:1200px;margin:0 auto;padding:72px 24px}
.section-eyebrow{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:6px}
.section-title{font-size:clamp(1.4rem,3vw,2rem);font-weight:800;letter-spacing:-0.02em;margin-bottom:6px;color:var(--text)}
.section-sub{color:var(--text-secondary);font-size:15px;margin-bottom:36px;max-width:560px}

/* ── WHY CARDS ── */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.why-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;transition:all .2s;box-shadow:var(--shadow-sm)}
.why-card:hover{box-shadow:var(--shadow-md)}
.why-card.wc-green{border-left:3px solid #10b981;background:linear-gradient(135deg,#ecfdf5 0%,var(--surface) 60%)}
.why-card.wc-gold{border-left:3px solid #d97706;background:linear-gradient(135deg,#fffbeb 0%,var(--surface) 60%)}
.why-card.wc-violet{border-left:3px solid #7c3aed;background:linear-gradient(135deg,#f5f3ff 0%,var(--surface) 60%)}
.why-card.wc-blue{border-left:3px solid #0ea5e9;background:linear-gradient(135deg,#f0f9ff 0%,var(--surface) 60%)}
.why-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:16px}
.why-icon.ic-1{background:var(--accent-bg);border:1px solid #bae6fd}
.why-icon.ic-2{background:var(--gold-bg);border:1px solid #fde68a}
.why-icon.ic-3{background:var(--green-bg);border:1px solid #a7f3d0}
.why-icon.ic-4{background:var(--violet-bg);border:1px solid #ddd6fe}
.why-card h3{font-size:15px;font-weight:700;margin-bottom:8px}
.why-card p{font-size:13.5px;color:var(--text-secondary);line-height:1.65}

/* ── PREVIEW CARDS (index) ── */
.preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.preview-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;text-decoration:none;color:var(--text);transition:all .2s;box-shadow:var(--shadow-sm);display:block}
.preview-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--border-dark)}
.preview-card.pc-blue{border-left:3px solid #0ea5e9;background:linear-gradient(135deg,#f0f9ff 0%,var(--surface) 50%)}
.preview-card.pc-green{border-left:3px solid #10b981;background:linear-gradient(135deg,#ecfdf5 0%,var(--surface) 50%)}
.preview-card.pc-violet{border-left:3px solid #7c3aed;background:linear-gradient(135deg,#f5f3ff 0%,var(--surface) 50%)}
.preview-card.pc-gold{border-left:3px solid #d97706;background:linear-gradient(135deg,#fffbeb 0%,var(--surface) 50%)}
.preview-card .card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.preview-card h3{font-size:16px;font-weight:700;margin-bottom:6px}
.preview-card p{font-size:13.5px;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}
.card-link{font-size:13px;font-weight:600;color:var(--accent)}

/* ── TICKER ── */
.ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 0;overflow:hidden;white-space:nowrap;background:var(--surface)}
.ticker-track{display:inline-flex;animation:scroll 40s linear infinite}
.ticker-item{display:inline-flex;align-items:center;gap:8px;margin-right:40px;font-size:13px;font-weight:500;color:var(--muted)}
.ticker-item .diamond{color:var(--accent);font-size:8px}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── TAB BUTTONS ── */
.tabs{display:flex;gap:4px;margin-bottom:28px;flex-wrap:wrap}
.tab-btn{padding:9px 18px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}
.tab-btn:hover{color:var(--text);border-color:var(--border-dark)}
.tab-btn.active{background:var(--accent-bg);color:var(--accent);border-color:#7dd3fc}

/* ── RECRUITER CARDS ── */
.rec-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}
.rec-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px;position:relative;transition:all .25s;box-shadow:var(--shadow-sm)}
.rec-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--border-dark)}
.rec-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.rec-name{font-size:16px;font-weight:700}
.rec-region{font-size:10px;font-weight:700;letter-spacing:1px;padding:4px 10px;border-radius:999px;text-transform:uppercase;flex-shrink:0}
.rg-us{background:var(--green-bg);color:var(--green);border:1px solid #a7f3d0}
.rg-uk{background:var(--gold-bg);color:var(--gold);border:1px solid #fde68a}
.rg-gl{background:var(--violet-bg);color:var(--violet);border:1px solid #ddd6fe}
.rec-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:14px}
.rec-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tag{font-size:11px;padding:3px 10px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}
.t-hf{border-color:#7dd3fc;color:var(--accent);background:var(--accent-bg)}
.t-pe{border-color:#ddd6fe;color:var(--violet);background:var(--violet-bg)}
.t-am{border-color:#fde68a;color:var(--gold);background:var(--gold-bg)}
.t-qt{border-color:#a7f3d0;color:var(--green);background:var(--green-bg)}
.rec-contact{border-top:1px solid var(--border);padding-top:14px}
.rec-contact h4{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.c-row{display:flex;align-items:center;gap:8px;font-size:13px;margin-bottom:7px}
.c-row a{text-decoration:none;transition:all .15s}
.c-row a:hover{text-decoration:underline}
.c-row a[href^="http"]{color:#7c3aed;font-weight:600}
.c-row a[href^="http"]:hover{color:#5b21b6}
.c-row a[href^="mailto"]{color:#d97706;font-weight:600}
.c-row a[href^="mailto"]:hover{color:#b45309}
.c-row.c-web .c-icon{background:var(--violet-bg);color:#7c3aed;width:26px;height:26px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;border:1px solid #ddd6fe}
.c-row.c-email .c-icon{background:var(--gold-bg);color:#d97706;width:26px;height:26px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;border:1px solid #fde68a}
.c-row.c-loc .c-icon{background:var(--accent-bg);color:var(--accent);width:26px;height:26px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;border:1px solid #bae6fd}
.rec-desc strong.rec-highlight{color:var(--text);font-weight:700}

/* ── PAGE ACCENT COLORS ── */
.page-top.pg-recruiters{background:linear-gradient(180deg,#ecfdf5 0%,var(--bg) 100%);border-bottom-color:#a7f3d0}
.page-top.pg-cv{background:linear-gradient(180deg,#f5f3ff 0%,var(--bg) 100%);border-bottom-color:#ddd6fe}
.page-top.pg-insights{background:linear-gradient(180deg,#f0f9ff 0%,var(--bg) 100%);border-bottom-color:#bae6fd}
.page-top.pg-coding{background:linear-gradient(180deg,#fffbeb 0%,var(--bg) 100%);border-bottom-color:#fde68a}
.page-top.pg-jobs{background:linear-gradient(180deg,#f0fdfa 0%,var(--bg) 100%);border-bottom-color:#99f6e4}
.page-top.pg-mentor{background:linear-gradient(180deg,#ecfdf5 0%,var(--bg) 100%);border-bottom-color:#a7f3d0}
.page-top.pg-outreach{background:linear-gradient(180deg,#fff7ed 0%,var(--bg) 100%);border-bottom-color:#fed7aa}

/* ── TAG FILTER DROPDOWN ── */
.filter-bar{display:flex;gap:12px;margin-bottom:28px;flex-wrap:wrap;align-items:center}
.filter-bar label{font-size:13px;font-weight:600;color:var(--text-secondary)}
.filter-select{padding:9px 36px 9px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:13px;font-weight:600;font-family:inherit;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:border-color .15s}
.filter-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(14,165,233,0.12)}
.c-icon{width:16px;text-align:center;font-size:13px;flex-shrink:0}
.rec-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}
.tier-badge{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 9px;border-radius:5px}
.tier-top{background:var(--gold-bg);color:var(--gold);border:1px solid #fde68a}
.tier-uk{background:var(--gold-bg);color:var(--gold);border:1px solid #fde68a}
.tier-sr{background:var(--violet-bg);color:var(--violet);border:1px solid #ddd6fe}

/* ── CV SECTION ── */
.cv-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.cv-tab{padding:10px 18px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}
.cv-tab:hover{color:var(--text);border-color:var(--border-dark)}
.cv-tab.active{background:var(--accent-bg);border-color:#7dd3fc;color:var(--accent)}
.cv-panel{display:none}
.cv-panel.active{display:block}
.cv-doc{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:36px 40px;max-width:800px;box-shadow:var(--shadow-md)}
.cv-disclaimer{background:var(--gold-bg);border:1px solid #fde68a;border-radius:10px;padding:12px 16px;font-size:12px;color:var(--gold);margin-bottom:24px;display:flex;align-items:center;gap:8px}
.cv-header{margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.cv-header h2{font-size:1.3rem;font-weight:800;margin-bottom:4px}
.cv-header p{font-size:13px;color:var(--text-secondary)}
.cv-section-title{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin:22px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.cv-entry{margin-bottom:16px}
.cv-entry-head{display:flex;justify-content:space-between;flex-wrap:wrap;gap:4px;margin-bottom:3px}
.cv-role{font-size:14px;font-weight:700}
.cv-date{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.cv-company{font-size:13px;color:var(--text-secondary);margin-bottom:5px}
.cv-bullets{list-style:none;padding-left:0}
.cv-bullets li{font-size:13px;color:var(--text-secondary);line-height:1.65;padding:3px 0 3px 18px;position:relative}
.cv-bullets li::before{content:'';position:absolute;left:0;top:11px;width:5px;height:5px;border-radius:50%;background:var(--border-dark)}
.cv-skills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.cv-skill{font-size:12px;padding:4px 12px;border-radius:6px;background:var(--accent-bg);border:1px solid #bae6fd;color:var(--accent)}

/* ── TIPS BOX ── */
.tips-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:36px;box-shadow:var(--shadow-sm)}
.tips-box h3{font-size:18px;font-weight:700;margin-bottom:20px;color:var(--accent)}
.tips-list{list-style:none}
.tips-list li{font-size:14px;color:var(--text);padding:10px 0;border-bottom:1px solid var(--border);display:flex;gap:12px;line-height:1.65}
.tips-list li:last-child{border-bottom:none}
.tip-num{color:var(--accent);font-weight:700;font-family:'JetBrains Mono',monospace;font-size:13px;flex-shrink:0;width:24px}

/* ── FORM SECTION ── */
.join-wrap{background:var(--surface);border-top:1px solid var(--border)}
.join-inner{max-width:1200px;margin:0 auto;padding:72px 24px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:768px){.join-inner{grid-template-columns:1fr;gap:40px}}
.join-left h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-0.02em;margin-bottom:12px}
.join-left h2 .accent{color:var(--accent)}
.join-left>p{color:var(--text-secondary);font-size:15px;line-height:1.7;margin-bottom:20px}
.join-perks{list-style:none}
.join-perks li{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;color:var(--text)}
.perk-check{width:22px;height:22px;border-radius:6px;background:var(--green-bg);border:1px solid #a7f3d0;display:flex;align-items:center;justify-content:center;color:var(--green);font-size:12px;flex-shrink:0}
.form-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:36px;box-shadow:var(--shadow-md)}
.form-card h3{font-size:18px;font-weight:700;margin-bottom:4px}
.form-card .form-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
.form-row{margin-bottom:16px}
.form-row label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .15s;outline:none}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(14,165,233,0.12)}
.form-row input::placeholder,.form-row textarea::placeholder{color:var(--muted)}
.form-row select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:500px){.form-grid-2{grid-template-columns:1fr}}
.form-submit{width:100%;padding:13px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;margin-top:8px}
.form-submit:hover{background:var(--accent-light);box-shadow:0 4px 20px rgba(3,105,161,0.2);transform:translateY(-1px)}
.form-submit:disabled{opacity:0.5;cursor:not-allowed;transform:none;box-shadow:none}
.form-success{display:none;text-align:center;padding:32px}
.form-success.show{display:block}
.form-success .check{width:56px;height:56px;border-radius:50%;background:var(--green-bg);border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 16px}
.form-success h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--green)}
.form-success p{font-size:14px;color:var(--text-secondary)}

/* ── MARKET INSIGHTS ── */
.market-grid{display:grid;grid-template-columns:1fr;gap:24px}
.market-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:var(--shadow-sm)}
.market-card h2{font-size:18px;font-weight:800;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.market-card .card-badge{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:999px}
.badge-rates{background:var(--accent-bg);color:var(--accent);border:1px solid #7dd3fc}
.badge-equities{background:var(--green-bg);color:var(--green);border:1px solid #a7f3d0}
.badge-credit{background:var(--violet-bg);color:var(--violet);border:1px solid #ddd6fe}
.badge-fx{background:var(--gold-bg);color:var(--gold);border:1px solid #fde68a}
.market-card>p.card-sub{font-size:13px;color:var(--muted);margin-bottom:20px}
.market-card h3{font-size:14px;font-weight:700;margin:20px 0 10px;color:var(--text)}
.market-card ul{list-style:none;padding:0}
.market-card li{font-size:14px;color:var(--text-secondary);line-height:1.7;padding:6px 0 6px 20px;position:relative;border-bottom:1px solid rgba(0,0,0,0.03)}
.market-card li:last-child{border-bottom:none}
.market-card li::before{content:'';position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%}
.market-card.rates li::before{background:var(--accent)}
.market-card.equities li::before{background:var(--green)}
.market-card.credit li::before{background:var(--violet)}
.market-card.fx li::before{background:var(--gold)}
.metric-row{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}
.metric{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 18px;flex:1;min-width:140px}
.metric-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.metric-value{font-size:20px;font-weight:800;color:var(--text)}
.metric-delta{font-size:12px;font-weight:600;margin-left:6px}
.delta-up{color:var(--green)}
.delta-down{color:var(--red)}
.market-disclaimer{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 18px;font-size:12px;color:var(--muted);margin-top:12px;line-height:1.6}
.updated-badge{font-size:12px;color:var(--muted);margin-bottom:24px}

/* ── FOOTER ── */
.footer{border-top:1px solid var(--border);padding:40px 24px;text-align:center;background:var(--surface)}
.footer-brand{font-size:18px;font-weight:800;margin-bottom:8px;color:var(--text)}
.footer-brand .accent{color:var(--accent)}
.footer p{font-size:12px;color:var(--muted);max-width:480px;margin:0 auto}
.footer-links{display:flex;justify-content:center;gap:20px;margin-top:16px}
.footer-links a{color:var(--muted);font-size:13px;text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--accent)}

/* ── CODING HUB ── */
.hub-intro{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;margin-bottom:32px;box-shadow:var(--shadow-sm)}
.hub-intro h2{font-size:18px;font-weight:800;margin-bottom:8px}
.hub-intro p{font-size:14px;color:var(--text-secondary);line-height:1.7}
.hub-intro ul{list-style:none;margin-top:16px}
.hub-intro li{font-size:14px;padding:6px 0;display:flex;align-items:center;gap:10px;color:var(--text)}
.hub-intro li span{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}

.project-tabs{display:flex;gap:6px;margin-bottom:32px;flex-wrap:wrap}
.project-tab{padding:12px 20px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;text-align:left;display:flex;align-items:center;gap:10px;flex:1;min-width:220px}
.project-tab:hover{color:var(--text);border-color:var(--border-dark)}
.project-tab.active{background:var(--accent-bg);border-color:#7dd3fc;color:var(--accent)}
.project-tab .tab-num{width:28px;height:28px;border-radius:8px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;flex-shrink:0}
.project-tab.active .tab-num{background:var(--accent);color:#fff;border-color:var(--accent)}
.project-panel{display:none}
.project-panel.active{display:block}

.project-header{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 32px;margin-bottom:24px;box-shadow:var(--shadow-sm)}
.project-header h2{font-size:20px;font-weight:800;margin-bottom:6px}
.project-header>p{font-size:14px;color:var(--text-secondary);line-height:1.6}
.project-meta{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.meta-item{font-size:12px;padding:5px 12px;border-radius:8px;display:flex;align-items:center;gap:6px;font-weight:600}
.meta-difficulty{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.meta-time{background:var(--accent-bg);color:var(--accent);border:1px solid #bae6fd}
.meta-stack{background:var(--violet-bg);color:var(--violet);border:1px solid #ddd6fe}
.meta-impact{background:var(--green-bg);color:var(--green);border:1px solid #a7f3d0}

.step-block{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px 32px;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.step-block h3{font-size:16px;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.step-block h3 .sn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:var(--accent);color:#fff;font-size:12px;font-weight:700;flex-shrink:0}
.step-block>p{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-bottom:12px}

pre.code-block{background:#1e293b;color:#e2e8f0;border-radius:10px;padding:20px;overflow-x:auto;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.7;margin:12px 0;border:1px solid #334155}
pre.code-block .comment{color:#64748b}
pre.code-block .keyword{color:#7dd3fc}
pre.code-block .string{color:#86efac}
pre.code-block .func{color:#c4b5fd}
.code-filename{display:inline-block;background:#334155;color:#94a3b8;font-size:11px;font-weight:600;padding:4px 12px;border-radius:6px 6px 0 0;font-family:'JetBrains Mono',monospace;margin-bottom:-1px;position:relative;z-index:1}

.cv-bullet-box{background:var(--green-bg);border:1px solid #a7f3d0;border-radius:12px;padding:20px 24px;margin-top:20px}
.cv-bullet-box h4{font-size:13px;font-weight:700;color:var(--green);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.cv-bullet-box p{font-size:13px;color:var(--text-secondary);line-height:1.6;font-style:italic}

.data-table{width:100%;border-collapse:collapse;font-size:13px;margin:12px 0;border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.data-table th{background:var(--bg);font-weight:600;text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:0.5px}
.data-table td{padding:8px 14px;border-bottom:1px solid var(--border);color:var(--text)}
.data-table tr:last-child td{border-bottom:none}

.extension-box{background:var(--violet-bg);border:1px solid #ddd6fe;border-radius:12px;padding:20px 24px;margin-top:20px}
.extension-box h4{font-size:13px;font-weight:700;color:var(--violet);margin-bottom:8px}
.extension-box ul{list-style:disc;padding-left:20px}
.extension-box li{font-size:13px;color:var(--text-secondary);line-height:1.6;padding:2px 0}

/* ── CODE WALKTHROUGH ENGINE ── */
.walkthrough{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow-md)}
.wt-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--bg);border-bottom:1px solid var(--border)}
.wt-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.wt-title .wt-icon{width:24px;height:24px;border-radius:6px;background:var(--green-bg);border:1px solid #a7f3d0;display:flex;align-items:center;justify-content:center;font-size:12px}
.wt-controls{display:flex;align-items:center;gap:8px}
.wt-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .15s;font-family:inherit}
.wt-btn:hover{background:var(--accent-bg);border-color:#7dd3fc;color:var(--accent)}
.wt-btn.playing{background:var(--green);border-color:var(--green);color:#fff}
.wt-progress{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.wt-body{display:grid;grid-template-columns:1fr 1fr;min-height:320px}
@media(max-width:768px){.wt-body{grid-template-columns:1fr;grid-template-rows:auto auto}}
.wt-code{background:#1e293b;padding:20px;overflow:auto;max-height:420px;position:relative}
.wt-code pre{font-family:'JetBrains Mono',monospace;font-size:12.5px;line-height:1.8;color:#e2e8f0;white-space:pre;margin:0}
.wt-code .wt-line{opacity:0.2;transition:opacity .3s}
.wt-code .wt-line.active{opacity:1}
.wt-code .wt-line.done{opacity:0.65}
.wt-code .wt-line.highlight{opacity:1;background:rgba(0,200,255,0.08);margin:0 -20px;padding:0 20px;border-left:3px solid var(--accent);display:block}
.wt-line-num{color:#475569;user-select:none;display:inline-block;width:28px;text-align:right;margin-right:16px;font-size:11px}
.wt-explain{padding:24px;overflow:auto;max-height:420px;border-left:1px solid var(--border)}
@media(max-width:768px){.wt-explain{border-left:none;border-top:1px solid var(--border)}}
.wt-step{display:none;animation:wtFade .3s ease}
.wt-step.active{display:block}
@keyframes wtFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.wt-step h4{font-size:14px;font-weight:700;margin-bottom:8px;color:var(--accent)}
.wt-step p{font-size:13.5px;color:var(--text-secondary);line-height:1.7;margin-bottom:10px}
.wt-step code{background:var(--bg);padding:2px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text)}
.wt-step .wt-tip{background:var(--green-bg);border:1px solid #a7f3d0;border-radius:8px;padding:10px 14px;font-size:12.5px;color:var(--green);margin-top:10px;line-height:1.6}
.wt-progressbar{height:3px;background:var(--border);width:100%}
.wt-progressbar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--green));transition:width .3s;width:0%}

@media(max-width:768px){
  .project-tabs{flex-direction:column}
  .step-block{padding:20px}
  pre.code-block{font-size:11.5px;padding:14px}
}

/* ── CV DOWNLOAD BUTTON ── */
.cv-download{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:8px 18px;border-radius:8px;border:1px solid var(--border-dark);background:var(--surface);color:var(--accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}
.cv-download:hover{background:var(--accent-bg);border-color:#7dd3fc}
@media print{
  .nav,.cv-tabs,.cv-disclaimer,.cv-download,.footer,.popup-overlay{display:none!important}
  .cv-doc{border:none!important;box-shadow:none!important;padding:0!important;max-width:100%!important}
  .page-top{padding-top:20px!important}
  body{background:#fff!important}
}

/* ── POPUP / MODAL ── */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.popup-overlay.show{opacity:1;pointer-events:auto}
.popup-box{background:var(--surface);border-radius:20px;padding:40px;max-width:420px;width:90%;text-align:center;box-shadow:0 16px 48px rgba(0,0,0,0.15);transform:translateY(20px);transition:transform .3s}
.popup-overlay.show .popup-box{transform:translateY(0)}
.popup-close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s}
.popup-close:hover{color:var(--text)}
.popup-box{position:relative}
.popup-icon{width:56px;height:56px;border-radius:16px;background:var(--accent-bg);border:1px solid #bae6fd;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 18px}
.popup-box h2{font-size:20px;font-weight:800;margin-bottom:8px}
.popup-box p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}
.popup-box .btn{width:100%;justify-content:center}
.popup-skip{display:block;margin-top:12px;font-size:13px;color:var(--muted);cursor:pointer;background:none;border:none;font-family:inherit;transition:color .15s}
.popup-skip:hover{color:var(--text)}

/* ── FADE ANIMATION (legacy, now handled by AOS) ── */
.fade-up{opacity:1;transform:none}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .hero{padding:100px 20px 56px}
  .stats-row{gap:24px}
  .stat-value{font-size:1.6rem}
  .section{padding:56px 20px}
  .rec-grid{grid-template-columns:1fr}
  .cv-doc{padding:24px 20px}
  .join-inner{padding:56px 20px}
}
