:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f3f5f4;color:#1d2522;--bg: #f3f5f4;--panel: #ffffff;--line: #dfe6e2;--muted: #6e7b75;--text: #1d2522;--teal: #158f8f;--teal-dark: #0f6f71;--green: #218b54;--red: #c94343;--amber: #c9861f;--blue: #2b74aa;--shadow: 0 18px 48px rgba(29, 37, 34, .13)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--bg)}button,input,select{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-columns:248px 1fr}.side-nav{position:sticky;top:0;height:100vh;padding:18px 14px;border-right:1px solid var(--line);background:#fbfcfb}.brand{display:flex;gap:12px;align-items:center;min-height:56px;padding:8px 10px 18px}.brand strong{display:block;font-size:18px}.brand span,.eyebrow,.hint,.empty{color:var(--muted)}.brand span{display:block;max-width:150px;overflow:hidden;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.nav-button,.mobile-tab{border:0;background:transparent;color:#4f5f59}.nav-button{width:100%;min-height:42px;display:flex;align-items:center;gap:10px;margin:2px 0;padding:0 12px;border-radius:8px;text-align:left}.nav-button.active{background:#dff5f2;color:var(--teal-dark);font-weight:700}.nav-button.subtle{margin-top:18px;color:var(--muted)}.workspace{min-width:0;padding:22px 26px 96px}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.top-bar h1{margin:0;font-size:30px;letter-spacing:0}.eyebrow{margin:0 0 4px;font-size:13px}.top-actions,.quick-actions,.filter-group,.modal-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.metric-card,.panel-section,.cash-card,.wide-card,.report-card{background:var(--panel);border:1px solid var(--line);border-radius:8px}.metric-card{min-height:136px;padding:18px;position:relative}.metric-card p,.report-card span,.cash-card span{margin:0 0 8px;color:var(--muted);font-size:13px}.metric-card strong{display:block;font-size:clamp(22px,2.4vw,31px);letter-spacing:0}.metric-card span{display:block;margin-top:8px;color:var(--muted)}.metric-icon{width:42px;height:42px;display:grid;place-items:center;margin-bottom:12px;border-radius:8px;background:#e9f5f2;color:var(--teal-dark)}.metric-card.danger .metric-icon,.metric-card.danger strong{color:var(--red)}.metric-card.warning .metric-icon,.metric-card.warning strong{color:var(--amber)}.metric-card.success .metric-icon,.metric-card.success strong{color:var(--green)}.metric-card.info .metric-icon,.metric-card.info strong{color:var(--blue)}.quick-actions{margin-bottom:18px}.action-button,.primary-button,.ghost-button,.tiny-button,.filter-button,.danger-button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;border:1px solid var(--line);padding:0 14px;background:#fff;color:var(--text)}.action-button{min-height:44px;font-weight:700}.primary-button{border-color:var(--teal);background:var(--teal);color:#fff;font-weight:700}.primary-button:disabled{opacity:.5;cursor:not-allowed}.ghost-button{color:var(--teal-dark)}.danger-button{border-color:#f0cccc;background:#fff5f4;color:var(--red)}.tiny-button{min-height:34px;padding:0 12px;color:var(--teal-dark);font-weight:700}.filter-button.active{border-color:var(--teal);background:#e5f7f5;color:var(--teal-dark);font-weight:700}.panel-section{padding:16px}.list-toolbar{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:12px;margin-bottom:14px}.search-box{min-height:44px;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:#fff}.search-box input{width:100%;border:0;outline:0}table{width:100%;border-collapse:collapse}th{color:var(--muted);font-size:13px;font-weight:700;text-align:left}th,td{padding:13px 10px;border-bottom:1px solid var(--line)}tbody tr{cursor:pointer}tbody tr:hover{background:#f8fbfa}.right{text-align:right}.strong{font-weight:800}.status{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;font-size:12px;font-weight:800}.status.overdue{background:#ffe8e8;color:var(--red)}.status.open{background:#fff3d8;color:var(--amber)}.status.paid{background:#e3f7eb;color:var(--green)}.mobile-card-list{display:none}.debt-card{display:grid;grid-template-columns:1fr auto;gap:12px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fff}.debt-card h3{margin:8px 0 4px;font-size:17px}.debt-card p{margin:0;color:var(--muted)}.debt-card-side{min-width:124px;display:grid;justify-items:end;gap:8px}.apt-pill{display:inline-flex;min-height:28px;align-items:center;padding:0 9px;border-radius:8px;background:#ebefed;font-weight:800}.drawer{position:fixed;top:0;right:0;z-index:30;width:min(440px,100vw);height:100vh;display:flex;flex-direction:column;background:#fff;border-left:1px solid var(--line);box-shadow:var(--shadow)}.drawer-header,.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}.drawer-header h2,.modal-header h2{margin:0}.drawer-body{overflow:auto;padding:18px 20px 32px}.detail-row,.detail-total,.mini-item{display:flex;justify-content:space-between;gap:12px}.detail-row{padding:12px 0;border-bottom:1px solid var(--line)}.detail-row span,.mini-item span{color:var(--muted)}.detail-total{align-items:center;margin:16px 0;padding:16px;border-radius:8px;background:#f6faf9}.detail-total strong{font-size:25px;color:var(--red)}.mini-list{display:grid;gap:10px}.mini-list.tall{min-height:260px}.expense-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.mini-item{align-items:center;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.mini-item strong,.mini-item span,.mini-item small{display:block}.mini-item small{margin-top:4px;color:#48554f}.expense-item>div:not(.amount-stack){min-width:0;flex:1}.expense-thumb{flex:0 0 76px;display:grid;gap:4px;color:var(--teal-dark);font-size:12px;font-weight:800;text-decoration:none}.expense-thumb img{width:76px;height:58px;object-fit:cover;border:1px solid var(--line);border-radius:8px;background:#f6faf9}.expense-thumb span{display:flex;align-items:center;gap:4px}.amount-stack{display:grid;gap:4px;justify-items:end;min-width:112px}.amount-stack em{padding:3px 8px;border-radius:999px;background:#eef7f4;color:var(--teal-dark);font-size:12px;font-style:normal;font-weight:800}.movement-item{align-items:flex-start}.movement-item>div:first-child{min-width:0}.movement-item strong,.movement-item span,.movement-item small{overflow-wrap:anywhere}.negative{color:var(--red)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:18px;background:#141c1975}.modal-card{width:min(560px,100%);max-height:min(720px,92vh);overflow:auto;border-radius:8px;background:#fff;box-shadow:var(--shadow)}.form-grid,.settings-list{display:grid;gap:14px;padding:18px 20px 20px}label{display:grid;gap:7px;color:#394641;font-weight:700}input,select{min-height:42px;width:100%;border:1px solid var(--line);border-radius:8px;padding:0 11px;background:#fff;color:var(--text)}.check-row{display:flex;align-items:center;gap:9px;font-weight:600}.check-row input{width:20px;min-height:20px}.image-picker{display:flex;align-items:center;gap:12px;padding:12px;border:1px dashed #9fc2b9;border-radius:8px;background:#f8fcfb;cursor:pointer}.image-picker input{display:none}.image-picker-icon{display:grid;flex:0 0 42px;width:42px;height:42px;place-items:center;border-radius:8px;background:#e5f4f1;color:var(--teal-dark)}.image-picker strong,.image-picker small{display:block}.image-picker small{margin-top:3px;color:var(--muted);font-weight:600}.attachment-preview{display:grid;grid-template-columns:76px minmax(0,1fr) auto;gap:12px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.attachment-preview img{width:76px;height:76px;object-fit:cover;border-radius:8px}.attachment-preview strong,.attachment-preview span{display:block;overflow-wrap:anywhere}.attachment-preview span,.form-note{color:var(--muted);font-size:13px}.form-note{margin:0}.modal-actions{justify-content:flex-end;padding-top:8px}.preview-box{display:grid;gap:5px;padding:14px;border:1px dashed #abc7bf;border-radius:8px;background:#f5fbfa}.preview-box span,.preview-box small{color:var(--muted)}.payment-preview,.payment-allocation-preview{grid-column:1 / -1}.payment-allocation-preview{max-height:220px;overflow:auto}.split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.cash-card{padding:18px}.cash-card strong,.cash-card b,.report-card strong{display:block}.cash-card strong{margin-bottom:10px}.cash-card b,.report-card strong{font-size:24px}.wide-card{grid-column:1 / -1;padding:18px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-head h2{margin:0}.compact{min-height:38px}.report-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.report-card{padding:16px}.report-card p{margin:8px 0 0;color:var(--muted)}.bottom-nav,.quick-sheet,.mobile-only{display:none}.icon-button{width:40px;height:40px;display:inline-grid;place-items:center;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text)}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(180deg,rgba(21,143,143,.1),transparent 36%),var(--bg)}.login-panel{width:min(420px,100%);display:grid;gap:16px;padding:24px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow)}.login-brand{display:grid;justify-items:center;gap:12px;margin-bottom:8px;text-align:center}.login-logo{width:min(280px,100%);max-height:190px;object-fit:contain;display:block}.login-brand h1,.login-brand p{margin:0}.login-brand p{color:var(--muted)}@media(max-width:1100px){.app-shell{grid-template-columns:1fr}.side-nav{display:none}.workspace{padding:18px 16px 104px}.mobile-only{display:inline-grid}.summary-grid,.report-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.top-bar{align-items:flex-start}.top-bar h1{font-size:23px}.top-actions{display:none}.summary-grid{grid-template-columns:1fr 1fr;gap:10px}.metric-card{min-height:126px;padding:13px}.metric-card strong{font-size:20px}.quick-actions{display:none}.list-toolbar{grid-template-columns:1fr}.filter-group{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}.filter-button{white-space:nowrap}.desktop-table{display:none}.mobile-card-list{display:grid;gap:10px}.panel-section{padding:12px}.drawer{top:auto;bottom:0;width:100vw;height:min(76vh,720px);border-top-left-radius:14px;border-top-right-radius:14px;border-left:0}.modal-backdrop{align-items:end;padding:0}.modal-card{width:100%;max-height:92vh;border-radius:14px 14px 0 0}.modal-actions{position:sticky;bottom:0;padding:10px 0 0;background:#fff}.mini-item.movement-item{display:grid;grid-template-columns:1fr}.mini-item.expense-item.has-attachment{display:grid;grid-template-columns:76px 1fr}.expense-item.has-attachment .amount-stack{grid-column:1 / -1}.attachment-preview{grid-template-columns:64px minmax(0,1fr) auto}.attachment-preview img{width:64px;height:64px}.amount-stack{justify-items:start;min-width:0}.split,.expense-summary,.report-grid{grid-template-columns:1fr}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:25;display:grid;grid-template-columns:1fr 1fr 72px 1fr 1fr;align-items:center;min-height:74px;padding:8px 8px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-tab{display:grid;justify-items:center;gap:3px;min-height:54px;font-size:12px}.mobile-tab.active{color:var(--teal-dark);font-weight:800}.fab{width:58px;height:58px;border:0;border-radius:50%;background:var(--teal);color:#fff;box-shadow:0 12px 26px #158f8f52}.quick-sheet{position:fixed;left:12px;right:12px;bottom:86px;z-index:35;display:grid;gap:8px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow)}.quick-sheet button{min-height:42px;border:1px solid var(--line);border-radius:8px;background:#f8fbfa;text-align:left}}
