/* ═══════════════════════════════════════════════════════════════════
   QUEZAP TEAM — matches your admin panel brand language.
   Clean, warm, orange + navy. Poppins. Light mode only.
   ═══════════════════════════════════════════════════════════════════ */

:root{
  --bg:          #FFF8F3;
  --bg-soft:     #FEFBF7;
  --bg-tint:     #FFF3EA;
  --surface:     #FFFFFF;
  --surface-2:   #FBF7F2;
  --surface-3:   #F5EFE7;
  --border:      #F0E7DC;
  --border-2:    #E5DACB;
  --border-strong:#D1C2AE;
  --text:        #111827;
  --text-2:      #334155;
  --text-muted:  #6B7280;
  --text-subtle: #9CA3AF;
  --brand:       #FF6B35;
  --brand-2:     #F55525;
  --brand-3:     #E0461C;
  --brand-soft:  #FFE4D4;
  --brand-wash:  #FFF0E5;
  --brand-tint:  #FFF7F0;
  --success:      #10B981;
  --success-bg:   #ECFDF5;
  --success-border:#A7F3D0;
  --warning:      #F59E0B;
  --warning-bg:   #FEF3C7;
  --warning-border:#FCD34D;
  --danger:       #EF4444;
  --danger-bg:    #FEF2F2;
  --danger-border:#FECACA;
  --info:         #3B82F6;
  --info-bg:      #EFF6FF;
  --info-border:  #BFDBFE;
  --accent:       #8B5CF6;
  --accent-bg:    #F3EFFF;
  --shadow-xs:   0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:   0 1px 3px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04);
  --shadow:      0 4px 6px rgba(15,23,42,.04), 0 2px 4px rgba(15,23,42,.03);
  --shadow-md:   0 10px 15px rgba(15,23,42,.05), 0 4px 6px rgba(15,23,42,.04);
  --shadow-lg:   0 20px 25px rgba(15,23,42,.08), 0 10px 10px rgba(15,23,42,.04);
  --shadow-xl:   0 25px 50px rgba(15,23,42,.12);
  --shadow-card: 0 2px 8px rgba(15,23,42,.04), 0 8px 32px rgba(15,23,42,.06);
  --r-xs:4px; --r-sm:6px; --r:8px; --r-md:10px; --r-lg:12px; --r-xl:16px; --r-2xl:20px; --r-3xl:28px;
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur-fast:120ms; --dur:200ms; --dur-slow:360ms;
  --sidebar-w:256px;
  --sidebar-w-collapsed:72px;
  --topbar-h:64px;
  --font:        'Poppins', system-ui, -apple-system, sans-serif;
  --font-body:   'Poppins', system-ui, -apple-system, sans-serif;
  --font-display:'Poppins', system-ui, sans-serif;
  --font-mono:   'Inter', ui-monospace, monospace;
  /* legacy aliases */
  --ink: var(--text); --ink-2: var(--text-2); --ink-3: var(--text-muted); --ink-4: var(--text-muted); --ink-muted: var(--text-subtle);
  --gray-50: var(--bg-soft); --gray-100: var(--surface-2); --gray-200: var(--surface-3);
  --gray-300: var(--border); --gray-400: var(--border-2); --gray-500: var(--text-subtle);
  --gray-600: var(--text-muted); --gray-700: var(--text-2); --gray-800: var(--text); --gray-900: var(--text);
  --brand-50: var(--brand-tint); --brand-100: var(--brand-wash); --brand-200: var(--brand-soft);
  --brand-600: var(--brand-2); --brand-700: var(--brand-3);
  --rule: var(--border-2); --rule-soft: var(--border); --rule-strong: var(--border-strong);
  --paper: var(--bg); --paper-2: var(--surface-2); --paper-3: var(--surface-3); --paper-soft: var(--bg-soft);
  --card: var(--surface); --card-2: var(--surface-2);
  --forest: var(--success); --clay: var(--danger); --indigo: var(--info); --butter: var(--warning);
  --forest-wash: var(--success-bg); --forest-soft: var(--success-border);
  --clay-wash: var(--danger-bg); --clay-soft: var(--danger-border);
  --indigo-wash: var(--info-bg); --indigo-soft: var(--info-border);
  --butter-wash: var(--warning-bg); --butter-soft: var(--warning-border);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}
::selection{background:var(--brand-soft);color:var(--brand-3)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--border-strong);background-clip:padding-box;border:2px solid transparent}

h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:700;letter-spacing:-.015em;color:var(--text);line-height:1.2}
h1{font-size:28px;letter-spacing:-.025em;font-weight:700}
h2{font-size:22px;font-weight:700;letter-spacing:-.02em}
h3{font-size:16px;font-weight:600;letter-spacing:-.01em}
h4{font-size:14px;font-weight:600}
p{color:var(--text-2)}
a{color:var(--brand);text-decoration:none;transition:color var(--dur-fast) var(--ease);font-weight:500}
a:hover{color:var(--brand-2)}
input,select,textarea,button{font-family:inherit;font-size:inherit;color:inherit}
button{background:none;border:none;cursor:pointer;color:inherit}
svg{display:block;flex-shrink:0;width:16px;height:16px}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes bounce-in{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.04)}100%{opacity:1;transform:scale(1)}}

.eyebrow{font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}
.num{font-family:var(--font);font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-weight:600}
.num-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.muted{color:var(--text-muted)}
.subtle{color:var(--text-subtle)}
.t-sm{font-size:12.5px}
.t-xs{font-size:11.5px}
.rule{height:1px;background:var(--border);margin:20px 0}
.serif, .serif-i, .display{font-family:var(--font);font-style:normal}

/* BRAND LOGO — the real QueZap identity */
.brand-mark{
  width:40px;height:40px;border-radius:10px;flex-shrink:0;
  background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-xs);
  display:flex;align-items:center;justify-content:center;padding:0;
}
.brand-mark::before{content:none}
.brand-mark svg, .brand-bolt{width:22px !important;height:22px !important;display:block;color:var(--brand) !important}
.brand-mark img{width:100%;height:100%;object-fit:contain;border-radius:9px;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1;overflow:hidden;white-space:nowrap}
.brand-text-top{font-family:var(--font);font-weight:800;font-size:20px;letter-spacing:-.02em;color:var(--text)}
.brand-text-top span{color:var(--brand)}
.brand-text-sub{font-size:9.5px;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-top:4px;font-weight:600}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:40px;padding:0 18px;border-radius:var(--r-md);font-family:var(--font);font-size:13.5px;font-weight:600;letter-spacing:-.005em;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--dur-fast) var(--ease);position:relative}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--text);color:#fff;border-color:var(--text)}
.btn-primary:hover{background:#000}
.btn-brand{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:0 1px 3px rgba(255,107,53,.3)}
.btn-brand:hover{background:var(--brand-2);box-shadow:0 4px 12px rgba(255,107,53,.35)}
.btn-ghost{background:var(--surface);color:var(--text-2);border-color:var(--border-2)}
.btn-ghost:hover{background:var(--bg-tint);border-color:var(--border-strong);color:var(--text)}
.btn-subtle{background:var(--surface-2);color:var(--text-2);border-color:transparent}
.btn-subtle:hover{background:var(--surface-3);color:var(--text)}
.btn-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}
.btn-success:hover{background:var(--success);color:#fff;border-color:var(--success)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-info{background:var(--info-bg);color:var(--info);border:1px solid var(--info-border)}
.btn-info:hover{background:var(--info);color:#fff;border-color:var(--info)}
.btn-sm{height:34px;padding:0 12px;font-size:12.5px;border-radius:var(--r);gap:5px}
.btn-xs{height:28px;padding:0 10px;font-size:11.5px;border-radius:var(--r-sm);gap:4px}
.btn-lg{height:48px;padding:0 24px;font-size:14.5px;border-radius:var(--r-md);font-weight:700}
.btn-icon{width:40px;padding:0}
.btn-icon.btn-sm{width:34px}
.btn-icon.btn-xs{width:28px}
.btn-full{width:100%}
.btn svg{width:14px;height:14px}
.btn-sm svg{width:13px;height:13px}
.btn-xs svg{width:12px;height:12px}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 9px;border-radius:99px;font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.02em;line-height:1;border:1px solid transparent}
.badge-dot{width:6px;height:6px;border-radius:99px;flex-shrink:0}
.badge-success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}
.badge-success .badge-dot{background:var(--success)}
.badge-warning{background:var(--warning-bg);color:#92400E;border-color:var(--warning-border)}
.badge-warning .badge-dot{background:var(--warning)}
.badge-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}
.badge-danger .badge-dot{background:var(--danger)}
.badge-info{background:var(--info-bg);color:var(--info);border-color:var(--info-border)}
.badge-info .badge-dot{background:var(--info)}
.badge-brand{background:var(--brand-wash);color:var(--brand-3);border-color:var(--brand-soft)}
.badge-brand .badge-dot{background:var(--brand)}
.badge-accent{background:var(--accent-bg);color:var(--accent);border-color:#E0D4FE}
.badge-neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}
.badge-neutral .badge-dot{background:var(--text-muted)}

.pill-brand{display:inline-flex;align-items:center;gap:8px;padding:9px 22px;border-radius:99px;background:var(--brand-wash);color:var(--brand-3);font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--brand-soft)}
.pill-brand svg{width:14px;height:14px;color:var(--brand)}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease)}
.card-pad{padding:20px 24px}
.card-pad-lg{padding:28px 32px}
.card-pad-sm{padding:14px 16px}
.card-hover{cursor:pointer}
.card-hover:hover{border-color:var(--border-2);box-shadow:var(--shadow);transform:translateY(-2px)}
.card-shadow{box-shadow:var(--shadow-card)}
.surface-2{background:var(--surface-2)}
.surface-3{background:var(--surface-3)}
.divider{height:1px;background:var(--border);margin:16px 0}
.divider-v{width:1px;background:var(--border);align-self:stretch}

/* FORMS */
.field{margin-bottom:16px}
.field-label{display:block;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:-.005em}
.field-label.req::after{content:' *';color:var(--brand)}
.input,.select,.textarea{width:100%;height:44px;padding:0 14px;background:var(--surface);color:var(--text);border:1.5px solid var(--border-2);border-radius:var(--r-md);font-family:var(--font);font-size:13.5px;font-weight:400;outline:none;transition:all var(--dur-fast) var(--ease)}
.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}
.input:focus,.select:focus,.textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-wash)}
.input::placeholder,.textarea::placeholder{color:var(--text-subtle);font-weight:400}
.textarea{height:auto;min-height:90px;padding:12px 14px;resize:vertical;line-height:1.55}
.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'><path d='M3 5l3 3 3-3' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:34px;cursor:pointer}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-hint{margin-top:6px;font-size:12px;color:var(--text-muted)}
.toggle{position:relative;display:inline-block;width:40px;height:22px}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border-2);border-radius:99px;transition:var(--dur) var(--ease);cursor:pointer}
.toggle-slider::before{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:var(--dur) var(--ease);box-shadow:var(--shadow-sm)}
.toggle input:checked + .toggle-slider{background:var(--brand)}
.toggle input:checked + .toggle-slider::before{transform:translateX(18px)}
.checkbox{display:inline-flex;align-items:center;gap:9px;cursor:pointer;user-select:none;font-size:13px;color:var(--text-2);font-weight:500}
.checkbox input{appearance:none;width:17px;height:17px;border:2px solid var(--border-strong);border-radius:4px;background:var(--surface);cursor:pointer;position:relative;transition:all var(--dur-fast) var(--ease)}
.checkbox input:checked{background:var(--brand);border-color:var(--brand)}
.checkbox input:checked::after{content:'';position:absolute;top:1px;left:4px;width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}

/* AVATARS */
.avatar{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--brand-wash);color:var(--brand-3);font-family:var(--font);font-size:13px;font-weight:700;overflow:hidden;flex-shrink:0;position:relative;letter-spacing:-.01em;border:2px solid var(--surface)}
.avatar img{width:100%;height:100%;object-fit:cover}
.avatar-xs{width:22px;height:22px;font-size:9.5px;border-width:1px}
.avatar-sm{width:30px;height:30px;font-size:11px;border-width:1.5px}
.avatar-md{width:40px;height:40px;font-size:14px}
.avatar-lg{width:56px;height:56px;font-size:18px;border-width:2px}
.avatar-xl{width:80px;height:80px;font-size:26px;border-width:3px}
.avatar-2xl{width:120px;height:120px;font-size:40px;border-width:4px}
.avatar-group{display:inline-flex}
.avatar-group .avatar + .avatar{margin-left:-8px}
.avatar-status{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--surface);background:var(--text-subtle)}
.avatar-status.online{background:var(--success)}
.avatar-status.away{background:var(--warning)}
.avatar.c-0{background:#FFE4D4;color:#E0461C}
.avatar.c-1{background:#DBEAFE;color:#1D4ED8}
.avatar.c-2{background:#D1FAE5;color:#047857}
.avatar.c-3{background:#EDE9FE;color:#6D28D9}
.avatar.c-4{background:#FEE2E2;color:#B91C1C}
.avatar.c-5{background:#FEF3C7;color:#B45309}
.avatar.c-6{background:#CFFAFE;color:#0E7490}
.avatar.c-7{background:#FCE7F3;color:#BE185D}

/* APP SHELL */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh;position:relative;background:var(--bg)}
.app.sidebar-collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}
.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width var(--dur) var(--ease);overflow:hidden;position:relative;z-index:20}
.sidebar-head{height:var(--topbar-h);display:flex;align-items:center;gap:10px;padding:0 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-search{padding:16px 16px 8px;flex-shrink:0}
.kbd-btn{display:flex;align-items:center;gap:10px;width:100%;height:38px;padding:0 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-muted);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--dur-fast) var(--ease)}
.kbd-btn:hover{border-color:var(--border-2);color:var(--text-2);background:var(--surface)}
.kbd-btn svg{width:14px;height:14px;color:var(--text-muted)}
.kbd-btn .kbd-text{flex:1;text-align:left}
.kbd{display:inline-flex;align-items:center;justify-content:center;height:20px;min-width:20px;padding:0 6px;background:var(--surface);border:1px solid var(--border-2);border-radius:4px;font-family:var(--font);font-size:10.5px;color:var(--text-muted);font-weight:600}
.sidebar-nav{flex:1;overflow-y:auto;padding:10px 12px 16px;scrollbar-width:thin}
.sidebar-nav::-webkit-scrollbar{width:4px}
.nav-section{margin-bottom:4px;padding-top:12px}
.nav-section:first-child{padding-top:0}
.nav-label{display:block;padding:6px 12px 8px;font-family:var(--font);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-subtle);transition:opacity var(--dur) var(--ease)}
.nav-item{display:flex;align-items:center;gap:11px;height:38px;padding:0 12px;margin-bottom:2px;border-radius:var(--r);color:var(--text-2);font-family:var(--font);font-size:13.5px;font-weight:500;cursor:pointer;position:relative;transition:all var(--dur-fast) var(--ease)}
.nav-item:hover{background:var(--surface-2);color:var(--text)}
.nav-item.active{background:var(--brand-wash);color:var(--brand-3);font-weight:600}
.nav-icon{width:18px;height:18px;flex-shrink:0;color:var(--text-muted);transition:color var(--dur-fast) var(--ease)}
.nav-item.active .nav-icon{color:var(--brand)}
.nav-item:hover .nav-icon{color:var(--text-2)}
.nav-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--dur) var(--ease)}
.nav-count{height:20px;min-width:20px;padding:0 6px;background:var(--brand);color:#fff;border-radius:99px;font-family:var(--font);font-size:10.5px;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:0}
.sidebar-foot{padding:12px;border-top:1px solid var(--border);flex-shrink:0}
.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r);cursor:pointer;transition:background var(--dur-fast) var(--ease);width:100%;text-align:left}
.user-chip:hover{background:var(--surface-2)}
.user-chip-info{flex:1;min-width:0;overflow:hidden;transition:opacity var(--dur) var(--ease)}
.user-chip-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.user-chip-role{font-size:11.5px;color:var(--text-muted);margin-top:2px;text-transform:capitalize;font-weight:500}
.user-chip-arrow{color:var(--text-muted)}
.app.sidebar-collapsed .nav-text,
.app.sidebar-collapsed .nav-label,
.app.sidebar-collapsed .nav-count,
.app.sidebar-collapsed .user-chip-info,
.app.sidebar-collapsed .user-chip-arrow,
.app.sidebar-collapsed .brand-text,
.app.sidebar-collapsed .kbd-text,
.app.sidebar-collapsed .kbd{opacity:0;pointer-events:none}
.app.sidebar-collapsed .sidebar-search .kbd-btn{justify-content:center;padding:0}
.app.sidebar-collapsed .nav-item{justify-content:center;padding:0}

/* MAIN */
.main{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}
.topbar{height:var(--topbar-h);flex-shrink:0;display:flex;align-items:center;gap:14px;padding:0 28px;background:var(--surface);border-bottom:1px solid var(--border);position:relative;z-index:10}
.topbar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r);color:var(--text-2);cursor:pointer;transition:all var(--dur-fast) var(--ease)}
.topbar-toggle:hover{background:var(--surface-2);color:var(--text)}
.topbar-title{font-family:var(--font);font-size:16px;font-weight:700;letter-spacing:-.015em;color:var(--text);line-height:1.1}
.topbar-bread{font-size:11.5px;color:var(--text-muted);margin-top:2px;font-weight:500}
.topbar-spacer{flex:1}
.topbar-right{display:flex;align-items:center;gap:6px}
.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r);color:var(--text-2);cursor:pointer;position:relative;transition:all var(--dur-fast) var(--ease)}
.icon-btn:hover{background:var(--surface-2);color:var(--text)}
.icon-btn svg{width:18px;height:18px}
.icon-btn .notif-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--brand);border:2px solid var(--surface);animation:pulse 2s var(--ease) infinite}
.content{flex:1;overflow-y:auto;padding:32px 36px 60px;scroll-behavior:smooth}
@media (max-width:640px){.content{padding:20px}}
.page{display:none;animation:fadeUp .3s var(--ease-out)}
.page.active{display:block}
.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:24px;flex-wrap:wrap}
.page-title{font-family:var(--font);font-size:28px;font-weight:700;letter-spacing:-.025em;color:var(--text);line-height:1.1}
.page-sub{font-size:14px;color:var(--text-muted);margin-top:6px;font-weight:400;max-width:520px}
.page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.page-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}

/* TABS */
.tabs{display:inline-flex;gap:2px;background:var(--surface-2);padding:4px;border-radius:var(--r-md);border:1px solid var(--border)}
.tab{padding:7px 14px;border-radius:var(--r);font-family:var(--font);font-size:12.5px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all var(--dur-fast) var(--ease);border:none;background:transparent}
.tab:hover{color:var(--text)}
.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}
.tabs-underline{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto;scrollbar-width:none}
.tabs-underline::-webkit-scrollbar{display:none}
.tab-under{padding:12px 16px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all var(--dur-fast) var(--ease);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.tab-under:hover{color:var(--text)}
.tab-under.active{color:var(--brand);border-bottom-color:var(--brand)}

/* STAT CARDS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}
.stat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:16px;padding:22px 26px;position:relative;overflow:hidden;
  transition:transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease, border-color 0.2s ease;
  animation:statCardIn 0.6s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
.stat-card::after{
  content:'';position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--brand),transparent);
  opacity:0;transition:opacity 0.3s ease;
}
.stat-card:hover{
  border-color:var(--brand-soft, rgba(255,107,53,0.25));
  box-shadow:0 12px 32px rgba(15,23,42,0.06), 0 4px 12px rgba(255,107,53,0.08);
  transform:translateY(-4px);
}
.stat-card:hover::after{opacity:1}
.stats-grid .stat-card:nth-child(1){animation-delay:0.05s}
.stats-grid .stat-card:nth-child(2){animation-delay:0.10s}
.stats-grid .stat-card:nth-child(3){animation-delay:0.15s}
.stats-grid .stat-card:nth-child(4){animation-delay:0.20s}
.stats-grid .stat-card:nth-child(5){animation-delay:0.25s}
.stats-grid .stat-card:nth-child(6){animation-delay:0.30s}
@keyframes statCardIn{
  0%{opacity:0;transform:translateY(20px) scale(0.96)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
.stat-label{display:flex;align-items:center;gap:7px;color:var(--text-muted);font-size:12.5px;font-weight:600;margin-bottom:14px;letter-spacing:.01em}
.stat-label svg{width:14px;height:14px}
.stat-value{font-family:var(--font);font-size:32px;font-weight:700;letter-spacing:-.03em;color:var(--text);line-height:1;font-variant-numeric:tabular-nums}
.stat-value .unit{font-size:14px;color:var(--text-muted);font-weight:600;margin-left:3px}
.stat-trend{display:flex;align-items:center;gap:5px;margin-top:12px;font-size:12px;color:var(--text-muted);font-weight:500}
.stat-trend.up{color:var(--success)}
.stat-trend.down{color:var(--danger)}
.stat-card.accent{background:var(--text);color:#fff;border-color:var(--text);position:relative;overflow:hidden}
.stat-card.accent::before{content:'';position:absolute;top:-60px;right:-40px;width:180px;height:180px;background:radial-gradient(circle,var(--brand) 0%,transparent 65%);opacity:.45}
.stat-card.accent .stat-label{color:rgba(255,255,255,.65)}
.stat-card.accent .stat-value{color:#fff}
.stat-card.accent .stat-trend{color:rgba(255,255,255,.65)}

/* TABLES */
.tbl-wrap{overflow-x:auto;border-radius:var(--r-lg)}
.tbl{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface)}
.tbl th{text-align:left;padding:12px 20px;font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}
.tbl td{padding:14px 20px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-2);font-weight:500}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--surface-2)}
.tbl .tbl-sub{font-size:11.5px;color:var(--text-muted);margin-top:2px;font-weight:400}

.empty{padding:60px 24px;text-align:center}
.empty-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--r-lg);background:var(--brand-wash);color:var(--brand);margin-bottom:16px}
.empty-icon svg{width:24px;height:24px}
.empty-title{font-family:var(--font);font-size:18px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.015em}
.empty-text{font-size:14px;color:var(--text-muted);max-width:380px;margin:0 auto;line-height:1.55}
.empty-action{margin-top:20px}

.progress{height:6px;background:var(--surface-3);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:var(--brand);border-radius:99px;transition:width .6s var(--ease)}

/* MODALS */
.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.45);display:none;align-items:flex-start;justify-content:center;padding:60px 16px 40px;z-index:200;backdrop-filter:blur(6px);overflow-y:auto;animation:fadeIn var(--dur) var(--ease)}
.modal-bg.open{display:flex}
.modal{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:scaleIn var(--dur-slow) var(--ease-out)}
.modal-lg{max-width:720px}
.modal-xl{max-width:960px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 26px;border-bottom:1px solid var(--border)}
.modal-title{font-family:var(--font);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.015em}
.modal-close{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:all var(--dur-fast) var(--ease)}
.modal-close:hover{background:var(--surface-2);color:var(--text)}
.modal-body{padding:24px 26px;max-height:70vh;overflow-y:auto}
.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:16px 26px;background:var(--surface-2);border-top:1px solid var(--border)}

/* TOAST */
#toasts{position:fixed;bottom:20px;right:20px;z-index:500;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{display:flex;align-items:center;gap:11px;padding:12px 18px;min-width:240px;max-width:380px;background:var(--text);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-lg);font-family:var(--font);font-size:13px;font-weight:500;animation:bounce-in var(--dur-slow) var(--ease-out);pointer-events:auto}
.toast svg{width:16px;height:16px;flex-shrink:0}
.toast.success svg{color:#6EE7B7}
.toast.error svg{color:#FCA5A5}
.toast.info svg{color:#93C5FD}

/* LOGIN — matches your admin panel reference exactly */
#loginPage{
  position:fixed;inset:0;display:none;background:var(--bg);overflow:auto;
  background-image:
    radial-gradient(ellipse 700px 500px at 20% 10%, rgba(255,228,212,.65), transparent 60%),
    radial-gradient(ellipse 700px 500px at 80% 90%, rgba(255,240,229,.55), transparent 60%);
}
/* ═══ Login Page — Premium upgraded ═══ */
#loginPage.active{
  display:flex;align-items:center;justify-content:center;padding:40px 20px;
  position:relative;overflow:hidden;min-height:100vh;
  background:linear-gradient(135deg, #fff5ee 0%, #fff 50%, #ffe9d8 100%);
}

/* Animated background orbs for depth */
.login-bg-orbs{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.login-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:0.45;animation:orbFloat 12s ease-in-out infinite}
.login-orb-1{width:380px;height:380px;background:radial-gradient(circle,rgba(255,170,80,0.65),transparent 70%);top:-120px;left:-100px;animation-delay:0s}
.login-orb-2{width:320px;height:320px;background:radial-gradient(circle,rgba(255,107,53,0.45),transparent 70%);bottom:-100px;right:-80px;animation-delay:-4s;animation-duration:14s}
.login-orb-3{width:260px;height:260px;background:radial-gradient(circle,rgba(255,213,79,0.55),transparent 70%);top:40%;right:25%;animation-delay:-8s;animation-duration:16s}

@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-20px) scale(1.06)}
  66%{transform:translate(-25px,30px) scale(0.96)}
}

.login-shell{display:block;width:100%;max-width:460px;position:relative;z-index:1}
.login-art{display:none !important}
.login-form-side{padding:0;background:transparent}
.login-form-side::before, .login-form-side::after{content:none !important}

.login-card{
  width:100%;background:rgba(255,255,255,0.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-radius:24px;padding:44px 40px 36px;
  box-shadow:
    0 1px 2px rgba(15,23,42,0.04),
    0 8px 24px rgba(15,23,42,0.06),
    0 24px 60px rgba(255,107,53,0.08),
    inset 0 1px 0 rgba(255,255,255,0.9);
  border:1px solid rgba(255,255,255,0.7);
  animation:loginCardIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes loginCardIn{
  0%{opacity:0;transform:translateY(24px) scale(0.96)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

.login-brand{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:8px;animation:loginItemIn 0.5s ease-out 0.1s both}
.login-brand .brand-mark.login-brand-mark{
  width:60px;height:60px;border-radius:15px;
  background:#fff;border:1px solid rgba(0,0,0,0.06);
  box-shadow:0 6px 18px rgba(255,107,53,0.18), 0 1px 3px rgba(0,0,0,0.04);
  position:relative;
}
.login-brand .brand-mark.login-brand-mark::after{
  content:'';position:absolute;inset:-2px;border-radius:17px;
  background:linear-gradient(135deg,#ffd54f,#ff6b35);
  opacity:0;filter:blur(8px);z-index:-1;
  animation:logoGlow 3s ease-in-out infinite;
}
@keyframes logoGlow{
  0%,100%{opacity:0.0}
  50%{opacity:0.3}
}
.login-brand h1{font-family:var(--font);font-size:34px;font-weight:800;letter-spacing:-.03em;line-height:1;margin:0;color:#0F172A}
.login-brand h1 span{
  background:linear-gradient(135deg,#ffd54f 0%,#ff6b35 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}

.login-subtitle{
  text-align:center;font-size:13px;color:var(--text-muted);font-weight:500;
  margin:0 0 24px;letter-spacing:0.005em;
  animation:loginItemIn 0.5s ease-out 0.18s both;
}

.login-badge-wrap{display:flex;justify-content:center;margin-bottom:30px;animation:loginItemIn 0.5s ease-out 0.25s both}

.login-hero{display:none}

.login-err{
  display:none;padding:11px 14px;background:var(--danger-bg);color:var(--danger);
  border:1px solid var(--danger-border);border-radius:var(--r-md);
  font-size:13px;font-weight:500;margin-bottom:16px;
  animation:slideDown var(--dur) var(--ease);
}

#loginPage .field{animation:loginItemIn 0.5s ease-out both}
#loginPage .field:nth-child(5){animation-delay:0.32s}
#loginPage .field:nth-child(6){animation-delay:0.39s}

#loginPage .input{
  height:48px;padding:0 16px;font-size:14.5px;
  border-radius:11px;border:1.5px solid var(--border);
  transition:all 0.2s ease;background:#fff;
}
#loginPage .input:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(255,107,53,0.12);
  outline:none;
}

#loginPage #loginBtn{
  height:50px;font-size:15px;font-weight:600;letter-spacing:-0.005em;
  background:linear-gradient(135deg,#ff6b35 0%,#f5471d 100%);
  box-shadow:0 4px 14px rgba(255,107,53,0.32), inset 0 1px 0 rgba(255,255,255,0.18);
  transition:all 0.2s ease;
  animation:loginItemIn 0.5s ease-out 0.46s both;
}
#loginPage #loginBtn:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(255,107,53,0.42), inset 0 1px 0 rgba(255,255,255,0.18);
}
#loginPage #loginBtn:active{transform:translateY(0)}

/* Trust signal */
.login-trust{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin-top:18px;font-size:11.5px;color:var(--text-muted);font-weight:500;
  animation:loginItemIn 0.5s ease-out 0.55s both;
}
.login-trust svg{color:#22c55e;flex-shrink:0}

.login-foot{
  margin-top:20px;padding-top:18px;border-top:1px solid rgba(0,0,0,0.06);
  display:flex;justify-content:space-between;align-items:center;
  font-size:11.5px;color:var(--text-muted);font-weight:500;
  animation:loginItemIn 0.5s ease-out 0.62s both;
}
.login-foot a{color:var(--brand);font-weight:600;text-decoration:none;transition:opacity 0.15s}
.login-foot a:hover{opacity:0.8}

@keyframes loginItemIn{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}
}

@media (prefers-reduced-motion: reduce){
  .login-card,.login-brand,.login-subtitle,.login-badge-wrap,
  #loginPage .field,#loginPage #loginBtn,.login-trust,.login-foot{animation:none !important}
  .login-orb{animation:none !important}
}

/* KANBAN */
.kanban{display:grid;grid-template-columns:repeat(4,minmax(260px,1fr));gap:16px;overflow-x:auto;padding-bottom:10px}
@media (max-width:1100px){.kanban{grid-template-columns:repeat(4,260px)}}
.kanban-col{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;min-height:280px}
.kanban-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.kanban-head-left{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.005em}
.kanban-count{font-family:var(--font);font-size:11px;color:var(--text-muted);background:var(--surface);padding:2px 8px;border-radius:99px;font-weight:600;border:1px solid var(--border)}
.kanban-body{flex:1;padding:10px;display:flex;flex-direction:column;gap:8px}
.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;cursor:pointer;transition:all var(--dur-fast) var(--ease)}
.task-card:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.task-card-head{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.task-card-title{font-family:var(--font);font-size:13.5px;font-weight:600;color:var(--text);line-height:1.35}
.task-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}
.task-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:10px;border-top:1px solid var(--border)}
.task-card-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);font-weight:500}

/* CALENDAR */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-day-label{text-align:center;font-family:var(--font);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:8px 0}
.cal-day{aspect-ratio:1;border:1px solid var(--border);border-radius:var(--r);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--text-2);background:var(--surface);cursor:default;position:relative;transition:all var(--dur-fast) var(--ease)}
.cal-day.other{color:var(--text-subtle);background:transparent;border-color:transparent}
.cal-day.today{border-color:var(--brand);border-width:2px;color:var(--brand);font-weight:700;background:var(--brand-wash)}
.cal-day.holiday{background:var(--brand-wash);border-color:var(--brand-soft);color:var(--brand-3);font-weight:600}
.cal-day.weekend{color:var(--text-subtle)}
.cal-dot{width:4px;height:4px;border-radius:50%;background:currentColor;margin-top:3px}
.heatmap{display:grid;grid-template-columns:repeat(auto-fill,14px);gap:3px;padding:6px 0}
.heat-cell{width:14px;height:14px;border-radius:3px;background:var(--surface-2);border:1px solid var(--border)}
.heat-cell.l1{background:#D1FAE5;border-color:#A7F3D0}
.heat-cell.l2{background:#86EFAC;border-color:#4ADE80}
.heat-cell.l3{background:#22C55E;border-color:#16A34A}
.heat-cell.l4{background:#059669;border-color:#047857}
.heat-cell.absent{background:var(--danger-bg);border-color:var(--danger-border)}
.heat-cell.wfh{background:var(--info-bg);border-color:var(--info-border)}
.heat-cell.half{background:var(--warning-bg);border-color:var(--warning-border)}

/* COMMAND PALETTE */
#cmdPalette{position:fixed;inset:0;z-index:300;display:none;align-items:flex-start;justify-content:center;padding:80px 16px;background:rgba(15,23,42,.5);backdrop-filter:blur(8px);animation:fadeIn var(--dur) var(--ease)}
#cmdPalette.open{display:flex}
.cmd-box{width:100%;max-width:580px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:scaleIn var(--dur) var(--ease-out)}
.cmd-input-wrap{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border)}
.cmd-input-wrap svg{width:18px;height:18px;color:var(--text-muted)}
.cmd-input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font);font-size:15px;color:var(--text);font-weight:500}
.cmd-input::placeholder{color:var(--text-subtle);font-weight:400}
.cmd-results{max-height:420px;overflow-y:auto;padding:8px 0}
.cmd-section{padding:6px 0}
.cmd-section-label{padding:8px 22px 4px;font-family:var(--font);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-subtle)}
.cmd-item{display:flex;align-items:center;gap:12px;padding:10px 22px;cursor:pointer;transition:background var(--dur-fast) var(--ease);font-size:13.5px;color:var(--text-2);font-weight:500}
.cmd-item:hover,.cmd-item.selected{background:var(--surface-2);color:var(--text)}
.cmd-item svg{width:16px;height:16px;color:var(--text-muted)}
.cmd-item.selected svg{color:var(--brand)}
.cmd-item-label{flex:1}
.cmd-item-hint{font-family:var(--font);font-size:10.5px;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-weight:600}
.cmd-foot{display:flex;align-items:center;gap:18px;padding:12px 22px;border-top:1px solid var(--border);background:var(--surface-2);font-size:11px;color:var(--text-muted);font-weight:500}
.cmd-foot span{display:flex;align-items:center;gap:6px}

/* NOTIF PANEL */
#notifPanel{position:fixed;top:68px;right:20px;width:380px;max-height:calc(100vh - 88px);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);overflow:hidden;display:none;flex-direction:column;z-index:150;animation:scaleIn var(--dur) var(--ease-out);transform-origin:top right}
#notifPanel.open{display:flex}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.notif-title{font-family:var(--font);font-size:15px;font-weight:700;letter-spacing:-.015em}
.notif-list{flex:1;overflow-y:auto;max-height:500px}
.notif-item{display:flex;gap:12px;padding:14px 20px;cursor:pointer;transition:background var(--dur-fast) var(--ease);border-bottom:1px solid var(--border);position:relative}
.notif-item:hover{background:var(--surface-2)}
.notif-item.unread::before{content:'';position:absolute;left:8px;top:22px;width:6px;height:6px;border-radius:50%;background:var(--brand)}
.notif-item:last-child{border-bottom:none}
.notif-body{flex:1;min-width:0}
.notif-t{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;line-height:1.35}
.notif-m{font-size:12px;color:var(--text-muted);line-height:1.45;font-weight:400}
.notif-time{font-size:11px;color:var(--text-subtle);margin-top:6px;font-weight:500}
#notifBackdrop{position:fixed;inset:0;z-index:140;display:none}
#notifBackdrop.open{display:block}

/* USER MENU */
#userMenu{position:fixed;bottom:16px;left:var(--sidebar-w);margin-left:12px;width:260px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);overflow:hidden;display:none;z-index:150;animation:scaleIn var(--dur) var(--ease-out)}
#userMenu.open{display:block}
.app.sidebar-collapsed #userMenu{left:var(--sidebar-w-collapsed)}
.umenu-head{padding:16px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.umenu-item{display:flex;align-items:center;gap:11px;padding:10px 16px;cursor:pointer;font-size:13px;color:var(--text-2);font-weight:500;transition:background var(--dur-fast) var(--ease)}
.umenu-item:hover{background:var(--surface-2);color:var(--text)}
.umenu-item svg{width:15px;height:15px;color:var(--text-muted)}
.umenu-sep{height:1px;background:var(--border);margin:6px 0}

/* MOBILE */
.mobile-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(4px);z-index:15;display:none}
.mobile-overlay.open{display:block;animation:fadeIn var(--dur) var(--ease)}
@media (max-width:900px){
  .app{grid-template-columns:1fr !important}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);transform:translateX(-100%);transition:transform var(--dur) var(--ease);z-index:25;box-shadow:var(--shadow-xl)}
  .sidebar.open{transform:translateX(0)}
  #userMenu{left:12px !important}
  .topbar{padding:0 20px}
  .content{padding:20px}
  .page-title{font-size:24px}
  #notifPanel{right:10px;left:10px;width:auto;top:64px}
}

/* UTILITIES */
.row{display:flex;align-items:center;gap:8px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.col{display:flex;flex-direction:column;gap:8px}
.flex-1{flex:1}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:780px){.grid-2,.grid-3{grid-template-columns:1fr}}
.hide-sm{display:initial}
@media (max-width:640px){.hide-sm{display:none}}
.text-ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.skel{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r-sm)}
.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}
.dropdown{position:relative;display:inline-block}
.dropdown-menu{position:absolute;right:0;top:calc(100% + 4px);min-width:180px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:4px;z-index:50;display:none}
.dropdown-menu.open{display:block;animation:scaleIn var(--dur-fast) var(--ease-out);transform-origin:top right}
.dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-2);border-radius:var(--r-sm);cursor:pointer}
.dropdown-item:hover{background:var(--surface-2);color:var(--text)}
.dropdown-item.danger{color:var(--danger)}
.dropdown-item.danger:hover{background:var(--danger-bg)}
.t-success{color:var(--success) !important}
.t-danger{color:var(--danger) !important}
.t-warning{color:var(--warning) !important}
.t-brand{color:var(--brand) !important}
.t-muted{color:var(--text-muted) !important}
.banner{display:flex;align-items:center;gap:14px;padding:16px 20px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);margin-bottom:20px}
.banner-icon{width:40px;height:40px;border-radius:var(--r);background:var(--brand-wash);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.banner-body{flex:1;min-width:0}
.banner-title{font-size:14px;font-weight:700;color:var(--text)}
.banner-text{font-size:12.5px;color:var(--text-muted);margin-top:2px;font-weight:400}

.profile-hero{background:linear-gradient(135deg,var(--surface) 0%,var(--brand-tint) 100%);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 32px;position:relative;overflow:hidden;margin-bottom:20px}
.profile-hero::before{content:'';position:absolute;top:-60px;right:-40px;width:220px;height:220px;background:radial-gradient(circle,var(--brand-soft) 0%,transparent 65%);opacity:.55;pointer-events:none}
.profile-hero-row{position:relative;z-index:1;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.profile-hero-row .avatar{width:80px;height:80px;border:3px solid var(--surface);box-shadow:var(--shadow-sm);font-size:26px;flex-shrink:0}
.profile-hero-info{flex:1;min-width:200px}
.profile-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.profile-name{font-family:var(--font);font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--text);line-height:1.2}
.profile-kicker{font-size:13.5px;color:var(--text-muted);font-weight:500;margin-top:2px}

/* KV rows — properly sized icons */
.kv-row{padding:12px 0;border-bottom:1px solid var(--border)}
.kv-row:last-child{border-bottom:none}
.kv-label{display:flex;align-items:center;gap:7px;font-size:10.5px;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.kv-icon{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;flex-shrink:0;color:var(--text-muted)}
.kv-icon svg{width:13px !important;height:13px !important}
.kv-value{font-size:13.5px;font-weight:500;color:var(--text);line-height:1.4;word-break:break-word}
.kudos-card{background:linear-gradient(135deg,var(--brand-tint) 0%,var(--brand-wash) 100%);border:1px solid var(--brand-soft);border-radius:var(--r-lg);padding:20px;position:relative;overflow:hidden}
.kudos-card::before{content:'';position:absolute;top:-40px;right:-30px;width:140px;height:140px;background:radial-gradient(circle,var(--brand-soft) 0%,transparent 60%);pointer-events:none;opacity:.6}

/* ═══════════════════════════════════════════════════════════════════
   v2 UPGRADE — validation, undo, polish
   ═══════════════════════════════════════════════════════════════════ */

/* Field error state */
.input.input-error, .select.input-error, .textarea.input-error{
  border-color:var(--danger) !important;
  box-shadow:0 0 0 3px rgba(239,68,68,.1);
}
.field-error{
  margin-top:6px;font-size:12px;color:var(--danger);font-weight:500;
  display:flex;align-items:center;gap:5px;
  animation:slideDown var(--dur) var(--ease);
}
.field-error::before{content:'!';display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:var(--danger);color:#fff;border-radius:50%;font-size:9px;font-weight:700;flex-shrink:0}

/* Undo snackbar */
.undo-bar{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--text);color:#fff;padding:12px 14px 12px 20px;
  border-radius:var(--r-md);box-shadow:var(--shadow-xl);
  display:flex;align-items:center;gap:14px;
  font-family:var(--font);font-size:13.5px;font-weight:500;
  z-index:600;min-width:300px;max-width:480px;
  animation:slideUp var(--dur-slow) var(--ease-out);
}
.undo-btn{
  background:transparent;border:1px solid rgba(255,255,255,.3);
  color:#fff;padding:6px 14px;border-radius:var(--r-sm);
  font-size:12.5px;font-weight:600;cursor:pointer;
  transition:all var(--dur-fast) var(--ease);
}
.undo-btn:hover{background:var(--brand);border-color:var(--brand)}
@keyframes slideUp{from{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%,0)}}

/* Improved kbd badge */
.kbd{
  font-family:var(--font);font-size:10.5px;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;
  height:22px;min-width:22px;padding:0 7px;
  background:var(--surface);border:1px solid var(--border-2);
  border-bottom-width:2px;border-radius:5px;
  color:var(--text-2);letter-spacing:0;
}

/* Better stat card on dashboard */
.stat-card.brand{
  background:linear-gradient(135deg,#ff6b35 0%,#f5471d 100%);color:#fff;border:none;
  position:relative;overflow:hidden;
  box-shadow:0 6px 20px rgba(255,107,53,0.28);
}
.stat-card.brand::before{
  content:'';position:absolute;top:-30px;right:-30px;width:140px;height:140px;
  background:radial-gradient(circle,rgba(255,255,255,0.22) 0%,transparent 70%);
  border-radius:50%;animation:brandPulse 4s ease-in-out infinite;
}
@keyframes brandPulse{
  0%,100%{transform:scale(1);opacity:0.8}
  50%{transform:scale(1.15);opacity:1}
}
.stat-card.brand:hover{
  box-shadow:0 12px 32px rgba(255,107,53,0.42);
  transform:translateY(-4px);
}
.stat-card.brand .stat-label{color:rgba(255,255,255,.85)}
.stat-card.brand .stat-value{color:#fff}
.stat-card.brand .stat-trend{color:rgba(255,255,255,.85)}

/* Activity feed item */
.activity-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.activity-item:last-child{border-bottom:none}
.activity-dot{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--brand-wash);color:var(--brand);
}
.activity-dot svg{width:14px;height:14px}
.activity-body{flex:1;min-width:0}
.activity-text{font-size:13px;color:var(--text);line-height:1.45}
.activity-meta{font-size:11.5px;color:var(--text-muted);margin-top:3px;font-weight:500}

/* Pulse dot for live indicators */
.pulse-dot{position:relative;display:inline-flex;width:8px;height:8px;background:var(--success);border-radius:50%}
.pulse-dot::before{content:'';position:absolute;inset:0;background:var(--success);border-radius:50%;animation:pulse-ring 1.6s var(--ease) infinite}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}100%{transform:scale(2.4);opacity:0}}

/* Better mobile drawer */
@media (max-width:900px){
  .topbar-toggle{display:flex !important}
  .sidebar.open{box-shadow:0 25px 50px rgba(0,0,0,.25)}
}

/* Mini chart bars */
.mini-chart{display:flex;align-items:flex-end;gap:3px;height:50px;padding:4px 0}
.mini-bar{flex:1;background:var(--brand);border-radius:3px 3px 0 0;min-height:4px;transition:height var(--dur-slow) var(--ease-out)}
.mini-bar.muted{background:var(--surface-3)}

/* Profile change request highlight */
.req-item{
  display:flex;align-items:flex-start;gap:14px;padding:16px;
  border:1px solid var(--border);border-radius:var(--r-lg);
  margin-bottom:10px;transition:all var(--dur-fast) var(--ease);
}
.req-item:hover{border-color:var(--border-2);box-shadow:var(--shadow-xs)}

/* Empty state with action */
.empty-action .btn{display:inline-flex}


/* ═══════════════════════════════════════════════════════════════════
   v3 POLISH — final UI refinement pass
   ═══════════════════════════════════════════════════════════════════ */

/* Smoother button interactions */
.btn{
  transition:transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease) !important;
  will-change:transform;
}
.btn:hover:not(:disabled){transform:translateY(-1px)}
.btn:active:not(:disabled){transform:translateY(0)}

/* Brand button — premium gradient with subtle shadow lift */
.btn-brand{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 100%) !important;
  box-shadow:0 1px 2px rgba(255,107,53,.12), 0 0 0 1px rgba(255,107,53,.04);
}
.btn-brand:hover:not(:disabled){
  box-shadow:0 6px 16px rgba(255,107,53,.28), 0 0 0 1px rgba(255,107,53,.06);
}

/* Card hover lift */
.card-hover, .card.card-hover{
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card-hover:hover{transform:translateY(-2px); box-shadow:var(--shadow-lg); border-color:var(--brand-soft)}

/* Pretty focus rings on inputs */
.input:focus, .select:focus, .textarea:focus{
  outline:none;
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(255,107,53,.13);
}

/* Polished sidebar nav items */
.nav-item{position:relative; transition:all var(--dur-fast) var(--ease)}
.nav-item::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:0;background:var(--brand);border-radius:0 4px 4px 0;
  transition:height var(--dur) var(--ease);
}
.nav-item.active::before{height:24px}
.nav-item:hover{background:var(--surface-2);color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,var(--brand-tint) 0%,transparent 100%); color:var(--brand); font-weight:600}
.nav-item.active .nav-icon{color:var(--brand)}

/* Better count badges */
.nav-count, .top-badge{
  background:linear-gradient(135deg,var(--danger) 0%,#dc2626 100%);
  color:#fff;font-weight:700;font-size:10.5px;
  min-width:18px;height:18px;padding:0 5px;border-radius:99px;
  display:flex;align-items:center;justify-content:center;
  letter-spacing:0;line-height:1;
  box-shadow:0 1px 3px rgba(220,38,38,.3);
  animation:badge-in var(--dur) var(--ease-out);
}
@keyframes badge-in{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}

/* Avatar with subtle ring on hover */
.avatar{transition:transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease)}
.avatar:hover{transform:scale(1.05); box-shadow:0 0 0 3px var(--brand-soft)}

/* Stat-card refinement */
.stat-card{
  position:relative;overflow:hidden;
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.stat-card:hover{transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--border-2)}
.stat-card .stat-label{font-size:11.5px;letter-spacing:.05em;text-transform:uppercase}
.stat-card .stat-value{font-size:30px;font-weight:800;letter-spacing:-.025em;line-height:1.1}
.stat-card.brand:hover{box-shadow:0 8px 20px rgba(255,107,53,.25)}

/* Page transitions */
.page{animation:page-in var(--dur) var(--ease-out)}
@keyframes page-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* Empty state polish */
.empty{padding:48px 20px;text-align:center}
.empty-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:50%;
  background:var(--surface-2);color:var(--text-muted);
  margin-bottom:14px;
}
.empty-icon svg{width:24px;height:24px}
.empty-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.01em}
.empty-text{font-size:13px;color:var(--text-muted);max-width:380px;margin:0 auto;line-height:1.5}
.empty-action{margin-top:16px}

/* Subtle scroll indicators */
.tbl-wrap::-webkit-scrollbar, .modal-body::-webkit-scrollbar{width:8px;height:8px}
.tbl-wrap::-webkit-scrollbar-track, .modal-body::-webkit-scrollbar-track{background:transparent}
.tbl-wrap::-webkit-scrollbar-thumb, .modal-body::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}
.tbl-wrap::-webkit-scrollbar-thumb:hover, .modal-body::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}

/* Better table rows */
.tbl tbody tr{transition:background var(--dur-fast) var(--ease)}
.tbl tbody tr:hover{background:var(--surface-2)}

/* Toast animation polish */
.toast{
  animation:toast-in var(--dur) var(--ease-out);
  box-shadow:var(--shadow-lg);
}
@keyframes toast-in{from{opacity:0;transform:translateX(20px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}

/* Modal animations */
.modal-bg{transition:opacity var(--dur) var(--ease)}
.modal-bg.open{animation:fadeIn var(--dur) var(--ease)}
.modal-bg.open .modal{animation:modalUp var(--dur-slow) var(--ease-out)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes modalUp{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Login page polish */
.login-card{
  animation:login-in 600ms var(--ease-out);
  box-shadow:0 1px 3px rgba(15,23,42,.04), 0 12px 40px rgba(15,23,42,.08);
}
@keyframes login-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* Avatar sizes — guarantee dimensions */
.avatar.avatar-xl{width:80px;height:80px;font-size:24px;font-weight:700}
.avatar.avatar-lg{width:48px;height:48px;font-size:16px;font-weight:700}
.avatar.avatar-md{width:36px;height:36px;font-size:13px;font-weight:600}
.avatar.avatar-sm{width:28px;height:28px;font-size:11px;font-weight:600}
.avatar.avatar-xs{width:22px;height:22px;font-size:9px;font-weight:600}

/* Better section dividers */
.divider{
  height:1px;background:linear-gradient(90deg,transparent 0%,var(--border) 50%,transparent 100%);
  margin:18px 0;border:none;
}

/* Mobile improvements */
@media (max-width:640px){
  .stat-card .stat-value{font-size:24px}
  .page-title{font-size:20px !important}
  .page-header{flex-direction:column;align-items:flex-start;gap:14px}
  .page-actions{width:100%;flex-wrap:wrap}
  .page-actions .input{flex:1;min-width:200px}
  .modal{margin:16px;max-width:calc(100vw - 32px) !important}
  .grid-2{grid-template-columns:1fr !important}
  .topbar{padding:0 16px}
  .topbar-title{font-size:15px}
  .breadcrumb{display:none}
}

/* Skeleton shimmer */
.skel{
  background:linear-gradient(90deg, var(--surface-2) 0%, var(--surface-3) 50%, var(--surface-2) 100%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite linear;
  border-radius:6px;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Consistent badge variants */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:99px;
  font-size:11px;font-weight:600;letter-spacing:.01em;line-height:1.4;
  white-space:nowrap;
}
.badge-dot{
  width:6px;height:6px;border-radius:50%;background:currentColor;
  flex-shrink:0;
}
.badge-success{background:#D1FAE5;color:#047857}
.badge-warning{background:#FEF3C7;color:#B45309}
.badge-danger{background:#FEE2E2;color:#B91C1C}
.badge-info{background:#DBEAFE;color:#1E40AF}
.badge-neutral{background:var(--surface-2);color:var(--text-muted)}
.badge-brand{background:var(--brand-tint);color:var(--brand-dk)}

/* Spinner */
.spinner{
  width:14px;height:14px;border:2px solid var(--border-2);
  border-top-color:var(--brand);border-radius:50%;
  animation:spin .7s linear infinite;display:inline-block;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Action banner (used for forced password change, etc.) */
.banner{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 16px;border-radius:var(--r-md);
  background:var(--brand-tint);border:1px solid var(--brand-soft);
}
.banner-icon{
  width:32px;height:32px;border-radius:50%;
  background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.banner-icon svg{width:14px;height:14px}
.banner-body{flex:1;min-width:0}
.banner-title{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:2px}
.banner-text{font-size:12.5px;color:var(--text-muted);line-height:1.5}

/* Make user chip in sidebar bottom feel premium */
.user-chip{
  transition:background var(--dur-fast) var(--ease);
  padding:10px 12px;border-radius:var(--r-md);cursor:pointer;
}
.user-chip:hover{background:var(--surface-2)}

/* Dashboard greeting card subtle background pattern */
.dash-hero{position:relative;overflow:hidden}
.dash-hero::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;
  background:radial-gradient(circle, var(--brand-soft) 0%, transparent 65%);
  opacity:.4;pointer-events:none;
}

/* Ensure SVG icons in everything stay 14-16px */
.btn svg{width:14px;height:14px;flex-shrink:0}
.btn.btn-sm svg, .btn.btn-xs svg{width:12px;height:12px}
.nav-icon svg{width:16px;height:16px}



/* Activity items — staggered slide-in */
.activity-item{
  display:flex;align-items:flex-start;gap:12px;padding:11px 0;
  border-bottom:1px solid rgba(0,0,0,0.04);
  animation:activityIn 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
#dashActivity .activity-item:nth-child(1){animation-delay:0.30s}
#dashActivity .activity-item:nth-child(2){animation-delay:0.36s}
#dashActivity .activity-item:nth-child(3){animation-delay:0.42s}
#dashActivity .activity-item:nth-child(4){animation-delay:0.48s}
#dashActivity .activity-item:nth-child(5){animation-delay:0.54s}
#dashActivity .activity-item:nth-child(n+6){animation-delay:0.60s}
.activity-item:last-child{border-bottom:none}
@keyframes activityIn{
  0%{opacity:0;transform:translateX(-8px)}
  100%{opacity:1;transform:translateX(0)}
}
.activity-dot{
  width:32px;height:32px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--brand-soft,rgba(255,107,53,0.1)),rgba(255,170,80,0.06));
  color:var(--brand);
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,107,53,0.12);
}
.activity-dot svg{width:14px;height:14px}
.activity-body{flex:1;min-width:0}
.activity-text{font-size:13px;color:var(--text);font-weight:500;margin-bottom:2px}
.activity-meta{font-size:11px;color:var(--text-muted);font-weight:500;letter-spacing:0.02em}



/* Page entrance — fade up smoothly when navigating */
.page.active{
  animation:pageIn 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes pageIn{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}
}

/* Greeting card — animated background orb */
.page-header + .card.card-pad-lg [style*="position:absolute"][style*="border-radius"]{
  animation:orbDrift 12s ease-in-out infinite;
}
@keyframes orbDrift{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-20px,15px) scale(1.08)}
}

/* Progress bar fill — animated grow */
.progress-fill{
  transition:width 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
  animation:progressGrow 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes progressGrow{
  0%{width:0 !important}
}

/* Card hover — subtle lift */
.card{
  transition:transform 0.25s ease, box-shadow 0.25s ease, border-color 0.2s ease;
}

/* Icon button hover — subtle bounce */
.btn{
  transition:transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.btn-brand:hover{
  transform:translateY(-1px);
}

/* Sidebar items — slide indicator on hover/active */
.nav-item{
  position:relative;
  transition:background 0.2s ease, color 0.2s ease, padding-left 0.25s ease;
}
.nav-item::before{
  content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;
  background:linear-gradient(180deg,#ffd54f,#ff6b35);
  border-radius:0 3px 3px 0;
  transform:scaleY(0);transform-origin:center;
  transition:transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.nav-item.active::before,
.nav-item:hover::before{transform:scaleY(1)}
.nav-item.active{padding-left:18px}

/* Smoother section transitions throughout app */
.grid-2 > .card,
.grid-3 > .card{
  animation:cardFadeIn 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}
.grid-2 > .card:nth-child(1),.grid-3 > .card:nth-child(1){animation-delay:0.1s}
.grid-2 > .card:nth-child(2),.grid-3 > .card:nth-child(2){animation-delay:0.18s}
.grid-3 > .card:nth-child(3){animation-delay:0.26s}
@keyframes cardFadeIn{
  0%{opacity:0;transform:translateY(12px)}
  100%{opacity:1;transform:translateY(0)}
}

/* Number values — count-up shimmer feel */
.stat-value.num,.num{
  font-variant-numeric:tabular-nums;
  letter-spacing:-0.02em;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .stat-card,.activity-item,.page.active,.card,.progress-fill,
  .stat-card.brand::before,.grid-2 > .card,.grid-3 > .card{
    animation:none !important;
    transition:none !important;
  }
}



/* ═══ UI Upgrade: Premium card polish ═══ */

/* Generic card hover — subtle lift everywhere */
.card-hover{
  transition:transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease, border-color 0.2s ease;
  cursor:pointer;
}
.card-hover:hover{
  transform:translateY(-3px);
  border-color:rgba(255,107,53,0.2);
  box-shadow:0 12px 28px rgba(15,23,42,0.06), 0 4px 12px rgba(255,107,53,0.08);
}

/* Directory grid card — premium employee card */
#dirResult > div > .card.card-hover{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, #fff 0%, #fffaf5 100%);
}
#dirResult > div > .card.card-hover::before{
  content:'';position:absolute;top:0;left:0;right:0;height:60px;
  background:linear-gradient(180deg, rgba(255,213,79,0.10) 0%, transparent 100%);
  pointer-events:none;
}
#dirResult > div > .card.card-hover:hover::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, #ffd54f, #ff6b35);
  border-radius:12px 12px 0 0;
}

/* Avatars — cleaner gradient ring on hover */
.av{
  transition:transform 0.25s ease, box-shadow 0.25s ease;
  position:relative;
}
.card-hover:hover .av{
  transform:scale(1.05);
  box-shadow:0 8px 24px rgba(0,0,0,0.08);
}

/* Icon buttons (mail, phone) — fancier hover */
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:9px;
  background:#fff;border:1px solid var(--border);color:var(--text-muted);
  text-decoration:none;
  transition:all 0.2s ease;
}
.icon-btn:hover{
  background:linear-gradient(135deg,#fff5ee,#ffe9d8);
  border-color:#ff6b35;color:#ff6b35;
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(255,107,53,0.12);
}
.icon-btn svg{width:15px;height:15px}

/* Department/role badges — refined */
.badge{
  font-size:10.5px;padding:3px 9px;
  border-radius:999px;font-weight:600;letter-spacing:0.01em;
  display:inline-flex;align-items:center;gap:4px;
}
.badge-neutral{
  background:rgba(15,23,42,0.05);color:var(--text-muted);
  text-transform:capitalize;
}
.badge-brand{
  background:linear-gradient(135deg,rgba(255,213,79,0.18),rgba(255,107,53,0.12));
  color:#c4441a;
}
.badge-warning{background:rgba(245,158,11,0.12);color:#b45309}
.badge-success{background:rgba(34,197,94,0.12);color:#15803d}
.badge-danger{background:rgba(239,68,68,0.12);color:#b91c1c}
.badge-info{background:rgba(59,130,246,0.12);color:#1d4ed8}

/* Page header — better breathing room */
.page-header{
  margin-bottom:24px;display:flex;justify-content:space-between;
  align-items:flex-start;gap:16px;flex-wrap:wrap;
}
.page-title{
  font-family:var(--font-display, var(--font));
  font-size:28px;font-weight:800;letter-spacing:-0.025em;
  color:#0F172A;line-height:1.1;margin-bottom:4px;
}
.page-sub{font-size:14px;color:var(--text-muted);font-weight:500}

/* Tab bar underlined — animated indicator */
.tabs-underline{
  display:flex;gap:4px;border-bottom:1px solid var(--border);
  padding:0 16px;
}
.tab-under{
  padding:11px 14px;font-size:13.5px;font-weight:500;
  color:var(--text-muted);cursor:pointer;
  border-bottom:2px solid transparent;
  transition:color 0.2s ease, border-color 0.2s ease;
  position:relative;
}
.tab-under:hover{color:var(--text)}
.tab-under.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}

/* Inputs — better focus ring */
.input,.select,textarea.input{
  transition:all 0.2s ease;
}
.input:focus,.select:focus,textarea.input:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 4px rgba(255,107,53,0.12);
  outline:none;
}

/* Buttons — micro-interactions */
.btn{transition:transform 0.15s ease, background 0.2s ease, box-shadow 0.2s ease}
.btn:active{transform:translateY(1px) scale(0.98)}
.btn-brand{
  background:linear-gradient(135deg,#ff6b35 0%,#f5471d 100%);
  box-shadow:0 2px 6px rgba(255,107,53,0.18);
}
.btn-brand:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(255,107,53,0.32);
}

/* Toast — smoother slide-in */
.toast{
  animation:toastIn 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  border-radius:12px;
  box-shadow:0 12px 28px rgba(15,23,42,0.12);
}
@keyframes toastIn{
  0%{opacity:0;transform:translateY(-12px) scale(0.94)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

/* Modal — premium look */
.modal-card{
  border-radius:16px;
  box-shadow:0 24px 60px rgba(15,23,42,0.18), 0 4px 12px rgba(15,23,42,0.06);
  animation:modalIn 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes modalIn{
  0%{opacity:0;transform:translateY(20px) scale(0.96)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}

/* Empty states — gentle */
.empty{padding:32px 16px;text-align:center}
.empty-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:14px;
  background:linear-gradient(135deg,#fff5ee,#ffe9d8);
  color:#ff6b35;margin-bottom:12px;
}
.empty-icon svg{width:22px;height:22px}
.empty-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px}
.empty-text{font-size:12.5px;color:var(--text-muted)}

/* Avatar gradient backgrounds — varied & vibrant */
.av-xl{width:64px;height:64px;font-size:22px}
.av{
  font-weight:700;letter-spacing:-0.02em;
  font-family:var(--font-display,var(--font));
}