:root{--bg: #121212;--bg-elevated: #1c1c1e;--bg-row: #1a1a1c;--border: #2c2c2e;--text: #ffffff;--text-muted: #8e8e93;--accent: #e85d4c;--income: #4a90d9;--expense: #e85d4c;--asset: #4a90d9;--liability: #e85d4c;--safe-bottom: env(safe-area-inset-bottom, 0px);font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text)}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:var(--income)}.app-shell{display:flex;flex-direction:column;min-height:100%;max-width:480px;margin:0 auto;background:var(--bg)}.app-main{flex:1;overflow-y:auto;padding-bottom:calc(72px + var(--safe-bottom))}.page-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-elevated);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.page-header h1{font-size:17px;font-weight:600;flex:1;text-align:center}.page-header .side{width:72px;display:flex;gap:8px}.page-header .side.right{justify-content:flex-end}.month-nav{display:flex;align-items:center;justify-content:center;gap:20px;padding:10px 16px;font-weight:600}.month-nav button{color:var(--text-muted);font-size:20px;padding:4px 8px}.summary-bar{display:flex;justify-content:space-around;padding:10px 16px 14px;border-bottom:1px solid var(--border)}.summary-bar .item{text-align:center}.summary-bar .label{font-size:12px;color:var(--text-muted);margin-bottom:4px}.summary-bar .value{font-size:15px;font-weight:600}.summary-bar .value.income{color:var(--income)}.summary-bar .value.expense{color:var(--expense)}.summary-bar-ledger{flex-wrap:wrap;gap:4px}.summary-bar-ledger .item{min-width:22%}.summary-bar .value.remains{color:var(--text);font-weight:700}.remains-hero{padding:12px 16px 8px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.remains-main{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:8px}.remains-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.remains-amount{font-size:28px;font-weight:700;color:var(--text)}.remains-formula{font-size:11px;color:var(--text-muted);text-align:center;line-height:1.4;margin-bottom:10px}.ledger-card{margin:12px 16px;padding:12px 14px;background:var(--bg-elevated);border-radius:12px;border:1px solid var(--border)}.ledger-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}.ledger-row.highlight{border-bottom:none;font-weight:600;padding-top:12px}.ledger-label{color:var(--text-muted)}.ledger-value.remains{color:var(--text);font-size:17px}.ledger-hint{margin-top:10px;font-size:11px;color:var(--text-muted);line-height:1.4}.link-btn{margin-left:8px;color:var(--income);font-size:12px;text-decoration:underline}.ledger-edit{display:flex;align-items:center;gap:8px}.scope-toggle{display:flex;margin:8px 16px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.scope-toggle button{flex:1;padding:10px;color:var(--text-muted)}.scope-toggle button.active{background:var(--accent);color:#fff}.account-row-detail{flex-direction:column;align-items:stretch;gap:8px}.account-row-detail>div:first-child{display:flex;justify-content:space-between;align-items:flex-start}.account-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.account-remain{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--border)}.account-remain .label{font-size:13px;color:var(--text-muted)}.account-remain .balance{font-size:20px;font-weight:700}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:var(--bg-elevated);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);z-index:20}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 10px;text-decoration:none;color:var(--text-muted);font-size:11px}.bottom-nav a.active{color:var(--accent)}.bottom-nav .icon{font-size:20px}.fab{position:fixed;right:max(16px,calc(50% - 224px));bottom:calc(80px + var(--safe-bottom));width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #e85d4c73;z-index:15}.tx-day-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px 6px;background:var(--bg)}.tx-day-header .left{display:flex;align-items:center;gap:8px}.tx-day-header .day-num{font-size:22px;font-weight:700}.tx-day-header .weekday{font-size:11px;color:var(--text-muted);background:var(--bg-elevated);padding:2px 6px;border-radius:4px}.tx-day-header .totals{text-align:right;font-size:12px}.tx-row{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-row);text-decoration:none;color:inherit}.tx-row .cat{font-size:12px;color:var(--text-muted);min-width:80px}.tx-row .body{flex:1;min-width:0}.tx-row .note{font-size:14px;margin-bottom:2px;word-break:break-word}.tx-row .meta{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.tx-row .amount{font-weight:600;white-space:nowrap}.tx-row .amount.income{color:var(--income)}.tx-row .amount.expense{color:var(--expense)}.badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600;color:#fff}.stats-toggle{display:flex;margin:0 16px 12px;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.stats-toggle button{flex:1;padding:10px;color:var(--text-muted)}.stats-toggle button.active{background:var(--accent);color:#fff}.stats-toggle button.active.income-tab{background:var(--income)}.pie-wrap{padding:8px 16px 16px}.category-list .row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border)}.category-list .row .name{flex:1}.category-list .row .amt{font-weight:600}.accounts-summary{display:flex;justify-content:space-around;padding:16px;border-bottom:1px solid var(--border)}.accounts-summary .col{text-align:center}.accounts-summary .label{font-size:12px;color:var(--text-muted)}.accounts-summary .val{font-size:18px;font-weight:700;margin-top:4px}.account-row{display:flex;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.account-row .balance.asset{color:var(--asset)}.account-row .balance.liability{color:var(--liability)}.form-page{padding:0 0 100px}.form-tabs{display:flex;gap:8px;padding:12px 16px}.form-tabs button{flex:1;padding:10px;border-radius:8px;border:1px solid var(--border);color:var(--text-muted)}.form-tabs button.active{border-color:var(--accent);color:var(--accent)}.form-tabs button.active.income{border-color:var(--income);color:var(--income)}.form-field{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);gap:12px}.form-field label{min-width:88px;color:var(--text-muted);font-size:14px}.form-field input,.form-field select,.form-field textarea{flex:1;background:transparent;border:none;outline:none;font-size:15px}.form-field input:focus,.form-field textarea:focus{border-bottom:2px solid var(--accent)}.form-field textarea{min-height:60px;resize:vertical}.attachment-preview{padding:12px 16px}.attachment-preview img{max-width:100%;max-height:200px;border-radius:8px}.form-actions{padding:16px;display:flex;gap:10px}.btn-primary{flex:1;background:var(--accent);color:#fff;padding:14px;border-radius:10px;font-weight:600}.btn-secondary{padding:14px 20px;border:1px solid var(--border);border-radius:10px;color:var(--text-muted)}.btn-danger{background:transparent;border:1px solid var(--liability);color:var(--liability);padding:14px 20px;border-radius:10px}.login-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:360px;background:var(--bg-elevated);border-radius:16px;padding:32px 24px;border:1px solid var(--border)}.login-card h1{font-size:22px;margin-bottom:8px}.login-card p{color:var(--text-muted);font-size:14px;margin-bottom:24px}.login-card input{width:100%;padding:14px;border-radius:10px;border:1px solid var(--border);background:var(--bg);margin-bottom:12px}.login-card .error{color:var(--expense);font-size:13px;margin-bottom:12px}.more-section{padding:16px}.more-section h2{font-size:13px;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}.more-list button,.more-list label{display:block;width:100%;text-align:left;padding:14px 0;border-bottom:1px solid var(--border);color:var(--text)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.loading{text-align:center;padding:24px;color:var(--text-muted)}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000eb;display:flex;align-items:center;justify-content:center;padding:16px}.lightbox img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.lightbox .close-hint{position:absolute;top:16px;right:16px;color:#fff;font-size:14px;opacity:.7}.filter-row{display:flex;gap:8px;padding:8px 16px;align-items:center}.filter-select{flex:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-size:13px;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.filter-clear{color:var(--text-muted);font-size:16px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:var(--bg-elevated)}.year-summary{margin:8px 16px;background:var(--bg-elevated);border-radius:12px;border:1px solid var(--border);overflow:hidden}.year-summary-header,.year-summary-row,.year-summary-total{display:grid;grid-template-columns:48px 1fr 1fr 1fr;gap:4px;padding:10px 14px;font-size:13px;align-items:center}.year-summary-header{font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);text-transform:uppercase;font-size:11px;letter-spacing:.04em}.year-summary-row{border-bottom:1px solid var(--border)}.year-summary-total{font-weight:700;border-top:2px solid var(--border)}.ys-month{font-weight:600}.ys-income{text-align:right;color:var(--income)}.ys-expense{text-align:right;color:var(--expense)}.ys-net{text-align:right;font-weight:600}.ys-net.income{color:var(--income)}.ys-net.expense{color:var(--expense)}
