/* ============================================================
   style.css — DL Money v3.1
   Theme: Dark header + Yellow accent (ไม่มีสีดำลอย)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&family=Outfit:wght@300;400;500;600;700&family=Orbitron:wght@700;900&display=swap');

:root {
  --bg:         #f5f5f0;
  --surface:    #ffffff;
  --card:       #ffffff;
  --border:     rgba(0,0,0,0.08);
  --border-bright: rgba(0,0,0,0.15);
  --accent:     #f59e0b;
  --accent-dim: rgba(245,158,11,0.12);
  --accent2:    #f97316;
  --red:        #dc2626;
  --red-dim:    rgba(220,38,38,0.10);
  --green:      #16a34a;
  --text:       #1a1a1a;
  --text-dark:  #111111;
  --text-muted: #9ca3af;
  --text-sub:   #6b7280;
  --mono:       "JetBrains Mono","Courier New",monospace;
  --sans:       "Outfit","Helvetica Neue",sans-serif;
  --display:    "Space Grotesk","Helvetica Neue",sans-serif;
  --shadow:     0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md:  0 4px 6px rgba(0,0,0,0.07), 0 2px 4px rgba(0,0,0,0.06);
  /* safe-area ใช้ทั่ว */
  --sat: env(safe-area-inset-top, 0px);
  --iv-accent: #00D4FF;
  --iv-accent-dim: rgba(0,212,255,0.12);
  --iv-red: #FF4466;
  --iv-yellow: #ffb400;
  --sab: env(safe-area-inset-bottom, 0px);
}

/* ══ DARK MODE — Bitkub Style ══ */
body.dark-mode {
  --bg:         #0B0E11;
  --surface:    #161B22;
  --card:       #1C2127;
  --border:     rgba(255,255,255,0.07);
  --border-bright: rgba(245,158,11,0.4);
  --accent-dim: rgba(245,158,11,0.15);
  --text:       #E6EDF3;
  --text-dark:  #F0F6FC;
  --text-muted: #8B949E;
  --text-sub:   #6E7681;
  --shadow:     0 4px 16px rgba(0,0,0,0.6), 0 1px 4px rgba(0,0,0,0.4);
  --shadow-md:  0 12px 40px rgba(0,0,0,0.7), 0 4px 12px rgba(0,0,0,0.5);
  --red-dim:    rgba(220,38,38,0.15);
}
body.dark-mode { background:#0B0E11; }
body.dark-mode .page, body.dark-mode .wrapper { background:#0B0E11; }
body.dark-mode .box {
  background:linear-gradient(160deg,#1C2127 0%,#161B22 100%);
  border:1px solid rgba(255,255,255,0.06);
  box-shadow:0 4px 20px rgba(0,0,0,0.4);
}
body.dark-mode .box:focus-within {
  border-color:rgba(245,158,11,0.35);
  box-shadow:0 4px 20px rgba(245,158,11,0.12);
}
body.dark-mode .page0-header,
body.dark-mode .page-header-bar {
  background:rgba(11,14,17,0.15);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:none;
  box-shadow:none;
  color:var(--accent);
}
body.dark-mode .nav {
  background:linear-gradient(135deg,rgba(22,27,34,0.98) 0%,rgba(28,33,39,0.98) 100%);
  border-top:1px solid rgba(245,158,11,0.2);
  box-shadow:0 -4px 24px rgba(0,0,0,0.5);
}
body.dark-mode input, body.dark-mode select, body.dark-mode textarea {
  background:#0D1117 !important;color:#E6EDF3 !important;border-color:rgba(255,255,255,0.1) !important;
}
body.dark-mode input::placeholder { color:#6E7681; }
body.dark-mode input:focus { border-color:rgba(245,158,11,0.5) !important; background:#0D1117 !important; }
body.dark-mode .modal-backdrop { background:rgba(0,0,0,0.75); }
body.dark-mode .modal-sheet {
  background:linear-gradient(160deg,#1C2127 0%,#161B22 100%) !important;
  border:1px solid rgba(255,255,255,0.07);
  box-shadow:0 24px 64px rgba(0,0,0,0.7);
}
body.dark-mode .modal-title { color:#F0F6FC !important; }
body.dark-mode .btn-ghost { background:#1C2127 !important;border-color:rgba(255,255,255,0.1) !important;color:#8B949E !important; }
body.dark-mode .btn-link { color:#f59e0b; }
body.dark-mode .hist-tx-row { background:#1C2127;border-bottom:1px solid rgba(255,255,255,0.05); }
body.dark-mode .hist-tx-row:hover { background:#21262D; }
body.dark-mode .hist-day-header { background:#161B22; }
body.dark-mode .hist-balance-bar { background:#161B22; }
body.dark-mode .hist-day-items { background:#1C2127; }
body.dark-mode .hist-filter-row { background:#0B0E11; }
body.dark-mode .hist-filter-btn { background:#1C2127; border-color:rgba(255,255,255,0.08); color:#8B949E; }
body.dark-mode .hist-toolbar { background:#161B22; }
body.dark-mode .hist-search-wrap { background:#0D1117; border-color:rgba(255,255,255,0.1); }
body.dark-mode .loginCard {
  background:linear-gradient(160deg,#1C2127 0%,#161B22 100%) !important;
  border:1px solid rgba(255,255,255,0.07);
}
body.dark-mode .loginInput { background:#0D1117 !important;border-color:rgba(255,255,255,0.1) !important;color:#E6EDF3 !important; }
body.dark-mode .loginTabs { background:#0D1117 !important; }
body.dark-mode .loginTabBtn { color:#8B949E; }
body.dark-mode .stat-mini { background:#1C2127 !important; border-color:rgba(255,255,255,0.06) !important; }
body.dark-mode #darkModeBtn { background:rgba(245,158,11,0.15);border-color:rgba(245,158,11,0.3); }
body.dark-mode .selActive { background:linear-gradient(135deg,#f59e0b,#f97316) !important; color:#fff !important; }
body.dark-mode .btn-logout { background:#1C2127 !important; color:#4ade80 !important; border-color:rgba(74,222,128,0.2) !important; }
body.dark-mode .wealth-grid > div { background:#1C2127 !important; border-color:rgba(255,255,255,0.06) !important; }
body.dark-mode .topic-entry-card { background:#1C2127 !important; border-color:rgba(255,255,255,0.06) !important; }
body, .box, .page, .nav, .modal-sheet, input, select, textarea,
.hist-tx-row, .page0-header, .page-header-bar,
.hist-day-group, .hist-day-items, .hist-day-header,
.hist-balance-bar, .hist-toolbar, .hist-filter-row, .hist-filter-btn,
.hist-search-wrap,
.summary-balance, .month-card,
.topic-card, .topic-entry-card,
.rec-row,
.wealth-item-row,
.stat-mini,
.loginCard, .loginTabs, .loginInput,
.modal-backdrop,
.typeSelector, .cat-btn,
.btn-ghost, .btn-logout {
  transition:background-color 0.35s ease,background 0.35s ease,color 0.25s ease,border-color 0.25s ease,box-shadow 0.35s ease;
}


*{box-sizing:border-box;margin:0;padding:0}
html{overflow:hidden;height:100%;width:100%;background:#1a1a1a;transition:background-color 0.35s ease;}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  width:100vw;height:100vh;
  overflow:hidden;position:fixed;top:0;left:0;
  -webkit-font-smoothing:antialiased;
}

/* ══════════════════════════════════════════════
   SPLASH — เหมือน DL Invest (progress bar + glow)
══════════════════════════════════════════════ */
#splashScreen{
  position:fixed;inset:0;z-index:99999;
  background:#0f0f0f;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.splash-ring{
  position:absolute;border-radius:50%;
  border:1.5px solid rgba(245,158,11,0.15);
  animation:splashRingPulse 3s ease-in-out infinite;
}
.splash-ring1{width:280px;height:280px;animation-delay:0s;}
.splash-ring2{width:420px;height:420px;animation-delay:0.6s;border-color:rgba(245,158,11,0.08);}
@keyframes splashRingPulse{
  0%,100%{transform:scale(1);opacity:0.5}
  50%{transform:scale(1.04);opacity:1}
}
.splash-inner{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  position:relative;z-index:2;
}
.splash-logo-wrap{position:relative;display:flex;align-items:center;justify-content:center;}
.splash-glow{
  position:absolute;width:420px;height:420px;
  background:radial-gradient(circle,rgba(245,158,11,0.45) 0%,transparent 65%);
  border-radius:50%;z-index:0;
  animation:splashGlowPulse 2s ease-in-out infinite;
}
@keyframes splashGlowPulse{0%,100%{opacity:0.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}

@keyframes spMonkey{
  0%{opacity:0;transform:scale(0.3) rotate(-15deg)}
  65%{transform:scale(1.1) rotate(4deg)}
  80%{transform:scale(0.96) rotate(-2deg)}
  100%{opacity:1;transform:scale(1) rotate(0deg)}
}
.splash-monkey{
  width:280px;height:280px;object-fit:contain;
  animation:spMonkey 0.9s cubic-bezier(.34,1.56,.64,1) both;
  filter:drop-shadow(0 0 40px rgba(245,158,11,0.8)) brightness(1.1) contrast(1.1);
  mix-blend-mode:screen;
  position:relative;z-index:1;
  background:transparent;border:none;border-radius:0;
}
.splash-title{
  animation:spTitle 0.5s ease 0.7s both;
  display:flex;align-items:baseline;gap:8px;
}
@keyframes spTitle{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.splash-dl{
  font-family:'Orbitron',monospace;font-size:52px;font-weight:900;
  color:#f59e0b;letter-spacing:2px;
  text-shadow:0 0 24px rgba(245,158,11,0.7);
}
.splash-name{
  font-family:'Orbitron',monospace;font-size:30px;font-weight:700;
  color:#fff;letter-spacing:4px;
}
.splash-sub{
  font-family:var(--mono);font-size:12px;color:#666;
  letter-spacing:3px;
  animation:spSub 0.4s ease 1.1s both;
}
@keyframes spSub{from{opacity:0}to{opacity:1}}
.splash-bar-wrap{
  width:180px;margin-top:8px;
  animation:spSub 0.4s ease 1.2s both;
}
.splash-bar{
  background:rgba(255,255,255,0.08);
  border-radius:10px;height:4px;overflow:hidden;
}
.splash-bar-fill{
  height:100%;width:0%;
  background:linear-gradient(90deg,#f59e0b,#f97316);
  border-radius:10px;
  transition:width 0.1s linear;
}
.splash-pct{
  font-family:var(--mono);font-size:10px;color:#555;
  text-align:center;margin-top:6px;letter-spacing:1px;
}

/* ══════════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════════ */
.wrapper{
  display:flex;width:600vw;height:100vh;
  transition:transform 0.42s cubic-bezier(0.4,0,0.2,1);
  will-change:transform;
  background:var(--bg);
}
.page{
  width:100vw;min-width:100vw;max-width:100vw;
  height:100vh;
  overflow-y:auto;overflow-x:hidden;
  padding-bottom:calc(68px + var(--sab) + 16px);
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
  background:var(--bg);
  /* ป้องกัน overscroll เห็นพื้นหลังดำ */
  overscroll-behavior-y:none;
}
.page::-webkit-scrollbar{display:none}
.page>*{animation:fadeUp 0.28s ease both}
.page>*:nth-child(1){animation-delay:0.02s}
.page>*:nth-child(2){animation-delay:0.05s}
.page>*:nth-child(3){animation-delay:0.08s}
.page>*:nth-child(4){animation-delay:0.11s}
.page>*:nth-child(5){animation-delay:0.14s}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ══════════════════════════════════════════════
   PAGE 0 HEADER — safe-area + สีส้ม ตัวหนังสือ
══════════════════════════════════════════════ */
.page0-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 16px 18px;
  padding-top:calc(var(--status-bar-height) + 18px);
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:none;
  position:sticky;top:0;z-index:5;
}
.page0-logo{display:flex;align-items:center;gap:8px;font-family:var(--display);font-size:20px;font-weight:700;color:var(--text-dark);}
.page0-brand{color:var(--accent);}

/* PAGE HEADER BAR (pages 1-5) */
.page-header-bar{
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:var(--accent);
  font-family:var(--display);font-size:16px;font-weight:700;
  padding:16px 16px 18px;
  padding-top:calc(var(--status-bar-height) + 18px);
  letter-spacing:0.02em;
  border-bottom:none;
  position:sticky;top:0;z-index:5;
  /* animation เมื่อเข้าหน้า */
  animation:headerSlideIn 0.32s cubic-bezier(0.4,0,0.2,1) both;
}
@keyframes headerSlideIn{
  from{ opacity:0; transform:translateY(-8px); }
  to{   opacity:1; transform:translateY(0);     }
}

/* ══════════════════════════════════════════════
   BOX
══════════════════════════════════════════════ */
.box{
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  padding:16px;margin:10px 14px 0;
  box-shadow:var(--shadow);transition:box-shadow 0.2s;
}
.box:focus-within{box-shadow:var(--shadow-md);border-color:var(--accent);}
.boxLabel{
  font-family:var(--mono);font-size:10px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--accent);
  margin-bottom:12px;font-weight:600;
}
.box-row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}

/* box กดได้ (รายรับ/รายจ่ายแยกหมวด) */
.box-tap{cursor:pointer;transition:background 0.15s,box-shadow 0.15s;}
.box-tap:active{background:#fef9ec;box-shadow:var(--shadow-md);}
.box-tap-row{display:flex;justify-content:space-between;align-items:center;}

/* ══════════════════════════════════════════════
   ย้อนหลัง 6 เดือน — horizontal scroll cards
══════════════════════════════════════════════ */
.hscroll-wrap{overflow-x:auto;margin:0 -4px;padding:4px;scrollbar-width:none;}
.hscroll-wrap::-webkit-scrollbar{display:none}
.hscroll-inner{display:flex;gap:10px;padding-bottom:4px;width:max-content;}
.month-card{
  background:var(--card);border:1.5px solid var(--border);border-radius:14px;
  padding:12px 14px;min-width:110px;flex-shrink:0;
}
.month-card-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);margin-bottom:8px;font-weight:600;}
.month-card-income{font-family:var(--mono);font-size:11px;color:#16a34a;font-weight:700;}
.month-card-expense{font-family:var(--mono);font-size:11px;color:#dc2626;font-weight:700;margin-top:2px;}
.month-card-balance{
  font-family:var(--mono);font-size:10px;
  margin-top:6px;padding-top:6px;
  border-top:1px solid var(--border);
  color:var(--text-muted);
}
.month-card.current-month{
  border-color:rgba(245,158,11,0.5);
  background:rgba(245,158,11,0.07);
}

/* ══════════════════════════════════════════════
   INPUTS
══════════════════════════════════════════════ */
input,select{
  width:100%;padding:12px 14px;
  background:var(--card);border:1.5px solid var(--border);border-radius:12px;
  color:var(--text);font-family:var(--mono);font-size:14px;
  margin-bottom:10px;appearance:none;-webkit-appearance:none;
  transition:border-color 0.2s,box-shadow 0.2s;outline:none;
}
input:focus,select:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(245,158,11,0.15);}
input::placeholder{color:#c4c4c4}
.pw-wrap{position:relative;}
.pw-wrap input{padding-right:44px;}
.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-60%);background:none;border:none;color:var(--text-muted);font-size:16px;padding:4px;width:auto;margin:0;cursor:pointer;}

/* ══════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════ */
button{
  padding:11px 16px;border:none;border-radius:12px;
  font-family:var(--display);font-weight:600;font-size:13px;
  cursor:pointer;transition:opacity 0.2s,transform 0.15s,box-shadow 0.2s;
  letter-spacing:0.01em;
}
button:hover{opacity:0.88;transform:translateY(-1px)}
button:active{transform:translateY(0);opacity:1}
.green{
  background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;
  width:100%;padding:14px;font-size:14px;font-weight:700;
  margin-top:4px;box-shadow:0 2px 8px rgba(245,158,11,0.35);border-radius:14px;
}
.btn-ghost{
  background:var(--card);border:1.5px solid var(--border);border-radius:10px;
  color:var(--text-sub);font-family:var(--mono);font-size:11px;padding:7px 12px;width:auto;
}
.btn-link{background:none;border:none;color:var(--accent);font-family:var(--mono);font-size:11px;padding:0;width:auto;font-weight:600;}
.btn-logout{
  background:#fef2f2;color:var(--red);border:1.5px solid rgba(220,38,38,0.2);border-radius:14px;
  font-family:var(--mono);font-size:13px;font-weight:600;padding:14px;
  width:calc(100% - 28px);margin:12px 14px 20px;
}
.btn-edit{background:rgba(245,158,11,0.1);color:var(--accent);border:1px solid rgba(245,158,11,0.25);border-radius:7px;font-size:11px;padding:4px 8px;width:auto;}
.btn-del{background:transparent;color:var(--red);border:1px solid rgba(220,38,38,0.25);border-radius:7px;font-size:11px;padding:4px 8px;width:auto;}
.btn-accent-sm{
  background:var(--accent-dim);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.35);border-radius:10px;
  font-family:var(--mono);font-size:11px;font-weight:700;
  padding:6px 12px;width:auto;
}
.btn-scan{
  background:rgba(245,158,11,0.1);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.3);border-radius:12px;
  font-family:var(--mono);font-size:12px;padding:11px;width:100%;margin-bottom:0;font-weight:600;
}
.btn-confirm-scan{
  background:rgba(22,163,74,0.1);color:var(--green);
  border:1.5px solid rgba(22,163,74,0.3);border-radius:12px;
  font-family:var(--mono);font-size:12px;padding:11px;width:100%;font-weight:600;
}
.quick-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px;margin-top:-4px;}
.chip{
  background:var(--card);border:1.5px solid var(--border);border-radius:8px;
  color:var(--text-sub);font-family:var(--mono);font-size:11px;padding:5px 10px;width:auto;
}
.chip:hover{background:var(--accent-dim);color:var(--accent);border-color:rgba(245,158,11,0.4);opacity:1;}
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;padding:10px 12px;}
.filter-btn{
  background:var(--card);border:1.5px solid var(--border);border-radius:8px;
  color:var(--text-sub);font-family:var(--mono);font-size:11px;padding:6px 12px;width:auto;
}

/* ══════════════════════════════════════════════
   TYPE SELECTOR
══════════════════════════════════════════════ */
.typeSelector{
  display:flex;gap:4px;margin-bottom:14px;
  background:var(--surface);border-radius:14px;padding:4px;
}
.typeSelector button{
  flex:1;background:transparent;color:var(--text-muted);border:none;
  border-radius:10px;font-family:var(--mono);font-size:11px;font-weight:500;
  padding:10px 6px;cursor:pointer;transition:all 0.2s;letter-spacing:0.03em;
}
.typeSelector button:hover{color:var(--text);background:rgba(0,0,0,0.05);opacity:1;transform:none;}
.selActive{
  background:linear-gradient(135deg,#f59e0b,#f97316)!important;
  color:#fff!important;font-weight:700!important;
  box-shadow:0 2px 6px rgba(245,158,11,0.3);
}

/* ══════════════════════════════════════════════
   CATEGORY PICKER
══════════════════════════════════════════════ */
.cat-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:12px;}
.cat-btn{
  background:var(--card);border:1.5px solid var(--border);border-radius:10px;
  padding:8px 4px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;width:100%;height:56px;cursor:pointer;transition:all 0.2s;color:var(--text-sub);
}
.cat-btn:hover{background:var(--accent-dim);border-color:rgba(245,158,11,0.4);color:var(--accent);opacity:1;transform:none;}
.cat-btn--active{background:rgba(245,158,11,0.15)!important;border-color:rgba(245,158,11,0.5)!important;color:var(--accent)!important;box-shadow:0 2px 6px rgba(245,158,11,0.2);}
.cat-btn-icon{font-size:20px;}
.cat-btn-label{font-family:var(--mono);font-size:9px;color:inherit;font-weight:500;}

/* ══════════════════════════════════════════════
   SUMMARY
══════════════════════════════════════════════ */
.summary-grid{padding:0;overflow:hidden;margin:10px 14px 0;}
.summary-month-row{
  width:100%;padding:10px 14px 0;
  display:flex;justify-content:space-between;align-items:center;
}
.btn-month-pick{
  background:var(--accent-dim);
  border:1.5px solid rgba(245,158,11,0.35);
  border-radius:20px;
  color:var(--accent);
  font-family:var(--mono);font-size:11px;font-weight:700;
  padding:5px 12px;width:auto;
  cursor:pointer;
}
.btn-month-pick:hover{background:rgba(245,158,11,0.2);opacity:1;transform:none;}
.summary-half{padding:12px 14px;display:inline-block;width:50%;vertical-align:top;}
.summary-half--left{border-right:1px solid var(--border);}
.summary-amount{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--text-dark);}
.summary-amount--income{color:#16a34a;}
.summary-amount--expense{color:#dc2626;}
.summary-balance{
  clear:both;padding:12px 14px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  background:var(--surface);border-radius:0 0 16px 16px;
}

/* ══════════════════════════════════════════════
   BUDGET
══════════════════════════════════════════════ */
.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.budget-remain{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:600;}
.budget-track{background:var(--surface);border-radius:6px;height:10px;overflow:hidden;}
.budget-fill{height:100%;border-radius:6px;transition:width 0.6s ease;background:#16a34a;}
.budget-msg{font-family:var(--mono);font-size:10px;color:var(--text-muted);margin-top:6px;}

/* ══════════════════════════════════════════════
   TOPIC LIST (หน้าติดตาม)
══════════════════════════════════════════════ */
.topic-card{
  background:var(--card);border:1.5px solid var(--border);border-radius:14px;
  padding:14px;margin-bottom:12px;
}
.topic-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.topic-name{font-family:var(--display);font-size:16px;font-weight:700;color:var(--text-dark);}
.topic-total{
  font-family:var(--mono);font-size:24px;font-weight:700;color:var(--accent);
  margin:6px 0 10px;
}
.topic-month-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);margin-bottom:2px;}

/* รายการที่บันทึก — แต่ละกล่องแยก */
.topic-entry-list{display:flex;flex-direction:column;gap:8px;}
.topic-entry-card{
  background:var(--card);border:1.5px solid var(--border);border-radius:10px;
  padding:10px 12px;
  display:flex;justify-content:space-between;align-items:center;
}
.topic-entry-card-left{display:flex;flex-direction:column;gap:2px;}
.topic-entry-date{font-family:var(--mono);font-size:10px;color:var(--text-muted);}
.topic-entry-note{font-family:var(--sans);font-size:13px;color:var(--text-dark);font-weight:500;}
.topic-entry-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.topic-entry-amount{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--accent);}
.topic-entry-del{
  background:none;border:1px solid rgba(220,38,38,0.25);border-radius:6px;
  color:var(--red);font-size:11px;padding:3px 7px;width:auto;cursor:pointer;
}

.topic-btn-add{
  width:100%;background:var(--accent-dim);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.35);border-radius:10px;
  font-family:var(--mono);font-size:12px;font-weight:700;
  padding:9px;cursor:pointer;
}
.topic-btn-del{
  background:transparent;color:var(--red);
  border:1px solid rgba(220,38,38,0.25);border-radius:10px;
  font-family:var(--mono);font-size:11px;padding:5px 10px;width:auto;
}

/* ══════════════════════════════════════════════
   TX ITEMS
══════════════════════════════════════════════ */
.tx-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.tx-item:last-child{border-bottom:none;}
.tx-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.tx-info{flex:1;min-width:0;}
.tx-label{font-size:13px;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;}
.tx-date{font-family:var(--mono);font-size:10px;color:var(--text-muted);margin-top:2px;}
.tx-right{display:flex;align-items:center;gap:5px;flex-shrink:0;}
.tx-amount{font-family:var(--mono);font-size:13px;font-weight:700;}

/* ══════════════════════════════════════════════
   ROW
══════════════════════════════════════════════ */
.row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--border);
  font-size:13px;color:var(--text-sub);
}
.row:last-child{border-bottom:none;}
.row span{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text-dark);}
.empty-msg{font-family:var(--mono);font-size:12px;color:var(--text-muted);text-align:center;padding:16px;line-height:1.8;}

/* ══════════════════════════════════════════════
   OCR
══════════════════════════════════════════════ */
.ocr-desc{font-family:var(--mono);font-size:11px;color:var(--text-muted);margin-bottom:12px;line-height:1.7;}
.scan-loading{text-align:center;padding:14px;font-family:var(--mono);font-size:12px;color:var(--accent);}

/* ══════════════════════════════════════════════
   SEARCH
══════════════════════════════════════════════ */
.search-wrap{display:flex;align-items:center;gap:8px;}
.search-icon{font-size:16px;flex-shrink:0;}
.search-input{
  margin-bottom:0;background:transparent;border:none;
  font-family:var(--mono);font-size:13px;padding:6px 0;flex:1;color:var(--text);
}
.search-input:focus{background:transparent;border:none;box-shadow:none;}



/* ══════════════════════════════════════════════
   STATS
══════════════════════════════════════════════ */
.stat-mini{background:var(--card);border:1.5px solid var(--border);border-radius:12px;padding:10px 8px;text-align:center;}
.stat-mini-label{font-family:var(--mono);font-size:9px;color:var(--text-muted);margin-bottom:4px;font-weight:500;}
.stat-mini-val{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text-dark);}

/* ══════════════════════════════════════════════
   COLLAPSE
══════════════════════════════════════════════ */
.collapse-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none;}
.collapseArrow{font-size:10px;color:var(--text-muted);transition:transform 0.2s;}

/* ══════════════════════════════════════════════
   PROFILE
══════════════════════════════════════════════ */
.profile-card{text-align:center;padding:24px 16px;display:flex;flex-direction:column;align-items:center;}
.avatar-wrap{position:relative;display:inline-block;margin-bottom:12px;}
.avatar-emoji{font-size:64px;line-height:1;}
.avatar-img{width:90px;height:90px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 0 0 4px rgba(245,158,11,0.15);}
.avatar-edit-btn{position:absolute;bottom:-2px;right:-2px;background:var(--accent);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;box-shadow:0 2px 6px rgba(245,158,11,0.4);}
.profile-name{font-family:var(--display);font-size:20px;font-weight:700;color:var(--text-dark);margin-bottom:4px;}
.profile-email{font-family:var(--mono);font-size:12px;color:var(--text-muted);margin-top:4px;}
.pass-msg{font-family:var(--mono);font-size:12px;margin-bottom:10px;padding:10px;border-radius:10px;background:var(--card);}

/* ══════════════════════════════════════════════
   BOTTOM NAV — แก้ข้อ 6 (safe-area + ไม่บัง)
══════════════════════════════════════════════ */
.nav{
  position:fixed;bottom:0;left:0;width:100%;
  background:rgba(245,158,11,0.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;align-items:stretch;
  padding:6px 0 calc(6px + var(--sab));
  border-top:2px solid rgba(255,255,255,0.25);z-index:10;
  box-shadow:0 -4px 20px rgba(0,0,0,0.08);
}
.nav button{
  flex:1;min-width:0;
  background:none;border:none;color:rgba(255,255,255,0.65);
  font-family:var(--mono);font-size:9px;font-weight:500;
  letter-spacing:0.04em;text-transform:uppercase;
  padding:6px 2px;border-radius:10px;
  transition:color 0.2s,background 0.2s;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
}
.nav button:hover{color:#fff;background:rgba(255,255,255,0.15);opacity:1;transform:none;}
.navActive{color:#fff!important;background:rgba(255,255,255,0.22)!important;}
.navIcon{font-size:20px;display:block;}
.navTxt{font-size:9px;display:block;}

/* ══════════════════════════════════════════════
   LOGIN
══════════════════════════════════════════════ */
.loginScreen{position:fixed;inset:0;background:#1a1a1a;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;}
.loginCard{background:#fff;border-radius:24px;padding:36px 22px;width:100%;max-width:360px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,0.4);}
.loginLogo{font-size:48px;margin-bottom:10px;}
.loginTitle{font-family:var(--display);font-size:24px;font-weight:700;color:#1a1a1a;margin-bottom:4px;}
.loginSub{font-family:var(--mono);font-size:11px;color:#9ca3af;margin-bottom:22px;}
.loginTabs{display:flex;gap:4px;background:var(--surface);border-radius:14px;padding:4px;margin-bottom:16px;}
.loginTabBtn{flex:1;background:transparent;color:#9ca3af;border:none;border-radius:10px;font-family:var(--mono);font-size:11px;font-weight:500;padding:10px 6px;cursor:pointer;transition:all 0.2s;}
.loginTabBtn:hover{background:rgba(0,0,0,0.05);opacity:1;transform:none;}
.loginTabActive{background:linear-gradient(135deg,#f59e0b,#f97316)!important;color:#fff!important;font-weight:700!important;box-shadow:0 2px 8px rgba(245,158,11,0.35);}
.loginInput{width:100%;padding:12px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;color:#1a1a1a;font-family:var(--mono);font-size:13px;margin-bottom:10px;outline:none;transition:border-color 0.2s;display:block;}
.loginInput:focus{border-color:#f59e0b;box-shadow:0 0 0 3px rgba(245,158,11,0.15);}
.loginInput::placeholder{color:#c4c4c4;}
.loginBtn{display:block;width:100%;padding:14px 20px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;border-radius:12px;font-family:var(--display);font-size:14px;font-weight:700;cursor:pointer;transition:all 0.2s;margin-bottom:10px;box-shadow:0 2px 10px rgba(245,158,11,0.35);}
.loginBtn:hover{opacity:0.88;transform:translateY(-1px);}
.forgotLink{font-family:var(--mono);font-size:11px;color:#9ca3af;cursor:pointer;text-decoration:underline;margin-top:4px;}
.forgotLink:hover{color:var(--accent);}
.login-hint{font-family:var(--mono);font-size:10px;color:#9ca3af;margin-top:8px;line-height:1.6;}
.login-msg{font-family:var(--mono);font-size:12px;margin-top:10px;padding:10px;border-radius:10px;}
.login-msg--error{color:#dc2626;background:#fef2f2;}
.login-msg--success{color:#16a34a;background:#f0fdf4;}

/* ══════════════════════════════════════════════
   MODALS — แก้ข้อ 7 (ขนาด popup พอดี)
══════════════════════════════════════════════ */
.modal-backdrop{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.55);
  display:flex;align-items:flex-end;justify-content:center;
}
.modal-sheet{
  background:var(--card);
  border-radius:24px 24px 0 0;
  padding:24px 18px calc(24px + var(--sab));
  width:100%;max-width:480px;
  border-top:2px solid var(--accent);
  max-height:80vh;          /* แก้ข้อ 7: ไม่ใหญ่เกิน */
  overflow-y:auto;
  animation:slideUp 0.32s cubic-bezier(0.32,0.72,0,1) both;
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-title{font-family:var(--display);font-size:17px;font-weight:700;margin-bottom:16px;color:var(--text-dark);}
.modal-body{font-family:var(--mono);font-size:12px;color:#6b7280;line-height:2;}
.month-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:280px;overflow-y:auto;}
.month-btn{background:var(--card);border:1.5px solid var(--border);border-radius:12px;color:#6b7280;font-family:var(--mono);font-size:12px;padding:12px 8px;width:100%;}
.month-btn--active{background:rgba(245,158,11,0.15)!important;border-color:rgba(245,158,11,0.5)!important;color:var(--accent)!important;font-weight:700;}
.month-btn:hover{background:var(--accent-dim);color:var(--accent);opacity:1;}

/* ══════════════════════════════════════════════
   PULL INDICATOR
══════════════════════════════════════════════ */
.pull-indicator{height:32px;display:none;text-align:center;padding-top:6px;color:var(--accent);font-family:var(--mono);font-size:12px;}

/* ══════════════════════════════════════════════
   TOAST
══════════════════════════════════════════════ */
.toast{
  position:fixed;bottom:calc(84px + var(--sab));left:50%;
  transform:translateX(-50%) translateY(20px);
  background:#1a1a1a;border:2px solid var(--accent);border-radius:14px;
  padding:10px 20px;font-family:var(--mono);font-size:13px;color:#fff;
  z-index:99998;opacity:0;transition:all 0.3s;
  white-space:nowrap;pointer-events:none;
  box-shadow:0 4px 16px rgba(245,158,11,0.3);
}
.toast--show{opacity:1;transform:translateX(-50%) translateY(0);}

@media(max-width:400px){
  .splash-dl{font-size:44px;}
  .splash-name{font-size:26px;}
}

/* ══════════════════════════════════════════════
   HISTORY PAGE — แบบแอปธนาคาร
══════════════════════════════════════════════ */

/* Summary bar — ยอดคงเหลือ */
.hist-balance-bar{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--surface);
  padding:12px 16px;
  border-bottom:1px solid var(--border);
}
.hist-balance-label{
  font-family:var(--mono);font-size:11px;color:var(--text-muted);
  font-weight:600;text-transform:uppercase;letter-spacing:0.08em;
}
.hist-balance-val{
  font-family:var(--mono);font-size:18px;font-weight:700;color:var(--text-dark);
}

/* Toolbar: เลือกเดือน + ค้นหา */
.hist-toolbar{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
}
.hist-month-btn{
  background:var(--accent-dim);
  border:1.5px solid rgba(245,158,11,0.4);
  border-radius:20px;color:var(--accent);
  font-family:var(--mono);font-size:11px;font-weight:700;
  padding:6px 14px;width:auto;white-space:nowrap;
  flex-shrink:0;
}
.hist-month-btn:hover{background:rgba(245,158,11,0.2);opacity:1;transform:none;}
.hist-search-wrap{
  flex:1;display:flex;align-items:center;gap:6px;
  background:var(--surface);border-radius:20px;
  padding:6px 12px;
}
.hist-search-input{
  border:none;background:transparent;
  font-family:var(--mono);font-size:12px;color:var(--text);
  padding:0;margin:0;flex:1;outline:none;
}
.hist-search-input:focus{border:none;box-shadow:none;background:transparent;}

/* Filter ทั้งหมด/รายรับ/รายจ่าย */
.hist-filter-row{
  display:flex;gap:6px;
  padding:10px 14px 8px;
  background:var(--bg);
  border-bottom:2px solid var(--border);
}
.hist-filter-btn{
  flex:1;background:var(--card);border:1.5px solid var(--border);
  border-radius:20px;color:var(--text-sub);
  font-family:var(--mono);font-size:11px;font-weight:600;
  padding:7px 4px;
}
.hist-filter-btn:hover{background:var(--accent-dim);color:var(--accent);opacity:1;transform:none;}
.hist-filter-active{
  background:linear-gradient(135deg,#f59e0b,#f97316)!important;
  color:#fff!important;border-color:transparent!important;
  box-shadow:0 2px 6px rgba(245,158,11,0.3);
}

/* กลุ่มวัน */
.hist-day-group{
  background:var(--card);
  margin-bottom:8px;
  border-bottom:1px solid var(--border);
}
.hist-day-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 16px 6px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:2;
}
.hist-day-label{
  font-family:var(--mono);font-size:11px;font-weight:700;
  color:var(--text-sub);
}
.hist-day-net{
  font-family:var(--mono);font-size:11px;font-weight:700;
}
.hist-day-items{
  background:var(--card);
}

/* แต่ละรายการ */
.hist-tx-row{
  display:flex;align-items:center;gap:12px;
  padding:13px 16px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background 0.15s;
  -webkit-tap-highlight-color:transparent;
}
.hist-tx-row:last-child{border-bottom:none;}
.hist-tx-row:active{background:#fef9ec;}
.hist-tx-icon{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;
}
.hist-tx-info{flex:1;min-width:0;}
.hist-tx-label{
  font-family:var(--sans);font-size:14px;font-weight:600;
  color:var(--text-dark);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hist-tx-sub{
  font-family:var(--mono);font-size:10px;color:var(--text-muted);margin-top:2px;
}
.hist-tx-amount{
  font-family:var(--mono);font-size:15px;font-weight:700;
  flex-shrink:0;
}

/* TX Detail popup rows */
.hist-detail-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0;border-bottom:1px solid var(--border);
  font-family:var(--mono);font-size:12px;
}
.hist-detail-row:last-child{border-bottom:none;}
.hist-detail-row span:first-child{color:var(--text-muted);}
.hist-detail-row span:last-child{color:var(--text-dark);font-weight:600;text-align:right;max-width:60%;}

/* ══════════════════════════════════════════════
   RECURRING
══════════════════════════════════════════════ */
.rec-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0;border-bottom:1px solid var(--border);
}
.rec-row:last-child{border-bottom:none;}
.rec-row-info{display:flex;flex-direction:column;gap:3px;}
.rec-row-name{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--text-dark);}
.rec-row-amt{font-family:var(--mono);font-size:13px;font-weight:700;}
.rec-apply-btn{
  background:rgba(245,158,11,0.12);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.4);border-radius:10px;
  font-family:var(--mono);font-size:11px;font-weight:700;
  padding:6px 12px;width:auto;
}
.rec-apply-btn:hover{background:var(--accent-dim);opacity:1;transform:none;}
.rec-done-badge{
  font-family:var(--mono);font-size:11px;color:#16a34a;
  background:rgba(22,163,74,0.1);border-radius:8px;padding:4px 8px;
}

/* ══════════════════════════════════════════════
   WEALTH PAGE — สินทรัพย์ & หนี้สิน
══════════════════════════════════════════════ */
.wealth-total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 0 0;
  border-top:1.5px solid var(--border);
  margin-top:8px;
}
.wealth-item-row{
  display:flex;align-items:center;gap:10px;
  padding:11px 0;border-bottom:1px solid var(--border);
}
.wealth-item-row:last-child{border-bottom:none;}
.wealth-item-num{
  font-family:var(--mono);font-size:10px;color:var(--text-muted);
  width:18px;text-align:center;flex-shrink:0;
}
.wealth-item-name{
  flex:1;font-family:var(--sans);font-size:14px;
  font-weight:600;color:var(--text-dark);
}
.wealth-item-amount{
  font-family:var(--mono);font-size:14px;font-weight:700;
}
.wealth-item-del{
  background:none;border:1px solid rgba(220,38,38,0.25);border-radius:6px;
  color:var(--red);font-size:11px;padding:3px 7px;width:auto;cursor:pointer;
}
/* ══════════════════════════════════════════════
   MANUAL ENTRY MODE
══════════════════════════════════════════════ */
.manual-item-row{
  display:flex;align-items:center;gap:6px;
  margin-bottom:8px;
}
.manual-item-num{
  font-family:var(--mono);font-size:10px;color:var(--text-muted);
  width:16px;flex-shrink:0;text-align:center;
}
.manual-item-name{
  flex:2;margin-bottom:0;padding:10px 12px;font-size:13px;
}
.manual-item-amount{
  flex:1;margin-bottom:0;padding:10px 12px;font-size:13px;
  min-width:0;
}

/* ══════════════════════════════════════════════
   ONBOARDING
══════════════════════════════════════════════ */
.ob-slide{
  width:25%;flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 32px 140px;
  color:#fff;text-align:center;
}
.ob-emoji{font-size:64px;margin-bottom:16px;animation:fadeUp 0.5s ease both;}
.ob-title{
  font-family:'Orbitron',monospace;font-size:22px;font-weight:700;
  color:#f59e0b;margin-bottom:14px;letter-spacing:0.02em;
  animation:fadeUp 0.5s ease 0.1s both;
}
.ob-desc{
  font-family:var(--sans);font-size:14px;color:#9ca3af;
  line-height:1.8;max-width:280px;margin-bottom:24px;
  animation:fadeUp 0.5s ease 0.15s both;
}
.ob-img-box{
  width:100%;max-width:300px;
  animation:fadeUp 0.5s ease 0.2s both;
}
.ob-mock{
  background:rgba(255,255,255,0.06);border:1.5px solid rgba(245,158,11,0.25);
  border-radius:16px;padding:16px;text-align:left;
}
.ob-mock-row{
  font-family:monospace;font-size:13px;padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.ob-mock-row:last-child{border-bottom:none;}
.ob-mock-row.green{color:#4ade80;}
.ob-mock-row.red{color:#f87171;}
.ob-mock-row.accent{color:#f59e0b;}
.ob-mock-row.muted{color:#6b7280;}
.ob-mock-row.white{color:#e5e7eb;}
.ob-mock-tab{
  display:flex;gap:8px;margin-bottom:10px;
  background:rgba(255,255,255,0.08);border-radius:10px;padding:4px;
}
.ob-tab-active{
  flex:1;text-align:center;background:linear-gradient(135deg,#f59e0b,#f97316);
  color:#fff;border-radius:8px;padding:6px;font-family:monospace;font-size:11px;font-weight:700;
}
.ob-tab{
  flex:1;text-align:center;color:#6b7280;
  padding:6px;font-family:monospace;font-size:11px;
}
.ob-bottom{
  position:fixed;bottom:0;left:0;width:100%;
  padding:16px 24px calc(24px + env(safe-area-inset-bottom,0px));
  background:linear-gradient(to top,#0f0f0f 60%,transparent);
}
.ob-dots{display:flex;justify-content:center;gap:8px;margin-bottom:20px;}
.ob-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.2);transition:all 0.3s;
}
.ob-dot-active{
  background:#f59e0b;width:24px;border-radius:4px;
}
.ob-nav-row{display:flex;justify-content:space-between;align-items:center;}
.ob-btn-skip{
  background:none;border:none;color:#6b7280;
  font-family:var(--mono);font-size:13px;padding:10px;width:auto;
}
.ob-btn-next{
  background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;
  border:none;border-radius:14px;padding:12px 28px;
  font-family:var(--display);font-size:14px;font-weight:700;width:auto;
}
.ob-btn-start{
  background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;
  border:none;border-radius:16px;padding:14px 40px;
  font-family:var(--display);font-size:15px;font-weight:700;
  width:100%;max-width:280px;margin-top:16px;
  box-shadow:0 4px 20px rgba(245,158,11,0.4);
  animation:fadeUp 0.5s ease 0.3s both;
}

/* ══════════════════════════════════════════════
   UI POLISH v2 — Animation, Cards, Buttons
══════════════════════════════════════════════ */

/* ── 1. Page transition ลื่นขึ้น ── */
#wrapper {
  transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ── 2. Card polish — shadow + depth ── */
.box {
  border-radius: 20px !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06), 0 1px 3px rgba(0,0,0,0.04) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  transition: box-shadow 0.2s, transform 0.2s;
}
.box:has(button:active) {
  transform: scale(0.995);
}

/* ── 3. Summary card upgrade ── */
.summary-grid {
  background: var(--card) !important;
  border: 1.5px solid rgba(245,158,11,0.2) !important;
  box-shadow: 0 4px 20px rgba(245,158,11,0.12), 0 1px 4px rgba(0,0,0,0.06) !important;
}
.summary-amount {
  font-size: 24px !important;
  letter-spacing: -0.02em;
}
.summary-balance {
  background: var(--surface) !important;
}

/* ── 4. ปุ่มหลัก ripple + press effect ── */
.green {
  position: relative;
  overflow: hidden;
  border-radius: 16px !important;
  padding: 15px !important;
  font-size: 15px !important;
  box-shadow: 0 4px 16px rgba(245,158,11,0.4), 0 1px 4px rgba(0,0,0,0.1) !important;
  transition: transform 0.15s, box-shadow 0.15s, opacity 0.15s !important;
  letter-spacing: 0.02em;
}
.green:active {
  transform: scale(0.97) translateY(1px) !important;
  box-shadow: 0 2px 8px rgba(245,158,11,0.3) !important;
  opacity: 0.95 !important;
}

/* ripple effect */
.green::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.15);
  opacity: 0;
  border-radius: inherit;
  transition: opacity 0.3s;
}
.green:active::after {
  opacity: 1;
}

/* ── 5. Month card upgrade ── */
.month-card {
  border-radius: 16px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
  transition: transform 0.2s, box-shadow 0.2s;
  background: var(--card) !important;
}
.month-card:active {
  transform: scale(0.96);
}
.month-card.current-month {
  background: linear-gradient(145deg, rgba(245,158,11,0.1) 0%, rgba(249,115,22,0.06) 100%) !important;
  box-shadow: 0 2px 12px rgba(245,158,11,0.2) !important;
}

/* ── 6. TX item upgrade ── */
.tx-item {
  padding: 12px 4px !important;
  transition: background 0.15s;
  border-radius: 10px;
  margin: 0 -4px;
  padding-left: 8px !important;
  padding-right: 4px !important;
}
.tx-item:active {
  background: rgba(245,158,11,0.06);
}
.tx-icon {
  border-radius: 12px !important;
  width: 40px !important;
  height: 40px !important;
  font-size: 20px !important;
}

/* ── 7. Nav upgrade ── */
.nav button {
  transition: transform 0.15s, color 0.15s, background 0.15s !important;
  border-radius: 12px !important;
}
.navActive {
  transform: translateY(-1px);
}
.navIcon {
  font-size: 22px !important;
  transition: transform 0.2s;
}
.navActive .navIcon {
  transform: scale(1.15);
}

/* ── 8. Modal upgrade ── */
.modal-sheet {
  border-radius: 28px 28px 0 0 !important;
  box-shadow: 0 -8px 40px rgba(0,0,0,0.15) !important;
}
@keyframes slideUp {
  from { transform: translateY(100%); opacity: 0.8; }
  to   { transform: translateY(0);    opacity: 1; }
}

/* ── 9. Budget bar upgrade ── */
.budget-track {
  height: 12px !important;
  border-radius: 8px !important;
  background: var(--surface) !important;
  overflow: hidden;
}
.budget-fill {
  border-radius: 8px !important;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15) inset;
}

/* ── 10. TypeSelector upgrade ── */
.typeSelector {
  background: var(--surface) !important;
  border-radius: 16px !important;
  padding: 5px !important;
}
.typeSelector button {
  border-radius: 12px !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.selActive {
  box-shadow: 0 3px 10px rgba(245,158,11,0.4) !important;
  transform: none !important;
}

/* ── 11. Input focus upgrade ── */
input:focus, select:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 4px rgba(245,158,11,0.12) !important;
  background: var(--card) !important;
  transform: none;
}

/* ── 12. Toast upgrade ── */
.toast {
  border-radius: 16px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  font-size: 13px !important;
  padding: 12px 20px !important;
  animation: toastIn 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}
@keyframes toastIn {
  from { transform: translateX(-50%) translateY(12px) scale(0.9); opacity: 0; }
  to   { transform: translateX(-50%) translateY(0) scale(1); opacity: 1; }
}

/* ── 13. Summary amount number animation ── */
@keyframes countUp {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.summary-amount {
  animation: countUp 0.3s ease both;
}

/* ── 14. Page header bar upgrade ── */
.page-header-bar, .page0-header {
  border-bottom: none !important;
}
.page-header-bar {
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em;
  padding-left: 16px !important;
  padding-right: 16px !important;
  padding-bottom: 14px !important;
  padding-top:calc(var(--status-bar-height) + 18px) !important;
}
.page0-header {
  padding-left: 16px !important;
  padding-right: 16px !important;
  padding-bottom: 10px !important;
  padding-top:calc(var(--status-bar-height) + 18px) !important;
}

/* ── 15. Cat btn upgrade ── */
.cat-btn {
  border-radius: 14px !important;
  height: 60px !important;
  transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.cat-btn:active {
  transform: scale(0.93) !important;
}
.cat-btn--active {
  box-shadow: 0 3px 12px rgba(245,158,11,0.3) !important;
  transform: scale(1.02);
}

/* ── 16. Chip upgrade ── */
.chip {
  border-radius: 10px !important;
  transition: all 0.15s !important;
  font-weight: 600 !important;
}
.chip:active {
  transform: scale(0.93) !important;
}

/* ── 17. Rec row upgrade ── */
.rec-row {
  border-radius: 14px !important;
  background: var(--card);
  border: 1.5px solid var(--border);
  padding: 12px 14px !important;
  margin-bottom: 8px;
  transition: background 0.15s;
}

/* ── 18. Topic card upgrade ── */
.topic-card {
  border-radius: 18px !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.06) !important;
  transition: transform 0.2s, box-shadow 0.2s;
}

/* ── 19. Scroll smooth ── */
.page {
  scroll-behavior: smooth;
}
.page-scroll {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
/* ══ Dark mode extra fixes ══ */
body.dark-mode .typeSelector { background:#161B22; }
body.dark-mode .typeSelector button { color:#6E7681; background:transparent; }
body.dark-mode .typeSelector button:hover { background:rgba(255,255,255,0.05); color:#E6EDF3; }
body.dark-mode .summary-balance { background:#0D1F17; }
body.dark-mode .topic-card { background:#1C2127; border-color:rgba(255,255,255,0.06); }
body.dark-mode .cat-btn { background:#1C2127; border-color:rgba(255,255,255,0.06); color:#E6EDF3; }
body.dark-mode .cat-btn--active { background:rgba(245,158,11,0.2); border-color:rgba(245,158,11,0.4); }
body.dark-mode .budget-track { background:#161B22; }
/* ข้อ 4 fix: เพิ่ม dark override สำหรับ elements ที่เคยค้าง */
body.dark-mode .rec-row { background:#1C2127; border-color:rgba(255,255,255,0.06); }
body.dark-mode .wealth-item-row { border-color:rgba(255,255,255,0.06); }
body.dark-mode .month-card { background:#1C2127; border-color:rgba(255,255,255,0.08); }
body.dark-mode .month-card.current-month { background:rgba(245,158,11,0.1); border-color:rgba(245,158,11,0.4); }
body.dark-mode .summary-balance { background:#0D1F17; border-color:rgba(255,255,255,0.06); }
body.dark-mode .hist-day-group { background:#1C2127; border-color:rgba(255,255,255,0.05); }
body.dark-mode .profile-card { background:transparent; }
body.dark-mode .row { border-color:rgba(255,255,255,0.06); color:#8B949E; }
body.dark-mode .collapseArrow { color:#6E7681; }
/* กัน background ดำค้างเมื่อ toggle กลับ light mode */
body:not(.dark-mode) .rec-row { background:var(--card); border-color:var(--border); }
body:not(.dark-mode) .month-card { background:var(--card); border-color:var(--border); }
body:not(.dark-mode) .hist-day-group { background:var(--card); }
body:not(.dark-mode) .hist-day-items { background:var(--card); }
body:not(.dark-mode) .hist-day-header { background:var(--surface); }
body:not(.dark-mode) .hist-balance-bar { background:var(--surface); }
body:not(.dark-mode) .hist-toolbar { background:var(--surface); }
body:not(.dark-mode) .summary-balance { background:var(--surface); }
/* ══════════════════════════════════════════════
   PORTAL — หน้าประตูกระเป๋า
══════════════════════════════════════════════ */

/* Portal screen */
#portalScreen{
  position:fixed;inset:0;z-index:100;
  background:var(--bg);
  display:flex;flex-direction:column;
}
.portal-wrapper{
  display:flex;width:300vw;height:100%;
  transition:transform 0.42s cubic-bezier(0.4,0,0.2,1);
  will-change:transform;
}
.portal-page{
  width:100vw;min-width:100vw;height:100%;
  overflow-y:auto;overflow-x:hidden;
  padding-bottom:calc(72px + env(safe-area-inset-bottom,0px) + 16px);
  background:var(--bg);
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.portal-page::-webkit-scrollbar{display:none}

/* Portal header — glassmorphism เหมือน DL Money */
.portal-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 16px 18px;
  padding-top:calc(var(--status-bar-height) + 18px);
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:none;
  position:sticky;top:0;z-index:5;
  color:var(--accent);
  font-family:var(--display);font-size:16px;font-weight:700;
  animation:headerSlideIn 0.32s cubic-bezier(0.4,0,0.2,1) both;
}
body.dark-mode .portal-header{
  background:rgba(11,14,17,0.15);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:var(--accent);
}

/* Wallet section title */
.portal-section-title{
  padding:16px 16px 4px;
  font-family:var(--display);font-size:18px;font-weight:700;
  color:var(--text-dark);
}
.portal-section-sub{
  padding:0 16px 12px;
  font-family:var(--mono);font-size:11px;color:var(--text-muted);
}

/* Wallet card */
.wallet-card{
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:20px;
  padding:16px 18px;
  margin:0 14px 12px;
  display:flex;justify-content:space-between;align-items:center;
  cursor:pointer;
  transition:all 0.2s cubic-bezier(0.4,0,0.2,1);
  box-shadow:0 2px 12px rgba(0,0,0,0.06),0 1px 3px rgba(0,0,0,0.04);
  position:relative;
  overflow:hidden;
}
.wallet-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(245,158,11,0.04),rgba(249,115,22,0.02));
  opacity:0;transition:opacity 0.2s;
}
.wallet-card:active{
  transform:scale(0.97);
  box-shadow:0 1px 4px rgba(0,0,0,0.08);
}
.wallet-card:active::before{ opacity:1; }
.wallet-card-left{flex:1;min-width:0;}
.wallet-mode-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--mono);font-size:10px;font-weight:700;
  padding:3px 10px;border-radius:20px;
  margin-bottom:6px;
}
.wallet-name{
  font-family:var(--display);font-size:16px;font-weight:700;
  color:var(--text-dark);margin-bottom:4px;
}
.wallet-summary-row{
  display:flex;align-items:center;gap:4px;
  font-family:var(--mono);font-size:11px;
}
.wallet-card-right{
  text-align:right;flex-shrink:0;margin-left:16px;
  display:flex;flex-direction:column;align-items:flex-end;gap:4px;
}
.wallet-balance{
  font-family:var(--mono);font-size:20px;font-weight:700;
  letter-spacing:-0.02em;
}
.wallet-arrow{
  font-family:var(--mono);font-size:18px;color:var(--text-muted);
  font-weight:400;line-height:1;
}

/* Empty state */
.portal-empty{
  text-align:center;padding:48px 20px;
}

/* Add wallet button */
.add-wallet-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin:4px 14px 0;padding:16px;
  background:var(--accent-dim);
  border:2px dashed rgba(245,158,11,0.4);
  border-radius:20px;cursor:pointer;
  transition:all 0.2s;color:var(--accent);
  font-family:var(--display);font-size:14px;font-weight:700;
}
.add-wallet-btn:active{background:rgba(245,158,11,0.2);transform:scale(0.98);}

/* Dark mode wallet */
body.dark-mode .wallet-card{
  background:linear-gradient(160deg,#1C2127 0%,#161B22 100%);
  border-color:rgba(255,255,255,0.06);
  box-shadow:0 4px 20px rgba(0,0,0,0.4);
}
body.dark-mode .add-wallet-btn{
  background:rgba(245,158,11,0.08);
  border-color:rgba(245,158,11,0.25);
}

/* ══ MODE SCREEN — ปุ่มกลับ ══ */
.mode-top-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(var(--status-bar-height) + 12px) 16px 10px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:none;
  flex-shrink:0;z-index:10;
  min-height:50px;
}
body.dark-mode .mode-top-bar{
  background:rgba(11,14,17,0.15);
}
.mode-title{
  font-family:var(--display);font-size:15px;font-weight:700;
  color:var(--accent);flex:1;text-align:center;
}

/* ปุ่มกลับ float ซ้าย */
.btn-back-portal{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  background:rgba(245,158,11,0.12);
  border:1.5px solid rgba(245,158,11,0.3);
  border-radius:50%;
  color:var(--accent);
  font-size:20px;font-weight:700;
  cursor:pointer;transition:all 0.15s;
  flex-shrink:0;
  line-height:1;
  padding:0;
}
.btn-back-portal:active{
  background:rgba(245,158,11,0.25);
  transform:scale(0.92);
}
body.dark-mode .btn-back-portal{
  background:rgba(245,158,11,0.15);
  border-color:rgba(245,158,11,0.4);
}

/* ── inline back (ใน page0 ของ mode) ── */
.btn-back-float-inline{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(245,158,11,0.1);
  border:1.5px solid rgba(245,158,11,0.3);
  border-radius:20px;
  color:var(--accent);
  font-family:var(--mono);font-size:11px;font-weight:700;
  padding:5px 12px;cursor:pointer;
  transition:all 0.15s;width:auto;
}
.btn-back-float-inline:active{
  background:rgba(245,158,11,0.2);
  transform:scale(0.95);
}

/* Portal nav */
.portal-page, .portal-wrapper{
  transition:background-color 0.35s ease;
}