/* ============================================================
   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);
  --sab: env(safe-area-inset-bottom, 0px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{overflow:hidden;height:100%;width:100%;background:#1a1a1a;}
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:500vw;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 — แก้ข้อ 5 (safe-area)
══════════════════════════════════════════════ */
.page0-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 16px 10px;
  padding-top:max(14px, calc(env(safe-area-inset-top, 0px) + 14px));
  background:#ffffff;
  border-bottom:2px solid var(--accent);
  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:#1a1a1a;}
.page0-brand{color:var(--accent);}

/* PAGE HEADER BAR (pages 1-4) */
.page-header-bar{
  background:#ffffff;color:#1a1a1a;
  font-family:var(--display);font-size:16px;font-weight:700;
  padding:14px 16px 14px;
  padding-top:max(14px, calc(env(safe-area-inset-top, 0px) + 14px));
  letter-spacing:0.02em;
  border-bottom:2px solid var(--accent);
  position:sticky;top:0;z-index:5;
}

/* ══════════════════════════════════════════════
   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:#f9fafb;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:#f9fafb;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:#f3f4f6;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:#f3f4f6;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:#f3f4f6;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:#f3f4f6;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:#f9fafb;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:#fafafa;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:#f3f4f6;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:#f9fafb;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:#fff;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:#f9fafb;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:#f9fafb;}

/* ══════════════════════════════════════════════
   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:grid;grid-template-columns:repeat(5,1fr);align-items:center;
  padding:8px 4px calc(8px + var(--sab));
  border-top:2px solid rgba(255,255,255,0.25);z-index:10;
}
.nav button{
  background:none;border:none;color:rgba(255,255,255,0.6);
  font-family:var(--mono);font-size:9px;font-weight:500;
  letter-spacing:0.06em;text-transform:uppercase;
  padding:8px 4px;border-radius:10px;transform:none;
  transition:color 0.2s,background 0.2s;
  display:flex;flex-direction:column;align-items: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.2)!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:#f3f4f6;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:#f9fafb;border:1.5px solid #e5e7eb;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:#fff;
  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:#1a1a1a;}
.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:#f9fafb;border:1.5px solid #e5e7eb;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;}
}