:root {
  --income:#16a34a;--income-light:#dcfce7;--income-dark:#15803d;
  --expense:#dc2626;--expense-light:#fee2e2;--expense-dark:#b91c1c;
  --bg:#f3f4f6;--card:#ffffff;--border:rgba(0,0,0,.08);--text:#111827;
  --muted:#6b7280;--accent:#d97706;--accent-light:#fef3c7;
  --sidebar-bg:#ffffff;--sidebar-text:#111827;--sidebar-muted:#6b7280;
  --budget-warn:#d97706;--budget-over:#dc2626;
  --header-h:56px;
}
*{box-sizing:border-box;margin:0;padding:0}
/* ซ่อน spin arrows ของ input[type=number] */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield;appearance:textfield}
body{font-family:'Sarabun',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}

/* ===== HAMBURGER DRAWER NAV ===== */
.drawer-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;
  opacity:0;pointer-events:none;transition:opacity .25s ease;
}
.drawer-overlay.open{opacity:1;pointer-events:all}

.drawer{
  position:fixed;left:0;top:0;height:100%;width:280px;
  background:var(--sidebar-bg);z-index:201;
  transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  box-shadow:4px 0 32px rgba(0,0,0,.3);
}
.drawer.open{transform:translateX(0)}

.drawer-header{
  padding:24px 20px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:12px;
}
.drawer-logo-icon{
  width:40px;height:40px;background:var(--accent);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:18px;color:white;flex-shrink:0;
}
.drawer-logo-text{color:var(--sidebar-text);font-size:16px;font-weight:400;line-height:1.2}
.drawer-logo-sub{color:var(--sidebar-muted);font-size:11px;margin-top:1px}
.drawer-close{
  margin-left:auto;width:32px;height:32px;border-radius:8px;border:none;
  background:rgba(255,255,255,.08);color:var(--sidebar-muted);font-size:16px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .15s;
}
.drawer-close:hover{background:rgba(255,255,255,.15);color:white}

.drawer-nav{flex:1;padding:12px 10px;overflow-y:auto}
.drawer-nav-label{
  color:var(--sidebar-muted);font-size:10px;font-weight:400;
  letter-spacing:.08em;text-transform:uppercase;
  padding:0 10px;margin:14px 0 6px;
}
.drawer-nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 12px;
  border-radius:10px;color:var(--sidebar-muted);font-size:14px;
  cursor:pointer;transition:all .15s;margin-bottom:2px;
}
.drawer-nav-item:hover{background:rgba(255,255,255,.07);color:var(--sidebar-text)}
.drawer-nav-item.active{background:var(--accent);color:white}
.drawer-nav-item i{width:18px;text-align:center;font-size:15px;flex-shrink:0}

.drawer-footer{
  padding:14px 20px;border-top:1px solid rgba(255,255,255,.08);
  font-size:11px;color:var(--sidebar-muted);text-align:center;
}

/* ===== TOP HEADER BAR ===== */
.topbar{
  background:var(--card);border-bottom:1px solid var(--border);
  padding:0 16px;height:var(--header-h);
  display:flex;align-items:center;gap:10px;
  position:sticky;top:0;z-index:100;
  box-shadow:0 1px 8px rgba(0,0,0,.06);
}

.hamburger-btn{
  width:38px;height:38px;border-radius:10px;border:none;
  background:transparent;color:var(--text);font-size:20px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .15s;
}
.hamburger-btn:hover{background:rgba(255,255,255,.05)}

.topbar-logo{
  display:flex;align-items:center;gap:8px;flex:1;min-width:0;
}
.topbar-logo-icon{
  width:30px;height:30px;background:var(--accent);border-radius:8px;
  display:flex;align-items:center;justify-content:center;font-size:14px;color:white;flex-shrink:0;
}
.topbar-title{font-size:16px;font-weight:400;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-sub{font-size:11px;color:var(--muted);margin-top:1px}

.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ===== MAIN CONTENT ===== */
.main-content{padding:8px 16px 16px;max-width:900px;margin:0 auto}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:10px;font-size:14px;font-weight:400;font-family:'Sarabun',sans-serif;cursor:pointer;border:none;transition:all .15s}
.btn-primary{background:var(--text);color:white}
.btn-primary:hover{background:#e6ac00}
.btn-income{background:var(--income-light);color:var(--income-dark)}
.btn-income:hover{background:#1a3d1a}
.btn-expense{background:var(--expense-light);color:var(--expense-dark)}
.btn-expense:hover{background:#3d1a1a}
.btn-scan{background:var(--accent);color:white}
.btn-scan:hover{background:#e6ac00}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,.05)}
.btn-export{background:#1e3a5f;color:white}
.btn-export:hover{background:#2a4f7c}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-icon{width:38px;height:38px;padding:0;border-radius:10px;justify-content:center;font-size:15px}

/* ===== SUMMARY CARDS ===== */
.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.summary-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:16px 18px;position:relative;overflow:hidden;
  transition:transform .15s,box-shadow .15s;
}
.summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.08)}
.summary-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.summary-card.balance::before{background:linear-gradient(90deg,var(--accent),transparent)}
.summary-card.income::before{background:linear-gradient(90deg,var(--income),transparent)}
.summary-card.expense::before{background:linear-gradient(90deg,var(--expense),transparent)}
.summary-label{font-size:11px;color:var(--muted);font-weight:400;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:flex;align-items:center;gap:5px}
.summary-amount{font-family:'IBM Plex Mono',monospace;font-size:22px;font-weight:400;line-height:1.2}
.summary-amount.income{color:var(--income)}
.summary-amount.expense{color:var(--expense)}
.summary-amount.balance{color:var(--text)}
.summary-sub{font-size:11px;color:var(--muted);margin-top:4px}

/* ===== SECTION CARD ===== */
.section-card{
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  overflow:hidden;margin-bottom:16px;
}
.section-card-header{
  padding:14px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.section-card-title{font-size:14px;font-weight:400;display:flex;align-items:center;gap:8px}
.section-card-title i{color:var(--accent)}
.section-card-body{padding:0}

/* ===== TRANSACTION LIST ===== */
.tx-list{padding:2px 0}
.tx-item{
  display:flex;align-items:center;gap:12px;padding:12px 18px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;
}
.tx-item:hover{background:#2a2d32;color:var(--text)}
.tx-item:last-child{border-bottom:none}

.tx-icon{
  width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
}
.tx-icon.income{background:var(--income-light);color:var(--income)}
.tx-icon.expense{background:var(--expense-light);color:var(--expense)}

.tx-info{flex:1;min-width:0}
.tx-desc{font-size:14px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.tx-meta{font-size:11px;color:var(--muted);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}
.tx-cat-badge{
  display:inline-flex;align-items:center;padding:1px 7px;border-radius:5px;
  font-size:10px;font-weight:400;background:var(--bg);color:var(--muted);border:1px solid var(--border);
}

.tx-amount-col{text-align:right;flex-shrink:0}
.tx-amount{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:400}
.tx-amount.income{color:var(--income)}
.tx-amount.expense{color:var(--expense)}
.tx-date-small{font-size:10px;color:var(--muted);margin-top:2px}

/* FILTER TABS */
.filter-tabs{display:flex;gap:3px;background:var(--bg);padding:3px;border-radius:8px}
.filter-tab{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:400;cursor:pointer;color:var(--muted);transition:all .15s;border:none;background:none;font-family:'Sarabun',sans-serif}
.filter-tab.active{background:var(--card);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.1)}

/* MONTH SELECTOR */
.month-selector{display:flex;align-items:center;gap:4px}
.month-selector select,.month-select-input{padding:6px 10px;border:1px solid var(--border);border-radius:8px;font-family:'Sarabun',sans-serif;font-size:12px;background:var(--card);color:var(--text);outline:none}
.btn-ghost-xs{padding:4px 8px;border-radius:6px;font-size:12px;background:transparent;color:var(--muted);border:1px solid var(--border);cursor:pointer;font-family:'Sarabun',sans-serif;transition:all .15s;display:inline-flex;align-items:center;gap:4px}
.btn-ghost-xs:hover{background:rgba(255,255,255,.05)}

/* ===== SCAN SLIP HERO ===== */
.scan-hero{
  background:linear-gradient(135deg, #1c1b19 0%, #2d2b27 100%);
  border-radius:20px;padding:24px;margin-bottom:16px;
  border:1px solid rgba(255,255,255,.08);
  position:relative;overflow:hidden;
}
.scan-hero::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle, rgba(217,119,6,.3) 0%, transparent 70%);
  pointer-events:none;
}
.scan-hero-label{font-size:11px;font-weight:400;color:rgba(217,119,6,.9);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.scan-hero-title{font-size:22px;font-weight:400;color:white;margin-bottom:4px;line-height:1.2}
.scan-hero-sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:20px}
.scan-hero-btns{display:flex;gap:10px;flex-wrap:wrap}
.scan-hero-btn{
  display:inline-flex;align-items:center;gap:8px;padding:12px 20px;
  border-radius:12px;font-size:14px;font-weight:400;font-family:'Sarabun',sans-serif;
  cursor:pointer;border:none;transition:all .2s;flex:1;justify-content:center;min-width:130px;
}
.scan-hero-btn-primary{background:var(--accent);color:white;box-shadow:0 4px 14px rgba(217,119,6,.4)}
.scan-hero-btn-primary:hover{background:#b45309;transform:translateY(-1px);box-shadow:0 6px 20px rgba(217,119,6,.5)}
.scan-hero-btn-secondary{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.15)}
.scan-hero-btn-secondary:hover{background:rgba(255,255,255,.18)}

.scan-mini-status{display:none;text-align:center;padding:8px 0;margin-top:8px}
.spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 8px}
@keyframes spin{to{transform:rotate(360deg)}}
.scan-mini-status-txt{font-size:12px;color:rgba(255,255,255,.6)}

/* ===== BANK ACCOUNTS ===== */
.accounts-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:10px;padding:14px 16px;
}
.account-card{
  background:linear-gradient(135deg, #1c1b19, #2a2926);
  border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px;
  cursor:pointer;transition:all .2s;position:relative;overflow:hidden;
}
.account-card::before{
  content:'';position:absolute;top:-20px;right:-20px;
  width:80px;height:80px;border-radius:50%;
  background:rgba(217,119,6,.15);pointer-events:none;
}
.account-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.25);border-color:rgba(217,119,6,.4)}
.account-card.selected{border-color:var(--accent);background:linear-gradient(135deg,#2a2008,#1c1b19)}
.account-bank-icon{
  width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.7);
  margin-bottom:12px;
}
.account-name{font-size:13px;font-weight:400;color:rgba(255,255,255,.9)}
.account-balance{font-family:'IBM Plex Mono',monospace;font-size:18px;font-weight:400;color:var(--accent);margin-top:4px}
.account-add-card{
  background:rgba(255,255,255,.04);border:1.5px dashed rgba(255,255,255,.15);
  border-radius:14px;padding:16px;cursor:pointer;transition:all .2s;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  min-height:100px;
}
.account-add-card:hover{background:rgba(255,255,255,.08);border-color:var(--accent)}
.account-add-icon{font-size:20px;color:rgba(255,255,255,.3)}
.account-add-label{font-size:12px;color:rgba(255,255,255,.4);font-weight:400}

.account-add-form{
  display:none;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg);
}
.account-add-form.show{display:flex;gap:8px}

/* ===== SECTION HEADERS ===== */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.section-title{font-size:18px;font-weight:400}
.section-sub{font-size:12px;color:var(--muted);margin-top:2px}

/* ===== TABLE ===== */
.table-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.table-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.table-title{font-size:14px;font-weight:400}
table{width:100%;border-collapse:collapse}
thead th{padding:10px 16px;text-align:left;font-size:10px;font-weight:400;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--bg)}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
tbody tr:hover{background:#2a2d32;color:var(--text)}
tbody tr:last-child{border-bottom:none}
td{padding:11px 16px;font-size:13px}
.tx-type{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:400}
.tx-type.income{background:var(--income-light);color:var(--income-dark)}
.tx-type.expense{background:var(--expense-light);color:var(--expense-dark)}
.category-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:5px;font-size:10px;font-weight:400;background:var(--bg);color:var(--muted);border:1px solid var(--border)}

/* ===== SCAN PAGE ===== */
.scan-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:20px;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 24px}
.scan-step{display:flex;align-items:center;gap:8px;opacity:.4;transition:opacity .2s}
.scan-step.active{opacity:1}
.scan-step.done{opacity:.7}
.step-num{width:26px;height:26px;border-radius:50%;background:var(--border);color:var(--muted);font-size:12px;font-weight:400;display:flex;align-items:center;justify-content:center;transition:all .2s}
.scan-step.active .step-num{background:var(--accent);color:white}
.scan-step.done .step-num{background:var(--income);color:white}
.step-label{font-size:13px;font-weight:400}
.scan-step-line{width:40px;height:2px;background:var(--border);margin:0 8px;flex-shrink:0}
.scan-upload-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:600px;margin:0 auto}
.scan-tips{display:flex;gap:16px;margin-top:20px;justify-content:center;flex-wrap:wrap}
.scan-tip{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px}
.scan-analyzing-state{text-align:center;padding:40px 20px}
.upload-zone{border:2px dashed var(--border);border-radius:12px;padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg);position:relative}
.upload-zone:hover,.upload-zone.dragging{border-color:var(--accent);background:var(--accent-light)}
.scan-progress-wrap{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px}
.scan-progress-txt{font-size:12px;color:var(--muted);margin-bottom:8px}
.scan-progress-bar-bg{height:6px;background:var(--border);border-radius:4px;overflow:hidden}
.scan-progress-bar{height:100%;width:5%;background:var(--accent);border-radius:4px;transition:width .25s}
.scan-type-btn.active-income{background:var(--income-light)!important;color:var(--income-dark)!important;border-color:transparent}
.scan-type-btn.active-expense{background:var(--expense-light)!important;color:var(--expense-dark)!important;border-color:transparent}
.scan-history-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);transition:background .15s;cursor:default}
.scan-history-item:hover{background:#2a2d32}
.scan-history-item:last-child{border-bottom:none}
.scan-history-thumb{width:44px;height:44px;border-radius:8px;object-fit:cover;border:1px solid var(--border);background:var(--bg);flex-shrink:0;cursor:zoom-in}
.scan-history-info{flex:1;min-width:0}
.scan-history-desc{font-size:14px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scan-history-sub{font-size:11px;color:var(--muted);margin-top:2px}
.panel-split{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ===== MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;z-index:500}
.modal-overlay.show{display:flex}
.modal{background:var(--card);border-radius:18px;padding:24px;width:440px;max-width:96vw;box-shadow:0 24px 60px rgba(0,0,0,.25);max-height:90vh;overflow-y:auto}
.modal-title{font-size:18px;font-weight:400;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:12px;font-weight:400;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.form-control{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:9px;font-size:14px;font-family:'Sarabun',sans-serif;background:var(--card);color:var(--text);outline:none;transition:border-color .15s}
.form-control:focus{border-color:var(--accent)}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}

/* ===== APP MODAL ===== */
.modal-app{padding:0;width:480px;max-width:98vw;border-radius:20px;overflow:hidden;max-height:92vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.3);display:flex;flex-direction:column}
.app-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--sidebar-bg)}
.app-modal-header.income-mode{background:#065f46}
.app-modal-header.expense-mode{background:#7f1d1d}
.app-hdr-btn{width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:white;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.app-hdr-btn:hover{background:rgba(255,255,255,.22)}
.app-hdr-type-toggle{display:flex;gap:0;background:rgba(255,255,255,.1);border-radius:8px;overflow:hidden}
.app-hdr-type{padding:7px 18px;border:none;font-size:14px;font-weight:400;font-family:'Sarabun',sans-serif;cursor:pointer;color:rgba(255,255,255,.55);background:transparent;transition:all .15s;display:flex;align-items:center;gap:6px}
.app-hdr-type.active{background:rgba(255,255,255,.2);color:white}
.app-amount-hero{padding:22px 28px 18px;background:var(--sidebar-bg);display:flex;flex-direction:column;align-items:flex-start}
.app-amount-hero.income-mode{background:#065f46}
.app-amount-hero.expense-mode{background:#7f1d1d}
.app-amount-label{font-size:12px;color:rgba(255,255,255,.5);font-weight:400;margin-bottom:4px}
.app-amount-row{display:flex;align-items:baseline;gap:10px;width:100%}
.app-amount-input{flex:1;background:transparent;border:none;outline:none;font-size:38px;font-family:'IBM Plex Mono',monospace;font-weight:400;color:white;min-width:0}
.app-amount-input::placeholder{color:rgba(255,255,255,.2)}
.app-amount-unit{font-size:18px;color:rgba(255,255,255,.55);font-weight:400;white-space:nowrap}
.app-cards-row{display:grid;grid-template-columns:1fr 1fr;gap:0;border-bottom:1px solid var(--border);position:relative}
.app-cards-row::after{content:'';position:absolute;left:50%;top:12px;bottom:12px;width:1px;background:var(--border)}
.app-card{padding:14px 16px;cursor:pointer;position:relative;transition:background .15s}
.app-card:hover{background:#2a2d32}
.app-card-inner{display:flex;align-items:center;justify-content:space-between}
.app-card-left{display:flex;align-items:center;gap:10px}
.app-card-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.bank-icon{background:#e8f5e9;color:#1b5e20;border:2px solid #a5d6a7}
.cat-icon{background:#fff3e0;color:#e65100;border:2px solid #ffcc80}
.app-card-title{font-size:14px;font-weight:400;color:var(--text)}
.app-card-sub{font-size:11px;margin-top:1px}
.app-card-x{background:none;border:none;color:var(--muted);cursor:pointer;font-size:18px;padding:2px;transition:color .15s}
.app-card-x:hover{color:var(--expense)}
.app-picker{border-top:1px solid var(--border);margin:0 -16px -14px;background:var(--bg)}
.app-picker-title{padding:8px 14px;font-size:11px;font-weight:400;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px;cursor:pointer;border-bottom:1px solid var(--border)}
.app-picker-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--border);transition:background .1s}
.app-picker-item:hover{background:#2a2d32}
.app-picker-item.selected{background:var(--income-light);color:var(--income-dark);font-weight:400}
.app-detail-rows{background:var(--card)}
.app-detail-row{display:flex;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border);gap:14px}
.app-detail-row:last-child{border-bottom:none}
.app-detail-label{font-size:13px;color:var(--muted);white-space:nowrap;width:130px;display:flex;align-items:center;gap:8px;flex-shrink:0}
.app-detail-label i{width:16px;text-align:center;color:var(--muted)}
.app-detail-input{flex:1;border:none;outline:none;font-size:14px;font-family:'Sarabun',sans-serif;background:transparent;color:var(--text);text-align:right}
.app-detail-input::placeholder{color:#c8c4bb}
.dt-row{display:flex;gap:6px;justify-content:flex-end;align-items:center}
.dt-input{border:none;outline:none;font-size:13px;font-family:'Sarabun',sans-serif;background:var(--bg);border-radius:7px;padding:5px 8px;color:var(--text);border:1px solid var(--border);cursor:pointer}
.dt-input:focus{border-color:var(--accent);background:var(--accent-light)}
.time24-wrap{position:relative}
.time24-display{display:flex;align-items:center;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:5px 10px;cursor:pointer;font-family:'IBM Plex Mono',monospace;font-size:15px;font-weight:400;color:var(--text);user-select:none;transition:border-color .15s,background .15s;white-space:nowrap}
.time24-display:hover{border-color:var(--accent);background:var(--accent-light)}
.time24-colon{margin:0 1px;color:var(--muted)}
.time24-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);z-index:9999;overflow:hidden}
.time24-cols{display:flex;align-items:stretch}
.time24-col{width:64px;max-height:220px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.time24-col::-webkit-scrollbar{width:4px}
.time24-col::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.time24-sep{display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:400;color:var(--muted);padding:0 4px}
.time24-item{padding:9px 0;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:400;cursor:pointer;color:var(--muted);transition:background .1s,color .1s}
.time24-item:hover{background:var(--accent-light);color:var(--accent)}
.time24-item.selected{background:var(--accent);color:white;font-weight:400;border-radius:6px;margin:0 4px}
.app-photo-section{background:var(--bg);border-top:1px solid var(--border);padding:14px 20px;display:flex;flex-direction:column;align-items:center;gap:10px}
.app-photo-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 20px;border-radius:10px;border:1.5px dashed var(--border);background:var(--card);color:var(--muted);font-size:13px;font-weight:400;cursor:pointer;transition:all .15s;font-family:'Sarabun',sans-serif}
.app-photo-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}
.app-photo-preview{width:100%}
.app-photo-preview img{width:100%;max-height:180px;object-fit:contain;border-radius:10px;border:1px solid var(--border)}

/* BUDGET */
.budget-item{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:10px}
.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.budget-cat{font-size:14px;font-weight:400}
.budget-pct{font-size:12px;font-weight:400;padding:2px 8px;border-radius:20px}
.budget-pct.safe{background:var(--income-light);color:var(--income-dark)}
.budget-pct.warn{background:#fef3c7;color:#92400e}
.budget-pct.over{background:var(--expense-light);color:var(--expense-dark)}
.budget-track{height:8px;background:var(--bg);border-radius:4px;overflow:hidden;border:1px solid var(--border);margin-bottom:6px}
.budget-fill{height:100%;border-radius:4px;transition:width .5s ease}
.budget-fill.safe{background:var(--income)}
.budget-fill.warn{background:var(--budget-warn)}
.budget-fill.over{background:var(--budget-over)}
.budget-nums{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);font-family:'IBM Plex Mono',monospace}

/* CHART */
.chart-wrapper{padding:16px;height:260px;position:relative}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.bar-label{font-size:12px;width:80px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:8px;background:var(--bg);border-radius:4px;overflow:hidden;border:1px solid var(--border)}
.bar-fill{height:100%;border-radius:4px;transition:width .6s ease}
.bar-fill.income{background:var(--income)}
.bar-fill.expense{background:var(--expense)}
.bar-amount{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);width:80px;text-align:right}

/* REPORT */
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.chip-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.chip{padding:4px 10px;border-radius:20px;font-size:12px;cursor:pointer;border:1px solid var(--border);font-family:'Sarabun',sans-serif;background:var(--bg);color:var(--muted);transition:all .15s}
.chip.active{background:var(--text);color:white;border-color:var(--text)}

/* EMPTY STATE */
.empty-state{text-align:center;padding:36px 20px;color:var(--muted)}
.empty-icon{font-size:36px;margin-bottom:10px}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;padding:12px 18px;background:var(--text);color:white;border-radius:12px;font-size:14px;display:flex;align-items:center;gap:8px;transform:translateY(80px);opacity:0;transition:all .3s ease;z-index:9999;box-shadow:0 4px 20px rgba(0,0,0,.2);font-weight:400}
.toast.show{transform:translateY(0);opacity:1}
.toast.income{background:var(--income)}
.toast.expense{background:var(--expense)}

/* PAGINATION */
.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border)}
.page-info{font-size:13px;color:var(--muted)}

/* TABS */
.tab-bar{display:flex;border-bottom:1px solid var(--border);margin-bottom:16px}
.tab-btn{padding:10px 16px;font-size:13px;font-weight:400;cursor:pointer;border:none;background:none;font-family:'Sarabun',sans-serif;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}

/* LOCATION */
.location-row{cursor:pointer;transition:background .15s}
.location-row:hover{background:#2a2d32}
.location-display{flex:1;text-align:right;min-width:0}
.location-placeholder{color:#c8c4bb;font-size:14px}
.location-name{font-size:13px;color:var(--text);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;display:inline-block;vertical-align:middle}
.location-actions{display:flex;gap:6px;margin-left:8px;flex-shrink:0}
.loc-action-btn{width:30px;height:30px;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;background:var(--bg);color:var(--muted);transition:all .15s}
.loc-action-btn:hover{background:#1a3d1a;color:#4caf50}
.loc-action-btn.clear-loc:hover{background:#3d1a1a;color:#f44336}
.loc-modal{width:520px;max-width:98vw;padding:0;border-radius:18px;overflow:hidden;max-height:88vh;display:flex;flex-direction:column}
.loc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--card)}
.loc-search-bar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--card)}
.loc-search-input{flex:1;border:none;outline:none;font-size:15px;font-family:'Sarabun',sans-serif;background:transparent;color:var(--text)}
.loc-search-input::placeholder{color:#bbb}
.loc-search-clear{background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;padding:2px;display:flex}
.loc-search-clear:hover{color:var(--expense)}
.loc-gps-row{padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;gap:12px}
.loc-gps-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:10px;border:1.5px solid #4285f4;color:#4285f4;background:white;font-size:13px;font-weight:400;font-family:'Sarabun',sans-serif;cursor:pointer;transition:all .15s}
.loc-gps-btn:hover{background:rgba(255,193,7,.1);border-color:var(--accent)}
.loc-results{flex:1;overflow-y:auto;background:var(--card)}
.loc-result-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}
.loc-result-item:hover{background:#2a2d32}
.loc-result-item:last-child{border-bottom:none}
.loc-result-icon{width:36px;height:36px;border-radius:10px;background:#e8f0fe;color:#4285f4;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.loc-result-icon.gps-icon{background:#e8f5e9;color:#34a853}
.loc-result-name{font-size:14px;font-weight:400;color:var(--text)}
.loc-result-addr{font-size:12px;color:var(--muted);margin-top:2px}
.loc-result-dist{font-size:11px;color:var(--income);font-weight:400;margin-top:2px}
.loc-empty{text-align:center;padding:28px 20px;color:var(--muted)}
.loc-empty i{font-size:28px;display:block;margin-bottom:10px;opacity:.4}
.loc-selected-preview{padding:14px 16px;border-top:2px solid var(--income);background:#1a2e1a}
.loc-preview-inner{display:flex;align-items:center;gap:12px}
.loc-preview-icon{width:42px;height:42px;background:var(--income);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:18px;flex-shrink:0}
.loc-preview-info{flex:1;min-width:0}
.loc-preview-name{font-size:14px;font-weight:400;color:var(--income-dark)}
.loc-preview-addr{font-size:12px;color:var(--muted);margin-top:2px}
.loc-preview-coords{font-size:11px;color:var(--muted);font-family:'IBM Plex Mono',monospace;margin-top:3px}
.loc-map-open-btn{display:flex;flex-direction:column;align-items:center;padding:8px 12px;border-radius:10px;background:white;border:1.5px solid #4285f4;color:#4285f4;font-size:16px;text-decoration:none;flex-shrink:0;transition:all .15s;text-align:center}
.loc-map-open-btn:hover{background:rgba(255,255,255,.05)}

/* GALLERY */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:4px}
.gallery-item{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s}
.gallery-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.1)}
.gallery-thumb-wrap{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bg)}
.gallery-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}
.gallery-item:hover .gallery-thumb{transform:scale(1.04)}
.gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;gap:10px;opacity:0;transition:opacity .15s}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-dl-single,.gallery-del-btn{width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:transform .1s}
.gallery-dl-single{background:white;color:var(--income-dark)}
.gallery-del-btn{background:var(--expense-light);color:var(--expense)}
.gallery-dl-single:hover,.gallery-del-btn:hover{transform:scale(1.12)}
.gallery-info{padding:8px 10px}
.gallery-date{font-size:11px;color:var(--muted)}
.gallery-source{font-size:11px;color:var(--accent);font-weight:400;margin-top:2px}

/* ===== MONEY MANAGER DASHBOARD ===== */

/* Header banner */
.mm-header {
  background:var(--sidebar-bg);
  border-radius:12px;
  padding:12px 20px 16px;
  margin-bottom:0;
  border:1px solid rgba(255,255,255,.07);
  position:relative;overflow:hidden;
}
.mm-header::before {
  content:'';position:absolute;top:-60px;right:-60px;
  width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle, rgba(217,119,6,.18) 0%, transparent 70%);
  pointer-events:none;
}
.mm-header-top {
  display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px;
}
.mm-month-nav {
  display:flex;align-items:center;gap:8px;
}
.mm-month-label {
  font-size:16px;font-weight:400;color:var(--text);min-width:130px;text-align:center;
}
.mm-nav-btn {
  width:30px;height:30px;border-radius:8px;border:none;
  background:rgba(0,0,0,.06);color:var(--muted);
  font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.mm-nav-btn:hover{background:rgba(0,0,0,.1);color:var(--text)}

.mm-filter .filter-tab {
  color:rgba(0,0,0,.45);
}
.mm-filter.filter-tabs {
  background:rgba(0,0,0,.07);
}
.mm-filter .filter-tab.active {
  background:#ffffff;color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.1);
}

.mm-totals-row {
  display:flex;align-items:center;justify-content:space-between;gap:4px;
}
.mm-total-block {
  flex:1;
}
.mm-balance-block {
  text-align:center;
}
.mm-total-label {
  font-size:11px;color:var(--muted);font-weight:400;letter-spacing:.04em;margin-bottom:5px;
}
.mm-total-amount {
  font-family:'IBM Plex Mono',monospace;font-size:16px;font-weight:400;
}
.mm-total-amount.income{color:#16a34a}
.mm-total-amount.expense{color:#dc2626}
.mm-total-sub {
  font-size:11px;color:var(--muted);margin-top:3px;
}
.mm-total-divider {
  width:1px;height:52px;background:rgba(0,0,0,.1);flex-shrink:0;margin:0 8px;
}
.mm-balance-amount {
  font-family:'IBM Plex Mono',monospace;font-size:22px;font-weight:400;color:var(--text);
}
.mm-balance-amount.positive{color:#16a34a}
.mm-balance-amount.negative{color:#dc2626}

/* Transaction section */
.mm-tx-section {
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  overflow:hidden;margin-top:12px;margin-bottom:12px;
}
.mm-tx-list {}

/* Date group */
.mm-date-group {}
.mm-date-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 18px 7px;
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.mm-date-label {
  font-size:12px;font-weight:400;color:var(--muted);
}
.mm-date-totals {
  display:flex;gap:10px;font-size:12px;font-family:'IBM Plex Mono',monospace;font-weight:400;
}
.mm-day-inc{color:var(--income)}
.mm-day-exp{color:var(--expense)}

/* Transaction row */
.mm-tx-row {
  display:flex;align-items:center;gap:12px;padding:12px 18px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;
}
.mm-tx-row:hover{background:#2a2d32;color:var(--text)}
.mm-tx-row:last-child{border-bottom:none}
.mm-tx-icon {
  width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
}
.mm-tx-icon.income{background:var(--income-light);color:var(--income)}
.mm-tx-icon.expense{background:var(--expense-light);color:var(--expense)}
.mm-tx-body{flex:1;min-width:0}
.mm-tx-desc{font-size:14px;font-weight:400;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mm-tx-meta{display:flex;gap:7px;align-items:center;margin-top:3px;flex-wrap:wrap}
.mm-tx-cat{font-size:10px;font-weight:400;padding:1px 7px;border-radius:5px;background:var(--bg);color:var(--muted);border:1px solid var(--border)}
.mm-tx-time{font-size:11px;color:var(--muted);font-family:'IBM Plex Mono',monospace}
.mm-tx-amount{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:400;flex-shrink:0;white-space:nowrap}
.mm-tx-amount.income{color:var(--income)}
.mm-tx-amount.expense{color:var(--expense)}
.mm-slip-badge{font-size:12px}

/* See all button */
.mm-see-all-wrap{padding:10px 16px;border-top:1px solid var(--border);background:var(--bg)}
.mm-see-all-btn{
  width:100%;padding:9px;border-radius:10px;border:none;background:transparent;
  color:var(--muted);font-size:13px;font-weight:400;font-family:'Sarabun',sans-serif;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s;
}
.mm-see-all-btn:hover{background:rgba(255,255,255,.05);color:var(--text)}

/* Accounts section */
.mm-accounts-section {
  background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:16px;
}
.mm-accounts-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--border);
}
.mm-accounts-title {
  font-size:14px;font-weight:400;color:var(--text);display:flex;align-items:center;gap:8px;
}
.mm-accounts-title i{color:var(--accent)}
.mm-accounts-total-label{font-size:13px;font-weight:400;color:var(--muted);font-family:'IBM Plex Mono',monospace}

/* Account list rows */
.mm-accounts-list{}
.mm-acc-row {
  display:flex;align-items:center;gap:12px;padding:12px 18px;
  border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;
}
.mm-acc-row:hover{background:#2a2d32;color:var(--text)}
.mm-acc-icon {
  width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:15px;color:white;flex-shrink:0;
}
.mm-acc-info{flex:1;min-width:0}
.mm-acc-name{font-size:14px;font-weight:400;color:var(--text)}
.mm-acc-sub{font-size:11px;color:var(--muted);margin-top:1px}
.mm-acc-balance{font-family:'IBM Plex Mono',monospace;font-size:14px;font-weight:400;color:var(--text);flex-shrink:0;white-space:nowrap}
.mm-acc-balance.negative{color:var(--expense)}
.mm-acc-edit-btn{
  width:28px;height:28px;border-radius:8px;border:none;background:var(--bg);
  color:var(--muted);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .15s;
}
.mm-acc-edit-btn:hover{background:rgba(255,255,255,.08);color:var(--text)}
.mm-acc-add {
  padding:12px 18px;font-size:13px;font-weight:400;color:var(--accent);
  display:flex;align-items:center;gap:8px;cursor:pointer;transition:background .1s;
}
.mm-acc-add:hover{background:#2a2d32}

/* Category section inside accounts */
.mm-cat-section{
  padding:14px 18px;border-top:1px solid var(--border);
}
.mm-cat-title{
  font-size:12px;font-weight:400;color:var(--muted);
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;
}

/* ===== RESPONSIVE ===== */
@media(max-width:700px) {
  .main-content{padding:12px}
  .summary-grid{grid-template-columns:1fr 1fr}
  .summary-amount{font-size:18px}
  .panel-split{grid-template-columns:1fr!important}
  .report-grid{grid-template-columns:1fr}
  .accounts-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .topbar-actions .btn-export{display:none}
  .scan-hero-title{font-size:18px}
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
  .section-header{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px) {
  .summary-grid{grid-template-columns:1fr}
  .scan-hero-btns{flex-direction:column}
  .scan-hero-btn{min-width:unset}
}

/* ===== MONEY MANAGER LIGHT THEME ===== */
*, body { font-family:'Sarabun',sans-serif !important; }
body { background:var(--bg); color:var(--text); font-size:15px; }

.topbar { background:#ffffff; border-bottom:1px solid rgba(0,0,0,.08); box-shadow:0 1px 4px rgba(0,0,0,.06); }
.topbar-title { color:var(--text); }

.mm-date-header { background:#f9fafb; border-bottom:1px solid rgba(0,0,0,.06); }
.mm-date-label { color:var(--muted); font-size:13px; }
.mm-day-inc { color:#16a34a; }
.mm-day-exp { color:#dc2626; }

.mm-tx-row { background:#ffffff; border-bottom:1px solid rgba(0,0,0,.05); }
.tx-item { background:#ffffff; border-bottom:1px solid rgba(0,0,0,.05); }
.mm-tx-row:hover { background:#f9fafb; }
.tx-item:hover { background:#f9fafb; }

.mm-tx-icon, .tx-icon { border-radius:50% !important; width:42px; height:42px; }
.mm-tx-icon.income, .tx-icon.income { background:#dcfce7; color:#16a34a; }
.mm-tx-icon.expense, .tx-icon.expense { background:#fee2e2; color:#dc2626; }

.mm-tx-desc, .tx-desc { color:var(--text); font-size:15px; }
.mm-tx-amount.income, .tx-amount.income { color:#16a34a; }
.mm-tx-amount.expense, .tx-amount.expense { color:#dc2626; }
.mm-tx-cat, .tx-cat-badge { background:#f3f4f6; color:var(--muted); border:1px solid rgba(0,0,0,.06); }
.mm-tx-time { color:var(--muted); }

.section-card, .mm-tx-section, .mm-accounts-section, .table-card {
  background:#ffffff; border:1px solid rgba(0,0,0,.07); box-shadow:0 1px 4px rgba(0,0,0,.04); border-radius:12px;
}
.section-card-header { border-bottom:1px solid rgba(0,0,0,.07); }
.summary-card { background:#ffffff; border:1px solid rgba(0,0,0,.07); box-shadow:0 1px 4px rgba(0,0,0,.04); }

.mm-see-all-wrap { background:#f9fafb; border-top:1px solid rgba(0,0,0,.06); }
.mm-see-all-btn { color:var(--muted); }
.mm-see-all-btn:hover { background:rgba(0,0,0,.04); color:var(--text); }

.mm-acc-row { background:#ffffff; border-bottom:1px solid rgba(0,0,0,.05); }
.mm-acc-row:hover { background:#f9fafb; }
.mm-acc-name, .mm-acc-balance { color:var(--text); }
.mm-acc-balance.negative { color:#dc2626; }

.drawer { background:#ffffff; box-shadow:4px 0 24px rgba(0,0,0,.12); }
.drawer-header { border-bottom:1px solid rgba(0,0,0,.08); }
.drawer-nav-item.active { background:rgba(217,119,6,.1); color:var(--accent); }
.drawer-nav-item:hover { background:rgba(0,0,0,.04); color:var(--text); }
.drawer-close:hover { background:rgba(0,0,0,.06); color:var(--text); }
.drawer-logo-text { color:var(--text); }
.drawer-nav-item { color:var(--muted); }

.filter-tab.active { background:#ffffff; color:var(--text); box-shadow:0 1px 4px rgba(0,0,0,.08); }
.filter-tabs { background:#e5e7eb; }
.mm-filter.filter-tabs { background:rgba(0,0,0,.08); }
.mm-filter .filter-tab.active { background:rgba(255,255,255,.7); color:var(--text); box-shadow:none; }
.mm-filter .filter-tab { color:rgba(0,0,0,.5); }

.btn-primary, .btn-scan { background:var(--accent); color:#ffffff; }
.topbar-logo-icon, .drawer-logo-icon { background:var(--accent); color:#ffffff; }

.form-control { background:#ffffff; border:1px solid rgba(0,0,0,.12); color:var(--text); }
.form-control:focus { border-color:var(--accent); box-shadow:0 0 0 2px rgba(217,119,6,.12); }
.dt-input { background:#ffffff; border-color:rgba(0,0,0,.12); color:var(--text); }
select, input, textarea { background:#ffffff !important; color:var(--text) !important; border-color:rgba(0,0,0,.12) !important; }

.modal { background:#ffffff; color:var(--text); }
.modal-overlay { background:rgba(0,0,0,.45); }
thead th { background:#f9fafb; color:var(--muted); }
tbody tr:hover { background:#f9fafb; color:var(--text); }

.mm-header { background:#ffffff; border:1px solid rgba(0,0,0,.07); }
.mm-header::before { background:radial-gradient(circle, rgba(217,119,6,.12) 0%, transparent 70%); }
.mm-month-label { color:var(--text); }
.mm-nav-btn { background:rgba(0,0,0,.06); color:var(--muted); }
.mm-total-label { color:var(--muted); }
.mm-total-sub { color:var(--muted); }
.mm-total-divider { background:rgba(0,0,0,.1); }
.mm-balance-amount { color:var(--text); }
.mm-balance-amount.positive { color:#16a34a; }
.mm-balance-amount.negative { color:#dc2626; }
.mm-total-amount.income { color:#16a34a; }
.mm-total-amount.expense { color:#dc2626; }

.section-card-title i { color:var(--accent); }
.account-card { background:linear-gradient(135deg,#ffffff,#f9fafb); border:1px solid rgba(0,0,0,.08); }
.account-card:hover { border-color:rgba(217,119,6,.4); box-shadow:0 4px 16px rgba(0,0,0,.08); }
.account-name { color:var(--text); }
.account-balance { color:var(--accent); }

.scan-hero { background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%); border:1px solid rgba(217,119,6,.2); }
.scan-hero-title { color:var(--text); }
.scan-hero-sub { color:var(--muted); }

.app-modal-header { background:#f9fafb; }
.app-modal-header.income-mode { background:#dcfce7; }
.app-modal-header.expense-mode { background:#fee2e2; }
.app-amount-hero { background:#f9fafb; }
.app-amount-hero.income-mode { background:#dcfce7; }
.app-amount-hero.expense-mode { background:#fee2e2; }
.app-amount-input { color:var(--text); }
.app-amount-input::placeholder { color:rgba(0,0,0,.2); }
.app-amount-unit { color:var(--muted); }
.app-hdr-btn { background:rgba(0,0,0,.08); color:var(--text); }
.app-hdr-type-toggle { background:rgba(0,0,0,.08); }
.app-hdr-type { color:var(--muted); }
.app-hdr-type.active { background:rgba(255,255,255,.7); color:var(--text); }
.app-detail-input { color:var(--text); }
.app-detail-input::placeholder { color:rgba(0,0,0,.25); }
.app-card:hover { background:#f9fafb; }
.app-picker { background:#f3f4f6; }
.app-picker-item:hover { background:#e5e7eb; }

.time24-display { background:#ffffff; border-color:rgba(0,0,0,.12); color:var(--text); }
.time24-dropdown { background:#ffffff; border-color:rgba(0,0,0,.1); }
.time24-item { color:var(--muted); }
.time24-item:hover { background:var(--accent-light); color:var(--accent); }

.upload-zone { background:#f9fafb; border-color:rgba(0,0,0,.12); }
.scan-upload-card { background:#ffffff; border-color:rgba(0,0,0,.08); }

.loc-gps-btn { background:#f0f9ff; border-color:#3b82f6; color:#2563eb; }
.loc-results { background:#ffffff; }
.loc-result-item:hover { background:#f9fafb; }
.loc-modal-header { background:#ffffff; }
.loc-search-bar { background:#ffffff; }
.loc-gps-row { background:#f9fafb; }
.loc-selected-preview { background:#f0fdf4; border-top:2px solid #16a34a; }

::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:rgba(0,0,0,.15); border-radius:3px; }
