:root {
  --bg: #f0f4f8;
  --panel: rgba(255,255,255,.96);
  --panel-2: #eef2f7;
  --text: #101828;
  --muted: #64748b;
  --line: rgba(15,23,42,.08);
  --hero1: #0f766e;
  --hero2: #14b8a6;
  --income: #16a34a;
  --expense: #e11d48;
  --adjust: #2563eb;
  --carry: #2563eb;
  --shadow: 0 8px 32px rgba(15,23,42,.10);
  --shadow-sm: 0 2px 12px rgba(15,23,42,.07);
  --radius: 24px;
}
body.dark {
  --bg: #0b1220;
  --panel: rgba(17,27,45,.95);
  --panel-2: #111b2d;
  --text: #f1f5f9;
  --muted: #94a3b8;
  --line: rgba(148,163,184,.13);
  --hero1: #0f172a;
  --hero2: #0f766e;
  --shadow: 0 8px 32px rgba(0,0,0,.30);
  --shadow-sm: 0 2px 12px rgba(0,0,0,.20);
}
* { box-sizing:border-box; -webkit-tap-highlight-color: transparent; }
html,body { margin:0; padding:0; background:var(--bg); color:var(--text); font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
button,input,textarea,select { font:inherit; }
button { cursor:pointer; }
body.modal-open { overflow:hidden; }

.fade-up { animation:fadeUp .38s cubic-bezier(.2,.8,.2,1) both; }
.delay-1 { animation-delay:.06s; }
.delay-2 { animation-delay:.12s; }
.delay-3 { animation-delay:.18s; }
.pulse-soft { animation:pulseSoft 4s ease-in-out infinite; }
.bounce-in { animation:bounceIn .5s cubic-bezier(.18,1.1,.3,1) both; }
.slide-up-modal { animation:sheetUp .26s cubic-bezier(.2,.8,.2,1); }
@keyframes fadeUp { from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)} }
@keyframes bounceIn { from{opacity:0;transform:translateY(14px) scale(.93)}to{opacity:1;transform:translateY(0) scale(1)} }
@keyframes pulseSoft { 0%,100%{transform:translateY(0)}50%{transform:translateY(-1.5px)} }
@keyframes sheetUp { from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)} }

.glass-card { backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); }
.app-shell,.compound-page,.detail-shell { max-width:760px; margin:0 auto; min-height:100vh; padding:0 0 110px; }

/* ─── Hero ─── */
.hero-wrap { background:linear-gradient(145deg,var(--hero1) 0%,var(--hero2) 100%); border-radius:0 0 32px 32px; padding:20px 16px 24px; margin-bottom:20px; }
.compact-hero { background:linear-gradient(145deg,var(--hero1) 0%,var(--hero2) 100%); border-radius:0 0 32px 32px; padding:20px 16px 22px; margin-bottom:18px; }
.hero-topline { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:16px; }
.hero-brand,.hero-month-mini { display:flex; align-items:center; gap:10px; font-size:14px; font-weight:900; color:white; letter-spacing:.01em; }
.hero-mark { display:inline-grid; place-items:center; width:30px; height:30px; border-radius:999px; background:rgba(255,255,255,.2); }
.theme-btn { width:40px; height:40px; border-radius:999px; border:0; background:rgba(255,255,255,.18); color:white; display:grid; place-items:center; font-size:17px; transition:background .18s; }
.theme-btn:hover { background:rgba(255,255,255,.28); }
.theme-btn .moon { display:none; }
body.dark .theme-btn .sun { display:none; }
body.dark .theme-btn .moon { display:block; }

/* ─── Summary Card ─── */
.summary-card { border-radius:24px; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.18); color:white; padding:20px 18px 18px; }
.summary-head-row { display:flex; justify-content:space-between; gap:16px; align-items:flex-start; margin-bottom:16px; }
.summary-caption { font-size:11px; opacity:.78; font-weight:800; letter-spacing:.08em; text-transform:uppercase; margin-bottom:4px; }
.summary-title { margin:0; font-size:34px; letter-spacing:-.05em; font-weight:900; line-height:1; }
.summary-title-small { font-size:28px; }
.summary-balance-box { text-align:right; }
.summary-balance-label { font-size:11px; opacity:.78; font-weight:800; letter-spacing:.04em; margin-bottom:2px; }
.summary-balance-value { font-size:26px; font-weight:900; letter-spacing:-.04em; }
.summary-grid { display:grid; gap:10px; }
.summary-grid-2 { grid-template-columns:repeat(2,1fr); }
.summary-grid-3 { grid-template-columns:repeat(3,1fr); }
.mini-card { border-radius:18px; padding:14px 16px; background:rgba(255,255,255,.13); border:1px solid rgba(255,255,255,.14); }
.mini-label { font-size:11px; font-weight:800; opacity:.82; margin-bottom:6px; letter-spacing:.02em; }
.mini-value { font-size:20px; font-weight:900; letter-spacing:-.04em; }
.mini-value.income { color:#bbf7d0; }
.mini-value.expense { color:#fecdd3; }
.mini-value.adjust { color:#bfdbfe; }
.mini-value.carry { color:#e9d5ff; }
.mini-value.balance { color:white; }
.month-jump-row { display:flex; gap:8px; margin-top:12px; }
.month-chip-hero { display:grid; place-items:center; padding:0 14px; height:36px; border-radius:12px; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.2); color:white; font-size:13px; font-weight:800; }

/* ─── Page Content ─── */
.page-main { padding:4px 14px 0; }
.stats-main { padding:4px 14px 0; }
.stats-shell { padding-bottom:120px; }
.section-title-row { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; padding:0 2px; }
.section-title-row h2 { margin:0; font-size:22px; letter-spacing:-.04em; font-weight:900; }
.nav-pair { display:flex; gap:8px; }
.month-arrow,.month-chip { display:grid; place-items:center; min-width:40px; height:40px; border-radius:14px; background:var(--panel); box-shadow:var(--shadow-sm); color:var(--text); font-size:18px; border:1px solid var(--line); }
.month-chip { padding:0 14px; font-size:13px; font-weight:800; }

/* ─── Cards ─── */
.calendar-card,.list-panel,.stats-card,.detail-card,.compound-card { background:var(--panel); border:1px solid var(--line); box-shadow:var(--shadow); border-radius:var(--radius); }

/* ─── Calendar ─── */
.calendar-card { padding:16px 10px 14px; }
.weekday-grid,.calendar-grid { display:grid; grid-template-columns:repeat(7,minmax(0,1fr)); }
.weekday-grid { padding:0 4px 8px; }
.weekday-name { text-align:center; font-size:11px; font-weight:800; color:var(--muted); }
.calendar-grid { gap:6px 2px; }
.day-cell { min-height:86px; padding:8px 4px 6px; border-radius:16px; display:flex; flex-direction:column; align-items:center; justify-content:flex-start; transition:none; -webkit-tap-highlight-color: transparent; }
.day-cell:hover { background:transparent; transform:none; }
.day-cell.muted { opacity:.32; }
.day-cell.selected { background:linear-gradient(145deg,var(--hero1),var(--hero2)); color:white; box-shadow:0 8px 24px rgba(15,118,110,.28); }
.day-cell.selected .day-num { color:#ffffff; opacity:1; }
.day-cell.selected:active { background:linear-gradient(145deg,var(--hero1),var(--hero2)); }
.day-cell:active { border-radius:16px; background:color-mix(in srgb,var(--panel-2) 75%,transparent); }
.day-cell.selected:active { border-radius:16px; background:linear-gradient(145deg,var(--hero1),var(--hero2)); }
.day-cell.today:not(.selected) { background:color-mix(in srgb,var(--hero2) 10%,transparent); outline:2px solid color-mix(in srgb,var(--hero2) 35%,transparent); }
.day-num { font-size:15px; font-weight:900; margin-bottom:4px; line-height:1; position:relative; z-index:2; }
.day-num.sun { color:#ef4444; }
.day-num.sat { color:#3b82f6; }
.day-cell.selected .day-num { color:white; }
.day-values { display:flex; flex-direction:column; gap:2px; align-items:center; width:100%; }
.day-cell.selected .day-values { margin-top:1px; }
.mini-income,.mini-expense,.mini-adjust,.mini-carry { font-size:9.5px; font-weight:800; line-height:1.18; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mini-income { color:var(--income); }
.mini-expense { color:var(--expense); }
.mini-adjust { color:var(--adjust); }
.mini-carry { color:var(--carry); }
.day-cell.selected .mini-income,.day-cell.selected .mini-expense,.day-cell.selected .mini-adjust,.day-cell.selected .mini-carry { color:rgba(255,255,255,.9); }

/* ─── Daily Detail Section ─── */
.detail-title-row { margin-top:16px; }
.detail-date { margin-top:3px; color:var(--muted); font-size:13px; font-weight:600; }
.day-head-right { display:flex; flex-wrap:wrap; gap:6px; justify-content:flex-end; }
.badge { display:inline-flex; align-items:center; padding:5px 10px; border-radius:999px; font-size:11.5px; font-weight:800; }
.income-badge { background:color-mix(in srgb,var(--income) 12%,transparent); color:var(--income); }
.expense-badge { background:color-mix(in srgb,var(--expense) 12%,transparent); color:var(--expense); }
.adjust-badge { background:color-mix(in srgb,var(--adjust) 12%,transparent); color:var(--adjust); }
.carry-badge { background:color-mix(in srgb,var(--carry) 12%,transparent); color:var(--carry); }

/* ─── Transaction List ─── */
.list-panel { overflow:hidden; }
.tx-row { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 16px; border-bottom:1px solid var(--line); transition:background .14s; }
.tx-row:last-child { border-bottom:0; }
.tx-row:hover { background:color-mix(in srgb,var(--panel-2) 60%,transparent); }
.tx-row.excluded { opacity:.70; }
.tx-left { display:flex; align-items:center; gap:12px; min-width:0; flex:1; }
.tx-icon { width:44px; height:44px; border-radius:14px; display:grid; place-items:center; flex-shrink:0; }
.tx-icon svg { width:20px; height:20px; }
.tx-icon.income { background:color-mix(in srgb,var(--income) 12%,transparent); color:var(--income); }
.tx-icon.expense { background:color-mix(in srgb,var(--expense) 12%,transparent); color:var(--expense); }
.tx-icon.adjust { background:color-mix(in srgb,var(--adjust) 12%,transparent); color:var(--adjust); }
.tx-icon.carry { background:color-mix(in srgb,var(--carry) 12%,transparent); color:var(--carry); }
.tx-meta { min-width:0; }
.tx-title-row { display:flex; align-items:center; gap:8px; }
.tx-title { font-size:15px; font-weight:800; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tx-memo { margin-top:3px; font-size:12px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.inline-chip { display:inline-flex; padding:3px 8px; border-radius:999px; background:color-mix(in srgb,var(--muted) 13%,transparent); color:var(--muted); font-size:10px; font-weight:800; flex-shrink:0; }
.tx-right { display:grid; gap:6px; justify-items:end; flex-shrink:0; }
.tx-amount { font-weight:900; font-size:16px; letter-spacing:-.02em; }
.tx-amount.income { color:var(--income); }
.tx-amount.expense { color:var(--expense); }
.tx-amount.adjust { color:var(--adjust); }
.tx-amount.carry { color:var(--carry); }
.tx-actions { display:flex; align-items:center; gap:6px; }
.tx-actions form { margin:0; }
.icon-btn,.line-icon-btn { width:36px; height:36px; padding:0; border-radius:12px; border:1px solid var(--line); background:var(--panel-2); color:var(--text); display:grid; place-items:center; transition:background .14s; }
.icon-btn:hover,.line-icon-btn:hover { background:var(--line); }
.icon-btn svg,.line-icon-btn svg { width:17px; height:17px; }
.icon-btn.danger,.line-icon-btn.danger { color:var(--expense); }
.empty-card { padding:32px 18px; color:var(--muted); text-align:center; font-size:14px; }

/* ─── FAB ─── */
.fab-main { position:fixed; right:max(16px,env(safe-area-inset-right)); bottom:calc(100px + env(safe-area-inset-bottom)); width:60px; height:60px; border-radius:999px; border:0; background:linear-gradient(145deg,var(--hero1),var(--hero2)); color:white; font-size:30px; box-shadow:0 12px 28px rgba(15,118,110,.38); display:grid; place-items:center; line-height:1; }

/* ─── Modal ─── */
.modal-backdrop { position:fixed; inset:0; background:rgba(2,6,23,.52); display:none; align-items:flex-end; justify-content:center; padding:16px; z-index:80; }
.modal-backdrop.open { display:flex; }
.modal-sheet { width:min(720px,100%); max-height:min(88vh,800px); overflow:auto; border-radius:28px; background:var(--panel); border:1px solid var(--line); box-shadow:0 -4px 40px rgba(0,0,0,.18); padding:18px; }
.modal-head { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:14px; }
.modal-head h3 { margin:0; font-size:22px; font-weight:900; letter-spacing:-.03em; }
.modal-head p { margin:4px 0 0; color:var(--muted); font-size:13px; }
.close-btn { width:38px; height:38px; border:0; border-radius:14px; background:var(--panel-2); color:var(--text); font-size:22px; display:grid; place-items:center; }
.tab-row { display:grid; gap:6px; grid-template-columns:repeat(2,minmax(0,1fr)); margin-bottom:14px; }
.tab-row.five-tabs { grid-template-columns:repeat(5,minmax(0,1fr)); }
.tab-btn { border:0; border-radius:12px; background:var(--panel-2); color:var(--muted); font-weight:800; padding:11px 8px; font-size:13px; transition:background .15s,color .15s; }
.tab-btn.active { background:var(--text); color:var(--panel); }
.panel-form { display:none; }
.panel-form.active { display:block; }
.field { display:grid; gap:6px; margin-bottom:12px; }
.field span { font-size:12px; color:var(--muted); font-weight:800; }
.field input[type="text"],.field textarea,.field select { width:100%; border-radius:14px; border:1.5px solid var(--line); background:var(--panel-2); color:var(--text); padding:13px 16px; outline:none; transition:border-color .15s; }
.field textarea { min-height:88px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus { border-color:var(--hero2); }
.inline-inputs { display:grid; grid-template-columns:1fr 86px; gap:8px; }
.check-row { grid-template-columns:1fr auto; align-items:center; }
.check-row input { width:22px; height:22px; }
.help-text { margin:0 0 12px; font-size:12px; color:var(--muted); line-height:1.5; }
.modal-actions { display:grid; grid-template-columns:1fr auto; gap:8px; }
.submit-btn,.ghost-btn,.run-compound-btn { border:0; border-radius:16px; padding:14px 18px; font-weight:900; font-size:15px; }
.submit-btn,.run-compound-btn { background:linear-gradient(145deg,var(--hero1),var(--hero2)); color:white; }
.ghost-btn { background:var(--panel-2); color:var(--text); }

/* ─── Bottom Nav ─── */
.bottom-nav { position:fixed !important; left:50%; transform:translateX(-50%); bottom:max(10px,env(safe-area-inset-bottom)); width:min(760px,calc(100% - 20px)); display:grid; grid-template-columns:repeat(3,1fr); gap:6px; padding:8px; border-radius:24px; background:color-mix(in srgb,var(--panel) 94%,transparent); border:1px solid var(--line); box-shadow:var(--shadow); backdrop-filter:blur(14px); z-index:90; }
.bottom-nav-icons .nav-item { min-height:58px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px; color:var(--muted); border-radius:18px; font-size:11.5px; font-weight:800; transition:background .15s,color .15s; }
.bottom-nav-icons .nav-item.active { background:color-mix(in srgb,var(--hero2) 13%,transparent); color:var(--hero2); }
.bottom-nav-icons .nav-item svg { width:20px; height:20px; }

/* ─── Stats ─── */
.stats-card { padding:18px; margin-bottom:14px; }
.stats-summary-grid,.top-list-grid { display:grid; gap:10px; grid-template-columns:repeat(2,minmax(0,1fr)); }
.four-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
.stat-head { margin-bottom:14px; }
.bar-chart-wrap { display:grid; gap:12px; }
.bar-row { display:grid; grid-template-columns:52px 1fr auto; gap:10px; align-items:center; }
.bar-label { font-size:13px; font-weight:800; color:var(--muted); }
.bar-value { font-size:13px; font-weight:800; min-width:70px; text-align:right; }
.bar-track { height:12px; border-radius:999px; background:var(--panel-2); overflow:hidden; }
.bar-fill { height:100%; border-radius:999px; transition:width .4s ease; }
.bar-fill.income { background:linear-gradient(90deg,color-mix(in srgb,var(--income) 50%,white),var(--income)); }
.bar-fill.expense { background:linear-gradient(90deg,color-mix(in srgb,var(--expense) 50%,white),var(--expense)); }
.bar-fill.adjust { background:linear-gradient(90deg,color-mix(in srgb,var(--adjust) 50%,white),var(--adjust)); }
.bar-fill.carry { background:linear-gradient(90deg,color-mix(in srgb,var(--carry) 50%,white),var(--carry)); }
.top-list-box { background:var(--panel-2); border-radius:18px; padding:14px; }
.top-list-title { font-weight:900; margin-bottom:10px; font-size:13px; }
.top-list-title.income { color:var(--income); }
.top-list-title.expense { color:var(--expense); }
.top-list-title.adjust { color:var(--adjust); }
.top-list-title.carry { color:var(--carry); }
.top-list-row { display:flex; justify-content:space-between; gap:10px; padding:9px 0; border-bottom:1px solid var(--line); font-size:13px; }
.top-list-row:last-child { border-bottom:0; }
.top-list-row span { color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.top-list-empty { color:var(--muted); font-size:13px; }

/* ─── Compound ─── */
.compound-page { padding-bottom:110px; }
.plain-compound-card { overflow:hidden; padding:20px; }
.compound-top { margin-bottom:18px; }
.compound-top h1 { margin:6px 0; font-size:30px; letter-spacing:-.05em; font-weight:900; }
.compound-top p { margin:0; color:var(--muted); font-size:14px; }
.back-link { color:var(--hero2); font-size:13px; font-weight:800; }
.compound-sticky-form { margin:0 0 16px; }
.compound-form { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)) auto; gap:10px; align-items:end; }
.compound-results-scroll { }
.compound-summary { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; margin-bottom:14px; }
.summary-box { background:var(--panel-2); border-radius:18px; padding:16px; min-width:0; }
.summary-box .cap { font-size:11px; color:var(--muted); font-weight:800; margin-bottom:6px; letter-spacing:.02em; }
.summary-box .val { font-size:20px; font-weight:900; letter-spacing:-.04em; }
.table-wrap { overflow:auto; border:1px solid var(--line); border-radius:18px; background:var(--panel); max-height:52vh; }
.compound-table { width:100%; min-width:680px; border-collapse:collapse; }
.compound-table th,.compound-table td { padding:13px 12px; border-bottom:1px solid var(--line); text-align:right; white-space:nowrap; font-size:14px; }
.compound-table th:first-child,.compound-table td:first-child { text-align:left; }
.compound-table thead th { position:sticky; top:0; background:var(--panel); z-index:1; font-size:13px; }
.sort-btn { width:100%; border:0; background:transparent; padding:0; display:inline-flex; align-items:center; justify-content:flex-end; gap:5px; font-weight:900; color:inherit; }
.compound-table th:first-child .sort-btn { justify-content:flex-start; }
.sort-btn::after { content:'↕'; color:var(--muted); font-size:10px; }
.sort-btn.asc::after { content:'↑'; color:var(--hero2); }
.sort-btn.desc::after { content:'↓'; color:var(--hero2); }

/* ─── Detail Page ─── */
.detail-shell { max-width:760px; }
.detail-topbar { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 14px 14px; }
.detail-topbar h1 { margin:0; font-size:19px; font-weight:900; letter-spacing:-.04em; }
.circle-btn { width:44px; height:44px; border-radius:999px; border:1px solid var(--line); background:var(--panel); box-shadow:var(--shadow-sm); color:var(--text); display:grid; place-items:center; font-size:20px; }
.detail-page-main { padding:0 14px; }
.detail-card { padding:20px; }
.detail-meta-row { display:flex; justify-content:space-between; align-items:center; gap:10px; margin-bottom:12px; }
.detail-date-top { color:var(--muted); font-weight:700; font-size:14px; }
.detail-type-block { display:grid; justify-items:center; gap:10px; padding:14px 0 22px; }
.detail-type-icon { width:90px; height:90px; border-radius:999px; display:grid; place-items:center; }
.detail-type-icon svg { width:40px; height:40px; }
.detail-type-block.income .detail-type-icon { background:color-mix(in srgb,var(--income) 14%,transparent); color:var(--income); }
.detail-type-block.expense .detail-type-icon { background:color-mix(in srgb,var(--expense) 14%,transparent); color:var(--expense); }
.detail-type-block.adjust .detail-type-icon { background:color-mix(in srgb,var(--adjust) 14%,transparent); color:var(--adjust); }
.detail-type-block.carry .detail-type-icon { background:color-mix(in srgb,var(--carry) 14%,transparent); color:var(--carry); }
.detail-type-label { font-size:20px; font-weight:800; color:var(--muted); }
.detail-grid { display:grid; grid-template-columns:88px 1fr; gap:20px 14px; align-items:start; }
.detail-label { font-size:16px; font-weight:800; }
.detail-value { font-size:16px; font-weight:600; word-break:break-word; }
.detail-value.amount { font-size:38px; font-weight:900; letter-spacing:-.05em; }
.detail-value.amount.income { color:var(--income); }
.detail-value.amount.expense { color:var(--expense); }
.detail-value.amount.adjust { color:var(--adjust); }
.detail-value.amount.carry { color:var(--carry); }
.detail-value.muted { color:var(--muted); }
.exclude-toggle-form { margin-top:16px; }
.toggle-card { display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--panel-2); border-radius:18px; padding:14px 16px; }
.toggle-title { font-weight:900; font-size:14px; }
.toggle-sub { margin-top:3px; color:var(--muted); font-size:12px; }
.switch { width:56px; height:32px; border:0; border-radius:999px; background:#cbd5e1; position:relative; padding:0; transition:background .2s; }
.switch span { position:absolute; top:3px; left:3px; width:26px; height:26px; border-radius:999px; background:white; transition:transform .2s ease; box-shadow:0 1px 4px rgba(0,0,0,.18); }
.switch.on { background:var(--hero2); }
.switch.on span { transform:translateX(24px); }
.detail-bottom-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:18px; padding-top:14px; border-top:1px solid var(--line); }

/* ─── Responsive ─── */
@media (max-width:600px) {
  .page-main,.stats-main { padding-left:12px; padding-right:12px; }
  .detail-page-main { padding:0 12px; }
  .detail-topbar { padding:14px 12px 12px; }
  .summary-title { font-size:28px; }
  .summary-balance-value { font-size:22px; }
  .mini-value { font-size:17px; }
  .section-title-row h2 { font-size:20px; }
  .day-cell { min-height:74px; padding:6px 2px 4px; }
  .day-num { font-size:13px; }
  .mini-income,.mini-expense,.mini-adjust,.mini-carry { font-size:8.5px; }
  .tab-row.five-tabs { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .modal-sheet { padding:14px; border-radius:24px; }
  .modal-actions { grid-template-columns:1fr; }
  .compound-form { grid-template-columns:1fr; }
  .single-summary-card .val { font-size:17px; }
  .detail-grid { grid-template-columns:72px 1fr; gap:16px 12px; }
  .detail-value.amount { font-size:32px; }
  .fab-main { width:56px; height:56px; bottom:calc(96px + env(safe-area-inset-bottom)); }
  .stats-summary-grid,.top-list-grid { grid-template-columns:1fr; }
}
@media (max-width:400px) {
  .day-cell { min-height:62px; }
}

.single-summary-card { display:block; padding:14px 16px; background:var(--panel-2); border-radius:18px; margin-bottom:14px; }
.single-summary-card .summary-line { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 2px; border-bottom:1px solid var(--line); }
.single-summary-card .summary-line:last-child { border-bottom:0; }
.single-summary-card .cap { font-size:12px; color:var(--muted); font-weight:800; }
.single-summary-card .val { font-size:18px; font-weight:900; letter-spacing:-.03em; }
.viewport-nav { position:fixed !important; bottom:max(10px,env(safe-area-inset-bottom)) !important; left:50% !important; transform:translateX(-50%) !important; }
