/* ── Variables & Reset ─────────────────────────────────────────────────────── */
:root {
  --primary:       #1d4ed8;
  --primary-hover: #1e40af;
  --primary-light: #eff6ff;
  --green:         #059669;
  --green-hover:   #047857;
  --green-light:   #ecfdf5;
  --purple:        #7c3aed;
  --purple-light:  #f5f3ff;
  --orange:        #ea580c;
  --orange-light:  #fff7ed;
  --gray-50:  #f8fafc; --gray-100: #f1f5f9; --gray-200: #e2e8f0;
  --gray-300: #cbd5e1; --gray-400: #94a3b8; --gray-500: #64748b;
  --gray-600: #475569; --gray-700: #334155; --gray-800: #1e293b; --gray-900: #0f172a;
  --white: #ffffff;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --radius-xs: 4px; --radius-sm: 6px; --radius: 10px;
  --radius-md: 12px; --radius-lg: 16px; --radius-full: 9999px;
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow:    0 4px 6px rgba(0,0,0,0.05),  0 2px 4px rgba(0,0,0,0.04);
  --shadow-md: 0 10px 15px rgba(0,0,0,0.06), 0 4px 6px rgba(0,0,0,0.04);
  --shadow-lg: 0 20px 25px rgba(0,0,0,0.07), 0 10px 10px rgba(0,0,0,0.04);
  --transition: 180ms ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);color:var(--gray-800);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--font)}
input,select,textarea{font-family:var(--font)}
ul{list-style:none}

/* ── Typography ─────────────────────────────────────────────────────────────── */
h1,h2,h3,h4,h5{line-height:1.25;font-weight:700;color:var(--gray-900)}
h1{font-size:clamp(2rem,5vw,3.25rem)}
h2{font-size:clamp(1.5rem,3vw,2.25rem)}
h3{font-size:1.25rem} h4{font-size:1.05rem}
p{color:var(--gray-600)}

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-sm{padding:56px 0}
.section-header{text-align:center;margin-bottom:52px}
.section-header .tag{
  display:inline-block;background:var(--primary-light);color:var(--primary);
  font-size:.78rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 14px;border-radius:var(--radius-full);margin-bottom:14px}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--gray-500);font-size:1.05rem;max-width:540px;margin:0 auto}

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:var(--radius);
  font-size:.9rem;font-weight:600;border:none;transition:var(--transition);white-space:nowrap;cursor:pointer;line-height:1}
.btn-sm{padding:7px 16px;font-size:.82rem}
.btn-lg{padding:13px 26px;font-size:.95rem}
.btn-xl{padding:15px 34px;font-size:1rem;border-radius:var(--radius-md)}
.btn-primary{background:var(--primary);color:var(--white)}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(29,78,216,.3)}
.btn-green{background:var(--green);color:var(--white)}
.btn-green:hover{background:var(--green-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(5,150,105,.3)}
.btn-outline{background:transparent;color:var(--gray-700);border:1.5px solid var(--gray-200)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.btn-ghost{background:transparent;color:var(--gray-600);padding-left:8px;padding-right:8px}
.btn-ghost:hover{color:var(--primary);background:var(--primary-light)}
.btn-white{background:var(--white);color:var(--primary);font-weight:600}
.btn-white:hover{background:var(--gray-50);box-shadow:var(--shadow-md)}

/* ── Navbar ─────────────────────────────────────────────────────────────────── */
.navbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-100);padding:0}
.nav-inner{display:flex;align-items:center;gap:12px;height:66px}
.nav-logo{display:flex;align-items:center;gap:9px;font-size:1.2rem;font-weight:800;
  color:var(--gray-900);flex-shrink:0;margin-right:8px}
.nav-logo .logo-icon{width:34px;height:34px;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.nav-links{display:flex;align-items:center;gap:4px;flex:1}
.nav-links a{padding:7px 13px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:500;
  color:var(--gray-600);transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--primary);background:var(--primary-light)}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.nav-divider{width:1px;height:20px;background:var(--gray-200);margin:0 4px}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer}
.hamburger span{width:22px;height:2px;background:var(--gray-700);border-radius:2px;transition:var(--transition)}
.mobile-menu{display:none;position:fixed;top:66px;left:0;right:0;bottom:0;
  background:var(--white);z-index:99;padding:24px;overflow-y:auto}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:13px 0;font-size:1rem;font-weight:500;
  color:var(--gray-700);border-bottom:1px solid var(--gray-100)}
.mobile-menu .mobile-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.mobile-menu .btn{width:100%;justify-content:center}

/* ── Hero ───────────────────────────────────────────────────────────────────── */
.hero{background:linear-gradient(135deg,#0f172a 0%,#1e3a6e 50%,#1d4ed8 100%);
  padding:90px 0 100px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  background:rgba(124,58,237,.15);top:-200px;right:-100px;pointer-events:none}
.hero::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;
  background:rgba(5,150,105,.1);bottom:-150px;left:-100px;pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:760px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.9);font-size:.82rem;font-weight:500;
  padding:6px 14px;border-radius:var(--radius-full);margin-bottom:24px;backdrop-filter:blur(8px)}
.hero-badge .dot{width:7px;height:7px;background:#4ade80;border-radius:50%;animation:pulse 2s infinite}
.hero h1{color:var(--white);margin-bottom:18px;letter-spacing:-.02em}
.hero h1 .hl{background:linear-gradient(90deg,#60a5fa,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{color:rgba(255,255,255,.75);font-size:1.15rem;margin-bottom:36px;max-width:560px}
.hero-search{background:var(--white);border-radius:var(--radius-md);padding:8px 8px 8px 20px;
  display:flex;align-items:center;gap:8px;max-width:640px;box-shadow:var(--shadow-lg)}
.hero-search input{flex:1;border:none;outline:none;font-size:.95rem;color:var(--gray-800);background:transparent}
.hero-search input::placeholder{color:var(--gray-400)}
.hero-search .vdivider{width:1px;height:28px;background:var(--gray-200)}
.hero-search select{border:none;outline:none;font-size:.88rem;color:var(--gray-600);
  background:transparent;padding:0 8px;cursor:pointer}
.hero-tags{display:flex;align-items:center;gap:8px;margin-top:20px;flex-wrap:wrap}
.hero-tags span{color:rgba(255,255,255,.55);font-size:.82rem}
.hero-tag{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.85);font-size:.78rem;padding:4px 11px;
  border-radius:var(--radius-full);cursor:pointer;transition:var(--transition)}
.hero-tag:hover{background:rgba(255,255,255,.18)}

/* ── Stats Bar ──────────────────────────────────────────────────────────────── */
.stats-bar{background:var(--white);border-bottom:1px solid var(--gray-100);padding:30px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat-item{text-align:center}
.stat-number{font-size:1.9rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;display:block}
.stat-label{font-size:.82rem;color:var(--gray-500);font-weight:500;margin-top:3px}

/* ── Categories ─────────────────────────────────────────────────────────────── */
.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.category-card{background:var(--white);border:1.5px solid var(--gray-100);border-radius:var(--radius-md);
  padding:22px 18px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:14px}
.category-card:hover{border-color:var(--primary);background:var(--primary-light);
  transform:translateY(-2px);box-shadow:var(--shadow-md)}
.category-icon{width:46px;height:46px;border-radius:var(--radius);display:flex;
  align-items:center;justify-content:center;font-size:1.35rem;flex-shrink:0}
.cat-blue{background:#dbeafe} .cat-purple{background:#f5f3ff} .cat-green{background:#dcfce7}
.cat-orange{background:#ffedd5} .cat-red{background:#fee2e2} .cat-yellow{background:#fef9c3}
.cat-cyan{background:#cffafe} .cat-pink{background:#fce7f3}
.category-info h4{font-size:.9rem;font-weight:600;color:var(--gray-800);margin-bottom:2px}
.category-info span{font-size:.76rem;color:var(--gray-500)}

/* ── Job Card (Grid layout on homepage) ─────────────────────────────────────── */
.jobs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.job-card{background:var(--white);border:1.5px solid var(--gray-100);border-radius:var(--radius-md);
  padding:22px;transition:var(--transition);position:relative;cursor:pointer}
.job-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.job-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}
.company-info{display:flex;align-items:center;gap:12px}
.company-avatar{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;
  justify-content:center;font-size:.9rem;font-weight:700;color:var(--white);flex-shrink:0}
.company-meta h4{font-size:.85rem;font-weight:600;color:var(--gray-800)}
.company-meta .meta-row{display:flex;align-items:center;gap:6px;margin-top:2px}
.company-name{font-size:.76rem;color:var(--gray-500)}
.verified-badge{display:inline-flex;align-items:center;gap:3px;font-size:.68rem;color:var(--primary);font-weight:600}
.save-btn{background:none;border:none;color:var(--gray-400);cursor:pointer;padding:4px;
  border-radius:var(--radius-sm);transition:var(--transition);font-size:1.05rem;line-height:1}
.save-btn:hover{color:var(--primary);background:var(--primary-light)}
.save-btn.saved{color:var(--primary)}
.job-title{font-size:1rem;font-weight:700;color:var(--gray-900);margin-bottom:12px;line-height:1.35}
.job-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.job-tag{background:var(--gray-50);color:var(--gray-600);font-size:.72rem;font-weight:500;
  padding:3px 10px;border-radius:var(--radius-full);border:1px solid var(--gray-200)}
.job-card-footer{display:flex;align-items:center;justify-content:space-between;
  padding-top:14px;border-top:1px solid var(--gray-100)}
.job-rate{font-size:.9rem;font-weight:700;color:var(--green)}
.job-meta-right{display:flex;align-items:center;gap:12px}
.job-meta-item{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--gray-400)}
.featured-badge{position:absolute;top:14px;right:50px;
  background:linear-gradient(90deg,var(--orange),#f97316);color:var(--white);
  font-size:.66rem;font-weight:700;padding:3px 8px;border-radius:var(--radius-full);
  letter-spacing:.04em;text-transform:uppercase}

/* ── How It Works ───────────────────────────────────────────────────────────── */
.hiw-section{background:var(--gray-50)}
.hiw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.hiw-card{text-align:center;padding:36px 24px;background:var(--white);
  border-radius:var(--radius-lg);border:1.5px solid var(--gray-100);position:relative}
.hiw-step{width:30px;height:30px;background:var(--primary);color:var(--white);
  font-size:.78rem;font-weight:700;border-radius:50%;display:flex;align-items:center;
  justify-content:center;position:absolute;top:-13px;left:50%;transform:translateX(-50%)}
.hiw-icon{width:70px;height:70px;border-radius:var(--radius-lg);background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;font-size:1.9rem;margin:0 auto 18px}
.hiw-card h3{margin-bottom:10px;color:var(--gray-900)}
.hiw-card p{font-size:.9rem;color:var(--gray-500);line-height:1.65}

/* ── Testimonials ───────────────────────────────────────────────────────────── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testimonial-card{background:var(--white);border:1.5px solid var(--gray-100);
  border-radius:var(--radius-md);padding:26px}
.testimonial-stars{color:#f59e0b;font-size:.9rem;margin-bottom:14px;letter-spacing:2px}
.testimonial-text{font-size:.92rem;color:var(--gray-600);line-height:1.68;margin-bottom:20px}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:.9rem;font-weight:600;color:var(--white);flex-shrink:0}
.author-name{font-size:.88rem;font-weight:600;color:var(--gray-800)}
.author-role{font-size:.75rem;color:var(--gray-400);margin-top:1px}

/* ── Trusted By ─────────────────────────────────────────────────────────────── */
.trusted-section{background:var(--gray-50);padding:48px 0}
.trusted-section h5{text-align:center;color:var(--gray-400);font-size:.78rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:26px}
.trusted-logos{display:flex;align-items:center;justify-content:center;gap:44px;flex-wrap:wrap}
.trusted-logo{font-size:1.15rem;font-weight:800;color:var(--gray-300);letter-spacing:-.02em}

/* ── CTA Section ────────────────────────────────────────────────────────────── */
.cta-section{background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%);
  padding:80px 0;text-align:center}
.cta-section h2{color:var(--white);margin-bottom:14px}
.cta-section p{color:rgba(255,255,255,.75);font-size:1.05rem;margin-bottom:36px;
  max-width:480px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── Footer ─────────────────────────────────────────────────────────────────── */
.footer{background:var(--gray-900);padding:72px 0 0;color:var(--white)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-brand .logo-row{display:flex;align-items:center;gap:9px;font-size:1.2rem;
  font-weight:800;margin-bottom:14px}
.footer-brand .logo-icon{width:32px;height:32px;
  background:linear-gradient(135deg,var(--primary),var(--purple));
  border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.footer-brand p{font-size:.86rem;color:rgba(255,255,255,.45);line-height:1.7;
  margin-bottom:22px;max-width:280px}
.social-links{display:flex;gap:10px}
.social-link{width:36px;height:36px;border-radius:var(--radius-sm);
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;font-size:.88rem;
  transition:var(--transition);color:rgba(255,255,255,.6)}
.social-link:hover{background:rgba(255,255,255,.14);color:var(--white)}
.footer-col h6{font-size:.8rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:rgba(255,255,255,.88);margin-bottom:18px}
.footer-col a{display:block;font-size:.86rem;color:rgba(255,255,255,.45);
  margin-bottom:10px;transition:var(--transition)}
.footer-col a:hover{color:var(--white)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:20px 0;
  font-size:.8rem;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:10px}
.footer-bottom-links{display:flex;gap:22px}
.footer-bottom-links a{color:rgba(255,255,255,.3);transition:var(--transition)}
.footer-bottom-links a:hover{color:rgba(255,255,255,.65)}

/* ── Auth Pages ─────────────────────────────────────────────────────────────── */
.auth-page-body{background:var(--gray-50)}
.auth-layout{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.auth-brand{background:linear-gradient(145deg,#0f172a 0%,#1a2f64 55%,#1d4ed8 100%);
  padding:48px;display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden}
.auth-brand::before{content:'';position:absolute;width:400px;height:400px;border-radius:50%;
  background:rgba(124,58,237,.2);top:-120px;right:-100px}
.auth-brand::after{content:'';position:absolute;width:320px;height:320px;border-radius:50%;
  background:rgba(5,150,105,.15);bottom:-100px;left:-80px}
.brand-content{position:relative;z-index:1}
.brand-logo{display:flex;align-items:center;gap:10px;font-size:1.3rem;font-weight:800;
  color:var(--white);margin-bottom:56px}
.brand-logo .logo-icon{width:38px;height:38px;background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.2);border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.brand-headline{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:var(--white);
  line-height:1.25;margin-bottom:14px}
.brand-headline .hl{background:linear-gradient(90deg,#60a5fa,#a78bfa);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.brand-sub{color:rgba(255,255,255,.6);font-size:.98rem;line-height:1.65;max-width:360px}
.brand-features{display:flex;flex-direction:column;gap:14px;margin-top:36px;
  position:relative;z-index:1}
.brand-feature{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.7);font-size:.9rem}
.brand-feature .check{width:22px;height:22px;background:rgba(5,150,105,.25);
  border:1px solid rgba(5,150,105,.5);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:.62rem;flex-shrink:0}
.brand-stats{display:flex;gap:32px;margin-top:40px;padding-top:28px;
  border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:1}
.brand-stat strong{display:block;font-size:1.6rem;font-weight:800;color:var(--white);letter-spacing:-.02em}
.brand-stat span{font-size:.76rem;color:rgba(255,255,255,.45)}

/* ── Auth Form ──────────────────────────────────────────────────────────────── */
.auth-form-side{background:var(--white);display:flex;align-items:center;
  justify-content:center;padding:48px 56px;overflow-y:auto}
.auth-form-wrap{width:100%;max-width:400px}
.auth-form-wrap h2{font-size:1.65rem;margin-bottom:6px}
.auth-form-wrap .auth-sub{color:var(--gray-500);font-size:.9rem;margin-bottom:32px}
.auth-form-wrap .auth-sub a{color:var(--primary);font-weight:600}
.form-group{margin-bottom:17px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.form-control{width:100%;padding:11px 14px;border:1.5px solid var(--gray-200);
  border-radius:var(--radius);font-size:.9rem;color:var(--gray-800);outline:none;
  transition:var(--transition);background:var(--white)}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(29,78,216,.08)}
.form-control.is-error{border-color:#dc2626}
.form-control::placeholder{color:var(--gray-300)}
.input-wrap{position:relative}
.input-wrap .form-control{padding-left:40px}
.input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);
  font-size:.95rem;color:var(--gray-400);pointer-events:none}
.input-suffix{position:absolute;right:11px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--gray-400);cursor:pointer;font-size:.95rem;
  padding:4px;border-radius:4px;line-height:1}
.input-suffix:hover{color:var(--gray-600)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-check{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--gray-600);cursor:pointer}
.form-check input[type="checkbox"]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer}
.form-footer-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.forgot-link{font-size:.82rem;color:var(--primary);font-weight:500}
.forgot-link:hover{text-decoration:underline}
.form-error{display:none;background:#fef2f2;border:1px solid #fecaca;color:#dc2626;
  font-size:.82rem;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:16px;
  align-items:center;gap:8px}
.form-error.show{display:flex}

/* ── CAPTCHA ────────────────────────────────────────────────────────────────── */
.captcha-wrap{border:1.5px solid var(--gray-200);border-radius:var(--radius);overflow:hidden}
.captcha-top{display:flex;align-items:center;gap:0;background:var(--gray-50);
  padding:10px 12px;border-bottom:1.5px solid var(--gray-200)}
#captchaCanvas,#regCaptchaCanvas{border-radius:6px;flex:1}
.captcha-refresh{background:none;border:none;color:var(--gray-400);cursor:pointer;
  font-size:1.1rem;padding:6px;border-radius:var(--radius-sm);transition:var(--transition);
  margin-left:8px;line-height:1}
.captcha-refresh:hover{color:var(--primary);background:var(--primary-light)}
.captcha-input{width:100%;padding:10px 14px;border:none;outline:none;font-size:.9rem;
  background:var(--white);letter-spacing:.08em;color:var(--gray-800)}
.captcha-input::placeholder{color:var(--gray-300);letter-spacing:0}

/* ── OR Divider ─────────────────────────────────────────────────────────────── */
.or-divider{display:flex;align-items:center;gap:12px;margin:20px 0;
  color:var(--gray-400);font-size:.82rem}
.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:var(--gray-200)}

/* ── Social Buttons ─────────────────────────────────────────────────────────── */
.social-btns{display:flex;gap:10px;margin-bottom:22px}
.btn-social{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:10px;border:1.5px solid var(--gray-200);border-radius:var(--radius);
  background:var(--white);color:var(--gray-700);font-size:.85rem;font-weight:500;
  cursor:pointer;transition:var(--transition)}
.btn-social:hover{border-color:var(--gray-300);background:var(--gray-50)}

/* ── Role Selector ──────────────────────────────────────────────────────────── */
.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.role-option{display:flex;flex-direction:column;align-items:center;gap:7px;
  padding:16px 10px;border:1.5px solid var(--gray-200);border-radius:var(--radius);
  cursor:pointer;transition:var(--transition);text-align:center}
.role-option:hover{border-color:var(--primary)}
.role-option.selected{border-color:var(--primary);background:var(--primary-light)}
.role-option input{display:none}
.role-icon{font-size:1.55rem}
.role-label{font-size:.82rem;font-weight:600;color:var(--gray-700)}
.role-desc{font-size:.72rem;color:var(--gray-400)}

/* ── Password Strength ──────────────────────────────────────────────────────── */
.strength-wrap{margin-top:6px}
.strength-bar{display:flex;gap:4px}
.strength-seg{flex:1;height:3px;border-radius:2px;background:var(--gray-200);transition:background .3s}
.strength-label{font-size:.74rem;color:var(--gray-400);margin-top:5px}

/* ── Jobs Browse Page ───────────────────────────────────────────────────────── */
.jobs-page-banner{background:var(--gray-50);border-bottom:1px solid var(--gray-200);padding:34px 0}
.jobs-page-banner h1{font-size:1.75rem;margin-bottom:4px}
.jobs-page-banner p{font-size:.9rem;color:var(--gray-500)}
.jobs-page-layout{display:grid;grid-template-columns:268px 1fr;gap:28px;padding:32px 0 72px}
.filters-sidebar{background:var(--white);border:1.5px solid var(--gray-100);
  border-radius:var(--radius-md);padding:22px;height:fit-content;position:sticky;top:86px}
.filter-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--gray-100)}
.filter-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.filter-title{font-size:.79rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--gray-400);margin-bottom:12px}
.filter-options{display:flex;flex-direction:column;gap:9px}
.filter-option{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--gray-600);cursor:pointer}
.filter-option input{accent-color:var(--primary);cursor:pointer;flex-shrink:0}
.filter-option .count{margin-left:auto;font-size:.72rem;color:var(--gray-400);
  background:var(--gray-100);padding:1px 7px;border-radius:var(--radius-full)}
.range-wrap{padding-top:4px}
.range-labels{display:flex;justify-content:space-between;font-size:.76rem;color:var(--gray-500);margin-top:6px}
input[type="range"]{width:100%;accent-color:var(--primary);margin-top:4px}
.skill-tags-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.skill-tag-item{display:flex;align-items:center;gap:4px;background:var(--primary-light);
  color:var(--primary);font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:var(--radius-full)}
.skill-tag-item button{background:none;border:none;color:var(--primary);cursor:pointer;
  font-size:.8rem;line-height:1;padding:0}
.jobs-main-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}
.jobs-count{font-size:.88rem;color:var(--gray-500)}
.jobs-count strong{color:var(--gray-800)}
.jobs-sort-wrap{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--gray-500)}
.jobs-sort-wrap select{border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);
  padding:6px 10px;font-size:.83rem;color:var(--gray-700);outline:none;cursor:pointer}
.jobs-list-stack{display:flex;flex-direction:column;gap:13px}
.job-list-card{background:var(--white);border:1.5px solid var(--gray-100);
  border-radius:var(--radius-md);padding:20px;display:flex;align-items:flex-start;
  gap:16px;transition:var(--transition);cursor:pointer}
.job-list-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateX(2px)}
.job-list-body{flex:1;min-width:0}
.job-list-title{font-size:1rem;font-weight:700;color:var(--gray-900);margin-bottom:3px}
.job-list-company{font-size:.82rem;color:var(--gray-500);margin-bottom:10px;
  display:flex;align-items:center;gap:6px}
.job-list-tags{display:flex;flex-wrap:wrap;gap:6px}
.job-list-side{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0}
.job-list-rate{font-size:.95rem;font-weight:700;color:var(--green)}
.job-list-type{font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:var(--radius-full);
  background:var(--primary-light);color:var(--primary)}
.job-list-date{font-size:.74rem;color:var(--gray-400)}
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:32px}
.page-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-sm);border:1.5px solid var(--gray-200);background:var(--white);
  color:var(--gray-600);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition)}
.page-btn:hover{border-color:var(--primary);color:var(--primary)}
.page-btn.active{background:var(--primary);border-color:var(--primary);color:var(--white)}
.page-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}

/* ── Animations ─────────────────────────────────────────────────────────────── */
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .5s ease forwards}

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .categories-grid{grid-template-columns:repeat(3,1fr)}
  .jobs-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .auth-layout{grid-template-columns:1fr}
  .auth-brand{display:none}
  .auth-form-side{padding:40px 32px}
  .jobs-page-layout{grid-template-columns:1fr}
  .filters-sidebar{position:static}
  .hiw-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
}
@media(max-width:768px){
  .nav-links,.nav-divider{display:none}
  .nav-actions .btn-outline{display:none}
  .hamburger{display:flex}
  .categories-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .testimonials-grid{grid-template-columns:1fr}
  .hero-search{flex-direction:column;padding:14px;gap:12px}
  .hero-search .vdivider,.hero-search select{display:none}
  .cta-actions{flex-direction:column;align-items:center}
  .form-row{grid-template-columns:1fr}
  .social-btns{flex-direction:column}
}
@media(max-width:480px){
  .categories-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{padding:56px 0 68px}
  .section{padding:52px 0}
  .trusted-logos{gap:24px}
}
