/* ============ DESIGN SYSTEM: VARIABLES ============ */
:root{
  /* Colors - Light Mode */
  --bg:#f8fafc;--bg2:#ffffff;--bg3:#f1f5f9;--tx:#1e293b;--tx2:#64748b;--tx3:#94a3b8;--brd:#e2e8f0;
  --green:#22c55e;--greenlt:#dcfce7;--greendark:#16a34a;--money:#34d399;--gold:#eab308;
  --red:#ef4444;--blue:#2563eb;--bluelt:#dbeafe;--purple:#7c3aed;
  --sidebar:#ffffff;--sidebartx:#64748b;--sidebar-active:#f1f5f9;--sidebar-hover:#f8fafc;
  /* Shadows */
  --shadow:0 1px 3px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px -2px rgba(0,0,0,.06),0 2px 6px -2px rgba(0,0,0,.04);
  --shadow-lg:0 8px 24px -4px rgba(0,0,0,.08),0 4px 12px -4px rgba(0,0,0,.05);
  --shadow-xl:0 20px 40px -8px rgba(0,0,0,.12),0 8px 20px -6px rgba(0,0,0,.06);
  /* Glass */
  --glass:rgba(255,255,255,.7);--glass-border:rgba(226,232,240,.5);
  --glass-strong:rgba(255,255,255,.85);--glass-subtle:rgba(255,255,255,.35);
  /* Radius */
  --radius:12px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;
  /* Spacing */
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-12:48px;
  /* Accent */
  --primary:#85adff;--primary-dim:#699cff;--primary-container:#dbeafe;
  --secondary:#69f6b8;--tertiary:#ac8aff;--error:#ff716c;
  /* Neon */
  --neon-blue:rgba(133,173,255,.35);--neon-green:rgba(16,185,129,.35);--neon-purple:rgba(172,138,255,.35);
  /* Transitions */
  --ease-fast:.15s cubic-bezier(.4,0,.2,1);--ease-smooth:.25s cubic-bezier(.4,0,.2,1);--ease-spring:.4s cubic-bezier(.16,1,.3,1)
}
.dark{
  --bg:#060e20;--bg2:#0f1930;--bg3:#192540;--tx:#dee5ff;--tx2:#a3aac4;--tx3:#6d758c;
  --brd:rgba(64,72,93,.4);--greenlt:#002114;--bluelt:#002150;
  --sidebar:#192540;--sidebartx:#dee5ff;--sidebar-active:#253352;--sidebar-hover:rgba(37,51,82,.6);
  --shadow:0 2px 12px rgba(0,0,0,.4);--shadow-md:0 4px 16px rgba(0,0,0,.45);
  --shadow-lg:0 8px 30px rgba(0,0,0,.5);--shadow-xl:0 20px 60px rgba(0,0,0,.6);
  --glass:rgba(15,25,48,.7);--glass-border:rgba(64,72,93,.15);
  --glass-strong:rgba(15,25,48,.9);--glass-subtle:rgba(15,25,48,.45)
}

/* ============ RESET & BASE ============ */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg);color:var(--tx);overflow:hidden;height:100vh;height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4{font-family:'Manrope','Inter',system-ui,sans-serif;font-weight:700;letter-spacing:-0.02em}
.mono{font-family:'SF Mono','Fira Code',Consolas,monospace;font-size:0.92em}
.app{display:flex;height:100vh;height:100dvh}

/* ============ SIDEBAR ============ */
.sidebar{width:264px;background:var(--sidebar);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--sidebartx);display:flex;flex-direction:column;flex-shrink:0;height:100vh;height:100dvh;position:relative;transition:width .3s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--brd);box-shadow:4px 0 24px rgba(0,0,0,.03)}
.dark .sidebar{background:var(--bg)!important;box-shadow:none;border-right:1px solid rgba(64,72,93,.3)}
.sidebar .sb-mid{flex:1;overflow-y:auto;min-height:0;scrollbar-width:thin}
.sb-bottom{padding:12px 16px;border-top:1px solid var(--brd);display:flex;flex-direction:column;gap:4px;flex-shrink:0;background:var(--bg3)}
.sidebar.collapsed{width:56px;overflow:hidden}
.sidebar.collapsed .sb-logo-text,.sidebar.collapsed .sb-stats,.sidebar.collapsed .sb-emp,.sidebar.collapsed .sb-missing,.sidebar.collapsed .sb-item span,.sidebar.collapsed .sb-badge,.sidebar.collapsed .sb-btn span{display:none}
.sidebar.collapsed .sb-item{justify-content:center;padding:10px 0}

/* ============ SIDEBAR: LOGO ============ */
.sb-logo{padding:20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--brd)}
.sb-logo-text{font-family:'Inter',system-ui,sans-serif;font-size:13px;color:#fff;line-height:1.3;font-weight:600;letter-spacing:-0.01em}

/* ============ SIDEBAR: USER PROFILE ============ */
.sb-user{padding:14px 18px;margin:8px 12px;border-radius:var(--radius-md);border:1px solid var(--brd);background:var(--bg3);backdrop-filter:blur(8px)}
.dark .sb-user{background:var(--bg3);border-color:rgba(64,72,93,.3)}
.sb-user-name{font-size:16px;font-weight:700;color:var(--tx);letter-spacing:-0.01em;display:flex;align-items:center;gap:10px}
.dark .sb-user-name{color:#fff}
.sb-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#85adff,#69f6b8);flex-shrink:0;box-shadow:0 2px 12px rgba(133,173,255,.3);border:2px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#0a1428;font-family:'Manrope',system-ui,sans-serif;letter-spacing:-.02em}
.sb-stats{font-size:13px;margin-top:12px;color:var(--sidebartx);line-height:2.0}
.sb-stats .hl{color:var(--money);font-weight:600}

/* ============ SIDEBAR: NAV ============ */
.sb-nav{flex:1;padding:12px 8px}
.sb-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;color:var(--sidebartx);font-size:13px;font-weight:500;border-left:3px solid transparent;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin:2px 0;transition:all var(--ease-smooth);position:relative}
.sb-item:hover{background:var(--sidebar-hover);color:var(--tx);transform:translateX(3px)}
.dark .sb-item:hover{background:var(--sidebar-hover);color:#dee5ff}
.sb-item.active{background:var(--sidebar-active);color:var(--blue);border-left-color:var(--blue);font-weight:600;box-shadow:0 0 24px rgba(133,173,255,.05)}
.dark .sb-item.active{background:var(--sidebar-active);color:#85adff;border-left-color:transparent}
.dark .sb-item.active::after{content:'';position:absolute;left:0;top:12%;bottom:12%;width:3px;background:linear-gradient(180deg,#85adff,#69f6b8);border-radius:0 3px 3px 0;box-shadow:0 0 8px rgba(133,173,255,.4)}
/* Material Symbols in sidebar */
.sb-item .material-symbols-outlined{font-size:20px;transition:all var(--ease-fast)}
.sb-item.active .material-symbols-outlined{font-variation-settings:'FILL' 1,'wght' 600}
.sidebar.collapsed .sb-item .material-symbols-outlined{font-size:18px;margin:0}
.sb-badge{background:linear-gradient(135deg,var(--green),var(--greendark));color:#fff;font-size:10px;padding:2px 8px;border-radius:10px;margin-left:auto;font-weight:600;box-shadow:0 2px 6px rgba(77,184,146,.3)}

/* ============ SIDEBAR: EMPLOYEE MONITOR ============ */
.sb-emp{padding:14px 20px;border-top:1px solid var(--brd)}
.sb-emp-row{font-size:13px;padding:8px 0;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:2px;transition:background .15s}
.sb-emp-row:hover{background:rgba(255,255,255,.03);border-radius:6px}

/* ============ SIDEBAR: BOTTOM BUTTONS ============ */
.sb-btn{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--sidebartx);border:none;background:transparent;width:100%;text-align:left;transition:all .15s}
.sb-btn:hover{background:var(--sidebar-hover);color:var(--tx);transform:translateX(2px)}

/* ============ CASE COUNTER ANIMATION ============ */
@keyframes countBounce{0%{transform:scale(1)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
@keyframes slideInLeft{from{transform:translateX(-100%);opacity:0}to{transform:translateX(0);opacity:1}}
.count-bounce{animation:countBounce .3s ease}
.str-meter{height:6px;border-radius:3px;background:var(--bg3);overflow:hidden;margin-top:6px}
.str-meter-fill{height:100%;border-radius:3px;transition:width .5s ease}

/* ============ CONTENT TRANSITIONS ============ */
.content{transition:opacity .2s ease}
.ta-resize{resize:vertical;min-height:100px}

/* Touch-optimized mode */
.touch-mode .btn{padding:12px 20px!important;font-size:15px!important}
.touch-mode .diag-row{padding:10px 14px!important;font-size:15px!important}
.touch-mode .diag-row input[type=checkbox]{width:20px;height:20px}
.touch-mode .sb-item{padding:14px 20px!important;font-size:15px!important}
.touch-mode .hist-card{padding:14px!important}
.touch-mode textarea{font-size:15px!important}
.sb-collapse-btn{background:none;border:none;color:var(--sidebartx);cursor:pointer;padding:8px 12px;font-size:16px;border-top:1px solid var(--brd)}
@media(max-width:768px){.sidebar{width:200px;font-size:12px}.sidebar .sb-stats{font-size:11px;line-height:1.6}.sidebar .sb-emp{display:none}.sidebar .sb-missing{display:none}
.touch-mode .btn{padding:12px 20px!important;font-size:15px!important}
.touch-mode .diag-row{padding:10px 14px!important;font-size:15px!important}
.touch-mode .diag-row input[type=checkbox]{width:20px;height:20px}
.touch-mode .sb-item{padding:14px 20px!important;font-size:15px!important}
.touch-mode .hist-card{padding:14px!important}
.touch-mode textarea{font-size:15px!important}
.sb-collapse-btn{display:block}.content{padding:16px}}

/* ============ MAIN LAYOUT ============ */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.content{flex:1;overflow-y:auto;padding:28px 36px}

/* ============ LOGIN PAGE ============ */
.login-wrap{display:flex;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#020617 0%,#060e20 30%,#091328 60%,#020617 100%);position:relative;overflow:hidden}
.login-wrap::before{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(133,173,255,.12) 0%,transparent 70%);top:-100px;left:-100px;animation:orbFloat 15s ease-in-out infinite;pointer-events:none}
.login-wrap::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(105,246,184,.08) 0%,transparent 70%);bottom:-80px;right:-80px;animation:orbFloat 18s ease-in-out infinite 5s;pointer-events:none}
@keyframes loginBgShift{0%{transform:translate(0,0) rotate(0deg)}100%{transform:translate(-2%,1%) rotate(1deg)}}
.login-box{background:rgba(15,25,48,.8);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-radius:var(--radius-2xl);padding:48px 40px;width:420px;box-shadow:0 25px 80px rgba(0,0,0,.5),0 0 60px rgba(133,173,255,.04);text-align:center;position:relative;z-index:1;animation:loginBoxIn .6s cubic-bezier(.16,1,.3,1) both,borderGlow 4s ease-in-out infinite 1s;border:1px solid rgba(133,173,255,.12);overflow:hidden}
.login-box::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(172,138,255,.06) 0%,transparent 70%);top:-150px;right:-100px;animation:orbFloat 20s ease-in-out infinite 8s;pointer-events:none;z-index:-1}
@keyframes loginBoxIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.login-box h1{color:#fff;font-size:26px;margin-bottom:6px;font-weight:700;letter-spacing:-0.02em}
.login-logo{margin-bottom:28px;animation:loginLogoIn .8s cubic-bezier(.16,1,.3,1) both .1s}
@keyframes loginLogoIn{from{opacity:0;transform:scale(.8) rotate(-5deg)}to{opacity:1;transform:scale(1) rotate(0)}}
.login-tagline{color:rgba(200,204,216,.5);font-size:13px;margin-bottom:28px;letter-spacing:0.02em}
.login-input{width:100%;padding:13px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#fff;font-size:15px;margin-bottom:14px;outline:none;transition:all .2s;backdrop-filter:blur(10px)}
.login-input:focus{border-color:#85adff;box-shadow:0 0 0 3px rgba(133,173,255,.15);background:rgba(255,255,255,.06)}
.login-input::placeholder{color:rgba(200,204,216,.35)}
.login-btn{width:100%;padding:13px;border-radius:12px;border:none;background:linear-gradient(135deg,#85adff,#6e9fff);color:#002c66;font-size:15px;font-weight:700;cursor:pointer;margin-top:8px;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px rgba(133,173,255,.3);letter-spacing:0.01em}
.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(133,173,255,.4);background:linear-gradient(135deg,#9bbeff,#85adff)}
.login-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(133,173,255,.3)}
.login-err{color:var(--red);font-size:13px;margin-top:10px;animation:shakeErr .4s ease}
@keyframes shakeErr{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .2s}
.btn:hover::after{opacity:1}
.btn-green{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 2px 8px rgba(34,197,94,.25)}.btn-green:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(34,197,94,.35)}
.btn-red{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px rgba(239,68,68,.2)}.btn-red:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(239,68,68,.3)}
.btn-blue{background:linear-gradient(135deg,#85adff,#6e9fff);color:#002c66;box-shadow:0 2px 8px rgba(133,173,255,.25)}.btn-blue:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(133,173,255,.35)}
.btn-purple{background:linear-gradient(135deg,#ac8aff,#8f60fa);color:#fff;box-shadow:0 2px 8px rgba(172,138,255,.2)}.btn-purple:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(172,138,255,.3)}
.btn-gold{background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;box-shadow:0 2px 8px rgba(234,179,8,.2)}.btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(234,179,8,.3)}
.btn-outline{background:transparent;border:1px solid var(--brd);color:var(--tx)}.btn-outline:hover{background:var(--bg3);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}
.btn-icon{padding:6px;border-radius:6px;border:none;background:transparent;color:var(--tx2);cursor:pointer;display:inline-flex;align-items:center;transition:all .15s}
.btn-icon:hover{background:var(--bg3);color:var(--tx);transform:scale(1.1)}
.btn:active{transform:translateY(0) scale(.98)}

/* ============ CARDS ============ */
.card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px) scale(1.002)}
.dark .card{background:rgba(15,25,48,.6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:rgba(64,72,93,.15)}

/* ============ FORM ELEMENTS ============ */
textarea{width:100%;border-radius:10px;border:1px solid var(--brd);padding:14px;font-size:14px;font-family:'Inter',system-ui;color:var(--tx);resize:vertical;outline:none;background:var(--bg2);transition:all .2s;line-height:1.6}
textarea:focus{border-color:#85adff;box-shadow:0 0 0 3px rgba(133,173,255,.1)}
.ta-case{background:#f0faf5;min-height:350px}.dark .ta-case{background:#132a1e}
.ta-rat{background:#f0f4fc;min-height:300px}.dark .ta-rat{background:#131e2e}
.ta-pi{font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:14px;min-height:120px;line-height:1.7;letter-spacing:0.01em}
input[type=text],input[type=password]{padding:9px 14px;border-radius:8px;border:1px solid var(--brd);background:var(--bg2);color:var(--tx);font-size:14px;outline:none;transition:all .2s}
input:focus{border-color:#85adff;box-shadow:0 0 0 3px rgba(133,173,255,.1)}

/* ============ BADGES ============ */
.badge{display:inline-block;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:0.01em}
.badge-green{background:var(--greenlt);color:var(--green)}
.badge-gold{background:#fdf3e0;color:var(--gold)}.dark .badge-gold{background:#2e2820}
.badge-blue{background:var(--bluelt);color:var(--blue)}
.badge-purple{background:#f0e8fc;color:var(--purple)}.dark .badge-purple{background:#221a2e}
.diag-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:500;margin:2px;background:var(--greenlt);color:var(--greendark);transition:all .15s}
.diag-badge:hover{transform:scale(1.05)}
.analysis-box{border:2px solid var(--blue);border-radius:var(--radius);padding:18px;margin-bottom:16px;background:var(--bluelt);font-size:13px;line-height:1.7;white-space:pre-wrap}

/* ============ HISTORY CARDS ============ */
.hist-card{background:var(--bg2);border:1px solid var(--brd);border-radius:16px;padding:16px;margin:8px 0;transition:all .3s cubic-bezier(.4,0,.2,1);border-left:3px solid transparent;animation:histCardIn .3s ease both}
.hist-card:hover{box-shadow:var(--shadow-lg);transform:translateX(2px) scale(1.005);border-left-color:var(--blue)}
.dark .hist-card{background:rgba(15,25,48,.4);border-color:rgba(64,72,93,.15)}
.dark .hist-card:hover{border-left-color:#85adff;background:rgba(25,37,64,.5)}
@keyframes histCardIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.hist-card-top{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.hist-card-preview{font-size:13px;color:var(--tx2);margin:6px 0;line-height:1.5}
.hist-card-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}

/* ============ CALENDAR ============ */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-hdr{text-align:center;font-size:11px;font-weight:700;padding:8px;color:var(--tx2);text-transform:uppercase;letter-spacing:0.05em}
.cal-cell{text-align:center;padding:8px 4px;border-radius:8px;font-size:12px;min-height:56px;border:1px solid var(--brd);background:var(--bg2);transition:all .2s;cursor:default}
.cal-cell:not(.empty):hover{transform:scale(1.05);box-shadow:var(--shadow);z-index:1;position:relative}
.cal-cell.today{border-color:var(--green);font-weight:700}
.cal-cell.in-week{background:var(--greenlt);border-color:rgba(77,184,146,.3)}
.cal-cell.today{background:linear-gradient(135deg,#d0f5e5,#e0faf2);border:2px solid var(--green);box-shadow:0 0 12px rgba(77,184,146,.2)}.dark .cal-cell.today{background:linear-gradient(135deg,#1a3e2e,#132a20);box-shadow:0 0 12px rgba(77,184,146,.15)}
.cal-cell.empty{border-color:transparent;background:transparent}
.cal-cell .cnt{font-size:10px;color:var(--green);font-weight:600}
.cal-cell.payday-cell{background:linear-gradient(135deg,#fdf8e8,#fef5da);border:2px solid var(--gold);box-shadow:0 0 10px rgba(212,168,64,.15)}.dark .cal-cell.payday-cell{background:linear-gradient(135deg,#2e2820,#2a2418);border:2px solid var(--gold)}
.cal-nav{display:flex;align-items:center;gap:12px;margin-bottom:12px}

/* ============ TABS ============ */
.tabs{display:flex;gap:2px;background:var(--bg3);padding:4px;border-radius:12px;margin-bottom:24px;overflow-x:auto}
.tab{padding:8px 16px;cursor:pointer;font-size:13px;font-weight:600;color:var(--tx2);border-bottom:none;transition:all .2s;border-radius:8px;white-space:nowrap}
.tab:hover{color:var(--tx);background:var(--bg2)}
.tab.active{color:#fff;background:var(--blue);box-shadow:0 2px 8px rgba(37,99,235,.25)}
.dark .tab.active{background:#85adff;color:#002c66;box-shadow:0 2px 12px rgba(133,173,255,.3)}
.tab:hover{color:var(--tx);background:var(--bg3)}

/* ============ ANIMATIONS ============ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes progress{0%{width:10%;margin-left:0}50%{width:60%;margin-left:20%}100%{width:10%;margin-left:90%}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
@keyframes glow{0%,100%{box-shadow:0 0 5px rgba(77,184,146,.3)}50%{box-shadow:0 0 20px rgba(77,184,146,.5)}}
@keyframes celebratePulse{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}
@keyframes confettiFall{0%{transform:translateY(-100vh) rotate(0deg);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}
@keyframes fadeOverlay{from{opacity:0}to{opacity:1}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes orbFloat{0%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-40px) scale(1.1)}50%{transform:translate(-20px,-60px) scale(.95)}75%{transform:translate(-40px,-20px) scale(1.05)}100%{transform:translate(0,0) scale(1)}}
@keyframes borderGlow{0%,100%{border-color:rgba(133,173,255,.1)}50%{border-color:rgba(133,173,255,.3)}}
@keyframes neonPulse{0%,100%{box-shadow:0 0 5px var(--neon-blue)}50%{box-shadow:0 0 20px var(--neon-blue),0 0 40px rgba(133,173,255,.08)}}
@keyframes breathe{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.03)}}
@keyframes skeletonLoad{0%{background-position:-200% 0}100%{background-position:200% 0}}

.recording{animation:pulse 1s infinite}
.skeleton{background:linear-gradient(90deg,var(--bg3) 25%,var(--bg2) 50%,var(--bg3) 75%);background-size:200% 100%;animation:skeletonLoad 1.5s infinite linear;border-radius:var(--radius-sm)}
.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--brd);border-top-color:var(--green);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Page content entrance animation */
.content>div{animation:slideUp .3s ease both}

/* Wow factor: animated number highlight */
.wow-number{display:inline-block;transition:all .3s ease;font-variant-numeric:tabular-nums}
.wow-number:hover{transform:scale(1.1);color:var(--green)}

/* Note Writer prompt buttons */
.nw-prompt-btn{transition:all .2s cubic-bezier(.4,0,.2,1);transform:scale(1)}
.nw-prompt-btn:hover{transform:scale(1.04) translateY(-2px);box-shadow:0 4px 15px rgba(0,0,0,.15)}
.nw-model-btn{transition:all .15s}
.nw-model-btn:hover{opacity:.85;transform:scale(1.02)}

/* Mobile nav */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:999;background:rgba(255,255,255,.85);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:8px 8px calc(8px + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(226,232,240,.5);justify-content:space-around;align-items:center;box-shadow:0 -8px 32px rgba(0,0,0,.08);border-radius:20px 20px 0 0}
.dark .mobile-nav{background:rgba(9,19,40,.88);border-top-color:rgba(64,72,93,.15);box-shadow:0 -8px 32px rgba(0,0,0,.4)}
.mobile-nav button{background:none;border:none;color:var(--tx3);padding:6px 10px;border-radius:12px;cursor:pointer;font-size:10px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:3px;transition:all var(--ease-smooth);min-width:56px;min-height:48px;position:relative;justify-content:center;letter-spacing:.02em}
.mobile-nav button.mob-active{color:#85adff;font-weight:700}
.mobile-nav button.mob-active::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:5px;height:5px;background:linear-gradient(135deg,#85adff,#69f6b8);border-radius:50%;box-shadow:0 0 8px rgba(133,173,255,.5)}
.dark .mobile-nav button{color:#6d758c}
.dark .mobile-nav button.mob-active{color:#85adff}
/* Material Symbols in mobile nav */
.mobile-nav .material-symbols-outlined{font-size:22px;line-height:1;transition:all var(--ease-fast)}
.mobile-nav button.mob-active .material-symbols-outlined{font-variation-settings:'FILL' 1,'wght' 600}
.mob-icon{font-size:22px;line-height:1}

/* === MOBILE RESPONSIVE === */
@media(max-width:768px){
  .mobile-nav{display:flex!important}
  .sidebar{display:none!important}
  .main{margin-left:0!important;padding:12px!important;padding-bottom:140px!important}
  .action-bar{bottom:68px!important;left:0!important;padding:8px 10px!important;gap:6px!important;border-radius:12px 12px 0 0!important}
  .action-bar .btn{padding:8px 14px!important;font-size:12px!important;min-height:44px!important}
  .action-bar .btn span{font-size:12px!important}
  .pt-layout{flex-direction:column!important}
  .pt-sidebar{width:100%!important;order:-1!important;flex-direction:row!important;overflow-x:auto!important;gap:6px!important;padding-bottom:8px!important}
  .pt-sidebar>div{min-width:120px!important;flex-shrink:0!important}
  .card{padding:12px!important}
  h2{font-size:18px!important}
  /* Case tab: ensure diagnosis selector doesn't overlap action bar */
  .ta-case{min-height:200px!important}
  .content{padding-bottom:150px!important}
  .flex-between{flex-wrap:wrap;gap:8px}
  .flex-gap{flex-wrap:wrap;gap:6px}
  .cal-grid{font-size:10px!important}
  .cal-cell{padding:3px!important;min-height:40px!important}
  .cal-day{font-size:11px!important}
  .cal-cases{font-size:10px!important}
  .cal-pay{font-size:8px!important}
  .cal-hdr{font-size:10px!important}
  textarea{font-size:14px!important;min-height:150px!important}
  input[type=text],input[type=password],input[type=number],select{font-size:16px!important}
  .tracker-table{font-size:11px!important}
  .tracker-table th,.tracker-table td{padding:4px 6px!important}
  .badge{font-size:10px!important;padding:2px 6px!important}
  .btn{min-height:44px!important;min-width:44px!important}
  .btn-sm{min-height:36px!important;font-size:12px!important;padding:6px 12px!important}
  .login-box{width:90%!important;min-width:auto!important;padding:24px!important}
  .login-input{font-size:16px!important;padding:12px!important}
  .grid-2,.grid-3{grid-template-columns:1fr!important;gap:8px!important}
  .content{padding:10px 8px!important}
  .admin-user-card{min-width:auto!important;flex:1 1 100%!important}
}
@media(max-width:480px){
  .main{padding:6px!important;padding-bottom:70px!important}
  .card{padding:8px!important;margin-bottom:8px!important}
  h2{font-size:16px!important}
  .flex-gap{gap:4px}
  .cal-grid{gap:1px!important}
  .btn{font-size:13px!important}
  textarea{min-height:120px!important}
  .content{padding:6px 4px!important}
}

/* ============ SCROLLBAR ============ */
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--brd);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--tx3)}

/* ============ LAYOUT UTILITIES ============ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.flex-gap{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}.mb24{margin-bottom:24px}
.mt8{margin-top:8px}.mt12{margin-top:12px}
.tsm{font-size:13px}.txs{font-size:11px}

/* ============ CHAT ============ */
.chat-box{border:1px solid var(--brd);border-radius:var(--radius);padding:18px;margin-top:16px;background:var(--bg2);box-shadow:var(--shadow)}
.chat-msgs{max-height:250px;overflow-y:auto;margin-bottom:12px}
.chat-msg{padding:10px 14px;border-radius:12px;margin-bottom:8px;font-size:13px;line-height:1.6;white-space:pre-wrap;animation:slideUp .2s ease both}
.chat-msg.user{background:linear-gradient(135deg,var(--greenlt),rgba(77,184,146,.08));color:var(--tx);margin-left:40px;border-bottom-right-radius:4px}
.chat-msg.ai{background:var(--bg3);color:var(--tx);margin-right:40px;border-bottom-left-radius:4px}
.chat-input-row{display:flex;gap:8px;align-items:center}
.chat-input-row input{flex:1}

/* ============ TRACKER TABLE ============ */
.tracker-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:10px;overflow:hidden}
.tracker-table th{text-align:left;padding:12px 14px;font-size:11px;color:var(--tx2);border-bottom:2px solid var(--brd);font-weight:700;text-transform:uppercase;letter-spacing:0.05em;background:var(--bg3)}
.tracker-table td{padding:11px 14px;border-bottom:1px solid var(--brd);font-size:13px;transition:background .15s}
.tracker-table tr:hover td{background:var(--bg3)}
.tracker-table tr.today-row td{background:var(--greenlt);font-weight:600}

/* ============ TEMPLATE EDITOR ============ */
.tpl-handle{cursor:grab;color:var(--tx3);padding:0 4px;user-select:none;font-size:16px}
.tpl-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--brd);transition:background .15s}
.tpl-row:hover{background:var(--bg3)}
.diag-row:hover{background:var(--greenlt)!important;border-color:var(--green)!important}
.dark .diag-row:hover{background:#132a1e!important}

/* ============ MISSING SIDEBAR ============ */
.sb-missing{padding:14px 16px;border-top:1px solid var(--brd);font-size:13px;color:#111;overflow-y:auto;line-height:1.8;flex:1}
.dark .sb-missing{color:var(--sidebartx)}
.sb-missing b,.sb-missing strong{color:#111;font-weight:700}
.dark .sb-missing b,.dark .sb-missing strong{color:#fff;font-weight:700}
.sb-missing ul,.sb-missing ol{margin:4px 0;padding-left:16px}
.sb-missing li{margin:2px 0}
.tpl-row:last-child{border-bottom:none}
.tpl-arrows{display:flex;flex-direction:column;gap:2px}
.tpl-arrows button{padding:0 4px;border:none;background:transparent;cursor:pointer;color:var(--tx3);font-size:14px;line-height:1;transition:color .15s}
.tpl-arrows button:hover{color:var(--green)}

/* ============ SELECTION & FOCUS STYLES ============ */
::selection{background:rgba(133,173,255,.25);color:inherit}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}

/* ============ STITCH DESIGN SYSTEM: GLASS & ANIMATIONS ============ */
.glass-card{background:var(--glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border)}
.glass-panel{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}

/* Shimmer loading effect */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.shimmer{background:linear-gradient(90deg,transparent,rgba(133,173,255,.05),transparent);background-size:200% 100%;animation:shimmer 2s infinite linear}

/* Fade + slide in */
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.fade-slide-in{animation:fadeSlideIn .3s cubic-bezier(.16,1,.3,1) both}

/* Scale in (for modals) */
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.scale-in{animation:scaleIn .2s cubic-bezier(.16,1,.3,1) both}

/* ============ STITCH DESIGN UPGRADE: NEON GLOWS ============ */
@keyframes glowPulse{0%{box-shadow:0 0 0 0 rgba(133,173,255,.4)}70%{box-shadow:0 0 0 10px rgba(133,173,255,0)}100%{box-shadow:0 0 0 0 rgba(133,173,255,0)}}
@keyframes floatUp{0%{transform:translateY(0)}50%{transform:translateY(-4px)}100%{transform:translateY(0)}}
@keyframes neonPulse{0%,100%{box-shadow:0 0 5px rgba(133,173,255,.2)}50%{box-shadow:0 0 20px rgba(133,173,255,.4),0 0 40px rgba(133,173,255,.1)}}
.glow-primary{box-shadow:0 0 20px rgba(133,173,255,.15)}
.glow-secondary{box-shadow:0 0 20px rgba(105,246,184,.15)}
.glow-active{box-shadow:inset 0 0 20px rgba(133,173,255,.1)}

/* ============ ENHANCED SIDEBAR ============ */
.dark .sb-item.active{box-shadow:inset 0 0 20px rgba(133,173,255,.06);position:relative}

/* ============ ENHANCED CARDS (Glass Morphism) ============ */
.dark .card{background:rgba(15,25,48,.55);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(64,72,93,.12);box-shadow:0 4px 24px rgba(0,0,0,.15)}
.dark .card:hover{box-shadow:0 8px 40px rgba(0,0,0,.25);transform:translateY(-1px) scale(1.003);border-color:rgba(133,173,255,.08)}

/* ============ ENHANCED BUTTONS (Gradients + Press) ============ */
.btn{font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
.btn-green{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 12px rgba(16,185,129,.25)}
.btn-green:hover{box-shadow:0 6px 20px rgba(16,185,129,.35);transform:translateY(-2px)}
.btn-blue{background:linear-gradient(135deg,#85adff,#6e9fff);box-shadow:0 2px 12px rgba(133,173,255,.25)}
.btn-blue:hover{box-shadow:0 6px 20px rgba(133,173,255,.35);transform:translateY(-2px)}
.btn-red{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 12px rgba(239,68,68,.2)}
.btn-red:hover{box-shadow:0 6px 20px rgba(239,68,68,.3);transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.97)!important;transition:transform .1s}

/* ============ ENHANCED TABS (Pill Style) ============ */
.tabs{border-radius:14px;padding:4px;gap:2px;border:1px solid var(--brd)}
.dark .tabs{border-color:rgba(64,72,93,.2)}
.tab{border-radius:10px;font-weight:600;letter-spacing:-0.01em;transition:all .25s cubic-bezier(.4,0,.2,1)}
.tab.active{box-shadow:0 2px 12px rgba(37,99,235,.2);font-weight:700}
.dark .tab.active{box-shadow:0 2px 16px rgba(133,173,255,.25)}

/* ============ ENHANCED INPUTS ============ */
.dark textarea,.dark input[type=text],.dark input[type=password]{background:rgba(15,25,48,.5);border-color:rgba(64,72,93,.2);box-shadow:inset 0 2px 4px rgba(0,0,0,.1)}
.dark textarea:focus,.dark input:focus{border-color:#85adff;box-shadow:0 0 0 3px rgba(133,173,255,.12),inset 0 2px 4px rgba(0,0,0,.05)}

/* ============ ENHANCED BADGES (Pill + Dot) ============ */
.badge{border-radius:20px;letter-spacing:0.03em;font-weight:700;position:relative;padding-left:18px}
.badge::before{content:'';position:absolute;left:8px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:currentColor}
.badge-green::before{background:#10b981}
.badge-gold::before{background:#f59e0b}
.badge-blue::before{background:#3b82f6}

/* ============ ENHANCED HISTORY CARDS ============ */
.hist-card{border-radius:18px;border-left-width:3px;transition:all .3s cubic-bezier(.4,0,.2,1)}
.dark .hist-card{background:rgba(15,25,48,.35);border-color:rgba(64,72,93,.1)}
.dark .hist-card:hover{background:rgba(25,37,64,.5);border-left-color:#85adff;box-shadow:0 12px 40px rgba(0,0,0,.3)}

/* ============ ENHANCED LOGIN ============ */
.login-wrap::before{animation:loginBgShift 20s ease-in-out infinite alternate}
.login-box{box-shadow:0 25px 80px rgba(0,0,0,.5),0 0 0 1px rgba(133,173,255,.08),0 0 60px rgba(133,173,255,.04);border:1px solid rgba(133,173,255,.1)}
.login-btn{box-shadow:0 4px 20px rgba(133,173,255,.35);letter-spacing:0.02em}
.login-btn:hover{box-shadow:0 8px 30px rgba(133,173,255,.45);transform:translateY(-2px)}

/* ============ ENHANCED MOBILE NAV ============ */
.mobile-nav{border-radius:20px 20px 0 0;box-shadow:0 -4px 30px rgba(0,0,0,.1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.dark .mobile-nav{background:rgba(9,19,40,.85);box-shadow:0 -4px 30px rgba(0,0,0,.4);border-top-color:rgba(64,72,93,.15)}
.mobile-nav button.mob-active{color:#85adff}
.mobile-nav button.mob-active::after{background:linear-gradient(90deg,#85adff,#69f6b8);width:24px;height:3px;border-radius:2px}

/* ============ ENHANCED SCROLLBAR ============ */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(100,116,139,.3);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:rgba(100,116,139,.5)}
.dark ::-webkit-scrollbar-thumb{background:rgba(64,72,93,.4)}
.dark ::-webkit-scrollbar-thumb:hover{background:rgba(64,72,93,.6)}

/* ============ NOTE WRITER OUTPUT: CLEAN FORMATTING ============ */
.pt-output-section{line-height:1.8;font-size:13px;font-family:'Inter',system-ui,sans-serif}
.pt-output-section [style*="font-weight:700"][style*="color:var(--blue)"]{font-family:'Manrope',system-ui,sans-serif;letter-spacing:-0.01em}

/* ============ TYPOGRAPHY UPGRADE ============ */
h1{font-size:28px}
h2{font-size:22px;font-weight:800}
h3{font-size:18px}
h4{font-size:15px;font-weight:700}
.label{font-family:'Inter',system-ui,sans-serif;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:0.06em;color:var(--tx3);display:block;margin-bottom:6px}

/* ============ ENHANCED CHAT MESSAGES ============ */
.chat-msg.ai{background:var(--bg3);border:1px solid var(--brd);border-radius:16px 16px 16px 4px}
.chat-msg.user{background:linear-gradient(135deg,rgba(133,173,255,.08),rgba(105,246,184,.05));border:1px solid rgba(133,173,255,.1);border-radius:16px 16px 4px 16px}
.dark .chat-msg.ai{background:rgba(25,37,64,.5);border-color:rgba(64,72,93,.15)}

/* ============ STITCH: STATUS INDICATOR DOTS ============ */
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.status-dot.active{background:#10b981;box-shadow:0 0 8px rgba(16,185,129,.5)}
.status-dot.pending{background:#f59e0b;box-shadow:0 0 8px rgba(245,158,11,.4)}
.status-dot.error{background:#ef4444;box-shadow:0 0 8px rgba(239,68,68,.4)}

/* ============ CASE OUTPUT HEADERS ============ */
.case-output-header{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-weight:700;font-size:14px;letter-spacing:-.01em;font-family:'Manrope',system-ui,sans-serif}
.case-output-header.case-green{background:linear-gradient(135deg,var(--greenlt),rgba(16,185,129,.05));color:var(--green);border-left:3px solid var(--green)}
.dark .case-output-header.case-green{background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(16,185,129,.02))}
.case-output-header.case-blue{background:linear-gradient(135deg,var(--bluelt),rgba(37,99,235,.05));color:var(--blue);border-left:3px solid var(--blue)}
.dark .case-output-header.case-blue{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(59,130,246,.02))}

/* ============ HISTORY TIMELINE ============ */
.hist-timeline{position:relative;padding-left:28px}
.hist-timeline::before{content:'';position:absolute;left:9px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--green),var(--blue),var(--purple),transparent);border-radius:1px;opacity:.4}
.hist-timeline .hist-card{position:relative}
.hist-timeline .hist-card::before{content:'';position:absolute;left:-23px;top:18px;width:10px;height:10px;border-radius:50%;background:var(--green);border:2px solid var(--bg2);box-shadow:0 0 8px var(--neon-green);z-index:1;transition:all var(--ease-smooth)}
.hist-timeline .hist-card:hover::before{transform:scale(1.3);box-shadow:0 0 14px var(--neon-green)}
@media(max-width:768px){.hist-timeline{padding-left:20px}.hist-timeline::before{left:6px}.hist-timeline .hist-card::before{left:-17px;width:8px;height:8px}}

/* ============ NOTE WRITER ENHANCEMENTS ============ */
.nw-prompt-card{border-radius:var(--radius-md);border:2px solid var(--brd);padding:12px 18px;cursor:pointer;transition:all var(--ease-smooth);position:relative;overflow:hidden}
.nw-prompt-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.nw-prompt-card.selected{border-color:currentColor;transform:translateY(-2px)}
.dark .nw-prompt-card.selected{box-shadow:0 0 20px currentColor}
.nw-billing-bar{background:var(--glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:14px 18px;transition:all var(--ease-smooth)}

/* ============ ASSIGNMENT ENHANCEMENTS ============ */
.asg-team-card{border-radius:var(--radius-lg);padding:16px;text-align:center;transition:all var(--ease-smooth);position:relative;overflow:hidden}
.asg-team-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.asg-team-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green),#06b6d4);border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.asg-team-card.on-call::before{background:linear-gradient(90deg,var(--gold),#f59e0b)}

/* ============ ADMIN STAT CARDS ============ */
.admin-stat-card{background:var(--bg2);border:1px solid var(--brd);border-radius:var(--radius-lg);padding:20px;text-align:center;position:relative;overflow:hidden;transition:all var(--ease-smooth)}
.admin-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.dark .admin-stat-card{background:rgba(15,25,48,.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:rgba(64,72,93,.15)}
.admin-stat-card .stat-value{font-size:28px;font-weight:800;font-family:'Manrope',system-ui;letter-spacing:-0.02em;line-height:1}
.admin-stat-card .stat-label{font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:0.06em;margin-top:8px;font-weight:700}

/* ============ ACCESSIBILITY ============ */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
@media(hover:none){.card:hover,.hist-card:hover,.admin-stat-card:hover,.asg-team-card:hover{transform:none!important;box-shadow:var(--shadow)!important}}

/* ============ TOAST NOTIFICATION ============ */
.toast-notification{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#0f1930,#111827);color:#fff;padding:14px 28px;border-radius:var(--radius-md);z-index:9999;font-size:14px;font-weight:600;box-shadow:0 12px 40px rgba(0,0,0,.35),0 0 0 1px rgba(77,184,146,.15);animation:fadeInDown .25s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(10px);letter-spacing:-.01em;border-left:3px solid var(--green)}

/* ============ PRINT STYLES ============ */
@media print{.sidebar,.mobile-nav,.action-bar,.sb-bottom,.btn{display:none!important}.content{padding:0!important}.card{box-shadow:none!important;border:1px solid #ccc!important;break-inside:avoid}}

/* Fade overlay */
@keyframes fadeOverlay{from{opacity:0}to{opacity:1}}
.fade-overlay{animation:fadeOverlay .2s ease both}

/* Neon glow effects */
.neon-primary{box-shadow:0 0 20px rgba(133,173,255,.15)}
.neon-secondary{box-shadow:0 0 20px rgba(105,246,184,.15)}
.neon-tertiary{box-shadow:0 0 20px rgba(172,138,255,.15)}

/* Smooth scrollbar */
.custom-scroll::-webkit-scrollbar{width:4px}
.custom-scroll::-webkit-scrollbar-track{background:transparent}
.custom-scroll::-webkit-scrollbar-thumb{background:var(--brd);border-radius:10px}
.custom-scroll::-webkit-scrollbar-thumb:hover{background:var(--tx3)}

/* Material-style elevation for dark mode */
.dark .elevation-1{box-shadow:0 1px 3px rgba(0,0,0,.3),0 1px 2px rgba(0,0,0,.2)}
.dark .elevation-2{box-shadow:0 3px 6px rgba(0,0,0,.3),0 3px 6px rgba(0,0,0,.2)}
.dark .elevation-3{box-shadow:0 10px 20px rgba(0,0,0,.3),0 6px 6px rgba(0,0,0,.2)}

/* Gradient text utility */
.gradient-text{background:linear-gradient(135deg,#85adff,#6e9fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* RVU progress shimmer */
.rvu-shimmer{background:linear-gradient(90deg,#85adff 0%,#6e9fff 50%,#85adff 100%);background-size:200% 100%;animation:shimmer 2s infinite linear}

/* Premium glow on focus */
.premium-glow:focus-within{box-shadow:0 0 0 1px rgba(133,173,255,.4),0 0 20px rgba(133,173,255,.1)}

/* Pill button base */
.pill-btn{padding:6px 16px;border-radius:9999px;font-size:12px;font-weight:600;border:1px solid var(--brd);background:var(--bg2);color:var(--tx2);cursor:pointer;transition:all .2s}
.pill-btn:hover{background:var(--bg3);color:var(--tx)}
.pill-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 2px 8px rgba(37,99,235,.25)}
.dark .pill-btn.active{background:#85adff;color:#002c66;border-color:#85adff;box-shadow:0 2px 12px rgba(133,173,255,.3)}
