.admin-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:#000000d9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:width var(--transition-slow);overflow:hidden}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid rgba(255,255,255,.08);min-height:var(--header-height);gap:var(--space-3)}.sidebar-logo{flex:1;overflow:visible}.sidebar-logo-img{height:48px;width:100%;object-fit:contain;object-position:center;mix-blend-mode:screen}.sidebar-collapse-btn{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#ffffff73;flex-shrink:0;transition:all var(--transition-fast)}.sidebar-collapse-btn:hover{background:#ffffff1f;color:#ffffffe6;border-color:#ffffff38}.sidebar-collapse-btn .rotated{transform:rotate(180deg)}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#ffffff80;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:#ffffff14;color:#ffffffe6}.nav-item.active{background:#0060d040;color:#93c5fd;border:1px solid rgba(0,96,208,.35);font-weight:600}.nav-item svg{flex-shrink:0}.nav-item-logout{color:#ef4444b3}.nav-item-logout:hover{background:#ef444426;color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.sidebar-footer{padding:var(--space-3) var(--space-2);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px));border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);overflow:hidden}.sidebar-user-avatar{width:32px;height:32px;background:#0060d099;border:1px solid rgba(0,96,208,.45);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;flex-shrink:0}.sidebar-user-info{overflow:hidden}.sidebar-user-name{font-size:.875rem;font-weight:600;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.75rem;color:#fff6;text-transform:capitalize}.admin-main{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-slow)}.sidebar-collapsed .admin-main{margin-left:var(--sidebar-collapsed-width)}.admin-header{height:var(--header-height);background:#000000bf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:50}.mobile-menu-btn{display:none;background:#ffffff14;border:1px solid rgba(255,255,255,.15);cursor:pointer;color:#fffc;padding:var(--space-2);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-header-right{display:flex;align-items:center;gap:var(--space-4)}.header-greeting{font-size:.875rem;color:#ffffff80}.header-greeting strong{color:#ffffffd9;font-weight:600}.admin-content{padding:var(--space-6);flex:1}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99}@media (max-width: 1024px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)!important}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.admin-main{margin-left:0!important}.mobile-menu-btn{display:flex}.admin-content{padding:var(--space-4)}}.nav-item-superadmin{margin-top:var(--space-3);border-top:1px solid rgba(255,255,255,.08);color:#facc15b3}.nav-item-superadmin:hover{background:#facc151a;color:#facc15f2;border-color:#ffffff14}.nav-item-superadmin.active{background:#facc1526;color:#facc15;border:1px solid rgba(250,204,21,.3)}.trainer-layout{display:flex;min-height:100vh}.trainer-sidebar{width:var(--sidebar-width);background:#000000d9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}.trainer-logo{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-bottom:1px solid rgba(255,255,255,.08);min-height:var(--header-height)}.trainer-nav{flex:1;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:2px}.trainer-footer{padding:var(--space-3) var(--space-2);border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:var(--space-2)}.trainer-main{margin-left:var(--sidebar-width);flex:1;padding:var(--space-6);min-height:100vh}@media (max-width: 768px){.trainer-sidebar{display:none}.trainer-main{margin-left:0;padding:var(--space-4)}}.member-layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.member-header{height:var(--header-height);background:#000000d1;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);position:sticky;top:0;z-index:50}.member-header-logo{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-size:1rem;font-weight:700;letter-spacing:.12em;color:#ffffffe6}.member-logo-icon{width:32px;height:32px;background:#0060d0b3;border:1px solid rgba(0,96,208,.5);color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:800}.member-header-user{display:flex;align-items:center;gap:var(--space-3)}.member-header-name{font-size:.875rem;font-weight:500;color:#ffffffa6}.member-content{flex:1;padding:var(--space-4);padding-bottom:calc(72px + var(--space-4));overflow-y:auto}.member-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#000000e0;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-around;padding:0 var(--space-2);padding-bottom:env(safe-area-inset-bottom,0px);min-height:72px;z-index:50}.member-content{flex:1;padding:var(--space-4);padding-bottom:calc(72px + env(safe-area-inset-bottom,0px) + var(--space-4));overflow-y:auto}.member-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#fff6;font-size:.6875rem;font-weight:500;text-decoration:none;transition:all var(--transition-fast);cursor:pointer;min-width:56px}.member-nav-item:hover{color:#ffffffbf;background:#ffffff0f}.member-nav-item.active{color:#93c5fd;background:#0060d033;border:1px solid rgba(0,96,208,.3)}@media (max-width: 480px){.member-header-logo span{display:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);position:relative}.login-bg{display:none}.login-container{width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:var(--space-6);position:relative;z-index:1}.login-logo{display:flex;align-items:center;justify-content:center}.login-logo-img{height:48px;width:auto;filter:drop-shadow(0 0 12px rgba(255,255,255,.2));mix-blend-mode:screen}.login-card{width:100%;background:#0a0d1ccc;backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.13);box-shadow:0 24px 64px #0000008c;overflow:hidden}.login-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1)}.login-tab{flex:1;padding:var(--space-4);background:transparent;border:none;cursor:pointer;font-family:var(--font-body);font-size:.875rem;font-weight:600;color:#fff6;transition:all var(--transition-fast);letter-spacing:.02em}.login-tab:hover{color:#ffffffb3;background:#ffffff0a}.login-tab.active{color:#93c5fd;background:#0060d01f;border-bottom:2px solid rgba(0,96,208,.7)}.login-form{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.login-form-title{font-size:1.5rem;color:#fffffff2;margin:0}.login-form-sub{font-size:.875rem;color:#ffffff73;margin-top:-var(--space-2)}.input-icon-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:var(--space-3);color:#ffffff59;pointer-events:none;z-index:1}.input-icon-right{position:absolute;right:var(--space-2);background:none;border:none;cursor:pointer;color:#ffffff59;padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--transition-fast)}.input-icon-right:hover{color:#ffffffb3}.input-icon-wrapper .form-input{padding-left:calc(var(--space-3) + 18px + var(--space-2))}.pin-inputs{display:flex;gap:var(--space-3);justify-content:center}.pin-input{width:56px;height:64px;text-align:center;font-size:1.5rem;font-weight:700;font-family:var(--font-mono);background:#ffffff1a;border:1.5px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#fffffff2;outline:none;transition:all var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);letter-spacing:.2em}.pin-input:focus{border-color:#0060d0cc;box-shadow:0 0 0 3px #0060d033;background:#ffffff24}.login-hint{font-size:.8125rem;color:#ffffff4d;text-align:center;font-family:var(--font-mono)}.login-footer{font-size:.8125rem;color:#ffffff40;text-align:center}.dashboard-actions{display:flex;gap:var(--space-3)}.dashboard-charts{margin:var(--space-4) 0}.dashboard-bottom{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-4)}.expiring-list{display:flex;flex-direction:column;gap:2px}.expiring-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);text-decoration:none;color:#fffc;transition:background var(--transition-fast)}.expiring-item:hover{background:#ffffff0f}.expiring-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:#0060d040;color:#93c5fd;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;flex-shrink:0;border:1px solid rgba(0,96,208,.35)}.expiring-info{flex:1}.expiring-name{font-size:.9rem;font-weight:500;color:#ffffffd9}.expiring-date{font-size:.8rem;color:#ffffff73}.payments-list{display:flex;flex-direction:column;gap:2px}.payment-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast)}.payment-item:hover{background:#ffffff0d}.payment-member{font-size:.9rem;font-weight:500;color:#fffc}.payment-amount{font-family:var(--font-mono);font-weight:600;color:#86efac;text-align:right}.attendance-today-list{display:flex;flex-direction:column;gap:2px}.attendance-today-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.9rem;color:#ffffffbf}@media (max-width: 768px){.dashboard-bottom{grid-template-columns:1fr}.dashboard-actions{flex-direction:column}}.payments-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.payments-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1);gap:0;margin-bottom:4px}.payments-tab{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;background:transparent;color:#ffffff73;font-size:.875rem;font-weight:500;cursor:pointer;font-family:var(--font-body);transition:all var(--transition-fast);white-space:nowrap}.payments-tab:hover{color:#ffffffbf;background:#ffffff0d}.payments-tab.active{color:#93c5fd;border-bottom-color:#0060d0cc;font-weight:600;background:transparent}.tab-badge{display:inline-flex;align-items:center;justify-content:center;background:#ef4444bf;color:#fff;font-size:.7rem;font-weight:700;border-radius:99px;padding:1px 6px;min-width:18px;line-height:1.4;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.comprobantes-aviso{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f59e0b26;border:1px solid rgba(245,158,11,.35);border-radius:var(--radius-md);color:#fcd34d;font-size:.875rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.class-types-row{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.class-type-chip{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;border:1.5px solid;background:transparent;color:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.class-type-dot{width:8px;height:8px;border-radius:50%}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.class-card{background:#ffffff14;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.13);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.class-card:hover{box-shadow:var(--shadow-md);border-color:#ffffff38}.class-card.inactive{opacity:.5}.class-card-header{display:flex;align-items:center;justify-content:space-between}.class-type-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.class-card-name{font-family:var(--font-display);font-size:1.25rem;color:#fffffff2}.class-card-meta{display:flex;flex-direction:column;gap:6px}.class-meta-item{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:#ffffff80}.class-capacity-bar{height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.class-capacity-fill{height:100%;border-radius:2px;transition:width var(--transition-base)}.week-nav{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.week-label{font-weight:600;font-size:.9375rem;color:#ffffffd9;flex:1;text-align:center}.schedule-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);overflow:hidden;background:#ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.schedule-day{border-right:1px solid rgba(255,255,255,.08);min-height:400px}.schedule-day:last-child{border-right:none}.schedule-day.today .schedule-day-header{background:#0060d066;border-bottom-color:#0060d080}.schedule-day.today .schedule-day-name,.schedule-day.today .schedule-day-number{color:#93c5fd}.schedule-day-header{padding:var(--space-2) var(--space-3);background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08);text-align:center}.schedule-day-name{font-size:.75rem;font-weight:600;color:#ffffff73;text-transform:uppercase;letter-spacing:.05em}.schedule-day-number{font-family:var(--font-display);font-size:1.5rem;color:#ffffffe6;line-height:1.2}.schedule-day-classes{display:flex;flex-direction:column;gap:4px;padding:var(--space-2)}.schedule-empty{text-align:center;color:#ffffff1f;font-size:1.5rem;padding:var(--space-4)}.schedule-class-item{border-left:3px solid rgba(0,96,208,.7);padding:6px 8px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:#ffffff0f;cursor:pointer;transition:all var(--transition-fast)}.schedule-class-item:hover{background:#0060d02e}.schedule-class-time{font-size:.6875rem;font-weight:700;color:#ffffff73;font-family:var(--font-mono)}.schedule-class-name{font-size:.8125rem;font-weight:600;color:#ffffffe6;margin:2px 0}.schedule-class-trainer{font-size:.6875rem;color:#ffffff73}.schedule-class-cupo{display:flex;align-items:center;gap:3px;font-size:.6875rem;color:#fff6;margin-top:3px;font-family:var(--font-mono)}.schedule-public{min-height:100vh;padding:var(--space-6)}.schedule-public-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.schedule-public-logo{width:48px;height:48px;background:#0060d099;border:1px solid rgba(0,96,208,.45);color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.75rem}.schedule-public-header h1{font-size:2rem;color:#fffffff2}.schedule-public-header p{color:#ffffff80}.schedule-public-container{max-width:1200px;margin:0 auto}@media (max-width: 768px){.schedule-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 480px){.schedule-grid{grid-template-columns:1fr}}.routine-days{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.08)}.routine-day{background:#ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:var(--space-3)}.routine-day-name{font-size:.9375rem;font-weight:600;margin-bottom:var(--space-2);color:#93c5fd}.routine-exercise{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.875rem;color:#ffffffbf}.routine-exercise:last-child{border-bottom:none}.checkin-layout{display:grid;grid-template-columns:420px 1fr;gap:var(--space-4)}.checkin-members-list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4)}.checkin-member-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.12);background:#ffffff0f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;text-align:left;transition:all var(--transition-fast);width:100%;color:#ffffffd9}.checkin-member-btn:hover{border-color:#0060d099;background:#0060d026}.checkin-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;flex-shrink:0}.checkin-result{margin-top:var(--space-4);padding:var(--space-5);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--space-4);animation:slideUp .2s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.checkin-result.success{background:#22c55e26;border:1px solid rgba(34,197,94,.35);color:#86efac}.checkin-result.error{background:#ef444426;border:1px solid rgba(239,68,68,.35);color:#fca5a5}.checkin-result-info h2{font-size:1.25rem;font-family:var(--font-display);color:inherit}.checkin-result-info p{font-size:.9rem;margin-top:4px;opacity:.8}.checkin-history{display:flex;flex-direction:column;gap:2px}.checkin-history-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);color:#ffffffbf}.checkin-history-item:hover{background:#ffffff0d}@media (max-width: 900px){.checkin-layout{grid-template-columns:1fr}}.reports-charts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media (max-width: 1024px){.reports-charts-row{grid-template-columns:1fr}.reports-charts-row .card[style*="span 2"]{grid-column:span 1}}.staff-notice{display:flex;align-items:center;gap:var(--space-2);background:#0060d026;color:#93c5fd;border:1px solid rgba(0,96,208,.35);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:.875rem;margin-bottom:var(--space-4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.roles-legend{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}.role-chip{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.12);background:#ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.role-dot{width:10px;height:10px;border-radius:50%;margin-top:3px;flex-shrink:0}.role-name{font-size:.8125rem;font-weight:700;color:#ffffffd9}.role-desc{font-size:.7rem;color:#ffffff73;margin-top:2px}.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.staff-card{background:#ffffff12;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.staff-card:hover{box-shadow:var(--shadow-md);border-color:#ffffff38}.staff-card.inactive{opacity:.45}.staff-card-header{display:flex;align-items:center;gap:var(--space-3)}.staff-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;flex-shrink:0}.staff-info{flex:1;min-width:0}.staff-name{font-weight:700;font-size:1rem;color:#ffffffe6;display:flex;align-items:center;gap:var(--space-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.staff-email{font-size:.8rem;color:#ffffff73}.badge-me{font-size:.65rem;font-weight:700;padding:2px 7px;background:#0060d0b3;color:#fff;border-radius:var(--radius-full);flex-shrink:0}.staff-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.staff-role-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.staff-phone,.staff-created{font-size:.8rem;color:#fff6}.staff-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;padding-top:var(--space-3);border-top:1px solid rgba(255,255,255,.08)}.role-selector{display:flex;flex-direction:column;gap:var(--space-2)}.role-option{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.12);cursor:pointer;background:#ffffff0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-fast);color:#fffc}.role-option:hover{border-color:#0060d080;background:#0060d01a}.role-option.selected{font-weight:600;border-color:#0060d099;background:#0060d02e}.btn-warning{background:#f59e0bbf;color:#fff;border:1px solid rgba(245,158,11,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-warning:hover{background:#f59e0bf2}@media (max-width: 900px){.roles-legend{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.roles-legend,.staff-grid{grid-template-columns:1fr}}.cuotas-page{display:flex;flex-direction:column;gap:20px}.periodo-selector{display:flex;align-items:center;gap:4px;background:#ffffff14;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:4px}.periodo-label{font-size:.9375rem;font-weight:600;color:#ffffffd9;min-width:140px;text-align:center}.cuotas-resumen{display:flex;flex-direction:column;gap:12px}.cuotas-barra{height:10px;border-radius:99px;overflow:hidden;display:flex;background:#ffffff14}.barra-seg{height:100%;transition:width .5s ease}.barra-seg.pagadas{background:var(--color-success)}.barra-seg.enviadas{background:var(--color-info)}.barra-seg.pendientes{background:var(--color-warning)}.barra-seg.vencidas{background:var(--color-danger)}.cuotas-resumen-legend{display:flex;align-items:center;gap:16px;font-size:.8125rem;color:#ffffff8c;flex-wrap:wrap}.leg-item{display:flex;align-items:center;gap:5px}.leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.leg-dot.pagadas{background:var(--color-success)}.leg-dot.enviadas{background:var(--color-info)}.leg-dot.pendientes{background:var(--color-warning)}.leg-dot.vencidas{background:var(--color-danger)}.bulk-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#0060d033;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(0,96,208,.4);border-radius:var(--radius-md);font-size:.875rem;color:#93c5fd;font-weight:600}.selected-row{background:#0060d01f!important}@media (max-width: 768px){.periodo-selector{flex-wrap:nowrap}.periodo-label{min-width:110px;font-size:.875rem}}.pagar-page{min-height:100vh;position:relative;--portal-primary: #2563EB}.pagar-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:linear-gradient(160deg,color-mix(in srgb,var(--portal-primary) 85%,#000),color-mix(in srgb,var(--portal-primary) 50%,#000) 40%,#080d18)}.pagar-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 20%,rgba(255,255,255,.04) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.03) 0%,transparent 50%)}.pagar-content{position:relative;z-index:1;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px 48px}.pagar-container{width:100%;max-width:460px;display:flex;flex-direction:column;gap:16px}.pagar-header{display:flex;align-items:center;gap:12px;margin-bottom:4px}.pagar-logo{width:44px;height:44px;border-radius:12px;background:var(--portal-primary);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px #0000004d;flex-shrink:0}.pagar-org-name{font-family:var(--font-display);font-size:1.25rem;letter-spacing:2px;color:#fff}.pagar-card{background:#fff;border-radius:20px;padding:28px 24px;box-shadow:0 20px 60px #0000004d,0 4px 16px #00000026;display:flex;flex-direction:column;gap:20px}.pagar-saludo{display:flex;flex-direction:column;gap:4px}.pagar-nombre{font-size:1.25rem;font-weight:700;color:var(--color-text);line-height:1.2}.pagar-numero-socio{font-size:.8125rem;color:var(--color-text-muted);font-family:var(--font-mono)}.pagar-concepto{padding:14px 16px;background:var(--color-surface-2);border-radius:var(--radius-md);border-left:3px solid var(--portal-primary, #2563EB)}.pagar-concepto-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-weight:600;margin-bottom:4px}.pagar-concepto-valor{font-size:1rem;font-weight:700;color:var(--color-text-secondary)}.pagar-vencimiento{display:flex;align-items:center;gap:7px;font-size:.875rem;color:var(--color-text-muted);padding:8px 12px;border-radius:var(--radius-md);background:var(--color-surface-2)}.pagar-vencimiento.vencida{background:var(--color-danger-light);color:var(--color-danger);font-weight:600}.pagar-vencimiento.por-vencer{background:var(--color-warning-light);color:var(--color-warning)}.pagar-monto-container{padding:16px;background:var(--color-primary-light);border-radius:var(--radius-lg);border:1px solid rgba(37,99,235,.15)}.pagar-desglose{margin-bottom:10px}.pagar-desglose-row{display:flex;justify-content:space-between;font-size:.875rem;color:var(--color-text-muted);padding:3px 0}.pagar-desglose-row.recargo{color:var(--color-danger)}.pagar-desglose-divider{border:none;border-top:1px solid rgba(37,99,235,.15);margin:8px 0}.pagar-monto-total{display:flex;align-items:center;justify-content:space-between}.pagar-monto-label{font-size:.875rem;font-weight:600;color:var(--color-text-secondary)}.pagar-monto-valor{font-family:var(--font-display);font-size:2.25rem;letter-spacing:1px;color:var(--portal-primary, #2563EB);line-height:1}.pagar-metodos{display:flex;flex-direction:column;gap:10px}.pagar-metodos-title{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.pagar-metodo-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:14px;cursor:pointer;transition:all .15s;text-align:left;width:100%;font-family:inherit}.pagar-metodo-btn:hover{border-color:var(--btn-color, var(--portal-primary));background:var(--color-surface-2);transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.pagar-metodo-btn.selected{border-color:var(--btn-color, var(--portal-primary));background:color-mix(in srgb,var(--btn-color, #2563EB) 6%,white)}.pagar-metodo-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pagar-metodo-info{flex:1;min-width:0}.pagar-metodo-nombre{font-size:.9375rem;font-weight:600;color:var(--color-text-secondary)}.pagar-metodo-desc{font-size:.8125rem;color:var(--color-text-muted);margin-top:2px}.pagar-panel{padding:16px;background:var(--color-surface-2);border-radius:14px;border:1px solid var(--color-border-light);animation:slideUp .2s ease}.btn-pagar-mp{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px;border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;box-shadow:0 4px 16px #009ee34d}.btn-pagar-mp:hover{filter:brightness(1.08);transform:translateY(-1px)}.btn-pagar-mp:disabled{opacity:.65;cursor:not-allowed;transform:none}.spinner-mp{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.pagar-transferencia-info{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}.pagar-field{display:flex;flex-direction:column;gap:3px}.pagar-field-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.pagar-field-valor{font-size:.9375rem;color:var(--color-text-secondary);font-weight:500}.pagar-field-valor.monospace{font-family:var(--font-mono);font-size:.875rem;background:var(--color-surface);padding:6px 10px;border-radius:8px;border:1px solid var(--color-border);word-break:break-all}.pagar-transferencia-aviso{display:flex;align-items:flex-start;gap:7px;padding:10px 12px;background:var(--color-warning-light);border-radius:10px;font-size:.8125rem;color:#92400e;line-height:1.5}.pagar-footer{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.75rem;color:#ffffff59;text-align:center;padding:0 8px}.pagar-footer strong{color:#ffffff8c}.pagar-icon-circle{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center}.pagar-title{font-size:1.375rem;font-weight:700;color:var(--color-text);margin-bottom:8px}.pagar-subtitle{font-size:.9375rem;color:var(--color-text-muted);line-height:1.6}@media (max-width: 480px){.pagar-content{padding:20px 12px 40px}.pagar-card{padding:22px 18px}.pagar-monto-valor{font-size:2rem}}.member-dashboard{display:flex;flex-direction:column;gap:var(--space-4)}.member-welcome{display:flex;align-items:center;justify-content:space-between}.member-welcome-text h2{font-family:var(--font-display);font-size:1.75rem;color:#fffffff2}.member-welcome-text p{font-size:.875rem;color:#ffffff80}.member-socio-badge{display:flex;flex-direction:column;align-items:flex-end;background:#0060d033;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(0,96,208,.35);color:#93c5fd;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:.875rem}.member-membership-card{border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);border:1px solid;transition:all var(--transition-base);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.member-membership-card.active{background:#22c55e26;border-color:#22c55e59;color:#86efac}.member-membership-card.expiring{background:#f59e0b26;border-color:#f59e0b59;color:#fcd34d}.member-membership-card.expired{background:#ef444426;border-color:#ef444459;color:#fca5a5}.member-card-icon{flex-shrink:0}.member-card-info{flex:1}.member-card-plan{font-weight:600;font-size:1rem}.member-card-status{font-size:.875rem;margin-top:2px;opacity:.85}.member-card-classes{font-size:.8125rem;margin-top:4px;opacity:.75}.member-stats-row{display:grid;grid-template-columns:repeat(3,1fr);background:#ffffff12;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.12);overflow:hidden}.member-stat{padding:var(--space-4) var(--space-3);text-align:center;border-right:1px solid rgba(255,255,255,.08)}.member-stat:last-child{border-right:none}.member-stat-value{font-family:var(--font-display);font-size:1.75rem;color:#93c5fd;line-height:1}.member-stat-label{font-size:.6875rem;color:#ffffff73;margin-top:4px;font-weight:500}.member-section{display:flex;flex-direction:column;gap:var(--space-3)}.member-section-title{font-family:var(--font-body);font-size:.9375rem;font-weight:700;color:#ffffffb3;display:flex;align-items:center;gap:var(--space-2)}.member-notifications{display:flex;flex-direction:column;gap:var(--space-2)}.member-notification{display:flex;align-items:flex-start;gap:var(--space-3);background:#ffffff12;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-md);padding:var(--space-3);border:1px solid rgba(255,255,255,.1);color:#fffc}.member-classes-list{display:flex;flex-direction:column;gap:var(--space-2)}.member-class-item{display:flex;align-items:flex-start;gap:var(--space-3);background:#ffffff12;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-md);padding:var(--space-3);border:1px solid rgba(255,255,255,.1);color:#fffc}.member-quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.member-quick-action{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);background:#ffffff12;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-3);border:1px solid rgba(255,255,255,.12);text-decoration:none;color:#ffffffb3;font-size:.8125rem;font-weight:500;text-align:center;transition:all var(--transition-fast)}.member-quick-action:hover{border-color:#0060d080;background:#0060d026;color:#93c5fd;box-shadow:var(--shadow-md)}.member-qa-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}:root{--color-bg: transparent;--color-surface: rgba(255,255,255,.1);--color-surface-2: rgba(255,255,255,.07);--color-primary: #0060D0;--color-primary-dark: #004DB3;--color-primary-light: rgba(0,96,208,.15);--color-text: rgba(255,255,255,1);--color-text-secondary: rgba(255,255,255,.92);--color-text-muted: rgba(255,255,255,.72);--color-text-faint: rgba(255,255,255,.5);--color-border: rgba(255,255,255,.18);--color-border-light: rgba(255,255,255,.1);--color-success: #22c55e;--color-success-light: rgba(34,197,94,.15);--color-warning: #f59e0b;--color-warning-light: rgba(245,158,11,.15);--color-danger: #ef4444;--color-danger-light: rgba(239,68,68,.15);--color-info: #38bdf8;--color-info-light: rgba(56,189,248,.15);--font-display: "Montserrat", sans-serif;--font-body: "Montserrat", sans-serif;--font-mono: "DM Mono", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0,0,0,.25);--shadow-md: 0 4px 16px rgba(0,0,0,.3);--shadow-lg: 0 8px 32px rgba(0,0,0,.35);--shadow-xl: 0 20px 60px rgba(0,0,0,.45);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 256px;--sidebar-collapsed-width: 72px;--header-height: 64px;--glass-bg: rgba(255,255,255,.1);--glass-bg-dark: rgba(10,10,20,.85);--glass-border: rgba(255,255,255,.18);--glass-blur: blur(16px);--glass-blur-heavy: blur(32px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:17px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text);line-height:1.5;min-height:100vh;background-image:url(https://images.unsplash.com/photo-1534438327276-14e5300c3a48?w=1920&q=80);background-size:cover;background-position:center;background-attachment:fixed;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:0;pointer-events:none}#root{min-height:100vh;position:relative;z-index:1}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-text);letter-spacing:.02em;text-shadow:0 1px 8px rgba(0,0,0,.4)}h1{font-size:2.4rem}h2{font-size:1.9rem}h3{font-size:1.45rem}h4{font-size:1.2rem}h5{font-size:1.05rem}p{line-height:1.6;color:var(--color-text-secondary);text-shadow:0 1px 4px rgba(0,0,0,.3)}a{color:var(--color-info);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:#7dd3fc}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-decoration:none;letter-spacing:.01em}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#0060d0d9;color:#fff;border:1px solid rgba(0,96,208,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-shadow:0 1px 3px rgba(0,0,0,.3)}.btn-primary:hover:not(:disabled){background:#0060d0;box-shadow:0 4px 16px #0060d073}.btn-secondary{background:#ffffff24;color:#fffffff2;border:1px solid rgba(255,255,255,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-shadow:0 1px 3px rgba(0,0,0,.3)}.btn-secondary:hover:not(:disabled){background:#ffffff38;border-color:#fff6}.btn-danger{background:#ef4444cc;color:#fff;border:1px solid rgba(239,68,68,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-danger:hover:not(:disabled){background:#ef4444;box-shadow:0 4px 16px #ef444466}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid transparent}.btn-ghost:hover:not(:disabled){background:#ffffff1a;color:var(--color-text);border-color:#ffffff2e}.btn-success{background:#22c55ecc;color:#fff;border:1px solid rgba(34,197,94,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-success:hover:not(:disabled){background:#22c55e;box-shadow:0 4px 16px #22c55e66}.btn-sm{padding:var(--space-1) var(--space-3);font-size:.8125rem}.btn-lg{padding:var(--space-3) var(--space-6);font-size:1rem}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md);background:transparent;border:1px solid transparent;cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:#ffffff1f;color:var(--color-text);border-color:#ffffff2e}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-label{font-size:.875rem;font-weight:600;color:#fffc;text-shadow:0 1px 4px rgba(0,0,0,.3)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);border:1.5px solid rgba(255,255,255,.22);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.9375rem;color:#fffffff2;background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#0060d0cc;box-shadow:0 0 0 3px #0060d038;background:#ffffff29}.form-input::placeholder{color:#ffffff6b}.form-select option{background:#1a1f2e;color:#fff}.form-textarea{resize:vertical;min-height:100px}.form-error{font-size:.8125rem;color:#fca5a5}.card{background:#ffffff1a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.18);padding:var(--space-6);box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-family:var(--font-display);font-size:1.25rem;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.35)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:700;letter-spacing:.02em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.badge-success{background:#22c55e40;color:#a7f3c0;border:1px solid rgba(34,197,94,.4)}.badge-danger{background:#ef444440;color:#fecaca;border:1px solid rgba(239,68,68,.4)}.badge-warning{background:#f59e0b40;color:#fde68a;border:1px solid rgba(245,158,11,.4)}.badge-info{background:#38bdf840;color:#bae6fd;border:1px solid rgba(56,189,248,.4)}.badge-primary{background:#0060d04d;color:#bfdbfe;border:1px solid rgba(0,96,208,.5)}.badge-neutral{background:#ffffff1f;color:#ffffffb3;border:1px solid rgba(255,255,255,.2)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.14);background:#ffffff0f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.table{width:100%;border-collapse:collapse;font-size:.9375rem}.table th{background:#ffffff12;color:#ffffffb3;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(255,255,255,.07);color:#ffffffe6;vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#ffffff0f}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--space-12);color:#ffffff8c;flex-direction:column;gap:var(--space-3)}.spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.18);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;color:#ffffff80;gap:var(--space-3)}.empty-state-icon{width:56px;height:56px;background:#ffffff1a;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#ffffff73;margin-bottom:var(--space-2);border:1px solid rgba(255,255,255,.15)}.empty-state h3{font-size:1rem;font-weight:600;color:#ffffffb3}.empty-state p{font-size:.875rem;max-width:300px;color:#ffffff80}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn var(--transition-fast)}.modal{background:#0a0d1cf2;backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);border:1px solid rgba(255,255,255,.14);animation:slideUp var(--transition-base)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.modal-title{font-family:var(--font-display);font-size:1.5rem;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.35)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:#ffffff8c}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#ffffff08}::-webkit-scrollbar-thumb{background:#ffffff38;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff59}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input-wrapper .search-icon{position:absolute;left:var(--space-3);color:#ffffff73;pointer-events:none}.search-input-wrapper .form-input{padding-left:calc(var(--space-3) + 20px + var(--space-2))}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.stat-card{background:#ffffff1a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-2)}.stat-value{font-family:var(--font-display);font-size:2rem;line-height:1;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.4)}.stat-label{font-size:.8125rem;color:#ffffffa6;font-weight:500}.stat-change{font-size:.8125rem;font-weight:700;display:flex;align-items:center;gap:4px}.stat-change.positive{color:#86efac}.stat-change.negative{color:#fca5a5}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.page-title{font-size:2rem;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.45)}.page-subtitle{font-family:var(--font-body);font-size:.9375rem;color:#ffffff9e;font-weight:400}.btn-back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.875rem;font-weight:600;color:#ffffffb8;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);margin-bottom:var(--space-4)}.btn-back:hover{background:#ffffff2e;color:#fff;border-color:#ffffff4d}.filter-bar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.status-activo{color:#86efac;font-weight:600}.status-vencido{color:#fca5a5;font-weight:600}.status-suspendido{color:#fde68a;font-weight:600}.status-baja{color:#ffffff80}.status-congelado{color:#bae6fd;font-weight:600}@media (max-width: 768px){html{font-size:16px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.filter-bar{flex-direction:column;align-items:stretch}}
