:root{color-scheme:light;font-family:Work Sans,sans-serif;--font-display: "Unbounded", sans-serif;--bg: #f7f2ea;--bg-accent: #e3efe1;--ink: #1c1c1a;--muted: #4a4a44;--accent: #0f6b66;--accent-2: #c65b2f;--panel: #ffffff;--panel-border: #d8d2c4;--shadow: 0 18px 40px rgba(34, 24, 10, .12)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,#fffdf8 0%,var(--bg) 45%,var(--bg-accent) 100%);color:var(--ink);min-height:100vh}#app{min-height:100vh}.app-shell{display:flex;flex-direction:column;min-height:100vh}header{padding:32px 6vw 20px;display:grid;grid-template-columns:1fr auto;align-items:start;gap:12px}.brand{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.6rem);text-transform:uppercase;letter-spacing:.06em;grid-column:1}.subtitle{color:var(--muted);font-size:1rem;grid-column:1}main{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;padding:0 6vw 40px}.dashboard{margin:0 6vw 24px;display:grid;gap:16px}.dashboard-head{display:flex;justify-content:space-between;gap:18px;align-items:end}.dashboard h2,.chart-panel h3{margin:0;font-family:var(--font-display)}.eyebrow{margin:0 0 6px;color:var(--muted);font-size:.8rem;font-weight:700;text-transform:uppercase}.income-estimate{width:min(280px,100%);display:grid;gap:6px}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric-card{min-width:0;display:grid;gap:8px;padding:16px;border:1px solid var(--panel-border);border-radius:8px;background:var(--panel);box-shadow:0 10px 24px #22180a14}.metric-card span{color:var(--muted);font-size:.85rem;font-weight:700}.metric-card strong{font-size:clamp(1.15rem,2vw,1.55rem);overflow-wrap:anywhere}.metric-card small{color:var(--muted);font-size:.75rem}.metric-bar{height:8px;overflow:hidden;border-radius:999px;background:#ebe6da}.metric-bar span{display:block;height:100%;border-radius:inherit;background:var(--accent)}.metric-card.expense .metric-bar span,.metric-card.tax .metric-bar span{background:var(--accent-2)}.metric-card.profit .metric-bar span{background:#2f7d32}.metric-card.profit.negative strong{color:var(--accent-2)}.metric-card.profit.negative .metric-bar span{background:var(--accent-2)}.chart-panel{display:grid;gap:14px;padding:18px;border:1px solid var(--panel-border);border-radius:8px;background:var(--panel);box-shadow:0 10px 24px #22180a14}.chart-head{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.chart-head p{margin:0;color:var(--muted);font-size:.9rem}.month-chart{display:grid;grid-template-columns:repeat(12,minmax(32px,1fr));gap:10px;min-height:210px;overflow-x:auto;padding:6px 2px 0}.month-column{min-width:32px;display:grid;grid-template-rows:1fr auto;gap:8px}.bar-area{position:relative;height:170px;display:flex;justify-content:center;align-items:flex-end;gap:4px;padding:0 3px;border-bottom:1px solid var(--panel-border)}.zero-line{position:absolute;left:0;right:0;bottom:var(--zero-line);border-top:1px dashed #bdb6a6}.bar{width:9px;min-height:3px;border-radius:999px 999px 0 0;z-index:1}.bar.income{background:var(--accent)}.bar.expense{background:var(--accent-2)}.profit-marker{position:absolute;left:50%;z-index:2;width:10px;height:10px;border:2px solid #2f7d32;border-radius:50%;background:var(--panel);transform:translate(-50%,50%)}.profit-marker.negative{border-color:var(--accent-2)}.month-label{color:var(--muted);font-size:.75rem;text-align:center;text-transform:uppercase}.chart-legend{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.85rem}.chart-legend span:before{content:"";display:inline-block;width:10px;height:10px;margin-right:6px;border-radius:50%;background:var(--accent)}.chart-legend .expense:before{background:var(--accent-2)}.chart-legend .profit:before{background:#2f7d32}.panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:22px;padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;min-height:0}.panel h2{margin:0 0 16px;font-family:var(--font-display);font-size:1.3rem}.card-list{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;overflow:auto;padding-right:8px}.entry-card{border:1px solid var(--panel-border);border-radius:16px;padding:12px 14px;display:grid;grid-template-columns:1fr auto;gap:12px;background:#fbfaf6;align-items:start}.entry-content{min-width:0}.entry-card .meta{font-size:.85rem;color:var(--muted)}.entry-card .amount{font-weight:600;font-size:1.05rem}.badge{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;padding:4px 10px;border-radius:999px;background:#0f6b6626;color:var(--accent)}.badge.expense{background:#c65b2f26;color:var(--accent-2)}.entry-actions{display:flex;gap:8px;justify-content:flex-end;align-items:flex-start}.entry-actions button{padding:6px 12px;font-size:.85rem}form{display:grid;gap:12px}.suggest-field{position:relative}.suggestions{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:10;display:flex;flex-direction:column;gap:4px;padding:8px;border:1px solid var(--panel-border);border-radius:14px;background:var(--panel);box-shadow:0 14px 28px #22180a1f;max-height:220px;overflow:auto}.suggestion-item{width:100%;justify-content:flex-start;text-align:left;background:transparent;color:var(--ink);border:1px solid transparent;border-radius:10px;padding:8px 10px;font-weight:500}.suggestion-item:hover{transform:none;background:#0f6b6614;box-shadow:none}label{font-weight:500;font-size:.9rem}.field-hint{margin:-4px 0 0;font-size:.8rem;color:var(--muted)}input,select,textarea{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--panel-border);font:inherit;background:#fff}textarea{min-height:90px;resize:vertical}button{border:none;border-radius:999px;padding:10px 16px;font:inherit;font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:transform .2s ease,box-shadow .2s ease}button.secondary{background:transparent;color:var(--accent);border:1px solid var(--accent)}button.danger{background:#c65b2f1f;color:var(--accent-2);border:1px solid rgba(198,91,47,.65)}button:hover{transform:translateY(-2px);box-shadow:0 6px 14px #0f6b662e}button.danger:hover{box-shadow:0 6px 14px #c65b2f38}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(420px,100%);background:var(--panel);border-radius:24px;border:1px solid var(--panel-border);padding:32px;box-shadow:var(--shadow)}.login-card h1{margin-top:0;font-family:var(--font-display)}.notice{background:#0f6b6614;color:var(--accent);padding:10px 12px;border-radius:12px;font-size:.85rem}.notice.error{background:#c65b2f1a;color:var(--accent-2)}.actions{display:flex;gap:10px;flex-wrap:wrap;grid-column:2;grid-row:1 / span 2;justify-content:flex-end}@media (max-width: 860px){.dashboard-head,.chart-head{align-items:stretch;flex-direction:column}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.entry-card{grid-template-columns:1fr}header{grid-template-columns:1fr}.actions{grid-column:1;grid-row:auto;justify-content:flex-start}main{grid-template-columns:1fr}}@media (max-width: 560px){.metric-grid{grid-template-columns:1fr}}
