:root{--bg-base:#0d0d14;--bg-surface:#14141e99;--bg-elevated:#1e1e2d80;--border-subtle:#ffffff0f;--border-accent:#ffffff1a;--text-primary:#f5f5f7;--text-secondary:#f5f5f799;--text-muted:#f5f5f766;--accent-cyan:#06b6d4;--accent-purple:#a855f7;--accent-pink:#ec4899;--accent-green:#10b981;--accent-amber:#f59e0b;--glass-bg:#ffffff08;--glass-border:#ffffff14;--sidebar-width:260px;--topbar-height:64px;--radius:16px;--radius-sm:10px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;line-height:1.5}body:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(80% 50% at 20% 20%,#a855f71f 0%,#0000 50%),radial-gradient(60% 40% at 80% 80%,#06b6d41a 0%,#0000 50%),radial-gradient(50% 30%,#ec489914 0%,#0000 50%);position:fixed;inset:0}.shell{min-height:100vh;display:flex}.sidebar-overlay{z-index:190;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;position:fixed;inset:0}.sidebar{width:var(--sidebar-width);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--glass-border);z-index:200;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}}.sidebar-logo{border-bottom:1px solid var(--border-subtle);padding:24px}.logo-mark{letter-spacing:-.5px;color:var(--text-primary);font-size:22px;font-weight:700}.logo-mark span{background:linear-gradient(135deg, var(--accent-cyan), var(--accent-purple));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.logo-sub{color:var(--text-muted);margin-top:4px;font-size:12px}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;padding:8px 12px;font-size:11px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:12px;margin-bottom:4px;padding:12px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:var(--text-primary);background:#ffffff0d}.nav-item.active{color:var(--text-primary);background:linear-gradient(135deg,#a855f726,#06b6d41a)}.nav-item.active:before{content:"";background:linear-gradient(180deg, var(--accent-cyan), var(--accent-purple));border-radius:0 4px 4px 0;width:3px;height:24px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:16px}.user-chip{background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);align-items:center;gap:12px;padding:12px;display:flex}.avatar{background:linear-gradient(135deg, var(--accent-purple), var(--accent-pink));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.user-name{color:var(--text-primary);font-size:13px;font-weight:600}.user-role{color:var(--text-muted);font-size:11px}.main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}@media (width<=768px){.main{margin-left:0}}.topbar{height:var(--topbar-height);background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);z-index:100;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:16px;display:flex}.menu-btn{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);padding:10px;transition:all .2s;display:none}.menu-btn:hover{color:var(--text-primary);background:#ffffff14}@media (width<=768px){.menu-btn{display:flex}}.topbar-title{color:var(--text-primary);font-size:16px;font-weight:600}.topbar-right{align-items:center;gap:12px;display:flex}.date-badge{color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:20px;padding:8px 14px;font-size:12px}.content{flex:1;max-width:1400px;padding:32px}@media (width<=768px){.content{padding:20px 16px}}.page-header{margin-bottom:32px}.page-title{color:var(--text-primary);letter-spacing:-.5px;align-items:center;gap:10px;font-size:28px;font-weight:700;display:flex}.sparkle{background:linear-gradient(135deg, var(--accent-cyan), var(--accent-purple));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:24px}.page-subtitle{color:var(--text-secondary);text-transform:capitalize;margin-top:6px;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius);padding:24px;transition:all .3s;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius) var(--radius) 0 0;height:2px;position:absolute;top:0;left:0;right:0}.stat-card.cyan:before{background:linear-gradient(90deg, var(--accent-cyan), transparent)}.stat-card.purple:before{background:linear-gradient(90deg, var(--accent-purple), transparent)}.stat-card.pink:before{background:linear-gradient(90deg, var(--accent-pink), transparent)}.stat-card:hover{border-color:#ffffff1f;transform:translateY(-2px)}.stat-top{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.stat-label{color:var(--text-secondary);font-size:13px;font-weight:500}.stat-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.stat-icon svg{width:22px;height:22px}.stat-icon.cyan{color:var(--accent-cyan);background:#06b6d426}.stat-icon.purple{color:var(--accent-purple);background:#a855f726}.stat-icon.pink{color:var(--accent-pink);background:#ec489926}.stat-number{color:var(--text-primary);letter-spacing:-1px;margin-bottom:6px;font-size:36px;font-weight:700;line-height:1}.stat-sub{color:var(--text-muted);font-size:12px}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden}.card-header{border-bottom:1px solid var(--border-subtle);padding:20px 24px}.card-title{color:var(--text-primary);font-size:16px;font-weight:600}.card-subtitle{color:var(--text-secondary);text-transform:capitalize;margin-top:4px;font-size:13px}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle);background:#ffffff05;padding:14px 24px;font-size:11px;font-weight:600}td{color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);padding:16px 24px;font-size:14px}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.td-time{color:var(--accent-cyan);font-family:SF Mono,Menlo,monospace;font-size:13px;font-weight:500}.td-primary{color:var(--text-primary);font-weight:500}.badge{text-transform:capitalize;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}.badge:before{content:"";border-radius:50%;width:6px;height:6px}.badge-pendiente{color:var(--accent-amber);background:#f59e0b26}.badge-pendiente:before{background:var(--accent-amber);animation:2s infinite pulse}.badge-completada{color:var(--accent-green);background:#10b98126}.badge-completada:before{background:var(--accent-green)}.badge-cancelada{color:#ef4444;background:#ef444426}.badge-cancelada:before{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-state{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px;display:flex}.spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent-cyan);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:48px;font-size:14px}.error{border-radius:var(--radius-sm);color:#ef4444;background:#ef44441a;border:1px solid #ef444433;padding:16px 24px;font-size:14px}::-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}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 18px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-cyan), var(--accent-purple));color:#fff}.btn-primary:hover{opacity:.85;transform:translateY(-1px)}.btn-ghost{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-subtle)}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-accent);background:#ffffff14}.btn-danger-soft{color:#ef4444;background:#ef44441f;border:1px solid #ef444433}.btn-danger-soft:hover{background:#ef444433}.btn-sm{border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;transition:all .2s}.btn-sm:hover{color:var(--text-primary);background:#ffffff14}.btn-sm.del:hover{color:#ef4444;background:#ef44441f;border-color:#ef444433}.actions{gap:8px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:500;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--glass-border);border-radius:var(--radius);background:#16161f;width:100%;max-width:480px;max-height:90vh;animation:.2s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding:24px 24px 0;display:flex}.modal-title{color:var(--text-primary);font-size:18px;font-weight:600}.modal-sub{color:var(--text-muted);margin-top:4px;font-size:12px}.modal-close{background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .15s;display:flex}.modal-close:hover{color:var(--text-primary);background:#ffffff14}.modal-body{padding:0 24px}.modal-footer{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:10px;margin-top:8px;padding:20px 24px;display:flex}.form-group{margin-bottom:16px}.form-group label{color:var(--text-muted);letter-spacing:.6px;text-transform:uppercase;margin-bottom:8px;font-size:11px;font-weight:600;display:block}.form-group input,.form-group select{border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);appearance:none;background:#ffffff0a;padding:10px 14px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus{border-color:var(--accent-cyan);outline:none;box-shadow:0 0 0 3px #06b6d41a}.form-group input::placeholder{color:var(--text-muted)}.form-group select option{background:#16161f}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:32px;display:flex}.msg-error{color:#ef4444;background:#ef44441a;border-radius:6px;margin-top:8px;padding:8px 12px;font-size:12px}@media (width<=768px){.form-row,.stats-grid{grid-template-columns:1fr}.topbar-right .date-badge{display:none}}.form-group input[type=date],.form-group input[type=time]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}
