@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#0a0e27;--bg-secondary:#111634;--bg-card:#111634cc;--bg-glass:#ffffff0d;--border-glass:#ffffff1a;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-blue:#3b82f6;--accent-blue-hover:#2563eb;--accent-emerald:#10b981;--accent-amber:#f59e0b;--accent-red:#ef4444;--accent-purple:#8b5cf6;--gradient-primary:linear-gradient(135deg, #3b82f6, #8b5cf6);--gradient-success:linear-gradient(135deg, #10b981, #059669);--gradient-warning:linear-gradient(135deg, #f59e0b, #d97706);--gradient-danger:linear-gradient(135deg, #ef4444, #dc2626);--glass-bg:#ffffff0d;--glass-border:1px solid #ffffff1a;--glass-blur:blur(12px);--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow-blue:0 0 20px #3b82f64d;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--sidebar-width:260px;--sidebar-collapsed:70px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20%,#3b82f614 0%,#0000 50%),radial-gradient(at 80% 20%,#8b5cf60f 0%,#0000 50%),radial-gradient(at 50% 80%,#10b9810a 0%,#0000 50%);position:fixed;inset:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:var(--font-family)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.login-page{z-index:1;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg), 0 0 60px #3b82f614;background:#111634d9;border:1px solid #ffffff14;padding:48px 40px;animation:.6s fadeInUp}.login-logo{text-align:center;margin-bottom:36px}.login-logo-icon{margin-bottom:12px;font-size:56px;animation:.8s bounceIn;display:block}.login-logo h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:800}.login-logo p{color:var(--text-muted);margin-top:4px;font-size:14px}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);letter-spacing:.3px;margin-bottom:8px;font-size:13px;font-weight:500;display:block}.form-input{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 16px;font-size:14px}.form-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.form-input::placeholder{color:var(--text-muted)}.form-select{border:var(--glass-border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;background:#ffffff0d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 14px center no-repeat;outline:none;padding:12px 16px;font-size:14px}.form-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.form-select option{color:#e2e8f0;background:#111634}.form-textarea{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);resize:vertical;min-height:80px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 16px;font-size:14px}.form-textarea:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow-blue)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 30px #3b82f666}.btn-success{background:var(--gradient-success);color:#fff}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 20px #10b9814d}.btn-danger{color:var(--accent-red);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-ghost{background:var(--glass-bg);border:var(--glass-border);color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#ffffff1a}.btn-sm{border-radius:6px;padding:6px 14px;font-size:12px}.btn-block{width:100%}.login-error{border-radius:var(--radius-sm);color:var(--accent-red);background:#ef44441a;border:1px solid #ef444433;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;font-size:13px;animation:.4s shake;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.data-table-wrapper{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:#ffffff05;border-bottom:1px solid #ffffff0f;padding:14px 20px;font-size:12px;font-weight:600}.data-table td{color:var(--text-primary);transition:background var(--transition-fast);border-bottom:1px solid #ffffff0a;padding:14px 20px;font-size:14px}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#ffffff08}.data-table tbody tr:nth-child(2n){background:#ffffff03}.data-table tbody tr:nth-child(2n):hover{background:#ffffff0a}.data-table .actions{gap:8px;display:flex}.data-table .action-btn{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;justify-content:center;align-items:center;font-size:14px;display:inline-flex}.data-table .action-btn:hover{color:var(--accent-blue);background:#3b82f626;border-color:#3b82f64d}.data-table .action-btn.delete:hover{color:var(--accent-red);background:#ef444426;border-color:#ef44444d}.glass-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal), box-shadow var(--transition-normal);padding:24px}.glass-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card{position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:3px 3px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:var(--gradient-primary)}.stat-card.green:before{background:var(--gradient-success)}.stat-card.amber:before{background:var(--gradient-warning)}.stat-card.red:before{background:var(--gradient-danger)}.stat-card-icon{margin-bottom:12px;font-size:32px}.stat-card-value{color:var(--text-primary);margin-bottom:4px;font-size:36px;font-weight:800;line-height:1}.stat-card-label{color:var(--text-muted);font-size:13px;font-weight:500}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.page-title{color:var(--text-primary);align-items:center;gap:10px;font-size:24px;font-weight:700;display:flex}.filters-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-input{background:var(--glass-bg);border:var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;min-width:140px;padding:8px 14px;font-size:13px}.filter-input:focus{border-color:var(--accent-blue)}.filter-select{border:var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);appearance:none;background:#ffffff0d url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%2394a3b8' d='M5 7L1 3h8z'/%3E%3C/svg%3E") right 10px center no-repeat;outline:none;min-width:140px;padding:8px 28px 8px 14px;font-size:13px}.filter-select:focus{border-color:var(--accent-blue)}.filter-select option{color:#e2e8f0;background:#111634}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:48px}.empty-state-text{margin-bottom:8px;font-size:16px}.empty-state-sub{color:var(--text-muted);font-size:13px}.calendar-wrapper{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.calendar-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.calendar-nav-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff08;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;font-size:16px;display:inline-flex}.calendar-nav-btn:hover{color:var(--accent-blue);background:#3b82f626;border-color:#3b82f64d}.calendar-title{color:var(--text-primary);font-size:16px;font-weight:600}.calendar-grid{grid-template-columns:140px repeat(7,1fr);min-height:500px;display:grid}.calendar-corner{color:var(--text-muted);border-bottom:1px solid #ffffff0f;border-right:1px solid #ffffff0f;justify-content:center;align-items:center;padding:10px;font-size:12px;display:flex}.calendar-day-header{text-align:center;color:var(--text-secondary);border-bottom:1px solid #ffffff0f;border-right:1px solid #ffffff0a;padding:10px 6px;font-size:12px;font-weight:600}.calendar-day-header.today{color:var(--accent-blue);background:#3b82f60d}.calendar-day-header .day-name{text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;display:block}.calendar-day-header .day-number{font-size:18px;font-weight:700}.calendar-row-label{color:var(--text-secondary);border-bottom:1px solid #ffffff0a;border-right:1px solid #ffffff0f;align-items:center;gap:8px;min-height:80px;padding:8px 12px;font-size:13px;display:flex}.calendar-cell{border-bottom:1px solid #ffffff0a;border-right:1px solid #ffffff0a;min-height:80px;padding:4px;position:relative}.calendar-event{cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;border-radius:6px;margin-bottom:3px;padding:4px 8px;font-size:11px;font-weight:500;overflow:hidden}.calendar-event:hover{transform:scale(1.02);box-shadow:0 2px 8px #0000004d}.calendar-event.pendiente{color:#fbbf24;background:#f59e0b33;border-left:3px solid #f59e0b}.calendar-event.en_curso{color:#60a5fa;background:#3b82f633;border-left:3px solid #3b82f6}.calendar-event.completado{color:#34d399;background:#10b98133;border-left:3px solid #10b981}.calendar-event.cancelado{color:#f87171;opacity:.6;background:#ef444426;border-left:3px solid #ef4444}.config-card{max-width:600px}.config-item{border-bottom:1px solid #ffffff0f;padding:20px 0}.config-item:last-child{border-bottom:none}.config-item label{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600;display:block}.config-item .config-desc{color:var(--text-muted);margin-bottom:10px;font-size:12px}.config-item input{width:120px}@media (max-width:1024px){.login-card{padding:36px 28px}}@media (max-width:768px){.page-header{flex-direction:column;align-items:flex-start}.filters-bar{flex-direction:column}.filter-input,.filter-select{width:100%}}
