.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);position:relative;overflow:hidden;background:linear-gradient(135deg,#1a0a1a,#2d142d,#1a0a1a);transition:background-color var(--transition-normal)}.login-background{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.login-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,rgba(236,72,153,.15) 1px,transparent 0);background-size:32px 32px;opacity:.8}.login-gradient-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.6;animation:float 10s ease-in-out infinite}.orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(236,72,153,.8) 0%,rgba(219,39,119,.4) 40%,transparent 70%);top:-150px;right:-100px;animation-delay:-2s}.orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(244,114,182,.6) 0%,rgba(236,72,153,.3) 40%,transparent 70%);bottom:-100px;left:-100px;animation-delay:-4s}.orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(251,113,133,.5) 0%,rgba(244,63,94,.2) 50%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-6s;opacity:.3}@keyframes float{0%,to{transform:translateY(0) scale(1) rotate(0)}33%{transform:translateY(-30px) scale(1.1) rotate(5deg)}66%{transform:translateY(20px) scale(.95) rotate(-5deg)}}.login-theme-toggle{position:fixed;top:var(--space-6);right:var(--space-6);display:flex;align-items:center;justify-content:center;width:44px;height:44px;background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);color:var(--text-secondary);cursor:pointer;z-index:10;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.login-theme-toggle:hover{background-color:var(--surface-secondary);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.login-card{position:relative;z-index:1;width:100%;max-width:420px;background:linear-gradient(145deg,var(--surface-primary) 0%,rgba(236,72,153,.03) 100%);border:1px solid var(--border-primary);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:0 0 0 1px var(--border-secondary),0 0 60px #ec48991a,var(--shadow-xl);animation:scaleIn var(--transition-slow) cubic-bezier(.34,1.56,.64,1);transition:all var(--transition-normal)}.login-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-2xl);padding:1px;background:linear-gradient(135deg,rgba(236,72,153,.3),transparent 40%,transparent 60%,rgba(219,39,119,.2));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.login-card-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{display:flex;justify-content:center;margin-bottom:var(--space-5);animation:slideDown var(--transition-slow) ease-out}.login-logo-img{height:80px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 20px rgba(236,72,153,.5));transition:filter var(--transition-fast)}.login-logo-img:hover{filter:drop-shadow(0 6px 30px rgba(236,72,153,.7))}.login-title{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);margin:0 0 var(--space-2);letter-spacing:-.025em;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{font-size:var(--text-base);color:var(--text-muted);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.login-field{position:relative;transition:all var(--transition-fast)}.login-field.focused{transform:translateY(-1px)}.login-label{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);transition:color var(--transition-fast)}.login-field.focused .login-label{color:var(--accent-primary)}.login-label svg{color:var(--text-muted);transition:color var(--transition-fast)}.login-field.focused .login-label svg{color:var(--accent-primary)}.login-input-wrapper{position:relative}.login-input{width:100%;padding:var(--space-4) var(--space-4);padding-right:var(--space-12);font-size:var(--text-base);color:var(--text-primary);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.login-input::placeholder{color:var(--text-muted)}.login-input:hover{border-color:var(--border-tertiary)}.login-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent)}.login-password-toggle{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.login-password-toggle:hover{background-color:var(--surface-tertiary);color:var(--text-primary)}.login-error{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-lg);color:var(--error-text);font-size:var(--text-sm);animation:shake var(--transition-slow) ease-out}.login-error-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:var(--color-error-500);color:#fff;font-weight:var(--font-bold);border-radius:var(--radius-full);flex-shrink:0;font-size:var(--text-xs)}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.login-submit{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-4) var(--space-6);margin-top:var(--space-2);background:linear-gradient(135deg,#ec4899,#db2777,#be185d);color:#fff;font-size:var(--text-base);font-weight:var(--font-semibold);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 1px 2px #ec489980,0 4px 12px #ec48994d;position:relative;overflow:hidden}.login-submit:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,rgba(255,255,255,.2),transparent);opacity:0;transition:opacity var(--transition-fast)}.login-submit:hover:before{opacity:1}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #ec489966,0 8px 24px #ec489940}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-submit.loading{gap:var(--space-3)}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 639px){.login-page{padding:var(--space-4);padding-top:calc(var(--space-4) + 60px)}.login-theme-toggle{top:var(--space-4);right:var(--space-4)}.login-card{padding:var(--space-6)}.login-feature{font-size:var(--text-xs)}}@media (max-width: 359px){.login-card{padding:var(--space-5)}.login-input{padding:var(--space-3) var(--space-3);padding-right:var(--space-10)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.login-page.loading{pointer-events:none}.login-page.loading .login-card{opacity:.7}[data-theme=light] .login-page{background:linear-gradient(135deg,#fdf2f8,#fce7f3,#fdf2f8)}[data-theme=light] .login-pattern{background-image:radial-gradient(circle at 1px 1px,rgba(244,114,182,.2) 1px,transparent 0)}[data-theme=light] .orb-1{background:radial-gradient(circle,rgba(244,114,182,.5) 0%,rgba(251,113,133,.25) 40%,transparent 70%)}[data-theme=light] .orb-2{background:radial-gradient(circle,rgba(251,207,232,.6) 0%,rgba(244,114,182,.2) 40%,transparent 70%)}[data-theme=light] .orb-3{background:radial-gradient(circle,rgba(252,231,243,.8) 0%,rgba(244,114,182,.15) 50%,transparent 70%)}[data-theme=light] .login-submit{background:linear-gradient(135deg,#f472b6,#ec4899,#db2777);box-shadow:0 1px 2px #f472b666,0 4px 12px #f472b640}[data-theme=light] .login-submit:hover:not(:disabled){box-shadow:0 4px 8px #f472b659,0 8px 24px #f472b633}[data-theme=light] .login-card:before{background:linear-gradient(135deg,rgba(244,114,182,.4),transparent 40%,transparent 60%,rgba(251,113,133,.3))}[data-theme=light] .login-card{background:linear-gradient(145deg,var(--surface-primary) 0%,rgba(253,242,248,.5) 100%);box-shadow:0 0 0 1px var(--border-secondary),0 0 60px #f472b614,var(--shadow-xl)}[data-theme=light] .login-logo-img{filter:drop-shadow(0 4px 16px rgba(244,114,182,.4))}[data-theme=light] .login-logo-img:hover{filter:drop-shadow(0 6px 24px rgba(244,114,182,.55))}.dashboard-page{animation:fadeIn var(--transition-normal) ease-out}@media (min-width: 768px){.page-header{flex-direction:row;align-items:flex-start;justify-content:space-between}}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:-.025em;margin-bottom:var(--space-1)}.page-description{font-size:var(--text-sm);color:var(--text-muted);margin:0}.page-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.week-selector{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.week-selector svg{color:var(--text-muted)}.week-selector select{background:transparent;border:none;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;padding-right:var(--space-6)}.week-selector select:focus{outline:none}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}@media (min-width: 640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-tertiary)}.stat-card-primary{border-color:var(--color-primary-300);background:linear-gradient(145deg,var(--color-primary-50),var(--surface-primary))}.stat-card-primary .stat-label{color:var(--color-primary-600)}.stat-card-primary .stat-value{color:var(--color-primary-700)}.stat-card-success{border-color:var(--success-border);background:linear-gradient(145deg,var(--success-bg),var(--surface-primary))}.stat-card-success .stat-value{color:var(--success-text)}.stat-card-warning{border-color:var(--warning-border);background:linear-gradient(145deg,var(--warning-bg),var(--surface-primary))}.stat-card-warning .stat-value{color:var(--warning-text)}.stat-label{display:block;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-2)}.stat-value{display:block;font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:var(--leading-tight)}.employee-summary-section{margin-bottom:var(--space-8)}.section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-4)}.employee-summary-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media (min-width: 640px){.employee-summary-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.employee-summary-grid{grid-template-columns:repeat(3,1fr)}}.employee-summary-card{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-3) var(--space-4);background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition-normal)}.employee-summary-card:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-sm)}.employee-summary-name{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-summary-stats{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:var(--text-sm)}.employee-stat-inline{color:var(--text-secondary)}.employee-stat-inline strong{font-weight:var(--font-medium);color:var(--text-muted);margin-right:var(--space-1)}.employee-stat-inline.employee-stat-paid{color:var(--color-success)}.employee-stat-inline.employee-stat-balance{color:var(--color-warning, #f59e0b)}.employee-stat{display:flex;flex-direction:column;gap:var(--space-1)}.employee-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.employee-stat-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.employee-stat-paid{color:var(--color-success-500)}.employee-stat-balance{color:var(--color-warning-500)}.employee-payment-btn{width:100%;justify-content:center}.records-section{margin-bottom:var(--space-8)}.employee-info{display:flex;align-items:center;gap:var(--space-3)}.employee-name{font-weight:var(--font-medium);color:var(--text-primary)}.amount-pending{color:var(--color-warning-500);margin-left:var(--space-1)}.event-cards-list{display:flex;flex-direction:column;gap:var(--space-3)}.event-card-planilla{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.event-card-planilla:hover{border-color:var(--border-tertiary)}.event-card-expanded{box-shadow:var(--shadow-md)}.event-card-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) var(--space-5);background:none;border:none;cursor:pointer;text-align:left;gap:var(--space-4);color:var(--text-primary);transition:background-color var(--transition-fast)}.event-card-toggle:hover{background-color:var(--surface-secondary)}.event-card-toggle-info{display:flex;flex-direction:column;gap:var(--space-1);min-width:0;flex:1}.event-card-toggle-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-card-toggle-meta{font-size:var(--text-xs);color:var(--text-muted)}.event-card-toggle-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.event-card-toggle-total{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--accent-primary)}.event-card-chevron{font-size:var(--text-sm);color:var(--text-muted);transition:transform var(--transition-fast);display:inline-block}.chevron-open{transform:rotate(90deg)}.event-card-preview{padding:var(--space-2) var(--space-5);border-top:1px solid var(--border-secondary);display:flex;flex-direction:column;gap:2px}.event-preview-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-muted);padding:2px 0;flex-wrap:wrap}.event-preview-name{font-weight:var(--font-medium);color:var(--text-secondary);min-width:80px}.event-preview-check{color:var(--text-muted);font-style:italic}.event-preview-date{color:var(--text-secondary)}.event-preview-time{font-weight:var(--font-medium);color:var(--text-primary)}.event-preview-sep{color:var(--text-muted)}.oficina-section{margin-top:var(--space-8);padding-top:var(--space-6);border-top:2px solid var(--border-secondary)}.oficina-section-title{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--text-lg)}.oficina-section-title svg{color:var(--accent-primary)}.oficina-section-desc{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-2) 0 var(--space-4)}.oficina-cards-list{display:flex;flex-direction:column;gap:var(--space-3)}.oficina-asistencia-card{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.oficina-asistencia-card:hover{border-color:color-mix(in srgb,var(--accent-primary) 40%,var(--border-primary))}.oficina-asistencia-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-4) var(--space-5);background:none;border:none;cursor:pointer;text-align:left;gap:var(--space-4);color:var(--text-primary);transition:background-color var(--transition-fast)}.oficina-asistencia-toggle:hover{background-color:var(--surface-secondary)}.oficina-asistencia-toggle-left{display:flex;align-items:center;gap:var(--space-3);min-width:0;flex:1}.oficina-asistencia-toggle-left svg{color:var(--accent-primary);flex-shrink:0}.oficina-asistencia-toggle-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.oficina-asistencia-toggle-meta{font-size:var(--text-xs);color:var(--text-muted);margin-left:var(--space-2)}.oficina-asistencia-chevron{font-size:var(--text-sm);color:var(--text-muted);transition:transform var(--transition-fast);display:inline-block}.oficina-asistencia-body{border-top:1px solid var(--border-secondary);padding:var(--space-4)}.oficina-asistencia-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.oficina-asistencia-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.oficina-asistencia-table th,.oficina-asistencia-table td{padding:var(--space-2) var(--space-3);text-align:left;border-bottom:1px solid var(--border-secondary)}.oficina-asistencia-table th{background-color:var(--surface-secondary);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.04em}.oficina-asistencia-table tbody tr:hover{background-color:var(--surface-secondary)}.oficina-cell-fecha{white-space:nowrap;color:var(--text-secondary)}.oficina-cell-nombre{font-weight:var(--font-medium)}.oficina-cell-hora{font-variant-numeric:tabular-nums;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-2)}.oficina-cell-hora-text{flex-shrink:0}.oficina-cell-foto-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--accent-primary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.oficina-cell-foto-btn:hover{background:var(--surface-tertiary);border-color:var(--accent-primary);color:var(--accent-secondary)}.oficina-cell-foto-btn svg{width:14px;height:14px}.oficina-cell-extra{color:var(--text-secondary)}.oficina-cell-extra-btn{padding:var(--space-1) var(--space-2);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--accent-primary);cursor:pointer;transition:all var(--transition-fast)}.oficina-cell-extra-btn:hover{background:var(--surface-tertiary);border-color:var(--accent-primary)}.oficina-extras-overlay{z-index:1100}.oficina-extras-modal{background:var(--surface-primary);border-radius:var(--radius-xl);padding:var(--space-4);max-width:90vw;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.oficina-extras-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-secondary)}.oficina-extras-header h4{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.oficina-extras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3);overflow-y:auto;max-height:60vh}.oficina-extras-grid-item{padding:0;border:none;background:transparent;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;aspect-ratio:1;transition:transform var(--transition-fast)}.oficina-extras-grid-item:hover{transform:scale(1.02)}.oficina-extras-thumb{width:100%;height:100%;object-fit:cover;display:block}.oficina-ver-mas{margin-top:var(--space-3);padding:var(--space-2) var(--space-4);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--accent-primary);cursor:pointer;font-weight:var(--font-medium);transition:all var(--transition-fast)}.oficina-ver-mas:hover{background:var(--surface-tertiary);border-color:var(--accent-primary)}.cargar-step-desc{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-3)}.cargar-back{background:none;border:none;color:var(--accent-primary);font-size:var(--text-sm);cursor:pointer;padding:0;margin-bottom:var(--space-3)}.cargar-back:hover{text-decoration:underline}.cargar-user-list,.cargar-event-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:280px;overflow-y:auto}.cargar-user-item,.cargar-event-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.cargar-user-item:hover,.cargar-event-item:hover{border-color:var(--accent-primary);background:var(--surface-tertiary)}.cargar-user-item{flex-direction:column;align-items:flex-start}.cargar-user-name{font-weight:var(--font-semibold);color:var(--text-primary)}.cargar-user-email{font-size:var(--text-xs);color:var(--text-muted)}.cargar-event-name{flex:1;font-weight:var(--font-medium);color:var(--text-primary)}.cargar-event-item svg{color:var(--accent-primary)}.cargar-event-type{font-size:var(--text-xs);color:var(--text-muted);padding:var(--space-1) var(--space-2);background:var(--surface-tertiary);border-radius:var(--radius-md)}.cargar-empty{font-size:var(--text-sm);color:var(--text-muted);margin:var(--space-4) 0}.cargar-error{font-size:var(--text-sm);color:var(--error-text);background:var(--error-bg);padding:var(--space-2);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.cargar-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.cargar-modal .form-group{margin-bottom:var(--space-4)}.cargar-modal .form-group .input{width:100%}.cargar-monto-preview{padding:var(--space-3);margin-bottom:var(--space-4);background:var(--surface-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.cargar-monto-preview-title{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.cargar-monto-preview-title svg{color:var(--accent-primary)}.cargar-monto-preview-line{margin:0 0 var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.cargar-monto-preview-note{margin:0 0 var(--space-2);font-size:var(--text-xs);color:var(--text-muted)}.cargar-monto-hint{font-weight:var(--font-normal);color:var(--text-muted)}.event-card-body{border-top:1px solid var(--border-secondary);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.event-user-group{display:flex;flex-direction:column;gap:var(--space-2)}.event-day-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-3);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);background-color:var(--surface-secondary);border-radius:var(--radius-md)}@media (max-width: 639px){.event-day-row{gap:var(--space-2);overflow-x:auto}.event-day-fecha,.event-day-time,.event-day-hours{font-size:var(--text-xs)}}.event-day-name{font-weight:var(--font-semibold);color:var(--text-primary);min-width:80px}.day-row-paid{background-color:color-mix(in srgb,var(--color-primary-500) 5%,transparent)}.event-day-fecha{color:var(--text-secondary);font-weight:var(--font-medium)}.event-day-time,.event-day-hours{color:var(--text-muted);font-size:var(--text-xs)}.event-day-monto{font-weight:var(--font-semibold);color:var(--text-primary)}.event-day-actions{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-left:auto;flex-shrink:0;justify-content:flex-end}.event-day-btn-danger{color:var(--error-text, #b91c1c)}.event-day-btn-danger:hover{background:var(--error-bg, #fef2f2)}.detailed-records-list{display:flex;flex-direction:column;gap:var(--space-2)}.detail-record{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.detail-record:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-sm)}.detail-record-paid{background:linear-gradient(145deg,var(--surface-primary),color-mix(in srgb,var(--color-primary-500) 3%,transparent));border-color:var(--color-primary-300)}.detail-record-main{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);flex-wrap:wrap}.detail-record-left{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:160px}.employee-avatar-sm{width:32px;height:32px;font-size:var(--text-sm)}.detail-record-info{display:flex;flex-direction:column;min-width:0}.detail-record-name{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-record-event{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-record-center{display:flex;gap:var(--space-3);align-items:center;flex-shrink:0}.detail-record-date{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.detail-record-time{font-size:var(--text-sm);color:var(--text-muted)}.detail-record-right{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.detail-record-monto{font-weight:var(--font-bold);font-size:var(--text-sm);color:var(--text-primary)}.detail-record-actions{display:flex;gap:var(--space-2);flex-shrink:0;margin-left:auto}.status-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap}.status-paid,.status-success{background-color:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.status-error{background-color:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.status-pending{background-color:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.mobile-only{display:none}.validation-info{display:flex;flex-direction:column;gap:var(--space-6)}.validation-employee{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background-color:var(--surface-secondary);border-radius:var(--radius-lg)}.validation-avatar{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:var(--font-bold);font-size:var(--text-xl);border-radius:var(--radius-xl);flex-shrink:0}.validation-employee h4{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-1)}.validation-employee p{font-size:var(--text-sm);color:var(--text-muted);margin:0}.validation-details{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.validation-detail{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);background-color:var(--surface-secondary);border-radius:var(--radius-lg)}.validation-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.validation-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.validation-amount{color:var(--accent-primary);font-size:var(--text-lg)}.validation-photos{display:flex;flex-direction:column;align-items:center;gap:var(--space-6);max-height:60vh;overflow-y:auto;overflow-x:hidden;padding-right:var(--space-2)}.validation-photos::-webkit-scrollbar{width:6px}.validation-photos::-webkit-scrollbar-track{background:var(--surface-secondary);border-radius:var(--radius-sm)}.validation-photos::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:var(--radius-sm)}.validation-photo{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);width:100%}.validation-photo-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);text-align:center}.validation-photo-img{width:100%;max-width:500px;aspect-ratio:4/3;object-fit:contain;border-radius:var(--radius-lg);border:2px solid var(--border-primary);cursor:zoom-in;transition:all var(--transition-normal)}.validation-photo-img:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg)}.validation-photos-extra{width:100%}.validation-photos-extra-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);width:100%;max-width:500px}.validation-photo-extra{max-width:100%;aspect-ratio:1}.validation-nota-extra{margin-bottom:var(--space-3)}.validation-nota-text{margin:var(--space-1) 0 0;padding:var(--space-2);background:var(--surface-secondary);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary)}.validation-photo-img.expanded{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90vw;max-width:1200px;height:80vh;aspect-ratio:auto;object-fit:contain;z-index:var(--z-modal);cursor:zoom-out;background:var(--bg-overlay);border:none;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.validation-modal-compact{display:flex;flex-direction:column;gap:var(--space-4)}.validation-info-inline{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--surface-secondary);border-radius:var(--radius-lg)}.validation-employee-compact{display:flex;flex-direction:column;gap:var(--space-1)}.validation-name{font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--text-primary)}.validation-meta{font-size:var(--text-sm);color:var(--text-muted)}.validation-details-inline{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary)}.validation-monto{font-weight:var(--font-semibold);color:var(--accent-primary)}.validation-nota-compact{padding:var(--space-2) var(--space-3);background:var(--surface-secondary);border-radius:var(--radius-md);font-size:var(--text-sm)}.validation-nota-label{font-weight:var(--font-medium);color:var(--text-secondary);margin-right:var(--space-2)}.validation-photos-icons{display:flex;flex-wrap:wrap;gap:var(--space-2)}.validation-photo-icon-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--accent-primary);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-fast)}.validation-photo-icon-btn:hover{background:var(--surface-tertiary);border-color:var(--accent-primary)}.validation-photo-icon-btn svg{width:18px;height:18px}.validation-photo-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1001;padding:var(--space-4)}.validation-photo-modal{position:relative;max-width:95vw;max-height:90vh}.validation-photo-close{position:absolute;top:var(--space-2);right:var(--space-2);width:36px;height:36px;border-radius:var(--radius-full);background:#0009;color:#fff;border:none;font-size:1.5rem;cursor:pointer;z-index:1;display:flex;align-items:center;justify-content:center;line-height:1}.validation-photo-modal .validation-photo-modal-img{display:block;max-width:95vw;max-height:85vh;width:auto;height:auto;border-radius:var(--radius-lg)}.payment-user{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--border-secondary)}.payment-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:var(--font-bold);font-size:var(--text-lg);border-radius:var(--radius-lg)}.payment-user-name{font-weight:var(--font-semibold);color:var(--text-primary)}.payment-balance{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);margin-bottom:var(--space-5);background:linear-gradient(135deg,var(--warning-bg),var(--surface-secondary));border:1px solid var(--warning-border);border-radius:var(--radius-lg)}.payment-balance-label{font-size:var(--text-sm);color:var(--warning-text)}.payment-balance-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--warning-text)}.input-prefix{position:relative;display:flex;align-items:center}.input-prefix-symbol{position:absolute;left:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-muted)}.input-prefix input{padding-left:var(--space-10);font-size:var(--text-lg);font-weight:var(--font-semibold)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);gap:var(--space-4);background-color:var(--surface-primary);border:1px dashed var(--border-primary);border-radius:var(--radius-xl)}.empty-state-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--surface-secondary),var(--surface-tertiary));border-radius:var(--radius-xl);color:var(--text-muted)}.empty-state-icon svg{width:32px;height:32px}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.empty-state-description{font-size:var(--text-sm);color:var(--text-muted);max-width:320px;margin:0}@media (max-width: 1023px){.page-title{font-size:var(--text-xl)}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.stat-value{font-size:var(--text-xl)}.employee-summary-grid{grid-template-columns:1fr}}@media (max-width: 639px){.stats-grid{grid-template-columns:1fr 1fr}.stat-card{padding:var(--space-4)}.page-actions{width:100%}.page-actions .btn{flex:1;justify-content:center}.week-selector{width:100%}.validation-photos{max-height:50vh;gap:var(--space-4)}.validation-photo-img{max-width:100%}.validation-photo-img.expanded{width:95vw;height:70vh}.validation-details{grid-template-columns:1fr}.event-card-toggle{padding:var(--space-3) var(--space-4);flex-wrap:wrap}.event-card-toggle-total{font-size:var(--text-sm)}.detail-record-main{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.detail-record-left,.detail-record-center{width:100%}.detail-record-right{width:100%;justify-content:space-between}.detail-record-actions{width:100%;justify-content:flex-end;margin-left:0}.btn-text{display:none}}@media print{.page-actions,.detail-record-actions,.event-day-actions,.employee-payment-btn{display:none!important}.stat-card{break-inside:avoid}}[data-theme=light] .stat-card-success{background:linear-gradient(145deg,#dcfce7,var(--surface-primary));border-color:#86efac}[data-theme=light] .stat-card-success .stat-value{color:#15803d}[data-theme=light] .stat-card-warning{background:linear-gradient(145deg,#fef3c7,var(--surface-primary));border-color:#fcd34d}[data-theme=light] .stat-card-warning .stat-value{color:#b45309}[data-theme=light] .stat-card-primary{background:linear-gradient(145deg,#fdf2f8,#fce7f3);border-color:#fbcfe8}[data-theme=light] .stat-card-primary .stat-label{color:#db2777}[data-theme=light] .stat-card-primary .stat-value{color:#be185d}[data-theme=light] .employee-avatar{background:linear-gradient(135deg,#f43f5e,#ec4899)}[data-theme=light] .stat-label,[data-theme=light] .employee-stat-label{color:var(--color-slate-600)}[data-theme=light] .stat-value,[data-theme=light] .employee-stat-value{color:var(--color-slate-900)}[data-theme=light] .employee-stat-paid{color:#15803d}[data-theme=light] .employee-stat-balance{color:#b45309}.eventos-page{animation:fadeIn var(--transition-normal) ease-out}.events-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-2)}@media (min-width: 640px){.events-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.events-grid{grid-template-columns:repeat(3,1fr)}}.event-card{display:flex;flex-direction:column;background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-normal)}.event-card:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.event-card-content{flex:1;padding:var(--space-2) var(--space-3)}.event-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-2)}.event-card-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);line-height:var(--leading-tight);flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.event-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1) var(--space-3)}.event-card-meta-item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.event-card-meta-item svg{flex-shrink:0;width:12px;height:12px;color:var(--text-muted)}.event-card-oficina .event-card-oficina-meta{gap:var(--space-1) var(--space-3)}.event-card-personal-list span{display:inline;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-oficina,.badge-default{font-size:10px;font-weight:var(--font-semibold);padding:2px var(--space-1);border-radius:var(--radius-sm)}.badge-oficina{background:color-mix(in srgb,var(--accent-primary) 20%,transparent);color:var(--accent-primary)}.event-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--surface-secondary);border-top:1px solid var(--border-secondary)}.event-card-footer .btn{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.loading-spinner-sm{width:16px;height:16px;border:2px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.eventos-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.eventos-modal{display:flex;flex-direction:column;max-height:90vh;width:100%;max-width:1200px}.eventos-modal-filters{display:flex;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid var(--border-secondary);background:var(--surface-secondary)}.eventos-filter-search{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:200px}.eventos-filter-search svg{color:var(--text-muted);flex-shrink:0}.eventos-filter-search .input{flex:1}.eventos-modal-body{flex:1;overflow-y:auto;padding:var(--space-3)}.eventos-modal-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-2)}@media (min-width: 640px){.eventos-modal-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 900px){.eventos-modal-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1200px){.eventos-modal-grid{grid-template-columns:repeat(4,1fr)}}.eventos-modal-empty{text-align:center;color:var(--text-muted);padding:var(--space-8)}.eventos-modal-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-secondary);background:var(--surface-secondary)}.eventos-pagination-info{font-size:var(--text-sm);color:var(--text-muted)}.eventos-pagination{display:flex;gap:var(--space-2)}.evento-historial-modal{max-width:min(95vw,1100px)}.evento-historial-body{max-height:80vh;overflow-y:auto;padding:var(--space-4)}.evento-historial-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8);color:var(--text-muted)}.evento-historial-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}@media (max-width: 767px){.evento-historial-grid{grid-template-columns:1fr}}.evento-historial-registros,.evento-historial-fotos-extras{display:flex;flex-direction:column;min-height:0}.evento-historial-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-secondary)}.evento-historial-section-title svg{color:var(--accent-primary)}.evento-historial-records-list{display:flex;flex-direction:column;gap:var(--space-2);overflow-y:auto;max-height:50vh}.evento-historial-empty{font-size:var(--text-sm);color:var(--text-muted);margin:0;padding:var(--space-4)}.evento-historial-record-item{padding:var(--space-3);background:var(--surface-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.evento-historial-record-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.evento-historial-record-nombre{font-weight:var(--font-semibold);color:var(--text-primary)}.evento-historial-record-fecha{font-size:var(--text-xs);color:var(--text-muted)}.evento-historial-record-details{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.evento-historial-record-photos{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.evento-historial-photo-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--surface-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--accent-primary);cursor:pointer}.evento-historial-photo-btn:hover{background:var(--surface-primary);border-color:var(--accent-primary)}.evento-historial-fotos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-3);overflow-y:auto;max-height:50vh}.evento-historial-foto-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.evento-historial-foto-thumb{width:100%;aspect-ratio:1;padding:0;border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:var(--surface-secondary)}.evento-historial-foto-thumb:hover{border-color:var(--accent-primary)}.evento-historial-foto-img{width:100%;height:100%;object-fit:cover;display:block}.evento-historial-foto-label{font-size:var(--text-xs);color:var(--text-muted);text-align:center}.evento-historial-photo-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1100}.evento-historial-photo-modal{position:relative;max-width:90vw;max-height:90vh}.evento-historial-photo-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:var(--space-1)}.evento-historial-photo-full{max-width:90vw;max-height:85vh;object-fit:contain}.calendar-picker{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-4);max-width:360px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-lg);cursor:pointer;transition:all var(--transition-fast)}.calendar-nav-btn:hover{background-color:var(--surface-tertiary);color:var(--text-primary)}.calendar-month-year{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1);margin-bottom:var(--space-2)}.calendar-weekday{text-align:center;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);padding:var(--space-2)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-1)}.calendar-day-wrapper{aspect-ratio:1;display:flex;align-items:center;justify-content:center}.calendar-day{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid transparent;border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.calendar-day:hover{background-color:var(--surface-secondary);border-color:var(--border-primary)}.calendar-day.selected{background:linear-gradient(135deg,var(--accent-primary),var(--color-primary-600));border-color:var(--accent-primary);color:#fff;font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}.calendar-day.selected:hover{background:linear-gradient(135deg,var(--accent-primary-hover),var(--accent-primary));transform:scale(1.05)}.calendar-summary{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-secondary);text-align:center;font-size:var(--text-sm);color:var(--text-secondary)}@media (max-width: 480px){.calendar-picker{padding:var(--space-3)}.calendar-nav-btn{width:32px;height:32px}.calendar-day{font-size:var(--text-xs);border-radius:var(--radius-md)}}.oficina-dias-picker{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-4);max-width:480px}.oficina-dias-picker .field-hint{margin-bottom:var(--space-3);font-size:var(--text-sm);color:var(--text-muted)}.oficina-dias-semana{margin-bottom:var(--space-5)}.oficina-dias-checkboxes{display:flex;flex-wrap:wrap;gap:var(--space-2)}.oficina-dia-check{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.oficina-dia-check:hover{border-color:var(--accent-primary)}.oficina-dia-check.checked{background:linear-gradient(135deg,color-mix(in srgb,var(--accent-primary) 15%,transparent),color-mix(in srgb,var(--accent-primary) 8%,transparent));border-color:var(--accent-primary)}.oficina-dia-check input{margin:0;accent-color:var(--accent-primary)}.oficina-dia-check span{font-weight:var(--font-medium);font-size:var(--text-sm);color:var(--text-primary)}.oficina-horarios{margin-bottom:var(--space-4)}.oficina-horarios .checkbox-label{margin-bottom:var(--space-3)}.oficina-horarios-generales{display:flex;gap:var(--space-4);flex-wrap:wrap}.oficina-horarios-generales label{flex:1;min-width:120px}.oficina-horarios-por-dia{display:flex;flex-direction:column;gap:var(--space-3)}.oficina-empty-hint{font-size:var(--text-sm);color:var(--text-muted);font-style:italic}.oficina-horario-fila{display:flex;align-items:center;gap:var(--space-3)}.oficina-dia-label{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--text-secondary);min-width:36px}.oficina-horario-fila input{flex:1;max-width:120px;padding:var(--space-2) var(--space-3)}.oficina-resumen{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-secondary);font-size:var(--text-sm);color:var(--text-secondary)}.oficina-fechas-list{color:var(--text-muted);font-size:var(--text-xs)}.evento-detalle h1{margin:0 0 var(--space-6);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.evento-detalle{padding:var(--space-4);max-width:800px}.field-tipo-evento{margin-bottom:var(--space-4)}.field-tipo-evento .field-hint{display:block;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--text-muted);text-transform:none;letter-spacing:normal}.field-tipo-evento select{min-width:180px;padding:var(--space-3) var(--space-4);font-size:var(--text-base);border-radius:var(--radius-lg)}.field-nombre-evento{margin-bottom:var(--space-6);padding:var(--space-5);background:linear-gradient(135deg,var(--surface-secondary) 0%,color-mix(in srgb,var(--surface-secondary) 95%,var(--bg-primary)) 100%);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.field-nombre-evento:focus-within{border-color:color-mix(in srgb,var(--accent-primary) 40%,var(--border-primary));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent-primary) 25%,transparent),var(--shadow-md)}.field-nombre-evento label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.field-nombre-evento input{width:100%;max-width:none;padding:var(--space-4) var(--space-4);font-size:var(--text-lg);font-weight:var(--font-medium);letter-spacing:-.01em;border-radius:var(--radius-lg)}.field-nombre-evento input::placeholder{color:var(--text-muted);font-weight:var(--font-normal)}.evento-detalle label{display:block;margin-bottom:var(--space-5);font-weight:var(--font-semibold);color:var(--text-primary);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em}.evento-detalle label input,.evento-detalle label textarea{margin-left:0;margin-top:var(--space-2);font-weight:var(--font-normal);text-transform:none;letter-spacing:normal}.evento-detalle input[type=text],.evento-detalle input[type=date],.evento-detalle input[type=time],.evento-detalle input[type=number],.evento-detalle input[type=url]{width:100%;max-width:320px;padding:var(--space-3) var(--space-4);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.evento-detalle input[type=text]:focus,.evento-detalle input[type=date]:focus,.evento-detalle input[type=time]:focus,.evento-detalle input[type=number]:focus,.evento-detalle input[type=url]:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent),var(--shadow-md);background:var(--surface-primary)}.evento-detalle input::placeholder{color:var(--text-muted)}.evento-detalle fieldset{border:1px solid var(--border-primary);border-radius:var(--radius-xl);padding:var(--space-4);margin-bottom:var(--space-5);background:var(--surface-secondary);box-shadow:var(--shadow-sm)}.evento-detalle fieldset legend{font-weight:var(--font-semibold);color:var(--text-primary);padding:0 var(--space-2)}.evento-detalle .checkbox-label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.evento-detalle .checkbox-label input{width:auto;max-width:none}.evento-fieldset{margin-bottom:1rem}.field-hint{font-size:.85rem;color:var(--text-muted);margin:0 0 .5rem}.horarios-generales{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-top:var(--space-2)}.horarios-generales label{margin-bottom:0}.horarios-por-fecha{margin-top:var(--space-2)}.horario-fila{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);flex-wrap:wrap}.horario-fila .fecha-label{min-width:100px;font-size:var(--text-sm);color:var(--text-secondary)}.horario-fila input[type=time]{width:100px;padding:.4rem}.evento-detalle textarea{width:100%;max-width:400px;padding:var(--space-3) var(--space-4);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);font-family:var(--font-sans);resize:vertical;min-height:80px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.evento-detalle textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent),var(--shadow-md);background:var(--surface-primary)}.evento-detalle textarea::placeholder{color:var(--text-muted)}.evento-detalle input[type=url]{max-width:100%}.form-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);flex-wrap:wrap}.btn-secondary{padding:var(--space-3) var(--space-4);background:var(--surface-secondary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:var(--radius-lg);cursor:pointer;font-weight:var(--font-medium);transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--surface-tertiary);border-color:var(--text-muted)}.btn-primary{padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,var(--accent-primary),var(--color-primary-600));border:none;color:#fff;border-radius:var(--radius-lg);cursor:pointer;font-weight:var(--font-semibold);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{padding:var(--space-3) var(--space-4);background:transparent;border:1px solid var(--color-error-500);color:var(--color-error-500);border-radius:var(--radius-lg);cursor:pointer;font-weight:var(--font-medium);margin-left:auto;transition:all var(--transition-fast)}.btn-danger:hover:not(:disabled){background:var(--color-error-50)}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.error-msg{color:var(--color-error-500);margin-bottom:var(--space-2);font-size:var(--text-sm)}.personal-fieldset{position:relative}.personal-search-wrapper{position:relative;margin-bottom:var(--space-3)}.personal-search-input{width:100%;max-width:100%!important;padding:var(--space-3) var(--space-4);background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.personal-search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent),var(--shadow-md)}.personal-search-results{position:absolute;top:100%;left:0;right:0;z-index:20;max-height:200px;overflow-y:auto;background:var(--surface-primary);border:1px solid var(--border-primary);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg);list-style:none;margin:0;padding:0}.personal-search-results li{padding:var(--space-3) var(--space-4);cursor:pointer;font-size:var(--text-sm);color:var(--text-primary);transition:background var(--transition-fast)}.personal-search-results li:hover{background:color-mix(in srgb,var(--accent-primary) 12%,var(--surface-primary))}.personal-search-empty{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-muted);position:absolute;top:100%;left:0;right:0;background:var(--surface-primary);border:1px solid var(--border-primary);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg)}.personal-assigned-list{display:flex;flex-direction:column;gap:var(--space-2)}.personal-assigned-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:box-shadow var(--transition-fast)}.personal-assigned-row:hover{box-shadow:var(--shadow-sm)}.personal-assigned-info{display:flex;align-items:center;gap:var(--space-3);flex:1;min-width:0}.personal-assigned-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.personal-remove-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 6px;font-size:var(--text-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);line-height:1;flex-shrink:0}.personal-remove-btn:hover{color:var(--color-error-500);background:var(--color-error-50)}.personal-monto-field{flex-shrink:0}.personal-monto-field label{display:flex;align-items:center;gap:var(--space-2);margin-bottom:0;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.personal-monto-field input{width:120px!important;max-width:120px!important;padding:var(--space-2) var(--space-3)!important;font-size:var(--text-sm)!important;text-align:right}.personal-page{animation:fadeIn var(--transition-normal) ease-out}.personal-search-bar{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-5);padding:var(--space-2);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);max-width:400px}.personal-search-bar svg{flex-shrink:0;color:var(--text-muted)}.personal-search-input{flex:1;min-width:0;border:none;background:transparent;font-size:var(--text-sm)}.personal-search-input:focus{outline:none;box-shadow:none}.personal-search-clear{display:flex;align-items:center;justify-content:center;padding:var(--space-1);background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md)}.personal-search-clear:hover{color:var(--text-primary);background:var(--surface-tertiary)}.personal-no-results{grid-column:1 / -1;text-align:center;padding:var(--space-8);color:var(--text-muted)}.personal-no-results p{margin:0 0 var(--space-3)}.historial-user-modal{max-width:min(95vw,800px)}@media (min-width: 768px){.historial-user-modal{max-width:min(95vw,1100px);width:100%}}.historial-user-tabs{display:flex;gap:var(--space-1);padding:0 var(--space-5) var(--space-2);border-bottom:1px solid var(--border-secondary);background:var(--surface-secondary)}.historial-user-tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.historial-user-tab:hover{color:var(--text-primary)}.historial-user-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.historial-user-modal-body{max-height:min(70vh,600px);overflow-y:auto}@media (min-width: 768px){.historial-user-modal-body{max-height:min(75vh,700px);min-height:360px}}.historial-user-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8);color:var(--text-muted)}.historial-user-section{margin-bottom:var(--space-6)}.historial-user-section:last-child{margin-bottom:0}.historial-user-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-secondary)}.historial-user-section-title svg{color:var(--accent-primary)}.historial-user-attendance-list,.historial-user-logs-list{display:flex;flex-direction:column;gap:var(--space-2)}.historial-user-empty{font-size:var(--text-sm);color:var(--text-muted);margin:0;padding:var(--space-4)}.historial-user-attendance-item{padding:var(--space-3);background:var(--surface-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.historial-user-attendance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.historial-user-attendance-evento{font-weight:var(--font-semibold);color:var(--text-primary)}.historial-user-attendance-fecha{font-size:var(--text-xs);color:var(--text-muted)}.historial-user-attendance-details{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.historial-user-photos{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.historial-user-photo-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--surface-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--accent-primary);cursor:pointer}.historial-user-photo-btn:hover{background:var(--surface-primary);border-color:var(--accent-primary)}.historial-user-logs-table-wrap{overflow-x:auto}.historial-user-logs-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.historial-user-logs-table th,.historial-user-logs-table td{padding:var(--space-2) var(--space-3);text-align:left;border-bottom:1px solid var(--border-primary)}.historial-user-logs-table th{font-weight:var(--font-semibold);color:var(--text-secondary);background:var(--surface-secondary)}.historial-user-photo-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1100}.historial-user-photo-modal{position:relative;max-width:90vw;max-height:90vh}.historial-user-photo-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:var(--space-1)}.historial-user-photo-img{max-width:90vw;max-height:85vh;object-fit:contain}.historial-user-actions{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border-primary)}.historial-user-cargar-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer}.historial-user-cargar-btn:hover{filter:brightness(1.1)}.historial-cargar-modal{max-width:min(95vw,480px)}.historial-cargar-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.historial-cargar-context{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--text-secondary)}.historial-cargar-context strong{color:var(--text-primary)}.historial-cargar-error{margin:0 0 var(--space-3);padding:var(--space-2);background:var(--error-bg, #fef2f2);color:var(--error-text, #b91c1c);border-radius:var(--radius-md);font-size:var(--text-sm)}.historial-cargar-monto-preview{margin-bottom:var(--space-4);padding:var(--space-3);background:var(--surface-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.historial-cargar-monto-title{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold)}.users-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--space-4)}@media (min-width: 640px){.users-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.users-grid{grid-template-columns:repeat(3,1fr)}}.user-card{display:flex;flex-direction:column;background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.user-card:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-lg)}.user-card-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5);background:linear-gradient(145deg,var(--surface-primary),var(--surface-secondary));border-bottom:1px solid var(--border-secondary)}.user-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:var(--font-bold);font-size:var(--text-lg);border-radius:var(--radius-lg);flex-shrink:0}.user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.user-name{font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);align-self:flex-start}.user-role-badge.personal{background-color:var(--info-bg);color:var(--info-text);border:1px solid var(--info-border)}.user-role-badge.admin{background:linear-gradient(135deg,#7c2d12,#b91c1c,#dc2626);color:#fef3c7;border:1px solid #f97316;box-shadow:0 0 8px #f9731666;animation:admin-fire-glow 2s ease-in-out infinite}.user-role-badge.admin svg{animation:admin-flame-flicker .8s ease-in-out infinite}@keyframes admin-fire-glow{0%,to{box-shadow:0 0 8px #f9731666;filter:brightness(1)}50%{box-shadow:0 0 14px #fb923cb3;filter:brightness(1.15)}}@keyframes admin-flame-flicker{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.9}}.user-role-badge:not(.personal):not(.admin){background-color:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.user-card-body{padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);flex:1}.user-contact{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.user-contact svg{flex-shrink:0;color:var(--text-muted);width:14px;height:14px}.user-card-footer{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--surface-secondary);border-top:1px solid var(--border-secondary)}.credentials-box{padding:var(--space-4);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.credentials-item{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.credentials-item:last-child{margin-bottom:0}.credentials-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.credentials-value{font-family:var(--font-mono);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);word-break:break-all}.credentials-hint{font-size:var(--text-sm);color:var(--text-muted);text-align:center;margin:0}.mis-eventos-page{animation:fadeIn var(--transition-normal) ease-out}.events-list{display:flex;flex-direction:column;gap:var(--space-3)}.event-list-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5);background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);color:inherit;text-decoration:none;transition:all var(--transition-normal)}.event-list-item:hover{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary),var(--shadow-lg);transform:translateY(-2px)}.event-list-item.today{background:linear-gradient(145deg,var(--surface-primary),color-mix(in srgb,var(--accent-primary) 5%,transparent));border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.event-list-item.past{opacity:.7}.event-list-content{flex:1;min-width:0}.event-badge-today,.event-badge-past,.event-badge-future{display:inline-block;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);margin-bottom:var(--space-2)}.event-badge-today{background:linear-gradient(135deg,var(--accent-primary),var(--color-primary-600));color:#fff}.event-badge-past{background-color:var(--surface-tertiary);color:var(--text-muted)}.event-badge-future{background-color:var(--info-bg);color:var(--info-text);border:1px solid var(--info-border)}.event-list-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-3);line-height:var(--leading-tight)}.event-list-meta{display:flex;flex-direction:column;gap:var(--space-2)}.event-list-meta-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-secondary)}.event-list-meta-item svg{flex-shrink:0;color:var(--text-muted);width:16px;height:16px}.event-list-ubicacion-link{color:var(--accent-primary);font-weight:var(--font-medium);text-decoration:none}.event-list-ubicacion-link:hover{text-decoration:underline}.event-list-ubicacion-ref{color:var(--text-secondary)}.event-list-ubicacion-none{color:var(--text-muted)}.event-list-action{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--surface-secondary);border-radius:var(--radius-lg);color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0}.event-list-item:hover .event-list-action{background-color:var(--accent-primary);color:#fff}@media (max-width: 639px){.event-list-item{padding:var(--space-4)}.event-list-title{font-size:var(--text-base)}}.evento-asistencia{width:100%;max-width:480px;margin:0 auto;padding:var(--space-4);animation:eventoAsistenciaFadeIn var(--transition-normal) ease-out}@keyframes eventoAsistenciaFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.evento-asistencia-card{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-md)}.evento-asistencia-header{margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-secondary)}.evento-asistencia-title{margin:0 0 var(--space-1);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--text-primary);line-height:var(--leading-tight)}.evento-asistencia-meta{display:flex;flex-direction:column;gap:var(--space-2);margin:0 0 var(--space-2)}.evento-asistencia-meta-item{display:flex;align-items:baseline;gap:var(--space-2);margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.evento-asistencia-meta-label{font-weight:var(--font-semibold);color:var(--text-muted);min-width:4.5rem}.evento-asistencia-badge{display:inline-block;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);margin-top:var(--space-2)}.evento-asistencia-badge.badge-ok{background-color:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.evento-asistencia-badge.badge-no{background-color:var(--surface-tertiary);color:var(--text-muted);border:1px solid var(--border-primary)}.evento-asistencia-ubicacion-block{margin-bottom:var(--space-3)}.evento-asistencia-ubicacion{margin:0 0 var(--space-2);font-size:var(--text-sm)}.evento-asistencia-ubicacion-none{color:var(--text-muted)}.evento-asistencia-ubicacion a{color:var(--accent-primary);font-weight:var(--font-medium);text-decoration:none;transition:color var(--transition-fast)}.evento-asistencia-ubicacion a:hover{color:var(--accent-primary-hover)}.evento-asistencia-indicaciones{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-4);font-style:italic}.evento-asistencia-camera{margin:var(--space-4) 0}.evento-asistencia-camera-preview{position:relative;margin-bottom:var(--space-3);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-slate-900);aspect-ratio:4/3;max-height:280px}.evento-asistencia-camera-preview video{width:100%;height:100%;object-fit:cover;display:block}.evento-asistencia-camera-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:var(--space-4);margin:0;font-size:var(--text-sm);color:var(--error-text);background-color:var(--error-bg);text-align:center}.evento-asistencia-camera-hint{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-3)}.evento-asistencia-camera-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.evento-asistencia-camera-actions .btn{flex:1;min-width:120px}.evento-asistencia-actions{display:flex;flex-direction:column;gap:var(--space-2);margin:var(--space-3) 0}.evento-asistencia-btn-checkin,.evento-asistencia-btn-checkout{width:100%;min-height:52px;font-size:var(--text-base);font-weight:var(--font-semibold)}.evento-asistencia-btn-checkin{background-color:var(--color-success-600);color:#fff;border:none;box-shadow:var(--shadow-sm),0 0 0 1px var(--color-success-700)}.evento-asistencia-btn-checkin:hover:not(:disabled){background-color:var(--color-success-700)}.evento-asistencia-btn-checkin:disabled{opacity:.6;cursor:not-allowed}.evento-asistencia-btn-checkout{background-color:var(--accent-primary);color:#fff;border:none;box-shadow:var(--shadow-sm),0 0 0 1px var(--accent-primary-active)}.evento-asistencia-btn-checkout:hover:not(:disabled){background-color:var(--accent-primary-hover)}.evento-asistencia-btn-checkout:disabled{opacity:.6;cursor:not-allowed}.evento-asistencia-extras{margin:var(--space-3) 0;padding:var(--space-3);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.evento-asistencia-fecha-select{margin-bottom:var(--space-3)}.evento-asistencia-fecha-select label{display:block;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.evento-asistencia-fecha-select select{padding:var(--space-2) var(--space-3);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-base);background:var(--bg-primary);color:var(--text-primary);min-width:180px}.evento-asistencia-extras-hint{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--space-3)}.evento-asistencia-extras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-1);margin-bottom:var(--space-3)}.evento-asistencia-nota{margin-bottom:var(--space-4)}.evento-asistencia-nota label{display:block;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.evento-asistencia-nota textarea{width:100%;padding:var(--space-2);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:inherit;resize:vertical;min-height:48px}.evento-asistencia-extras-slot{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background-color:var(--surface-tertiary)}.evento-asistencia-extras-add{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-muted);background:none;border:2px dashed var(--border-primary);cursor:pointer;transition:border-color var(--transition-fast),color var(--transition-fast)}.evento-asistencia-extras-add:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.evento-asistencia-extras-add:disabled{cursor:not-allowed;opacity:.5}.evento-asistencia-extras-preview{position:relative;width:100%;height:100%}.evento-asistencia-extras-preview img,.evento-asistencia-extras-preview .evento-asistencia-extras-img{width:100%;height:100%;object-fit:cover;display:block}.evento-asistencia-extras-img{cursor:default}.evento-asistencia-extras-remove{position:absolute;top:var(--space-1);right:var(--space-1);width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1;background-color:#0009;color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;padding:0}.evento-asistencia-extras-actions{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.evento-asistencia-extras-actions .btn{flex:1;min-width:100px}.evento-asistencia-save-ok{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-success-600);display:inline-flex;align-items:center;gap:var(--space-1)}.evento-asistencia-done{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius-lg);color:var(--success-text)}.evento-asistencia-done-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--color-success-500);color:#fff;border-radius:var(--radius-full);font-size:var(--text-lg);font-weight:var(--font-bold);flex-shrink:0}.evento-asistencia-summary{margin-top:var(--space-3);padding:var(--space-3);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md)}.evento-asistencia-summary-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0}.evento-asistencia-summary-row:not(:last-child){border-bottom:1px solid var(--border-secondary)}.evento-asistencia-summary-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary)}.evento-asistencia-summary-value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.evento-asistencia-alert{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm)}.evento-asistencia-error{background-color:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}[data-theme=light] .evento-asistencia-card{box-shadow:var(--shadow-md),0 1px 3px #0000000f}[data-theme=light] .evento-asistencia-btn-checkin{background-color:var(--color-success-600)}[data-theme=light] .evento-asistencia-btn-checkin:hover:not(:disabled){background-color:var(--color-success-700)}[data-theme=light] .evento-asistencia-btn-checkout{background-color:var(--accent-primary)}[data-theme=light] .evento-asistencia-btn-checkout:hover:not(:disabled){background-color:var(--accent-primary-hover)}[data-theme=light] .evento-asistencia-summary{background-color:var(--surface-secondary)}@media (min-width: 640px){.evento-asistencia{max-width:520px;padding:var(--space-6)}.evento-asistencia-card{padding:var(--space-8)}.evento-asistencia-title{font-size:var(--text-2xl)}.evento-asistencia-camera-preview{max-height:320px}}@media (min-width: 768px){.evento-asistencia{max-width:560px}}.historial-page{animation:fadeIn var(--transition-normal) ease-out}.historial-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-5);background:linear-gradient(145deg,var(--surface-primary),var(--surface-secondary));border:1px solid var(--border-primary);border-radius:var(--radius-xl)}@media (max-width: 639px){.historial-summary{grid-template-columns:1fr;gap:var(--space-3)}}.historial-stat{display:flex;flex-direction:column;gap:var(--space-1);text-align:center;padding:var(--space-3);border-radius:var(--radius-lg)}.historial-stat-success{background-color:var(--success-bg)}.historial-stat-warning{background-color:var(--warning-bg)}.historial-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.historial-stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary)}.historial-stat-success .historial-stat-value{color:var(--success-text)}.historial-stat-warning .historial-stat-value{color:var(--warning-text)}.historial-list{display:flex;flex-direction:column;gap:var(--space-4)}.historial-item{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.historial-item:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-md)}.historial-item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:var(--space-5);background:linear-gradient(145deg,var(--surface-primary),var(--surface-secondary));border-bottom:1px solid var(--border-secondary)}.historial-item-info{flex:1;min-width:0}.historial-item-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2);line-height:var(--leading-tight)}.historial-item-date{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted)}.historial-item-date svg{width:14px;height:14px}.historial-status{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.historial-status svg{width:12px;height:12px}.historial-status.status-paid{background-color:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.historial-status.status-pending{background-color:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.historial-item-body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.historial-details{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media (max-width: 639px){.historial-details{grid-template-columns:1fr;gap:var(--space-2)}}.historial-detail{display:flex;flex-direction:column;gap:var(--space-1)}.historial-detail-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.historial-detail-value{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.historial-amount{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);background:linear-gradient(135deg,var(--accent-primary),var(--color-primary-600));border-radius:var(--radius-lg);color:#fff}.historial-amount svg{width:20px;height:20px}.historial-amount-value{font-size:var(--text-xl);font-weight:var(--font-bold)}.historial-photos{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);padding:0 var(--space-5) var(--space-5)}@media (max-width: 639px){.historial-photos{grid-template-columns:1fr}}.historial-photo{display:flex;flex-direction:column;gap:var(--space-2)}.historial-photo-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.historial-photo-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius-lg);border:2px solid var(--border-primary)}.historial-nota-extra{grid-column:1 / -1;margin:0;padding:var(--space-2);background:var(--surface-secondary);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-secondary)}.historial-photos-oficina{display:flex;flex-wrap:wrap}.historial-photo-icons{display:flex;flex-wrap:wrap;gap:var(--space-3)}.historial-photo-icon-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--accent-primary);cursor:pointer;transition:all var(--transition-fast)}.historial-photo-icon-btn:hover{background:var(--surface-tertiary);border-color:var(--accent-primary)}.historial-photo-icon-btn svg{width:24px;height:24px}.historial-photo-icon-label{font-size:var(--text-sm);font-weight:var(--font-medium)}.historial-photo-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.historial-photo-modal{position:relative;max-width:90vw;max-height:90vh;background:var(--surface-primary);border-radius:var(--radius-xl);overflow:hidden}.historial-photo-modal-close{position:absolute;top:var(--space-2);right:var(--space-2);width:36px;height:36px;border-radius:var(--radius-full);background:#00000080;color:#fff;border:none;font-size:1.5rem;cursor:pointer;z-index:1;display:flex;align-items:center;justify-content:center;line-height:1}.historial-photo-modal-img{display:block;max-width:90vw;max-height:85vh;width:auto;height:auto;object-fit:contain}.configuracion-page{animation:fadeIn var(--transition-normal) ease-out}.config-section{margin-bottom:var(--space-8)}.config-section-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.config-section-hint{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-4)}.config-section-danger{padding:var(--space-4);background-color:#dc35450f;border:1px solid rgba(220,53,69,.2);border-radius:var(--radius-lg)}.config-section-danger .btn{display:inline-flex;align-items:center;gap:var(--space-2)}.roles-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.role-card{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-fast)}.role-card.role-sistema{border-color:var(--border-tertiary);background-color:var(--surface-secondary)}.role-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-3)}.role-info{display:flex;align-items:center;gap:var(--space-2)}.role-name{font-weight:var(--font-semibold);color:var(--text-primary)}.role-badge-sistema{font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background-color:var(--surface-tertiary);color:var(--text-muted);border-radius:var(--radius-full)}.role-card-actions{display:flex;gap:var(--space-1)}.role-permisos-list{display:flex;flex-wrap:wrap;gap:var(--space-1)}.role-permiso-badge{font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background-color:var(--success-bg);color:var(--success-text);border-radius:var(--radius-sm)}.role-permiso-admin{background-color:var(--info-bg);color:var(--info-text)}.permisos-checkboxes{display:flex;flex-direction:column;gap:var(--space-2)}.checkbox-label-inline{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);color:var(--text-secondary)}.checkbox-label-inline input{width:18px;height:18px}.modal.modal-logs{max-width:min(95vw,1200px);width:min(95vw,1200px);min-width:560px;max-height:90vh;display:flex;flex-direction:column}.logs-modal-body{display:flex;flex-direction:column;gap:var(--space-4);overflow:hidden;min-height:0}.logs-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.logs-filters .input{flex:1;min-width:120px}.logs-list-container{flex:1;overflow:auto;min-height:300px}.logs-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8);color:var(--text-muted)}.logs-table-wrapper{overflow-x:auto}.logs-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.logs-table th,.logs-table td{padding:var(--space-2) var(--space-3);text-align:left;border-bottom:1px solid var(--border-primary)}.logs-table th{font-weight:var(--font-semibold);color:var(--text-secondary);background-color:var(--surface-secondary);position:sticky;top:0;white-space:nowrap}.logs-table tbody tr:hover{background-color:var(--surface-secondary)}.logs-cell-fecha{white-space:nowrap;color:var(--text-muted)}.logs-cell-detalle{max-width:280px;overflow:hidden;text-overflow:ellipsis}.logs-empty{text-align:center;padding:var(--space-8)!important;color:var(--text-muted)}.app-layout{min-height:100vh;display:flex;background-color:var(--bg-primary);transition:background-color var(--transition-normal)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background-color:var(--surface-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;z-index:var(--z-fixed);transition:all var(--transition-normal)}.sidebar-header{padding:var(--space-5);border-bottom:1px solid var(--border-secondary)}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);color:var(--text-primary);font-weight:var(--font-bold);font-size:var(--text-xl);letter-spacing:-.025em}.sidebar-brand:hover{color:var(--text-primary)}.sidebar-brand-logo{width:100%;max-width:160px;height:auto;object-fit:contain}.sidebar-brand-text{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.sidebar-nav-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-lg);transition:all var(--transition-fast);position:relative}.sidebar-nav-link:hover{background-color:var(--surface-secondary);color:var(--text-primary)}.sidebar-nav-link.active{background:linear-gradient(135deg,var(--accent-primary),var(--color-primary-600));color:#fff;box-shadow:var(--shadow-md)}.sidebar-nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background-color:#fff;border-radius:0 2px 2px 0}.sidebar-nav-link svg{flex-shrink:0}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border-secondary);display:flex;flex-direction:column;gap:var(--space-3)}.sidebar-theme-toggle{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.sidebar-theme-toggle:hover{background-color:var(--surface-tertiary);border-color:var(--border-tertiary);color:var(--text-primary)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--surface-secondary);border-radius:var(--radius-lg)}.sidebar-user-info{flex:1;min-width:0;display:flex;flex-direction:column}.sidebar-user-name{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:var(--text-xs);color:var(--text-muted);text-transform:capitalize}.sidebar-logout{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:transparent;border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.sidebar-logout:hover{background-color:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.main-content{flex:1;margin-left:260px;min-height:100vh;padding:var(--space-6);transition:margin-left var(--transition-normal)}.main-content-inner{max-width:1400px;margin:0 auto;animation:fadeIn var(--transition-normal) ease-out}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;width:100%;background-color:var(--surface-primary);border-bottom:1px solid var(--border-primary);z-index:var(--z-fixed);transition:all var(--transition-normal)}.mobile-header-content{display:grid;grid-template-columns:1fr auto;align-items:center;padding:var(--space-3) var(--space-4);width:100%;box-sizing:border-box}.mobile-brand{display:flex;align-items:center;color:var(--text-primary);flex-shrink:0}.mobile-brand:hover{color:var(--text-primary)}.mobile-logo-img{height:32px;width:auto;object-fit:contain}.mobile-header-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-1);padding-right:0;flex-shrink:0}.mobile-menu-toggle,.mobile-theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.mobile-menu-toggle:hover,.mobile-theme-toggle:hover{background-color:var(--surface-secondary);color:var(--text-primary)}.mobile-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:all var(--transition-normal);z-index:var(--z-modal-backdrop)}.mobile-menu-overlay.open{opacity:1;visibility:visible}.mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;width:280px;max-width:85vw;background-color:var(--surface-primary);border-left:1px solid var(--border-primary);box-shadow:var(--shadow-xl);transform:translate(100%);transition:transform var(--transition-normal);z-index:var(--z-modal);overflow-y:auto}.mobile-menu.open{transform:translate(0)}.mobile-menu-header{padding:var(--space-5);border-bottom:1px solid var(--border-secondary);background:linear-gradient(180deg,var(--surface-primary),var(--surface-secondary))}.mobile-user-card{display:flex;align-items:center;gap:var(--space-3)}.mobile-user-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;font-weight:var(--font-bold);font-size:var(--text-lg);border-radius:var(--radius-xl);flex-shrink:0}.mobile-user-info{display:flex;flex-direction:column;min-width:0}.mobile-user-name{font-weight:var(--font-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-user-role{font-size:var(--text-xs);color:var(--text-muted);text-transform:capitalize}.mobile-nav-list{list-style:none;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.mobile-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-medium);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.mobile-nav-link:hover{background-color:var(--surface-secondary);color:var(--text-primary)}.mobile-nav-link.active{background:linear-gradient(135deg,var(--accent-primary),var(--color-primary-600));color:#fff;box-shadow:var(--shadow-md)}.mobile-menu-footer{padding:var(--space-4);border-top:1px solid var(--border-secondary);margin-top:auto}.mobile-logout-btn{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4);background-color:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-lg);color:var(--error-text);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.mobile-logout-btn:hover{background-color:color-mix(in srgb,var(--color-error-500) 20%,transparent)}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background-color:var(--surface-primary);border-top:1px solid var(--border-primary);padding:var(--space-2) var(--space-4) calc(var(--space-2) + env(safe-area-inset-bottom));z-index:var(--z-fixed);transition:all var(--transition-normal)}.mobile-bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-2) var(--space-1);color:var(--text-muted);font-size:11px;font-weight:var(--font-medium);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.mobile-bottom-nav-item:hover{color:var(--text-secondary);background-color:var(--surface-secondary)}.mobile-bottom-nav-item.active{color:var(--accent-primary)}.mobile-bottom-nav-item.active svg{stroke-width:2.5}.mobile-bottom-nav-item svg{width:24px;height:24px}@media (max-width: 1023px){.sidebar{display:none}.main-content{margin-left:0;padding-top:calc(var(--space-6) + 120px);padding-bottom:calc(var(--space-6) + 72px)}.mobile-header,.mobile-menu,.mobile-menu-overlay,.mobile-bottom-nav{display:flex}.mobile-menu,.mobile-menu-overlay{display:block}.mobile-bottom-nav{display:flex;justify-content:space-around}.mobile-header-content{padding-right:0}.mobile-header-actions{margin-left:auto;margin-right:0}.mobile-menu-toggle,.mobile-theme-toggle{margin-right:0}}@media (max-width: 639px){.main-content{padding:var(--space-4);padding-top:calc(var(--space-4) + 110px);padding-bottom:calc(var(--space-4) + 68px)}}@supports (padding-top: env(safe-area-inset-top)){.mobile-header{padding-top:env(safe-area-inset-top);padding-right:env(safe-area-inset-right,0)}.mobile-bottom-nav{padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom))}}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.page-transition-enter{opacity:0;transform:translateY(8px)}.page-transition-enter-active{opacity:1;transform:translateY(0);transition:all var(--transition-normal)}.page-transition-exit{opacity:1}.page-transition-exit-active{opacity:0;transition:opacity var(--transition-fast)}[data-theme=light] .mobile-menu-toggle,[data-theme=light] .mobile-theme-toggle{color:var(--color-slate-600)}[data-theme=light] .mobile-menu-toggle:hover,[data-theme=light] .mobile-theme-toggle:hover{background-color:var(--color-slate-200);color:var(--color-slate-900)}:root{--color-primary-50: #fff1f2;--color-primary-100: #ffe4e6;--color-primary-200: #fecdd3;--color-primary-300: #fda4af;--color-primary-400: #fb7185;--color-primary-500: #f43f5e;--color-primary-600: #e11d48;--color-primary-700: #be123c;--color-primary-800: #9f1239;--color-primary-900: #881337;--color-secondary-50: #f0fdfa;--color-secondary-100: #ccfbf1;--color-secondary-200: #99f6e4;--color-secondary-300: #5eead4;--color-secondary-400: #2dd4bf;--color-secondary-500: #14b8a6;--color-secondary-600: #0d9488;--color-secondary-700: #0f766e;--color-secondary-800: #115e59;--color-secondary-900: #134e4a;--color-slate-50: #f8fafc;--color-slate-100: #f1f5f9;--color-slate-200: #e2e8f0;--color-slate-300: #cbd5e1;--color-slate-400: #94a3b8;--color-slate-500: #64748b;--color-slate-600: #475569;--color-slate-700: #334155;--color-slate-800: #1e293b;--color-slate-900: #0f172a;--color-slate-950: #020617;--color-success-50: #f0fdf4;--color-success-100: #dcfce7;--color-success-500: #22c55e;--color-success-600: #16a34a;--color-success-700: #15803d;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-error-50: #fef2f2;--color-error-100: #fee2e2;--color-error-500: #ef4444;--color-error-600: #dc2626;--color-error-700: #b91c1c;--color-info-50: #eff6ff;--color-info-100: #dbeafe;--color-info-500: #3b82f6;--color-info-600: #2563eb;--color-info-700: #1d4ed8;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, Monaco, "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-toast: 1080}[data-theme=dark]{--bg-primary: var(--color-slate-950);--bg-secondary: var(--color-slate-900);--bg-tertiary: var(--color-slate-800);--bg-elevated: var(--color-slate-800);--bg-overlay: rgb(15 23 42 / .8);--surface-primary: var(--color-slate-900);--surface-secondary: var(--color-slate-800);--surface-tertiary: var(--color-slate-700);--surface-hover: var(--color-slate-800);--text-primary: var(--color-slate-50);--text-secondary: var(--color-slate-400);--text-tertiary: var(--color-slate-500);--text-muted: var(--color-slate-500);--text-inverse: var(--color-slate-950);--border-primary: var(--color-slate-700);--border-secondary: var(--color-slate-800);--border-tertiary: var(--color-slate-600);--accent-primary: var(--color-primary-500);--accent-primary-hover: var(--color-primary-400);--accent-primary-active: var(--color-primary-600);--accent-secondary: var(--color-secondary-500);--accent-secondary-hover: var(--color-secondary-400);--success-bg: var(--color-success-900);--success-text: var(--color-success-400);--success-border: var(--color-success-700);--warning-bg: var(--color-warning-900);--warning-text: var(--color-warning-400);--warning-border: var(--color-warning-700);--error-bg: var(--color-error-900);--error-text: var(--color-error-400);--error-border: var(--color-error-700);--info-bg: var(--color-info-900);--info-text: var(--color-info-400);--info-border: var(--color-info-700);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4), 0 4px 6px -4px rgb(0 0 0 / .3);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .5), 0 8px 10px -6px rgb(0 0 0 / .4)}[data-theme=light]{--bg-primary: var(--color-slate-50);--bg-secondary: #ffffff;--bg-tertiary: var(--color-slate-100);--bg-elevated: #ffffff;--bg-overlay: rgb(15 23 42 / .6);--surface-primary: #ffffff;--surface-secondary: var(--color-slate-50);--surface-tertiary: var(--color-slate-100);--surface-hover: var(--color-slate-100);--text-primary: var(--color-slate-900);--text-secondary: var(--color-slate-600);--text-tertiary: var(--color-slate-500);--text-muted: var(--color-slate-500);--text-inverse: #ffffff;--border-primary: var(--color-slate-200);--border-secondary: var(--color-slate-100);--border-tertiary: var(--color-slate-300);--accent-primary: var(--color-primary-600);--accent-primary-hover: var(--color-primary-700);--accent-primary-active: var(--color-primary-800);--accent-secondary: var(--color-secondary-600);--accent-secondary-hover: var(--color-secondary-700);--success-bg: var(--color-success-50);--success-text: var(--color-success-700);--success-border: var(--color-success-200);--warning-bg: var(--color-warning-50);--warning-text: var(--color-warning-700);--warning-border: var(--color-warning-200);--error-bg: var(--color-error-50);--error-text: var(--color-error-700);--error-border: var(--color-error-200);--info-bg: var(--color-info-50);--info-text: var(--color-info-700);--info-border: var(--color-info-200)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);font-size:16px;line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);letter-spacing:-.025em;color:var(--text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{color:var(--text-secondary);line-height:var(--leading-relaxed)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary-hover)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-md)}::selection{background-color:var(--accent-primary);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.container{width:100%;max-width:1280px;margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}@media (min-width: 640px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}@media (min-width: 1024px){.container{padding-left:var(--space-8);padding-right:var(--space-8)}}.stack-xs>*+*{margin-top:var(--space-1)}.stack-sm>*+*{margin-top:var(--space-2)}.stack-md>*+*{margin-top:var(--space-4)}.stack-lg>*+*{margin-top:var(--space-6)}.stack-xl>*+*{margin-top:var(--space-8)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-primary)}.text-success{color:var(--color-success-500)}.text-warning{color:var(--color-warning-500)}.text-error{color:var(--color-error-500)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fadeIn{animation:fadeIn var(--transition-normal) ease-out}.animate-slideUp{animation:slideUp var(--transition-normal) ease-out}.animate-scaleIn{animation:scaleIn var(--transition-normal) cubic-bezier(.34,1.56,.64,1)}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.loading-shimmer{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton{background:var(--bg-tertiary);border-radius:var(--radius-md);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-text{height:1em;margin-bottom:var(--space-2);background:var(--bg-tertiary);border-radius:var(--radius-sm);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-text:last-child{width:80%;margin-bottom:0}.skeleton-circle{border-radius:var(--radius-full);background:var(--bg-tertiary);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@media print{.no-print{display:none!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--leading-tight);border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,rgb(255 255 255 / .1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:before{opacity:1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:translateY(1px)}.btn-primary{background-color:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm),0 0 0 1px var(--accent-primary-active)}.btn-primary:hover:not(:disabled){background-color:var(--accent-primary-hover);box-shadow:var(--shadow-md),0 0 0 1px var(--accent-primary-active)}.btn-primary:active:not(:disabled){background-color:var(--accent-primary-active)}.btn-secondary{background-color:var(--surface-secondary);color:var(--text-primary);border-color:var(--border-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--surface-hover);border-color:var(--border-tertiary)}.btn-ghost{background-color:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background-color:var(--surface-secondary);color:var(--text-primary)}.btn-danger{background-color:var(--color-error-600);color:#fff;box-shadow:var(--shadow-sm),0 0 0 1px var(--color-error-700)}.btn-danger:hover:not(:disabled){background-color:var(--color-error-700);box-shadow:var(--shadow-md),0 0 0 1px var(--color-error-700)}.btn-success{background-color:var(--color-success-600);color:#fff;box-shadow:var(--shadow-sm),0 0 0 1px var(--color-success-700)}.btn-success:hover:not(:disabled){background-color:var(--color-success-700)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-md)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-xl)}.btn-xl{padding:var(--space-5) var(--space-8);font-size:var(--text-lg);border-radius:var(--radius-xl);min-height:56px}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn-icon.btn-sm{padding:var(--space-1)}.btn-loading{position:relative;color:transparent!important}.btn-loading:after{content:"";position:absolute;width:1em;height:1em;border:2px solid transparent;border-top-color:currentColor;border-radius:var(--radius-full);animation:spin 1s linear infinite}.form-label-required:after{content:"*";color:var(--color-error-500);margin-left:var(--space-1)}.form-hint{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-muted)}.form-error{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-error-500);display:flex;align-items:center;gap:var(--space-1)}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.input::placeholder{color:var(--text-muted)}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent)}.input:disabled{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.input-error{border-color:var(--color-error-500)}.input-error:focus{border-color:var(--color-error-500);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-error-500) 15%,transparent)}.input-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-md)}.input-lg{padding:var(--space-4) var(--space-5);font-size:var(--text-base);border-radius:var(--radius-xl)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:1rem;padding-right:var(--space-10)}.textarea{min-height:100px;resize:vertical}.checkbox-label,.radio-label{display:inline-flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox,.radio{width:1.125rem;height:1.125rem;margin:0;border:2px solid var(--border-tertiary);border-radius:var(--radius-sm);background-color:var(--surface-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;display:grid;place-content:center}.radio{border-radius:var(--radius-full)}.checkbox:before,.radio:before{content:"";width:.625rem;height:.625rem;transform:scale(0);transition:transform var(--transition-fast)}.checkbox:checked{background-color:var(--accent-primary);border-color:var(--accent-primary)}.checkbox:checked:before{transform:scale(1);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.radio:checked{border-color:var(--accent-primary)}.radio:checked:before{transform:scale(1);background-color:var(--accent-primary);border-radius:var(--radius-full)}.checkbox:focus-visible,.radio:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent)}.input-group{position:relative;display:flex;align-items:center}.input-group .input{padding-left:var(--space-10)}.input-group-icon{position:absolute;left:var(--space-3);color:var(--text-muted);pointer-events:none}.card{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.card-hover:hover{border-color:var(--border-tertiary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-interactive{cursor:pointer}.card-interactive:hover{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary),var(--shadow-lg)}.card-header{padding:var(--space-5);border-bottom:1px solid var(--border-secondary)}.card-body{padding:var(--space-5)}.card-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-secondary);background-color:var(--surface-secondary)}.card-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-1)}.card-subtitle{font-size:var(--text-sm);color:var(--text-muted)}.stat-card{padding:var(--space-5);background:linear-gradient(145deg,var(--surface-primary),var(--surface-secondary));border:1px solid var(--border-primary);border-radius:var(--radius-xl);transition:all var(--transition-normal)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-label{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-1)}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:var(--leading-tight)}.stat-change{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);margin-top:var(--space-2)}.stat-change-positive{color:var(--color-success-500)}.stat-change-negative{color:var(--color-error-500)}.event-card{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-5);background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);transition:all var(--transition-normal)}.event-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg)}.event-card-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.event-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary)}.event-card-meta-item{display:inline-flex;align-items:center;gap:var(--space-1)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1;border-radius:var(--radius-full);white-space:nowrap}.badge-sm{padding:.125rem var(--space-1);font-size:.625rem}.badge-lg{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.badge-default{background-color:var(--bg-tertiary);color:var(--text-secondary)}.badge-primary{background-color:color-mix(in srgb,var(--accent-primary) 15%,transparent);color:var(--accent-primary)}.badge-success{background-color:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.badge-warning{background-color:var(--warning-bg);color:var(--warning-text);border:1px solid var(--warning-border)}.badge-error{background-color:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border)}.badge-info{background-color:var(--info-bg);color:var(--info-text);border:1px solid var(--info-border)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-full);background-color:var(--bg-tertiary);color:var(--text-secondary)}.status-badge:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background-color:currentColor}.status-badge-success{background-color:var(--success-bg);color:var(--success-text)}.status-badge-warning{background-color:var(--warning-bg);color:var(--warning-text)}.status-badge-error{background-color:var(--error-bg);color:var(--error-text)}.status-badge-pending{background-color:var(--warning-bg);color:var(--warning-text)}.status-badge-paid{background-color:var(--success-bg);color:var(--success-text)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid transparent}.alert-icon{flex-shrink:0;margin-top:.125rem}.alert-content{flex:1;min-width:0}.alert-title{font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.alert-description{font-size:var(--text-sm);color:var(--text-secondary)}.alert-success{background-color:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}.alert-warning{background-color:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}.alert-error{background-color:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.alert-info{background-color:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}.table-container{overflow-x:auto;border:1px solid var(--border-primary);border-radius:var(--radius-xl);background-color:var(--surface-primary)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table th,.table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--border-secondary)}.table th{font-weight:var(--font-semibold);color:var(--text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;background-color:var(--surface-secondary)}.table th:first-child{border-top-left-radius:var(--radius-xl)}.table th:last-child{border-top-right-radius:var(--radius-xl)}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--surface-secondary)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:last-child td:first-child{border-bottom-left-radius:var(--radius-xl)}.table tbody tr:last-child td:last-child{border-bottom-right-radius:var(--radius-xl)}.table-compact th,.table-compact td{padding:var(--space-2) var(--space-3)}.table-striped tbody tr:nth-child(2n){background-color:var(--surface-secondary)}.row-success{background-color:color-mix(in srgb,var(--color-success-500) 5%,transparent)!important}.row-warning{background-color:color-mix(in srgb,var(--color-warning-500) 5%,transparent)!important}.row-error{background-color:color-mix(in srgb,var(--color-error-500) 5%,transparent)!important}.modal-xl{max-width:800px}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.modal-close{padding:var(--space-1);background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);gap:var(--space-4)}.empty-state-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background-color:var(--surface-secondary);border-radius:var(--radius-xl);color:var(--text-muted);font-size:var(--text-2xl)}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.empty-state-description{font-size:var(--text-sm);color:var(--text-muted);max-width:320px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:var(--space-4)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-primary);border-top-color:var(--accent-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.loading-text{font-size:var(--text-sm);color:var(--text-muted)}.page-loading{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:var(--bg-primary);z-index:var(--z-tooltip)}.avatar{display:inline-flex;align-items:center;justify-content:center;background-color:var(--accent-primary);color:#fff;font-weight:var(--font-semibold);border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-md{width:40px;height:40px;font-size:var(--text-sm)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-xl{width:64px;height:64px;font-size:var(--text-lg)}.avatar-group{display:flex;align-items:center}.avatar-group .avatar{margin-left:-8px;border:2px solid var(--surface-primary);transition:transform var(--transition-fast)}.avatar-group .avatar:first-child{margin-left:0}.avatar-group .avatar:hover{transform:translateY(-2px);z-index:1}.divider{height:1px;background-color:var(--border-primary);margin:var(--space-6) 0}.divider-vertical{width:1px;height:auto;align-self:stretch;margin:0 var(--space-6)}.tooltip{position:relative;display:inline-block}.tooltip-content{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:var(--space-2) var(--space-3);background-color:var(--color-slate-900);color:#fff;font-size:var(--text-xs);border-radius:var(--radius-md);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:var(--z-tooltip)}[data-theme=light] .tooltip-content{background-color:var(--color-slate-800)}.tooltip:hover .tooltip-content{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--color-slate-900)}[data-theme=light] .tooltip-content:after{border-top-color:var(--color-slate-800)}.page-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-primary)}@media (min-width: 640px){.page-header{flex-direction:row;align-items:center;justify-content:space-between}}.page-header-content{flex:1}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:-.025em}.page-description{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.page-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-4)}.breadcrumbs a{color:var(--text-secondary);transition:color var(--transition-fast)}.breadcrumbs a:hover{color:var(--accent-primary)}.breadcrumbs-separator{color:var(--text-muted)}.breadcrumbs-current{color:var(--text-primary);font-weight:var(--font-medium)}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideUp var(--transition-normal) ease-out;max-width:360px}.toast-success{border-color:var(--success-border);background-color:var(--success-bg)}.toast-error{border-color:var(--error-border);background-color:var(--error-bg)}.toast-warning{border-color:var(--warning-border);background-color:var(--warning-bg)}.toast-info{border-color:var(--info-border);background-color:var(--info-bg)}.toast-icon{flex-shrink:0}.toast-content{flex:1;min-width:0}.toast-title{font-weight:var(--font-semibold);font-size:var(--text-sm);margin-bottom:var(--space-1)}.toast-message{font-size:var(--text-sm);color:var(--text-secondary)}.toast-close{flex-shrink:0;padding:var(--space-1);background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.toast-close:hover{background-color:var(--surface-hover);color:var(--text-primary)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:var(--text-base)}.error-msg{color:var(--error-text);background-color:var(--error-bg);border:1px solid var(--error-border);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm)}.success-msg{color:var(--success-text);background-color:var(--success-bg);border:1px solid var(--success-border);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm)}.empty{text-align:center;padding:var(--space-12);color:var(--text-muted);font-size:var(--text-base)}.btn-small{composes:btn btn-sm from "./styles/components.css"}.btn-secondary{composes:btn btn-secondary from "./styles/components.css"}.btn-danger{composes:btn btn-danger from "./styles/components.css"}.btn-primary{composes:btn btn-primary from "./styles/components.css"}.btn-icon{composes:btn btn-icon from "./styles/components.css"}.badge-validacion{display:inline-block;padding:.25rem .5rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.badge-validacion.aprobado{background-color:var(--success-bg);color:var(--success-text)}.badge-validacion.rechazado{background-color:var(--error-bg);color:var(--error-text)}.badge-validacion.pendiente{background-color:var(--warning-bg);color:var(--warning-text)}.estado{display:inline-block;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.estado.pagado{background-color:var(--success-bg);color:var(--success-text)}.estado.pendiente{background-color:var(--warning-bg);color:var(--warning-text)}.row-aprobado{background-color:color-mix(in srgb,var(--color-success-500) 5%,transparent)}.row-rechazado{background-color:color-mix(in srgb,var(--color-error-500) 5%,transparent)}.foto-fallback{width:120px;height:120px;object-fit:cover;border-radius:var(--radius-lg);border:2px solid var(--border-primary);background-color:var(--surface-secondary)}.foto-mini{margin-top:var(--space-2)}.foto-mini .foto-fallback{width:80px;height:80px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast) ease-out}.modal{background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;max-height:calc(100vh - var(--space-8));overflow:hidden;display:flex;flex-direction:column;animation:scaleIn var(--transition-normal) cubic-bezier(.34,1.56,.64,1)}.modal-lg{max-width:640px}.modal-sm{max-width:360px}.modal-header{padding:var(--space-5);border-bottom:1px solid var(--border-secondary);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.modal-close{padding:var(--space-1);background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.modal-close:hover{background-color:var(--surface-secondary);color:var(--text-primary)}.modal-body{padding:var(--space-5);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-secondary);background-color:var(--surface-secondary);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.input:hover{border-color:var(--border-tertiary)}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-primary) 15%,transparent)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:1rem;padding-right:var(--space-10)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
