/* ============================================================
   Express Factory Scheduler - Components CSS
   Multi-theme token system
   ============================================================ */

/* ============================================================
   Design tokens (single source of truth)
   ============================================================ */

/* Density/shape tokens (theme-invariant) */
:root{
  --fs-base: 14px;
  --fs-title: 16px;
  --fs-compact: 12px;
  --space-1: 6px;
  --space-2: 8px;
  --space-3: 10px;
  --space-4: 12px;
  --space-5: 14px;
  --radius: 12px;
}

/* Default theme for anonymous and fallback */
:root,
html[data-theme="dark"]{
  --app-bg: #0b1220;
  --surface-1: #0f172a;
  --surface-2: #111c33;
  --card-bg: #0f1a2e;
  --card-bg-2: rgba(255,255,255,0.03);
  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.14);
  --text: #e5e7eb;
  --text-2: #9ca3af;
  --text-3: rgba(229,231,235,0.75);
  --accent: #60a5fa;
  --accent-soft: rgba(96,165,250,0.15);
  --accent-strong: rgba(96,165,250,0.35);
  --ok: #22c55e;
  --warn: #f59e0b;
  --err: #ef4444;
  --info: #60a5fa;
  --scroll-thumb: rgba(255,255,255,0.12);
  --scroll-track: rgba(255,255,255,0.05);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.22);
  --shadow-md: 0 12px 30px rgba(0,0,0,.28);
  --app-link: #93c5fd;
  --app-link-hover: #bfdbfe;
  --app-text: var(--text);
  --app-border: var(--border);
  --body-radial: rgba(96,165,250,0.12);
  --body-grad-start: #0b1220;
  --body-grad-end: #07101f;
  --selection-bg: rgba(96,165,250,0.28);
  --placeholder-text: rgba(229,231,235,0.58);
  --control-text-strong: #f8fafc;
  --control-fill: rgba(96,165,250,0.18);
  --control-fill-hover: rgba(96,165,250,0.26);
  --control-border: rgba(96,165,250,0.36);
  --control-border-hover: rgba(147,197,253,0.58);
  --chip-fill: rgba(255,255,255,0.04);
  --chip-border: rgba(255,255,255,0.14);
  --surface-highlight-text: #f8fafc;
  --tone-neutral-bg: rgba(148,163,184,0.14);
  --tone-neutral-border: rgba(148,163,184,0.28);
  --tone-info-bg: rgba(96,165,250,0.16);
  --tone-info-border: rgba(96,165,250,0.34);
  --tone-success-bg: rgba(34,197,94,0.15);
  --tone-success-border: rgba(34,197,94,0.30);
  --tone-warning-bg: rgba(245,158,11,0.18);
  --tone-warning-border: rgba(245,158,11,0.30);
  --tone-danger-bg: rgba(239,68,68,0.17);
  --tone-danger-border: rgba(239,68,68,0.30);
  --tone-asap-bg: rgba(249,115,22,0.16);
  --tone-asap-border: rgba(249,115,22,0.40);
  --tone-lock-bg: rgba(168,85,247,0.16);
  --tone-lock-border: rgba(168,85,247,0.30);
}

html[data-theme="light"]{
  --app-bg: #f4f7fb;
  --surface-1: #ffffff;
  --surface-2: #e8eef7;
  --card-bg: #ffffff;
  --card-bg-2: rgba(11,18,32,0.03);
  --border: rgba(11,18,32,0.12);
  --border-strong: rgba(11,18,32,0.25);
  --text: #0b1220;
  --text-2: #374151;
  --text-3: rgba(11,18,32,0.82);
  --accent: #2563eb;
  --accent-soft: rgba(37,99,235,0.14);
  --accent-strong: rgba(37,99,235,0.36);
  --ok: #15803d;
  --warn: #b45309;
  --err: #b91c1c;
  --info: #1d4ed8;
  --scroll-thumb: rgba(11,18,32,0.2);
  --scroll-track: rgba(11,18,32,0.07);
  --shadow-sm: 0 2px 8px rgba(11,18,32,.12);
  --shadow-md: 0 12px 30px rgba(11,18,32,.16);
  --app-link: #1d4ed8;
  --app-link-hover: #1e40af;
  --app-text: var(--text);
  --app-border: var(--border);
  --body-radial: rgba(59,130,246,0.10);
  --body-grad-start: #f6f9ff;
  --body-grad-end: #e9eff9;
  --selection-bg: rgba(37,99,235,0.24);
  --placeholder-text: rgba(11,18,32,0.58);
  --control-text-strong: #0b1220;
  --control-fill: rgba(37,99,235,0.18);
  --control-fill-hover: rgba(37,99,235,0.26);
  --control-border: rgba(37,99,235,0.36);
  --control-border-hover: rgba(29,78,216,0.52);
  --chip-fill: rgba(11,18,32,0.04);
  --chip-border: rgba(11,18,32,0.14);
  --surface-highlight-text: #0b1220;
  --tone-neutral-bg: rgba(148,163,184,0.24);
  --tone-neutral-border: rgba(100,116,139,0.34);
  --tone-info-bg: rgba(37,99,235,0.24);
  --tone-info-border: rgba(37,99,235,0.38);
  --tone-success-bg: rgba(34,197,94,0.24);
  --tone-success-border: rgba(22,163,74,0.38);
  --tone-warning-bg: rgba(245,158,11,0.26);
  --tone-warning-border: rgba(217,119,6,0.40);
  --tone-danger-bg: rgba(239,68,68,0.24);
  --tone-danger-border: rgba(220,38,38,0.38);
  --tone-asap-bg: rgba(249,115,22,0.24);
  --tone-asap-border: rgba(234,88,12,0.40);
  --tone-lock-bg: rgba(168,85,247,0.22);
  --tone-lock-border: rgba(147,51,234,0.36);
}

html[data-theme="ocean"]{
  --app-bg: #061822;
  --surface-1: #0a2635;
  --surface-2: #0f3347;
  --card-bg: #0a2231;
  --card-bg-2: rgba(120,200,237,0.07);
  --border: rgba(125,211,252,0.20);
  --border-strong: rgba(125,211,252,0.33);
  --text: #d6f0ff;
  --text-2: #94c6dd;
  --text-3: rgba(214,240,255,0.77);
  --accent: #38bdf8;
  --accent-soft: rgba(56,189,248,0.20);
  --accent-strong: rgba(56,189,248,0.45);
  --ok: #34d399;
  --warn: #fbbf24;
  --err: #fb7185;
  --info: #38bdf8;
  --scroll-thumb: rgba(125,211,252,0.28);
  --scroll-track: rgba(125,211,252,0.09);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.30);
  --shadow-md: 0 12px 30px rgba(0,0,0,.34);
  --app-link: #67e8f9;
  --app-link-hover: #a5f3fc;
  --app-text: var(--text);
  --app-border: var(--border);
  --body-radial: rgba(56,189,248,0.18);
  --body-grad-start: #071926;
  --body-grad-end: #021019;
  --selection-bg: rgba(56,189,248,0.28);
  --placeholder-text: rgba(214,240,255,0.62);
  --control-text-strong: #f4fbff;
  --control-fill: rgba(56,189,248,0.20);
  --control-fill-hover: rgba(56,189,248,0.28);
  --control-border: rgba(56,189,248,0.38);
  --control-border-hover: rgba(103,232,249,0.56);
  --chip-fill: rgba(125,211,252,0.07);
  --chip-border: rgba(125,211,252,0.22);
  --surface-highlight-text: #f4fbff;
  --tone-neutral-bg: rgba(125,211,252,0.12);
  --tone-neutral-border: rgba(125,211,252,0.26);
  --tone-info-bg: rgba(56,189,248,0.18);
  --tone-info-border: rgba(56,189,248,0.34);
  --tone-success-bg: rgba(52,211,153,0.16);
  --tone-success-border: rgba(52,211,153,0.32);
  --tone-warning-bg: rgba(251,191,36,0.18);
  --tone-warning-border: rgba(251,191,36,0.30);
  --tone-danger-bg: rgba(251,113,133,0.18);
  --tone-danger-border: rgba(251,113,133,0.32);
  --tone-asap-bg: rgba(249,115,22,0.18);
  --tone-asap-border: rgba(249,115,22,0.40);
  --tone-lock-bg: rgba(168,85,247,0.18);
  --tone-lock-border: rgba(168,85,247,0.32);
}

html[data-theme="forest"]{
  --app-bg: #0b1a12;
  --surface-1: #13281c;
  --surface-2: #193625;
  --card-bg: #102217;
  --card-bg-2: rgba(167,243,208,0.07);
  --border: rgba(167,243,208,0.19);
  --border-strong: rgba(167,243,208,0.33);
  --text: #e1f7ea;
  --text-2: #9ec9b1;
  --text-3: rgba(225,247,234,0.78);
  --accent: #34d399;
  --accent-soft: rgba(52,211,153,0.20);
  --accent-strong: rgba(52,211,153,0.44);
  --ok: #4ade80;
  --warn: #fbbf24;
  --err: #f87171;
  --info: #2dd4bf;
  --scroll-thumb: rgba(167,243,208,0.25);
  --scroll-track: rgba(167,243,208,0.08);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.28);
  --shadow-md: 0 12px 30px rgba(0,0,0,.34);
  --app-link: #6ee7b7;
  --app-link-hover: #a7f3d0;
  --app-text: var(--text);
  --app-border: var(--border);
  --body-radial: rgba(52,211,153,0.18);
  --body-grad-start: #0d1e15;
  --body-grad-end: #06120d;
  --selection-bg: rgba(52,211,153,0.28);
  --placeholder-text: rgba(225,247,234,0.62);
  --control-text-strong: #f3fff8;
  --control-fill: rgba(52,211,153,0.20);
  --control-fill-hover: rgba(52,211,153,0.28);
  --control-border: rgba(52,211,153,0.38);
  --control-border-hover: rgba(110,231,183,0.56);
  --chip-fill: rgba(167,243,208,0.07);
  --chip-border: rgba(167,243,208,0.22);
  --surface-highlight-text: #f3fff8;
  --tone-neutral-bg: rgba(167,243,208,0.12);
  --tone-neutral-border: rgba(167,243,208,0.26);
  --tone-info-bg: rgba(52,211,153,0.16);
  --tone-info-border: rgba(52,211,153,0.34);
  --tone-success-bg: rgba(74,222,128,0.16);
  --tone-success-border: rgba(74,222,128,0.32);
  --tone-warning-bg: rgba(251,191,36,0.18);
  --tone-warning-border: rgba(251,191,36,0.30);
  --tone-danger-bg: rgba(248,113,113,0.18);
  --tone-danger-border: rgba(248,113,113,0.32);
  --tone-asap-bg: rgba(249,115,22,0.18);
  --tone-asap-border: rgba(249,115,22,0.40);
  --tone-lock-bg: rgba(168,85,247,0.18);
  --tone-lock-border: rgba(168,85,247,0.32);
}

html[data-theme="sunset"]{
  --app-bg: #27120d;
  --surface-1: #351a14;
  --surface-2: #48251c;
  --card-bg: #30170f;
  --card-bg-2: rgba(253,186,116,0.08);
  --border: rgba(253,186,116,0.22);
  --border-strong: rgba(253,186,116,0.36);
  --text: #fff1e4;
  --text-2: #f9c8a8;
  --text-3: rgba(255,241,228,0.8);
  --accent: #fb923c;
  --accent-soft: rgba(251,146,60,0.22);
  --accent-strong: rgba(251,146,60,0.45);
  --ok: #4ade80;
  --warn: #facc15;
  --err: #f87171;
  --info: #fdba74;
  --scroll-thumb: rgba(253,186,116,0.29);
  --scroll-track: rgba(253,186,116,0.10);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.30);
  --shadow-md: 0 12px 30px rgba(0,0,0,.35);
  --app-link: #fdba74;
  --app-link-hover: #fed7aa;
  --app-text: var(--text);
  --app-border: var(--border);
  --body-radial: rgba(251,146,60,0.18);
  --body-grad-start: #2a120d;
  --body-grad-end: #170804;
  --selection-bg: rgba(251,146,60,0.30);
  --placeholder-text: rgba(255,241,228,0.64);
  --control-text-strong: #fff7f0;
  --control-fill: rgba(251,146,60,0.22);
  --control-fill-hover: rgba(251,146,60,0.30);
  --control-border: rgba(251,146,60,0.40);
  --control-border-hover: rgba(253,186,116,0.58);
  --chip-fill: rgba(253,186,116,0.08);
  --chip-border: rgba(253,186,116,0.24);
  --surface-highlight-text: #fff7f0;
  --tone-neutral-bg: rgba(253,186,116,0.13);
  --tone-neutral-border: rgba(253,186,116,0.28);
  --tone-info-bg: rgba(251,146,60,0.18);
  --tone-info-border: rgba(251,146,60,0.36);
  --tone-success-bg: rgba(74,222,128,0.16);
  --tone-success-border: rgba(74,222,128,0.32);
  --tone-warning-bg: rgba(250,204,21,0.20);
  --tone-warning-border: rgba(250,204,21,0.32);
  --tone-danger-bg: rgba(248,113,113,0.18);
  --tone-danger-border: rgba(248,113,113,0.32);
  --tone-asap-bg: rgba(249,115,22,0.20);
  --tone-asap-border: rgba(249,115,22,0.42);
  --tone-lock-bg: rgba(217,70,239,0.18);
  --tone-lock-border: rgba(217,70,239,0.32);
}

html[data-theme="high_contrast"]{
  --app-bg: #000000;
  --surface-1: #101010;
  --surface-2: #1a1a1a;
  --card-bg: #0d0d0d;
  --card-bg-2: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.55);
  --border-strong: rgba(255,255,255,0.78);
  --text: #ffffff;
  --text-2: #f5f5f5;
  --text-3: rgba(255,255,255,0.95);
  --accent: #00e5ff;
  --accent-soft: rgba(0,229,255,0.26);
  --accent-strong: rgba(0,229,255,0.58);
  --ok: #00ff7f;
  --warn: #ffd400;
  --err: #ff4d4d;
  --info: #00e5ff;
  --scroll-thumb: rgba(255,255,255,0.68);
  --scroll-track: rgba(255,255,255,0.22);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.45);
  --shadow-md: 0 12px 30px rgba(0,0,0,.55);
  --app-link: #00e5ff;
  --app-link-hover: #7df9ff;
  --app-text: var(--text);
  --app-border: var(--border);
  --body-radial: rgba(0,229,255,0.24);
  --body-grad-start: #000000;
  --body-grad-end: #050505;
  --selection-bg: rgba(0,229,255,0.35);
  --placeholder-text: rgba(255,255,255,0.85);
  --control-text-strong: #ffffff;
  --control-fill: rgba(0,229,255,0.26);
  --control-fill-hover: rgba(0,229,255,0.38);
  --control-border: rgba(0,229,255,0.62);
  --control-border-hover: rgba(125,249,255,0.84);
  --chip-fill: rgba(255,255,255,0.08);
  --chip-border: rgba(255,255,255,0.40);
  --surface-highlight-text: #ffffff;
  --tone-neutral-bg: rgba(255,255,255,0.14);
  --tone-neutral-border: rgba(255,255,255,0.44);
  --tone-info-bg: rgba(0,229,255,0.24);
  --tone-info-border: rgba(0,229,255,0.56);
  --tone-success-bg: rgba(0,255,127,0.24);
  --tone-success-border: rgba(0,255,127,0.56);
  --tone-warning-bg: rgba(255,212,0,0.24);
  --tone-warning-border: rgba(255,212,0,0.56);
  --tone-danger-bg: rgba(255,77,77,0.24);
  --tone-danger-border: rgba(255,77,77,0.56);
  --tone-asap-bg: rgba(255,136,0,0.24);
  --tone-asap-border: rgba(255,136,0,0.58);
  --tone-lock-bg: rgba(217,70,239,0.24);
  --tone-lock-border: rgba(217,70,239,0.58);
}

/* ============================================================
   Base reset
   ============================================================ */

*{ box-sizing:border-box; }
html,body{ height:100%; }
html{ font-size: var(--fs-base); overflow-x: hidden; }

body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans;
  color:var(--text);
  font-size: 1rem;
  line-height: 1.35;
  overflow-x: hidden;

  background: radial-gradient(1200px 700px at 30% -20%, var(--body-radial), transparent 60%),
              linear-gradient(180deg, var(--body-grad-start), var(--body-grad-end));
}

img,svg,video{ max-width:100%; height:auto; }

a{ color: var(--accent); }
a:hover{ color: var(--app-link-hover); }

::selection{
  background: var(--selection-bg);
}

/* Scrollbars (nice-to-have) */
*::-webkit-scrollbar{ height:10px; width:10px; }
*::-webkit-scrollbar-thumb{ background: var(--scroll-thumb); border-radius: 999px; }
*::-webkit-scrollbar-track{ background: var(--scroll-track); border-radius: 999px; }

/* ============================================================
   Layout utilities
   ============================================================ */

.grid{ display:grid; gap:12px; }
.grid-2-1{ grid-template-columns:2fr 1fr; }
.grid-2{ grid-template-columns:repeat(2,minmax(0,1fr)); }
.grid-3{ grid-template-columns:repeat(3,minmax(0,1fr)); }

.app-page,
.workspace-page{
  display:grid;
  gap:10px;
  min-height:0;
  height:100%;
  min-width:0;
  overflow:auto;
  padding:10px 0 0;
}

.app-page{
  align-content:start;
  grid-auto-rows:max-content;
}

.workspace-page{
  grid-template-rows:minmax(0, 1fr);
  overflow:hidden;
}

.app-panel,
.panel-compact{
  min-width:0;
  color:var(--text);
  background:var(--card-bg-2);
  border:1px solid var(--border);
  border-radius:8px;
  padding:10px;
  box-shadow:none;
}

.app-panel--flush{
  padding:0;
  overflow:hidden;
}

.app-panel-scroll{
  min-height:0;
  overflow:auto;
}

.app-form{
  display:grid;
  gap:12px;
  min-width:0;
}

.app-section{
  display:grid;
  gap:10px;
  min-width:0;
}

@media (max-width:900px){
  .grid-2-1{ grid-template-columns:1fr; }
}
@media (max-width:640px){
  .grid-2,.grid-3{ grid-template-columns:1fr; }
}

/* ============================================================
   Cards
   ============================================================ */

.card{
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: none;
  padding: 10px;
  color: var(--text);
  min-width: 0;
}

.card-hd{
  font-weight: 900;
  margin-bottom: var(--space-2);
  font-size: var(--fs-title);
  color: var(--text);
}

.card-bd{ display:block; }
.card,.empty{ overflow-wrap:anywhere; }

/* ============================================================
   Toolbar
   ============================================================ */

.toolbar{
  display:flex;
  align-items:center;
  gap: 8px;
  margin-bottom: 8px;
  min-width: 0;
  flex-wrap: wrap;
}

.toolbar-title{
  font-weight: 950;
  font-size: var(--fs-title);
}

.toolbar-spacer{ flex:1; }

@media (max-width:640px){
  .toolbar{ flex-wrap:wrap; }
  .toolbar-spacer{ display:none; }
}

.pager{
  display:flex;
  align-items:center;
  gap: var(--space-3);
  margin-top: var(--space-3);
  flex-wrap: wrap;
}

.pager-info{
  color: var(--text-2);
  font-size: var(--fs-compact);
}

/* ============================================================
   Inputs
   ============================================================ */

.select,input,select,textarea{
  padding:7px 9px;
  border-radius:8px;
  border:1px solid var(--border);
  background: var(--surface-1);
  color: var(--text);
  box-shadow: none;
  max-width:100%;
}

.select::placeholder,
input::placeholder,
textarea::placeholder{
  color: var(--placeholder-text);
}

.select:focus,input:focus,select:focus,textarea:focus{
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-soft);
}

/* Make the date input icon visible in dark mode (browser-dependent) */
input[type="date"]{
  color-scheme: dark;
}

@media (max-width:420px){
  .select,input,select,textarea{ padding:12px 14px; }
}

/* ============================================================
   Buttons
   ============================================================ */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height: 36px;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid var(--control-border);
  background: var(--control-fill);
  color: var(--control-text-strong);

  text-decoration:none;
  font-weight:900;
  font-size: var(--fs-compact);
  box-shadow: none;
  cursor:pointer;
  line-height: 1.2;
  transition: background-color .16s ease, border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.btn:hover{
  border-color: var(--control-border-hover);
  background: var(--control-fill-hover);
  color: var(--control-text-strong);
  transform: translateY(-1px);
}

.btn:focus{
  outline:none;
  box-shadow: 0 0 0 2px var(--accent-soft);
}

.btn:disabled,
.btn[disabled]{
  opacity:.58;
  cursor:not-allowed;
  transform:none;
}

.btn-primary{
  background: var(--control-fill);
  border-color: var(--control-border);
  color: var(--control-text-strong);
}

.btn-secondary{
  background: var(--control-fill);
  border-color: var(--control-border);
  color: var(--control-text-strong);
}

.btn-danger{
  background: var(--tone-danger-bg);
  border-color: var(--tone-danger-border);
  color: var(--control-text-strong);
}

.btn-sm{
  min-height: 32px;
  padding:7px 10px;
  font-size:11px;
}

.btn-xs{
  min-height: 28px;
  padding:5px 8px;
  font-size:11px;
}

.btn-icon{
  width:36px;
  min-width:36px;
  padding:0;
  aspect-ratio:1;
}

@media (max-width:640px){
  .toolbar .btn{ width:100%; }
}

/* ============================================================
   Badges and Pills
   ============================================================ */

.pill,
.badge,
.status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  max-width:100%;
  padding:4px 8px;
  border-radius:10px;
  font-size:11px;
  font-weight:800;
  line-height:1.2;
  white-space:nowrap;
  border:1px solid var(--tone-neutral-border);
  background: var(--tone-neutral-bg);
  color: var(--surface-highlight-text);
}

.status-pill{
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.pill-text,
.status-pill-text{
  text-transform:none;
  letter-spacing:0;
  font-size:12px;
  font-weight:800;
}

.pill-neutral,
.badge-neutral,
.status-pill-neutral{
  background: var(--tone-neutral-bg);
  border-color: var(--tone-neutral-border);
  color: var(--surface-highlight-text);
}

.pill-info,
.pill-status,
.status-pill-draft{
  background: var(--tone-info-bg);
  border-color: var(--tone-info-border);
  color: var(--surface-highlight-text);
}

.pill-success,
.status-pill-approved,
.status-pill-yes{
  background: var(--tone-success-bg);
  border-color: var(--tone-success-border);
  color: var(--surface-highlight-text);
}

.pill-warning,
.status-pill-issue{
  background: var(--tone-warning-bg);
  border-color: var(--tone-warning-border);
  color: var(--surface-highlight-text);
}

.pill-danger,
.status-pill-no{
  background: var(--tone-danger-bg);
  border-color: var(--tone-danger-border);
  color: var(--surface-highlight-text);
}

.pill-lock,
.status-pill-locked{
  background: var(--tone-lock-bg);
  border-color: var(--tone-lock-border);
  color: var(--surface-highlight-text);
}

.pill-asap{
  background: var(--tone-asap-bg);
  border-color: var(--tone-asap-border);
  color: var(--surface-highlight-text);
}

.pill-checkbox,
.badge input[type="checkbox"],
.pill input[type="checkbox"]{
  accent-color: var(--accent);
}

.pill-checkbox{
  cursor:pointer;
}

/* ============================================================
   Chips
   ============================================================ */

.chip{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:10px;
  align-items:start;
  padding:8px 10px;
  border:1px solid var(--chip-border);
  border-radius:12px;
  background: var(--chip-fill);
  color: var(--surface-highlight-text);
}

.chip-body{
  display:grid;
  gap:6px;
  min-width:0;
}

.chip-label,
.chip-title{
  display:block;
  color: var(--surface-highlight-text);
  font-weight:900;
  line-height:1.2;
}

.chip-sub,
.chip-meta{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  min-width:0;
}

.chip-actions{
  display:flex;
  align-items:flex-start;
  gap:8px;
}

/* ============================================================
   Table highlights
   ============================================================ */

.table-highlight{
  border:1px solid transparent;
  background: rgba(255,255,255,0.02);
  color: var(--surface-highlight-text);
}

.table-highlight--scheduled{ background: var(--tone-info-bg); border-color: var(--tone-info-border); }
.table-highlight--confirmed{ background: var(--tone-success-bg); border-color: var(--tone-success-border); }
.table-highlight--waiting{ background: var(--tone-warning-bg); border-color: var(--tone-warning-border); }
.table-highlight--issue{ background: var(--tone-danger-bg); border-color: var(--tone-danger-border); }
.table-highlight--late{ background: var(--tone-warning-bg); border-color: var(--tone-warning-border); }
.table-highlight--show-up-pay{ background: var(--tone-warning-bg); border-color: var(--tone-warning-border); }
.table-highlight--availability-open{
  background: rgba(148,163,184,0.06);
  border-color: rgba(148,163,184,0.16);
}
.table-highlight--availability-blocked{
  background: rgba(15,23,42,0.20);
  border-color: transparent;
  color: var(--text-3);
}
.table-highlight--assignment-ended{
  background: rgba(127,29,29,0.48);
  border-color: rgba(248,113,113,0.50);
  color: #fff7f0;
}
.table-highlight--day-off{
  background:
    linear-gradient(135deg, rgba(251, 113, 133, 0.16) 25%, transparent 25%) -8px 0/16px 16px,
    linear-gradient(225deg, rgba(251, 113, 133, 0.16) 25%, transparent 25%) -8px 0/16px 16px,
    linear-gradient(315deg, rgba(251, 113, 133, 0.16) 25%, transparent 25%) 0 0/16px 16px,
    linear-gradient(45deg, rgba(251, 113, 133, 0.16) 25%, transparent 25%) 0 0/16px 16px,
    rgba(251, 113, 133, 0.08);
  border-color: var(--tone-danger-border);
}
.table-highlight--asap{
  box-shadow: inset 0 4px 0 #f97316;
}

.table-highlight-swatch{
  width:14px;
  min-width:14px;
  height:14px;
  padding:0;
  border-radius:5px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
  font-weight:900;
}

/* ============================================================
   Tables
   ============================================================ */

.table-wrap{
  background: var(--card-bg);
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow: none;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  min-height:0;
}

.table-wrap table{
  width:100%;
  border-collapse:collapse;
  min-width:680px;
}

.table-wrap th,.table-wrap td{
  padding:7px 8px;
  border-bottom:1px solid var(--border);
  font-size: var(--fs-compact);
}

.table-wrap th{
  color: var(--text);
  font-weight: 900;
  white-space: nowrap;
}

.table-wrap td{
  color: var(--text-2);
  white-space: normal;
  overflow-wrap: anywhere;
}

.table-wrap td small{ white-space:normal; color: var(--text-3); }

/* ============================================================
   Empty states
   ============================================================ */

.empty{
  padding:12px;
  color: var(--text-2);
  font-size: var(--fs-compact);
  text-align:center;

  background: rgba(255,255,255,0.03);
  border: 1px dashed var(--border);
  border-radius: 8px;
}

@media (max-width:900px){
  .app-page,
  .workspace-page{
    padding-top:8px;
  }
}

/* ============================================================
   Toasts (Django messages)
   ============================================================ */

.toasts{
  position:fixed;
  top:12px;
  right:12px;
  z-index:9999;
  display:flex;
  flex-direction:column;
  gap:8px;
  pointer-events:none;
}

.toast{
  position:relative;
  box-sizing:border-box;
  min-width:220px;
  max-width:440px;
  padding:8px 32px 8px 10px;
  border-radius:10px;
  font-size: var(--fs-compact);
  pointer-events:auto;

  background: var(--surface-1);
  color: var(--text);
  box-shadow: var(--shadow-md);

  border-left:4px solid rgba(255,255,255,0.18);
  transition:opacity .18s ease,transform .18s ease;
}

.toast.success{ border-left-color: var(--ok); }
.toast.warning{ border-left-color: var(--warn); }
.toast.error{ border-left-color: var(--err); }
.toast.info{ border-left-color: var(--info); }

.toast.hiding{ opacity:0; transform:translateY(-6px); }

.toast-close{
  position:absolute;
  top:6px;
  right:6px;
  width:30px;
  height:30px;

  border:1px solid var(--border);
  background: rgba(255,255,255,0.04);
  color: var(--text);

  border-radius: 10px;
  font-size:14px;
  cursor:pointer;
  opacity:.85;

  display:flex;
  align-items:center;
  justify-content:center;
}

.toast-close:hover{
  opacity: 1;
  border-color: var(--accent-strong);
  background: rgba(96,165,250,0.10);
}

@media (max-width:520px){
  .toasts{ left:12px; right:12px; }
  .toast{ min-width:0; max-width:none; width:100%; }
}

/* ============================================================
   Check-ins (mobile-first)
   ============================================================ */

.checkins-autosave-hint{
  font-size:.88rem;
  color: var(--text-2);
  padding:10px 0 2px;
}

@media (max-width:900px){
  .checkins-autosave-hint{
    padding:0;
  }
}

.checkins-empty{ margin-top:16px; }

/* Ensure hidden actually hides panels */
.tab-panel[hidden]{ display:none !important; }

/* ============================================================
   Tabs (mobile-first)
   ============================================================ */

.tabs{ margin-top:14px; }

.tab-buttons{
  display:flex;
  gap:2px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  align-items:flex-end;
  padding:0 2px;
  margin:0 0 12px;
  border-bottom:1px solid var(--border-strong);
  scroll-snap-type:x mandatory;
  flex-wrap:nowrap;
  scrollbar-width:none;
  -ms-overflow-style:none;
}

.tab-buttons::-webkit-scrollbar{
  display:none;
}

.tab-btn{
  flex:0 0 auto;
  scroll-snap-align:start;

  appearance:none;
  border:1px solid var(--border);
  border-bottom-color: var(--border-strong);
  background: var(--card-bg-2);
  color: var(--text-2);

  margin-bottom:-1px;
  padding:9px 12px 8px;
  border-radius:8px 8px 0 0;
  box-shadow: none;

  font-weight: 950;
  line-height:1.1;
  cursor:pointer;

  display:inline-flex;
  align-items:center;
  gap:10px;
}

.tab-btn:hover{
  border-color: var(--accent-strong);
  background: var(--accent-soft);
  color: var(--text);
}

.tab-btn:focus{
  outline: none;
  box-shadow: 0 0 0 2px var(--accent-soft);
}

.tab-btn[aria-selected="true"],
.tab-btn.active{
  background: var(--accent);
  color: var(--app-bg);
  border-color: var(--accent);
  border-bottom-color: var(--accent);
}

.tab-count{
  font-weight: 950;
  font-size:12px;
  padding:3px 9px;
  border-radius:6px;

  background: rgba(255,255,255,0.08);
  border:1px solid var(--border);
  color: var(--text);
}

.tab-btn[aria-selected="true"] .tab-count,
.tab-btn.active .tab-count{
  background: rgba(7,16,31,0.18);
  border-color: rgba(7,16,31,0.24);
  color: var(--app-bg);
}

/* Panel wrapper */
.tab-panel{ padding:0; }

/* ============================================================
   Associate list + cards (Check-in rows)
   ============================================================ */

.checkins-list{
  display:grid;
  gap:10px;
  padding:2px;
}

.checkin-row{
  background: var(--card-bg-2);
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: none;
  padding:10px;
  position:relative;
}

/* left accent bar */
.checkin-row::before{
  content:"";
  position:absolute;
  left:0;
  top:12px;
  bottom:12px;
  width:4px;
  border-radius:999px;
  background: rgba(255,255,255,0.12);
}

/* Top area */
.checkin-row-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:12px;
}

@media (max-width:640px){
  .checkin-row-top{ flex-direction:column; align-items:flex-start; }
  .checkin-when{ margin-top:4px; }
}

.checkin-name{
  font-weight: 950;
  font-size: 1rem;
  letter-spacing:.1px;
  color: var(--text);
}

.checkin-meta{
  color: var(--text-2);
  font-size: .86rem;
  line-height: 1.25;
  margin-top: 4px;
}

.checkin-line{ margin-left:8px; }

.checkin-when{
  color: var(--text-2);
  font-weight: 900;
  font-size: .88rem;
  white-space: nowrap;
}

.checkin-row-state{
  display: grid;
  gap: 6px;
  justify-items: end;
}

/* Controls */
.checkin-controls{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.checkin-row-compact .checkin-controls{
  display: none;
}

.checkin-row-compact .checkin-row-top{
  margin-bottom: 0;
}

.js-row-expand[hidden]{
  display: none !important;
}

/* Field separators */
.checkin-field{
  padding-top:6px;
  border-top:1px solid rgba(255,255,255,0.06);
}
.checkin-field:first-child{
  padding-top:0;
  border-top:none;
}

.checkin-field label{
  display:block;
  font-size:.82rem;
  color: var(--text-2);
  margin:0 0 6px;
}

.checkin-hint{
  display:block;
  margin-top:6px;
  color: var(--text-2);
  font-size:.82rem;
}

/* Notes input looks tappable */
.js-checkin-notes{
  cursor:pointer;
  background: rgba(255,255,255,0.06);
}

/* Backup visibility safety */
.checkin-backup-wrap[hidden]{ display:none !important; }

/* Saving / saved / error states */
.checkin-row.saving{ opacity:.78; }

.checkin-row.saved{
  border-color: rgba(96,165,250,0.45);
  box-shadow: 0 0 0 2px rgba(96,165,250,0.18);
}

.checkin-row.error{
  border-color: rgba(239,68,68,0.55);
  box-shadow: 0 0 0 2px rgba(239,68,68,0.18);
}

/* Optional status accents */
.checkin-row.status-on_time::before{ background: var(--ok); }
.checkin-row.status-no_show::before{ background: var(--err); }
.checkin-row.status-call_off::before{ background: var(--warn); }
.checkin-row.status-show_up_pay_express::before{ background: var(--info); }
.checkin-row.status-unmarked::before{ background: rgba(255,255,255,0.12); }

.checkin-row-open::before{
  background: rgba(250,204,21,0.7);
}

.checkin-open-slot-assign{
  display: grid;
  gap: 6px;
  margin-bottom: 8px;
}

.checkin-open-slot-toggle{
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-2);
}

.checkin-open-slot-menu{
  position: relative;
  z-index: 1;
  display: grid;
  gap: 4px;
  padding: 6px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--surface-1);
  box-shadow: var(--shadow-sm);
  max-height: 220px;
  overflow-y: auto;
}

.checkin-open-slot-item{
  appearance: none;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border-radius: 8px;
  padding: 7px 8px;
  text-align: left;
  cursor: pointer;
  font-size: 13px;
}

.checkin-open-slot-item:hover{
  border-color: var(--accent-strong);
  background: rgba(96,165,250,0.10);
}

/* Desktop: optional 2 columns */
@media (min-width:900px){
  .checkin-controls{
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-items:end;
  }
}

@media (max-width:900px){
  .checkin-row{
    padding:12px;
  }
  .checkin-row::before{
    top:10px;
    bottom:10px;
  }
}

/* Notes modal buttons */
.notes-btn{ width:auto; }

/* ============================================================
   Generic Modal (components/modal.html)
   ============================================================ */

.modal{
  position: fixed;
  inset: 0;
  z-index: 2000;

  display: grid;
  place-items: center;

  padding: 12px;

  background: rgba(2, 6, 23, 0.68);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.modal[hidden]{ display: none !important; }

.modal-dialog{
  width: min(720px, 100%);
  max-height: min(85vh, 900px);
  overflow: auto;

  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--surface-1);
  color: var(--text);

  box-shadow: var(--shadow-md);
  min-width: 0;
}

.modal-hd{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid var(--border);

  position: sticky;
  top: 0;
  background: inherit;
  z-index: 1;
}

.modal-hd strong{ font-weight: 950; }

.modal-bd{ padding: 12px; }

.modal-ft{
  padding: 10px 12px;
  border-top: 1px solid var(--border);

  display:flex;
  justify-content:flex-end;
  gap: 10px;

  position: sticky;
  bottom: 0;
  background: inherit;
}

.modal-close{
  width: 32px;
  height: 32px;

  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.06);
  color: var(--text);

  font-size: 16px;
  line-height: 1;
  cursor: pointer;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  box-shadow: none;
  opacity: .95;
}

.modal-close:hover{
  border-color: var(--accent-strong);
  background: rgba(96,165,250,0.12);
}

.modal-close:focus{
  outline:none;
  box-shadow: 0 0 0 2px var(--accent-soft);
}

@media (max-width:520px){
  .modal{ padding: 12px; }
  .modal-dialog{ border-radius: 14px; }
  .modal-bd{ padding: 14px; }
}


/* Notes modal: only what differs from generic modal */
.notes-textarea{
  width: 100%;
  min-height: 180px;
  resize: vertical;
  line-height: 1.35;
}

/* If you want the dialog slightly wider than default, keep; otherwise remove */
.notes-dialog{
  width: min(760px, 100%);
}

/* Common utility classes for page-level cleanup */
.text-muted{ color: var(--text-2); font-size: var(--fs-compact); }
.panel-compact{
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
  min-width: 0;
}
.app-page{
  display: grid;
  gap: var(--space-4);
  max-width: 1200px;
  min-width: 0;
}

.sms-preview {
  display: grid;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card-bg-2);
  padding: 10px;
  min-width: 0;
}

.sms-preview-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.sms-preview-block {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.sms-preview-label {
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.sms-preview-text {
  min-height: 42px;
  max-height: 220px;
  overflow: auto;
  margin: 0;
  padding: 9px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface-1);
  color: var(--text);
  font-family: Segoe UI, Arial, sans-serif;
  font-size: 13px;
  line-height: 1.35;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.sms-preview-status {
  font-size: 12px;
}

.sms-preview-status-error {
  color: var(--err);
}

.sched-drawer-send-preview {
  margin-top: 10px;
}

.sched-drawer-preview-textarea {
  width: 100%;
  min-height: 150px;
  box-sizing: border-box;
  resize: vertical;
  line-height: 1.35;
  white-space: pre-wrap;
}

@media (max-width:720px){
  .table-wrap table{ min-width: 0; }
}


/* ============================================================
   End
   ============================================================ */

/* DEPLOY MARKER (update if you want quick "is this live?" checks) */
