/* ===================================
   Workooo — Light/White Design System
   Clean SaaS · White + Light Blue
   =================================== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  /* Light palette */
  --bg:           #f0f6ff;
  --bg-white:     #ffffff;
  --bg-soft:      #f8faff;
  --bg-elevated:  #eef4ff;
  --bg-hover:     #e4eeff;

  /* Borders */
  --border:       #dce6f7;
  --border-light: #edf3fc;
  --border-focus: #4f7cff;

  /* Text */
  --text:         #0f172a;
  --text-muted:   #64748b;
  --text-light:   #94a3b8;

  /* Brand — blue */
  --primary:       #4f7cff;
  --primary-dark:  #3a63e0;
  --primary-light: #eef3ff;
  --primary-glow:  rgba(79,124,255,.18);

  --accent:        #38bdf8;
  --accent-light:  #e0f7ff;

  /* Semantic */
  --success:       #10b981;
  --success-light: #ecfdf5;
  --danger:        #ef4444;
  --danger-light:  #fef2f2;
  --warning:       #f59e0b;
  --warning-light: #fffbeb;

  /* Radii */
  --r:     16px;
  --r-sm:  12px;
  --r-xs:  8px;
  --r-pill: 999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(79,124,255,.04);
  --shadow-sm: 0 1px 3px rgba(79,124,255,.06), 0 2px 8px rgba(79,124,255,.04);
  --shadow:    0 4px 12px rgba(79,124,255,.08), 0 8px 24px rgba(15,23,42,.04);
  --shadow-lg: 0 12px 32px rgba(79,124,255,.12), 0 24px 48px rgba(15,23,42,.06);
  --shadow-primary: 0 4px 14px rgba(79,124,255,.3);

  --nav-height: 66px;
  --font: 'Inter', system-ui, -apple-system, sans-serif;
  --t: .2s cubic-bezier(.4,0,.2,1);
  --t-bounce: .4s cubic-bezier(.34,1.56,.64,1);
}

/* ---------- Animations ---------- */
@keyframes fadeUp     { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }
@keyframes fadeDown   { from{opacity:0;transform:translateY(-12px)} to{opacity:1;transform:none} }
@keyframes fadeIn     { from{opacity:0} to{opacity:1} }
@keyframes scaleIn    { from{opacity:0;transform:scale(.93)} to{opacity:1;transform:none} }
@keyframes slideRight { from{opacity:0;transform:translateX(36px)} to{opacity:1;transform:none} }
@keyframes float      { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)} }
@keyframes bounceIn   { 0%{transform:scale(0);opacity:0} 60%{transform:scale(1.25)} 100%{transform:scale(1);opacity:1} }
@keyframes spin       { to{transform:rotate(360deg)} }
@keyframes ripple     { from{transform:scale(0);opacity:.3} to{transform:scale(4);opacity:0} }
@keyframes navSlide   { from{transform:translateY(-100%)} to{transform:none} }
@keyframes badgePop   { 0%{transform:scale(0)} 70%{transform:scale(1.3)} 100%{transform:scale(1)} }
@keyframes gradShift  { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

/* ---------- Scroll Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.reveal.revealed{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}

.stagger>*{opacity:0;transform:translateY(16px);transition:opacity .45s ease,transform .45s ease}
.stagger.revealed>*:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
.stagger.revealed>*:nth-child(2){opacity:1;transform:none;transition-delay:.1s}
.stagger.revealed>*:nth-child(3){opacity:1;transform:none;transition-delay:.15s}
.stagger.revealed>*:nth-child(4){opacity:1;transform:none;transition-delay:.2s}
.stagger.revealed>*:nth-child(5){opacity:1;transform:none;transition-delay:.25s}
.stagger.revealed>*:nth-child(6){opacity:1;transform:none;transition-delay:.3s}
.stagger.revealed>*:nth-child(7){opacity:1;transform:none;transition-delay:.35s}
.stagger.revealed>*:nth-child(8){opacity:1;transform:none;transition-delay:.4s}

/* Page progress bar */
#pageProgress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--primary),var(--accent));z-index:9999;transition:width .1s linear;border-radius:0 2px 2px 0}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:15px}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
input,select,textarea,button{font-family:inherit;font-size:inherit}
h1{font-size:clamp(1.7rem,4vw,2.6rem);font-weight:800;line-height:1.15;letter-spacing:-.03em}
h2{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:700;letter-spacing:-.02em}
h3{font-size:1.08rem;font-weight:600}
h4{font-size:.92rem;font-weight:600}

/* ---------- Navbar ---------- */
.navbar{
  position:sticky;top:0;z-index:200;height:var(--nav-height);
  background:rgba(255,255,255,.88);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  animation:navSlide .45s ease;
}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;gap:.75rem}
.nav-logo{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1.2rem;flex-shrink:0;transition:transform var(--t-bounce);color:var(--text)}
.nav-logo:hover{transform:scale(1.04)}
.logo-icon{font-size:1.45rem;animation:float 4s ease-in-out infinite}
/* Brand wordmark — Workooo */
.logo-text{
  color:rgb(146,71,255);
  font-weight:800;
  letter-spacing:-.02em;
  background:none;
  -webkit-background-clip:unset;
  background-clip:unset;
  -webkit-text-fill-color:rgb(146,71,255);
}

.nav-links{display:flex;align-items:center;gap:.25rem;margin-left:auto}
.nav-link{padding:.5rem .82rem;border-radius:var(--r-xs);color:var(--text-muted);font-weight:500;font-size:.88rem;transition:all var(--t);white-space:nowrap}
.nav-link:hover{background:var(--primary-light);color:var(--primary)}

.btn-post{
  background:var(--primary);color:#fff!important;border-radius:var(--r-pill);
  padding:.48rem 1.1rem!important;font-weight:600;font-size:.88rem;
  box-shadow:var(--shadow-primary);transition:all var(--t)!important;
}
.btn-post:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,124,255,.35)}
.btn-register{background:var(--text);color:#fff!important;border-radius:var(--r-pill);padding:.48rem 1.1rem!important;font-weight:600;font-size:.88rem;transition:all var(--t)!important}
.btn-register:hover{background:#1e293b}

/* ══ Notification badge — RED Telegram-style ══ */
.nav-chat{position:relative;display:inline-flex;align-items:center}
.nav-badge{
  position:absolute;
  top:-7px;right:-9px;
  background:#e53935;
  color:#fff;
  border-radius:var(--r-pill);
  min-width:19px;height:19px;
  display:flex;align-items:center;justify-content:center;
  font-size:.66rem;font-weight:800;line-height:1;padding:0 5px;
  border:2.5px solid #fff;
  animation:badgePop .35s var(--t-bounce);
  box-shadow:0 0 0 2px rgba(229,57,53,.2), 0 2px 8px rgba(229,57,53,.4);
}

/* Hamburger */
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:var(--r-xs)}
.nav-hamburger span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px;transition:var(--t)}
.nav-hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-hamburger.active span:nth-child(2){opacity:0}
.nav-hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Avatar dropdown */
.nav-dropdown{position:relative}
.nav-avatar-btn{display:flex;align-items:center;gap:.5rem;background:var(--bg-soft);border:1.5px solid var(--border);border-radius:var(--r-pill);padding:.38rem .85rem .38rem .42rem;cursor:pointer;font-weight:500;font-size:.88rem;color:var(--text);transition:all var(--t)}
.nav-avatar-btn:hover{border-color:var(--primary);background:var(--primary-light)}
.nav-avatar-img{width:27px;height:27px;border-radius:50%;object-fit:cover}
.nav-avatar-placeholder{width:27px;height:27px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.76rem}
.nav-dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);min-width:175px;padding:.45rem;display:none;z-index:300;animation:scaleIn .15s ease;transform-origin:top right}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown-menu:hover{display:block}
.nav-dropdown-menu a{display:flex;align-items:center;gap:.55rem;padding:.55rem .8rem;border-radius:var(--r-xs);color:var(--text-muted);font-weight:500;font-size:.88rem;transition:all var(--t)}
.nav-dropdown-menu a:hover{background:var(--primary-light);color:var(--primary)}
.nav-dropdown-menu hr{border:none;border-top:1px solid var(--border);margin:.35rem 0}

/* ---------- Alerts ---------- */
.messages-container{position:fixed;top:calc(var(--nav-height) + .75rem);right:1rem;z-index:999;display:flex;flex-direction:column;gap:.5rem;max-width:380px}
.alert{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1rem;border-radius:var(--r-sm);font-weight:500;font-size:.88rem;box-shadow:var(--shadow-lg);animation:slideRight .32s ease}
.alert-success{background:var(--success-light);border:1px solid #a7f3d0;color:#065f46}
.alert-error,.alert-danger{background:var(--danger-light);border:1px solid #fecaca;color:#991b1b}
.alert-warning{background:var(--warning-light);border:1px solid #fde68a;color:#92400e}
.alert-info{background:var(--primary-light);border:1px solid rgba(79,124,255,.3);color:var(--primary)}
.alert button{background:none;border:none;cursor:pointer;font-size:1.1rem;opacity:.45;transition:opacity var(--t);color:inherit}
.alert button:hover{opacity:1}

/* ---------- Layout ---------- */
.main-content{min-height:calc(100vh - var(--nav-height))}
.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.section{padding:4rem 0}
.page-layout{display:grid;grid-template-columns:280px 1fr;gap:1.75rem;padding-top:2rem;padding-bottom:3rem;align-items:start}
.detail-layout{display:grid;grid-template-columns:1fr 345px;gap:1.75rem;padding-top:2rem;padding-bottom:3rem;align-items:start}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.see-all{color:var(--primary);font-weight:500;font-size:.88rem;display:inline-flex;align-items:center;gap:.25rem;transition:all var(--t)}
.see-all:hover{gap:.5rem}
.text-center{text-align:center}
.text-muted{color:var(--text-muted);font-size:.9rem}
.form-page{padding:2rem 1.5rem 4rem;max-width:860px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.58rem 1.15rem;border-radius:var(--r-xs);font-weight:600;font-size:.88rem;cursor:pointer;border:1.5px solid transparent;transition:all var(--t);white-space:nowrap;position:relative;overflow:hidden;-webkit-user-select:none;user-select:none}
.btn-ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.3);animation:ripple .5s ease-out;pointer-events:none}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-primary)}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary-light);transform:translateY(-1px)}
.btn-ghost{background:var(--bg-soft);color:var(--text);border-color:var(--border)}
.btn-ghost:hover{background:var(--bg-elevated);border-color:var(--text-light)}
.btn-success{background:var(--success);color:#fff;border-color:transparent}
.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.3)}
.btn-danger{background:transparent;color:var(--danger);border-color:var(--danger)}
.btn-danger:hover{background:var(--danger-light)}
.btn-secondary{background:var(--bg-white);color:var(--text);border-color:var(--border)}
.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}
.btn-lg{padding:.75rem 1.75rem;font-size:.95rem;border-radius:var(--r-sm)}
.btn-sm{padding:.33rem .75rem;font-size:.8rem;border-radius:var(--r-xs)}
.btn-block{display:flex;width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}

/* ---------- Forms ---------- */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;font-size:.84rem;color:var(--text);margin-bottom:.42rem}
.form-control,input[type="text"],input[type="password"],input[type="email"],input[type="date"],input[type="number"],select,textarea{width:100%;padding:.65rem .92rem;border:1.5px solid var(--border);border-radius:var(--r-xs);background:var(--bg-white);color:var(--text);transition:all var(--t);outline:none;font-size:.9rem}
.form-control:hover,input:hover:not(:focus),select:hover:not(:focus){border-color:var(--text-light)}
.form-control:focus,input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);background:#fff}
.form-error{display:block;color:var(--danger);font-size:.8rem;margin-top:.28rem;font-weight:500}
.form-error-box{background:var(--danger-light);border:1px solid #fecaca;border-radius:var(--r-xs);padding:.8rem 1rem;margin-bottom:1.15rem;color:#991b1b;font-size:.88rem}
.form-error-box p{margin:0}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.15rem}
.form-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:2.25rem;box-shadow:var(--shadow)}
.form-card h2{margin-bottom:1.85rem;font-size:1.35rem}
.form-actions{display:flex;gap:.85rem;margin-top:1.75rem;flex-wrap:wrap}
.form-section{background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--r-sm);padding:1.35rem;margin-bottom:1.35rem}
.form-section-title{font-weight:700;font-size:.82rem;color:var(--primary);margin-bottom:1.15rem;display:flex;align-items:center;gap:.42rem;padding-bottom:.65rem;border-bottom:1px solid var(--border);letter-spacing:.04em;text-transform:uppercase}

/* ---------- Search bar ---------- */
.search-bar{display:flex;gap:.6rem;background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.45rem;margin-bottom:1.75rem;transition:all var(--t);box-shadow:var(--shadow-sm)}
.search-bar:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.search-bar input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:.92rem;padding:.2rem .5rem}
.search-bar input::placeholder{color:var(--text-light)}
.search-bar .btn{border-radius:var(--r-sm);flex-shrink:0}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(135deg,#0f172a 0%,#1e2d52 50%,#16213e 100%);color:#fff;padding:5rem 0 4.5rem;overflow:hidden;position:relative}
.hero::before{content:'';position:absolute;top:-30%;right:-5%;width:700px;height:700px;background:radial-gradient(circle,rgba(79,124,255,.2) 0%,transparent 65%);border-radius:50%;animation:float 8s ease-in-out infinite}
.hero::after{content:'';position:absolute;bottom:-25%;left:-8%;width:500px;height:500px;background:radial-gradient(circle,rgba(56,189,248,.12) 0%,transparent 65%);border-radius:50%;animation:float 10s ease-in-out infinite reverse}
.hero-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center;position:relative;z-index:1}
.hero-text{animation:fadeUp .65s ease both}
.hero-text h1{color:#fff;margin-bottom:1.15rem}
.hero-highlight{background:linear-gradient(135deg,#7fa8ff,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-text p{color:rgba(255,255,255,.7);font-size:1.05rem;margin-bottom:1.85rem;max-width:510px;line-height:1.75}
.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-actions .btn-primary{background:var(--primary);padding:.82rem 1.85rem;font-size:.95rem;border-radius:var(--r-sm)}
.hero-actions .btn-outline{border-color:rgba(255,255,255,.3);color:rgba(255,255,255,.85);padding:.82rem 1.85rem;font-size:.95rem;border-radius:var(--r-sm)}
.hero-actions .btn-outline:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
.hero-stats{display:flex;flex-direction:column;gap:.75rem;animation:fadeUp .65s .2s ease both}
.stat-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:1.1rem 1.6rem;text-align:center;backdrop-filter:blur(12px);transition:all var(--t);cursor:default}
.stat-card:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25);transform:translateY(-2px)}
.stat-num{display:block;font-size:1.65rem}
.stat-label{font-size:.78rem;color:rgba(255,255,255,.65);font-weight:500}

/* ---------- Category Pills ---------- */
.category-pills{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:1.85rem}
.pill{display:inline-flex;align-items:center;gap:.35rem;background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r-pill);padding:.42rem .9rem;font-weight:500;font-size:.84rem;color:var(--text-muted);transition:all var(--t);cursor:pointer;box-shadow:var(--shadow-xs)}
.pill:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);transform:translateY(-2px);box-shadow:var(--shadow-sm)}

/* ---------- Job Cards ---------- */
.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.15rem}
.job-card{background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:all .28s ease;cursor:pointer;position:relative}
.job-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary)}
.job-card-img{height:168px;overflow:hidden;background:var(--bg-soft)}
.job-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.job-card:hover .job-card-img img{transform:scale(1.07)}
.job-card-body{padding:1.2rem;flex:1;display:flex;flex-direction:column;gap:.42rem}
.job-badge{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:.72rem;font-weight:700;padding:.2rem .65rem;border-radius:var(--r-pill);width:fit-content}
.job-card-title{font-weight:700;font-size:.97rem;color:var(--text);line-height:1.35;margin:.1rem 0}
.job-card-location{font-size:.82rem;color:var(--text-muted)}
.job-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.6rem;border-top:1px solid var(--border)}
.job-salary{font-weight:700;color:var(--primary);font-size:.9rem}
.job-time{font-size:.76rem;color:var(--text-light)}

/* ---------- Job List Cards ---------- */
.jobs-list{display:flex;flex-direction:column;gap:.8rem}
.job-list-card{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:1.15rem;background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r);padding:1.1rem;transition:all .22s ease}
.job-list-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}
.job-list-img{width:90px;height:90px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0;background:var(--bg-soft)}
.job-list-img img{width:100%;height:100%;object-fit:cover}
.job-list-img-placeholder{display:flex;align-items:center;justify-content:center;font-size:1.75rem;height:100%}
.job-list-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.3rem}
.job-list-body h3{font-size:.95rem;font-weight:700;margin:.18rem 0;color:var(--text)}
.job-desc-preview{color:var(--text-muted);font-size:.85rem;margin:.25rem 0;line-height:1.5}
.job-list-meta{display:flex;flex-wrap:wrap;gap:.4rem .9rem;font-size:.8rem;color:var(--text-muted)}
.job-list-salary{text-align:right;flex-shrink:0}
.job-list-salary strong{color:var(--primary);font-size:.92rem;white-space:nowrap}

/* ---------- Filter Sidebar ---------- */
.filter-card{background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r);padding:1.35rem;box-shadow:var(--shadow-sm);position:sticky;top:calc(var(--nav-height) + 1rem)}
.filter-card h3{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem}
.jobs-main .jobs-header{display:flex;align-items:center;gap:.65rem;margin-bottom:1.1rem}
.count-badge{background:var(--primary);color:#fff;border-radius:var(--r-pill);padding:.18rem .65rem;font-size:.78rem;font-weight:700}
.jobs-header h2{display:flex;align-items:center;gap:.5rem}

/* ---------- Job Detail ---------- */
.detail-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:1.75rem;box-shadow:var(--shadow-sm);margin-bottom:1.1rem}
.detail-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.detail-meta-row{display:flex;flex-wrap:wrap;gap:.45rem 1.35rem;font-size:.87rem;color:var(--text-muted);margin:.75rem 0 1.35rem}
.salary-block{background:linear-gradient(135deg,var(--primary-light),var(--accent-light));border:1px solid rgba(79,124,255,.15);border-radius:var(--r-sm);padding:1.1rem 1.35rem;margin:1.15rem 0}
.salary-amount{font-size:1.55rem;font-weight:800;color:var(--primary)}
.detail-hero-img{width:100%;border-radius:var(--r);overflow:hidden;max-height:360px;margin-bottom:1.15rem}
.detail-hero-img img{width:100%;height:100%;object-fit:cover}
.job-description{color:var(--text-muted);line-height:1.8;margin:.5rem 0 1.35rem;font-size:.93rem}
.detail-sidebar{position:sticky;top:calc(var(--nav-height) + 1rem);display:flex;flex-direction:column;gap:1rem}
.sidebar-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:1.35rem;box-shadow:var(--shadow-sm)}
.sidebar-card h4{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.85rem}

/* Map in job detail */
#job-map{height:300px;border-radius:var(--r-sm);overflow:hidden;margin:1rem 0;border:1.5px solid var(--border);cursor:zoom-in}

.employer-info{display:flex;align-items:center;gap:.8rem;padding:.42rem 0;transition:opacity var(--t)}
.employer-info:hover{opacity:.8}
.employer-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.employer-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem}
.employer-info div{display:flex;flex-direction:column;gap:.1rem}
.employer-info strong{font-weight:700;font-size:.92rem}
.employer-info span{font-size:.82rem;color:var(--text-muted)}

/* Statuses */
.application-status-block{padding:1.1rem;border-radius:var(--r-sm);font-weight:600;text-align:center;font-size:.9rem}
.status-kutilmoqda{background:var(--warning-light);border:1px solid #fde68a;color:#92400e}
.status-qabul_qilindi{background:var(--success-light);border:1px solid #a7f3d0;color:#065f46}
.status-rad_etildi{background:var(--danger-light);border:1px solid #fecaca;color:#991b1b}
.job-status{display:inline-block}
.status-ochiq{background:var(--primary-light);color:var(--primary);padding:.2rem .65rem;border-radius:var(--r-pill);font-size:.78rem;font-weight:700}
.status-yopiq{background:var(--bg-soft);color:var(--text-muted);padding:.2rem .65rem;border-radius:var(--r-pill);font-size:.78rem;font-weight:700}
.status-tugallangan{background:var(--success-light);color:var(--success);padding:.2rem .65rem;border-radius:var(--r-pill);font-size:.78rem;font-weight:700}

/* Applicants */
.applicant-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem 0;border-bottom:1px solid var(--border);transition:all var(--t)}
.applicant-row:last-of-type{border-bottom:none}
.applicant-row:hover{background:var(--bg-soft);padding-left:.6rem;padding-right:.6rem;margin:0 -.6rem;border-radius:var(--r-xs)}
.applicant-info{display:flex;align-items:center;gap:.8rem;flex:1}
.applicant-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover}
.applicant-avatar-placeholder{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem}
.applicant-actions{display:flex;gap:.4rem}
.app-message{font-size:.82rem;color:var(--text-muted);font-style:italic;margin-top:.2rem}
.mini-rating{font-size:.8rem;color:var(--warning);font-weight:600}
.badge-accepted{background:var(--success-light);color:var(--success);border:1px solid #a7f3d0;border-radius:var(--r-pill);padding:.2rem .65rem;font-size:.8rem;font-weight:600}
.badge-rejected{background:var(--danger-light);color:var(--danger);border:1px solid #fecaca;border-radius:var(--r-pill);padding:.2rem .65rem;font-size:.8rem;font-weight:600}
.employer-manage-links{display:flex;gap:.45rem;margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid var(--border)}

/* ---------- My Jobs ---------- */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.65rem}
.job-manage-card{display:flex;align-items:center;gap:1rem;background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r);padding:1.1rem 1.35rem;transition:all var(--t)}
.job-manage-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}
.job-manage-info{flex:1}
.job-manage-info a h3{font-size:.95rem;font-weight:700;color:var(--text);transition:color var(--t)}
.job-manage-info a h3:hover{color:var(--primary)}
.job-manage-meta{display:flex;flex-wrap:wrap;gap:.35rem .85rem;font-size:.82rem;color:var(--text-muted);margin-top:.3rem;align-items:center}
.job-manage-actions{display:flex;gap:.4rem;flex-shrink:0}

/* ---------- Auth Pages ---------- */
.auth-page{min-height:calc(100vh - var(--nav-height));display:flex;align-items:center;justify-content:center;padding:2.5rem 1.5rem;background:linear-gradient(160deg,var(--bg) 0%,var(--primary-light) 100%)}
.auth-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:2.5rem 2.15rem;box-shadow:var(--shadow-lg);width:100%;max-width:440px;animation:scaleIn .4s ease}
.auth-card-wide{max-width:680px}
.auth-logo{font-size:1.5rem;font-weight:800;margin-bottom:.8rem;text-align:center;color:var(--text)}
.auth-card h2{text-align:center;margin-bottom:1.65rem;font-size:1.28rem}
.auth-switch{text-align:center;margin-top:1.35rem;color:var(--text-muted);font-size:.88rem}
.auth-switch a{color:var(--primary);font-weight:600;transition:color var(--t)}
.auth-switch a:hover{color:var(--primary-dark)}
.role-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1.75rem}
.role-tab{background:var(--bg-soft);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.82rem;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.15rem;transition:all var(--t);font-weight:600;font-size:.88rem;color:var(--text-muted)}
.role-tab small{font-size:.75rem;font-weight:400;color:var(--text-light)}
.role-tab:hover{border-color:var(--primary);color:var(--text)}
.role-tab.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.role-tab.active small{color:var(--primary)}

/* ---------- Profile ---------- */
.profile-layout{padding:2rem 1.5rem 4rem}
.profile-hero-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:2rem;display:flex;align-items:flex-start;gap:1.65rem;margin-bottom:1.1rem;box-shadow:var(--shadow-sm);position:relative}
.profile-avatar{width:100px;height:100px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--primary-light)}
.profile-avatar-placeholder{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:2.5rem;flex-shrink:0}
.profile-hero-info{flex:1}
.profile-hero-info h1{font-size:1.55rem;margin-bottom:.25rem}
.profile-role-badge{display:inline-block;border-radius:var(--r-pill);padding:.2rem .8rem;font-size:.78rem;font-weight:700;margin-bottom:.5rem}
.role-worker{background:var(--accent-light);color:#0284c7}
.role-employer{background:var(--primary-light);color:var(--primary)}
.profile-rating{display:flex;align-items:center;gap:.5rem;margin:.5rem 0}
.stars{letter-spacing:.1rem;font-size:.95rem}
.profile-bio{color:var(--text-muted);font-size:.92rem;margin-top:.5rem;max-width:520px;line-height:1.7}
.profile-edit-btn{position:absolute;top:1.65rem;right:1.65rem}
.profile-section-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:1.35rem;margin-bottom:1.1rem;box-shadow:var(--shadow-sm)}
.profile-section-card h3{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem}
.mini-job-card{display:flex;align-items:center;gap:.8rem;padding:.65rem 0;border-bottom:1px solid var(--border);font-size:.88rem;flex-wrap:wrap;transition:all var(--t);border-radius:var(--r-xs)}
.mini-job-card:hover{background:var(--bg-soft);padding-left:.5rem}
.mini-job-card:last-child{border-bottom:none}
.review-card{padding:.8rem 0;border-bottom:1px solid var(--border)}
.review-card:last-child{border-bottom:none}
.review-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.25rem;flex-wrap:wrap}
.review-stars{color:var(--warning)}
.review-job{font-size:.82rem;color:var(--primary);margin-bottom:.25rem;display:inline-block}

/* ---------- Chat ---------- */
.chat-page{max-width:800px;display:flex;flex-direction:column;height:calc(100vh - var(--nav-height));padding:0}
.chat-header-bar{display:flex;align-items:center;gap:.8rem;padding:.8rem 1.35rem;background:var(--bg-white);border-bottom:1px solid var(--border);flex-wrap:wrap}
.chat-partner-info strong{font-size:.97rem;font-weight:700}
.chat-job-link{font-size:.82rem;color:var(--text-muted);margin-left:auto;transition:color var(--t)}
.chat-job-link:hover{color:var(--primary)}
.chat-messages{flex:1;overflow-y:auto;padding:1.35rem;display:flex;flex-direction:column;gap:.75rem;background:var(--bg)}
.chat-empty{text-align:center;color:var(--text-muted);font-size:.88rem;margin:auto}
.chat-bubble{max-width:66%;display:flex;flex-direction:column;gap:.18rem;animation:fadeUp .22s ease}
.bubble-own{align-self:flex-end}
.bubble-other{align-self:flex-start}
.bubble-own p{background:linear-gradient(135deg,var(--primary),#7fa8ff);color:#fff;border-radius:20px 20px 4px 20px;padding:.7rem 1.05rem;line-height:1.5;font-size:.9rem;box-shadow:0 2px 8px var(--primary-glow)}
.bubble-other p{background:var(--bg-white);color:var(--text);border:1px solid var(--border);border-radius:20px 20px 20px 4px;padding:.7rem 1.05rem;line-height:1.5;font-size:.9rem;box-shadow:var(--shadow-xs)}
.bubble-time{font-size:.7rem;color:var(--text-light)}
.bubble-own .bubble-time{text-align:right}
.chat-input-bar{display:flex;gap:.55rem;padding:.8rem 1.35rem;background:var(--bg-white);border-top:1px solid var(--border)}
.chat-send-btn{flex-shrink:0;width:44px;height:44px;border-radius:50%;padding:0;font-size:1.05rem}
.conversation-list{display:flex;flex-direction:column;gap:.55rem}
.conv-card{display:flex;align-items:center;gap:.9rem;background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r);padding:.9rem 1.05rem;transition:all var(--t);position:relative}
.conv-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}
.conv-other-avatar{position:relative}
.conv-unread{
  border-color:rgba(229,57,53,.45);
  background:linear-gradient(90deg,rgba(229,57,53,.08) 0%,var(--primary-light) 8%,var(--bg-white) 100%);
  box-shadow:inset 3px 0 0 #e53935;
}
.conv-unread-dot{
  position:absolute;top:-2px;left:-2px;width:12px;height:12px;border-radius:50%;
  background:#e53935;border:2px solid var(--bg-white);
  box-shadow:0 0 0 1px rgba(229,57,53,.35);
  z-index:2;
}
.conv-name-unread{font-weight:800!important;color:var(--text)!important}
.conv-preview-unread{font-weight:600;color:var(--text)!important;opacity:1}
[data-theme="dark"] .conv-unread{
  background:linear-gradient(90deg,rgba(229,57,53,.14) 0%,rgba(79,124,255,.12) 10%,var(--bg-white) 100%);
}
[data-theme="dark"] .conv-unread-dot{border-color:var(--bg-white)}
.conv-other-avatar img,.avatar-placeholder-sm{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}
.avatar-placeholder-sm{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}
.conv-info{flex:1;min-width:0}
.conv-top{display:flex;align-items:center;justify-content:space-between}
.conv-time{font-size:.76rem;color:var(--text-light)}
.conv-job{font-size:.8rem;color:var(--primary)}
.conv-preview{font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ══ Unread badge — RED like social media ══ */
.unread-badge{
  background:#e53935;
  color:#fff;
  border-radius:var(--r-pill);
  min-width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:800;flex-shrink:0;padding:0 5px;
  animation:badgePop .35s var(--t-bounce);
  box-shadow:0 0 0 2px rgba(229,57,53,.2),0 2px 6px rgba(229,57,53,.45);
}

/** ---------- Ratings ---------- **/
.rate-worker-info{display:flex;align-items:center;gap:1rem;margin-bottom:1.65rem;padding:1.1rem;background:var(--bg-soft);border-radius:var(--r-sm);border:1px solid var(--border)}
.star-rating{display:flex;gap:.5rem;margin:.55rem 0}
.star-btn{background:none;border:none;font-size:2.2rem;cursor:pointer;color:var(--text-light);transition:all var(--t-bounce);padding:0;line-height:1}
.star-btn:hover,.star-btn.hover{color:var(--warning);transform:scale(1.2)}
.star-btn.active{color:var(--warning);transform:scale(1.2);pointer-events:auto}
[data-theme="dark"] .star-btn{color:var(--text-light)}
[data-theme="dark"] .star-btn:hover,[data-theme="dark"] .star-btn.hover{color:var(--warning);transform:scale(1.2)}
[data-theme="dark"] .star-btn.active{color:var(--warning);transform:scale(1.2)}

/* ---------- How It Works ---------- */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.25rem;margin-top:1.85rem}
.step-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r);padding:1.75rem;text-align:center;transition:all .3s ease;position:relative;overflow:hidden}
.step-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-light),transparent);opacity:0;transition:opacity var(--t)}
.step-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--primary)}
.step-card:hover::before{opacity:1}
.step-icon{font-size:2.5rem;margin-bottom:.8rem;display:block;position:relative;z-index:1}
.step-card h3{margin-bottom:.5rem;position:relative;z-index:1}
.step-card p{font-size:.88rem;color:var(--text-muted);line-height:1.6;position:relative;z-index:1}

/* ---------- Empty State ---------- */
.empty-state{text-align:center;padding:4rem 1.25rem}
.empty-icon{font-size:3.25rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite;display:block}
.empty-state h3{margin-bottom:.55rem}
.empty-state p{color:var(--text-muted);margin-bottom:1.65rem;font-size:.92rem}

/* ---------- Footer ---------- */
.footer{background:var(--bg-white);border-top:1px solid var(--border);color:var(--text-muted);padding:3rem 0 0;margin-top:5rem}
.footer-inner{max-width:1280px;margin:0 auto;padding:0 1.5rem 2.5rem;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.footer-brand a{display:flex;align-items:center;gap:.55rem;font-size:1.15rem;font-weight:800;color:var(--text)}
.footer-brand a .logo-text{color:rgb(146,71,255);-webkit-text-fill-color:rgb(146,71,255)}
.footer-brand p{font-size:.86rem;margin-top:.5rem}
.footer-links{display:flex;gap:2.5rem}
.footer-links div{display:flex;flex-direction:column;gap:.5rem}
.footer-links h4{color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem;font-weight:700}
.footer-links a{font-size:.86rem;transition:color var(--t)}
.footer-links a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid var(--border);padding:1.25rem;text-align:center;font-size:.8rem;color:var(--text-light)}

/* ---------- Map Picker ---------- */
.map-picker-wrapper{margin-top:.35rem}
.map-picker-preview{position:relative;width:100%;height:230px;border-radius:var(--r-sm);border:1.5px solid var(--border);overflow:hidden;cursor:pointer;transition:all var(--t);background:var(--bg-soft)}
.map-picker-preview:hover{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.map-expand-hint{position:absolute;bottom:10px;right:10px;background:rgba(15,23,42,.65);color:#fff;font-size:.75rem;font-weight:600;padding:.3rem .8rem;border-radius:var(--r-pill);pointer-events:none;backdrop-filter:blur(5px);z-index:500}
.map-address-result{display:flex;align-items:center;gap:.55rem;background:var(--success-light);border:1px solid #a7f3d0;border-radius:var(--r-xs);padding:.65rem .9rem;margin-top:.55rem;font-size:.86rem;color:#065f46;animation:fadeUp .3s ease}
.map-pin-icon{font-size:1rem;flex-shrink:0}
.map-address-result span:nth-child(2){flex:1}
.btn-clear-pin{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:.95rem;line-height:1;padding:.12rem .3rem;border-radius:4px;transition:all var(--t)}
.btn-clear-pin:hover{background:var(--danger-light);color:var(--danger)}
.map-hint-text{font-size:.78rem;color:var(--text-light);margin-top:.4rem}
.map-picker-actions{display:flex;gap:.55rem;margin-top:.55rem}
.map-modal{position:fixed;inset:0;z-index:9999;background:var(--bg-white);flex-direction:column;display:none}
.map-modal-header{display:flex;align-items:center;gap:.8rem;padding:.8rem 1.15rem;background:var(--bg-white);border-bottom:1px solid var(--border);height:58px;flex-shrink:0;position:relative;z-index:10001}
.map-modal-title{flex:1;font-weight:700;text-align:center;font-size:.95rem}
.map-modal-hint{position:absolute;bottom:85px;left:50%;transform:translateX(-50%);background:rgba(15,23,42,.72);color:#fff;padding:.5rem 1.25rem;border-radius:24px;font-size:.86rem;pointer-events:none;white-space:nowrap;max-width:90vw;text-align:center;backdrop-filter:blur(8px);z-index:10000}

/* ---------- Responsive ---------- */
@media(max-width:1024px){.page-layout{grid-template-columns:250px 1fr}.detail-layout{grid-template-columns:1fr 310px}}
@media(max-width:768px){
  .nav-hamburger{display:flex}
  .nav-links{display:none;position:fixed;top:var(--nav-height);left:0;right:0;bottom:0;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);flex-direction:column;padding:1.25rem;gap:.3rem;overflow-y:auto;z-index:99;animation:fadeIn .2s ease}
  [data-theme="dark"] .nav-links{background:rgba(15,23,42,.98)}
  .nav-links.open{display:flex}
  .nav-link{padding:.8rem 1rem;border-radius:var(--r-xs);font-size:.95rem}
  .btn-post,.btn-register{border-radius:var(--r-xs)!important;width:100%;justify-content:center}
  .nav-dropdown{width:100%}
  .nav-avatar-btn{width:100%;justify-content:flex-start;border-radius:var(--r-xs)}
  .nav-dropdown-menu{position:static;box-shadow:none;border:none;background:var(--bg-soft);display:block;border-radius:var(--r-xs)}
  .hero-inner{grid-template-columns:1fr}
  .hero-stats{flex-direction:row}
  .stat-card{flex:1}
  .page-layout{grid-template-columns:1fr}
  .filter-card{position:static}
  .detail-layout{grid-template-columns:1fr}
  .detail-sidebar{position:static}
  .form-grid-2,.form-grid-3{grid-template-columns:1fr}
  .job-list-card{grid-template-columns:72px 1fr}
  .job-list-salary{display:none}
  .profile-hero-card{flex-direction:column;align-items:center;text-align:center}
  .profile-edit-btn{position:static;margin-top:.85rem}
  .chat-page{height:calc(100vh - var(--nav-height))}
  .footer-inner{grid-template-columns:1fr}
  .footer-links{flex-wrap:wrap}
  .form-actions{flex-direction:column}
}
@media(max-width:480px){
  .hero{padding:3rem 0 2.5rem}
  .auth-card{padding:1.65rem 1.1rem}
  .form-card{padding:1.35rem}
  .jobs-grid{grid-template-columns:1fr}
  .hero-stats{flex-direction:column}
}

/* ---------- i18n + theme controls ---------- */
.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.nav-controls{
  display:flex;align-items:center;gap:.5rem;margin-left:auto;padding-left:.5rem;
  border-left:1px solid var(--border);flex-shrink:0;
}
.lang-form{margin:0}
.nav-select{
  appearance:none;-webkit-appearance:none;
  background:var(--bg-soft);border:1.5px solid var(--border);border-radius:var(--r-pill);
  padding:.35rem 2rem .35rem .75rem;font-size:.8rem;font-weight:600;color:var(--text-muted);
  cursor:pointer;transition:all var(--t);max-width:9rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .5rem center;
}
.nav-select:hover,.nav-select:focus{border-color:var(--primary);color:var(--primary);outline:none}
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:32px;padding:0;border:none;background:transparent;cursor:pointer;border-radius:var(--r-pill);
}
.theme-toggle:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}
.theme-toggle-track{
  position:relative;width:44px;height:26px;border-radius:var(--r-pill);
  background:var(--border);transition:background var(--t);
}
.theme-toggle-thumb{
  position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;
  background:#fff;box-shadow:var(--shadow-sm);transition:transform var(--t);
}
.theme-toggle--dark .theme-toggle-track{background:var(--primary)}
.theme-toggle--dark .theme-toggle-thumb{transform:translateX(18px)}
.alert-dismiss{background:none;border:none;cursor:pointer;font-size:1.1rem;opacity:.45;transition:opacity var(--t);color:inherit;padding:.25rem}
.alert-dismiss:hover{opacity:1}

/* ---------- Dark theme ---------- */
[data-theme="dark"]{
  --bg:#0f172a;
  --bg-white:#1e293b;
  --bg-soft:#172033;
  --bg-elevated:#243047;
  --bg-hover:#334155;
  --border:#334155;
  --border-light:#1e293b;
  --border-focus:#7c9cff;
  --text:#f1f5f9;
  --text-muted:#94a3b8;
  --text-light:#64748b;
  --primary:#6b8cff;
  --primary-dark:#4f6fef;
  --primary-light:rgba(79,124,255,.15);
  --primary-glow:rgba(107,140,255,.22);
  --accent:#38bdf8;
  --accent-light:rgba(56,189,248,.12);
  --success:#34d399;
  --success-light:rgba(16,185,129,.12);
  --danger:#f87171;
  --danger-light:rgba(248,113,113,.12);
  --warning:#fbbf24;
  --warning-light:rgba(245,158,11,.12);
  --shadow-xs:0 1px 2px rgba(0,0,0,.2);
  --shadow-sm:0 2px 8px rgba(0,0,0,.25);
  --shadow:0 8px 24px rgba(0,0,0,.35);
  --shadow-lg:0 16px 40px rgba(0,0,0,.45);
  --shadow-primary:0 4px 14px rgba(79,124,255,.35);
}
[data-theme="dark"] .navbar{
  background:rgba(15,23,42,.92);
  border-bottom-color:var(--border);
}
[data-theme="dark"] .hero{
  background:linear-gradient(135deg,#020617 0%,#0f172a 50%,#1e1b4b 100%);
}
[data-theme="dark"] .nav-badge{border-color:var(--bg-white)}
[data-theme="dark"] .btn-register{background:var(--bg-elevated);color:var(--text)!important}
[data-theme="dark"] .btn-register:hover{background:var(--bg-hover)}
[data-theme="dark"] .form-control,
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="date"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] select,
[data-theme="dark"] textarea{background:#334155;color:var(--text);border-color:#475569}
[data-theme="dark"] .form-control:hover,
[data-theme="dark"] input:hover:not(:focus),
[data-theme="dark"] select:hover:not(:focus){border-color:#64748b}
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus{background:#475569;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
[data-theme="dark"] .auth-page{
  background:linear-gradient(160deg,var(--bg) 0%,var(--bg-soft) 100%);
}
@media(max-width:768px){
  .nav-controls{
    margin-left:0;padding-left:0;border-left:none;width:100%;
    justify-content:flex-end;padding-top:.75rem;margin-top:.75rem;border-top:1px solid var(--border);
  }
}
