*{margin:0;padding:0;box-sizing:border-box}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
:root{
  --bg:#ffffff;
  --bg-elevated:#fafafa;
  --bg-secondary:#f3f4f6;
  --bg-hover:#f5f5f5;
  --border:rgba(0,0,0,0.08);
  --border-hover:rgba(0,0,0,0.12);
  --text-primary:rgba(0,0,0,0.9);
  --text-secondary:rgba(0,0,0,0.55);
  --text-tertiary:rgba(0,0,0,0.35);
  --accent:#5e5ce6;
  --green:#16a34a;
  --red:#dc2626;
}
body{font-family:-apple-system,BlinkMacSystemFont,'Inter','Segoe UI',sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.5;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.15);border-radius:3px}

/* App layout */
.app{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{width:220px;background:var(--bg);border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}
.sidebar-header{display:flex;align-items:center;gap:10px;padding:8px 10px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:16px}
.logo{width:26px;height:26px;background:linear-gradient(135deg,#2a2a2a 0%,#555 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.logo svg{width:16px;height:16px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.app-name{font-size:14px;font-weight:600;letter-spacing:-0.3px}
.nav-section{margin-bottom:24px}
.nav-label{font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:0.5px;padding:12px 10px 6px;margin-bottom:6px;border-top:1px solid var(--border)}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;color:var(--text-secondary);text-decoration:none;font-size:13px;transition:all .15s;cursor:pointer;position:relative;margin-left:3px;border-left:3px solid transparent}
.nav-item:hover{background:rgba(0,0,0,0.04);color:var(--text-primary)}
.nav-item.active{background:var(--bg-elevated);color:var(--text-primary);font-weight:600;border-left-color:var(--accent)}
.nav-icon{width:16px;height:16px;opacity:.55;transition:all .15s}
.nav-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.5}
.nav-item:hover .nav-icon{opacity:.85}
.nav-item.active .nav-icon{opacity:1;color:var(--accent)}
/* Nav group (submenu) */
.nav-group{display:block;margin:2px 0}
.nav-group-header{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;color:var(--text-secondary);text-decoration:none;font-size:13px;transition:all .15s;cursor:pointer;position:relative;margin-left:3px;border-left:3px solid transparent}
.nav-group-header:hover{background:rgba(0,0,0,0.04);color:var(--text-primary)}
.nav-group-header.active{background:var(--bg-elevated);color:var(--text-primary);font-weight:600;border-left-color:var(--accent)}
.nav-group-header .nav-icon{width:16px;height:16px;opacity:.55;transition:all .15s;flex-shrink:0}
.nav-group-header:hover .nav-icon{opacity:.85}
.nav-group-header.active .nav-icon{opacity:1;color:var(--accent)}
.nav-arrow{display:flex;align-items:center;transition:transform .25s ease;color:var(--text-tertiary);margin-left:auto;opacity:.5}
.nav-group-header:hover .nav-arrow{opacity:.8}
.nav-arrow svg{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-group.open .nav-arrow{transform:rotate(90deg);opacity:.7}
.nav-submenu{display:block;max-height:0;overflow:hidden;transition:max-height .3s ease-out,opacity .25s ease;opacity:0}
.nav-group.open .nav-submenu{max-height:300px;opacity:1}
.nav-submenu .nav-item{display:flex;padding:7px 10px 7px 36px;margin:0;font-size:12.5px;border-left:3px solid transparent;position:relative}
.nav-submenu .nav-item::before{content:'';position:absolute;left:22px;top:50%;width:4px;height:4px;border-radius:50%;background:var(--text-tertiary);transform:translateY(-50%);transition:all .15s}
.nav-submenu .nav-item:hover::before{background:var(--text-secondary)}
.nav-submenu .nav-item.active::before{background:var(--accent);box-shadow:0 0 0 2px rgba(94,92,230,0.15)}
.nav-submenu .nav-item.active{border-left-color:transparent;color:var(--accent);font-weight:600;background:transparent}
.nav-submenu .nav-item.active:hover{background:rgba(94,92,230,0.04)}

.sidebar-spacer{flex:1}

/* Main */
.main{flex:1;display:flex;flex-direction:column;margin-left:220px}
.topbar{height:52px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;background:var(--bg);z-index:50}
.breadcrumb{font-size:13px;color:var(--text-secondary)}
.breadcrumb span{color:var(--text-primary)}
.topbar-spacer{flex:1}
.topbar-btn{padding:6px 12px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit}
.topbar-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}
.topbar-btn.primary{background:#171717;color:#fff;border-color:#171717}
.topbar-btn.primary:hover{background:#333}
.content{flex:1;padding:32px;overflow-y:auto}
.page-header{margin-bottom:32px}
.page-title{font-size:24px;font-weight:600;letter-spacing:-0.5px;margin-bottom:8px}
.page-subtitle{font-size:14px;color:var(--text-secondary)}

/* Stats */
.stats-row{display:flex;gap:16px;margin-bottom:32px}
.stat-card{flex:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;padding:20px}
.stat-label{font-size:12px;color:var(--text-tertiary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}
.stat-value{font-size:28px;font-weight:600;letter-spacing:-1px}
.stat-value.positive{color:var(--green)}
.stat-value.negative{color:var(--red)}
.stat-change{font-size:12px;color:var(--text-tertiary);margin-top:8px}

/* List */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.section-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}
.section-link{font-size:12px;color:var(--text-tertiary);text-decoration:none;cursor:pointer}
.section-link:hover{color:var(--text-secondary)}
.list{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.list-header{display:flex;align-items:center;padding:12px 20px;font-size:11px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;border-bottom:1px solid var(--border);background:rgba(0,0,0,0.02);gap:12px}
.list-item{display:flex;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer;gap:12px}
.list-item:last-child{border-bottom:none}
.list-item:hover{background:var(--bg-hover)}
.item-main{flex:1;display:flex;align-items:center;gap:12px;min-width:100px}
.item-icon{width:32px;height:32px;border-radius:8px;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.item-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item-desc{font-size:12px;color:var(--text-tertiary);margin-top:2px}
.item-category{font-size:12px;color:var(--text-secondary);background:var(--bg-hover);padding:4px 8px;border-radius:4px;width:80px;flex-shrink:0;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:20px}
.item-date{font-size:13px;color:var(--text-tertiary);width:70px;flex-shrink:0}
.item-amount{font-size:14px;font-weight:500;font-variant-numeric:tabular-nums;width:90px;flex-shrink:0;text-align:right}
.item-amount.out{color:var(--text-primary)}
.item-amount.in{color:var(--green)}
.list-empty{padding:40px 20px;text-align:center;color:var(--text-tertiary)}
.col-desc{flex:1;min-width:100px}
.col-field{width:80px;flex-shrink:0;text-align:center;margin-right:20px}
.col-date{width:70px;flex-shrink:0}
.col-amount{width:90px;flex-shrink:0;text-align:right}

/* Auth overlay */
.auth-overlay{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center}
.auth-box{width:360px;padding:20px}
.auth-header{text-align:center;margin-bottom:40px}
.auth-logo{width:56px;height:56px;background:linear-gradient(135deg,#1a1a1a 0%,#444 100%);border-radius:14px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,0.2)}
.auth-logo svg{width:28px;height:28px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.auth-title{font-size:24px;font-weight:600;letter-spacing:-0.5px}
.auth-desc{color:var(--text-secondary);margin-top:8px}
.auth-form{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:24px}
.auth-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--bg);transition:all .15s;font-family:inherit}
.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(94,92,230,0.1)}
.auth-btn{width:100%;padding:12px;background:#171717;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;margin-top:16px;font-family:inherit}
.auth-btn:hover{background:#333}
.auth-btn:disabled{opacity:.6;cursor:not-allowed}
.auth-err{color:var(--red);font-size:13px;margin-top:12px;text-align:center;min-height:18px}

/* Quick actions */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quick-btn{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:all .15s;font-family:inherit}
.quick-btn:hover{background:var(--bg-hover);border-color:var(--border-hover)}
.quick-btn svg{width:20px;height:20px;stroke:var(--text-secondary);fill:none;stroke-width:1.5}
.quick-btn span{font-size:12.5px;color:var(--text-secondary);font-weight:500}

/* Menu button (mobile) */
.menu-btn{display:none;width:44px;height:44px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.menu-btn:hover{background:var(--bg-hover);border-color:var(--border-hover)}
.menu-btn svg{width:22px;height:22px;stroke:var(--text-primary);fill:none;stroke-width:2}
.overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.3);z-index:99}
.overlay.active{display:block}

/* Item actions */
.item-actions{display:flex;gap:4px;margin-left:8px}
.item-actions button{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:5px;border-radius:4px;transition:all .15s;font-size:14px;min-width:28px;min-height:28px;display:inline-flex;align-items:center;justify-content:center}
.item-actions button:hover{color:var(--text-primary);background:var(--bg-hover)}

/* Tag chips */
.tag-chips{display:flex;flex-wrap:wrap;gap:4px}
.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;color:var(--text-secondary);background:var(--bg-hover);border:1px solid var(--border);cursor:default;transition:all .15s;line-height:1.4}
.tag-chip .tag-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.tag-chip.selectable{cursor:pointer}
.tag-chip.selectable:hover{border-color:var(--border-hover);background:var(--bg)}
.tag-chip.selected{background:rgba(94,92,230,0.08);border-color:var(--accent);color:var(--text-primary)}
.tag-select-wrap{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0}

/* Settings */
.settings-grid{display:grid;gap:20px;max-width:600px}
.settings-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.settings-card-header{padding:16px 20px;border-bottom:1px solid var(--border)}
.settings-card-title{font-size:14px;font-weight:600;margin-bottom:4px}
.settings-card-desc{font-size:12px;color:var(--text-tertiary)}
.settings-card-body{padding:16px 20px}
.settings-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;background:var(--bg);transition:all .15s;font-family:inherit}
.settings-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(94,92,230,0.1)}
.settings-row{display:flex;align-items:center;gap:8px}
.settings-row .settings-input{flex:1}
.settings-unit{color:var(--text-secondary);font-size:14px;white-space:nowrap}
.settings-btn{margin-top:12px;padding:10px 20px;background:#171717;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}
.settings-btn:hover{background:#333}
.settings-btn:disabled{opacity:.6;cursor:not-allowed}

/* Dashboard layout */
.dash-quick-section{margin-top:16px}
.dash-section-row{display:flex;gap:16px;margin-top:16px}
.dash-section{flex:1;min-width:0}
.dash-section-wide{flex:1.35}
.dash-hero{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(260px,1fr);gap:16px;margin-bottom:24px}
.dash-hero-main,.dash-hero-metric,.dash-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px}
.dash-hero-main{padding:20px}
.dash-hero-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:var(--bg);border:1px solid var(--border);font-size:12px;color:var(--text-secondary);margin-bottom:12px}
.dash-hero-title{font-size:22px;font-weight:600;letter-spacing:-0.4px;color:var(--text-primary);margin-bottom:8px}
.dash-hero-desc{font-size:14px;line-height:1.7;color:var(--text-secondary);margin-bottom:18px}
.dash-hero-desc strong{color:var(--text-primary)}
.dash-budget-panel{padding:14px 16px;background:var(--bg);border:1px solid var(--border);border-radius:8px}
.dash-budget-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;color:var(--text-secondary);margin-bottom:8px}
.dash-budget-row strong{font-size:14px;color:var(--text-primary)}
.dash-budget-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.dash-budget-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s}
.dash-budget-note{margin-top:8px;font-size:12px;color:var(--text-tertiary)}
.dash-budget-empty{font-size:13px;color:var(--text-secondary)}
.dash-hero-side{display:grid;grid-template-columns:1fr;gap:12px}
.dash-hero-metric{padding:16px 18px}
.dash-hero-metric-label{font-size:12px;color:var(--text-tertiary);margin-bottom:8px}
.dash-hero-metric-value{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.dash-hero-metric-note{font-size:12px;color:var(--text-secondary)}
.dash-finance-stats{margin-bottom:0}
.dash-panel{padding:6px 0}
.memo-upcoming{display:flex;flex-direction:column}
.memo-upcoming-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.memo-upcoming-item:last-child{border-bottom:none}
.memo-upcoming-item:hover{background:var(--bg-hover)}
.memo-priority{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--text-tertiary)}
.memo-priority.priority-high{background:#ef4444}
.memo-priority.priority-medium{background:#f59e0b}
.memo-priority.priority-low{background:#6b7280}
.memo-upcoming-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:var(--text-primary)}
.memo-upcoming-text.overdue{color:var(--red)}
.memo-upcoming-date{font-size:12px;color:var(--text-tertiary);flex-shrink:0}

/* Statistics */
.stats-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.stats-presets{display:flex;gap:6px;flex-wrap:wrap}
.stats-preset{padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:var(--bg);cursor:pointer;font-size:12px;color:var(--text-secondary);transition:all .15s;font-family:inherit}
.stats-preset:hover{background:var(--bg-hover);color:var(--text-primary)}
.stats-preset.active{background:#171717;color:#fff;border-color:#171717}
.stats-date-range{display:flex;align-items:center;gap:8px}
.stats-date-input{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--bg);font-family:inherit;color:var(--text-primary)}
.stats-date-input:focus{outline:none;border-color:var(--accent)}
.stats-date-sep{color:var(--text-tertiary);font-size:12px}
.stats-tabs{display:flex;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:24px}
.stats-tab{flex:1;padding:10px 16px;background:var(--bg);border:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .15s;font-family:inherit;border-right:1px solid var(--border)}
.stats-tab:last-child{border-right:none}
.stats-tab:hover{background:var(--bg-hover);color:var(--text-primary)}
.stats-tab.active{background:#171717;color:#fff}
.stats-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}
.stats-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;padding:20px}
.stats-card.full{grid-column:1/-1}
.stats-card .section-title{margin-bottom:16px}
.stats-chart-wrap{position:relative;min-height:260px}
.chart-category{min-height:200px}
.cat-item{margin-bottom:12px}
.cat-item:last-child{margin-bottom:0}
.cat-header{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px}
.cat-name{color:var(--text-primary)}
.cat-amount{color:var(--text-tertiary);font-size:12px}
.cat-bar{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden}
.cat-fill{height:100%;border-radius:3px;transition:width .3s}
.stats-type-toggle{display:flex;gap:4px;margin-bottom:16px}
.stats-type-btn{padding:4px 12px;border:1px solid var(--border);border-radius:4px;background:var(--bg);cursor:pointer;font-size:12px;color:var(--text-secondary);font-family:inherit}
.stats-type-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Categories management */
.cat-mgr-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.cat-sort-btn{background:none;border:1px solid var(--border);border-radius:4px;cursor:pointer;padding:2px 6px;font-size:11px;color:var(--text-tertiary);transition:all .15s}
.cat-sort-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.icon-picker{display:flex;flex-wrap:wrap;gap:6px}
.icon-opt{width:36px;height:36px;border:1px solid var(--border);border-radius:6px;background:var(--bg);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.icon-opt:hover{background:var(--bg-hover);border-color:var(--border-hover)}
.icon-opt.active{border-color:var(--accent);background:rgba(94,92,230,0.08)}

/* Date input combo */
.date-input-wrap{display:inline-flex;align-items:center;position:relative}
.date-text-input{padding:6px 10px;border:1px solid var(--border);border-radius:6px 0 0 6px;font-size:12px;background:var(--bg);font-family:inherit;color:var(--text-primary);width:110px;outline:none}
.date-text-input:focus{border-color:var(--accent)}
.date-hidden-picker{position:absolute;width:0;height:0;opacity:0;pointer-events:none}
.date-picker-btn{padding:6px 8px;border:1px solid var(--border);border-left:none;border-radius:0 6px 6px 0;background:var(--bg-elevated);cursor:pointer;display:flex;align-items:center;color:var(--text-tertiary);transition:all .15s}
.date-picker-btn:hover{background:var(--bg-hover);color:var(--text-primary)}
.modal-form .date-input-wrap{display:flex}
.modal-form .date-text-input{width:100%;padding:10px 12px;font-size:14px;border-radius:6px 0 0 6px}
.modal-form .date-picker-btn{padding:10px 12px}
.modal-close{line-height:1}

/* Responsive */
@media(max-width:768px){
  html{font-size:13px}
  .menu-btn{display:flex}
  .sidebar{transform:translateX(-100%);transition:transform .3s ease;box-shadow:2px 0 12px rgba(0,0,0,0.1);width:280px;max-width:88vw;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}
  .sidebar.open{transform:translateX(0)}
  .nav-item,.nav-group-header{min-height:44px}
  .nav-submenu .nav-item{min-height:40px}
  .main{margin-left:0}
  .topbar{padding:calc(8px + env(safe-area-inset-top,0px)) 12px 8px;gap:10px;min-height:52px;height:auto;flex-wrap:wrap}
  .breadcrumb{display:none}
  .topbar-spacer{display:none}
  #topAddBtn{width:100%;min-height:40px}
  .content{padding:16px 12px calc(20px + env(safe-area-inset-bottom,0px));overscroll-behavior-y:contain}
  .page-header{margin-bottom:20px}
  .page-title{font-size:20px}
  .stats-row{flex-direction:column;gap:12px;margin-bottom:24px}
  .stat-card{padding:16px}
  .stat-value{font-size:24px}
  .dash-hero{grid-template-columns:1fr}
  .dash-hero-title{font-size:20px}
  .dash-hero-main,.dash-hero-metric{padding:16px}
  .list-header{display:none}
  .list-item{flex-wrap:wrap;padding:16px}
  .item-main{width:100%;flex:none;margin-bottom:8px}
  .item-category{width:auto}
  .item-date{width:auto;margin-left:auto}
  .item-amount{font-size:16px;width:auto;margin-left:12px}
  .topbar-btn{padding:8px 12px;font-size:13px}
  .stats-charts{grid-template-columns:1fr}
  .stats-toolbar{flex-direction:column;align-items:stretch}
  .stats-presets{justify-content:center;flex-wrap:wrap}
  .stats-date-range{justify-content:center;flex-wrap:wrap}
  .stats-card.full{grid-column:1}
  .quick-grid{grid-template-columns:1fr 1fr}
  .auth-box{width:100%;padding:16px}
  .auth-form{padding:16px}
  .modal-content{margin:8px;max-height:calc(100vh - 16px);overflow-y:auto}
  .modal-header{padding:16px}
  .modal-body{padding:16px}
  .modal-footer{padding:12px 16px;flex-direction:column;gap:8px}
  .modal-footer .modal-btn{width:100%;justify-content:center}
  .modal-form input,.modal-form select,.modal-form textarea{font-size:16px}
  .tag-chips{gap:6px}
  .tag-chip{font-size:10px;padding:2px 6px}
  .item-actions{margin-left:4px}
  .item-actions button{min-width:36px;min-height:36px}
  .dash-section-row{flex-direction:column}
  .dash-quick-section{order:-1}
  .stat-card{min-width:0}
  .stats-tabs{flex-direction:column}
  .stats-tab{border-right:none;border-bottom:1px solid var(--border)}
  .stats-tab:last-child{border-bottom:none}
  .stats-preset{padding:8px 10px;font-size:11px}
  .quick-btn{padding:20px 10px}
  .quick-btn svg{width:18px;height:18px}
  .quick-btn span{font-size:12px}
  .memo-upcoming-item{padding:12px 14px}
}

@media(max-width:480px){
  .content{padding:12px 10px calc(16px + env(safe-area-inset-bottom,0px))}
  .topbar{padding:calc(8px + env(safe-area-inset-top,0px)) 10px 8px}
  .menu-btn{width:40px;height:40px;border-radius:8px}
  .quick-grid{grid-template-columns:1fr}
  .list-item{padding:14px 12px}
  .item-title{font-size:13px}
  .item-amount{font-size:15px}
  .dash-hero-title{font-size:18px}
  .dash-budget-panel,.dash-hero-main,.dash-hero-metric{padding:12px}
  .modal-content{margin:6px;max-height:calc(100vh - 12px)}
  .topbar-btn{min-height:40px}
}
