/* ============ RichMark style.css ============ */
/* 基礎重設與主題變數 */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0f1117;--surface:#1a1d27;--card:#22263a;--border:#2e3348;
  --primary:#6c63ff;--primary-light:#8b83ff;--accent:#00d2ff;
  --green:#22c55e;--red:#ef4444;--orange:#f59e0b;--pink:#ec4899;
  --text:#e8e8f0;--text2:#9ca3af;--text3:#6b7280;
  --chart-grid:rgba(46,51,72,.5);--chart-text:#6b7280;
  --donut-hole:var(--card);--bar-bg:var(--bg);
  --sidebar-width:240px;
  /* 陰影系統（v1.9.3） — 深色模式用半透明黑 + 微光 */
  --shadow-sm:0 1px 2px rgba(0,0,0,.25),0 1px 1px rgba(0,0,0,.15);
  --shadow-md:0 4px 12px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.18);
  --shadow-lg:0 12px 28px rgba(0,0,0,.38),0 6px 12px rgba(0,0,0,.22);
  --shadow-xl:0 24px 48px rgba(0,0,0,.5),0 12px 24px rgba(0,0,0,.3);
  --shadow-glow:0 0 24px rgba(108,99,255,.25);
  --shadow-glow-accent:0 0 24px rgba(0,210,255,.2);
  --shadow-inset:inset 0 1px 0 rgba(255,255,255,.04);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-out-soft:cubic-bezier(.4,.0,.2,1);
  --trans-fast:.15s var(--ease-out-soft);
  --trans-base:.25s var(--ease-out);
  --trans-slow:.4s var(--ease-out);
}
html.light{
  --bg:#f5f7fa;--surface:#ffffff;--card:#ffffff;--border:#e2e8f0;
  --primary:#6c63ff;--primary-light:#5548d9;--accent:#0891b2;
  --green:#16a34a;--red:#dc2626;--orange:#d97706;--pink:#db2777;
  --text:#1e293b;--text2:#64748b;--text3:#94a3b8;
  --chart-grid:rgba(0,0,0,.08);--chart-text:#64748b;
  --donut-hole:#ffffff;--bar-bg:#f1f5f9;
  /* 淺色模式陰影：較淡但有辨識度 */
  --shadow-sm:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.04);
  --shadow-md:0 4px 12px rgba(15,23,42,.08),0 2px 4px rgba(15,23,42,.04);
  --shadow-lg:0 12px 28px rgba(15,23,42,.12),0 6px 12px rgba(15,23,42,.06);
  --shadow-xl:0 24px 48px rgba(15,23,42,.18),0 12px 24px rgba(15,23,42,.1);
  --shadow-glow:0 0 24px rgba(108,99,255,.2);
  --shadow-glow-accent:0 0 24px rgba(8,145,178,.18);
  --shadow-inset:inset 0 1px 0 rgba(255,255,255,.6);
}
body{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--text);
  min-height:100vh;transition:background .3s,color .3s;
  font-size:15px;
}
input,select,textarea,button{font-family:inherit;font-size:inherit}
button{cursor:pointer;border:none;background:none;color:inherit}

/* ============ 登入頁面 ============ */
.login-overlay{
  position:fixed;inset:0;background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  z-index:9999;transition:background .3s;
}
.login-box{
  background:var(--surface);border:1px solid var(--border);
  border-radius:24px;padding:48px;width:400px;max-width:95vw;text-align:center;
  box-shadow:var(--shadow-xl);
  animation:modalIn .45s var(--ease-out);
}
.login-logo{
  width:96px;height:96px;border-radius:24px;margin-bottom:16px;
  background:var(--card);padding:10px;object-fit:contain;
  box-shadow:0 8px 24px rgba(108,99,255,.25),0 0 0 1px var(--border);
}
html.light .login-logo{background:#fff}

/* ============ 品牌 Logo 深淺色切換 ============ */
/* 登入頁完整橫版 */
.brand-full{
  display:block;max-width:240px;width:80%;height:auto;
  margin:0 auto 20px;object-fit:contain;
}
/* 側欄完整橫版 */
.sidebar-brand{
  display:block;height:32px;width:auto;max-width:100%;object-fit:contain;
}
/* 預設深色模式：顯示白色 logo */
.light-only{display:none!important}
.dark-only{display:block!important}
/* 淺色模式：反過來 */
html.light .light-only{display:block!important}
html.light .dark-only{display:none!important}
.login-box h1{
  font-size:28px;margin-bottom:8px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.login-box p{color:var(--text2);margin-bottom:28px;font-size:14px}
.login-box input{
  width:100%;padding:14px 18px;background:var(--card);
  border:1px solid var(--border);border-radius:12px;
  color:var(--text);font-size:15px;margin-bottom:12px;text-align:center;
}
.login-box input[type="text"]{letter-spacing:0}
.login-box input[type="password"]{letter-spacing:4px}
.login-box input:focus{outline:none;border-color:var(--primary)}
.login-box .btn-primary{
  width:100%;padding:14px;border-radius:12px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;font-weight:600;font-size:16px;margin-bottom:12px;
  min-height:48px;
}
.login-box .btn-secondary{
  color:var(--text2);font-size:13px;text-decoration:underline;
  background:none;border:none;min-height:44px;
}
.login-error{color:var(--red);font-size:13px;margin-bottom:12px;display:none}

/* ============ App 主結構 ============ */
.app{display:none;height:100vh;overflow:hidden}
html,body{overflow-x:hidden;max-width:100vw}

/* ============ 側邊欄（桌面） ============ */
.sidebar{
  width:var(--sidebar-width);background:var(--surface);
  border-right:1px solid var(--border);padding:16px 0;
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  box-shadow:var(--shadow-md);
  overflow-y:auto;overflow-x:hidden;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
  transition:background var(--trans-slow),width var(--trans-base);
}
/* 側邊欄專用窄捲動條 */
.sidebar::-webkit-scrollbar{width:4px}
.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.sidebar:hover::-webkit-scrollbar-thumb{background:var(--text3)}
.sidebar .logo{
  padding:6px 20px 0;margin-bottom:20px;
  display:flex;align-items:center;justify-content:flex-start;
  flex-shrink:0;
}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 20px;color:var(--text2);font-size:14px;
  cursor:pointer;min-height:42px;position:relative;flex-shrink:0;
  transition:background var(--trans-base),color var(--trans-base),padding var(--trans-base);
}
.nav-item::before{
  content:'';position:absolute;left:0;top:10%;bottom:10%;width:3px;
  background:var(--primary);border-radius:0 2px 2px 0;
  transform:scaleY(0);transform-origin:center;
  transition:transform var(--trans-base);
}
.nav-item:hover{background:rgba(108,99,255,.08);color:var(--text);padding-left:24px}
.nav-item.active{
  background:linear-gradient(90deg,rgba(108,99,255,.18),rgba(108,99,255,.04));
  color:var(--primary-light);
}
.nav-item.active::before{transform:scaleY(1)}
.nav-item svg{width:20px;height:20px;flex-shrink:0;transition:transform var(--trans-base)}
.nav-item:hover svg{transform:scale(1.1)}
.nav-spacer{flex:1;min-height:8px}
.main{
  margin-left:var(--sidebar-width);height:100vh;
  overflow-y:auto;overflow-x:hidden;padding:28px 36px;
  box-sizing:border-box;
  transition:background .3s,margin-left .3s;
}
/* 頁面內容：預設全寬；在超寬螢幕 (>1800px) 才設上限讓行長保持可讀性 */
.page{width:100%}
@media(min-width:1800px){
  .page{max-width:1600px;margin:0 auto}
}
.user-info{padding:6px 20px 12px;font-size:12px;color:var(--text3);flex-shrink:0;word-break:break-all}

/* ============ 使用者卡（側欄 + 設定頁共用） ============ */
.user-card{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px!important;margin:0 10px 12px;
  border-radius:12px;background:var(--card);border:1px solid var(--border);
  cursor:pointer;transition:background var(--trans-base),border-color var(--trans-base),transform var(--trans-fast);
}
.user-card:hover{border-color:var(--primary);background:rgba(108,99,255,.08)}
.user-card:active{transform:scale(.98)}
.user-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;line-height:1;
  background:linear-gradient(135deg,rgba(108,99,255,.2),rgba(0,210,255,.2));
  border:1px solid var(--border);overflow:hidden;
}
.user-avatar img{width:100%;height:100%;object-fit:cover}
.user-meta{flex:1;min-width:0;overflow:hidden}
.user-meta .user-nick{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.user-meta .user-email{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin-top:2px}

/* 大尺寸頭像（設定頁 & Modal 使用） */
.user-avatar-lg{
  width:96px;height:96px;border-radius:50%;
  font-size:56px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(108,99,255,.25),rgba(0,210,255,.2));
  border:2px solid var(--border);overflow:hidden;margin:0 auto 8px;
}
.user-avatar-lg img{width:100%;height:100%;object-fit:cover}

/* Emoji 選擇器（Profile Modal 用） */
.avatar-emoji-grid{
  display:grid;grid-template-columns:repeat(8,1fr);gap:8px;margin-top:8px;
}
.avatar-emoji-opt{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:26px;border-radius:10px;background:var(--card);border:2px solid var(--border);
  cursor:pointer;transition:.18s;
}
.avatar-emoji-opt:hover{border-color:var(--primary);transform:scale(1.08)}
.avatar-emoji-opt.selected{border-color:var(--primary);background:rgba(108,99,255,.15);box-shadow:0 0 0 3px rgba(108,99,255,.18)}
@media(max-width:420px){
  .avatar-emoji-grid{grid-template-columns:repeat(6,1fr)}
}

/* ============ 底部導航（手機） ============ */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  background:var(--surface);border-top:1px solid var(--border);
  z-index:200;
  justify-content:space-around;align-items:center;
  padding:4px 0;
  padding-bottom:env(safe-area-inset-bottom,0);
  box-shadow:0 -4px 20px rgba(0,0,0,.25);
}
html.light .bottom-nav{box-shadow:0 -4px 20px rgba(15,23,42,.08)}
.bottom-nav .bottom-nav-item{
  transition:color var(--trans-base),transform var(--trans-fast),background var(--trans-base);
}
.bottom-nav .bottom-nav-item:active{transform:scale(.92)}
.bottom-nav .bottom-nav-item.active{
  background:rgba(108,99,255,.12);
}
.bottom-nav .bottom-nav-item{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;
  padding:6px 4px;color:var(--text3);font-size:10px;
  cursor:pointer;min-width:44px;min-height:44px;
  transition:.2s;border-radius:8px;gap:2px;
}
.bottom-nav .bottom-nav-item svg{width:20px;height:20px;flex-shrink:0}
.bottom-nav .bottom-nav-item.active{color:var(--primary-light)}
.bottom-nav .bottom-nav-item:hover{color:var(--text)}

/* 漢堡按鈕（手機用，桌面隱藏） */
.mobile-menu-btn{
  display:none;
  position:fixed;top:12px;left:12px;z-index:300;
  width:44px;height:44px;border-radius:10px;
  background:var(--surface);box-shadow:var(--shadow-sm);
  align-items:center;justify-content:center;
  cursor:pointer;color:var(--text);font-size:22px;
}

/* ============ 頁面 ============ */
.page{display:none}
.page.active{display:block;animation:pageIn .35s var(--ease-out)}
@keyframes pageIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.page-title{
  font-size:24px;font-weight:700;margin-bottom:24px;
  background:linear-gradient(135deg,var(--text),var(--primary-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
html.light .page-title{
  -webkit-text-fill-color:var(--text);
}

/* ============ 統計卡片 ============ */
.stat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;margin-bottom:28px;
}
.stat-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:16px;padding:20px;
  box-shadow:var(--shadow-sm),var(--shadow-inset);
  transition:transform var(--trans-base),box-shadow var(--trans-base),border-color var(--trans-base),background var(--trans-slow);
  position:relative;overflow:hidden;
}
.stat-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(108,99,255,.08),transparent 50%);
  opacity:0;transition:opacity var(--trans-base);pointer-events:none;
}
.stat-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg),var(--shadow-inset);
  border-color:rgba(108,99,255,.35);
}
.stat-card:hover::before{opacity:1}
.stat-card[onclick]{cursor:pointer}
.stat-card[onclick]:active{transform:translateY(-1px) scale(.99)}
.stat-card .label{
  font-size:12px;color:var(--text2);text-transform:uppercase;
  letter-spacing:1px;margin-bottom:8px;
  position:relative;z-index:1;
}
.stat-card .value{font-size:24px;font-weight:700;position:relative;z-index:1;letter-spacing:-.02em}
.stat-card .sub{font-size:12px;color:var(--text3);margin-top:4px;position:relative;z-index:1}

/* 統計卡片分區標題 */
.stat-section-title{
  font-size:14px;font-weight:600;color:var(--text2);
  letter-spacing:.5px;margin:4px 0 12px;
  display:flex;align-items:center;gap:8px;
}
.stat-section-title::before{
  content:'';display:inline-block;
  width:3px;height:14px;background:var(--primary);border-radius:2px;
}

/* 顏色輔助類 */
.c-green{color:var(--green)}
.c-red{color:var(--red)}
.c-blue{color:var(--accent)}
.c-orange{color:var(--orange)}
.c-pink{color:var(--pink)}
.c-primary{color:var(--primary-light)}
.c-muted{color:var(--text3)}

/* ============ 表格 ============ */
.table-wrap{
  background:var(--card);border:1px solid var(--border);
  border-radius:16px;overflow:hidden;margin-bottom:24px;
  box-shadow:var(--shadow-sm);
  transition:background var(--trans-slow),box-shadow var(--trans-base);
}
.table-wrap:hover{box-shadow:var(--shadow-md)}
.table-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 20px;border-bottom:1px solid var(--border);
}
.table-header h3{font-size:16px;font-weight:600}
.table-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:500px}
th{
  text-align:left;padding:12px 20px;font-size:12px;color:var(--text2);
  text-transform:uppercase;letter-spacing:1px;
  border-bottom:1px solid var(--border);font-weight:500;white-space:nowrap;
}
td{padding:12px 20px;font-size:14px;border-bottom:1px solid var(--border)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(108,99,255,.03)}

/* ============ 標籤 ============ */
.tag{
  display:inline-flex;align-items:center;justify-content:center;
  gap:4px;padding:4px 10px;border-radius:20px;
  font-size:11px;font-weight:500;line-height:1.4;vertical-align:middle;
}
.tag .cat-icon{margin:0;font-size:13px;line-height:1;display:inline-flex;align-items:center}
.tag-green{background:rgba(34,197,94,.15);color:var(--green)}
.tag-red{background:rgba(239,68,68,.15);color:var(--red)}
.tag-blue{background:rgba(0,210,255,.15);color:var(--accent)}
.tag-orange{background:rgba(245,158,11,.15);color:var(--orange)}
.tag-purple{background:rgba(108,99,255,.15);color:var(--primary-light)}

/* ============ 按鈕 ============ */
.btn{
  padding:10px 20px;border-radius:10px;font-size:14px;
  font-weight:500;min-height:44px;
  transition:transform var(--trans-fast),box-shadow var(--trans-base),background var(--trans-base),border-color var(--trans-base),opacity var(--trans-base),color var(--trans-base);
  position:relative;will-change:transform;
}
.btn:active{transform:translateY(1px) scale(.98)}
.btn-p{
  background:linear-gradient(135deg,var(--primary),#5548d9);color:#fff;
  box-shadow:0 4px 14px rgba(108,99,255,.35),inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-p:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(108,99,255,.5),inset 0 1px 0 rgba(255,255,255,.2);
  filter:brightness(1.05);
}
/* v1.18.10：按鈕一律無描邊，靠陰影/底色立體感 */
.btn-s{background:var(--card);color:var(--text2);box-shadow:var(--shadow-sm)}
.btn-s:hover{
  color:var(--text);
  box-shadow:var(--shadow-md);transform:translateY(-1px);
}
.btn-danger{background:rgba(239,68,68,.18);color:var(--red);box-shadow:0 2px 6px rgba(239,68,68,.15)}
.btn-danger:hover{background:rgba(239,68,68,.28);box-shadow:0 4px 12px rgba(239,68,68,.3);transform:translateY(-1px)}
.btn-sm{padding:6px 14px;font-size:12px;border-radius:8px;min-height:36px}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}

/* ============ Modal ============ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.65);
  z-index:1000;display:none;align-items:center;justify-content:center;
  padding:20px;box-sizing:border-box;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  -webkit-overflow-scrolling:touch;
}
.modal-overlay.show{display:flex;animation:fadeIn .2s var(--ease-out-soft)}
.modal{
  background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:32px;width:460px;
  max-width:95vw;max-height:calc(100vh - 40px);overflow-y:auto;overflow-x:hidden;
  box-shadow:var(--shadow-xl);
  animation:modalIn .3s var(--ease-out);
  overscroll-behavior:contain;
}
/* 雙層結構 Modal：外層固定高度，內層滾動、底部操作列 sticky 不被遮擋 */
.modal.modal-scroll{padding:0;overflow:hidden}
.modal.modal-scroll > .modal-scroll-body{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  padding:28px 28px 8px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
}
.modal.modal-scroll > .modal-actions-sticky{
  position:sticky;bottom:0;
  margin-top:0;padding:14px 24px;
  background:var(--surface);
  border-top:1px solid var(--border);
  box-shadow:0 -4px 16px rgba(0,0,0,.12);
  display:flex;gap:8px;align-items:center;justify-content:flex-end;
  flex-wrap:wrap;z-index:2;
}
/* body scroll lock */
body.modal-open{overflow:hidden;touch-action:none}
@keyframes modalIn{
  from{opacity:0;transform:translateY(16px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
/* v1.18.12：手機底部 sheet 從下往上 + 尾端回彈 */
@keyframes modalSlideUp{
  0%   {opacity:.4; transform:translateY(100%)}
  60%  {opacity:1;  transform:translateY(-8px)}  /* overshoot 上彈 8px */
  80%  {transform:translateY(2px)}                /* 回拉小段 */
  100% {transform:translateY(0)}
}
.modal h3{font-size:18px;margin-bottom:20px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:13px;color:var(--text2);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:10px 14px;background:var(--card);
  border:1px solid var(--border);border-radius:10px;
  color:var(--text);font-size:14px;min-height:44px;
}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}

/* ============ 圖表容器 ============ */
.chart-container{
  background:var(--card);border:1px solid var(--border);
  border-radius:16px;padding:20px;margin-bottom:24px;
  box-shadow:var(--shadow-sm);
  transition:background var(--trans-slow),box-shadow var(--trans-base),transform var(--trans-base);
}
.chart-container:hover{box-shadow:var(--shadow-md)}
.chart-container h3{font-size:16px;font-weight:600;margin-bottom:16px;text-align:center}
.chart-bar-group{margin-bottom:12px}
.chart-bar-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}
.chart-bar{height:24px;background:var(--bar-bg);border-radius:6px;overflow:hidden}
.chart-bar-fill{height:100%;border-radius:6px;transition:width .6s ease}
.pie-chart-wrap{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.pie-legend{display:flex;flex-direction:column;gap:8px}
.pie-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}
.pie-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}

/* ============ 匯率換算 ============ */
.converter-box{
  background:var(--card);border:1px solid var(--border);
  border-radius:16px;padding:24px;max-width:640px;
  margin:0 auto;
}
.converter-box .conv-row{display:flex;gap:12px;align-items:center;margin-bottom:16px}
.converter-box input{
  flex:1;padding:12px;background:var(--bg);
  border:1px solid var(--border);border-radius:10px;
  color:var(--text);font-size:18px;
}
.converter-box select{
  padding:12px;background:var(--bg);border:1px solid var(--border);
  border-radius:10px;color:var(--text);font-size:14px;min-width:90px;
}
.converter-result{
  font-size:28px;font-weight:700;text-align:center;
  padding:16px;background:var(--bg);border-radius:12px;margin-top:8px;
}
.rate-info{font-size:12px;color:var(--text3);text-align:center;margin-top:12px}

/* ============ 篩選列 ============ */
.filter-bar{
  display:flex;gap:12px;align-items:center;
  flex-wrap:wrap;margin-bottom:20px;
}
.filter-bar select,.filter-bar input{
  padding:8px 14px;background:var(--card);
  border:1px solid var(--border);border-radius:10px;
  color:var(--text);font-size:13px;min-height:40px;
}

/* ============ 操作按鈕 ============ */
.del-btn{color:var(--text3);cursor:pointer;transition:.2s;min-width:28px;min-height:28px;display:inline-flex;align-items:center;justify-content:center}
.del-btn:hover{color:var(--red)}
.edit-btn{color:var(--text3);cursor:pointer;transition:.2s;margin-right:10px;min-width:28px;min-height:28px;display:inline-flex;align-items:center;justify-content:center}
.edit-btn:hover{color:var(--primary)}
/* v1.18.8：應收/付勾選框永遠顯示——未付灰色、已付綠色 */
.edit-btn.paid-toggle{filter:grayscale(1);opacity:.45}
.edit-btn.paid-toggle:hover{filter:grayscale(.6);opacity:.75;color:var(--green, #22c55e)}
.edit-btn.paid-toggle.paid{filter:none;opacity:1;color:var(--green, #22c55e)}
.edit-btn.paid-toggle.paid:hover{opacity:.85}

/* ============ 拖拽 ============ */
.drag-handle{cursor:grab;color:var(--text3);user-select:none;font-size:16px;padding:0 8px;transition:.2s}
.drag-handle:hover{color:var(--text)}
.drag-handle:active{cursor:grabbing}
tr.dragging{opacity:.4;background:rgba(108,99,255,.1)}
tr.drag-over-top td{border-top:3px solid var(--primary)!important;border-top-style:solid!important}
tr.drag-over-bottom td{border-bottom:3px solid var(--primary)!important;border-bottom-style:solid!important}

/* ============ 主題切換 ============ */
.theme-toggle{
  display:flex;align-items:center;gap:8px;
  padding:8px 20px;cursor:pointer;color:var(--text2);font-size:13px;
  transition:.2s;min-height:40px;flex-shrink:0;
}
.theme-toggle:hover{color:var(--text)}
.theme-toggle .toggle-track{
  width:40px;height:22px;background:var(--border);
  border-radius:11px;position:relative;transition:.3s;
}
.theme-toggle .toggle-thumb{
  width:18px;height:18px;background:#fff;border-radius:50%;
  position:absolute;top:2px;left:2px;transition:.3s;
}
html.light .theme-toggle .toggle-track{background:var(--primary)}
html.light .theme-toggle .toggle-thumb{left:20px}

/* ============ 頁籤列 ============ */
.tab-bar{
  display:flex;gap:4px;margin-bottom:20px;
  background:var(--card);border-radius:12px;padding:4px;
  border:1px solid var(--border);flex-wrap:wrap;
  box-shadow:var(--shadow-sm);
}
.tab-btn{
  padding:8px 16px;border-radius:10px;font-size:13px;
  color:var(--text2);min-height:40px;position:relative;
  transition:background var(--trans-base),color var(--trans-base),transform var(--trans-fast),box-shadow var(--trans-base);
}
.tab-btn.active{
  background:linear-gradient(135deg,var(--primary),#5548d9);color:#fff;
  box-shadow:0 4px 12px rgba(108,99,255,.35),inset 0 1px 0 rgba(255,255,255,.15);
}
.tab-btn:hover:not(.active){background:rgba(108,99,255,.12);color:var(--text)}
.tab-btn:active{transform:scale(.96)}

/* ============ 雙欄格線 ============ */
.dual-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* ============ 圖示 ============ */
.cat-icon{margin-right:6px;font-size:15px}

/* ============ 新聞卡 ============ */
.news-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:16px;margin-bottom:12px;
  box-shadow:var(--shadow-sm);
  transition:background var(--trans-slow),border-color var(--trans-base),transform var(--trans-base),box-shadow var(--trans-base);
}
.news-card:hover{
  border-color:var(--primary);transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.news-card .news-title{font-weight:600;font-size:14px;margin-bottom:6px}
.news-card .news-meta{font-size:12px;color:var(--text3)}
.news-card .news-src{color:var(--accent);font-size:11px}

/* ============ 股票卡 ============ */
.stock-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:16px;display:flex;
  justify-content:space-between;align-items:center;margin-bottom:10px;
  box-shadow:var(--shadow-sm);
  transition:transform var(--trans-base),box-shadow var(--trans-base),border-color var(--trans-base);
}
.stock-card:hover{
  transform:translateY(-2px);box-shadow:var(--shadow-md);
  border-color:rgba(108,99,255,.3);
}
.stock-card .stock-name{font-weight:600;font-size:14px}
.stock-card .stock-code{font-size:12px;color:var(--text3)}
.stock-card .stock-price{font-size:20px;font-weight:700;letter-spacing:-.02em}
.stock-card .stock-change{font-size:13px;font-weight:500}

/* ============ Icon Picker ============ */
.icon-grid{
  display:grid;grid-template-columns:repeat(8,1fr);gap:4px;
  max-height:300px;overflow-y:auto;margin-bottom:16px;
}
.icon-option{
  display:flex;align-items:center;justify-content:center;
  width:40px;height:40px;font-size:22px;cursor:pointer;
  border-radius:8px;transition:.2s;
}
.icon-option:hover{background:rgba(108,99,255,.2)}

/* ============ Sortable Table Headers ============ */
th.sortable{cursor:pointer;user-select:none;white-space:nowrap;transition:background .2s}
th.sortable:hover{background:rgba(108,99,255,.1)}
.sort-icon{font-size:10px;opacity:.3;margin-left:2px;vertical-align:middle}
.sort-icon.active{opacity:1;color:var(--primary)}

/* ============ Category Row ============ */
.cat-row{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;border-bottom:1px solid var(--border);
}
.cat-row:last-child{border-bottom:none}
.cat-icon-btn{
  font-size:20px;cursor:pointer;padding:4px;
  border-radius:8px;transition:.2s;min-width:32px;text-align:center;
}
.cat-icon-btn:hover{background:rgba(108,99,255,.15)}
.cat-name{flex:1;font-size:14px}
.cat-group{border-bottom:1px solid var(--border);padding-bottom:4px;margin-bottom:4px}
.cat-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.cat-group .cat-row{border-bottom:none}
.sub-cat-toggle{cursor:pointer;font-size:16px;color:var(--primary);padding:2px 6px;border-radius:6px;transition:.2s}
.sub-cat-toggle:hover{background:rgba(108,99,255,.15)}
/* v1.17.3：每個主類別的子類別展開/收合 chevron */
.cat-sub-toggle{
  cursor:pointer;font-size:11px;color:var(--text3);padding:3px 8px;border-radius:6px;
  background:var(--surface);border:1px solid var(--border);transition:.2s;
  display:inline-flex;align-items:center;gap:4px;user-select:none;
}
.cat-sub-toggle:hover{background:rgba(108,99,255,.1);color:var(--primary-light);border-color:var(--primary)}
.cat-sub-toggle.cat-sub-toggle-empty{cursor:default;opacity:.45}
.cat-sub-toggle.cat-sub-toggle-empty:hover{background:var(--surface);color:var(--text3);border-color:var(--border)}
.cat-subs-wrap{}
.sub-cat-row{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 42px;font-size:13px;color:var(--text2)}
.sub-cat-dot{font-size:18px;font-weight:bold;color:var(--text3)}
.sub-cat-add{display:flex;gap:8px;padding:6px 12px 6px 42px;align-items:center}
.sub-cat-input{padding:6px 10px;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;flex:1}
.sub-cat-label{font-size:11px;color:var(--text3);margin-left:2px}

/* ============ 帳單掃描 ============ */
.bill-upload-area{
  border:2px dashed var(--border);border-radius:16px;
  padding:40px 20px;text-align:center;cursor:pointer;
  transition:border-color .3s,background .3s;
}
.bill-upload-area:hover,.bill-upload-area.bill-drag-over{
  border-color:var(--primary);background:rgba(108,99,255,.05);
}
.bill-upload-icon{font-size:48px;margin-bottom:12px}
.bill-upload-area p{color:var(--text2);font-size:14px;margin-bottom:4px}
.bill-progress-bar{
  height:8px;background:var(--bar-bg);border-radius:4px;overflow:hidden;
}
.bill-progress-fill{
  height:100%;background:linear-gradient(135deg,var(--primary),var(--accent));
  border-radius:4px;transition:width .3s;width:0%;
}
.bill-item{
  display:flex;gap:12px;padding:12px;
  border:1px solid var(--border);border-radius:12px;
  margin-bottom:8px;background:var(--card);
}
.bill-item-check{display:flex;align-items:flex-start;padding-top:8px}
.bill-item-check input[type="checkbox"]{
  width:18px;height:18px;accent-color:var(--primary);cursor:pointer;
}
.bill-item-fields{flex:1;display:flex;flex-direction:column;gap:8px}
.bill-item-row{display:flex;gap:8px}
.bill-item-row input,.bill-item-row select{
  padding:8px 10px;background:var(--bg);
  border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:13px;min-height:36px;min-width:0;
}
.bill-item-row input[type="text"]{flex:3}
.bill-item-row select{flex:1.5}
.bill-item-row input:focus,.bill-item-row select:focus{
  outline:none;border-color:var(--primary);
}

/* ============ 同步狀態 ============ */
.sync-status{
  position:fixed;bottom:16px;right:16px;
  padding:10px 18px;border-radius:12px;font-size:12px;font-weight:500;
  z-index:9999;pointer-events:auto;
  box-shadow:var(--shadow-lg);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:opacity .3s,transform .3s var(--ease-out);
  animation:syncIn .35s var(--ease-out);
}
@keyframes syncIn{
  from{opacity:0;transform:translateX(40px) scale(.9)}
  to{opacity:1;transform:translateX(0) scale(1)}
}
.sync-ok{background:rgba(34,197,94,.18);color:var(--green);border:1px solid rgba(34,197,94,.3);opacity:1}
.sync-err{background:rgba(239,68,68,.18);color:var(--red);border:1px solid rgba(239,68,68,.3);opacity:1}
.sync-saving{
  background:rgba(108,99,255,.18);color:var(--primary-light);border:1px solid rgba(108,99,255,.3);opacity:1;
}
.sync-saving::before{
  content:'';display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--primary-light);margin-right:8px;
  animation:pulse 1.2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.7)}
}
.sync-hide{opacity:0;transform:translateX(20px) scale(.95);pointer-events:none}

/* ============ 捲動條 ============ */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* ============ 輸入框統一樣式（全域強化） ============ */
input,select,textarea{
  font-family:inherit;
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  box-sizing:border-box;
}
/* select 加自訂下拉箭頭 */
select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%236b7280' d='M6 8L0 0h12z'/></svg>");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:32px!important;
}
/* 輸入聚焦效果 */
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:var(--primary)!important;
  box-shadow:0 0 0 3px rgba(108,99,255,.15);
}
/* placeholder 色 */
input::placeholder,textarea::placeholder{color:var(--text3);opacity:.7}
/* number input 去除上下箭頭 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}
/* checkbox 保持原生 */
input[type=checkbox],input[type=radio]{-webkit-appearance:auto;appearance:auto;width:18px;height:18px;cursor:pointer}
/* textarea：垂直 resize */
textarea{resize:vertical;min-height:80px;line-height:1.5}
/* date/time input：保持原生圖示但統一外框；Chrome 日曆圖示顯示 */
input[type=date],input[type=time],input[type=datetime-local],input[type=month]{
  -webkit-appearance:none;appearance:none;
  background-image:none;  /* 覆蓋 select 的箭頭 */
  padding-right:14px!important;
  color-scheme:light dark;
}
input[type=date]::-webkit-calendar-picker-indicator,
input[type=time]::-webkit-calendar-picker-indicator{
  filter:invert(.6);cursor:pointer;opacity:.8;padding:2px;
}
html.light input[type=date]::-webkit-calendar-picker-indicator,
html.light input[type=time]::-webkit-calendar-picker-indicator{filter:none}
/* color input */
input[type=color]{padding:2px!important;height:40px;min-height:40px}
/* disabled 狀態 */
input:disabled,select:disabled,textarea:disabled{opacity:.5;cursor:not-allowed}
/* 輸入群組間距統一 */
.form-group + .form-group{margin-top:0}

/* ============ 手機「更多」彈出選單 ============ */
.more-menu-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.65);
  z-index:900;display:none;align-items:flex-end;justify-content:center;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  animation:fadeIn .2s ease;
}
.more-menu-overlay.show{display:flex}
.more-menu-sheet{
  width:100%;max-width:500px;background:var(--surface);
  border-radius:20px 20px 0 0;padding:12px 20px 24px;
  box-shadow:0 -8px 32px rgba(0,0,0,.3);
  animation:slideUp .28s cubic-bezier(.2,.9,.3,1);
  padding-bottom:calc(24px + env(safe-area-inset-bottom,0));
}
.more-menu-handle{
  width:40px;height:4px;border-radius:2px;background:var(--border);
  margin:0 auto 16px;
}
.more-menu-title{font-size:16px;font-weight:600;margin-bottom:16px;text-align:center;color:var(--text)}
.more-menu-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  margin-bottom:16px;
}
.more-menu-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;padding:14px 8px;border-radius:12px;
  background:var(--card);color:var(--text);font-size:12px;
  cursor:pointer;transition:.2s;text-align:center;
  min-height:72px;
}
.more-menu-item:active{transform:scale(.96);background:rgba(108,99,255,.15)}
.more-menu-item svg{width:22px;height:22px;color:var(--primary-light)}
.more-menu-close{width:100%;min-height:44px}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* ======================================================== */
/* ============ RWD - 平板 (769px ~ 1024px) ============ */
/* ======================================================== */
@media(min-width:769px) and (max-width:1024px){
  :root{--sidebar-width:200px}
  .sidebar{width:var(--sidebar-width)}
  .sidebar .logo{font-size:18px;padding:0 16px}
  .nav-item{padding:10px 16px;font-size:13px;gap:10px}
  .nav-item span{display:inline}
  .main{margin-left:var(--sidebar-width);padding:24px}
  .stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
  .stat-card .value{font-size:20px}
  .dual-grid{grid-template-columns:1fr 1fr;gap:16px}
  .page-title{font-size:22px}
  .user-info{padding:6px 16px}
  .theme-toggle{padding:8px 16px}
}

/* ======================================================== */
/* ============ RWD - 手機 (max-width: 768px) ============ */
/* ======================================================== */
@media(max-width:768px){
  :root{--sidebar-width:0px}

  body{font-size:14px}

  /* 隱藏桌面側邊欄 */
  .sidebar{display:none}

  /* 顯示底部導航 */
  .bottom-nav{display:flex}

  /* 主內容區全寬，底部留空給 bottom-nav */
  /* v1.18.9：移除右上浮動 avatar 後恢復全寬，右邊不再保留 64px */
  .main{
    margin-left:0;padding:16px;padding-bottom:88px;
    padding-top:calc(16px + env(safe-area-inset-top,0));
    height:100vh;
    width:100%;max-width:100vw;
  }
  .page{max-width:100%;width:100%}

  /* 顯示漢堡按鈕（可選，目前使用底部導航所以隱藏） */
  .mobile-menu-btn{display:none}

  /* 頁面標題 */
  .page-title{font-size:20px;margin-bottom:16px}

  /* 統計卡片：手機用 2 欄 */
  .stat-grid{
    grid-template-columns:repeat(2,1fr);
    gap:10px;margin-bottom:20px;
  }
  .stat-card{padding:14px;border-radius:12px}
  .stat-card .value{font-size:18px}
  .stat-card .label{font-size:11px;letter-spacing:.5px}
  .stat-card .sub{font-size:11px}

  /* 表格：水平滾動 */
  .table-wrap{border-radius:12px}
  .table-header{padding:12px 16px}
  .table-header h3{font-size:14px}
  table{min-width:600px}
  th{padding:10px 12px;font-size:11px}
  td{padding:10px 12px;font-size:13px}

  /* Modal：手機全寬、底部 sheet；限制在安全區內 + 從下往上帶回彈動畫 */
  .modal-overlay{align-items:flex-end}
  .modal{
    width:100%;max-width:100vw;
    border-radius:20px 20px 0 0;
    padding:24px 20px;
    /* v1.18.12：safe-area 上限 → 不會被瀏海/dynamic island 蓋住 */
    max-height:calc(100vh - env(safe-area-inset-top,0) - 20px);
    padding-bottom:calc(24px + env(safe-area-inset-bottom,0));
    /* v1.18.12：換成「從下往上 + 尾端回彈」；尾段用 overshoot cubic-bezier */
    animation:modalSlideUp .42s cubic-bezier(.22,1.2,.36,1);
  }
  .modal h3{font-size:16px;margin-bottom:16px}
  .form-row{grid-template-columns:1fr}

  /* 圖表：堆疊而非並排 */
  .dual-grid{grid-template-columns:1fr!important;gap:16px}
  .pie-chart-wrap{flex-direction:column;align-items:center;gap:16px}

  /* 圖表容器 */
  .chart-container{padding:16px;border-radius:12px;margin-bottom:16px}
  .chart-container h3{font-size:14px;margin-bottom:12px}

  /* 登入框 */
  .login-box{
    width:100%;max-width:100vw;padding:32px 20px;
    border-radius:16px;margin:0 12px;
  }
  .login-box h1{font-size:24px}
  /* 輸入框 16px 防 iOS Safari 縮放 */
  .login-box input{font-size:16px;padding:12px 14px}

  /* 篩選列 */
  .filter-bar{gap:8px;margin-bottom:16px}
  .filter-bar select,.filter-bar input{
    padding:10px 12px;font-size:14px;
    min-height:44px;flex:1 1 auto;min-width:0;
  }
  .filter-bar .btn{font-size:13px;padding:10px 14px;white-space:nowrap;min-height:44px}

  /* 頁籤列 */
  .tab-bar{
    flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    gap:4px;padding:4px;
    scrollbar-width:none;
  }
  .tab-bar::-webkit-scrollbar{display:none}

  /* v1.18.9：舊底部 3-tab sub-nav 已移除，整合到 cal-switcher-row 內的 combobox + 模式 seg。 */
  .tab-btn{padding:10px 14px;font-size:13px;white-space:nowrap;flex-shrink:0;min-height:40px}

  /* 匯率換算 */
  .converter-box{padding:16px;max-width:100%}
  .converter-box .conv-row{flex-direction:column;gap:8px}
  .converter-box input{font-size:16px}
  .converter-result{font-size:22px;padding:12px}

  /* 按鈕群組 */
  .btn-group{flex-wrap:wrap}

  /* 新聞卡/股票卡 */
  .news-card{padding:12px}
  .stock-card{padding:12px;flex-wrap:wrap;gap:8px}
  .stock-card .stock-price{font-size:16px}

  /* 同步狀態：手機底部導航上方 */
  .sync-status{bottom:80px;right:12px;font-size:11px}

  /* 拖拽手把放大 */
  .drag-handle{font-size:20px;padding:0 12px}

  /* 按鈕觸控友好 */
  .btn{min-height:44px}
  .del-btn,.edit-btn{min-width:36px;min-height:36px;font-size:16px}

  /* Icon Picker mobile */
  .icon-grid{grid-template-columns:repeat(6,1fr)}
  .icon-option{width:36px;height:36px;font-size:20px}

  /* Bill Scanner mobile */
  .bill-upload-area{padding:24px 16px}
  .bill-upload-icon{font-size:36px}
  .bill-item{padding:10px;gap:8px}
  .bill-item-row{flex-wrap:wrap}
  .bill-item-row input,.bill-item-row select{font-size:14px;min-width:0;flex:1 1 45%}

  /* 應收款表格優化 */
  #receivableSection table{min-width:700px}
  #receivableSection th,#receivableSection td{padding:8px 10px;font-size:12px;white-space:nowrap}

  /* 資產 tab 欄可水平滾動 */
  #assetTabBar{
    flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    gap:4px;padding:4px;scrollbar-width:none;
  }
  #assetTabBar::-webkit-scrollbar{display:none}
  #assetTabBar .tab-btn{padding:10px 14px;font-size:13px;white-space:nowrap;flex-shrink:0;min-height:40px}

  /* 表格操作按鈕不換行 */
  td .btn-group,td div[style*="gap"]{flex-wrap:nowrap}

  /* form-group：Modal 內輸入框 16px 防 iOS 縮放 */
  .form-group{margin-bottom:14px}
  .form-group label{font-size:13px;margin-bottom:6px}
  .form-group input,.form-group select,.form-group textarea{
    font-size:16px;padding:12px 14px;min-height:48px;
  }

  /* 子類別管理手機優化 */
  .cat-group{padding:10px;margin-bottom:8px}
  .sub-cat-row{padding:4px 0;font-size:13px}
  .sub-cat-add{gap:6px}
  .sub-cat-add input{font-size:14px;padding:8px 10px}

  /* 新聞卡片手機觸控友好 */
  a.news-card{padding:14px;margin-bottom:8px}
  a.news-card:active{opacity:0.7}
  .news-card .news-title{font-size:14px;line-height:1.5}
  .news-card .news-meta{font-size:12px;line-height:1.4}

  /* 投資卡片手機適配 */
  .stock-card{gap:6px}
  .stock-card .stock-name{font-size:14px}
  .stock-card .stock-code{font-size:12px}
  .stock-card .stock-change{font-size:12px}

  /* 確認彈窗手機適配 */
  #confirmModalOverlay .modal{
    max-width:92vw;
    border-radius:16px;
    margin:0 auto;
  }

  /* 底部導航：5 項均分，觸控放大 */
  .bottom-nav{padding:6px 4px;padding-bottom:calc(6px + env(safe-area-inset-bottom,0))}
  .bottom-nav .bottom-nav-item{
    flex:1;min-height:52px;padding:6px 2px;font-size:10px;gap:3px;
  }
  .bottom-nav .bottom-nav-item svg{width:22px;height:22px}

  /* 股票卡容器、收支卡片等 flex 容器自動 wrap */
  .stat-card .sub{word-break:break-word;line-height:1.4}

  /* Bill scanner 信用卡下拉 16px */
  #billCardSelect{font-size:16px;min-height:48px}

  /* 更多選單手機 4 欄 */
  .more-menu-grid{grid-template-columns:repeat(4,1fr);gap:8px}
  .more-menu-item{padding:10px 4px;min-height:68px;font-size:11px}
  .more-menu-item svg{width:20px;height:20px}
}

/* ============ 批量選取工具列 ============ */
.bulk-action-bar{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;margin-bottom:16px;
  background:linear-gradient(135deg,rgba(108,99,255,.12),rgba(108,99,255,.06));
  border:1px solid rgba(108,99,255,.35);
  border-radius:12px;
  box-shadow:var(--shadow-sm);
  animation:slideDown .25s var(--ease-out);
  font-size:13px;color:var(--text);
}
.bulk-action-bar strong{color:var(--primary-light);font-size:16px;margin:0 4px}
@keyframes slideDown{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}

/* 行內 checkbox（表格用） */
.row-check{cursor:pointer;vertical-align:middle}
tr.row-selected td{background:rgba(108,99,255,.08)}

/* ============ 勳章卡呼吸光暈（v1.9.3） ============ */
@keyframes medalGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(251,191,36,.5),0 8px 24px rgba(251,191,36,.3)}
  50%{box-shadow:0 0 0 12px rgba(251,191,36,0),0 8px 24px rgba(251,191,36,.5)}
}
[style*="linear-gradient(135deg,#fbbf24"]{
  animation:medalGlow 2.4s ease-in-out infinite;
}

/* ============ 進度條動畫 ============ */
.chart-bar-fill{transition:width .8s var(--ease-out)}

/* ============ 觸控裝置：停用 hover 浮起效果避免「卡住」（v1.10.4） ============ */
/* 只有真的能 hover 的裝置（滑鼠）才有 lift 動態。觸控裝置按完就釋放，不留殘影。 */
@media(hover:none){
  .stat-card:hover,
  .news-card:hover,
  .stock-card:hover,
  .chart-container:hover,
  .table-wrap:hover,
  .btn-p:hover,
  .btn-s:hover,
  .btn-danger:hover,
  .user-card:hover{
    transform:none!important;
  }
  .stat-card:hover{box-shadow:var(--shadow-sm),var(--shadow-inset)!important;border-color:var(--border)!important}
  .stat-card:hover::before{opacity:0!important}
  .news-card:hover{box-shadow:var(--shadow-sm)!important;border-color:var(--border)!important}
  .stock-card:hover{box-shadow:var(--shadow-sm)!important;border-color:var(--border)!important}
  .chart-container:hover{box-shadow:var(--shadow-sm)!important}
  .table-wrap:hover{box-shadow:var(--shadow-sm)!important}
  .btn-p:hover{box-shadow:0 4px 14px rgba(108,99,255,.35),inset 0 1px 0 rgba(255,255,255,.15)!important;filter:none!important}
  .btn-s:hover{box-shadow:var(--shadow-sm)!important;border-color:var(--border)!important;color:var(--text2)!important}
  .btn-danger:hover{box-shadow:none!important;background:rgba(239,68,68,.15)!important}
  .nav-item:hover{padding-left:20px!important;background:initial!important;color:var(--text2)!important}
  .nav-item:hover svg{transform:none!important}
  .user-card:hover{border-color:var(--border)!important;background:var(--card)!important}
  .avatar-emoji-opt:hover{transform:none!important}
}

/* ============ 尊重使用者 prefers-reduced-motion ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* ============ 極小螢幕 (max-width: 400px) ============ */
@media(max-width:400px){
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .stat-card{padding:12px}
  .stat-card .value{font-size:16px}
  .main{padding:12px;padding-bottom:88px}
  .page-title{font-size:18px}
  .login-box{padding:24px 16px;margin:0 8px}
  .modal{padding:20px 16px}
  .filter-bar{gap:6px}
  .filter-bar select,.filter-bar input{font-size:14px;padding:8px 10px;min-height:40px}
  .filter-bar .btn{font-size:12px;padding:8px 12px;min-height:40px}
  .chart-container{padding:12px}
  table{min-width:500px}
  th{padding:8px 10px;font-size:10px}
  td{padding:8px 10px;font-size:12px}
  .stock-card{padding:10px}
  .news-card{padding:10px}
  #confirmModalOverlay .modal{max-width:95vw;padding:20px 16px}
  /* 底部導航更小螢幕仍可見 */
  .bottom-nav .bottom-nav-item{font-size:9px}
  .bottom-nav .bottom-nav-item svg{width:20px;height:20px}
  /* 更多選單 3 欄，項目不致太擠 */
  .more-menu-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .more-menu-item{font-size:11px;min-height:64px;padding:10px 4px}
  .more-menu-item svg{width:20px;height:20px}
  /* Tab 按鈕在極小螢幕仍保留可讀性 */
  .tab-btn{padding:8px 10px;font-size:12px;min-height:38px}
  /* Modal 在極小螢幕 max-height 略縮以留出 keyboard 空間 */
  .modal{max-height:88vh}
}

/* ============ 群組行事曆 (v1.12 / v1.13) ============ */
.cal-view-seg{
  display:inline-flex;background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:3px;gap:2px;flex-shrink:0;
}
.cal-view-seg-btn{
  padding:6px 12px;border-radius:8px;font-size:13px;color:var(--text2);
  cursor:pointer;min-height:34px;min-width:40px;
  transition:background var(--trans-base),color var(--trans-base);
}
.cal-view-seg-btn:hover:not(.active){background:rgba(108,99,255,.1);color:var(--text)}
.cal-view-seg-btn.active{
  background:linear-gradient(135deg,var(--primary),#5548d9);color:#fff;
  box-shadow:0 2px 8px rgba(108,99,255,.3);
}

.cal-week-list{display:flex;flex-direction:column;gap:10px}
.cal-week-day{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:12px 14px;cursor:pointer;
  transition:background var(--trans-base),border-color var(--trans-base);
}
.cal-week-day:hover{border-color:var(--primary);background:rgba(108,99,255,.04)}
.cal-week-day.today{border-color:var(--primary);background:rgba(108,99,255,.08)}
.cal-week-day.sun .cal-week-day-dow{color:var(--red)}
.cal-week-day.sat .cal-week-day-dow{color:var(--primary-light)}
.cal-week-day-head{
  display:flex;align-items:center;gap:10px;margin-bottom:8px;
}
.cal-week-day-dow{font-size:13px;font-weight:600;color:var(--text)}
.cal-week-day-date{font-size:12px;color:var(--text3)}
.cal-week-day-badge{
  margin-left:auto;padding:2px 10px;border-radius:999px;
  background:rgba(108,99,255,.15);color:var(--primary-light);
  font-size:11px;font-weight:600;
}
.cal-week-day-empty{color:var(--text3);font-size:12px;padding:4px 0;text-align:center}
.cal-week-day-events{display:flex;flex-wrap:wrap;gap:6px}
.cal-week-event{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:8px;
  font-size:12px;color:#fff;cursor:pointer;
  max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:filter var(--trans-base);
}
.cal-week-event:hover{filter:brightness(1.1)}


/* v1.18.9：行事曆切換整合列 — combobox + 顯示模式 seg + overflow ⋯
   取代原 cal-switcher pill bar + 底部 3-tab sub-nav */
.cal-switcher-row{
  display:flex;gap:8px;align-items:center;flex-wrap:nowrap;
  padding:6px 8px;background:var(--card);border:1px solid var(--border);
  border-radius:12px;margin-bottom:12px;
}
/* v1.18.10：自訂下拉 combobox — 開合位置在按鈕「下方」、寬度依內容自適應（max-content）*/
.cal-combo-wrap{
  position:relative;flex:0 1 auto;min-width:0;max-width:100%;
}
.cal-combobox{
  display:inline-flex;align-items:center;gap:6px;
  max-width:100%;
  padding:8px 12px;
  border-radius:8px;
  background:var(--surface);color:var(--text);
  box-shadow:var(--shadow-sm);
  font-size:13px;min-height:36px;cursor:pointer;
  text-align:left;
}
.cal-combobox:focus{outline:none;box-shadow:0 0 0 2px rgba(108,99,255,.3),var(--shadow-sm)}
.cal-combobox:hover{box-shadow:var(--shadow-md)}
.cal-combo-label{
  flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.cal-combo-caret{
  flex-shrink:0;font-size:11px;color:var(--text3);transition:transform var(--trans-fast);
}
.cal-combo-wrap.open .cal-combo-caret{transform:rotate(180deg)}
.cal-combo-menu{
  display:none;position:absolute;
  /* v1.18.10：開在按鈕下方，避免蓋住選中的 combobox */
  top:calc(100% + 6px);left:0;
  min-width:100%;
  /* 寬度依最長項自適應，手機最多不超過畫面寬 */
  width:max-content;max-width:calc(100vw - 40px);
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  box-shadow:0 10px 26px rgba(0,0,0,.28);
  padding:4px;z-index:310;
  max-height:min(60vh,360px);overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
html.light .cal-combo-menu{box-shadow:0 10px 26px rgba(15,23,42,.12)}
.cal-combo-wrap.open .cal-combo-menu{display:block}
.cal-combo-item{
  padding:10px 12px;font-size:13px;color:var(--text);cursor:pointer;
  border-radius:8px;white-space:nowrap;
  transition:background var(--trans-base);
}
.cal-combo-item:hover{background:rgba(108,99,255,.08);color:var(--primary-light)}
.cal-combo-item.active{color:var(--primary-light);background:rgba(108,99,255,.10);font-weight:600}

.cal-combobox-static{
  flex:0 1 auto;min-width:0;max-width:100%;
  padding:8px 12px;border-radius:8px;
  background:var(--surface);border:1px solid var(--border);color:var(--text);
  font-size:13px;min-height:36px;display:inline-flex;align-items:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  cursor:default;
}
/* 顯示模式 seg：傳統 / 清單 */
.cal-mode-seg{
  display:inline-flex;flex-shrink:0;
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  overflow:hidden;
}
.cal-mode-seg-btn{
  padding:8px 12px;background:transparent;color:var(--text2);border:none;
  font-size:12px;cursor:pointer;white-space:nowrap;min-height:36px;
  transition:background var(--trans-base),color var(--trans-base);
}
/* v1.18.10：segmented control 內部改用細窄間距而非 border-right 分隔 */
.cal-mode-seg-btn:not(:last-child){margin-right:1px}
.cal-mode-seg-btn:hover{color:var(--text)}
.cal-mode-seg-btn.active{
  background:linear-gradient(135deg,var(--primary),#5548d9);
  color:#fff;
}
/* overflow ⋯（新增群組 / 掃碼加入 / 管理群組 / 手動同步） */
.cal-switcher-overflow-wrap{position:relative;flex-shrink:0}
.cal-switcher-overflow-btn{
  width:36px;height:36px;padding:0;border-radius:8px;
  background:var(--surface);box-shadow:var(--shadow-sm);color:var(--text2);
  font-weight:700;font-size:18px;letter-spacing:.5px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:box-shadow var(--trans-base),color var(--trans-base);
}
.cal-switcher-overflow-btn:hover{box-shadow:var(--shadow-md);color:var(--primary-light)}
.cal-switcher-overflow-menu{
  display:none;position:absolute;top:calc(100% + 6px);right:0;
  min-width:160px;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.25);
  padding:4px;z-index:300;
}
html.light .cal-switcher-overflow-menu{box-shadow:0 8px 24px rgba(15,23,42,.12)}
.cal-switcher-overflow-wrap.open .cal-switcher-overflow-menu{display:block}
.cal-switcher-overflow-menu .cso-item{
  padding:10px 12px;font-size:13px;color:var(--text);cursor:pointer;
  border-radius:8px;white-space:nowrap;
  transition:background var(--trans-base);
}
.cal-switcher-overflow-menu .cso-item:hover{background:rgba(108,99,255,.08);color:var(--primary-light)}
@media(max-width:420px){
  .cal-mode-seg-btn{padding:8px 8px;font-size:11px}
}

/* v1.19.2：緊湊版 combobox — 給 view 切換 + 清單篩選用（寬度依內容，內距比群組 combobox 小） */
.cal-combo-compact{flex:0 0 auto}
.cal-combobox-compact{
  padding:6px 10px;min-height:34px;font-size:12px;gap:4px;
  background:var(--card);border:1px solid var(--border);
}
.cal-combobox-compact .cal-combo-label{font-weight:500}
.cal-combo-compact .cal-combo-menu{min-width:90px}

/* v1.19.2：年檢視 12 個月縮圖網格 */
.cal-year-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;
  margin-top:4px;
}
.cal-year-month{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:12px;cursor:pointer;
  transition:border-color var(--trans-base),background var(--trans-base),transform var(--trans-fast);
}
.cal-year-month:hover{border-color:var(--primary);background:rgba(108,99,255,.04)}
.cal-year-month.current{border-color:var(--primary);background:rgba(108,99,255,.08)}
.cal-year-month-head{
  display:flex;align-items:center;gap:8px;margin-bottom:8px;
}
.cal-year-month-name{font-size:14px;font-weight:600;color:var(--text)}
.cal-year-month-badge{
  margin-left:auto;padding:2px 8px;border-radius:999px;
  background:rgba(108,99,255,.15);color:var(--primary-light);
  font-size:11px;font-weight:600;
}
.cal-ym-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:2px;
}
.cal-ym-weekday{
  font-size:10px;text-align:center;color:var(--text3);font-weight:500;
  padding:2px 0;
}
.cal-ym-weekday.sun{color:var(--red)}
.cal-ym-weekday.sat{color:var(--primary-light)}
.cal-ym-cell{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:11px;color:var(--text2);border-radius:4px;
  min-height:20px;
}
.cal-ym-cell.muted{opacity:0}
.cal-ym-cell.sun{color:var(--red)}
.cal-ym-cell.sat{color:var(--primary-light)}
.cal-ym-cell.has{
  background:rgba(108,99,255,.18);color:var(--primary-light);font-weight:600;
}
.cal-ym-cell.today{
  background:linear-gradient(135deg,var(--primary),#5548d9);color:#fff;
  font-weight:700;box-shadow:0 1px 4px rgba(108,99,255,.3);
}
@media(max-width:420px){
  .cal-year-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .cal-year-month{padding:8px}
  .cal-ym-cell{font-size:10px;min-height:18px}
  .cal-year-month-name{font-size:12px}
}

.group-card{
  background:linear-gradient(135deg,rgba(108,99,255,.08),rgba(0,210,255,.04));
  border:1px solid rgba(108,99,255,.22);
  border-radius:14px;padding:16px 18px;margin-bottom:14px;
  transition:transform var(--trans-base),box-shadow var(--trans-base),border-color var(--trans-base);
}
.group-card.active{border-color:var(--primary);box-shadow:0 4px 16px rgba(108,99,255,.2)}
.group-card h4{font-size:15px;font-weight:700;margin:0 0 4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.group-card .g-meta{font-size:11px;color:var(--text3);margin-bottom:10px}

.ce-scope-row{
  display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  cursor:pointer;transition:background var(--trans-base),border-color var(--trans-base);
  font-size:13px;color:var(--text);
}
.ce-scope-row:hover{border-color:var(--primary);background:rgba(108,99,255,.06)}
.ce-scope-row.primary{background:rgba(108,99,255,.12);border-color:var(--primary)}
/* v1.16.9：覆蓋 .form-group input 的全域 width:100%，避免 checkbox 撐滿換行 */
.ce-scope-row input[type="checkbox"]{
  width:18px !important;
  min-width:18px;
  height:18px !important;
  min-height:0 !important;
  padding:0 !important;
  margin:0;
  flex-shrink:0;
  accent-color:var(--primary);
  cursor:pointer;
}
.ce-scope-row .cs-tag{font-size:11px;padding:2px 8px;border-radius:999px;background:rgba(108,99,255,.15);color:var(--primary-light)}

/* ============ v1.18.10：iOS 風格事件日期/時間卡片 ============ */
.dt-card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:4px 14px;margin:6px 0 16px;
  box-shadow:var(--shadow-sm);
}
.dt-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 0;min-height:44px;
}
.dt-row-toggle{padding:14px 0}
.dt-row-label{font-size:14px;font-weight:600;color:var(--text);flex-shrink:0}
.dt-divider{height:1px;background:var(--border);opacity:.6}
.dt-pills{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;flex:1}
.dt-pill{
  position:relative;display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:10px;
  background:rgba(108,99,255,.10);
  color:var(--primary-light);font-size:15px;font-weight:600;
  cursor:pointer;user-select:none;
  transition:background var(--trans-base),transform var(--trans-base);
  min-height:36px;
}
.dt-pill:hover{background:rgba(108,99,255,.18)}
.dt-pill:active{transform:scale(.97)}
.dt-pill-icon{font-size:14px;opacity:.85}
.dt-pill-text{white-space:nowrap;font-variant-numeric:tabular-nums}
/* 隱藏 native input，但保留可點擊（觸發原生 wheel picker） */
.dt-native{
  position:absolute !important;inset:0;
  width:100% !important;height:100% !important;min-height:0 !important;
  padding:0 !important;margin:0 !important;border:none !important;background:transparent !important;
  opacity:0;cursor:pointer;
  color:transparent;
  -webkit-appearance:none;appearance:none;
  font-size:16px; /* iOS 防自動縮放 */
}
/* iOS Safari：把日期/時間 indicator 也藏掉，避免重疊 */
.dt-native::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0;padding:0;margin:0}
.dt-native::-webkit-date-and-time-value{text-align:left;color:transparent}
.dt-native::-webkit-datetime-edit{color:transparent}
.dt-pill.dt-pill-disabled{opacity:.45;pointer-events:none}
.dt-duration{
  font-size:12px;color:var(--text3);text-align:right;
  padding:0 0 10px;line-height:1.4;
}
.dt-duration:empty{display:none}
/* iOS-風格 toggle */
.dt-switch{position:relative;display:inline-block;width:46px;height:28px;flex-shrink:0}
.dt-switch input{opacity:0;width:0;height:0;position:absolute}
.dt-switch-slider{
  position:absolute;cursor:pointer;inset:0;
  background:var(--border);border-radius:999px;
  transition:background .25s;
}
.dt-switch-slider::before{
  content:"";position:absolute;left:3px;top:3px;
  width:22px;height:22px;border-radius:50%;background:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.25);
  transition:transform .25s;
}
.dt-switch input:checked + .dt-switch-slider{background:var(--primary)}
.dt-switch input:checked + .dt-switch-slider::before{transform:translateX(18px)}
@media (max-width:768px){
  .dt-row{flex-wrap:wrap;gap:8px}
  .dt-pills{justify-content:flex-start;width:100%}
  .dt-pill{font-size:14px;padding:8px 12px}
}

/* ============ v1.18.12：inline 日期/時間 picker ============ */
.dt-pill-active{
  background:rgba(108,99,255,.22);
  box-shadow:0 0 0 2px rgba(108,99,255,.5) inset;
}
.dt-picker-slot{
  overflow:hidden;
  max-height:0;
  opacity:0;
  transition:max-height .28s ease, opacity .22s ease, padding .2s ease;
  padding:0;
}
.dt-picker-slot.dt-picker-open{
  max-height:520px;
  opacity:1;
  padding:8px 0 4px;
}
.dt-picker-panel{
  background:var(--surface, var(--card));
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  box-shadow:var(--shadow-sm);
  animation:dtpFadeIn .22s ease;
}
@keyframes dtpFadeIn{
  from{transform:translateY(-4px);opacity:0}
  to{transform:translateY(0);opacity:1}
}

/* — 日期 月曆 — */
.dtp-date-wrap{display:flex;flex-direction:column;gap:8px}
.dtp-nav{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:2px 0 6px;
}
.dtp-nav-btn{
  background:transparent;border:none;padding:6px 10px;border-radius:8px;
  font-size:18px;cursor:pointer;color:var(--text);
  box-shadow:var(--shadow-sm);
}
.dtp-nav-btn:hover{background:rgba(108,99,255,.12)}
.dtp-nav-btn:active{transform:scale(.95)}
.dtp-ym{
  font-weight:700;font-size:15px;color:var(--text);
  display:flex;align-items:center;gap:6px;cursor:pointer;
  padding:4px 8px;border-radius:8px;background:transparent;border:none;
}
.dtp-ym:hover{background:rgba(108,99,255,.1)}
.dtp-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:4px;
}
.dtp-wk-cell{
  text-align:center;font-size:11px;font-weight:600;color:var(--text3);
  padding:4px 0;
}
.dtp-cell{
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  background:transparent;border:none;border-radius:8px;
  font-size:13px;color:var(--text);cursor:pointer;
  font-variant-numeric:tabular-nums;
  min-height:32px;
}
.dtp-cell:hover{background:rgba(108,99,255,.14)}
.dtp-cell:active{transform:scale(.92)}
.dtp-empty{visibility:hidden}
.dtp-today{
  outline:1.5px solid var(--primary);
  outline-offset:-1.5px;
  font-weight:700;color:var(--primary);
}
.dtp-selected{
  background:var(--primary)!important;color:#fff!important;
  font-weight:700;
  box-shadow:0 2px 6px rgba(108,99,255,.4);
}
.dtp-selected:hover{background:var(--primary)!important}
.dtp-shortcuts{
  display:flex;gap:6px;flex-wrap:wrap;
  padding:8px 0 2px;border-top:1px dashed var(--border);margin-top:6px;
}
.dtp-chip{
  background:rgba(108,99,255,.1);border:none;color:var(--primary);
  padding:5px 10px;border-radius:14px;font-size:12px;cursor:pointer;
  font-weight:600;
}
.dtp-chip:hover{background:rgba(108,99,255,.2)}
.dtp-chip:active{transform:scale(.96)}

/* — 時間 — */
.dtp-time-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  max-height:240px;
}
.dtp-time-col{display:flex;flex-direction:column;min-height:0}
.dtp-col-label{
  font-size:11px;font-weight:700;color:var(--text3);
  text-align:center;padding:4px 0 6px;text-transform:uppercase;letter-spacing:.5px;
}
.dtp-scroll{
  flex:1;overflow-y:auto;
  background:rgba(0,0,0,.04);
  border-radius:8px;padding:4px;
  display:flex;flex-direction:column;gap:2px;
  scrollbar-width:thin;
  max-height:200px;
}
.dtp-scroll::-webkit-scrollbar{width:6px}
.dtp-scroll::-webkit-scrollbar-thumb{background:rgba(108,99,255,.4);border-radius:3px}
.dtp-scroll-item{
  background:transparent;border:none;padding:8px 4px;border-radius:6px;
  font-size:14px;color:var(--text);cursor:pointer;text-align:center;
  font-variant-numeric:tabular-nums;
}
.dtp-scroll-item:hover{background:rgba(108,99,255,.16)}
.dtp-scroll-item.dtp-selected{
  background:var(--primary);color:#fff;font-weight:700;
}

/* — 自定類型 add option — */
.cal-cat-add{color:var(--primary)!important;font-weight:700}

@media (max-width:768px){
  .dtp-cell{font-size:12.5px;min-height:36px}
  .dtp-scroll{max-height:180px}
  .dtp-time-wrap{max-height:200px}
}

/* ============ 家庭行事曆 (v1.12) ============ */
.cal-toolbar{
  display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap;
}
.cal-toolbar .cal-title{
  font-size:18px;font-weight:700;color:var(--text);
  background:linear-gradient(135deg,var(--text),var(--primary-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cal-nav-btn{
  width:40px;height:40px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--card);box-shadow:var(--shadow-sm);
  color:var(--text);font-size:20px;cursor:pointer;
  transition:background var(--trans-base),box-shadow var(--trans-base);
}
.cal-nav-btn:hover{background:rgba(108,99,255,.1);box-shadow:var(--shadow-md)}
.cal-nav-btn:active{transform:scale(.95)}

.cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);
  background:var(--card);border:1px solid var(--border);
  border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.cal-weekday{
  text-align:center;padding:10px 4px;font-size:12px;font-weight:600;
  background:var(--surface);border-bottom:1px solid var(--border);color:var(--text2);
}
.cal-weekday.sun{color:var(--red)}
.cal-weekday.sat{color:var(--primary-light)}
.cal-cell{
  min-height:96px;padding:6px 6px 8px;cursor:pointer;
  border-right:1px solid var(--border);border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;gap:4px;position:relative;
  transition:background var(--trans-base);
  overflow:hidden;
}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell:hover{background:rgba(108,99,255,.06)}
.cal-cell.cal-muted{background:rgba(0,0,0,0);opacity:.4}
html.light .cal-cell.cal-muted{background:rgba(0,0,0,.02)}
.cal-cell.cal-today{background:rgba(108,99,255,.12)}
.cal-cell.cal-today .cal-daynum{color:var(--primary-light);font-weight:700}
.cal-cell.cal-weekend{background:rgba(239,68,68,.04)}
.cal-daynum{font-size:13px;font-weight:600;color:var(--text)}
.cal-daynum.sun{color:var(--red)}
.cal-daynum.sat{color:var(--primary-light)}
.cal-event-dot{
  font-size:11px;line-height:1.3;padding:2px 6px;border-radius:6px;
  color:#fff;background:var(--primary);
  white-space:nowrap;overflow:hidden;
  display:flex;align-items:center;gap:3px;cursor:pointer;
  min-width:0;
}
.cal-event-dot .cal-ev-icons{flex-shrink:0;letter-spacing:-.5px}
.cal-event-dot .cal-ev-mark{flex-shrink:0}
.cal-event-dot .cal-ev-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-event-dot.family::before{content:'👨‍👩‍👧';font-size:10px;flex-shrink:0}
.cal-event-dot.multi-start{border-left:3px solid rgba(255,255,255,.85);padding-left:4px}
.cal-event-dot.multi-mid{opacity:.75;border-left:2px dashed rgba(255,255,255,.6);padding-left:4px}
.cal-event-dot.multi-end{border-right:3px solid rgba(255,255,255,.85);padding-right:4px;opacity:.9}
.cal-event-more{
  font-size:11px;color:var(--text3);padding:0 4px;cursor:pointer;
}

.family-card{
  background:linear-gradient(135deg,rgba(108,99,255,.1),rgba(0,210,255,.06));
  border:1px solid rgba(108,99,255,.25);
  border-radius:16px;padding:20px;margin-bottom:20px;
}
.family-code-box{
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  background:var(--card);border:1px dashed var(--border);
  padding:10px 14px;border-radius:12px;margin-top:8px;
}
.family-code-box strong{font-size:18px;letter-spacing:3px;color:var(--primary-light);flex:1;min-width:120px}
.family-member-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  background:var(--card);border:1px solid var(--border);border-radius:10px;
  margin-bottom:6px;
}
.family-member-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,rgba(108,99,255,.2),rgba(0,210,255,.15));
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;
}
.family-member-info{flex:1;min-width:0;overflow:hidden}
.family-member-name{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.family-member-role{font-size:11px;color:var(--text3)}

/* 行事曆事件清單 */
.cal-event-list{
  background:var(--card);border:1px solid var(--border);
  border-radius:14px;overflow:hidden;
}
.cal-event-row{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;border-bottom:1px solid var(--border);
  cursor:pointer;transition:background var(--trans-base);
}
.cal-event-row:last-child{border-bottom:none}
.cal-event-row:hover{background:rgba(108,99,255,.05)}
.cal-event-date{
  min-width:58px;text-align:center;
  padding:6px;border-radius:10px;
  background:rgba(108,99,255,.1);flex-shrink:0;
}
.cal-event-date .m{font-size:11px;color:var(--text3)}
.cal-event-date .d{font-size:18px;font-weight:700;color:var(--primary-light);line-height:1.1}
.cal-event-body{flex:1;min-width:0;overflow:hidden}
.cal-event-body .t{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-event-body .s{font-size:12px;color:var(--text3);margin-top:2px}

/* v1.18.8：事件清單 — 倒數時間 chip（取代原本的「編輯」按鈕） */
.cal-event-countdown{
  flex-shrink:0;min-width:52px;text-align:center;
  padding:5px 10px;border-radius:999px;
  font-size:11px;font-weight:600;line-height:1.2;
  background:rgba(148,163,184,.12);color:var(--text3);
  border:1px solid transparent;letter-spacing:.3px;
}
.cal-event-countdown.far{background:rgba(59,130,246,.12);color:#3b82f6}
.cal-event-countdown.soon{background:rgba(14,165,233,.12);color:#0ea5e9}
.cal-event-countdown.imminent{background:rgba(245,158,11,.15);color:#d97706;border-color:rgba(245,158,11,.3)}
.cal-event-countdown.live{background:rgba(34,197,94,.18);color:#16a34a;border-color:rgba(34,197,94,.35)}
.cal-event-countdown.past{background:rgba(148,163,184,.08);color:var(--text3);opacity:.7}

/* v1.18.8：事件清單 filter + 統計合一行 */
.cal-list-filter-bar{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;margin-bottom:12px;flex-wrap:nowrap;
}
.cal-list-filter-seg{flex-shrink:0}
.cal-list-count{
  font-size:12px;color:var(--text3);white-space:nowrap;
  padding:4px 10px;border-radius:999px;background:rgba(148,163,184,.08);
}
@media(max-width:400px){
  .cal-list-filter-bar{flex-wrap:wrap}
  .cal-list-count{margin-left:auto}
}

/* v1.18.8：事件清單 FAB（右下浮動新增按鈕） */
.cal-event-fab{
  position:fixed;
  /* v1.18.9：底部 sub-nav 已移除，只需避開主 bottom-nav（~68px）+ safe-area */
  right:18px;
  bottom:calc(84px + env(safe-area-inset-bottom,0));
  width:54px;height:54px;border-radius:50%;
  border:none;cursor:pointer;
  background:var(--primary);color:#fff;
  font-size:28px;font-weight:300;line-height:1;
  box-shadow:0 8px 20px rgba(108,99,255,.4),0 4px 10px rgba(0,0,0,.15);
  display:flex;align-items:center;justify-content:center;
  z-index:90;transition:transform .15s ease, box-shadow .15s ease;
}
.cal-event-fab:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(108,99,255,.5),0 6px 14px rgba(0,0,0,.18)}
.cal-event-fab:active{transform:scale(.92)}
/* 桌面版 sub-nav 不會貼底，減掉高度 */
@media(min-width:769px){
  .cal-event-fab{bottom:24px}
}

/* 行事曆 RWD */
@media(max-width:768px){
  /* v1.17.2：工具列不再強制把 title 另起一列，讓它與左右箭頭同行 */
  .cal-toolbar{gap:6px;margin-bottom:10px;justify-content:center;flex-wrap:wrap}
  .cal-toolbar .cal-title{
    flex:1 1 auto !important;
    order:0;
    text-align:center !important;
    font-size:15px !important;
    min-width:80px !important;
    margin:0 !important;
    padding:0 4px;
  }
  .cal-nav-btn{width:32px;height:32px;font-size:16px}
  .cal-view-seg{padding:2px}
  .cal-view-seg-btn{padding:5px 10px;font-size:12px;min-height:30px;min-width:34px}

  /* 日期格：稍微壓縮 */
  .cal-cell{min-height:72px;padding:3px 2px 5px;gap:2px}
  .cal-daynum{font-size:11px}
  .cal-weekday{font-size:11px;padding:7px 2px}

  /* 事件膠囊：字縮小，icons 隱藏避免重複 emoji 搶版面（資訊仍在 tooltip） */
  .cal-event-dot{font-size:10px;padding:1px 4px;gap:2px;border-radius:4px}
  .cal-event-dot .cal-ev-icons{display:none}
  .cal-event-dot.multi-start{border-left-width:2px;padding-left:3px}
  .cal-event-dot.multi-mid{border-left-width:2px;padding-left:3px}
  .cal-event-dot.multi-end{border-right-width:2px;padding-right:3px}
  .cal-event-more{font-size:10px}

  /* 清單 */
  .family-card{padding:16px;border-radius:12px}
  .cal-event-date{min-width:50px}
  .cal-event-date .d{font-size:16px}

  /* 週檢視 */
  .cal-week-event{font-size:11px;padding:3px 8px}
  .cal-week-event .cal-ev-icons{display:none}
  .cal-week-day{padding:10px 12px}
}
@media(max-width:400px){
  /* 極小螢幕：月曆格只用色塊 + 圓點提示 */
  .cal-cell{min-height:52px;padding:3px 2px 4px}
  .cal-daynum{font-size:11px}
  .cal-event-dot, .cal-event-more{display:none}
  .cal-cell.has-events::after{
    content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
    width:5px;height:5px;border-radius:50%;background:var(--primary);
  }
  .cal-cell.has-events.family-only::after{background:#22c55e}
  /* 工具列字再縮小一點 */
  .cal-toolbar .cal-title{font-size:14px !important}
  .cal-view-seg-btn{padding:5px 8px;font-size:11px;min-width:30px}
}

/* Modal 內表格自動水平滾動（避免 overflow 撐破 modal） */
.modal .table-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* 確保長內容 modal 在手機上也能完整捲動；v1.18.12：max-height 改安全區感知 */
@media(max-width:768px){
  .modal-overlay{padding:0}
  .modal-overlay.show{align-items:flex-end}
  .modal{max-height:calc(100vh - env(safe-area-inset-top,0) - 20px)}
  .modal.modal-scroll > .modal-scroll-body{padding:20px 18px 6px}
  .modal.modal-scroll > .modal-actions-sticky{padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0))}
}

/* ============ v1.19.0：事件重要度徽章 ============ */
.ev-importance{
  display:inline-block;
  color:#ef4444;
  font-weight:800;
  letter-spacing:1px;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  margin-right:2px;
}

/* ============ v1.19.0：事件類別管理 ============ */
#ecm_list{display:flex;flex-direction:column;gap:10px}
.ecm-row{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  display:flex;flex-direction:column;gap:8px;
}
.ecm-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ecm-icon{
  width:40px;height:40px;border-radius:10px;border:1px solid var(--border);
  background:var(--surface);font-size:22px;line-height:1;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 1px 2px rgba(0,0,0,.05);
}
.ecm-icon:hover{background:var(--card)}
.ecm-name{
  flex:1;min-width:100px;padding:8px 10px;background:var(--surface);
  border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;
}
.ecm-swatches{display:flex;gap:6px;flex-wrap:wrap}
.ecm-sw{
  width:26px;height:26px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:transform .15s;
  padding:0;box-shadow:0 1px 2px rgba(0,0,0,.1);
}
.ecm-sw:hover{transform:scale(1.12)}
.ecm-sw-active{border-color:var(--text);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--primary)}
.ecm-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.cs-tag{
  display:inline-block;padding:2px 8px;border-radius:999px;
  font-size:11px;background:#f1f5f9;color:#475569;
}
