/* =====================================================================
   數發課工作儀表板 — 設計系統 (Design System)  v1  [A1]
   - 以 CSS 變數為單一真實來源：色票 / 字級 / 間距 / 圓角 / 陰影
   - 保留既有 class name（login / mfa / home 不破圖）
   ===================================================================== */

/* ====== 設計 Token ====== */
:root {
  /* 品牌色（teal 主色 + 深藍輔色） */
  --brand-50:  #f0fdfa;
  --brand-100: #ccfbf1;
  --brand-200: #99f6e4;
  --brand-400: #2dd4bf;
  --brand-500: #14b8a6;
  --brand-600: #0f766e;   /* 主色 */
  --brand-700: #115e59;
  --brand-800: #134e4a;
  --ink-navy:  #0f1b2d;   /* 深色背景 */

  /* 中性色 */
  --ink:    #0f172a;      /* 主要文字 */
  --text:   #1e293b;
  --muted:  #64748b;      /* 次要文字 */
  --faint:  #94a3b8;      /* 提示文字 */
  --line:   #e2e8f0;      /* 邊框 */
  --line-2: #cbd5e1;
  --bg:     #f1f5f9;      /* 頁面底 */
  --surface:#ffffff;      /* 卡片面 */
  --surface-2:#f8fafc;    /* 次要面 */

  /* 語意色 */
  --success:#16a34a; --success-bg:#f0fdf4; --success-line:#bbf7d0;
  --warning:#b45309; --warning-bg:#fffbeb; --warning-line:#fde68a;
  --danger: #dc2626; --danger-bg:#fef2f2; --danger-line:#fecaca;
  --info:   #2563eb; --info-bg:#eff6ff;   --info-line:#bfdbfe;

  /* 字級 */
  --fs-xs:12px; --fs-sm:13px; --fs-base:14px; --fs-md:15px;
  --fs-lg:17px; --fs-xl:22px; --fs-2xl:26px; --fs-3xl:32px;

  /* 間距 */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px;
  --sp-5:20px; --sp-6:24px; --sp-8:32px; --sp-10:40px; --sp-12:48px;

  /* 圓角 */
  --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:16px; --r-2xl:20px; --r-full:999px;

  /* 陰影 */
  --sh-xs: 0 1px 2px rgba(15,23,42,.06);
  --sh-sm: 0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);
  --sh-md: 0 4px 12px -2px rgba(15,23,42,.10), 0 2px 6px -2px rgba(15,23,42,.06);
  --sh-lg: 0 12px 28px -8px rgba(15,23,42,.18);
  --sh-xl: 0 28px 60px -18px rgba(15,27,45,.45);

  /* 動態 */
  --ease: 0.18s cubic-bezier(.4,0,.2,1);
  --ring: 0 0 0 3px rgba(15,118,110,.18);
}

/* ====== Reset / Base ====== */
*{margin:0;padding:0;box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  font-family:"Noto Sans TC","PingFang TC","Microsoft JhengHei",
    -apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  min-height:100vh;
  line-height:1.6;
  font-size:var(--fs-base);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:var(--brand-600);text-decoration:none;}
a:hover{text-decoration:underline;}
::selection{background:var(--brand-200);color:var(--ink);}

/* 捲軸（細緻化） */
*::-webkit-scrollbar{width:10px;height:10px;}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:var(--r-full);border:2px solid transparent;background-clip:content-box;}
*::-webkit-scrollbar-thumb:hover{background:var(--faint);}

/* =====================================================================
   共用元件
   ===================================================================== */

/* --- 按鈕 --- */
.btn-primary,.btn-secondary,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  font-family:inherit;font-weight:600;font-size:var(--fs-md);
  border:none;border-radius:var(--r-md);cursor:pointer;
  padding:13px var(--sp-5);transition:transform var(--ease),box-shadow var(--ease),background var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.btn-primary{
  width:100%;color:#fff;
  background:linear-gradient(135deg,var(--brand-600) 0%,var(--brand-700) 100%);
  box-shadow:var(--sh-sm);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 22px -6px rgba(15,118,110,.45);}
.btn-primary:active{transform:translateY(0);}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none;}

.btn-secondary{background:var(--surface);color:var(--brand-700);border:1.5px solid var(--line);box-shadow:var(--sh-xs);}
.btn-secondary:hover{border-color:var(--brand-600);background:var(--brand-50);}

.btn-ghost{background:transparent;color:var(--muted);padding:8px var(--sp-3);font-size:var(--fs-sm);}
.btn-ghost:hover{background:var(--surface-2);color:var(--ink);}

/* --- 狀態標籤 / Badge --- */
.tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:var(--fs-xs);font-weight:600;line-height:1;
  padding:5px 10px;border-radius:var(--r-full);
  border:1px solid transparent;white-space:nowrap;
}
.tag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9;}
.tag-neutral{background:var(--surface-2);color:var(--muted);border-color:var(--line);}
.tag-info{background:var(--info-bg);color:var(--info);border-color:var(--info-line);}
.tag-success{background:var(--success-bg);color:var(--success);border-color:var(--success-line);}
.tag-warning{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-line);}
.tag-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-line);}
.tag-brand{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-200);}

/* --- 表單控制項 --- */
.form-group{margin-bottom:var(--sp-5);}
.form-group label{
  display:block;font-size:var(--fs-base);font-weight:600;
  color:#334155;margin-bottom:var(--sp-2);
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px var(--sp-4);font-size:var(--fs-md);font-family:inherit;
  color:var(--ink);border:1.5px solid var(--line);border-radius:var(--r-md);
  background:var(--surface-2);transition:border-color var(--ease),box-shadow var(--ease),background var(--ease);
}
.form-group textarea{resize:vertical;min-height:96px;line-height:1.6;}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--faint);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--brand-600);background:var(--surface);box-shadow:var(--ring);
}
.field-hint{font-size:var(--fs-xs);color:var(--faint);margin-top:6px;}

/* --- 提示訊息（error / 一般 callout）--- */
.error-message{
  background:var(--danger-bg);color:var(--danger);
  padding:11px var(--sp-4);border-radius:var(--r-md);
  font-size:var(--fs-sm);margin-bottom:var(--sp-4);
  border-left:3px solid var(--danger);display:none;
}
.error-message.show{display:block;animation:fadeIn .2s var(--ease);}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:none;}}

/* =====================================================================
   驗證頁（登入 / MFA）
   ===================================================================== */
.login-wrapper{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:var(--sp-5);position:relative;overflow:hidden;
  background:
    radial-gradient(900px 500px at 12% 8%, rgba(20,184,166,.20), transparent 55%),
    radial-gradient(800px 520px at 100% 100%, rgba(30,58,138,.30), transparent 50%),
    linear-gradient(135deg,#0d3b39 0%,#0f1b2d 55%,#13294b 100%);
}
/* 細緻網格紋理 */
.login-wrapper::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:42px 42px;mask-image:radial-gradient(circle at 50% 40%,#000,transparent 78%);
  pointer-events:none;
}
.login-card{
  position:relative;background:var(--surface);width:100%;max-width:420px;
  padding:var(--sp-12) var(--sp-10);border-radius:var(--r-2xl);
  box-shadow:var(--sh-xl);border:1px solid rgba(255,255,255,.6);
  animation:cardIn .4s var(--ease);
}
@keyframes cardIn{from{opacity:0;transform:translateY(10px) scale(.99);}to{opacity:1;transform:none;}}
.mfa-card{max-width:480px;}

.login-logo{text-align:center;margin-bottom:var(--sp-8);}
.login-logo .icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:60px;height:60px;margin-bottom:var(--sp-4);font-size:30px;
  border-radius:var(--r-lg);
  background:linear-gradient(135deg,var(--brand-500),var(--brand-700));
  box-shadow:0 8px 20px -6px rgba(15,118,110,.55);
}
.login-logo h1{font-size:var(--fs-xl);font-weight:800;color:var(--ink);margin-bottom:var(--sp-2);letter-spacing:.3px;}
.login-logo p{font-size:var(--fs-sm);color:var(--muted);}

.login-hint{
  text-align:center;font-size:var(--fs-xs);color:var(--faint);
  margin-top:var(--sp-6);padding-top:var(--sp-5);border-top:1px solid var(--line);
}
.login-hint code{background:var(--surface-2);padding:2px 7px;border-radius:var(--r-sm);font-size:11px;color:var(--muted);border:1px solid var(--line);}
.login-hint a{color:var(--muted);font-size:var(--fs-xs);}
.login-hint a:hover{color:var(--brand-600);}

/* --- MFA 專用 --- */
.mfa-steps{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);margin-bottom:var(--sp-5);}
.step-item{display:flex;align-items:flex-start;gap:var(--sp-3);font-size:var(--fs-sm);color:#334155;line-height:1.6;padding:var(--sp-1) 0;}
.step-item .step-num{flex-shrink:0;width:22px;height:22px;background:var(--brand-600);color:#fff;border-radius:50%;font-size:var(--fs-xs);font-weight:700;display:flex;align-items:center;justify-content:center;}
.qr-section{margin-bottom:var(--sp-5);}
.qr-box{background:var(--surface);border:2px dashed var(--line-2);border-radius:var(--r-lg);padding:var(--sp-5);display:flex;align-items:center;justify-content:center;min-height:220px;margin-bottom:var(--sp-3);}
.qr-box img{max-width:200px;width:100%;height:auto;}
.qr-loading{color:var(--faint);font-size:var(--fs-sm);}
.secret-box{background:var(--surface-2);border-radius:var(--r-md);padding:var(--sp-3) 14px;}
.secret-label{font-size:var(--fs-xs);color:var(--muted);margin-bottom:6px;}
.secret-row{display:flex;align-items:center;gap:var(--sp-2);}
.secret-row code{flex:1;font-family:"Consolas","Monaco",monospace;font-size:var(--fs-sm);color:var(--ink);background:var(--surface);padding:8px 10px;border-radius:var(--r-sm);border:1px solid var(--line);letter-spacing:1px;overflow-x:auto;white-space:nowrap;}
.btn-copy{background:var(--brand-600);color:#fff;border:none;border-radius:var(--r-sm);padding:8px var(--sp-3);font-size:var(--fs-xs);font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background var(--ease);}
.btn-copy:hover{background:var(--brand-700);}
.code-input{font-family:"Consolas","Monaco",monospace;font-size:22px !important;letter-spacing:8px;text-align:center;font-weight:700;}

/* =====================================================================
   側邊欄（全站一致導覽）
   ===================================================================== */
.app-wrapper.with-sidebar{flex-direction:row;}
.app-wrapper.with-sidebar > .app-header{display:none;}   /* 改用側邊欄取代頂部列 */

.sidebar{
  width:232px;flex:none;align-self:stretch;
  background:linear-gradient(180deg,#0f1b2d 0%,#13243c 100%);
  color:#cbd5e1;display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto;
}
.sidebar .s-brand{display:flex;align-items:center;gap:10px;padding:var(--sp-5) var(--sp-5) var(--sp-4);font-weight:800;font-size:var(--fs-md);color:#fff;text-decoration:none;}
.sidebar .s-brand .icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;font-size:17px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--brand-500),var(--brand-700));}
.sidebar .s-nav{flex:1;padding:var(--sp-2) var(--sp-3) var(--sp-4);}
.sidebar .s-group-title{font-size:11px;font-weight:700;letter-spacing:1px;color:#64748b;text-transform:none;padding:var(--sp-4) var(--sp-3) 6px;}
.sidebar a.s-link{display:flex;align-items:center;gap:10px;padding:9px var(--sp-3);margin:1px 0;border-radius:var(--r-md);color:#cbd5e1;text-decoration:none;font-size:var(--fs-sm);font-weight:600;transition:all var(--ease);}
.sidebar a.s-link .ic{width:18px;text-align:center;}
.sidebar a.s-link:hover{background:rgba(255,255,255,.07);color:#fff;}
.sidebar a.s-link.active{background:var(--brand-600);color:#fff;}
.sidebar .s-user{border-top:1px solid rgba(255,255,255,.08);padding:var(--sp-4);display:flex;align-items:center;gap:10px;}
.sidebar .s-user .s-name{font-size:var(--fs-sm);font-weight:700;color:#fff;line-height:1.3;}
.sidebar .s-user .s-dept{font-size:var(--fs-xs);color:#94a3b8;}
.sidebar .s-logout{margin-left:auto;background:rgba(255,255,255,.1);color:#e2e8f0;border:none;border-radius:var(--r-sm);padding:6px 12px;font-size:var(--fs-xs);font-weight:600;cursor:pointer;font-family:inherit;}
.sidebar .s-logout:hover{background:rgba(255,255,255,.2);}
.app-wrapper.with-sidebar > .app-main{flex:1;min-width:0;}

@media (max-width:820px){
  .app-wrapper.with-sidebar{flex-direction:column;}
  .sidebar{width:100%;height:auto;position:static;}
  .sidebar .s-nav{display:flex;flex-wrap:wrap;gap:4px;padding:var(--sp-2) var(--sp-3);}
  .sidebar .s-group-title{display:none;}
  .sidebar a.s-link{margin:0;}
}

/* =====================================================================
   App Shell（首頁 / 後台版型）
   ===================================================================== */
.app-wrapper{min-height:100vh;display:flex;flex-direction:column;}
.app-header{
  background:var(--surface);border-bottom:1px solid var(--line);
  padding:0 var(--sp-8);height:64px;display:flex;align-items:center;justify-content:space-between;
  box-shadow:var(--sh-xs);position:sticky;top:0;z-index:10;
}
.brand{display:flex;align-items:center;gap:var(--sp-3);font-weight:800;font-size:var(--fs-lg);color:var(--ink);}
.brand .icon{
  display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;font-size:18px;
  border-radius:var(--r-md);background:linear-gradient(135deg,var(--brand-500),var(--brand-700));color:#fff;
}
.user-area{display:flex;align-items:center;gap:var(--sp-4);}
.user-info{text-align:right;line-height:1.3;}
.user-info .name{font-size:var(--fs-base);font-weight:700;color:var(--text);}
.user-info .dept{font-size:var(--fs-xs);color:var(--muted);}
.btn-logout{padding:8px var(--sp-4);background:var(--surface-2);color:#475569;border:1px solid var(--line);border-radius:var(--r-sm);font-size:var(--fs-sm);font-weight:600;cursor:pointer;transition:all var(--ease);font-family:inherit;}
.btn-logout:hover{background:var(--line);color:var(--ink);}

.app-main{flex:1;padding:var(--sp-8);max-width:1280px;margin:0 auto;width:100%;}
.welcome{margin-bottom:var(--sp-8);}
.welcome h1{font-size:var(--fs-2xl);font-weight:800;color:var(--ink);margin-bottom:6px;}
.welcome p{color:var(--muted);font-size:var(--fs-md);}
.section-title{font-size:var(--fs-md);font-weight:700;color:#475569;margin:var(--sp-6) 0 var(--sp-4);letter-spacing:.3px;}

/* --- 待辦橫幅（主畫面醒目提示）--- */
.todo-hero{display:flex;align-items:center;gap:var(--sp-5);border-radius:var(--r-xl);padding:22px 26px;margin-bottom:var(--sp-6);text-decoration:none;box-shadow:var(--sh-md);transition:transform var(--ease),box-shadow var(--ease);}
.todo-hero:hover{transform:translateY(-2px);box-shadow:var(--sh-lg);text-decoration:none;}
.todo-hero.urgent{background:linear-gradient(135deg,var(--brand-600),var(--brand-800));color:#fff;}
.todo-hero.calm{background:var(--surface);color:var(--ink);border:1px solid var(--line);}
.todo-hero .num{font-size:44px;font-weight:800;line-height:1;flex:none;}
.todo-hero .body .txt{font-size:var(--fs-lg);font-weight:700;}
.todo-hero .body .sub{font-size:var(--fs-sm);opacity:.9;margin-top:2px;}
.todo-hero .go{margin-left:auto;font-size:var(--fs-sm);font-weight:700;opacity:.9;}
.todo-hero.calm .go{color:var(--brand-700);}

/* 可點擊的統計卡 */
a.stat-card{text-decoration:none;display:block;}
a.stat-card:hover{border-color:var(--brand-400);text-decoration:none;}

/* --- 統計卡片 --- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--sp-4);margin-bottom:var(--sp-2);}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--sh-xs);transition:box-shadow var(--ease);}
.stat-card:hover{box-shadow:var(--sh-md);}
.stat-card .label{font-size:var(--fs-xs);color:var(--muted);font-weight:600;margin-bottom:var(--sp-2);}
.stat-card .value{font-size:var(--fs-2xl);font-weight:800;color:var(--ink);}
.stat-card .change{font-size:var(--fs-xs);color:var(--success);margin-top:var(--sp-1);}

/* --- 模組卡片 --- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--sp-5);}
.module-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-6);cursor:pointer;transition:all var(--ease);position:relative;overflow:hidden;box-shadow:var(--sh-xs);}
.module-card:hover{border-color:var(--brand-600);transform:translateY(-2px);box-shadow:var(--sh-lg);}
.module-card .icon-box{width:44px;height:44px;background:linear-gradient(135deg,var(--brand-100),var(--brand-200));border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:var(--sp-4);}
.module-card h3{font-size:var(--fs-lg);font-weight:700;color:var(--ink);margin-bottom:6px;}
.module-card p{font-size:var(--fs-sm);color:var(--muted);line-height:1.6;}
.module-card .badge{position:absolute;top:var(--sp-4);right:var(--sp-4);background:var(--warning-bg);color:var(--warning);font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--r-sm);letter-spacing:.5px;border:1px solid var(--warning-line);}

/* =====================================================================
   後台內容元件（admin / 列表 / 表格 / 彈窗）— 供 B3 起各後台共用
   ===================================================================== */
/* 頁首 */
.page-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);margin-bottom:var(--sp-6);flex-wrap:wrap;}
.page-head h1{font-size:var(--fs-2xl);font-weight:800;color:var(--ink);}
.page-head .sub{font-size:var(--fs-sm);color:var(--muted);margin-top:2px;}

/* 面板 */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-xs);margin-bottom:var(--sp-6);overflow:hidden;}
.panel-head{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:var(--sp-3);font-weight:700;color:var(--ink);font-size:var(--fs-md);}
.panel-head .count{margin-left:auto;font-size:var(--fs-xs);font-weight:700;color:var(--brand-700);background:var(--brand-50);border:1px solid var(--brand-200);padding:2px 10px;border-radius:var(--r-full);}
.panel-body{padding:var(--sp-5);}

/* 資料表 */
.data-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm);}
.data-table th{text-align:left;font-weight:700;color:var(--muted);font-size:var(--fs-xs);text-transform:none;padding:10px var(--sp-4);border-bottom:1px solid var(--line);white-space:nowrap;}
.data-table td{padding:14px var(--sp-4);border-bottom:1px solid var(--line);color:var(--text);vertical-align:top;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tbody tr:hover{background:var(--surface-2);}
.data-table .muted{color:var(--muted);}
.cell-strong{font-weight:700;color:var(--ink);}
.cell-sub{font-size:var(--fs-xs);color:var(--muted);margin-top:2px;}

/* 空狀態 */
.empty{text-align:center;padding:var(--sp-10) var(--sp-5);color:var(--faint);}
.empty .emoji{font-size:40px;display:block;margin-bottom:var(--sp-3);opacity:.7;}
.empty p{font-size:var(--fs-sm);}

/* 小按鈕 / 危險按鈕 */
.btn-sm{padding:7px 14px;font-size:var(--fs-sm);border-radius:var(--r-sm);font-weight:600;font-family:inherit;cursor:pointer;border:1px solid transparent;transition:all var(--ease);}
.btn-approve{background:var(--brand-600);color:#fff;}
.btn-approve:hover{background:var(--brand-700);}
.btn-danger{background:var(--surface);color:var(--danger);border-color:var(--danger-line);}
.btn-danger:hover{background:var(--danger-bg);}
.btn-row{display:flex;gap:var(--sp-2);flex-wrap:wrap;}

/* 彈窗 */
.modal-mask{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;z-index:50;padding:var(--sp-5);}
.modal-mask.show{display:flex;animation:fadeIn .15s var(--ease);}
.modal{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--sh-lg);width:100%;max-width:440px;padding:var(--sp-8);animation:cardIn .2s var(--ease);}
.modal h3{font-size:var(--fs-xl);font-weight:800;color:var(--ink);margin-bottom:var(--sp-2);}
.modal p{font-size:var(--fs-sm);color:var(--muted);margin-bottom:var(--sp-5);line-height:1.7;}
.modal-actions{display:flex;gap:var(--sp-3);justify-content:flex-end;margin-top:var(--sp-6);}
.modal-actions .btn-sm{padding:10px 18px;}

/* 可複製欄位（顯示臨時密碼）*/
.copy-field{display:flex;align-items:center;gap:var(--sp-2);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-2) var(--sp-3);}
.copy-field code{flex:1;font-family:"Consolas","Monaco",monospace;font-size:var(--fs-lg);font-weight:700;color:var(--brand-700);letter-spacing:1px;}

/* 提示框（個資提醒等）*/
.notice{border-radius:var(--r-md);padding:var(--sp-4);font-size:var(--fs-sm);line-height:1.7;margin-bottom:var(--sp-4);border:1px solid;}
.notice-warning{background:var(--warning-bg);border-color:var(--warning-line);color:#7c4a02;}
.notice-info{background:var(--info-bg);border-color:var(--info-line);color:#1e40af;}
.notice b{font-weight:700;}
.notice a{font-weight:700;}

/* 申請類型分頁 */
.type-tabs{display:flex;gap:var(--sp-3);margin-bottom:var(--sp-6);flex-wrap:wrap;}
.type-tab{flex:1;min-width:150px;background:var(--surface);border:1.5px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-5);cursor:pointer;transition:all var(--ease);text-align:center;}
.type-tab:hover{border-color:var(--brand-400);}
.type-tab.active{border-color:var(--brand-600);background:var(--brand-50);box-shadow:var(--ring);}
.type-tab .emoji{font-size:26px;display:block;margin-bottom:var(--sp-2);}
.type-tab .t{font-weight:700;color:var(--ink);font-size:var(--fs-md);}
.type-tab .d{font-size:var(--fs-xs);color:var(--muted);margin-top:4px;}

/* 勾選列 */
.check-row{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) 0;}
.check-row input{width:20px;height:20px;margin-top:2px;accent-color:var(--brand-600);cursor:pointer;flex:none;}
.check-row label{font-size:var(--fs-sm);color:var(--text);cursor:pointer;}
.check-row .sub{font-size:var(--fs-xs);color:var(--muted);margin-top:2px;}

/* 檔案上傳區 */
.file-list{margin-top:var(--sp-3);display:flex;flex-direction:column;gap:6px;}
.file-list .fitem{font-size:var(--fs-xs);color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:6px 10px;}

/* header 導覽連結 */
.nav-link{padding:8px var(--sp-4);color:var(--muted);font-size:var(--fs-sm);font-weight:600;border-radius:var(--r-sm);transition:all var(--ease);}
.nav-link:hover{background:var(--surface-2);color:var(--brand-700);text-decoration:none;}

/* 進度時間軸 */
.timeline{position:relative;padding-left:var(--sp-6);}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line);}
.tl-item{position:relative;padding-bottom:var(--sp-5);}
.tl-item:last-child{padding-bottom:0;}
.tl-item::before{content:"";position:absolute;left:-23px;top:3px;width:16px;height:16px;border-radius:50%;background:var(--surface);border:3px solid var(--brand-400);}
.tl-item.done::before{background:var(--brand-600);border-color:var(--brand-600);}
.tl-item .tl-act{font-weight:700;color:var(--ink);font-size:var(--fs-sm);}
.tl-item .tl-meta{font-size:var(--fs-xs);color:var(--muted);margin-top:2px;}
.tl-item .tl-note{font-size:var(--fs-sm);color:var(--text);margin-top:4px;background:var(--surface-2);border-radius:var(--r-sm);padding:8px 12px;border:1px solid var(--line);}

/* 獨立控制項（非 form-group 內）*/
.ctl{padding:10px 14px;border:1.5px solid var(--line);border-radius:var(--r-md);font-family:inherit;font-size:var(--fs-sm);background:var(--surface-2);color:var(--ink);transition:border-color var(--ease),box-shadow var(--ease);}
.ctl:focus{outline:none;border-color:var(--brand-600);background:var(--surface);box-shadow:var(--ring);}
textarea.ctl{width:100%;min-height:72px;resize:vertical;line-height:1.6;}
.act-block{padding:var(--sp-4) 0;}
.act-block + .act-block{border-top:1px solid var(--line);}
.act-block .cell-sub{margin-bottom:6px;}

/* 問卷評分元件 */
.survey-q{margin-bottom:var(--sp-5);}
.survey-q .q-label{font-weight:600;color:var(--ink);font-size:var(--fs-sm);margin-bottom:var(--sp-2);}
.rate-group{display:flex;gap:var(--sp-2);flex-wrap:wrap;}
.rate-btn{width:44px;height:44px;border:1.5px solid var(--line);background:var(--surface);border-radius:var(--r-md);font-weight:700;color:var(--muted);cursor:pointer;font-family:inherit;font-size:var(--fs-md);transition:all var(--ease);}
.rate-btn:hover{border-color:var(--brand-400);}
.rate-btn.sel{background:var(--brand-600);border-color:var(--brand-600);color:#fff;}
.rate-hint{display:flex;justify-content:space-between;font-size:var(--fs-xs);color:var(--faint);margin-top:4px;max-width:260px;}

/* 詳情：定義列表 */
.kv{display:grid;grid-template-columns:120px 1fr;gap:10px var(--sp-4);font-size:var(--fs-sm);}
.kv dt{color:var(--muted);font-weight:600;}
.kv dd{color:var(--text);}
.att-link{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-sm);color:var(--brand-700);background:var(--brand-50);border:1px solid var(--brand-200);border-radius:var(--r-sm);padding:6px 12px;margin:2px 6px 2px 0;text-decoration:none;}
.att-link:hover{background:var(--brand-100);text-decoration:none;}

/* 目前頁籤高亮 */
.nav-link.active{background:var(--brand-50);color:var(--brand-700);}

/* 載入中 spinner */
.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:var(--sp-10);color:var(--muted);font-size:var(--fs-sm);}
.spinner{width:20px;height:20px;border:3px solid var(--line);border-top-color:var(--brand-600);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* =====================================================================
   響應式
   ===================================================================== */
@media (max-width:820px){
  .app-header{flex-wrap:wrap;height:auto;padding:10px var(--sp-4);gap:8px;}
  .user-area{flex-wrap:wrap;gap:8px;}
  .panel-body{overflow-x:auto;}           /* 表格在小螢幕可橫向捲動 */
}
@media (max-width:640px){
  .app-main{padding:var(--sp-5) var(--sp-4);}
  .login-card{padding:var(--sp-8) var(--sp-6);}
  .welcome h1{font-size:var(--fs-xl);}
  .user-info .dept{display:none;}
  .nav-link{padding:6px 10px;font-size:var(--fs-xs);}
  .page-head{flex-direction:column;align-items:flex-start;}
  .type-tab{min-width:120px;}
  .data-table th:nth-child(n+5),.data-table td:nth-child(n+5){display:none;} /* 窄螢幕隱藏次要欄 */
}
