
/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{--coral:#F26A4A;--coral-dark:#d45232;--coral-light:#f58a6f;--coral-bg:rgba(194,58,41,0.08);--coral-glow:rgba(194,58,41,0.25);--bg:#ffffff;--bg2:#f8f9fa;--card:#ffffff;--text:#1a1a2e;--text2:#5a626f;--text3:#6e747a;--border:#e5e7eb;--shadow:0 2px 12px rgba(0,0,0,0.08);--shadow-lg:0 8px 32px rgba(0,0,0,0.12);--radius:16px;--radius-sm:10px;--radius-xs:6px;--font:'Montserrat',sans-serif;--header-h:56px;--bottom-h:72px;--safe-bottom:env(safe-area-inset-bottom,0px);--transition:0.35s cubic-bezier(.4,0,.2,1);--ad-bg:#fdf2f0;--notif-unread:#fef2f0}
.dark{--bg:#0f0f1a;--bg2:#1a1a2e;--card:#1e1e32;--text:#f0f0f0;--text2:#a0a0b0;--text3:#8a8a9a;--border:#2a2a3e;--shadow:0 2px 12px rgba(0,0,0,0.3);--shadow-lg:0 8px 32px rgba(0,0,0,0.45);--ad-bg:rgba(194,58,41,0.08);--notif-unread:rgba(194,58,41,0.12)}
html,body{height:100%;overflow-x:hidden}
body{font-family:var(--font);background:var(--bg);color:var(--text);transition:background var(--transition),color var(--transition);padding-top:var(--header-h);padding-bottom:calc(var(--bottom-h) + var(--safe-bottom) + 8px);line-height:1.5}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:var(--font);font-size:inherit}
button:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
a:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
[role="button"]:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
input,textarea,select{font-family:var(--font);font-size:16px;outline:none;border:2px solid var(--border);background:var(--bg);color:var(--text);border-radius:var(--radius-sm);padding:12px 16px;width:100%;transition:border-color var(--transition)}
input:focus,textarea:focus,select:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-bg)}
textarea{resize:vertical;min-height:90px}
select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236e747a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.dark select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238a8a9a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E")}
img{max-width:100%;display:block}
.page{display:none;animation:fadeIn 0.3s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideRight{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}
@keyframes checkPulse{0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes bounceIn{0%{opacity:0;transform:scale(0.85)}60%{transform:scale(1.02)}100%{opacity:1;transform:scale(1)}}
.container{max-width:420px;margin:0 auto;padding:0 16px;width:100%}
@media(min-width:768px){
  .container{max-width:960px}
  .header-inner{max-width:960px;gap:14px}
  .header-nav{display:flex;align-items:center;gap:2px}
  .header-nav a{padding:8px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--text2);white-space:nowrap;transition:all .2s}
  .header-nav a:hover{background:var(--bg2);color:var(--coral)}
  .header-nav a.active{background:var(--coral-bg);color:var(--coral);font-weight:700}
  .header-search{max-width:340px;flex:0 1 auto;min-width:200px}
  .header-search input{min-width:80px}
  .logo-text{display:inline!important}
  .logo{gap:10px;font-size:22px}
  .logo-icon{width:40px;height:40px;font-size:20px}
  .btn-login{display:inline-flex!important;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:14px;font-weight:600;color:var(--coral);background:var(--coral-bg);white-space:nowrap;transition:all .2s}
  .btn-login:hover{background:var(--coral);color:#fff}
}
@media(min-width:1024px){
  .container{max-width:1100px}
  .header-inner{max-width:1100px;gap:18px}
  .header-search{max-width:420px;min-width:280px}
  .header-nav a{padding:8px 16px;font-size:15px}
}
/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:1000;background:rgba(255,255,255,0.72);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(229,231,235,0.3);transition:background var(--transition),border-color var(--transition)}
.dark .header{background:rgba(15,15,26,0.78);border-bottom-color:rgba(42,42,62,0.3)}
.header-inner{max-width:420px;margin:0 auto;padding:0 8px;height:100%;display:flex;align-items:center;gap:6px}
/* Unified header search — flex:1 to be wider, input fills available space */
.header-search{display:flex;align-items:center;gap:4px;background:var(--bg2);border:2px solid var(--border);border-radius:10px;padding:0 6px;transition:border-color var(--transition)}
.header-search:focus-within{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-bg)}
.header-search input{flex:1;border:none;background:none;outline:none;font-size:14px;font-family:var(--font);color:var(--text);padding:8px 4px;width:100%}
.header-search input::placeholder{color:var(--text3);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.header-search-btn{flex-shrink:0;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600;background:var(--coral);color:#fff;cursor:pointer;border:none;font-family:var(--font);white-space:nowrap;line-height:1.4;transition:background .2s}
.header-search-btn:hover{background:var(--coral-dark)}
.header-search-btn .btn-text{display:inline}
.header-search-btn .btn-icon{display:none}
/* Unified header filters bar — more padding so chips aren't crushed */
.header-filters{display:flex;align-items:center;gap:6px;padding:6px 12px 10px;flex-wrap:wrap}
.header-filters::-webkit-scrollbar{display:none}
.hf-chip{flex-shrink:0;display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600;background:var(--bg2);color:var(--text2);cursor:pointer;transition:all .2s;border:none;font-family:var(--font);white-space:nowrap}
.hf-chip:hover{background:var(--coral-bg);color:var(--coral)}
.hf-count{font-size:12px;color:var(--text3);white-space:nowrap;flex-shrink:0}
/* On narrow screens hide logo text so search gets max width */
@media(max-width:767px){
  .header-inner{padding:0 6px;gap:4px}
  .logo{gap:4px;font-size:16px}
  .logo-icon{width:30px;height:30px;font-size:15px;border-radius:8px}
  .logo-text{display:none}
  .header-search{flex:1;min-width:0;max-width:100%;padding:0 4px}
  .header-search input{min-width:0;font-size:13px;padding:7px 2px}
  .header-search input::placeholder{font-size:12px}
  .header-search-btn{padding:6px 8px;font-size:0}
  .header-search-btn .btn-text{display:none}
  .header-search-btn .btn-icon{display:inline;width:16px;height:16px}
  .header-actions{gap:4px}
  .notif-btn{min-width:44px;min-height:44px;font-size:15px}
  .burger-btn{min-width:44px;min-height:44px}
}
.logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:20px;color:var(--text)}
.logo-icon{width:36px;height:36px;background:var(--coral);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:900}
.logo span{background:linear-gradient(135deg,var(--coral),#e8745e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.header-actions{display:flex;align-items:center;gap:6px}
.header-nav{display:none}
.btn-login{display:none}
.notif-btn{position:relative;min-width:44px;min-height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text2);font-size:18px;transition:all var(--transition)}
.notif-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--coral);border-radius:50%;border:2px solid var(--bg)}
.dark .notif-dot{border-color:var(--card)}
/* ===== BURGER MENU ===== */
.burger-btn{min-width:44px;min-height:44px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:var(--bg2);padding:10px 8px;transition:all var(--transition)}
.burger-btn span{display:block;width:18px;height:2px;background:var(--text);border-radius:1px;transition:all .3s}
.burger-btn.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.burger-btn.open span:nth-child(2){opacity:0}
.burger-btn.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:2000;opacity:0;pointer-events:none;transition:opacity .35s}
.menu-overlay.show{opacity:1;pointer-events:auto}
.menu-panel{position:fixed;top:0;right:-300px;width:280px;height:100%;background:var(--card);z-index:2001;padding:20px 0;overflow-y:auto;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px rgba(0,0,0,.15)}
.menu-panel.show{right:0}
.menu-header{display:flex;align-items:center;gap:12px;padding:0 20px 16px;border-bottom:1px solid var(--border);margin-bottom:8px}
.menu-avatar{width:44px;height:44px;background:var(--coral);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex-shrink:0}
.menu-name{font-weight:700;font-size:15px;color:var(--text)}
.menu-role{font-size:12px;color:var(--text2)}
.menu-nav{display:flex;flex-direction:column;padding:8px 12px}
.menu-item{padding:10px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--text);transition:background .2s;display:flex;align-items:center;gap:8px}
.menu-item:hover,.menu-item.active{background:var(--coral-bg);color:var(--coral)}
.menu-section-title{padding:16px 20px 8px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.menu-theme{display:flex;align-items:center;gap:10px;padding:12px 20px;margin:0 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;font-size:14px;font-weight:500}
.menu-theme:hover{background:var(--bg2)}
.theme-toggle-track{width:44px;height:24px;background:var(--border);border-radius:12px;position:relative;transition:background .3s;margin-left:auto}
.theme-toggle-track.on{background:var(--coral)}
.theme-toggle-thumb{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .3s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.theme-toggle-track.on .theme-toggle-thumb{left:22px}
/* ===== BOTTOM NAV ===== */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);z-index:1000;background:rgba(255,255,255,0.75);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid rgba(229,231,235,0.3);display:flex;align-items:center;justify-content:space-around;padding:0 4px calc(4px + var(--safe-bottom));transition:background var(--transition),border-color var(--transition)}
.dark .bottom-nav{background:rgba(15,15,26,0.8);border-top-color:rgba(42,42,62,0.3)}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 10px;border-radius:12px;color:var(--text3);font-size:10px;font-weight:500;transition:all var(--transition);position:relative;touch-action:manipulation;cursor:pointer;-webkit-tap-highlight-color:transparent}
.nav-item svg{width:24px;height:24px;transition:all var(--transition)}
.nav-item.active{color:var(--coral)}
.nav-item.active svg{color:var(--coral)}
.nav-badge{position:absolute;top:0;right:2px;background:var(--coral);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
/* ===== UTILITY CLASSES ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-sm);font-weight:600;font-size:15px;transition:all var(--transition);white-space:nowrap;min-height:44px}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 4px 14px rgba(194,58,41,0.3)}
.btn-primary:hover{background:var(--coral-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(212,85,62,0.35)}
.btn-secondary{background:var(--bg2);color:var(--text);border:2px solid var(--border)}
.btn-secondary:hover{border-color:var(--coral);color:var(--coral)}
.btn-sm{padding:8px 16px;font-size:13px;border-radius:var(--radius-xs);min-height:36px}
.btn-lg{padding:14px 32px;font-size:17px}
.btn-block{width:100%;justify-content:center}
.btn-outline{background:transparent;border:2px solid var(--coral);color:var(--coral)}
.btn-outline:hover{background:var(--coral);color:#fff}
.btn-ghost{color:var(--text2)}
.btn-ghost:hover{color:var(--coral);background:var(--coral-bg)}
.btn-group{display:flex;gap:12px;margin-top:24px}
.btn-group .btn{flex:1}
.section-title{font-size:20px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}
.section-title .link{font-size:13px;font-weight:500;color:var(--coral);cursor:pointer}
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-coral{background:var(--coral-bg);color:var(--coral)}
.badge-green{background:#e6f7e6;color:#16a34a}
.dark .badge-green{background:rgba(22,163,74,0.15);color:#4ade80}
.badge-gray{background:var(--bg2);color:var(--text2)}
.card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);border:1px solid var(--border);transition:background var(--transition),border-color var(--transition),transform 0.2s}
.divider{height:1px;background:var(--border);margin:16px 0}
.divider-text{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text3);font-size:13px;font-weight:500}
.divider-text::before,.divider-text::after{content:'';flex:1;height:1px;background:var(--border)}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.justify-around{justify-content:space-around}
.gap-4{gap:4px}
.gap-6{gap:6px}
.gap-8{gap:8px}
.gap-10{gap:10px}
.gap-12{gap:12px}
.gap-16{gap:16px}
.group-label{padding:10px 0 4px;font-size:13px;font-weight:700;color:var(--text2);display:flex;align-items:center;gap:6px}
.gap-20{gap:20px}
.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1}
.text-center{text-align:center}
.mt-8{margin-top:8px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}
.mt-20{margin-top:20px}
.mb-12{margin-bottom:12px}
.mb-16{margin-bottom:16px}
.text-sm{font-size:13px}
.text-xs{font-size:11px}
.text-lg{font-size:18px}
.text-xl{font-size:22px;font-weight:700}
.text-coral{color:var(--coral)}
.text-muted{color:var(--text2)}
.fw-6{font-weight:600}
.fw-7{font-weight:700}
.fw-8{font-weight:800}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
/* === OLD SEARCH PANEL CSS REMOVED (moved to unified header) === */
/* Keep sp-icon for compact bar compatibility */
.sp-icon{width:18px;height:18px;color:var(--text3);flex-shrink:0}

/* COMPACT bar — hidden on mobile (search is in unified header) */
.search-compact{display:none}
.search-compact.visible{top:var(--header-h)}
.sc-input-wrap{flex:1;display:flex;align-items:center;gap:6px;background:var(--bg2);border:2px solid var(--border);border-radius:10px;padding:0 8px;min-width:0}
.sc-input{flex:1;border:none;background:none;font-size:13px;font-family:var(--font);color:var(--text);outline:none;padding:8px 0}
.sc-input::placeholder{color:var(--text3)}
.sc-filter-btn{display:flex;align-items:center;gap:2px;padding:6px 10px;border-radius:10px;font-size:12px;font-weight:600;background:var(--bg2);color:var(--text2);cursor:pointer;white-space:nowrap;font-family:var(--font);border:2px solid var(--border);transition:all .2s}
.sc-count{font-size:11px;font-weight:600;color:var(--coral);padding:4px 8px;background:var(--coral-bg);border-radius:8px;white-space:nowrap}

@media(min-width:768px){
  .search-compact{display:none!important}
  .sp-chips{gap:8px}
  .sp-chip{font-size:13px;padding:6px 12px}
}

/* Filter sheet (mobile) */
.filter-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:2000;opacity:0;pointer-events:none;transition:opacity .35s}
.filter-overlay.show{opacity:1;pointer-events:auto}
.filter-sheet{position:fixed;bottom:0;left:0;right:0;max-height:80vh;background:var(--card);z-index:2001;border-radius:var(--radius) var(--radius) 0 0;padding:20px 16px calc(16px + var(--safe-bottom));overflow-y:auto;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 24px rgba(0,0,0,.15)}
.filter-sheet.show{transform:translateY(0)}
.filter-sheet-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}
.filter-sheet-title{font-size:16px;font-weight:700;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.filter-sheet-close{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text2);font-size:16px;cursor:pointer;transition:background .2s;border:none;font-family:var(--font)}
.filter-sheet-close:hover{background:var(--border)}
.filter-sheet .filter-chips{flex-wrap:wrap;gap:8px;margin-bottom:12px}
.filter-sheet-group{margin-bottom:16px}
.filter-sheet-group label{display:block;font-size:12px;font-weight:700;color:var(--text3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}
.filter-sheet .chip-sel,.filter-sheet .chip-tag{padding:8px 14px;font-size:13px;border-radius:10px;background:var(--bg2);color:var(--text2);border:2px solid transparent;cursor:pointer;transition:all .2s;font-family:var(--font);font-weight:600}
.filter-sheet .chip-sel.on,.filter-sheet .chip-tag.on{border-color:var(--coral);background:var(--coral-bg);color:var(--coral)}
.filter-sheet .city-option-sheet{padding:10px 14px;border-radius:10px;background:var(--bg2);color:var(--text2);border:2px solid transparent;cursor:pointer;transition:all .2s;font-family:var(--font);font-weight:600;font-size:13px;display:inline-flex;margin:3px}
.filter-sheet .city-option-sheet.active{border-color:var(--coral);background:var(--coral-bg);color:var(--coral)}
.filter-sheet-actions{display:flex;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}
.filter-sheet-actions button{flex:1;padding:12px;border-radius:var(--radius-sm);font-weight:700;font-size:14px;cursor:pointer;font-family:var(--font);transition:all .2s}
.filter-sheet-actions .fs-btn-reset{background:var(--bg2);color:var(--text2);border:2px solid var(--border)}
.filter-sheet-actions .fs-btn-reset:hover{border-color:var(--coral);color:var(--coral)}
.filter-sheet-actions .fs-btn-apply{background:var(--coral);color:#fff;border:none;box-shadow:0 4px 14px rgba(194,58,41,0.3)}
.filter-sheet-actions .fs-btn-apply:hover{background:var(--coral-dark)}

@media(min-width:768px){
  /* Inline filters on tablet+ */
  .filter-overlay{display:none!important}
  .filter-sheet{position:static!important;display:block!important;max-height:none!important;border-radius:0!important;box-shadow:none!important;background:transparent!important;padding:0!important;width:100%!important;left:auto!important;bottom:auto!important;transform:none!important;animation:none!important}
  .filter-sheet .filter-sheet-handle,.filter-sheet .filter-sheet-close,.filter-sheet .filter-sheet-actions{display:none!important}
  .filter-sheet .filter-sheet-group{padding:0;margin-bottom:8px}
  .filter-sheet .filter-sheet-title{display:none!important}
}

.sticky-top{position:sticky;top:var(--header-h);z-index:100;background:var(--bg);padding:4px 0 4px;border-bottom:1px solid var(--border);margin:0;transition:transform .3s,opacity .3s}
.sticky-top.hidden{transform:translateY(-100%);opacity:0;pointer-events:none}
/* ===== VARIANT SWITCHER ===== */
.variant-switcher{display:flex;gap:4px;overflow-x:auto;padding:2px 0 4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.variant-switcher::-webkit-scrollbar{display:none}
.variant-btn{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;width:44px;height:44px;border-radius:var(--radius-sm);background:var(--bg2);color:var(--text3);font-size:8px;font-weight:500;transition:all 0.2s;border:2px solid transparent;position:relative}
.variant-btn .v-icon{font-size:16px;line-height:1}
.variant-btn:hover{border-color:var(--coral-bg);color:var(--text)}
.variant-btn.active{border-color:var(--coral);background:var(--coral-bg);color:var(--coral);font-weight:700}
.variant-btn .v-num{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--coral);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}
.variant-panel{display:none}
.variant-panel.active{display:block;animation:bounceIn 0.25s ease}
/* ===== VARIANT 1: Classic Cards ===== */
.v1-card{padding:16px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);transition:all var(--transition);cursor:pointer}
.v1-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,0.1)}
.v1-card .v1-title{font-size:16px;font-weight:700;margin-bottom:4px}
.v1-card .v1-company{font-size:13px;color:var(--text2);font-weight:500}
.v1-card .v1-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.v1-card .v1-salary{font-size:15px;font-weight:700;color:var(--coral)}
.v1-card .v1-location{font-size:12px;color:var(--text3)}
.v1-card .v1-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
/* ===== VARIANT 2: Compact Row ===== */
.v2-row{padding:12px 16px;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--border);display:flex;align-items:center;gap:12px;cursor:pointer;transition:all 0.2s}
.v2-row:hover{background:var(--bg2)}
.v2-row .v2-icon{width:36px;height:36px;border-radius:8px;background:var(--coral-bg);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.v2-row .v2-info{flex:1;min-width:0}
.v2-row .v2-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.v2-row .v2-meta{font-size:11px;color:var(--text2)}
.v2-row .v2-salary{font-weight:700;color:var(--coral);font-size:14px;white-space:nowrap}
/* ===== VARIANT 3: Grid Cards ===== */
.v3-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(min-width:768px){.v3-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.v3-grid{grid-template-columns:repeat(4,1fr)}}
.v3-grid-item{padding:14px 12px;border-radius:var(--radius);background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);cursor:pointer;transition:all 0.2s;position:relative;overflow:hidden}
.v3-grid-item:hover{transform:translateY(-2px)}
.v3-grid-item .v3-hot{position:absolute;top:0;right:0;background:var(--coral);color:#fff;font-size:9px;font-weight:700;padding:2px 8px;border-radius:0 var(--radius) 0 var(--radius-sm)}
.v3-grid-item .v3-icon{font-size:24px;margin-bottom:6px}
.v3-grid-item .v3-title{font-size:13px;font-weight:700;line-height:1.3;margin-bottom:2px}
.v3-grid-item .v3-salary{font-size:14px;font-weight:700;color:var(--coral);margin-top:4px}
.v3-grid-item .v3-location{font-size:10px;color:var(--text3);margin-top:2px}
/* ===== VARIANT 4: Minimal List ===== */
.v4-list{display:flex;flex-direction:column}
.v4-item{padding:10px 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all 0.15s}
.v4-item:last-child{border-bottom:none}
.v4-item:hover{padding-left:4px}
.v4-item .v4-left{flex:1;min-width:0}
.v4-item .v4-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.v4-item .v4-sub{font-size:11px;color:var(--text2);margin-top:1px}
.v4-item .v4-salary{font-size:13px;font-weight:700;color:var(--coral);white-space:nowrap;margin-left:8px}
/* ===== VARIANT 5: Featured / Hero Cards ===== */
.v5-card{padding:20px;border-radius:var(--radius);background:linear-gradient(135deg,var(--card),var(--coral-bg));border:1px solid var(--coral);box-shadow:0 4px 20px rgba(212,85,62,0.12);cursor:pointer;transition:all 0.3s;position:relative;overflow:hidden}
.v5-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(212,85,62,0.2)}
.v5-card .v5-badge-top{display:inline-block;padding:2px 10px;border-radius:12px;font-size:10px;font-weight:700;background:var(--coral);color:#fff;margin-bottom:8px}
.v5-card .v5-title{font-size:18px;font-weight:800;margin-bottom:2px}
.v5-card .v5-company{font-size:13px;color:var(--text2);font-weight:500;margin-bottom:6px}
.v5-card .v5-salary{font-size:20px;font-weight:800;color:var(--coral);margin-bottom:4px}
.v5-card .v5-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.v5-card .v5-meta span{padding:4px 10px;border-radius:16px;font-size:10px;font-weight:600;background:var(--bg2);color:var(--text2)}
.v5-card .v5-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}
/* ===== VARIANT 6: Detail — НОВИЙ ДИЗАЙН ===== */
/* Mobile-first */
.v6-card{display:flex;flex-direction:column;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-bottom:16px;cursor:pointer;transition:transform .2s,box-shadow .2s}
.v6-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.v6-photo{width:100%;height:200px;object-fit:cover;display:flex;align-items:center;justify-content:center;font-size:56px;position:relative}
.fav-heart{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.92);border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:all .2s;color:#999}
.fav-heart:hover{transform:scale(1.15);color:#e74c3c}
.fav-heart.liked{color:#e74c3c;background:rgba(255,235,235,.95)}
.v6-details-card{padding:16px}
.v6-title{font-size:20px;font-weight:800;margin-bottom:2px}
.v6-company{font-size:14px;color:var(--text2);font-weight:500;margin-bottom:4px}
.v6-benefits{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.v6-benefits .v6-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;background:var(--coral-bg);color:var(--coral)}
.v6-salary{font-size:22px;font-weight:900;color:var(--coral);margin-top:8px}
.v6-date{font-size:12px;color:var(--text3);margin-top:6px}
.v6-desc{font-size:14px;line-height:1.6;margin:12px 0;color:var(--text2)}
.v6-cta{width:100%;padding:14px;border-radius:12px;font-weight:700;font-size:14px;cursor:pointer;background:var(--coral);color:#fff;border:none;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}
.v6-cta:hover{background:var(--coral-dark)}
@media(min-width:768px){
  .v6-card{flex-direction:row;align-items:stretch}
  .v6-card .v6-photo{flex:0 0 45%;max-height:400px;height:auto}
  .v6-card .v6-details-card{flex:1;padding:20px;display:flex;flex-direction:column;justify-content:center}
  .v6-split{display:flex;align-items:stretch}
  .v6-split .v6-photo{flex:0 0 45%;max-height:400px;height:auto}
  .v6-split .v6-details{flex:1;padding:24px}
}
/* ===== VARIANT 7: Gallery ===== */
.v7-gallery{display:flex;flex-direction:column;gap:16px}
.v7-card{border-radius:var(--radius);overflow:hidden;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);cursor:pointer;transition:all 0.3s}
.v7-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,0.1)}
.v7-card .v7-img{height:120px;display:flex;align-items:center;justify-content:center;font-size:48px;position:relative;overflow:hidden}
.v7-card .v7-img .v7-overlay{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;background:linear-gradient(transparent,rgba(0,0,0,0.5));color:#fff;font-size:11px;font-weight:600}
.v7-card .v7-body{padding:12px 14px 14px}
.v7-card .v7-title{font-size:15px;font-weight:700;margin-bottom:2px}
.v7-card .v7-salary{font-weight:700;color:var(--coral);font-size:15px}
.v7-card .v7-meta{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.v7-card .v7-meta span{padding:2px 8px;border-radius:10px;font-size:10px;background:var(--bg2);color:var(--text2)}
/* ===== VARIANT 8: Timeline ===== */
.v8-timeline{position:relative;padding-left:28px}
.v8-timeline::before{content:'';position:absolute;left:10px;top:4px;bottom:4px;width:2px;background:var(--border)}
.v8-item{position:relative;padding:12px 0 12px 16px;cursor:pointer;transition:all 0.2s;border-left:3px solid transparent;margin-left:-3px}
.v8-item:hover{border-left-color:var(--coral);background:var(--bg2);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.v8-item .v8-dot{position:absolute;left:-24px;top:16px;width:12px;height:12px;border-radius:50%;background:var(--coral);border:3px solid var(--bg);z-index:1}
.dark .v8-item .v8-dot{border-color:var(--bg)}
.v8-item .v8-time{font-size:10px;color:var(--text3);font-weight:500;margin-bottom:2px}
.v8-item .v8-title{font-size:14px;font-weight:700}
.v8-item .v8-company{font-size:12px;color:var(--text2);font-weight:500}
.v8-item .v8-salary{font-size:13px;font-weight:700;color:var(--coral);margin-top:2px}
.v8-item .v8-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}
.v8-item .v8-tags span{padding:2px 8px;border-radius:10px;font-size:9px;background:var(--coral-bg);color:var(--coral);font-weight:600}
/* ===== AD BLOCKS ===== */
.ad-block{border-radius:var(--radius);padding:14px 16px;margin:12px 0;background:var(--ad-bg);border:1px solid rgba(194,58,41,0.15);display:flex;align-items:center;gap:12px;cursor:pointer;transition:all 0.2s}
.ad-block:hover{background:var(--coral-bg);border-color:var(--coral)}
.ad-block .ad-label{font-size:9px;font-weight:700;color:var(--coral);text-transform:uppercase;letter-spacing:1px;background:rgba(212,85,62,0.12);padding:2px 8px;border-radius:8px;display:inline-block;margin-bottom:4px}
.ad-block .ad-title{font-size:14px;font-weight:700;margin-bottom:2px}
.ad-block .ad-text{font-size:12px;color:var(--text2);line-height:1.4}
.ad-block .ad-icon{font-size:32px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(212,85,62,0.08);border-radius:12px}
.ad-banner{width:100%;height:80px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--coral),#e8745e);display:flex;align-items:center;justify-content:center;gap:12px;color:#fff;font-weight:700;font-size:15px;cursor:pointer;margin:12px 0;transition:transform 0.2s;position:relative;overflow:hidden}
.ad-banner:hover{transform:scale(1.01)}
.ad-banner .ad-label-light{position:absolute;top:4px;right:6px;font-size:8px;font-weight:600;color:rgba(255,255,255,0.5);text-transform:uppercase}
.ad-banner .ad-emoji{font-size:28px}
/* ===== FILTER PANEL ===== */
.filter-panel{background:var(--card);border-radius:var(--radius);padding:6px 10px;margin-bottom:8px;box-shadow:var(--shadow);border:1px solid var(--border)}
.filter-row{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:2px}
.filter-row::-webkit-scrollbar{display:none}
.filter-chips{display:flex;gap:8px;padding:4px 0;flex-wrap:wrap;align-items:center}
.chip-filter{padding:8px 14px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg2);color:var(--text2);cursor:pointer;transition:all .2s;user-select:none;border:2px solid transparent;white-space:nowrap;font-family:var(--font)}
.chip-filter:hover,.chip-filter:focus{border-color:var(--coral-bg);color:var(--text)}
.chip-filter.active{border-color:var(--coral);background:var(--coral-bg);color:var(--coral)}
.chip-filter.filter-input{padding:8px 12px;width:100px;font-size:12px;font-weight:500;background:var(--bg2);color:var(--text);border:2px solid transparent;outline:none;font-family:var(--font);transition:border-color .2s}
.chip-filter.filter-input:focus{border-color:var(--coral)}
.chip-filter.filter-input::placeholder{color:var(--text3)}
.chip-sel{padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600;background:var(--bg2);color:var(--text2);cursor:pointer;transition:all .2s;user-select:none;white-space:nowrap;flex-shrink:0}
.chip-sel.on{background:var(--coral);color:#fff}
.chip-tag{padding:5px 10px;border-radius:14px;font-size:11px;font-weight:500;background:var(--bg2);color:var(--text3);cursor:pointer;transition:all .2s;user-select:none;white-space:nowrap;flex-shrink:0}
.chip-tag.on{background:rgba(194,58,41,0.12);color:var(--coral)}
.chip-more{background:transparent;color:var(--coral);font-weight:600;font-size:12px;padding:5px 8px}
.chip-reset{padding:8px 14px;border-radius:20px;font-size:12px;font-weight:600;background:var(--coral);color:#fff;cursor:pointer;transition:all .2s;user-select:none;border:none;white-space:nowrap;font-family:var(--font)}
.chip-reset:hover{background:var(--coral-dark)}
.filter-dropdown{display:none;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;box-shadow:0 4px 20px rgba(0,0,0,0.12);max-width:320px;margin:8px 0}
.filter-dropdown-inner{display:flex;flex-wrap:wrap;gap:6px}
.city-option{padding:8px 16px;border-radius:20px;font-size:12px;font-weight:600;background:var(--bg2);color:var(--text2);cursor:pointer;transition:all .2s;border:2px solid transparent;font-family:var(--font)}
.city-option:hover,.city-option:focus{border-color:var(--coral-bg);color:var(--text)}
.city-option.active{border-color:var(--coral);background:var(--coral-bg);color:var(--coral)}
.filter-summary{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
#favModeIndicator{font-weight:700;animation:pulse 2s infinite}
.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.scroll-x::-webkit-scrollbar{display:none}
.vacancy-group{margin-bottom:8px}
.vacancy-group.filtered-out{display:none}
.vacancy-card{transition:opacity 0.3s,transform 0.3s}
.vacancy-card.filtered-out{opacity:0.3;pointer-events:none;transform:scale(0.96)}
.group-header{display:flex;align-items:center;gap:10px;padding:14px 16px;margin-bottom:10px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.group-header .group-icon{font-size:22px;width:40px;height:40px;border-radius:10px;background:var(--coral-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.group-header .group-title{font-size:16px;font-weight:700;flex:1;color:var(--text)}
.group-header .group-count{font-size:11px;color:var(--text3);padding:3px 10px;border-radius:10px;background:var(--bg2);font-weight:600;white-space:nowrap}
@media(min-width:768px){
  .filter-chips{flex-wrap:nowrap}
  .chip-filter.filter-input{width:120px}
}
/* ===== NOTIFICATION PANEL (MODAL) ===== */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:2000;display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.show{display:flex}
.modal-sheet{background:var(--card);border-radius:20px 20px 0 0;width:100%;max-width:420px;max-height:80vh;overflow-y:auto;padding:24px 20px;animation:slideUp 0.3s ease;position:relative}
.modal-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}
.modal-close{position:absolute;top:16px;right:16px;min-width:44px;min-height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text2);font-size:16px}
.notif-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:all 0.15s}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{opacity:0.8}
.notif-item.unread{background:var(--notif-unread);margin:0 -16px;padding:12px 16px;border-radius:var(--radius-sm)}
.notif-item .notif-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.notif-item .notif-icon.icon-new{background:var(--coral-bg);color:var(--coral)}
.notif-item .notif-icon.icon-applied{background:rgba(22,163,74,0.1);color:#16a34a}
.notif-item .notif-icon.icon-system{background:var(--bg2);color:var(--text2)}
.notif-item .notif-body{flex:1;min-width:0}
.notif-item .notif-title{font-size:14px;font-weight:600;margin-bottom:2px}
.notif-item .notif-text{font-size:12px;color:var(--text2);line-height:1.4}
.notif-item .notif-time{font-size:10px;color:var(--text3);margin-top:4px}
.notif-item .notif-badge{font-size:9px;font-weight:700;color:var(--coral);background:var(--coral-bg);padding:2px 8px;border-radius:8px;display:inline-block;margin-top:2px}
/* ===== TOAST ===== */
#toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:9999;background:var(--card);color:var(--text);padding:12px 24px;border-radius:var(--radius-sm);box-shadow:0 4px 24px rgba(0,0,0,0.15);font-size:14px;font-weight:500;opacity:0;transition:opacity 0.3s;pointer-events:none;border:1px solid var(--border);max-width:90%;text-align:center}
/* ===== COUNTER BADGE ===== */
.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--coral);color:#fff;font-size:10px;font-weight:700}
/* ===== REGISTER / LOGIN STYLES ===== */
.progress-wrap{padding:24px 0 12px}
.progress-bar-reg{display:flex;align-items:center;justify-content:space-between;position:relative;padding:0 4px}
.progress-track{position:absolute;top:16px;left:20px;right:20px;height:3px;background:var(--border);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:var(--coral);border-radius:2px;transition:width 0.5s cubic-bezier(.4,0,.2,1);width:0%}
.progress-step-reg{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:2;cursor:pointer}
.progress-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:var(--bg2);border:2px solid var(--border);color:var(--text3);transition:all 0.4s ease}
.progress-step-reg.done .progress-circle{background:var(--coral);border-color:var(--coral);color:#fff}
.progress-step-reg.active .progress-circle{border-color:var(--coral);color:var(--coral);font-weight:800;box-shadow:0 0 0 4px var(--coral-bg)}
.progress-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.3px;transition:color 0.3s}
.progress-step-reg.done .progress-label,.progress-step-reg.active .progress-label{color:var(--coral)}
.section-title-lg{font-size:24px;font-weight:800;margin-bottom:6px}
.section-sub{font-size:14px;color:var(--text2);margin-bottom:24px;line-height:1.6}
.social-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.social-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 18px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;color:var(--text);background:var(--card);border:2px solid var(--border);transition:all var(--transition);position:relative;overflow:hidden}
.social-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.social-btn:active{transform:translateY(0)}
.social-btn .s-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.social-btn .s-text{flex:1;text-align:left}
.social-btn .s-arrow{color:var(--text3);font-size:14px;transition:transform 0.3s}
.social-btn:hover .s-arrow{transform:translateX(3px)}
.social-btn.google{border-color:rgba(219,68,55,0.25)}
.social-btn.google .s-icon{background:#DB4437;color:#fff}
.social-btn.google:hover{border-color:#DB4437;box-shadow:0 4px 16px rgba(219,68,55,0.2)}
.social-btn.facebook{border-color:rgba(24,119,242,0.25)}
.social-btn.facebook .s-icon{background:#1877F2;color:#fff}
.social-btn.facebook:hover{border-color:#1877F2;box-shadow:0 4px 16px rgba(24,119,242,0.2)}
.social-btn.telegram{border-color:rgba(0,136,204,0.25)}
.social-btn.telegram .s-icon{background:#0088cc;color:#fff}
.social-btn.telegram:hover{border-color:#0088cc;box-shadow:0 4px 16px rgba(0,136,204,0.2)}
.social-btn.email{border-color:rgba(194,58,41,0.2)}
.social-btn.email .s-icon{background:var(--coral);color:#fff}
.social-btn.email:hover{border-color:var(--coral)}
.social-btn.phone{border-color:rgba(194,58,41,0.2)}
.social-btn.phone .s-icon{background:var(--coral);color:#fff}
.social-btn.phone:hover{border-color:var(--coral)}
.dark .social-btn{background:var(--bg2);border-color:var(--border)}
.dark .social-btn:hover{background:var(--card)}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text2)}
.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.role-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--card);cursor:pointer;transition:all var(--transition);text-align:center}
.role-card:hover{border-color:var(--coral-bg)}
.role-card.active{border-color:var(--coral);background:var(--coral-bg)}
.role-card .r-icon{font-size:28px;line-height:1}
.role-card .r-title{font-size:14px;font-weight:700;color:var(--text)}
.role-card .r-desc{font-size:11px;color:var(--text2);line-height:1.3}
.role-card.active .r-title{color:var(--coral)}
.filter-section{margin-bottom:18px}
.filter-label{display:block;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text2)}
.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip-reg{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;font-size:13px;font-weight:500;background:var(--bg2);color:var(--text2);border:1.5px solid transparent;cursor:pointer;transition:all 0.2s;user-select:none}
.chip-reg:hover{background:var(--coral-bg);color:var(--coral)}
.chip-reg.active{background:var(--coral);color:#fff;font-weight:600;border-color:var(--coral-dark)}
.chip-reg .chip-count{font-size:11px;opacity:0.7}
.salary-range{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.salary-range input{padding:10px 14px;font-size:14px;text-align:center}
.telegram-card{background:var(--card);border:2px solid rgba(0,136,204,0.2);border-radius:var(--radius);padding:20px;margin-bottom:20px;transition:all var(--transition)}
.dark .telegram-card{border-color:rgba(0,136,204,0.15)}
.telegram-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.telegram-card-header .tg-icon{width:44px;height:44px;background:#0088cc;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;flex-shrink:0}
.telegram-card-header .tg-title{font-size:16px;font-weight:700;color:var(--text)}
.telegram-card-header .tg-sub{font-size:12px;color:var(--text2);margin-top:2px}
.telegram-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg2);border-radius:var(--radius-sm);margin-bottom:16px}
.telegram-toggle .tt-label{font-size:14px;font-weight:600;color:var(--text)}
.toggle-switch{width:48px;height:26px;background:var(--border);border-radius:13px;position:relative;cursor:pointer;transition:background 0.3s;flex-shrink:0}
.toggle-switch.on{background:var(--coral)}
.toggle-switch .toggle-thumb{width:22px;height:22px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left 0.3s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-switch.on .toggle-thumb{left:24px}
.telegram-note{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:var(--coral-bg);border-radius:var(--radius-sm);font-size:12px;color:var(--text2);line-height:1.5;margin-top:12px}
.telegram-note .tn-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.auth-switch{text-align:center;margin-top:24px;font-size:14px;color:var(--text2)}
.auth-switch a{color:var(--coral);font-weight:600;cursor:pointer}
.auth-switch a:hover{text-decoration:underline}
.checkbox-wrap{display:flex;align-items:flex-start;gap:8px;margin:12px 0}
.checkbox-wrap input[type="checkbox"]{width:20px;height:20px;flex-shrink:0;margin-top:2px;accent-color:var(--coral);cursor:pointer}
.checkbox-wrap label{font-size:13px;color:var(--text2);cursor:pointer;line-height:1.5}
.pwd-wrap{position:relative}
.pwd-wrap input{padding-right:44px}
.pwd-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;color:var(--text3);padding:4px}
.pwd-toggle:hover{color:var(--coral)}
.success-screen{text-align:center;padding:40px 0;animation:scaleIn 0.4s ease}
.success-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--coral),#e8745e);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:36px;color:#fff;animation:checkPulse 0.6s ease}
.success-title{font-size:24px;font-weight:800;margin-bottom:8px}
.success-desc{font-size:14px;color:var(--text2);margin-bottom:24px}
.sms-inputs{display:flex;gap:10px;justify-content:center;margin:16px 0}
.sms-inputs input{width:48px;height:56px;text-align:center;font-size:24px;font-weight:700;border-radius:var(--radius-sm);padding:0}
.sms-timer{text-align:center;font-size:13px;color:var(--text3);margin-top:10px}
.sms-timer .resend{cursor:pointer;color:var(--coral);font-weight:600}
.sms-timer .resend:hover{text-decoration:underline}
.forgot-link{text-align:right;font-size:13px;margin-top:-8px;margin-bottom:16px}
.forgot-link a{color:var(--coral);font-weight:500;cursor:pointer}
.forgot-link a:hover{text-decoration:underline}
.page-section-reg{display:none;animation:fadeInUp 0.35s ease}
.page-section-reg.active{display:block}
/* ===== CREATE VACANCY / RESUME STYLES ===== */
.page-header{display:flex;align-items:center;gap:12px;padding:16px 0;position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border);margin-bottom:20px}
.page-header .back-btn{min-width:44px;min-height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text2);font-size:18px;transition:all var(--transition);flex-shrink:0}
.page-header .back-btn:hover{background:var(--coral-bg);color:var(--coral)}
.page-header h1{font-size:18px;font-weight:700;flex:1}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:6px}
.form-label .required{color:var(--coral);margin-left:2px}
.form-hint{font-size:11px;color:var(--text3);margin-top:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.chip-create{cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;font-size:13px;font-weight:500;background:var(--bg2);color:var(--text2);border:2px solid transparent;transition:all 0.2s;user-select:none}
.chip-create:hover{border-color:var(--coral-bg);color:var(--text)}
.chip-create.selected{background:var(--coral-bg);border-color:var(--coral);color:var(--coral);font-weight:600}
.chip-create .chip-icon{font-size:15px;line-height:1}
.photo-upload-wrap{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.photo-box{width:90px;height:90px;border-radius:var(--radius-sm);border:2px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;color:var(--text3);font-size:10px;font-weight:500;gap:4px;position:relative;overflow:hidden;background:var(--bg2)}
.photo-box:hover{border-color:var(--coral);color:var(--coral);background:var(--coral-bg)}
.photo-box .photo-icon{font-size:28px;line-height:1}
.photo-box.has-photo{border-style:solid;border-color:var(--border);cursor:default}
.photo-box.has-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.photo-box .photo-remove{position:absolute;top:-2px;right:-2px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,0.5);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background 0.2s}
.photo-box .photo-remove:hover{background:var(--coral)}
.photo-box .photo-add-label{font-size:10px;font-weight:500;text-align:center;position:relative;z-index:1}
.camera-avatar{width:100px;height:100px;border-radius:50%;border:3px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;color:var(--text3);font-size:11px;font-weight:500;gap:2px;margin:0 auto 16px;position:relative;overflow:hidden;background:var(--bg2)}
.camera-avatar:hover{border-color:var(--coral);color:var(--coral);background:var(--coral-bg)}
.camera-avatar .cam-icon{font-size:36px;line-height:1}
.camera-avatar.has-photo{border-style:solid;border-color:var(--border);cursor:default}
.camera-avatar.has-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.camera-avatar .photo-remove{position:absolute;top:2px;right:2px;width:24px;height:24px;border-radius:50%;background:rgba(0,0,0,0.5);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}
.skill-cat{margin-bottom:12px}
.skill-cat-title{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px}
.skill-search{position:relative;margin-bottom:12px}
.skill-search input{padding-left:36px;font-size:14px}
.skill-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:16px;pointer-events:none}
.form-section-title{font-size:15px;font-weight:700;margin-bottom:12px;padding-top:4px;display:flex;align-items:center;gap:8px}
.form-section-title .sec-icon{font-size:18px}
.preview-area{background:var(--card);border-radius:var(--radius);padding:16px;border:1px solid var(--border);margin-bottom:16px;min-height:80px;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:13px}
.progress-bar-create{display:flex;gap:8px;margin-bottom:20px;padding:0 4px}
.progress-step-create{flex:1;height:10px;border-radius:5px;background:var(--border);transition:background 0.3s;position:relative}
.progress-step-create.done{background:var(--coral)}
.progress-step-create::after{content:attr(data-step);position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--text3);font-weight:600;white-space:nowrap}
.progress-step-create.done::after{color:var(--coral)}
@media(max-width:400px){
  .container{padding:0 14px}
  .section-title-lg{font-size:20px}
  .role-grid{grid-template-columns:1fr}
  .salary-range{grid-template-columns:1fr}
}
/* ===== SKIP TO CONTENT ===== */
.skip-link{position:fixed;top:-100px;left:16px;padding:12px 20px;background:var(--coral);color:#fff;z-index:10000;font-weight:700;font-size:14px;border-radius:0 0 var(--radius-sm) var(--radius-sm);transition:top 0.2s}
.skip-link:focus{top:0;outline:3px solid #ffd700;outline-offset:2px}
/* ===== REDUCED MOTION ===== */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
}
/* ===== DETAIL PAGE ===== */
.detail-header{display:flex;align-items:center;padding:12px 16px;gap:12px;position:sticky;top:0;z-index:10;background:var(--bg);border-bottom:1px solid var(--border)}
.detail-back{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;font-size:18px;color:var(--text)}
.detail-header-actions{margin-left:auto;display:flex;gap:8px}
.detail-header-btn{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;font-size:16px;color:var(--text)}
.detail-photo{width:100%;height:220px;object-fit:cover;background:linear-gradient(135deg,var(--coral-bg),var(--bg2));display:flex;align-items:center;justify-content:center;font-size:64px}
.detail-body{padding:16px}
.detail-title{font-size:22px;font-weight:800;margin-bottom:4px;line-height:1.3}
.detail-company{font-size:15px;color:var(--text2);font-weight:500;margin-bottom:4px}
.detail-salary{font-size:24px;font-weight:800;color:var(--coral);margin:8px 0}
.detail-chips{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}
.detail-chip{padding:6px 14px;border-radius:20px;background:var(--coral-bg);color:var(--coral);font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px}
.detail-stats{display:flex;gap:16px;margin:12px 0;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-wrap:wrap}
.detail-stat{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text2)}
.detail-stat strong{color:var(--text)}
.detail-section{margin:16px 0}
.detail-section-title{font-size:16px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.detail-section-text{font-size:14px;line-height:1.7;color:var(--text2)}
.detail-requirements{list-style:none;padding:0;margin:0}
.detail-requirements li{padding:6px 0;font-size:14px;display:flex;align-items:flex-start;gap:8px;color:var(--text2)}
.detail-requirements li::before{content:'✓';color:var(--coral);font-weight:700;flex-shrink:0}
.detail-apply-bar{position:fixed;bottom:calc(var(--bottom-h) + var(--safe-bottom));left:0;right:0;padding:12px 16px;background:var(--bg);border-top:1px solid var(--border);display:flex;gap:10px;z-index:5}
.detail-apply-fav{width:48px;height:48px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:22px;flex-shrink:0}
.detail-apply-btn{flex:1;height:48px;border-radius:var(--radius);background:var(--coral);color:#fff;border:none;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.detail-similar{margin:20px 0}
.detail-similar-card{padding:12px;border-radius:var(--radius);background:var(--bg2);border:1px solid var(--border);cursor:pointer;margin-bottom:8px}
.detail-similar-title{font-size:14px;font-weight:600}
.detail-similar-salary{font-size:13px;font-weight:700;color:var(--coral)}


/* ===== RECRUITER BULK CREATE PAGE ===== */
.bulk-header{display:flex;align-items:center;padding:12px 16px;gap:12px;background:var(--bg);border-bottom:1px solid var(--border)}
.bulk-header h1{font-size:18px;font-weight:700;margin:0}
.bulk-tabs{display:flex;gap:4px;padding:8px 16px;background:var(--bg2);border-bottom:1px solid var(--border)}
.bulk-tab{flex:1;padding:10px 8px;border-radius:10px;font-size:12px;font-weight:600;text-align:center;cursor:pointer;transition:all .2s;border:2px solid transparent;color:var(--text2);background:transparent;display:flex;flex-direction:column;align-items:center;gap:4px}
.bulk-tab .tab-icon{font-size:24px;line-height:1}
.bulk-tab.active{border-color:var(--coral);background:var(--coral-bg);color:var(--coral)}
.bulk-tab:hover:not(.active){background:var(--bg)}
.bulk-content{padding:16px}
.bulk-panel{display:none}
.bulk-panel.active{display:block}
.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg2)}
.drop-zone.drag-over{border-color:var(--coral);background:var(--coral-bg)}
.drop-zone-icon{font-size:48px;margin-bottom:12px}
.drop-zone-title{font-size:16px;font-weight:700;margin-bottom:4px}
.drop-zone-sub{font-size:13px;color:var(--text2);margin-bottom:12px}
.drop-zone input{display:none}
.tg-code-box{background:var(--bg2);border:2px solid var(--coral);border-radius:var(--radius);padding:20px;text-align:center;margin:16px 0}
.tg-code{font-size:32px;font-weight:900;letter-spacing:4px;color:var(--coral);font-family:monospace;user-select:all}
.tg-code-label{font-size:12px;color:var(--text2);margin-bottom:8px}
.tg-instruction{margin:16px 0;padding:12px;border-radius:var(--radius-sm);background:var(--bg2);font-size:13px;line-height:1.6}
.tg-instruction code{background:var(--coral-bg);color:var(--coral);padding:2px 6px;border-radius:4px;font-size:13px}
.ai-input-area{margin:16px 0}
.ai-input-area textarea{width:100%;min-height:120px;padding:12px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font);resize:vertical;background:var(--bg);color:var(--text)}
.bulk-results{margin-top:16px}
.bulk-result-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;margin-bottom:6px;font-size:13px}
.bulk-result-row.success{background:#e8f5e9;color:#2e7d32}
.bulk-result-row.error{background:#fce4ec;color:#c62828}
.bulk-result-icon{font-size:18px;flex-shrink:0}
.bulk-stats{display:flex;gap:16px;margin:12px 0;flex-wrap:wrap}
.bulk-stat{padding:12px 16px;border-radius:var(--radius-sm);background:var(--bg2);font-size:13px;text-align:center;min-width:80px}
.bulk-stat .stat-num{font-size:28px;font-weight:900}
.bulk-stat.success .stat-num{color:#2e7d32}
.bulk-stat.error .stat-num{color:#c62828}
.bulk-stat.pending .stat-num{color:#f57c00}

/* ===== ADMIN DASHBOARD ===== */
.admin-header{display:flex;align-items:center;padding:12px 16px;gap:12px;background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.admin-header h2{font-size:17px;font-weight:700;margin:0;flex:1}
.admin-tabs{display:flex;gap:2px;padding:8px 12px;background:var(--bg2);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-tab{flex-shrink:0;padding:8px 14px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;border:none;background:transparent;color:var(--text2)}
.admin-tab.active{background:var(--coral);color:#fff}
.admin-tab:hover:not(.active){background:var(--bg)}
.admin-panel{display:none;padding:16px}
.admin-panel.active{display:block}
/* Stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
@media(min-width:768px){.stat-grid{grid-template-columns:repeat(4,1fr)}}
.stat-card{padding:14px;border-radius:12px;background:var(--bg2);border:1px solid var(--border)}
.stat-card .stat-icon{font-size:24px;margin-bottom:4px}
.stat-card .stat-val{font-size:26px;font-weight:900;margin:4px 0}
.stat-card .stat-label{font-size:12px;color:var(--text2)}
.stat-card.trend-up .stat-val{color:#2e7d32}
.stat-card.trend-warn .stat-val{color:#f57c00}
/* Quick actions */
.quick-actions{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.quick-actions .btn{padding:10px 18px;font-size:13px;font-weight:600;border-radius:10px;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{opacity:.9}
.btn-outline{background:transparent;border:2px solid var(--border);color:var(--text)}
.btn-outline:hover{background:var(--bg2)}
.btn-ghost{background:transparent;border:none;color:var(--text2);padding:8px 12px;font-size:12px;cursor:pointer}
.btn-ghost:hover{color:var(--text)}
/* Bar chart */
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:140px;padding:8px 0}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar-fill{width:100%;background:var(--coral);border-radius:4px 4px 0 0;min-height:4px;transition:height .4s}
.bar-label{font-size:10px;color:var(--text2)}
/* Activity feed */
.activity-feed{margin-top:12px}
.activity-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.activity-item:last-child{border-bottom:none}
.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--coral);margin-top:5px;flex-shrink:0}
.activity-dot.old{background:var(--text3)}
.activity-time{font-size:11px;color:var(--text3);white-space:nowrap}
/* Vacancy table */
.vac-table{width:100%;border-collapse:collapse;font-size:13px}
.vac-table th{text-align:left;padding:10px 8px;border-bottom:2px solid var(--border);font-weight:700;font-size:12px;color:var(--text2);white-space:nowrap}
.vac-table td{padding:10px 8px;border-bottom:1px solid var(--border);vertical-align:middle}
.vac-table tr:hover td{background:var(--bg2)}
.vac-table .status-badge{padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap}
.status-active{background:#e8f5e9;color:#2e7d32}
.status-paused{background:#fff3e0;color:#f57c00}
.status-archived{background:#f5f5f5;color:#9e9e9e}
.vac-actions{display:flex;gap:4px}
/* Kanban */
.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch}
.kanban-col{flex:0 0 260px;background:var(--bg2);border-radius:12px;padding:12px;min-height:200px}
@media(min-width:768px){.kanban-col{flex:0 0 280px}}
.kanban-col h4{font-size:14px;font-weight:700;margin:0 0 10px;display:flex;align-items:center;gap:6px}
.kanban-count{background:var(--coral);color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}
.kanban-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .2s;font-size:13px}
.kanban-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.kanban-card .kc-name{font-weight:600;margin-bottom:2px}
.kanban-card .kc-pos{color:var(--text2);font-size:12px}
.kanban-card .kc-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px;color:var(--text3)}
/* AI tools */
.ai-tool-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px}
.ai-tool-card h4{font-size:15px;font-weight:700;margin:0 0 4px;display:flex;align-items:center;gap:6px}
.ai-tool-card p{font-size:12px;color:var(--text2);margin:0 0 12px}
.ai-tool-card textarea{width:100%;min-height:80px;padding:10px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;resize:vertical;font-family:inherit}
.ai-result{margin-top:10px;padding:12px;border-radius:8px;background:var(--bg);border:1px solid var(--border);font-size:13px;line-height:1.6;display:none}
/* AI Chat */
.ai-chat{display:flex;flex-direction:column;height:300px;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.ai-chat-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.ai-chat-msg{padding:10px 14px;border-radius:16px;font-size:13px;max-width:85%;line-height:1.5}
.ai-chat-msg.user{align-self:flex-end;background:var(--coral);color:#fff;border-bottom-right-radius:4px}
.ai-chat-msg.bot{align-self:flex-start;background:var(--bg2);color:var(--text);border-bottom-left-radius:4px}
.ai-chat-input{display:flex;gap:8px;padding:10px;border-top:1px solid var(--border);background:var(--bg)}
.ai-chat-input input{flex:1;padding:10px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:13px;outline:none}
.ai-chat-input input:focus{border-color:var(--coral)}
/* Filter builder */
.filter-form{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:16px}
.filter-form h4{font-size:14px;font-weight:700;margin:0 0 12px}
.filter-form .ff-row{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.filter-form input,.filter-form select{padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;outline:none;flex:1;min-width:120px}
.filter-form input:focus,.filter-form select:focus{border-color:var(--coral)}
.filter-list{margin-top:8px}
.filter-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-radius:8px;background:var(--bg);border:1px solid var(--border);margin-bottom:6px;font-size:13px;gap:8px}
.filter-item .fi-name{font-weight:600;flex:1}
.filter-item .fi-meta{font-size:11px;color:var(--text3);display:flex;gap:8px}
.filter-item .fi-del{background:none;border:none;color:#c62828;cursor:pointer;font-size:16px;padding:2px 6px}
.filter-preview{padding:12px;border-radius:8px;background:var(--bg);border:1px dashed var(--border);margin-top:8px;font-size:12px;color:var(--text2)}
.filter-preview strong{color:var(--text)}
/* Mass actions bar */
.mass-bar{display:none;align-items:center;gap:8px;padding:10px 16px;background:var(--coral);color:#fff;border-radius:10px;margin-bottom:12px;font-size:13px;font-weight:600}
.mass-bar.active{display:flex}
.mass-bar .btn{background:rgba(255,255,255,.2);color:#fff;border:none;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer}
/* Notifications */
.notif-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#333;color:#fff;padding:12px 24px;border-radius:24px;font-size:13px;font-weight:600;z-index:1000;animation:toastIn .3s ease;white-space:nowrap}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
/* Modal overlay */
/* .modal-overlay defined at line 428 — z-index:2000, bottom-sheet alignment */
/* .modal-overlay.center{align-items:center;padding:20px} — use for centered modals */
.modal-box{background:var(--bg);border-radius:16px;padding:24px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto}
.modal-box h3{font-size:18px;margin:0 0 12px}
.modal-box .btn-row{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}


/* Desktop: hide bottom nav */
@media(min-width:1024px){
  .bottom-nav{display:none}
  .burger-btn{display:none}
  .header-nav{display:flex}
  .btn-login{display:flex}
  /* Max-width for forms */
  .form-container,.register-form,.login-box{max-width:520px;margin:0 auto}
  /* Max-width for cards */
  .v1-card{max-width:600px;margin:0 auto 12px}
  .v5-card{max-width:800px;margin:0 auto 16px}
  /* Kanban smaller columns */
  .kanban-col{flex:0 0 240px}
  /* Vacancy table */
  .vac-table{font-size:13px}
  /* Main container wider */
  .container{max-width:1200px}
}



/* ===== V5 SMART STREAM HEADER ===== */
/* ===== RESET & BASE ===== */
  *, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
  html { font-size: 16px; }
  body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: #1a1a2e;
    color: #fff;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }

  /* ===== SCROLLBAR ===== */
  ::-webkit-scrollbar { width: 4px; }
  ::-webkit-scrollbar-track { background: transparent; }
  ::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }

  /* ===== TOP HEADER (56px) ===== */
  .top-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    height: 56px;
    background: rgba(26, 26, 46, 0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .top-header-inner {
    max-width: 1280px;
    margin: 0 auto;
    height: 100%;
    display: flex;
    align-items: center;
    padding: 0 16px;
    gap: 12px;
  }

  /* ===== LOGO ===== */
  .logo {
    display: flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    flex-shrink: 0;
  }
  .logo-icon {
    width: 32px; height: 32px;
    background: #F26A4A;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 16px;
    color: #fff;
  }
  .logo-text {
    font-weight: 700;
    font-size: 18px;
    color: #fff;
    letter-spacing: -0.3px;
  }
  .logo-text span { color: #F26A4A; }

  /* ===== SEARCH BAR ===== */
  .search-wrap {
    flex: 1;
    max-width: 480px;
    position: relative;
  }
  .search-wrap input {
    width: 100%;
    height: 40px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 0 16px 0 40px;
    color: #fff;
    font-size: 14px;
    outline: none;
    transition: border-color 0.2s, background 0.2s;
  }
  .search-wrap input::placeholder { color: rgba(255,255,255,0.4); }
  .search-wrap input:focus {
    border-color: rgba(242, 106, 74, 0.5);
    background: rgba(255,255,255,0.12);
  }
  .search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
    color: rgba(255,255,255,0.4);
    pointer-events: none;
  }

  /* ===== HEADER ACTIONS (icons right) ===== */
  .header-actions {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
  }
  .header-action-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #fff;
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s, transform 0.15s;
    position: relative;
  }
  .header-action-btn:hover { background: rgba(255,255,255,0.14); }
  .header-action-btn:active { transform: scale(0.92); }
  .badge-dot {
    position: absolute;
    top: 4px; right: 4px;
    width: 8px; height: 8px;
    background: #F26A4A;
    border-radius: 50%;
    border: 2px solid #1a1a2e;
  }
  .avatar-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 2px solid rgba(242,106,74,0.5);
    background: rgba(242,106,74,0.15);
    font-size: 16px;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: border-color 0.2s;
  }
  .avatar-btn:hover { border-color: #F26A4A; }

  /* ===== TAB PILLS (desktop & mobile shared) ===== */
  .tab-pills {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
  }
  .tab-pill {
    padding: 6px 14px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.05);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: rgba(255,255,255,0.65);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
    text-decoration: none;
  }
  .tab-pill:hover {
    background: rgba(255,255,255,0.1);
    color: #fff;
  }
  .tab-pill.active {
    background: rgba(242,106,74,0.2);
    border-color: rgba(242,106,74,0.4);
    color: #F26A4A;
  }
  .tab-pill.register {
    background: rgba(242,106,74,0.15);
    border-color: rgba(242,106,74,0.3);
    color: #F26A4A;
  }
  .tab-pill.register:hover {
    background: rgba(242,106,74,0.25);
  }

  /* ===== DESKTOP: tabs next to search ===== */
  .desktop-tabs { display: flex; }
  .mobile-tabs { display: none; }

  /* ===== MOBILE BOTTOM NAV ===== */
  .bottom-nav {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 1000;
    height: 64px;
    background: rgba(26, 26, 46, 0.9);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border-top: 1px solid rgba(255,255,255,0.06);
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 0 8px;
    display: none; /* shown on mobile */
  }
  .bottom-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.45);
    font-size: 10px;
    font-weight: 500;
    cursor: pointer;
    padding: 6px 10px;
    border-radius: 12px;
    transition: all 0.2s;
    text-decoration: none;
    min-width: 56px;
    position: relative;
  }
  .bottom-nav-item .nav-icon {
    font-size: 20px;
    line-height: 1;
  }
  .bottom-nav-item .nav-label { line-height: 1; }
  .bottom-nav-item:hover { color: rgba(255,255,255,0.7); }
  .bottom-nav-item.active {
    color: #F26A4A;
  }
  .bottom-nav-item.active::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 20px; height: 3px;
    background: #F26A4A;
    border-radius: 0 0 3px 3px;
  }
  .bottom-nav-badge {
    position: absolute;
    top: 2px; right: 10px;
    min-width: 16px; height: 16px;
    background: #F26A4A;
    border-radius: 8px;
    font-size: 9px;
    font-weight: 700;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
  }

  /* ===== DEMO CONTENT ===== */
  .demo-content {
    flex: 1;
    padding: 80px 16px 88px;
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
  }
  .demo-content h1 {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 8px;
    background: linear-gradient(135deg, #fff 40%, rgba(242,106,74,0.6));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
  .demo-content p {
    color: rgba(255,255,255,0.55);
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 24px;
  }
  .demo-card {
    background: rgba(255,255,255,0.05);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 16px;
    padding: 24px;
    margin-bottom: 16px;
  }
  .demo-card h3 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 6px;
    color: #fff;
  }
  .demo-card p {
    font-size: 13px;
    color: rgba(255,255,255,0.5);
    margin-bottom: 0;
  }
  .demo-tag {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 12px;
    background: rgba(242,106,74,0.15);
    color: #F26A4A;
    font-size: 11px;
    font-weight: 600;
    margin-top: 8px;
  }
  .demo-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  @media (max-width: 500px) {
    .demo-grid { grid-template-columns: 1fr; }
  }

  /* ===== RESPONSIVE ===== */
  @media (min-width: 820px) {
    /* Desktop: show tabs in header, hide bottom nav */
    .desktop-tabs { display: flex; }
    .mobile-tabs { display: none; }
    .bottom-nav { display: none; }
    .top-header-inner { gap: 16px; }
  }

  @media (max-width: 819px) {
    /* Mobile: hide desktop tabs, show mobile tabs below header, show bottom nav */
    .desktop-tabs { display: none; }
    .mobile-tabs {
      display: flex;
      position: relative;
      z-index: auto;
      padding: 8px 12px;
      gap: 6px;
      overflow-x: auto;
      background: rgba(26, 26, 46, 0.95);
      border-bottom: 1px solid rgba(255,255,255,0.04);
      -webkit-overflow-scrolling: touch;
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border-bottom: 1px solid rgba(255,255,255,0.04);
      scrollbar-width: none;
    }
    .mobile-tabs::-webkit-scrollbar { display: none; }
    .mobile-tabs .tab-pill { flex-shrink: 0; }
    .bottom-nav { display: flex; }
    .top-header-inner { gap: 8px; }
    .search-wrap { max-width: none; }
    body { padding-top: 56px; } /* header only — mobile-tabs now in flow */

    /* Hide avatar on mobile header, only show bell + burger */
    .avatar-btn { display: none; }
  }

  @media (max-width: 420px) {
    .logo-text { display: none; }
    .top-header-inner { padding: 0 10px; gap: 6px; }
    .header-action-btn { width: 32px; height: 32px; font-size: 16px; }
  }

  /* ===== SAFE AREA (notched phones) ===== */
  @supports (padding-bottom: env(safe-area-inset-bottom)) {
    .bottom-nav {
      padding-bottom: env(safe-area-inset-bottom);
      height: calc(64px + env(safe-area-inset-bottom));
    }
    .demo-content { padding-bottom: calc(88px + env(safe-area-inset-bottom)); }
  }

/* ===== V5 ADS: BRANDLIFT, BOOSTER, GLASS CARD ===== */
/* ===== RESET + ROOTS ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --coral:#F26A4A;
  --coral-dark:#d45232;
  --coral-light:#f58a6f;
  --coral-ghost:rgba(242,106,74,0.08);
  --coral-bg:rgba(242,106,74,0.12);
  --coral-glow:rgba(242,106,74,0.25);
  --bg:#f4f5f7;
  --card:#ffffff;
  --text:#1a1a2e;
  --text2:#5a626f;
  --text3:#8a9099;
  --border:#e8eaed;
  --shadow-soft:0 2px 8px rgba(0,0,0,0.06);
  --shadow-hard:0 8px 0 rgba(0,0,0,0.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.12);
  --radius:16px;
  --radius-sm:10px;
  --radius-xs:6px;
  --font:'Inter',-apple-system,sans-serif;
  --transition:0.3s cubic-bezier(.4,0,.2,1);
  --brandlift-h:200px;
}
html{height:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  min-height:100%;
  padding:0;
}
/* ===== LAYOUT ===== */
.wrap{max-width:1140px;margin:0 auto;padding:40px 20px 80px}
.section{margin-bottom:64px}
.section:last-child{margin-bottom:0}
.section-title{
  font-size:28px;font-weight:800;
  margin-bottom:8px;
  color:var(--text);
  letter-spacing:-0.5px;
}
.section-sub{
  font-size:15px;color:var(--text2);
  margin-bottom:28px;
  font-weight:400;
}
.section-label{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 14px;border-radius:20px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;
  background:var(--coral-ghost);color:var(--coral);
  margin-bottom:12px;
}
/* ===== GLASSMORPHISM UTILITY ===== */
.glass{
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(255,255,255,0.7);
  box-shadow:var(--shadow-hard);
}
.glass-dark{
  background:rgba(255,255,255,0.38);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid rgba(255,255,255,0.5);
  box-shadow:var(--shadow-hard);
}
/* ====================================
   Praca.ua Ad System v6
   Уніфікована система рекламних блоків
   3 tiers: ad-hero / ad-featured / ad-native
   ==================================== */

/* ---- Уніфікований close button ---- */
.ad-close{position:absolute;top:8px;right:8px;z-index:5;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;background:rgba(0,0,0,.05);color:var(--text3);border:none;cursor:pointer;transition:all .2s;opacity:.6}
.ad-close:hover,.ad-close:focus-visible{background:var(--coral);color:#fff;opacity:1}
.ad-close:focus-visible{outline:3px solid var(--coral);outline-offset:2px}
.ad-close::before{content:'';position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%}

/* ===== AD HERO (ex-Brandlift) ===== */
.ad-hero{position:relative;width:100%;border-radius:var(--radius);overflow:hidden;cursor:pointer;margin-bottom:16px;height:200px;transition:transform var(--transition),box-shadow var(--transition)}
.ad-hero:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(242,106,74,.2)}
.ad-hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,var(--coral) 0%,#f58a6f 40%,#ffb088 100%)}
.ad-hero-bg::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.4}
.ad-hero-glass{position:absolute;inset:0;z-index:1;background:rgba(255,255,255,.12);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border-radius:var(--radius)}
.ad-hero-content{position:relative;z-index:2;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 48px;gap:32px}
.ad-hero-left{display:flex;flex-direction:column;gap:8px;max-width:55%}
.ad-hero-label{display:inline-flex;align-items:center;gap:5px;align-self:flex-start;padding:4px 14px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;background:rgba(255,255,255,.2);color:#fff;backdrop-filter:blur(4px)}
.ad-hero-title{font-size:32px;font-weight:900;color:#fff;line-height:1.15;letter-spacing:-.5px}
.ad-hero-title span{display:inline-block;background:rgba(255,255,255,.18);padding:0 8px;border-radius:4px}
.ad-hero-desc{font-size:15px;color:rgba(255,255,255,.85);font-weight:400;line-height:1.5}
.ad-hero-cta{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:12px;font-size:15px;font-weight:700;color:var(--coral);background:#fff;border:none;cursor:pointer;font-family:var(--font);transition:all var(--transition);box-shadow:0 4px 16px rgba(0,0,0,.12);flex-shrink:0}
.ad-hero-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.18)}
.ad-hero-cta .arrow{transition:transform var(--transition);display:inline-block}
.ad-hero-cta:hover .arrow{transform:translateX(4px)}
.ad-hero-stats{display:flex;align-items:center;gap:20px;flex-shrink:0}
.ad-hero-stat{text-align:center;color:#fff}
.ad-hero-stat-num{font-size:38px;font-weight:900;line-height:1;letter-spacing:-1px}
.ad-hero-stat-label{font-size:11px;font-weight:500;color:rgba(255,255,255,.7);margin-top:2px}
.ad-hero-stat-divider{width:1px;height:48px;background:rgba(255,255,255,.25)}

@media(max-width:480px){
  .ad-hero{height:auto;min-height:80px}
  .ad-hero-glass{display:none}
  .ad-hero-content{flex-direction:column;align-items:flex-start;padding:12px 14px 10px;gap:6px}
  .ad-hero-left{max-width:100%}
  .ad-hero-title{font-size:18px;line-height:1.2}
  .ad-hero-desc{display:none}
  .ad-hero-cta{padding:10px 20px;font-size:13px;align-self:center;white-space:nowrap}
  .ad-hero-stats{display:none}
  .ad-hero .ad-close{top:4px;right:4px}
}

@media(max-width:768px){
  .ad-hero{height:180px}
  .ad-hero-content{padding:0 24px;flex-direction:column;justify-content:center;align-items:flex-start;gap:12px}
  .ad-hero-left{max-width:100%}
  .ad-hero-title{font-size:22px}
  .ad-hero-desc{font-size:13px}
  .ad-hero-cta{padding:10px 24px;font-size:13px}
  .ad-hero-stats{display:none}
}

/* ===== AD NATIVE (ex-glass-card — окремий блок МІЖ v1-card) ===== */
/* ===== AD NATIVE v2 (Detail-Lite — 88% консенсус) ===== */
.ad-native{position:relative;display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--radius-sm);background:var(--ad-bg);border-left:3px solid var(--coral);border-top:1px solid var(--border);border-right:1px solid var(--border);border-bottom:1px solid var(--border);box-shadow:var(--shadow);margin:10px 0;cursor:pointer;transition:all var(--transition)}
.ad-native:hover{box-shadow:var(--shadow-lg);border-left-color:var(--coral-dark)}
.ad-native-icon{width:44px;height:44px;flex-shrink:0;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--coral-bg);border:1px solid rgba(242,106,74,.2)}
.ad-native-body{flex:1;min-width:0}
.ad-native-title{font-size:17px;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ad-native-label{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:6px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;background:var(--coral-bg);color:var(--coral);border:1px solid rgba(242,106,74,.2)}
.ad-native-meta{font-size:12px;color:var(--text2);display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.ad-native-salary{font-size:16px;font-weight:800;color:var(--coral)}
.ad-native-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:20px;font-size:10px;font-weight:600;background:var(--coral-bg);color:var(--coral)}
.ad-native-cta{flex-shrink:0;padding:8px 18px;border-radius:8px;font-size:13px;font-weight:700;background:var(--coral);color:#fff;border:none;cursor:pointer;font-family:var(--font);transition:all var(--transition);white-space:nowrap;box-shadow:0 3px 10px rgba(242,106,74,.25)}
.ad-native-cta:hover{background:var(--coral-dark);transform:translateY(-1px)}

@media(max-width:480px){
  .ad-native{flex-wrap:wrap;gap:10px;padding:10px 12px}
  .ad-native-cta{width:100%;text-align:center}
  .ad-native-icon{width:36px;height:36px;font-size:16px}
  .ad-native-title{font-size:15px}
  .ad-native-salary{font-size:14px}
}

/* Touch-оптимізація */
@media(hover:none) and (pointer:coarse){
  .ad-native:hover,.ad-featured:hover,.ad-hero:hover{transform:none}
}

/* ===== AD FEATURED (ex-Booster + ex-sp-card) ===== */
.ad-featured{position:relative;display:flex;flex-direction:column;padding:20px 24px;border-radius:var(--radius);background:var(--card);border:1px solid var(--coral);box-shadow:var(--shadow);margin-bottom:10px;cursor:pointer;transition:all var(--transition)}
.ad-featured:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.ad-featured-badge{position:absolute;top:-1px;right:16px;padding:4px 14px;border-radius:0 0 10px 10px;background:var(--coral);color:#fff;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;z-index:2}
.ad-featured-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;margin-bottom:8px;flex-shrink:0;border:2px solid rgba(242,106,74,.3);background:var(--ad-bg)}
.ad-featured-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.ad-featured-name{font-size:16px;font-weight:800;letter-spacing:-.3px;color:var(--coral);margin-bottom:2px}
.ad-featured-company{font-size:12px;font-weight:500;color:var(--text2);margin-bottom:6px}
.ad-featured-list{list-style:none;display:flex;flex-direction:column;gap:4px;margin-bottom:0;padding:0}
.ad-featured-list li{display:flex;align-items:flex-start;gap:6px;font-size:12px;font-weight:500;color:var(--text2);line-height:1.4}
.ad-featured-list .check{flex-shrink:0;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;background:var(--coral);color:#fff;margin-top:1px}
.ad-featured-cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:700;border:2px solid transparent;cursor:pointer;font-family:var(--font);transition:all var(--transition);margin-top:8px;background:var(--coral);color:#fff;box-shadow:0 4px 14px rgba(242,106,74,.3)}
.ad-featured-cta:hover{background:var(--coral-dark);transform:translateY(-1px)}
.ad-featured-cta.quick{box-shadow:0 4px 14px rgba(242,106,74,.3)}
.ad-featured::before{content:'';position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;border-radius:var(--radius);border:1px solid transparent;animation:featuredPulse 3s ease-in-out infinite;pointer-events:none}
@keyframes featuredPulse{0%,100%{border-color:var(--coral)}50%{border-color:rgba(242,106,74,.3)}}

@media(max-width:480px){
  .ad-featured{padding:14px 16px}
  .ad-featured-badge{font-size:9px;padding:3px 10px;right:10px}
  .ad-featured-name{font-size:14px}
  .ad-featured-icon{width:28px;height:28px;font-size:11px}
}

/* ====================================
   DEMO CONTAINER — hard shadow card
   ==================================== */
.demo-card{
  background:var(--card);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:var(--shadow-hard);
  border:1px solid var(--border);
}
.demo-card-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;
  padding-bottom:16px;
  border-bottom:1px solid var(--border);
}
.demo-card-title{
  font-size:20px;font-weight:800;
  display:flex;align-items:center;gap:8px;
}
.demo-card-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 12px;border-radius:16px;
  font-size:10px;font-weight:700;text-transform:uppercase;
  background:var(--coral-ghost);color:var(--coral);
}
.demo-divider{
  height:1px;
  background:var(--border);
  margin:24px 0;
}

/* ===== MISC ===== */
.flex{display:flex}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.gap-8{gap:8px}
.gap-12{gap:12px}
.gap-16{gap:16px}
.mb-8{margin-bottom:8px}
.mb-16{margin-bottom:16px}
.mb-24{margin-bottom:24px}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.text-sm{font-size:13px}
.text-xs{font-size:11px}
.text-muted{color:var(--text2)}
.text-coral{color:var(--coral)}
.fw-7{font-weight:700}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .wrap{padding:24px 16px 60px}
  .section{margin-bottom:40px}
  .section-title{font-size:22px}
  .demo-card{padding:20px}
  .demo-card-header{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ===== FOOTER ===== */
.footer-note{
  text-align:center;
  padding:32px 0 0;
  border-top:1px solid var(--border);
  margin-top:48px;
  font-size:12px;
  color:var(--text3);
}

/* ===== V5 OVERRIDES ===== */
.top-header { position:fixed;top:0;left:0;right:0;z-index:1000;height:56px;background:rgba(255,255,255,0.72);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);border-bottom:1px solid rgba(229,231,235,0.3);transition:background var(--transition),border-color var(--transition); }
.dark .top-header { background:rgba(15,15,26,0.78);border-bottom-color:rgba(42,42,62,0.3); }
.top-header-inner { max-width:1100px;margin:0 auto;height:100%;display:flex;align-items:center;padding:0 16px;gap:12px; }
.search-wrap { flex:1;max-width:480px;position:relative; }
.search-wrap input { width:100%;height:38px;border-radius:10px;border:2px solid var(--border);background:var(--bg2);padding:0 16px 0 40px;color:var(--text);font-size:14px;outline:none;transition:border-color var(--transition),background var(--transition); }
.search-wrap input:focus { border-color:var(--coral);background:var(--bg);box-shadow:0 0 0 3px var(--coral-bg); }
.search-wrap input::placeholder { color:var(--text3); }
.search-icon { position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--text3);pointer-events:none; }
.header-action-btn { width:36px;height:36px;border-radius:50%;border:none;background:var(--bg2);color:var(--text2);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.2s,transform 0.15s;position:relative; }
.header-action-btn:hover { background:var(--coral-bg);color:var(--coral); }
.badge-dot { position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--coral);border-radius:50%;border:2px solid var(--bg); }
.dark .badge-dot { border-color:var(--card); }
.avatar-btn { width:36px;height:36px;border-radius:50%;border:2px solid var(--coral);background:var(--coral-bg);font-size:16px;color:var(--coral);cursor:pointer;display:flex;align-items:center;justify-content:center; }
.tab-pills { display:flex;gap:4px;flex-shrink:0; }
.tab-pill { padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg2);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all 0.2s;text-decoration:none; }
.tab-pill:hover { background:var(--coral-bg);color:var(--coral); }
.tab-pill.active { background:var(--coral-bg);border-color:var(--coral);color:var(--coral); }
.tab-pill.register { background:rgba(242,106,74,0.12);border-color:rgba(242,106,74,0.3);color:var(--coral); }
.desktop-tabs { display:flex; }
.mobile-tabs { display:none; }
.logo-text { font-weight:700;font-size:18px;color:var(--text);letter-spacing:-0.3px; }
.logo-text span { color:var(--coral); }

.bottom-nav { position:fixed;bottom:0;left:0;right:0;z-index:1000;height:64px;background:rgba(255,255,255,0.75);backdrop-filter:blur(20px)saturate(180%);-webkit-backdrop-filter:blur(20px)saturate(180%);border-top:1px solid rgba(229,231,235,0.3);display:none;align-items:center;justify-content:space-around;padding:0 8px;transition:background var(--transition),border-color var(--transition); }
.dark .bottom-nav { background:rgba(15,15,26,0.8);border-top-color:rgba(42,42,62,0.3); }
.bottom-nav-item { display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text3);font-size:10px;font-weight:500;cursor:pointer;padding:6px 10px;border-radius:12px;transition:all 0.2s;text-decoration:none;min-width:56px;position:relative; }
.bottom-nav-item .nav-icon { font-size:20px;line-height:1; }
.bottom-nav-item .nav-label { line-height:1; }
.bottom-nav-item:hover { color:var(--text2); }
.bottom-nav-item.active { color:var(--coral); }
.bottom-nav-item.active::before { content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:20px;height:3px;background:var(--coral);border-radius:0 0 3px 3px; }
.bottom-nav-badge { position:absolute;top:2px;right:10px;min-width:16px;height:16px;background:var(--coral);border-radius:8px;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;padding:0 4px; }
/* Floating Create Button */
.fab-create{position:fixed;bottom:calc(72px + var(--safe-bottom, 0px));right:20px;z-index:999;width:52px;height:52px;border-radius:50%;background:var(--coral);color:#fff;font-size:22px;display:none;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(242,106,74,0.4);transition:transform 0.2s,box-shadow 0.2s;text-decoration:none;border:none;cursor:pointer}
.fab-create:active{transform:scale(0.92);box-shadow:0 2px 8px rgba(242,106,74,0.3)}
@media(max-width:819px){.fab-create{display:flex}}
.mobile-tabs { display:none;position:relative;padding:8px 12px;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;background:rgba(26,26,46,0.95);border-bottom:1px solid rgba(255,255,255,0.04);scrollbar-width:none; }
.dark .mobile-tabs { background:rgba(15,15,26,0.78);border-bottom-color:rgba(42,42,62,0.3); }
.mobile-tabs::-webkit-scrollbar { display:none; }
.mobile-tabs .tab-pill { flex-shrink:0; }

@media(min-width:820px){ .desktop-tabs{display:flex} .mobile-tabs{display:none} .bottom-nav{display:none} .top-header-inner{gap:16px} }
@media(max-width:819px){ .desktop-tabs{display:none} .mobile-tabs{display:flex} .bottom-nav{display:flex} .top-header-inner{gap:8px} .search-wrap{max-width:none} .avatar-btn{display:none} }
@media(max-width:420px){ .logo-text{display:none} .top-header-inner{padding:0 10px;gap:6px} .header-action-btn{width:32px;height:32px;font-size:16px} }
@media(min-width:1024px){ .bottom-nav{display:none!important} }
@media(max-width:1023px){ .bottom-nav{display:flex!important} }
@supports(padding-bottom:env(safe-area-inset-bottom)){ .bottom-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(64px + env(safe-area-inset-bottom))} }

.praca-nav-item { display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 10px;border-radius:12px;color:var(--text3);font-size:10px;font-weight:500;transition:all var(--transition);position:relative;touch-action:manipulation;cursor:pointer;-webkit-tap-highlight-color:transparent;background:none;border:none;font-family:var(--font); }
.praca-nav-item svg { width:24px;height:24px;transition:all var(--transition); }
.praca-nav-item.active { color:var(--coral); }
.praca-nav-item.active svg { color:var(--coral); }
.praca-nav-badge { position:absolute;top:0;right:2px;background:var(--coral);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px; }

/* ===== WIZARD CREATE VACANCY v5 ===== */
.cv-hero{text-align:center;padding:24px 0 0}
.cv-hero-icon{font-size:2.2rem;margin-bottom:8px}
.cv-hero h2{font-size:1.2rem;font-weight:800;margin-bottom:4px;color:var(--text)}
.cv-hero .cv-sub{font-size:.8rem;color:var(--text2);margin-bottom:10px}
.cv-social{display:inline-flex;align-items:center;gap:8px;background:var(--card);padding:6px 14px;border-radius:20px;font-size:.7rem;color:var(--text2);border:1px solid var(--border);margin-bottom:10px}
.cv-social .cv-avatars{display:flex;margin-right:2px}
.cv-social .cv-avatars span{width:20px;height:20px;border-radius:50%;background:var(--coral);color:#fff;font-size:.55rem;display:flex;align-items:center;justify-content:center;margin-left:-5px;border:2px solid var(--card)}
.cv-social .cv-avatars span:first-child{margin-left:0}

.cv-templates{display:flex;gap:6px;overflow-x:auto;padding:4px 0 14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.cv-templates::-webkit-scrollbar{display:none}
.cv-tpl{flex-shrink:0;padding:8px 14px;border:2px solid var(--border);border-radius:20px;font-size:.75rem;font-weight:600;cursor:pointer;background:var(--card);color:var(--text2);transition:all .15s;white-space:nowrap;font-family:var(--font);user-select:none}
.cv-tpl:hover,.cv-tpl.active{border-color:var(--coral);color:var(--coral);background:var(--coral-bg)}
.cv-tpl.active{background:var(--coral);color:#fff;border-color:var(--coral)}

.cv-wizard{display:none;padding-top:4px}
.cv-wizard.visible{display:block}
.cv-steps{display:flex;gap:5px;margin-bottom:16px}
.cv-step-dot{flex:1;height:4px;background:var(--border);border-radius:2px;transition:background .3s}
.cv-step-dot.done{background:var(--coral)}
.cv-step-dot.active{background:var(--coral)}

.cv-panel{display:none;animation:cvFade .3s ease}
.cv-panel.active{display:block}
@keyframes cvFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

.cv-ai-fork{display:none;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0}
.cv-ai-fork.visible{display:grid}
.cv-fork{padding:14px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;transition:all .2s;position:relative;background:var(--card)}
.cv-fork:hover{border-color:var(--coral)}
.cv-fork.selected{border-color:var(--coral);background:var(--coral-bg)}
.cv-fork .cv-fork-icon{font-size:1.5rem;margin-bottom:4px}
.cv-fork .cv-fork-name{font-weight:700;font-size:.8rem;color:var(--text)}
.cv-fork .cv-fork-hint{font-size:.65rem;color:var(--text3);margin-top:2px}
.cv-fork-badge{position:absolute;top:4px;right:4px;font-size:.55rem;font-weight:700;padding:2px 7px;border-radius:8px;background:var(--coral);color:#fff}

.cv-editor-bar{display:flex;gap:3px;margin-bottom:8px;flex-wrap:wrap}
.cv-editor-bar button{width:30px;height:30px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .15s;color:var(--text2);font-family:var(--font)}
.cv-editor-bar button:hover{background:var(--coral-bg);border-color:var(--coral);color:var(--coral)}
.cv-char-count{text-align:right;font-size:.7rem;color:var(--text3);margin-top:2px}

.cv-pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:480px){.cv-pkg-grid{grid-template-columns:1fr}}
.cv-pkg{border:2px solid var(--border);border-radius:var(--radius);padding:14px;cursor:pointer;transition:all .2s;text-align:center;position:relative;background:var(--card)}
.cv-pkg:hover{border-color:var(--coral)}
.cv-pkg.selected{border-color:var(--coral);background:var(--coral-bg)}
.cv-pkg .cv-pkg-name{font-weight:800;font-size:.85rem;margin-bottom:3px;color:var(--text)}
.cv-pkg .cv-pkg-price{font-size:1.1rem;font-weight:800;color:var(--coral);margin-bottom:4px}
.cv-pkg .cv-pkg-feats{font-size:.65rem;color:var(--text2);line-height:1.5}
.cv-pkg-badge{position:absolute;top:-7px;right:10px;padding:2px 8px;border-radius:10px;font-size:.55rem;font-weight:700;background:var(--coral);color:#fff}
.cv-pkg-check{width:18px;height:18px;border-radius:50%;background:var(--coral);color:#fff;font-size:.55rem;display:none;align-items:center;justify-content:center;position:absolute;top:8px;right:8px}
.cv-pkg.selected .cv-pkg-check{display:flex}

.cv-forecast{text-align:center;display:flex;justify-content:center;gap:20px;font-size:.8rem;color:var(--text)}
.cv-forecast strong{font-size:1.05rem;color:var(--text)}
.cv-forecast span{font-size:.65rem;color:var(--text3);display:block}

.cv-success{display:none;text-align:center;padding:40px 20px}
.cv-success.show{display:block;animation:bounceIn .4s ease}
.cv-success .cv-success-icon{font-size:3.5rem;margin-bottom:10px;animation:bounce .6s ease}
.cv-success h2{font-size:1.2rem;margin-bottom:4px}
.cv-success p{font-size:.82rem;color:var(--text2);max-width:320px;margin:0 auto 16px}
@keyframes bounce{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}

/* ===== RESUME WIZARD v5 (cr-*) ===== */
.cr-hero{text-align:center;padding:12px 0 0}
.cr-hero-icon{font-size:2rem;margin-bottom:6px}
.cr-hero h2{font-size:1.1rem;font-weight:800;margin-bottom:3px}
.cr-score-bar{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin-bottom:14px}
.cr-score-ring{width:48px;height:48px;border-radius:50%;border:4px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex-shrink:0;transition:border-color .5s,color .5s}
.cr-score-ring.lv1{border-color:#9CA3AF;color:#9CA3AF}
.cr-score-ring.lv2{border-color:#3B82F6;color:#3B82F6}
.cr-score-ring.lv3{border-color:#F97316;color:#F97316}
.cr-score-ring.lv4{border-color:#F59E0B;color:#F59E0B}
.cr-score-info{flex:1;min-width:0}
.cr-score-level{font-size:.75rem;font-weight:700;margin-bottom:1px}
.cr-score-hint{font-size:.65rem;color:var(--text3)}
.cr-score-badge-wrap{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap}
.cr-badge{font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:10px;background:var(--coral-bg);color:var(--coral)}
.cr-badge.gold{background:rgba(245,158,11,.15);color:#B45309}
.cr-phase-transition{text-align:center;padding:20px 0}
.cr-phase-transition .cr-phase-icon{font-size:2.5rem;margin-bottom:6px;animation:bounce .5s ease}
.cr-phase-transition h3{font-size:1rem;margin-bottom:4px}
.cr-phase-transition p{font-size:.78rem;color:var(--text2);margin-bottom:12px}
@keyframes crPulse{0%,100%{box-shadow:0 0 0 0 rgba(242,106,74,.3)}50%{box-shadow:0 0 0 8px rgba(242,106,74,0)}}
.cr-upgrade-btn{animation:crPulse 2s infinite}

/* ===== RECRUITER DASHBOARD v5.1 (Kvorum 94.35%) ===== */
/* AI FAB */
.rd-fab{position:fixed;bottom:100px;right:16px;z-index:999;width:56px;height:56px;border-radius:50%;background:var(--coral);color:#fff;font-size:22px;box-shadow:0 4px 16px var(--coral-glow);cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;transition:transform var(--transition),box-shadow var(--transition);font-family:var(--font)}
.rd-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px var(--coral-glow)}
.rd-fab:active{transform:scale(0.95)}
@media(min-width:768px){.rd-fab{bottom:24px;right:24px}}

/* AI Sidebar */
.rd-ai-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1099;display:none;transition:opacity var(--transition)}
.rd-ai-overlay.show{display:block}
.rd-ai-sidebar{position:fixed;top:0;right:0;bottom:0;width:100vw;max-width:420px;background:var(--bg);z-index:1100;transform:translateX(100%);transition:transform var(--transition);box-shadow:-4px 0 24px rgba(0,0,0,.12);display:flex;flex-direction:column}
.rd-ai-sidebar.open{transform:translateX(0)}
.rd-ai-header{display:flex;align-items:center;gap:8px;padding:16px;border-bottom:1px solid var(--border);font-size:16px;font-weight:700}
.rd-ai-header h3{margin:0;font-size:16px;flex:1}
.rd-ai-close{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text2);font-size:16px;cursor:pointer;border:none;font-family:var(--font)}
.rd-ai-close:hover{background:var(--coral-bg);color:var(--coral)}
.rd-ai-body{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch}
.rd-ai-body .ai-tool-card{margin-bottom:10px}
.rd-ai-body .ai-tool-card textarea{min-height:60px;font-size:12px}
.rd-ai-body .ai-chat{max-height:300px}

/* Gamification */
.rd-level-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;background:var(--coral-bg);color:var(--coral);white-space:nowrap;flex-shrink:0}
.rd-level-badge.lv-book{border:1.5px solid var(--coral);background:transparent}
.rd-level-badge.lv-shield{background:var(--coral);color:#fff}
.rd-level-badge.lv-crown{background:linear-gradient(135deg,#F26A4A,#d45232);color:#fff;box-shadow:0 2px 8px var(--coral-glow)}
.rd-xp-bar{height:4px;background:var(--border);margin:0;overflow:hidden}
.rd-xp-fill{height:100%;background:var(--coral);transition:width .5s ease}

/* Inline filters (inside tables) */
.rd-inline-filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.rd-inline-filters input,.rd-inline-filters select{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;font-family:var(--font);flex:1;min-width:120px}
.rd-inline-filters select{flex:0 0 auto;min-width:auto;max-width:160px}
.rd-inline-filters input:focus,.rd-inline-filters select:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-bg);outline:none}

/* Analytics */
.rd-analytics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
@media(min-width:768px){.rd-analytics-grid{grid-template-columns:repeat(4,1fr)}}
.rd-analytics-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px}
.rd-kpi{font-size:28px;font-weight:900;line-height:1.2}
.rd-kpi-label{font-size:11px;color:var(--text2);margin-top:2px}
.rd-kpi-label.up{color:#2e7d32}
.rd-kpi-label.down{color:#d32f2f}

/* Candidate AI score */
.rd-ai-score{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700}
.rd-ai-score.high{background:rgba(46,125,50,.12);color:#2e7d32}
.rd-ai-score.mid{background:rgba(245,124,0,.12);color:#f57c00}
.rd-ai-score.low{background:rgba(211,47,47,.12);color:#d32f2f}

/* Onboarding wizard */
.rd-onboarding{display:none;position:fixed;inset:0;z-index:1200;background:var(--bg);flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px}
.rd-onboarding.show{display:flex}
.rd-onboard-icon{font-size:4rem;margin-bottom:16px}
.rd-onboard-title{font-size:22px;font-weight:800;margin-bottom:8px}
.rd-onboard-sub{font-size:14px;color:var(--text2);margin-bottom:24px;max-width:300px}
.rd-onboard-steps{display:flex;gap:6px;margin-bottom:24px}
.rd-onboard-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}
.rd-onboard-dot.active{background:var(--coral);transform:scale(1.5)}

/* Upgrade prompt */
.rd-upgrade-banner{display:none;padding:12px 16px;background:linear-gradient(135deg,var(--coral-bg),rgba(242,106,74,.05));border:1px solid rgba(242,106,74,.15);border-radius:12px;font-size:13px;color:var(--text);margin:12px 0;align-items:center;gap:10px}
.rd-upgrade-banner.show{display:flex}
.rd-upgrade-banner .btn-sm{padding:6px 14px;font-size:12px;white-space:nowrap}

/* Upsell context CTA */
.rd-upsell-cta{display:none;padding:8px 12px;background:linear-gradient(135deg,rgba(242,106,74,.06),rgba(242,106,74,.02));border-radius:8px;font-size:12px;color:var(--text2);margin-top:8px;align-items:center;gap:8px}
.rd-upsell-cta.show{display:flex}
.rd-upsell-cta .rd-up-arrow{color:var(--coral);font-weight:700}

/* ===== WORKER CABINET v1.0 (Kvorum 100%) ===== */
/* Tabs */
.wc-tabs{display:flex;gap:2px;padding:8px 12px;background:var(--bg2);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}
.wc-tab{flex-shrink:0;padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;border:none;background:transparent;color:var(--text2)}
.wc-tab.active{background:var(--coral);color:#fff}
.wc-tab:hover:not(.active){background:var(--bg)}
.wc-panel{display:none;padding:16px}
.wc-panel.active{display:block}

/* Dashboard states */
.wc-greeting{display:flex;align-items:center;gap:12px;padding:16px;background:linear-gradient(135deg,var(--coral-bg),rgba(242,106,74,.03));border-radius:var(--radius);margin-bottom:16px}
.wc-avatar{width:48px;height:48px;border-radius:50%;background:var(--coral);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;flex-shrink:0}
.wc-greet-text{flex:1}
.wc-greet-name{font-size:18px;font-weight:800;margin-bottom:2px}
.wc-greet-sub{font-size:12px;color:var(--text2)}
.wc-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;background:var(--coral-bg);color:var(--coral)}
.wc-status-badge.active{background:rgba(46,125,50,.12);color:#2e7d32}
.wc-status-badge.idle{background:rgba(245,124,0,.12);color:#f57c00}

/* Checklist */
.wc-checklist{margin-bottom:16px}
.wc-cl-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--bg2);margin-bottom:6px;font-size:13px;transition:all .2s}
.wc-cl-item.done{opacity:.6}
.wc-cl-item.done .wc-cl-text{text-decoration:line-through}
.wc-cl-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all .2s}
.wc-cl-item.done .wc-cl-check{background:var(--coral);border-color:var(--coral);color:#fff}
.wc-cl-text{flex:1}
.wc-cl-cta{font-size:11px;color:var(--coral);font-weight:600;cursor:pointer;white-space:nowrap}

/* XP Streak bar */
.wc-streak-card{padding:14px;border-radius:12px;background:var(--bg2);border:1px solid var(--border);margin-bottom:12px}
.wc-streak-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;font-weight:700}
.wc-streak-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.wc-streak-fill{height:100%;background:var(--coral);border-radius:3px;transition:width .5s ease}
.wc-streak-days{display:flex;justify-content:space-between;margin-top:4px;font-size:10px;color:var(--text3)}
.wc-streak-days span.done{color:var(--coral);font-weight:700}

/* Calculator */
.wc-calc{display:none;position:fixed;inset:0;z-index:1200;background:var(--bg);flex-direction:column}
.wc-calc.show{display:flex}
.wc-calc-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--border)}
.wc-calc-header h3{margin:0;font-size:16px;flex:1}
.wc-calc-body{flex:1;overflow-y:auto;padding:20px}
.wc-calc-result{text-align:center;padding:20px;margin-top:16px;background:var(--coral-bg);border-radius:var(--radius)}
.wc-calc-net{font-size:42px;font-weight:900;color:var(--coral)}

/* CV Steps */
.wc-cv-steps{display:flex;gap:5px;margin-bottom:16px}
.wc-cv-dot{flex:1;height:4px;background:var(--border);border-radius:2px;transition:background .3s}
.wc-cv-dot.done{background:var(--coral)}
.wc-cv-dot.active{background:var(--coral)}
.wc-cv-section{display:none;animation:fadeInUp .3s ease}
.wc-cv-section.active{display:block}
.wc-cv-section h4{font-size:15px;font-weight:700;margin-bottom:12px}

/* Worker favorites inline toggle */
.wc-fav-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:14px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;background:var(--bg2);color:var(--text2);border:none}
.wc-fav-toggle.on{background:var(--coral-bg);color:var(--coral)}

/* Worker notifications */
.wc-notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px;border-radius:10px;background:var(--bg2);border:1px solid var(--border);margin-bottom:8px;transition:all .2s}
.wc-notif-item.unread{background:var(--notif-unread);border-color:var(--coral-bg)}
.wc-notif-icon{font-size:20px;flex-shrink:0;margin-top:2px}
.wc-notif-body{flex:1;min-width:0}
.wc-notif-title{font-size:13px;font-weight:700;margin-bottom:2px}
.wc-notif-text{font-size:12px;color:var(--text2)}
.wc-notif-time{font-size:10px;color:var(--text3);margin-top:4px}

/* ===== ADMIN PANEL v1.0 (Kvorum 100%) ===== */
.adp-page{overflow-y:auto;max-height:calc(100vh - var(--header-h) - var(--bottom-h))}
.adp-table{width:100%;border-collapse:collapse;font-size:12px}
.adp-table th{text-align:left;padding:8px 6px;border-bottom:2px solid var(--border);font-weight:700;font-size:11px;color:var(--text2);white-space:nowrap}
.adp-table td{padding:8px 6px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:12px}
.adp-table tr:hover td{background:var(--bg2)}
.adp-table .adp-check{width:18px;height:18px;cursor:pointer}
.adp-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700}
.adp-badge.active{background:rgba(46,125,50,.12);color:#2e7d32}
.adp-badge.blocked{background:rgba(211,47,47,.12);color:#d32f2f}
.adp-badge.admin{background:var(--coral-bg);color:var(--coral)}
.adp-badge.recruiter{background:rgba(25,118,210,.1);color:#1976d2}
.adp-actions{display:flex;gap:4px}
.adp-btn-sm{padding:4px 8px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;border:none;transition:all .15s}
.adp-btn-sm.edit{background:var(--bg2);color:var(--text2)}
.adp-btn-sm.edit:hover{background:var(--coral-bg);color:var(--coral)}
.adp-btn-sm.block{background:rgba(211,47,47,.08);color:#d32f2f}
.adp-btn-sm.block:hover{background:rgba(211,47,47,.18)}

/* 2FA setup */
.adp-2fa-box{padding:16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);text-align:center;margin-bottom:12px}
.adp-qr{width:120px;height:120px;background:var(--border);margin:12px auto;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:40px}
.adp-code-row{display:flex;gap:6px;justify-content:center;margin:12px 0}
.adp-code-box{width:40px;height:48px;border:2px solid var(--border);border-radius:8px;text-align:center;font-size:20px;font-weight:800;font-family:monospace}
.adp-recovery{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin:12px 0}
.adp-rec-code{font-family:monospace;font-size:11px;padding:6px;background:var(--bg);border-radius:6px;text-align:center;border:1px solid var(--border)}

/* Audit log */
.adp-audit-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px}
.adp-audit-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.adp-audit-body{flex:1;min-width:0}
.adp-audit-action{font-weight:700;margin-bottom:1px}
.adp-audit-detail{color:var(--text2);font-size:11px}
.adp-audit-time{font-size:10px;color:var(--text3);white-space:nowrap}
.adp-audit-diff{font-size:10px;margin-top:3px;padding:4px 6px;background:var(--bg2);border-radius:4px;font-family:monospace}
.adp-audit-diff .old{color:#d32f2f;text-decoration:line-through}
.adp-audit-diff .new{color:#2e7d32}

/* Broadcast panel */
.adp-broadcast-card{padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);margin-bottom:10px}
.adp-broadcast-card h4{font-size:14px;font-weight:700;margin:0 0 8px}
.adp-channels{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.adp-channel{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:16px;font-size:11px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--bg);transition:all .15s}
.adp-channel.sel{border-color:var(--coral);background:var(--coral-bg);color:var(--coral)}
.adp-preview{padding:12px;background:var(--bg);border-radius:8px;border:1px solid var(--border);font-size:12px;line-height:1.6;max-height:150px;overflow-y:auto}

/* ===== CONTENT TAB v1.0 (Kvorum 100%) ===== */
/* Sub-tabs inside Content */
.adc-subtabs{display:flex;gap:2px;padding:0 0 12px;border-bottom:1px solid var(--border);margin-bottom:12px}
.adc-subtab{flex:1;padding:8px 12px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:none;background:var(--bg);color:var(--text2);transition:all .2s;text-align:center}
.adc-subtab.active{background:var(--coral);color:#fff}
.adc-subtab:hover:not(.active){background:var(--bg2)}

/* -- FILTER MANAGER -- */
.adc-filter-grid{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:12px}
.adc-filter-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);transition:box-shadow .15s}
.adc-filter-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}
.adc-filter-card .adc-fc-type{font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;flex-shrink:0}
.adc-fc-type.chip{background:var(--coral-bg);color:var(--coral)}
.adc-fc-type.range{background:rgba(25,118,210,.1);color:#1976d2}
.adc-fc-type.dropdown{background:rgba(46,125,50,.12);color:#2e7d32}
.adc-fc-type.multi{background:rgba(255,152,0,.12);color:#e65100}
.adc-fc-type.radio{background:rgba(156,39,176,.1);color:#7b1fa2}
.adc-filter-card .adc-fc-name{font-size:13px;font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adc-filter-card .adc-fc-usage{font-size:10px;color:var(--text3);flex-shrink:0}
.adc-fc-drag{font-size:14px;cursor:grab;color:var(--text2);flex-shrink:0}
.adc-fc-drag:active{cursor:grabbing}
.adc-fc-actions{display:flex;gap:4px;flex-shrink:0}

/* -- Add filter modal inline -- */
.adc-add-filter-bar{display:flex;gap:8px;align-items:center;padding:10px;background:var(--bg);border-radius:var(--radius);border:1px dashed var(--border);margin-bottom:8px;flex-wrap:wrap}
.adc-add-filter-bar input,.adc-add-filter-bar select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--bg2);color:var(--text);min-width:100px}
.adc-add-filter-bar .adc-af-options{display:flex;gap:4px;flex-wrap:wrap;flex:1;min-width:200px}
.adc-af-chip{display:inline-flex;padding:3px 8px;border-radius:10px;font-size:10px;background:var(--bg2);border:1px solid var(--border);cursor:pointer}
.adc-af-chip.active{background:var(--coral-bg);color:var(--coral);border-color:var(--coral)}

/* -- Filter analytics -- */
.adc-analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:12px}
.adc-stat-card{padding:12px;border-radius:var(--radius);background:var(--bg2);border:1px solid var(--border);text-align:center}
.adc-stat-card .adc-stat-val{font-size:22px;font-weight:800;color:var(--coral);margin-bottom:2px}
.adc-stat-card .adc-stat-label{font-size:10px;color:var(--text2)}
.adc-stat-bar{height:4px;border-radius:2px;background:var(--bg);margin-top:6px;overflow:hidden}
.adc-stat-bar-fill{height:100%;border-radius:2px;transition:width .3s}

/* -- AD CONSTRUCTOR -- */
.adc-ad-card{padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);margin-bottom:10px}
.adc-ad-card h4{font-size:13px;font-weight:700;margin:0 0 8px;display:flex;align-items:center;gap:6px}
.adc-ad-card h4 .adc-ad-badge{font-size:10px;padding:2px 6px;border-radius:6px;font-weight:400}
.adc-ad-badge.brandlift{background:var(--coral-bg);color:var(--coral)}
.adc-ad-badge.sponsored{background:rgba(255,152,0,.12);color:#e65100}
.adc-ad-badge.booster{background:rgba(46,125,50,.12);color:#2e7d32}
.adc-ad-form{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:12px}
.adc-ad-form .form-group{margin:0}
.adc-ad-form .form-group.full{grid-column:1/-1}
.adc-ad-form input,.adc-ad-form textarea,.adc-ad-form select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--bg);color:var(--text);width:100%;box-sizing:border-box}
.adc-ad-form textarea{min-height:60px;resize:vertical}
.adc-ad-preview{grid-column:1/-1;padding:12px;background:var(--bg);border-radius:8px;border:1px solid var(--border);font-size:11px;line-height:1.5;min-height:40px}

/* -- Visual card grid (F-light) -- */
.adc-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-bottom:12px}
.adc-card-preview{padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg2);transition:box-shadow .15s}
.adc-card-preview:hover{box-shadow:0 2px 8px rgba(0,0,0,.08)}
.adc-card-preview .adc-cp-title{font-size:14px;font-weight:700;margin-bottom:4px}
.adc-card-preview .adc-cp-company{font-size:11px;color:var(--text2);margin-bottom:6px}
.adc-card-preview .adc-cp-salary{font-size:14px;font-weight:800;color:var(--coral);margin-bottom:4px}
.adc-card-preview .adc-cp-chips{display:flex;gap:4px;flex-wrap:wrap}
.adc-card-preview .adc-cp-chip{font-size:9px;padding:2px 6px;border-radius:6px;background:var(--bg);color:var(--text2)}
.adc-view-toggle{display:flex;gap:4px;margin-bottom:8px}
.adc-view-btn{padding:5px 10px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg2);color:var(--text2);transition:all .15s}
.adc-view-btn.active{background:var(--coral);color:#fff;border-color:var(--coral)}

/* Connection graph placeholder */
.adp-graph-placeholder{height:200px;background:var(--bg2);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:13px;border:1px dashed var(--border)}

/* Reusable sponsored helpers (used in card markup) */
.sp-btn{padding:10px 24px;border-radius:10px;background:var(--coral);color:#fff;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.sp-btn:hover{background:var(--coral-dark)}
.sp-urgent{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700;background:rgba(211,47,47,.12);color:#d32f2f}
/* ===== NOTIFICATION PANEL (Coral Unified v7) ===== */
.notif-panel{position:fixed;top:0;right:-340px;width:320px;max-width:90vw;height:100%;background:var(--card);z-index:2001;padding:0;overflow-y:auto;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px rgba(0,0,0,.15);will-change:transform}
.notif-panel.show{right:0}
.notif-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card);z-index:2}
.notif-header h3{font-size:16px;font-weight:700;margin:0}
.notif-header button{min-width:44px;min-height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text2);font-size:18px;transition:background .2s,transform .15s;border:none;cursor:pointer}
.notif-header button:hover{background:var(--border)}
.notif-header button:active{transform:scale(.92)}
.notif-body{padding:8px 20px calc(20px + env(safe-area-inset-bottom))}
.notif-empty{text-align:center;padding:40px 20px;color:var(--text3);font-size:14px}

/* ===== GPU ACCELERATION ===== */
.menu-panel,.notif-panel,.filter-sheet,.modal-sheet{will-change:transform}

/* ===== FAB EXPANDED MENU ===== */
.fab-menu-expanded{position:fixed;bottom:132px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:8px;will-change:opacity,transform;animation:fabMenuIn .2s ease}
@keyframes fabMenuIn{from{opacity:0;transform:translateY(12px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}
.fab-menu-item{min-width:44px;min-height:44px;padding:10px 18px;border-radius:22px;background:var(--card);color:var(--text);font-size:14px;font-weight:600;border:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.12);cursor:pointer;display:flex;align-items:center;gap:8px;text-decoration:none;transition:transform .2s,box-shadow .2s}
.fab-menu-item:hover{transform:translateX(-4px);box-shadow:0 6px 20px rgba(0,0,0,.18)}
.fab-menu-item:active{transform:scale(.96)}

/* ===== GLASSMORPHISM MENU ===== */
.menu-panel{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(30,30,35,.92)}
.menu-overlay{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}

/* ===== STAGGERED MENU ITEMS ===== */
.menu-panel .menu-item{opacity:0;transform:translateX(16px);transition:opacity .25s ease,transform .25s ease}
.menu-panel.show .menu-item{opacity:1;transform:translateX(0)}
.menu-panel.show .menu-item:nth-child(1){transition-delay:.04s}
.menu-panel.show .menu-item:nth-child(2){transition-delay:.08s}
.menu-panel.show .menu-item:nth-child(3){transition-delay:.12s}
.menu-panel.show .menu-item:nth-child(4){transition-delay:.16s}
.menu-panel.show .menu-item:nth-child(5){transition-delay:.20s}
.menu-panel.show .menu-item:nth-child(6){transition-delay:.24s}
.menu-panel.show .menu-item:nth-child(7){transition-delay:.28s}
.menu-panel.show .menu-item:nth-child(8){transition-delay:.32s}
