:root{--primary: #0f4492;--primary-dark: #17233c;--primary-light: #1a5bb8;--secondary: #F0AB00;--secondary-dark: #d99a00;--success: #10b981;--success-bg: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .1);--bg-body: #0f1419;--bg-sidebar: #151b23;--bg-card: #1c2432;--bg-card-hover: #232d3f;--bg-input: #0d1117;--text-primary: #f0f6fc;--text-secondary: #8b949e;--text-muted: #6e7681;--border-color: #30363d;--border-light: #21262d;--sidebar-width: 280px;--header-height: 60px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--bg-body);color:var(--text-primary);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-body) 0%,var(--primary-dark) 50%,var(--primary) 100%);padding:24px}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.login-header{text-align:center;margin-bottom:40px}.login-header img{width:120px;height:auto;margin-bottom:24px}.login-header h1{font-size:24px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.login-header p{color:var(--text-secondary);font-size:14px}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 16px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:15px;font-weight:500;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.btn-google:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-muted)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.app-layout{display:flex;min-height:100vh}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-sidebar);border-bottom:1px solid var(--border-color);padding:0 16px;align-items:center;gap:16px;z-index:100}.menu-toggle{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.menu-toggle:hover{background:var(--bg-card)}.mobile-logo{height:36px;width:auto}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:199;opacity:0;transition:opacity var(--transition-normal)}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:200;overflow:hidden}.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:14px}.sidebar-logo{width:48px;height:48px;object-fit:contain;flex-shrink:0}.sidebar-brand h2{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.sidebar-subtitle{font-size:12px;color:var(--secondary);font-weight:500}.sidebar-close{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;margin-left:auto}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-title{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:0 12px;margin-bottom:8px}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 14px;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);margin-bottom:2px}.nav-link svg{flex-shrink:0}.nav-link span{font-size:14px;font-weight:500}.nav-link:hover{background:var(--bg-card);color:var(--text-primary)}.nav-link.active{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);color:var(--primary-dark);font-weight:600}.nav-link.active svg{stroke:var(--primary-dark)}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color)}.user-card{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:8px;background:var(--bg-card);border-radius:var(--radius-md)}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{display:block;font-size:14px;font-weight:600;color:var(--text-primary)}.user-email{display:block;font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:500;transition:all var(--transition-fast)}.btn-logout:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px 40px;min-height:100vh;width:calc(100% - var(--sidebar-width))}.page-container{width:100%;max-width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;gap:16px;flex-wrap:wrap}.page-header h1{font-size:28px;font-weight:700;color:var(--text-primary)}.page-description{color:var(--text-secondary);margin-bottom:24px;font-size:15px}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);color:var(--primary-dark);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f0ab004d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--bg-card);border-color:var(--text-muted)}.btn-small{padding:8px 14px;font-size:13px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-card);color:var(--text-primary);font-weight:500}.btn-small:hover{background:var(--bg-card-hover)}.btn-small.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-small.btn-danger:hover{background:var(--danger);color:#fff}.btn-icon{padding:8px;background:transparent;border:none;cursor:pointer;font-size:18px;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-card);color:var(--text-primary)}.btn-icon.btn-danger:hover{background:var(--danger-bg);color:var(--danger)}.form-container{background:var(--bg-card);padding:32px;border-radius:var(--radius-lg);border:1px solid var(--border-color);max-width:800px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text-primary)}.form-group small{display:block;margin-top:6px;color:var(--text-muted);font-size:12px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px #f0ab0026}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group textarea{resize:vertical;min-height:120px}.form-group select{cursor:pointer}.form-group input:disabled,.form-group select:disabled{opacity:.6;cursor:not-allowed}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.checkbox-group label{display:flex;align-items:center;gap:12px;cursor:pointer}.checkbox-group input[type=checkbox]{width:20px;height:20px;accent-color:var(--secondary)}.alert{padding:12px 16px;border-radius:var(--radius-md);margin-bottom:20px;font-size:14px}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.3)}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid rgba(16,185,129,.3)}.dashboard h1{font-size:32px;margin-bottom:8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:center;gap:20px;text-decoration:none;transition:all var(--transition-fast);border:1px solid var(--border-color)}.stat-card:hover{transform:translateY(-2px);border-color:var(--secondary);box-shadow:var(--shadow-md)}.stat-icon{width:56px;height:56px;background:var(--bg-body);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.stat-number{font-size:32px;font-weight:700;color:var(--text-primary);display:block;line-height:1.2}.stat-label{color:var(--text-secondary);font-size:14px}.quick-actions{margin-top:40px}.quick-actions h2{margin-bottom:20px;font-size:20px;font-weight:600}.actions-grid{display:flex;gap:12px;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.action-btn:hover{border-color:var(--secondary);background:#f0ab0014}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border-color);transition:all var(--transition-fast)}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm)}.card-inactive{opacity:.5}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.card-header h3{font-size:18px;font-weight:600;color:var(--text-primary)}.card-conductor{color:var(--secondary);font-size:14px;margin-bottom:8px;display:flex;align-items:center;gap:6px}.card-description{color:var(--text-secondary);font-size:14px;margin-bottom:20px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--border-color)}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-success{background:var(--success-bg);color:var(--success)}.badge-muted{background:#6e768133;color:var(--text-muted)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.dias-tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap;background:var(--bg-card);padding:8px;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.dia-tab{padding:12px 20px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:14px;font-weight:500}.dia-tab:hover{background:var(--bg-card-hover);color:var(--text-primary)}.dia-tab.active{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-dark) 100%);color:var(--primary-dark);font-weight:600}.dia-title{font-size:24px;margin-bottom:24px;font-weight:600}.horarios-list{display:flex;flex-direction:column;gap:12px}.horario-item{display:flex;align-items:center;gap:20px;background:var(--bg-card);padding:20px 24px;border-radius:var(--radius-lg);border:1px solid var(--border-color);transition:all var(--transition-fast)}.horario-item:hover{border-color:var(--secondary)}.horario-time{font-weight:700;font-size:16px;color:var(--secondary);min-width:140px;font-family:SF Mono,Menlo,monospace}.horario-programa{flex:1;font-size:15px;color:var(--text-primary)}.filtros-tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.filtro-tab{padding:10px 18px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:14px;font-weight:500}.filtro-tab:hover{border-color:var(--text-muted)}.filtro-tab.active{border-color:var(--secondary);color:var(--text-primary);background:#f0ab0014}.mensajes-list{display:flex;flex-direction:column;gap:16px}.mensaje-card{display:flex;align-items:center;gap:24px;background:var(--bg-card);padding:20px 24px;border-radius:var(--radius-lg);border-left:4px solid var(--warning);border-top:1px solid var(--border-color);border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);transition:all var(--transition-fast)}.mensaje-card:hover{background:var(--bg-card-hover)}.mensaje-card.estado-aprobado{border-left-color:var(--success)}.mensaje-card.estado-rechazado{border-left-color:var(--danger)}.mensaje-info{min-width:180px}.mensaje-fecha{font-size:13px;color:var(--text-muted)}.mensaje-duracion{font-size:14px;color:var(--text-secondary);margin-top:4px}.mensaje-player{flex:1}.btn-play{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border:none;cursor:pointer;font-size:18px;transition:all var(--transition-fast);color:#fff;display:flex;align-items:center;justify-content:center}.btn-play:hover{transform:scale(1.05);box-shadow:0 4px 12px #0f449266}.btn-play.playing{background:linear-gradient(135deg,var(--danger) 0%,#dc2626 100%)}.mensaje-actions{display:flex;gap:8px}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-card);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color);box-shadow:var(--shadow-lg)}.modal h2{margin-bottom:24px;font-size:20px;font-weight:600}.table-container{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-color)}table{width:100%;border-collapse:collapse}th,td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--border-color)}th{background:var(--bg-body);font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-card-hover)}.text-muted{color:var(--text-muted)}.actions-cell{display:flex;gap:8px}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary);font-size:15px}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-body);gap:16px}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--secondary);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:80px 24px;color:var(--text-secondary)}.empty-state p{margin-bottom:24px;font-size:15px}.error-message{background:var(--danger-bg);color:var(--danger);padding:14px 18px;border-radius:var(--radius-md);margin-bottom:20px;font-size:14px;border:1px solid rgba(239,68,68,.3)}hr{border:none;border-top:1px solid var(--border-color);margin:32px 0}@media(max-width:1024px){.main-content{padding:24px}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.mobile-header{display:flex}.sidebar{transform:translate(-100%);transition:transform var(--transition-normal)}.sidebar-close{display:block}body.sidebar-open .sidebar{transform:translate(0)}body.sidebar-open .sidebar-overlay{display:block;opacity:1}.main-content{margin-left:0;width:100%;padding:80px 16px 24px}.page-header{flex-direction:column;align-items:flex-start}.page-header h1{font-size:24px}.form-row{grid-template-columns:1fr}.form-container{padding:24px}.stats-grid,.cards-grid{grid-template-columns:1fr}.horario-item{flex-direction:column;align-items:flex-start;gap:12px}.horario-time{min-width:auto}.mensaje-card{flex-direction:column;align-items:flex-start;gap:16px}.mensaje-actions{width:100%}.mensaje-actions .btn-small{flex:1}.dias-tabs{padding:6px;gap:4px}.dia-tab{padding:10px 14px;font-size:13px}.modal{padding:24px;margin:16px}}@media(max-width:480px){.stat-card{padding:20px}.stat-icon{width:48px;height:48px;font-size:20px}.stat-number{font-size:28px}.action-btn{width:100%;justify-content:center}.form-actions{flex-direction:column}.form-actions button{width:100%}}.image-upload-zone{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-input)}.image-upload-zone:hover{border-color:var(--secondary);background:#f0ab000d}.image-upload-zone.drag-over{border-color:var(--secondary);background:#f0ab001a;transform:scale(1.01)}.image-upload-zone.uploading{pointer-events:none;opacity:.8}.upload-icon{color:var(--text-muted);margin-bottom:16px}.upload-text{display:flex;flex-direction:column;gap:4px}.upload-text strong{color:var(--text-primary);font-size:15px}.upload-text span{color:var(--text-muted);font-size:13px}.upload-hint{color:var(--success)!important;font-size:12px!important;margin-top:8px}.upload-loading{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--text-secondary)}.upload-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--secondary);border-radius:50%;animation:spin .8s linear infinite}.image-preview-container{display:flex;gap:20px;align-items:flex-start}.image-preview{flex:0 0 200px;height:150px;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-input);border:1px solid var(--border-color)}.image-preview img{width:100%;height:100%;object-fit:cover}.image-actions{display:flex;flex-direction:column;gap:8px}.image-error{color:var(--danger);font-size:13px;margin-top:8px;padding:8px 12px;background:var(--danger-bg);border-radius:var(--radius-sm)}@media(max-width:768px){.image-preview-container{flex-direction:column}.image-preview{flex:none;width:100%;height:200px}.image-actions{flex-direction:row;width:100%}.image-actions button{flex:1}}.btn-small.btn-success{background:var(--success-color, #22c55e);color:#fff;border-color:var(--success-color, #22c55e)}.btn-small.btn-success:hover{background:#16a34a;border-color:#16a34a}.btn-small.btn-warning{background:var(--warning-color, #f59e0b);color:#fff;border-color:var(--warning-color, #f59e0b)}.btn-small.btn-warning:hover{background:#d97706;border-color:#d97706}.success-message{color:var(--success-color, #22c55e);font-weight:500;display:inline-flex;align-items:center;gap:6px}.preview-card{background:var(--card-bg, #1e293b);border:1px solid var(--border-color, #334155);border-radius:var(--radius-md, 8px);padding:16px;margin-top:12px}.preview-card h4{margin:0 0 12px;color:var(--text-secondary, #94a3b8);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.preview-content{display:flex;flex-direction:column;gap:4px}.preview-label{font-size:.7rem;font-weight:700;letter-spacing:.1em;color:var(--primary-color, #6366f1)}.preview-title{font-size:1.1rem;font-weight:600;color:var(--text-primary, #f1f5f9)}.preview-description{color:var(--text-secondary, #94a3b8);font-size:.9rem}.filtro-tab.active.warning{background:var(--warning-color, #f59e0b);color:#fff;border-color:var(--warning-color, #f59e0b)}.filtro-tab.active.success{background:var(--success-color, #22c55e);color:#fff;border-color:var(--success-color, #22c55e)}.filtro-tab.active.danger{background:var(--danger-color, #ef4444);color:#fff;border-color:var(--danger-color, #ef4444)}.stat-card.highlight{border-color:var(--primary-color, #6366f1);box-shadow:0 0 0 1px var(--primary-color, #6366f1)}.subtitle{color:var(--text-secondary, #94a3b8);margin-top:-8px;margin-bottom:24px}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color, #334155);border-top-color:var(--primary-color, #6366f1);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius-md, 8px);color:#fff;font-weight:500;box-shadow:0 4px 12px #0000004d;animation:slideIn .3s ease}.toast.success{background:var(--success-color, #22c55e)}.toast.error{background:var(--danger-color, #ef4444)}.toast.warning{background:var(--warning-color, #f59e0b)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}
