:root {
  --accent: #0066FF;
  --accent-50: #E6F1FB;
  --accent-100: #B5D4F4;
  --accent-700: #185FA5;
  --accent-800: #0C447C;
  --accent-light: #E6F1FB;
  --sidebar-w: 220px;
  --color-background-primary: #ffffff;
  --color-background-secondary: #f5f5f5;
  --color-background-tertiary: #efefef;
  --color-text-primary: #111111;
  --color-text-secondary: #666666;
  --color-border-tertiary: rgba(0,0,0,0.12);
  --color-border-secondary: rgba(0,0,0,0.22);
  --border-radius-md: 8px;
  --border-radius-lg: 12px;
  --border-radius-xl: 16px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
@media (prefers-color-scheme: dark) {
  :root {
    --accent-50: #0c2a52; --accent-100: #0d3566; --accent-700: #85B7EB; --accent-800: #B5D4F4; --accent-light: #0c2a52;
    --color-background-primary: #1c1c1e; --color-background-secondary: #2c2c2e; --color-background-tertiary: #242426;
    --color-text-primary: #f0f0f0; --color-text-secondary: #999999;
    --color-border-tertiary: rgba(255,255,255,0.1); --color-border-secondary: rgba(255,255,255,0.18);
  }
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { background: #e0e0e0; color: var(--color-text-primary); display: flex; align-items: flex-start; justify-content: center; min-height: 100vh; padding: 24px; }
/* Ensure app-frame is hidden on login screen */
#app-frame { display: none; }
@media (prefers-color-scheme: dark) { :root:not([data-color-mode="light"]) body { background: #111; } }

/* ── Manual color mode overrides ── */
[data-color-mode="light"] {
  --accent-50: #E6F1FB; --accent-100: #B5D4F4; --accent-700: #185FA5; --accent-800: #0C447C; --accent-light: #E6F1FB;
  --color-background-primary: #ffffff; --color-background-secondary: #f5f5f5; --color-background-tertiary: #efefef;
  --color-text-primary: #111111; --color-text-secondary: #666666;
  --color-border-tertiary: rgba(0,0,0,0.12); --color-border-secondary: rgba(0,0,0,0.22);
}
[data-color-mode="dark"] {
  --accent-50: #0c2a52; --accent-100: #0d3566; --accent-700: #85B7EB; --accent-800: #B5D4F4; --accent-light: #0c2a52;
  --color-background-primary: #1c1c1e; --color-background-secondary: #2c2c2e; --color-background-tertiary: #242426;
  --color-text-primary: #f0f0f0; --color-text-secondary: #999999;
  --color-border-tertiary: rgba(255,255,255,0.1); --color-border-secondary: rgba(255,255,255,0.18);
}
[data-color-mode="dark"] body { background: #111; }
[data-color-mode="light"] body { background: #e0e0e0; }


/* ── Login screen ── */
#login-screen { display:flex; align-items:center; justify-content:center; width:100%; min-height:100vh; background:var(--color-background-tertiary); }
.login-card { background:var(--color-background-primary); border-radius:20px; border:0.5px solid var(--color-border-tertiary); padding:48px 40px 40px; width:380px; display:flex; flex-direction:column; align-items:center; gap:24px; }
.logo-wrap { display:flex; flex-direction:column; align-items:center; gap:8px; }
.logo-name { font-size:22px; font-weight:500; color:var(--color-text-primary); letter-spacing:.02em; }

/* Branding skeleton — pulsing opacity while /branding fetch is in flight */
@keyframes branding-pulse { 0%,100%{opacity:.4} 50%{opacity:.9} }
.branding-loading #login-logo-placeholder { animation:branding-pulse 1.2s ease-in-out infinite; }
.branding-loading #login-app-name { animation:branding-pulse 1.2s ease-in-out infinite; color:var(--color-text-tertiary); }
.logo-sub { font-size:12px; color:var(--color-text-secondary); }
.login-form { width:100%; display:flex; flex-direction:column; gap:14px; }
.login-field { display:flex; flex-direction:column; gap:5px; }
.login-field label { font-size:12px; font-weight:500; color:var(--color-text-secondary); letter-spacing:.02em; }
.login-field input { padding:11px 14px; border-radius:10px; border:0.5px solid var(--color-border-secondary); background:var(--color-background-primary); font-size:15px; color:var(--color-text-primary); font-family:inherit; width:100%; }
.login-field input:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,102,255,.1); }
.login-btn { width:100%; padding:13px; border-radius:10px; background:var(--accent); color:#fff; border:none; font-size:15px; font-weight:500; cursor:pointer; font-family:inherit; margin-top:4px; }
.login-btn:hover { background:#0052CC; }
.login-err { font-size:13px; color:#A32D2D; text-align:center; display:none; }

/* ── Theme picker ── */



/* ── Shell frame ── */
#app-frame { display:none; width:100%; }
.device-frame { width:100%; max-width:1024px; margin:0 auto; background:var(--color-background-secondary); border-radius:var(--border-radius-lg); border:0.5px solid var(--color-border-tertiary); overflow:hidden; display:flex; flex-direction:column; }
.status-bar { background:var(--color-background-primary); border-bottom:0.5px solid var(--color-border-tertiary); padding:8px 20px 8px 16px; display:flex; align-items:center; justify-content:space-between; font-size:12px; color:var(--color-text-secondary); }
.status-bar .app-title { font-size:13px; font-weight:500; color:var(--color-text-primary); display:flex; align-items:center; gap:8px; }
.app-body { display:flex; height:740px; }
.sidebar { width:var(--sidebar-w); background:var(--color-background-primary); border-right:0.5px solid var(--color-border-tertiary); display:flex; flex-direction:column; padding:16px 0; flex-shrink:0; transition:width .22s ease; overflow:hidden; }
.sidebar.collapsed { width:64px; }
.sidebar.collapsed .sidebar-section-label { display:none; }
.sidebar.collapsed .sidebar-section { padding:0; }
.sidebar.collapsed .nav-item {
  justify-content:center; align-items:center;
  padding:10px 0; width:64px;
  font-size:0; color:transparent;
  white-space:nowrap; overflow:hidden;
  gap:0;
}
.sidebar.collapsed .nav-item .nav-icon {
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--color-text-secondary);
  width:20px; height:20px; flex-shrink:0;
}
.sidebar.collapsed .nav-item.active .nav-icon { color:var(--accent); }
.sidebar.collapsed .nav-item:hover .nav-icon { color:var(--color-text-primary); }
.sidebar.collapsed .sidebar-bottom .user-info,
.sidebar.collapsed .user-row .user-info,
.sidebar.collapsed .user-row > svg { display:none; }
.sidebar.collapsed .user-row { justify-content:center; padding:10px 0; width:64px; border-radius:var(--border-radius-md); }
.sidebar.collapsed .user-row .avatar { margin:0; cursor:pointer; flex-shrink:0; }
.sidebar.collapsed .sidebar-bottom { padding:8px 0; }
.sidebar-section { padding:0 12px; margin-bottom:8px; }
.sidebar-section-label { font-size:10px; font-weight:500; color:var(--color-text-secondary); text-transform:uppercase; letter-spacing:0.06em; padding:8px 8px 4px; }
.nav-item { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:var(--border-radius-md); cursor:pointer; font-size:14px; color:var(--color-text-secondary); transition:background 0.15s; border:none; background:none; width:100%; text-align:left; }
.nav-item:hover { background:var(--color-background-secondary); color:var(--color-text-primary); }
.nav-item.active { background:var(--accent-light); color:var(--accent); font-weight:500; }
.nav-item .nav-icon { width:20px; height:20px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.nav-item .perm-tag { margin-left:auto; font-size:9px; padding:2px 6px; border-radius:10px; font-weight:500; }
.perm-m { background:#EAF3DE; color:#3B6D11; }
.perm-ms { background:#FAEEDA; color:#854F0B; }
.perm-msa { background:#E1F5EE; color:#0F6E56; }
.perm-all { background:var(--color-background-secondary); color:var(--color-text-secondary); }
.perm-it { background:#FCEBEB; color:#A32D2D; }
.sidebar-bottom { margin-top:auto; padding:12px; border-top:0.5px solid var(--color-border-tertiary); }
.user-row { display:flex; align-items:center; gap:10px; padding:8px; border-radius:var(--border-radius-md); cursor:pointer; }
.user-row:hover { background:var(--color-background-secondary); }
.avatar { width:32px; height:32px; border-radius:50%; background:var(--accent-light); color:var(--accent); font-size:12px; font-weight:500; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.user-info .name { font-size:13px; font-weight:500; color:var(--color-text-primary); }
.user-info .role { font-size:11px; color:var(--color-text-secondary); }
.main-content { flex:1; overflow:hidden; display:flex; flex-direction:column; min-width:0; }
.content-header { background:var(--color-background-primary); border-bottom:0.5px solid var(--color-border-tertiary); padding:12px 20px; display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.content-header h1 { font-size:18px; font-weight:500; color:var(--color-text-primary); }
.header-actions { display:flex; gap:8px; align-items:center; }
.content-body { flex:1; padding:20px; overflow-y:auto; background:var(--color-background-tertiary); }
.btn { padding:8px 16px; border-radius:var(--border-radius-md); font-size:13px; cursor:pointer; border:0.5px solid var(--color-border-secondary); background:var(--color-background-primary); color:var(--color-text-primary); font-family:inherit; transition:background .12s; }
.btn:hover { background:var(--color-background-secondary); }
.btn-primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover { background:#0052CC; border-color:#0052CC; }
.btn-ghost { border:none; background:none; color:var(--color-text-secondary); cursor:pointer; padding:6px 8px; border-radius:var(--border-radius-md); display:flex; align-items:center; gap:4px; font-size:13px; font-family:inherit; }
.btn-ghost:hover { color:var(--color-text-primary); background:var(--color-background-secondary); }
.screen { display:none; flex-direction:column; height:100%; }
.screen.active { display:flex; }
.tag { display:inline-flex; align-items:center; padding:2px 8px; border-radius:10px; font-size:11px; font-weight:500; margin:1px 2px 1px 0; white-space:nowrap; }
.tag-blue { background:#E6F1FB; color:#185FA5; }
.tag-mach { background:var(--accent-50); color:var(--accent-700); }
.tag-emp { background:#F1EFE8; color:#444441; }
.tag-green { background:#EAF3DE; color:#3B6D11; }
.tag-amber { background:#FAEEDA; color:#854F0B; }
.tag-gray { background:var(--color-background-secondary); color:var(--color-text-secondary); }
.tag-site { color:var(--color-text-primary); font-weight:500; }
.tag-client { color:var(--color-text-secondary); font-size:12px; }
.more-tag { background:var(--color-background-secondary); color:var(--color-text-secondary); font-size:10px; padding:2px 6px; }
.filter-bar { display:flex; gap:8px; margin-bottom:16px; align-items:center; flex-wrap:wrap; row-gap:8px; }
.filter-bar .search-wrap { flex:1 1 160px; min-width:140px; margin-left:0; }
.filter-bar .search-wrap input { width:100%; }
.filter-chip { padding:6px 14px; border-radius:20px; font-size:12px; border:0.5px solid var(--color-border-tertiary); background:var(--color-background-primary); color:var(--color-text-secondary); cursor:pointer; }
.filter-chip.active { background:var(--accent-light); color:var(--accent); border-color:var(--accent); }
.table-card { background:var(--color-background-primary); border:0.5px solid var(--color-border-tertiary); border-radius:var(--border-radius-lg); overflow:hidden; }
.table-header { display:grid; padding:10px 16px; column-gap:12px; background:var(--color-background-secondary); border-bottom:0.5px solid var(--color-border-tertiary); font-size:11px; font-weight:500; color:var(--color-text-secondary); text-transform:uppercase; letter-spacing:0.04em; }
.table-row { display:grid; padding:13px 16px; column-gap:12px; border-bottom:0.5px solid var(--color-border-tertiary); font-size:13px; color:var(--color-text-primary); align-items:center; cursor:pointer; transition:background 0.1s; }
.table-row:last-child { border-bottom:none; }
.table-row:hover { background:var(--color-background-secondary); }
.table-row.selected { background:var(--accent-50); }
.secondary { color:var(--color-text-secondary); font-size:12px; }
.dot-menu { width:28px; height:28px; border-radius:var(--border-radius-md); border:none; background:none; color:var(--color-text-secondary); cursor:pointer; display:flex; align-items:center; justify-content:center; }
.dot-menu:hover { background:var(--color-background-secondary); }
.summary-bar { display:flex; gap:10px; margin-bottom:16px; }
.scard { background:var(--color-background-primary); border:0.5px solid var(--color-border-tertiary); border-radius:var(--border-radius-md); padding:12px 16px; flex:1; }
.scard-label { font-size:11px; color:var(--color-text-secondary); margin-bottom:4px; }
.scard-val { font-size:22px; font-weight:500; color:var(--color-text-primary); }
.scard-sub { font-size:11px; color:var(--color-text-secondary); margin-top:2px; }
.pager { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-top:0.5px solid var(--color-border-tertiary); background:var(--color-background-primary); font-size:12px; color:var(--color-text-secondary); }
.pager-btns { display:flex; gap:4px; }
.pager-btn { padding:4px 10px; border-radius:var(--border-radius-md); border:0.5px solid var(--color-border-tertiary); background:var(--color-background-primary); font-size:12px; cursor:pointer; color:var(--color-text-secondary); }
.pager-btn.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.search-wrap { position:relative; }
.search-wrap input { padding:7px 12px 7px 32px; border-radius:20px; border:0.5px solid var(--color-border-secondary); background:var(--color-background-primary); font-size:13px; color:var(--color-text-primary); font-family:inherit; width:180px; }
.search-wrap input:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,102,255,.1); }
.search-icon { position:absolute; left:10px; top:50%; transform:translateY(-50%); width:14px; height:14px; color:var(--color-text-secondary); pointer-events:none; }
.modal-overlay { background:rgba(0,0,0,0.35); display:flex; align-items:flex-start; justify-content:center; padding:24px 16px 32px; flex:1; overflow-y:auto; }
.modal { background:var(--color-background-primary); border-radius:var(--border-radius-xl); border:0.5px solid var(--color-border-tertiary); width:100%; max-width:720px; overflow:hidden; flex-shrink:0; }
.modal-header { padding:18px 24px 14px; border-bottom:0.5px solid var(--color-border-tertiary); display:flex; align-items:flex-start; justify-content:space-between; }
.modal-header h2 { font-size:17px; font-weight:500; line-height:1.3; }
.modal-subtitle { font-size:12px; color:var(--color-text-secondary); margin-top:3px; }
.modal-body { padding:20px 24px; display:flex; flex-direction:column; gap:18px; }
.modal-footer { padding:14px 24px; border-top:0.5px solid var(--color-border-tertiary); display:flex; align-items:center; justify-content:space-between; background:var(--color-background-secondary); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:16px; }
.field { display:flex; flex-direction:column; gap:6px; min-width:0; }
.field label { font-size:12px; font-weight:500; color:var(--color-text-secondary); letter-spacing:.03em; }
.req { color:#E24B4A; margin-left:2px; }
.field input,.field select,.field textarea { padding:9px 12px; border-radius:var(--border-radius-md); border:0.5px solid var(--color-border-secondary); background:var(--color-background-primary); font-size:14px; color:var(--color-text-primary); font-family:inherit; width:100%; transition:border-color .12s,box-shadow .12s; }
.field input:focus,.field select:focus,.field textarea:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,102,255,.1); }
.field textarea { resize:vertical; min-height:68px; line-height:1.6; }
.multisel { position:relative; border:1px solid var(--color-border-secondary); border-radius:var(--border-radius-md); background:var(--color-background-primary); padding:6px 36px 6px 8px; display:flex; flex-wrap:wrap; gap:5px; min-height:44px; cursor:text; transition:border-color .12s,box-shadow .12s; align-items:center; }
.multisel:focus-within { border-color:var(--accent); box-shadow:0 0 0 3px rgba(0,102,255,.1); }
.multisel::after { content:''; position:absolute; right:12px; top:50%; transform:translateY(-50%); width:0; height:0; border-left:4px solid transparent; border-right:4px solid transparent; border-top:5px solid var(--color-text-secondary); pointer-events:none; }
.sel-tag { display:inline-flex; align-items:center; gap:4px; padding:3px 4px 3px 10px; border-radius:20px; border:1px solid var(--color-border-secondary); background:var(--color-background-secondary); font-size:12px; font-weight:500; white-space:nowrap; }
.sel-tag-mach { color:var(--accent-700); border-color:var(--accent-200,#b3ceff); background:#EBF0FF; }
.sel-tag-emp { color:#444441; background:#F1EFE8; border-color:#D6D2C7; }
.sel-tag-x { display:inline-flex; align-items:center; justify-content:center; width:16px; height:16px; border-radius:50%; border:none; background:var(--color-border-secondary); cursor:pointer; font-size:10px; line-height:1; padding:0; color:var(--color-text-secondary); flex-shrink:0; }
.sel-tag-x:hover { background:var(--color-text-secondary); color:var(--color-background-primary); }
.sel-ghost { border:none; background:none; font-size:13px; color:var(--color-text-secondary); font-family:inherit; outline:none; flex:1; min-width:80px; padding:3px 4px; }
.dropdown { position:relative; border:1px solid var(--color-border-secondary); border-radius:var(--border-radius-md); background:var(--color-background-primary); overflow:hidden; margin-top:4px; box-shadow:0 4px 16px rgba(0,0,0,.10); z-index:20; }
.dd-item { padding:10px 14px; font-size:13px; cursor:pointer; display:flex; align-items:center; gap:10px; border-bottom:0.5px solid var(--color-border-tertiary); }
.dd-item:last-child { border-bottom:none; }
.dd-item:hover { background:var(--color-background-secondary); }
.dd-item.picked,.dd-item.is-picked { background:var(--accent-50); color:var(--accent-700); }
.dd-check { width:16px; height:16px; border-radius:4px; border:1.5px solid var(--color-border-secondary); display:flex; align-items:center; justify-content:center; flex-shrink:0; background:var(--color-background-primary); }
.dd-check.on { background:var(--accent); border-color:var(--accent); }
.dd-item-info { display:flex; flex-direction:column; }
.dd-item-main { font-size:13px; color:var(--color-text-primary); }
.dd-item-sub { font-size:11px; color:var(--color-text-secondary); margin-top:1px; }
.dd-badge { margin-left:auto; font-size:10px; font-weight:500; padding:2px 8px; border-radius:10px; white-space:nowrap; }
.badge-warn { background:#FAEEDA; color:#633806; }
.badge-ok { background:#EAF3DE; color:#27500A; }
.badge-err { background:#FCEBEB; color:#791F1F; }
.section-label { font-size:11px; font-weight:500; color:var(--color-text-secondary); letter-spacing:.05em; margin-bottom:12px; text-transform:uppercase; }
.sep { height:0.5px; background:var(--color-border-tertiary); margin:0 -24px; }
.type-toggle { display:flex; border:0.5px solid var(--color-border-secondary); border-radius:var(--border-radius-md); overflow:hidden; background:var(--color-background-secondary); }
.type-btn { flex:1; padding:10px 0; font-size:14px; border:none; background:none; cursor:pointer; font-family:inherit; color:var(--color-text-secondary); transition:background .12s,color .12s; }
.type-btn.active-hosho { background:#FAEEDA; color:#633806; font-weight:500; }
.type-btn.active-hoshu { background:#FCEBEB; color:#791F1F; font-weight:500; }
.type-btn:not(.active-hosho):not(.active-hoshu):hover { background:var(--color-background-primary); }
.type-divider { width:0.5px; background:var(--color-border-tertiary); flex-shrink:0; }
.amount-row { display:grid; grid-template-columns:1fr auto 1fr; gap:12px; align-items:end; }
.amount-hint { font-size:12px; color:var(--color-text-secondary); margin-top:5px; }
.preview-bar { background:var(--color-background-secondary); border:0.5px solid var(--color-border-tertiary); border-radius:var(--border-radius-md); padding:14px 18px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.preview-item { display:flex; flex-direction:column; gap:2px; }
.preview-label { font-size:11px; color:var(--color-text-secondary); }
.preview-value { font-size:15px; font-weight:500; color:var(--color-text-primary); }
.preview-divider { width:0.5px; height:32px; background:var(--color-border-tertiary); flex-shrink:0; }
.preview-total { margin-left:auto; text-align:right; }
.preview-total-label { font-size:11px; color:var(--color-text-secondary); }
.preview-total-value { font-size:20px; font-weight:500; color:var(--accent); }
.hint-box { border-radius:var(--border-radius-md); padding:10px 14px; font-size:12px; display:flex; align-items:flex-start; gap:8px; line-height:1.5; }
.hint-icon { width:14px; height:14px; flex-shrink:0; margin-top:1px; }
.section-title { font-size:14px; font-weight:500; color:var(--color-text-primary); margin-bottom:12px; }
.export-check { width:18px; height:18px; border-radius:4px; border:1.5px solid var(--color-border-secondary); display:flex; align-items:center; justify-content:center; background:var(--color-background-primary); cursor:pointer; flex-shrink:0; }
.export-check.on { background:var(--accent); border-color:var(--accent); }
.file-btn { flex:1; padding:10px 0; border-radius:var(--border-radius-md); border:0.5px solid var(--color-border-secondary); background:var(--color-background-primary); font-size:13px; cursor:pointer; font-family:inherit; color:var(--color-text-secondary); transition:background .12s; }
.file-btn.on { background:#E6F1FB; color:#185FA5; border-color:#B5D4F4; font-weight:500; }.profile-menu-item:hover { background:var(--color-background-secondary) !important; color:var(--color-text-primary) !important; }
.lang-btn { padding:7px 4px; border-radius:var(--border-radius-md); border:0.5px solid var(--color-border-tertiary); background:none; cursor:pointer; font-size:11px; color:var(--color-text-secondary); font-family:inherit; transition:background .12s; }
.lang-btn:hover { background:var(--color-background-secondary); }
.lang-btn.active { background:var(--accent-50); color:var(--accent-700); border-color:var(--accent-100); font-weight:500; }
.color-mode-btn {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:7px 4px; border-radius:var(--border-radius-md); border:0.5px solid var(--color-border-tertiary);
  background:none; cursor:pointer; font-size:10px; color:var(--color-text-secondary); font-family:inherit;
  transition:background .12s, color .12s, border-color .12s; width:100%;
}
.color-mode-btn:hover { background:var(--color-background-secondary); color:var(--color-text-primary); }
.color-mode-btn.active { background:var(--accent-50); color:var(--accent-700); border-color:var(--accent-100); font-weight:500; }



/* ── Employee clock-in (phone-style, centered in content pane) ── */
.emp-ci-wrap {
  flex: 1;
  overflow-y: auto;
  background: var(--color-background-tertiary);
  display: flex;
  justify-content: center;
  padding: 24px 20px 40px;
}
.emp-ci-state {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  max-width: 420px;
}
.emp-ci-user-card {
  background: var(--color-background-primary);
  border-radius: 16px;
  border: 0.5px solid var(--color-border-tertiary);
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.emp-ci-avatar {
  width: 50px; height: 50px;
  border-radius: 50%;
  background: var(--accent-50);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 500; color: var(--accent-800);
  flex-shrink: 0;
}
.emp-ci-name { font-size: 17px; font-weight: 500; }
.emp-ci-meta { font-size: 12px; color: var(--color-text-secondary); margin-top: 2px; }
.emp-ci-status-tag { font-size: 12px; font-weight: 500; margin-top: 3px; color: var(--color-text-secondary); }
.emp-ci-clock-card {
  background: var(--color-background-primary);
  border-radius: 16px;
  border: 0.5px solid var(--color-border-tertiary);
  padding: 24px;
  text-align: center;
}
.emp-ci-big-clock {
  font-size: 52px; font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: -2px;
  color: var(--color-text-primary);
}
.emp-ci-date { font-size: 14px; color: var(--color-text-secondary); margin-top: 6px; }
.emp-ci-status-strip {
  background: var(--color-background-primary);
  border-radius: 14px;
  border: 0.5px solid var(--color-border-tertiary);
  padding: 14px 16px;
  display: flex; align-items: center; gap: 12px;
}
.emp-ci-strip-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.dot-in { background: #3B6D11; }
.dot-out { background: #A32D2D; }
.emp-ci-strip-time { font-size: 15px; font-weight: 500; font-variant-numeric: tabular-nums; }
.emp-ci-action-btn {
  border-radius: 16px; border: none; padding: 20px 12px;
  cursor: pointer; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 10px;
  transition: opacity .1s;
}
.emp-ci-action-btn:active { opacity: .85; }
.emp-ci-btn-in { background: #EAF3DE; }
.emp-ci-btn-out { background: #FCEBEB; }
.emp-ci-action-icon {
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.emp-ci-log-card {
  background: var(--color-background-primary);
  border-radius: 14px;
  border: 0.5px solid var(--color-border-tertiary);
  overflow: hidden;
}
.emp-ci-log-row {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  border-bottom: 0.5px solid var(--color-border-tertiary);
}
.emp-ci-log-row:last-child { border-bottom: none; }
.emp-ci-log-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.emp-ci-confirm-time {
  font-size: 44px; font-weight: 500;
  font-variant-numeric: tabular-nums; letter-spacing: -1px;
  margin-bottom: 4px;
}
.emp-ci-main-btn {
  width: 100%; padding: 20px 0;
  border-radius: 14px; border: none;
  font-size: 17px; font-weight: 500; cursor: pointer; font-family: inherit;
  transition: opacity .12s;
  background: #27500A; color: #EAF3DE;
}
.emp-ci-main-btn:active { opacity: .88; }
.emp-ci-cancel-btn {
  width: 100%; padding: 14px 0;
  border-radius: 14px; border: none;
  background: var(--color-background-secondary);
  color: var(--color-text-secondary);
  font-size: 15px; cursor: pointer; font-family: inherit;
}
.emp-ci-success-icon {
  width: 80px; height: 80px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.emp-ci-success-pill {
  padding: 10px 24px; border-radius: 24px;
  font-size: 20px; font-weight: 500; font-variant-numeric: tabular-nums;
}


/* ── Delete confirmation modal ── */
.del-modal-bg { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.45); z-index:100; align-items:center; justify-content:center; }
.del-modal-bg.show { display:flex; }
.del-modal { background:var(--color-background-primary); border-radius:var(--border-radius-xl); border:0.5px solid var(--color-border-tertiary); width:360px; padding:28px 28px 24px; display:flex; flex-direction:column; gap:16px; box-shadow:0 20px 60px rgba(0,0,0,0.18); }
.del-modal-icon { width:44px; height:44px; border-radius:50%; background:#FCEBEB; display:flex; align-items:center; justify-content:center; }
.del-modal h3 { font-size:16px; font-weight:500; color:var(--color-text-primary); }
.del-modal p { font-size:13px; color:var(--color-text-secondary); line-height:1.6; margin-top:-8px; }
.del-modal-actions { display:flex; gap:8px; justify-content:flex-end; margin-top:4px; }

/* ── Dark mode colour overrides ── */
[data-color-mode="dark"] .tag-blue  { background:#0d3566; color:#85B7EB; }
[data-color-mode="dark"] .tag-green { background:#1a3d1a; color:#7BC67E; }
[data-color-mode="dark"] .tag-amber { background:#3d2e0d; color:#F0B55A; }
[data-color-mode="dark"] .tag-gray  { background:#38383a; color:#aaaaaa; }
[data-color-mode="dark"] .tag-mach  { background:#0c2a52; color:#85B7EB; }
[data-color-mode="dark"] .tag-emp   { background:#2e2e28; color:#c8c8b8; }

/* Table headers need stronger contrast in dark */
[data-color-mode="dark"] .table-header { background:#38383a; color:#bbbbbb; }
[data-color-mode="dark"] .table-card   { border-color:rgba(255,255,255,0.14); color:var(--color-text-primary); }
[data-color-mode="dark"] .table-row:hover { background:#2a2a2c; }

/* KPI delta colours */
[data-color-mode="dark"] .delta-up { color:#7BC67E; }
[data-color-mode="dark"] .delta-dn { color:#F07070; }

/* Export / green buttons */
[data-color-mode="dark"] .btn-export,
[data-color-mode="dark"] [style*="background:#EAF3DE"] {
  background:#1a3d1a !important; color:#7BC67E !important; border-color:#2d6b2d !important;
}

/* Sidebar & card backgrounds need more depth */
[data-color-mode="dark"] .sidebar        { background:#141416; border-right-color:rgba(255,255,255,0.1); }
[data-color-mode="dark"] .content-header { background:#141416; border-bottom-color:rgba(255,255,255,0.1); }
[data-color-mode="dark"] .table-card,
[data-color-mode="dark"] .card,
[data-color-mode="dark"] .ci-ipad-card   { background:#1e1e20; }
[data-color-mode="dark"] .scard          { background:#1e1e20; border-color:rgba(255,255,255,0.1); }
[data-color-mode="dark"] .filter-chip    { background:#1e1e20; border-color:rgba(255,255,255,0.14); }
[data-color-mode="dark"] .filter-chip.active { background:#0c2a52; border-color:#1a4a8a; }

/* Dashboard KPI cards */
[data-color-mode="dark"] .dash-grid > div,
[data-color-mode="dark"] [style*="background:var(--color-background-secondary)"][style*="border-radius:8px"] {
  background:#252528 !important;
}

/* Preview bar in maintenance form */
[data-color-mode="dark"] .preview-bar { background:#252528; }

/* Type toggle */
[data-color-mode="dark"] .type-toggle { background:#252528; }

/* Badge colours */
[data-color-mode="dark"] .badge-ok   { background:#1a3d1a; color:#7BC67E; }
[data-color-mode="dark"] .badge-warn { background:#3d2e0d; color:#F0B55A; }
[data-color-mode="dark"] .badge-err  { background:#3d1a1a; color:#F07070; }

/* Delete modal */
[data-color-mode="dark"] .del-modal  { background:#1e1e20; border-color:rgba(255,255,255,0.14); }
[data-color-mode="dark"] .del-modal-icon { background:#3d1a1a; }

/* perm-tag variants */
[data-color-mode="dark"] .perm-m   { background:#1a3d1a; color:#7BC67E; }
[data-color-mode="dark"] .perm-ms  { background:#3d2e0d; color:#F0B55A; }
[data-color-mode="dark"] .perm-msa { background:#0d3530; color:#4ec9b0; }
[data-color-mode="dark"] .perm-it  { background:#3d1a1a; color:#F07070; }

/* also apply same overrides for @media auto dark — skipped when light mode is forced */
@media (prefers-color-scheme: dark) {
  :root:not([data-color-mode="light"]) .tag-blue  { background:#0d3566; color:#85B7EB; }
  :root:not([data-color-mode="light"]) .tag-green { background:#1a3d1a; color:#7BC67E; }
  :root:not([data-color-mode="light"]) .tag-amber { background:#3d2e0d; color:#F0B55A; }
  :root:not([data-color-mode="light"]) .tag-gray  { background:#38383a; color:#aaaaaa; }
  :root:not([data-color-mode="light"]) .tag-mach  { background:#0c2a52; color:#85B7EB; }
  :root:not([data-color-mode="light"]) .tag-emp   { background:#2e2e28; color:#c8c8b8; }
  :root:not([data-color-mode="light"]) .table-header { background:#38383a; color:#bbbbbb; }
  :root:not([data-color-mode="light"]) .table-card { border-color:rgba(255,255,255,0.14); color:var(--color-text-primary); }
  :root:not([data-color-mode="light"]) .delta-up { color:#7BC67E; }
  :root:not([data-color-mode="light"]) .delta-dn { color:#F07070; }
  :root:not([data-color-mode="light"]) .sidebar { background:#141416; border-right-color:rgba(255,255,255,0.1); }
  :root:not([data-color-mode="light"]) .content-header { background:#141416; border-bottom-color:rgba(255,255,255,0.1); }
  :root:not([data-color-mode="light"]) .table-card,
  :root:not([data-color-mode="light"]) .scard { background:#1e1e20; }
  :root:not([data-color-mode="light"]) .filter-chip { background:#1e1e20; }
  :root:not([data-color-mode="light"]) .filter-chip.active { background:#0c2a52; border-color:#1a4a8a; }
  :root:not([data-color-mode="light"]) .badge-ok   { background:#1a3d1a; color:#7BC67E; }
  :root:not([data-color-mode="light"]) .badge-warn { background:#3d2e0d; color:#F0B55A; }
  :root:not([data-color-mode="light"]) .badge-err  { background:#3d1a1a; color:#F07070; }
  :root:not([data-color-mode="light"]) .del-modal  { background:#1e1e20; }
  :root:not([data-color-mode="light"]) .perm-m   { background:#1a3d1a; color:#7BC67E; }
  :root:not([data-color-mode="light"]) .perm-ms  { background:#3d2e0d; color:#F0B55A; }
  :root:not([data-color-mode="light"]) .perm-it  { background:#3d1a1a; color:#F07070; }
}

/* ── Dashboard classes (replaces inline styles for dark-mode compatibility) ── */
.kpi-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:12px; margin-bottom:20px; }
.kpi-card { background:var(--color-background-primary); border-radius:var(--border-radius-md); padding:14px 16px; border:0.5px solid var(--color-border-tertiary); }
.kpi-label { font-size:11px; color:var(--color-text-secondary); margin-bottom:6px; }
.kpi-value { font-size:24px; font-weight:500; color:var(--color-text-primary); }
.kpi-sub   { font-size:11px; color:var(--color-text-secondary); margin-top:3px; }
.kpi-delta { font-size:11px; font-weight:500; margin-top:4px; color:var(--color-text-secondary); }
.delta-up  { color:#3B6D11; }
.delta-dn  { color:#A32D2D; }
.dash-card-header { padding:12px 16px 10px; display:flex; align-items:center; justify-content:space-between; border-bottom:0.5px solid var(--color-border-tertiary); }
.dash-card-title  { font-size:13px; font-weight:500; color:var(--color-text-primary); }
.dash-card-sub    { font-size:12px; color:var(--color-text-secondary); }
.dash-table-head  { display:flex; align-items:center; padding:8px 16px; gap:10px; font-size:11px; font-weight:500; color:var(--color-text-secondary); letter-spacing:.04em; background:var(--color-background-secondary); border-bottom:0.5px solid var(--color-border-tertiary); }
.dash-total-row   { padding:9px 16px; border-top:0.5px solid var(--color-border-tertiary); display:flex; align-items:center; justify-content:space-between; }
.dash-total-value { font-size:14px; font-weight:500; color:var(--color-text-primary); }

/* Dark mode dashboard overrides */
[data-color-mode="dark"] .kpi-card  { background:#1e1e20; border-color:rgba(255,255,255,0.1); }
[data-color-mode="dark"] .kpi-value { color:#f0f0f0; }
[data-color-mode="dark"] .delta-up  { color:#7BC67E; }
[data-color-mode="dark"] .delta-dn  { color:#F07070; }
[data-color-mode="dark"] .dash-card-title  { color:#f0f0f0; }
[data-color-mode="dark"] .dash-table-head  { background:#2a2a2d; color:#aaaaaa; border-bottom-color:rgba(255,255,255,0.12); }
[data-color-mode="dark"] .dash-total-value { color:#f0f0f0; }

@media (prefers-color-scheme: dark) {
  :root:not([data-color-mode="light"]) .kpi-card  { background:#1e1e20; border-color:rgba(255,255,255,0.1); }
  :root:not([data-color-mode="light"]) .kpi-value { color:#f0f0f0; }
  :root:not([data-color-mode="light"]) .delta-up  { color:#7BC67E; }
  :root:not([data-color-mode="light"]) .delta-dn  { color:#F07070; }
  :root:not([data-color-mode="light"]) .dash-card-title  { color:#f0f0f0; }
  :root:not([data-color-mode="light"]) .dash-table-head  { background:#2a2a2d; color:#aaaaaa; }
  :root:not([data-color-mode="light"]) .dash-total-value { color:#f0f0f0; }
}

.dash-data-row { display:flex; align-items:center; padding:10px 16px; border-bottom:0.5px solid var(--color-border-tertiary); gap:10px; font-size:13px; color:var(--color-text-primary); }
.dash-data-row:last-child { border-bottom:none; }
.dash-sub-text { font-size:12px; color:var(--color-text-secondary); }
.dash-days-val { width:44px; text-align:right; font-weight:500; color:var(--color-text-primary); }
.dash-center   { text-align:center; }
.dash-right    { text-align:right; }
.dash-diff     { text-align:center; font-weight:500; }
.dash-bar-wrap { flex:1; height:6px; background:var(--color-background-secondary); border-radius:3px; overflow:hidden; min-width:40px; }
.dash-bar-fill { height:100%; background:var(--accent); border-radius:3px; }
[data-color-mode="dark"] .dash-data-row { color:#e8e8e8; border-bottom-color:rgba(255,255,255,0.08); }
[data-color-mode="dark"] .dash-days-val { color:#e8e8e8; }
[data-color-mode="dark"] .dash-bar-wrap { background:#38383a; }
@media (prefers-color-scheme: dark) {
  :root:not([data-color-mode="light"]) .dash-data-row { color:#e8e8e8; border-bottom-color:rgba(255,255,255,0.08); }
  :root:not([data-color-mode="light"]) .dash-days-val { color:#e8e8e8; }
  :root:not([data-color-mode="light"]) .dash-bar-wrap { background:#38383a; }
}
.tag-repair { background:#FCEBEB; color:#A32D2D; }
[data-color-mode="dark"] .tag-repair { background:#3d1a1a; color:#F07070; }
@media (prefers-color-scheme: dark) { :root:not([data-color-mode="light"]) .tag-repair { background:#3d1a1a; color:#F07070; } }

#toast { display:none; position:fixed; bottom:24px; left:50%; transform:translateX(-50%); background:#27500A; color:#EAF3DE; padding:10px 20px; border-radius:10px; font-size:13px; font-weight:500; white-space:nowrap; z-index:999; }
.toggle-switch { width:36px; height:20px; background:var(--color-border-secondary); border-radius:10px; position:relative; cursor:pointer; transition:background .2s; border:none; padding:0; flex-shrink:0; }
.toggle-switch.on { background:var(--accent); }
.toggle-knob { position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:#fff; transition:transform .2s; }
.toggle-switch.on .toggle-knob { transform:translateX(16px); }

/* ── Clock-in iPad layout ── */
.clockin-ipad { display:flex; gap:20px; height:100%; }
.clockin-left { width:320px; flex-shrink:0; display:flex; flex-direction:column; gap:14px; padding:20px; background:var(--color-background-tertiary); overflow-y:auto; }
.clockin-right { flex:1; padding:20px 20px 20px 0; display:flex; flex-direction:column; gap:14px; background:var(--color-background-tertiary); overflow-y:auto; }
.ci-ipad-card { background:var(--color-background-primary); border:0.5px solid var(--color-border-tertiary); border-radius:var(--border-radius-lg); padding:16px; }
.ci-ipad-user { display:flex; align-items:center; gap:12px; }
.ci-ipad-avatar { width:44px; height:44px; border-radius:50%; background:#E6F1FB; display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:500; color:#0C447C; flex-shrink:0; }
.ci-ipad-time { text-align:center; padding:20px 16px; }
.ci-ipad-clock { font-size:44px; font-weight:500; font-variant-numeric:tabular-nums; letter-spacing:-2px; }
.ci-ipad-date { font-size:13px; color:var(--color-text-secondary); margin-top:4px; }
.ci-ipad-btns { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.ci-ipad-btn { border-radius:12px; border:none; padding:16px 8px; cursor:pointer; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; }
.ci-ipad-btn:active { opacity:.85; }
.ci-ipad-btn-icon { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.ci-ipad-btn-in { background:#EAF3DE; }
.ci-ipad-btn-in .ci-ipad-btn-icon { background:#C0DD97; }
.ci-ipad-btn-out { background:#FCEBEB; }
.ci-ipad-btn-out .ci-ipad-btn-icon { background:#F09595; }

/* ── Confirm overlay (iPad inline) ── */
.ci-confirm-overlay { position:absolute; inset:0; background:rgba(0,0,0,0.4); display:none; align-items:flex-end; z-index:10; border-radius:var(--border-radius-lg); }
.ci-confirm-sheet { background:var(--color-background-primary); border-radius:20px 20px 0 0; width:100%; padding:22px 24px 36px; display:flex; flex-direction:column; gap:14px; }

/* ════════════════════════════════════════════════
   RESPONSIVE LAYOUT — Field Management System
   Mobile-first: base = iPhone (<768px)
   Tablet: 768px+ (iPad — existing design)
   Desktop: 1280px+ (wider, no device frame)
   ════════════════════════════════════════════════ */

/* ── MOBILE BASE (<768px) ── */
@media (max-width: 767px) {
  /* Remove desktop body padding / centering */
  body { padding:0; align-items:stretch; }

  /* Login card full-width */
  .login-card { width:100%; max-width:100%; border-radius:0; border:none; min-height:100vh; justify-content:center; padding:40px 24px; }

  /* Hide device-frame decoration on mobile */
  .device-frame { border-radius:0; border:none; max-width:100%; }

  /* App frame: fill screen */
  #app-frame { width:100%; }

  /* Status bar: smaller, no role-switcher area */
  .status-bar { padding:8px 16px; position:sticky; top:0; z-index:50; }

  /* Hide sidebar entirely on mobile — replaced by bottom nav */
  .sidebar { display:none; }

  /* Main content fills full width */
  .main-content { width:100%; }

  /* App body: no sidebar, fill height — use svh so Safari chrome doesn't shift layout */
  .app-body { height:calc(100svh - 44px - 56px); /* statusbar + bottom-nav */ }

  /* Content header: compact + sticky so Save button stays visible while scrolling */
  .content-header { padding:10px 16px; flex-wrap:wrap; gap:8px; position:sticky; top:0; z-index:40; }
  .content-header h1 { font-size:16px; }
  .header-actions { gap:6px; }
  .header-actions .btn { padding:6px 10px; font-size:12px; }

  /* Content body: tighter padding */
  .content-body { padding:12px 16px; }

  /* Summary cards: 2-col grid on mobile */
  .summary-bar { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
  .scard { padding:10px 12px; }
  .scard-val { font-size:18px; }

  /* Filter bar: horizontal scroll */
  .filter-bar { flex-wrap:nowrap; overflow-x:auto; padding-bottom:4px; -webkit-overflow-scrolling:touch; }
  .filter-bar::-webkit-scrollbar { display:none; }
  .filter-chip { flex-shrink:0; padding:5px 12px; font-size:12px; }
  .search-wrap { margin-left:0; width:100%; }
  .search-wrap input { width:100%; }

  /* Tables: simplify with horizontal scroll */
  .table-card { overflow-x:auto; }
  .table-header, .table-row {
    min-width:480px; /* force scroll on very narrow */
  }

  /* Worklog table: hide secondary columns on mobile */
  .wl-col-machinery, .wl-col-employee, .wl-col-item { display:none; }

  /* KPI grid: 2×2 on mobile */
  .kpi-grid { grid-template-columns:1fr 1fr; gap:8px; }
  .kpi-card { padding:12px; }
  .kpi-value { font-size:20px; }

  /* Dashboard 2-col grids → single col */
  #screen-dashboard .content-body > div[style*="grid-template-columns:1fr 1fr"] {
    display:flex !important; flex-direction:column !important; gap:12px !important;
  }

  /* Forms: single column */
  .form-row, .form-row-3 { grid-template-columns:1fr; }
  .modal-overlay { padding:0; }
  .modal { border-radius:0; max-width:100%; min-height:100vh; }
  .modal-header { padding:14px 16px 10px; }
  .modal-body { padding:16px; gap:14px; }
  .modal-footer { padding:12px 16px; }

  /* Clock-in iPad layout → single column */
  .clockin-ipad { flex-direction:column; }
  .clockin-left { width:100%; padding:12px 16px; }
  .clockin-right { padding:0 16px 16px; }

  /* Employee clockin: full-screen natural */
  #screen-emp-clockin .content-body { padding:16px; }

  /* Maintenance form: compact amount row */
  .amount-row { grid-template-columns:1fr auto 100px; }

  /* Preview bar: wrap */
  .preview-bar { gap:10px; }
  .preview-total { margin-left:0; }

  /* Detail views: single column */
  #screen-worklog-detail .content-body > div[style*="grid-template-columns:1fr 1fr"],
  #screen-machinery-detail .content-body > div[style*="grid-template-columns:1fr 1fr"],
  #screen-employee-detail .content-body > div[style*="grid-template-columns:1fr 1fr"],
  #screen-client-detail .content-body > div[style*="grid-template-columns:1fr 1fr"] {
    display:flex !important; flex-direction:column !important; gap:12px !important;
  }

  /* Pager: compact */
  .pager { padding:10px 12px; font-size:11px; }
  .pager-btn { padding:4px 8px; }

  /* Delete modal */
  .del-modal { width:calc(100vw - 32px); }

  /* Export modal */
  #screen-export > div { padding:16px; }
  #screen-export > div > div { width:100%; }
}

/* ── BOTTOM TAB BAR (mobile only) ── */
#mobile-tab-bar {
  display:none;
}
@media (max-width: 767px) {
  body.logged-in #mobile-tab-bar {
    display:flex;
    position:fixed;
    bottom:0; left:0; right:0;
    height:56px;
    background:var(--color-background-primary);
    -webkit-backdrop-filter:none;
    border-top:0.5px solid var(--color-border-tertiary);
    z-index:200;
    align-items:stretch;
    padding-bottom:env(safe-area-inset-bottom);
    /* Prevent Safari rubber-band scroll from hiding the bar */
    transform:translateZ(0);
    -webkit-transform:translateZ(0);
  }
  .tab-bar-item {
    flex:1; display:flex; flex-direction:column; align-items:center;
    justify-content:center; gap:2px; cursor:pointer;
    color:var(--color-text-secondary); font-size:10px;
    border:none; background:none; font-family:inherit;
    padding:6px 4px; transition:color .12s;
  }
  .tab-bar-item svg { width:22px; height:22px; }
  .tab-bar-item.active { color:var(--accent); }
  .tab-bar-item .tab-label { font-size:10px; white-space:nowrap; }

  /* Hamburger → replaced by tab bar, hide it on mobile */
  #sidebarToggleBtn { display:none; }

  /* App body height accounts for bottom nav */
  .app-body { height:calc(100svh - 44px - 56px); }
}

/* ── Tablet portrait (768–900px): search on own row ── */
@media (min-width: 768px) and (max-width: 900px) {
  .filter-bar .search-wrap { flex:1 1 100%; margin-left:0; }
  .filter-bar .search-wrap input { width:100%; }
  /* Quote list portrait: hide 幣別 (col 5), show 6 cols */
  #screen-quote-list .table-header > span:nth-child(5),
  #screen-quote-list .table-row > span:nth-child(5) { display:none; }
  #screen-quote-list .table-header,
  #screen-quote-list .table-row {
    grid-template-columns: 110px 80px 88px 1fr 110px 80px !important;
  }
}
/* ── Tablet landscape+: search stays inline right-aligned ── */
@media (min-width: 901px) {
  .filter-bar .search-wrap { flex:0 0 auto; margin-left:auto; }
  .filter-bar .search-wrap input { width:180px; }
}

@media (min-width: 768px) and (max-width: 1279px) {
  body { padding:16px; }
  .device-frame { max-width:1024px; border-radius:var(--border-radius-lg); }
  .app-body { height:740px; }
}

/* ── DESKTOP ≥1280px ── */
@media (min-width: 1280px) {
  body { padding:0; align-items:stretch; }

  /* Remove device frame decoration — fill browser */
  .device-frame {
    max-width:100%; border-radius:0; border:none;
    height:100dvh; overflow:hidden;
  }

  /* Taller app body */
  .app-body { height:calc(100dvh - 44px); }

  /* Wider sidebar on desktop */
  :root { --sidebar-w: 240px; }

  /* Sidebar always visible — hide toggle button */
  #sidebarToggleBtn { display:none; }

  /* Content: wider padding */
  .content-body { padding:24px 32px; }
  .content-header { padding:14px 32px; }

  /* KPI grid: stay 4-col */
  .kpi-grid { grid-template-columns:repeat(4,1fr); }

  /* Summary bar: stay in a row */
  .summary-bar { display:flex; }

  /* Dashboard 2-col grids: larger on wide screen */
  #screen-dashboard .content-body {
    max-width:100%;
  }

  /* Wider column gap on desktop */
  .table-header, .table-row { column-gap:16px; }

  /* Worklog table: wider columns */
  .table-header[style*="88px 120px"],
  .table-row[style*="88px 120px"] {
    grid-template-columns: 100px 160px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 100px !important;
  }

  /* Forms: comfy 2-col */
  .form-row { gap:20px; }
  .modal { max-width:760px; }

  /* Login card: centred with max-width */
  #login-screen { background:var(--color-background-tertiary); }
  .login-card { max-width:400px; }

  /* Larger content-header title */
  .content-header h1 { font-size:20px; }
}

/* ── EXTRA WIDE ≥1600px ── */
@media (min-width: 1600px) {
  :root { --sidebar-w: 260px; }
  .content-body { padding:28px 40px; }
  .content-header { padding:16px 40px; }
}

/* Mobile more drawer */
.mob-drawer-item {
  display:flex; align-items:center; gap:12px;
  width:100%; padding:13px 20px;
  border:none; background:none; cursor:pointer;
  font-family:inherit; font-size:14px; color:var(--color-text-primary);
  text-align:left;
}
.mob-drawer-item:active { background:var(--color-background-secondary); }

/* ── Mobile status bar refinements ── */
@media (max-width: 767px) {
  /* Compact status bar */
  .status-bar { gap:8px; }
  .status-bar .app-title { font-size:14px; }
  .role-badge { display:none; } /* role shown in profile instead */

  /* Summary card labels smaller */
  .scard-label { font-size:10px; }
  .scard-sub { font-size:10px; }

  /* Table rows: smaller text, tighter padding, reduced gap */
  .table-row { padding:10px 12px; font-size:12px; column-gap:8px; }
  .table-header { padding:8px 12px; font-size:10px; column-gap:8px; }

  /* Hide less important columns in worklog on mobile */
  /* Targets grid cells by column position using nth child on rows */
  /* Instead: use column-hiding classes on specific screens */

  /* Filter chips: single-row horizontal scroll on mobile */
  .filter-bar {
    display:flex !important;
    flex-wrap:nowrap !important;
    overflow-x:auto;
    gap:6px;
    padding:0 0 8px;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
  }
  .filter-bar::-webkit-scrollbar { display:none; }
  .filter-chip {
    flex-shrink:0;
    scroll-snap-align:start;
    padding:6px 14px;
    font-size:12px;
    white-space:nowrap;
  }
  /* Search goes on its own row below chips */
  .filter-bar .search-wrap {
    display:none; /* hide inline search on mobile — use header search icon instead */
  }

  /* Maintenance form: amount row stack */
  .amount-row { grid-template-columns:1fr; gap:10px; }
  .amount-row > div:nth-child(2) { display:none; } /* hide + separator */

  /* Clockin iPad panels: stack */
  .clockin-left { width:100%; flex-shrink:1; }
  .ci-ipad-btns { grid-template-columns:1fr 1fr; }
  .ci-ipad-clock { font-size:36px; }

  /* KPI delta smaller */
  .kpi-delta { font-size:10px; }

  /* Dash card headers */
  .dash-card-header { padding:10px 12px 8px; }
  .dash-card-title { font-size:12px; }

  /* Nav breadcrumb in detail screens: truncate */
  .content-header > div:first-child { overflow:hidden; }
  .content-header .btn-ghost { flex-shrink:0; }

  /* Modal full screen on mobile */
  .modal-overlay { overflow-y:auto; -webkit-overflow-scrolling:touch; }

  /* Profile menu on mobile: position above avatar */
  #profileMenu { display:none !important; } /* profile accessed via tab bar more */

  /* Profile trigger: hide on mobile */
  .sidebar-bottom { display:none; }

  /* App body: remove overflow constraint that hides tap bar content */
  .main-content { overflow:hidden; }
  .screen.active { overflow-y:auto; }

  /* Lock login screen to mobile safe area */
  #login-screen { min-height:100dvh; padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom); }

  /* Pager: center on mobile */
  .pager { flex-direction:column; gap:8px; align-items:center; }
  .pager-btns { gap:4px; }

  /* Worklog table: hide columns 3,4,5 (machinery, employee, task) to show date+site+client */
  #screen-worklog-list .table-header > span:nth-child(3),
  #screen-worklog-list .table-header > span:nth-child(4),
  #screen-worklog-list .table-header > span:nth-child(5),
  #screen-worklog-list .table-row > span:nth-child(3),
  #screen-worklog-list .table-row > span:nth-child(4),
  #screen-worklog-list .table-row > span:nth-child(5) { display:none; }

  /* Clockin list: hide site column */
  #screen-clockin .table-header > span:nth-child(3),
  #screen-clockin .table-row > span:nth-child(3) { display:none; }

  /* Machinery list: hide model column */
  #screen-machinery .table-header > span:nth-child(3),
  #screen-machinery .table-row > span:nth-child(3) { display:none; }

  /* Employees list: hide hire/leave dates */
  #screen-employees .table-header > span:nth-child(3),
  #screen-employees .table-header > span:nth-child(4),
  #screen-employees .table-row > span:nth-child(3),
  #screen-employees .table-row > span:nth-child(4) { display:none; }

  /* Users list: hide last-login column */
  #screen-users .table-header > span:nth-child(3),
  #screen-users .table-row > span:nth-child(3) { display:none; }

  /* Clients list: hide tax ID + phone */
  #screen-clients .table-header > span:nth-child(3),
  #screen-clients .table-header > span:nth-child(5),
  #screen-clients .table-row > span:nth-child(3),
  #screen-clients .table-row > span:nth-child(5) { display:none; }

  /* Remove grid column constraints on mobile so cells reflow */
  #screen-worklog-list .table-header,
  #screen-worklog-list .table-row {
    grid-template-columns: 88px 1fr 80px 32px !important;
    min-width:0 !important;
  }
  #screen-clockin .table-header,
  #screen-clockin .table-row {
    grid-template-columns: 72px 1fr 100px 90px !important;
    min-width:0 !important;
  }
  #screen-machinery .table-header > span:nth-child(6),
  #screen-machinery .table-row > span:nth-child(6) { display:none; }
  #screen-machinery .table-header,
  #screen-machinery .table-row {
    grid-template-columns: 80px 80px 92px 92px !important;
    min-width:0 !important;
  }
  #screen-employees .table-header,
  #screen-employees .table-row {
    grid-template-columns: 70px 1fr 80px !important;
    min-width:0 !important;
  }
  #screen-users .table-header,
  #screen-users .table-row {
    grid-template-columns: 1fr 90px 70px !important;
    min-width:0 !important;
  }
  #screen-clients .table-header,
  #screen-clients .table-row {
    grid-template-columns: 72px 1fr 72px !important;
    min-width:0 !important;
  }
}

/* ── iPhone safe area padding ── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  @media (max-width: 767px) {
    #mobile-tab-bar { padding-bottom:calc(env(safe-area-inset-bottom) + 6px); height:calc(56px + env(safe-area-inset-bottom) + 6px); }
    .app-body { height:calc(100svh - 44px - 56px - env(safe-area-inset-bottom) - 6px); }
  }
}

/* ── Desktop: seamless full-browser look ── */
@media (min-width: 1280px) {
  body { background:var(--color-background-tertiary); }
  .device-frame { box-shadow:none; }
  .status-bar { border-bottom:0.5px solid var(--color-border-tertiary); }

  /* Sidebar: slightly deeper on desktop */
  .sidebar { background:var(--color-background-primary); }

  /* Worklog table: wider columns on desktop */
  #screen-worklog-list .table-header,
  #screen-worklog-list .table-row {
    grid-template-columns:100px 160px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 100px !important;
  }

  /* Maintenance table: wider on desktop */
  #screen-maintenance-list .table-header,
  #screen-maintenance-list .table-row {
    grid-template-columns:100px 96px 110px 1fr 130px !important;
  }
}

/* ── Mobile profile button in topbar ── */
#mob-profile-btn {
  display:none;
  margin-left:auto;
  width:32px; height:32px;
  border-radius:50%;
  background:var(--accent-50); color:var(--accent-700);
  border:none; cursor:pointer;
  font-size:12px; font-weight:500; font-family:inherit;
  align-items:center; justify-content:center;
  flex-shrink:0;
}
@media (max-width: 767px) {
  #mob-profile-btn { display:flex !important; }
  .role-badge { display:none; }
}
@media (min-width: 768px) {
  #mob-profile-btn { display:none !important; }
}

/* ── List search bar ── */
.list-search-bar { padding:0 0 12px; }
.list-search-bar .search-wrap { position:relative; display:inline-block; width:100%; }
.list-search-bar .search-wrap input {
  width:100%; max-width:320px; box-sizing:border-box;
  padding:8px 12px 8px 32px;
  border:0.5px solid var(--color-border-secondary);
  border-radius:var(--border-radius-md);
  background:var(--color-background-primary);
  color:var(--color-text-primary);
  font-size:13px; font-family:inherit;
  outline:none;
  transition:border-color .15s;
}
.list-search-bar .search-wrap input:focus {
  border-color:var(--accent);
}
@media (max-width: 767px) {
  .list-search-bar .search-wrap input { max-width:100%; }
}

/* Rows hidden by pagination */
.table-row[data-paged="hide"] { display:none !important; }

/* ── Export format modal buttons ── */
.expfmt-btn {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:14px 10px;
  border:1.5px solid var(--color-border-secondary);
  border-radius:var(--border-radius-md);
  background:var(--color-background-primary);
  color:var(--color-text-secondary);
  cursor:pointer; font-family:inherit;
  transition:border-color .12s, background .12s, color .12s;
  text-align:center;
}
.expfmt-btn:hover { border-color:var(--accent); color:var(--color-text-primary); }
.expfmt-btn.active {
  border-color:var(--accent);
  background:var(--accent-50);
  color:var(--accent-700);
}
[data-color-mode="dark"] .expfmt-btn.active { background:var(--accent-50); color:var(--accent-700); }
@media (prefers-color-scheme: dark) { .expfmt-btn.active { background:var(--accent-50); color:var(--accent-700); } }

/* ════════════════════════════════════════
   QUOTE / 報價單  CSS
   ════════════════════════════════════════ */

/* ── Status stepper ── */
.quote-stepper {
  display:flex; align-items:center; gap:0;
}
.qs-step {
  display:flex; flex-direction:column; align-items:center; gap:4px; flex-shrink:0;
}
.qs-dot {
  width:28px; height:28px; border-radius:50%;
  background:var(--color-background-secondary);
  border:2px solid var(--color-border-secondary);
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
}
.qs-dot-blue  { background:var(--accent)!important; border-color:var(--accent)!important; }
.qs-dot-green { background:#3B6D11!important; border-color:#3B6D11!important; }
.qs-dot-empty { }
.qs-step.done .qs-dot  { background:var(--accent); border-color:var(--accent); }
.qs-step.active .qs-dot { background:var(--accent); border-color:var(--accent); }
.qs-label { font-size:12px; font-weight:500; color:var(--color-text-primary); }
.qs-date  { font-size:11px; color:var(--color-text-secondary); }
.qs-line  {
  flex:1; height:2px; background:var(--color-border-secondary);
  margin:0 6px; margin-bottom:24px; border-radius:1px;
  transition:background .2s;
}
.qs-line.done { background:var(--accent); }

/* ── Quote line items ── */
.quote-line-row {
  display:grid; grid-template-columns:1fr 100px 80px 90px 110px 36px;
  gap:8px; align-items:center; padding:8px 0; border-bottom:0.5px solid var(--color-border-tertiary);
}

/* ── A4 print area ── */
.quote-a4 {
  width:794px;
  min-height:1123px;
  height:auto;
  background:#fff;
  padding:48px 52px;
  box-sizing:border-box;
  font-family:"Noto Sans TC", "PingFang TC", sans-serif;
  font-size:12px;
  color:#222;
  box-shadow:0 4px 32px rgba(0,0,0,.15);
  border-radius:4px;
  flex-shrink:0;
}
.qa4-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:2px solid #222;
}
.qa4-meta { text-align:right; }
.qa4-meta-row { display:flex; justify-content:flex-end; gap:12px; margin-bottom:3px; font-size:12px; }
.qa4-meta-label { color:#555; width:64px; text-align:right; }
.qa4-meta-val { font-weight:500; min-width:110px; text-align:right; }

.qa4-parties {
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
  margin-bottom:16px;
  padding-bottom:14px;
  border-bottom:0.5px solid #d0d0d0;
}
.qa4-party-title { font-size:10px; font-weight:600; color:#555; letter-spacing:.06em; text-transform:uppercase; margin-bottom:5px; }
.qa4-party-row { font-size:11px; margin-bottom:3px; display:grid; grid-template-columns:72px 1fr; gap:0; }
.qa4-party-row span:first-child { color:#666; white-space:nowrap; }
.qa4-party-row span:last-child { text-align:left; }

.qa4-table {
  width:100%; border-collapse:collapse;
  margin-bottom:24px; font-size:12px;
}
.qa4-table th {
  background:#222; color:#fff;
  padding:9px 12px; font-weight:500; text-align:left; font-size:12px;
}
.qa4-table th:not(:first-child) { text-align:right; }
.qa4-table td { padding:9px 12px; border-bottom:0.5px solid #e0e0e0; }
.qa4-table tbody tr:nth-child(even) td { background:#f8f8f8; }
.qa4-subtotal td { border-top:0.5px solid #d0d0d0; font-size:12px; color:#444; padding:7px 12px; }
.qa4-total td { font-weight:600; font-size:14px; border-top:2px solid #222; padding:10px 12px; }
.qa4-total td:last-child { text-align:right; }
.qa4-subtotal td:last-child { text-align:right; }

.qa4-terms {
  border:0.5px solid #d0d0d0; border-radius:4px;
  padding:12px 14px; margin-bottom:32px;
  font-size:11px; color:#555; line-height:1.7;
}
.qa4-sign {
  display:grid; grid-template-columns:1fr 1fr; gap:48px;
  margin-top:16px; font-size:12px;
}

/* ── @media print ── */
@media print {
  body { background:#fff!important; padding:0!important; }
  .sidebar, .status-bar, .content-header, #mobile-tab-bar,
  .del-modal-bg, #mob-profile-sheet, #mob-profile-overlay,
  #screen-quote-print .content-header { display:none!important; }
  .device-frame, .app-body, .main-content, #screen-quote-print,
  #screen-quote-print .content-body { all:unset!important; display:block!important; }
  #screen-quote-print .content-body { background:#fff!important; padding:0!important; }
  .quote-a4 {
    width:100%!important; box-shadow:none!important;
    padding:20mm 20mm!important; border-radius:0!important;
    page-break-after:always;
  }
  .screen { display:none!important; }
  #screen-quote-print { display:block!important; }
}

/* ── Profile popup (floating panel, above avatar) ── */
#profileMenu {
  display: none;
  position: fixed;
  z-index: 500;
  padding: 10px 8px 8px;
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-secondary);
  border-radius: var(--border-radius-lg);
  box-shadow: 0 8px 32px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08);
}
[data-color-mode="dark"] #profileMenu {
  box-shadow: 0 8px 32px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.2);
  border-color: rgba(255,255,255,0.15);
}
@media (prefers-color-scheme: dark) {
  :root:not([data-color-mode="light"]) #profileMenu {
    box-shadow: 0 8px 32px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.2);
    border-color: rgba(255,255,255,0.15);
  }
}

/* ── Quote list mobile: hide 日期(2) 專案(4) 幣別(5), show 報價單號|業主|金額|狀態 ── */
@media (max-width: 767px) {
  #screen-quote-list .table-header > span:nth-child(2),
  #screen-quote-list .table-row > span:nth-child(2),
  #screen-quote-list .table-header > span:nth-child(4),
  #screen-quote-list .table-row > span:nth-child(4),
  #screen-quote-list .table-header > span:nth-child(5),
  #screen-quote-list .table-row > span:nth-child(5) { display:none; }
  #screen-quote-list .table-header,
  #screen-quote-list .table-row {
    grid-template-columns: 100px 1fr 110px 80px !important;
    min-width:0 !important;
  }
}

/* ── Quote print: fit A4 to screen on mobile ── */
@media (max-width: 1100px) {
  .quote-a4 {
    width:100% !important;
    max-width:100% !important;
    padding:24px 20px !important;
  }
  #screen-quote-print .content-body {
    padding:12px !important;
    align-items:stretch !important;
  }
}
@media (max-width: 767px) {
  .quote-a4 {
    padding:16px !important;
    font-size:10px !important;
  }
  .qa4-header { flex-direction:column; gap:12px; }
  .qa4-parties { grid-template-columns:1fr; gap:16px; }
  .qa4-table th, .qa4-table td { padding:6px 8px !important; font-size:10px !important; }
  .qa4-sign { grid-template-columns:1fr; gap:24px; }
}

/* List screens — match each table header's grid */
#screen-clients .table-header,
#screen-clients .table-row { grid-template-columns: 80px 1fr 100px 80px 110px; }

#screen-employees .table-header,
#screen-employees .table-row { grid-template-columns: 90px minmax(0,1fr) 92px 92px 80px; }

#screen-worklog-list .table-header,
#screen-worklog-list .table-row { grid-template-columns: 88px 120px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 80px; }

#screen-maintenance-list .table-header,
#screen-maintenance-list .table-row { grid-template-columns: 90px 80px 110px 1fr 110px; }

#screen-machinery .table-header,
#screen-machinery .table-row { grid-template-columns: 100px 80px 1fr 92px 92px 100px; }

#screen-users .table-header,
#screen-users .table-row { grid-template-columns: 90px 1fr 96px 120px 120px 80px; }

#screen-quote-list .table-header,
#screen-quote-list .table-row { grid-template-columns: 110px 92px 88px 1fr 72px 120px 88px; }

/* Quote list — prevent 金額(col 6) wrapping; clip 業主(col 3) and 專案(col 4) gracefully */
#screen-quote-list .table-row > span:nth-child(6),
#screen-quote-list .table-header > span:nth-child(6) { white-space:nowrap; }
#screen-quote-list .table-row > span:nth-child(3),
#screen-quote-list .table-row > span:nth-child(4) {
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}

/* Maintenance list — prevent category tag overflow */
#screen-maintenance-list .table-row > span:nth-child(3) {
  overflow: hidden;
  display: flex;
  align-items: center;
}
#screen-maintenance-list .table-row > span:nth-child(3) .tag {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Machinery list — prevent model column text wrapping */
#screen-machinery .table-row > span:nth-child(3),
#screen-machinery .table-header > span:nth-child(3) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* Machinery list — status column */
#screen-machinery .table-row > span:nth-child(4) {
  overflow: hidden;
  display: flex;
  align-items: center;
}
#screen-machinery .table-row > span:nth-child(4) .tag {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Language flyout submenu ── */
#lang-submenu .lang-menu-item {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  border: none;
  background: none;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  color: var(--color-text-secondary);
  border-radius: var(--border-radius-md);
  transition: background .1s;
}
#lang-submenu[style*="display:none"] .lang-menu-item { display: none; }
.lang-menu-item:hover { background: var(--color-background-secondary); color: var(--color-text-primary); }
.lang-menu-item.active { color: var(--color-text-primary); font-weight: 500; }
.lang-menu-item .lang-check { opacity: 0; }
.lang-menu-item.active .lang-check { opacity: 1; color: var(--accent); }
[data-color-mode="dark"] #lang-submenu { box-shadow: 0 8px 24px rgba(0,0,0,.4); }
@media (prefers-color-scheme: dark) { #lang-submenu { box-shadow: 0 8px 24px rgba(0,0,0,.4); } }

/* ── Body-level overlays: excluded from flex layout via position:fixed ── */
body > #toast { position:fixed; bottom:20px; left:50%; transform:translateX(-50%); width:auto; height:auto; }

/* lang-submenu hidden state */
#lang-submenu.lang-submenu-hidden { display:none !important; }
#lang-submenu.lang-submenu-hidden .lang-menu-item { display:none; }

/* Quote print: hide discount column when no discounts */
.qa4-table.no-discount .qa4-discount-col,
.qa4-table.no-discount #qa4-th-discount,
.qa4-table.no-discount .qa4-discount-row,
.qa4-table.no-discount .qa4-gross-row { display:none; }

/* ── Quote PDF multi-page print ── */
@page { margin: 6mm; }
@media print {
  /* Each A4 div: remove shadow/radius, natural size */
  .quote-a4 {
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 15mm 18mm !important;
    font-size: 11px !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  /* Force table header background to print */
  .qa4-table th {
    background: #222 !important;
    color: #fff !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  /* Force alternating row background to print */
  .qa4-table tbody tr:nth-child(even) td {
    background: #f8f8f8 !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  /* Table rows can break across pages */
  .qa4-table tbody tr { page-break-inside: avoid; }
  /* Keep tfoot, terms, signature together */
  .qa4-table tfoot  { page-break-inside: avoid; }
  .qa4-terms        { page-break-inside: avoid; page-break-before: avoid; }
  /* Force signature to flexbox — CSS Grid misplaces second cell across page breaks in Chrome */
  .qa4-sign {
    display: flex !important;
    flex-direction: row !important;
    gap: 48px !important;
    page-break-inside: avoid;
    page-break-before: avoid;
  }
  .qa4-sign > div { flex: 1; min-width: 0; }
  /* Keep header on first page */
  .qa4-header       { page-break-inside: avoid; }
  .qa4-parties      { page-break-inside: avoid; }
}

/* ── Quote print screen: allow full-height scrolling for long quotes ── */
#screen-quote-print {
  overflow-y: auto !important;
  height: auto !important;
  min-height: 100%;
}
#screen-quote-print .content-body {
  overflow-y: visible !important;
  flex: none !important;
  height: auto !important;
}

