:root{--bg: #020202;--surface: #1a1a1a;--surface2: #1a1a1a;--accent: #a4c136;--accent2: #a4c136;--text: #f0f0f0;--sub: rgba(255,255,255,.55);--border: rgba(255,255,255,.09);--used: #a4c136;--free: rgba(255,255,255,.08);--radius: 12px;--radius-sm:8px;--shadow: 0 8px 32px rgba(0,0,0,.4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow:hidden}.logoLogin{width:150px}.logoDash{width:40px}.logoCarga{width:50px}.splash{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg)}.splash-icon{font-size:3rem;animation:pulse 1.2s ease-in-out infinite}.splash p{color:var(--sub);font-size:.9rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--bg) 0%,var(--surface2) 100%);padding:1.5rem;overflow-y:auto}.login-box{width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:2rem}.login-icon{font-size:3.5rem;display:block;animation:floatY 3s ease-in-out infinite}@keyframes floatY{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.login-logo h1{font-size:2rem;font-weight:800;letter-spacing:.05em;margin:.4rem 0 .2rem;background:linear-gradient(135deg,var(--accent),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-logo p{color:var(--sub);font-size:.88rem}.login-form{background:#ffffff0d;border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.f-label{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);margin-bottom:1rem}.f-input{padding:.7rem .9rem;background:#ffffff12;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;width:100%;transition:border-color .2s,box-shadow .2s}.f-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa26;background:#00d4aa0d}.f-input::placeholder{color:#ffffff38}.f-hint{font-size:.7rem;color:#ffffff59;margin-top:.1rem}.pass-wrap{position:relative}.pass-wrap .f-input{padding-right:2.8rem}.eye-btn{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;color:var(--sub)}.check-row{display:flex;align-items:center;gap:.5rem;font-size:.84rem;color:var(--sub);cursor:pointer;margin-bottom:1.2rem}.check-row input{accent-color:var(--accent)}.error-box{padding:.65rem .9rem;background:#dc35451a;border:1px solid rgba(220,53,69,.3);border-radius:var(--radius-sm);color:#ff6b6b;font-size:.84rem;margin-bottom:1rem}.btn-primary{width:100%;padding:.8rem;border:none;border-radius:var(--radius-sm);background:var(--accent);color:var(--surface);font-weight:800;font-size:1rem;cursor:pointer;transition:opacity .2s,transform .2s;display:flex;align-items:center;justify-content:center}.btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{padding:.6rem 1.2rem;background:#ffffff12;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-ghost:hover{background:#ffffff1f}.app-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.header-left{display:flex;align-items:center;gap:.8rem}.header-icon{font-size:1.8rem}.header-name{font-weight:800;font-size:1rem;color:var(--text)}.header-sub{font-size:.75rem;color:var(--sub)}.logout-btn{background:none;border:none;font-size:1.2rem;color:var(--sub);cursor:pointer;padding:.3rem}.logout-btn:hover{color:#ff6b6b}.bottom-nav{display:flex;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;order:10}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.7rem .5rem;background:none;border:none;cursor:pointer;color:var(--sub);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:color .2s;fill:#fff}.nav-btn span:first-child{font-size:1.3rem}.nav-btn.active{color:var(--accent)!important;fill:var(--accent)!important}.nav-btn:hover{color:var(--text)}.app-content{flex:1;overflow-y:auto;padding:1.2rem;background:var(--bg)}.app-content::-webkit-scrollbar{width:4px}.app-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.scan-result{padding:.8rem 1.2rem;font-size:.88rem;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-shrink:0}.scan-result.success{background:#00d4aa26;color:var(--accent);border-bottom:1px solid rgba(0,212,170,.3)}.scan-result.error{background:#dc35451f;color:#ff6b6b;border-bottom:1px solid rgba(220,53,69,.3)}.result-close{background:none;border:none;cursor:pointer;font-size:1rem;color:inherit;flex-shrink:0}.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem;margin-bottom:1.2rem}.plan-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.2rem}.plan-mes{font-size:1.2rem;font-weight:800;color:var(--accent)}.plan-sub{font-size:.75rem;color:var(--sub)}.refresh-btn{background:#ffffff12;border:1px solid var(--border);border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1rem;color:var(--sub);display:flex;align-items:center;justify-content:center}.refresh-btn:hover{color:var(--accent)}.progress-circle-wrap{position:relative;width:150px;height:150px;margin:0 auto 1.2rem}.progress-circle{width:100%;height:100%;transform:rotate(-90deg)}.pc-track{fill:none;stroke:#ffffff14;stroke-width:10}.pc-fill{fill:none;stroke:var(--accent);stroke-width:10;stroke-linecap:round;transition:stroke-dasharray .6s ease}.pc-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.pc-num{font-size:2.2rem;font-weight:800;color:var(--accent);line-height:1}.pc-label{font-size:.72rem;color:var(--sub)}.plan-stats{display:flex;justify-content:center;gap:0;margin-top:.5rem}.pstat{flex:1;text-align:center;padding:.5rem}.pstat-div{width:1px;background:var(--border);margin:.5rem 0}.pstat-num{display:block;font-size:1.4rem;font-weight:800;color:var(--text)}.pstat-num.used{color:var(--accent)}.pstat-num.free{color:#fff9}.pstat-lbl{font-size:.7rem;color:var(--sub);text-transform:uppercase;letter-spacing:.06em}.section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--sub);margin-bottom:.9rem}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:.6rem;margin-bottom:1.5rem}.slot{border-radius:var(--radius-sm);padding:.65rem .4rem;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:76px;transition:transform .15s;border:2px solid}.slot.free{background:#ffffff0a;border-color:#ffffff14;color:#ffffff40}.slot.used{background:var(--bg);border-color:var(--accent)}.slot:hover{transform:scale(1.04)}.slot-num{font-size:1.1rem;font-weight:800;line-height:1}.slot.used .slot-num{color:var(--accent)}.slot.free .slot-num{color:#ffffff4d}.slot-date{font-size:.65rem;color:var(--accent);font-weight:600}.slot-time{font-size:.62rem;color:var(--sub)}.slot-empty{font-size:.65rem;color:#ffffff2e}.btn-scan-big{width:100%;padding:1.1rem;border:none;border-radius:var(--radius);background:var(--accent);color:var(--surface);font-weight:800;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:opacity .2s,transform .2s;margin-bottom:1rem}.btn-scan-big:hover{opacity:.88;transform:translateY(-1px)}.plan-full-msg{background:#00d4aa14;border:1px solid rgba(0,212,170,.25);border-radius:var(--radius);padding:1.2rem;text-align:center;font-size:.9rem;color:var(--accent);font-weight:600}.empty-plan{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center}.ep-icon{font-size:3rem;margin-bottom:1rem}.empty-plan h2{font-size:1.2rem;margin-bottom:.4rem}.empty-plan p{color:var(--sub);font-size:.88rem;line-height:1.7}.scanner-wrap{display:flex;flex-direction:column;gap:1.2rem;max-width:420px;margin:0 auto}.scanner-header h3{font-size:1.1rem;font-weight:700;margin-bottom:.2rem}.scanner-sub{font-size:.84rem;color:var(--sub)}.scanner-viewport{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;aspect-ratio:1}#qr-reader{border:none!important}#qr-reader video{width:100%!important;height:100%!important;object-fit:cover}#qr-reader__scan_region{border:none!important}#qr-reader__dashboard{display:none!important}.scanner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:center;justify-content:center}.scan-frame{width:220px;height:220px;border-radius:16px;border:3px solid var(--accent);box-shadow:0 0 0 9999px #00000073;animation:scanPulse 2s ease-in-out infinite}@keyframes scanPulse{0%,to{border-color:var(--accent)}50%{border-color:#fff}}.scanner-hint{text-align:center;font-size:.82rem;color:var(--sub)}.scanner-error{text-align:center;padding:2.5rem 1rem;background:var(--surface);border-radius:var(--radius)}.se-icon{font-size:2.5rem;margin-bottom:.8rem}.scanner-error p{color:var(--sub);font-size:.9rem}.scanner-processing{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;background:var(--surface);border-radius:var(--radius);text-align:center}.sp-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.scanner-actions{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center}.history-list{display:flex;flex-direction:column;gap:.7rem}.history-item{display:grid;grid-template-columns:44px 1fr 32px;align-items:center;gap:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.9rem 1rem;transition:border-color .15s}.history-item:hover{border-color:#00d4aa4d}.hi-slot{width:44px;height:44px;border-radius:50%;background:#a4c1361f;border:2px solid rgba(164,193,54,.35);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:800;color:var(--accent)}.hi-fecha{font-size:.92rem;font-weight:700;color:var(--text)}.hi-hora{font-size:.78rem;color:var(--sub)}.hi-check{font-size:1.2rem;text-align:center}.empty-msg{text-align:center;color:var(--sub);padding:3rem 1rem;font-size:.9rem}.app-header{padding-top:max(.9rem,env(safe-area-inset-top))}.bottom-nav{padding-bottom:max(.3rem,env(safe-area-inset-bottom))}.manual-form{display:flex;flex-direction:column;gap:.5rem;background:#ffffff0a;border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem}.manual-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--sub)}.manual-row{display:flex;gap:.5rem}.manual-input{flex:1;padding:.7rem .9rem;background:#ffffff14;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.88rem;font-family:monospace;transition:border-color .2s}.manual-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa26}.manual-input::placeholder{color:#fff3}.manual-btn{width:auto!important;padding:.7rem 1.1rem!important;font-size:1.1rem!important;border-radius:var(--radius-sm)!important}.manual-hint{font-size:.7rem;color:#ffffff4d;font-style:italic}.no-cam-box{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center}.no-cam-icon{font-size:2rem;margin-bottom:.5rem}.no-cam-box p{font-size:.88rem;color:var(--sub)}
