:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#172f2d;background:#f3f6f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.7}h1,h2,h3,p{margin:0}h1{margin-top:6px;font-size:clamp(2rem,4vw,4rem);line-height:1;max-width:760px}h2{font-size:1.2rem}h3{font-size:.95rem;margin-bottom:12px}.boot-screen,.auth-shell{min-height:100vh;display:grid;place-items:center;padding:22px;background:linear-gradient(120deg,rgba(29,154,138,.12),transparent 38%),linear-gradient(300deg,rgba(76,120,168,.18),transparent 42%),#f3f6f5}.boot-screen{align-content:center;gap:12px;color:#173d38}.brand-logo{width:54px;height:54px;display:inline-grid;place-items:center;border-radius:16px;background:#fff;box-shadow:0 16px 34px #173d383d;overflow:hidden}.brand-logo.compact{width:38px;height:38px;border-radius:12px;flex:0 0 auto}.brand-logo img{width:100%;height:100%;object-fit:cover;display:block}.auth-panel{width:min(520px,100%);display:grid;gap:18px;padding:28px;border:1px solid rgba(23,47,45,.1);border-radius:8px;background:#fff;box-shadow:0 22px 70px #172f2d1f}.auth-panel p{color:#657671;line-height:1.55}.auth-brand{display:flex;align-items:center;gap:12px}.auth-brand strong,.auth-brand span{display:block}.auth-brand strong{font-size:1.2rem}.auth-brand span{color:#657671;font-weight:800;margin-top:2px}.auth-switch{width:100%}.auth-switch button{flex:1}.app-layout{min-height:100vh;display:grid;grid-template-columns:276px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;display:grid;grid-template-rows:auto auto 1fr auto;gap:18px;padding:22px;background:#172f2d;color:#fff}.brand-mark{display:flex;gap:11px;align-items:center}.brand-mark strong,.brand-mark span{display:block}.brand-mark span,.user-card span{color:#ffffffad;font-size:.86rem;margin-top:3px}.user-card{display:grid;gap:4px;padding:14px;border:1px solid rgba(255,255,255,.11);border-radius:8px;background:#ffffff0f;overflow:hidden}.user-card span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-list{display:grid;align-content:start;gap:8px}.nav-list button,.logout-button{width:100%;min-height:44px;border:0;border-radius:8px;display:flex;align-items:center;gap:10px;padding:0 12px;color:#fffc;background:transparent;font-weight:800;text-align:left}.nav-list button.active,.nav-list button:hover,.logout-button:hover{color:#fff;background:#ffffff1f}.logout-button{border:1px solid rgba(255,255,255,.12)}.content-shell{min-width:0;padding:28px}.mobile-header,.nav-backdrop{display:none}.view-stack{display:grid;gap:18px}.page-title{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.page-title.compact-title h1{font-size:clamp(1.8rem,3vw,3rem)}.eyebrow{display:inline-flex;align-items:center;gap:7px;color:#61756f;font-size:.82rem;font-weight:800;text-transform:uppercase}.status-pill,.metric,.panel,.score-card,.message{box-shadow:0 18px 50px #152d2914}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid rgba(24,49,45,.1);border-radius:999px;background:#fff;font-weight:900;white-space:nowrap}.status-pill.good,.score-card.good{color:#0f6b5f}.status-pill.warning,.score-card.warning{color:#8a5a08}.status-pill.danger,.score-card.danger{color:#a33325}.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.metric{min-height:128px;display:flex;align-items:center;justify-content:space-between;padding:22px;border-radius:8px;background:#fff;border:1px solid rgba(24,49,45,.08)}.metric span{color:#657871;display:block;margin-bottom:7px;font-weight:800}.metric strong{font-size:clamp(1.35rem,2.2vw,2rem);line-height:1.05}.metric.income svg{color:#1d9a8a}.metric.expense svg{color:#df6b4f}.metric.balance svg{color:#4c78a8}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:18px;align-items:start}.panel{background:#fff;border:1px solid rgba(24,49,45,.09);border-radius:8px;padding:20px}.single-panel{max-width:960px}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.panel-header.compact{margin-bottom:14px}.muted,.block-copy{color:#6f817c;font-size:.92rem}.block-copy{line-height:1.55}.segmented,.toggle-row{display:inline-flex;gap:4px;padding:4px;border-radius:8px;background:#e9efed}.segmented button,.toggle-row button{border:0;border-radius:6px;background:transparent;color:#526661;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:0 12px;font-weight:900}.segmented button.active,.toggle-row button.selected{background:#173d38;color:#fff}.toggle-row{width:100%;margin-bottom:4px}.toggle-row button{flex:1}.transaction-form{display:grid;gap:14px}label{display:grid;gap:7px;color:#526661;font-size:.88rem;font-weight:900}input,select,textarea{width:100%;min-height:44px;border:1px solid #d6ded9;border-radius:8px;color:#18312d;background:#fbfdfc;outline:none;padding:11px 12px}textarea{resize:vertical}input:focus,select:focus,textarea:focus{border-color:#1d9a8a;box-shadow:0 0 0 3px #1d9a8a24}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.primary-button,.ai-note button,.ghost-button,.danger-button{min-height:46px;border:0;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 16px;font-weight:900}.primary-button,.ai-note button{color:#fff;background:#1d9a8a}.ghost-button{border:1px solid #cbd8d4;background:#fff;color:#173d38}.danger-button{margin-top:16px;color:#fff;background:#a33325}.reset-chat-button{width:100%;margin-top:10px}.receipt-drop{position:relative;min-height:300px;display:grid;place-items:center;align-content:center;gap:10px;border:2px dashed #b8cac5;border-radius:8px;background:#fbfdfc;color:#526661;text-align:center;padding:20px}.receipt-drop input{position:absolute;inset:0;opacity:0;cursor:pointer}.receipt-drop strong{color:#18312d;font-size:1.05rem}.receipt-drop svg{color:#1d9a8a}.error-text{color:#a33325;font-weight:900}.ai-note{margin-top:16px;display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center;border-radius:8px;padding:14px;background:#eef8f5;border:1px solid #c5e4db}.ai-note.boros,.ai-note.sangat_boros{background:#fff2ec;border-color:#f5c9bc}.ai-note p{margin-top:5px;color:#526661}.ai-note span{display:block;margin-top:8px;color:#6f817c}.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.chart-box{min-height:280px;padding:14px;border:1px solid #e2e8e5;border-radius:8px;background:#fbfdfc}.chart-box.wide{grid-column:1 / -1}.empty-chart,.empty-list{min-height:220px;display:grid;place-items:center;color:#6f817c;border:1px dashed #cbd8d4;border-radius:8px;background:#f7faf9}.empty-list{min-height:160px}.score-card{display:grid;gap:6px;padding:16px;border-radius:8px;background:#fbfdfc;border:1px solid #e2e8e5}.score-card strong{font-size:1.4rem}.score-card span{color:#526661}.largest{margin-top:14px;padding-top:14px;border-top:1px solid #e2e8e5;display:grid;gap:5px}.largest span{color:#6f817c;font-weight:900}.largest p{color:#526661}.chat-panel{min-height:520px;display:grid;grid-template-rows:auto 1fr auto}.full-chat{height:calc(100vh - 56px);min-height:560px}.chat-log{overflow:auto;display:flex;flex-direction:column;gap:10px;padding-right:4px}.message{max-width:min(720px,88%);padding:11px 13px;border-radius:8px;line-height:1.45;white-space:pre-wrap;font-size:.94rem}.message.assistant{align-self:flex-start;background:#eef8f5;color:#18312d}.message.user{align-self:flex-end;background:#173d38;color:#fff}.message.typing{color:#61756f}.chat-form{display:grid;grid-template-columns:1fr 46px;gap:8px;margin-top:12px}.chat-form button,.transaction-item button,.developer-user button{border:0;border-radius:8px;background:#173d38;color:#fff;display:inline-grid;place-items:center}.transaction-list{display:grid;gap:9px}.transaction-item{display:grid;grid-template-columns:12px minmax(0,1fr) auto auto 36px;gap:12px;align-items:center;min-height:64px;padding:12px;background:#fbfdfc;border:1px solid #e2e8e5;border-radius:8px}.type-dot{width:11px;height:11px;border-radius:999px}.type-dot.income{background:#1d9a8a}.type-dot.expense{background:#df6b4f}.transaction-item strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-item span{display:block;color:#6f817c;margin-top:4px;font-size:.9rem}.transaction-item b{white-space:nowrap}.transaction-item b.income{color:#0f6b5f}.transaction-item b.expense{color:#a33325}.waste{padding:5px 8px;border-radius:999px;background:#eef2ec;color:#526661;font-weight:900;white-space:nowrap}.waste.boros,.waste.sangat_boros{background:#fff2ec;color:#a33325}.settings-grid,.developer-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);gap:18px;align-items:start}.developer-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.9fr)}.danger-panel{border-color:#f0c6bd}.notification-panel{display:grid;gap:14px}.notification-state{display:grid;gap:5px;padding:13px;border:1px solid #dbe5e1;border-radius:8px;background:#fbfdfc}.notification-state strong{color:#173d38}.notification-state span{color:#6f817c;line-height:1.45}.notification-state.granted{border-color:#b7dfd3;background:#eef8f5}.notification-state.denied{border-color:#f0c6bd;background:#fff2ec}.notification-button{width:100%}.feedback-panel,.feedback-inline{color:#173d38;font-weight:800}.feedback-panel{grid-column:1 / -1}.feedback-inline{margin-top:14px}.developer-list{display:grid;gap:10px}.developer-user{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto auto;align-items:center;gap:12px;min-height:62px;padding:12px;border:1px solid #e2e8e5;border-radius:8px;background:#fbfdfc}.developer-user strong,.developer-user span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.developer-user span{color:#6f817c;margin-top:3px}.developer-user small{color:#173d38;font-weight:900;padding:5px 8px;border-radius:999px;background:#e9efed}.developer-user b{white-space:nowrap}.developer-user button{min-height:36px;padding:0 10px;display:inline-flex;align-items:center;gap:6px}.mini-role{padding:5px 8px;border-radius:999px;color:#173d38;background:#e9efed;font-size:.76rem;font-weight:900}@media(max-width:1120px){.dashboard-grid,.settings-grid,.developer-grid{grid-template-columns:1fr}}@media(max-width:860px){.app-layout{grid-template-columns:1fr}.content-shell{padding:82px 18px 18px}.mobile-header{position:fixed;z-index:30;top:0;left:0;right:0;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#fffffff0;border-bottom:1px solid rgba(24,49,45,.1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-header button{width:42px;height:42px;border:0;border-radius:8px;display:inline-grid;place-items:center;background:#173d38;color:#fff}.sidebar{position:fixed;z-index:40;inset:0 auto 0 0;width:min(300px,86vw);transform:translate(-105%);transition:transform .16s ease}.app-layout.nav-open .sidebar{transform:translate(0)}.nav-backdrop{position:fixed;z-index:35;inset:0;border:0;background:#172f2d73;opacity:0;pointer-events:none}.app-layout.nav-open .nav-backdrop{display:block;opacity:1;pointer-events:auto}.page-title,.panel-header{display:grid;grid-template-columns:1fr}.summary-grid,.chart-grid,.form-row{grid-template-columns:1fr}.full-chat{height:calc(100vh - 108px);min-height:500px}.ai-note{grid-template-columns:1fr}}@media(max-width:560px){h1{font-size:2.2rem}.content-shell{padding-inline:14px}.segmented{width:100%}.segmented button{flex:1;padding-inline:8px}.metric{min-height:106px}.transaction-item{grid-template-columns:10px minmax(0,1fr) 34px}.transaction-item b,.transaction-item small{grid-column:2 / 3}.developer-user{grid-template-columns:minmax(0,1fr)}.developer-user button{justify-content:center}}
