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

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Kanit:wght@300;400;500;600;700&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:         #f2f2f7;
  --surface:    #ffffff;
  --card:       #ffffff;
  --border:     rgba(0,0,0,0.07);
  --border-bright: rgba(0,0,0,0.12);
  --accent:     #f59e0b;
  --accent-dim: rgba(245,158,11,0.10);
  --accent2:    #f97316;
  --red:        #dc2626;
  --red-dim:    rgba(220,38,38,0.10);
  --green:      #16a34a;
  /* ตัวเลขบวก/ลบ — สบายตาแต่ชัดเจน */
  --num-pos:    #059669;
  --num-neg:    #e11d48;
  --text:       #1c1c1e;
  --text-dark:  #0a0a0b;
  --text-muted: rgba(60,60,67,0.45);
  --text-sub:   rgba(60,60,67,0.6);
  --mono:       "Inter","JetBrains Mono","Courier New",monospace;
  --sans:       "Inter","Kanit","Outfit","Helvetica Neue",sans-serif;
  --display:    "Inter","Space Grotesk","Helvetica Neue",sans-serif;
  --shadow:     0 2px 16px rgba(0,0,0,0.06), 0 1px 4px rgba(0,0,0,0.04);
  --shadow-md:  0 8px 32px rgba(0,0,0,0.08), 0 2px 8px rgba(0,0,0,0.05);
  --shadow-lg:  0 16px 48px rgba(0,0,0,0.10), 0 4px 16px 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);
  --radius-sm:  12px;
  --radius-md:  16px;
  --radius-lg:  20px;
  --radius-xl:  24px;
}

/* ══ 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.12);
  --text:       #E6EDF3;
  --text-dark:  #F0F6FC;
  --text-muted: rgba(230,237,243,0.4);
  --text-sub:   rgba(230,237,243,0.55);
  --shadow:     0 4px 24px rgba(0,0,0,0.5), 0 1px 6px rgba(0,0,0,0.35);
  --shadow-md:  0 12px 48px rgba(0,0,0,0.65), 0 4px 16px rgba(0,0,0,0.45);
  --shadow-lg:  0 24px 64px rgba(0,0,0,0.75), 0 8px 24px rgba(0,0,0,0.5);
  --red-dim:    rgba(220,38,38,0.15);
  --num-pos:    #34d399;
  --num-neg:    #fb7185;
}
body.dark-mode { background:#0B0E11; }
body.dark-mode .page, body.dark-mode .wrapper { background:#0B0E11; }
body.dark-mode .box {
  background:linear-gradient(160deg,rgba(28,33,39,0.95) 0%,rgba(22,27,34,0.95) 100%);
  border:1px solid rgba(255,255,255,0.06);
  box-shadow:0 4px 24px rgba(0,0,0,0.35), 0 1px 4px rgba(0,0,0,0.2);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
body.dark-mode .box:focus-within {
  border-color:rgba(245,158,11,0.3);
  box-shadow:0 4px 24px rgba(245,158,11,0.10), 0 0 0 1px rgba(245,158,11,0.15);
}
body.dark-mode .page0-header,
body.dark-mode .page-header-bar {
  background:rgba(11,14,17,0.75);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.05);
  box-shadow:0 1px 0 rgba(255,255,255,0.04);
  color:var(--accent);
}
body.dark-mode .nav {
  background:linear-gradient(135deg,rgba(15,50,25,0.97) 0%,rgba(20,60,30,0.97) 100%);
  border-top:1px solid rgba(22,163,74,0.2);
  box-shadow:0 -8px 32px rgba(0,0,0,0.4);
}
body.dark-mode input, body.dark-mode select, body.dark-mode textarea {
  background:rgba(13,17,23,0.8) !important;color:#E6EDF3 !important;border-color:rgba(255,255,255,0.08) !important;
}
body.dark-mode input::placeholder { color:rgba(230,237,243,0.3); }
body.dark-mode input:focus { border-color:rgba(245,158,11,0.45) !important; background:rgba(13,17,23,0.9) !important; box-shadow:0 0 0 3px rgba(245,158,11,0.10) !important; }
body.dark-mode .modal-backdrop { background:rgba(0,0,0,0.8); backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); }
body.dark-mode .modal-sheet {
  background:linear-gradient(160deg,rgba(28,33,39,0.98) 0%,rgba(22,27,34,0.98) 100%) !important;
  border:1px solid rgba(255,255,255,0.07);
  box-shadow:0 -8px 48px rgba(0,0,0,0.6);
}
body.dark-mode .modal-title { color:#F0F6FC !important; }
body.dark-mode .btn-ghost { background:rgba(28,33,39,0.8) !important;border-color:rgba(255,255,255,0.08) !important;color:rgba(139,148,158,0.9) !important; }
body.dark-mode .btn-link { color:#f59e0b; }
body.dark-mode .hist-tx-row { background:rgba(28,33,39,0.6);border-bottom:1px solid rgba(255,255,255,0.04); }
body.dark-mode .hist-tx-row:hover { background:rgba(33,38,45,0.8); }
body.dark-mode .hist-day-header { background:rgba(22,27,34,0.9); }
body.dark-mode .hist-balance-bar { background:rgba(22,27,34,0.9); }
body.dark-mode .hist-day-items { background:rgba(28,33,39,0.6); }
body.dark-mode .hist-filter-row { background:#0B0E11; }
body.dark-mode .hist-filter-btn { background:rgba(28,33,39,0.7); border-color:rgba(255,255,255,0.06); color:rgba(139,148,158,0.9); }
body.dark-mode .hist-toolbar { background:rgba(22,27,34,0.9); }
body.dark-mode .hist-search-wrap { background:rgba(13,17,23,0.8); border-color:rgba(255,255,255,0.08); }
body.dark-mode .loginCard {
  background:linear-gradient(160deg,rgba(28,33,39,0.98) 0%,rgba(22,27,34,0.98) 100%) !important;
  border:1px solid rgba(255,255,255,0.07);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
body.dark-mode .loginInput { background:rgba(13,17,23,0.8) !important;border-color:rgba(255,255,255,0.08) !important;color:#E6EDF3 !important; }
body.dark-mode .loginTabs { background:rgba(13,17,23,0.6) !important; }
body.dark-mode .loginTabBtn { color:rgba(139,148,158,0.9); }
body.dark-mode .stat-mini { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode #darkModeBtn { background:rgba(245,158,11,0.12);border-color:rgba(245,158,11,0.25); }
body.dark-mode .selActive { background:linear-gradient(135deg,#f59e0b,#f97316) !important; color:#fff !important; }
body.dark-mode .btn-logout { background:rgba(28,33,39,0.8) !important; color:#4ade80 !important; border-color:rgba(74,222,128,0.15) !important; }
body.dark-mode .wealth-grid > div { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode .topic-entry-card { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.05) !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;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  line-height:1.5;
}

/* ══════════════════════════════════════════════
   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;
}
.splash-memory{
  font-family:var(--mono);font-size:9px;color:rgba(245,158,11,0.5);
  letter-spacing:2px;text-align:center;margin-top:14px;
  animation:spSub 0.5s ease 2.2s both;
}

/* ══════════════════════════════════════════════
   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.72);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.4);
  position:sticky;top:0;z-index:5;
}
.page0-logo{display:flex;align-items:center;gap:8px;font-family:"Inter",var(--display);font-size:20px;font-weight:800;color:var(--text-dark);letter-spacing:-0.02em;}
.page0-brand{color:var(--accent);}

/* PAGE HEADER BAR (pages 1-5) */
.page-header-bar{
  background:rgba(255,255,255,0.72);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  color:var(--accent);
  font-family:"Inter",var(--display);font-size:17px;font-weight:800;
  padding:16px 16px 18px;
  padding-top:calc(var(--status-bar-height) + 18px);
  letter-spacing:-0.01em;
  border-bottom:1px solid rgba(255,255,255,0.4);
  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:rgba(255,255,255,0.72);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.55);
  border-radius:var(--radius-lg);
  padding:18px;margin:10px 14px 0;
  box-shadow:var(--shadow);
  transition:box-shadow 0.3s ease,transform 0.3s ease,border-color 0.3s ease;
}
.box:focus-within{
  box-shadow:var(--shadow-md);
  border-color:rgba(245,158,11,0.3);
}
.boxLabel{
  font-family:var(--mono);font-size:10px;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--accent);
  margin-bottom:14px;font-weight:700;
  -webkit-font-smoothing:antialiased;
}
.box-row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}

/* 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:rgba(255,255,255,0.75);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:var(--radius-md);
  padding:14px 16px;min-width:112px;flex-shrink:0;
  box-shadow:0 2px 12px rgba(0,0,0,0.05);
}
.month-card-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);margin-bottom:8px;font-weight:600;letter-spacing:0.06em;}
.month-card-income{font-family:"Inter",var(--mono);font-size:11px;color:var(--num-pos);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-0.01em;}
.month-card-expense{font-family:"Inter",var(--mono);font-size:11px;color:var(--num-neg);font-weight:700;margin-top:2px;font-variant-numeric:tabular-nums;letter-spacing:-0.01em;}
.month-card-balance{
  font-family:"Inter",var(--mono);font-size:10px;
  margin-top:6px;padding-top:6px;
  border-top:1px solid rgba(0,0,0,0.06);
  color:var(--text-muted);
  font-variant-numeric:tabular-nums;
}
.month-card.current-month{
  border-color:rgba(245,158,11,0.35);
  background:rgba(245,158,11,0.06);
  box-shadow:0 2px 16px rgba(245,158,11,0.15);
}

/* ══════════════════════════════════════════════
   INPUTS
══════════════════════════════════════════════ */
input,select{
  width:100%;padding:13px 16px;
  background:rgba(255,255,255,0.8);
  border:1.5px solid rgba(0,0,0,0.08);
  border-radius:var(--radius-md);
  color:var(--text);font-family:"Inter",var(--mono);font-size:14px;
  font-weight:500;
  margin-bottom:10px;appearance:none;-webkit-appearance:none;
  transition:border-color 0.3s ease,box-shadow 0.3s ease,background 0.3s ease;
  outline:none;
  -webkit-font-smoothing:antialiased;
}
input:focus,select:focus{
  border-color:var(--accent);
  background:rgba(255,255,255,0.95);
  box-shadow:0 0 0 4px rgba(245,158,11,0.12);
}
input::placeholder{color:rgba(60,60,67,0.3);}
.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;transition:all 0.3s ease;}

/* ══════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════ */
button{
  padding:11px 16px;border:none;border-radius:var(--radius-md);
  font-family:"Inter",var(--display);font-weight:600;font-size:13px;
  cursor:pointer;
  transition:all 0.3s ease;
  letter-spacing:0.01em;
  -webkit-font-smoothing:antialiased;
}
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:15px;font-size:15px;font-weight:700;
  margin-top:4px;
  box-shadow:0 4px 20px rgba(245,158,11,0.4), 0 1px 4px rgba(0,0,0,0.1);
  border-radius:var(--radius-lg) !important;
  transition:all 0.3s ease !important;
  letter-spacing:0.02em;
  position:relative;overflow:hidden;
}
.green:active{
  transform:scale(0.97) translateY(1px) !important;
  box-shadow:0 2px 8px rgba(245,158,11,0.3) !important;
}
.green::after{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,0.15);
  opacity:0;border-radius:inherit;transition:opacity 0.3s ease;
}
.green:active::after{opacity:1;}
.btn-ghost{
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1.5px solid rgba(0,0,0,0.08);
  border-radius:var(--radius-sm);
  color:var(--text-sub);font-family:"Inter",var(--mono);font-size:11px;padding:7px 12px;width:auto;
  transition:all 0.3s ease;
}
.btn-link{background:none;border:none;color:var(--accent);font-family:"Inter",var(--mono);font-size:11px;padding:0;width:auto;font-weight:600;transition:all 0.3s ease;}
.btn-logout{
  background:rgba(254,242,242,0.8);color:var(--red);
  border:1.5px solid rgba(220,38,38,0.15);border-radius:var(--radius-lg);
  font-family:"Inter",var(--mono);font-size:13px;font-weight:600;padding:14px;
  width:calc(100% - 28px);margin:12px 14px 20px;
  transition:all 0.3s ease;
}
.btn-edit{background:rgba(22,163,74,0.08);color:#16a34a;border:1px solid rgba(22,163,74,0.18);border-radius:10px;font-size:11px;padding:5px 10px;width:auto;transition:all 0.3s ease;}
.btn-del{background:transparent;color:var(--red);border:1px solid rgba(220,38,38,0.18);border-radius:10px;font-size:11px;padding:5px 10px;width:auto;transition:all 0.3s ease;}
.btn-accent-sm{
  background:var(--accent-dim);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.25);border-radius:var(--radius-sm);
  font-family:"Inter",var(--mono);font-size:11px;font-weight:700;
  padding:6px 12px;width:auto;
  transition:all 0.3s ease;
}
.btn-scan{
  background:rgba(245,158,11,0.08);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.22);border-radius:var(--radius-md);
  font-family:"Inter",var(--mono);font-size:12px;padding:11px;width:100%;margin-bottom:0;font-weight:600;
  transition:all 0.3s ease;
}
.btn-confirm-scan{
  background:rgba(22,163,74,0.08);color:var(--green);
  border:1.5px solid rgba(22,163,74,0.22);border-radius:var(--radius-md);
  font-family:"Inter",var(--mono);font-size:12px;padding:11px;width:100%;font-weight:600;
  transition:all 0.3s ease;
}
.quick-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px;margin-top:-4px;}
.chip{
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1.5px solid rgba(0,0,0,0.07);
  border-radius:10px;
  color:var(--text-sub);font-family:"Inter",var(--mono);font-size:11px;padding:5px 12px;width:auto;
  transition:all 0.3s ease;
}
.chip:hover{background:var(--accent-dim);color:var(--accent);border-color:rgba(245,158,11,0.3);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:rgba(0,0,0,0.05);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-radius:var(--radius-md);padding:4px;
  border:1px solid rgba(0,0,0,0.06);
}
.typeSelector button{
  flex:1;background:transparent;color:var(--text-muted);border:none;
  border-radius:var(--radius-sm);font-family:"Inter",var(--mono);font-size:11px;font-weight:500;
  padding:10px 6px;cursor:pointer;transition:all 0.3s ease;letter-spacing:0.03em;
}
.typeSelector button:hover{color:var(--text);background:rgba(255,255,255,0.5);opacity:1;transform:none;}
.selActive{
  background:linear-gradient(135deg,#f59e0b,#f97316)!important;
  color:#fff!important;font-weight:700!important;
  box-shadow:0 3px 10px rgba(245,158,11,0.4) !important;
}

/* ══════════════════════════════════════════════
   CATEGORY PICKER
══════════════════════════════════════════════ */
.cat-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:12px;}
.cat-btn{
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1.5px solid rgba(0,0,0,0.07);
  border-radius:var(--radius-md);
  padding:8px 4px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;width:100%;height:60px;cursor:pointer;transition:all 0.3s ease;color:var(--text-sub);
}
.cat-btn:hover{background:var(--accent-dim);border-color:rgba(245,158,11,0.3);color:var(--accent);opacity:1;transform:none;}
.cat-btn--active{background:rgba(245,158,11,0.12)!important;border-color:rgba(245,158,11,0.4)!important;color:var(--accent)!important;box-shadow:0 3px 12px rgba(245,158,11,0.2);}
.cat-btn-icon{font-size:20px;}
.cat-btn-label{font-family:"Inter",var(--mono);font-size:9px;color:inherit;font-weight:600;}

/* ══════════════════════════════════════════════
   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.28);
  border-radius:20px;
  color:var(--accent);
  font-family:"Inter",var(--mono);font-size:11px;font-weight:700;
  padding:5px 14px;width:auto;
  cursor:pointer;transition:all 0.3s ease;
}
.btn-month-pick:hover{background:rgba(245,158,11,0.18);opacity:1;transform:none;}
.summary-half{padding:14px 16px;display:inline-block;width:50%;vertical-align:top;}
.summary-half--left{border-right:1px solid rgba(0,0,0,0.06);}
.summary-amount{
  font-family:"Inter",var(--mono);font-size:22px;font-weight:800;
  color:var(--text-dark);
  font-variant-numeric:tabular-nums;
  letter-spacing:-0.03em;
  -webkit-font-smoothing:antialiased;
}
.summary-amount--income{color:var(--num-pos);}
.summary-amount--expense{color:var(--num-neg);}
.summary-balance{
  clear:both;padding:12px 16px;border-top:1px solid rgba(0,0,0,0.06);
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(248,248,252,0.6);border-radius:0 0 var(--radius-lg) var(--radius-lg);
}

/* ══════════════════════════════════════════════
   BUDGET
══════════════════════════════════════════════ */
.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.budget-remain{font-family:"Inter",var(--mono);font-size:12px;color:var(--accent);font-weight:700;font-variant-numeric:tabular-nums;}
.budget-track{background:rgba(0,0,0,0.06);border-radius:8px;height:10px;overflow:hidden;}
.budget-fill{height:100%;border-radius:8px;transition:width 0.8s cubic-bezier(0.4,0,0.2,1);background:var(--num-pos);box-shadow:0 1px 4px rgba(0,0,0,0.1) inset;}
.budget-msg{font-family:"Inter",var(--mono);font-size:10px;color:var(--text-muted);margin-top:6px;}

/* ══════════════════════════════════════════════
   TOPIC LIST (หน้าติดตาม)
══════════════════════════════════════════════ */
.topic-card{
  background:rgba(255,255,255,0.72);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:var(--radius-lg);
  padding:16px;margin-bottom:12px;
  box-shadow:0 2px 12px rgba(0,0,0,0.05);
  transition:box-shadow 0.3s ease,transform 0.3s ease;
}
.topic-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.topic-name{font-family:"Inter",var(--display);font-size:16px;font-weight:700;color:var(--text-dark);letter-spacing:-0.01em;}
.topic-total{
  font-family:"Inter",var(--mono);font-size:26px;font-weight:800;color:var(--accent);
  margin:6px 0 10px;
  font-variant-numeric:tabular-nums;letter-spacing:-0.03em;
  -webkit-font-smoothing:antialiased;
}
.topic-month-label{font-family:"Inter",var(--mono);font-size:10px;color:var(--text-muted);margin-bottom:2px;font-weight:600;letter-spacing:0.04em;}

/* รายการที่บันทึก — แต่ละกล่องแยก */
.topic-entry-list{display:flex;flex-direction:column;gap:8px;}
.topic-entry-card{
  background:rgba(255,255,255,0.6);
  border:1px solid rgba(0,0,0,0.06);
  border-radius:var(--radius-md);
  padding:11px 14px;
  display:flex;justify-content:space-between;align-items:center;
  transition:background 0.2s ease;
}
.topic-entry-card-left{display:flex;flex-direction:column;gap:2px;}
.topic-entry-date{font-family:"Inter",var(--mono);font-size:10px;color:var(--text-muted);}
.topic-entry-note{font-family:"Inter",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:"Inter",var(--mono);font-size:14px;font-weight:700;color:var(--accent);
  font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
}
.topic-entry-del{
  background:none;border:1px solid rgba(220,38,38,0.18);border-radius:8px;
  color:var(--red);font-size:11px;padding:4px 8px;width:auto;cursor:pointer;
  transition:all 0.3s ease;
}

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

/* ══════════════════════════════════════════════
   TX ITEMS
══════════════════════════════════════════════ */
.tx-item{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid rgba(0,0,0,0.05);transition:background 0.2s ease;}
.tx-item:last-child{border-bottom:none;}
.tx-icon{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;}
.tx-info{flex:1;min-width:0;}
.tx-label{font-family:"Inter",var(--sans);font-size:13px;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;letter-spacing:-0.01em;}
.tx-date{font-family:"Inter",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:"Inter",var(--mono);font-size:14px;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
}

/* ══════════════════════════════════════════════
   ROW
══════════════════════════════════════════════ */
.row{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 0;border-bottom:1px solid rgba(0,0,0,0.05);
  font-size:13px;color:var(--text-sub);
}
.row:last-child{border-bottom:none;}
.row span{font-family:"Inter",var(--mono);font-size:13px;font-weight:700;color:var(--text-dark);font-variant-numeric:tabular-nums;letter-spacing:-0.01em;}
.empty-msg{font-family:"Inter",var(--mono);font-size:12px;color:var(--text-muted);text-align:center;padding:20px;line-height:1.9;}

/* ══════════════════════════════════════════════
   OCR
══════════════════════════════════════════════ */
.ocr-desc{font-family:"Inter",var(--mono);font-size:11px;color:var(--text-muted);margin-bottom:12px;line-height:1.8;}
.scan-loading{text-align:center;padding:14px;font-family:"Inter",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:"Inter",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:rgba(255,255,255,0.72);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:var(--radius-md);padding:12px 10px;text-align:center;
  box-shadow:0 2px 12px rgba(0,0,0,0.04);
}
.stat-mini-label{font-family:"Inter",var(--mono);font-size:9px;color:var(--text-muted);margin-bottom:5px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;}
.stat-mini-val{
  font-family:"Inter",var(--mono);font-size:14px;font-weight:800;color:var(--text-dark);
  font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
  -webkit-font-smoothing:antialiased;
}

/* ══════════════════════════════════════════════
   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.3s ease;}

/* ══════════════════════════════════════════════
   PROFILE
══════════════════════════════════════════════ */
.profile-card{text-align:center;padding:24px 16px;display:flex;flex-direction:column;align-items:center;}
.profile-name{font-family:"Inter",var(--display);font-size:20px;font-weight:800;color:var(--text-dark);margin-bottom:4px;letter-spacing:-0.02em;}
.profile-email{font-family:"Inter",var(--mono);font-size:12px;color:var(--text-muted);margin-top:4px;}
.pass-msg{font-family:"Inter",var(--mono);font-size:12px;margin-bottom:10px;padding:10px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.7);}

/* ══════════════════════════════════════════════
   BOTTOM NAV — แก้ข้อ 6 (safe-area + ไม่บัง)
══════════════════════════════════════════════ */
.nav{
  position:fixed;bottom:0;left:0;width:100%;
  background:rgba(22,163,74,0.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;align-items:stretch;
  padding:6px 0 calc(6px + var(--sab));
  border-top:1px solid rgba(255,255,255,0.15);z-index:10;
  box-shadow:0 -4px 24px rgba(0,0,0,0.1);
}
.nav button{
  flex:1;min-width:0;
  background:none;border:none;color:rgba(255,255,255,0.65);
  font-family:"Inter",var(--mono);font-size:9px;font-weight:600;
  letter-spacing:0.04em;text-transform:uppercase;
  padding:6px 2px;border-radius:var(--radius-sm);
  transition:all 0.3s ease;
  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;transform:translateY(-1px);}
.navIcon{font-size:22px;display:block;transition:transform 0.3s ease;}
.navActive .navIcon{transform:scale(1.15);}
.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:rgba(255,255,255,0.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.6);
  border-radius:var(--radius-xl);
  padding:36px 24px;width:100%;max-width:360px;text-align:center;
  box-shadow:0 24px 64px rgba(0,0,0,0.25), 0 4px 16px rgba(0,0,0,0.1);
}
.loginLogo{font-size:48px;margin-bottom:10px;}
.loginTitle{font-family:"Inter",var(--display);font-size:24px;font-weight:800;color:#1c1c1e;margin-bottom:4px;letter-spacing:-0.02em;}
.loginSub{font-family:"Inter",var(--mono);font-size:11px;color:rgba(60,60,67,0.5);margin-bottom:22px;}
.loginTabs{display:flex;gap:4px;background:rgba(0,0,0,0.06);border-radius:var(--radius-md);padding:4px;margin-bottom:16px;}
.loginTabBtn{flex:1;background:transparent;color:rgba(60,60,67,0.5);border:none;border-radius:var(--radius-sm);font-family:"Inter",var(--mono);font-size:11px;font-weight:500;padding:10px 6px;cursor:pointer;transition:all 0.3s ease;}
.loginTabBtn:hover{background:rgba(255,255,255,0.5);opacity:1;transform:none;}
.loginTabActive{background:linear-gradient(135deg,#f59e0b,#f97316)!important;color:#fff!important;font-weight:700!important;box-shadow:0 3px 10px rgba(245,158,11,0.35);}
.loginInput{width:100%;padding:13px 16px;background:rgba(242,242,247,0.8);border:1.5px solid rgba(0,0,0,0.08);border-radius:var(--radius-md);color:#1c1c1e;font-family:"Inter",var(--mono);font-size:13px;margin-bottom:10px;outline:none;transition:all 0.3s ease;display:block;}
.loginInput:focus{border-color:#f59e0b;box-shadow:0 0 0 4px rgba(245,158,11,0.12);background:rgba(255,255,255,0.95);}
.loginInput::placeholder{color:rgba(60,60,67,0.3);}
.loginBtn{display:block;width:100%;padding:15px 20px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;border-radius:var(--radius-md);font-family:"Inter",var(--display);font-size:15px;font-weight:700;cursor:pointer;transition:all 0.3s ease;margin-bottom:10px;box-shadow:0 4px 16px rgba(245,158,11,0.4);}
.loginBtn:hover{opacity:0.88;transform:translateY(-1px);}
.forgotLink{font-family:"Inter",var(--mono);font-size:11px;color:rgba(60,60,67,0.5);cursor:pointer;text-decoration:underline;margin-top:4px;}
.forgotLink:hover{color:var(--accent);}
.login-hint{font-family:"Inter",var(--mono);font-size:10px;color:rgba(60,60,67,0.45);margin-top:8px;line-height:1.7;}
.login-msg{font-family:"Inter",var(--mono);font-size:12px;margin-top:10px;padding:10px;border-radius:var(--radius-sm);}
.login-msg--error{color:#dc2626;background:rgba(254,242,242,0.8);}
.login-msg--success{color:#16a34a;background:rgba(240,253,244,0.8);}

/* ══════════════════════════════════════════════
   MODALS — แก้ข้อ 7 (ขนาด popup พอดี)
══════════════════════════════════════════════ */
.modal-backdrop{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  display:flex;align-items:flex-end;justify-content:center;
}
.modal-sheet{
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  padding:24px 18px calc(24px + var(--sab));
  width:100%;max-width:480px;
  border-top:1px solid rgba(22,163,74,0.3);
  max-height:80vh;
  overflow-y:auto;
  animation:slideUp 0.32s cubic-bezier(0.32,0.72,0,1) both;
  box-shadow:0 -8px 48px rgba(0,0,0,0.12);
}
@keyframes slideUp{from{transform:translateY(100%);opacity:0.8;}to{transform:translateY(0);opacity:1;}}
.modal-title{font-family:"Inter",var(--display);font-size:17px;font-weight:700;margin-bottom:16px;color:var(--text-dark);letter-spacing:-0.01em;}
.modal-body{font-family:"Inter",var(--mono);font-size:12px;color:var(--text-sub);line-height:2;}
.month-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:280px;overflow-y:auto;}
.month-btn{background:rgba(255,255,255,0.7);border:1.5px solid rgba(0,0,0,0.07);border-radius:var(--radius-md);color:var(--text-sub);font-family:"Inter",var(--mono);font-size:12px;padding:12px 8px;width:100%;transition:all 0.3s ease;}
.month-btn--active{background:rgba(245,158,11,0.12)!important;border-color:rgba(245,158,11,0.4)!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:rgba(26,26,26,0.9);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(245,158,11,0.3);border-radius:var(--radius-md);
  padding:11px 20px;font-family:"Inter",var(--mono);font-size:13px;color:#fff;
  z-index:99998;opacity:0;transition:all 0.3s ease;
  white-space:nowrap;pointer-events:none;
  box-shadow:0 8px 32px rgba(0,0,0,0.25), 0 0 0 1px rgba(245,158,11,0.15);
}
.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:rgba(255,255,255,0.75);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:13px 16px;
  border-bottom:1px solid rgba(0,0,0,0.05);
}
.hist-balance-label{
  font-family:"Inter",var(--mono);font-size:11px;color:var(--text-muted);
  font-weight:600;text-transform:uppercase;letter-spacing:0.08em;
}
.hist-balance-val{
  font-family:"Inter",var(--mono);font-size:19px;font-weight:800;color:var(--text-dark);
  font-variant-numeric:tabular-nums;letter-spacing:-0.03em;
}

/* Toolbar: เลือกเดือน + ค้นหา */
.hist-toolbar{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  background:rgba(255,255,255,0.75);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,0.05);
}
.hist-month-btn{
  background:var(--accent-dim);
  border:1.5px solid rgba(245,158,11,0.3);
  border-radius:20px;color:var(--accent);
  font-family:"Inter",var(--mono);font-size:11px;font-weight:700;
  padding:6px 14px;width:auto;white-space:nowrap;
  flex-shrink:0;transition:all 0.3s ease;
}
.hist-month-btn:hover{background:rgba(245,158,11,0.18);opacity:1;transform:none;}
.hist-search-wrap{
  flex:1;display:flex;align-items:center;gap:6px;
  background:rgba(242,242,247,0.6);border-radius:20px;
  border:1px solid rgba(0,0,0,0.06);
  padding:6px 12px;
}
.hist-search-input{
  border:none;background:transparent;
  font-family:"Inter",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:1px solid rgba(0,0,0,0.05);
}
.hist-filter-btn{
  flex:1;background:rgba(255,255,255,0.65);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border:1.5px solid rgba(0,0,0,0.07);
  border-radius:20px;color:var(--text-sub);
  font-family:"Inter",var(--mono);font-size:11px;font-weight:600;
  padding:7px 4px;transition:all 0.3s ease;
}
.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 3px 10px rgba(245,158,11,0.3);
}

/* กลุ่มวัน */
.hist-day-group{
  background:rgba(255,255,255,0.6);
  margin-bottom:8px;
  border-bottom:1px solid rgba(0,0,0,0.04);
}
.hist-day-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 16px 6px;
  background:rgba(242,242,247,0.7);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(0,0,0,0.04);
  position:sticky;top:0;z-index:2;
}
.hist-day-label{
  font-family:"Inter",var(--mono);font-size:11px;font-weight:700;
  color:var(--text-sub);letter-spacing:0.02em;
}
.hist-day-net{
  font-family:"Inter",var(--mono);font-size:11px;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:-0.01em;
}
.hist-day-items{
  background:rgba(255,255,255,0.55);
}

/* แต่ละรายการ */
.hist-tx-row{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;
  border-bottom:1px solid rgba(0,0,0,0.04);
  cursor:pointer;
  transition:background 0.2s ease;
  -webkit-tap-highlight-color:transparent;
}
.hist-tx-row:last-child{border-bottom:none;}
.hist-tx-row:active{background:rgba(245,158,11,0.06);}
.hist-tx-icon{
  width:42px;height:42px;border-radius:var(--radius-md);
  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:"Inter",var(--sans);font-size:14px;font-weight:600;
  color:var(--text-dark);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:-0.01em;
}
.hist-tx-sub{
  font-family:"Inter",var(--mono);font-size:10px;color:var(--text-muted);margin-top:2px;
}
.hist-tx-amount{
  font-family:"Inter",var(--mono);font-size:16px;font-weight:800;
  flex-shrink:0;
  font-variant-numeric:tabular-nums;
  letter-spacing:-0.03em;
}

/* TX Detail popup rows */
.hist-detail-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 0;border-bottom:1px solid rgba(0,0,0,0.05);
  font-family:"Inter",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%;font-variant-numeric:tabular-nums;}

/* ══════════════════════════════════════════════
   RECURRING
══════════════════════════════════════════════ */
.rec-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 14px;
  border-bottom:1px solid rgba(0,0,0,0.05);
  border-radius:var(--radius-md);
  background:rgba(255,255,255,0.6);
  margin-bottom:6px;
  transition:background 0.3s ease;
}
.rec-row:last-child{border-bottom:none;margin-bottom:0;}
.rec-row-info{display:flex;flex-direction:column;gap:3px;}
.rec-row-name{font-family:"Inter",var(--sans);font-size:14px;font-weight:600;color:var(--text-dark);letter-spacing:-0.01em;}
.rec-row-amt{
  font-family:"Inter",var(--mono);font-size:14px;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
}
.rec-apply-btn{
  background:var(--accent-dim);color:var(--accent);
  border:1.5px solid rgba(245,158,11,0.25);border-radius:var(--radius-sm);
  font-family:"Inter",var(--mono);font-size:11px;font-weight:700;
  padding:7px 14px;width:auto;transition:all 0.3s ease;
}
.rec-apply-btn:hover{background:rgba(245,158,11,0.18);opacity:1;transform:none;}
.rec-done-badge{
  font-family:"Inter",var(--mono);font-size:11px;color:var(--num-pos);
  background:rgba(5,150,105,0.08);border-radius:10px;padding:5px 10px;
  font-weight:600;
}

/* ══════════════════════════════════════════════
   WEALTH PAGE — สินทรัพย์ & หนี้สิน
══════════════════════════════════════════════ */
.wealth-total-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 0 0;
  border-top:1px solid rgba(0,0,0,0.07);
  margin-top:8px;
}
.wealth-item-row{
  display:flex;align-items:center;gap:10px;
  padding:12px 0;border-bottom:1px solid rgba(0,0,0,0.05);
  transition:background 0.2s ease;
}
.wealth-item-row:last-child{border-bottom:none;}
.wealth-item-num{
  font-family:"Inter",var(--mono);font-size:10px;color:var(--text-muted);
  width:18px;text-align:center;flex-shrink:0;font-variant-numeric:tabular-nums;
}
.wealth-item-name{
  flex:1;font-family:"Inter",var(--sans);font-size:14px;
  font-weight:600;color:var(--text-dark);letter-spacing:-0.01em;
}
.wealth-item-amount{
  font-family:"Inter",var(--mono);font-size:15px;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:-0.02em;
}
.wealth-item-del{
  background:none;border:1px solid rgba(220,38,38,0.18);border-radius:8px;
  color:var(--red);font-size:11px;padding:4px 8px;width:auto;cursor:pointer;
  transition:all 0.3s ease;
}
/* ══════════════════════════════════════════════
   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 v3 — Premium 2026
══════════════════════════════════════════════ */

/* ── 1. Page transition ── */
#wrapper {
  transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ── 2. Card polish — glassmorphism ── */
.box {
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.05), 0 1px 4px rgba(0,0,0,0.03) !important;
  border: 1px solid rgba(255,255,255,0.55) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  transition: box-shadow 0.3s ease, transform 0.3s ease, border-color 0.3s ease !important;
}
.box:has(button:active) {
  transform: scale(0.995);
}

/* ── 3. Summary card upgrade ── */
.summary-grid {
  background: rgba(255,255,255,0.72) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255,255,255,0.55) !important;
  box-shadow: 0 4px 24px rgba(245,158,11,0.08), 0 2px 8px rgba(0,0,0,0.04) !important;
}
.summary-amount {
  font-size: 24px !important;
  letter-spacing: -0.03em !important;
  font-weight: 800 !important;
  font-variant-numeric: tabular-nums !important;
  animation: countUp 0.3s ease both;
}
.summary-balance {
  background: rgba(248,248,252,0.6) !important;
}

/* ── 4. ปุ่มหลัก .green ── */
.green {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg) !important;
  padding: 15px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 20px rgba(245,158,11,0.4), 0 1px 4px rgba(0,0,0,0.1) !important;
  transition: all 0.3s ease !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;
}
.green::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.15);
  opacity: 0;
  border-radius: inherit;
  transition: opacity 0.3s ease;
}
.green:active::after { opacity: 1; }

/* ── 5. Month card ── */
.month-card {
  border-radius: var(--radius-md) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}
.month-card:active { transform: scale(0.96); }
.month-card.current-month {
  background: rgba(245,158,11,0.07) !important;
  box-shadow: 0 2px 16px rgba(245,158,11,0.18) !important;
}

/* ── 6. TX item ── */
.tx-item {
  padding: 12px 4px !important;
  transition: background 0.2s ease !important;
  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: var(--radius-sm) !important;
  width: 40px !important;
  height: 40px !important;
  font-size: 20px !important;
}

/* ── 7. Nav button ── */
.nav button {
  transition: all 0.3s ease !important;
  border-radius: var(--radius-sm) !important;
}

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

/* ── 9. Budget bar ── */
.budget-track {
  height: 10px !important;
  border-radius: 8px !important;
  background: rgba(0,0,0,0.06) !important;
  overflow: hidden;
}
.budget-fill {
  border-radius: 8px !important;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* ── 10. TypeSelector ── */
.typeSelector {
  background: rgba(0,0,0,0.05) !important;
  border-radius: var(--radius-md) !important;
  padding: 4px !important;
}
.typeSelector button {
  border-radius: var(--radius-sm) !important;
  transition: all 0.3s ease !important;
}
.selActive {
  box-shadow: 0 3px 10px rgba(245,158,11,0.4) !important;
  transform: none !important;
}

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

/* ── 12. Toast ── */
.toast {
  border-radius: var(--radius-md) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.2) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  font-size: 13px !important;
  padding: 11px 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 animation ── */
@keyframes countUp {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── 14. Page header bars ── */
.page-header-bar, .page0-header {
  border-bottom: none !important;
}
.page-header-bar {
  font-family: "Inter", var(--display) !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  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 ── */
.cat-btn {
  border-radius: var(--radius-md) !important;
  height: 62px !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}
.cat-btn:active { transform: scale(0.93) !important; }
.cat-btn--active { box-shadow: 0 3px 14px rgba(245,158,11,0.25) !important; transform: scale(1.02); }

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

/* ── 17. Rec row ── */
.rec-row {
  border-radius: var(--radius-md) !important;
  border: 1px solid rgba(0,0,0,0.05) !important;
  padding: 12px 14px !important;
  margin-bottom: 6px;
  transition: background 0.3s ease !important;
}

/* ── 18. Topic card ── */
.topic-card {
  border-radius: var(--radius-lg) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}

/* ── 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:rgba(13,17,23,0.7) !important; border-color:rgba(255,255,255,0.06) !important; }
body.dark-mode .typeSelector button { color:rgba(139,148,158,0.9); background:transparent; }
body.dark-mode .typeSelector button:hover { background:rgba(255,255,255,0.06); color:#E6EDF3; }
body.dark-mode .summary-balance { background:rgba(13,17,23,0.7) !important; }
body.dark-mode .topic-card { background:rgba(28,33,39,0.85) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode .cat-btn { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.06) !important; color:#E6EDF3 !important; }
body.dark-mode .cat-btn--active { background:rgba(245,158,11,0.18) !important; border-color:rgba(245,158,11,0.35) !important; }
body.dark-mode .budget-track { background:rgba(22,27,34,0.8) !important; }
/* dark overrides for toggled elements */
body.dark-mode .rec-row { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode .wealth-item-row { border-color:rgba(255,255,255,0.05); }
body.dark-mode .month-card { background:rgba(28,33,39,0.85) !important; border-color:rgba(255,255,255,0.07) !important; }
body.dark-mode .month-card.current-month { background:rgba(245,158,11,0.1) !important; border-color:rgba(245,158,11,0.35) !important; }
body.dark-mode .summary-balance { background:rgba(13,17,23,0.7) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode .hist-day-group { background:rgba(28,33,39,0.7) !important; border-color:rgba(255,255,255,0.04) !important; }
body.dark-mode .profile-card {
  background: transparent;
}
body.dark-mode .row { border-color:rgba(255,255,255,0.05); color:rgba(139,148,158,0.9); }
body.dark-mode .collapseArrow { color:rgba(110,118,129,0.8); }
body.dark-mode .stat-mini { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode .stat-mini-val { color:#F0F6FC; }
body.dark-mode .stat-mini-label { color:rgba(139,148,158,0.8); }
body.dark-mode .hist-tx-label { color:#E6EDF3; }
body.dark-mode .hist-tx-amount { color:#F0F6FC; }
body.dark-mode .hist-balance-val { color:#F0F6FC; }
body.dark-mode .topic-total { color:var(--accent); }
body.dark-mode .topic-entry-card { background:rgba(28,33,39,0.8) !important; border-color:rgba(255,255,255,0.05) !important; }
body.dark-mode .topic-entry-note { color:#E6EDF3; }
body.dark-mode .wealth-item-name { color:#E6EDF3; }
body.dark-mode .wealth-item-amount { color:#F0F6FC; }
body.dark-mode .tx-label { color:#E6EDF3; }
body.dark-mode .tx-amount { color:#F0F6FC; }
body.dark-mode .rec-row-name { color:#E6EDF3; }
/* กัน background ดำค้างเมื่อ toggle กลับ light mode */
body:not(.dark-mode) .rec-row { background:rgba(255,255,255,0.6) !important; border-color:rgba(0,0,0,0.05) !important; }
body:not(.dark-mode) .month-card { background:rgba(255,255,255,0.75) !important; border-color:rgba(255,255,255,0.5) !important; }
body:not(.dark-mode) .hist-day-group { background:rgba(255,255,255,0.6); }
body:not(.dark-mode) .hist-day-items { background:rgba(255,255,255,0.55); }
body:not(.dark-mode) .hist-day-header { background:rgba(242,242,247,0.7); }
body:not(.dark-mode) .hist-balance-bar { background:rgba(255,255,255,0.75); }
body:not(.dark-mode) .hist-toolbar { background:rgba(255,255,255,0.75); }
body:not(.dark-mode) .summary-balance { background:rgba(248,248,252,0.6); }
/* ══════════════════════════════════════════════
   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 โปร่งแสง สีเขียว */
.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(22,163,74,0.72);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.12);
  position:sticky;top:0;z-index:5;
  color:#fff;
  font-family:"Inter",var(--display);font-size:16px;font-weight:800;
  letter-spacing:-0.01em;
  animation:headerSlideIn 0.32s cubic-bezier(0.4,0,0.2,1) both;
}
body.dark-mode .portal-header{
  background:rgba(15,50,25,0.65);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.06);
  color:#4ade80;
}

/* Wallet section title */
.portal-section-title{
  padding:16px 16px 4px;
  font-family:"Inter",var(--display);font-size:18px;font-weight:800;
  color:var(--text-dark);letter-spacing:-0.02em;
}
.portal-section-sub{
  padding:0 16px 12px;
  font-family:"Inter",var(--mono);font-size:11px;color:var(--text-muted);
}

/* Wallet card */
.wallet-card{
  background:rgba(255,255,255,0.75);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:var(--radius-lg);
  padding:18px 20px;
  margin:0 14px 12px;
  display:flex;justify-content:space-between;align-items:center;
  cursor:pointer;
  transition:all 0.3s ease;
  box-shadow:0 2px 16px rgba(0,0,0,0.05),0 1px 4px rgba(0,0,0,0.03);
  position:relative;
  overflow:hidden;
}
.wallet-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(22,163,74,0.04),rgba(16,185,129,0.02));
  opacity:0;transition:opacity 0.3s ease;
}
.wallet-card:active{
  transform:scale(0.97);
  box-shadow:0 1px 6px rgba(0,0,0,0.07);
}
.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:"Inter",var(--mono);font-size:10px;font-weight:700;
  padding:3px 10px;border-radius:20px;
  margin-bottom:6px;
  letter-spacing:0.04em;
}
.wallet-name{
  font-family:"Inter",var(--display);font-size:16px;font-weight:700;
  color:var(--text-dark);margin-bottom:4px;letter-spacing:-0.01em;
}
.wallet-summary-row{
  display:flex;align-items:center;gap:4px;
  font-family:"Inter",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:"Inter",var(--mono);font-size:20px;font-weight:800;
  letter-spacing:-0.03em;
  font-variant-numeric:tabular-nums;
  -webkit-font-smoothing:antialiased;
}
.wallet-arrow{
  font-family:"Inter",var(--mono);font-size:18px;color:rgba(22,163,74,0.45);
  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:rgba(22,163,74,0.06);
  border:1.5px dashed rgba(22,163,74,0.3);
  border-radius:var(--radius-lg);cursor:pointer;
  transition:all 0.3s ease;color:#16a34a;
  font-family:"Inter",var(--display);font-size:14px;font-weight:700;
}
.add-wallet-btn:active{background:rgba(22,163,74,0.12);transform:scale(0.98);}

/* Dark mode wallet */
body.dark-mode .wallet-card{
  background:linear-gradient(160deg,rgba(28,33,39,0.95) 0%,rgba(22,27,34,0.95) 100%);
  border-color:rgba(255,255,255,0.06);
  box-shadow:0 4px 24px rgba(0,0,0,0.35);
}
body.dark-mode .wallet-name{ color:#E6EDF3; }
body.dark-mode .wallet-balance{ -webkit-font-smoothing:antialiased; }
body.dark-mode .portal-section-title{ color:#E6EDF3; }
body.dark-mode .add-wallet-btn{
  background:rgba(22,163,74,0.07);
  border-color:rgba(22,163,74,0.2);
  color:#4ade80;
}

/* ══ Portal Dashboard — font & color standardization ══ */
/* ให้ตัวเลขหลักทุก card ใช้ Inter mono เหมือนกัน */
#dashNetWorth, #dashWealthNet {
  font-family:"Inter",var(--mono) !important;
  font-weight:800 !important;
  letter-spacing:-0.03em !important;
  font-variant-numeric:tabular-nums !important;
}
#dashAssets { color:var(--num-pos) !important; }
#dashDebts  { color:var(--num-neg) !important; }
#dashIncome { color:var(--num-pos) !important; }
#dashExpense{ color:var(--num-neg) !important; }
/* portal card label ใช้ mono เหมือนกันทุก card */
#dashboardPage [style*="font-size:9px"],
#dashboardPage [style*="font-size:10px"] {
  font-family:"Inter",var(--mono) !important;
}
/* dark mode portal dashboard cards */
body.dark-mode #portalScreen [style*="background:var(--card)"],
body.dark-mode #portalScreen [style*="background: var(--card)"] {
  background:rgba(28,33,39,0.9) !important;
  border-color:rgba(255,255,255,0.06) !important;
}

/* ══ 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.72);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.4);
  flex-shrink:0;z-index:10;
  min-height:50px;
}
body.dark-mode .mode-top-bar{
  background:rgba(11,14,17,0.75);
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.mode-title{
  font-family:"Inter",var(--display);font-size:16px;font-weight:800;
  color:var(--accent);flex:1;text-align:center;
  letter-spacing:-0.01em;
}

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

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

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

/* ══ INVEST MODE — nav สีฟ้า ══ */
.nav--invest{
  background:rgba(0,140,200,0.95) !important;
  border-top:2px solid rgba(255,255,255,0.15) !important;
}
body.dark-mode .nav--invest{
  background:linear-gradient(135deg,rgba(0,60,100,0.98) 0%,rgba(0,80,130,0.98) 100%) !important;
  border-top:1px solid rgba(0,212,255,0.3) !important;
}
.nav--invest .navActive{
  color:#fff !important;
  background:rgba(255,255,255,0.25) !important;
}

/* ══ MONEY MODE — nav สีส้มเดิม ══ */
.nav--money{
  background:rgba(245,158,11,0.97) !important;
  border-top:2px solid rgba(255,255,255,0.25) !important;
}
body.dark-mode .nav--money{
  background:linear-gradient(135deg,rgba(180,100,0,0.97) 0%,rgba(160,80,0,0.97) 100%) !important;
  border-top:1px solid rgba(245,158,11,0.4) !important;
}
.nav--money .navActive{
  color:#fff !important;
  background:rgba(255,255,255,0.22) !important;
}

/* ══ PORTAL HEADER — page0-logo สีขาว บน green header ══ */
.portal-header .page0-logo{ color:#fff; }
.portal-header .page0-brand{ color:#fff; }
body.dark-mode .portal-header .page0-logo{ color:#4ade80; }
body.dark-mode .portal-header .page0-brand{ color:#4ade80; }

/* ══ Portal page box labels — สีเขียว ══ */
#portalScreen .boxLabel{ color:#16a34a; }
body.dark-mode #portalScreen .boxLabel{ color:#4ade80; }
#portalScreen .collapse-header .boxLabel{ color:#16a34a; }
body.dark-mode #portalScreen .collapse-header .boxLabel{ color:#4ade80; }
#portalScreen .collapseArrow{ color:rgba(22,163,74,0.6); }
/* keep accent color for admin panel label */
#portalScreen #adminPanel .boxLabel{ color:#f59e0b; }

/* ══ Portal .green button — สีเขียว (ทั้ง modal และ portal page) ══ */
#portalScreen .green,
.modal-backdrop .green,
.modal-sheet .green {
  background:linear-gradient(135deg,#16a34a,#15803d) !important;
  box-shadow:0 4px 16px rgba(22,163,74,0.35),0 1px 4px rgba(0,0,0,0.1) !important;
}
#portalScreen .green:active,
.modal-backdrop .green:active,
.modal-sheet .green:active {
  box-shadow:0 2px 8px rgba(22,163,74,0.25) !important;
}

/* ══ DL Money mode — .green button สีส้มเดิม (override portal green) ══ */
body.mode--money .green,
body.mode--money .modal-backdrop .green,
body.mode--money .modal-sheet .green {
  background:linear-gradient(135deg,#f59e0b,#f97316) !important;
  box-shadow:0 4px 16px rgba(245,158,11,0.4),0 1px 4px rgba(0,0,0,0.1) !important;
}
body.mode--money .green:active,
body.mode--money .modal-backdrop .green:active,
body.mode--money .modal-sheet .green:active {
  box-shadow:0 2px 8px rgba(245,158,11,0.3) !important;
}

/* ══ DL MONEY — summary-grid dark mode fix ══ */
/* แก้สีเพี้ยนของกล่องสรุปรายรับ/รายจ่าย เฉพาะ dark mode + money mode เท่านั้น */
body.dark-mode.mode--money .summary-grid {
  background:linear-gradient(160deg,rgba(28,33,39,0.98) 0%,rgba(22,27,34,0.98) 100%) !important;
  border:1px solid rgba(255,255,255,0.06) !important;
  backdrop-filter:blur(12px) !important;
  -webkit-backdrop-filter:blur(12px) !important;
}
body.dark-mode.mode--money .summary-half {
  background:transparent !important;
}
body.dark-mode.mode--money .summary-half--left {
  border-right:1px solid rgba(255,255,255,0.07) !important;
}
body.dark-mode.mode--money .summary-month-row {
  background:transparent !important;
}
body.dark-mode.mode--money .summary-balance {
  background:rgba(13,17,23,0.55) !important;
  border-top:1px solid rgba(255,255,255,0.06) !important;
}

/* ══ DL PROPERTY MODE ══ */

/* nav bar สีแดง */
.nav--property{
  background:rgba(185,28,28,0.97) !important;
  border-top:2px solid rgba(255,255,255,0.18) !important;
}
body.dark-mode .nav--property{
  background:linear-gradient(135deg,rgba(120,10,10,0.98) 0%,rgba(153,27,27,0.98) 100%) !important;
  border-top:1px solid rgba(220,38,38,0.4) !important;
}
.nav--property .navActive{
  color:#fff !important;
  background:rgba(255,255,255,0.22) !important;
}
.nav--property button{
  color:rgba(255,255,255,0.75) !important;
}

/* header โปร่งใส 80-90% */
body.mode--property .page0-header{
  background:rgba(185,28,28,0.15) !important;
  backdrop-filter:blur(18px) !important;
  -webkit-backdrop-filter:blur(18px) !important;
  border-bottom:1px solid rgba(220,38,38,0.25) !important;
}
body.mode--property .page-header-bar{
  background:rgba(185,28,28,0.15) !important;
  backdrop-filter:blur(18px) !important;
  -webkit-backdrop-filter:blur(18px) !important;
  border-bottom:1px solid rgba(220,38,38,0.25) !important;
  color:#dc2626 !important;
}
body.dark-mode.mode--property .page0-header{
  background:rgba(220,38,38,0.12) !important;
}
body.dark-mode.mode--property .page-header-bar{
  background:rgba(220,38,38,0.12) !important;
  color:#fca5a5 !important;
}

/* .green button สีแดง */
body.mode--property .green,
body.mode--property .modal-backdrop .green,
body.mode--property .modal-sheet .green {
  background:linear-gradient(135deg,#dc2626,#b91c1c) !important;
  box-shadow:0 4px 16px rgba(220,38,38,0.4),0 1px 4px rgba(0,0,0,0.1) !important;
}
body.mode--property .green:active,
body.mode--property .modal-backdrop .green:active,
body.mode--property .modal-sheet .green:active {
  box-shadow:0 2px 8px rgba(220,38,38,0.3) !important;
}

/* input focus border สีแดง */
body.mode--property input:focus,
body.mode--property textarea:focus,
body.mode--property select:focus {
  border-color:#dc2626 !important;
  box-shadow:0 0 0 3px rgba(220,38,38,0.15) !important;
}

/* boxLabel สีแดง */
body.mode--property .boxLabel{
  color:#dc2626 !important;
}
body.dark-mode.mode--property .boxLabel{
  color:#fca5a5 !important;
}

/* btn-accent-sm สีตามประเภท (ใช้ inline style ใน property แล้ว ไม่ override ที่นี่) */

/* stat-mini Net Worth card */
body.mode--property .stat-mini{
  background:var(--card);
  border:1px solid var(--border);
}

/* text colors light/dark */
body.mode--property{
  --pp-accent: #dc2626;
  --pp-accent-soft: rgba(220,38,38,0.12);
}
body.dark-mode.mode--property{
  --pp-accent: #fca5a5;
  --pp-accent-soft: rgba(220,38,38,0.18);
}

/* ══ WALLET COUNT LABEL — ปรับสีให้เห็นบน green header ══ */
#walletCountLabel{
  font-family:"Inter",var(--mono);font-size:10px;font-weight:700;
  color:rgba(255,255,255,0.9) !important;
  background:rgba(255,255,255,0.2) !important;
  padding:3px 10px;border-radius:20px;
  letter-spacing:0.04em;
}
#walletCountLabel.is-owner{
  color:#fff !important;
  background:rgba(255,255,255,0.25) !important;
}