:root{color-scheme:light;font-family:Inter,Microsoft YaHei,PingFang SC,Noto Sans SC,Arial,sans-serif;background:#f6f7f7;color:#202124;--bg: #f6f7f7;--surface: #ffffff;--surface-strong: #f1f3f2;--ink: #202124;--muted: #686f72;--line: #dce1df;--red: #b73732;--red-soft: #fae9e7;--green: #27794c;--green-soft: #e6f3eb;--amber: #b56b18;--amber-soft: #fff0d8;--shadow: 0 18px 42px rgba(32, 33, 36, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(180deg,rgba(183,55,50,.08),transparent 280px),var(--bg)}button,input,select{font:inherit}button{cursor:pointer}.app-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:24px 0 36px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px;border:1px solid var(--line);border-radius:8px;background:#ffffffeb;box-shadow:var(--shadow)}.brand-lockup,.date-controls,.date-field,.primary-button,.secondary-button,.summary-card,.panel-title-row,.ledger-row,.history-date,.profit-meter,.stock-row,.mini-stats{display:flex;align-items:center}.brand-lockup{gap:12px;min-width:220px}.brand-mark{display:grid;width:44px;height:44px;place-items:center;flex:0 0 auto;border-radius:8px;background:var(--red);color:#fff}.brand-name{margin:0;font-size:20px;font-weight:800;line-height:1.2}.brand-subtitle,.panel-title-row p,.ledger-row span,td span{margin:3px 0 0;color:var(--muted);font-size:13px;line-height:1.35}.date-controls{justify-content:flex-end;gap:10px;flex-wrap:wrap}.date-field{min-height:42px;gap:8px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted)}.date-field input,input,select{min-height:40px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.date-field input{border:0;min-height:auto;padding:0;background:transparent}input,select{width:100%;padding:0 11px;outline:none}input:focus,select:focus,.date-field:focus-within{border-color:var(--red);box-shadow:0 0 0 3px #b737321f}.primary-button,.secondary-button,.icon-button{min-height:42px;border:0;border-radius:8px}.primary-button,.secondary-button{justify-content:center;gap:8px;padding:0 15px;font-weight:760;white-space:nowrap}.primary-button{background:var(--red);color:#fff}.secondary-button{border:1px solid var(--line);background:var(--surface);color:var(--ink)}.primary-button:hover{background:#9f2f2b}.secondary-button:hover{border-color:#b8c0bd;background:var(--surface-strong)}.icon-button{display:inline-grid;width:42px;place-items:center;flex:0 0 auto;border:1px solid var(--line);background:var(--surface);color:var(--ink)}.icon-button:hover{border-color:#b8c0bd;background:var(--surface-strong)}.icon-button.danger{color:var(--red)}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0}.summary-card{min-height:120px;align-items:flex-start;flex-direction:column;justify-content:space-between;gap:12px;padding:16px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.summary-card p{margin:0;color:var(--muted);font-size:13px}.summary-card strong{display:block;max-width:100%;font-size:27px;line-height:1.05;overflow-wrap:anywhere}.summary-icon{display:grid;width:34px;height:34px;place-items:center;border-radius:8px}.summary-card.green .summary-icon{background:var(--green-soft);color:var(--green)}.summary-card.red .summary-icon{background:var(--red-soft);color:var(--red)}.summary-card.amber .summary-icon{background:var(--amber-soft);color:var(--amber)}.summary-card.ink .summary-icon{background:#e8eceb;color:#2d3436}.content-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px;align-items:start;min-width:0}.main-stack{display:grid;gap:18px;min-width:0}.work-panel,.history-panel,.cloud-sync-panel,.side-panel{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:0 12px 30px #2021240f;min-width:0}.work-panel,.history-panel,.cloud-sync-panel{padding:18px}.cloud-sync-panel{margin-bottom:18px}.sync-title{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}.sync-title h2{margin:0;font-size:18px;line-height:1.2}.sync-title p{margin:3px 0 0;color:var(--muted);font-size:13px}.sync-controls{display:grid;grid-template-columns:minmax(220px,1fr) auto auto auto;gap:10px;align-items:end}.sync-key-field{display:flex;align-items:center;gap:8px;min-height:40px;padding:0 11px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--muted)}.sync-key-field:focus-within{border-color:var(--red);box-shadow:0 0 0 3px #b737321f}.sync-key-field input{min-height:auto;padding:0;border:0}.sync-status{margin:12px 0 0;padding:10px 12px;border-radius:8px;background:var(--surface-strong);color:var(--muted);font-size:13px;font-weight:720}.auto-sync-note{margin-top:10px;color:var(--muted);font-size:13px;font-weight:720}.sync-status.good{background:var(--green-soft);color:var(--green)}.sync-status.warn{background:var(--amber-soft);color:var(--amber)}.sync-status.bad{background:var(--red-soft);color:var(--red)}.side-panel{position:sticky;top:16px;padding:16px}.panel-title-row{justify-content:space-between;gap:14px;margin-bottom:16px}.panel-title-row.compact{margin-bottom:12px}.panel-title-row h2{margin:0;font-size:19px;line-height:1.2}.category-manager{display:grid;grid-template-columns:minmax(180px,240px) auto minmax(0,1fr);gap:10px;align-items:end;margin-bottom:14px}.type-chip-list{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.type-chip{display:inline-flex;min-height:32px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fff}.type-chip.active{border-color:#b7373261;background:var(--red-soft)}.type-chip button{border:0;background:transparent;color:var(--ink);font-weight:720}.type-chip button:first-child{padding:0 10px}.chip-delete{display:grid;width:30px;place-items:center;border-left:1px solid rgba(32,33,36,.08)!important;color:var(--red)!important}.chip-delete:disabled{cursor:not-allowed;color:#b5b9bb!important}.ticket-form{display:grid;grid-template-columns:1.05fr repeat(4,minmax(96px,.8fr));gap:10px;align-items:end;margin-bottom:16px}.cash-form{display:grid;grid-template-columns:176px 1fr 150px 1.2fr 128px;gap:10px;align-items:end;margin-bottom:14px}label{display:grid;gap:6px;min-width:0}label span{color:var(--muted);font-size:13px;font-weight:650}.add-button{align-self:end}.row-actions{display:flex;gap:8px;align-items:center}.segmented{display:grid;grid-template-columns:1fr 1fr;min-height:40px;padding:3px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.segmented button{border:0;border-radius:6px;background:transparent;color:var(--muted);font-weight:750}.segmented button.active{background:var(--surface);color:var(--red);box-shadow:0 4px 14px #20212414}.table-wrap{width:100%;max-width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:8px}table{width:100%;min-width:720px;border-collapse:collapse}th,td{padding:13px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{color:var(--muted);background:var(--surface-strong);font-size:12px;font-weight:800}td{font-size:14px}td strong,.ledger-row strong,.stock-row strong{display:block;font-size:14px;line-height:1.25}tbody tr:last-child td{border-bottom:0}tfoot td{border-top:1px solid var(--line);border-bottom:0;background:#fbf6f2;font-weight:800}.ticket-total-row span{font-weight:650}.empty-cell,.empty-strip{color:var(--muted);text-align:center}.empty-strip{padding:16px;border:1px dashed #cfd6d3;border-radius:8px;background:#fbfcfc}.ledger-list,.history-list,.stock-list{display:grid;gap:10px}.history-range{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:10px;align-items:end;margin-bottom:14px}.history-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.history-stats div{min-height:74px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fbfcfc}.history-stats span{display:block;margin-bottom:8px;color:var(--muted);font-size:12px;font-weight:760}.history-stats strong{display:block;max-width:100%;font-size:17px;line-height:1.15;overflow-wrap:anywhere}.history-charts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px}.chart-panel{min-width:0;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.trend-panel{grid-column:1 / -1}.chart-title{display:flex;align-items:center;gap:8px;margin-bottom:12px}.chart-title strong{font-size:14px}.bar-list{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:44px minmax(0,1fr) minmax(86px,auto);gap:10px;align-items:center}.bar-row span{color:var(--muted);font-size:12px;font-weight:800}.bar-row b{font-size:13px;text-align:right;overflow-wrap:anywhere}.bar-track{height:12px;overflow:hidden;border-radius:8px;background:var(--surface-strong)}.bar-fill{display:block;height:100%;min-width:4px;border-radius:8px}.bar-fill.income,.bar-fill.sell{background:var(--green)}.bar-fill.expense{background:var(--red)}.bar-fill.buy{background:var(--amber)}.trend-chart{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(76px,1fr);gap:8px;align-items:end;overflow-x:auto;padding-bottom:2px}.trend-day{display:grid;min-height:148px;align-content:end;gap:6px;padding:8px;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;color:var(--ink);text-align:center}.trend-day:hover{border-color:#bdc6c2}.trend-bars{display:flex;align-items:flex-end;justify-content:center;height:92px}.trend-bar{display:block;width:18px;border-radius:8px 8px 3px 3px}.trend-bar.positive{background:var(--green)}.trend-bar.negative{background:var(--red)}.trend-day b{font-size:12px}.trend-day small{color:var(--muted);font-size:11px;overflow-wrap:anywhere}.ledger-row{display:grid;grid-template-columns:12px minmax(0,1fr) auto 42px;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.direction-dot{width:10px;height:10px;border-radius:99px}.direction-dot.income{background:var(--green)}.direction-dot.expense{background:var(--red)}.amount{white-space:nowrap}.amount.income{color:var(--green)}.amount.expense{color:var(--red)}.history-row{display:grid;grid-template-columns:1.2fr repeat(4,minmax(98px,1fr));gap:10px;width:100%;min-height:58px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);text-align:left}.history-row:hover{border-color:#bdc6c2;background:#fbfcfc}.history-row span,.history-row strong{overflow-wrap:anywhere}.history-date{gap:8px;font-weight:760}.profit-meter{align-items:flex-start;flex-direction:column;gap:8px;min-height:128px;padding:16px;border-radius:8px;background:linear-gradient(135deg,#2e3234,#101314);color:#fff}.profit-meter span{color:#ffffffbf;font-size:13px}.profit-meter strong{max-width:100%;margin-top:auto;font-size:28px;line-height:1.05;overflow-wrap:anywhere}.mini-stats{justify-content:space-between;gap:8px;margin:12px 0}.mini-stats span{flex:1;min-height:42px;display:grid;place-items:center;padding:6px;border-radius:8px;background:var(--surface-strong);color:var(--muted);font-size:12px;font-weight:720;text-align:center}.stock-row{justify-content:space-between;gap:10px;min-height:48px;padding:12px;border:1px solid var(--line);border-radius:8px}.stock-row span{font-weight:800;color:var(--green);white-space:nowrap}@media(max-width:1060px){.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.content-grid{grid-template-columns:minmax(0,1fr)}.side-panel{position:static}.ticket-form,.category-manager,.cash-form{grid-template-columns:repeat(2,minmax(0,1fr))}.type-chip-list{grid-column:1 / -1}}@media(max-width:720px){.app-shell{width:min(100% - 20px,520px);padding-top:10px}.app-header{align-items:stretch;flex-direction:column;padding:12px}.date-controls{justify-content:stretch}.date-field{flex:1 1 190px}.primary-button{flex:1 1 150px}.summary-grid,.ticket-form,.category-manager,.history-range,.cash-form{grid-template-columns:1fr}.summary-card{min-height:104px}.summary-card strong,.profit-meter strong{font-size:24px}.work-panel,.history-panel,.cloud-sync-panel,.side-panel{padding:14px}.sync-controls{grid-template-columns:1fr}.history-row{grid-template-columns:1fr 1fr}.history-date{grid-column:1 / -1}.brand-name{font-size:18px}.table-wrap{border:0;overflow:visible}table,tbody,tr,td{display:block}table{min-width:0}thead{display:none}tbody{display:grid;gap:10px}tbody tr,tfoot tr{padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}tfoot,tfoot tr,tfoot td{display:block}tfoot tr{margin-top:10px;background:#fbf6f2}tfoot td{border-top:0;background:transparent}tbody tr.empty-row{padding:0}td{border-bottom:0}td[data-label]{display:grid;grid-template-columns:82px minmax(0,1fr);gap:8px;padding:7px 0}td[data-label]:before{content:attr(data-label);color:var(--muted);font-size:12px;font-weight:800}td[data-label] .icon-button,.row-actions{width:100%}.row-actions .icon-button{flex:1}}@media(max-width:420px){.summary-grid{gap:10px}.ledger-row{grid-template-columns:10px minmax(0,1fr) auto}.ledger-row .icon-button{grid-column:2 / -1;width:100%}.mini-stats{align-items:stretch;flex-direction:column}}@media(max-width:900px){.history-stats,.history-charts{grid-template-columns:repeat(2,minmax(0,1fr))}.trend-panel{grid-column:1 / -1}}@media(max-width:520px){.history-stats,.history-charts{grid-template-columns:1fr}.bar-row{grid-template-columns:42px minmax(0,1fr)}.bar-row b{grid-column:2;text-align:left}.trend-chart{grid-auto-columns:minmax(74px,82px)}}
