@import"https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@700;800;900&family=Barlow:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #e8441a;--accent: #ff6b35;--bg: #0f0f0f;--surface: #1a1a1a;--text: #f0f0f0;--muted: #9ca3af;--radius: 12px;--transition: .2s ease}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:Barlow,sans-serif;-webkit-font-smoothing:antialiased}.app{max-width:430px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative;overflow-x:hidden}.header{background:var(--surface);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--primary);position:sticky;top:0;z-index:100}.header-gym{display:flex;align-items:center;gap:10px}.header-logo{font-size:26px;line-height:1}.header-name{font-family:Barlow Condensed,sans-serif;font-weight:900;font-size:18px;letter-spacing:1px;color:var(--primary);line-height:1}.header-slogan{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:1px}.header-role{font-size:11px;background:color-mix(in srgb,var(--primary) 15%,transparent);color:var(--primary);padding:4px 10px;border-radius:20px;border:1px solid color-mix(in srgb,var(--primary) 30%,transparent);font-weight:600;letter-spacing:1px}.nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;background:var(--surface);border-top:1px solid #2a2a2a;display:flex;z-index:100;box-sizing:border-box;padding-bottom:env(safe-area-inset-bottom,0px)}.nav-item{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;padding:10px 2px 8px;gap:3px;cursor:pointer;transition:var(--transition);border:none;background:transparent;color:var(--muted)}.nav-item.active{color:var(--primary)}.nav-label{font-size:10px;font-weight:600;letter-spacing:.5px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content{padding:18px 16px 90px}.card{background:var(--surface);border-radius:var(--radius);border:1px solid #2a2a2a;overflow:hidden}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.stat-card{background:var(--surface);border-radius:var(--radius);padding:16px;border:1px solid #2a2a2a;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary)}.stat-num{font-family:Barlow Condensed,sans-serif;font-size:34px;font-weight:900;color:var(--primary);line-height:1}.stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}.stat-sub{font-size:12px;color:var(--text);margin-top:5px}.section-title{font-family:Barlow Condensed,sans-serif;font-weight:800;font-size:17px;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.section-title span{color:var(--muted);font-size:13px;font-weight:400;text-transform:none;letter-spacing:0}.alert-band{background:color-mix(in srgb,var(--primary) 8%,transparent);border:1px solid color-mix(in srgb,var(--primary) 25%,transparent);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:10px}.alert-text{font-size:13px}.alert-text strong{color:var(--accent)}.socio-item{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid #222;cursor:pointer;transition:background var(--transition)}.socio-item:last-child{border-bottom:none}.socio-item:active{background:#ffffff08}.avatar{width:40px;height:40px;border-radius:10px;background:color-mix(in srgb,var(--primary) 15%,transparent);border:1.5px solid color-mix(in srgb,var(--primary) 30%,transparent);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-weight:800;font-size:13px;color:var(--primary);flex-shrink:0}.socio-info{flex:1;min-width:0}.socio-nombre{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.socio-plan{font-size:12px;color:var(--muted);margin-top:1px}.badge{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.badge-activo{background:#22c55e22;color:#4ade80;border:1px solid #22c55e44}.badge-vencido{background:#ef444422;color:#f87171;border:1px solid #ef444444}.badge-inactivo{background:#71717a22;color:#a1a1aa;border:1px solid #71717a44}.badge-suspendido{background:#f59e0b22;color:#fbbf24;border:1px solid #f59e0b44}.search-bar{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid #2a2a2a;border-radius:var(--radius);padding:10px 14px;margin-bottom:12px}.search-bar input{background:transparent;border:none;outline:none;color:var(--text);font-family:Barlow,sans-serif;font-size:15px;flex:1}.search-bar input::placeholder{color:var(--muted)}.fab{position:fixed;bottom:80px;right:calc(50% - 199px);width:52px;height:52px;border-radius:14px;background:var(--primary);border:none;color:#fff;font-size:26px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px color-mix(in srgb,var(--primary) 40%,transparent);z-index:50;transition:transform var(--transition)}.fab:active{transform:scale(.93)}.pago-item{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid #222}.pago-item:last-child{border-bottom:none}.pago-monto{font-family:Barlow Condensed,sans-serif;font-size:22px;font-weight:800;color:var(--primary)}.pago-info{font-size:12px;color:var(--muted);margin-top:2px}.log-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid #1e1e1e;align-items:flex-start}.log-item:last-child{border-bottom:none}.total-bar{background:color-mix(in srgb,var(--primary) 8%,transparent);border:1px solid color-mix(in srgb,var(--primary) 20%,transparent);border-radius:var(--radius);padding:16px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}.total-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.total-amount{font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:900;color:var(--primary)}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.chip{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;white-space:nowrap;border:1px solid #333;background:transparent;color:var(--muted);transition:var(--transition);flex-shrink:0}.chip.active{background:color-mix(in srgb,var(--primary) 15%,transparent);color:var(--primary);border-color:color-mix(in srgb,var(--primary) 40%,transparent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;z-index:200;display:flex;align-items:flex-end;justify-content:center}.modal{background:var(--surface);border-radius:20px 20px 0 0;padding:24px 20px 44px;width:100%;max-width:430px;max-height:88vh;overflow-y:auto;animation:slideUp .22s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{width:40px;height:4px;background:#444;border-radius:2px;margin:0 auto 20px}.modal-title{font-family:Barlow Condensed,sans-serif;font-weight:900;font-size:22px;letter-spacing:1px;margin-bottom:20px}.form-group{margin-bottom:14px}.form-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;display:block}.form-input{width:100%;background:#111;border:1px solid #333;border-radius:10px;padding:11px 14px;color:var(--text);font-family:Barlow,sans-serif;font-size:15px;outline:none;transition:border-color var(--transition)}.form-input:focus{border-color:var(--primary)}.form-select{width:100%;background:#111;border:1px solid #333;border-radius:10px;padding:11px 14px;color:var(--text);font-family:Barlow,sans-serif;font-size:15px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;border-radius:12px;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:none;transition:var(--transition)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:not(:disabled):active{opacity:.85;transform:scale(.98)}.btn-ghost{background:transparent;color:var(--muted);border:1px solid #333;margin-top:8px}@media print{.no-print{display:none!important}body{background:#fff;color:#000}body.printing *{visibility:hidden}body.printing .print-area,body.printing .print-area *{visibility:visible}body.printing .print-area{position:absolute;left:0;top:0;width:100%}body.printing .no-print{display:none!important}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 500px){html{background:#060606;min-height:100%}body{background:transparent;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 700px 500px at 15% 25%,rgba(232,68,26,.13) 0%,transparent 65%),radial-gradient(ellipse 600px 600px at 85% 75%,rgba(255,107,53,.09) 0%,transparent 65%),radial-gradient(ellipse 450px 350px at 60% 5%,rgba(180,40,0,.06) 0%,transparent 60%);animation:gymFoco 14s ease-in-out infinite alternate}@keyframes gymFoco{0%{opacity:.55;transform:scale(1) translate(0)}45%{opacity:1;transform:scale(1.07) translate(25px,-20px)}to{opacity:.65;transform:scale(.96) translate(-18px,22px)}}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:repeating-linear-gradient(-55deg,rgba(255,255,255,.009) 0px,rgba(255,255,255,.009) 1px,transparent 1px,transparent 44px)}#root{position:relative;z-index:1}.app{box-shadow:0 0 0 1px #ffffff0a,0 0 80px #000000f5,0 0 180px #e8441a12}}
