:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-elevated: #ffffff;--bg-hover: #e2e8f0;--border: #e2e8f0;--border-focus: #1E90FF;--accent: #1E90FF;--accent-light: #60b0ff;--accent-dark: #1a7ce0;--accent-bg: rgba(30, 144, 255, .08);--accent-bg-hover: rgba(30, 144, 255, .14);--tehui-naranja: #FF6B00;--tehui-verde: #00A651;--tehui-amarillo: #FFD700;--tehui-rojo: #E31E24;--success: #00A651;--success-bg: rgba(0, 166, 81, .08);--danger: #E31E24;--danger-bg: rgba(227, 30, 36, .08);--warning: #FF6B00;--warning-bg: rgba(255, 107, 0, .08);--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-inverse: #ffffff;--font: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 30px rgba(0,0,0,.12);--sidebar-width: 340px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;overflow:hidden;height:100dvh}#root{height:100dvh;display:flex;flex-direction:column}::selection{background:var(--accent);color:#fff}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:4px}.gap-sm{gap:8px}.gap-md{gap:12px}.gap-lg{gap:16px}.gap-xl{gap:24px}.flex-1{flex:1;min-width:0}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.relative{position:relative}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:.8125rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.input-group{display:flex;flex-direction:column;gap:6px}.input-label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);letter-spacing:.02em}.input{padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font);font-size:.9375rem;transition:border-color .2s}.input:focus{border-color:var(--accent);outline:none}.input::placeholder{color:var(--text-muted)}.input-error{border-color:var(--danger)!important}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:var(--radius-full);font-size:.6875rem;font-weight:700}.badge-accent{background:var(--accent);color:#fff}.badge-danger{background:var(--danger);color:#fff}.badge-success{background:var(--success);color:var(--text-inverse)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:48px;height:48px;font-size:1rem}.avatar img{width:100%;height:100%;border-radius:inherit;object-fit:cover}.status-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-secondary)}.status-online{background:var(--success)}.status-offline{background:#cbd5e1}.divider{height:1px;background:var(--border);margin:16px 0}.notice{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);font-size:.8125rem}.notice-info{background:var(--accent-bg);color:var(--accent-dark);border:1px solid rgba(30,144,255,.2)}.notice-warn{background:var(--warning-bg);color:#c45500;border:1px solid rgba(255,107,0,.2)}.notice-success{background:var(--success-bg);color:#007a3d;border:1px solid rgba(0,166,81,.2)}.app-layout{display:flex;height:100dvh;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.main-content{flex:1;display:flex;flex-direction:column;min-width:0}.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 20% 50%,rgba(30,144,255,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(0,166,81,.04) 0%,transparent 50%),var(--bg-primary)}.auth-card{width:100%;max-width:420px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px 32px}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.auth-logo-icon{width:44px;height:44px;background:var(--accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px}.auth-logo h1{font-size:1.25rem;font-weight:800;letter-spacing:-.02em}.auth-logo span{color:var(--text-secondary);font-weight:400;font-size:.8125rem;display:block}@media (max-width: 768px){:root{--sidebar-width: 100vw}.sidebar{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10}.sidebar.hidden,.main-content.hidden-mobile{display:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .3s ease-out}.slide-in{animation:slideIn .25s ease-out}.spinner{width:20px;height:20px;border:2px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
