:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--accent-blue: #3b82f6;--accent-gold: #fbbf24;--accent-silver: #9ca3af;--accent-bronze: #d97706;--success: #22c55e;--danger: #ef4444;--border-color: #475569}body.light-mode{--bg-primary: #f1f5f9;--bg-secondary: #ffffff;--bg-card: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--accent-blue: #2563eb;--accent-gold: #d97706;--accent-silver: #64748b;--accent-bronze: #b45309;--success: #16a34a;--danger: #dc2626;--border-color: #cbd5e1}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 2rem}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--text-primary);font-weight:700;font-size:1.25rem}.logo-icon{font-size:1.5rem}.logo-text-container{display:flex;flex-direction:column}.logo-subtitle{font-size:.7rem;font-weight:400;color:var(--text-secondary)}.nav{display:flex;align-items:center;gap:1.5rem}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.nav-link:hover{color:var(--text-primary)}.btn-login{background:var(--accent-blue);color:#fff!important;padding:.5rem 1rem;border-radius:.5rem}.admin-name{color:var(--text-secondary);font-size:.875rem}.btn-logout{background:transparent;border:1px solid var(--danger);color:var(--danger);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-weight:500;transition:all .2s}.btn-logout:hover{background:var(--danger);color:#fff}.btn-theme{background:var(--bg-card);border:1px solid var(--border-color);border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.btn-theme:hover{transform:scale(1.1);border-color:var(--accent-gold)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ranking-container{text-align:center}.ranking-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.ranking-subtitle{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1.1rem}.filtros-turno{display:flex;justify-content:center;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.btn-filtro{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-filtro:hover{border-color:var(--accent-blue);color:var(--text-primary)}.btn-filtro.activo{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.leyenda-plazas{display:flex;justify-content:center;gap:1.5rem;margin-bottom:1rem;font-size:.8rem;color:var(--text-secondary);flex-wrap:wrap}.leyenda-plazas span:first-child{font-weight:600;color:var(--text-primary)}.leyenda-plazas .plaza-libre{color:#22c55e;font-weight:600}.leyenda-plazas .plaza-discapacidad{color:#3b82f6;font-weight:600}.leyenda-plazas .plaza-interna{color:#a855f7;font-weight:600}.busqueda-container{display:flex;justify-content:center;margin-bottom:1.5rem}.busqueda-container .search-input{max-width:350px}.form-group select{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:1rem;cursor:pointer}.form-group select:focus{outline:none;border-color:var(--accent-blue)}.turno{font-size:.75rem;color:var(--text-secondary)}.empty-ranking{background:var(--bg-secondary);border-radius:1rem;padding:4rem 2rem;color:var(--text-secondary)}.ranking-table-container{background:var(--bg-secondary);border-radius:1rem;overflow:hidden;margin-top:2rem}.ranking-table{width:100%;border-collapse:collapse}.ranking-table th,.ranking-table td{padding:1rem 1.5rem;text-align:left}.ranking-table th{background:var(--bg-card);font-weight:600;color:var(--text-secondary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.ranking-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .2s}.ranking-table tbody tr:hover{background:var(--bg-card)}.ranking-table .position{font-weight:700;color:var(--text-secondary)}.ranking-table .top-1{background:#fbbf241a}.ranking-table .top-1 .position{color:var(--accent-gold)}.ranking-table .top-2{background:#9ca3af1a}.ranking-table .top-2 .position{color:var(--accent-silver)}.ranking-table .top-3{background:#d977061a}.ranking-table .top-3 .position{color:var(--accent-bronze)}.ranking-table .dentro-plazas{background:#22c55e26}.ranking-table .dentro-plazas .iniciales{color:var(--success)}.ranking-table .fuera-plazas{background:#ef44441a}.ranking-table .fuera-plazas .iniciales{color:var(--danger)}.ranking-table .iniciales{font-weight:600}.ranking-table .total{font-weight:700;color:var(--accent-blue)}.ranking-footer{margin-top:2rem;color:var(--text-secondary)}.visitas-stats{display:flex;justify-content:center;gap:1.5rem;margin-top:1rem;font-size:.875rem}.visitas-stats span{display:flex;align-items:center;gap:.25rem}.nota-informativa{margin:1.5rem 0 2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:.75rem;border:1px solid var(--border-color);text-align:center;font-size:.9rem;color:var(--text-secondary);line-height:1.6}.nota-informativa .info-titulo{color:var(--accent-gold);font-size:1.1rem;margin-bottom:1rem;letter-spacing:.05em}.nota-informativa .contactos{margin-top:.75rem;font-weight:600}.nota-informativa .contactos a{color:var(--accent-blue);text-decoration:none}.nota-informativa .contactos a:hover{text-decoration:underline}.nota-informativa .click-hint{font-size:.8rem;font-weight:500;color:var(--accent-blue);margin-top:.5rem}.nota-informativa .gracias{margin-top:.75rem;font-style:italic;color:var(--success)}.login-container{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{background:var(--bg-secondary);border-radius:1rem;padding:2.5rem;width:100%;max-width:400px}.login-card h2{margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);margin-bottom:2rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-secondary)}.form-group input{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent-blue)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-total{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-card);border-radius:.5rem;margin-bottom:1.5rem}.total-value{font-size:1.5rem;font-weight:700;color:var(--accent-blue)}.form-actions{display:flex;gap:1rem}.btn-submit{flex:1;padding:.875rem 1.5rem;background:var(--accent-blue);color:#fff;border:none;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:opacity .2s}.btn-submit:hover{opacity:.9}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{flex:1;padding:.875rem 1.5rem;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:var(--bg-card)}.error-message{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:.75rem 1rem;border-radius:.5rem;margin-bottom:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:var(--bg-secondary);border-radius:1rem;padding:2rem;width:100%;max-width:450px;margin:1rem}.modal h3{margin-bottom:1.5rem}.admin-container{max-width:1000px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{font-size:2rem}.admin-search{margin-bottom:1.5rem}.search-input{width:100%;max-width:300px;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--accent-blue)}.search-input::placeholder{color:var(--text-secondary)}.btn-add{background:var(--success);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-add:hover{opacity:.9}.empty-state{text-align:center;padding:4rem 2rem;background:var(--bg-secondary);border-radius:1rem}.empty-state p{margin-bottom:1.5rem;color:var(--text-secondary)}.admin-table-container{background:var(--bg-secondary);border-radius:1rem;overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:1rem 1.25rem;text-align:left}.admin-table th{background:var(--bg-card);font-weight:600;color:var(--text-secondary);font-size:.875rem}.admin-table tbody tr{border-bottom:1px solid var(--border-color)}.admin-table tbody tr:hover{background:var(--bg-card)}.admin-table .position{font-weight:700;color:var(--accent-gold)}.admin-table .iniciales{font-weight:600}.admin-table .total{font-weight:700;color:var(--accent-blue)}.admin-table .actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-edit{background:var(--accent-blue);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:opacity .2s}.btn-edit:hover{opacity:.9}.btn-delete{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-delete:hover{background:var(--danger);color:#fff}.delete-confirm{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.btn-confirm-yes{background:var(--danger);color:#fff;border:none;padding:.375rem .75rem;border-radius:.25rem;cursor:pointer}.btn-confirm-no{background:var(--bg-card);color:var(--text-primary);border:none;padding:.375rem .75rem;border-radius:.25rem;cursor:pointer}.admin-footer{margin-top:1.5rem;text-align:center;color:var(--text-secondary)}.nota-calculada{display:block;font-size:.875rem;color:var(--accent-blue);margin-top:.25rem}.nota-calc{color:var(--accent-blue);font-size:.85em}@media (max-width: 768px){.main-content{padding:.5rem}.header{padding:.75rem 1rem}.header-content{flex-direction:column;gap:.75rem}.nav{flex-wrap:wrap;justify-content:center;gap:.75rem}.ranking-container{padding:0}.ranking-title{font-size:1.25rem;padding:0 .5rem}.ranking-subtitle{font-size:.9rem;margin-bottom:1rem}.ranking-table-container{margin-top:1rem;border-radius:.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.ranking-table{font-size:.75rem;min-width:500px}.ranking-table th,.ranking-table td{padding:.5rem .4rem;white-space:nowrap}.ranking-table th{font-size:.65rem}.nota-calc{display:none}.form-row{grid-template-columns:1fr}.admin-header{flex-direction:column;gap:1rem;text-align:center}.admin-header h1{font-size:1.25rem}.admin-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{font-size:.75rem;min-width:600px}.admin-table th,.admin-table td{padding:.5rem .4rem;white-space:nowrap}.admin-table .actions{flex-direction:row;gap:.25rem}.btn-edit,.btn-delete{padding:.4rem .6rem;font-size:.7rem}.modal{margin:.5rem;padding:1.25rem;max-height:90vh;overflow-y:auto}.login-card{padding:1.5rem;margin:1rem}}@media (max-width: 480px){.ranking-title{font-size:1.1rem}.logo-text{font-size:1rem}.nav-link{font-size:.85rem}}.admin-tabs{display:flex;gap:.5rem}.tab-btn{padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:.5rem;cursor:pointer;font-weight:500;transition:all .2s}.tab-btn:hover{border-color:var(--accent-blue);color:var(--text-primary)}.tab-btn.active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.btn-refresh{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-refresh:hover{border-color:var(--accent-blue);background:var(--bg-secondary)}.logs-container{margin-top:1rem}.logs-summary{margin-bottom:1rem;padding:1rem;background:var(--bg-secondary);border-radius:.5rem}.logs-summary p{display:flex;gap:2rem;justify-content:center}.log-stat{font-weight:600;padding:.25rem .75rem;border-radius:.25rem}.log-stat.success{background:#22c55e33;color:var(--success)}.log-stat.failed{background:#ef444433;color:var(--danger)}.logs-table .log-success{background:#22c55e0d}.logs-table .log-failed{background:#ef44441a}.logs-table .ip-address{font-family:monospace;font-size:.9rem;color:var(--accent-blue)}.logs-table .user-agent{font-size:.75rem;color:var(--text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis}.status-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.status-badge.success{background:var(--success);color:#fff}.status-badge.failed{background:var(--danger);color:#fff}@media (max-width: 768px){.admin-tabs{order:2;width:100%;justify-content:center}.logs-table{min-width:700px}.logs-table .user-agent{max-width:100px}}
