@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-family:"Outfit", sans-serif;--bg-color:#0b0914;--bg-gradient:radial-gradient(circle at top, #1e1336 0%, #0b0914 100%);--panel-bg:#14102699;--panel-border:#a855f726;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--primary-accent:#a855f7;--primary-gradient:linear-gradient(135deg, #a855f7 0%, #6366f1 100%);--cyan-accent:#06b6d4;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--glow-shadow:0 0 20px #a855f766;--box-shadow:0 10px 30px #00000080}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-primary);-webkit-font-smoothing:antialiased;justify-content:center;align-items:flex-start;min-height:100vh;display:flex;overflow-x:hidden}#root{width:100%;max-width:480px;min-height:100vh;box-shadow:var(--box-shadow);background:#0b0914f2;border-left:1px solid #ffffff0d;border-right:1px solid #ffffff0d;flex-direction:column;padding-bottom:90px;display:flex;position:relative}.login-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;display:flex}.login-logo{letter-spacing:-1px;background:var(--primary-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:8px;margin-bottom:8px;font-size:32px;font-weight:700;display:flex}.login-logo span{color:var(--cyan-accent);-webkit-text-fill-color:initial}.login-subtitle{color:var(--text-secondary);margin-bottom:40px;font-size:15px}.login-card{background:var(--panel-bg);border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;box-shadow:var(--box-shadow);border-radius:24px;padding:32px 24px}.form-group{text-align:left;margin-bottom:20px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:500;display:block}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper svg{color:var(--text-secondary);pointer-events:none;width:18px;height:18px;position:absolute;left:14px}.form-input{width:100%;color:var(--text-primary);font-size:15px;font-family:var(--font-family);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:14px 14px 14px 44px;transition:all .3s}.form-input:focus{border-color:var(--primary-accent);background:#ffffff14;outline:none;box-shadow:0 0 10px #a855f733}.remember-me{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-bottom:24px;font-size:14px;display:flex}.remember-me input{accent-color:var(--primary-accent);width:16px;height:16px}.btn-primary{background:var(--primary-gradient);color:#fff;cursor:pointer;width:100%;font-size:16px;font-weight:600;font-family:var(--font-family);border:none;border-radius:12px;padding:14px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #a855f74d}.btn-primary:hover{box-shadow:var(--glow-shadow);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none!important;transform:none!important}.error-banner{color:#fca5a5;text-align:left;background:#ef444426;border:1px solid #ef44444d;border-radius:12px;align-items:center;gap:8px;margin-bottom:20px;padding:12px;font-size:14px;display:flex}.bottom-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;background:#100c22f2;border-top:1px solid #ffffff14;justify-content:space-around;align-items:center;width:100%;max-width:480px;height:76px;padding:0 10px;display:flex;position:fixed;bottom:0;box-shadow:0 -10px 30px #00000080}.nav-item{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:70px;height:100%;font-size:11px;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.nav-item svg{width:22px;height:22px;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.nav-item.active{color:var(--primary-accent)}.nav-item.active svg{color:var(--primary-accent);transform:translateY(-4px)scale(1.15)}.app-header{justify-content:space-between;align-items:center;padding:24px 20px 16px;display:flex}.header-user{align-items:center;gap:12px;display:flex}.avatar-placeholder{background:var(--primary-gradient);color:#fff;border:2px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex;box-shadow:0 4px 10px #0000004d}.user-welcome{flex-direction:column;display:flex}.welcome-label{color:var(--text-secondary);font-size:13px}.welcome-name{font-size:18px;font-weight:600}.logout-btn{width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:12px;justify-content:center;align-items:center;transition:all .3s;display:flex}.logout-btn:hover{color:var(--danger-color);background:#ef444426;border-color:#ef44444d}.tab-content{flex-direction:column;gap:20px;padding:8px 20px 24px;display:flex}.view-title{margin-bottom:4px;font-size:24px;font-weight:700}.view-subtitle{color:var(--text-secondary);margin-top:-16px;margin-bottom:8px;font-size:14px}.qr-card-container{flex-direction:column;align-items:center;width:100%;display:flex}.qr-card{background:var(--panel-bg);border:1px solid var(--panel-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;box-shadow:var(--box-shadow);border-radius:32px;flex-direction:column;align-items:center;padding:32px 24px;display:flex;position:relative;overflow:hidden}.qr-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#a855f714 0%,#0000 60%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.qr-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:24px;font-size:15px;font-weight:600}.qr-box{background:#fff;border-radius:20px;justify-content:center;align-items:center;margin-bottom:24px;padding:16px;transition:all .3s;display:flex;position:relative;box-shadow:0 20px 40px #0009}.qr-box.expiring{animation:1s infinite alternate pulse-border}.qr-image{width:200px;height:200px;display:block}.qr-spinner{width:100%;height:100%;color:var(--primary-accent);background:#ffffffe6;border-radius:20px;justify-content:center;align-items:center;display:flex;position:absolute}.qr-countdown-container{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.qr-countdown-text{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.qr-countdown-bar{background:#ffffff14;border-radius:10px;width:120px;height:5px;overflow:hidden}.qr-countdown-fill{background:var(--primary-gradient);border-radius:10px;height:100%;transition:width 1s linear}.client-tag{color:var(--primary-accent);background:#a855f71a;border:1px solid #a855f733;border-radius:20px;margin-top:24px;padding:6px 14px;font-size:14px;font-weight:500}.bulletin-container{flex-direction:column;gap:20px;width:100%;display:flex}.bulletin-hero-card{background:linear-gradient(135deg,#9333ea40 0%,#4f46e540 100%);border:1px solid #a855f733;border-radius:20px;flex-direction:column;justify-content:center;padding:24px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 24px #00000026}.bulletin-hero-overlay{pointer-events:none;background:radial-gradient(circle at 100% 0,#ffffff0d,#0000 60%);width:100%;height:100%;position:absolute;top:0;left:0}.bulletin-hero-content{z-index:2;flex-direction:column;gap:6px;display:flex;position:relative}.bulletin-hero-tag{background:var(--primary-accent);color:#fff;text-transform:uppercase;letter-spacing:.8px;border-radius:12px;align-self:flex-start;padding:4px 10px;font-size:11px;font-weight:700}.bulletin-hero-content h3{color:var(--text-primary);margin:4px 0;font-size:22px;font-weight:800}.bulletin-hero-quote{color:var(--text-secondary);margin:4px 0;font-size:14px;font-style:italic;line-height:1.5}.bulletin-hero-meta{color:var(--text-secondary);align-items:center;gap:6px;margin-top:8px;font-size:12px;display:flex}.announcements-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:20px;padding:20px}.announcements-title{color:var(--text-primary);margin-top:0;margin-bottom:12px;font-size:15px;font-weight:700}.announcements-list{flex-direction:column;gap:12px;display:flex}.announcement-item{align-items:flex-start;gap:10px;display:flex}.announcement-icon{font-size:18px}.announcement-text{color:var(--text-secondary);font-size:12.5px;line-height:1.5}.announcement-text strong{color:var(--text-primary)}.quick-stats{grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}.stat-item{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;align-items:center;gap:12px;padding:16px;display:flex}.stat-icon{width:40px;height:40px;color:var(--cyan-accent);background:#ffffff0a;border-radius:10px;justify-content:center;align-items:center;display:flex}.stat-info{flex-direction:column;display:flex}.stat-label{color:var(--text-secondary);font-size:12px}.stat-value{font-size:15px;font-weight:600}.plans-list{flex-direction:column;gap:16px;display:flex}.plan-card{background:var(--panel-bg);border:1px solid var(--panel-border);box-shadow:var(--box-shadow);border-radius:24px;padding:20px;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s;position:relative;overflow:hidden}.plan-card.clickable{cursor:pointer}.plan-card.clickable:hover{border-color:var(--primary-accent);transform:translateY(-4px);box-shadow:0 12px 30px #6f42c140}.plan-card.clickable:active{transform:translateY(-1px)}.plan-card:after{content:"";background:var(--primary-gradient);width:4px;height:100%;position:absolute;top:0;left:0}.plan-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.plan-name{color:#fff;font-size:18px;font-weight:600}.plan-badge{text-transform:uppercase;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.plan-badge.activo{color:var(--success-color);background:#10775126;border:1px solid #1077514d}.plan-badge.caducado,.plan-badge.baja{color:var(--danger-color);background:#ef444426;border:1px solid #ef44444d}.plan-badge.en_cola{color:var(--warning-color);background:#f59e0b26;border:1px solid #f59e0b4d}.plan-details{flex-direction:column;gap:8px;margin-bottom:16px;font-size:14px;display:flex}.plan-detail-row{color:var(--text-secondary);justify-content:space-between;display:flex}.plan-detail-row span:last-child{color:var(--text-primary);font-weight:500}.plan-progress-container{flex-direction:column;gap:6px;width:100%;display:flex}.plan-progress-bar{background:#ffffff0d;border-radius:10px;width:100%;height:6px;overflow:hidden}.plan-progress-fill{background:var(--primary-gradient);border-radius:10px;height:100%}.plan-progress-text{color:var(--text-secondary);text-align:right;font-size:12px}.payments-list{flex-direction:column;gap:12px;display:flex}.payment-item{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:16px;justify-content:space-between;align-items:center;padding:16px;transition:all .3s;display:flex}.payment-item:hover{background:#ffffff05}.payment-left{align-items:center;gap:12px;display:flex}.payment-icon{width:44px;height:44px;color:var(--primary-accent);background:#ffffff08;border-radius:12px;justify-content:center;align-items:center;display:flex}.payment-info{flex-direction:column;display:flex}.payment-title{color:#fff;font-size:14px;font-weight:600}.payment-date{color:var(--text-secondary);font-size:12px}.payment-right{flex-direction:column;align-items:flex-end;display:flex}.payment-value{color:#fff;font-size:15px;font-weight:600}.payment-status{margin-top:2px;font-size:11px;font-weight:500}.payment-status.complete{color:var(--success-color)}.payment-status.pending{color:var(--warning-color)}.placeholder-view{background:var(--panel-bg);border:1px solid var(--panel-border);text-align:center;border-radius:24px;flex-direction:column;align-items:center;gap:20px;margin-top:10px;padding:40px 24px;display:flex}.placeholder-icon{width:80px;height:80px;color:var(--primary-accent);background:#a855f71a;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 0 30px #a855f726}.placeholder-icon svg{width:40px;height:40px}.placeholder-title{font-size:20px;font-weight:600}.placeholder-description{color:var(--text-secondary);font-size:14px;line-height:1.5}.placeholder-coming{color:var(--cyan-accent);background:#06b6d41a;border:1px solid #06b6d433;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.spinner{border:4px solid #ffffff0d;border-left-color:var(--primary-accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-border{0%{border-color:#ef44444d;box-shadow:0 0 10px #ef44444d}to{border-color:#ef444499;box-shadow:0 0 20px #ef444499}}.perfil-btn-hover:hover{transform:translateY(-2px);border-color:var(--primary-accent)!important;background:#ffffff14!important;box-shadow:0 0 15px #a855f740!important}.perfil-btn-hover:active{transform:translateY(0)}@media (width>=768px),(orientation:landscape) and (width>=568px){body{background:var(--bg-color);background-image:var(--bg-gradient);justify-content:stretch;align-items:stretch;padding:0;overflow:hidden}#root{background:var(--bg-color);background-image:var(--bg-gradient);width:100vw;max-width:100%;height:100vh;min-height:100vh;box-shadow:none;border:none;border-radius:0;grid-template:"sidebar header"80px"sidebar main"1fr/240px 1fr;margin:0;padding-bottom:0;display:grid;overflow:hidden}.app-header{background:#100c2233;border-bottom:1px solid #ffffff0d;grid-area:header;justify-content:space-between;align-items:center;height:80px;padding:0 40px;display:flex}.tab-content{grid-area:main;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));align-content:start;align-items:start;gap:32px;max-height:calc(100vh - 80px);padding:40px;display:grid;overflow-y:auto!important}.tab-content .view-title{grid-column:1/-1;margin-bottom:6px;font-size:28px}.tab-content .view-subtitle{grid-column:1/-1;margin-top:-16px;margin-bottom:12px;font-size:15px}.tab-content .error-banner{grid-column:1/-1}.tab-content .placeholder-view{grid-column:1/-1;padding:60px 40px}.bottom-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:240px;height:100%;box-shadow:none;background:#0b0914f2;border-top:none;border-right:1px solid #ffffff14;flex-direction:column;grid-area:sidebar;justify-content:flex-start;align-items:stretch;gap:8px;max-width:240px;padding:32px 16px;position:sticky;top:0;left:0;overflow-y:auto}.nav-item{border-radius:12px;flex-direction:row;justify-content:flex-start;gap:12px;width:100%;height:48px;padding:0 16px;font-size:14px;font-weight:600}.nav-item svg{width:20px;height:20px}.nav-item.active{color:var(--primary-accent);background:#a855f71f;border:1px solid #a855f72e}.nav-item.active svg{transform:scale(1.1)}.login-container,.loading-screen{z-index:999;background:var(--bg-color);background-image:var(--bg-gradient);flex-direction:column;justify-content:center;align-items:center;width:100vw;min-height:100vh;padding:32px 24px;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.login-card{width:100%;max-width:440px}}.sub-tabs-container{background:#ffffff08;border:1px solid #ffffff0d;border-radius:16px;width:100%;max-width:480px;margin-bottom:24px;padding:6px;display:flex}.sub-tab{color:var(--text-secondary);cursor:pointer;text-align:center;background:0 0;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:13.5px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.sub-tab:hover{color:var(--text-primary);background:#ffffff05}.sub-tab.active{background:var(--primary-accent);color:#fff;box-shadow:0 4px 12px #a855f759}.booking-alert{border-radius:16px;justify-content:space-between;align-items:center;width:100%;margin-bottom:24px;padding:14px 20px;font-size:13px;font-weight:500;animation:.3s ease-out slideIn;display:flex}.booking-alert.success{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e33}.booking-alert.error{color:#f87171;background:#ef44441a;border:1px solid #ef444433}.alert-close{color:currentColor;cursor:pointer;opacity:.7;background:0 0;border:none;padding:2px;font-size:14px}.alert-close:hover{opacity:1}.classes-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-content:start;gap:20px;width:100%;display:grid}.class-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-left:5px solid var(--primary-accent);border-radius:18px;flex-direction:column;gap:14px;padding:20px;transition:all .25s;display:flex;box-shadow:0 4px 12px #0000001a}.class-card:hover{border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.class-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.class-activity{font-size:17px;font-weight:800}.class-spots{color:var(--text-secondary);background:#ffffff0d;border:1px solid #ffffff14;border-radius:12px;padding:4px 10px;font-size:11.5px;font-weight:600}.class-body{flex-direction:column;gap:8px;display:flex}.class-info-item{align-items:center;gap:8px;display:flex}.info-icon{opacity:.8;font-size:14px}.info-text{color:var(--text-secondary);font-size:13px}.info-text strong{color:var(--text-primary)}.class-progress-container{width:100%;margin-top:4px}.class-progress-bar{background:#ffffff0f;border-radius:3px;height:6px;overflow:hidden}.class-progress-fill{border-radius:3px;height:100%;transition:width .4s}.class-footer{margin-top:auto;padding-top:10px}.book-btn{cursor:pointer;border:none;border-radius:14px;width:100%;padding:12px;font-size:13.5px;font-weight:700;transition:all .2s}.book-btn.action{color:var(--primary-accent);background:#a855f71a;border:1px solid #a855f733}.book-btn.action:hover:not(:disabled){background:var(--primary-accent);color:#fff;box-shadow:0 4px 12px #a855f74d}.book-btn.booked{color:#4ade80;cursor:default;background:#22c55e1a;border:1px solid #22c55e33}.book-btn.full{color:var(--text-muted);cursor:not-allowed;background:#ffffff08;border:1px solid #ffffff0d}.reservations-list{flex-direction:column;gap:14px;width:100%;display:flex}.reservation-item{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:18px;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;transition:all .2s;display:flex}.reservation-item:hover{background:#ffffff03;border-color:#ffffff14}.reservation-item.X{opacity:.6}.res-meta{flex-direction:column;gap:4px;display:flex}.res-activity{color:var(--text-primary);font-size:15px;font-weight:700}.res-trainer{color:var(--text-secondary);font-size:12.5px}.res-date{color:var(--primary-accent);font-size:12.5px;font-weight:500}.res-right{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.res-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:10px;padding:4px 10px;font-size:11px;font-weight:700}.res-badge.A{color:var(--primary-accent);background:#a855f71a;border:1px solid #a855f733}.res-badge.F{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e33}.res-badge.N{color:#f87171;background:#ef44441a;border:1px solid #ef444433}.res-badge.X{color:var(--text-secondary);background:#ffffff0d;border:1px solid #ffffff0d}.cancel-res-btn{color:#f87171;cursor:pointer;background:#ef44441a;border:1px solid #ef444433;border-radius:10px;padding:6px 12px;font-size:11px;font-weight:700;transition:all .2s}.cancel-res-btn:hover{color:#fff;background:#ef4444;box-shadow:0 4px 12px #ef44444d}.cancel-lock-text{color:var(--text-muted);font-size:11px;font-style:italic}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
