/* ═══════════════════════════════════════════
   CONTROLE DE CONDOMÍNIO — v5 CSS
   Minimalist · Neutral · Descriptive
   ═══════════════════════════════════════════ */
:root{
  --bg-0:#0f1117;--bg-1:#161822;--bg-2:#1c1f2e;--bg-3:#232738;
  --bg-card:rgba(22,24,34,.85);--bg-card-hover:rgba(28,31,46,.9);
  --bg-input:rgba(255,255,255,.04);--bg-input-focus:rgba(255,255,255,.06);
  --text-1:#e8eaf0;--text-2:rgba(232,234,240,.6);--text-3:rgba(232,234,240,.32);
  --blue:#5b8def;--blue-muted:rgba(91,141,239,.12);
  --amber:#e0a53e;--amber-muted:rgba(224,165,62,.12);
  --teal:#3cc7a6;--teal-muted:rgba(60,199,166,.12);
  --purple:#9b7be8;--purple-muted:rgba(155,123,232,.12);
  --cyan:#5bbcd6;--cyan-muted:rgba(91,188,214,.12);
  --red:#e05555;--red-muted:rgba(224,85,85,.12);
  --green:#5cb874;--green-muted:rgba(92,184,116,.12);
  --neutral:#8891a5;--neutral-muted:rgba(136,145,165,.12);
  --border:rgba(255,255,255,.06);--border-h:rgba(255,255,255,.12);--border-focus:rgba(91,141,239,.4);
  --shadow:0 4px 24px rgba(0,0,0,.35);--shadow-lg:0 8px 40px rgba(0,0,0,.5);
  --r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;--r-full:100px;
  --ease:cubic-bezier(.22,1,.36,1);--t:.2s var(--ease);--t-slow:.4s var(--ease);
  --safe-t:env(safe-area-inset-top,0px);--safe-b:env(safe-area-inset-bottom,0px);
  --safe-l:env(safe-area-inset-left,0px);--safe-r:env(safe-area-inset-right,0px);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg-0);color:var(--text-1);min-height:100dvh;overflow-x:hidden;line-height:1.6;
  padding:var(--safe-t) var(--safe-r) var(--safe-b) var(--safe-l)}

/* Ambient */
.ambient-bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(140px);opacity:.18;animation:orb 25s ease-in-out infinite}
.orb-1{width:500px;height:500px;background:radial-gradient(circle,var(--blue-muted),transparent 70%);top:-10%;left:-5%}
.orb-2{width:400px;height:400px;background:radial-gradient(circle,var(--teal-muted),transparent 70%);bottom:-5%;right:-8%;animation-delay:-10s}
@keyframes orb{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}

/* AUTH */
.view{position:relative;z-index:1}
.auth-container{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:36px 28px;backdrop-filter:blur(16px);animation:fadeUp .5s var(--ease)}
.auth-logo{text-align:center;margin-bottom:30px}
.auth-logo-mark{width:52px;height:52px;margin:0 auto 14px;background:linear-gradient(135deg,var(--blue),var(--teal));border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:900;color:white;letter-spacing:-.02em}
.auth-logo h1{font-size:1.25rem;font-weight:800;color:var(--text-1)}
.auth-logo p{font-size:.75rem;color:var(--text-3);margin-top:4px}
.auth-form h2{font-size:1rem;font-weight:700;margin-bottom:20px;text-align:center;color:var(--text-2)}
.auth-field{margin-bottom:14px}
.auth-field label{display:block;font-size:.68rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.auth-field input{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-1);font-family:inherit;font-size:.9rem;outline:none;transition:all var(--t)}
.auth-field input::placeholder{color:var(--text-3)}.auth-field input:focus{border-color:var(--blue);background:var(--bg-input-focus);box-shadow: 0 0 14px rgba(91,141,239,.25)}
.pass-wrapper{position:relative}.pass-wrapper input{padding-right:44px}
.pass-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:.9rem;color:var(--text-3);cursor:pointer;padding:8px;transition:color var(--t)}.pass-toggle:hover{color:var(--text-1)}

/* Remember me */
.remember-me{display:flex;align-items:center;gap:10px;margin:14px 0 6px;font-size:.82rem;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none}
.remember-me input{display:none}
.remember-check{width:18px;height:18px;border:1.5px solid var(--border-h);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all var(--t);flex-shrink:0}
.remember-me input:checked+.remember-check{background:var(--blue);border-color:var(--blue)}
.remember-me input:checked+.remember-check::after{content:'✓';color:white;font-size:.65rem;font-weight:700}

.auth-error{color:var(--red);font-size:.78rem;text-align:center;min-height:18px;margin-bottom:6px}
.auth-switch{text-align:center;margin-top:16px;font-size:.8rem;color:var(--text-3)}
.auth-switch a{color:var(--blue);text-decoration:none;font-weight:600}.auth-switch a:hover{text-decoration:underline}
.auth-footer{text-align:center;margin-top:18px;font-size:.7rem;color:var(--text-3);max-width:300px}

/* Google Button */
.btn-google{background:white;color:#3c4043;border:1px solid #dadce0;margin-top:8px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:10px}
.btn-google:hover{background:#f8f9fa;border-color:#d2d4d7;transform:translateY(-1px);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.btn-google svg{width:18px;height:18px}

.auth-divider{display:flex;align-items:center;text-align:center;margin:16px 0;color:var(--text-3);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em}
.auth-divider::before,.auth-divider::after{content:'';flex:1;border-bottom:1px solid var(--border);margin:0 10px}
.auth-divider span{padding:0 4px}

/* Verify View */
.verify-icon{font-size:3rem;text-align:center;margin-bottom:18px;animation:fadeUp .5s var(--ease)}
.verify-text{font-size:.88rem;color:var(--text-2);text-align:center;margin-bottom:16px;line-height:1.5}
.verify-email-display{background:var(--bg-input);border:1px solid var(--border);padding:10px;border-radius:var(--r-md);color:var(--blue);font-weight:700;font-size:.9rem;text-align:center;margin-bottom:24px;font-family:monospace}
.verify-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.verify-actions .btn{box-shadow:none}

/* ALERT */
.alert-banner{position:relative;z-index:200;background:rgba(224,165,62,.06);border-bottom:1px solid rgba(224,165,62,.12);display:none}
.alert-banner.show{display:block;animation:slideD .4s var(--ease)}
@keyframes slideD{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.alert-content{max-width:1100px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;gap:10px}
.alert-dot{width:8px;height:8px;border-radius:50%;background:var(--amber);flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.alert-text{flex:1;font-size:.8rem;color:var(--text-2)}.alert-text strong{color:var(--amber)}
.alert-close{background:none;border:none;color:var(--text-3);font-size:.85rem;cursor:pointer;padding:4px 8px;border-radius:var(--r-sm);transition:all var(--t)}.alert-close:hover{background:rgba(255,255,255,.05);color:var(--text-1)}

/* HEADER */
.header{position:sticky;top:0;z-index:100;background:rgba(15,17,23,.85);backdrop-filter:blur(20px) saturate(1.3);-webkit-backdrop-filter:blur(20px) saturate(1.3);border-bottom:1px solid var(--border)}
@media all and (display-mode:standalone){.header{padding-top:var(--safe-t)}}
.header-content{max-width:1100px;margin:0 auto;padding:12px 20px;display:flex;justify-content:space-between;align-items:center;gap:14px}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{width:36px;height:36px;background:linear-gradient(135deg,var(--blue),var(--teal));border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:900;color:white}
.logo h1{font-size:1.05rem;font-weight:800;color:var(--text-1)}
.header-subtitle{font-size:.66rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
.header-subtitle span{color:var(--blue);font-weight:600}
.header-actions{display:flex;align-items:center;gap:6px}
.header-stats{display:flex;gap:5px}
.stat-pill{display:flex;flex-direction:column;align-items:center;padding:4px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);min-width:50px}
.stat-pill.stat-danger{border-color:rgba(224,85,85,.2)}
.stat-label{font-size:.55rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;font-weight:500}
.stat-value{font-size:.85rem;font-weight:700;color:var(--text-1)}
.stat-danger .stat-value{color:var(--red)}
.btn-icon-header{width:34px;height:34px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);font-size:.95rem;color:var(--text-3);cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center}
.btn-icon-header:hover{background:var(--bg-input-focus);border-color:var(--border-h);color:var(--text-1)}

/* CONDO SELECTOR */
.condo-selector{display:flex;align-items:center;gap:6px;padding:3px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow-x:auto;-webkit-overflow-scrolling:touch}
.condo-selector::-webkit-scrollbar{display:none}
.condo-tabs{display:flex;gap:3px;flex:1;overflow-x:auto}
.condo-tab-wrap{display:flex;align-items:center;gap:1px;flex-shrink:0}
.condo-tab{padding:9px 14px;background:transparent;border:1px solid transparent;border-radius:var(--r-md);color:var(--text-3);font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--t);white-space:nowrap}
.condo-tab:hover{color:var(--text-2);background:var(--bg-input)}
.condo-tab.active{background:rgba(91,141,239,.1);border-color:rgba(91,141,239,.2);color:var(--blue)}
.condo-rename{width:24px;height:24px;background:transparent;border:none;border-radius:4px;font-size:.65rem;color:var(--text-3);cursor:pointer;opacity:.3;transition:all var(--t);display:flex;align-items:center;justify-content:center}
.condo-rename:hover{opacity:1;background:var(--bg-input)}
.condo-add{width:34px;height:34px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-2);font-size:1.1rem;cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:inherit}
.condo-add:hover{background:var(--blue-muted);border-color:rgba(91,141,239,.3);color:var(--blue)}

/* TOTAL GERAL */
.total-geral{text-align:center;padding:28px 20px;background:linear-gradient(135deg,rgba(91,141,239,.06),rgba(60,199,166,.04));border:1px solid var(--border);border-radius:var(--r-xl)}
.tg-label{font-size:.72rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.tg-value{font-size:2.2rem;font-weight:900;background:linear-gradient(135deg,var(--text-1),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tg-sub{font-size:.72rem;color:var(--text-3);margin-top:4px}

/* SECTION DIVIDERS */
.section-divider{display:flex;flex-direction:column;gap:3px;padding:4px 0}
.sd-label{font-size:.92rem;font-weight:700;color:var(--text-1)}
.sd-desc{font-size:.72rem;color:var(--text-3)}
.section-actions{display:flex;gap:8px;justify-content:flex-end}

/* MAIN */
.main{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px}

/* DASHBOARD */
.dashboard{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dash-card{display:flex;align-items:center;gap:10px;padding:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);transition:all var(--t)}
.dash-card:hover{border-color:var(--border-h)}
.dash-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot-blue{background:var(--blue)}.dot-amber{background:var(--amber)}.dot-teal{background:var(--teal)}
.dot-purple{background:var(--purple)}.dot-cyan{background:var(--cyan)}.dot-red{background:var(--red)}
.dot-green{background:var(--green)}.dot-neutral{background:var(--neutral)}
.dash-info{display:flex;flex-direction:column;gap:1px}
.dash-label{font-size:.64rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:500}
.dash-value{font-size:1rem;font-weight:700;color:var(--text-1)}

/* HOUSES */
.houses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:10px}
.house-btn{position:relative;display:flex;flex-direction:column;gap:3px;padding:16px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all var(--t);overflow:hidden}
.house-btn::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--neutral);opacity:0;transition:opacity var(--t)}
.house-btn:hover{transform:translateY(-2px);border-color:var(--border-h);box-shadow:var(--shadow)}
.house-btn:hover::before{opacity:1}
.house-btn.has-debt{border-color:rgba(224,85,85,.15)}.house-btn.has-debt::before{background:var(--red);opacity:.6}
.house-btn.all-paid{border-color:rgba(92,184,116,.12)}.house-btn.all-paid::before{background:var(--green);opacity:.5}
.house-name{font-size:.9rem;font-weight:700}
.house-resident{font-size:.72rem;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.house-nif{font-size:.65rem;color:var(--text-3);font-family:monospace}
.house-fees{font-size:.68rem;color:var(--text-3);margin-top:2px}
.house-fees span{color:var(--teal)}
.house-meta{font-size:.65rem;color:var(--text-3);margin-top:4px}
.house-badge{position:absolute;top:8px;right:8px;padding:2px 8px;font-size:.58rem;font-weight:700;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em}
.house-badge.debt{background:var(--red-muted);color:var(--red);border:1px solid rgba(224,85,85,.2)}
.house-badge.paid{background:var(--green-muted);color:var(--green);border:1px solid rgba(92,184,116,.2)}

/* ERROR DOT / PENDÊNCIA DE LEITURA */
.house-error-dot{position:absolute;top:10px;left:10px;width:10px;height:10px;background:var(--red);border-radius:50%;box-shadow:0 0 0 2px var(--bg-1), 0 0 8px var(--red);z-index:2;animation:alert-pulse 1.5s infinite}
@keyframes alert-pulse{0%{transform:scale(.95);box-shadow:0 0 0 0 rgba(224,85,85,.7)}70%{transform:scale(1);box-shadow:0 0 0 6px rgba(224,85,85,0)}100%{transform:scale(.95);box-shadow:0 0 0 0 rgba(224,85,85,0)}}
.house-btn.needs-data{border-color:rgba(224,85,85,.3);background:linear-gradient(135deg,rgba(22,24,34,.85),rgba(224,85,85,.03))}
.house-btn.needs-data .house-name{color:var(--red)}

/* PANEL */
.panel-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.45);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:all var(--t-slow)}.panel-overlay.show{opacity:1;visibility:visible}
.house-panel{position:fixed;top:0;right:0;bottom:0;z-index:310;width:540px;max-width:100vw;background:var(--bg-1);border-left:1px solid var(--border);transform:translateX(100%);transition:transform var(--t-slow);overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}
.house-panel.open{transform:translateX(0)}
@media all and (display-mode:standalone){.house-panel{padding-top:var(--safe-t)}}
.panel-header{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:10px;padding:14px 18px;background:rgba(22,24,34,.92);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.panel-back{width:32px;height:32px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);font-size:1rem;color:var(--text-1);cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center}.panel-back:hover{background:var(--bg-input-focus)}
.panel-title{flex:1}.panel-title h2{font-size:1rem;font-weight:700}
.panel-badge{display:inline-block;padding:2px 8px;margin-top:2px;font-size:.6rem;font-weight:700;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em}
.panel-badge.badge-ok{background:var(--green-muted);color:var(--green)}
.panel-badge.badge-debt{background:var(--red-muted);color:var(--red)}

/* Panel Sections */
.panel-section{padding:14px 18px;border-bottom:1px solid var(--border)}
.ps-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.ps-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ps-title{font-size:.78rem;font-weight:700;color:var(--text-1);flex:1}
.ps-toggle{width:28px;height:28px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t)}.ps-toggle:hover{color:var(--text-1);background:var(--bg-input-focus)}
.ps-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ps-field{display:flex;flex-direction:column;gap:4px}
.ps-field label{font-size:.65rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
.ps-field input{padding:8px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:inherit;font-size:.85rem;outline:none;transition:all var(--t)}
.ps-field input:focus{border-color:var(--border-focus);background:var(--bg-input-focus)}
.ps-body{transition:all var(--t)}.ps-body.hidden{opacity:.25;pointer-events:none}.ps-body.hidden input{filter:blur(5px)}
.ps-inline{display:flex;align-items:center;gap:8px}
.ps-inline input{flex:1;padding:8px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:inherit;font-size:1rem;font-weight:700;outline:none;transition:all var(--t)}
.ps-inline input:focus{border-color:var(--border-focus);background:var(--bg-input-focus)}
.ps-unit{font-size:.75rem;color:var(--text-3);white-space:nowrap}
.ps-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.pstat{padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:2px}
.pstat-label{font-size:.62rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:500}
.pstat-value{font-size:1.05rem;font-weight:700}.pstat-debt{color:var(--red)}.pstat-paid{color:var(--green)}

/* FORM */
.panel-form{display:flex;flex-direction:column;gap:10px}
.pform-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.pform-group{display:flex;flex-direction:column;gap:4px}
.pform-group label{font-size:.65rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
.pform-group input,.pform-group select{padding:8px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:inherit;font-size:.85rem;outline:none;transition:all var(--t)}
.pform-group input::placeholder{color:var(--text-3)}
.pform-group input:focus,.pform-group select:focus{border-color:var(--border-focus);background:var(--bg-input-focus)}
.pform-group select{cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23666' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.pform-group select option{background:var(--bg-1);color:var(--text-1)}

/* METER SECTIONS */
.meter-section{padding:14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}
.ms-bar{position:absolute;top:0;left:0;right:0;height:2px}
.bar-blue{background:var(--blue)}.bar-amber{background:var(--amber)}.bar-purple{background:var(--purple)}
.ms-head{display:flex;justify-content:space-between;align-items:center}
.ms-title{font-size:.78rem;font-weight:700;color:var(--text-2)}
.meter-result{padding:8px 10px;background:rgba(0,0,0,.15);border-radius:var(--r-sm);display:flex;flex-direction:column;gap:3px;justify-content:center}
.mr-line{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-2)}
.mr-line.mr-total{font-weight:700;font-size:.85rem;color:var(--text-1)}
.mr-formula{font-size:.65rem;color:var(--text-3);text-align:center;padding-top:3px;border-top:1px solid var(--border);font-family:monospace}

/* EXTRAS */
.btn-tiny{padding:4px 10px;background:var(--purple-muted);border:1px solid rgba(155,123,232,.25);border-radius:var(--r-sm);color:var(--purple);font-family:inherit;font-size:.68rem;font-weight:600;cursor:pointer;transition:all var(--t)}
.btn-tiny:hover{background:rgba(155,123,232,.2);border-color:var(--purple)}
.extra-item{display:flex;gap:6px;align-items:flex-end;padding:6px;background:rgba(0,0,0,.06);border-radius:var(--r-sm);margin-bottom:5px}
.extra-desc{flex:2;display:flex;flex-direction:column;gap:2px}
.extra-val{flex:1;display:flex;flex-direction:column;gap:2px}
.extra-desc label,.extra-val label{font-size:.58rem;color:var(--text-3);text-transform:uppercase;font-weight:600}
.extra-desc input,.extra-val input{padding:6px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text-1);font-family:inherit;font-size:.8rem;outline:none;transition:all var(--t)}
.extra-desc input:focus,.extra-val input:focus{border-color:var(--border-focus)}
.extra-del{width:26px;height:26px;background:transparent;border:1px solid rgba(224,85,85,.15);border-radius:4px;color:var(--red);font-size:.7rem;cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:1px}
.extra-del:hover{background:var(--red-muted);border-color:var(--red)}
.extras-total{display:flex;justify-content:space-between;font-size:.82rem;font-weight:700;color:var(--purple);padding-top:4px;border-top:1px solid rgba(155,123,232,.1)}

/* GRAND TOTAL */
.grand-total-box{padding:14px;background:rgba(91,141,239,.04);border:1px solid rgba(91,141,239,.1);border-radius:var(--r-md);display:flex;flex-direction:column;gap:5px}
.gt-row{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-2)}.gt-row span:last-child{font-weight:600;color:var(--text-1)}
.gt-sep{height:1px;background:rgba(91,141,239,.15);margin:3px 0}
.gt-final{font-size:1rem;font-weight:800!important}.gt-final span{color:var(--blue)!important}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:var(--r-md);font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--t);white-space:nowrap;outline:none}
.btn-primary{background:linear-gradient(135deg, var(--blue), var(--teal));color:white;box-shadow:0 6px 20px rgba(60,199,166,.3), inset 0 1px 0 rgba(255,255,255,.2); font-weight:800; letter-spacing:.02em; transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1)}
.btn-primary:hover{transform:translateY(-3px) scale(1.02); box-shadow:0 12px 28px rgba(91,141,239,.5), inset 0 1px 0 rgba(255,255,255,.3); filter:brightness(1.15)}
.btn-primary:active{transform:translateY(1px) scale(0.98); box-shadow:0 2px 10px rgba(60,199,166,.3)}
.btn-action{background:linear-gradient(135deg,rgba(91,141,239,.12),rgba(60,199,166,.08));color:var(--blue);border:1px solid rgba(91,141,239,.2);padding:10px 20px;font-weight:700}
.btn-action:hover{background:linear-gradient(135deg,rgba(91,141,239,.2),rgba(60,199,166,.14));border-color:var(--blue)}
.btn-secondary{background:var(--bg-input);color:var(--text-1);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-input-focus);border-color:var(--border-h)}
.btn-outline{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-outline:hover{background:var(--bg-input);color:var(--text-1)}
.btn-danger{background:linear-gradient(135deg,var(--red),#c93d3d);color:white}.btn-danger:hover{filter:brightness(1.1)}
.btn-sm{padding:7px 12px;font-size:.75rem}.btn-lg{padding:13px 20px;font-size:.9rem}.btn-full{width:100%}

/* HISTORY */
.history-list{display:flex;flex-direction:column;gap:8px}
.history-card{padding:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);transition:all var(--t)}.history-card:hover{border-color:var(--border-h)}
.hc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.hc-period{font-size:.82rem;font-weight:700}
.hc-status{padding:2px 8px;font-size:.58rem;font-weight:700;border-radius:var(--r-full);text-transform:uppercase;letter-spacing:.04em}
.hc-status.st-paid{background:var(--green-muted);color:var(--green)}.hc-status.st-debt{background:var(--red-muted);color:var(--red)}
.hc-meters{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px}
.hc-meter{padding:6px 8px;background:rgba(0,0,0,.1);border-radius:var(--r-sm)}
.hc-meter-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;color:var(--text-3)}
.hc-meter.agua .hc-meter-title{color:var(--blue)}.hc-meter.luz .hc-meter-title{color:var(--amber)}
.hc-meter-line{display:flex;justify-content:space-between;font-size:.68rem;color:var(--text-3)}
.hc-meter-line.result{font-weight:600;color:var(--text-1)}
.hc-fixed-charges{display:flex;gap:8px;margin-bottom:6px}
.hc-fixed{padding:4px 8px;background:rgba(91,188,214,.05);border-radius:4px;font-size:.72rem;color:var(--text-2)}
.hc-extras-list{margin-bottom:6px}
.hc-extra-item{display:flex;justify-content:space-between;font-size:.72rem;color:var(--purple);padding:1px 0}
.hc-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--border)}
.hc-total{font-size:.95rem;font-weight:800;color:var(--blue)}
.hc-actions{display:flex;gap:4px}
.hc-btn{width:26px;height:26px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.75rem;cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center}
.hc-btn:hover{background:var(--bg-input-focus)}.hc-btn.del:hover{background:var(--red-muted);border-color:var(--red)}
.hc-btn.pay:hover{background:var(--green-muted);border-color:var(--green)}
.history-empty{display:none;text-align:center;padding:30px 20px;color:var(--text-3);font-size:.82rem}.history-empty.show{display:block}

/* MODALS */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all var(--t-slow)}.modal-overlay.show{opacity:1;visibility:visible}
.modal{background:var(--bg-1);border:1px solid var(--border-h);border-radius:var(--r-xl);max-width:400px;width:92%;transform:scale(.94);transition:transform var(--t-slow)}.modal-overlay.show .modal{transform:scale(1)}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-head h3{font-size:.92rem;font-weight:700}
.modal-close{width:28px;height:28px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t)}.modal-close:hover{color:var(--text-1);background:var(--bg-input-focus)}
.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border)}
.mf-group{margin-bottom:16px}.mf-group label{display:block;font-size:.7rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.mf-group input{width:100%;padding:9px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:inherit;font-size:.88rem;outline:none;transition:all var(--t)}.mf-group input:focus{border-color:var(--border-focus);background:var(--bg-input-focus)}
.mf-divider{height:1px;background:var(--border);margin:16px 0}.mf-danger label{color:var(--red)}
.modal-sm{text-align:center;padding:28px 20px}.modal-sm h3{font-size:1rem;font-weight:700;margin-bottom:6px}.modal-sm p{font-size:.82rem;color:var(--text-2);margin-bottom:18px}
.modal-actions{display:flex;justify-content:center;gap:8px}.modal-actions .btn{min-width:100px}

.toast{position:fixed;bottom:24px;right:24px;z-index:600;display:flex;align-items:center;gap:8px;padding:12px 20px;background:rgba(22,24,34,.95);border:1px solid var(--border-h);border-radius:var(--r-md);box-shadow:var(--shadow-lg);font-size:.82rem;font-weight:500;transform:translateY(100px);opacity:0;transition:all var(--t-slow);pointer-events:none;color:var(--text-1)}
.toast.show{transform:translateY(0);opacity:1;pointer-events:auto}
.footer{position:relative;z-index:1;text-align:center;padding:20px;font-size:.7rem;color:var(--text-3);border-top:1px solid var(--border);margin-top:24px}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.total-geral,.dashboard,.section-divider,.houses-grid,.condo-selector{animation:fadeUp .5s var(--ease) both}
.condo-selector{animation-delay:0s}.total-geral{animation-delay:.03s}.dashboard{animation-delay:.06s}.houses-grid{animation-delay:.1s}
.house-btn{animation:popIn .35s var(--ease) both}

/* Responsive — iPhone 14/15/16 Pro Max */
@media(max-width:960px){.dashboard{grid-template-columns:repeat(3,1fr)}.house-panel{width:100%}}
@media(max-width:600px){
  .main{padding:12px;gap:12px}.dashboard{grid-template-columns:1fr 1fr;gap:6px}.dash-card{padding:10px}
  .dash-value{font-size:.92rem}.houses-grid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:8px}
  .header-stats{display:none}.pform-row{grid-template-columns:1fr}
  .ps-stats,.ps-grid{grid-template-columns:1fr}
  .toast{left:12px;right:12px;bottom:calc(12px + var(--safe-b))}.auth-card{padding:28px 18px}
  .hc-meters{grid-template-columns:1fr}.condo-tab{padding:8px 12px;font-size:.75rem}
  .extra-item{flex-wrap:wrap}.extra-desc{flex:1 1 100%}.extra-val{flex:1 1 45%}
  .tg-value{font-size:1.8rem}
}
@media(max-width:380px){.dashboard{grid-template-columns:1fr}.houses-grid{grid-template-columns:1fr 1fr}}

@supports(padding-top:env(safe-area-inset-top)){
  @media all and (display-mode:standalone){
    body{padding-top:0}
    .header{padding-top:env(safe-area-inset-top)}
    .house-panel .panel-header{padding-top:calc(8px + env(safe-area-inset-top))}
    .auth-container{padding-top:calc(24px + env(safe-area-inset-top))}
    .footer{padding-bottom:calc(20px + env(safe-area-inset-bottom))}
  }
}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.06);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.12)}
