/* ===================== Seu Condo — Painel Desktop ===================== */
:root{
  /* Marca: teal (ações) + navy (sidebar/títulos), alinhado à logomarca */
  --brand:#0d9488; --brand-d:#0f766e; --brand-l:#d5f5ef; --brand-xl:#effbf9;
  --navy:#12354c; --navy-2:#1c4561; --navy-line:#21506e;
  --ink:#0f172a; --ink-2:#334155; --muted:#6b7a8d; --line:#e7ebf0;
  --bg:#f3f6f8; --card:#ffffff;
  --green:#16a34a; --green-l:#dcfce7; --red:#e11d48; --red-l:#ffe4e6;
  --amber:#d97706; --amber-l:#fef3c7; --sky:#0ea5e9; --violet:#7c3aed;
  --radius:14px; --radius-sm:10px;
  --shadow:0 1px 2px rgba(16,42,67,.04),0 2px 8px rgba(16,42,67,.06);
  --shadow-md:0 6px 20px rgba(16,42,67,.10);
  --shadow-lg:0 18px 48px rgba(16,42,67,.22);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:'Inter','Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;color:var(--ink);
  background:var(--bg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
.hidden{display:none !important}
a{color:var(--brand-d);text-decoration:none}
code{background:var(--brand-xl);color:var(--brand-d);padding:2px 7px;border-radius:6px;font-size:.85em;font-weight:600}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cdd6df;border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#b6c1cd;background-clip:padding-box}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid transparent;border-radius:var(--radius-sm);
  padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;background:#fff;color:var(--ink);
  transition:background .15s,border-color .15s,box-shadow .15s,transform .05s;white-space:nowrap}
.btn:active{transform:translateY(.5px)}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 1px 2px rgba(13,148,136,.25)}
.btn-primary:hover{background:var(--brand-d)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink-2)}
.btn-ghost:hover{background:#f7fafc;border-color:#d7dee6}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{filter:brightness(.95)}
.btn-sm{padding:6px 12px;font-size:13px;border-radius:9px}
.btn-block{width:100%;justify-content:center;padding:11px 16px}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn:focus-visible,#nav a:focus-visible,.nav a:focus-visible,.icon-btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.icon-btn{background:none;border:none;font-size:19px;cursor:pointer;color:var(--ink-2);padding:7px 10px;border-radius:9px;line-height:1;transition:background .15s}
.icon-btn:hover{background:#eef2f5}

/* ---------- Login ---------- */
.login-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(1200px 600px at 80% -10%,rgba(13,148,136,.55),transparent 60%),
             linear-gradient(140deg,#12354c 0%,#0f766e 60%,#13b39b 120%)}
.login-card{background:#fff;width:400px;max-width:94vw;padding:38px 34px;border-radius:20px;box-shadow:var(--shadow-lg)}
.login-brand{text-align:center;margin-bottom:26px}
.login-logo{width:60px;height:60px;border-radius:16px;background:#fff;border:1px solid var(--line);padding:7px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;box-shadow:var(--shadow)}
.login-logo img{width:100%;height:100%;object-fit:contain;border-radius:9px}
.login-logo.sm{width:34px;height:34px;border-radius:9px;padding:4px;margin:0;box-shadow:none;border:none;background:rgba(255,255,255,.12)}
.login-brand h1{margin:0;font-size:23px;letter-spacing:-.3px}
.login-brand p{margin:5px 0 0;color:var(--muted);font-size:13px}
#login-form label{display:block;font-weight:600;font-size:13px;color:var(--ink-2);margin-bottom:14px}
#login-form input{width:100%;margin-top:6px;padding:12px 13px;border:1px solid var(--line);border-radius:11px;font-size:14px;transition:border-color .15s,box-shadow .15s}
#login-form input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.login-hint{text-align:center;color:var(--muted);font-size:12px;margin-top:18px}
.form-error{background:var(--red-l);color:#be123c;padding:10px 13px;border-radius:10px;font-size:13px;margin-bottom:14px}
.login-or{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:12px;margin:20px 0 16px}
.login-or::before,.login-or::after{content:"";flex:1;height:1px;background:var(--line)}
.login-or span{padding:0 12px}
.google-btn-wrap{display:flex;justify-content:center;min-height:44px}

/* ---------- App shell ---------- */
.app-shell{display:flex;height:100vh;overflow:hidden}
.sidebar{width:252px;background:linear-gradient(180deg,#12354c,#0f2c40);color:#b9c7d3;display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease}
.sidebar-brand{display:flex;align-items:center;gap:11px;padding:18px 18px;font-weight:800;color:#fff;font-size:16px;letter-spacing:-.2px;border-bottom:1px solid var(--navy-line);white-space:nowrap}
.nav{flex:1;overflow-y:auto;padding:12px 12px}
.nav-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:#7f93a3;margin:16px 12px 6px;font-weight:800}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:#c2d0db;font-weight:500;margin-bottom:3px;cursor:pointer;transition:background .14s,color .14s;position:relative}
.nav a .ic{width:20px;text-align:center;font-size:16px;opacity:.95;flex-shrink:0}
.nav a .lbl{white-space:nowrap;overflow:hidden}
.nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.nav a.active{background:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(13,148,136,.35)}
.nav a.active .ic{opacity:1}
.nav .badge-dot{margin-left:auto;background:var(--red);color:#fff;border-radius:20px;padding:1px 7px;font-size:11px;font-weight:700}
.sidebar-foot{padding:14px 18px;border-top:1px solid var(--navy-line);font-size:12px;white-space:nowrap;overflow:hidden}
.condo-name{color:#e8eef3;font-weight:700}
.sidebar-version{color:#7f93a3;margin-top:2px}
/* Colapso → barra de ícones */
.app-shell.collapsed .sidebar{width:72px}
.app-shell.collapsed .sidebar .nav a{justify-content:center;padding:11px 0}
.app-shell.collapsed .sidebar .nav a .lbl,
.app-shell.collapsed .sidebar .sidebar-brand span,
.app-shell.collapsed .sidebar .sidebar-foot{opacity:0;width:0;visibility:hidden}
.app-shell.collapsed .sidebar .nav-group{text-align:center;font-size:0;margin:12px 0 4px}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{height:64px;background:rgba(255,255,255,.86);backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 22px;flex-shrink:0;z-index:5}
.topbar-title{font-size:18px;font-weight:800;color:var(--navy);letter-spacing:-.2px}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.user-chip{display:flex;align-items:center;gap:9px;padding:5px 6px;border-radius:12px}
.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#13b39b);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:13px}
.user-meta{display:flex;flex-direction:column;line-height:1.2}
.user-name{font-weight:700;font-size:13px}
.user-role{font-size:11px;color:var(--muted)}
.content{flex:1;overflow-y:auto;padding:26px 30px}

/* ---------- Page header ---------- */
.page-head{display:flex;align-items:center;margin-bottom:22px;gap:14px;flex-wrap:wrap}
.page-head h2{margin:0;font-size:21px;font-weight:800;color:var(--navy);letter-spacing:-.3px}
.page-head .sub{color:var(--muted);font-size:13px;margin-top:2px}
.page-head .spacer{flex:1}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:20px 22px}
.card-title{font-weight:800;font-size:15px;margin:0 0 16px;color:var(--navy)}
.grid{display:grid;gap:16px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1180px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}

/* KPI */
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--brand),#13b39b)}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.kpi .lbl{color:var(--muted);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-size:27px;font-weight:800;margin-top:7px;color:var(--navy);letter-spacing:-.5px}
.kpi .delta{font-size:12px;margin-top:5px;font-weight:700}
.kpi .delta.up{color:var(--green)} .kpi .delta.down{color:var(--red)}
.kpi .ic{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--brand-xl);color:var(--brand-d)}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px;min-width:600px}
table.tbl th{text-align:left;padding:13px 16px;background:#f7f9fb;color:var(--muted);font-weight:800;font-size:11.5px;
  text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line);white-space:nowrap}
table.tbl td{padding:13px 16px;border-bottom:1px solid #eef2f5;vertical-align:middle}
table.tbl tr:last-child td{border-bottom:none}
table.tbl tbody tr{transition:background .12s}
table.tbl tbody tr:hover td{background:var(--brand-xl)}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}
.row-actions{display:flex;gap:6px;justify-content:flex-end}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;line-height:1.5}
.badge.green{background:var(--green-l);color:#15803d}
.badge.red{background:var(--red-l);color:#be123c}
.badge.amber{background:var(--amber-l);color:#b45309}
.badge.blue{background:var(--brand-l);color:var(--brand-d)}
.badge.gray{background:#eef2f5;color:#5b6b7c}
.badge.violet{background:#ede9fe;color:#6d28d9}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:22px;flex-wrap:wrap}
.tabs button{background:none;border:none;padding:11px 16px;font-size:14px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:color .14s,border-color .14s}
.tabs button.active{color:var(--brand-d);border-bottom-color:var(--brand)}
.tabs button:hover{color:var(--navy)}

/* ---------- Bars / chart ---------- */
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:11px;font-size:13px}
.bar-row .bl{width:130px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.bar-track{flex:1;background:#eef2f5;border-radius:7px;height:11px;overflow:hidden}
.bar-fill{height:100%;border-radius:7px;background:linear-gradient(90deg,var(--brand),#13b39b)}
.bar-row .bv{width:96px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
.spark{display:flex;align-items:flex-end;gap:8px;height:130px;padding-top:8px}
.spark .col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:4px;height:100%}
.spark .barg{width:46%;background:linear-gradient(var(--brand),#13b39b);border-radius:6px 6px 0 0;min-height:2px;transition:height .3s}
.spark .barg.exp{background:linear-gradient(#f59e0b,#fbbf24)}
.spark .cl{font-size:11px;color:var(--muted)}
.legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-top:10px}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}

/* ---------- Forms / modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(16,42,67,.45);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:fadein .15s}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border-radius:16px;width:520px;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:pop .18s}
@keyframes pop{from{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line);flex-shrink:0}
.modal-head h3{margin:0;font-size:17px;font-weight:800;color:var(--navy)}
.modal-head .icon-btn{margin-left:auto}
.modal-body{padding:22px;flex:1;min-height:0;overflow-y:auto}
.modal-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0;background:#fafbfc;border-radius:0 0 16px 16px}
.field{margin-bottom:15px}
.field label{display:block;font-weight:600;font-size:13px;color:var(--ink-2);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:11px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.field-row{display:flex;gap:12px}.field-row .field{flex:1}

/* ---------- Toast ---------- */
.toast-root{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:80}
.toast{background:var(--navy);color:#fff;padding:13px 18px;border-radius:12px;box-shadow:var(--shadow-lg);font-size:14px;min-width:240px;font-weight:500;animation:slidein .22s}
.toast.ok{background:#15803d}.toast.err{background:#be123c}
@keyframes slidein{from{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}

/* ---------- Misc ---------- */
.empty{text-align:center;color:var(--muted);padding:54px 20px}
.empty .ic{font-size:42px;opacity:.45;margin-bottom:6px}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;margin:54px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.toolbar input,.toolbar select{padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-size:13px;background:#fff}
.toolbar input:focus,.toolbar select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.muted{color:var(--muted)}
.pager{display:flex;align-items:center;justify-content:flex-end;gap:14px;padding:16px 4px 2px}
.list-meta{font-size:12px;color:var(--muted);margin-top:2px}
.avatar-sm{width:30px;height:30px;border-radius:50%;background:var(--brand-l);color:var(--brand-d);font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.detail-grid{display:grid;grid-template-columns:150px 1fr;gap:10px 16px;font-size:14px}
.detail-grid .k{color:var(--muted);font-weight:600}
.feed-item{padding:14px 0;border-bottom:1px solid #eef2f5}
.feed-item:last-child{border-bottom:none}
.feed-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}

/* ---------- Kanban ---------- */
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
@media(max-width:900px){.kanban{grid-template-columns:1fr}}
.kb-col{background:#f7f9fb;border:1px solid var(--line);border-radius:14px;padding:12px;min-height:120px}
.kb-col-head{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-weight:700;font-size:13px}
.kb-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s}
.kb-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.kb-card-title{font-weight:700;font-size:13px;color:var(--navy)}
.kb-card-meta{color:var(--muted);font-size:12px;margin:4px 0 9px}
.kb-card-actions{display:flex;flex-wrap:wrap;gap:6px}
