/* shell/public/pages/all-models.css — All Models page (1:1 v1 replica).
   Ported from v1 modules/admin/public/admin.css (.mtbl-* / .mdl-* rules), scoped
   under .allmodels-page so nothing leaks into other v2 pages (A18 isolation).

   COLOUR PARITY (2026-06-15): v2's theme vars differ from v1's (v2 --text2 #b6c0d0
   vs v1 #8890a4, --text3 #7a8493 vs #555f74, --border/--red/--yellow/--blue all
   differ, and v2 has no --border2/--*-dim), so the ported rules rendered in the
   wrong shades. We re-declare v1's EXACT dark+light palette scoped to this page —
   the page now matches v1 without touching any other v2 page. Row SPACING is kept
   as-is (== v1). */
.allmodels-page{
  --bg:#0a0b0f; --bg2:#111318; --bg3:#181c24; --bg4:#1e2330;
  --border:#252b38; --border2:#2e3547;
  --text:#e8eaf0; --text2:#8890a4; --text3:#555f74;
  --accent:#00e5a0; --accent2:#00b87a; --accent-dim:rgba(0,229,160,0.1);
  --red:#ff4d6a; --red-dim:rgba(255,77,106,0.12);
  --yellow:#ffb930; --yellow-dim:rgba(255,185,48,0.12);
  --blue:#4d8eff; --blue-dim:rgba(77,142,255,0.12);
}
html[data-theme="light"] .allmodels-page{
  --bg:#f4f5f7; --bg2:#ffffff; --bg3:#f0f1f4; --bg4:#e5e7ec;
  --border:#d5d8e0; --border2:#c5c8d0;
  --text:#1a1c24; --text2:#4a5068; --text3:#8890a4;
  --accent:#00b87a; --accent2:#009966; --accent-dim:rgba(0,184,122,0.1);
  --red:#e63e58; --red-dim:rgba(230,62,88,0.1);
  --yellow:#e6a800; --yellow-dim:rgba(230,168,0,0.1);
  --blue:#3a7bdd; --blue-dim:rgba(58,123,221,0.1);
}

.allmodels-page .mtbl-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0}
.allmodels-page .mtbl-avatar img{width:100%;height:100%;object-fit:cover}
.allmodels-page .mtbl-avatar-initial{width:60px;height:60px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif;font-weight:600;font-size:20px;color:var(--accent);flex-shrink:0}
.allmodels-page .mtbl-name-info{min-width:0}
.allmodels-page .mtbl-display-name{font-weight:500;font-size:12px;line-height:1.3;cursor:pointer;white-space:normal;word-break:break-word;max-width:110px}
.allmodels-page .mtbl-display-name:hover{color:var(--accent)}
.allmodels-page .mtbl-nick{font-size:10px;color:var(--text3);font-family:'DM Mono',monospace;margin-top:2px;cursor:pointer}
.allmodels-page .mtbl-nick:hover{color:var(--accent)}
.allmodels-page .mtbl-pwd-btn{background:none;border:1px solid var(--border2);border-radius:6px;padding:3px 5px;cursor:pointer;font-size:20px;line-height:1;color:var(--text2);transition:all .15s;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px}
.allmodels-page .mtbl-pwd-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,229,160,.08)}
.allmodels-page .mtbl-pwd-btn img{width:24px;height:24px}
.allmodels-page .mtbl-platforms{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.allmodels-page .mtbl-platforms a,.allmodels-page .mtbl-platforms>span{display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:6px;transition:background .15s;min-width:34px;min-height:34px;cursor:pointer}
.allmodels-page .mtbl-platforms a:hover,.allmodels-page .mtbl-platforms>span:hover{background:var(--bg3)}
.allmodels-page .mtbl-platforms img{width:26px!important;height:26px!important;border-radius:3px!important}
.allmodels-page .mtbl-status{font-size:10px;font-family:'DM Mono',monospace;line-height:1.4;white-space:nowrap;max-width:120px}
.allmodels-page .mtbl-status .s-line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* expand row show/hide (v1 used .model-expand-tr.collapsed/.expanded) */
.allmodels-page .model-expand-tr.collapsed{display:none}
.allmodels-page .model-expand-tr.expanded{display:table-row}

/* expand detail panel */
.allmodels-page .mdl-detail{background:var(--bg2);border-top:1px solid var(--border);padding:12px 16px;display:flex;flex-direction:column;gap:8px}
/* row fill: v1 used var(--surface) which is UNDEFINED in v1 → transparent (shows the
   --bg2 panel); on hover → --bg3. Mirror that exactly (the "row color" fix). */
.allmodels-page .mdl-detail-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface,transparent);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s;min-height:44px}
.allmodels-page .mdl-detail-row:hover{border-color:var(--accent);background:var(--bg3)}
.allmodels-page .mdl-detail-icon{font-size:16px;flex-shrink:0;width:24px;text-align:center}
.allmodels-page .mdl-detail-body{flex:1;min-width:0;display:flex;flex-wrap:wrap;gap:4px 16px;align-items:center}
.allmodels-page .mdl-detail-label{font-size:11px;color:var(--text3);font-family:'DM Mono',monospace;text-transform:uppercase;letter-spacing:.3px;width:100%}
.allmodels-page .mdl-detail-vals{display:flex;flex-wrap:wrap;gap:4px 14px;align-items:center}
.allmodels-page .mdl-dv{font-size:12px;color:var(--text2)}
.allmodels-page .mdl-dv strong{color:var(--text);font-weight:600}
.allmodels-page .mdl-dv .accent{color:var(--accent)}
.allmodels-page .mdl-dv .yellow{color:var(--yellow)}
.allmodels-page .mdl-dv .green{color:#2dd36f}
.allmodels-page .mdl-dv .red{color:var(--red)}
.allmodels-page .mdl-dv .blue{color:var(--blue)}
.allmodels-page .mdl-detail-arrow{font-size:10px;color:var(--text3);flex-shrink:0;transition:color .15s}
.allmodels-page .mdl-detail-row:hover .mdl-detail-arrow{color:var(--accent)}
.allmodels-page .mdl-week{display:flex;gap:3px;align-items:center}
.allmodels-page .mdl-week-day{width:28px;height:22px;border-radius:4px;font-size:9px;font-family:'DM Mono',monospace;display:flex;align-items:center;justify-content:center;font-weight:600;border:1px solid var(--border)}
.allmodels-page .mdl-week-day.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.allmodels-page .mdl-week-day.shift{background:rgba(0,229,160,.15);color:var(--accent)}
.allmodels-page .mdl-week-day.dayoff{background:var(--yellow-dim);color:var(--yellow)}
.allmodels-page .mdl-week-day.vacation{background:var(--yellow-dim);color:var(--yellow)}
.allmodels-page .mdl-week-day.period{background:var(--blue-dim);color:var(--blue)}
.allmodels-page .mdl-week-day.sick{background:rgba(249,115,22,.15);color:#f97316}
.allmodels-page .mdl-week-day.missed{background:var(--red-dim);color:var(--red)}
.allmodels-page .mdl-week-day.makeup{background:rgba(167,139,250,.15);color:#a78bfa}
.allmodels-page .mdl-week-day.none{background:var(--bg);color:var(--text3)}
.allmodels-page .mdl-detail-loading{text-align:center;padding:16px;color:var(--text3);font-size:12px}

/* r3 Hours — per-day confirmed-hours bars (new 2026-06-15) */
.allmodels-page .am-hbars{display:flex;align-items:flex-end;gap:4px;width:100%;height:96px;padding:4px 0 0;overflow-x:auto}
.allmodels-page .am-hbar{flex:1 0 18px;min-width:18px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.allmodels-page .am-hbar-val{font-size:8px;color:var(--text3);font-family:'DM Mono',monospace;line-height:1;margin-bottom:2px;white-space:nowrap}
.allmodels-page .am-hbar-track{width:100%;flex:1;display:flex;align-items:flex-end;background:var(--bg);border-radius:3px;overflow:hidden}
.allmodels-page .am-hbar-fill{width:100%;background:var(--accent);border-radius:3px 3px 0 0;min-height:2px}
.allmodels-page .am-hbar-day{font-size:8px;color:var(--text3);font-family:'DM Mono',monospace;margin-top:3px}

/* r4 Latest Penalty — status badge (new 2026-06-15) */
.allmodels-page .am-badge{display:inline-block;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:10px;vertical-align:middle}
.allmodels-page .am-badge-red{background:var(--red-dim);color:var(--red)}
.allmodels-page .am-badge-yellow{background:var(--yellow-dim);color:var(--yellow)}
.allmodels-page .am-badge-blue{background:var(--blue-dim);color:var(--blue)}

/* ── COLUMN EDITOR (2026-06-15): resizable/reorderable/show-hide columns ── */
/* Name column: line1 = alias, line2 = full name. Let it fill the (resizable) column. */
.allmodels-page .am-table .mtbl-display-name{max-width:none;font-size:18px}              /* name alias +50% (12→18) */
.allmodels-page .am-table .mtbl-fullname{font-size:15px}                                  /* full name +50% (10→15) */
.allmodels-page .am-table .am-login{color:var(--accent);font-family:'DM Mono',monospace} /* login green; size from col fontPx */
.allmodels-page .mtbl-fullname{font-size:10px;color:var(--text2);margin-top:2px;line-height:1.25;white-space:normal;word-break:break-word}
/* table cells wrap into 2–4 lines instead of nowrap-clipping (owner: resize → wrap) */
.allmodels-page .am-table td,.allmodels-page .am-table th{white-space:normal;word-break:break-word}
/* resize handle on each header's right edge */
.allmodels-page .am-table th .am-col-resize{position:absolute;top:0;right:-4px;width:9px;height:100%;cursor:col-resize;z-index:3}
.allmodels-page .am-table th .am-col-resize:hover{background:var(--accent);opacity:.35}

/* editor overlay + panel (panel carries .allmodels-page so the palette vars resolve) */
.am-ce-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:flex-start;justify-content:center;z-index:9000;padding:40px 16px;overflow:auto}
.am-ce-panel{background:var(--bg2);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;box-shadow:0 12px 40px rgba(0,0,0,.45)}
.am-ce-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-weight:600;font-size:15px;color:var(--text)}
.am-ce-x{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:6px}
.am-ce-x:hover{color:var(--text);background:var(--bg3)}
.am-ce-hint{padding:8px 16px;font-size:11px;color:var(--text3);border-bottom:1px solid var(--border)}
.am-ce-list{max-height:52vh;overflow:auto;padding:6px 8px}
.am-ce-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 8px;border-radius:8px}
.am-ce-row:hover{background:var(--bg3)}
.am-ce-lbl{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer;flex:1;min-width:0}
.am-ce-lbl>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.am-ce-move{display:flex;gap:4px;flex-shrink:0}
.am-ce-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:11px;line-height:1}
.am-ce-btn:hover:not([disabled]){border-color:var(--accent);color:var(--accent)}
.am-ce-btn[disabled]{opacity:.35;cursor:default}
.am-ce-foot{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex-wrap:wrap}

/* ── Room + RustDesk columns + Normal/All toggle + zebra (2568.190.665) ── */
/* Zebra striping — alternate row shade so each model's row is easy to read across.
   Each model renders TWO <tr> (the row + its expand row); only the main row carries
   .am-row-zebra, so the detail row is never striped. */
.allmodels-page .am-table tbody tr.am-row-zebra > td{background:var(--bg3)}

/* Normal / All column-view toggle (next to the ⚙ Columns button) */
.allmodels-page .am-viewtoggle{display:inline-flex;gap:0}
.allmodels-page .am-viewtoggle .btn{border-radius:0}
.allmodels-page .am-viewtoggle .btn:first-child{border-radius:8px 0 0 8px}
.allmodels-page .am-viewtoggle .btn:last-child{border-radius:0 8px 8px 0}

/* RustDesk ID (click-to-copy) + revealed password cell */
.allmodels-page .am-rustdesk{font-family:'DM Mono',monospace;font-size:13px;color:var(--text);white-space:nowrap}
.allmodels-page .am-rustdesk:hover{color:var(--accent)}
.allmodels-page .am-rdpw{font-family:'DM Mono',monospace;font-size:12px;color:var(--text2);white-space:nowrap}
