:root {
  color-scheme: light;
  --bg: #f5f7f5;
  --surface: #ffffff;
  --surface-2: #eef3ef;
  --surface-3: #e6ece8;
  --text: #17231d;
  --muted: #6d7a72;
  --border: #dfe7e1;
  --primary: #225a40;
  --primary-2: #17432f;
  --primary-soft: #e3f1e8;
  --danger: #a63b3b;
  --warning: #a66a1f;
  --shadow: 0 10px 30px rgba(25, 46, 34, .08);
  --radius: 18px;
  --kyle: #3a8f5c;
  --tina: #3d73ba;
  --marcel: #d69523;
  --emersyn: #d46b9f;
  --archie: #8358b7;
}

* { box-sizing: border-box; }
html { font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: var(--bg); }
body { margin: 0; color: var(--text); background: var(--bg); }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 270px 1fr; }
.sidebar { position: sticky; top: 0; height: 100vh; background: #17231d; color: white; padding: 22px 16px; display: flex; flex-direction: column; z-index: 20; }
.brand { display: flex; align-items: center; gap: 12px; padding: 4px 8px 24px; }
.brand-mark { width: 44px; height: 44px; display: grid; place-items: center; border-radius: 14px; background: linear-gradient(145deg, #7bc39a, #2e7651); color: #102018; font-weight: 900; }
.brand strong { display: block; font-size: 16px; }
.brand span { display: block; color: #aebbb3; font-size: 12px; margin-top: 2px; }
.nav { display: grid; gap: 5px; overflow-y: auto; padding-right: 3px; }
.nav button { display: flex; align-items: center; gap: 11px; width: 100%; border: 0; background: transparent; color: #cbd5cf; padding: 10px 12px; border-radius: 12px; text-align: left; }
.nav button:hover, .nav button.active { background: rgba(255,255,255,.09); color: white; }
.nav .nav-icon { width: 20px; text-align: center; }
.sidebar-footer { margin-top: auto; padding: 18px 6px 0; }
.privacy-note { color: #8fa097; font-size: 11px; line-height: 1.5; margin-top: 12px; }

.main-wrap { min-width: 0; }
.topbar { min-height: 92px; display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 20px 30px; border-bottom: 1px solid var(--border); background: rgba(245,247,245,.92); backdrop-filter: blur(16px); position: sticky; top: 0; z-index: 10; }
.topbar h1 { margin: 0; font-size: 25px; letter-spacing: -.03em; }
.topbar p { margin: 4px 0 0; color: var(--muted); font-size: 13px; }
.topbar-actions { display: flex; align-items: end; gap: 10px; }
.month-control { display: grid; gap: 5px; color: var(--muted); font-size: 11px; }
.month-control input { border: 1px solid var(--border); border-radius: 11px; background: var(--surface); padding: 9px 11px; color: var(--text); }
.content { padding: 26px 30px 60px; max-width: 1600px; margin: auto; }

.primary-button, .secondary-button, .ghost-button, .danger-button, .icon-button { border-radius: 11px; border: 1px solid transparent; min-height: 40px; padding: 9px 14px; font-weight: 700; }
.primary-button { background: var(--primary); color: white; }
.primary-button:hover { background: var(--primary-2); }
.secondary-button { background: var(--surface); color: var(--text); border-color: var(--border); }
.ghost-button { background: transparent; color: inherit; border-color: rgba(255,255,255,.18); }
.danger-button { background: #fff0f0; color: var(--danger); border-color: #efcccc; }
.icon-button { padding: 8px 10px; background: var(--surface); border-color: var(--border); color: var(--text); }
.full { width: 100%; }
.mobile-only { display: none; }

.grid { display: grid; gap: 18px; }
.grid.cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); padding: 20px; min-width: 0; }
.card h2, .card h3 { margin: 0; }
.card-header { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; }
.card-header p { margin: 4px 0 0; color: var(--muted); font-size: 12px; }
.metric-card { position: relative; overflow: hidden; }
.metric-label { color: var(--muted); font-size: 12px; font-weight: 700; }
.metric-value { font-size: clamp(24px, 3vw, 34px); font-weight: 850; letter-spacing: -.04em; margin-top: 8px; }
.metric-note { color: var(--muted); font-size: 12px; margin-top: 8px; }
.metric-card::after { content: ""; position: absolute; width: 90px; height: 90px; border-radius: 50%; background: var(--primary-soft); right: -35px; top: -35px; opacity: .75; }

.toolbar { display: flex; flex-wrap: wrap; gap: 10px; align-items: end; justify-content: space-between; margin-bottom: 18px; }
.filters { display: flex; flex-wrap: wrap; gap: 8px; }
.field { display: grid; gap: 6px; }
.field label, .field > span { color: var(--muted); font-size: 12px; font-weight: 700; }
.field input, .field select, .field textarea { width: 100%; border: 1px solid var(--border); border-radius: 11px; background: white; color: var(--text); padding: 10px 11px; outline: none; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: #80ad94; box-shadow: 0 0 0 3px rgba(34,90,64,.09); }
.field textarea { min-height: 88px; resize: vertical; }
.form-grid { display: grid; gap: 14px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.form-grid .span-2 { grid-column: 1 / -1; }
.checkbox-row { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); }
.checkbox-row input { width: 17px; height: 17px; }

.table-wrap { overflow: auto; border: 1px solid var(--border); border-radius: 14px; }
table { width: 100%; border-collapse: collapse; min-width: 780px; }
th, td { padding: 12px 13px; border-bottom: 1px solid var(--border); text-align: left; font-size: 13px; vertical-align: middle; }
th { background: var(--surface-2); color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; position: sticky; top: 0; }
tr:last-child td { border-bottom: 0; }
.amount-income { color: var(--primary); font-weight: 800; }
.amount-expense { color: var(--danger); font-weight: 800; }
.action-cell { display: flex; gap: 6px; }
.table-action { border: 0; background: var(--surface-2); border-radius: 8px; padding: 6px 8px; color: var(--text); }

.badge { display: inline-flex; align-items: center; gap: 6px; border-radius: 999px; background: var(--surface-2); padding: 5px 8px; font-size: 11px; font-weight: 750; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--person-color, var(--primary)); }
.status-paid { background: #e6f4eb; color: #236941; }
.status-due { background: #fff2dc; color: #8a591d; }
.status-overdue { background: #fde7e7; color: #9d3434; }

.progress { height: 10px; border-radius: 999px; background: var(--surface-3); overflow: hidden; }
.progress > span { display: block; height: 100%; width: var(--progress, 0%); background: var(--progress-color, var(--primary)); border-radius: inherit; }
.progress-row { display: grid; gap: 7px; margin-bottom: 15px; }
.progress-row:last-child { margin-bottom: 0; }
.progress-meta { display: flex; justify-content: space-between; gap: 12px; font-size: 12px; }
.progress-meta strong { font-size: 13px; }
.progress-meta span { color: var(--muted); }

.family-grid { display: grid; gap: 12px; grid-template-columns: repeat(5, minmax(0,1fr)); }
.family-card { border: 1px solid var(--border); border-top: 4px solid var(--person-color); border-radius: 14px; background: var(--surface); padding: 14px; }
.family-card strong { display: block; }
.family-card span { color: var(--muted); font-size: 11px; }
.family-card .family-amount { font-size: 19px; font-weight: 850; margin-top: 10px; }

.chart-layout { display: grid; grid-template-columns: minmax(220px, .8fr) 1.2fr; align-items: center; gap: 20px; }
.chart-canvas { width: 100%; max-width: 330px; aspect-ratio: 1; margin: auto; }
.legend { display: grid; gap: 10px; }
.legend-row { display: grid; grid-template-columns: 12px 1fr auto; align-items: center; gap: 9px; font-size: 12px; }
.legend-swatch { width: 10px; height: 10px; border-radius: 3px; background: var(--swatch); }
.legend-row span:last-child { font-weight: 800; }

.empty { border: 1px dashed #cbd6cf; border-radius: 14px; padding: 32px; text-align: center; color: var(--muted); }
.empty strong { display: block; color: var(--text); margin-bottom: 6px; }
.section-gap { margin-top: 20px; }
.page-intro { display: flex; justify-content: space-between; align-items: center; gap: 18px; margin-bottom: 20px; }
.page-intro h2 { margin: 0; font-size: 21px; }
.page-intro p { margin: 5px 0 0; color: var(--muted); font-size: 13px; }

.scenario-tabs { display: inline-flex; border: 1px solid var(--border); border-radius: 12px; background: var(--surface); padding: 3px; }
.scenario-tabs button { border: 0; background: transparent; padding: 8px 11px; border-radius: 9px; color: var(--muted); font-weight: 750; }
.scenario-tabs button.active { background: var(--primary); color: white; }

.goal-card { display: grid; gap: 14px; }
.goal-top { display: flex; justify-content: space-between; gap: 12px; }
.goal-amount { font-size: 22px; font-weight: 850; }
.goal-note { font-size: 12px; color: var(--muted); }

.tax-result { border-radius: 16px; background: linear-gradient(145deg, #173e2d, #235d43); color: white; padding: 22px; }
.tax-result .big { font-size: 34px; font-weight: 900; letter-spacing: -.04em; }
.tax-result .muted { color: #b9d1c3; }
.tax-breakdown { display: grid; gap: 9px; margin-top: 18px; }
.tax-line { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; }
.tax-line.total { border-top: 1px solid rgba(255,255,255,.2); padding-top: 10px; font-weight: 850; }
.disclaimer { color: var(--muted); font-size: 11px; line-height: 1.5; }

.modal-backdrop { position: fixed; inset: 0; background: rgba(8,17,12,.55); display: grid; place-items: center; padding: 20px; z-index: 100; backdrop-filter: blur(4px); }
.modal { width: min(720px, 100%); max-height: 92vh; overflow: auto; background: white; border-radius: 20px; box-shadow: 0 26px 80px rgba(0,0,0,.25); }
.modal-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 20px 22px; border-bottom: 1px solid var(--border); }
.modal-header h2 { margin: 0; font-size: 19px; }
.modal-body { padding: 22px; }
.modal-footer { display: flex; justify-content: flex-end; gap: 9px; padding: 16px 22px 22px; }
.close-button { border: 0; background: var(--surface-2); width: 34px; height: 34px; border-radius: 10px; }

.toast-root { position: fixed; bottom: 22px; right: 22px; z-index: 200; display: grid; gap: 10px; }
.toast { background: #17231d; color: white; border-radius: 12px; padding: 12px 15px; box-shadow: var(--shadow); animation: toast-in .2s ease-out; font-size: 13px; }
@keyframes toast-in { from { opacity: 0; transform: translateY(8px); } }

.settings-list { display: grid; gap: 14px; }
.settings-item { border: 1px solid var(--border); border-radius: 14px; padding: 16px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.settings-item p { margin: 4px 0 0; color: var(--muted); font-size: 12px; }

@media (max-width: 1180px) {
  .grid.cols-4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .family-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 880px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { position: fixed; transform: translateX(-105%); transition: transform .2s ease; width: min(300px, 88vw); box-shadow: 10px 0 40px rgba(0,0,0,.2); }
  .sidebar.open { transform: translateX(0); }
  .mobile-only { display: inline-flex; }
  .topbar { padding: 16px 18px; align-items: center; }
  .topbar-actions { margin-left: auto; }
  .topbar > div:nth-child(2) { display: none; }
  .content { padding: 20px 16px 50px; }
  .grid.cols-3, .grid.cols-2 { grid-template-columns: 1fr; }
  .chart-layout { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .topbar-actions .month-control { display: none; }
  .primary-button { min-height: 42px; }
  .grid.cols-4 { grid-template-columns: 1fr; }
  .family-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .span-2 { grid-column: auto; }
  .page-intro { align-items: flex-start; flex-direction: column; }
  .toolbar { align-items: stretch; flex-direction: column; }
  .filters { display: grid; grid-template-columns: 1fr 1fr; }
  .modal-backdrop { padding: 0; align-items: end; }
  .modal { border-radius: 20px 20px 0 0; max-height: 95vh; }
}


/* Secure account gate and cloud status */
.hidden{display:none!important}
.app-locked{display:none!important}
.auth-gate{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top right,#244535 0,transparent 35%),linear-gradient(145deg,#0e1713,#17231d 55%,#0b120f);color:#eef7f1}
.auth-card{width:min(440px,100%);background:rgba(248,251,249,.98);color:#102018;border:1px solid rgba(255,255,255,.15);border-radius:22px;padding:32px;box-shadow:0 28px 80px rgba(0,0,0,.35)}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:24px}.auth-brand strong{display:block;font-size:1.25rem}.auth-brand span{display:block;color:#68786f;font-size:.9rem;margin-top:3px}
.auth-message{padding:12px 14px;border-radius:12px;background:#edf5f0;color:#3c5748;margin-bottom:18px;font-size:.92rem}.auth-message.error{background:#fdeaea;color:#8a2e2e}.auth-message.success{background:#e4f5e9;color:#22673d}
.auth-form{display:grid;gap:15px}.auth-form label{font-weight:700;font-size:.88rem}.auth-form input{width:100%;margin-top:7px;border:1px solid #cbd8d0;border-radius:10px;padding:12px 13px;font:inherit;background:white;color:#102018}
.auth-link{display:block;margin:16px auto 0;border:0;background:none;color:#276a48;font-weight:700;cursor:pointer}.auth-security{text-align:center;color:#718078;font-size:.78rem;margin:22px 0 0}
.account-bar{display:flex;align-items:center;gap:10px}.sync-chip{font-size:.76rem;border:1px solid #cfdbd4;border-radius:999px;padding:7px 10px;background:#fff;color:#52655a}.sync-chip.syncing{color:#8a6417}.sync-chip.error{color:#a63b3b;background:#fff0f0}.user-chip{font-size:.78rem;color:#5f6e66;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cloud-card{border-left:4px solid #2f7c50}.cloud-grid{display:grid;gap:12px}.cloud-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid #e4ebe7}.cloud-row:last-child{border-bottom:0}.cloud-row p{margin:4px 0 0;color:var(--muted)}
@media(max-width:760px){.user-chip{display:none}.sync-chip{display:none}.auth-card{padding:24px}.account-bar .secondary-button{padding:9px 11px}}
