/* 由 index.html <head> 主 style 塊外移 2026-06-09，純搬遷未改內容 */
  @import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700&family=DM+Mono:wght@400;500&display=swap');

  :root {
    --bg: #0d0d0d;
    --surface: #161616;
    --surface2: #1e1e1e;
    --border: #252525;
    --accent: #e8c547;
    --accent2: #4ade80;
    --danger: #f87171;
    --text: #f0ede6;
    --text2: #666;
    --admin-color: #e8c547;
    --sales-color: #60a5fa;
    --sidebar-width: 220px;
    --sidebar-collapsed: 56px;
    --card-radius: 10px;
  }

  /* 亮色模式：舊系統 CSS 變數映射到 lhrm tokens，令 var(--surface/text/bg) 跟隨主題 */
  [data-theme="light"] {
    --bg:       var(--lhrm-bg);
    --surface:  var(--lhrm-surface);
    --surface2: var(--lhrm-surface-2);
    --border:   var(--lhrm-border-2);
    --text:     var(--lhrm-text);
    --text2:    var(--lhrm-text-dim);
  }
  [data-theme="light"] body { color: var(--lhrm-text); }

  * { margin: 0; padding: 0; box-sizing: border-box; }

  body {
    font-family: 'Noto Sans TC', sans-serif;
    background: var(--bg);
    color: #d0cdc7;
    min-height: 100vh;
    font-size: 14px;
    line-height: 1.6;
  }

  /* ── Global form elements ── */
  input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="range"]),
  select, textarea {
    background: var(--surface2);
    border: 0.5px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text);
    padding: 9px 12px;
    font-size: 14px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
  }
  input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="range"]):focus,
  select:focus, textarea:focus {
    border-color: #e8c547;
    box-shadow: 0 0 0 2px rgba(232,197,71,0.12);
  }

  /* ── Global button styles ── */
  .btn-primary, button.btn-primary { background: #e8c547; color: #111; border: none; border-radius: var(--r-sm); padding: 9px 20px; font-size: 14px; font-weight: 500; cursor: pointer; font-family: inherit; transition: opacity 0.15s; }
  .btn-primary:hover { opacity: 0.88; }
  .btn-secondary, button.btn-secondary { background: transparent; border: 0.5px solid #444; color: #aaa; border-radius: var(--r-sm); padding: 9px 20px; font-size: 14px; cursor: pointer; font-family: inherit; transition: border-color 0.15s; }
  .btn-secondary:hover { border-color: #666; color: #ccc; }

  /* ── Global card ── */
  .wb-card { border: 0.5px solid var(--lhrm-border-2); border-radius: var(--r-md); background: var(--lhrm-surface); padding: 16px 20px; margin-bottom: 10px; transition: border-color 0.15s; }
  .wb-card:hover { border-color: var(--lhrm-border); }

  /* ── Global filter tabs ── */
  .wb-tab { background: transparent; border: 0.5px solid #333; border-radius: 20px; color: #888; padding: 5px 14px; font-size: 13px; cursor: pointer; font-family: inherit; transition: all 0.15s; }
  .wb-tab:hover { border-color: #555; color: #bbb; }
  .wb-tab.active, .wb-tab[data-active="true"] { background: rgba(232,197,71,0.12); border-color: #e8c547; color: #e8c547; }

  /* ── LOGIN ── */

  @keyframes login-breeze{0%{background-position:calc(50% - 3px) center}25%{background-position:calc(50% + 2px) calc(50% - 1px)}50%{background-position:calc(50% + 3px) center}75%{background-position:calc(50% - 1px) calc(50% + 1px)}100%{background-position:calc(50% - 3px) center}}
  #login-screen {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: url('/images/login/login_closed.png') center center / cover no-repeat #0a0a0a;
    position: relative;
    overflow: hidden;
    animation: login-breeze 6s ease-in-out infinite;
  }

  .login-box {
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(4px);
    border: 2px solid #e8c547;
    border-radius: 16px;
    padding: 48px 40px;
    width: 380px;
    box-shadow: 0 0 20px rgba(232,197,71,0.3), inset 0 0 20px rgba(0,0,0,0.5);
    position: relative;
    z-index: 2;
    transition: opacity 0.3s;
  }

  .login-logo {
    font-family: 'Courier New', monospace;
    font-size: 14px;
    color: #e8c547;
    letter-spacing: 4px;
    text-transform: uppercase;
    margin-bottom: 32px;
    text-shadow: 0 0 8px rgba(232,197,71,0.4);
  }


  .field { margin-bottom: 16px; }

  .field label {
    display: block;
    font-size: 12px;
    color: var(--text2);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 8px;
  }

  .field input {
    width: 100%;
    background: #111;
    border: 1px solid #e8c54766;
    border-radius: var(--r-sm);
    padding: 12px 16px;
    color: var(--text);
    font-size: 15px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
  }

  .field input:focus { border-color: #e8c547; box-shadow: 0 0 12px rgba(232,197,71,0.3); }

  .btn-login {
    width: 100%;
    background: var(--accent);
    color: #0f0f12;
    border: none;
    border-radius: var(--r-sm);
    padding: 14px;
    font-size: 15px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    margin-top: 8px;
    transition: opacity 0.2s;
  }

  .btn-login:hover { opacity: 0.88; }

  .login-error {
    color: var(--danger);
    font-size: 13px;
    margin-top: 12px;
    text-align: center;
    display: none;
  }

  /* ── SIDEBAR ── */
  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: var(--sidebar-width);
    background: var(--lhrm-surface);
    border-right: 1px solid var(--lhrm-border);
    z-index: 200;
    display: flex;
    flex-direction: column;
    transition: width 0.2s ease;
    overflow: hidden;
  }
  .sidebar.collapsed { width: var(--sidebar-collapsed); }
  .sidebar-header {
    padding: 20px 16px;
    border-bottom: 1px solid var(--lhrm-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 60px;
  }
  .sidebar-brand {
    font-family: var(--font-num);
    font-size: 11px;
    color: var(--lhrm-text);
    letter-spacing: 2px;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
  }
  .sidebar-toggle {
    background: none;
    border: none;
    color: var(--lhrm-text-dim);
    cursor: pointer;
    font-size: 18px;
    padding: 4px;
    flex-shrink: 0;
  }
  .sidebar-toggle:hover { color: var(--lhrm-text); }
  .sidebar-nav {
    flex: 1;
    overflow-y: auto;
    padding: 12px 0;
    scrollbar-width: thin;
    scrollbar-color: var(--lhrm-border) transparent;
  }
  .sidebar-group-label {
    font-size: 10px;
    color: var(--lhrm-text-dim);
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 16px 20px 6px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
  }
  .sidebar .nav-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    background: none;
    border: none;
    border-radius: 0;
    color: var(--lhrm-text-dim);
    padding: 10px 20px;
    font-size: 13px;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
    overflow: hidden;
    text-align: left;
  }
  .sidebar .nav-btn.nav-sub { padding-left: 34px; font-size: 12px; color: var(--lhrm-text-dim); opacity: 0.85; }
  .sidebar .nav-btn.nav-sub .nav-icon { width: 16px; }
  .sidebar .nav-btn:hover { color: #e8c547; background: var(--lhrm-surface-2); }
  .sidebar .nav-btn.active { color: #e8c547; background: rgba(232,197,71,0.06); border-right: 2px solid #e8c547; }
  [data-theme="light"] .sidebar .nav-btn.active { color: var(--lhrm-text); background: rgba(232,197,71,0.14); border-right: 2px solid #e8c547; }
  .sidebar .nav-icon { flex-shrink: 0; width: 20px; display: flex; align-items: center; justify-content: center; }
  .sidebar .nav-label { overflow: hidden; }
  .sidebar.collapsed .nav-label,
  .sidebar.collapsed .sidebar-brand,
  .sidebar.collapsed .sidebar-group-label { display: none; }
  .sidebar.collapsed .nav-btn { justify-content: center; padding: 12px 0; }
  .sidebar.collapsed .sidebar-header {
    flex-direction: column;
    justify-content: center;
    gap: 8px;
    padding: 16px 0;
  }
  .sidebar-footer {
    padding: 12px 16px;
    border-top: 1px solid var(--lhrm-border);
    font-size: 12px;
    color: var(--lhrm-text-dim);
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .sidebar-footer .user-info {
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
    overflow: hidden;
  }
  .sidebar.collapsed .sidebar-footer .user-info span,
  .sidebar.collapsed .sidebar-footer .btn-sidebar-action span { display: none; }
  .btn-sidebar-action {
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text2);
    padding: 6px 12px;
    font-size: 11px;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.15s;
    display: flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
  }
  .btn-sidebar-action:hover { color: var(--text); border-color: var(--text2); }

  /* ── MAIN CONTENT ── */
  #app {
    display: none;
    min-height: 100vh;
  }
  .app-main {
    margin-left: var(--sidebar-width);
    transition: margin-left 0.2s ease;
    min-height: 100vh;
    padding: 0;
    background: var(--lhrm-bg);
  }
  .app-main.sidebar-collapsed { margin-left: var(--sidebar-collapsed); }

  .role-badge {
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
  }

  .role-admin { background: rgba(232,197,71,0.15); color: var(--admin-color); }
  .role-sales { background: rgba(96,165,250,0.15); color: var(--sales-color); }


  .btn-save-all {
    background: rgba(232,197,71,0.12); border: 1px solid var(--accent);
    border-radius: 7px; color: var(--accent); padding: 6px 14px;
    font-size: 13px; font-family: inherit; cursor: pointer;
    transition: background 0.15s; font-weight: 600; margin-right: 8px;
  }
  .btn-save-all:hover { background: rgba(232,197,71,0.25); }
  .btn-save-all.saving { opacity: 0.6; pointer-events: none; }
  /* restore-banner */
  .restore-banner {
    position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
    background: var(--surface); border: 1px solid var(--accent);
    border-radius: var(--r-md); padding: 16px 24px; z-index: 9999;
    display: flex; align-items: center; gap: 14px; box-shadow: 0 8px 32px rgba(0,0,0,0.4);
    font-size: 14px; min-width: 320px;
  }
  .restore-banner-text { flex: 1; }
  .restore-banner-title { font-weight: 700; color: var(--accent); margin-bottom: 3px; }
  .restore-banner-sub { font-size: 12px; color: var(--text2); }

  .btn-logout {
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text2);
    padding: 5px 12px;
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.2s;
  }

  .btn-logout:hover { border-color: var(--danger); color: var(--danger); }

  /* Pages */
  .page { display: none; padding: 32px 40px; max-width: 2000px; margin: 0 auto; width: 100%; }
  .page.active { display: block; }

  /* ── CALCULATOR PAGE ── */
  .page-title {
    font-size: 20px;
    font-weight: 500;
    color: var(--text);
    margin-bottom: 4px;
  }

  .page-sub { color: #666; font-size: 13px; margin-bottom: 24px; }

  .calc-layout { display: grid; grid-template-columns: 1fr 360px; gap: 24px; align-items: start; }

  .card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 24px;
    margin-bottom: 16px;
  }

  .card-title {
    font-size: 11px;
    color: var(--text2);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .card-title::before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 12px;
    background: var(--accent);
    border-radius: 2px;
  }

  /* Category Selector */
  .category-tabs { display: flex; gap: 8px; flex-wrap: wrap; }

  .cat-tab {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text2);
    padding: 10px 20px;
    font-size: 14px;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.2s;
  }

  .cat-tab:hover { border-color: var(--accent); color: var(--text); }
  .cat-tab.active { background: rgba(232,197,71,0.1); border-color: var(--accent); color: var(--accent); font-weight: 700; }

  /* Selector Grid */
  .selector-row { display: flex; gap: 24px; margin-bottom: 20px; flex-wrap: wrap; }

  .selector-group { flex: 1; min-width: 150px; }

  .selector-label {
    font-size: 12px;
    color: var(--text2);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 10px;
  }

  .chip-group { display: flex; gap: 8px; flex-wrap: wrap; }

  .chip {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text2);
    padding: 7px 14px;
    font-size: 13px;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.18s;
  }

  .chip:hover { border-color: var(--accent); color: var(--text); }
  .chip.active { background: rgba(232,197,71,0.12); border-color: var(--accent); color: var(--accent); font-weight: 500; }

  .color-chip {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--border);
    cursor: pointer;
    transition: all 0.18s;
    position: relative;
  }

  .color-chip.active { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(232,197,71,0.3); }

  /* Module Grid */
  .module-section { margin-bottom: 20px; }

  .module-section-title {
    font-size: 12px;
    color: var(--text2);
    letter-spacing: 1px;
    margin-bottom: 10px;
  }

  .module-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 10px; }

  .module-card {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 14px;
    cursor: pointer;
    transition: all 0.18s;
    position: relative;
  }

  .module-card:hover { border-color: rgba(232,197,71,0.4); }

  .module-card.in-cart {
    background: rgba(232,197,71,0.06);
    border-color: var(--accent);
  }

  .module-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--accent);
    margin-bottom: 10px;
  }

  .module-name { font-size: 13px; font-weight: 500; margin-bottom: 6px; }

  .module-price { font-size: 15px; font-weight: 700; color: var(--accent); }

  .module-cost { font-size: 11px; color: var(--text2); margin-top: 2px; }

  .module-qty {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
  }

  .qty-btn {
    width: 26px;
    height: 26px;
    border-radius: var(--r-sm);
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text);
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
  }

  .qty-btn:hover { border-color: var(--accent); color: var(--accent); }
  .qty-num { font-family: var(--font-num); font-size: 14px; min-width: 20px; text-align: center; }

  /* Quote Panel */
  .quote-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 24px;
    position: sticky;
    top: 76px;
  }

  .quote-title {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: 4px;
  }

  .quote-brand { font-size: 11px; color: var(--text2); margin-bottom: 16px; }

  .quote-items { min-height: 80px; margin-bottom: 16px; }

  .quote-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
    gap: 12px;
  }

  .quote-item-name { font-size: 13px; flex: 1; }
  .quote-item-qty { font-size: 12px; color: var(--text2); }

  .quote-item-price {
    font-family: var(--font-num);
    font-size: 14px;
    font-weight: 500;
    white-space: nowrap;
  }

  .quote-empty { color: var(--text2); font-size: 13px; text-align: center; padding: 24px 0; }
  .q-sync-item-btn { cursor:pointer; user-select:none; display:inline-block; opacity:0.35; transition:opacity .15s,transform .2s; font-size:12px; padding:0 2px; }
  .q-sync-item-btn:hover { opacity:1; transform:rotate(180deg); }
  .q-lock-row-btn { cursor:pointer; user-select:none; display:inline-block; font-size:12px; padding:0 2px; transition:opacity .15s; }
  .q-lock-row-btn.locked { opacity:1; }
  .q-lock-row-btn:not(.locked) { opacity:0.25; }
  .q-lock-row-btn:hover { opacity:1; }
  .q-lock-row-btn.q-lock-active { color:#f59e0b; opacity:1; }
  .qb-input-locked { background: rgba(245,158,11,0.08) !important; color:#d97706 !important; cursor:not-allowed; border-color: rgba(245,158,11,0.3) !important; }
  .q-convert-btn { cursor:pointer; user-select:none; display:inline-block; font-size:12px; padding:0 4px; margin-right:4px; color:#60a5fa; opacity:0.45; transition:opacity .15s,color .15s; }
  .q-convert-btn:hover { opacity:1; }
  .q-convert-btn.q-convert-active { color:#3b82f6; opacity:1; }
  /* B1 軟刪除 */
  .qb-item-deleted { background: rgba(220,38,38,.08); }
  .qb-item-deleted input { text-decoration: line-through; color: #b91c1c !important; opacity: .7; }
  .qb-item-deleted td { color: #b91c1c; }
  .qb-deleted-badge { display: inline-block; background: #dc2626; color: #fff; padding: 1px 6px; border-radius: 3px; font-size: 10px; margin-left: 6px; vertical-align: middle; }
  .qb-restore-btn { background: #16a34a !important; color: #fff !important; margin-right: 4px; border-radius: 4px; padding: 2px 8px; }
  .qb-hard-del-btn { background: #991b1b !important; color: #fff !important; border-radius: 4px; padding: 2px 6px; }
  .qb-hard-del-btn:hover { background: #7f1d1d !important; }
  /* B2 本次新增 — 僅第一欄徽章，列本身不動（對稱「已刪除」風格） */
  .qb-item-new td:first-child::after { content: '本次新增'; display: inline-block; background: #22c55e; color: #fff; padding: 2px 6px; border-radius: 4px; font-size: 10px; margin-left: 4px; white-space: nowrap; }
  .qb-confirm-new-btn { background: #16a34a !important; color: #fff !important; margin-right: 4px; border-radius: 4px; padding: 2px 8px; }
  .qb-confirm-new-btn:hover { background: #15803d !important; }
  .qb-mark-new-btn { background: rgba(34, 197, 94, 0.1) !important; color: #22c55e !important; border: 1px solid rgba(34, 197, 94, 0.3) !important; margin-right: 4px; border-radius: 4px; padding: 2px 8px; transition: all 150ms ease-out; }
  .qb-mark-new-btn:hover { background: rgba(34, 197, 94, 0.2) !important; border-color: #22c55e !important; }
  /* 規則 F：contenteditable 備註欄 */
  .qb-note-editable:empty::before { content: attr(data-placeholder); color: #666; pointer-events: none; }
  .qb-note-editable:focus { border-bottom-color: #888 !important; color: #ccc !important; }
  .qb-note-color-btn:hover { background: rgba(220,38,38,.1) !important; }
  .qb-note-color-btn:active { background: rgba(220,38,38,.25) !important; }
  /* 成本管理改動視覺 */
  .cm-row-new { background: rgba(74, 222, 128, 0.10) !important; }
  tr.cm-row-dirty td {
    box-shadow:
      inset 0 1px 0 #ef4444,
      inset 0 -1px 0 #ef4444,
      0 0 8px rgba(239, 68, 68, 0.25);
    background: rgba(239, 68, 68, 0.04) !important;
  }
  tr.cm-row-dirty td:first-child {
    box-shadow:
      inset 1px 1px 0 #ef4444,
      inset 1px -1px 0 #ef4444,
      0 0 8px rgba(239, 68, 68, 0.25);
  }
  tr.cm-row-dirty td:last-child {
    box-shadow:
      inset -1px 1px 0 #ef4444,
      inset -1px -1px 0 #ef4444,
      0 0 8px rgba(239, 68, 68, 0.25);
  }
  /* 通用 td transition:class 加/移除時淡入淡出 */
  #cm-table tr td { transition: box-shadow 400ms ease-in-out, background 400ms ease-in-out; }
  /* 詢價歷史 */
  .cm-history-btn { background: rgba(59, 130, 246, 0.1); color: #60a5fa; border: 1px solid rgba(59, 130, 246, 0.3); padding: 2px 6px; border-radius: 4px; cursor: pointer; font-size: 13px; margin-right: 4px; }
  .cm-history-btn:hover { background: rgba(59, 130, 246, 0.2); border-color: #3b82f6; }
  .cm-history-modal { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.6); display: flex; align-items: center; justify-content: center; z-index: 1000; }
  .cm-history-modal-inner { background: var(--surface); border-radius: var(--r-md); width: 90%; max-width: 600px; max-height: 85vh; overflow: auto; padding: 20px; color: var(--text); }
  .cm-history-modal h3 { margin: 0 0 4px 0; font-size: 16px; }
  .cm-history-modal .cm-history-sub { color: var(--lhrm-text-dim); font-size: 12px; margin-bottom: 14px; }
  .cm-history-list { border-top: 1px solid var(--lhrm-border); margin-top: 10px; }
  .cm-history-row { display: grid; grid-template-columns: 84px minmax(140px, max-content) 1fr auto; gap: 10px; padding: 11px 8px; border-bottom: 1px solid var(--lhrm-border); align-items: center; font-size: 13px; }
  .cm-history-breakdown { display: flex; gap: 6px; font-size: 12px; flex-wrap: wrap; align-items: baseline; }
  .cm-history-cost { color: var(--lhrm-text-dim); font-family: var(--font-num); font-variant-numeric: tabular-nums; }
  .cm-history-markup { color: var(--lhrm-text-dim); font-style: italic; font-family: var(--font-num); font-variant-numeric: tabular-nums; }
  .cm-history-sell { color: var(--lhrm-text); font-weight: 700; font-family: var(--font-num); font-variant-numeric: tabular-nums; }
  .cm-history-date { color: var(--lhrm-text-dim); font-family: var(--font-num); font-variant-numeric: tabular-nums; font-size: 11px; }
  .cm-history-contractor { color: var(--lhrm-text); font-weight: 700; display: flex; align-items: center; gap: 6px; white-space: nowrap; }
  .cm-history-price { text-align: right; font-weight: 700; color: var(--lhrm-text); font-family: var(--font-num); font-variant-numeric: tabular-nums; }
  .cm-history-actions { display: flex; gap: 6px; }
  .cm-history-apply-btn { background: #15663f; color: #fff; border: 1px solid transparent; padding: 4px 10px; border-radius: 3px; cursor: pointer; font-size: 11px; font-weight: 600; transition: var(--transition); }
  .cm-history-apply-btn:hover { filter: brightness(1.08); }
  .cm-history-del-btn { background: transparent; color: var(--c-money); border: 1px solid color-mix(in srgb, var(--c-money) 35%, transparent); padding: 3px 8px; border-radius: 3px; cursor: pointer; font-size: 11px; transition: var(--transition); }
  .cm-history-del-btn:hover { background: color-mix(in srgb, var(--c-money) 12%, transparent); }
  .cm-history-set-default-btn { background: transparent; color: var(--lhrm-text); border: 1px solid var(--lhrm-border-2); padding: 3px 8px; border-radius: 3px; cursor: pointer; font-size: 11px; transition: var(--transition); }
  .cm-history-set-default-btn:hover { background: var(--lhrm-surface-2); border-color: var(--lhrm-text-dim); }
  .cm-history-add-form { background: var(--lhrm-surface-2); padding: 14px 16px; border-radius: var(--r-sm); margin-top: 16px; }
  .cm-history-add-form h4 { margin: 0 0 12px 0; font-size: 13px; color: var(--lhrm-text-dim); }
  .cm-history-add-form .field-row { display: grid; grid-template-columns: 84px 1fr; gap: 10px; margin-bottom: 10px; align-items: center; font-size: 13px; }
  .cm-history-add-form .field-row label { color: var(--lhrm-text-dim); font-size: 12px; }
  .cm-history-add-form select, .cm-history-add-form input { background: var(--lhrm-input-bg); border: 1px solid var(--lhrm-border-2); color: var(--lhrm-text); padding: 6px 10px; border-radius: 4px; font-size: 13px; outline: none; }
  .cm-history-close-btn { float: right; background: transparent; color: var(--lhrm-text-dim); border: none; font-size: 20px; cursor: pointer; padding: 0 8px; }
  .cm-history-toggle-all { color: var(--c-info); cursor: pointer; font-size: 12px; margin: 10px 0; text-align: center; transition: var(--transition); }
  .cm-history-toggle-all:hover { text-decoration: underline; }
  /* 報價單工項列詢價歷史按鈕 */
  .qb-quote-history-btn { background: rgba(59, 130, 246, 0.1); color: #60a5fa; border: 1px solid rgba(59, 130, 246, 0.3); padding: 2px 6px; border-radius: 4px; cursor: pointer; font-size: 12px; margin-left: 6px; transition: all 150ms ease-out; vertical-align: middle; }
  .qb-quote-history-btn:hover { background: rgba(59, 130, 246, 0.2); border-color: #3b82f6; }
  .qb-list-vat-tag { display:inline-block; font-size:11px; color:#888; background:rgba(255,255,255,.08); padding:1px 6px; border-radius:3px; margin-left:4px; }
  .qb-tax-badge { display:inline-block; font-size:12px; color:#fff; background:#4a90e2; padding:2px 8px; border-radius:3px; margin-left:8px; vertical-align:middle; }
  /* sticky 分類快速跳轉 chips */
  .cm-sticky-header { position: sticky; top: 0; z-index: 40; background: var(--lhrm-surface); backdrop-filter: blur(4px); padding: 10px 4px 0 4px; margin: 0 -4px 12px -4px; border-bottom: 1px solid var(--lhrm-border-2); }
  .cm-sticky-header #cm-search { margin-bottom: 8px; }
  .cm-chips-bar { padding: 6px 0 8px 0; display: flex; flex-wrap: wrap; gap: 6px; }
  .cm-chip { padding: 4px 12px; border-radius: 14px; background: color-mix(in srgb,var(--lhrm-text) 6%,transparent); color: var(--lhrm-text-dim); font-size: 12px; cursor: pointer; border: 1px solid var(--lhrm-border-2); transition: all var(--transition); white-space: nowrap; }
  .cm-chip:hover { background: rgba(232,197,71,.18); color: #e8c547; border-color: rgba(232,197,71,.4); }
  .cm-chip-active { background: rgba(232,197,71,.25); color: #e8c547; border-color: rgba(232,197,71,.6); }

  /* ===== 規則 G：報價單範本區 sticky ===== */
  .qb-templates-panel {
    position: sticky;
    top: 16px;
    align-self: start;
    z-index: 10;
    max-height: min(600px, calc(100vh - 120px)) !important;
  }
  @media (max-width: 768px) {
    .qb-templates-panel {
      position: static !important;
      top: auto !important;
      z-index: auto !important;
      max-height: min(600px, calc(100vh - 120px)) !important;
      transition: max-height 0.25s ease, padding 0.25s ease;
    }
    .qb-templates-panel.qb-panel-collapsed {
      max-height: 44px !important;
      padding: 10px 16px !important;
      overflow: hidden !important;
    }
    .qb-templates-panel.qb-panel-collapsed #qb-search,
    .qb-templates-panel.qb-panel-collapsed #qb-templates {
      display: none !important;
    }
  }
  .qb-panel-toggle {
    display: none;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text);
    padding: 4px 10px;
    font-size: 13px;
    cursor: pointer;
    line-height: 1;
    margin-left: auto;
  }
  .qb-panel-toggle:hover {
    background: rgba(255,255,255,0.05);
  }
  @media (max-width: 768px) {
    .qb-panel-toggle {
      display: inline-flex;
      align-items: center;
      gap: 4px;
    }
  }
  .qb-templates-panel .qb-panel-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
  }
  /* 分類 header:箭頭 + 可點擊 */
  .cat-header { cursor: pointer; user-select: none; transition: background 150ms ease-out; }
  .cat-header:hover { background: rgba(255, 255, 255, 0.04) !important; }
  .cat-arrow { display: inline-block; margin-right: 6px; transition: transform 200ms ease-out; font-size: 10px; opacity: 0.7; }
  .cat-expanded .cat-arrow { transform: rotate(90deg); }
  /* 收合時隱藏 body */
  .cat-body { overflow: hidden; }
  .cat-collapsed .cat-body { display: none; }

  .quote-divider { border: none; border-top: 1px solid var(--border); margin: 12px 0; }

  .quote-subtotal, .quote-total-row {
    display: flex;
    justify-content: space-between;
    font-size: 13px;
    margin-bottom: 8px;
  }

  .quote-total-row { font-size: 18px; font-weight: 700; }

  .quote-total-price { color: var(--accent); font-family: var(--font-num); }

  .quote-profit {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--accent2);
    margin-bottom: 16px;
  }

  .btn-primary {
    width: 100%;
    background: var(--accent);
    color: #0f0f12;
    border: none;
    border-radius: var(--r-sm);
    padding: 13px;
    font-size: 14px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    transition: opacity 0.2s;
    margin-bottom: 8px;
  }

  .btn-primary:hover { opacity: 0.88; }

  .btn-secondary {
    width: 100%;
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 11px;
    font-size: 13px;
    font-family: inherit;
    color: var(--text2);
    cursor: pointer;
    transition: all 0.2s;
  }

  .btn-secondary:hover { border-color: var(--text2); color: var(--text); }

  /* ── HISTORY PAGE ── */
  .history-grid { display: grid; gap: 12px; }

  .history-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 18px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
  }

  .history-info { flex: 1; }
  .history-id { font-family: var(--font-num); font-size: 12px; color: var(--text2); margin-bottom: 4px; }
  .history-name { font-size: 15px; font-weight: 500; margin-bottom: 4px; }
  .history-date { font-size: 12px; color: var(--text2); }
  .history-amount { font-family: var(--font-num); font-size: 18px; font-weight: 700; color: var(--accent); }

  .btn-sm {
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text2);
    padding: 6px 12px;
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.2s;
  }

  .btn-sm:hover { border-color: var(--accent); color: var(--accent); }

  /* ── MODAL ── */
  .modal-bg {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    z-index: 200;
    align-items: center;
    justify-content: center;
  }

  .modal-bg.open { display: flex; }

  .modal {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 32px;
    width: 440px;
    max-width: 95vw;
    box-shadow: 0 40px 80px rgba(0,0,0,0.5);
  }

  .modal-title { font-size: 18px; font-weight: 700; margin-bottom: 20px; }

  .modal-field { margin-bottom: 14px; }

  .modal-field label { display: block; font-size: 12px; color: var(--text2); letter-spacing: 1px; margin-bottom: 6px; }

  .modal-field input {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 10px 14px;
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s;
  }

  .modal-field input:focus { border-color: var(--accent); }

  .modal-actions { display: flex; gap: 10px; margin-top: 20px; }

  .modal-actions .btn-primary { flex: 1; }

  .btn-cancel {
    flex: 1;
    background: none;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 13px;
    font-size: 14px;
    font-family: inherit;
    color: var(--text2);
    cursor: pointer;
    transition: all 0.2s;
  }

  .btn-cancel:hover { border-color: var(--text2); color: var(--text); }



  /* ── VENDOR DB ── */

  .vendor-add-form {
    background: var(--surface); border: 1px solid var(--accent);
    border-radius: var(--r-md); padding: 18px 20px; margin-bottom: 20px;
  }
  .vaf-title { font-size: 14px; font-weight: 700; color: var(--accent); margin-bottom: 12px; }
  .vaf-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 8px;
  }
  .vaf-input {
    background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-sm);
    color: var(--text); padding: 8px 12px; font-size: 13px; font-family: inherit;
    outline: none; transition: border-color 0.15s;
  }
  .vaf-input:focus { border-color: var(--accent); }


  .user-row {
    display:flex; align-items:center; gap:10px;
    padding:12px 16px; background:var(--surface); border:1px solid var(--border);
    border-radius:var(--r-sm); margin-bottom:8px;
  }
  .user-row.inactive { opacity:0.45; }
  .user-avatar {
    width:36px; height:36px; border-radius:50%; background:var(--surface2);
    display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0;
  }
  .user-info { flex:1 }
  .user-name { font-weight:600; font-size:14px; }
  .user-meta { font-size:12px; color:var(--text2); }
  .role-pill {
    font-size:11px; padding:3px 10px; border-radius:10px; font-weight:700;
  }
  .role-pill.admin { background:rgba(232,197,71,0.15); color:var(--accent); }
  .role-pill.sales { background:rgba(100,180,255,0.12); color:#64b4ff; }
  /* ── Calc2 / Basic Calculator ── */
  .calc2-tabs { display:flex;gap:8px;margin-bottom:24px;background:var(--surface);padding:6px;border-radius:var(--r-md);width:fit-content; }
  .calc2-tab { padding:8px 20px;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text2);transition:all .2s; }
  .calc2-tab.active { background:var(--accent);color:#000; }
  .calc2-panel { display:none; }
  .calc2-panel.active { display:block; }

  /* Area calc */
  .area-input-row { display:flex;gap:8px;align-items:center;margin-bottom:10px; }
  .area-unit-btn { padding:6px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text2);transition:all .15s; }
  .area-unit-btn.active { background:var(--accent);color:#000;border-color:var(--accent); }
  .area-expr-input { flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:10px 14px;font-size:14px; }
  .area-expr-input:focus { outline:none;border-color:var(--accent); }
  .area-result-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px; }
  .area-result-big { font-size:48px;font-weight:700;color:var(--accent);line-height:1; }
  .area-result-unit { font-size:14px;color:var(--text2);margin-left:4px; }
  .area-result-row { display:flex;gap:32px;margin-top:12px;flex-wrap:wrap; }
  .area-result-item { text-align:center; }
  .area-result-num { font-size:20px;font-weight:700; }
  .area-result-label { font-size:11px;color:var(--text2); }
  .area-entries { margin-top:12px; }
  .empty-permission-hint { display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center; }
  .empty-permission-icon { font-size:40px;margin-bottom:16px;opacity:.5; }
  .empty-permission-title { font-size:15px;color:#888;font-weight:600;margin-bottom:8px; }
  .empty-permission-desc { font-size:13px;color:#555;line-height:1.6; }
  .area-entry { display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg);border-radius:var(--r-sm);margin-bottom:4px;font-size:13px; }

  /* Lighting */
  .calc-expr-result { display:none;font-size:13px;color:#e8c547;font-weight:700;white-space:nowrap; }
  .light-circuit { background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;margin-bottom:8px; }
  .light-circuit-header { display:flex;align-items:center;gap:10px;margin-bottom:10px; }
  .light-num { width:24px;height:24px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text2);flex-shrink:0; }
  .light-result { font-size:13px;font-weight:700;margin-left:auto; }
  .light-result.overload { color:#ef4444; }
  .light-bom-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 20px; }
  .light-bom-item { display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg);border-radius:var(--r-sm);margin-bottom:6px; }
  .light-bom-w { font-size:16px;font-weight:700; }
  .light-bom-qty { font-size:12px;color:var(--text2); }

  /* Unit converter */
  .conv-input-wrap { position:relative;margin-bottom:16px; }
  .conv-expr-input { width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--r-md);padding:16px 120px 16px 20px;font-size:20px;box-sizing:border-box; }
  .conv-expr-input:focus { outline:none;border-color:var(--accent); }
  .conv-unit-toggle { position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;gap:4px; }
  .conv-unit-btn { padding:6px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer;border:none;background:var(--bg);color:var(--text2);transition:all .15s; }
  .conv-unit-btn.active { background:var(--accent);color:#000; }
  .conv-result-grid { display:grid;grid-template-columns:1fr 1fr;gap:10px; }
  .conv-result-item { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 18px; }
  .conv-result-item.highlight { background:rgba(245,197,24,.08);border-color:rgba(245,197,24,.4); }
  .conv-result-label { font-size:10px;color:var(--text2);letter-spacing:1px;margin-bottom:4px;font-weight:600; }
  .conv-result-num { font-size:22px;font-weight:700; }

  /* ── Ops / Project Schedule ── */
  .ops-list { display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-top:4px; }
  .ops-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;cursor:pointer;transition:all .2s; }
  .ops-card:hover { border-color:var(--accent);transform:translateY(-1px); }
  .ops-card-name { font-size:15px;font-weight:700;margin-bottom:4px; }
  .ops-card-meta { font-size:12px;color:var(--text2); }
  .ops-card-progress { margin-top:10px;height:4px;background:var(--border);border-radius:2px;overflow:hidden; }
  .ops-card-progress-bar { height:100%;background:var(--accent);border-radius:2px;transition:width .3s; }

  /* Project Editor */
  .ops-editor { display:none; }
  .ops-editor.active { display:block; }
  .ops-field-row { display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px; }
  .ops-field-row.single { grid-template-columns:1fr; }
  .ops-label { font-size:11px;color:var(--text2);margin-bottom:4px;font-weight:600;letter-spacing:.5px; }
  .ops-input { width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:9px 12px;font-size:13px;box-sizing:border-box; }
  .ops-input:focus { outline:none;border-color:var(--accent); }

  /* Phase rows */
  .phase-row { display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:6px; }
  .phase-row.payment { background:rgba(245,197,24,.06);border-color:rgba(245,197,24,.3); }
  .phase-drag { cursor:grab;color:#555;font-size:14px;flex-shrink:0;user-select:none; }
  .phase-drag:hover { color:var(--accent); }
  .phase-drag:active { cursor:grabbing; }
  .phase-num  { width:24px;height:24px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text2);flex-shrink:0; }
  .phase-num.payment { background:rgba(245,197,24,.2);border-color:rgba(245,197,24,.5);color:#f5c518; }
  .phase-name { flex:1;font-size:13px;font-weight:500; }
  .phase-sub  { font-size:11px;color:var(--text2); }
  .phase-dur  { width:70px;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:4px 8px;font-size:12px;text-align:center; }
  .phase-pct  { width:60px;background:var(--surface);border:1px solid var(--border);color:#f5c518;border-radius:var(--r-sm);padding:4px 8px;font-size:12px;text-align:center; }
  .phase-date-input { width:110px;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:4px 8px;font-size:11px; }

  /* Stats panel */
  .ops-stats { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;margin-bottom:20px; }
  .ops-stat-row { display:flex;gap:24px;flex-wrap:wrap; }
  .ops-stat-item { text-align:center; }
  .ops-stat-num { font-size:28px;font-weight:700;color:var(--accent); }
  .ops-stat-label { font-size:11px;color:var(--text2);margin-top:2px; }
  .ops-holiday-tip { font-size:13px;cursor:default;opacity:0.75;margin-left:4px; }
  .sg-title-common { color:#94a3b8; }
  .sg-title-rare { color:#60a5fa;text-shadow:0 0 8px rgba(96,165,250,.5); }
  .sg-title-elite { color:#a78bfa;text-shadow:0 0 8px rgba(167,139,250,.5); }
  .sg-title-legendary { background:linear-gradient(90deg,#e8c547,#fff,#e8c547);-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:sg-pulse 2s ease-in-out infinite; }
  @keyframes sg-pulse { 0%,100%{opacity:1}50%{opacity:.6} }
  .sg-title-img { width:28px;height:28px;vertical-align:middle;margin-right:8px; }
  .sg-section { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px;margin-bottom:16px; }
  .sg-section-title { font-size:15px;font-weight:700;color:#e8c547;margin-bottom:14px;display:flex;align-items:center;gap:8px; }
  .sg-stat-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:8px; }
  .sg-stat-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;text-align:center; }
  .sg-stat-card .sg-stat-num { font-size:22px;font-weight:700;color:#e8c547;line-height:1.2; }
  .sg-stat-card .sg-stat-label { font-size:11px;color:#888;margin-top:4px; }
  .sg-reward-list { display:flex;flex-direction:column;gap:6px;margin-top:4px; }
  .sg-reward-row { display:flex;align-items:center;justify-content:space-between;background:var(--surface);border-left:3px solid #e8c547;border-radius:0 6px 6px 0;padding:7px 12px;font-size:13px; }
  .sg-reward-row .sg-reward-name { color:#ccc; }
  .sg-reward-row .sg-reward-val { color:#e8c547;font-weight:700;white-space:nowrap; }
  .sg-table { width:100%;border-collapse:collapse;font-size:13px;margin-top:8px; }
  .sg-table th { background:var(--surface2);color:#e8c547;font-weight:600;padding:8px 12px;text-align:left;border-bottom:1px solid #383838; }
  .sg-table td { padding:8px 12px;border-bottom:1px solid #2a2a2a;color:#ccc; }
  .sg-table tr:hover td { background:var(--surface2); }
  .sg-steps { display:flex;flex-direction:column;gap:0;margin-top:8px; }
  .sg-step { display:flex;gap:14px;align-items:flex-start;padding:10px 0;border-left:2px solid #383838;margin-left:12px;padding-left:18px;position:relative; }
  .sg-step::before { content:attr(data-step);position:absolute;left:-12px;top:10px;width:22px;height:22px;background:#e8c547;color:#1a1a1a;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center; }
  .sg-step-text { font-size:13px;color:#ccc;padding-top:2px; }
  .sg-two-col { display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px; }
  .sg-info-block { background:var(--surface);border-radius:var(--r-sm);padding:12px 14px; }
  .sg-info-block .sg-info-label { font-size:11px;color:#e8c547;font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em; }
  .sg-info-block .sg-info-text { font-size:13px;color:#bbb;line-height:1.6; }
  .sg-intimacy-row { display:grid;grid-template-columns:40px 100px 1fr;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid #2a2a2a;font-size:13px; }
  .sg-intimacy-row .sg-lv { color:#e8c547;font-weight:700;text-align:center; }
  .sg-intimacy-row .sg-range { color:#888; }
  .sg-intimacy-row .sg-status { color:#ccc; }
  .sg-pet-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px; }
  .sg-pet-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;text-align:center; }
  .sg-pet-card img { width:64px;height:64px;image-rendering:pixelated;margin-bottom:8px; }
  .sg-pet-card .sg-pet-name { font-size:15px;font-weight:700;color:#e8c547;margin-bottom:4px; }
  .sg-pet-card .sg-pet-info { font-size:12px;color:#888;line-height:1.6; }

  /* ── Ops Goals Dashboard Cards ── */
  .ops-dash-card {
    background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px 18px;
    position:relative;overflow:hidden;transition:box-shadow .3s,border-color .3s;
  }
  .ops-dash-card:hover { border-color:#555; }
  .ops-dash-card.og-ahead { box-shadow:0 0 14px rgba(81,207,102,.2); }
  .ops-dash-card.og-behind { box-shadow:0 0 10px rgba(220,80,80,.15); }
  .ops-dash-card.og-critical { animation:og-pulse 1.5s ease-in-out infinite; }
  @keyframes og-pulse {
    0%,100% { box-shadow:0 0 0 0 rgba(244,67,54,0); }
    50%     { box-shadow:0 0 16px 4px rgba(244,67,54,.4); }
  }
  .ops-dash-bar { height:6px;background:var(--border);border-radius:4px;overflow:hidden;margin-top:2px;position:relative; }
  .ops-dash-fill { height:100%;border-radius:4px;transition:width .4s; }
  .og-fill-ahead  { background:#51cf66; }
  .og-fill-behind { background:#ff6b6b; }
  .og-fill-normal { background:#e8c547; }
  .ops-tag-system { font-size:10px;background:rgba(96,165,250,.12);color:#60a5fa;border:1px solid rgba(96,165,250,.3);border-radius:4px;padding:1px 6px; }
  .ops-tag-manual { font-size:10px;background:rgba(232,197,71,.1);color:#e8c547;border:1px solid rgba(232,197,71,.3);border-radius:4px;padding:1px 6px; }
  .fb-resolved-note { display:flex;gap:10px;align-items:flex-start;background:color-mix(in srgb,#4caf50 10%,var(--surface));border-left:3px solid #4caf50;border-radius:0 6px 6px 0;padding:8px 12px;margin-top:10px;font-size:13px; }
  .fb-resolved-label { color:#4caf50;font-weight:600;white-space:nowrap; }
  .fb-resolved-text { color:#bbb;line-height:1.6; }

  /* ── Announce ── */
  .announce-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px;margin-bottom:12px;transition:border-color .2s; }
  .announce-card:hover { border-color:var(--accent); }
  .announce-level { display:inline-block;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:700;margin-bottom:10px; }
  .level-normal    { background:rgba(121,134,203,.15);color:#7986cb; }
  .level-important { background:rgba(255,167,38,.15);color:#ffa726; }
  .level-urgent    { background:rgba(239,83,80,.18);color:#ef5350;animation:pulse-urgent 1.5s infinite; }
  @keyframes pulse-urgent { 0%,100%{opacity:1} 50%{opacity:.6} }
  @keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.3)} }
  .emote-inline { display:inline-block !important; vertical-align:middle !important; background-size:contain !important; background-repeat:no-repeat !important; background-position:center !important; }
  .merit-normal { color:#888; }
  .merit-bronze,.merit-copper { color:#cd7f32; }
  .merit-silver { color:#c0c0c0; text-shadow:0 0 8px rgba(192,192,192,0.6); }
  .merit-gold   { color:#ffd700; text-shadow:0 0 10px rgba(255,215,0,0.7), 0 0 20px rgba(255,215,0,0.4); }
  .merit-platinum { color:#e8f4ff; text-shadow:0 0 10px rgba(255,255,255,0.8), 0 0 20px rgba(200,230,255,0.5); animation:merit-plat-pulse 2s ease-in-out infinite; }
  @keyframes merit-plat-pulse { 0%,100%{text-shadow:0 0 10px rgba(255,255,255,0.8),0 0 20px rgba(200,230,255,0.5)} 50%{text-shadow:0 0 16px rgba(255,255,255,1),0 0 32px rgba(200,230,255,0.8)} }
  .merit-diamond,.merit-legend { background:linear-gradient(90deg,#00cfff,#bf00ff,#00cfff); background-size:200% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:merit-diamond-flow 3s linear infinite; }
  @keyframes merit-diamond-flow { 0%{background-position:0% center} 100%{background-position:200% center} }
  .monthly-star-row { display:flex;align-items:center;gap:8px;padding:5px 0; }
  .monthly-star-rank { font-size:12px;color:#555;width:22px;text-align:right;flex-shrink:0;font-weight:700;font-family:var(--font-num); }
  .monthly-star-name { font-size:13px;font-weight:600; }
  .monthly-star-stones { margin-left:auto;font-size:12px;color:#e8c547;font-weight:600;font-family:var(--font-num); }
  .merit-glow-showcase { display:flex;flex-direction:column;gap:8px;margin:12px 0; }
  .merit-glow-row { display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 16px; }
  .merit-glow-threshold { font-size:12px;color:#666;min-width:90px;font-family:var(--font-num); }
  .merit-glow-preview { font-size:18px;font-weight:700;min-width:90px;text-align:center; }
  .merit-glow-desc { font-size:13px;color:#888; }
  .iv-tab-label[title]:hover::after { content:' \270E';font-size:11px;margin-left:3px;opacity:.45; }
  @keyframes pet-evolve-breathe { 0%,100%{box-shadow:0 0 8px 2px rgba(232,197,71,.3)} 50%{box-shadow:0 0 20px 6px rgba(232,197,71,.8)} }
  .pet-card-evolvable { border:1px solid #e8c547 !important;animation:pet-evolve-breathe 2.5s ease-in-out infinite; }
  .pet-summon-btn { display:block;width:100%;margin-top:8px;padding:6px;background:linear-gradient(135deg,#2a1a4a,#1a2a4a);border:1px solid #6a4aaa;border-radius:var(--r-sm);color:#c4a0ff;font-size:12px;cursor:pointer;transition:border-color .2s,box-shadow .2s; }
  .pet-summon-btn:hover { border-color:#e8c547;box-shadow:0 0 8px rgba(232,197,71,.3);color:#e8c547; }
  .pet-summon-btn.active { border-color:#e8c547;color:#e8c547;background:linear-gradient(135deg,#2a2a1a,#1a2a2a); }
  @keyframes legendPulse { 0%,100%{filter:brightness(1);text-shadow:0 0 12px rgba(232,197,71,0.9)} 50%{filter:brightness(1.3);text-shadow:0 0 20px rgba(232,197,71,1)} }
  #wb-lightbox { display:none; position:fixed; inset:0; z-index:99997; background:rgba(0,0,0,.92); align-items:center; justify-content:center; flex-direction:column; }
  #wb-lightbox.open { display:flex; }
  #wb-lightbox img { max-width:95vw; max-height:80vh; object-fit:contain; border-radius:4px; transition:opacity .15s; }
  #wb-lightbox .lb-close { position:absolute; top:16px; right:16px; background:none; border:none; color:#fff; font-size:32px; cursor:pointer; width:44px; height:44px; display:flex; align-items:center; justify-content:center; }
  #wb-lightbox .lb-arrow { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.1); border:none; color:#fff; font-size:28px; cursor:pointer; width:48px; height:64px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; }
  #wb-lightbox .lb-arrow:hover { background:rgba(255,255,255,.2); }
  #wb-lightbox .lb-prev { left:12px; }
  #wb-lightbox .lb-next { right:12px; }
  #wb-lightbox .lb-info { position:absolute; bottom:16px; text-align:center; color:#999; font-size:12px; }
  @keyframes ptsToastIn { from{opacity:0;transform:translateX(120%)} to{opacity:1;transform:translateX(0)} }
  @keyframes ptsToastOut { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(120%)} }
  @keyframes pet-breathe { 0%,100%{transform:scale(1)} 50%{transform:scale(1.06)} }
  @keyframes pet-breathe-fast { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }
  @keyframes pet-float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
  @keyframes pet-bubble { 0%{opacity:0;transform:translateY(10px)} 10%{opacity:1;transform:translateY(0)} 80%{opacity:1} 100%{opacity:0;transform:translateY(-10px)} }
  /* Merit Achievement Wall */
  .merit-stats-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px; }
  .merit-stat-card { background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:14px;text-align:center; }
  .merit-stat-num { font-size:24px;font-weight:700;color:#e8c547;font-family:var(--font-num); }
  .merit-stat-label { font-size:11px;color:var(--text2);margin-top:4px;letter-spacing:0.5px; }
  .merit-title-wall { display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:16px; }
  .merit-title-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;text-align:center;transition:border-color .2s; }
  .merit-title-card.unlocked { border-color:#333; }
  .merit-title-card.locked { opacity:0.45; }
  .merit-title-card.equipped { border-color:#e8c547;box-shadow:0 0 10px rgba(232,197,71,.25); }
  .merit-rarity-common { color:#94a3b8;font-size:13px;font-weight:600;margin:6px 0; }
  .merit-rarity-rare { color:#60a5fa;text-shadow:0 0 8px rgba(96,165,250,.4);font-size:13px;font-weight:600;margin:6px 0; }
  .merit-rarity-elite { color:#a78bfa;text-shadow:0 0 8px rgba(167,139,250,.4);font-size:13px;font-weight:600;margin:6px 0; }
  .merit-rarity-legendary { background:linear-gradient(90deg,#e8c547,#fff,#e8c547);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:13px;font-weight:700;margin:6px 0;animation:merit-gold-shift 3s linear infinite; }
  @keyframes merit-gold-shift { 0%{background-position:0% center} 100%{background-position:200% center} }
  .merit-title-progress { font-size:10px;color:#555;margin-top:4px; }
  .merit-title-progress-bar { background:var(--border);border-radius:3px;height:3px;margin-top:4px;overflow:hidden; }
  .merit-title-progress-fill { height:100%;border-radius:3px;background:#e8c547;transition:width .3s; }
  .merit-equip-btn { background:rgba(232,197,71,.12);border:1px solid rgba(232,197,71,.25);border-radius:var(--r-sm);padding:3px 10px;color:#e8c547;cursor:pointer;font-size:11px;font-weight:600;margin-top:6px; }
  .merit-equip-btn:hover { background:rgba(232,197,71,.2); }
  .merit-equip-btn.active { background:rgba(232,197,71,.25);border-color:#e8c547; }
  .announce-title { font-size:16px;font-weight:700;margin-bottom:8px; }
  .announce-body  { font-size:13px;color:var(--text2);line-height:1.7;white-space:pre-wrap; }
  .announce-meta  { font-size:11px;color:var(--text2);margin-top:10px;display:flex;gap:16px;flex-wrap:wrap; }
  .announce-form  { background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px;margin-bottom:20px; }
  .announce-input { width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:10px 14px;font-size:14px;box-sizing:border-box;margin-bottom:10px; }
  .announce-input:focus { outline:none;border-color:var(--accent); }
  .announce-textarea { width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:10px 14px;font-size:14px;box-sizing:border-box;resize:vertical;min-height:100px;font-family:inherit; }
  .announce-textarea:focus { outline:none;border-color:var(--accent); }
  .level-select { background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:8px 12px;font-size:13px; }

  .log-row {
    display:flex; gap:14px; padding:8px 14px; border-bottom:1px solid var(--border);
    font-size:12px; align-items:center;
  }
  .log-row:hover { background:var(--surface); }
  .log-time  { color:var(--text2); width:160px; flex-shrink:0; }
  .log-user  { font-weight:600; width:100px; flex-shrink:0; }
  .log-ip    { color:var(--text2); flex:1; font-family:var(--font-num); font-size:11px; }
  .log-ok    { color:#4caf50; font-size:11px; }
  .log-fail  { color:var(--danger); font-size:11px; }

  .vendor-toolbar {
    display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px;
  }
  .vendor-search-wrap input {
    width: 100%; background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-sm); padding: 12px 16px; color: var(--text);
    font-size: 14px; font-family: inherit; outline: none; transition: border-color 0.2s;
  }
  .vendor-search-wrap input:focus { border-color: var(--accent); }
  .vendor-filters { display: flex; gap: 8px; flex-wrap: wrap; }
  .vcat-btn {
    background: var(--surface2); border: 1px solid var(--border);
    border-radius: var(--r-sm); color: var(--text2); padding: 5px 14px;
    font-size: 12px; font-family: inherit; cursor: pointer; transition: all 0.18s;
  }
  .vcat-btn:hover { border-color: var(--accent); color: var(--text); }
  .vcat-btn.active { background: rgba(232,197,71,0.12); border-color: var(--accent); color: var(--accent); font-weight: 700; }
  .vendor-table-wrap { }
  .vendor-table { width: 100%; border-collapse: collapse; font-size: 13px; table-layout: fixed; }
  .vendor-table th {
    background: var(--surface2); color: var(--text2); font-size: 11px;
    letter-spacing: 1px; text-transform: uppercase; padding: 10px 14px;
    text-align: left; border-bottom: 1px solid var(--border); white-space: nowrap;
    cursor: pointer; user-select: none;
  }
  .vendor-table th:hover { color: var(--accent); }
  .vendor-table td {
    padding: 8px 6px; border-bottom: 1px solid var(--border);
    vertical-align: top; max-width: 200px;
  }
  .vendor-table tr:hover td { background: var(--surface2); }
  .vendor-table tr:last-child td { border-bottom: none; }
  .vcat-tag {
    display: inline-block; background: var(--surface2); border: 1px solid var(--border);
    border-radius: 4px; padding: 2px 8px; font-size: 11px; color: var(--text2); white-space: nowrap;
  }
  .vprice { font-family: var(--font-num); font-weight: 500; }
  .vprice-cost { color: var(--danger); }
  .vprice-sell { color: var(--accent); }
  .vprice-list { color: var(--text2); font-size: 11px; }
  .vcontact { color: var(--accent2); font-size: 12px; }
  .vendor-count { font-size: 12px; color: var(--text2); margin-top: 12px; text-align: right; }
  .vremarks { color: var(--text2); font-size: 11px; max-width: 160px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .hidden-col { display: none; }

  /* ── Vendor Inquiry ── */
  .btn-inquiry { background: transparent; border: 1px solid #555; color: #ccc; padding: 2px 8px; border-radius: 4px; cursor: pointer; font-size: 12px; white-space: nowrap; }
  .btn-inquiry:hover { background: rgba(255,255,255,0.05); border-color: #888; }
  .btn-inquiry.has-primary { color: #f0c419; border-color: #f0c419; }
  .inquiry-panel { background: var(--surface2); padding: 12px; border-left: 3px solid #f0c419; }
  .inquiry-table { width: 100%; font-size: 12px; }
  .inquiry-table th { color: #888; font-weight: normal; padding: 4px 8px; text-align: left; border-bottom: 1px solid #333; }
  .inquiry-table td { padding: 6px 8px; border-bottom: 1px solid #2a2a2a; vertical-align: middle; }
  .inquiry-table td[contenteditable="true"]:hover { background: rgba(255,255,255,0.03); outline: 1px solid #444; }
  .inquiry-row-primary { background: rgba(240,196,25,0.1); }
  .inquiry-price-min { color: #4caf50; font-weight: bold; }
  .btn-pin { background: #f0c419; color: #000; border: none; padding: 2px 8px; border-radius: 3px; cursor: pointer; font-size: 11px; }
  .btn-pin:hover { background: #d4a90a; }
  .btn-del-inq { color: #ff5555; background: transparent; border: none; cursor: pointer; padding: 2px 6px; font-size: 13px; }
  .btn-add-inquiry { background: #2a7a3a; color: #fff; border: none; padding: 4px 12px; border-radius: 4px; cursor: pointer; font-size: 12px; }
  .inquiry-add-form { background: var(--surface2); padding: 12px; margin-top: 8px; border-radius: 4px; }
  .inquiry-add-title { font-size: 13px; color: #f0c419; margin-bottom: 8px; }
  .inquiry-add-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
  .inquiry-add-grid label { display: flex; flex-direction: column; font-size: 11px; color: #aaa; }
  .inquiry-add-grid label.full { grid-column: 1 / -1; }
  .inquiry-add-grid input { background: var(--surface2); border: 1px solid var(--border); color: var(--text); padding: 4px 6px; margin-top: 2px; border-radius: 3px; }
  .inquiry-add-actions { margin-top: 8px; display: flex; gap: 8px; justify-content: flex-end; }
  .btn-save-inq { background: #2a7a3a; color: #fff; border: none; padding: 4px 16px; border-radius: 4px; cursor: pointer; }


  /* ── ADMIN PANEL (tree-based) ── */
  .admin-topbar {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 24px; flex-wrap: wrap; gap: 12px;
  }
  .import-export-bar { display: flex; gap: 8px; }
  .admin-tree { display: grid; gap: 0; }

  /* Category row */
  .tree-cat {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-md); margin-bottom: 12px; overflow: hidden;
  }
  .tree-cat-header {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 18px; cursor: pointer;
    border-bottom: 1px solid transparent; transition: background 0.15s;
  }
  .tree-cat-header:hover { background: var(--surface2); }
  .tree-cat-header.open { border-bottom-color: var(--border); }
  .tree-cat-icon { font-size: 16px; }
  .tree-cat-name { font-size: 15px; font-weight: 700; flex: 1; }
  .tree-actions { display: flex; gap: 6px; align-items: center; }
  .tree-chevron { color: var(--text2); font-size: 12px; transition: transform 0.2s; }
  .tree-chevron.open { transform: rotate(180deg); }

  /* Brand row */
  .tree-cat-body { padding: 0 0 8px 0; display: none; }
  .tree-cat-body.open { display: block; }
  .tree-brand {
    margin: 8px 16px 0; background: var(--surface2);
    border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden;
  }
  .tree-brand-header {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 14px; cursor: pointer;
  }
  .tree-brand-header:hover { background: rgba(255,255,255,0.03); }
  .tree-brand-icon { font-size: 13px; color: var(--text2); }
  .tree-brand-name { font-size: 13px; font-weight: 700; flex: 1; }

  /* Series row */
  .tree-brand-body { padding: 0 0 8px 0; display: none; }
  .tree-brand-body.open { display: block; }
  .tree-series {
    margin: 6px 12px 0; background: var(--bg);
    border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden;
  }
  .tree-series-header {
    display: flex; align-items: center; gap: 8px;
    padding: 9px 12px; cursor: pointer;
  }
  .tree-series-header:hover { background: rgba(255,255,255,0.03); }
  .tree-series-name { font-size: 12px; font-weight: 600; color: var(--accent); flex: 1; }

  /* Color tabs inside series */
  .tree-color-tabs { display: flex; gap: 5px; flex-wrap: wrap; padding: 0 12px 8px; }
  .tree-color-tab {
    display: flex; align-items: center; gap: 5px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 5px; color: var(--text2); padding: 4px 10px;
    font-size: 11px; font-family: inherit; cursor: pointer; transition: all 0.15s;
  }
  .tree-color-tab.active { border-color: var(--accent); color: var(--accent); background: rgba(232,197,71,0.08); }
  .tree-cdot { width: 9px; height: 9px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.2); flex-shrink:0; }

  /* Module rows */
  .tree-modules { padding: 0 12px 6px; }
  .tree-module-row {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 0; border-bottom: 1px solid var(--border);
  }
  .tree-module-row:last-child { border-bottom: none; }
  .tree-mod-badge {
    font-size: 10px; padding: 2px 7px; border-radius: 10px;
    background: var(--surface); color: var(--text2); white-space: nowrap; flex-shrink: 0;
  }
  .tree-mod-name { flex: 1; font-size: 13px; }
  .tree-price-input {
    background: var(--surface); border: 1px solid var(--border); border-radius: 5px;
    color: var(--text); padding: 4px 8px; font-size: 12px;
    font-family: var(--font-num); width: 80px; outline: none; text-align: right;
    transition: border-color 0.15s;
  }
  .tree-price-input:focus { border-color: var(--accent); }
  .tree-price-label { font-size: 10px; color: var(--text2); white-space: nowrap; }

  /* Inline add row */
  .tree-inline-add {
    display: flex; align-items: center; gap: 6px; padding: 6px 0 2px;
  }
  .tree-inline-input {
    background: var(--surface2); border: 1px solid var(--border); border-radius: 5px;
    color: var(--text); padding: 5px 10px; font-size: 12px;
    font-family: inherit; outline: none; flex: 1;
    transition: border-color 0.15s;
  }
  .tree-inline-input:focus { border-color: var(--accent); }
  .tree-inline-input.narrow { width: 70px; flex: none; }
  .btn-tree-add {
    background: rgba(232,197,71,0.1); border: 1px solid var(--accent);
    border-radius: 5px; color: var(--accent); padding: 5px 12px;
    font-size: 12px; font-family: inherit; cursor: pointer; white-space: nowrap;
    transition: background 0.15s;
  }
  .btn-tree-add:hover { background: rgba(232,197,71,0.2); }
  .btn-tree-del {
    background: none; border: 1px solid transparent; border-radius: 5px;
    color: var(--text2); padding: 4px 8px; font-size: 12px;
    cursor: pointer; transition: all 0.15s; flex-shrink: 0;
  }
  .btn-tree-del:hover { border-color: var(--danger); color: var(--danger); }
  .tree-panel-row {
    display: flex; align-items: center; gap: 8px;
    padding: 4px 0; border-bottom: 1px solid var(--border);
  }
  .tree-panel-row:last-child { border-bottom: none; }
  .tree-panel-label { font-size: 12px; font-family:var(--font-num); color: var(--text2); width: 40px; flex-shrink:0; }
  .panel-section-label { font-size: 11px; color: var(--text2); letter-spacing:1px; padding: 10px 12px 4px; }
  .save-flash { font-size: 11px; color: var(--accent2); opacity: 0; transition: opacity 0.3s; margin-left: 6px; }
  .save-flash.show { opacity: 1; }

  /* ── ADMIN PANEL ── */
  .admin-toolbar {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 24px; flex-wrap: wrap; gap: 12px;
  }
  .admin-toolbar-left { display: flex; gap: 8px; flex-wrap: wrap; }
  .btn-add {
    background: rgba(232,197,71,0.12); border: 1px solid var(--accent);
    border-radius: var(--r-sm); color: var(--accent); padding: 9px 18px;
    font-size: 13px; font-weight: 700; font-family: inherit; cursor: pointer;
    transition: all 0.2s;
  }
  .btn-add:hover { background: rgba(232,197,71,0.22); }
  .btn-danger-sm {
    background: none; border: 1px solid var(--border); border-radius: var(--r-sm);
    color: var(--danger); padding: 5px 10px; font-size: 12px;
    font-family: inherit; cursor: pointer; transition: all 0.2s;
  }
  .btn-danger-sm:hover { border-color: var(--danger); background: rgba(248,113,113,0.08); }
  .admin-tree { display: grid; gap: 16px; }
  .admin-cat {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-md); overflow: hidden;
  }
  .admin-cat-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px; cursor: pointer; user-select: none;
    border-bottom: 1px solid var(--border);
  }
  .admin-cat-header:hover { background: var(--surface2); }
  .admin-cat-title { font-size: 15px; font-weight: 700; display: flex; align-items: center; gap: 10px; }
  .admin-cat-body { padding: 16px 20px; display: none; }
  .admin-cat-body.open { display: block; }
  .admin-brand-block {
    background: var(--surface2); border: 1px solid var(--border);
    border-radius: var(--r-md); padding: 14px 16px; margin-bottom: 12px;
  }
  .admin-brand-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px;
  }
  .admin-brand-name { font-size: 14px; font-weight: 700; }
  .admin-series-block {
    background: var(--bg); border: 1px solid var(--border);
    border-radius: var(--r-sm); padding: 12px 14px; margin-bottom: 8px;
  }
  .admin-series-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 10px;
  }
  .admin-series-name { font-size: 13px; font-weight: 600; color: var(--accent); }
  .admin-color-tabs { display: flex; gap: 6px; margin-bottom: 12px; flex-wrap: wrap; }
  .admin-color-tab {
    background: var(--surface2); border: 1px solid var(--border);
    border-radius: var(--r-sm); color: var(--text2); padding: 5px 12px;
    font-size: 12px; font-family: inherit; cursor: pointer; transition: all 0.18s;
    display: flex; align-items: center; gap: 6px;
  }
  .admin-color-tab.active { border-color: var(--accent); color: var(--accent); }
  .color-dot { width: 10px; height: 10px; border-radius: 50%; border: 1px solid #555; flex-shrink: 0; }
  .admin-panel-table { width: 100%; border-collapse: collapse; margin-bottom: 14px; }
  .admin-panel-table th {
    font-size: 11px; color: var(--text2); letter-spacing: 1px;
    text-align: left; padding: 0 8px 8px; border-bottom: 1px solid var(--border);
  }
  .admin-panel-table td { padding: 6px 8px; }
  .admin-price-input {
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-sm);
    color: var(--text); padding: 5px 10px; font-size: 13px;
    font-family: var(--font-num); width: 90px; outline: none;
    transition: border-color 0.2s;
  }
  .admin-price-input:focus { border-color: var(--accent); }
  .admin-module-row {
    display: flex; align-items: center; gap: 10px;
    padding: 7px 0; border-bottom: 1px solid var(--border);
  }
  .admin-module-row:last-child { border-bottom: none; }
  .admin-module-name { flex: 1; font-size: 13px; }
  .module-type-badge {
    font-size: 10px; padding: 2px 8px; border-radius: 10px;
    background: var(--surface2); color: var(--text2); white-space: nowrap;
  }
  .save-indicator {
    font-size: 12px; color: var(--accent2); opacity: 0;
    transition: opacity 0.3s; margin-left: 8px;
  }
  .save-indicator.show { opacity: 1; }
  .admin-section-label {
    font-size: 11px; color: var(--text2); letter-spacing: 1px;
    text-transform: uppercase; margin: 12px 0 8px;
  }
  .modal-wide { width: 520px; }
  .modal-field select {
    width: 100%; background: var(--bg); border: 1px solid var(--border);
    border-radius: var(--r-sm); padding: 10px 14px; color: var(--text);
    font-size: 14px; font-family: inherit; outline: none;
  }
  .modal-field select:focus { border-color: var(--accent); }
  .inline-add { display: flex; gap: 8px; margin-top: 8px; }
  .inline-add input {
    flex: 1; background: var(--bg); border: 1px solid var(--border);
    border-radius: var(--r-sm); padding: 7px 12px; color: var(--text);
    font-size: 13px; font-family: inherit; outline: none;
  }
  .inline-add input:focus { border-color: var(--accent); }
  .tag-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
  .tag {
    background: var(--surface2); border: 1px solid var(--border);
    border-radius: var(--r-sm); padding: 4px 10px; font-size: 12px;
    display: flex; align-items: center; gap: 6px;
  }
  .tag-remove { cursor: pointer; color: var(--text2); font-size: 14px; line-height: 1; }
  .tag-remove:hover { color: var(--danger); }
  .import-export-bar { display: flex; gap: 8px; }

  /* Scrollbar */
  ::-webkit-scrollbar { width: 6px; }
  ::-webkit-scrollbar-track { background: var(--bg); }
  ::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

  /* ── Permission Matrix ── */
  .perm-row {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 10px 14px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .perm-module-name { flex: 1; font-size: 13px; font-weight: 600; }
  .perm-select {
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: var(--r-sm);
    padding: 4px 8px;
    font-size: 12px;
    cursor: pointer;
  }
  .perm-select:focus { border-color: var(--accent); outline: none; }
  .user-row { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 14px 16px; margin-bottom: 10px; }
  .user-row.inactive { opacity: .5; }
  .user-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
  .user-avatar { font-size: 22px; }
  .user-name { font-weight: 700; font-size: 14px; }
  .user-meta { font-size: 12px; color: var(--text2); }
  .user-dept-badge { background: var(--bg); border: 1px solid var(--border); border-radius: 99px; padding: 2px 10px; font-size: 11px; color: var(--text2); }
  .user-perm-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
  .perm-chip { border-radius: 99px; padding: 2px 10px; font-size: 11px; font-weight: 600; }
  .perm-chip.admin  { background: color-mix(in srgb,#f5c518 15%,var(--surface)); color: #f5c518; border: 1px solid #f5c518; }
  .perm-chip.edit   { background: color-mix(in srgb,#4caf50 15%,var(--surface)); color: #4caf50; border: 1px solid #4caf50; }
  .perm-chip.view   { background: color-mix(in srgb,#7986cb 15%,var(--surface)); color: #7986cb; border: 1px solid #7986cb; }
  .user-actions { display: flex; gap: 6px; margin-left: auto; flex-shrink: 0; }

  /* ── Finance Module ── */
  #page-finance { background: var(--lhrm-bg); max-width: none; }
  select option { background: var(--surface2); color: var(--text); }
  .fin-tab {
    background: transparent; color: var(--lhrm-text-dim);
    border: 0.5px solid var(--lhrm-border-2); border-radius: 20px;
    padding: 5px 14px; cursor: pointer; font-size: 13px; transition: all 0.15s; font-family: inherit;
  }
  .fin-tab.active { background: rgba(232,197,71,0.12); color: #e8c547; border-color: #e8c547; font-weight: 500; }
  [data-theme="light"] .fin-tab.active { background: rgba(232,197,71,0.16); color: var(--lhrm-text); border-color: #e8c547; }
  .fin-tab:hover:not(.active) { border-color: var(--lhrm-text-dim); color: var(--lhrm-text); }

  /* ── PNL Module ── */
  .pnl-project-card {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-md); padding: 18px 20px; margin-bottom: 12px;
    cursor: pointer; transition: border-color .2s;
  }
  .pnl-project-card:hover { border-color: var(--accent); }

  .fin-account-card {
    background: var(--lhrm-surface); border: 1px solid var(--lhrm-border);
    border-radius: var(--r-md); padding: 12px 16px; min-width: 150px; flex: 1;
  }
  .fin-account-name { font-size: 11px; color: var(--lhrm-text-dim); margin-bottom: 4px; }
  .fin-account-balance { font-size: 20px; font-weight: 700; color: #e8c547; }
  .fin-record {
    background: var(--lhrm-surface); border: 1px solid var(--lhrm-border);
    border-radius: var(--r-md); padding: 14px 16px; margin-bottom: 10px;
    transition: border-color 0.2s;
  }
  .fin-record:hover { border-color: rgba(232,197,71,0.3); }
  .fin-record.urgent { border-left: 3px solid #e8c547; }
  .fin-record-header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
  .fin-badge {
    font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 600;
  }
  .fin-badge.expense { background: color-mix(in srgb, var(--c-money) 18%, transparent); color: var(--c-money); }
  .fin-badge.income  { background: color-mix(in srgb, var(--c-success) 18%, transparent); color: var(--c-success); }
  .fin-badge.daily   { background: color-mix(in srgb, var(--c-muted) 25%, transparent); color: var(--c-muted); }
  .fin-badge.project { background: color-mix(in srgb, var(--c-info) 18%, transparent); color: var(--c-info); }
  .fin-status-badge {
    font-size: 11px; padding: 2px 8px; border-radius: 20px; margin-left: auto;
  }
  .fin-status-badge.PENDING    { background: color-mix(in srgb, var(--c-warning) 18%, transparent); color: var(--c-warning); }
  .fin-status-badge.APPROVED   { background: color-mix(in srgb, var(--c-info) 18%, transparent); color: var(--c-info); }
  .fin-status-badge.DISBURSING { background: color-mix(in srgb, var(--c-progress) 18%, transparent); color: var(--c-progress); }
  .fin-status-badge.PAID       { background: color-mix(in srgb, var(--c-success) 18%, transparent); color: var(--c-success); }
  .fin-status-badge.CANCELLED  { background: color-mix(in srgb, var(--c-muted) 18%, transparent); color: var(--c-muted); }
  .fin-amount { font-size: 18px; font-weight: 700; }
  .fin-amount.expense { color: var(--c-money); }
  .fin-amount.income  { color: var(--c-success); }
  .fin-meta { font-size: 12px; color: var(--lhrm-text-dim); }
  .fin-actions { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
  .fin-btn {
    font-size: 12px; padding: 4px 12px; border-radius: var(--r-sm); border: 1px solid var(--lhrm-border-2);
    background: var(--lhrm-surface-2); color: var(--lhrm-text); cursor: pointer; transition: all 0.15s;
  }
  .fin-btn:hover { background: var(--lhrm-surface); }
  .fin-btn.approve { border-color: var(--c-info); color: var(--c-info); }
  .fin-btn.paid    { border-color: var(--c-success); color: var(--c-success); }
  .fin-btn.cancel  { border-color: var(--c-money); color: var(--c-money); }

  /* ── CONTRACTOR INFO ── */
  .ctr-group { margin-bottom: 28px; }
  .ctr-group-header {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 12px; padding-bottom: 8px;
    border-bottom: 1px solid var(--border);
  }
  .ctr-trade-badge {
    font-family: var(--font-num); font-size: 11px; font-weight: 700;
    padding: 3px 9px; border-radius: 5px; color: #0f0f12; letter-spacing: 1px;
  }
  .ctr-trade-name { font-weight: 700; font-size: 15px; }
  .ctr-count { font-size: 12px; color: var(--text2); margin-left: auto; }
  .ctr-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
  .ctr-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
    padding: 14px 14px 12px; transition: border-color 0.2s; position: relative;
  }
  .ctr-card:hover { border-color: rgba(232,197,71,0.35); }
  .ctr-card-seq { font-family:var(--font-num); font-size:10px; color:var(--text2); margin-bottom:5px; }
  .ctr-card-name { font-size: 14px; font-weight: 600; margin-bottom: 4px; padding-right: 26px; }
  .ctr-card-contact { font-size: 12px; color: var(--text2); margin-bottom: 4px; }
  .ctr-card-phone { font-family:var(--font-num); font-size:13px; color:var(--accent2); margin-bottom:3px; }
  .ctr-card-note { font-size: 11px; color: var(--text2); }
  .ctr-card-edit {
    position: absolute; top: 10px; right: 10px; background: none; border: none;
    cursor: pointer; color: var(--text2); font-size: 13px; padding: 3px 5px;
    border-radius: 4px; transition: color 0.15s, background 0.15s; line-height: 1;
  }
  .ctr-card-edit:hover { color: var(--accent); background: rgba(232,197,71,0.12); }
  .ctr-empty { color: var(--text2); font-size: 13px; padding: 40px; text-align: center; }

  /* ══════════════════════════════════
     📅 請假管理系統 CSS
  ══════════════════════════════════ */
  .leave-wrap { display: grid; grid-template-columns: 200px 1fr; min-height: calc(100vh - 56px); }
  #page-leave { max-width: 100% !important; padding: 0 !important; overflow-y: auto; z-index: 10; background: var(--bg); display: none; }
  #page-leave.active { display: block !important; }
  #page-salary { max-width: 100% !important; padding: 0 !important; overflow-y: auto; background: var(--bg); display: none; }
  #page-salary.active { display: block !important; }
  #page-salary .leave-wrap { min-height: calc(100vh - 56px); align-items: start; }
  #page-receipt { max-width: 100% !important; padding: 0 !important; overflow-y: auto; background: var(--lhrm-bg); }
  #page-receipt.active { display: block !important; }
  /* ── receipt/payees/cost-mgmt 亮色 token 修正 ── */
  #page-receipt input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]),
  #page-receipt select { background: var(--lhrm-input-bg) !important; border-color: var(--lhrm-border-2) !important; color: var(--lhrm-text) !important; }
  #page-payees input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]) { background: var(--lhrm-input-bg) !important; border-color: var(--lhrm-border-2) !important; color: var(--lhrm-text) !important; }
  #page-cost-mgmt .filter-input { background: var(--lhrm-input-bg) !important; border-color: var(--lhrm-border-2) !important; color: var(--lhrm-text) !important; }
  #page-inventory input:not([type=checkbox]):not([type=radio]):not([type=file]):not([type=range]) { background: var(--lhrm-input-bg) !important; border-color: var(--lhrm-border-2) !important; color: var(--lhrm-text) !important; }
  .leave-sidenav { background: var(--surface); border-right: 1px solid var(--border); padding: 20px 0; }
  .leave-sidenav-label { font-size: 10px; color: var(--text2); letter-spacing: 2px; padding: 0 20px 10px; font-weight: 700; }
  .leave-snav-btn { display: flex; align-items: center; gap: 9px; width: 100%; padding: 10px 20px; background: none; border: none; border-left: 3px solid transparent; color: var(--text2); font-size: 13px; font-family: inherit; cursor: pointer; text-align: left; transition: all .15s; }
  .leave-snav-btn:hover { background: var(--surface2); color: var(--text); }
  .leave-snav-btn.active { background: rgba(232,197,71,.07); color: var(--accent); border-left-color: var(--accent); }
  .leave-snav-badge { margin-left: auto; background: var(--danger); color: #fff; font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 10px; display: none; }
  .leave-body { padding: 28px 32px; }
  .leave-sub { display: none; }
  .leave-sub.active { display: block; }
  .lbal-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; margin-bottom: 28px; }
  .lbal-card { background: var(--surface); border: 1px solid var(--border); border-left: 3px solid var(--lc, var(--accent)); border-radius: var(--r-md); padding: 14px 14px 12px; }
  .lbal-type { font-size: 11px; color: var(--text2); margin-bottom: 6px; }
  .lbal-num { font-size: 26px; font-weight: 800; color: var(--lc, var(--accent)); line-height: 1; }
  .lbal-total { font-size: 12px; color: var(--text2); margin-top: 2px; }
  .lbal-bar { height: 3px; background: var(--border); border-radius: 2px; margin-top: 8px; }
  .lbal-bar-fill { height: 100%; border-radius: 2px; background: var(--lc, var(--accent)); transition: width .4s; }
  .lform-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 22px 24px; margin-bottom: 20px; }
  .lform-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
  .lform-group { display: flex; flex-direction: column; gap: 6px; }
  .lform-group.full { grid-column: 1/-1; }
  .lform-label { font-size: 12px; color: var(--text2); letter-spacing: .5px; }
  .lform-input, .lform-select, .lform-textarea { background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text); font-size: 14px; font-family: inherit; padding: 9px 12px; outline: none; transition: border-color .2s; }
  .lform-input:focus, .lform-select:focus, .lform-textarea:focus { border-color: var(--accent); }
  .lform-textarea { resize: vertical; min-height: 72px; }
  .lform-select option { background: var(--surface); }
  .ldays-preview { display: inline-flex; align-items: center; gap: 6px; background: rgba(232,197,71,.08); border: 1px solid rgba(232,197,71,.25); border-radius: var(--r-sm); padding: 5px 12px; font-size: 13px; color: var(--accent); margin-top: 8px; }
  .lbtn { display: inline-flex; align-items: center; gap: 5px; padding: 9px 18px; border-radius: var(--r-sm); font-size: 13px; font-weight: 700; font-family: inherit; border: none; cursor: pointer; transition: all .15s; }
  .lbtn-accent { background: var(--accent); color: #0f0f12; }
  .lbtn-accent:hover { opacity: .88; }
  .lbtn-ok { background: rgba(74,222,128,.12); border: 1px solid #4ade80; color: #4ade80; }
  .lbtn-ok:hover { background: rgba(74,222,128,.22); }
  .lbtn-no { background: rgba(248,113,113,.12); border: 1px solid var(--danger); color: var(--danger); }
  .lbtn-no:hover { background: rgba(248,113,113,.22); }
  .lbtn-ghost { background: none; border: 1px solid var(--border); color: var(--text2); }
  .lbtn-ghost:hover { border-color: var(--text2); color: var(--text); }
  .lbtn-sm { padding: 5px 12px; font-size: 12px; }
  .lbtn:disabled { opacity: .4; cursor: not-allowed; }
  .lfil-bar { display: flex; gap: 6px; margin-bottom: 14px; flex-wrap: wrap; }
  .lfil-chip { padding: 5px 14px; border-radius: 20px; font-size: 12px; font-weight: 600; border: 1px solid var(--border); background: none; color: var(--text2); font-family: inherit; cursor: pointer; transition: all .15s; }
  .lfil-chip:hover { border-color: var(--accent); color: var(--accent); }
  .lfil-chip.active { background: var(--accent); border-color: var(--accent); color: #0f0f12; }
  .ltable-wrap { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; }
  .ltable { width: 100%; border-collapse: collapse; font-size: 13px; }
  .ltable thead th { background: var(--surface2); color: var(--text2); font-size: 11px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; padding: 10px 14px; text-align: left; white-space: nowrap; }
  .ltable tbody tr { border-top: 1px solid var(--border); transition: background .12s; }
  .ltable tbody tr:hover { background: var(--surface2); }
  .ltable td { padding: 11px 14px; color: var(--text); vertical-align: middle; }
  .lstat { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: var(--r-md); font-size: 11px; font-weight: 700; }
  .lstat-pending  { background: rgba(251,191,36,.12);  color: #fbbf24; }
  .lstat-approved { background: rgba(74,222,128,.12);  color: #4ade80; }
  .lstat-rejected { background: rgba(248,113,113,.12); color: var(--danger); }
  .lstat-cancelled{ background: rgba(136,136,153,.12); color: var(--text2); }
  .lstat-auto_converted{ background: rgba(251,191,36,.12); color: #fbbf24; }
  .leave-modal-bg { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.65); z-index: 500; align-items: center; justify-content: center; padding: 20px; }
  .leave-modal-bg.open { display: flex; }
  .leave-modal { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 28px; width: 100%; max-width: 500px; box-shadow: 0 40px 80px rgba(0,0,0,.5); }
  .lmodal-title { font-size: 17px; font-weight: 700; margin-bottom: 18px; display: flex; justify-content: space-between; align-items: center; }
  .lmodal-close { background: none; border: none; color: var(--text2); font-size: 18px; cursor: pointer; padding: 2px 6px; border-radius: 5px; transition: color .15s; }
  .lmodal-close:hover { color: var(--text); }
  .ldet-row { display: flex; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
  .ldet-label { color: var(--text2); min-width: 80px; flex-shrink: 0; }
  #leave-toast-area { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; pointer-events: none; }
  .ltoast { display: inline-flex; align-items: center; gap: 8px; padding: 11px 16px; border-radius: var(--r-md); font-size: 13px; font-weight: 600; animation: lToastIn .2s ease, lToastOut .3s ease 3s forwards; pointer-events: auto; }
  .ltoast-ok   { background: var(--surface); border: 1px solid #4ade80; color: #4ade80; }
  .ltoast-err  { background: var(--surface); border: 1px solid var(--danger); color: var(--danger); }
  .ltoast-info { background: var(--surface); border: 1px solid var(--border); color: var(--text); }
  @keyframes lToastIn  { from { opacity:0; transform:translateX(16px); } }
  @keyframes lToastOut { to   { opacity:0; transform:translateX(16px); } }
  .luser-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
  .luser-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px; }
  .luser-name { font-size: 14px; font-weight: 700; margin-bottom: 12px; color: var(--accent); }
  .luser-bal-row { display: flex; justify-content: space-between; font-size: 12px; color: var(--text2); padding: 4px 0; border-bottom: 1px solid var(--border); }
  .luser-bal-row:last-child { border: none; }
  .luser-bal-num { font-family: var(--font-num); font-weight: 700; color: var(--text); }
  @media (max-width: 720px) {
    .leave-wrap { grid-template-columns: 1fr; }
    .leave-sidenav { display: flex; overflow-x: auto; padding: 10px; border-right: none; border-bottom: 1px solid var(--border); }
    .leave-snav-btn { white-space: nowrap; border-left: none; border-bottom: 3px solid transparent; padding: 8px 14px; }
    .leave-snav-btn.active { border-bottom-color: var(--accent); border-left-color: transparent; }
    .leave-sidenav-label { display: none; }
    .lform-grid { grid-template-columns: 1fr; }
    .leave-body { padding: 16px; }
  }

  /* ── MOBILE OVERLAY ── */
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.6);
    z-index: 199;
  }
  .sidebar-overlay.show { display: block; }

  @media (max-width: 768px) {
    /* Sidebar: hidden by default, overlay when open */
    .sidebar {
      width: var(--sidebar-width);
      transform: translateX(-100%);
      transition: transform 0.25s ease;
      z-index: 200;
    }
    .sidebar.mobile-open {
      transform: translateX(0);
    }
    .sidebar.collapsed { width: var(--sidebar-width); transform: translateX(-100%); }
    .sidebar.collapsed.mobile-open { transform: translateX(0); }
    .sidebar .nav-label, .sidebar .sidebar-brand, .sidebar .sidebar-group-label { display: block; }
    .sidebar .nav-btn { justify-content: flex-start; padding: 10px 16px; }
    .sidebar-footer .user-info span,
    .sidebar-footer .btn-sidebar-action span { display: inline; }
    .sidebar .nav-btn { min-height: 44px; font-size: 14px; }
    .sidebar-footer .btn-sidebar-action { min-height: 44px; }

    /* Main: full width, no margin */
    .app-main, .app-main.sidebar-collapsed {
      margin-left: 0 !important;
      width: 100% !important;
    }

    /* Mobile hamburger bar */
    .mobile-topbar {
      display: flex !important;
      position: fixed;
      top: 0; left: 0; right: 0;
      height: 52px;
      background: var(--surface);
      border-bottom: 1px solid var(--border);
      z-index: 198;
      align-items: center;
      padding: 0 16px;
      gap: 12px;
    }
    .mobile-topbar .mob-hamburger {
      background: none; border: none; color: var(--text);
      font-size: 22px; cursor: pointer; padding: 8px;
      min-width: 44px; min-height: 44px;
      display: flex; align-items: center; justify-content: center;
    }
    .mobile-topbar .mob-title {
      font-family: var(--font-num);
      font-size: 12px; color: var(--text); letter-spacing: 2px;
    }

    /* Push page content below topbar */
    .page { padding: 16px 14px !important; margin-top: 52px; }
    #page-leave, #page-salary, #page-receipt {
      top: 52px !important;
      left: 0 !important;
    }

    /* Dashboard grids */
    #dashboard-content [style*="grid-template-columns:repeat(auto-fill"] {
      grid-template-columns: 1fr 1fr !important;
    }
    #dashboard-content [style*="grid-template-columns:2fr 1fr"] {
      grid-template-columns: 1fr !important;
    }

    /* Global mobile rules */
    body { font-size: 14px; overflow-x: hidden; }
    .page { overflow-x: hidden; }
    button, .nav-btn, .btn-sidebar-action, .fin-tab, .leave-snav-btn {
      min-height: 44px;
    }

    /* Leave page: horizontal scroll tabs, single column cards */
    .leave-sidenav {
      display: flex !important;
      overflow-x: auto !important;
      -webkit-overflow-scrolling: touch;
      padding: 10px !important;
      border-right: none !important;
      border-bottom: 1px solid var(--border) !important;
      gap: 6px;
    }
    .leave-snav-btn { white-space: nowrap !important; min-height: 44px; }
    .leave-wrap { grid-template-columns: 1fr !important; }
    .leave-body { padding: 14px !important; }
    .leave-balance-grid { grid-template-columns: 1fr !important; }

    /* HR page: card mode */
    #hr-page-content table { display: none !important; }
    #hr-page-content .hr-mobile-cards { display: block !important; }

    /* Finance filters wrap */
    #page-finance .fin-tab { font-size: 12px; padding: 8px 10px; }

    /* No horizontal scroll anywhere */
    html, body, #app, .app-main { overflow-x: hidden; max-width: 100vw; }

    /* Page content: full width, no overflow */
    .page { width: 100% !important; max-width: 100% !important; box-sizing: border-box !important; }

    /* Panel quote: single column */
    .calc-layout { grid-template-columns: 1fr !important; }
    .quote-panel { margin-top: 16px; }

    /* Cards & panels full width */
    .card, .quote-panel, [style*="max-width:750px"], [style*="max-width:600px"] { max-width: 100% !important; width: 100% !important; box-sizing: border-box; }

    /* Tables: horizontal scroll */
    table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }

    /* Modals: mobile friendly — fix iOS touch offset bug */
    .modal-bg, div[style*="position:fixed"][style*="z-index:9999"],
    div[style*="position:fixed"][style*="z-index: 9999"] {
      align-items: flex-start !important;
      overflow-y: auto !important;
      -webkit-overflow-scrolling: touch !important;
      padding: 20px 0 !important;
    }
    .modal-bg .modal, .modal-bg > div > div,
    div[style*="position:fixed"][style*="z-index:9999"] > div,
    div[style*="position:fixed"][style*="z-index: 9999"] > div {
      width: 95vw !important; max-width: 95vw !important;
      max-height: none !important; overflow-y: visible !important;
      box-sizing: border-box !important; margin: 0 auto !important;
    }
    /* Modal inner grids: single column on mobile */
    .modal-bg .modal [style*="grid-template-columns:1fr 1fr"],
    .modal-bg .modal [style*="grid-template-columns: 1fr 1fr"],
    div[style*="position:fixed"] [style*="grid-template-columns:1fr 1fr"],
    div[style*="position:fixed"] [style*="grid-template-columns: 1fr 1fr"] {
      grid-template-columns: 1fr !important;
    }
    /* Modal inputs full width */
    .modal-bg input, .modal-bg select, .modal-bg textarea,
    div[style*="position:fixed"][style*="z-index:9999"] input,
    div[style*="position:fixed"][style*="z-index:9999"] select,
    div[style*="position:fixed"][style*="z-index:9999"] textarea {
      width: 100% !important; box-sizing: border-box !important; font-size: 16px !important;
      min-height: 44px !important; padding: 10px 12px !important;
    }

    /* Inputs: prevent iOS zoom */
    input, select, textarea { font-size: 16px !important; }

    /* Floating pet: hide on mobile */
    #floating-pet, #fp-toggle, #fp-context, #fp-container { display: none !important; }

    /* Two-column grids: single column */
    [style*="grid-template-columns:1fr 1fr"], [style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }

    /* Client mobile back button */
    .cli-mobile-back { display:block !important; }
    .cli-desktop-back { display:none !important; }
    /* Client/project detail max-width */
    #cli-detail-view, #pm-detail-view { max-width: 100% !important; }
    #cli-detail-view > div, #pm-detail-view > div { max-width: 100% !important; padding: 0 !important; }
    /* Client detail: mobile RWD — two-card stack + info grid 2-col */
    .cli-top-grid { grid-template-columns: 1fr !important; }
    #cli-side-entries { grid-column: 1 !important; grid-row: auto !important; }
    .cli-info-row1 { grid-template-columns: repeat(2, 1fr) !important; }
    .cli-info-grid { grid-template-columns: repeat(2, 1fr) !important; }
    /* Client detail: timeline vertical list + band horizontal scroll */
    .cli-tl-grid { display: flex !important; flex-direction: column !important; gap: 0 !important; }
    .cli-tl-grid > div[style*="grid-column:1"] { display: none !important; }
    .cli-tl-grid > div[onclick] { grid-column: auto !important; display: flex !important; flex-direction: row !important; align-items: center !important; gap: 10px !important; text-align: left !important; padding: 8px 4px !important; border-bottom: 1px solid var(--lhrm-border-2); border-radius: 0 !important; }
    .cli-tl-grid > div[onclick]:last-child { border-bottom: none; }
    .cli-tl-grid > div[onclick] > div:first-child { flex: 0 0 auto; margin: 0 !important; }
    .cli-tl-grid > div[onclick] > div:nth-child(2) { flex: 1; margin: 0 !important; white-space: nowrap; }
    .cli-tl-grid > div[onclick] > div:nth-child(n+3) { flex: 0 0 auto; margin: 0 !important; }
    .cli-stage-band { display: flex !important; flex-direction: row !important; overflow-x: auto !important; gap: 6px !important; -webkit-overflow-scrolling: touch; }
    .cli-stage-band > div { grid-column: auto !important; grid-row: auto !important; flex: 0 0 auto !important; white-space: nowrap; min-width: max-content; }
    /* Client detail: overflow containment (batch 3) */
    #cli-detail-view, #cli-detail-view > div { max-width: 100vw !important; overflow-x: hidden !important; box-sizing: border-box !important; }
    #cli-pay-section, #cli-detail-view [style*="grid-column:1/-1"] { max-width: 100% !important; overflow-x: auto !important; box-sizing: border-box !important; }
    #cli-pay-section > div[style*="display:flex"] { flex-wrap: wrap !important; }
    #cli-pay-section > div[style*="display:flex"] > * { min-width: 0 !important; }
    .cli-tl-grid > div[onclick] { box-sizing: border-box !important; max-width: 100% !important; }
    .cli-tl-grid > div[onclick] > div { min-width: 0 !important; }
    .cli-tl-grid > div[onclick] > div:nth-child(2) { overflow: hidden !important; text-overflow: ellipsis !important; }
    .cli-stage-band { max-width: 100% !important; }

    /* Calc2 page: full-width inputs and buttons */
    #page-calc2 .area-input-row, #page-calc2 .conv-input-wrap { flex-direction: column !important; }
    #page-calc2 input, #page-calc2 select, #page-calc2 button { width: 100% !important; box-sizing: border-box !important; max-width: 100% !important; }
    #page-calc2 .area-unit-btn, #page-calc2 .conv-unit-btn { width: auto !important; }
    #page-calc2 [style*="display:flex"][style*="gap"] { flex-wrap: wrap !important; }

    /* Tile calc: single column */
    #page-calc2 [style*="grid-template-columns:1fr 1fr"], #page-calc2 [style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }
    #page-calc2 canvas, #page-calc2 svg { max-width: 100% !important; height: auto !important; }

    /* Expense page: full-width form */
    #page-expense input, #page-expense select, #page-expense textarea { width: 100% !important; box-sizing: border-box !important; max-width: 100% !important; }
    #page-expense [style*="display:grid"] { grid-template-columns: 1fr !important; }
    #page-expense [style*="display:flex"][style*="gap"] { flex-wrap: wrap !important; }

    /* All inputs full-width on mobile */
    .page input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="range"]),
    .page select, .page textarea { width: 100% !important; box-sizing: border-box !important; max-width: 100% !important; }

    /* Page content padding */
    .page { padding: 12px !important; margin-top: 52px; max-width: 100vw !important; overflow-x: hidden !important; }
  }

  /* Desktop: hide mobile topbar */
  .mobile-topbar { display: none; }

  @media (min-width: 769px) {
    .sidebar-overlay { display: none !important; }
  }

  /* ── FILTER INPUT 統一樣式 ── */
  .filter-input {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s;
  }
  .filter-input:focus { border-color: var(--accent); }
  .filter-input::placeholder { color: var(--text2); }
  textarea.filter-input { resize: vertical; }

  /* ── TOAST 通知 ── */
  .wb-toast-container {
    position: fixed;
    top: 66px;
    right: 16px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
  }
  .wb-toast {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 12px 20px;
    font-size: 13px;
    color: var(--text);
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
    pointer-events: auto;
    animation: wbToastIn 0.25s ease, wbToastOut 0.3s ease 3s forwards;
    max-width: 360px;
  }
  .wb-toast.success { border-left: 4px solid var(--accent2); }
  .wb-toast.error   { border-left: 4px solid var(--danger); }
  .wb-toast.warning { border-left: 4px solid var(--accent); }
  .wb-toast.info    { border-left: 4px solid var(--sales-color); }
  @keyframes wbToastIn  { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
  @keyframes wbToastOut { from { opacity:1; } to { opacity:0; transform:translateY(-10px); } }

  /* ── 確認對話框 ── */
  .wb-confirm-bg {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    z-index: 10000;
    align-items: center;
    justify-content: center;
  }
  .wb-confirm-bg.open { display: flex; }
  .wb-confirm-box {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 28px 28px 20px;
    width: 380px;
    max-width: 90vw;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  }
  .wb-confirm-title { font-size: 15px; font-weight: 700; margin-bottom: 10px; }
  .wb-confirm-msg { font-size: 13px; color: var(--text2); margin-bottom: 20px; line-height: 1.5; }
  .wb-confirm-actions { display: flex; gap: 8px; justify-content: flex-end; }
  .wb-confirm-actions button {
    padding: 8px 20px;
    border-radius: var(--r-sm);
    border: 1px solid var(--border);
    background: var(--surface2);
    color: var(--text);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.15s;
  }
  .wb-confirm-actions .confirm-yes {
    background: var(--danger);
    border-color: var(--danger);
    color: #fff;
  }

  /* ── LOADING 指示器 ── */
  .wb-loading {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: wbSpin 0.6s linear infinite;
    vertical-align: middle;
    margin-right: 6px;
  }
  @keyframes wbSpin { to { transform: rotate(360deg); } }
  .btn-loading {
    opacity: 0.7;
    pointer-events: none;
  }

  /* ── 表格容器 ── */
  .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* ═══ 響應式：平板 ═══ */
  @media (max-width: 1024px) {
    .page { padding: 20px; }
  }

  /* ═══ 響應式：小平板 ═══ */
  @media (max-width: 768px) {
    .page { padding: 16px; }
    .page-title { font-size: 18px; }

    .login-box { width: 90vw; max-width: 380px; padding: 32px 24px; }

    .modal { width: 92vw; padding: 24px; }
    .modal-wide { width: 92vw; }

    .card { padding: 16px; }
    .quote-panel { position: static; }

    .vendor-table td { padding: 8px 10px; font-size: 12px; }
    .history-card { flex-direction: column; align-items: flex-start; gap: 8px; }
  }

  /* ═══ 響應式：手機 ═══ */
  @media (max-width: 480px) {
    .page { padding: 12px; }
    .page-title { font-size: 16px; }
    .page-sub { font-size: 12px; }

    .login-box { padding: 28px 20px; }

    .card { padding: 14px; border-radius: var(--r-md); }
    .modal { padding: 20px; border-radius: var(--r-md); }

    .fin-tab { padding: 6px 10px; font-size: 12px; }
    .fin-amount { font-size: 16px; }

    .ctr-cards { grid-template-columns: 1fr; }

    /* 報價單產生器手機版 */
    .qb-layout { grid-template-columns: 1fr !important; }
    .qb-client-grid { grid-template-columns: 1fr !important; }
    .qb-summary-grid { grid-template-columns: 1fr 1fr !important; }

    .hide-mobile { display: none; }
  }

  /* =============================================
     iPad 橫屏優化（769px ~ 1180px）
     ============================================= */
  @media (min-width: 769px) and (max-width: 1180px) {

    /* 側邊導覽列：強制 icon-only 模式 */
    .sidebar {
      width: var(--sidebar-collapsed) !important;
    }
    .sidebar .nav-label,
    .sidebar .sidebar-brand,
    .sidebar .sidebar-group-label {
      display: none !important;
    }
    .sidebar .nav-btn {
      justify-content: center;
      padding: 12px 0;
    }

    /* 主內容區補回空間 */
    .app-main {
      margin-left: var(--sidebar-collapsed) !important;
    }

    /* 所有按鈕加大觸控面積 */
    button, .btn, [class*="btn-"] {
      min-height: 40px;
      min-width: 40px;
    }

    /* input / select / textarea 加大 */
    input[type="text"],
    input[type="number"],
    input[type="date"],
    input[type="email"],
    select,
    textarea {
      min-height: 40px;
      font-size: 14px;
    }

    /* 卡片列表：改兩欄 */
    .ops-list { grid-template-columns: repeat(2, 1fr) !important; }
    .module-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important; }
    .ctr-cards { grid-template-columns: repeat(2, 1fr) !important; }
    .luser-grid { grid-template-columns: repeat(2, 1fr) !important; }

    /* 工程排程：工項列觸控優化 */
    .phase-row {
      min-height: 52px;
      padding: 10px 8px;
    }
    .phase-drag {
      width: 36px;
      height: 36px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 18px;
    }
    .phase-dur, .phase-pct {
      min-width: 64px;
      min-height: 40px;
      font-size: 14px;
    }
    .phase-date-input {
      min-width: 100px;
      min-height: 40px;
      font-size: 13px;
    }
    .btn-tree-del {
      width: 36px !important;
      height: 36px !important;
      font-size: 18px !important;
    }

    /* 訪談需求表：容器間距加大 */
    #interview-container {
      padding: 12px 8px;
    }
    #itv-form-body input,
    #itv-form-body textarea,
    #itv-form-body select {
      min-height: 40px;
      font-size: 14px;
    }
    #itv-form-body label {
      min-height: 36px;
      display: inline-flex;
      align-items: center;
    }

    /* 浮動按鈕位置 */
    #fb-float-btn,
    #chat-btn,
    #fp-toggle {
      bottom: 24px !important;
      right: 24px !important;
    }

    /* 通知面板起始位置跟隨縮窄後的 sidebar */
    #notif-panel {
      left: var(--sidebar-collapsed) !important;
    }
  }

  /* 訪談需求表「內部備註」紅底警示樣式（提醒不會匯出 PDF）
     itvTextarea 產出的 textarea 帶 inline style，必須用 !important 才能覆蓋 */
  textarea[data-itv="internalNote"] {
    background: #2d1518 !important;
    border: 1px solid #5a2828 !important;
    color: #e88 !important;
  }
  textarea[data-itv="internalNote"]::placeholder {
    color: #a55;
  }
  textarea[data-itv="internalNote"]:focus {
    background: #3a1a1d !important;
    border-color: #8b3a3a !important;
    outline: none !important;
  }
/* ========== BRIEFING 早安簡報(2026-04-26)========== */
.briefing-card { position:relative; z-index:2; background:var(--lhrm-surface); border-radius:var(--r-sm); padding:14px 18px; margin-bottom:18px; color:var(--lhrm-text); overflow:hidden; border:1px solid var(--lhrm-border-2); }
.briefing-card.is-day { background:var(--surface2); }
.briefing-card::before { display:none; }
.briefing-tag { display:flex; align-items:center; gap:6px; font-family:var(--lhrm-font-mono); font-size:10px; font-weight:500; letter-spacing:2px; color:#caa84e; text-transform:uppercase; margin-bottom:6px; }
.briefing-meta { margin-left:auto; font-family:var(--lhrm-font-mono); font-size:10px; font-weight:400; letter-spacing:.5px; color:var(--lhrm-text-dim); text-transform:none; }
.briefing-tag-arrow { display:inline-block; width:0; height:0; border-left:6px solid #caa84e; border-top:4px solid transparent; border-bottom:4px solid transparent; }
.briefing-tag-divider { color:var(--lhrm-text-dim); margin:0 4px; }
.briefing-tag-greeting { color:var(--lhrm-text-dim); letter-spacing:1px; font-weight:500; }
.briefing-main { font-size:13.5px; line-height:1.6; color:var(--lhrm-text); margin-bottom:8px; display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.briefing-main-text { flex:1; }
.briefing-num { color:#ffd166; font-weight:700; font-size:15px; margin:0 2px; }
.briefing-num.warn { color:#ff7a7a; }
.briefing-expand-btn { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); color:var(--lhrm-text-dim); padding:3px 8px; border-radius:4px; font-size:10px; cursor:pointer; white-space:nowrap; transition:all 0.2s; }
.briefing-expand-btn:hover { background:rgba(255,255,255,0.10); color:var(--lhrm-text); }
.briefing-rotator { font-size:12px; color:var(--lhrm-text-dim); min-height:18px; margin-bottom:8px; padding-left:10px; border-left:2px solid rgba(202,168,78,0.4); transition:opacity 0.4s; }
.briefing-rotator.fading { opacity:0; }
.briefing-rotator strong { color:#ffd166; font-weight:600; }
.briefing-rotator .alert { color:#ff9a7a; }
.briefing-status { display:flex; flex-wrap:wrap; gap:10px; font-size:11px; color:var(--lhrm-text-dim); padding-top:8px; border-top:1px solid rgba(255,255,255,0.04); }
.briefing-status-item { display:inline-flex; align-items:center; gap:4px; }
.briefing-status-divider { color:var(--lhrm-text-dim); }
.briefing-detail-panel { margin-top:8px; padding:10px 12px; background:rgba(255,255,255,0.02); border-radius:var(--r-sm); font-size:12px; color:var(--lhrm-text); display:none; }
.briefing-detail-panel.open { display:block; }
.briefing-detail-section { margin-bottom:12px; }
.briefing-detail-section:last-child { margin-bottom:0; }
.briefing-detail-title { font-size:10px; font-weight:700; color:#caa84e; letter-spacing:1px; margin-bottom:4px; }
.briefing-detail-item { padding:3px 0; border-bottom:1px dashed rgba(255,255,255,0.04); line-height:1.5; font-size:12px; }
.briefing-detail-item:last-child { border-bottom:0; }
.briefing-detail-item .waited { color:#ff7a7a; font-size:11px; margin-left:6px; }
.briefing-loading { font-size:12px; color:#718096; text-align:center; padding:6px; }
/* 行銷管理 header 手機 RWD (2026-05-09) */
@media (max-width: 768px) {
  #mkt-header { flex-direction: column !important; align-items: stretch !important; gap: 8px; }
  #mkt-controls { justify-content: space-between !important; flex-wrap: wrap; }
  #mkt-add-btn { white-space: nowrap; flex-shrink: 0; }
  .mkt-stages-wrap { display: grid !important; grid-template-columns: 1fr !important; gap: 10px !important; }
  .mkt-stage-card { min-width: 0 !important; text-align: left !important; }
  .mkt-connector-btn { display: block !important; margin: 2px auto !important; align-self: center !important; height: 26px !important; }
}
/* 浮動按鈕 iOS safe-area (2026-05-09) */
#fb-float-btn { bottom: calc(env(safe-area-inset-bottom, 0px) + 24px) !important; }
#chat-btn { bottom: calc(env(safe-area-inset-bottom, 0px) + 80px) !important; }
#chat-contacts { bottom: calc(env(safe-area-inset-bottom, 0px) + 132px) !important; }
/* 頁面底部留白讓浮動按鈕不擋內容 */
.page { padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 100px); }
/* 無專案員工卡 compact 樣式 */
.emp-card--empty { padding:10px 14px !important; }
.emp-card--empty > div { margin-bottom:0 !important; }
/* 全公司專案進度：名稱單行 */
.proj-prog-name { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
/* 行銷管理第二輪手機優化 (2026-05-09) */
#mkt-search { display:none; padding:6px 10px; width:100%; box-sizing:border-box; background:var(--surface2); border:1px solid var(--border); border-radius:var(--r-sm); color:var(--text); font-size:13px; }
#mkt-search::placeholder { color:#555; }
@media (max-width: 768px) {
  #mkt-month-picker { display:none !important; }
  #mkt-filter { display:none !important; }
  #mkt-search { display:block; }
  #mkt-subtitle { display:none !important; }
}
/* 行銷項目收起展開 */
.mkt-item--collapsed .mkt-stages-wrap { display:none !important; }
.mkt-item-summary { cursor:pointer; user-select:none; }
.mkt-item-chevron { display:inline-block; transition:transform 0.2s; margin-right:6px; font-size:11px; color:#888; vertical-align:middle; }
.mkt-item:not(.mkt-item--collapsed) .mkt-item-chevron { transform:rotate(90deg); }
  .view-toggle-group { display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden; }
  .view-toggle-group button { background:transparent;border:none;color:var(--text2);padding:6px 12px;cursor:pointer;font-size:13px;display:flex;align-items:center;gap:4px; }
  .view-toggle-group button.active { background:var(--accent);color:#111;font-weight:600; }
  .view-toggle-group button:hover:not(.active) { background:rgba(255,255,255,.05); }
  .cli-list-row:hover, .pm-list-row:hover { border-color:var(--accent) !important; }
  .stage-section-title { transition:opacity 0.15s; }
  .stage-section-title:hover { opacity:0.75; }
  .stage-fold-arrow { display:inline-block;font-size:10px;width:12px;text-align:center; }
  /* 照片合併工具:上傳區 hover 效果 */
  .pm-uploader-row label:hover { border-color: #f0c040 !important; background: #333 !important; color: #f0c040 !important; box-shadow: inset 0 2px 8px rgba(0,0,0,0.4) !important; }
  .pm-uploader-row label:active { background: #3a3a3a !important; }

  /* page-salary 舊 scoped 試點主題(--bg/--accent 等舊變數名)已移除,改吃 DESIGN_TOKENS.css 的 --lhrm-* (2026-05-31) */

/* ── 輕量 token tooltip 元件(純 CSS,跟 data-theme 走,hover 即現,無 JS) 2026-06-09 ── */
/* 用法:在元素加 class="lhrm-tip" data-tip="說明文字" */
.lhrm-tip{position:relative;cursor:help;border-bottom:1px dotted var(--lhrm-border-2)}
.lhrm-tip::after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translateX(-50%);background:var(--lhrm-surface-2);color:var(--lhrm-text);border:1px solid var(--lhrm-border-2);border-radius:8px;padding:8px 12px;font-size:12px;line-height:1.6;white-space:normal;width:max-content;max-width:260px;opacity:0;pointer-events:none;transition:opacity .12s;z-index:9999}
.lhrm-tip:hover::after{opacity:1}

/* ── 損益表 A3 狀態 pill(收支列共用,不帶金額) 2026-06-09 ── */
.pnl-pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:5px;font-family:var(--font-num,monospace);letter-spacing:.5px;white-space:nowrap}
.pnl-pill-done{color:var(--c-success);border:1px solid color-mix(in srgb,var(--c-success) 40%,transparent)}
.pnl-pill-wait{color:var(--lhrm-text-dim);border:1px solid var(--lhrm-border-2)}
.pnl-pill-part{color:var(--c-info);border:1px solid color-mix(in srgb,var(--c-info) 40%,transparent)}
.pnl-pill-over{color:var(--c-money);border:1px solid color-mix(in srgb,var(--c-money) 45%,transparent)}

/* ── 損益表列操作鈕:靜止淡出,列 hover 才顯(A3 v3 乾淨感) 2026-06-09 ── */
.pnl-row-ops{opacity:0;transition:opacity .15s ease}
tr:hover .pnl-row-ops{opacity:1}

/* ===== 儀表板 v3 版面(scoped .dv3,照 v3 mockup,全 token 雙主題;品牌金 #e8c547/#caa84e 保留) 2026-06-12 ===== */
.dv3 .dv3-head{display:flex;align-items:center;gap:12px;}
.dv3 .dv3-h1{font-size:25px;font-weight:500;letter-spacing:.5px;color:var(--lhrm-text);}
.dv3 .dv3-hsub{font-family:var(--lhrm-font-mono);font-size:11px;letter-spacing:2px;color:var(--lhrm-text-faint);margin-top:6px;text-transform:uppercase;}
.dv3 .dv3-rule{height:1px;background:var(--lhrm-border-2);margin:16px 0 22px;}
.dv3 .dv3-sec{font-family:var(--lhrm-font-mono);font-size:10px;letter-spacing:2.5px;color:var(--lhrm-text-faint);text-transform:uppercase;margin:22px 0 12px;display:flex;gap:10px;align-items:center;}
.dv3 .dv3-sec .ll{flex:1;height:1px;background:var(--lhrm-border);}
.dv3 .dv3-cols{display:grid;grid-template-columns:1fr 320px;gap:22px;align-items:start;}
.dv3 .dv3-left{min-width:0;}
.dv3 .dv3-right{min-width:0;}
/* KPI 網格融合:gap:1px 線色當格線,子卡去個別邊框 */
.dv3 .dv3-kpi{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1px;background:var(--lhrm-border-2);border:1px solid var(--lhrm-border-2);border-radius:12px;overflow:hidden;margin-bottom:4px;}
.dv3 .dv3-kpi>div{border:0!important;border-radius:0!important;background:var(--lhrm-surface)!important;}
.dv3 .dv3-lower{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:4px;}
.dv3 .dv3-lower>*{min-width:0;}
/* 我的任務 banner */
.dv3 .dv3-mytask{border:1px solid #caa84e;border-radius:12px;padding:16px 20px;cursor:pointer;background:linear-gradient(100deg,color-mix(in srgb,#e8c547 7%,var(--lhrm-surface)),var(--lhrm-surface) 60%);}
.dv3 .dv3-mytask .mtt{display:flex;align-items:center;gap:11px;}
.dv3 .dv3-mytask .mtic{width:32px;height:32px;border-radius:9px;background:color-mix(in srgb,#e8c547 16%,transparent);color:#e8c547;display:flex;align-items:center;justify-content:center;font-size:16px;flex:none;}
.dv3 .dv3-mytask .mttl{font-size:15px;font-weight:600;color:var(--lhrm-text);}
.dv3 .dv3-mytask .mtc{margin-left:auto;font-family:var(--lhrm-font-mono);font-size:11px;color:var(--lhrm-text-dim);}
.dv3 .dv3-mytask .mtc b{color:#e8c547;font-size:15px;}
.dv3 .dv3-mytask .mtr{display:flex;align-items:center;gap:14px;margin-top:13px;padding-top:13px;border-top:1px solid var(--lhrm-border);}
.dv3 .dv3-mytask .mtn{font-size:14px;color:var(--lhrm-text);}
.dv3 .dv3-mytask .mtp{margin-left:auto;display:flex;align-items:center;gap:10px;}
.dv3 .dv3-mytask .mtb{width:110px;height:6px;background:var(--lhrm-border-2);border-radius:4px;overflow:hidden;}
.dv3 .dv3-mytask .mtb i{display:block;height:100%;background:#e8c547;border-radius:4px;}
.dv3 .dv3-mytask .mtf{font-family:var(--lhrm-font-mono);font-size:13px;color:#caa84e;}
/* 個人職級 scard(右欄) */
.dv3 .dv3-scard{background:var(--lhrm-surface);border:1px solid var(--lhrm-border-2);border-radius:12px;padding:18px;margin-bottom:16px;}
.dv3 .dv3-rank{display:flex;align-items:center;gap:13px;}
.dv3 .dv3-medal{width:44px;height:44px;border-radius:50%;border:1px solid #caa84e;display:flex;align-items:center;justify-content:center;color:#caa84e;font-size:18px;flex:none;overflow:hidden;}
.dv3 .dv3-medal img{width:100%;height:100%;object-fit:contain;}
.dv3 .dv3-rt{font-size:15px;font-weight:600;color:var(--lhrm-text);}
.dv3 .dv3-rl{font-family:var(--lhrm-font-mono);font-size:9px;letter-spacing:1.5px;color:var(--lhrm-text-faint);text-transform:uppercase;}
.dv3 .dv3-rno{margin-left:auto;font-family:var(--lhrm-font-mono),monospace;font-size:22px;font-weight:500;color:#e8c547;font-variant-numeric:tabular-nums;}
.dv3 .dv3-pbar{height:6px;background:var(--lhrm-border-2);border-radius:4px;margin-top:12px;overflow:hidden;}
.dv3 .dv3-pbar i{display:block;height:100%;background:linear-gradient(90deg,#caa84e,#e8c547);}
.dv3 .dv3-pnext{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-faint);margin-top:8px;}
@media(max-width:980px){
  .dv3 .dv3-cols{grid-template-columns:1fr;}
  .dv3 .dv3-lower{grid-template-columns:1fr;}
  .dv3 .dv3-toprow{grid-template-columns:1fr;}
}
/* v3 修正批:BRIEFING|公告 並排一排 + 公告 compact 髮絲線列 2026-06-12 */
.dv3 .dv3-toprow{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;margin-bottom:4px;}
.dv3 .dv3-toprow>*{min-width:0;}
.dv3 .dv3-toprow .briefing-card{margin-bottom:0;height:100%;}
.dv3 .dv3-card{background:var(--lhrm-surface);border:1px solid var(--lhrm-border-2);border-radius:12px;padding:14px 20px;}
.dv3 .dv3-ann .ah{font-family:var(--lhrm-font-mono);font-size:10px;letter-spacing:2px;color:var(--lhrm-text-faint);text-transform:uppercase;margin-bottom:4px;}
.dv3 .dv3-lrow{display:flex;gap:12px;padding:7px 0;border-bottom:1px solid var(--lhrm-border);align-items:baseline;font-size:12.5px;color:var(--lhrm-text);}
.dv3 .dv3-lrow:last-child{border-bottom:none;}
.dv3 .dv3-lrow .lr-r{margin-left:auto;font-family:var(--lhrm-font-mono);font-size:10.5px;color:var(--lhrm-text-dim);white-space:nowrap;}
.dv3 .dv3-lrow .dot{width:5px;height:5px;border-radius:50%;background:#caa84e;flex:none;align-self:center;}
/* 本月之星 髮絲線列(照 mockup .star/.sr) */
.dv3 .dv3-star .sh{font-family:var(--lhrm-font-mono);font-size:10px;letter-spacing:2px;color:var(--lhrm-text-faint);text-transform:uppercase;margin-bottom:12px;}
.dv3 .dv3-sr{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--lhrm-border);align-items:center;font-size:13px;color:var(--lhrm-text);}
.dv3 .dv3-sr:last-child{border-bottom:none;}
.dv3 .dv3-sr .srank{font-family:var(--lhrm-font-mono);font-size:12px;color:var(--lhrm-text-faint);width:20px;flex:none;}
.dv3 .dv3-sr.f .srank{color:#e8c547;}
.dv3 .dv3-sr .sname{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dv3 .dv3-sr .sval{margin-left:auto;font-family:var(--lhrm-font-mono);color:var(--c-success);font-size:13px;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;}

/* ===== 儀表板 v4 完整版區塊(scoped .dv3,照 v4 SOURCE,token 雙主題) 2026-06-12 ===== */
.dv3 .dv3-two{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;}
.dv3 .dv3-two>*{min-width:0;}
.dv3 .dv3-panel{background:var(--lhrm-surface);border:1px solid var(--lhrm-border-2);border-radius:12px;padding:18px 20px;}
.dv3 .dv3-panel h3{font-size:13px;font-weight:600;display:flex;gap:9px;margin-bottom:12px;align-items:center;color:var(--lhrm-text);}
.dv3 .dv3-panel h3 .ti3{color:#caa84e;font-size:14px;}
.dv3 .dv3-panel h3 .en{font-family:var(--lhrm-font-mono);font-size:9px;letter-spacing:2px;color:var(--lhrm-text-faint);text-transform:uppercase;margin-left:auto;font-weight:400;}
.dv3 .dv3-panel .lrow{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--lhrm-border);align-items:center;font-size:12.5px;color:var(--lhrm-text);}
.dv3 .dv3-panel .lrow:last-child{border-bottom:none;}
.dv3 .dv3-panel .lrow .lr-r{margin-left:auto;font-family:var(--lhrm-font-mono);font-size:11px;color:var(--lhrm-text-faint);white-space:nowrap;}
.dv3 .dv3-panel .lrow .dot{width:5px;height:5px;border-radius:50%;background:#caa84e;flex:none;}
/* 每日任務 widget 融合網格 */
.dv3 .dv3-daily{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--lhrm-border-2);border:1px solid var(--lhrm-border-2);border-radius:12px;overflow:hidden;}
.dv3 .dv3-daily .dt{background:var(--lhrm-surface);padding:14px 16px;}
.dv3 .dv3-daily .dt .dth{display:flex;align-items:center;gap:8px;}
.dv3 .dv3-daily .dt .dti{color:var(--lhrm-text-dim);font-size:14px;width:16px;text-align:center;}
.dv3 .dv3-daily .dt.done .dti{color:var(--c-success);}
.dv3 .dv3-daily .dt .dtn{font-size:12.5px;font-weight:500;color:var(--lhrm-text);}
.dv3 .dv3-daily .dt .dts{margin-left:auto;font-family:var(--lhrm-font-mono);font-size:11px;color:var(--lhrm-text-faint);}
.dv3 .dv3-daily .dt.done .dts{color:var(--c-success);}
.dv3 .dv3-daily .dt .dtd{font-size:11px;color:var(--lhrm-text-faint);margin-top:6px;line-height:1.5;}
.dv3 .dv3-daily .dt .dbar{height:3px;background:var(--lhrm-border-2);border-radius:2px;margin-top:9px;overflow:hidden;}
.dv3 .dv3-daily .dt .dbar i{display:block;height:100%;background:#caa84e;}
.dv3 .dv3-daily .dt.done .dbar i{background:var(--c-success);}
.dv3 .dv3-daily .dt-claim{margin-top:9px;width:100%;font-family:var(--lhrm-font-mono);font-size:11px;background:color-mix(in srgb,var(--c-success) 14%,transparent);border:1px solid color-mix(in srgb,var(--c-success) 35%,transparent);color:var(--c-success);border-radius:6px;padding:5px;cursor:pointer;}
.dv3 .dv3-daily .dt-claimed{margin-top:9px;font-family:var(--lhrm-font-mono);font-size:11px;color:var(--lhrm-text-dim);}
.dv3 .dv3-daily .dt-reset{display:flex;align-items:center;justify-content:center;}
.dv3 .dv3-daily .dt-reset span{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-faint);letter-spacing:1px;}
/* 待審款 / 壽星 */
.dv3 .dv3-pend .pname{font-size:13px;color:var(--lhrm-text);}
.dv3 .dv3-pend .pmeta{font-family:var(--lhrm-font-mono);font-size:10.5px;color:var(--lhrm-text-faint);margin-top:2px;}
.dv3 .dv3-pend .pamt{margin-left:auto;font-family:var(--lhrm-font-mono);font-size:14px;color:var(--c-money);white-space:nowrap;}
.dv3 .dv3-bday .bic{color:#caa84e;}
/* 專案進度 */
.dv3 .dv3-proj .pjname{font-size:13px;color:var(--lhrm-text);}
.dv3 .dv3-proj .pjown{font-family:var(--lhrm-font-mono);font-size:10.5px;color:var(--lhrm-text-faint);margin-top:2px;}
.dv3 .dv3-proj .pjr{margin-left:auto;display:flex;align-items:center;gap:10px;}
.dv3 .dv3-proj .pjbar{width:90px;height:5px;background:var(--lhrm-border-2);border-radius:3px;overflow:hidden;flex:none;}
.dv3 .dv3-proj .pjbar i{display:block;height:100%;background:var(--c-info);border-radius:3px;}
.dv3 .dv3-proj .pjpct{font-family:var(--lhrm-font-mono);font-size:11.5px;color:var(--lhrm-text-dim);width:34px;text-align:right;}
.dv3 .pill{font-family:var(--lhrm-font-mono);font-size:9.5px;letter-spacing:.5px;padding:2px 8px;border-radius:4px;white-space:nowrap;}
.dv3 .pill.sign{color:var(--c-info);background:color-mix(in srgb,var(--c-info) 13%,transparent);}
.dv3 .pill.work{color:var(--c-warning);background:color-mix(in srgb,var(--c-warning) 13%,transparent);}
.dv3 .pill.other{color:var(--lhrm-text-dim);background:color-mix(in srgb,var(--lhrm-text-dim) 13%,transparent);}
/* 出勤 / 登入 chips / 打卡清單 */
.dv3 .dv3-att .big{font-size:14px;color:var(--c-success);font-weight:500;}
.dv3 .dv3-att .sub{font-size:11.5px;color:var(--lhrm-text-faint);margin-top:5px;}
.dv3 .dv3-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.dv3 .dv3-chip{font-family:var(--lhrm-font-mono);font-size:10.5px;color:var(--lhrm-text-dim);border:1px solid var(--lhrm-border-2);border-radius:5px;padding:3px 9px;}
.dv3 .dv3-chip.onl{color:var(--c-success);border-color:color-mix(in srgb,var(--c-success) 40%,var(--lhrm-border-2));}
.dv3 .dv3-punchlist .sumline{font-family:var(--lhrm-font-mono);font-size:11px;margin-bottom:8px;color:var(--lhrm-text);}
.dv3 .dv3-punchlist .sumline b{color:var(--c-success);}
.dv3 .dv3-punchlist .sumline .miss{color:var(--lhrm-text-faint);}
.dv3 .dv3-punchlist .lrow{padding:6px 0;font-size:12px;}
.dv3 .dv3-punchlist .pdept{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-faint);}
.dv3 .dv3-punchlist .pst{margin-left:auto;font-family:var(--lhrm-font-mono);font-size:11px;color:var(--lhrm-text-faint);}
/* 員工總覽 人卡網格 */
.dv3 .dv3-empgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.dv3 .dv3-empgrid>*{min-width:0;}
.dv3 .dv3-emp{background:var(--lhrm-surface);border:1px solid var(--lhrm-border-2);border-radius:12px;padding:15px 16px;}
.dv3 .dv3-emp .eh{display:flex;align-items:center;gap:10px;}
.dv3 .dv3-emp .eav{width:30px;height:30px;border-radius:8px;background:var(--lhrm-surface-2);border:1px solid var(--lhrm-border-2);display:flex;align-items:center;justify-content:center;font-family:var(--lhrm-font-mono);font-size:13px;color:#caa84e;flex:none;}
.dv3 .dv3-emp .en2{font-size:13.5px;font-weight:600;color:var(--lhrm-text);}
.dv3 .dv3-emp .edept{font-family:var(--lhrm-font-mono);font-size:9.5px;letter-spacing:1px;color:var(--lhrm-text-faint);margin-top:1px;}
.dv3 .dv3-emp .edot{width:7px;height:7px;border-radius:50%;background:var(--c-success);margin-left:auto;flex:none;}
.dv3 .dv3-emp .edot.off{background:var(--lhrm-text-faint);}
.dv3 .dv3-emp .edot.away{background:var(--c-warning);}
.dv3 .dv3-emp .eproj{margin-top:10px;padding-top:9px;border-top:1px solid var(--lhrm-border);}
.dv3 .dv3-emp .ep{font-size:11px;color:var(--lhrm-text-dim);padding:2.5px 0;display:flex;gap:7px;}
.dv3 .dv3-emp .ep .d2{width:4px;height:4px;border-radius:50%;background:var(--lhrm-text-faint);flex:none;margin-top:6px;}
@media(max-width:980px){ .dv3 .dv3-two{grid-template-columns:1fr;} .dv3 .dv3-daily{grid-template-columns:repeat(2,1fr);} .dv3 .dv3-empgrid{grid-template-columns:repeat(2,1fr);} }

/* ===== 訪談需求表 LEBRI 改版 — 元件庫(全 token,命名空間 itv-,亮暗雙主題)===== */
#page-interview{ --itv-gs: color-mix(in srgb, #e8c547 72%, transparent); }

/* 文件頭 */
.itv-dochead{border:1px solid var(--lhrm-border-2);border-radius:16px;background:var(--lhrm-surface);padding:22px 28px;margin-bottom:20px}
.itv-dh-top{display:flex;align-items:center;gap:13px;flex-wrap:wrap}
.itv-dh-tag{font-family:var(--lhrm-font-mono);font-size:12px;letter-spacing:2px;color:var(--itv-gs)}
.itv-dh-name{font-size:22px;font-weight:500;letter-spacing:.5px;color:var(--lhrm-text)}
.itv-dh-sub{font-family:var(--lhrm-font-mono);font-size:11px;color:var(--lhrm-text-dim);letter-spacing:1px}
.itv-dh-meta{display:flex;gap:34px;margin-top:18px;padding-top:16px;border-top:1px solid color-mix(in srgb,var(--lhrm-border-2) 55%,transparent);flex-wrap:wrap}
.itv-kv{display:flex;flex-direction:column;gap:4px}
.itv-kv .k{font-family:var(--lhrm-font-mono);font-size:9.5px;letter-spacing:2px;color:var(--lhrm-text-dim)}
.itv-kv .v{font-family:var(--lhrm-font-mono);font-size:13px;color:var(--lhrm-text)}

/* 主體骨架 */
.itv-shell{display:grid;grid-template-columns:222px 1fr;border:1px solid var(--lhrm-border-2);border-radius:16px;overflow:hidden;background:var(--lhrm-surface)}
.itv-side{border-right:1px solid var(--lhrm-border-2);padding:12px 0;background:var(--lhrm-surface)}
.itv-side-h{font-family:var(--lhrm-font-mono);font-size:9.5px;letter-spacing:2.5px;color:var(--lhrm-text-dim);padding:6px 20px 12px;border-bottom:1px solid color-mix(in srgb,var(--lhrm-border-2) 55%,transparent);margin-bottom:5px}
.itv-nav{display:flex;align-items:center;gap:11px;padding:9px 20px;cursor:pointer;border-left:2px solid transparent;transition:.13s}
.itv-nav:hover{background:var(--lhrm-surface-2);padding-left:23px}
.itv-nav.on{border-left-color:#e8c547;background:var(--lhrm-surface-2)}
.itv-nav .c{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-dim);min-width:28px}
.itv-nav.on .c{color:var(--itv-gs)}
.itv-nav .n{font-size:13.5px;color:var(--lhrm-text-dim);flex:1}
.itv-nav.on .n,.itv-nav:hover .n{color:var(--lhrm-text)}
.itv-nav .d{width:5px;height:5px;border-radius:50%;background:#e8c547;opacity:.55}
.itv-nav .d.e{background:var(--lhrm-border-2);opacity:1}
.itv-side-foot{padding:12px 18px 4px;margin-top:6px;border-top:1px solid color-mix(in srgb,var(--lhrm-border-2) 55%,transparent);display:flex;flex-direction:column;gap:2px}
.itv-mini{text-align:left;font-family:var(--lhrm-font-mono);font-size:10.5px;color:var(--lhrm-text-dim);background:none;border:none;padding:8px 0;cursor:pointer;display:flex;align-items:center;gap:9px}
.itv-mini:hover{color:var(--lhrm-text)} .itv-mini i{font-size:15px}

/* 頂部 strip(窄螢幕/直向) */
.itv-strip{display:none;gap:8px;padding:10px 14px;border-bottom:1px solid var(--lhrm-border-2);overflow-x:auto;background:var(--lhrm-surface)}
.itv-schip{flex:0 0 auto;font-size:13px;color:var(--lhrm-text-dim);padding:8px 15px;border-radius:22px;border:1px solid var(--lhrm-border-2);cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:7px;background:transparent}
.itv-schip .c{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-dim)}
.itv-schip.on{color:var(--lhrm-text);border-color:#e8c547;background:color-mix(in srgb,#e8c547 9%,transparent)}
.itv-schip.on .c{color:var(--itv-gs)}

/* 內容 + 區段標題 */
.itv-content{padding:28px 34px 36px}
.itv-sechead{display:flex;align-items:baseline;gap:12px;margin-bottom:6px}
.itv-sec-c{font-family:var(--lhrm-font-mono);font-size:11px;letter-spacing:1.5px;color:var(--itv-gs)}
.itv-sec-t{font-size:18px;font-weight:500;color:var(--lhrm-text)}
.itv-sec-m{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-dim);margin-left:auto;letter-spacing:1px}
.itv-rule{height:1px;background:var(--lhrm-border-2);margin:13px 0 24px}

/* 欄位分組 + 髮絲線小標 */
.itv-fgroup{margin-bottom:28px}
.itv-fglabel{font-family:var(--lhrm-font-mono);font-size:10px;letter-spacing:2px;color:var(--lhrm-text-dim);margin-bottom:13px;display:flex;align-items:center;gap:10px}
.itv-fglabel::after{content:'';flex:1;height:1px;background:color-mix(in srgb,var(--lhrm-border-2) 55%,transparent)}

/* 帶值唯讀 key-value */
.itv-kvgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px 26px}
.itv-kvcell{display:flex;flex-direction:column;gap:5px;padding-bottom:11px;border-bottom:1px solid color-mix(in srgb,var(--lhrm-border-2) 55%,transparent)}
.itv-kvcell .kk{font-size:11.5px;color:var(--lhrm-text-dim)}
.itv-kvcell .vv{font-family:var(--lhrm-font-mono);font-size:14px;color:var(--lhrm-text)}
.itv-kvcell .vv.e{color:var(--lhrm-text-dim);opacity:.7}

/* text/number 欄 */
.itv-grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 26px}
.itv-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px 26px}
.itv-field{display:flex;flex-direction:column;gap:7px}
.itv-field>label{font-size:12.5px;color:var(--lhrm-text-dim)}
.itv-field>label .u{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--lhrm-text-dim);opacity:.75;margin-left:6px}
.itv-inp{background:transparent;border:none;border-bottom:1px solid var(--lhrm-border-2);color:var(--lhrm-text);font-family:var(--lhrm-font-mono);font-size:14px;padding:8px 2px;outline:none;width:100%;transition:.15s}
.itv-inp::placeholder{color:var(--lhrm-text-dim);opacity:.6;font-family:'Noto Sans TC',sans-serif}
.itv-inp:focus{border-bottom-color:#e8c547}
.itv-inp.cjk{font-family:'Noto Sans TC',sans-serif}

/* radio chips(div 包原生 radio,itvRadioToggle 切值;視覺跟 input:checked 走)*/
.itv-chips{display:flex;flex-wrap:wrap;gap:9px}
.itv-chip{position:relative;display:inline-flex;align-items:center;font-size:12.5px;color:var(--lhrm-text-dim);padding:7px 15px;border:1px solid var(--lhrm-border-2);border-radius:22px;cursor:pointer;transition:.13s;user-select:none;background:transparent}
.itv-chip input{position:absolute;opacity:0;width:0;height:0;margin:0;pointer-events:none}
.itv-chip:hover{color:var(--lhrm-text)}
.itv-chip:has(input:checked){border-color:#e8c547;color:var(--lhrm-text);background:color-mix(in srgb,#e8c547 9%,transparent)}
.itv-chip:has(input:checked)::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:#e8c547;margin-right:7px}

/* checkbox chips(label 包原生 checkbox;視覺 + 勾選才展開備註,皆跟 input:checked 走)*/
.itv-checks{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-start}
.itv-ck-opt{display:flex;flex-direction:column;gap:6px}
.itv-cbx{position:relative;display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--lhrm-text-dim);padding:7px 14px;border:1px solid var(--lhrm-border-2);border-radius:9px;cursor:pointer;transition:.13s;user-select:none;background:transparent}
.itv-cbx input{position:absolute;opacity:0;width:0;height:0;margin:0}
.itv-cbx .b{width:14px;height:14px;border:1px solid var(--lhrm-text-dim);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:.13s;flex:0 0 auto}
.itv-cbx .b i{font-size:11px;opacity:0;color:var(--lhrm-bg)}
.itv-cbx:hover{color:var(--lhrm-text)}
.itv-cbx:has(input:checked){border-color:color-mix(in srgb,#e8c547 55%,transparent);color:var(--lhrm-text);background:color-mix(in srgb,#e8c547 7%,transparent)}
.itv-cbx:has(input:checked) .b{background:#e8c547;border-color:#e8c547}
.itv-cbx:has(input:checked) .b i{opacity:1}
.itv-ck-note{display:none;background:var(--lhrm-surface-2);border:1px solid var(--lhrm-border-2);border-radius:8px;color:var(--lhrm-text);font-family:'Noto Sans TC',sans-serif;font-size:12px;padding:8px 10px;outline:none;resize:vertical;min-width:170px}
.itv-ck-opt:has(input:checked) .itv-ck-note{display:block}
.itv-ck-note:focus{border-color:#e8c547}

/* 條件展開 */
.itv-reveal{margin-top:13px;padding:14px 16px;border-left:2px solid color-mix(in srgb,#e8c547 40%,transparent);background:var(--lhrm-surface-2);border-radius:0 9px 9px 0;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.itv-reveal .rl{font-size:11.5px;color:var(--lhrm-text-dim);font-family:var(--lhrm-font-mono);letter-spacing:.5px}

/* textarea + 內部備註 */
.itv-ta{background:var(--lhrm-surface-2);border:1px solid var(--lhrm-border-2);border-radius:10px;color:var(--lhrm-text);font-family:'Noto Sans TC',sans-serif;font-size:13px;padding:12px 14px;outline:none;width:100%;min-height:80px;resize:vertical;transition:.15s}
.itv-ta:focus{border-color:#e8c547}
.itv-internal{position:relative}
.itv-internal .tag{position:absolute;top:-9px;right:12px;font-family:var(--lhrm-font-mono);font-size:9px;letter-spacing:1px;color:var(--c-money);background:var(--lhrm-surface);padding:0 7px;border:1px solid color-mix(in srgb,var(--c-money) 35%,transparent);border-radius:10px}

/* 商業空間 zone */
.itv-zone{border:1px solid var(--lhrm-border-2);border-radius:11px;padding:16px 18px;margin-bottom:14px;background:var(--lhrm-surface-2)}
.itv-zone-h{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.itv-zone-h .zc{font-family:var(--lhrm-font-mono);font-size:10px;color:var(--itv-gs);letter-spacing:1px}
.itv-addzone{font-family:var(--lhrm-font-mono);font-size:11.5px;letter-spacing:.5px;color:var(--itv-gs);background:none;border:1px dashed var(--lhrm-border-2);border-radius:9px;padding:10px;width:100%;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:.13s}
.itv-addzone:hover{border-color:#e8c547;color:#e8c547}

/* 儲存狀態 */
.itv-savedot{display:inline-flex;align-items:center;gap:7px;font-family:var(--lhrm-font-mono);font-size:10.5px;letter-spacing:1px;color:var(--lhrm-text-dim)}
.itv-savedot::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--c-confirm);box-shadow:0 0 0 3px color-mix(in srgb,var(--c-confirm) 18%,transparent)}

/* ===== iPad 觸控 / 響應式覆蓋(≤1024px 觸控放大;≤860px 直向 reflow)===== */
@media (max-width:1024px){
  #page-interview .itv-nav{min-height:50px;padding-top:0;padding-bottom:0}
  #page-interview .itv-nav .n{font-size:15px}
  #page-interview .itv-mini{min-height:46px;padding:0 2px}
  #page-interview .itv-chip{min-height:46px;font-size:14px;padding:0 18px}
  #page-interview .itv-cbx{min-height:46px;font-size:14px;padding:0 16px}
  #page-interview .itv-cbx .b{width:18px;height:18px}
  #page-interview .itv-schip{min-height:44px}
  #page-interview .itv-inp{background:var(--lhrm-surface-2);border:1px solid var(--lhrm-border-2);border-radius:11px;font-size:15px;padding:13px 14px;min-height:48px}
  #page-interview .itv-inp:focus{border-color:#e8c547;background:color-mix(in srgb,#e8c547 4%,transparent)}
  #page-interview .itv-nav:hover{padding-left:20px}
}
@media (max-width:860px){
  #page-interview .itv-shell{grid-template-columns:1fr}
  #page-interview .itv-side{display:none}
  #page-interview .itv-strip{display:flex}
  #page-interview .itv-content{padding:22px 20px 32px}
  #page-interview .itv-kvgrid{grid-template-columns:repeat(2,1fr)}
  #page-interview .itv-grid3{grid-template-columns:repeat(2,1fr)}
  #page-interview .itv-grid2{grid-template-columns:1fr}
  #page-interview .itv-dh-meta{gap:20px}
}
@media (max-width:560px){
  #page-interview .itv-kvgrid,#page-interview .itv-grid3{grid-template-columns:1fr}
}
