:root{--color-primary: #2563EB;--color-primary-hover: #3B82F6;--color-primary-light: #DBEAFE;--color-primary-bg: #EFF6FF;--color-accent: #06B6D4;--color-accent-glow: #22D3EE;--color-accent-light: #CFFAFE;--color-accent-deep: #0E7490;--color-bg: #F8FAFC;--color-surface: #FFFFFF;--color-surface-elevated: #FFFFFF;--color-text: #1E293B;--color-text-secondary: #64748B;--color-border: #E2E8F0;--color-border-light: #F1F5F9;--color-success: #10B981;--color-warning: #F59E0B;--color-danger: #EF4444;--color-violet: #8B5CF6;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 1px 3px rgba(0,0,0,.05), 0 4px 12px rgba(0,0,0,.05);--shadow-lg: 0 4px 6px rgba(0,0,0,.04), 0 10px 24px rgba(0,0,0,.08);--shadow-primary: 0 4px 14px rgba(37,99,235,.25);--sidebar-width: 260px;--header-height: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--color-primary: #3B82F6;--color-primary-hover: #60A5FA;--color-primary-light: rgba(59,130,246,.15);--color-primary-bg: rgba(59,130,246,.08);--color-accent: #22D3EE;--color-accent-glow: #67E8F9;--color-accent-light: rgba(34,211,238,.12);--color-accent-deep: #06B6D4;--color-bg: #0F172A;--color-surface: #1E293B;--color-surface-elevated: #334155;--color-text: #F8FAFC;--color-text-secondary: #94A3B8;--color-border: rgba(255,255,255,.1);--color-border-light: rgba(255,255,255,.05);--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 1px 3px rgba(0,0,0,.3), 0 4px 12px rgba(0,0,0,.2);--shadow-lg: 0 4px 6px rgba(0,0,0,.3), 0 10px 24px rgba(0,0,0,.3);--shadow-primary: 0 4px 20px rgba(59,130,246,.3)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.6;transition:background-color var(--transition-slow),color var(--transition-slow)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}h1,h2,h3,h4,h5{font-weight:700;line-height:1.3;letter-spacing:-.025em;color:var(--color-text)}h1{font-size:1.875rem;font-weight:800}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem;font-weight:600}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-secondary{color:var(--color-text-secondary)}.text-primary{color:var(--color-primary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-center{text-align:center}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:24px 32px;max-width:calc(100vw - var(--sidebar-width));transition:margin-left var(--transition-normal)}@media(max-width:1023px){.main-content{margin-left:0;padding:16px 16px 80px;max-width:100vw}}.page-header{margin-bottom:24px}.page-header h1{margin-bottom:4px}.page-header p{color:var(--color-text-secondary);font-size:.875rem}.content-grid{display:grid;gap:20px}.content-grid.cols-2{grid-template-columns:repeat(2,1fr)}.content-grid.cols-3{grid-template-columns:repeat(3,1fr)}.content-grid.cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1023px){.content-grid.cols-3,.content-grid.cols-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:639px){.content-grid.cols-2,.content-grid.cols-3,.content-grid.cols-4{grid-template-columns:1fr}}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:24px;border:1px solid var(--color-border-light);transition:all var(--transition-fast)}.card.hoverable:hover{box-shadow:var(--shadow-lg);border-color:#2563eb26;transform:translateY(-1px)}.card.glass{background:#ffffffb3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}[data-theme=dark] .card.glass{background:#1e293bcc}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-header h3{font-size:1rem}.stat-card{display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:var(--color-primary-light);color:var(--color-primary)}.stat-icon.cyan{background:var(--color-accent-light);color:var(--color-accent)}.stat-icon.green{background:#10b9811f;color:var(--color-success)}.stat-icon.violet{background:#8b5cf61f;color:var(--color-violet)}.stat-icon.amber{background:#f59e0b1f;color:var(--color-warning)}.stat-value{font-size:1.75rem;font-weight:800;line-height:1}.stat-label{font-size:.8rem;color:var(--color-text-secondary);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-family);font-weight:600;font-size:.875rem;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb59}.btn-secondary{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}.btn-secondary:hover{background:var(--color-primary-light)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-primary-bg);color:var(--color-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-md)}.btn-block{width:100%}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-family:var(--font-family);font-size:.95rem;transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:100px}.form-error{font-size:.8rem;color:var(--color-danger);margin-top:4px}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.badge-blue{background:var(--color-primary-light);color:var(--color-primary)}.badge-cyan{background:var(--color-accent-light);color:var(--color-accent-deep)}.badge-green{background:#10b9811f;color:#059669}.badge-amber{background:#f59e0b1f;color:#d97706}.badge-red{background:#ef44441f;color:var(--color-danger)}.badge-violet{background:#8b5cf61f;color:var(--color-violet)}.tag{display:inline-flex;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;background:var(--color-primary-bg);color:var(--color-primary);cursor:pointer;transition:all var(--transition-fast)}.tag:hover{background:var(--color-primary-light)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .2s ease}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--color-border-light)}.modal-body{padding:24px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--color-border-light)}.toast-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{padding:14px 20px;border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-lg);border-left:4px solid var(--color-primary);display:flex;align-items:center;gap:12px;min-width:300px;max-width:420px;animation:slideInRight .3s ease;font-size:.9rem}.toast.success{border-left-color:var(--color-success)}.toast.error{border-left-color:var(--color-danger)}.toast.warning{border-left-color:var(--color-warning)}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-secondary)}.empty-state svg{width:64px;height:64px;margin-bottom:16px;opacity:.4}.empty-state h3{color:var(--color-text);margin-bottom:8px}.streak-ring{position:relative;width:80px;height:80px}.streak-ring svg{transform:rotate(-90deg)}.streak-ring .value{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--color-accent)}.progress-bar{height:8px;background:var(--color-border-light);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full);transition:width .6s ease-in-out;position:relative}.progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.skeleton{background:linear-gradient(90deg,var(--color-border-light) 25%,var(--color-border) 50%,var(--color-border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-title{height:24px;width:60%;margin-bottom:12px}.skeleton-avatar{width:48px;height:48px;border-radius:50%}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:56px;height:56px;font-size:1.25rem}.divider{height:1px;background:var(--color-border-light);margin:16px 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.animate-fadeIn{animation:fadeIn .2s ease}.animate-slideUp{animation:slideUp .2s ease}.animate-bounceIn{animation:bounceIn .4s ease}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.p-4{padding:16px}.p-6{padding:24px}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hidden{display:none}@media(min-width:768px){.md-show{display:block}}
