:root{--surface: #fafafa;--card: #f5f5f7;--card-strong: #ffffff;--text: #1c1c1e;--muted: #6b7280;--subtle: #e5e7eb;--primary: #007aff;--primary-deep: #0059d1;--success: #34c759;--danger: #ff3b30;--warning: #f59e0b;--shadow: 0 16px 40px rgba(17, 24, 39, .08);--radius: 12px;--radius-sm: 8px;color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;letter-spacing:0}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,rgba(0,122,255,.07),rgba(52,199,89,.04) 34%,transparent 70%),var(--surface)}button,input{font:inherit}button{cursor:pointer;transition:background .18s ease,box-shadow .18s ease,transform .12s ease}button:active{transform:scale(.97)}button:disabled{cursor:not-allowed;opacity:.55;transform:none}.app-shell{min-height:100vh;padding:20px;padding-bottom:env(safe-area-inset-bottom,0)}.auth-shell{display:grid;min-height:100vh;min-height:100dvh;place-items:center;padding:24px 16px}.auth-panel{display:grid;width:min(440px,100%);gap:20px}.auth-brand{display:flex;gap:14px;align-items:center;justify-content:center}.auth-brand h1,.login-card h2,.loading-card h1{margin:0}.auth-icon{width:58px;height:58px;border-radius:var(--radius);box-shadow:0 10px 24px #007aff33}.login-card,.loading-card{display:grid;gap:18px;padding:24px 20px;border:1px solid rgba(229,231,235,.95);border-radius:var(--radius);background:#fffffff0;box-shadow:var(--shadow)}.login-card>div>p,.loading-card p{margin:5px 0 0;color:var(--muted)}.loading-card{width:min(360px,100%);place-items:center;text-align:center}.spinner{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.input-with-icon{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;min-height:48px;padding:0 12px;border:1px solid var(--subtle);border-radius:var(--radius-sm);color:var(--primary);background:#fff;transition:border-color .18s ease,box-shadow .18s ease}.input-with-icon:focus-within{border-color:#007aff8f;box-shadow:0 0 0 3px #007aff1a}.input-with-icon input{min-height:46px;padding:0;border:0;color:var(--text);outline:none}.password-box{grid-template-columns:auto 1fr auto}.password-toggle{display:grid;width:34px;height:34px;place-items:center;border:0;border-radius:6px;color:var(--muted);background:transparent}.auth-error{margin:0;padding:10px 12px;border-radius:var(--radius-sm);color:var(--danger);background:#ff3b301a;font-size:.86rem;font-weight:700;line-height:1.4}.auth-submit{width:100%}.topbar{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:minmax(180px,1fr) auto auto;gap:14px;align-items:center;max-width:1180px;margin:0 auto 20px;padding:10px 14px;border:1px solid rgba(229,231,235,.95);border-radius:var(--radius);background:#ffffffdb;box-shadow:0 10px 30px #11182712;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.brand{display:flex;gap:10px;align-items:center;min-width:0}.brand-icon{width:44px;height:44px;border-radius:var(--radius-sm);box-shadow:0 8px 18px #007aff2e;flex-shrink:0}.eyebrow,.section-label,.panel-title p,.workspace-header p,.summary-pill p,.stat-tile p{margin:0;color:var(--muted);font-size:.8rem;line-height:1.35}.brand h1{margin:0;font-size:1.25rem;line-height:1.1}.main-tabs,.segmented-control{display:inline-flex;align-items:center;gap:3px;padding:3px;border:1px solid var(--subtle);border-radius:var(--radius-sm);background:#f1f5f9}.tab-button,.segmented-control button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:0 10px;border:0;border-radius:6px;color:var(--muted);background:transparent;white-space:nowrap;font-size:.88rem;font-weight:600}.tab-button.is-active,.segmented-control button.is-selected{color:var(--text);background:var(--card-strong);box-shadow:0 4px 12px #11182714}.icon-button{display:inline-grid;width:40px;height:40px;place-items:center;border:1px solid var(--subtle);border-radius:var(--radius-sm);color:var(--text);background:var(--card-strong);flex-shrink:0}.icon-button.soft{color:var(--primary);background:#007aff1a;border-color:#007aff2e}.icon-button.micro{width:34px;height:34px;color:var(--muted)}.icon-button.danger,.icon-button.micro.danger{color:var(--danger)}.top-actions{display:inline-flex;gap:6px;align-items:center;justify-content:flex-end}.user-chip{display:inline-flex;align-items:center;max-width:180px;min-height:36px;padding:0 10px;border:1px solid var(--subtle);border-radius:var(--radius-sm);color:var(--muted);background:var(--card-strong);font-size:.78rem;font-weight:700}.user-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip.ready{color:var(--success);border-color:#34c7593d;background:#34c7591a}.user-chip.error{color:var(--danger);border-color:#ff3b303d;background:#ff3b301a}.app-main{max-width:1180px;margin:0 auto;padding-bottom:80px}.sync-banner{margin-bottom:14px;padding:12px 14px;border:1px solid rgba(255,59,48,.24);border-radius:var(--radius-sm);color:var(--danger);background:#ff3b301a;font-weight:700;font-size:.9rem}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,1fr);gap:16px}.panel{border:1px solid rgba(229,231,235,.95);border-radius:var(--radius);background:#ffffffeb;box-shadow:var(--shadow);transition:box-shadow .22s ease}.balance-panel,.budget-panel,.today-panel,.chart-panel,.recent-panel,.workspace-panel{padding:18px}.balance-panel,.today-panel{grid-row:span 2}.recent-panel{grid-column:span 2}.panel-heading,.budget-main,.list-heading,.workspace-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.hero-number,.large-number{display:block;margin-top:6px;font-size:1.95rem;line-height:1.08;overflow-wrap:anywhere}.large-number{font-size:1.65rem}.primary{color:var(--primary)}.success{color:var(--success)}.danger{color:var(--danger)}.warning{color:var(--warning)}.neutral{color:var(--text)}.flow-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}.metric-tile{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;min-height:84px;padding:12px;border:1px solid transparent;border-radius:var(--radius-sm);text-align:left;background:var(--card);transition:background .16s ease}.metric-tile:hover{background:#0000000a}.metric-tile span{color:var(--muted);font-size:.82rem}.metric-tile strong{grid-column:1 / -1;font-size:.95rem;overflow-wrap:anywhere}.success-tile{color:var(--success);background:#34c75917}.success-tile:hover{background:#34c75924}.danger-tile{color:var(--danger);background:#ff3b3017}.danger-tile:hover{background:#ff3b3024}.compact-list{display:grid;gap:4px;margin-top:14px;padding-top:12px;border-top:1px solid var(--subtle)}.compact-row{display:grid;grid-template-columns:22px 1fr auto;gap:10px;align-items:center;min-height:42px;padding:8px;border:0;border-radius:var(--radius-sm);color:var(--muted);background:transparent;text-align:left;transition:background .16s ease}.compact-row strong{color:var(--text);overflow-wrap:anywhere;font-size:.92rem}.compact-row:hover,.compact-row:focus-visible{background:var(--card)}.compact-row.is-static{cursor:default}.panel-title{display:flex;gap:10px;align-items:center;min-width:0}.panel-title h2,.workspace-header h2,.form-title h2{margin:0;font-size:1.02rem;line-height:1.25}.title-icon{display:inline-grid;width:36px;height:36px;flex:0 0 auto;place-items:center;border-radius:999px;color:var(--primary);background:#007aff1a}.budget-main{margin-top:16px}.status-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:.78rem;font-weight:700;white-space:nowrap;flex-shrink:0}.status-badge.primary{color:var(--primary);background:#007aff1a}.status-badge.success{color:var(--success);background:#34c7591f}.status-badge.danger{color:var(--danger);background:#ff3b301a}.status-badge.warning{color:var(--warning);background:#f59e0b1f}.progress-block{margin-top:14px}.progress-track{height:10px;overflow:hidden;border-radius:999px;background:#eef2f7}.progress-fill{height:100%;min-width:0;border-radius:inherit;background:var(--primary);transition:width .4s cubic-bezier(.4,0,.2,1)}.progress-fill.success{background:var(--success)}.progress-fill.danger{background:var(--danger)}.progress-fill.warning{background:var(--warning)}.progress-caption{display:flex;justify-content:space-between;gap:12px;margin-top:8px;color:var(--muted);font-size:.76rem}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:14px}.stat-tile{min-height:86px;padding:10px;border-radius:var(--radius-sm);background:var(--card)}.stat-tile span{display:inline-grid;width:24px;height:24px;place-items:center;margin-bottom:6px;border-radius:999px;background:#1118270f}.stat-tile strong{display:block;margin-top:3px;font-size:.88rem;overflow-wrap:anywhere}.stat-tile.primary span,.summary-pill.primary>span{color:var(--primary);background:#007aff1a}.stat-tile.success span,.summary-pill.success>span{color:var(--success);background:#34c7591f}.stat-tile.danger span,.summary-pill.danger>span{color:var(--danger);background:#ff3b301a}.stat-tile.warning span,.summary-pill.warning>span{color:var(--warning);background:#f59e0b1f}.today-panel.is-alert{border-color:#ff3b306b}.callout{margin:12px 0 0;padding:12px;border-radius:var(--radius-sm);color:#7c2d12;background:#f59e0b24;line-height:1.45;font-size:.88rem}.today-list{display:grid;gap:6px;margin-top:14px;padding-top:14px;border-top:1px solid var(--subtle)}.compact-transaction{display:flex;justify-content:space-between;gap:12px;min-height:34px;color:var(--muted);font-size:.88rem}.compact-transaction strong{color:var(--danger);white-space:nowrap}.chart-bars{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;align-items:end;height:180px;margin-top:10px}.bar-column{display:grid;grid-template-rows:20px 1fr 18px;gap:4px;min-width:0;text-align:center}.bar-value{color:var(--muted);font-size:.68rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{display:flex;align-items:flex-end;min-height:100px;overflow:hidden;border-radius:999px 999px 6px 6px;background:#eef2f7}.bar-fill{width:100%;min-height:0;border-radius:inherit;background:var(--primary);transition:height .4s cubic-bezier(.4,0,.2,1)}.bar-label{color:var(--muted);font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transaction-list,.debt-list,.grouped-list{display:grid;gap:8px}.transaction-list.spacious{gap:10px}.transaction-row{display:grid;grid-template-columns:40px minmax(0,1fr) minmax(100px,auto) auto;gap:10px;align-items:center;min-height:58px;padding:10px;border:1px solid var(--subtle);border-radius:var(--radius-sm);background:var(--card-strong);transition:border-color .16s ease}.transaction-row:hover{border-color:#007aff33}.row-icon{display:inline-grid;width:40px;height:40px;place-items:center;border-radius:999px;font-weight:800;background:#1118270f;flex-shrink:0}.row-icon.success{color:var(--success);background:#34c7591f}.row-icon.danger{color:var(--danger);background:#ff3b301a}.row-main{min-width:0}.row-main strong,.row-main span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.row-main strong{font-size:.92rem}.row-main span{margin-top:2px;color:var(--muted);font-size:.78rem}.row-amount{text-align:right;overflow-wrap:anywhere;font-size:.92rem}.row-actions{display:inline-flex;gap:4px}.text-button{border:0;color:var(--primary);background:transparent;font-weight:700;white-space:nowrap;font-size:.88rem}.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:42px;padding:0 14px;border-radius:var(--radius-sm);font-weight:800;font-size:.9rem}.primary-button{border:1px solid var(--primary);color:#fff;background:var(--primary);box-shadow:0 8px 18px #007aff33}.primary-button:hover,.primary-button:focus-visible{background:var(--primary-deep)}.primary-button.compact{min-height:36px}.secondary-button{border:1px solid var(--subtle);color:var(--text);background:var(--card-strong)}.floating-action{position:fixed;right:20px;bottom:20px;z-index:15;display:grid;width:56px;height:56px;place-items:center;border:0;border-radius:999px;color:#fff;background:var(--primary);box-shadow:0 14px 30px #007aff52;bottom:calc(20px + env(safe-area-inset-bottom,0px))}.workspace{display:grid;gap:14px}.workspace-header{align-items:center}.workspace-header h2{font-size:1.4rem}.summary-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.summary-pill{display:flex;gap:10px;align-items:center;min-height:70px;padding:12px;border:1px solid var(--subtle);border-radius:var(--radius-sm);background:#ffffffdb}.summary-pill>span{display:inline-grid;width:34px;height:34px;flex:0 0 auto;place-items:center;border-radius:999px;background:#1118270f}.summary-pill strong{display:block;margin-top:2px;overflow-wrap:anywhere;font-size:.92rem}.workspace-panel{min-height:200px}.date-group{display:grid;gap:8px}.date-group+.date-group{padding-top:10px;border-top:1px solid var(--subtle)}.date-group h3{margin:0 0 2px;color:var(--muted);font-size:.84rem}.empty-state{display:grid;place-items:center;align-content:center;gap:12px;min-height:150px;padding:18px;color:var(--muted);text-align:center}.empty-state>span{display:grid;width:50px;height:50px;place-items:center;border-radius:999px;color:var(--primary);background:#007aff1a}.empty-state p{margin:0;font-weight:700;font-size:.9rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:16px;background:#0f172a57;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}}.modal-card{position:relative;width:min(580px,100%);max-height:min(720px,calc(100dvh - 32px));overflow:auto;border-radius:var(--radius);background:#fff;box-shadow:0 24px 70px #0f172a3d;animation:slide-up .25s cubic-bezier(.4,0,.2,1);-webkit-overflow-scrolling:touch}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}}.close-button{position:absolute;top:12px;right:12px;z-index:1}.entry-form{display:grid;gap:18px;padding:22px 20px}.form-title{display:flex;gap:12px;align-items:center;padding-right:44px}.form-grid{display:grid;gap:14px}.field{display:grid;gap:6px;color:var(--muted);font-size:.85rem;font-weight:700}.field input{width:100%;min-height:46px;padding:0 12px;border:1px solid var(--subtle);border-radius:var(--radius-sm);color:var(--text);background:#fff;outline:none;transition:border-color .18s ease,box-shadow .18s ease}.field input:focus{border-color:#007aff8f;box-shadow:0 0 0 3px #007aff1a}.currency-box{display:grid;grid-template-columns:auto 1fr;align-items:center;border:1px solid var(--subtle);border-radius:var(--radius-sm);background:#fff;transition:border-color .18s ease,box-shadow .18s ease}.currency-box:focus-within{border-color:#007aff8f;box-shadow:0 0 0 3px #007aff1a}.currency-box span{padding-left:12px;color:var(--muted);font-size:1rem}.currency-box input{border:0;font-size:1.5rem;font-weight:800}.currency-field.primary .currency-box input{color:var(--primary)}.currency-field.success .currency-box input{color:var(--success)}.currency-field.danger .currency-box input{color:var(--danger)}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.toast{position:fixed;left:50%;bottom:24px;z-index:60;min-width:160px;transform:translate(-50%);padding:12px 18px;border-radius:999px;color:#fff;background:#111827;box-shadow:0 16px 30px #11182738;text-align:center;font-weight:800;font-size:.88rem;animation:toast-in .3s cubic-bezier(.4,0,.2,1);bottom:calc(24px + env(safe-area-inset-bottom,0px))}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}}@media(max-width:920px){.topbar{grid-template-columns:1fr auto;gap:10px;padding:10px 12px}.top-actions{justify-self:end}.main-tabs{grid-column:1 / -1;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.main-tabs::-webkit-scrollbar{display:none}.main-tabs .tab-button{flex:1 0 auto}.dashboard-grid{grid-template-columns:1fr}.balance-panel,.today-panel,.recent-panel{grid-row:auto;grid-column:auto}.summary-strip{grid-template-columns:1fr}}@media(max-width:640px){.app-shell{padding:10px;padding-bottom:env(safe-area-inset-bottom,0)}.topbar{margin-bottom:12px;padding:8px 10px;gap:8px;border-radius:var(--radius-sm)}.brand-icon{width:36px;height:36px}.brand h1{font-size:1.05rem}.eyebrow{font-size:.72rem}.user-chip,.tab-button span{display:none}.tab-button{min-height:34px;padding:0 10px}.icon-button{width:36px;height:36px}.dashboard-grid{gap:10px}.balance-panel,.budget-panel,.today-panel,.chart-panel,.recent-panel,.workspace-panel{padding:14px 12px}.hero-number,.large-number{font-size:1.4rem}.large-number{font-size:1.25rem}.flow-grid{gap:8px;margin-top:12px}.metric-tile{min-height:72px;padding:10px}.metric-tile strong{font-size:.88rem}.stats-grid{gap:6px;margin-top:12px}.stat-tile{min-height:78px;padding:10px}.stat-tile strong{font-size:.82rem}.panel-heading,.budget-main,.workspace-header{flex-wrap:wrap;gap:10px}.workspace-header .primary-button{width:100%}.workspace-header h2{font-size:1.2rem}.chart-bars{gap:4px;height:160px}.bar-track{min-height:80px}.bar-value{font-size:.62rem}.bar-label{font-size:.64rem}.transaction-row{grid-template-columns:36px minmax(0,1fr) auto;gap:8px;padding:10px 8px;min-height:52px}.row-icon{width:36px;height:36px}.row-main strong{font-size:.86rem}.row-main span{font-size:.74rem}.row-amount{grid-column:2 / -1;text-align:left;font-size:.86rem}.row-actions{grid-column:1 / -1;justify-content:flex-end}.summary-pill{min-height:62px;padding:10px;gap:8px}.summary-pill>span{width:30px;height:30px}.summary-pill strong{font-size:.86rem}.summary-pill p{font-size:.74rem}.entry-form{padding:18px 14px;gap:16px}.form-title{padding-right:38px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.currency-box input{font-size:1.3rem}.modal-backdrop{padding:10px;align-items:end}.modal-card{width:100%;max-height:calc(100dvh - 20px);border-radius:var(--radius) var(--radius) 0 0}.floating-action{right:14px;bottom:calc(14px + env(safe-area-inset-bottom,0px));width:52px;height:52px}.segmented-control{width:100%}.segmented-control button{flex:1;min-height:34px;font-size:.84rem}.panel-title h2{font-size:.94rem}.title-icon{width:32px;height:32px}.panel-title p{font-size:.72rem}.list-heading{flex-wrap:wrap;gap:8px}.callout{font-size:.82rem;padding:10px}.progress-caption{font-size:.72rem}.status-badge{min-height:26px;padding:0 8px;font-size:.74rem}.empty-state{min-height:130px;padding:14px}.empty-state>span{width:44px;height:44px}.empty-state p{font-size:.84rem}}@media(max-width:400px){.app-shell{padding:8px}.topbar{padding:6px 8px;gap:6px}.brand-icon{width:32px;height:32px}.brand h1{font-size:.95rem}.brand{gap:8px}.top-actions{gap:4px}.icon-button{width:34px;height:34px}.hero-number{font-size:1.25rem}.large-number{font-size:1.12rem}.flow-grid,.stats-grid{grid-template-columns:1fr;gap:6px}.balance-panel,.budget-panel,.today-panel,.chart-panel,.recent-panel,.workspace-panel{padding:12px 10px}.chart-bars{height:140px;gap:3px}.bar-track{min-height:70px}.bar-column{grid-template-rows:18px 1fr 16px;gap:3px}.bar-value,.bar-label{font-size:.58rem}.transaction-row{gap:6px;padding:8px 6px}.row-icon{width:32px;height:32px}.row-main strong{font-size:.82rem}.compact-row{padding:6px;gap:8px}.compact-row strong{font-size:.84rem}.entry-form{padding:16px 12px;gap:14px}.currency-box input{font-size:1.15rem}.modal-card{max-height:calc(100dvh - 12px)}.floating-action{width:48px;height:48px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px))}}
