@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --indigo:#6366F1;--indigo2:#818CF8;--indigo3:#EEF2FF;--indigo4:#C7D2FE;
  --brand-dark:#023448;--brand-teal:#1b485a;
  --dark:#0d1526;--mid:#1b485a;--text:#475569;--muted:#94a3b8;
  --border:#E2E8F0;--bg:#F8FAFC;--white:#fff;--surface:#fff;
  --green:#10B981;--red:#EF4444;--gold:#F59E0B;
  --r:'Space Grotesk',sans-serif;--b:'Inter',sans-serif;
  --radius:12px;--radius-sm:8px;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -1px rgba(0,0,0,.04);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -2px rgba(0,0,0,.04);
}
body{font-family:var(--b);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}

/* ── LOCATION GEO ─────────────────────────────────────────── */
.location-geo-label{font-size:13px;font-weight:600;color:var(--indigo);margin-bottom:10px;display:flex;align-items:center;gap:6px;border-left:3px solid var(--indigo);padding-left:10px;letter-spacing:.3px}
.info-box{background:var(--indigo3);border:1px solid var(--indigo4);border-radius:var(--radius-sm);padding:12px 16px;font-size:13px;color:var(--indigo);display:flex;align-items:flex-start;gap:8px;margin-bottom:16px}
.info-box i{flex-shrink:0;margin-top:2px;font-size:16px}
.check-label{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer;padding:6px 12px;border:1px solid var(--border);border-radius:20px;background:#fff;transition:all .15s;user-select:none}
.check-label:hover{border-color:var(--indigo4);background:var(--indigo3);color:var(--indigo)}
.check-label input[type=checkbox]{accent-color:var(--indigo);width:14px;height:14px}
.filter-select-province{font-weight:500;min-width:160px}
.province-badge{display:inline-flex;align-items:center;gap:4px;background:var(--indigo3);color:var(--indigo);border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600;letter-spacing:.3px}
.job-location-line{font-size:13px;color:var(--muted);margin:3px 0 6px;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.job-location-line strong{color:var(--text);font-weight:600}
.job-location-detail{margin-bottom:4px}
.detail-location-text{font-size:14px;color:var(--muted);display:inline-flex;align-items:center;gap:5px}
.detail-location-text strong{color:var(--text);font-weight:600}
.loc-remote{color:#059669;font-weight:500}
.loc-hybrid{color:var(--gold);font-weight:500}
a{text-decoration:none;color:inherit}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── NAV ──────────────────────────────────────────────────── */
.nav{background:#0d1526;backdrop-filter:blur(12px);position:sticky;top:0;z-index:100}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;gap:0}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;margin-right:40px}
.logo-mark{width:34px;height:34px;flex-shrink:0}
.logo-word{font-family:var(--r);font-size:20px;font-weight:700;color:#fff;letter-spacing:-.4px;line-height:1}
.logo-word em{font-style:normal;color:var(--indigo)}

/* ── SCROLL REVEAL ────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-stagger>*{opacity:0;transform:translateY(20px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1)}
.reveal-stagger.visible>*{opacity:1;transform:translateY(0)}
.reveal-stagger.visible>*:nth-child(1){transition-delay:.05s}
.reveal-stagger.visible>*:nth-child(2){transition-delay:.1s}
.reveal-stagger.visible>*:nth-child(3){transition-delay:.15s}
.reveal-stagger.visible>*:nth-child(4){transition-delay:.2s}
.reveal-stagger.visible>*:nth-child(5){transition-delay:.25s}
.reveal-stagger.visible>*:nth-child(6){transition-delay:.3s}
.reveal-stagger.visible>*:nth-child(7){transition-delay:.35s}
.reveal-stagger.visible>*:nth-child(8){transition-delay:.4s}
.nav-links{display:flex;gap:2px;flex:1}
.nav-link{padding:6px 14px;border-radius:8px;font-size:14px;color:rgba(255,255,255,.7);cursor:pointer;transition:all .15s;white-space:nowrap;font-weight:500}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-actions{display:flex;gap:10px;align-items:center;margin-left:auto}
/* ── Hamburger (hidden on desktop) ── */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:1100;margin-left:8px;flex-shrink:0}
.hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.85);border-radius:2px;transition:all .25s ease;transform-origin:center}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* Mobile close btn + auth — hidden on desktop */
.nav-mob-close{display:none}
.nav-mob-auth{display:none}
.nav-mob-btn{text-decoration:none}
/* ── Categories dropdown toggle (mobile only) ── */
.cat-dropdown-toggle{
  display:none;width:100%;align-items:center;justify-content:space-between;
  padding:14px 18px;border-radius:12px;border:1px solid var(--border);
  background:var(--surface,#fff);color:var(--text);font-size:15px;font-weight:600;
  cursor:pointer;font-family:var(--b);margin-bottom:4px;
}
.cat-toggle-chevron{transition:transform .25s ease;font-size:18px;opacity:.6}
.cat-dropdown-toggle.active .cat-toggle-chevron{transform:rotate(180deg)}
.lang-toggle{display:flex;border:1px solid rgba(255,255,255,.2);border-radius:8px;overflow:hidden;font-size:12px}
.lang-btn{padding:5px 10px;cursor:pointer;color:rgba(255,255,255,.6);background:transparent;border:none;font-family:var(--b);font-weight:500;transition:all .15s}
.lang-btn.active{background:rgba(255,255,255,.15);color:#fff}
.notif-bell{position:relative;width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:rgba(255,255,255,.7);transition:all .15s}
.notif-bell:hover{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.3)}
.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:100px;align-items:center;justify-content:center;padding:0 4px}
.notif-badge:empty{display:none!important}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn-ghost{padding:8px 18px;border-radius:8px;font-size:14px;cursor:pointer;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;font-family:var(--b);font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.4)}
.btn-primary{padding:8px 20px;border-radius:8px;font-size:14px;cursor:pointer;border:none;background:var(--indigo);color:#fff;font-family:var(--b);font-weight:600;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary:hover{background:#4F46E5;transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,102,241,.3)}
.btn-primary:active{transform:translateY(0)}
.btn-lg{padding:12px 28px;font-size:15px;border-radius:10px}
.btn-full{width:100%;justify-content:center}
.btn-link{background:none;border:none;color:var(--indigo);font-size:14px;cursor:pointer;font-family:var(--b);font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:4px 0}
.btn-link:hover{text-decoration:underline}

/* ── USER MENU ────────────────────────────────────────────── */
.user-menu{display:flex;align-items:center;gap:6px;cursor:pointer;padding:6px 12px;border-radius:8px;border:1px solid var(--border);position:relative;background:#fff}
.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:6px;min-width:200px;display:none;z-index:200;box-shadow:var(--shadow-lg)}
.user-dropdown.open{display:block;animation:fadeIn .15s ease}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;font-size:13px;cursor:pointer;color:var(--text);transition:background .1s}
.dropdown-item:hover{background:var(--indigo3);color:var(--indigo)}
.dropdown-item i{font-size:16px}
.dropdown-divider{height:1px;background:var(--border);margin:4px 0}

/* ── PAGES ────────────────────────────────────────────────── */
.page{display:none;animation:fadeIn .2s ease}
.page.active{display:block}

/* ── HERO ─────────────────────────────────────────────────── */
.hero{background:var(--dark);padding:96px 24px 80px;text-align:center;position:relative;overflow:hidden}
.hero-bg{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;pointer-events:none}
.hbg-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease;transform:scale(1.05);transition:opacity 1.2s ease,transform 9s ease}
.hbg-slide.hbg-on{opacity:1;transform:scale(1)}
.hbg-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,18,40,.88) 0%,rgba(10,18,40,.72) 60%,rgba(10,18,40,.55) 100%)}
.hero-inner{max-width:820px;margin:0 auto;position:relative}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(99,102,241,.15);border:1px solid rgba(99,102,241,.3);border-radius:100px;padding:6px 16px;font-size:13px;color:var(--indigo2);font-weight:500;margin-bottom:24px}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--indigo2);animation:pulse 2s infinite}
.hero-title{font-family:var(--r);font-size:clamp(36px,6vw,64px);font-weight:700;color:#fff;line-height:1.15;letter-spacing:-1px;margin-bottom:20px}
.hero-title em{font-style:normal;color:var(--indigo2)}
.hero-sub{font-size:18px;color:#94A3B8;margin-bottom:40px;max-width:600px;margin-left:auto;margin-right:auto}
.search-bar{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:14px;padding:8px;display:flex;gap:4px;max-width:780px;margin:0 auto 20px;backdrop-filter:blur(8px)}
.search-field{flex:1;display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(255,255,255,.15);border-radius:10px;min-width:0}
.search-field i{color:rgba(255,255,255,.7);font-size:16px;flex-shrink:0}
.search-field input,.search-field select{background:none;border:none;outline:none;color:#fff;font-family:var(--b);font-size:14px;width:100%;min-width:0}
.search-field input::placeholder{color:rgba(255,255,255,.55)}
.search-field select{color:#fff;cursor:pointer}
.search-field select option{background:var(--mid);color:#fff}
.search-loc{flex:.8}
.search-mode{flex:.6}
.search-btn{border-radius:10px;padding:10px 22px;white-space:nowrap;flex-shrink:0}
.quick-tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.qtag{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:100px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#CBD5E1;font-size:13px;cursor:pointer;transition:all .18s;font-weight:500}
.qtag i{font-size:14px}
.qtag:hover{background:rgba(99,102,241,.25);border-color:rgba(99,102,241,.5);color:#fff;transform:translateY(-1px)}

/* ── CATEGORIES SECTION ───────────────────────────────────── */
.categories-section{padding:56px 0;background:#fff}
.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:4px}
.cat-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border:1.5px solid var(--border);border-radius:14px;cursor:pointer;transition:all .18s;background:#fff}
.cat-card:hover{border-color:var(--indigo);box-shadow:0 4px 16px rgba(99,102,241,.12);transform:translateY(-2px)}
.cat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.cat-info{flex:1;min-width:0}
.cat-name{font-size:14px;font-weight:600;color:var(--dark);line-height:1.3}
.cat-sub{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-arrow{font-size:16px;color:var(--muted);flex-shrink:0;transition:transform .18s}
.cat-card:hover .cat-arrow{transform:translateX(3px);color:var(--indigo)}

/* ── SKILL PICKER (profile) ───────────────────────────────── */
.skill-picker{display:flex;flex-direction:column;gap:20px;padding:18px;background:#F8FAFC;border:1.5px solid var(--border);border-radius:14px;margin-top:6px}
.sp-group{}
.sp-group-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.sp-group-label i{font-size:13px}
.sp-chips{display:flex;flex-wrap:wrap;gap:7px}
.sp-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:8px;background:#fff;border:1.5px solid var(--border);font-size:12px;font-weight:500;color:#475569;cursor:pointer;transition:all .15s;user-select:none}
.sp-chip:hover{border-color:#A5B4FC;color:var(--indigo)}
.sp-chip.active{background:#EEF2FF;border-color:var(--indigo);color:var(--indigo);font-weight:600}
.sp-logo{width:16px;height:16px;object-fit:contain;flex-shrink:0}
.sp-badge{width:22px;height:18px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;letter-spacing:-.2px;flex-shrink:0}
.sp-custom-wrap{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border:1.5px dashed var(--border);border-radius:8px;margin-top:4px}
.sp-custom-icon{color:var(--muted);font-size:15px}
.sp-custom-input{flex:1;border:none;outline:none;font-size:12px;font-family:inherit;color:var(--dark);background:transparent}
.sp-custom-input::placeholder{color:#94A3B8}
.sp-custom-chip{background:#F0FDF4;border-color:#86EFAC;color:#15803D}
.sp-custom-chip.active{background:#F0FDF4;border-color:#86EFAC;color:#15803D}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.hstat{padding:0 32px;text-align:center}
.hstat-n{font-family:var(--r);font-size:28px;font-weight:700;color:#fff;letter-spacing:-.5px}
.hstat-l{font-size:13px;color:#64748B;margin-top:2px}
.hstat-div{width:1px;height:40px;background:rgba(255,255,255,.1)}
.employer-hero{background:linear-gradient(135deg,#0d1526 0%,#1b485a 100%)}

/* ── SECTIONS ─────────────────────────────────────────────── */
.section-inner{max-width:1280px;margin:0 auto;padding:0 24px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.section-header h2{font-family:var(--r);font-size:24px;font-weight:700;color:var(--dark)}
.featured-section{padding:64px 0}
.features-section{padding:64px 0;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* ── JOB CARDS ────────────────────────────────────────────── */
.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.job-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all .2s;position:relative}
.job-card:hover{border-color:var(--indigo4);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.job-card.featured{border-color:var(--indigo4);background:linear-gradient(135deg,#fff 0%,var(--indigo3) 100%)}
.job-featured-badge{position:absolute;top:12px;right:44px;background:var(--indigo);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:100px;letter-spacing:.5px;text-transform:uppercase}
.save-btn{position:absolute;top:10px;right:10px;background:none;border:1px solid var(--border);border-radius:8px;padding:5px 8px;cursor:pointer;color:var(--muted);font-size:14px;transition:all .15s;display:flex;align-items:center;justify-content:center;z-index:2}
.save-btn:hover,.save-btn.saved{border-color:var(--red);color:var(--red);background:#FFF1F2}
.save-btn.saved{color:var(--red)}
.job-company-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;margin-top:8px}
.company-logo{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}
.company-name{font-size:13px;color:var(--muted);font-weight:500}
.job-title{font-family:var(--r);font-size:16px;font-weight:600;color:var(--dark);margin-bottom:8px;line-height:1.3}
.job-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.job-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:500;background:var(--bg);border:1px solid var(--border);color:var(--muted)}
.job-tag.remote{background:#DCFCE7;border-color:#BBF7D0;color:#15803D}
.job-tag.hybrid{background:#FEF3C7;border-color:#FDE68A;color:#92400E}
.job-tag.onsite{background:var(--indigo3);border-color:var(--indigo4);color:#4338CA}
.salary-tag{color:var(--indigo)!important;background:var(--indigo3)!important;border-color:var(--indigo4)!important}
.job-salary{font-size:13px;font-weight:600;color:var(--indigo);margin-top:10px}

/* ── FEATURES ─────────────────────────────────────────────── */
.features-section{padding:72px 0;background:#f8f9fb;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.feature-card{padding:32px 28px;border:1px solid #e5e9f0;border-radius:16px;background:#fff;transition:all .22s;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.feature-card:hover{border-color:#c7d4f5;box-shadow:0 6px 20px rgba(0,0,0,.08);transform:translateY(-3px)}
.feature-icon-sm{width:40px;height:40px;border-radius:10px;border:1px solid #e5e9f0;background:#f8f9fb;display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:18px;color:#6366f1}
.feature-card h3{font-family:var(--r);font-size:15px;font-weight:700;color:var(--dark);margin-bottom:10px}
.feature-card p{color:var(--muted);font-size:13.5px;line-height:1.65}

/* ── BENTO SPLIT SECTION ──────────────────────────────────── */
.bento-section{overflow:hidden}
.bento-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:380px 300px}
.bento-cell{padding:56px 60px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.bento-dark{background:#6366F1}
.bento-light{background:#f4f6f8}
.bento-teal{background:#022837}
.bento-photo{padding:0;overflow:hidden}
.bento-photo img{width:100%;height:100%;object-fit:cover;display:block}
.bento-label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#4ecdc4}
.bento-label-accent{color:#6366f1}
.bento-heading{font-family:var(--r);font-size:30px;font-weight:700;color:#fff;line-height:1.2;margin:0}
.bento-heading-dark{color:var(--dark)}
.bento-desc{font-size:14.5px;color:rgba(255,255,255,.72);line-height:1.65;max-width:400px;margin:0}
.bento-desc-dark{color:var(--muted)}
.btn-bento{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:8px;background:#fff;color:#023448;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s;width:fit-content;font-family:var(--b)}
.btn-bento:hover{background:#e8f0fe;transform:translateX(3px)}
.btn-bento-dark{background:#023448;color:#fff;border:1.5px solid rgba(255,255,255,.15)}
.btn-bento-dark:hover{background:#1b485a;transform:translateX(3px)}

/* ── PRICING ──────────────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.pricing-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:32px;position:relative}
.pricing-card-pro{border-color:var(--indigo);box-shadow:0 0 0 2px var(--indigo3)}
.pricing-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--indigo);color:#fff;font-size:12px;font-weight:700;padding:4px 16px;border-radius:100px;white-space:nowrap}
.pricing-name{font-family:var(--r);font-size:18px;font-weight:700;color:var(--dark);margin-bottom:8px}
.pricing-price{font-family:var(--r);font-size:40px;font-weight:800;color:var(--dark);line-height:1}
.pricing-period{font-size:13px;color:var(--muted);margin-bottom:24px;margin-top:4px}
.pricing-features{list-style:none;margin-bottom:28px}
.pricing-features li{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;border-bottom:1px solid var(--border)}
.pricing-features li:last-child{border:none}
.pricing-features .ti-check{color:var(--green);font-size:16px}
.pricing-features .ti-x{color:var(--border);font-size:16px}
.pricing-features .muted{color:var(--muted)}

/* ── JOBS PAGE ────────────────────────────────────────────── */
.page-header-bar{background:#fff;border-bottom:1px solid var(--border);padding:24px 0}
.page-title{font-family:var(--r);font-size:28px;font-weight:700;color:var(--dark);margin-bottom:16px}
.filters-bar{display:flex;flex-direction:column;gap:10px}
.filters-search-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.filters-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.filters-search-btn{white-space:nowrap;padding:9px 20px;font-size:14px}
.filter-input{padding:8px 14px;border:1px solid var(--border);border-radius:8px;font-family:var(--b);font-size:14px;outline:none;background:#fff;min-width:240px;flex:1;transition:border .15s}
.filter-input:focus{border-color:var(--indigo)}
.filter-select{padding:8px 14px;border:1px solid var(--border);border-radius:8px;font-family:var(--b);font-size:14px;outline:none;background:#fff;cursor:pointer;transition:border .15s}
.filter-select:focus{border-color:var(--indigo)}
.jobs-page-layout{display:flex;gap:24px;padding-top:24px;padding-bottom:48px}
.jobs-list-col{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}
.job-list-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;cursor:pointer;transition:border-color .15s,box-shadow .15s;display:block;margin-bottom:10px}
.job-list-item:hover,.job-list-item.selected{border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo3)}
/* Jobs page v2 — sidebar layout */
.jobs-search-hdr{background:#fff;border-bottom:1px solid var(--border);padding:16px 0}
.jobs-search-row{display:flex;gap:10px;align-items:center}
.jobs-search-field{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:8px;padding:0 12px;flex:1;transition:border-color .15s;min-width:0}
.jobs-search-field:focus-within{border-color:var(--indigo)}
.jobs-search-field i{color:var(--muted);font-size:15px;flex-shrink:0}
.jobs-search-field input,.jobs-search-field select{border:none;outline:none;font-family:var(--b);font-size:14px;background:transparent;flex:1;padding:9px 0;color:var(--text);min-width:0;cursor:pointer}
.jobs-search-field-loc{max-width:230px;flex:0 0 230px}
.jobs-search-btn{white-space:nowrap;flex-shrink:0;padding:9px 20px}
.jobs-page-v2{display:flex;gap:24px;padding-top:24px;padding-bottom:48px;align-items:flex-start}
.jobs-sidebar{width:256px;flex-shrink:0;position:sticky;top:76px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.jf-group{padding:14px 16px;border-bottom:1px solid var(--border)}
.jf-group:last-child{border-bottom:none}
.jf-group-hdr{font-weight:700;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.jf-radio-list{display:flex;flex-direction:column;gap:7px}
.jf-radio{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13.5px;color:var(--text)}
.jf-radio input{accent-color:var(--indigo);width:15px;height:15px;cursor:pointer;flex-shrink:0}
.jf-select{width:100%;padding:7px 8px;border:1px solid var(--border);border-radius:7px;font-family:var(--b);font-size:13px;outline:none;background:#fff;cursor:pointer;color:var(--text)}
.jf-select:focus{border-color:var(--indigo)}
.jf-select-sm{padding:5px 8px;border:1px solid var(--border);border-radius:7px;font-family:var(--b);font-size:13px;outline:none;background:#fff;cursor:pointer;color:var(--text)}
.jobs-main-col{flex:1;min-width:0;display:flex;flex-direction:column}
.jobs-chips-row{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:8px}
.jobs-chips-row:empty{padding:0}
.jobs-chip{display:inline-flex;align-items:center;gap:5px;background:var(--indigo3);border:1px solid var(--indigo4);border-radius:100px;padding:4px 10px;font-size:12px;font-weight:500;color:var(--indigo)}
.jobs-chip-x{background:none;border:none;cursor:pointer;color:var(--indigo);display:flex;align-items:center;padding:0;line-height:1}
/* Job card v2 internals */
.jli-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.jli-badges{display:flex;align-items:center;gap:5px;flex-wrap:wrap;min-width:0}
.jli-save{position:static!important;flex-shrink:0;padding:4px 7px!important;font-size:14px!important}
.jli-title{font-family:var(--r);font-size:16px;font-weight:600;color:var(--dark);margin-bottom:5px;line-height:1.3}
.jli-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:6px}
.jli-meta i{font-size:12px;vertical-align:-1px;margin-right:1px}
.jli-company{font-weight:600;color:var(--text)}
.jli-date{margin-left:auto;font-size:12px}
.jli-skills{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}
.jli-skill{font-size:12px;padding:2px 8px;border-radius:5px;background:var(--surface);border:1px solid var(--border);color:var(--muted)}
.job-detail-panel{flex:1;min-width:0;background:transparent;border:none;padding:0;position:static;max-height:none;overflow:visible}
/* ── Job detail full-page layout ─────────────────────────── */
.jd-page{padding-bottom:60px}
.jd-back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:var(--indigo);font-size:14px;font-family:var(--b);font-weight:500;padding:0;margin-bottom:20px;transition:color .15s}
.jd-back:hover{color:var(--dark)}
.jd-layout{display:flex;gap:28px;align-items:flex-start}
.jd-main{flex:1;min-width:0}
.jd-right-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:14px;position:sticky;top:76px}
.jd-title{font-family:var(--r);font-size:26px;font-weight:700;color:var(--dark);line-height:1.25;margin-bottom:6px}
.jd-pub{font-size:13px;color:var(--muted);margin-bottom:14px}
.jd-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.jd-apply-btn{display:inline-flex;align-items:center;gap:7px;background:var(--indigo);color:#fff;border:none;border-radius:8px;padding:10px 22px;font-family:var(--b);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}
.jd-apply-btn:hover{background:var(--indigo-dk,#4338ca)}
.jd-apply-btn.jd-apply-sent{background:var(--green);cursor:default}
.jd-save-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:8px;padding:9px 16px;font-family:var(--b);font-size:14px;cursor:pointer;color:var(--text);transition:all .15s}
.jd-save-btn:hover,.jd-save-btn.saved{border-color:var(--red);color:var(--red);background:#FFF1F2}
.jd-stats{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:4px}
.jd-divider{border:none;border-top:1px solid var(--border);margin:4px 0 20px}
.jd-section{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.jd-section:first-of-type{border-top:none;padding-top:0;margin-top:0}
.jd-section-title{font-family:var(--r);font-size:16px;font-weight:700;color:var(--dark);margin-bottom:14px;display:flex;align-items:center;gap:7px}
.jd-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}
.jd-info-item{display:flex;align-items:flex-start;gap:10px;font-size:13.5px}
.jd-info-item i{color:var(--indigo);font-size:16px;margin-top:1px;flex-shrink:0}
.jd-info-val{font-weight:500;color:var(--dark)}
.jd-info-sub{font-size:12px;color:var(--muted);margin-top:1px}
.jd-desc{font-size:14px;color:var(--text);line-height:1.75;white-space:pre-wrap}
.jd-apply-bottom{margin-top:28px;padding-top:20px;border-top:1px solid var(--border)}
.jd-published-until{font-size:13px;color:var(--muted);margin-top:14px;display:flex;align-items:center;gap:6px}
/* Right sidebar cards */
.jd-company-card,.jd-match-card,.jd-reviews-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.jd-company-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.jd-co-logo{width:48px;height:48px;border-radius:10px;object-fit:contain;flex-shrink:0}
.jd-co-name{font-weight:700;font-size:15px;color:var(--dark)}
.jd-co-desc{font-size:12.5px;color:var(--muted);line-height:1.55;margin-bottom:10px}
.jd-co-link{display:flex;align-items:center;gap:5px;font-size:12.5px;width:100%;justify-content:center;margin-top:6px}
.jd-card-hdr{font-weight:700;font-size:13px;color:var(--dark);margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em}
.jd-match-circle-wrap{position:relative;display:flex;justify-content:center;align-items:center;margin-bottom:6px}
.jd-match-num{position:absolute;font-family:var(--r);font-size:20px;font-weight:700;color:var(--indigo)}
/* Loading state */
.jd-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:80px 24px;flex-direction:column}
/* Geo pill in location search field */
.geo-pill{font-size:13px;font-weight:500;color:var(--indigo);white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis;pointer-events:none}
/* Adzuna unified feed */
.adzuna-loading-row{display:flex;align-items:center;gap:8px;padding:14px 0;color:var(--muted);font-size:13px;border-top:1px solid var(--border)}
.adzuna-divider{display:flex;align-items:center;gap:8px;padding:14px 0 10px;font-size:12px;color:var(--muted);border-top:2px dashed var(--border);margin-top:4px}
.adzuna-divider a{color:var(--indigo);text-decoration:none;font-weight:600}
.source-adzuna{background:#e8f4fd!important;color:#1a5276!important;font-size:10px!important;font-weight:700!important}
.jli-apply-ext{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--indigo);background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.2);border-radius:6px;padding:4px 10px;text-decoration:none;white-space:nowrap;transition:background .15s}
.jli-apply-ext:hover{background:rgba(59,130,246,.15)}
/* Responsive */
@media(max-width:900px){.jd-layout{flex-direction:column}.jd-right-sidebar{width:100%;position:static}.jd-info-grid{grid-template-columns:1fr}}
.job-detail-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:4px}
.job-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.job-section h4{font-family:var(--r);font-size:14px;font-weight:600;color:var(--dark);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.job-desc{font-size:14px;color:var(--text);line-height:1.7;white-space:pre-wrap}
.detail-apply-row{display:flex;align-items:center;gap:12px;margin-top:16px;margin-bottom:4px}
.job-stats-mini{display:flex;gap:12px;font-size:12px;color:var(--muted)}
.job-stats-mini span{display:flex;align-items:center;gap:4px}
.skills-chips{display:flex;flex-wrap:wrap;gap:6px}
.skill-chip{padding:3px 10px;border-radius:100px;background:var(--indigo3);border:1px solid var(--indigo4);color:var(--indigo);font-size:12px;font-weight:500}
.review-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:8px}

/* ── STARS ────────────────────────────────────────────────── */
.star-picker{display:flex;gap:4px;margin-bottom:4px}
.rev-star{background:none;border:none;cursor:pointer;font-size:22px;color:#D1D5DB;padding:2px;transition:color .1s}
.rev-star.active,.rev-star:hover{color:var(--gold)}

/* ── DASHBOARD ────────────────────────────────────────────── */
.dash-layout{display:flex;min-height:calc(100vh - 64px)}
.dash-sidebar{width:240px;background:#fff;border-right:1px solid var(--border);padding:32px 16px;display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.dash-avatar{width:64px;height:64px;border-radius:50%;background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;margin-bottom:12px}
.dash-name{font-family:var(--r);font-weight:700;font-size:16px;color:var(--dark);text-align:center}
.dash-role{font-size:12px;color:var(--muted);margin-bottom:24px}
.dash-nav{width:100%;display:flex;flex-direction:column;gap:4px}
.dash-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:14px;color:var(--muted);cursor:pointer;transition:all .15s;font-weight:500}
.dash-nav-item:hover,.dash-nav-item.active{background:var(--indigo3);color:var(--indigo)}
.dash-nav-item i{font-size:16px}
.dash-content{flex:1;padding:40px;overflow-y:auto}
.dash-content h2{font-family:var(--r);font-size:24px;font-weight:700;color:var(--dark);margin-bottom:24px;display:flex;align-items:center;gap:8px}
.dash-tab{display:none}
.dash-tab.active{display:block;animation:fadeIn .2s ease}

/* ── PROFILE COMPLETENESS ─────────────────────────────────── */
.completeness-bar-wrap{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px}
.completeness-track{height:8px;background:var(--border);border-radius:100px;overflow:hidden}
.completeness-fill{height:100%;border-radius:100px;transition:width .5s ease}
.missing-chip{display:inline-flex;align-items:center;padding:2px 8px;background:var(--gold);color:#fff;border-radius:100px;font-size:11px;font-weight:600;margin-right:4px;margin-top:4px}

/* ── APPLICATION CARDS ────────────────────────────────────── */
.app-card-v2{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:12px;animation:fadeIn .2s ease}
.app-card-top{display:flex;align-items:flex-start;gap:14px;margin-bottom:12px}
.app-card-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.app-card-date{font-size:11px;color:var(--muted)}
.app-msg-btn{font-size:11px;padding:4px 10px;border-radius:6px;border:1px solid #c7d2fe;background:#eef2ff;cursor:pointer;color:#6366f1;font-weight:600;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.app-msg-btn:hover{background:#e0e7ff}
.app-status{padding:3px 10px;border-radius:100px;font-size:12px;font-weight:600;white-space:nowrap}
.app-status.new{background:#DBEAFE;border:1px solid #93C5FD;color:#1D4ED8}
.app-status.reviewed{background:#EDE9FE;border:1px solid #C4B5FD;color:#5B21B6}
.app-status.shortlisted{background:#FEF3C7;border:1px solid #FCD34D;color:#92400E}
.app-status.interview{background:#D1FAE5;border:1px solid #6EE7B7;color:#065F46}
.app-status.offer{background:#F0FDF4;border:1px solid #86EFAC;color:#14532D}
.app-status.rejected{background:#FEE2E2;border:1px solid #FCA5A5;color:#991B1B}
.app-status.withdrawn{background:var(--bg);border:1px solid var(--border);color:var(--muted)}

/* ── APPLICATION PROGRESS ─────────────────────────────────── */
.app-progress{display:flex;align-items:center;margin-top:4px;padding:8px 0}
.prog-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:0}
.prog-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:background .2s;flex-shrink:0}
.prog-step.done .prog-dot{background:var(--indigo)}
.prog-step.current .prog-dot{background:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,.2)}
.prog-label{font-size:10px;color:var(--muted);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.prog-step.done .prog-label,.prog-step.current .prog-label{color:var(--indigo);font-weight:600}
.prog-line{flex:1;height:2px;background:var(--border);margin-top:-18px;flex-shrink:0}
.prog-step.done + .prog-line{background:var(--indigo)}

/* Mobile: restructure app card ≤ 520px */
@media(max-width:520px){
  .app-card-v2{padding:12px 12px}
  .app-card-top{flex-wrap:wrap;gap:8px}
  .app-card-meta{flex-direction:row;align-items:center;justify-content:space-between;width:100%;gap:6px}
  .app-card-date{margin-left:auto}
  .app-msg-btn{margin-left:0}
  .prog-label{font-size:9px;white-space:normal;line-height:1.2;word-break:break-word}
  .prog-dot{width:8px;height:8px}
  .prog-line{margin-top:-15px}
}

/* ── JOBS FOR YOU ─────────────────────────────────────────── */
.jfy-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:all .15s}
.jfy-card:hover{border-color:var(--indigo4);box-shadow:var(--shadow)}
.jfy-title{font-family:var(--r);font-weight:600;color:var(--dark);font-size:14px;margin-bottom:2px}

/* ── EMPLOYER JOB CARDS ───────────────────────────────────── */
.emp-job-card-v2{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:12px;transition:all .15s}
.emp-job-card-v2:hover{border-color:var(--indigo4);box-shadow:var(--shadow)}
.emp-job-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.emp-job-title{font-family:var(--r);font-weight:600;color:var(--dark);font-size:15px;margin-bottom:6px}
.emp-job-meta{display:flex;flex-wrap:wrap;gap:6px}
.emp-job-stats{display:flex;gap:20px;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:12px}
.emp-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;text-align:center}
.emp-stat i{font-size:16px;color:var(--muted)}
.emp-stat span{font-family:var(--r);font-size:20px;font-weight:700;color:var(--dark);line-height:1}
.emp-stat small{font-size:11px;color:var(--muted)}
.emp-job-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ── BILLING ──────────────────────────────────────────────── */
.billing-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;max-width:540px}
.billing-plan-name{font-family:var(--r);font-size:22px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.billing-slots{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.billing-slot-item{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text);padding:8px;background:var(--bg);border-radius:8px}
.billing-slot-item i{color:var(--muted);font-size:16px}
.billing-slot-item strong{margin-left:auto;font-weight:700;color:var(--dark)}
.upgrade-cta{background:linear-gradient(135deg,var(--indigo3),#fff);border:1px solid var(--indigo4);border-radius:12px;padding:16px;margin-top:16px}

/* ── KANBAN ───────────────────────────────────────────────── */
.kanban-header{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}
.kanban-board{display:flex;gap:16px;padding:20px 28px;overflow-x:auto;flex:1;align-items:flex-start}
.kanban-col{min-width:220px;max-width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:8px}
.kanban-col-header{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.kanban-col-header span{color:#fff}
.kanban-count{background:rgba(255,255,255,.15);color:#fff;font-size:12px;font-weight:700;padding:2px 8px;border-radius:100px;min-width:22px;text-align:center}
.kanban-cards{display:flex;flex-direction:column;gap:8px;min-height:60px}
.kanban-card{background:#fff;border-radius:10px;padding:12px 14px;animation:fadeIn .15s ease;transition:box-shadow .15s}
.kanban-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.15)}
.kanban-card-name{font-family:var(--r);font-weight:600;color:var(--dark);font-size:13px;margin-bottom:2px}
.kanban-actions{display:flex;gap:4px;flex-wrap:wrap;margin-top:8px}
.ai-score-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:11px;font-weight:600;margin-bottom:4px}

/* ── FORMS ────────────────────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--dark);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-family:var(--b);font-size:14px;outline:none;color:var(--text);transition:border .15s;background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,.1)}
.form-group textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-error{color:var(--red);font-size:13px;margin-bottom:12px;display:none;padding:8px 12px;background:#FEF2F2;border-radius:6px;border:1px solid #FEE2E2}
.profile-form{max-width:640px}
.job-form{max-width:700px;display:flex;flex-direction:column}

/* ── MODALS ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:1000;padding:16px;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeIn .2s ease}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.modal-header h3{font-family:var(--r);font-size:18px;font-weight:700;color:var(--dark)}
.modal-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:20px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;transition:background .1s;flex-shrink:0;margin-top:-2px}
.modal-close:hover{background:var(--bg)}
.modal-body{padding:24px;display:flex;flex-direction:column;gap:0}
.modal-divider{text-align:center;color:var(--muted);font-size:13px;margin:14px 0;position:relative}
.modal-divider::before,.modal-divider::after{content:'';position:absolute;top:50%;width:calc(50% - 20px);height:1px;background:var(--border)}
.modal-divider::before{left:0}.modal-divider::after{right:0}
.role-tabs{display:flex;gap:8px;margin-bottom:16px}
.role-tab{flex:1;padding:10px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;font-family:var(--b);font-size:13px;font-weight:600;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}
.role-tab.active{border-color:var(--indigo);background:var(--indigo3);color:var(--indigo)}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:40px}
.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px}
.link-sm{color:var(--indigo);font-size:13px}

/* ── AI CHAT ──────────────────────────────────────────────── */
.ai-chat-box{height:340px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;display:flex;flex-direction:column;gap:10px;background:var(--bg)}
.ai-msg{max-width:80%;padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.5}
.ai-msg-user{background:var(--indigo);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ai-msg-bot{background:#fff;border:1px solid var(--border);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px}
.ai-chat-input{display:flex;gap:8px}
.ai-chat-input input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-family:var(--b);font-size:14px;outline:none;transition:border .15s}
.ai-chat-input input:focus{border-color:var(--indigo)}

/* ── TOASTS ───────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}
.toast{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 18px;font-size:14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);animation:slideIn .2s ease}
.toast.success{border-left:3px solid var(--green)}
.toast.success i{color:var(--green)}
.toast.error{border-left:3px solid var(--red)}
.toast.error i{color:var(--red)}

/* ── EMPTY & LOADING STATES ───────────────────────────────── */
.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}
.empty-state i{font-size:40px;display:block;margin-bottom:12px;opacity:.4}
.empty-state p{font-size:14px;line-height:1.6}
.loading-state{display:flex;align-items:center;justify-content:center;padding:48px}

/* ── RECENT SEARCHES ──────────────────────────────────────── */
.recent-searches-title{font-size:15px;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:12px;letter-spacing:.01em}
.recent-searches-list{display:flex;flex-wrap:wrap;gap:10px}
.recent-search-chip{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:10px 16px;cursor:pointer;transition:all .18s;color:#fff;font-size:13px;text-align:left;min-width:0}
.recent-search-chip:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);transform:translateY(-1px)}
.recent-search-chip .ti-history{font-size:16px;color:rgba(255,255,255,.5);flex-shrink:0}
.rsc-text{display:flex;flex-direction:column;gap:1px;min-width:0}
.rsc-label{font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.rsc-sub{font-size:11px;color:rgba(255,255,255,.5);white-space:nowrap}
.rsc-badge{background:rgba(99,102,241,.35);color:#A5B4FC;border:1px solid rgba(99,102,241,.4);border-radius:20px;font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap;flex-shrink:0}

/* ── DROPDOWN IMPROVEMENTS ────────────────────────────────── */
.dropdown-email{padding:10px 16px 8px;font-size:13px;font-weight:600;color:var(--dark);border-bottom:1px solid var(--border);margin-bottom:4px;word-break:break-all}
.dropdown-item.danger{color:var(--red)}
.dropdown-item.danger:hover{background:#FEF2F2;color:var(--red)}
.dropdown-item.btn-active{background:var(--indigo3);color:var(--indigo)}

/* ── SETTINGS PAGE ────────────────────────────────────────── */
.settings-layout{display:flex;min-height:calc(100vh - 64px);max-width:1100px;margin:0 auto;padding:0 24px}
.settings-sidebar{width:280px;flex-shrink:0;padding:40px 0 40px 0;border-right:1px solid var(--border)}
.settings-title{font-family:var(--r);font-size:24px;font-weight:700;color:var(--dark);margin-bottom:24px;padding-left:4px}
.settings-nav{display:flex;flex-direction:column;gap:2px}
.settings-nav-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-sm);cursor:pointer;text-decoration:none;color:var(--text);transition:all .15s;border-left:3px solid transparent}
.settings-nav-item:hover{background:var(--bg)}
.settings-nav-item.active{background:var(--indigo3);border-left-color:var(--indigo);color:var(--indigo)}
.settings-nav-item i:first-child{font-size:18px;flex-shrink:0;color:var(--muted)}
.settings-nav-item.active i:first-child{color:var(--indigo)}
.sn-label{font-size:14px;font-weight:500;line-height:1.3}
.sn-sub{font-size:12px;color:var(--muted);margin-top:1px}
.settings-nav-item.active .sn-sub{color:var(--indigo);opacity:.7}
.sn-arrow{margin-left:auto;font-size:14px;color:var(--muted)}
.badge-new{background:var(--indigo);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;vertical-align:middle;margin-left:4px}
.settings-content{flex:1;padding:40px 40px}
.settings-section-title{font-family:var(--r);font-size:22px;font-weight:700;color:var(--dark);margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.settings-rows{display:flex;flex-direction:column}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border);gap:16px}
.settings-row:last-child{border-bottom:none}
.settings-row-label{font-size:14px;font-weight:500;color:var(--dark)}
.settings-row-value{font-size:14px;color:var(--text);margin-top:2px}
.settings-muted{color:var(--muted) !important;font-size:13px !important}
.btn-sm{padding:6px 14px;font-size:13px}
.btn-active{background:var(--indigo);color:#fff;border-color:var(--indigo)}

/* ── TOGGLE SWITCH ────────────────────────────────────────── */
.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:24px;transition:.3s}
.toggle-slider:before{content:'';position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:var(--shadow)}
.toggle-switch input:checked + .toggle-slider{background:var(--indigo)}
.toggle-switch input:checked + .toggle-slider:before{transform:translateX(20px)}

/* ── HELP PAGE ────────────────────────────────────────────── */
.help-hero{background:linear-gradient(135deg,#1b485a 0%,#023448 100%);padding:64px 32px;text-align:center}
.help-hero-title{font-family:var(--r);font-size:clamp(22px,4vw,36px);font-weight:700;color:#fff;max-width:700px;margin:0 auto;line-height:1.3}
.help-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:48px}
.help-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;display:flex;flex-direction:column;gap:12px}
.help-card-icon{width:48px;height:48px;border-radius:12px;background:var(--indigo3);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--indigo);margin-bottom:8px}
.help-card-icon.employer{background:#FEF3C7;color:var(--gold)}
.help-card h3{font-family:var(--r);font-size:18px;font-weight:700;color:var(--dark)}
.help-card p{font-size:14px;color:var(--text);line-height:1.6}
.help-faqs{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.help-faq-item{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.help-faq-item summary{padding:12px 16px;font-size:13px;font-weight:500;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--dark)}
.help-faq-item summary::-webkit-details-marker{display:none}
.help-faq-item summary::after{content:'›';font-size:18px;color:var(--muted);transition:transform .2s}
.help-faq-item[open] summary::after{transform:rotate(90deg)}
.help-faq-item p{padding:0 16px 14px;font-size:13px;color:var(--text);line-height:1.6;border-top:1px solid var(--border);padding-top:12px;margin:0}
.help-link{font-size:14px;font-weight:600;color:var(--indigo);cursor:pointer;margin-top:auto}
.help-link:hover{text-decoration:underline}
.help-footer-cta{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:32px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.help-footer-cta h3{font-family:var(--r);font-size:18px;font-weight:700;color:var(--dark)}
.help-footer-cta p{font-size:14px;color:var(--muted);margin-top:4px}

/* ── PRIVACY PAGE ─────────────────────────────────────────── */
.privacy-hero{background:var(--dark);padding:48px 32px;text-align:center}
.privacy-hero h1{font-family:var(--r);font-size:32px;font-weight:700;color:#fff;margin-bottom:8px}
.privacy-hero p{color:rgba(255,255,255,.6);font-size:16px}
.privacy-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:32px}
.privacy-tab{padding:10px 20px;background:none;border:none;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}
.privacy-tab.active{color:var(--indigo);border-bottom-color:var(--indigo)}
.privacy-section h2{font-family:var(--r);font-size:22px;font-weight:700;color:var(--dark);margin-bottom:12px}
.privacy-section h3{font-size:16px;font-weight:600;color:var(--dark);margin:24px 0 8px}
.privacy-section p,.privacy-section li{font-size:14px;color:var(--text);line-height:1.7}
.privacy-section ul{padding-left:20px;display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.privacy-lead{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}

/* ── MY REVIEWS ───────────────────────────────────────────── */
.my-reviews-tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:24px}
.my-rev-tab{padding:10px 20px;background:none;border:none;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;display:flex;align-items:center;gap:6px}
.my-rev-tab.active{color:var(--indigo);border-bottom-color:var(--indigo)}
.rev-count{background:var(--bg);border:1px solid var(--border);border-radius:10px;font-size:11px;padding:1px 7px;color:var(--muted)}
.my-reviews-empty{text-align:center;padding:64px 32px}
.my-reviews-lock{font-size:40px;margin-bottom:16px;color:var(--indigo);opacity:.4;display:flex;align-items:center;justify-content:center;gap:6px}
.my-reviews-empty h3{font-family:var(--r);font-size:20px;font-weight:700;color:var(--dark);margin-bottom:8px}
.my-reviews-empty p{font-size:14px;color:var(--muted);margin-bottom:24px}
.my-review-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:12px}
.my-review-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.my-review-company{font-size:15px;font-weight:600;color:var(--dark);margin-bottom:4px}
.my-review-title{font-size:13px;color:var(--muted);font-style:italic;margin-top:4px}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:1024px){.job-detail-panel{width:380px}}
@media(max-width:1100px){.categories-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){
  .jobs-page-layout{flex-direction:column}
  .jobs-page-v2{flex-direction:column}
  .jobs-sidebar{width:100%;position:static}
  .jobs-search-row{flex-wrap:wrap}
  .jobs-search-field-loc{max-width:none;flex:1}
  .job-detail-panel{width:100%;position:static;max-height:none}
  .dash-layout{flex-direction:column}
  .dash-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;padding:16px;gap:12px}
  .dash-sidebar .dash-avatar,.dash-sidebar .dash-name,.dash-sidebar .dash-role{display:none}
  .dash-nav{flex-direction:row;flex-wrap:wrap;gap:4px;width:100%}
  .kanban-board{padding:16px}
  .categories-grid{grid-template-columns:repeat(2,1fr)}
  .bento-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .bento-photo{height:260px}
  .bento-cell{padding:44px 32px;gap:14px}
  .bento-heading{font-size:24px}
}
@media(max-width:640px){
  /* ── Hamburger menu ── */
  .hamburger{display:flex}
  #nav-auth-guest{display:none!important}
  .nav-links{
    display:none;
    position:fixed;top:0;left:0;width:100%;height:100vh;
    background:var(--dark,#023448);
    flex-direction:column;align-items:center;justify-content:center;
    gap:8px;z-index:1050;padding:80px 24px 40px;box-sizing:border-box;
    overflow-y:auto;
  }
  .nav-links.open{display:flex}
  .nav-link{font-size:1.2rem;font-weight:600;color:rgba(255,255,255,.85);padding:12px 24px;width:100%;text-align:center;border-radius:12px}
  .nav-link:hover,.nav-link.active{background:rgba(255,255,255,.1);color:#fff}
  .nav-mob-close{
    display:flex;align-items:center;justify-content:center;
    position:absolute;top:18px;right:18px;
    width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
    background:rgba(255,255,255,.08);color:#fff;cursor:pointer;font-size:18px;
  }
  .nav-mob-auth{
    display:flex;flex-direction:column;align-items:center;gap:12px;
    width:100%;max-width:280px;margin-top:24px;padding-top:24px;
    border-top:1px solid rgba(255,255,255,.15);
  }
  .nav-mob-btn{width:100%;text-align:center;padding:12px 24px;font-size:15px;border-radius:12px;box-sizing:border-box}
  /* ── Categories dropdown on mobile ── */
  .cat-section-header{display:none}
  .cat-dropdown-toggle{display:flex}
  #categories-grid{display:none;margin-top:8px}
  #categories-grid.open{display:grid;grid-template-columns:1fr;gap:6px}
  /* ── Rest of mobile fixes ── */
  .search-bar{flex-direction:column}
  .search-loc,.search-mode{display:none}
  .hstat{padding:0 16px}
  .cta-card{flex-direction:column}
  .jobs-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .app-progress{display:none}
  .emp-job-stats{flex-wrap:wrap}
  .kanban-col{min-width:180px}
  .help-cards{grid-template-columns:1fr}
  .help-footer-cta{flex-direction:column;gap:16px}
  .settings-layout{flex-direction:column;padding:0 16px}
  .settings-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);padding:24px 0 16px}
  .settings-title{font-size:20px;margin-bottom:12px}
  .settings-content{padding:24px 0}
  .settings-row{flex-direction:column;align-items:flex-start;gap:10px}
  .privacy-tabs{overflow-x:auto;gap:0}
  .privacy-tab{white-space:nowrap;font-size:13px;padding:8px 12px}
}

/* ── ENDORSEMENTS ────────────────────────────────────────── */
.endorsements-section{border-top:1px solid var(--border);margin-top:28px;padding-top:24px}
.endorsements-section-placeholder{margin-top:28px;height:4px}
.endorse-header{margin-bottom:16px}
.endorse-title{font-family:var(--r);font-size:16px;font-weight:700;color:var(--dark);margin:0 0 4px;display:flex;align-items:center;gap:7px}
.endorse-sub{font-size:13px;color:var(--muted);margin:0}
.endorse-sub.has-total{color:var(--indigo);font-weight:600}
.endorse-grid{display:flex;flex-direction:column;gap:8px}
.endorse-card{display:flex;align-items:center;gap:12px;background:#f9fafb;border:1px solid var(--border);border-radius:10px;padding:12px 14px;transition:box-shadow .15s}
.endorse-card.has-endorsements{background:#fff;border-color:var(--border);box-shadow:0 1px 6px rgba(0,0,0,.06)}
.endorse-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.endorse-body{flex:1;min-width:0}
.endorse-label{font-weight:600;color:var(--dark);font-size:13px}
.endorse-names{font-size:12px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.endorse-count-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0}
.endorse-count{font-size:18px;font-weight:800;min-width:24px;text-align:right}
.endorse-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--ec,#6366f1);background:transparent;color:var(--ec,#6366f1);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .18s;flex-shrink:0}
.endorse-btn:hover{background:var(--ec,#6366f1);color:#fff;transform:scale(1.1)}
.endorse-btn.endorsed{background:var(--ec,#6366f1);color:#fff;border-color:var(--ec,#6366f1)}
.endorse-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
/* Passport endorsement pill */
.passport-endorse-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;color:#fff;margin-top:10px;cursor:default}
/* Kanban endorsement row */
.kanban-endorse-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.kanban-endorse-pill{display:inline-flex;align-items:center;gap:4px;background:#eef2ff;color:#6366f1;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:700}
.kanban-endorse-btn{font-size:11px;padding:4px 10px;color:var(--indigo);border-color:var(--indigo)20;flex-shrink:0}
/* Kanban notes row */
.kanban-notes-row{margin-top:8px}
.kanban-notes-btn{font-size:11px;padding:4px 10px;color:var(--dark);width:100%;justify-content:center;gap:6px}
.kanban-notes-badge{display:inline-flex;align-items:center;justify-content:center;background:#023448;color:#fff;border-radius:20px;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;margin-left:4px}
/* Notes modal */
.notes-modal-card{max-width:560px;width:100%;display:flex;flex-direction:column;max-height:80vh}
.notes-thread{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:12px;min-height:120px;max-height:340px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.notes-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);padding:32px 16px;font-size:13px;line-height:1.6}
.note-item{background:var(--surface,#f8f9fa);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.note-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:12px}
.note-author{font-weight:700;color:var(--dark);display:flex;align-items:center;gap:4px}
.note-date{color:var(--muted);margin-left:auto}
.note-del-btn{background:none;border:none;cursor:pointer;color:var(--muted);padding:2px 4px;border-radius:4px;font-size:13px;transition:color .15s}
.note-del-btn:hover{color:var(--red)}
.note-body{font-size:13px;color:var(--text);line-height:1.55;white-space:pre-wrap;word-break:break-word}
.notes-compose{padding:16px 24px}
.notes-textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;font-family:inherit;resize:vertical;outline:none;transition:border-color .18s;box-sizing:border-box}
.notes-textarea:focus{border-color:var(--indigo)}
/* ── JOB DETAIL COMPANY SECTION ──────────────────────────── */
.job-section-company{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:16px 18px;margin-top:16px}
.job-section-company h4{margin-top:0}
/* ── SKILL SECTOR FILTER ─────────────────────────────────── */
.sp-sector-bar{display:flex;flex-wrap:wrap;gap:6px;padding:10px 0 10px;border-bottom:1px solid var(--border);margin-bottom:12px}
.sp-subsector-bar{padding:8px 0;border-bottom:1px solid var(--border);margin-top:-8px;margin-bottom:12px;gap:5px}
.sp-sector-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 11px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}
.sp-sector-btn:hover{border-color:#6366f1;color:#6366f1}
.sp-sector-btn.active{background:#6366f1;color:#fff;border-color:#6366f1;font-weight:700}
.sp-subsector-bar .sp-sector-btn.active{background:var(--dark);border-color:var(--dark)}
/* ── MATCH SCORE BADGE ───────────────────────────────────── */
.match-badge{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.3px;white-space:nowrap}
/* ── HIGHLIGHTS ──────────────────────────────────────────── */
.highlights-section{border-top:1px solid var(--border);margin-top:28px;padding-top:24px}
.highlights-header{margin-bottom:16px}
.highlights-title{font-family:var(--r);font-size:16px;font-weight:700;color:var(--dark);margin:0 0 4px;display:flex;align-items:center;gap:7px}
.highlights-sub{font-size:13px;color:var(--muted);margin:0}
/* grid cards */
.hl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:12px}
.hl-grid-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 14px 14px;position:relative;transition:transform .2s,box-shadow .2s}
.hl-grid-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.09)}
.hl-grid-icon{font-size:2rem;margin-bottom:8px;line-height:1}
.hl-grid-title{font-weight:700;font-size:.88rem;color:var(--dark)}
.hl-grid-desc{font-size:.75rem;color:var(--muted);margin-top:4px;line-height:1.4}
.hl-grid-link{display:inline-block;margin-top:6px;font-size:.75rem;color:var(--indigo);text-decoration:none;font-weight:600}
.hl-grid-remove{position:absolute;top:7px;right:7px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;opacity:0;transition:opacity .15s;padding:2px 5px;border-radius:6px;line-height:1}
.hl-grid-card:hover .hl-grid-remove{opacity:1}
.hl-grid-remove:hover{color:#ef4444;background:#fef2f2}
/* modal */
.hl-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:800;display:flex;align-items:center;justify-content:center;padding:16px}
.hl-modal-backdrop.hidden{display:none}
.hl-modal-box{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:380px;box-shadow:0 16px 48px rgba(0,0,0,.18)}
/* icon picker */
.hl-icon-picker{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.hl-icon-opt{font-size:1.4rem;cursor:pointer;padding:5px 7px;border-radius:8px;border:2px solid transparent;transition:border-color .15s,background .15s;line-height:1}
.hl-icon-opt:hover{background:#f1f5f9}
.hl-icon-opt.selected{border-color:var(--indigo);background:var(--indigo3)}
/* ── PROFILE SKILLS ──────────────────────────────────────── */
.ps-section{border-top:1px solid var(--border);margin-top:28px;padding-top:24px}
.ps-section-header{margin-bottom:16px}
.ps-category{margin-bottom:20px}
.ps-cat-title{font-size:.8rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:0 0 10px}
.ps-empty{font-size:13px;color:var(--muted);margin:0 0 10px}
.ps-add-btn{font-size:13px;padding:7px 14px;margin-top:4px}
/* hard skill bars */
.ps-bar-wrap{position:relative;margin-bottom:14px;padding-right:28px}
.ps-bar-header{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:5px}
.ps-bar-name{font-weight:600;color:var(--dark)}
.ps-level-label{font-size:.72rem;color:var(--muted);font-weight:600}
.ps-bar-track{height:6px;background:var(--border);border-radius:999px;overflow:hidden}
.ps-bar-fill{height:100%;background:linear-gradient(90deg,var(--indigo),#818cf8);border-radius:999px;transition:width .6s cubic-bezier(.23,1,.32,1)}
.ps-remove{position:absolute;right:0;top:0;background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;opacity:0;transition:opacity .15s;padding:2px 4px;border-radius:4px}
.ps-bar-wrap:hover .ps-remove{opacity:1}
.ps-remove:hover{color:#ef4444;background:#fef2f2}
/* soft skill tags */
.ps-soft-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.ps-tag{display:flex;align-items:center;gap:6px;background:var(--indigo3);color:var(--indigo);border:1px solid #c7d2fe;padding:5px 12px;border-radius:999px;font-size:.8rem;font-weight:500}
.ps-tag-rm{cursor:pointer;opacity:.55;font-size:.7rem;transition:opacity .15s;line-height:1}
.ps-tag-rm:hover{opacity:1}
/* skills modal */
.ps-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:800;display:flex;align-items:center;justify-content:center;padding:16px}
.ps-modal-backdrop.hidden{display:none}
/* ── RECOMMENDATIONS ─────────────────────────────────────── */
.rec-section{border-top:1px solid var(--border);margin-top:28px;padding-top:24px}
.rec-grid{display:flex;flex-direction:column;gap:14px;margin-bottom:8px}
.rec-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;position:relative;transition:box-shadow .2s}
.rec-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.08)}
.rec-remove{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:.75rem;opacity:0;transition:opacity .15s;padding:3px 6px;border-radius:6px}
.rec-card:hover .rec-remove{opacity:1}
.rec-remove:hover{color:#ef4444;background:#fef2f2}
.rec-quote{font-size:.9rem;color:var(--dark);line-height:1.65;margin-bottom:16px;font-style:italic}
.rec-author{display:flex;align-items:center;gap:12px}
.rec-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;flex-shrink:0;overflow:hidden}
.rec-author-name{font-weight:700;font-size:.88rem;color:var(--dark)}
.rec-author-meta{font-size:.78rem;color:var(--muted);margin-top:2px}
.rec-stars{margin-top:3px}
/* star picker in modal */
.rec-star-picker{display:flex;gap:4px;margin-bottom:2px}
.rec-star-opt{font-size:22px;cursor:pointer;color:#cbd5e1;transition:color .12s;line-height:1}
.rec-star-opt.active{color:#f59e0b}
/* ── TALENT PASSPORT ─────────────────────────────────────── */
.talent-passport{background:linear-gradient(135deg,#0d1526 0%,#1b485a 100%);border-radius:16px;color:#fff;padding:24px;margin-bottom:28px;box-shadow:0 8px 32px rgba(27,72,90,.28)}
.passport-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}
.passport-avatar-lg{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;flex-shrink:0;letter-spacing:-1px}
.passport-avatar-cam{position:absolute;inset:0;border-radius:50%;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .18s}
.passport-avatar-upload:hover .passport-avatar-cam{opacity:1}
.passport-info{flex:1;min-width:0}
.passport-name{font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.passport-headline{font-size:13px;opacity:.72;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.passport-meta{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px;font-size:12px;opacity:.8}
.passport-meta span{display:flex;align-items:center;gap:4px}
.passport-score-wrap{position:relative;width:80px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.score-ring-svg{width:80px;height:80px}
.score-overlay{position:absolute;text-align:center}
.score-num{font-size:17px;font-weight:800;line-height:1}
.score-lbl{font-size:9px;opacity:.65;letter-spacing:.5px;text-transform:uppercase;margin-top:2px}
.passport-stats{display:flex;gap:8px;border-top:1px solid rgba(255,255,255,.12);padding-top:16px}
.passport-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;opacity:.82}
.passport-stat i{font-size:16px;opacity:.65}
.passport-stat strong{font-size:15px;font-weight:700}
/* Sidebar score pill */
.dash-score-pill{display:inline-flex;align-items:center;gap:5px;border-radius:20px;padding:4px 11px;font-size:12px;font-weight:700;margin-top:4px;margin-bottom:2px}
/* Sidebar open-to-work pill */
.sidebar-otw{display:inline-flex;align-items:center;gap:5px;background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;border-radius:20px;padding:4px 11px;font-size:12px;font-weight:700;margin-top:4px}
/* Open to Work avatar ring — LinkedIn style (outline ignores overflow:hidden) */
.otw-ring{outline:3px solid #16a34a!important;outline-offset:2px;transition:outline-color .25s}
.otw-ring-lg{outline:4px solid #16a34a!important;outline-offset:3px;transition:outline-color .25s}
/* ── AVAILABILITY BADGES ─────────────────────────────────── */
.avail-section{background:#f9fafb;border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:20px}
.avail-label{font-size:13px;font-weight:600;color:var(--dark);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.avail-chips{display:flex;flex-wrap:wrap;gap:8px}
.avail-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:20px;font-size:13px;cursor:pointer;transition:all .15s;user-select:none;white-space:nowrap}
.avail-chip:hover{opacity:.88;transform:translateY(-1px)}
/* Passport badges row */
.passport-badges-row{flex-wrap:wrap;gap:6px;padding-top:12px;margin-top:4px;border-top:1px solid rgba(255,255,255,.12)}
.passport-badge-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
/* ── AI CAREER AGENT ─────────────────────────────────────── */
.agent-banner{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#0d1526,#1b485a);color:#fff;border-radius:14px;padding:16px 20px;margin-bottom:16px}
.agent-avatar{width:44px;height:44px;background:rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.agent-name{font-weight:700;font-size:15px}
.agent-status{font-size:12px;opacity:.72;display:flex;align-items:center;gap:5px;margin-top:3px}
.agent-quick-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.agent-qa{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid var(--border);background:#fff;border-radius:24px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;color:var(--dark);font-family:var(--b)}
.agent-qa:hover{border-color:var(--indigo);background:var(--indigo3);color:var(--indigo)}

/* ── SITE FOOTER ──────────────────────────────────────────── */
.site-footer{background:linear-gradient(180deg,#0d1526 0%,#070d18 100%);color:#94A3B8;margin-top:0;border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{max-width:1100px;margin:0 auto;padding:56px 24px 40px;display:grid;grid-template-columns:260px 1fr;gap:64px}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{display:flex;align-items:center;gap:10px}
.footer-tagline{font-size:13px;color:#64748B;margin-top:4px}
.footer-civicai{font-size:13px;color:#94A3B8;margin-top:8px;line-height:1.6;border-top:1px solid rgba(255,255,255,.08);padding-top:16px}
.footer-civicai strong{color:#CBD5E1;font-weight:600}
.footer-links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#475569;margin-bottom:6px}
.footer-link{font-size:13px;color:#94A3B8;cursor:pointer;transition:color .15s;text-decoration:none;display:flex;align-items:center;gap:5px}
.footer-link:hover{color:#E2E8F0}
.footer-bottom{max-width:1100px;margin:0 auto;padding:20px 24px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:#475569}
.footer-bottom-links{display:flex;gap:20px}
.footer-link-sm{font-size:12px;color:#475569;cursor:pointer;text-decoration:none;transition:color .15s}
.footer-link-sm:hover{color:#94A3B8}
.footer-made{font-size:12px;color:#334155}
@media(max-width:768px){
  .footer-inner{grid-template-columns:1fr;gap:40px}
  .footer-links-grid{grid-template-columns:1fr 1fr;gap:24px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .footer-made{display:none}
}


/* ── TRUST BAND / MARQUEE ─────────────────────────────────── */
.trust-band{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 0;overflow:hidden}
.trust-label{text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:14px}
.marquee-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%)}
.marquee-track{display:flex;width:max-content;animation:marquee-scroll 32s linear infinite;gap:0}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee-item{display:flex;align-items:center;gap:9px;padding:0 28px;white-space:nowrap;border-right:1px solid var(--border)}
.mq-logo{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;font-size:11px;font-weight:800;flex-shrink:0;letter-spacing:.5px}
.mq-name{font-size:14px;font-weight:600;color:var(--dark)}
@media(max-width:640px){.mq-name{font-size:13px}.mq-logo{width:30px;height:30px;font-size:10px}}

/* ── EMPLOYER FEATURES BENTO ───────────────────────────────── */
.emp-bento{overflow:hidden}
.emp-bento-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:0;
}

/* Base cell */
.eb-cell{
  position:relative;overflow:hidden;
  padding:40px 44px;
  display:flex;flex-direction:column;justify-content:flex-start;gap:12px;
  border:1px solid rgba(255,255,255,.08);
  min-height:280px;
  box-sizing:border-box;
}
.eb-label{
  font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  opacity:.75;margin-bottom:2px;
}
.eb-cell h3{
  font-family:var(--r);font-size:24px;font-weight:800;line-height:1.2;
  color:#fff;margin:0;
}
.eb-cell>p{
  font-size:14.5px;line-height:1.65;color:rgba(255,255,255,.82);margin:0;
}

/* Colors */
.eb-indigo{background:linear-gradient(135deg,#4F52D3 0%,#6366F1 100%);color:rgba(255,255,255,.7)}
.eb-emerald{background:linear-gradient(135deg,#0c5a72 0%,#1a82a0 100%);color:rgba(255,255,255,.7)}
.eb-orange{background:linear-gradient(135deg,#1d3557 0%,#2e5080 100%);color:rgba(255,255,255,.7)}
.eb-navy{background:linear-gradient(135deg,#0A1929 0%,#0D1F2E 100%);color:rgba(255,255,255,.7)}

/* Deco icons — large translucent background icon */
.eb-deco{
  position:absolute;right:-16px;bottom:-16px;
  font-size:110px;line-height:1;
  opacity:.07;pointer-events:none;color:#fff;
}

/* Checks (cell 1) */
.eb-checks{
  display:flex;flex-direction:column;gap:6px;
  margin-top:4px;
}
.eb-checks span{
  display:flex;align-items:center;gap:7px;
  font-size:13px;color:rgba(255,255,255,.85);
}
.eb-checks .ti-check{color:#a5f3c0;font-size:12px;flex-shrink:0}

/* Score pills (cell 2) */
.eb-scores{display:flex;flex-direction:column;gap:7px;margin-top:4px}
.eb-score-row{
  display:flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.08);border-radius:10px;
  padding:7px 10px;
}
.eb-avatar{
  width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;
  font-size:8.5px;font-weight:800;color:#fff;flex-shrink:0;
}
.eb-sname{flex:1;font-size:12px;font-weight:500;color:rgba(255,255,255,.9)}
.eb-pill{
  font-size:10.5px;font-weight:800;padding:2px 9px;border-radius:100px;
}
.eb-pill-hi{background:#d1fae5;color:#065f46}
.eb-pill-mid{background:#fef3c7;color:#92400e}
.eb-pill-lo{background:#fee2e2;color:#991b1b}

/* Kanban pills (cell 3) */
.eb-kanban-pills{
  display:flex;align-items:center;gap:5px;flex-wrap:wrap;
  margin-top:4px;
}
.eb-kpill{
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);
  border-radius:7px;padding:4px 11px;font-size:11.5px;font-weight:600;color:#fff;
}

/* Stats + mini chart (cell 4) */
.eb-stats{display:flex;align-items:center;gap:0;margin-top:4px}
.eb-stat{text-align:center;padding:0 16px}
.eb-stat:first-child{padding-left:0}
.eb-stat-n{font-family:var(--r);font-size:22px;font-weight:800;color:#fff;line-height:1}
.eb-stat-l{font-size:10.5px;color:rgba(255,255,255,.55);margin-top:4px;text-transform:uppercase;letter-spacing:.05em}
.eb-stat-sep{width:1px;height:28px;background:rgba(255,255,255,.1)}
.eb-chart{
  display:flex;align-items:flex-end;gap:4px;height:52px;
  padding:0 2px;margin-top:8px;
}
.eb-bar{
  flex:1;border-radius:4px 4px 0 0;
  background:rgba(99,140,255,.35);
  min-height:4px;transition:height .3s;
}
.eb-bar:nth-child(6),.eb-bar:nth-child(10){background:rgba(150,175,255,.85)}

/* Buttons */
.eb-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:9px;
  font-size:13.5px;font-weight:700;cursor:pointer;border:none;
  transition:opacity .18s,transform .18s;
  align-self:flex-start;
  margin-top:auto;
  flex-shrink:0;
}
.eb-btn:hover{opacity:.88;transform:translateY(-1px)}
.eb-btn-white{background:#fff;color:#1E293B}
.eb-btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}
.eb-btn-outline:hover{background:rgba(255,255,255,.08)}

/* Responsive */
@media(max-width:960px){
  .emp-bento-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .eb-cell{padding:32px 28px;min-height:0}
  .eb-cell h3{font-size:20px}
  .eb-deco{font-size:90px}
}
@media(max-width:600px){
  .eb-cell{padding:28px 20px}
  .eb-cell h3{font-size:18px}
  .eb-deco{font-size:80px}
  .eb-cell>p{font-size:13px}
}

/* ── JOBS RESULTS BAR ──────────────────────────────────────── */
.jobs-results-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0 6px;border-bottom:1px solid var(--border);min-height:36px}
.jobs-count-label{font-size:13.5px;font-weight:600;color:var(--text)}
.jobs-clear-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:1px solid var(--border);border-radius:8px;padding:5px 12px;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--b);transition:all .15s}
.jobs-clear-btn:hover{border-color:#EF4444;color:#EF4444;background:#FFF1F2}

/* ── JOB NEW BADGE ─────────────────────────────────────────── */
.job-new-badge{display:inline-flex;align-items:center;background:#DCFCE7;color:#15803D;border:1px solid #BBF7D0;border-radius:100px;font-size:10px;font-weight:800;padding:2px 8px;letter-spacing:.04em;text-transform:uppercase;flex-shrink:0}

/* ── HERO PILLS ────────────────────────────────────────────── */
.hero-pills{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
  margin-top:20px;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(8px);
  border-radius:100px;
  padding:8px 18px;
  font-size:13.5px;font-weight:600;color:#fff;
  white-space:nowrap;
}
.hero-pill i{font-size:14px;opacity:.85}

/* ── HERO STATS BAR ────────────────────────────────────────── */
.hero-stats-bar{
  display:flex;align-items:center;justify-content:center;gap:0;
  margin-top:28px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  border-radius:16px;
  padding:16px 32px;
  max-width:560px;
  margin-left:auto;margin-right:auto;
}
.hero-stat{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}
.hero-stat-n{font-family:var(--r);font-size:26px;font-weight:800;color:#fff;line-height:1}
.hero-stat-l{font-size:11px;font-weight:500;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.hero-stat-sep{width:1px;height:36px;background:rgba(255,255,255,.2);margin:0 12px}
@media(max-width:480px){
  /* Stats bar → 2×2 grid */
  .hero-stats-bar{flex-wrap:wrap;padding:14px 12px;gap:0;max-width:100%}
  .hero-stat{flex:0 0 50%;min-width:0;padding:8px 4px}
  .hero-stat-sep{display:none}
  .hero-stat-n{font-size:20px}
  .hero-stat-l{font-size:10px;white-space:normal;text-align:center;line-height:1.3}
  /* Categories grid */
  .categories-grid{grid-template-columns:repeat(2,1fr);gap:8px;padding:0 4px;overflow:hidden;width:100%;box-sizing:border-box}
  .category-card{width:100%;box-sizing:border-box}
}

/* ── HOW IT WORKS ──────────────────────────────────────────── */
.hiw-section{
  background:#fff;
  padding:88px 24px;
  position:relative;overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.hiw-section::before{content:none}
.hiw-section::after{content:none}

.hiw-header{text-align:center;margin-bottom:60px;position:relative;z-index:1}
.hiw-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--indigo3);border:1px solid rgba(99,102,241,.2);
  color:var(--indigo);border-radius:100px;
  padding:7px 20px;font-size:11px;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;
}
.hiw-header h2{
  font-family:var(--r);font-size:38px;font-weight:800;color:var(--dark);
  margin:0 0 14px;line-height:1.15;
}
.hiw-header p{font-size:16px;color:var(--muted);margin:0}

/* ── grid ── */
.hiw-grid{
  display:flex;align-items:stretch;justify-content:center;
  gap:16px;max-width:980px;margin:0 auto;
  position:relative;z-index:1;
}

/* ── cards ── */
.hiw-step{
  flex:1;position:relative;overflow:hidden;
  background:#F8FAFC;
  border:1px solid var(--border);
  border-radius:22px;
  padding:36px 30px 32px;
  transition:border-color .22s,background .22s,transform .22s;
}
.hiw-step:hover{
  background:#fff;
  border-color:rgba(99,102,241,.4);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(99,102,241,.08);
}
/* top accent bar on hover */
.hiw-step::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,#6366F1,#818CF8);
  border-radius:22px 22px 0 0;opacity:0;transition:opacity .22s;
}
.hiw-step:hover::before{opacity:1}

/* big decorative number */
.hiw-num{
  position:absolute;top:-4px;right:18px;
  font-family:var(--r);font-size:92px;font-weight:900;line-height:1;
  letter-spacing:-.04em;
  background:linear-gradient(160deg,rgba(99,102,241,.14) 0%,transparent 70%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;pointer-events:none;
}

.hiw-icon{
  width:52px;height:52px;border-radius:15px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin:0 0 18px;
  position:relative;z-index:1;
  box-shadow:0 4px 16px rgba(0,0,0,.06);
}
.hiw-step h3{
  font-family:var(--r);font-size:18px;font-weight:700;color:var(--dark);
  margin:0 0 10px;position:relative;z-index:1;
}
.hiw-step p{
  font-size:13.5px;line-height:1.72;
  color:var(--muted);
  margin:0;position:relative;z-index:1;
}

/* connector between cards */
.hiw-connector{
  display:flex;align-items:center;flex-shrink:0;
  padding-bottom:24px;
}
.hiw-connector i{font-size:18px;color:#CBD5E1}

/* ── CTA ── */
.hiw-cta{
  text-align:center;margin-top:56px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  position:relative;z-index:1;
}
.hiw-cta .btn-primary{
  font-size:15px;padding:14px 36px;
  box-shadow:0 4px 20px rgba(99,102,241,.25);
  letter-spacing:.01em;
}
.hiw-cta .btn-primary:hover{
  box-shadow:0 6px 28px rgba(99,102,241,.38);
}
.hiw-note{font-size:12.5px;color:var(--muted);letter-spacing:.02em}

/* ── responsive ── */
@media(max-width:760px){
  .hiw-grid{flex-direction:column;align-items:stretch;gap:12px}
  .hiw-connector{justify-content:center;padding:0;transform:rotate(90deg);height:28px}
  .hiw-step{padding:28px 22px 24px}
  .hiw-num{font-size:72px}
  .hiw-header h2{font-size:28px}
  .hiw-num{font-size:72px}
}

/* ── NEX CHATBOT WIDGET ────────────────────────────────────── */
#nex-bot-widget{position:fixed;bottom:28px;right:28px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:12px}

/* trigger bubble */
.nex-bot-trigger{
  width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg,#4F52D3,#6366F1);
  color:#fff;font-size:24px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(99,102,241,.45);
  transition:transform .2s,box-shadow .2s;position:relative;
}
.nex-bot-trigger:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(99,102,241,.6)}
.nex-bot-badge{
  position:absolute;top:0;right:0;
  background:#EF4444;color:#fff;border-radius:50%;
  width:18px;height:18px;font-size:10px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:2px solid #fff;
}

/* window */
.nex-bot-window{
  width:360px;
  background:#fff;
  border-radius:20px;
  box-shadow:0 24px 80px rgba(0,0,0,.18),0 4px 20px rgba(0,0,0,.08);
  overflow:hidden;display:flex;flex-direction:column;
  animation:nexBotSlide .2s ease;
  border:1px solid var(--border);
  max-height:min(580px,80vh);
}
@keyframes nexBotSlide{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}

/* header */
.nex-bot-header{
  background:linear-gradient(135deg,#07111C,#0D1F2E);
  padding:14px 16px;display:flex;align-items:center;gap:12px;flex-shrink:0;
}
.nex-bot-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#4F52D3,#818CF8);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:#fff;
}
.nex-bot-name{font-family:var(--r);font-size:13.5px;font-weight:700;color:#fff}
.nex-bot-status{font-size:11px;color:#34D399;margin-top:1px;display:flex;align-items:center;gap:4px}
.nex-bot-status::before{content:'●';font-size:8px}
.nex-bot-close{
  margin-left:auto;background:rgba(255,255,255,.12);border:none;
  color:#fff;border-radius:8px;width:30px;height:30px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:14px;
  transition:background .15s;flex-shrink:0;
}
.nex-bot-close:hover{background:rgba(255,255,255,.22)}

/* messages */
.nex-bot-messages{
  flex:1;overflow-y:auto;padding:16px;
  display:flex;flex-direction:column;gap:10px;
  scroll-behavior:smooth;
}
.nex-bot-messages::-webkit-scrollbar{width:4px}
.nex-bot-messages::-webkit-scrollbar-track{background:transparent}
.nex-bot-messages::-webkit-scrollbar-thumb{background:#E2E8F0;border-radius:4px}

/* bubbles */
.nex-msg{display:flex;gap:8px;align-items:flex-end;max-width:100%}
.nex-msg.user{flex-direction:row-reverse}
.nex-msg-avatar{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#4F52D3,#818CF8);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:#fff;
}
.nex-msg-bubble{
  background:#F1F5F9;border-radius:16px 16px 16px 4px;
  padding:10px 14px;font-size:13.5px;line-height:1.55;color:var(--dark);
  max-width:82%;
}
.nex-msg.user .nex-msg-bubble{
  background:linear-gradient(135deg,#4F52D3,#6366F1);
  color:#fff;border-radius:16px 16px 4px 16px;
}

/* typing indicator */
.nex-typing{display:flex;gap:4px;padding:10px 14px;background:#F1F5F9;border-radius:16px 16px 16px 4px;width:fit-content}
.nex-dot{width:6px;height:6px;border-radius:50%;background:#94A3B8;animation:nexPulse 1.2s infinite}
.nex-dot:nth-child(2){animation-delay:.2s}
.nex-dot:nth-child(3){animation-delay:.4s}
@keyframes nexPulse{0%,80%,100%{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}

/* inline job cards */
.nex-job-card{
  background:#fff;border:1px solid var(--border);border-radius:12px;
  padding:12px 14px;cursor:pointer;transition:border-color .15s,box-shadow .15s;
  margin-top:4px;
}
.nex-job-card:hover{border-color:var(--indigo4);box-shadow:0 2px 12px rgba(99,102,241,.1)}
.nex-job-card-title{font-family:var(--r);font-weight:600;color:var(--dark);font-size:13px;margin-bottom:3px}
.nex-job-card-co{font-size:12px;color:var(--muted)}
.nex-job-card-tags{display:flex;gap:5px;margin-top:6px;flex-wrap:wrap}
.nex-job-card-tag{background:#F1F5F9;border-radius:6px;padding:2px 8px;font-size:11px;color:#64748B;font-weight:500}
.nex-job-card-tag.new{background:#DCFCE7;color:#15803D}

/* CTA card */
.nex-cta-card{
  background:linear-gradient(135deg,#EEF2FF,#F5F3FF);
  border:1px solid rgba(99,102,241,.2);border-radius:12px;
  padding:14px 16px;margin-top:4px;text-align:center;
}
.nex-cta-card p{font-size:13px;color:var(--dark);margin:0 0 10px;line-height:1.5}
.nex-cta-card .btn-primary{font-size:13px;padding:8px 20px;width:100%}

/* chips */
.nex-bot-chips{
  padding:0 12px 8px;display:flex;flex-wrap:wrap;gap:6px;flex-shrink:0;
}
.nex-chip{
  background:#F1F5F9;border:1px solid var(--border);border-radius:100px;
  padding:6px 14px;font-size:12.5px;font-weight:500;color:#475569;
  cursor:pointer;transition:all .15s;white-space:nowrap;
}
.nex-chip:hover{background:#EEF2FF;border-color:var(--indigo4);color:var(--indigo)}

/* input row */
.nex-bot-input-row{
  display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--border);
  background:#FAFAFA;flex-shrink:0;
}
#nex-bot-input{
  flex:1;border:1px solid var(--border);border-radius:12px;
  padding:9px 14px;font-size:13.5px;font-family:var(--b);
  outline:none;color:var(--dark);background:#fff;
  transition:border-color .15s;
}
#nex-bot-input:focus{border-color:var(--indigo4)}
.nex-bot-send{
  width:38px;height:38px;border-radius:12px;border:none;
  background:linear-gradient(135deg,#4F52D3,#6366F1);
  color:#fff;cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:opacity .15s;
}
.nex-bot-send:hover{opacity:.88}

/* no-result card */
.nex-noresult{font-size:13px;color:var(--muted);text-align:center;padding:12px 0;font-style:italic}

@media(max-width:480px){
  #nex-bot-widget{bottom:16px;right:16px}
  .nex-bot-window{width:calc(100vw - 32px)}
}

/* ── Profile Skill Editor (compact) ────────────────────────── */
#pf-skill-editor{display:flex;flex-direction:column;gap:10px}

.pf-skill-tags-row{
  display:flex;flex-wrap:wrap;gap:7px;
  min-height:36px;align-items:flex-start;align-content:flex-start;
}
.pf-skill-empty{font-size:13px;color:var(--muted);font-style:italic;align-self:center}

.pf-skill-tag{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--indigo3);border:1px solid rgba(99,102,241,.2);
  color:var(--indigo);border-radius:100px;
  padding:5px 10px 5px 14px;
  font-size:13px;font-weight:500;
  transition:border-color .15s;
}
.pf-skill-tag:hover{border-color:rgba(99,102,241,.4)}
.pf-skill-rm{
  background:none;border:none;cursor:pointer;
  color:var(--indigo);opacity:.55;
  font-size:15px;line-height:1;padding:0;
  display:flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  transition:opacity .15s,background .15s;
}
.pf-skill-rm:hover{opacity:1;background:rgba(99,102,241,.15)}

.pf-skill-input-wrap{position:relative}
.pf-skill-input{
  width:100%;box-sizing:border-box;
  border:1px solid var(--border);border-radius:10px;
  padding:9px 14px;font-size:13.5px;font-family:var(--b);
  color:var(--dark);background:#fff;outline:none;
  transition:border-color .15s;
}
.pf-skill-input:focus{border-color:var(--indigo4)}
.pf-skill-input::placeholder{color:#94A3B8}

.pf-skill-sug-box{
  position:absolute;top:calc(100% + 4px);left:0;right:0;
  background:#fff;border:1px solid var(--border);
  border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.1);
  z-index:120;overflow:hidden;
}
.pf-skill-sug-item{
  padding:9px 14px;font-size:13.5px;cursor:pointer;
  color:var(--dark);transition:background .1s;
}
.pf-skill-sug-item:hover{background:var(--indigo3);color:var(--indigo)}

/* ── CPC Calculator & ROI & Testimonials responsive ─────── */
@media (max-width: 640px) {
  #cpc-calculator > div:nth-child(3) {
    grid-template-columns: 1fr !important;
  }
  #cpc-calculator #calc-result > div:first-child {
    grid-template-columns: 1fr !important;
  }
}

/* Testimonials grid responsive */
@media (max-width: 700px) {
  /* employer page inner grids */
  [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

/* ROI slider track */
#roi-slider {
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  background: rgba(99,102,241,.3);
  border-radius: 3px;
  outline: none;
}
#roi-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #6366F1;
  cursor: pointer;
  box-shadow: 0 0 0 4px rgba(99,102,241,.25);
  transition: box-shadow .15s;
}
#roi-slider::-webkit-slider-thumb:hover {
  box-shadow: 0 0 0 6px rgba(99,102,241,.3);
}
#roi-slider::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #6366F1;
  cursor: pointer;
  border: none;
  box-shadow: 0 0 0 4px rgba(99,102,241,.25);
}

/* Calc selects focus ring */
#calc-poste:focus, #calc-ville:focus {
  border-color: #6366F1 !important;
  box-shadow: 0 0 0 3px rgba(99,102,241,.15);
}

/* Testimonials card hover */
[style*="border-radius:20px"] {
  transition: box-shadow .2s, transform .2s;
}

/* ═══════════════════════════════════════════════════════════
   FEED
   ═══════════════════════════════════════════════════════════ */
.feed-layout {
  display: grid;
  grid-template-columns: 220px 1fr 220px;
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 28px 20px 60px;
  align-items: start;
}
@media (max-width: 1024px) {
  .feed-layout { grid-template-columns: 1fr 2fr; }
  .feed-sidebar-right { display: none; }
}
@media (max-width: 700px) {
  .feed-layout { grid-template-columns: 1fr; padding: 16px 12px; }
  .feed-sidebar { display: none; }
}
.feed-sidebar { position: sticky; top: 80px; }
.feed-sidebar-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
}
.feed-sidebar-title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
  margin-bottom: 10px;
}
.feed-filters { display: flex; flex-direction: column; gap: 4px; }
.feed-filter-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 8px; border: none;
  background: none; cursor: pointer;
  font-size: 13px; font-family: var(--b); font-weight: 500;
  color: var(--text); transition: background .15s, color .15s;
  width: 100%; text-align: left;
}
.feed-filter-btn:hover  { background: rgba(99,102,241,.08); color: var(--indigo); }
.feed-filter-btn.active { background: rgba(99,102,241,.12); color: var(--indigo); font-weight: 700; }
.feed-hashtag {
  display: inline-block; padding: 4px 10px; margin: 3px 3px 0 0;
  background: rgba(99,102,241,.08); color: var(--indigo);
  border-radius: 20px; font-size: 12px; font-weight: 600; cursor: pointer;
  transition: background .15s;
}
.feed-hashtag:hover { background: rgba(99,102,241,.18); }

/* Compose box */
.compose-box {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 16px; padding: 16px; margin-bottom: 16px;
  cursor: pointer; transition: box-shadow .2s;
}
.compose-box:hover { box-shadow: 0 4px 20px rgba(0,0,0,.08); }
.compose-box-inner { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.compose-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(135deg,var(--indigo),#8b5cf6);
  color: #fff; font-size: 14px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.compose-placeholder {
  flex: 1; padding: 10px 14px;
  border: 1px solid var(--border); border-radius: 24px;
  font-size: 14px; color: var(--muted);
  background: var(--bg); pointer-events: none;
}
.compose-type-btns { display: flex; gap: 8px; flex-wrap: wrap; border-top: 1px solid var(--border); padding-top: 12px; }
.compose-type-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 8px; border: 1px solid var(--border);
  background: none; cursor: pointer; font-size: 13px;
  font-family: var(--b); color: var(--muted); transition: all .15s;
}
.compose-type-btn:hover { background: var(--surface); color: var(--dark); border-color: var(--indigo); }

/* Compose modal tabs */
.compose-tabs {
  display: flex; gap: 4px; margin-bottom: 0;
  border-bottom: 1px solid var(--border); padding: 0 0 0 0;
}
.compose-tab {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 16px; border: none; background: none;
  cursor: pointer; font-size: 13px; font-family: var(--b); font-weight: 600;
  color: var(--muted); border-bottom: 2px solid transparent;
  transition: all .15s; margin-bottom: -1px;
}
.compose-tab:hover  { color: var(--dark); }
.compose-tab.active { color: var(--indigo); border-bottom-color: var(--indigo); }

/* Post card */
.post-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 16px; padding: 20px; margin-bottom: 14px;
  transition: box-shadow .2s;
}
.post-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.06); }
.post-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
.post-avatar {
  width: 42px; height: 42px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg,#6366f1,#8b5cf6);
  color: #fff; font-size: 15px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.post-author-info { flex: 1; min-width: 0; }
.post-author-name  { font-size: 14px; font-weight: 700; color: var(--dark); }
.post-author-title { font-size: 12px; color: var(--muted); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.post-date         { font-size: 11px; color: var(--muted); margin-top: 2px; }
.post-type-badge {
  font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 20px;
  display: inline-flex; align-items: center; gap: 4px; flex-shrink: 0;
}
.post-type-badge.hired  { background: #ecfdf5; color: #10b981; }
.post-type-badge.article { background: rgba(99,102,241,.1); color: var(--indigo); }
.post-type-badge.job     { background: #fffbeb; color: #d97706; }
.post-menu-btn {
  background: none; border: none; cursor: pointer; padding: 6px;
  color: var(--muted); border-radius: 6px; transition: color .15s, background .15s;
}
.post-menu-btn:hover { color: #ef4444; background: #fef2f2; }
.post-content { font-size: 14px; color: var(--dark); line-height: 1.7; margin-bottom: 14px; white-space: pre-wrap; word-break: break-word; }
.post-image { width: 100%; border-radius: 12px; margin-bottom: 14px; max-height: 400px; object-fit: cover; }
.post-article { background: rgba(99,102,241,.04); border: 1px solid rgba(99,102,241,.15); border-radius: 12px; padding: 16px; margin-bottom: 14px; }
.post-article-title { font-size: 16px; font-weight: 700; color: var(--dark); margin-bottom: 8px; }
.post-article-body  { font-size: 13px; color: var(--muted); line-height: 1.65; }
.post-stats { display: flex; gap: 16px; font-size: 13px; color: var(--muted); margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }
.post-actions { display: flex; gap: 4px; margin-bottom: 0; }
.post-action-btn {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 8px 12px; border: none; background: none; cursor: pointer;
  font-size: 13px; font-family: var(--b); font-weight: 600; color: var(--muted);
  border-radius: 8px; transition: all .15s;
}
.post-action-btn:hover { background: rgba(99,102,241,.08); color: var(--indigo); }
.post-action-btn.liked { color: #ef4444; }
.post-action-btn.liked:hover { background: #fef2f2; }

/* Comments */
.comments-section { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border); }
.comment-item { display: flex; gap: 10px; margin-bottom: 12px; }
.comment-avatar {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg,#6366f1,#8b5cf6);
  color: #fff; font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.comment-body { flex: 1; background: var(--bg); border-radius: 12px; padding: 10px 12px; }
.comment-author { font-size: 12px; font-weight: 700; color: var(--dark); }
.comment-time   { font-size: 11px; color: var(--muted); margin-left: 8px; }
.comment-text   { font-size: 13px; color: var(--dark); margin-top: 3px; line-height: 1.55; }
.comment-input-row { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.comment-input-avatar {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg,#6366f1,#8b5cf6);
  color: #fff; font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.comment-input {
  flex: 1; border: 1px solid var(--border); border-radius: 20px;
  padding: 8px 14px; font-size: 13px; outline: none;
  background: var(--bg); transition: border-color .15s;
}
.comment-input:focus { border-color: var(--indigo); }
.comment-submit-btn {
  width: 34px; height: 34px; border-radius: 50%; border: none;
  background: var(--indigo); color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: opacity .15s;
}
.comment-submit-btn:hover { opacity: .85; }

/* Q&A */
.qa-item { padding: 12px 0; border-bottom: 1px solid var(--border); }
.qa-item:last-child { border-bottom: none; }
.qa-question { font-size: 13px; font-weight: 600; color: var(--dark); margin-bottom: 6px; display: flex; gap: 6px; align-items: flex-start; }
.qa-answer   { font-size: 13px; color: var(--dark); line-height: 1.6; padding: 8px 12px; background: #f0fdf4; border-left: 3px solid #10b981; border-radius: 0 8px 8px 0; }
.qa-input-row { display: flex; gap: 8px; margin-top: 14px; }
.qa-input {
  flex: 1; border: 1px solid var(--border); border-radius: 8px;
  padding: 9px 12px; font-size: 13px; outline: none;
  transition: border-color .15s;
}
.qa-input:focus { border-color: var(--indigo); }

/* ── Fix: modal inputs lisibles sur mobile (forced dark mode) ── */
.modal-box {
  color-scheme: light;
}
.modal-box textarea,
.modal-box input[type="text"],
.modal-box input[type="url"],
.modal-box input[type="email"],
.modal-box input[type="search"],
.modal-box select {
  color: #1e293b !important;
  background-color: #ffffff !important;
}
.modal-box textarea::placeholder,
.modal-box input::placeholder {
  color: #94a3b8 !important;
}
#compose-image-label {
  color: #64748b !important;
}
#compose-image-label span {
  color: #64748b !important;
}

/* ── Notification dropdown ─────────────────────────────────── */
.notif-dropdown{position:absolute;top:calc(100% + 10px);right:-8px;width:360px;max-width:calc(100vw - 24px);background:#fff;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.18);z-index:9999;overflow:hidden;animation:ddSlide .15s ease}
@keyframes ddSlide{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.notif-dd-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid #f1f5f9}
.notif-dd-title{font-weight:700;font-size:15px;color:#1e293b}
.notif-dd-markall{background:none;border:none;font-size:12px;color:#6366f1;cursor:pointer;font-weight:600;padding:4px 8px;border-radius:6px;transition:background .15s}
.notif-dd-markall:hover{background:#eef2ff}
.notif-dd-list{max-height:400px;overflow-y:auto}
.notif-dd-empty{padding:32px 16px;text-align:center;color:#94a3b8;font-size:13px}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;border-bottom:1px solid #f8fafc}
.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:#f5f3ff}
.notif-item:hover{background:#f1f5f9}
.notif-item.unread:hover{background:#ede9fe}
.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.notif-item-body{flex:1;min-width:0}
.notif-item-title{font-size:13px;font-weight:600;color:#1e293b;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-msg{font-size:12px;color:#64748b;margin-top:2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.notif-item-time{font-size:11px;color:#94a3b8;margin-top:4px}
.notif-unread-dot{width:8px;height:8px;border-radius:50%;background:#6366f1;flex-shrink:0;margin-top:4px}

/* ── Compose modal — thème sombre (fond navy + texte blanc) ──── */
#compose-modal .modal-box {
  background: #111827;
  color: #fff;
  color-scheme: dark;
  border: 1px solid rgba(255,255,255,.08);
}
#compose-modal .modal-header {
  border-bottom-color: rgba(255,255,255,.08);
}
#compose-modal .modal-header h3 {
  color: #fff;
}
#compose-modal .modal-close {
  color: rgba(255,255,255,.55);
}
#compose-modal .modal-close:hover {
  color: #fff;
  background: rgba(255,255,255,.08);
}
#compose-modal .compose-tabs {
  border-bottom-color: rgba(255,255,255,.08);
}
#compose-modal .compose-tab {
  color: rgba(255,255,255,.5);
}
#compose-modal .compose-tab:hover {
  color: rgba(255,255,255,.85);
}
#compose-modal .compose-tab.active {
  color: #818cf8;
  border-bottom-color: #818cf8;
}
#compose-modal textarea,
#compose-modal input[type="text"],
#compose-modal input[type="url"],
#compose-modal input[type="email"],
#compose-modal input[type="search"],
#compose-modal select {
  background: rgba(255,255,255,.07) !important;
  color: #fff !important;
  border-color: rgba(255,255,255,.14) !important;
}
#compose-modal textarea::placeholder,
#compose-modal input::placeholder {
  color: rgba(255,255,255,.32) !important;
}
#compose-modal .modal-body {
  color: #fff;
}
#compose-modal .modal-footer {
  border-top: 1px solid rgba(255,255,255,.08);
}
#compose-modal .modal-footer .btn-ghost {
  color: rgba(255,255,255,.65);
  border-color: rgba(255,255,255,.18);
}
#compose-modal .modal-footer .btn-ghost:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
}
#compose-modal #compose-image-label {
  color: rgba(255,255,255,.45) !important;
  border-color: rgba(255,255,255,.18) !important;
}
#compose-modal #compose-image-label span {
  color: rgba(255,255,255,.45) !important;
}
#compose-modal #compose-image-label.success-label {
  color: #4ade80 !important;
}
#compose-modal #compose-image-label.success-label span {
  color: #4ade80 !important;
}

/* ── Tax Calculator ─────────────────────────────────────── */
.tax-page-wrap{max-width:920px;margin:0 auto;padding:36px 20px 80px}
.tax-page-hdr{text-align:center;margin-bottom:32px}
.tax-page-hdr h1{font-family:var(--r);font-size:30px;font-weight:800;color:var(--dark);margin-bottom:8px}
.tax-page-hdr p{color:var(--muted);font-size:15px}
.tax-input-card{background:#fff;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.06);padding:24px;margin-bottom:24px}
.tax-rate-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:20px;background:#f8fafc;border-radius:10px;padding:4px}
.tc-tab{flex:1;min-width:56px;background:none;border:none;border-radius:7px;padding:8px 10px;font-size:13px;font-weight:500;color:var(--text);cursor:pointer;transition:all .15s}
.tc-tab:hover{color:var(--dark);background:rgba(255,255,255,.6)}
.tc-tab.active{background:#fff;color:var(--dark);box-shadow:0 1px 4px rgba(0,0,0,.1);font-weight:700}
.tax-fields-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.tax-salary-wrap{display:flex;align-items:center;flex:1;min-width:200px;border:2px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;transition:border-color .15s}
.tax-salary-wrap:focus-within{border-color:var(--indigo)}
.tax-cur-sym{padding:0 8px 0 14px;font-size:20px;font-weight:700;color:var(--dark)}
.tax-salary-input{flex:1;border:none;outline:none;font-size:22px;font-weight:700;color:var(--dark);padding:12px 0;font-family:var(--r);background:transparent;min-width:80px}
.tax-cur-code{padding:0 14px;font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.04em}
.tax-prov-select{border:2px solid var(--border);border-radius:10px;padding:12px 16px;font-size:15px;font-weight:500;color:var(--dark);background:#fff;cursor:pointer;outline:none;min-width:180px;transition:border-color .15s}
.tax-prov-select:focus{border-color:var(--indigo)}
.tc-grid{display:grid;grid-template-columns:1fr 220px;gap:20px;margin-bottom:24px}
.tc-breakdown-card,.tc-visual-card{background:#fff;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.06);padding:24px}
.tc-card-title{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:16px;text-transform:uppercase;letter-spacing:.04em}
.tc-rows{display:flex;flex-direction:column}
.tc-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f1f5f9;font-size:15px;color:var(--text)}
.tc-row small{font-size:11px;color:var(--muted);margin-left:4px}
.tc-salary-row{font-weight:700;font-size:16px;color:var(--dark)}
.tc-neg{color:#ef4444}
.tc-total-row{border-top:2px solid var(--border)!important;padding-top:12px;font-size:15px}
.tc-net-row{font-weight:700;font-size:17px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);margin:0 -24px;padding:14px 24px;border-radius:0 0 16px 16px;border-bottom:none!important}
.tc-green{color:#16a34a;font-size:18px}
.tc-rate-chips{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}
.tc-rate-chip{flex:1;min-width:100px;background:#f8fafc;border-radius:10px;padding:12px;text-align:center;border:1px solid var(--border)}
.tc-rate-num{font-family:var(--r);font-size:22px;font-weight:800;color:var(--dark)}
.tc-rate-lbl{font-size:11px;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.04em}
.tc-visual-card{display:flex;flex-direction:column;align-items:center;gap:16px}
.tc-donut-legend{display:flex;flex-direction:column;gap:7px;align-self:stretch}
.tc-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--dark)}
.tc-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.tc-net-big{text-align:center;margin-top:auto}
.tc-net-amount{font-family:var(--r);font-size:22px;font-weight:800;color:var(--dark)}
.tc-net-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.tax-prov-table-wrap{background:#fff;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.06);padding:24px;margin-bottom:24px;overflow-x:auto}
.tax-section-title{font-family:var(--r);font-size:18px;font-weight:700;color:var(--dark);margin-bottom:20px}
.tc-prov-tbl{width:100%;border-collapse:collapse;font-size:14px}
.tc-prov-tbl th{text-align:left;padding:10px 12px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border)}
.tc-prov-tbl td{padding:11px 12px;border-bottom:1px solid #f8fafc;vertical-align:middle}
.tc-prov-tbl tr.tc-sel td{background:#eff6ff;font-weight:600}
.tc-rank{display:inline-flex;width:22px;height:22px;border-radius:50%;background:#f1f5f9;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted)}
.tc-you{font-size:10px;font-weight:700;color:var(--indigo);margin-left:4px}
.tc-bar-wrap{width:80px;height:6px;background:#f1f5f9;border-radius:3px;overflow:hidden;flex-shrink:0}
.tc-bar{height:100%;background:var(--indigo);border-radius:3px;max-width:80px}
.tax-disclaimer{font-size:12px;color:var(--muted);text-align:center;padding:0 20px;margin-top:8px}

/* ── Messages responsive layout ─────────────────────────── */
.msg-layout-outer{display:flex;border:1px solid var(--border);border-radius:12px;overflow:hidden;height:calc(100vh - 210px);min-height:480px;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.msg-threads-panel{width:300px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;background:#fafbfc;display:flex;flex-direction:column}
.msg-threads-header{padding:12px 16px;border-bottom:1px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.msg-new-conv-btn{font-size:11px;padding:4px 10px;border-radius:6px;background:#6366f1;color:#fff;border:none;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;gap:4px}
.msg-thread-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#fff}
.msg-mobile-back{display:none}
@media(max-width:640px){
  .msg-layout-outer{height:calc(100dvh - 140px);min-height:0;border-radius:8px;position:relative}
  .msg-threads-panel{width:100%;border-right:none}
  .msg-thread-panel{display:none;position:absolute;inset:0;z-index:20;background:#fff}
  .msg-layout-outer.msg-conv-open .msg-threads-panel{display:none}
  .msg-layout-outer.msg-conv-open .msg-thread-panel{display:flex}
  .msg-mobile-back{display:flex;align-items:center;gap:8px;padding:11px 14px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;cursor:pointer;font-size:13px;font-weight:600;color:#6366f1}
}
@media(max-width:720px){.tc-grid{grid-template-columns:1fr}.tax-fields-row{flex-direction:column}.tax-prov-select,.tax-salary-wrap{width:100%}.tc-bar-wrap{display:none}}
