@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Bebas+Neue&display=swap');
:root{
  --blue:#1a56db;--blue-dark:#1040b0;--black:#0d0d12;--dark:#14141f;
  --card:#1c1c2a;--card2:#23233a;--border:#2e2e48;--white:#f8f9ff;
  --muted:#8888aa;--green:#22c55e;--orange:#f59e0b;--red:#ef4444;
  --yellow:#facc15;--purple:#9333ea;--teal:#0d9488;
  --radius:14px;--shadow:0 4px 24px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:'Space Grotesk',sans-serif;background:var(--black);color:var(--white);min-height:100vh;font-size:17px}
#topbar{background:var(--dark);border-bottom:1px solid var(--border);padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:100}
.brand{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:2px;line-height:1}
.brand span{color:var(--blue)}
.top-right{display:flex;align-items:center;gap:8px}
.today-badge{background:var(--blue);color:#fff;font-size:13px;font-weight:600;padding:4px 11px;border-radius:20px}
.logout-btn{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:#ff9090;font-size:13px;font-weight:700;padding:6px 13px;border-radius:8px;cursor:pointer}
.sticky-banners{position:sticky;top:60px;z-index:90}
.banner{padding:11px 16px;text-align:center;font-size:14px;font-weight:600;cursor:pointer;animation:pulse-bg 2s infinite}
.banner-alert{background:linear-gradient(135deg,#7c2d12,#9a3412);border-bottom:2px solid #f97316;color:#fff}
.banner-dues{background:linear-gradient(135deg,#14532d,#166534);border-bottom:2px solid var(--green);color:#fff;animation:none}
.banner-repair{background:linear-gradient(135deg,#1e1b4b,#312e81);border-bottom:2px solid var(--purple);color:#c4b5fd;animation:none}
@keyframes pulse-bg{0%,100%{opacity:1}50%{opacity:.85}}
.bc{background:rgba(255,255,255,.25);border-radius:20px;padding:2px 9px;font-size:12px;margin-left:6px}
#nav{display:flex;background:var(--dark);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none}
#nav::-webkit-scrollbar{display:none}
.nav-tab{flex:0 0 auto;padding:13px 15px;font-size:14px;font-weight:600;color:var(--muted);border-bottom:2.5px solid transparent;cursor:pointer;white-space:nowrap;transition:all .2s;position:relative}
.nav-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.nav-tab:hover:not(.active){color:var(--white)}
.nav-tab .dot{position:absolute;top:8px;right:5px;background:var(--red);border-radius:50%;width:8px;height:8px;display:none}
.nav-tab .dot.green{background:var(--green)}
.page{display:none;padding:16px}
.page.active{display:block}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:13px}
.card-title{font-size:12px;font-weight:700;letter-spacing:1px;color:var(--muted);text-transform:uppercase;margin-bottom:12px}
.card-dues{border-color:rgba(34,197,94,.25);background:rgba(20,83,45,.08)}
.card-red{border-color:rgba(239,68,68,.3)}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:13px}
.stat-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:9px;margin-bottom:13px}
.stat-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center}
.stat-box .num{font-family:'Bebas Neue',sans-serif;font-size:36px;color:var(--blue);line-height:1}
.stat-box .lbl{font-size:13px;color:var(--muted);margin-top:4px;font-weight:500}
.stat-box.s-green{border-color:rgba(34,197,94,.3)}.stat-box.s-green .num{color:var(--green)}
.stat-box.s-red{border-color:rgba(239,68,68,.35)}.stat-box.s-red .num{color:var(--red)}
.stat-box.s-orange{border-color:rgba(245,158,11,.3)}.stat-box.s-orange .num{color:var(--orange)}
.stat-box.s-purple{border-color:rgba(147,51,234,.3)}.stat-box.s-purple .num{color:var(--purple)}
.stat-box.s-teal{border-color:rgba(13,148,136,.3)}.stat-box.s-teal .num{color:var(--teal)}
.form-group{margin-bottom:13px}
label{display:block;font-size:14px;font-weight:600;color:var(--muted);margin-bottom:6px}
input,select,textarea{width:100%;background:var(--card2);border:1px solid var(--border);border-radius:10px;color:var(--white);font-family:'Space Grotesk',sans-serif;font-size:16px;padding:13px 14px;outline:none;transition:border .2s}
input:focus,select:focus,textarea:focus{border-color:var(--blue)}
input[type="date"],input[type="time"]{color-scheme:dark}
select option{background:var(--card2)}
textarea{resize:vertical;min-height:72px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:13px 20px;border-radius:10px;font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;border:none;cursor:pointer;transition:all .15s}
.btn:active{transform:scale(.97)}
.btn-w{width:100%}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark)}
.btn-green{background:var(--green);color:#fff}
.btn-red{background:var(--red);color:#fff}
.btn-orange{background:var(--orange);color:#fff}
.btn-purple{background:var(--purple);color:#fff}
.btn-teal{background:var(--teal);color:#fff}
.btn-sm{padding:9px 14px;font-size:13px;border-radius:8px}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--white)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-blue-o{background:transparent;border:1.5px solid var(--blue);color:var(--blue)}
.btn-red-o{background:transparent;border:1.5px solid var(--red);color:var(--red)}
.btn-green-o{background:transparent;border:1.5px solid var(--green);color:var(--green)}
.btn-purple-o{background:transparent;border:1.5px solid var(--purple);color:var(--purple)}
.btn-row{display:flex;gap:8px;flex-wrap:wrap}
.badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.3px;text-transform:uppercase}
.bw{background:rgba(245,158,11,.18);color:var(--orange)}
.br{background:rgba(26,86,219,.18);color:#6b9fff}
.bd{background:rgba(34,197,94,.18);color:var(--green)}
.bc-red{background:rgba(239,68,68,.18);color:var(--red)}
.bdep{background:rgba(239,68,68,.25);color:#ff7070;border:1px solid rgba(239,68,68,.4)}
.bpurple{background:rgba(147,51,234,.18);color:#c084fc}
.bteal{background:rgba(13,148,136,.18);color:#5eead4}
.byellow{background:rgba(250,204,21,.15);color:var(--yellow)}
.bfree{background:rgba(34,197,94,.15);color:var(--green);border:1px solid rgba(34,197,94,.3)}
.dcard{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:11px}
.dcard.dep-card{border-color:rgba(239,68,68,.45);box-shadow:0 0 0 1px rgba(239,68,68,.15)}
.dcard.repair-card{border-color:rgba(147,51,234,.4)}
.dcard.alert-card{border-color:#f97316;box-shadow:0 0 10px rgba(249,115,22,.18)}
.dcard.tmrw-card{border-color:var(--yellow)}
.dc-h{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:9px}
.dc-name{font-size:18px;font-weight:700}
.dc-info{font-size:15px;color:var(--muted);margin-bottom:4px}
.dc-info strong{color:var(--white)}
.dc-actions{display:flex;gap:7px;margin-top:11px;flex-wrap:wrap}
.dep-warn{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:9px;padding:10px 13px;margin:8px 0;display:flex;align-items:center;gap:9px;font-size:14px;color:#ff9090;font-weight:600}
.info-box{background:var(--card2);border:1px solid var(--border);border-radius:9px;padding:10px 13px;margin:8px 0;font-size:14px;color:var(--muted)}
.info-box.green{border-color:rgba(34,197,94,.3);color:var(--green)}
.info-box.red{border-color:rgba(239,68,68,.3);color:#ff9090}
.info-box.purple{border-color:rgba(147,51,234,.3);color:#c084fc}
.pill{display:inline-flex;align-items:center;gap:5px;border-radius:20px;padding:4px 11px;font-size:13px;font-weight:700}
.pill-due{background:rgba(239,68,68,.13);border:1px solid rgba(239,68,68,.35);color:#ff9090}
.pill-paid{background:rgba(34,197,94,.13);border:1px solid rgba(34,197,94,.3);color:var(--green)}
.date-pill{display:inline-flex;align-items:center;gap:5px;background:var(--card2);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:14px;font-weight:600;margin-bottom:7px}
.date-pill.dp-today{background:rgba(249,115,22,.13);border-color:#f97316;color:#f97316}
.date-pill.dp-tmrw{background:rgba(250,204,21,.1);border-color:var(--yellow);color:var(--yellow)}
.sec-banner{border-radius:var(--radius);padding:13px 15px;margin-bottom:10px;font-size:15px;font-weight:600;display:flex;align-items:center;gap:10px}
.sb-orange{background:rgba(249,115,22,.13);border:1px solid rgba(249,115,22,.4);color:#f97316}
.sb-yellow{background:rgba(250,204,21,.09);border:1px solid rgba(250,204,21,.3);color:var(--yellow)}
.sb-blue{background:rgba(26,86,219,.13);border:1px solid rgba(26,86,219,.3);color:#6b9fff}
.rule-box{background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.22);border-radius:9px;padding:13px;margin-bottom:15px;font-size:14px;line-height:1.7;color:#ffaaaa}
.rule-box strong{color:#ff8080;display:block;margin-bottom:4px}
.filter-bar{display:flex;gap:8px;margin-bottom:13px;flex-wrap:wrap}
.filter-bar input,.filter-bar select{flex:1;min-width:110px}
.date-filter{display:flex;gap:8px;margin-bottom:13px;align-items:center;flex-wrap:wrap}
.date-filter label{margin:0;font-size:14px;white-space:nowrap}
.date-filter input{flex:1;min-width:120px}
.divider{border:none;border-top:1px solid var(--border);margin:14px 0}
.tr{display:flex;justify-content:space-between;align-items:center;background:var(--card2);border-radius:9px;padding:13px 15px;margin-top:8px}
.tr .tl{font-size:15px;color:var(--muted)}
.tr .tv{font-size:19px;font-weight:700;color:var(--blue)}
.top-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:15px}
.top-item:last-child{border-bottom:none}
.top-item .rank{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--blue);width:30px}
.top-item .nm{flex:1;font-weight:500}
.top-item .vl{font-weight:700;color:var(--green);font-size:14px}
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:13px}
.section-head h2{font-size:20px;font-weight:700}
.tab-switch{display:flex;background:var(--card2);border-radius:9px;padding:3px;margin-bottom:14px;gap:2px}
.tab-switch button{flex:1;padding:9px;border:none;border-radius:7px;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;color:var(--muted);background:transparent;cursor:pointer;transition:all .2s}
.tab-switch button.active{background:var(--blue);color:#fff}
.avance-sec{background:rgba(147,51,234,.07);border:1px solid rgba(147,51,234,.2);border-radius:9px;padding:13px;margin-bottom:13px}
.avance-sec label{color:#c084fc}
.gains-card{background:var(--card2);border:1px solid var(--border);border-radius:11px;padding:15px;margin-top:10px}
.gr{display:flex;justify-content:space-between;align-items:center;font-size:15px;padding:7px 0;border-bottom:1px solid var(--border)}
.gr:last-child{border-bottom:none}
.gr .gk{color:var(--muted)}
.gr .gv{font-weight:700}
.gains-total{background:rgba(239,68,68,.09);border:1px solid rgba(239,68,68,.28);border-radius:8px;padding:11px 14px;display:flex;justify-content:space-between;align-items:center;margin-top:9px;font-size:15px;font-weight:700}
.gains-total .ga{color:var(--red);font-family:'Bebas Neue',sans-serif;font-size:26px}
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:400;overflow-y:auto;padding:16px}
#modal-overlay.active{display:flex;align-items:flex-start;justify-content:center}
#modal-box{background:var(--dark);border:1px solid var(--border);border-radius:var(--radius);padding:20px;width:100%;max-width:500px;margin:auto}
#modal-box h3{font-size:20px;font-weight:700;margin-bottom:16px}
#toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--blue);color:#fff;font-weight:600;font-size:15px;padding:12px 24px;border-radius:30px;z-index:600;transition:transform .3s;white-space:nowrap;box-shadow:var(--shadow)}
#toast.show{transform:translateX(-50%) translateY(0)}
#toast.terror{background:var(--red)}
#toast.tsuccess{background:var(--green)}
.loading-spin{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:380px){.stat-box .num{font-size:28px}.form-row{grid-template-columns:1fr}.btn-sm{font-size:12px;padding:8px 11px}}
@media print{body>*:not(#recu-overlay){display:none!important}#recu-overlay{display:block!important;position:static!important;background:white!important}}
