:root{--color-primary: #158900;--color-danger: #e53935;--color-bg: #f4f6f9}body{margin:0;font-family:Roboto,sans-serif;background-color:#f4f6f9}*{font-family:Roboto,sans-serif}input{padding:8px;border-radius:6px;border:1px solid #ccc;margin:5px 0;width:100%;max-width:250px}.container{max-width:900px;margin:auto;padding:20px}button{padding:8px 14px;margin:5px;border:none;border-radius:6px;cursor:pointer;font-weight:700}button.primary{background-color:#64e51e;color:#fff}button.danger{background-color:#e53935;color:#fff}button.secondary{background-color:#287200;color:#fff}.bloque_btn{text-align:center}.card{background:#fff;padding:15px;margin:10px 0;border-radius:8px;box-shadow:0 2px 6px #0000001a}.horario{padding:8px;margin:6px 0;border-radius:6px;display:flex;justify-content:space-between;align-items:center;color:#fff}@media(max-width:600px){.container{padding:10px}button{width:100%;margin:6px 0}.card{padding:12px}.horario{flex-direction:column;align-items:flex-start;gap:6px}}.table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 6px #0000001a}.admin-table th,.admin-table td{padding:10px;text-align:left;border-bottom:1px solid #eee;font-size:14px}.admin-table th{background-color:var(--color-primary);color:#fff;font-weight:500}.admin-table tr:hover{background-color:#f5f5f5}.estado-activo{color:#43a047;font-weight:700}.estado-cancelado{color:#e53935;font-weight:700}.notificacion.error{background-color:#ffebee;color:#c62828;border:1px solid #ef5350}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:999}.modal{background:#fff;padding:25px;border-radius:10px;width:350px;max-width:90%;box-shadow:0 5px 15px #0000004d;animation:fadeIn .2s ease-in-out}.modal h3{margin-bottom:10px}.modal p{font-size:14px;margin-bottom:20px}.modal-buttons{display:flex;justify-content:flex-end;gap:10px}.bloqueo-card{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-bottom:25px;text-align:center}.bloqueo-card h3{margin-bottom:15px;text-align:center}.disponibilidad-container{max-width:1100px;margin:40px auto;padding:0 20px;text-align:center}.bloqueo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.bloqueo-grid input,.bloqueo-grid select{padding:8px;border-radius:6px;border:1px solid #ddd;font-size:14px;transition:border .2s ease}.bloqueo-grid input:focus,.bloqueo-grid select:focus{outline:none;border-color:var(--color-primary)}.bloqueo-grid button{grid-column:span 2}.input-icon{position:relative;display:flex;align-items:center}.input-icon .icon{position:absolute;left:10px;color:#666;font-size:14px}.input-icon input,.input-icon select{padding:8px 8px 8px 30px;width:100%}.login-container{height:100vh;display:flex;justify-content:center;align-items:center}.login-card{background:#fff;padding:35px;border-radius:12px;width:350px;max-width:90%;box-shadow:0 8px 20px #0003;text-align:center}.login-logo{width:80px;margin-bottom:15px}.title_ppn_login{color:#00551b}.login-subtitle{font-size:14px;margin-bottom:25px;color:#666}.login-button{width:100%;margin-top:15px;background-color:#00551b!important}.login-card h2{margin-bottom:5px}.login-card input{margin-bottom:15px}.error-box{background:#ffebee;color:#c62828;padding:10px;border-radius:6px;margin-bottom:15px;font-size:14px}.app-header{background-color:#009c1d;color:#fff;padding:15px 25px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px}.header-left{display:flex;align-items:center;gap:15px}.header-logo{height:70px}.header-left h2{margin:0;font-weight:500}.header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.header-rol{font-weight:700;background:#fff3;padding:6px 10px;border-radius:20px;font-size:12px}.notificacion{padding:12px;border-radius:6px;margin-bottom:15px;font-weight:500;animation:fadeIn .3s ease-in-out}.notificacion.success{background-color:#e8f5e9;color:#2e7d32;border:1px solid #66bb6a}.toast{position:fixed;top:30px;left:50%;transform:translate(-50%);padding:15px 25px;border-radius:10px;background:#fff;box-shadow:0 8px 20px #00000026;z-index:9999;animation:slideDown .3s ease;min-width:320px;text-align:center}.toast.success{border-left:5px solid #2e7d32}.toast.error{border-left:5px solid #c62828}.toast-content{display:flex;align-items:center;gap:10px;justify-content:center}.toast-icon{font-size:18px}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-15px)}to{opacity:1;transform:translate(-50%)}}.toast-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease}.toast-modal{background:#fff;padding:25px 35px;border-radius:14px;box-shadow:0 15px 30px #00000040;min-width:350px;max-width:90%;position:relative;animation:scaleIn .25s ease;text-align:center}.toast-modal.success{border-top:5px solid #2e7d32}.toast-modal.error{border-top:5px solid #c62828}.toast-modal-content{display:flex;flex-direction:column;align-items:center;gap:10px;font-size:16px}.toast-icon{font-size:28px}.toast-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:14px;cursor:pointer;color:#777}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.resumen-reserva{background:#f4f6f8;padding:12px;border-radius:8px;margin-top:10px;text-align:left;font-size:14px}.horarios-grid{margin-top:20px;display:flex;flex-direction:column;gap:12px}.horario-card{background:#fff;border-radius:10px;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 3px 10px #0000000d;border:1px solid #eee;transition:transform .15s ease}.horario-card:hover{transform:translateY(-2px)}.horario-info{display:flex;align-items:center;gap:15px}.hora{font-weight:600;font-size:15px}.estado-badge{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.estado-badge.disponible{background:#e8f5e9;color:#2e7d32}.estado-badge.reserva{background:#ffebee;color:#c62828}.estado-badge.entrenamiento,.estado-badge.mantenimiento,.estado-badge.torneo{background:#fff3e0;color:#ef6c00}.reservar-btn{padding:6px 14px;font-size:13px}.cal-header,.cal-row{display:grid;grid-template-columns:150px repeat(7,1fr);text-align:center}.celda{padding:15px 0;cursor:pointer;transition:background .2s ease}.celda.disponible:hover{background:#e8f5e9}.celda.reserva,.celda.entrenamiento,.celda.mantenimiento,.celda.torneo{background:#ffebee}.calendario{margin-top:25px;overflow-x:auto}.cal-header,.cal-row{display:grid;grid-template-columns:140px repeat(7,1fr);text-align:center}.cal-header{font-weight:600;background:#f4f6f8;padding:10px 0}.cal-row{border-bottom:1px solid #eee}.hora-col{padding:10px;font-size:13px;background:#fafafa}.dia-col{padding:10px;font-size:12px}.celda{padding:12px 6px;cursor:pointer;font-size:12px;border-right:1px solid #eee;transition:.2s ease}.celda.disponible{background:#e8f5e9;color:#2e7d32}.celda.disponible:hover{background:#c8e6c9}.celda.reserva{background:#ffebee;color:#c62828}.celda.entrenamiento{background:#00551b;color:#fff}.celda.mantenimiento{background:#eceff1;color:#455a64}.celda.torneo{background:#e3f2fd;color:#1565c0}.celda.clubes{background-color:#510057;color:#fff}.celda.torneo{background-color:#e17055;color:#fff}.celda{padding:8px;text-align:center;font-size:13px;cursor:pointer;transition:all .2s ease;border:1px solid #e0e0e0}.celda:hover{transform:scale(1.02)}.celda-content{display:flex;align-items:center;justify-content:center;gap:6px}.estado-dot{width:10px;height:10px;border-radius:50%}.estado-dot.disponible{background:#27ae60}.estado-dot.reserva{background:#e74c3c}.estado-dot.entrenamiento{background:#1df800}.estado-dot.clubes{background:#c802b4}.estado-dot.torneo{background:#e67e22}.celda.disponible{background:#f1fff5}.celda.torneo{background:#fff3e6}.celda.reserva{background:#ffeaea}.leyenda{display:flex;gap:20px;margin:15px 0;flex-wrap:wrap;font-size:14px}.leyenda-item{display:flex;align-items:center;gap:6px}.login-background{min-height:100vh;background:url(/assets/podcast-URkKkqDP.svg) no-repeat center center;background-size:cover;display:flex;align-items:center;justify-content:center;position:relative}.admin-container{max-width:1200px;margin:40px auto;padding:0 30px;text-align:center}.admin-header{margin-bottom:30px}.admin-header h2{font-size:28px;margin-bottom:5px;text-align:center}.admin-header p{color:#666}.login-background:before{content:"";position:absolute;inset:0;background:#0000008c}.login-container{position:relative;z-index:2}.login-card{background:#fff;padding:40px;border-radius:12px;width:350px;box-shadow:0 15px 40px #00000040;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.escenarios-container{padding:30px}.titulo-seccion{margin-bottom:25px;font-size:28px;font-weight:600}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:25px}.card-escenario{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 6px 18px #00000014;transition:all .3s ease}.card-escenario:hover{transform:translateY(-6px);box-shadow:0 12px 28px #00000026}.card-imagen{width:100%;height:200px;object-fit:cover}.card-body{padding:18px}.card-body h3{margin:0 0 10px;font-size:20px}.card-info{font-size:14px;color:#555;margin-bottom:8px}.btn-card{margin-top:15px;width:100%;padding:10px;background-color:#009c1d;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:.2s}.btn-card:hover{background-color:#007a16}.nav-btn{background:transparent;border:none;color:#fff;font-size:15px;font-weight:500;cursor:pointer;padding:8px 12px;position:relative;transition:.3s}.nav-btn:after{content:"";position:absolute;left:0;bottom:0;width:0%;height:2px;background-color:#fff;transition:width .3s ease}.nav-btn:hover:after{width:100%}.nav-btn:hover{opacity:.8}.nav-btn.active:after{width:100%}.usuario-nombre{margin-right:15px;font-weight:500;color:#fff;opacity:.9}.reservas-container{padding:30px;text-align:center}.card-reserva{background:#fff;border-radius:12px;padding:20px;box-shadow:0 6px 18px #00000014;transition:all .3s ease}.card-reserva:hover{transform:translateY(-4px);box-shadow:0 10px 24px #00000026}.estado-badge{display:inline-block;padding:6px 10px;border-radius:20px;font-size:13px;margin-top:8px;margin-bottom:15px;font-weight:500}.estado-badge.reserva{background-color:#e6f7ea;color:#009c1d}.estado-badge.cancelada{background-color:#fdeaea;color:#c0392b}.btn-cancelar{width:100%;padding:10px;border:none;border-radius:8px;background-color:#e74c3c;color:#fff;cursor:pointer;transition:.2s}.btn-cancelar:hover{background-color:#c0392b}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:#fff;padding:25px;border-radius:12px;width:350px;text-align:center;animation:fadeIn .3s ease}.modal-actions{margin-top:20px;display:flex;justify-content:space-between;gap:10px}.btn-secondary{flex:1;padding:10px;border-radius:8px;border:none;background:#ddd;cursor:pointer}.btn-danger{flex:1;padding:10px;border-radius:8px;border:none;background:#e74c3c;color:#fff;cursor:pointer}.btn-danger:hover{background:#c0392b}.toast{position:fixed;bottom:30px;right:30px;padding:15px 20px;border-radius:8px;color:#fff;animation:slideIn .3s ease;z-index:2000}.toast.success{background:#27ae60}.toast.error{background:#e74c3c}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.loader-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:9999}.loader-box{background:#fff;padding:30px 40px;border-radius:12px;text-align:center;box-shadow:0 10px 30px #00000026}.spinner{width:40px;height:40px;border:4px solid #e5e5e5;border-top:4px solid #009c1d;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 15px}@keyframes spin{to{transform:rotate(360deg)}}.not-found{text-align:center;padding:100px 20px}.not-found h2{font-size:80px;margin-bottom:10px;color:#009c1d}.disponible{background-color:#43a047}.reserva{background-color:#e53935}.entrenamiento{background-color:var(--color-primary)}.mantenimiento{background-color:#fb8c00}.torneo{background-color:#8e24aa}
