/* ── Design tokens (matches main site) ──────────────────────────────── */
:root{
  --navy:#0f1f3d;
  --navy-2:#1a3461;
  --blue:#0b3d91;
  --blue-2:#2563eb;
  --bg:#f8fafc;
  --bg-alt:#f1f5f9;
  --surface:#fff;
  --text:#0f172a;
  --muted:#64748b;
  --subtle:#94a3b8;
  --line:#e2e8f0;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 1px 3px rgba(15,23,42,.06),0 4px 16px rgba(15,23,42,.07);
  --shadow-lg:0 4px 6px rgba(15,23,42,.04),0 16px 40px rgba(15,23,42,.12);
}

/* ── Reset & base ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:var(--blue);text-decoration:none}

/* ── Header ───────────────────────────────────────────────────────────── */
.topbar-wrap{background:var(--navy);position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.22)}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo{width:48px;height:48px;object-fit:contain;border-radius:8px;mix-blend-mode:screen}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-text .company{font-weight:800;font-size:15px;color:#fff}
.brand-text .slogan{font-size:11px;color:rgba(255,255,255,.5);font-weight:600;margin-top:2px;letter-spacing:.02em}
.header-right{display:flex;align-items:center;gap:6px}
.header-right a{color:rgba(255,255,255,.78);font-weight:600;font-size:.87rem;padding:7px 13px;border-radius:var(--radius-sm);transition:background .15s,color .15s;text-decoration:none}
.header-right a:hover{color:#fff;background:rgba(255,255,255,.1)}
#nav-admin{color:rgba(255,255,255,.78)}

/* user pill */
.pill{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);font-size:.75rem;font-weight:700;letter-spacing:.02em;border:1px solid rgba(255,255,255,.2)}

/* ── Layout ───────────────────────────────────────────────────────────── */
.layout{display:flex;min-height:calc(100vh - 73px)}

/* ── Sidebar ──────────────────────────────────────────────────────────── */
.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);padding:24px 0;display:flex;flex-direction:column;gap:2px}
.nav-group{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--subtle);padding:4px 18px 10px;margin-top:8px}
.nav-group:first-child{margin-top:0}
.nav-link{display:block;padding:9px 18px;color:var(--muted);text-decoration:none;border-left:3px solid transparent;font-size:.9rem;font-weight:600;transition:background .14s,color .14s,border-color .14s}
.nav-link:hover{background:var(--bg);color:var(--blue)}
.nav-link.active{background:#eff6ff;color:var(--blue);border-left-color:var(--blue-2);font-weight:700}

/* ── Main content ─────────────────────────────────────────────────────── */
.content{flex:1;padding:32px 36px;overflow:auto;min-width:0}
.section{display:none}
.section.active{display:block}
.section-header{margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.section-header h2{margin:0 0 5px;font-size:1.4rem;font-weight:800;letter-spacing:-.01em}
.section-header p{margin:0;color:var(--muted);font-size:.9rem}

/* ── Cards ────────────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:18px;box-shadow:var(--shadow)}
.card h3{margin:0 0 14px;font-size:1rem;font-weight:800;color:var(--text)}

/* ── Feature grid (post-login overview) ──────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.feature{border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;background:var(--bg-alt)}
.feature strong{font-size:.95rem;font-weight:800;color:var(--text)}

/* ── Welcome card ────────────────────────────────────────────────────── */
.welcome-user-row{display:flex;align-items:center;gap:14px;margin:0 0 12px}
.welcome-profile-photo{width:80px;height:80px;border-radius:var(--radius-sm);object-fit:cover;background:var(--bg-alt);border:1px solid var(--line)}

/* ── Login form ──────────────────────────────────────────────────────── */
.login-form-compact{max-width:380px}

/* ── Forms (general) ─────────────────────────────────────────────────── */
form{background:transparent;padding:0;border-radius:0}
label{display:block;font-size:.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;margin-top:14px}
label:first-child{margin-top:0}
input[type="text"],input[type="email"],input[type="password"],select,textarea{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:var(--radius-sm);font-size:.92rem;font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;appearance:none}
input[type="text"]:focus,input[type="email"]:focus,input[type="password"]:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue-2);box-shadow:0 0 0 3px rgba(37,99,235,.11)}
input::placeholder,textarea::placeholder{color:#c1cfe2}
textarea{resize:vertical;line-height:1.5;min-height:90px}

.password-wrap{position:relative}
.password-wrap input{padding-right:42px}
.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--subtle);cursor:pointer;font-size:15px;line-height:1;padding:4px}
.pw-toggle:hover{color:var(--blue)}

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 22px;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--blue-2));color:#fff;font-weight:800;font-size:.9rem;border:none;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(11,61,145,.2);transition:filter .16s;text-decoration:none}
.btn:hover{filter:brightness(1.08)}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;padding:9px 20px;border-radius:999px;background:transparent;color:var(--blue);font-weight:700;font-size:.88rem;border:1.5px solid var(--line);transition:background .15s;text-decoration:none;cursor:pointer;font-family:inherit}
.btn-outline:hover{background:var(--bg)}

/* ── Status badges ───────────────────────────────────────────────────── */
.status-badge,.notice-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.status-badge,.notice-badge.normal{background:#eff6ff;color:#1d4ed8}
.notice-badge.low{background:#ecfeff;color:#0369a1}
.notice-badge.high{background:#fee2e2;color:#b91c1c}

/* ── News & notice lists ─────────────────────────────────────────────── */
.news-list,.notice-list{display:grid;gap:10px}
.news-item,.notice-item{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-alt);padding:14px}
.news-meta,.notice-meta{font-size:.78rem;color:var(--subtle);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.news-title,.notice-title{font-weight:700;font-size:.93rem;color:var(--text);margin:0 0 4px}
.notice-body{font-size:.87rem;color:var(--muted);margin-top:6px;line-height:1.6}

/* ── Lease / doc / application lists ────────────────────────────────── */
.lease-list,.application-list,.document-list{display:grid;gap:12px}
.lease-item,.application-item,.document-item{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-alt);padding:16px}
.lease-topline{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.lease-meta{font-size:.84rem;color:var(--muted);margin-top:4px;line-height:1.55}
.lease-money-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.lease-money-grid span{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--subtle)}
.lease-money-grid strong{display:block;font-size:1.1rem;font-weight:800;color:var(--blue);margin-top:2px}
.application-item{display:flex;align-items:center;justify-content:space-between;gap:12px}
.document-item a{font-weight:700;color:var(--blue)}
.document-item a:hover{text-decoration:underline}

/* ── Financials (legacy placeholder classes kept for safety) ─────────── */
.financial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.financial-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-alt);padding:16px}
.financial-card .k{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--subtle)}
.financial-card .v{font-size:1.35rem;font-weight:800;color:var(--blue);margin-top:4px;line-height:1}

/* ── Financials ledger view ───────────────────────────────────────────── */
.fin-header{background:linear-gradient(90deg,var(--navy),var(--navy-2));color:#fff;border-radius:var(--radius);padding:18px 22px;margin-bottom:16px}
.fin-greeting{display:block;font-size:1rem;font-weight:800;margin-bottom:3px}
.fin-detail{font-size:.83rem;color:rgba(255,255,255,.68)}

.fin-top-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}

.fin-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.fin-card-title{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle);margin-bottom:12px}
.fin-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.fin-ytd-badge{font-size:.78rem;font-weight:700;color:var(--blue);background:#eff6ff;padding:3px 10px;border-radius:999px}

.fin-balance-amount{font-size:2rem;font-weight:900;line-height:1;margin-bottom:14px;letter-spacing:-.02em}
.fin-amount-red{color:#dc2626}
.fin-amount-green{color:#16a34a}
.fin-amount-neutral{color:var(--text)}

.fin-breakdown{border-top:1px solid var(--line);padding-top:12px;margin-bottom:16px;display:grid;gap:6px}
.fin-breakdown-row{display:flex;justify-content:space-between;font-size:.88rem}
.fin-breakdown-row .fin-cat{color:var(--muted);text-transform:capitalize}
.fin-breakdown-row .fin-amt{font-weight:700;color:var(--text)}
.fin-breakdown-row.fin-credit .fin-amt{color:#16a34a}
.fin-breakdown-row.fin-total{border-top:1px solid var(--line);padding-top:8px;font-weight:800;font-size:.9rem}
.fin-breakdown-row.fin-total .fin-cat{color:var(--text)}

.fin-actions{display:flex;flex-direction:column;gap:8px}
.fin-btn{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:11px 18px;border-radius:999px;font-weight:800;font-size:.88rem;border:none;cursor:pointer;font-family:inherit;transition:filter .16s}
.fin-btn-primary{background:linear-gradient(90deg,var(--blue),var(--blue-2));color:#fff;box-shadow:0 4px 14px rgba(11,61,145,.2)}
.fin-btn-primary:hover:not(:disabled){filter:brightness(1.08)}
.fin-btn-primary:disabled{opacity:.45;cursor:not-allowed}
.fin-btn-secondary{background:transparent;color:var(--blue);border:1.5px solid var(--line)}
.fin-btn-secondary:hover{background:var(--bg)}

.fin-upcoming-table{width:100%;border-collapse:collapse;font-size:.87rem}
.fin-upcoming-table td{padding:6px 0;vertical-align:top}
.fin-upcoming-table td:last-child{text-align:right;font-weight:700}
.fin-upcoming-total{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:10px;margin-top:6px;font-weight:800;font-size:.9rem}

.fin-filter-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.fin-filter{padding:7px 12px;border:1.5px solid var(--line);border-radius:var(--radius-sm);font-size:.85rem;font-family:inherit;color:var(--text);background:#fff;cursor:pointer}
.fin-filter:focus{outline:none;border-color:var(--blue-2)}

.fin-history-table{width:100%;border-collapse:collapse;font-size:.86rem}
.fin-history-table th{padding:8px 10px;text-align:left;font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--subtle);border-bottom:2px solid var(--line)}
.fin-history-table td{padding:10px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.fin-history-table tr:last-child td{border-bottom:none}
.fin-history-table tr:hover td{background:var(--bg)}
.fin-amount-charge{color:#dc2626;font-weight:700}
.fin-amount-payment{color:#16a34a;font-weight:700}
.fin-cat-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:capitalize;background:var(--bg-alt);color:var(--muted)}
.fin-ref{font-size:.78rem;color:var(--subtle)}

.fin-annual-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.fin-annual-row:last-child{border-bottom:none}
.fin-annual-year{font-weight:800}
.fin-annual-amount{font-weight:700;color:var(--blue)}

.fin-empty{text-align:center;padding:32px 16px;color:var(--subtle);font-size:.9rem}

@media(max-width:960px){
  .fin-top-row{grid-template-columns:1fr}
}
@media(max-width:680px){
  .fin-balance-amount{font-size:1.6rem}
}

/* ── Maintenance form ────────────────────────────────────────────────── */
.maintenance-form-compact{max-width:640px}

/* ── Misc ────────────────────────────────────────────────────────────── */
.muted{color:var(--muted)}
ul.clean{margin:0;padding-left:18px;color:var(--muted)}
ul.clean li{margin:5px 0;font-size:.9rem}

/* ── Footer ──────────────────────────────────────────────────────────── */
.footer{padding:18px 28px;text-align:center;color:var(--subtle);font-size:.8rem;border-top:1px solid var(--line);background:var(--surface)}

/* ── Responsive ──────────────────────────────────────────────────────── */
@media(max-width:960px){
  .layout{flex-direction:column}
  .sidebar{width:100%;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;padding:10px 16px;gap:4px;border-right:none;border-bottom:1px solid var(--line)}
  .nav-group{display:none}
  .nav-link{flex:0 0 auto;border-left:none;border-bottom:2px solid transparent;border-radius:999px;padding:8px 14px;font-size:.85rem;white-space:nowrap}
  .nav-link.active{border-left:none;border-bottom-color:var(--blue-2);background:#eff6ff}
  .content{padding:22px 20px}
}
@media(max-width:680px){
  .topbar{padding:12px 16px;flex-wrap:wrap}
  .brand-text .slogan{display:none}
  .content{padding:16px}
  .section-header h2{font-size:1.2rem}
  .card{padding:16px;margin-bottom:14px}
  .grid,.financial-grid,.lease-money-grid{grid-template-columns:1fr}
  .application-item{flex-direction:column;align-items:flex-start}
  .btn{width:100%;justify-content:center}
  input[type="text"],input[type="email"],input[type="password"],select,textarea{font-size:16px}
}
