*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}html,body,div,section,main,aside,nav{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar,body::-webkit-scrollbar,div::-webkit-scrollbar,section::-webkit-scrollbar,main::-webkit-scrollbar,aside::-webkit-scrollbar,nav::-webkit-scrollbar{display:none}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;color:#333;background-color:#f8f9fa;overflow-x:hidden}*{-webkit-tap-highlight-color:transparent}@media (max-width: 1024px) and (min-width: 769px){html{font-size:15px}body{font-size:.95rem}}@media (hover: none) and (pointer: coarse){button,[role=button],input[type=button],input[type=submit],input[type=reset]{min-height:44px;min-width:44px}body{font-size:1rem;line-height:1.7}}.dashboard-container{display:flex;min-height:100vh;background-color:#f8f9fa}.main-content{flex:1;margin-left:280px;padding:20px;background-color:#f8f9fa;min-height:100vh;overflow-x:auto;transition:margin-left .3s ease}@media (max-width: 2100px){.main-content{padding:20px;max-width:95vw;margin-right:auto;margin-left:auto;width:100%}}@media (max-width: 1024px) and (min-width: 769px){.main-content{margin-left:0;padding:15px}}@media (max-width: 768px){.main-content{margin-left:0;padding:10px;max-width:100vw;width:100vw}}.main-content::-webkit-scrollbar{display:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (prefers-color-scheme: dark){body{background-color:#1a1a1a;color:#e0e0e0}.main-content{background-color:#1a1a1a}}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/inter/v12/UcCO3FwrK3iLTeHuS_fvQtMwCp50KnMw2boKoduKmMEVuLyfAZ9hiA.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.gpu-accelerated{transform:translateZ(0);will-change:transform}img{max-width:100%;height:auto;display:block}@media (max-width: 1024px) and (min-width: 769px){input,select,textarea{font-size:16px;padding:12px;border-radius:8px}button{padding:12px 20px;border-radius:8px;font-size:16px}}.lazy-load{opacity:0;transition:opacity .3s ease-in-out}.lazy-load.loaded{opacity:1}#root{min-height:100vh;display:flex;flex-direction:column}.content-wrapper{flex:1;display:flex;flex-direction:column}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;margin-bottom:20px;transition:box-shadow .2s ease-in-out}.card:hover{box-shadow:0 4px 16px #00000026}@media (max-width: 1024px) and (min-width: 769px){.card{padding:15px;margin-bottom:15px}}.grid{display:grid;gap:20px}@media (max-width: 1024px) and (min-width: 769px){.grid{gap:15px}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.98)}@media (max-width: 1024px) and (min-width: 769px){.btn{padding:12px 24px;font-size:1.1rem}}@media (min-width: 768px) and (max-width: 2100px){html{font-size:19px}body{padding:24px}button,input,select,textarea{min-height:44px;font-size:1.1rem}table th,table td{font-size:1.05rem;padding:16px 10px}}html,body,#root{height:100%;margin:0;padding:0;font-family:Inter,sans-serif}.layout-container{display:flex;height:100vh;width:100vw;overflow:hidden;position:relative}.login-panel{position:relative;z-index:2;width:32%;min-height:100vh;background-color:#fff;border-top-right-radius:32px;border-bottom-right-radius:32px;display:flex;align-items:center;justify-content:center;box-shadow:10px 0 30px #00000014;margin-right:-40px}.login-input:focus{outline:none;border-color:#0077c9;background-color:#fff}.login-box{width:100%;max-width:380px;padding:48px 32px;box-sizing:border-box;text-align:center}.login-logo{width:260px;height:auto;margin-bottom:40px}.login-title{font-size:2rem;font-weight:700;color:#036;margin-bottom:32px}.login-input{width:100%;padding:14px 16px;margin-bottom:20px;border-radius:8px;border:1px solid #ccc;background-color:#f9fafb;font-size:1rem;box-sizing:border-box}.login-button{width:100%;padding:14px;background-color:#0077c9;color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s;box-sizing:border-box}.login-button:hover{background-color:#005fa3}.login-error{color:#c0392b;margin-bottom:16px;font-size:.95rem}.image-panel{flex:1;position:relative;z-index:1;overflow:hidden;height:100vh;background:none!important}.background-image{width:100%;height:100vh;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;display:block;background:none!important}.login-support{margin-top:20px;font-size:.95rem;color:#444}.whatsapp-link{color:#25d366;text-decoration:none;font-weight:600;transition:color .3s}.whatsapp-link:hover{color:#1ebe5d}@media (max-width: 768px){.layout-container{flex-direction:column}.login-panel{width:100%;border-radius:0;margin-right:0;box-shadow:none}.image-panel{display:none}.login-box{padding:32px 24px}}.image-panel,.background-image{background:none!important;opacity:1!important;filter:none!important}.image-panel:before,.image-panel:after,.background-image:before,.background-image:after{display:none!important;content:none!important;background:none!important}.dashboard-container{width:100%;min-height:100vh;background:linear-gradient(135deg,var(--bg-light) 0%,#ffffff 100%);padding:24px}.main-content-ds{max-width:95vw;width:100%;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px;width:100%;padding:24px;background:#fff;border-radius:20px;box-shadow:var(--shadow-medium);border:1px solid var(--border-color)}.refresh-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:8px;min-height:48px;font-size:.875rem;box-shadow:var(--shadow-light)}.refresh-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #5f988966}.refresh-btn:active{transform:translateY(0)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff;padding:20px 24px;border-radius:16px;margin-bottom:32px;text-align:center;font-weight:600;box-shadow:0 8px 20px #dc35454d;animation:slideIn .3s ease;font-size:.875rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:40px;width:100%}.stats-card{background:#fff;padding:32px 24px;border-radius:20px;box-shadow:var(--shadow-medium);display:flex;flex-direction:column;align-items:center;text-align:center;transition:var(--transition);border:1px solid var(--border-color);min-height:180px;justify-content:center;width:100%;position:relative;overflow:hidden}.stats-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.stats-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-heavy)}.metric-icon{font-size:3rem;margin-bottom:20px;color:var(--primary-green)}.stats-title{font-size:1rem;font-weight:600;color:var(--text-light);margin-bottom:16px;text-transform:uppercase;letter-spacing:.1em}.stats-value{font-size:2.5rem;font-weight:800;color:var(--text-dark);line-height:1}.blurred{filter:blur(8px);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:filter .3s ease;position:relative}.blurred:after{content:"👁️";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;opacity:.7}.revealed{filter:none;cursor:default}.revealed:after{display:none}.reservas-section{background:#fff;border-radius:20px;padding:32px;margin-bottom:32px;box-shadow:var(--shadow-medium);border:1px solid var(--border-color);transition:var(--transition)}.reservas-section:hover{box-shadow:var(--shadow-heavy);transform:translateY(-2px)}.reservas-title{font-size:1.5rem;font-weight:700;color:var(--primary-green);margin-bottom:24px;display:flex;align-items:center;gap:12px;border-bottom:2px solid var(--border-color);padding-bottom:16px}.reserva-item{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#5f98890d,#8ac6b60d);padding:16px 20px;border-radius:12px;margin-bottom:8px;gap:12px;transition:background-color .2s ease;min-width:200px}.reserva-item:hover{background:linear-gradient(135deg,#5f98891a,#8ac6b61a);transform:translate(8px);box-shadow:var(--shadow-light)}.reserva-nombre{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;font-weight:600;font-size:1rem;color:var(--text-dark)}.reserva-status{flex-shrink:0;font-weight:600;color:#fff;padding:6px 12px;border-radius:20px;font-size:.75rem;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);text-transform:uppercase;letter-spacing:.05em}.dashboard-heading{font-size:2.5rem;font-weight:800;color:var(--primary-green);margin:0;display:flex;align-items:center;gap:16px}.reserva-hora{color:#0077c9}.reserva-no{color:#777;font-style:italic;text-align:center;font-size:1rem;padding:20px}.spaced-item{margin-bottom:20px}.menu-item{border:1px solid #f5f8f8}.menu-item:hover{background-color:#ffffff1a;transform:translate(4px)}.stats-card h3{margin:0}.background-wrapper{position:relative;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.background-image{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.1;z-index:-1}.sidebar-logo{width:150px;display:block;margin:0 auto 15px}.kinesiologia-section{background:#fff;padding:24px;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin-bottom:32px}.kinesiologia-title{font-size:1.4rem;font-weight:700;color:#036;margin-bottom:16px}.kinesiologia-info{color:#555;margin-bottom:8px}.kinesiologia-no{color:#777;font-style:italic;text-align:center;font-size:1rem}.scroll-contenedor{position:relative;display:flex;align-items:center;gap:16px;margin-top:24px}.scroll-horizontal{display:flex;gap:24px;overflow-x:auto;scroll-behavior:smooth;padding:12px 0;flex:1;scrollbar-width:none;-ms-overflow-style:none}.scroll-horizontal::-webkit-scrollbar{display:none}.grupo-clase-horizontal{background:#fff;border-radius:16px;padding:24px;min-width:300px;box-shadow:var(--shadow-medium);border:1px solid var(--border-color);flex-shrink:0;transition:var(--transition);position:relative;overflow:hidden}.grupo-clase-horizontal:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.grupo-clase-horizontal:hover{transform:translateY(-4px);box-shadow:var(--shadow-heavy)}.grupo-clase-titulo{font-size:1.125rem;font-weight:700;color:var(--primary-green);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border-color);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.reserva-count-badge{font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);padding:4px 12px;border-radius:12px;margin-left:8px;white-space:nowrap;box-shadow:var(--shadow-light)}.carousel-arrow{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0;box-shadow:var(--shadow-medium);font-size:1.125rem}.carousel-arrow:hover{transform:scale(1.1);box-shadow:0 8px 20px #5f988966}.arrow-left{left:-24px}.arrow-right{right:-24px}.carousel-arrow svg{width:18px;height:18px;color:#fff}.reservas-list{list-style:none;padding:0;margin:0}.reserva-no{color:var(--text-light);font-style:italic;text-align:center;font-size:1rem;padding:32px;background:#5f98890d;border-radius:12px;border:2px dashed var(--border-color)}@media (max-width: 1024px) and (min-width: 769px){.main-content-ds{margin-left:25%;padding:1.5rem}.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.refresh-btn{align-self:flex-end;padding:10px 16px;font-size:.9rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:24px}.stats-card{padding:20px;min-height:120px}.metric-icon{font-size:1.8rem;margin-bottom:10px}.stats-title{font-size:.9rem;margin-bottom:6px}.stats-value{font-size:1.6rem}.reservas-section,.kinesiologia-section{padding:20px;margin-bottom:24px}.reservas-title,.kinesiologia-title{font-size:1.2rem;margin-bottom:12px}.dashboard-heading{font-size:1.5rem;margin-bottom:0}.reserva-item{padding:10px 15px;margin-bottom:8px}.reserva-nombre{max-width:140px;font-size:.9rem}.reserva-status{font-size:.8rem;padding:3px 6px}.scroll-contenedor{position:relative;width:100%;margin:0 -10px}.scroll-horizontal{display:flex;overflow-x:auto;scroll-behavior:smooth;padding:20px 10px;gap:24px;scrollbar-width:none;-ms-overflow-style:none;width:100%}.grupo-clase-horizontal{min-width:320px;background:#f8f9fa;border-radius:12px;padding:20px;border:1px solid #e9ecef;flex-shrink:0}.grupo-clase-titulo{font-size:1rem;font-weight:600;color:#495057;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #dee2e6}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffe6;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .2s ease;z-index:10}.carousel-arrow:hover{background:#fff;box-shadow:0 4px 12px #0003;transform:translateY(-50%) scale(1.05)}.arrow-left{left:10px}.arrow-right{right:10px}.carousel-arrow svg{width:16px;height:16px;color:#495057}}@media (max-width: 1024px) and (min-width: 769px) and (orientation: landscape){.main-content-ds{margin-left:20%;padding:1rem}.dashboard-header{flex-direction:row;align-items:center}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stats-card{padding:16px;min-height:100px}.metric-icon{font-size:1.5rem}.stats-value{font-size:1.4rem}.reservas-section,.kinesiologia-section{padding:16px}}@media (max-width: 768px){.main-content-ds{margin-left:0;padding:1rem}.dashboard-header{flex-direction:column;align-items:stretch;gap:1rem}.refresh-btn{align-self:stretch;justify-content:center;padding:12px}.stats-grid{grid-template-columns:1fr;gap:16px;margin-bottom:20px}.stats-card{padding:16px;min-height:100px}.metric-icon{font-size:1.6rem;margin-bottom:8px}.stats-title{font-size:.85rem;margin-bottom:4px}.stats-value{font-size:1.4rem}.reservas-section,.kinesiologia-section{padding:16px;margin-bottom:20px}.reservas-title,.kinesiologia-title{font-size:1.1rem;margin-bottom:10px}.dashboard-heading{font-size:1.3rem;margin-bottom:0}.reserva-item{padding:8px 10px;margin-bottom:6px}.reserva-nombre{max-width:120px;font-size:.85rem}.reserva-status{font-size:.75rem;padding:2px 4px}.scroll-contenedor{margin:0 -8px}.scroll-horizontal{padding:8px;gap:16px}.grupo-clase-horizontal{min-width:240px;padding:12px}.grupo-clase-titulo{font-size:.9rem;margin-bottom:8px}.carousel-arrow{width:36px;height:36px}.carousel-arrow svg{width:14px;height:14px}}@media (prefers-reduced-motion: reduce){.stats-card,.reservas-section,.carousel-arrow,.refresh-btn{transition:none}.stats-card:hover{transform:none}.scroll-horizontal{scroll-behavior:auto}.error-message{animation:none}}@media (prefers-color-scheme: dark){.stats-card{background:#2d3748;border-color:#4a5568;color:#e2e8f0}.stats-title{color:#a0aec0}.stats-value{color:#f7fafc}.reservas-section,.kinesiologia-section{background:#2d3748;color:#e2e8f0}.reservas-title,.kinesiologia-title{color:#90cdf4}.reserva-item{background-color:#4a5568;color:#e2e8f0}.reserva-item:hover{background-color:#553c9a}.grupo-clase-horizontal{background:#4a5568;border-color:#718096}.grupo-clase-titulo{color:#a0aec0;border-bottom-color:#718096}.refresh-btn{background:linear-gradient(135deg,#4a5568,#2d3748)}.error-message{background:linear-gradient(135deg,#c53030,#9b2c2c)}}:root{--primary-color: #5f9889;--secondary-color: #8ac6b6;--active-color: #06694b;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107;--text-color: #333;--text-secondary: #6b7280;--light-bg: #ffffff;--border-color: #e5e7eb;--hover-bg: #f9fafb;--table-shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--transition-speed: .2s}*{box-sizing:border-box;margin:0;padding:0}.dashboard-container-tabla{padding:16px;background:#f8fafc;min-height:100vh;max-width:100vw;margin:0 auto}.main-content-tabla{max-width:95vw;margin:0 auto}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f8fafc;color:var(--text-color);line-height:1.6;overflow:hidden}.table-container{overflow-x:auto;margin-top:24px;background:var(--light-bg);border-radius:12px;box-shadow:var(--table-shadow);border:1px solid var(--border-color);overflow:hidden}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table thead{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff}.admin-table th{padding:16px 12px;text-align:left;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:#fff;border-bottom:2px solid rgba(255,255,255,.1)}.admin-table td{padding:16px 12px;border-bottom:1px solid var(--border-color);color:var(--text-color);vertical-align:middle}.new-user-btn{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff;padding:12px 32px;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all var(--transition-speed);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:220px;text-align:center;white-space:nowrap}.new-user-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #dc354566}.export-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:12px 32px;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all var(--transition-speed);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:200px;text-align:center;white-space:nowrap}.export-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3498db66}.export-btn:disabled{background:#bdc3c7;cursor:not-allowed;transform:none;box-shadow:none}.header-actions{display:flex;justify-content:space-between;margin-bottom:24px;align-items:center;flex-wrap:wrap}.header-actions input{padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:all var(--transition-speed);min-width:200px;box-shadow:0 1px 2px #0000000d}.header-actions input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5f98891a}.switch{position:relative;display:inline-block;width:48px;height:24px}.switch input{opacity:0;width:0;height:0}.switch:before{content:"";position:absolute;width:23px;height:23px;left:0;bottom:0;background-color:#ccc;border-radius:50%;transition:.3s}.switch input:checked+.slider{background-color:var(--primary-color)}.switch input:checked+.slider:before{transform:translate(24px);background-color:#fff}.pagination-container{display:flex;justify-content:center;gap:8px;margin-top:20px}.page-link{padding:8px 16px;background-color:var(--secondary-green);color:var(--light-bg);border:none;border-radius:4px;cursor:pointer;transition:background-color var(--transition-speed)}.page-link:hover{background-color:var(--primary-green)}.page-link.active{background-color:var(--active-green)}.popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:1000;display:flex;justify-content:center;align-items:center;overflow-y:auto;padding:40px 20px}.popup-content{background:#fff;padding:32px;border-radius:16px;max-width:600px;width:100%;max-height:none;box-shadow:0 20px 40px #5f98894d;border:1px solid rgba(95,152,137,.1);animation:slideIn .3s ease-out}.popup-close{position:absolute;top:16px;right:16px;background:#5f98891a;border:none;font-size:24px;cursor:pointer;color:var(--primary-color);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-speed)}.popup-close:hover{background:var(--primary-color);color:#fff;transform:scale(1.1)}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;color:var(--text-color)}.form-group input,.form-group select{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.success-message,.error-message{padding:10px 15px;border-radius:4px;margin:10px 0}.success-message{background-color:#28a7451a;color:#28a745}.error-message{background-color:#dc35451a;color:#dc3545}.admin-table th,.admin-table td{padding:12px 15px;text-align:center;border-bottom:1px solid #ddd;font-size:14px}.admin-table tbody tr{transition:background var(--transition-speed)}.admin-table tbody tr:hover{background-color:var(--hover-bg);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a;transition:all var(--transition-speed)}.socio-activo{color:var(--success-green);font-weight:600;background:#10b9811a;padding:4px 12px;border-radius:20px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.socio-inactivo{color:var(--danger-red);font-weight:600;background:#ef44441a;padding:4px 12px;border-radius:20px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.pagination{list-style:none;display:flex;justify-content:center;margin:24px 0;padding:0;gap:8px}.pagination li{cursor:pointer;padding:12px 16px;background:#fff;color:var(--text-color);border:1px solid var(--border-color);border-radius:8px;transition:all var(--transition-speed);font-weight:500;min-width:44px;text-align:center;box-shadow:0 1px 2px #0000000d}.pagination li:hover{background-color:var(--hover-bg);border-color:var(--primary-color);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.pagination .active{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border-color:var(--primary-color);box-shadow:0 4px 12px #5f98894d}.popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#5f9889e6,#8ac6b6e6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;padding:20px;z-index:9999;animation:fadeIn .3s ease-out}.popup-close:hover{color:var(--text-color)}.popup-buttons{display:flex;justify-content:space-between;margin-top:32px;gap:16px}.popup-buttons button{flex:1;padding:16px 24px;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:all var(--transition-speed);box-shadow:0 2px 4px #0000001a}.popup-buttons button:first-child{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff}.popup-buttons button:last-child{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff}.popup-buttons button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.popup-buttons button:first-child:hover{box-shadow:0 4px 12px #5f988966}.popup-buttons button:last-child:hover{box-shadow:0 4px 12px #dc354566}.popup-content input,.popup-content select{width:100%;padding:16px;margin-bottom:20px;font-size:.875rem;border:2px solid var(--border-color);border-radius:8px;background:#fff;transition:all var(--transition-speed);font-family:inherit}.popup-content input:focus,.popup-content select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.popup-content input::-moz-placeholder{color:var(--text-secondary);opacity:.7}.popup-content input::placeholder{color:var(--text-secondary);opacity:.7}.popup-content h3{color:var(--primary-color);font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center;border-bottom:2px solid rgba(95,152,137,.1);padding-bottom:16px}.input-label{display:block;font-size:.875rem;font-weight:600;margin-bottom:8px;text-align:left;color:var(--text-color)}.checkbox-label{display:flex;align-items:center;gap:12px;margin:20px 0;padding:16px;background:#5f98890d;border-radius:8px;border:1px solid rgba(95,152,137,.1);cursor:pointer;transition:all var(--transition-speed)}.checkbox-label:hover{background:#5f98891a;border-color:var(--primary-color)}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary-color);margin:0}.date-container{position:relative;margin-bottom:20px}.date-placeholder{position:absolute;top:16px;left:16px;color:var(--text-secondary);pointer-events:none;transition:all var(--transition-speed);font-size:.875rem}.date-container input[type=date]:not(:-moz-placeholder)+.date-placeholder{opacity:0;transform:translateY(-10px)}.date-container input[type=date]:not(:placeholder-shown)+.date-placeholder,.date-container input[type=date]:focus+.date-placeholder{opacity:0;transform:translateY(-10px)}.plan-info{background:linear-gradient(135deg,#5f98891a,#8ac6b61a);border:1px solid rgba(95,152,137,.2);border-radius:8px;padding:16px;margin:16px 0;font-size:.875rem;color:var(--text-color)}.plan-info p{margin:0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.plan-info strong{color:var(--primary-color);font-weight:600}@media (max-width: 768px){.admin-table th,.admin-table td{padding:8px;font-size:12px}.header-actions,.popup-buttons{flex-direction:column}.pagination li{padding:8px 10px;font-size:12px}}.switch-container{display:flex;align-items:center;gap:10px}.switch-container input[type=checkbox]{display:none}.switch-container input[type=checkbox]:checked+.switch{background:var(--primary-color)}.switch-container input[type=checkbox]:checked+.switch:before{transform:translate(25px)}.view-profile-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:all var(--transition-speed);box-shadow:0 1px 2px #0000000d}.view-profile-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5f98894d}.export-users-box{display:flex;gap:12px;align-items:center;margin-bottom:24px;padding:16px;background:#fff;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.export-users-box input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:all var(--transition-speed);min-width:250px}.export-users-box input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5f98891a}.socio-detalle-container{background:#fff;border-radius:20px;box-shadow:var(--shadow-heavy);padding:32px;width:100%;margin:24px auto;max-width:1200px;display:flex;flex-direction:column;gap:32px;animation:fadeIn .6s ease-out;border:1px solid var(--border-color)}@keyframes fadeIn{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.socio-detalle-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-green);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.spinner{display:inline-block;width:18px;height:18px;border:2px solid #fff;border-top:2px solid #888;border-radius:50%;animation:spin 1s linear infinite;margin-right:8px;vertical-align:middle}.loading-btn{background:#aaa!important;color:#fff!important;cursor:not-allowed!important;position:relative;transition:background .2s;opacity:.85}.socio-detalle-loading p{color:var(--text-light);font-size:1rem;margin:0}.socio-detalle-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.socio-detalle-error span{font-size:3rem;margin-bottom:16px}.socio-detalle-error h3{color:var(--text-dark);font-size:1.5rem;margin-bottom:8px}.socio-detalle-error p{color:var(--text-light);margin-bottom:24px}.error-back-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:600;cursor:pointer;transition:var(--transition)}.error-back-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #5f988966}.socio-detalle-header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-bottom:24px;border-bottom:2px solid var(--border-color)}.socio-detalle-back{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;font-size:.875rem;border-radius:12px;padding:12px 20px;cursor:pointer;transition:var(--transition);font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-light)}.socio-detalle-back:hover{transform:translateY(-2px);box-shadow:0 8px 20px #5f988966}.socio-detalle-profile{display:flex;align-items:center;gap:20px;flex:1}.socio-detalle-avatar{width:80px;height:80px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;box-shadow:var(--shadow-medium);border:4px solid white}.socio-detalle-info{display:flex;flex-direction:column;gap:8px}.socio-detalle-title{font-size:2.25rem;font-weight:800;color:var(--primary-green);margin:0;line-height:1.2}.socio-detalle-subtitle{display:flex;align-items:center;gap:16px;font-size:.875rem;color:var(--text-light)}.socio-rut{background:#5f98891a;padding:4px 12px;border-radius:20px;font-weight:600;color:var(--primary-green)}.socio-age-group{font-weight:500}.socio-detalle-actions{display:flex;gap:12px}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:var(--transition);font-size:.875rem}.edit-btn{background:linear-gradient(135deg,var(--success-green) 0%,#4caf50 100%);color:#fff;box-shadow:var(--shadow-light)}.edit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #28a74566}.contact-btn{background:linear-gradient(135deg,var(--warning-orange) 0%,#ffb74d 100%);color:#fff;box-shadow:var(--shadow-light)}.contact-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #ffc10766}.socio-detalle-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:24px;display:flex;align-items:center;gap:16px;transition:var(--transition);box-shadow:var(--shadow-light);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-green),var(--success-green));opacity:0;transition:var(--transition)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-heavy)}.stat-card:hover:before{opacity:1}.stat-icon{font-size:2rem;flex-shrink:0}.stat-content{flex:1}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-green);margin-bottom:4px}.stat-label{font-size:.875rem;color:var(--text-light);font-weight:500}.socio-detalle-tabs{display:flex;gap:8px;margin-bottom:32px;background:var(--bg-light);padding:8px;border-radius:16px;border:1px solid var(--border-color)}.socio-detalle-tab{background:transparent;border:none;color:var(--text-light);font-size:.875rem;border-radius:12px;padding:12px 20px;cursor:pointer;font-weight:600;transition:var(--transition);display:flex;align-items:center;gap:8px;flex:1;justify-content:center}.socio-detalle-tab:hover{background:#5f98891a;color:var(--primary-green)}.socio-detalle-tab.active{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;box-shadow:var(--shadow-medium)}.socio-detalle-content{animation:slideIn .4s ease-out}.content-section{background:transparent;border:none;box-shadow:none;padding:32px 0 0}.section-title{display:flex;align-items:center;gap:12px;font-size:1.5rem;font-weight:700;color:var(--primary-green);margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border-color)}.section-title span:first-child{font-size:1.75rem}.visit-count{font-size:1rem;color:var(--text-light);font-weight:500;margin-left:auto}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.info-item{background:var(--bg-light);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:var(--transition)}.info-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium);border-color:var(--primary-green)}.info-label{font-size:.875rem;font-weight:600;color:var(--text-light);margin-bottom:8px;display:flex;align-items:center;gap:8px}.info-value{font-size:1rem;font-weight:600;color:var(--text-dark)}.training-placeholder,.payments-placeholder,.visits-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.placeholder-icon{font-size:4rem;margin-bottom:16px;opacity:.6}.training-placeholder h4,.payments-placeholder h4,.visits-placeholder h4{color:var(--text-dark);font-size:1.25rem;margin-bottom:8px}.training-placeholder p,.payments-placeholder p,.visits-placeholder p{color:var(--text-light);margin-bottom:24px;max-width:400px}.assign-routine-btn,.view-payments-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-light)}.assign-routine-btn:hover,.view-payments-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #5f988966}.visits-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-light);border:1px solid var(--border-color)}.socio-detalle-table{width:100%;border-collapse:collapse;background:#fff;font-size:.875rem}.socio-detalle-table th{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;font-weight:600;padding:16px 20px;text-align:left;font-size:.875rem}.socio-detalle-table td{padding:16px 20px;border-bottom:1px solid var(--border-color);color:var(--text-dark)}.socio-detalle-table tbody tr:hover{background:var(--bg-light);transition:var(--transition)}.socio-detalle-table tbody tr:last-child td{border-bottom:none}@media (max-width: 1024px){.socio-detalle-container{margin:16px;padding:24px}.socio-detalle-header{flex-direction:column;align-items:flex-start;gap:16px}.socio-detalle-actions{width:100%;justify-content:center}.socio-detalle-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.socio-detalle-tabs{flex-wrap:wrap}.socio-detalle-tab{flex:1 1 calc(50% - 4px)}.info-grid{grid-template-columns:1fr;gap:16px}}@media (max-width: 768px){.socio-detalle-container{margin:8px;padding:20px;border-radius:16px}.socio-detalle-title{font-size:1.75rem}.socio-detalle-avatar{width:60px;height:60px;font-size:2rem}.socio-detalle-subtitle{flex-direction:column;align-items:flex-start;gap:8px}.socio-detalle-stats{grid-template-columns:1fr;gap:12px}.stat-card{padding:20px}.socio-detalle-tabs{flex-direction:column;gap:4px}.socio-detalle-tab{flex:none}.content-section{padding:20px}.section-title{font-size:1.25rem}.socio-detalle-table th,.socio-detalle-table td{padding:12px 16px;font-size:.8rem}}@media (max-width: 480px){.socio-detalle-container{margin:4px;padding:16px}.socio-detalle-header{padding-bottom:16px}.socio-detalle-profile{flex-direction:column;text-align:center;gap:16px}.socio-detalle-actions{flex-direction:column;gap:8px}.action-btn{width:100%;justify-content:center}.stat-card{padding:16px}.stat-icon{font-size:1.5rem}.stat-value{font-size:1.25rem}.content-section,.info-item{padding:16px}}.add-to-screen-btn{background-color:#2196f3!important;color:#fff!important;border:none!important;border-radius:4px!important;padding:4px 8px!important;font-size:12px!important;cursor:pointer!important;transition:background-color .2s ease!important}.add-to-screen-btn:hover{background-color:#1976d2!important}.remove-from-screen-btn{background-color:#ff9800!important;color:#fff!important;border:none!important;border-radius:4px!important;padding:4px 8px!important;font-size:12px!important;cursor:pointer!important;transition:background-color .2s ease!important}.remove-from-screen-btn:hover{background-color:#f57c00!important}.add-to-screen-btn:disabled,.remove-from-screen-btn:disabled{opacity:.6!important;cursor:not-allowed!important}.socios-pantalla-counter{display:flex;align-items:center;padding:8px 16px;background-color:#e3f2fd;border-radius:8px;border:1px solid #2196f3;color:#1976d2;font-weight:600;margin-right:16px}.socios-pantalla-counter span{margin-right:8px}.popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;z-index:1000;padding-top:40px}.popup-content{background:#fff;padding:20px 20px 32px;border-radius:10px;width:400px;max-width:90%;text-align:center;box-shadow:0 4px 10px #0000004d;position:relative}.popup-close{position:absolute;top:10px;right:15px;font-size:1.5rem;color:#dc3545;cursor:pointer}.popup-content h3{margin-bottom:15px;font-size:1.5rem;color:#333}.popup-content input,.popup-content label{display:block;width:100%;margin-bottom:10px;padding:8px;border:1px solid #ccc;border-radius:5px;font-size:1rem}.popup-content label{display:flex;align-items:center;justify-content:space-between;font-weight:700;cursor:pointer}.popup-buttons{display:flex;justify-content:space-between;margin-top:15px}.popup-buttons button{width:48%;padding:10px;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:.3s}.popup-buttons button:first-child{background:#28a745;color:#fff}.popup-buttons button:first-child:hover{background:#218838}.popup-buttons button:last-child{background:#dc3545;color:#fff}.popup-buttons button:last-child:hover{background:#c82333}.switch-container{display:flex;align-items:center;justify-content:space-between;font-size:1rem;font-weight:700;margin-top:10px}.switch-container input{display:none}.switch{position:relative;display:inline-block;width:50px;height:24px}.switch-background{position:absolute;width:100%;height:100%;background:#ccc;border-radius:34px;transition:.3s}.switch-circle{position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:3px;transition:.3s;box-shadow:0 2px 5px #0003}.switch-container input:checked+.switch .switch-background{background:#28a745}.switch-container input:checked+.switch .switch-circle{transform:translate(26px)}.sidebar{width:280px;background:linear-gradient(180deg,var(--primary-green) 0%,var(--secondary-green) 100%);box-shadow:var(--shadow-heavy);color:#fff;padding:24px 16px;transition:var(--transition);display:flex;flex-direction:column;align-items:center;position:fixed;top:0;left:0;height:100vh;z-index:1000;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;border-right:1px solid rgba(255,255,255,.1)}.sidebar-collapsed{transform:translate(-100%);width:0}.sidebar-toggle-btn{display:none}@media (max-width: 2100px){.sidebar{transform:translate(-100%);width:0}.sidebar.sidebar-open{transform:translate(0);width:280px}.sidebar-toggle-btn{display:block;position:fixed;top:20px;left:20px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px;border-radius:50%;z-index:1100;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-heavy);font-size:1.125rem}.main-content{margin-left:0!important;width:100%!important;transition:margin .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1)}}@media (max-width: 2100px){.sidebar.sidebar-open~.main-content{margin-left:280px!important;width:calc(100% - 280px)!important}}.sidebar::-webkit-scrollbar{display:none}.sidebar.sidebar-narrow{width:280px}.sidebar-logo{width:180px;height:auto;display:block;margin:0 auto 32px;transition:var(--transition);filter:brightness(1.1) contrast(1.1);border-radius:12px;box-shadow:var(--shadow-medium)}.sidebar.sidebar-narrow .sidebar-logo{width:180px;margin-bottom:32px}.menu-item{width:100%;max-width:240px;padding:16px 20px;font-size:.875rem;font-weight:600;text-align:left;display:flex;align-items:center;gap:16px;border-radius:12px;cursor:pointer;transition:var(--transition);text-decoration:none;color:#fff;background-color:transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.menu-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff1a;transform:translate(-100%);transition:var(--transition)}.menu-item:hover:before{transform:translate(0)}.menu-item:hover{transform:translate(8px);box-shadow:var(--shadow-medium)}.menu-item:active{transform:translate(4px) scale(.98)}.menu-icon{font-size:1.25rem;flex-shrink:0;z-index:1;position:relative;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.menu-text{z-index:1;position:relative;font-weight:600}.sidebar-menu{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;width:100%;padding:16px 0}.sidebar.sidebar-narrow .menu-item{font-size:.75rem;padding:12px 16px;justify-content:flex-start}.sidebar.sidebar-narrow .menu-text{display:block}.logout-button-fixed{margin-top:auto;width:100%;background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);border-radius:12px;color:#fff;border:none;padding:16px 20px;display:flex;justify-content:center;align-items:center;gap:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:var(--shadow-medium);border:1px solid rgba(255,255,255,.1)}.logout-button-fixed:hover{transform:translateY(-2px);box-shadow:0 8px 20px #dc354566}.logout-button-fixed:active{transform:translateY(0) scale(.98)}.sidebar.sidebar-narrow .logout-button-fixed{left:16px;right:16px;padding:16px 20px}.sidebar.sidebar-narrow .logout-button-fixed .menu-text{display:block}.sidebar-toggle-btn:hover{transform:scale(1.1);box-shadow:0 8px 20px #5f988966}.sidebar-toggle-btn:active{transform:scale(.95)}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;z-index:999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease-in-out}@media (max-width: 1024px) and (min-width: 769px){.sidebar{width:25%;padding:12px}.sidebar.sidebar-narrow{width:15%}.sidebar-logo{width:120px}.sidebar.sidebar-narrow .sidebar-logo{width:70px}.menu-item{padding:10px 15px;font-size:.9rem}.sidebar.sidebar-narrow .menu-item{font-size:.7rem;padding:8px}}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:70%;padding:15px}.sidebar.sidebar-open{transform:translate(0)}.sidebar-toggle-btn{display:block}.sidebar-logo{width:120px}.menu-item{padding:12px 15px;font-size:1rem}.sidebar.sidebar-narrow{width:50%}.logout-button-fixed{width:85%;margin-left:7.5%;padding:.6rem 1.2rem;font-size:.9rem}}@media (max-width: 1024px) and (min-width: 769px) and (orientation: landscape){.sidebar{width:20%}.sidebar-logo{width:100px}.menu-item{padding:8px 12px;font-size:.85rem}}@media (prefers-reduced-motion: reduce){.sidebar,.menu-item,.logout-button-fixed,.sidebar-toggle-btn{transition:none}.menu-item:hover{transform:none}}@media (prefers-color-scheme: dark){.sidebar{box-shadow:2px 0 8px #0000004d}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#5f9889e6,#8ac6b6e6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .3s ease-out}.modal{background:#fff;padding:32px;border-radius:16px;width:90%;max-width:500px;box-shadow:var(--shadow-heavy);text-align:center;display:flex;flex-direction:column;border:1px solid rgba(95,152,137,.1);animation:slideIn .3s ease-out}.modal h3{margin-bottom:24px;color:var(--primary-green);font-size:1.5rem;font-weight:700;border-bottom:2px solid rgba(95,152,137,.1);padding-bottom:16px}.modal label{display:block;font-weight:600;margin:16px 0 8px;text-align:left;color:var(--text-dark);font-size:.875rem}.modal select,.modal input{width:100%;padding:16px;margin-bottom:16px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit}.modal select:focus,.modal input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.modal-actions{display:flex;justify-content:space-between;margin-top:32px;gap:16px}.confirm-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;flex:1;transition:var(--transition);box-shadow:var(--shadow-light)}.confirm-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.cancel-btn{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;flex:1;transition:var(--transition);box-shadow:var(--shadow-light)}.cancel-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.search-container{display:flex;gap:16px;margin-bottom:32px;align-items:center;background:transparent;padding:0;border-radius:0;box-shadow:none;border:none;position:relative}.search-input{flex:1;padding:16px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition);min-width:300px}.search-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.search-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);white-space:nowrap}.search-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.payment-status-advanced{background:transparent;padding:0;border-radius:0;box-shadow:none;margin-top:32px;border:none;animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.payment-title{color:var(--primary-green);font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center;border-bottom:2px solid rgba(95,152,137,.1);padding-bottom:16px;display:flex;align-items:center;justify-content:center;gap:12px}.payment-title i{font-size:1.25rem}.payment-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:32px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#5f98890d;border-radius:8px;border:1px solid rgba(95,152,137,.1);transition:var(--transition)}.info-row:hover{background:#5f98891a;transform:translateY(-2px);box-shadow:var(--shadow-light)}.label{font-weight:600;color:var(--text-dark);font-size:.875rem}.value{font-weight:500;color:var(--text-light);font-size:.875rem}.amount{color:var(--success-green);font-weight:700;font-size:1rem}.plan-badge,.method-badge{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.expired-text{color:var(--danger-red);font-weight:600}.button-container{display:flex;justify-content:center;gap:16px;margin-top:24px;flex-wrap:wrap}.pay-btn,.history-btn,.toggle-user-btn{padding:12px 24px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);display:inline-flex;align-items:center;gap:8px}.pay-btn{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff}.pay-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.history-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff}.history-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.error-text{color:var(--danger-red);font-weight:600;margin:16px 0;padding:16px;background:#dc35451a;border:1px solid rgba(220,53,69,.2);border-radius:8px;text-align:center;animation:fadeIn .3s ease-out}.success-text{margin:16px 0;padding:16px;color:var(--success-green);background:#28a7451a;border:1px solid rgba(40,167,69,.2);border-radius:8px;font-weight:600;text-align:center;animation:fadeIn .3s ease-out}.loading-screen{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:48px;border-radius:16px;text-align:center;z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow-heavy);border:1px solid var(--border-color);animation:fadeIn .3s ease-out}.loading-screen img{width:80px;height:auto;margin-bottom:16px;animation:pulse 2s infinite}.loading-text{font-size:1.125rem;font-weight:600;color:var(--primary-green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.history-table{width:100%;border-collapse:collapse;margin-top:24px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-medium);border:1px solid var(--border-color)}.history-table th,.history-table td{padding:16px 12px;text-align:left;border-bottom:1px solid var(--border-color)}.history-table thead{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff}.history-table th{font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.history-table tbody tr:nth-child(2n){background-color:#5f98890d}.history-table tbody tr:hover{background-color:#5f98891a;transform:translateY(-1px);transition:var(--transition)}.plan-badge,.method-badge{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.95rem;font-weight:900;color:#fff;margin-left:.5rem}.plan-badge{background-color:#1e88e5a3}.method-badge{background-color:#f907}.suggestions-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border-color);border-radius:0 0 8px 8px;z-index:10;max-height:200px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;list-style:none;padding:0;margin:0;box-shadow:var(--shadow-medium);border-top:none}.suggestions-list::-webkit-scrollbar{display:none}.suggestion-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:var(--transition);font-size:.875rem}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#5f98891a;color:var(--primary-green);font-weight:600}.plan-summary{background:#5f98890d;border:1px solid rgba(95,152,137,.2);border-radius:8px;padding:20px;margin:20px 0;text-align:left}.plan-summary p{margin:8px 0;font-size:.875rem;display:flex;justify-content:space-between;align-items:center}.plan-summary strong{color:var(--primary-green);font-weight:600}.toggle-user-btn{background:linear-gradient(135deg,var(--warning-orange) 0%,#ffb74d 100%);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);display:inline-flex;align-items:center;gap:8px}.toggle-user-btn.activate{background:linear-gradient(135deg,var(--success-green) 0%,#4caf50 100%)}.toggle-user-btn.activate:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a74566}.toggle-user-btn.deactivate{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%)}.toggle-user-btn.deactivate:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}@media (max-width: 768px){.search-container{flex-direction:column;gap:12px}.search-input{min-width:auto}.payment-info{grid-template-columns:1fr;gap:16px}.button-container{flex-direction:column;gap:12px}.modal{width:95%;padding:24px}.modal-actions{flex-direction:column;gap:12px}}@media (max-width: 480px){.payment-status-advanced{margin-top:24px}.modal{padding:20px}}.classes-container{max-width:95vw;width:100%;margin:0 auto;padding:24px;background:var(--bg-light);min-height:100vh;font-family:inherit;box-sizing:border-box}h2{color:var(--primary-green);font-size:2rem;font-weight:700;margin-bottom:32px;text-align:center;border-bottom:3px solid var(--primary-green);padding-bottom:16px;word-break:break-word}.classes-buttons-row{display:flex;justify-content:center;gap:16px;margin-bottom:32px}.toggle-view-button,.admin-register-button{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);display:inline-flex;align-items:center;gap:8px}.toggle-view-button:hover,.admin-register-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}@media (max-width: 600px){.classes-buttons-row{flex-direction:column;align-items:center}.toggle-view-button,.admin-register-button{width:100%;text-align:center}}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffd9;display:flex;align-items:center;justify-content:center;z-index:999}.loading-spinner{font-size:1.5rem;font-weight:700;color:#333}.reservations-filter{margin:24px auto;padding:24px;max-width:400px;background:#fff;border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-medium);display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.reservations-filter label{font-weight:600;color:var(--text-dark);font-size:.875rem;margin-bottom:8px}.reservations-filter input[type=date]{width:100%;padding:16px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit}.reservations-filter input[type=date]:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.weekdays-selector-wrapper{display:flex;justify-content:center;margin-bottom:24px}.weekdays-selector{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.day-button{padding:12px 20px;border:none;border-radius:25px;background:#5f98891a;color:var(--text-dark);cursor:pointer;font-weight:600;transition:var(--transition);border:2px solid transparent}.day-button:hover:not(:disabled){background:#5f988933;transform:translateY(-1px);box-shadow:var(--shadow-light)}.day-button:disabled{opacity:.4;cursor:not-allowed}.day-button.active{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;font-weight:700;box-shadow:var(--shadow-medium)}.accordion-list{display:flex;flex-direction:column;gap:16px;margin-top:24px}.accordion-item{border:1px solid var(--border-color);border-radius:12px;background:#fff;overflow:hidden;box-shadow:var(--shadow-light);transition:var(--transition)}.accordion-item:hover{box-shadow:var(--shadow-medium);transform:translateY(-2px)}.accordion-header{padding:20px 24px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);cursor:pointer;transition:var(--transition)}.accordion-header:hover{background:linear-gradient(135deg,var(--active-green) 0%,var(--primary-green) 100%)}.accordion-header h3{margin:0;font-size:1.125rem;color:#fff;font-weight:700;display:flex;align-items:center;gap:12px}.accordion-body-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:24px;background:#5f988905}.reservation-card.enhanced{background:#fff;border:1px solid var(--border-color);padding:16px;border-radius:12px;display:flex;align-items:center;gap:16px;font-size:.875rem;box-shadow:var(--shadow-light);transition:var(--transition);position:relative;overflow:hidden}.reservation-card.enhanced:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.reservation-card.enhanced:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.res-number{font-weight:700;color:#fff;min-width:40px;text-align:center;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);padding:8px 12px;border-radius:8px;font-size:.875rem}.res-info{display:flex;flex-direction:column;flex:1}.res-name{font-weight:600;color:var(--text-dark);font-size:1rem;margin-bottom:4px}.res-status{font-size:.75rem;color:var(--text-light);font-weight:500}.scroll-container{background:#fff;border-radius:16px;box-shadow:var(--shadow-medium);border:1px solid var(--border-color);overflow:hidden;margin-top:24px}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-top:24px}@media (max-width: 1024px){.classes-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 768px){.classes-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width: 480px){.classes-grid{grid-template-columns:1fr}}.class-card{background:#fff;padding:24px;border-radius:16px;box-shadow:var(--shadow-medium);border:1px solid var(--border-color);font-size:.875rem;transition:var(--transition);position:relative;overflow:hidden}.class-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.class-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-heavy)}.class-card h3{margin:0 0 16px;font-size:1.125rem;color:var(--text-dark);font-weight:700}.class-card p{margin:8px 0;font-size:.875rem;color:var(--text-light);font-weight:500}.class-card button{margin-top:16px;padding:12px 20px;font-size:.875rem;border:none;border-radius:8px;cursor:pointer;background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff;font-weight:600;transition:var(--transition);width:100%}.class-card button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a74566}.popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-in-out}.popup-content{background:#fff;border-radius:20px;padding:32px;width:100%;max-width:480px;box-shadow:var(--shadow-heavy);border:1px solid var(--border-color);animation:slideIn .3s ease-out;position:relative;overflow:hidden}.popup-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}@media (max-width: 480px){.popup-content{margin:16px;padding:24px;width:calc(100% - 32px)}}.popup-content h2{color:var(--primary-green);font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center;border:none;padding:0}.popup-content form{display:flex;flex-direction:column;gap:20px}.popup-content label{font-size:.875rem;font-weight:600;margin-bottom:8px;color:var(--text-dark);display:block}.popup-content input,.popup-content select{width:100%;padding:16px;border:2px solid var(--border-color);border-radius:12px;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit;box-sizing:border-box}.popup-content input:focus,.popup-content select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.popup-buttons{display:flex;gap:16px;margin-top:24px}.popup-buttons button{flex:1;padding:16px 24px;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);font-family:inherit}.save-button{background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #28a74566}.save-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.close-popup-button{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff}.close-popup-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.close-popup-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{color:var(--danger-red);margin-bottom:16px;font-weight:600;padding:12px 16px;background:#dc35451a;border:1px solid rgba(220,53,69,.2);border-radius:8px;font-size:.875rem}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.loading-spinner:after{content:"⏳";font-size:2rem;animation:spin 1.5s linear infinite;display:block;margin-top:1.5rem}:root{--primary-green: #5f9889;--secondary-green: #8ac6b6;--active-green: #06694b;--success-green: #28a745;--danger-red: #dc3545;--warning-orange: #ffc107;--text-dark: #333;--text-light: #666;--border-color: #e5e7eb;--bg-light: #f8fafc;--shadow-light: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--transition: all .2s ease-in-out}.tabla-reservas-container{padding:24px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;background:#fff;border-radius:16px;box-shadow:var(--shadow-medium)}.tabla-reservas-container::-webkit-scrollbar{display:none}.mrt-cell-center{text-align:center!important;justify-content:center!important}.mrt-header-bold{font-weight:700!important;text-align:center!important;color:var(--primary-green)!important;font-size:.875rem!important}.acciones-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}.editar-btn,.cancelar-btn{padding:8px 16px;border-radius:8px;color:#fff;border:none;cursor:pointer;font-size:.75rem;font-weight:600;transition:var(--transition);display:inline-flex;align-items:center;gap:6px;min-width:80px;justify-content:center}.editar-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.cancelar-btn{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%)}.editar-btn:hover:not(:disabled),.cancelar-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-medium)}.editar-btn.disabled,.cancelar-btn.disabled{opacity:.5;cursor:not-allowed;transform:none}.MuiTableContainer-root{border-radius:12px!important;overflow:hidden!important;box-shadow:var(--shadow-light)!important}.MuiTableHead-root{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)!important}.MuiTableHead-root .MuiTableCell-head{color:#fff!important;font-weight:700!important;font-size:.875rem!important;border-bottom:none!important}.MuiTableBody-root .MuiTableCell-body{border-bottom:1px solid var(--border-color)!important;font-size:.875rem!important;padding:16px 8px!important}.MuiTableBody-root .MuiTableRow-root:hover{background:#5f98890d!important}.attended-true{color:var(--success-green)!important;font-weight:600!important}.attended-false{color:var(--danger-red)!important;font-weight:600!important}.status-active{color:var(--success-green)!important;font-weight:600!important}.status-cancelled{color:var(--danger-red)!important;font-weight:600!important}.modal{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.history-table tbody tr:hover{background-color:#f9f9f9;transition:background-color .3s ease}.plan-summary{background-color:#f0f9f0;border:1px solid #cce0cc;padding:10px;border-radius:8px;margin-top:10px}.sales-container{max-width:95vw;width:100%;margin:24px auto;padding:32px;background:#fff;border-radius:16px;box-shadow:var(--shadow-medium);font-family:inherit;border:1px solid var(--border-color)}.sales-container h2{text-align:center;margin-bottom:32px;color:var(--primary-green);font-size:2rem;font-weight:700;border-bottom:3px solid var(--primary-green);padding-bottom:16px}.top-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.metric-card{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-light);text-align:center;transition:var(--transition);position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-green),var(--success-green));opacity:0;transition:var(--transition)}.metric-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-heavy)}.metric-card:hover:before{opacity:1}.metric-card h3{margin-bottom:16px;color:var(--text-dark);font-size:1.1rem;font-weight:600}.metric-card p{font-size:2rem;font-weight:700;color:var(--primary-green);margin:0}.sales-table{width:100%;border-collapse:collapse;margin-top:16px;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-light);border:1px solid var(--border-color)}.sales-table th,.sales-table td{border:none;border-bottom:1px solid var(--border-color);padding:12px 8px;text-align:center;font-size:.875rem}.sales-table th{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;font-weight:600;font-size:.875rem}.sales-table tbody tr:hover{background:var(--bg-light);transition:var(--transition)}.sales-table tbody tr:last-child td{border-bottom:none}.middle-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;margin-bottom:32px}.chart-box{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-light);text-align:center;transition:var(--transition);position:relative;overflow:hidden}.chart-box:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-green),var(--success-green));opacity:0;transition:var(--transition)}.chart-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.chart-box:hover:before{opacity:1}.chart-box h3{margin-bottom:20px;color:var(--primary-green);font-size:1.25rem;font-weight:700;border-bottom:2px solid var(--border-color);padding-bottom:12px}.fixed-chart{height:300px;position:relative}.small-chart{max-width:300px;margin:0 auto}.range-chart{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-light);margin-bottom:32px;transition:var(--transition)}.range-chart:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.range-chart h3{margin-bottom:20px;color:var(--primary-green);font-size:1.25rem;font-weight:700;border-bottom:2px solid var(--border-color);padding-bottom:12px;text-align:center}.date-inputs{display:flex;gap:16px;margin-bottom:24px;align-items:center;justify-content:center;flex-wrap:wrap}.date-inputs label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-dark);font-size:.875rem}.date-inputs input[type=date]{padding:8px 12px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition)}.date-inputs input[type=date]:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a}.bottom-row{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;margin-bottom:32px}.export-button{background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff;padding:12px 24px;font-size:.875rem;font-weight:600;border:none;border-radius:12px;margin:8px 16px;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light)}.export-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #28a74566}@media (max-width: 1024px){.sales-container{margin:16px;padding:24px}.top-row{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.middle-row{grid-template-columns:1fr}.fixed-chart{height:250px}}@media (max-width: 768px){.sales-container{margin:8px;padding:20px;border-radius:12px}.sales-container h2{font-size:1.5rem}.top-row,.middle-row{grid-template-columns:1fr;gap:16px}.metric-card,.chart-box,.range-chart{padding:20px}.fixed-chart{height:220px}.date-inputs{flex-direction:column;gap:12px}.sales-table th,.sales-table td{font-size:.75rem;padding:8px 4px}}@media (max-width: 480px){.sales-container{margin:4px;padding:16px}.metric-card,.chart-box,.range-chart{padding:16px}.fixed-chart{height:200px}}.admin-classes-container{padding:2rem;font-family:Segoe UI,sans-serif}.filter-date{margin-bottom:1.5rem}.filter-date input[type=date]{padding:.4rem;margin-left:.5rem;border-radius:6px;border:1px solid #ccc;font-size:1rem}.classes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.class-card{background-color:#f9f9f9;padding:1.2rem;border-radius:12px;box-shadow:0 3px 8px #00000014;transition:transform .2s ease}.class-card:hover{transform:scale(1.02)}.class-card.special{background:linear-gradient(135deg,#d3c4ff,#f0eaff);border-left:6px solid #6a5acd}.class-card.inactive{opacity:.6;background-color:#f3f3f3;border-left:6px solid #ccc}.badge{display:inline-block;padding:.3rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;margin-right:.5rem}.badge-type{background-color:#e0f7fa;color:#00796b}.badge-active.active{background-color:#d0f0d0;color:#2e7d32}.badge-active.inactive{background-color:#ffe0e0;color:#c62828}button.activate,button.deactivate{margin-top:1rem;padding:.6rem 1rem;font-weight:700;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.4rem;font-size:.9rem}button.activate{background-color:#2e7d32;color:#fff}button.deactivate{background-color:#c62828;color:#fff}button.activate:hover{background-color:#1b5e20}button.deactivate:hover{background-color:#a50000}.error{color:red;margin-bottom:1rem;padding:12px 16px;background-color:#ffebee;border:1px solid #ffcdd2;border-radius:8px;font-weight:600}.success{color:#2e7d32;margin-bottom:1rem;padding:12px 16px;background-color:#e8f5e8;border:1px solid #c8e6c9;border-radius:8px;font-weight:600;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.class-info{margin:.5rem 0 1rem}.class-card.disabled-for-date{opacity:.5;filter:grayscale(.7);border:2px dashed #aaa}.class-card.disabled-for-date button{background:#ccc!important;color:#888!important;cursor:not-allowed!important}.class-card.disabled-for-date button:last-child{background:#43a047!important;color:#fff!important;cursor:pointer!important;opacity:1!important;pointer-events:auto!important}html,body{margin:0;padding:0}.pantalla-container{background-color:#0a0f1a;color:#fff;font-family:Segoe UI,sans-serif;padding:1.5rem;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;min-height:100vh;width:100%}.clock,.class-title,.class-subinfo,.time-remaining{text-align:center;width:100%;justify-content:center;align-items:center;display:flex;flex-direction:column}.clock{font-size:4.5rem;color:#00ffd5;text-shadow:0 0 10px rgba(0,255,213,.4);animation:pulse 1s infinite alternate;margin-bottom:1rem;z-index:2}@keyframes pulse{0%{text-shadow:0 0 10px rgba(0,255,213,.3)}to{text-shadow:0 0 25px rgba(0,255,213,.8)}}.class-title{font-size:3rem;font-weight:700;margin:0}.class-subinfo{font-size:1.8rem;color:#ccc;margin-bottom:1rem}.time-remaining{font-size:2.5rem;font-weight:700;margin-bottom:1.5rem;transition:color .3s}.time-remaining.blue{color:#00d1ff}.time-remaining.yellow{color:#f7e500}.time-remaining.orange{color:#f90}.time-remaining.red{color:#ff3b3b}.cards-container{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;width:100%}.user-card{background:#161f2e;padding:.8rem;border-radius:1rem;display:flex;flex-direction:column;justify-content:space-between}.user-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.user-number{font-size:1.35rem;font-weight:700;color:#00ffd5}.user-name{font-size:1.9rem;font-weight:600;color:#eee;text-align:right;flex:1;margin-left:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-routine{border-top:1px solid rgba(255,255,255,.15);padding-top:.7rem;display:flex;flex-direction:column;justify-content:space-between}.routine-title{font-size:1.4rem;font-weight:700;color:#f7e500;margin-bottom:.75rem}.routine-exercises{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}.routine-exercises li{background:#ffffff0d;padding:.7rem;border-radius:.5rem;display:flex;justify-content:space-between;align-items:center;font-size:1.18rem;color:#f0f0f0;box-shadow:0 0 8px #00ffd51a}.routine-exercises li strong{font-weight:700;color:#fff;font-size:1rem;flex:1}.stat-container{display:flex;gap:.5rem;flex-shrink:0}.stat-pill{padding:.38rem .85rem;border-radius:.4rem;font-size:1.08rem;font-weight:600;background:#00ffd5be;color:#f6f7f8}.stat-pill.reps{background:#f7e700bc;color:#f6f7f8}.stat-pill.weight{background:#f13a03bc;color:#f6f7f8}.no-routine{font-size:1.3rem;color:#888;text-align:center}.ads-section{position:absolute;top:0;left:0;width:100vw;height:100vh;margin:0;padding:0;display:flex;justify-content:center;align-items:center;background:#0a0f1a;z-index:9}.ad-image{width:100vw;height:100vh;-o-object-fit:contain;object-fit:contain;background-color:#0a0f1a;border-radius:0}.user-card.socio-seleccionado{border:2px solid #2196f3!important;box-shadow:0 4px 12px #2196f34d!important;position:relative}.user-card.socio-seleccionado:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2196f3,#1976d2);border-radius:8px 8px 0 0}.socio-manual-indicator{position:absolute;top:8px;right:8px;background:#2196f3;color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;font-weight:700;z-index:10}@media (max-width: 1200px){.cards-container{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.cards-container{grid-template-columns:1fr}}.main-content{max-width:95vw;width:100%;margin:24px auto;padding:32px;background:#fff;border-radius:16px;box-shadow:var(--shadow-medium);box-sizing:border-box}.row-fields{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.row-fields .input-group{flex:1;min-width:150px}.search-btn{background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff;border:none;border-radius:12px;padding:16px 24px;font-weight:600;font-size:.875rem;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light)}.search-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #28a74566}.error-text{color:red;text-align:center}.success-text{color:green;text-align:center}.medical-profile-section,.evaluation-section{background:transparent;padding:0;margin-bottom:32px;border-radius:0;border:none}.medical-profile-section h3,.evaluation-section h3{margin-bottom:20px;color:var(--primary-green);font-size:1.25rem;font-weight:700;border-bottom:2px solid var(--border-color);padding-bottom:12px}label{display:block;margin-top:16px;margin-bottom:8px;font-weight:600;color:var(--text-dark);font-size:.875rem}input[type=text],input[type=number],input[type=date],textarea,select{width:100%;padding:16px;margin-top:0;border-radius:12px;border:2px solid var(--border-color);font-size:.875rem;box-sizing:border-box;background:#fff;transition:var(--transition);font-family:inherit}input[type=text]:focus,input[type=number]:focus,input[type=date]:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}textarea{min-height:80px;resize:vertical}.save-btn{margin-top:20px;padding:12px 24px;background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:.875rem;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light)}.save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #28a74566}.save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.evaluation-section .input-group{display:flex;flex-direction:column;margin-bottom:10px}.evaluation-section .input-group label{font-weight:400;margin-bottom:4px}.evaluation-section .input-group input[type=number]{padding:6px;border:1px solid #ccc;border-radius:4px;font-size:14px}.grid-container{display:flex;gap:2rem;flex-wrap:wrap}.grid-section{flex:1;min-width:300px}.three-column-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}@media (min-width: 768px){.three-column-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.three-column-grid{grid-template-columns:repeat(3,1fr)}}.three-column-grid label{display:block;margin-bottom:.25rem;font-weight:700}.three-column-grid input{width:100%;margin-bottom:1rem}.evaluation-history{margin-bottom:32px;background:transparent;border:none;border-radius:0;padding:0;box-shadow:none}.evaluation-history h3{margin-bottom:20px;font-size:1.25rem;font-weight:700;color:var(--primary-green);border-bottom:2px solid var(--border-color);padding-bottom:12px}.evaluation-history table{width:100%;border-collapse:collapse;font-size:.875rem;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-light);border:1px solid var(--border-color)}.evaluation-history th,.evaluation-history td{padding:16px 12px;border-bottom:1px solid var(--border-color);text-align:center}.evaluation-history th{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);font-weight:600;color:#fff;font-size:.875rem}.evaluation-history tr:last-child td{border-bottom:none}@media (max-width: 768px){.main-content{margin:16px;padding:20px;border-radius:12px}.grid-container{flex-direction:column;gap:1rem}.grid-section{min-width:100%}.three-column-grid{grid-template-columns:repeat(2,1fr)}.evaluation-history table{font-size:.75rem}.evaluation-history th,.evaluation-history td{padding:12px 8px}}@media (max-width: 480px){.main-content{margin:8px;padding:16px}.three-column-grid{grid-template-columns:1fr}.row-fields{flex-direction:column}.row-fields .input-group{min-width:100%}}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.center-box{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;min-height:80vh;text-align:center}.center-box.loading .spinner{border:4px solid #f3f3f3;border-top:4px solid #4caf50;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.form-container{max-width:500px;margin:2rem auto;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a}.form-container h2{text-align:center;margin-bottom:1rem;font-size:1.5rem;color:#333}.form-container p{text-align:center;font-size:1rem;margin-bottom:1.5rem}.guardian-form{display:flex;flex-direction:column;gap:1.2rem}.guardian-form label{font-weight:500;font-size:.95rem;color:#444;display:flex;flex-direction:column}.guardian-form input,.guardian-form select{padding:.65rem;border-radius:6px;border:1px solid #ccc;margin-top:.3rem;font-size:1rem}.guardian-form button{background-color:#4caf50;color:#fff;padding:.75rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s ease}.guardian-form button:disabled{background-color:#a5d6a7;cursor:not-allowed}.guardian-form button:hover:not(:disabled){background-color:#388e3c}@media (max-width: 600px){.form-container{padding:1rem;margin:1rem}.guardian-form input,.guardian-form select,.guardian-form button{font-size:.95rem}}.center-box{max-width:500px;margin:0 auto;padding:2rem;background-color:#f5f5f5;border-radius:12px;text-align:center;box-shadow:0 2px 12px #0000001a}.center-box h2{color:#2e7d32;margin-bottom:1rem;font-size:1.8rem}.center-box p{font-size:1rem;color:#333}@media (max-width: 600px){.center-box{padding:1.5rem 1rem}.center-box h2{font-size:1.5rem}.center-box p{font-size:.95rem}}.form-container{max-width:600px;margin:2rem auto;background:#fff;padding:2rem;border-radius:12px;box-shadow:0 0 10px #0000001a}.center-box{display:flex;flex-direction:column;align-items:center;margin-top:4rem;text-align:center}.spinner{width:32px;height:32px;border:4px solid #ccc;border-top-color:#222;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-title{color:var(--primary-green);font-size:2rem;font-weight:700;margin-bottom:32px;text-align:center;border-bottom:3px solid var(--primary-green);padding-bottom:16px}.search-container{display:flex;gap:16px;margin-bottom:32px;align-items:center;background:#5f98890d;padding:24px;border-radius:16px;border:1px solid rgba(95,152,137,.1)}.search-container input{flex:1;padding:16px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition);min-width:300px}.search-container input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.search-container button{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);white-space:nowrap}.search-container button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.user-section{background:#fff;padding:24px;border-radius:16px;box-shadow:var(--shadow-medium);border:1px solid var(--border-color);margin-bottom:24px}.user-section p{color:var(--text-dark);font-size:1.125rem;font-weight:600;margin-bottom:20px;padding:16px;background:#5f98890d;border-radius:8px;border-left:4px solid var(--primary-green)}.user-section label{display:block;font-weight:600;margin:16px 0 8px;color:var(--text-dark);font-size:.875rem}.user-section select{width:100%;padding:16px;margin-bottom:16px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit}.user-section select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.user-section button{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;border:none;padding:16px 24px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);margin-right:12px;margin-bottom:12px}.user-section button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.rutinas-asignadas{margin-top:32px}.rutinas-asignadas h4{color:var(--primary-green);font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center;border-bottom:2px solid var(--primary-green);padding-bottom:16px}.rutina-card{background:#fff;border:1px solid var(--border-color);border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:var(--shadow-medium);transition:var(--transition);position:relative;overflow:hidden}.rutina-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.rutina-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-heavy)}.rutina-card strong{font-size:1.25rem;font-weight:700;color:var(--primary-green);display:block;margin-bottom:8px}.rutina-card span{font-size:.875rem;color:var(--text-light);display:block;margin-bottom:16px;padding:8px 12px;background:#5f98890d;border-radius:6px}.rutina-details{margin-top:16px}.rutina-details summary{cursor:pointer;font-weight:600;margin-top:16px;color:var(--primary-green);padding:12px 16px;background:#5f98890d;border-radius:8px;border:1px solid rgba(95,152,137,.2);transition:var(--transition);display:flex;align-items:center;gap:8px}.rutina-details summary:hover{background:#5f98891a;transform:translateY(-1px);box-shadow:var(--shadow-light)}.rutina-details summary:before{content:"📋";font-size:1.125rem}.rutina-ejercicios{margin-top:20px;padding:20px;background:#5f988905;border-radius:12px;border:1px solid rgba(95,152,137,.1)}.rutina-dia{margin-bottom:24px}.rutina-dia h5{margin-bottom:16px;color:var(--primary-green);font-size:1.125rem;font-weight:600;padding:12px 16px;background:#5f98890d;border-radius:8px;border-left:4px solid var(--primary-green)}.rutina-ejercicio{margin-left:0;font-size:.875rem;color:var(--text-dark);padding:12px;background:#fff;border-radius:8px;border-left:4px solid var(--primary-green);box-shadow:var(--shadow-light);margin-bottom:8px;transition:var(--transition);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.rutina-ejercicio:hover{transform:translate(4px);box-shadow:var(--shadow-medium)}.rutina-ejercicio span{flex:1;min-width:200px}.edit-btn,.save-btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;padding:12px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);font-size:.875rem;margin-top:16px}.edit-btn:hover,.save-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.save-btn{background:linear-gradient(135deg,var(--success-green) 0%,#4caf50 100%)}.save-btn:hover{box-shadow:0 4px 12px #28a74566}input[type=text],input[type=number]{padding:16px;margin:8px 0;border:2px solid var(--border-color);border-radius:8px;width:100%;box-sizing:border-box;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit}input[type=text]:focus,input[type=number]:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}button[style*="background-color: #5f9889"]{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)!important;color:#fff!important;padding:16px 24px!important;margin-top:16px!important;border:none!important;border-radius:8px!important;cursor:pointer!important;transition:var(--transition)!important;font-weight:600!important;font-size:.875rem!important;box-shadow:var(--shadow-light)!important}button[style*="background-color: #5f9889"]:hover{transform:translateY(-2px)!important;box-shadow:0 4px 12px #5f988966!important}ul{padding-left:0;margin:0;list-style:none}li{margin:0}.base-routines-section{margin-top:32px;background:#fff;padding:24px;border-radius:16px;border:1px solid var(--border-color);box-shadow:var(--shadow-medium);text-align:center}.base-routines-section h3{margin-bottom:24px;color:var(--primary-green);font-size:1.5rem;font-weight:700}.ia-form{background:#fff;border-radius:16px;box-shadow:var(--shadow-medium);padding:32px 24px;margin-top:24px;display:flex;flex-direction:column;gap:28px;border:1.5px solid var(--border-color);max-width:700px;margin-left:auto;margin-right:auto}.ia-form-title{color:var(--primary-green);font-size:1.5em;font-weight:700;margin-bottom:0;text-align:center}.ia-form-desc{color:var(--text-light);font-size:1em;text-align:center;margin-bottom:12px}.ia-form-section{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px}.ia-form-section label{display:flex;flex-direction:column;font-weight:600;color:var(--text-dark);font-size:.98em;gap:6px}.ia-form-section input,.ia-form-section select{padding:12px 14px;border-radius:8px;border:1.5px solid var(--border-color);font-size:1em;background:#f8fafc;transition:border .2s}.ia-form-section input:focus,.ia-form-section select:focus{border-color:var(--primary-green);outline:none}.ia-form-btn{margin-top:18px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;font-weight:700;font-size:1.15em;border:none;border-radius:10px;padding:16px 0;cursor:pointer;box-shadow:var(--shadow-light);transition:background .2s,transform .2s;width:100%}.ia-form-btn:active{transform:scale(.98)}@media (max-width: 700px){.ia-form-section{grid-template-columns:1fr}.ia-form{padding:18px 6px}}.user-section,.ia-form{background:#f8fafc;border-radius:14px;border:1.5px solid var(--border-color);box-shadow:none!important;margin-bottom:32px}.rutina-card,.rutinas-asignadas,.ia-form-section,.search-container{border-radius:14px}.user-section,.ia-form,.rutinas-asignadas{margin-bottom:36px}.dashboard-container{padding:24px;background:#f4f7fa;min-height:100vh;box-shadow:none}.main-content{max-width:95vw;width:100%;margin:0 auto;background:#fff;padding:32px;border-radius:16px;box-shadow:var(--shadow-light);border:1px solid var(--border-color);display:block}.rutina-card{box-shadow:none;background:#fff;border:1.5px solid var(--border-color)}.user-section button,.ia-form-btn{box-shadow:none}@media (max-width: 768px){.dashboard-container{padding:16px}.main-content{padding:24px}.admin-title{font-size:1.5rem;margin-bottom:24px}.search-container{flex-direction:column;gap:12px}.search-container input{min-width:auto}.user-section,.rutina-card{padding:20px}.rutina-ejercicio{flex-direction:column;align-items:flex-start}.rutina-ejercicio span{min-width:auto}}@media (max-width: 480px){.dashboard-container{padding:12px}.main-content{padding:20px}.admin-title{font-size:1.25rem}.user-section,.rutina-card{padding:16px}}.uploader-container{max-width:1200px;margin:24px auto;padding:32px;background:#fff;border-radius:16px;box-shadow:var(--shadow-medium);font-family:inherit}.uploader-title{text-align:center;margin-bottom:32px;font-size:2rem;font-weight:700;color:var(--primary-green);border-bottom:3px solid var(--primary-green);padding-bottom:16px}.upload-form{background:transparent;padding:0;border-radius:0;border:none;margin-bottom:40px}.uploader-label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-dark);font-size:.875rem}.link-input,.file-input{display:block;width:100%;padding:16px;margin-top:8px;margin-bottom:20px;border:2px solid var(--border-color);border-radius:12px;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit;box-sizing:border-box}.link-input:focus,.file-input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.upload-button{background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff;padding:16px 24px;border:none;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);width:100%;margin-bottom:20px;box-shadow:var(--shadow-light)}.upload-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #28a74566}.upload-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.progress{background:var(--bg-light);border-radius:12px;padding:16px;margin:16px 0;border:1px solid var(--border-color);text-align:center;font-weight:600;color:var(--primary-green);position:relative;overflow:hidden}.progress:before{content:"";position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--success-green),var(--primary-green));width:var(--progress-width, 0%);transition:width .3s ease}.progress span{position:relative;z-index:1}.message{margin:16px 0;padding:16px;border-radius:12px;font-weight:600;text-align:center;border:1px solid;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message.success{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:var(--success-green);border-color:#c3e6cb}.message.error{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:var(--danger-red);border-color:#f5c6cb}.images-section{background:transparent;padding:0;border-radius:0;border:none;margin:40px 0}.images-section h3{color:var(--primary-green);font-size:1.25rem;font-weight:700;margin-bottom:24px;text-align:center;border-bottom:2px solid var(--border-color);padding-bottom:12px}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-top:20px;justify-content:center}.image-wrapper{position:relative;overflow:hidden;border-radius:12px;box-shadow:var(--shadow-light);transition:var(--transition);max-width:320px;margin:auto;background:#fff;border:1px solid var(--border-color)}.image-wrapper:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.carousel-img{width:100%;max-width:100%;height:200px;-o-object-fit:cover;object-fit:cover;border-radius:12px 12px 0 0;display:block;transition:var(--transition)}.image-wrapper:hover .carousel-img{transform:scale(1.05)}.image-wrapper button{position:absolute;bottom:12px;right:12px;background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:.75rem;font-weight:600;cursor:pointer;opacity:0;transition:var(--transition);box-shadow:var(--shadow-light)}.image-wrapper:hover button{opacity:1;transform:translateY(-2px)}.image-wrapper button:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #dc354566}hr{margin:32px 0;border:none;border-top:1px solid var(--border-color);opacity:.3}.plan-manager{background:transparent;border:none;border-radius:0;padding:0;margin-top:40px;box-shadow:none}.plan-manager h3{margin-bottom:20px;font-size:1.25rem;font-weight:700;color:var(--primary-green);text-align:center;border-bottom:2px solid var(--border-color);padding-bottom:12px}@media (max-width: 768px){.uploader-container{margin:16px;padding:20px;border-radius:16px}.uploader-title{font-size:1.5rem}.image-gallery{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.image-wrapper{max-width:100%}.carousel-img{height:180px}}@media (max-width: 480px){.uploader-container{margin:8px;padding:16px}.image-gallery{grid-template-columns:1fr}.upload-form,.images-section{padding:16px}}.plan-manager{max-width:100%;margin:0;background:transparent;border-radius:0;box-shadow:none;padding:0;font-family:inherit}.plan-form{background:transparent;padding:0;border-radius:0;border:none;margin-bottom:40px}.form-row{display:grid;gap:20px;margin-bottom:20px;align-items:end}.form-row.row-3{grid-template-columns:repeat(3,1fr)}.form-row label,.form-row>div{width:100%}.plan-info-preview{display:flex;flex-direction:column;gap:8px;background:var(--bg-light);border:1px solid var(--primary-green);border-radius:8px;padding:12px;min-width:200px;font-size:.875rem;margin-top:4px}.form-buttons{min-width:110px}.form-buttons button{min-width:90px}.plan-manager h3{font-size:1.25rem;margin-bottom:24px;color:var(--primary-green);text-align:center;font-weight:700;border-bottom:2px solid var(--border-color);padding-bottom:12px}.plan-info-preview{display:flex;flex-direction:column;gap:4px;background:#f6faf9;border:1px solid #e6f0ed;border-radius:8px;padding:12px 16px;min-width:200px;font-size:1rem}.plan-info-name{font-weight:600;color:#27997a;margin-bottom:3px;display:flex;gap:6px}.plan-info-label{color:#1e6150;font-weight:500}.plan-info-value{color:#247565;font-weight:600;margin-left:2px}.plan-info-meta{display:flex;gap:16px;font-size:.97rem;margin-top:2px}.plan-status-dot{font-size:1.13em;margin-left:5px;vertical-align:middle}.plan-status-yes{color:#30cfa7}.plan-status-no{color:#ea6161}.form-row label{display:flex;flex-direction:column;font-size:.875rem;font-weight:600;margin-bottom:0;color:var(--text-dark)}.plan-manager input[type=text],.plan-manager input[type=number],.plan-manager select{padding:16px;border:2px solid var(--border-color);border-radius:12px;font-size:.875rem;margin-top:8px;background:#fff;transition:var(--transition);font-family:inherit;box-sizing:border-box}.plan-manager input[type=text]:focus,.plan-manager input[type=number]:focus,.plan-manager select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.plan-manager input[type=checkbox]{margin-top:9px;transform:scale(1.16)}.plan-manager button{background:linear-gradient(135deg,var(--success-green) 0%,var(--primary-green) 100%);color:#fff;font-weight:600;border:none;padding:12px 20px;border-radius:12px;margin-top:8px;margin-right:12px;transition:var(--transition);cursor:pointer;font-size:.875rem;box-shadow:var(--shadow-light)}.plan-manager button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #28a74566}.plan-manager button[type=button]{background:linear-gradient(135deg,#6c757d,#495057);color:#fff}.plan-manager button[disabled]{opacity:.6;cursor:not-allowed;transform:none}.feedback{font-size:1rem;padding:9px 17px;border-radius:7px;margin:10px 0 18px;display:inline-block}.feedback.ok{background:#def8f0;color:#278c70}.feedback.err{background:#ffe8e6;color:#bf3427}.plan-manager h4{margin-top:32px;color:var(--primary-green);font-size:1.25rem;font-weight:700;text-align:center;border-bottom:2px solid var(--border-color);padding-bottom:12px}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:24px}.plan-card{background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-light);padding:20px;display:flex;flex-direction:column;align-items:flex-start;transition:var(--transition);position:relative}.plan-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary-green);opacity:0;transition:var(--transition)}.plan-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.plan-card.active{border-color:var(--primary-green);box-shadow:var(--shadow-medium)}.plan-card.active:before{opacity:1}.plan-header{width:100%;display:flex;justify-content:space-between;font-size:.97rem;margin-bottom:2px}.plan-id{font-weight:700;color:#38b48e;background:#e6faf5;padding:2px 10px;border-radius:5px}.plan-status.yes{color:#38b48e;font-weight:700}.plan-status.no{color:#e57373;font-weight:700}.plan-title{font-size:1.15rem;font-weight:700;color:#252f34;margin:8px 0 9px}.plan-detail{font-size:.98rem;color:#32695b;margin-bottom:14px;display:flex;flex-direction:column;gap:2px}.plan-actions{display:flex;gap:10px;width:100%}.plan-actions button{flex:1;background:#34a58c;color:#fff;border:none;border-radius:7px;padding:7px 0;font-weight:600;font-size:1rem;cursor:pointer;transition:background .16s;margin-top:0}.plan-actions button:last-child{background:#c6eae0;color:#166d57}.plan-actions button:hover{filter:brightness(.97)}@media (max-width: 900px){.plan-form{padding:20px}.form-row{gap:16px}.form-row.row-3{grid-template-columns:repeat(2,1fr)}.plans-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}}@media (max-width: 650px){.plan-form{padding:16px}.form-row.row-3{grid-template-columns:1fr}.plans-grid{grid-template-columns:1fr;gap:16px}.plan-card{padding:20px}}@media (max-width: 650px){.plan-manager{padding:8px 2vw}.plans-grid{grid-template-columns:1fr;gap:12px}}.form-row input[type=text],.form-row input[type=number],.form-row select{width:100%;box-sizing:border-box}.plan-manager input[name=name]{min-width:210px;padding-right:6px}@media (max-width: 800px){.form-row{grid-template-columns:1fr}}:root{--primary-green: #5f9889;--secondary-green: #8ac6b6;--active-green: #06694b;--success-green: #28a745;--danger-red: #dc3545;--warning-orange: #ffc107;--text-dark: #333;--text-light: #666;--border-color: #e5e7eb;--bg-light: #f8fafc;--shadow-light: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-heavy: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition: all .2s ease-in-out}.rutinas-base-container{max-width:95vw;width:100%;margin:0 auto;padding:24px;background:var(--bg-light);min-height:100vh}.rutinas-base-container h2{color:var(--primary-green);font-size:2rem;font-weight:700;margin-bottom:32px;text-align:center;border-bottom:3px solid var(--primary-green);padding-bottom:16px}.rutinas-base-container h3{color:var(--text-dark);font-size:1.5rem;font-weight:600;margin:32px 0 24px;text-align:center}.modal-ejercicios{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#5f9889e6,#8ac6b6e6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.modal-contenido.estilizado{background:#fff;padding:32px;border-radius:16px;width:90%;max-width:900px;max-height:90vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;box-shadow:var(--shadow-heavy);border:1px solid rgba(95,152,137,.1);animation:slideIn .3s ease-out}.modal-contenido.estilizado::-webkit-scrollbar{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-contenido h3{margin-bottom:24px;color:var(--primary-green);font-size:1.5rem;font-weight:700;border-bottom:2px solid rgba(95,152,137,.1);padding-bottom:16px;text-align:center}.modal-contenido h4{color:var(--text-dark);font-size:1.125rem;font-weight:600;margin:24px 0 16px;padding:12px 16px;background:#5f98890d;border-radius:8px;border-left:4px solid var(--primary-green)}.modal-contenido input[type=text],.modal-contenido input[type=number]{display:block;width:100%;margin-bottom:16px;padding:16px;border:2px solid var(--border-color);border-radius:8px;font-size:.875rem;background:#fff;transition:var(--transition);font-family:inherit}.modal-contenido input[type=text]:focus,.modal-contenido input[type=number]:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #5f98891a;transform:translateY(-1px)}.bloque-dia{background:#5f98890d;border:1px solid rgba(95,152,137,.2);border-radius:12px;padding:20px;margin-bottom:24px;transition:var(--transition)}.bloque-dia:hover{background:#5f98891a;transform:translateY(-2px);box-shadow:var(--shadow-light)}.encabezado-dia{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-weight:600;color:var(--primary-green);font-size:1.125rem;padding-bottom:8px;border-bottom:1px solid rgba(95,152,137,.2)}.campo-ejercicio{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:12px;margin-bottom:12px;align-items:center;background:#fff;padding:12px;border-radius:8px;border:1px solid var(--border-color);transition:var(--transition)}.campo-ejercicio:hover{border-color:var(--primary-green);box-shadow:var(--shadow-light)}.campo-ejercicio input{flex:1;min-width:100px;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;transition:var(--transition)}.campo-ejercicio input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px #5f98891a}.campo-ejercicio .btn-eliminar{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff;border:none;border-radius:6px;padding:8px 12px;cursor:pointer;transition:var(--transition);font-size:.75rem}.campo-ejercicio .btn-eliminar:hover{transform:translateY(-1px);box-shadow:0 2px 8px #dc35454d}.botones-modal{margin-top:32px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.botones-modal .btn{padding:16px 24px;border-radius:8px;font-weight:600;border:none;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-light);font-size:.875rem;min-width:120px}.btn{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:600;transition:var(--transition);border:none;box-shadow:var(--shadow-light)}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.btn-editar{background:linear-gradient(135deg,var(--success-green) 0%,#4caf50 100%);color:#fff}.btn-editar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #28a74566}.btn-agregar{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff}.btn-agregar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.btn-eliminar{background:linear-gradient(135deg,var(--danger-red) 0%,#c82333 100%);color:#fff}.btn-eliminar:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc354566}.btn-ver{background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%);color:#fff}.btn-ver:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5f988966}.grid-rutinas{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px;margin-top:24px}.tarjeta-rutina{background:#fff;border-radius:16px;box-shadow:var(--shadow-medium);padding:24px;transition:var(--transition);border:1px solid var(--border-color);position:relative;overflow:hidden}.tarjeta-rutina:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,var(--primary-green) 0%,var(--secondary-green) 100%)}.tarjeta-rutina:hover{transform:translateY(-4px);box-shadow:var(--shadow-heavy)}.rutina-titulo{margin-bottom:12px;font-size:1.25rem;font-weight:700;color:var(--primary-green);display:flex;align-items:center;gap:8px}.rutina-detalle{color:var(--text-light);margin-bottom:20px;font-size:.875rem;line-height:1.5;padding:12px;background:#5f98890d;border-radius:8px;border-left:3px solid var(--primary-green)}.rutina-detalle strong{color:var(--primary-green);font-weight:600}.botones-rutina{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.vista-ejercicios{max-height:60vh;overflow-y:auto;margin-top:24px;padding:20px;background:#5f988905;border-radius:12px;border:1px solid rgba(95,152,137,.1)}.vista-ejercicios h4{margin-top:24px;color:var(--primary-green);font-size:1.125rem;font-weight:600;border-bottom:2px solid var(--primary-green);padding-bottom:12px;margin-bottom:16px}.vista-ejercicios ul{list-style:none;margin-left:0;padding-left:0}.vista-ejercicios li{margin-bottom:12px;line-height:1.5;color:var(--text-dark);padding:12px;background:#fff;border-radius:8px;border-left:4px solid var(--primary-green);box-shadow:var(--shadow-light);transition:var(--transition)}.vista-ejercicios li:hover{transform:translate(4px);box-shadow:var(--shadow-medium)}.vista-ejercicios li strong{color:var(--primary-green);font-weight:600}@media (max-width: 768px){.rutinas-base-container{padding:16px}.rutinas-base-container h2{font-size:1.5rem;margin-bottom:24px}.grid-rutinas{grid-template-columns:1fr;gap:16px}.tarjeta-rutina{padding:20px}.botones-rutina{flex-direction:column;gap:8px}.modal-contenido.estilizado{width:95%;padding:24px}.campo-ejercicio{grid-template-columns:1fr;gap:8px}.botones-modal{flex-direction:column;gap:12px}}@media (max-width: 480px){.rutinas-base-container{padding:12px}.rutinas-base-container h2{font-size:1.25rem}.tarjeta-rutina{padding:16px}.modal-contenido.estilizado{padding:20px}}.statistics-container{padding:24px;max-width:1400px;margin:0 auto;background:#f8f9fa;min-height:100vh}.header-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.header-section h2{color:#5f9889;margin:0 0 20px;font-size:1.8em;font-weight:700}.date-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.date-inputs{display:flex;gap:16px;align-items:center}.date-inputs label{display:flex;align-items:center;gap:8px;font-weight:600;color:#333}.date-inputs input{padding:8px 12px;border:1.5px solid #ddd;border-radius:6px;font-size:14px}.export-button{background:#5f9889;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.export-button:hover{background:#4a7c6f}.summary-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.summary-section h3{color:#5f9889;margin:0 0 20px;font-size:1.4em;font-weight:700}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.summary-card{background:#f8f9fa;padding:20px;border-radius:8px;text-align:center;border:1px solid #e9ecef}.summary-card h4{color:#6c757d;margin:0 0 12px;font-size:.9em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.summary-card .number{color:#5f9889;font-size:2em;font-weight:700;margin:0}.charts-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.chart-row:last-child{margin-bottom:0}.chart-container{background:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef}.chart-container h3{color:#5f9889;margin:0 0 16px;font-size:1.2em;font-weight:600;text-align:center}.chart-container canvas{max-height:300px}.table-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.table-section h3{color:#5f9889;margin:0 0 20px;font-size:1.4em;font-weight:700}.table-container{overflow-x:auto}.statistics-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px #0000001a}.statistics-table th{background:#5f9889;color:#fff;padding:12px 16px;text-align:left;font-weight:600;font-size:.9em}.statistics-table td{padding:12px 16px;border-bottom:1px solid #e9ecef;font-size:.9em}.statistics-table tr:hover{background:#f8f9fa}.statistics-table .attended{color:#28a745;font-weight:600}.statistics-table .cancelled{color:#dc3545;font-weight:600}.insights-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.insights-section h3{color:#5f9889;margin:0 0 20px;font-size:1.4em;font-weight:700}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.insight-card{background:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef}.insight-card h4{color:#5f9889;margin:0 0 16px;font-size:1.1em;font-weight:600}.insight-card ul{margin:0;padding-left:20px}.insight-card li{margin-bottom:8px;color:#333;font-size:.9em}.insight-card li:last-child{margin-bottom:0}.loading-container{display:flex;align-items:center;justify-content:center;min-height:60vh;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:16px;margin:20px 0}.loading-content{text-align:center;padding:40px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;border:1px solid #e9ecef;max-width:400px;width:100%}.loading-icon{font-size:3em;margin-bottom:16px;animation:pulse 2s ease-in-out infinite}.loading-content h3{color:#5f9889;margin:0 0 8px;font-size:1.3em;font-weight:600}.loading-content p{color:#6c757d;margin:0 0 24px;font-size:.95em}.loading-bar{width:100%;height:6px;background:#f1f3f4;border-radius:3px;overflow:hidden;position:relative}.loading-progress{height:100%;background:linear-gradient(90deg,#5f9889,#4a7c6f);border-radius:3px;animation:loading 2s ease-in-out infinite;width:30%}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@keyframes loading{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}.error-message{text-align:center;padding:40px;color:#dc3545}.error-message h3{margin:0 0 16px;font-size:1.4em}.retry-button{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;margin-top:16px}.retry-button:hover{background:#c82333}.no-data{text-align:center;padding:40px;color:#6c757d}.no-data h3{margin:0 0 16px;font-size:1.4em}@media (max-width: 768px){.statistics-container{padding:16px}.date-controls{flex-direction:column;align-items:stretch}.date-inputs{flex-direction:column;gap:12px}.chart-row{grid-template-columns:1fr;gap:16px}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.insights-grid{grid-template-columns:1fr}.statistics-table{font-size:.8em}.statistics-table th,.statistics-table td{padding:8px 12px}}
