:root{
  --bg:#0b1020;
  --card:#111a33;
  --card-solid:#151e3a;
  --muted:#9aa7c7;
  --text:#e8eeff;
  --line:#233057;
  --accent:#3b82f6;
  --ok:#22c55e;
  --bad:#ef4444;
  --warn:#eab308;
  --sidebar-w:240px;
  --input-bg:rgba(0,0,0,.25);
  --input-border:rgba(255,255,255,.10);
  --hover-bg:rgba(59,130,246,.08);
  --hover-bg-strong:rgba(59,130,246,.15);
}

*{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,-apple-system,sans-serif;background:linear-gradient(180deg,#0a1020,#060812);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{color:inherit;text-decoration:none}

/* ---- Topbar ---- */
.topbar{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;padding:8px 18px;border-bottom:1px solid var(--line);background:rgba(10,16,32,.9);backdrop-filter:blur(10px);position:sticky;top:0;z-index:10;gap:12px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.4px}
.brand-logo{height:64px;width:auto}
.topbar-center{font-size:22px;font-weight:900;letter-spacing:1.8px;text-align:center;white-space:nowrap}
.topbar-right{display:flex;gap:12px;align-items:center;justify-content:flex-end}

/* ---- Layout ---- */
.layout{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:calc(100vh - 82px)}

/* ---- Sidebar ---- */
.sidebar{
  border-right:1px solid var(--line);
  padding:10px 8px;
  background:rgba(17,26,51,.35);
  position:sticky;
  top:82px;
  height:calc(100vh - 82px);
  overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.08) transparent;
}
.sidebar::-webkit-scrollbar{width:4px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px}

.nav-section-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;
  color:rgba(154,167,199,.5);padding:18px 12px 6px;margin-top:4px;
  border-top:1px solid rgba(255,255,255,.04);
}
.nav-section-label:first-child{padding-top:8px;border-top:none;margin-top:0}

.nav-item{
  display:block;padding:9px 12px;border-radius:8px;color:var(--text);
  font-size:13.5px;font-weight:500;border-left:2px solid transparent;
  margin-bottom:2px;transition:all .15s ease;
}
.nav-item:hover{background:var(--hover-bg)}
.nav-item.active{color:#fff;background:rgba(59,130,246,.14);border-left-color:var(--accent);font-weight:600}

.nav-group{margin-bottom:1px}
.nav-group-toggle{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border-radius:8px;color:var(--text);font-size:13.5px;
  font-weight:500;cursor:pointer;user-select:none;
  border-left:2px solid transparent;transition:all .15s ease;
}
.nav-group-toggle:hover{background:var(--hover-bg)}
.nav-arrow{font-size:16px;line-height:1;transition:transform .2s ease;opacity:.5}
.nav-group.open .nav-arrow{transform:rotate(90deg);opacity:.8}
.nav-group-children{display:none;padding:2px 0 2px 10px}
.nav-group.open .nav-group-children{display:block}
.nav-child{font-size:12.5px;padding:7px 12px;border-radius:6px;color:var(--muted);margin-bottom:1px}
.nav-child:hover{color:var(--text);background:rgba(59,130,246,.06)}
.nav-child.active{color:#fff;background:rgba(59,130,246,.12);border-left-color:var(--accent);font-weight:600}

/* ---- Content ---- */
.content{padding:18px;min-width:0}
.muted{color:var(--muted)}
.strong{font-weight:700}

/* ---- Utilities ---- */
/* Layout */
.flex{display:flex}
.flex-wrap{display:flex;flex-wrap:wrap}
.flex-col{display:flex;flex-direction:column}
.flex-1{flex:1}
.inline{display:inline}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.justify-between{justify-content:space-between}
.d-flex{display:flex}
.d-block{display:block}
.gap-4{gap:4px}
.gap-6{gap:6px}
.gap-8{gap:8px}
.gap-10{gap:10px}
.gap-12{gap:12px}
.gap-16{gap:16px}
.gap-24{gap:24px}

/* Spacing */
.mt-4{margin-top:4px}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}
.mb-4{margin-bottom:4px}
.mb-8{margin-bottom:8px}
.mb-10{margin-bottom:10px}
.mb-12{margin-bottom:12px}
.mb-14{margin-bottom:14px}
.mb-16{margin-bottom:16px}
.mt-0{margin-top:0}
.m-0{margin:0}
.my-12{margin-top:12px;margin-bottom:12px}
.m-4-0{margin:4px 0}
.p-10{padding:10px}
.p-14{padding:14px}
.pl-24{padding-left:24px}

/* Visibility */
.d-none{display:none}

/* Text */
.text-xs{font-size:11px}
.text-sm{font-size:12px}
.text-md{font-size:14px}
.text-lg{font-size:16px}
.text-xl{font-size:20px}
.fw-400{font-weight:400}
.fw-600{font-weight:600}
.fw-bold{font-weight:bold}
.text-ok{color:var(--ok)}
.text-bad{color:var(--bad)}
.text-warn{color:#e67e22}
.text-info{color:#3498db}
.text-accent{color:var(--accent)}
.text-blue{color:#2980b9}
.text-green{color:#27ae60}

/* Misc */
.w-full{width:100%}
.w-100{width:100px}
.w-120{width:120px}
.text-center{text-align:center}
.text-right{text-align:right}
.cursor-pointer{cursor:pointer}
.pre-wrap{white-space:pre-wrap}
.overflow-auto{overflow:auto}
.pos-relative{position:relative}
.ml-auto{margin-left:auto}
.w-40{width:40px}
.opacity-45{opacity:0.45}
.opacity-40{opacity:0.4}
.opacity-30{opacity:0.3}
.w-30{width:30px}
.w-50{width:50px}
.w-90{width:90px}
.max-w-300{max-width:300px}
.msg-body{padding:14px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px}
.ml-8{margin-left:8px}
.p-12{padding:12px}

/* Semantic components */
.form-inline{display:inline}
.action-row{display:flex;gap:8px;align-items:center}
.checkbox-row{display:flex;gap:8px;align-items:center}
.checkbox-row input{width:auto}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.term-switcher{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;font-weight:700}
.term-switcher select{
  width:150px;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid var(--input-border);
  background:var(--input-bg);
  color:var(--text);
  font-size:13px;
}
.photo-thumb{display:block;width:96px;min-width:96px;max-width:96px;height:128px;min-height:128px;max-height:128px;border-radius:8px;object-fit:cover;object-position:center}
.avatar-lg{width:120px;height:160px;border-radius:12px;object-fit:cover}
.avatar-md{width:160px;height:160px;border-radius:12px;object-fit:cover}
.avatar-thumb{width:32px;height:32px;border-radius:50%;object-fit:cover}
.reading-card{background:rgba(255,255,255,.03);padding:10px;border-radius:10px;border:1px solid var(--line)}
.utility-record{border:1px solid var(--line);border-radius:12px;padding:14px;margin:12px 0;background:rgba(255,255,255,.03)}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.scroll-list{max-height:280px;overflow-y:auto;border:1px solid var(--line);border-radius:12px;padding:4px}
.scroll-list-sm{max-height:200px;overflow-y:auto;border:1px solid var(--line);border-radius:12px;padding:4px;margin-top:6px}
.notif-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.border-top-line{border-top:1px solid var(--line);padding-top:10px}
.max-w-400{max-width:400px}
.min-w-280{min-width:280px}
.bg-subtle{background:rgba(255,255,255,.03)}
.col-full{grid-column:1/-1}
.staff-photo{width:160px;height:160px;border-radius:12px;object-fit:cover}
.border-danger{border-color:rgba(239,68,68,.5)}
.border-muted{border-color:rgba(255,255,255,.2)}
.input-inline{padding:6px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.25);color:var(--text);width:140px}
.dialog-box{border-radius:12px;border:1px solid rgba(255,255,255,.15);background:var(--bg-card, #1e1e2e);color:var(--text);padding:24px;max-width:400px;width:90%}
.note-box{padding:14px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px}
.bg-unread{background:rgba(234,179,8,.06)}
.meal-editor{display:flex;flex-direction:column;gap:10px}
.inline-input-row{display:flex;align-items:center;gap:8px}
.tag-input{position:relative}
.tag-text{flex:1 1 auto}
.inline-textarea-wrap{display:flex;flex-direction:column;gap:8px}
.inline-textarea-wrap textarea{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--input-border);
  background:var(--input-bg);
  color:var(--text);
  resize:vertical;
}
.inline-save-btn{
  display:none;
  flex:0 0 auto;
  padding:8px 12px;
  border:1px solid rgba(59,130,246,.5);
  border-radius:10px;
  background:rgba(59,130,246,.15);
  color:var(--text);
  font-size:12px;
  font-weight:700;
  cursor:pointer;
}
.inline-save-host.is-active .inline-save-btn{display:inline-flex;align-items:center;justify-content:center}
.inline-save-btn:hover{background:rgba(59,130,246,.25)}

/* ---- Buttons ---- */
.btn{
  padding:8px 12px;border:1px solid var(--line);border-radius:10px;
  background:rgba(255,255,255,.04);cursor:pointer;margin:4px 0;
  color:var(--text);font-size:13px;display:inline-block;
}
.btn:hover{border-color:rgba(59,130,246,.6)}
.btn+.btn,.btn+form,.form-inline+.btn,.form-inline+.form-inline{margin-left:8px}
.btn-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.btn-danger{
  padding:6px 12px;border:1px solid rgba(239,68,68,.4);border-radius:8px;
  background:rgba(239,68,68,.12);color:var(--bad);cursor:pointer;
  font-size:12px;font-weight:600;
}
.btn-danger:hover{background:rgba(239,68,68,.25);border-color:var(--bad)}
.tenant-detail-delete-btn{
  padding:8px 12px;
  border-radius:10px;
  font-size:13px;
  font-weight:700;
}

.btn-ok{
  padding:8px 16px;border:1px solid rgba(34,197,94,.4);border-radius:10px;
  background:rgba(34,197,94,.12);color:var(--ok);cursor:pointer;
  font-size:13px;font-weight:600;
}
.btn-ok:hover{background:rgba(34,197,94,.25);border-color:var(--ok)}

.btn-success{
  padding:8px 16px;border:none;border-radius:10px;
  background:#27ae60;color:#fff;cursor:pointer;
  font-size:13px;font-weight:600;
}
.btn-success:hover{background:#219a52}

.shift-editor-wrap{overflow:auto}
.shift-editor-table{min-width:1500px}
.shift-editor-table th,.shift-editor-table td{vertical-align:top;min-width:150px}
.shift-editor-sticky-col{
  position:sticky;
  left:0;
  z-index:2;
  background:#0f1730;
  min-width:120px !important;
}
.shift-editor-table thead .shift-editor-sticky-col{z-index:3}
.shift-assignment-select,
.shift-cell-input{
  width:100%;
  min-width:0;
  padding:8px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  color:var(--text);
}
.shift-cell-input{font-size:13px}
.shift-cell-input.is-error{border-color:rgba(239,68,68,.7);background:rgba(239,68,68,.08)}
.shift-helper-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.shift-preset-btn{margin:0;padding:6px 10px;font-size:12px}
.copy-panel{display:flex;flex-direction:column;gap:12px}
.copy-grid{display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:12px}
.copy-checkbox{display:flex;align-items:center;gap:8px;color:var(--text)}

/* Back link */
.back-link{
  display:inline-flex;align-items:center;gap:8px;
  margin-bottom:14px;padding:10px 14px;
  color:var(--text);text-decoration:none;
  font-size:16px;font-weight:700;line-height:1;
  border:1px solid rgba(255,255,255,.12);border-radius:12px;
  background:rgba(255,255,255,.04);
}
.back-link:hover{
  color:var(--text);
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.2);
}

/* ---- Cards ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin:14px 0}
.card{background:rgba(17,26,51,.7);border:1px solid var(--line);border-radius:16px;padding:14px 14px;margin:16px 0}
.dashboard-board{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  align-items:start;
}
.dashboard-column{
  display:flex;
  flex-direction:column;
  gap:18px;
  min-width:0;
}
.dashboard-widget{
  margin:0;
  min-width:0;
  padding:18px;
  background:linear-gradient(180deg, rgba(20,31,60,.92), rgba(12,20,41,.92));
  box-shadow:0 14px 32px rgba(0,0,0,.22);
}
.dashboard-widget-wide{
  grid-column:1 / -1;
}
.widget-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.widget-header h2{margin:0;font-size:18px;letter-spacing:.2px}
.widget-handle{
  width:34px;
  height:34px;
  flex:0 0 auto;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.03);
  color:var(--muted);
  cursor:grab;
  font-size:15px;
  line-height:1;
}
.widget-handle:hover{
  color:var(--text);
  border-color:rgba(59,130,246,.45);
  background:rgba(59,130,246,.14);
}
.widget-handle:active{cursor:grabbing}
.dashboard-widget.sortable-ghost{opacity:.35}
.dashboard-widget.sortable-chosen{transform:scale(.98)}
.dashboard-column.sortable-drag-target{
  outline:2px dashed rgba(59,130,246,.55);
  outline-offset:6px;
  border-radius:16px;
}

/* ---- KPI ---- */
.kpi-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:4px}
.kpi{border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:10px;background:rgba(255,255,255,.03)}
.kpi-label{font-size:12px;color:var(--muted)}
.kpi-value{font-size:22px;font-weight:800;margin-top:2px}
.kpi-link{display:block;transition:border-color .15s ease,background .15s ease,transform .15s ease}
.kpi-link:hover,.kpi-link:focus-visible{
  border-color:rgba(59,130,246,.45);
  background:rgba(59,130,246,.08);
  transform:translateY(-1px);
}

/* ---- Tables ---- */
.table-wrap{overflow:auto;border-radius:12px;border:1px solid rgba(255,255,255,.07);margin-bottom:16px}
.live-scroll{max-height:360px}
table{width:100%;border-collapse:collapse;background:rgba(0,0,0,.15)}
th,td{padding:10px 10px;border-bottom:1px solid rgba(255,255,255,.06);text-align:left;font-size:13px}
th{color:var(--muted);font-weight:600}
tr.highlight{background:rgba(234,179,8,.06)}
.dorm-select-row td{cursor:pointer}
.dorm-select-row:hover{background:rgba(59,130,246,.08)}

/* ---- Pills ---- */
.pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;border:1px solid rgba(255,255,255,.10)}
.pill.ok{border-color:rgba(34,197,94,.5);color:var(--ok)}
.pill.bad{border-color:rgba(239,68,68,.5);color:var(--bad)}
.pill.warn{border-color:rgba(234,179,8,.5);color:var(--warn)}
.pill.info{border-color:rgba(59,130,246,.5);color:var(--accent)}

/* ---- Messages ---- */
.messages{margin-bottom:12px}
.msg{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);margin-bottom:8px}
.msg.error{border-color:rgba(239,68,68,.35)}
.msg.success{border-color:rgba(34,197,94,.35)}

/* ---- Auth ---- */
.auth{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:18px}
.auth-card{width:420px;max-width:100%;border:1px solid var(--line);background:rgba(17,26,51,.8);border-radius:18px;padding:18px}
.auth-card h1{margin:0 0 6px 0}
.auth-card form{display:grid;gap:10px;margin-top:10px}
.auth-card input{padding:10px 12px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text)}
.auth-card button{padding:10px 12px;border-radius:12px;border:1px solid rgba(59,130,246,.5);background:rgba(59,130,246,.15);color:var(--text);font-weight:700;cursor:pointer}
.auth-links{margin-top:10px}
.auth-links a{color:var(--muted)}

/* ---- Forms ---- */
.form-grid{display:grid;gap:10px}
.form-grid label{color:var(--muted);font-size:13px;font-weight:600}
.form-grid input,.form-grid select,.form-grid textarea{
  padding:10px 12px;border-radius:12px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text)
}
.form-grid input::placeholder{color:var(--muted);opacity:.6}
.form-grid textarea{resize:vertical}
.form-grid button{padding:10px 12px;border-radius:12px;border:1px solid rgba(59,130,246,.5);background:rgba(59,130,246,.15);color:var(--text);font-weight:700;cursor:pointer}
.form-grid button:hover{background:rgba(59,130,246,.25)}
.form-actions{grid-column:1/-1;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.form-actions .btn{margin:0}

/* Fieldsets */
fieldset,.fieldset{
  border:1px solid var(--line);padding:14px;border-radius:12px;margin-top:8px;
  background:rgba(255,255,255,.02);
}
fieldset legend,.fieldset legend{color:var(--text);font-weight:600;font-size:14px;padding:0 6px}

/* Info box (read-only info panel) */
.info-box{
  padding:12px;background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.15);
  border-radius:12px;margin:8px 0;color:var(--text);font-size:13px;
}

/* Confirm dialog */
.confirm-box{
  margin-top:12px;padding:14px;border:1px solid rgba(239,68,68,.3);
  border-radius:12px;background:rgba(239,68,68,.06);
}

/* Detail grid */
.detail-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;
}
.detail-item{padding:10px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.02)}
.detail-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}
.detail-value{font-size:14px;font-weight:600}

/* ---- Autocomplete dropdown (custom JS) ---- */
.autocomplete-results{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;
  background:var(--card-solid);border:1px solid var(--line);
  border-radius:0 0 12px 12px;max-height:260px;overflow-y:auto;
  box-shadow:0 8px 24px rgba(0,0,0,.5);
}
.autocomplete-anchor{position:relative;overflow:visible}
.autocomplete-results .ac-item{
  padding:10px 12px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);
  color:var(--text);font-size:13px;transition:background .1s;
}
.autocomplete-results .ac-item:last-child{border-bottom:none}
.autocomplete-results .ac-item:hover,.autocomplete-results .ac-item.active{
  background:var(--hover-bg-strong);color:#fff;
}
.autocomplete-results .ac-empty{
  padding:10px 12px;color:var(--muted);font-size:13px;
}

/* ---- Tom Select dark theme ---- */
.ts-wrapper.single .ts-control,
.ts-wrapper.multi .ts-control{
  background:var(--input-bg) !important;
  border:1px solid var(--input-border) !important;
  border-radius:12px !important;
  color:var(--text) !important;
  padding:8px 12px !important;
  min-height:40px;
}
.ts-wrapper .ts-control input{color:var(--text) !important}
.ts-wrapper .ts-control input::placeholder{color:var(--muted) !important;opacity:.7}
.ts-wrapper.focus .ts-control{
  border-color:var(--accent) !important;
  box-shadow:0 0 0 2px rgba(59,130,246,.15) !important;
}
.ts-dropdown{
  background:var(--card-solid) !important;
  border:1px solid var(--line) !important;
  border-radius:12px !important;
  margin-top:4px !important;
  color:var(--text) !important;
  box-shadow:0 8px 24px rgba(0,0,0,.4) !important;
}
.ts-dropdown .option{color:var(--text) !important;padding:9px 12px !important}
.ts-dropdown .option:hover,.ts-dropdown .active{background:var(--hover-bg-strong) !important;color:#fff !important}
.ts-dropdown .option.selected{background:rgba(59,130,246,.1) !important}
.ts-dropdown .ts-dropdown-content{max-height:240px}
.ts-wrapper .ts-control .item{
  background:rgba(59,130,246,.15) !important;border:1px solid rgba(59,130,246,.3) !important;
  border-radius:8px !important;color:var(--text) !important;
}
.ts-wrapper .ts-control>.ts-input-wrap>input{color:var(--text) !important}
.ts-dropdown .no-results{color:var(--muted) !important;padding:9px 12px !important}

/* ---- Flatpickr dark overrides ---- */
.flatpickr-calendar{
  background:var(--card-solid) !important;border:1px solid var(--line) !important;
  border-radius:12px !important;box-shadow:0 8px 24px rgba(0,0,0,.5) !important;
  font-family:'Inter',system-ui,sans-serif !important;
}
.flatpickr-months .flatpickr-month,.flatpickr-current-month .flatpickr-monthDropdown-months{background:transparent !important;color:var(--text) !important}
.flatpickr-current-month input.cur-year{color:var(--text) !important}
.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{fill:var(--text) !important;color:var(--text) !important}
.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{fill:var(--accent) !important;color:var(--accent) !important}
span.flatpickr-weekday{color:var(--muted) !important;font-weight:600}
.flatpickr-day{color:var(--text) !important;border-radius:8px !important}
.flatpickr-day:hover,.flatpickr-day:focus{background:var(--hover-bg-strong) !important;border-color:transparent !important}
.flatpickr-day.selected,.flatpickr-day.selected:hover{background:var(--accent) !important;border-color:var(--accent) !important;color:#fff !important}
.flatpickr-day.today{border-color:var(--accent) !important}
.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:var(--muted) !important;opacity:.4}
.flatpickr-time{border-top:1px solid var(--line) !important}
.flatpickr-time input,.flatpickr-time .flatpickr-am-pm{color:var(--text) !important}
.flatpickr-time input:hover,.flatpickr-time input:focus{background:rgba(59,130,246,.1) !important}
.numInputWrapper:hover{background:var(--hover-bg) !important}
.numInputWrapper span{border-color:var(--muted) !important}
.numInputWrapper span:hover{background:var(--hover-bg-strong) !important}
.flatpickr-monthDropdown-months option{background:var(--card-solid) !important;color:var(--text) !important}
.flatpickr-input.flatpickr-input[readonly]{cursor:pointer}

/* ---- Checkbox rows ---- */
.check-row{
  display:flex;align-items:center;gap:10px;padding:8px 10px;
  border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;
  border-radius:6px;font-size:13px;transition:background .1s;
}
.check-row:last-child{border-bottom:none}
.check-row:hover{background:rgba(59,130,246,.06)}
.check-row input[type="checkbox"]{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}

/* ---- Tabs ---- */
.tabs{display:flex;gap:2px;margin-bottom:18px}
.tab{
  padding:10px 20px;border:1px solid var(--line);border-bottom:none;
  border-radius:12px 12px 0 0;background:rgba(255,255,255,.03);
  color:var(--muted);font-size:13.5px;font-weight:500;cursor:pointer;
  transition:all .15s ease;
}
.tab:hover{background:var(--hover-bg);color:var(--text)}
.tab.active{background:rgba(59,130,246,.14);color:#fff;font-weight:700;border-color:var(--accent);border-bottom:2px solid var(--bg)}
.tab .badge{
  display:inline-block;background:var(--bad);color:#fff;border-radius:10px;
  padding:1px 7px;font-size:11px;font-weight:700;margin-left:6px;vertical-align:middle;
}

/* ---- Tag Input ---- */
.tag-input{
  position:relative;display:flex;flex-wrap:wrap;align-items:center;gap:4px;
  min-height:38px;padding:4px 6px;
  border:1px solid var(--input-border);border-radius:10px;
  background:var(--input-bg);cursor:text;
  transition:border-color .15s;
}
.tag-input:focus-within{
  border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(59,130,246,.15);
}
.tag-input .tag-text{
  border:none !important;background:transparent !important;
  padding:4px 2px !important;min-width:80px;flex:1;
  font-size:12px;outline:none;box-shadow:none !important;
  color:var(--text);
}
.tag{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:8px;font-size:12px;font-weight:500;
  background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);
  color:var(--text);white-space:nowrap;
}
.tag .tag-remove{
  background:none;border:none;color:var(--muted);cursor:pointer;
  font-size:14px;line-height:1;padding:0 0 0 2px;
  transition:color .1s;
}
.tag .tag-remove:hover{color:var(--bad)}

/* ---- Wizard ---- */
.wizard-steps{
  display:flex;gap:4px;margin-bottom:20px;overflow-x:auto;
}
.wizard-step{
  display:flex;align-items:center;gap:8px;padding:10px 16px;
  border:1px solid var(--line);border-radius:12px;
  background:rgba(255,255,255,.02);font-size:13px;color:var(--muted);
  white-space:nowrap;transition:all .2s;
}
.wizard-step .step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  border:2px solid var(--line);font-weight:700;font-size:13px;
  transition:all .2s;
}
.wizard-step.active{
  border-color:var(--accent);color:var(--text);background:rgba(59,130,246,.08);
}
.wizard-step.active .step-num{
  border-color:var(--accent);background:var(--accent);color:#fff;
}
.wizard-step.done{
  border-color:rgba(34,197,94,.3);color:var(--ok);
}
.wizard-step.done .step-num{
  border-color:var(--ok);background:var(--ok);color:#fff;
}
.wizard-options{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;
}
.wizard-option{
  cursor:pointer;display:block;
}
.wizard-option input[type="radio"]{display:none}
.wizard-option .option-card{
  display:flex;flex-direction:column;gap:4px;padding:14px;
  border:1px solid var(--line);border-radius:12px;
  background:rgba(255,255,255,.02);transition:all .15s;
}
.wizard-option:hover .option-card{
  border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.06);
}
.wizard-option input:checked + .option-card{
  border-color:var(--accent);background:rgba(59,130,246,.12);
  box-shadow:0 0 0 2px rgba(59,130,246,.2);
}
.wizard-option .option-title{font-weight:600;font-size:14px}
.wizard-option-disabled{opacity:.5;pointer-events:none}
.wizard-option-disabled .option-card{
  padding:14px;border:1px solid var(--line);border-radius:12px;
  background:rgba(255,255,255,.01);display:flex;flex-direction:column;gap:4px;
}

/* ---- Global: ensure all inputs/selects/textareas respect dark theme ---- */
input,select,textarea{
  color:var(--text);background:var(--input-bg);
  border:1px solid var(--input-border);border-radius:12px;
  padding:10px 12px;font-family:inherit;font-size:13px;
}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:.6}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(59,130,246,.15);
}
select option{background:var(--card-solid);color:var(--text)}

/* Summary/details */
summary{cursor:pointer;color:var(--text);font-size:13px}
details{margin:4px 0}

@media (max-width: 900px){
  .dashboard-board{grid-template-columns:1fr}
  .dashboard-column{gap:14px}
  .kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width: 640px){
  .kpi-row{grid-template-columns:1fr}
  .dashboard-widget{padding:14px}
}
