/* ============================================================================
   styles.css — Production Manager
   A calm, simple look. Light by default; respects your Mac's dark mode.
   ============================================================================ */

/* Monochrome palette in Notion's warm-neutral key (greys carry a subtle warm tint). */
:root {
  --bg: #f7f6f4;
  --panel: #ffffff;
  --ink: #37352f;
  --ink-soft: #787774;
  --line: #eae8e3;
  --accent: #37352f;
  --accent-soft: #ecebe7;
  --on-accent: #ffffff;     /* text/icon colour on top of an --accent or --danger fill */
  --hover: rgba(55, 53, 47, 0.055);   /* Notion-style subtle hover wash */
  --ok: #37352f;
  --warn: #787774;
  --danger: #37352f;
  --tint: #f1f0ec;          /* neutral background tint (replaces the old warm/red tints) */
  --tint-line: #e6e3dc;     /* border for tinted chips/badges */
  /* The three accents kept on top of the monochrome base */
  --green: #2e9b6c;         /* progress bars, delivered */
  --green-soft: #e3f3ea;    /* delivered pill background */
  --green-line: #c2e3d1;
  --orange: #cb7b2e;        /* deadline pills (informational) */
  --orange-soft: #f8ecdd;
  --orange-line: #ecd6ba;
  --alert: #e3322c;         /* bright red — gear clashes / overbooking / warnings */
  --alert-soft: #fdecea;
  --alert-line: #f6c4c1;
  --red: #e3322c;           /* delete / destructive actions — bright red */
  --shadow: 0 1px 2px rgba(15, 15, 15, 0.06), 0 6px 20px rgba(15, 15, 15, 0.08);
  --radius: 12px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #191919;
    --panel: #262624;
    --ink: #e9e8e5;
    --ink-soft: #989792;
    --line: #34332f;
    --accent: #e9e8e5;
    --accent-soft: #2f2e2b;
    --on-accent: #191919;
    --hover: rgba(255, 255, 255, 0.055);
    --ok: #e9e8e5;
    --warn: #b4b3ad;
    --danger: #e9e8e5;
    --tint: #2b2a27;
    --tint-line: #3a3934;
    --green: #4cc38a;
    --green-soft: #1d3328;
    --green-line: #2f5743;
    --alert: #f1554e;
    --alert-soft: #3a1d1c;
    --alert-line: #5e2e2b;
    --orange: #e0934d;
    --orange-soft: #322619;
    --orange-line: #56432a;
    --red: #f1554e;
    --shadow: 0 1px 3px rgba(0,0,0,0.4), 0 6px 20px rgba(0,0,0,0.32);
  }
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  height: 100%;
  background: var(--bg);
  color: var(--ink);
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Segoe UI', sans-serif;
}

button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; }

/* ---------- Sidebar (collapsible icon rail) ---------- */
:root { --sb-w: 64px; --sb-w-open: 218px; --topbar-h: 0px; }
#app { margin-left: var(--sb-w); transition: margin-left .16s ease; }
body.sb-pinned #app { margin-left: var(--sb-w-open); }
.brand .dot, .signin-brand .dot { width: 11px; height: 11px; border-radius: 50%; background: var(--accent); display: inline-block; flex: 0 0 auto; }

.sidebar {
  position: fixed; top: 0; bottom: 0; left: 0; width: var(--sb-w); z-index: 40;
  background: var(--panel); border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 6px; padding: 12px 10px;
  overflow: hidden; transition: width .16s ease, box-shadow .16s ease;
  transform: translateZ(0); will-change: width;   /* own compositor layer → no scroll jitter */
}
.sidebar.expanded { width: var(--sb-w-open); }
.sidebar.expanded:not(.pinned) { box-shadow: var(--shadow); }

.sb-head { display: flex; align-items: center; gap: 9px; padding: 0 4px 12px; margin-bottom: 8px; border-bottom: 1px solid var(--line); }
.sb-brand {
  flex: 1; min-width: 0; height: 34px;
  background-repeat: no-repeat; background-position: center; background-size: contain;
  background-image: url('assets/logo-icon-square-black.svg');
}
.sidebar.expanded .sb-brand {
  background-position: left center; background-image: url('assets/logo-landscape-black.svg');
}
@media (prefers-color-scheme: dark) {
  .sb-brand { background-image: url('assets/logo-icon-white.svg'); }
  .sidebar.expanded .sb-brand { background-image: url('assets/logo-landscape-white.svg'); }
}
.sb-pin {
  border: none; background: none; color: var(--ink-soft);
  width: 30px; height: 30px; border-radius: 7px; flex: 0 0 auto;
  display: none; align-items: center; justify-content: center; transition: background .12s, color .12s;
}
.sb-pin svg { width: 19px; height: 19px; }
.sidebar.expanded .sb-pin { display: flex; }
.sb-pin:hover { background: var(--hover); color: var(--ink); }
/* Base icon points «  (collapse). When pinned-open it stays « (= "collapse").
   When only hover-expanded (not pinned) it flips to » (= "pin open / keep"). */
/* When the menu is pinned out, the toggle shows a "selected" look like an active nav item */
.sidebar.pinned .sb-pin { background: var(--tint); color: var(--ink); }
.sidebar.pinned .sb-pin:hover { background: var(--tint); }
.sidebar.expanded:not(.pinned) .sb-pin { transform: rotate(180deg); }

.sb-nav { display: flex; flex-direction: column; gap: 4px; }
.sb-foot { margin-top: auto; display: flex; flex-direction: column; gap: 4px; padding-top: 10px; border-top: 1px solid var(--line); }
.sb-item, .sb-util {
  display: flex; align-items: center; gap: 13px; width: 100%;
  border: none; background: none; color: var(--ink-soft); text-align: left;
  padding: 9px 8px; border-radius: 7px; font-weight: 500; font-size: 14px;
}
.sb-ico { flex: 0 0 26px; width: 26px; height: 22px; display: flex; align-items: center; justify-content: center; }
.sb-ico svg { width: 20px; height: 20px; }
.sb-text { white-space: nowrap; opacity: 0; transition: opacity .12s; }
.sidebar.expanded .sb-text { opacity: 1; }
.sb-item:hover, .sb-util:hover { background: var(--hover); color: var(--ink); }
.sb-item.active { background: var(--tint); color: var(--ink); font-weight: 600; }
.sb-foot #user-switcher { display: block; }
.sb-foot #user-switcher .user-btn { width: 100%; border: none; background: none; padding: 9px 8px; gap: 13px; border-radius: 7px; }
.sb-foot #user-switcher .user-btn:hover { background: var(--hover); }
/* avatar left edge aligns with the nav-icon column so it centres in the collapsed rail */
.sb-foot #user-switcher .user-btn .avatar { flex: 0 0 auto; margin: 0 0 0 -1px; }
.sb-foot #user-switcher .user-btn > span:not(.avatar) { white-space: nowrap; opacity: 0; transition: opacity .12s; }
.sidebar.expanded #user-switcher .user-btn > span:not(.avatar) { opacity: 1; }

.btn {
  border: 1px solid var(--line); background: var(--panel); color: var(--ink);
  padding: 8px 14px; border-radius: 8px; font-weight: 600;
  text-decoration: none; display: inline-flex; align-items: center; justify-content: center;
}
.btn:hover { border-color: var(--accent); color: var(--accent); }
.btn.primary { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.btn.primary:hover { filter: brightness(1.05); color: var(--on-accent); }
.btn.ghost { border-color: transparent; background: transparent; color: var(--ink-soft); }
.btn.ghost:hover { color: var(--red); }
.btn.small { padding: 5px 10px; font-size: 13px; }

/* ---------- Layout ---------- */
.view { padding: 22px 24px 60px; }
.view-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.view-head h1 { font-size: 22px; margin: 0; letter-spacing: -0.3px; }
.view-head .spacer { flex: 1; }
.muted { color: var(--ink-soft); }

/* ---------- Board ---------- */
/* Columns flex to fit the width (never scroll sideways); the PAGE scrolls vertically. */
.board-page { padding: 22px 24px 40px; }
.board { display: flex; gap: 14px; align-items: flex-start; }
.column {
  flex: 1 1 0; min-width: 0; display: flex; flex-direction: column;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px;
}
.col-body { display: flex; flex-direction: column; }
.column.drop-hover { border-color: var(--accent); background: var(--accent-soft); }
.column-head { display: flex; align-items: center; gap: 8px; margin: 2px 4px 12px; flex: 0 0 auto; }
.column-head .name { font-weight: 700; font-size: 14px; }
.column-head .count {
  margin-left: auto; font-size: 12px; color: var(--ink-soft);
  background: var(--bg); border-radius: 20px; padding: 2px 9px;
}

.card {
  background: var(--bg); border: 1px solid var(--line);
  border-radius: 10px; padding: 12px; margin-bottom: 10px; cursor: pointer;
  transition: border-color .12s, transform .05s;
}
.card:hover { border-color: var(--accent); }
.card:active { transform: scale(0.995); }
.card.dragging { opacity: .4; }
.card .title { font-weight: 650; margin-bottom: 3px; }
.card .client { font-size: 13px; color: var(--ink-soft); margin-bottom: 9px; }
.card .meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

.badge {
  font-size: 12px; padding: 2px 8px; border-radius: 20px;
  background: var(--bg); border: 1px solid var(--line); color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 5px;
}
.badge.due { background: var(--orange-soft); border-color: var(--orange-line); color: var(--orange); }
.badge.overdue { background: var(--tint); border-color: var(--tint-line); color: var(--danger); }
.badge.ok { background: var(--green-soft); border-color: var(--green-line); color: var(--green); }
@media (prefers-color-scheme: dark) {
  .badge.due { background: var(--orange-soft); border-color: var(--orange-line); }
  .badge.overdue { background: var(--tint); border-color: var(--tint-line); }
  .badge.ok { background: var(--green-soft); border-color: var(--green-line); }
}

.progress { height: 6px; background: var(--line); border-radius: 6px; overflow: hidden; margin-top: 10px; }
.progress > span { display: block; height: 100%; background: var(--green); }

.column .add-card {
  width: 100%; text-align: left; color: var(--ink-soft);
  border: 1px dashed var(--line); background: transparent; border-radius: 10px; padding: 10px;
}
.column .add-card:hover { border-color: var(--accent); color: var(--accent); }

/* ---------- Equipment ---------- */
.eq-search { position: relative; max-width: 440px; margin-bottom: 22px; }
.eq-search-ico { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; color: var(--ink-soft); pointer-events: none; }
.eq-search-input {
  width: 100%; padding: 10px 12px 10px 36px; font: inherit;
  border: 1px solid var(--line); border-radius: 9px; background: var(--panel); color: var(--ink);
}
.eq-search-input::placeholder { color: var(--ink-soft); }
.eq-search-input:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.eq-match { font-size: 12px; font-weight: 600; color: var(--accent); background: var(--accent-soft); border-radius: 5px; padding: 1px 7px; margin-left: 4px; }
.eq-group { margin-bottom: 22px; }
.eq-group h2 { font-size: 17px; margin: 0 0 10px; display: flex; align-items: center; gap: 8px; }
.eq-table {
  width: 100%; background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); border-collapse: separate; border-spacing: 0; overflow: hidden;
}
.eq-table th, .eq-table td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); }
.eq-table th { font-size: 12px; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); }
.eq-table tr:last-child td { border-bottom: none; }
.eq-table tr.clickable:hover td { background: var(--bg); cursor: pointer; }
.tag { font-size: 12px; padding: 2px 8px; border-radius: 6px; background: var(--accent-soft); color: var(--accent); }
.tag.rental { background: var(--tint); color: var(--warn); }
@media (prefers-color-scheme: dark) { .tag.rental { background: var(--tint); } }

/* ---------- Slide-over panel ---------- */
.scrim {
  position: fixed; inset: 0; background: rgba(15,20,28,0.45);
  opacity: 0; pointer-events: none; transition: opacity .18s; z-index: 30;
}
.scrim.open { opacity: 1; pointer-events: auto; }
.panel {
  position: fixed; top: 0; right: 0; height: 100%; width: 560px; max-width: 96vw;
  background: var(--panel); box-shadow: var(--shadow); z-index: 40;
  transform: translateX(100%); transition: transform .2s ease;
  display: flex; flex-direction: column;
}
.panel.open { transform: translateX(0); }
.panel-head { display: flex; align-items: center; gap: 10px; padding: 16px 20px; border-bottom: 1px solid var(--line); }
.panel-head h2 { margin: 0; font-size: 17px; }
.panel-body { padding: 18px 20px; overflow-y: auto; overflow-x: hidden; flex: 1; }
.panel-foot { padding: 14px 20px; border-top: 1px solid var(--line); display: flex; gap: 10px; }

.field { margin-bottom: 14px; }
.field label { display: block; font-size: 12px; font-weight: 600; color: var(--ink-soft); margin-bottom: 5px; text-transform: uppercase; letter-spacing: .3px; }
.field input, .field select, .field textarea {
  width: 100%; padding: 9px 11px; border: 1px solid var(--line);
  border-radius: 8px; background-color: var(--bg); color: var(--ink);
}
.field select { padding-right: 34px; } /* room for the custom dropdown arrow from the base select rule */
.field input:focus, .field select:focus, .field textarea:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.field textarea { resize: vertical; min-height: 64px; }
.field-row { display: flex; gap: 12px; }
.field-row .field { flex: 1; }

.section-title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); margin: 22px 0 10px; }

/* tasks */
.task { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); }
.task input[type=checkbox] { width: 17px; height: 17px; accent-color: var(--accent); }
.task .t-title { flex: 1; }
.task.done .t-title { text-decoration: line-through; color: var(--ink-soft); }
.task .t-due { font-size: 12px; color: var(--ink-soft); }
.task .t-due.overdue { color: var(--danger); }
.deliv-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); }
.deliv-row input[type=checkbox] { width: 17px; height: 17px; accent-color: var(--accent); flex: 0 0 auto; }
.deliv-title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.deliv-row.done .deliv-title { text-decoration: line-through; color: var(--ink-soft); }
.editable-text { cursor: text; border-radius: 5px; margin: 0 -5px; padding: 0 5px; transition: background .12s; }
.editable-text:hover { background: var(--hover); }
.inline-edit {
  flex: 1; min-width: 0; font: inherit; font-weight: 600;
  border: 1px solid var(--accent); border-radius: 6px; padding: 3px 7px;
  background: var(--panel); color: var(--ink);
}
.inline-edit:focus { outline: none; box-shadow: 0 0 0 2px var(--accent-soft); }
.inline-add { display: flex; gap: 8px; margin-top: 10px; }
.inline-add input { flex: 1; min-width: 0; padding: 9px 11px; min-height: 43px; box-sizing: border-box; border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--ink); }
.inline-add input:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }

/* reservations / gear list inside project */
.res { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--line); }
.res .r-name { flex: 1; font-weight: 600; }
.res .r-dates { font-size: 12px; color: var(--ink-soft); }

.conflict {
  background: var(--alert-soft); border: 1px solid var(--alert-line); color: var(--alert);
  border-radius: 8px; padding: 9px 12px; font-size: 13px; margin-top: 8px;
}
@media (prefers-color-scheme: dark) { .conflict { background: var(--alert-soft); border-color: var(--alert-line); color: var(--alert); } }

.empty { text-align: center; color: var(--ink-soft); padding: 30px; font-size: 14px; }

/* tiny helper buttons */
.icon-btn { border: none; background: none; color: var(--ink-soft); padding: 4px 7px; border-radius: 6px; font-size: 15px; }
.icon-btn:hover { background: var(--bg); color: var(--red); }
.dup-btn { display: inline-flex; align-items: center; justify-content: center; }
.dup-btn:hover { background: var(--accent-soft); color: var(--accent); }

/* ---------- Dashboard ---------- */
.greet-title { margin: 0; font-size: 22px; letter-spacing: -0.3px; }
.greet-title .wave { font-size: 20px; }
.greet-sub { color: var(--ink-soft); font-size: 14px; margin-top: 4px; }

/* dashboard fills the viewport (no page scroll): banner + KPI rows, then two tall boxes */
.dash-fill {
  height: calc(100vh - var(--topbar-h, 52px));
  box-sizing: border-box; padding: 16px 24px;
  display: flex; flex-direction: column; gap: 16px;
  overflow: hidden;
}
.dash-fill .dash-hero { margin-bottom: 0; flex: 0 0 auto; }
.dash-fill .stats { flex: 0 0 auto; }
.dash-lower { flex: 1; min-height: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.quad {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 16px 18px; display: flex; flex-direction: column; min-height: 0; min-width: 0; overflow: hidden;
}
.quad-banner { background: var(--accent-soft); border-color: transparent; justify-content: center; }
.quad-head { flex: 0 0 auto; margin-bottom: 12px; }
.quad-title { font-size: 17px; font-weight: 700; margin-bottom: 10px; }
.quad-body { flex: 1; min-height: 0; overflow-y: auto; overflow-x: hidden; padding-right: 10px; margin-right: -4px; scrollbar-gutter: stable; }
.quad-body::-webkit-scrollbar { width: 8px; }
.quad-body::-webkit-scrollbar-thumb { background: var(--line); border-radius: 8px; }
.quad-body::-webkit-scrollbar-thumb:hover { background: var(--ink-soft); }
.quad-body::-webkit-scrollbar-track { background: transparent; }
.stats.kpi-grid { grid-template-columns: repeat(auto-fit, minmax(155px, 1fr)); gap: 10px; align-content: start; }
.kpi-grid .stat { padding: 12px 14px; }
.kpi-grid .stat-value { font-size: 21px; }
.kpi-grid .stat-label { font-size: 12px; }
@media (max-width: 820px) {
  .dash-fill { height: auto; overflow: visible; }
  .dash-lower { grid-template-columns: 1fr; }
  .quad { min-height: 220px; }
  .quad-body { overflow: visible; }
}

.dash-hero {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 20px 24px; margin-bottom: 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
}
.today-tiles { display: flex; gap: 12px; }
.today-tile { background: var(--bg); border: 1px solid var(--line); border-radius: 10px; padding: 10px 18px; min-width: 88px; text-align: center; cursor: pointer; }
.today-tile:hover { border-color: var(--accent); }
.today-tile.static { cursor: default; }
.today-tile.static:hover { border-color: var(--line); }
.tt-num { font-size: 22px; font-weight: 750; letter-spacing: -0.5px; line-height: 1.1; }
.tt-lbl { font-size: 11px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: .3px; margin-top: 3px; }
.today-tile.alert .tt-num { color: var(--danger); }
.today-clear { font-size: 15px; color: var(--ink-soft); background: var(--bg); border: 1px solid var(--line); border-radius: 10px; padding: 14px 20px; }

/* ---------- Sign-in ---------- */
.signin-overlay { position: fixed; inset: 0; z-index: 45; background: var(--bg); display: flex; align-items: center; justify-content: center; padding: 24px; }
.signin-card { background: var(--panel); border: 1px solid var(--line); border-radius: 16px; box-shadow: var(--shadow); padding: 36px 40px; max-width: 540px; width: 100%; text-align: center; }
.signin-brand {
  height: 46px; width: 220px; margin: 0 auto 24px;
  background: url('assets/logo-landscape-black.svg') no-repeat center/contain;
}
@media (prefers-color-scheme: dark) { .signin-brand { background-image: url('assets/logo-landscape-white.svg'); } }
.signin-title { font-size: 23px; font-weight: 700; margin-bottom: 24px; letter-spacing: -0.3px; }
.signin-people { display: grid; grid-template-columns: repeat(auto-fill, minmax(124px, 1fr)); gap: 14px; }
.signin-person { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 18px 12px; border: 1px solid var(--line); border-radius: 12px; background: var(--bg); color: var(--ink); cursor: pointer; font-weight: 600; font-size: 14px; }
.signin-person:hover { border-color: var(--accent); background: var(--accent-soft); }

/* email + password auth form */
.signin-card.signin-auth { max-width: 380px; }
.signin-auth .signin-title { margin-bottom: 18px; }
.signin-form { display: flex; flex-direction: column; gap: 10px; text-align: left; }
.signin-input { width: 100%; padding: 11px 13px; font: inherit; border: 1px solid var(--line); border-radius: 9px; background: var(--bg); color: var(--ink); box-sizing: border-box; }
.signin-input:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.signin-input::placeholder { color: var(--ink-soft); }
.signin-err { color: var(--red); font-size: 13px; min-height: 16px; text-align: center; }
.signin-submit { width: 100%; padding: 11px; font-size: 15px; margin-top: 2px; }
.signin-toggle { border: none; background: none; color: var(--ink-soft); font: inherit; font-size: 13px; cursor: pointer; padding: 8px; margin-top: 2px; }
.signin-toggle:hover { color: var(--ink); text-decoration: underline; }
.prof-av-row { display: flex; align-items: center; gap: 14px; }

.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; }
.stat {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 16px 18px;
}
.stat.good { border-color: var(--tint-line); }
.stat.bad { border-color: var(--alert-line); background: var(--alert-soft); }
.stat.bad .stat-value { color: var(--alert); }
.stat.bad .stat-label, .stat.bad .stat-sub { color: var(--alert); }
.stat.warn { border-color: var(--tint-line); background: var(--tint); }
.stat.warn .stat-value { color: var(--warn); }
@media (prefers-color-scheme: dark) { .stat.bad { border-color: var(--alert-line); background: var(--alert-soft); } .stat.warn { border-color: var(--tint-line); background: var(--tint); } }
.stat.clickable { cursor: pointer; }
.stat.clickable:hover { border-color: var(--accent); }

/* gear-clash popup rows */
.clash-row { padding: 10px 0; border-bottom: 1px solid var(--line); }
.clash-row:last-child { border-bottom: none; }
.clash-name { font-weight: 650; color: var(--alert); }
.clash-detail { font-size: 13px; color: var(--ink-soft); margin: 3px 0 5px; }
.clash-projects { display: flex; flex-wrap: wrap; gap: 12px; }

/* equipment bundles */
.bundle-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.bundle-card { text-align: left; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 12px 14px; cursor: pointer; }
.bundle-card:hover { border-color: var(--accent); }
.bundle-name { font-weight: 650; margin-bottom: 3px; }
.bundle-items { font-size: 12px; color: var(--ink-soft); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
@media (prefers-color-scheme: dark) { .stat.good { border-color: var(--tint-line); } }
.stat-value { font-size: 26px; font-weight: 750; letter-spacing: -0.5px; }
.stat.good .stat-value { color: var(--ok); }
.stat-label { color: var(--ink-soft); font-size: 13px; margin-top: 2px; }
.stat-sub { color: var(--ink-soft); font-size: 11px; margin-top: 2px; opacity: .8; }

.inline-label { font-size: 13px; color: var(--ink-soft); display: flex; align-items: center; gap: 6px; }
.inline-label select { padding: 6px 9px; border: 1px solid var(--line); border-radius: 8px; background: var(--panel); color: var(--ink); }

/* This-week strip */
.week-strip { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.week-cell { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 9px; min-height: 124px; display: flex; flex-direction: column; gap: 4px; }
.week-cell.today { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
.wc-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 2px; }
.wc-dow { font-size: 11px; text-transform: uppercase; letter-spacing: .3px; color: var(--ink-soft); }
.wc-num { font-size: 16px; font-weight: 700; }
.wc-pill { display: inline-flex; align-items: center; text-align: left; border: 1px solid var(--line); background: var(--bg); color: var(--ink-soft); border-radius: 20px; padding: 3px 9px; font-size: 11px; cursor: default; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }
.wc-pill.shoot { background: var(--accent-soft); border-color: transparent; color: var(--accent); cursor: pointer; }
.wc-pill.deadline { background: var(--tint); border-color: var(--tint-line); color: var(--warn); cursor: pointer; }
.wc-pill.task { margin-top: auto; }
.wc-pill.shoot:hover, .wc-pill.deadline:hover { filter: brightness(.97); }
@media (prefers-color-scheme: dark) { .wc-pill.deadline { background: var(--tint); border-color: var(--tint-line); } }
@media (max-width: 760px) { .week-strip { grid-template-columns: repeat(4, 1fr); } }

/* Dashboard two-column layout */
.dash-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; margin-top: 26px; }
@media (max-width: 880px) { .dash-cols { grid-template-columns: 1fr; } }
.dash-col { min-width: 0; }
.dash-cols.equal-height { align-items: stretch; }
.shoot-list.one-col { grid-template-columns: 1fr; }
.shoot-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; align-content: start; }
.shoot-card.mini { padding: 13px 15px; gap: 12px; }
.shoot-card.mini .shoot-date { width: 50px; padding: 7px 0; }
.shoot-card.mini .sd-day { font-size: 21px; }
.shoot-card.mini .shoot-proj { font-size: 15px; }
.shoot-card.mini .shoot-sub { margin-top: 2px; }

/* Calendar (Schedule view) */
/* Full-height calendar: fills the viewport; month nav lives inline in the page header */
.schedule-page { height: 100vh; box-sizing: border-box; padding: 22px 24px; display: flex; flex-direction: column; overflow: hidden; }
.sched-head { display: grid; grid-template-columns: 1fr 220px 1fr; align-items: center; gap: 12px; }
.sched-head > h1 { justify-self: start; }
.sched-head > .segmented { justify-self: end; }
.schedule-page .view-head { flex: 0 0 auto; margin-bottom: 14px; }
/* block grid item fills its 220px column reliably; inline content is centred with text-align.
   NOTE: class is .month-nav (NOT .cal-nav — that's the date-picker's arrow button) */
.month-nav { display: block; width: 100%; text-align: center; white-space: nowrap; }
.month-nav .cal-arrow { display: inline-flex; align-items: center; justify-content: center; vertical-align: middle; font-size: 18px; color: var(--ink-soft); }
.month-nav .cal-arrow:hover { background: var(--hover); color: var(--ink); }
.month-nav .cal-month-title { display: inline-block; vertical-align: middle; font-size: 16px; font-weight: 700; min-width: 130px; text-align: center; }
.schedule-body { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.schedule-body.scroll { overflow-y: auto; }
.cal-wrap { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.month-wd-row { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; flex: 0 0 auto; }
.month-grid { display: grid; grid-template-columns: repeat(7, 1fr); grid-auto-rows: 1fr; gap: 6px; flex: 1; min-height: 0; margin-top: 6px; }
.month-wd { text-align: center; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); padding-bottom: 4px; }
.month-cell { background: var(--panel); border: 1px solid var(--line); border-radius: 9px; min-height: 0; padding: 6px; display: flex; flex-direction: column; gap: 3px; overflow-y: auto; }
.month-cell.blank { background: transparent; border: none; }
.month-cell.today { border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
.mc-num { font-size: 12px; font-weight: 700; color: var(--ink-soft); }
.month-cell.today .mc-num { color: var(--accent); }
.mc-event { text-align: left; border: none; background: var(--accent-soft); color: var(--accent); border-radius: 6px; padding: 3px 6px; font-size: 11px; cursor: pointer; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mc-event:hover { filter: brightness(.97); }
.mc-event.deadline { background: var(--tint); color: var(--warn); }
.mc-event.task { background: var(--bg); color: var(--ink-soft); border: 1px solid var(--line); }
@media (prefers-color-scheme: dark) { .mc-event.deadline { background: var(--tint); } }
.past-row td { opacity: .55; }

/* ---------- Metrics charts ---------- */
/* Full-height metrics: fills the viewport, charts scale to the available height */
.metrics-page { height: 100vh; box-sizing: border-box; padding: 22px 24px; display: flex; flex-direction: column; gap: 16px; overflow: hidden; }
.metrics-page .view-head { flex: 0 0 auto; margin-bottom: 0; }
.metrics-page .stats { flex: 0 0 auto; }
.metrics-lower { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 16px; }
.metrics-lower > .panel-card { flex: 1.25; min-height: 0; display: flex; flex-direction: column; margin: 0; }
.metrics-lower .dash-cols { flex: 1; min-height: 0; margin: 0; }
.metrics-lower .dash-cols .panel-card { min-height: 0; display: flex; flex-direction: column; }
.metrics-lower .panel-card > .section-title { flex: 0 0 auto; }
.metrics-lower .bar-chart { flex: 1; min-height: 0; }
.metrics-lower .hbars { flex: 1; min-height: 0; }
.metrics-head { display: flex; align-items: center; gap: 12px; flex: 0 0 auto; }
.metrics-head h1 { margin: 0; }
.metrics-head .spacer { flex: 1; }
.bar-chart { display: flex; align-items: flex-end; gap: 10px; height: 200px; padding-top: 10px; }
.bar-col { flex: 1; display: flex; flex-direction: column; align-items: center; height: 100%; }
.bar-val { font-size: 11px; font-weight: 600; color: var(--ink-soft); margin-bottom: 4px; height: 14px; }
.bar-wrap { flex: 1; width: 100%; display: flex; align-items: flex-end; justify-content: center; }
.bar { width: 70%; max-width: 34px; min-height: 0; background: var(--accent); border-radius: 5px 5px 0 0; transition: height .2s; }
.bar-col:hover .bar { background: var(--ink); }
.bar-label { font-size: 11px; color: var(--ink-soft); margin-top: 6px; }

.hbars { display: flex; flex-direction: column; gap: 9px; }
.hbar-row { display: flex; align-items: center; gap: 10px; }
.hbar-label { flex: 0 0 140px; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hbar-person { display: inline-flex; align-items: center; gap: 7px; }
.hbar-track { flex: 1; background: var(--bg); border-radius: 20px; height: 12px; overflow: hidden; }
.hbar-fill { height: 100%; background: var(--accent); border-radius: 20px; }
.hbar-val { flex: 0 0 auto; font-size: 12px; font-weight: 600; color: var(--ink-soft); min-width: 48px; text-align: right; }

/* User switcher in the top bar */
.user-btn { display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); background: var(--panel); color: var(--ink); border-radius: 20px; padding: 4px 12px 4px 5px; font-weight: 600; font-size: 13px; cursor: pointer; }
.user-btn:hover { border-color: var(--accent); }

/* Task filter chips (per-person workload + overdue) */
.filter-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.fchip { display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); background: var(--panel); color: var(--ink); border-radius: 20px; padding: 5px 11px; font-size: 13px; font-weight: 600; cursor: pointer; }
.fchip:hover { border-color: var(--accent); }
.fchip.active { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.fchip.danger { color: var(--danger); border-color: var(--tint-line); }
.fchip.danger.active { background: var(--danger); color: var(--on-accent); border-color: var(--danger); }
.fchip-person { display: inline-flex; align-items: center; gap: 6px; }
.fchip-count { font-size: 12px; opacity: .7; min-width: 14px; text-align: center; }
.fchip.active .fchip-count { opacity: .95; }

.card-list { display: flex; flex-direction: column; gap: 8px; }
.card-list.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 10px; }
.dash-section { margin-top: 26px; }
.task-row {
  display: flex; align-items: center; gap: 12px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px;
}
.task-row input[type=checkbox] { width: 17px; height: 17px; accent-color: var(--accent); flex: 0 0 auto; }
.task-mid { flex: 1; min-width: 0; }
.task-mid .t-title { font-weight: 600; }
.task-mid .t-sub { display: flex; align-items: center; gap: 8px; margin-top: 3px; }
.link { border: none; background: none; padding: 0; color: var(--accent); font-size: 13px; cursor: pointer; }
.link:hover { text-decoration: underline; }
.chip { font-size: 12px; padding: 1px 8px; border-radius: 20px; background: var(--accent-soft); color: var(--accent); }
.task-row .t-due { font-size: 13px; color: var(--ink-soft); flex: 0 0 auto; }
.task-row .t-due.soon { color: var(--warn); }
.task-row .t-due.overdue { color: var(--danger); font-weight: 600; }

/* ---------- Shoot days ---------- */
.day-card { display: flex; align-items: center; gap: 10px; background: var(--bg); border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px; margin-bottom: 10px; cursor: pointer; }
.day-card:hover { border-color: var(--accent); }
.day-card-main { flex: 1; min-width: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.day-crew { display: inline-flex; flex: 0 0 auto; }
.day-crew .avatar { margin-left: -6px; box-shadow: 0 0 0 2px var(--bg); }
.day-crew .avatar:first-child { margin-left: 0; }
.day-block { border: 1px solid var(--line); border-radius: 10px; padding: 11px 12px; margin-bottom: 10px; background: var(--bg); }
.day-head { display: flex; align-items: center; gap: 9px; margin-bottom: 8px; }
.day-date { font-weight: 700; }
.day-label { font-size: 12px; color: var(--ink-soft); }
.day-gear { }
.gear-group { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-bottom: 6px; }
.gear-cat { font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); flex: 0 0 58px; }
.gear-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; padding: 3px 4px 3px 10px; border-radius: 20px;
  background: var(--accent-soft); color: var(--accent);
}
.gear-chip.rental { background: var(--tint); color: var(--warn); }
@media (prefers-color-scheme: dark) { .gear-chip.rental { background: var(--tint); } }
.chip-x { border: none; background: none; color: inherit; cursor: pointer; font-size: 11px; opacity: .6; padding: 0 4px; border-radius: 50%; }
.chip-x:hover { opacity: 1; }

select.mini { padding: 6px 8px; border: 1px solid var(--line); border-radius: 7px; background: var(--bg); color: var(--ink); font-size: 13px; max-width: 100%; }

/* dropdowns styled to look and size exactly like text inputs (flat, custom arrow) */
select {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  padding: 9px 34px 9px 11px;
  border: 1px solid var(--line); border-radius: 8px;
  background-color: var(--bg); color: var(--ink);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' fill='none' stroke='%238a96a3' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 11px center; background-size: 13px;
  box-sizing: border-box; min-height: 43px;
}
select:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.field select { width: 100%; }
.inline-label select { min-width: 160px; }

/* custom dropdown (replaces native <select>; sized like a text input) */
.cselect {
  display: inline-flex; align-items: center; gap: 8px; justify-content: space-between;
  min-height: 43px; padding: 8px 11px; box-sizing: border-box; width: auto;
  border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--ink);
  font: inherit; cursor: pointer; text-align: left;
}
.cselect:hover { border-color: var(--ink-soft); }
.cselect:focus-visible { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.cselect-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cselect-caret { flex: 0 0 auto; color: var(--ink-soft); display: inline-flex; }
.cselect-caret svg { width: 13px; height: 13px; }
.field .cselect { width: 100%; }
.cselect.phase-pill { min-height: 0; padding: 8px 13px; font-weight: 600; }
.cselect-menu .cselect-check { flex: 0 0 15px; width: 15px; text-align: center; color: var(--accent); font-size: 11px; }
.cselect-menu .menu-row.selected .menu-label { font-weight: 600; }
.chip.soft { background: var(--bg); color: var(--ink-soft); border: 1px solid var(--line); }

/* ---------- Segmented control (equipment grouping) ---------- */
.segmented { display: inline-flex; border: 1px solid var(--line); border-radius: 9px; overflow: hidden; box-sizing: border-box; height: 40px; }
.seg { border: none; background: var(--panel); color: var(--ink-soft); padding: 0 14px; font-weight: 600; font-size: 13px; display: flex; align-items: center; }
.seg.active { background: var(--accent); color: var(--on-accent); }
/* keep every control in a view header the same height */
.view-head .btn { box-sizing: border-box; height: 40px; display: inline-flex; align-items: center; }
.eq-table td:nth-child(3), .eq-table th:nth-child(3) { text-align: center; }

/* ---------- Full-screen project page ---------- */
.project-page { max-width: 1200px; margin: 0 auto; }
.project-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.project-name {
  flex: 1; min-width: 220px; font-size: 22px; font-weight: 700; letter-spacing: -0.3px;
  border: 1px solid transparent; background: transparent; color: var(--ink); padding: 6px 8px; border-radius: 8px;
}
.project-name:hover { border-color: var(--line); }
.project-name:focus { outline: none; border-color: var(--accent); background: var(--panel); }
.phase-pill { font-weight: 600; }

.project-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items: start; }
@media (max-width: 900px) { .project-grid { grid-template-columns: 1fr; } }
.project-col { display: flex; flex-direction: column; gap: 18px; }
.panel-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; }

/* tasks grouped by phase */
.task-phase { margin-bottom: 12px; }
.task-phase-head { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); padding: 6px 0 2px; border-bottom: 1px solid var(--line); margin-bottom: 4px; }
.task-phase-head .count { margin-left: auto; background: var(--bg); border-radius: 20px; padding: 1px 8px; font-size: 11px; }
.task-controls { display: flex; gap: 6px; margin-top: 5px; flex-wrap: wrap; }
.task-controls select { flex: 1; min-width: 110px; }

/* category-first gear rows */
.cat-row { display: flex; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--line); align-items: flex-start; }
.cat-row:last-child { border-bottom: none; }
.cat-label { flex: 0 0 88px; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); padding-top: 9px; line-height: 1.3; }
.cat-content { flex: 1; min-width: 0; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 7px; }
.gear-chip { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; padding: 4px 5px 4px 11px; border-radius: 20px; background: var(--accent-soft); color: var(--accent); white-space: nowrap; border: 1px solid transparent; }
/* per-category colour (bg = the colour mixed toward the panel, so it adapts light/dark).
   Deliberately COOL hues only — no orange/amber/red — so a chip never reads as a gear clash. */
.gear-chip[class*="cat-"] { background: color-mix(in srgb, var(--cat) 15%, var(--panel)); color: var(--cat); }
.gear-chip.cat-lighting        { --cat: #3f86cf; }  /* blue */
.gear-chip.cat-light-modifiers { --cat: #2aa7b8; }  /* teal */
.gear-chip.cat-grip            { --cat: #7c8694; }  /* slate */
.gear-chip.cat-camera          { --cat: #9152c7; }  /* purple */
.gear-chip.cat-camera-support  { --cat: #5360cf; }  /* indigo */
.gear-chip.cat-lens            { --cat: #2d9d7f; }  /* green-teal */
.gear-chip.cat-accessories     { --cat: #b06ba8; }  /* orchid */
.gear-chip.cat-audio           { --cat: #c2569a; }  /* pink */
/* over-booked = a SOLID orange pill so a clash is unmistakable (never confused with a category tint) */
.gear-chip.over { background: var(--alert-soft); color: var(--alert); border-color: var(--alert-line); }   /* over-booked clash — soft pill w/ border */
.gear-chip.rental { background: var(--tint); color: var(--warn); }   /* rented overrides category colour */
@media (prefers-color-scheme: dark) { .gear-chip.rental { background: var(--tint); } .gear-chip.over { background: var(--alert-soft); color: var(--alert); border-color: var(--alert-line); } }
.chip-x { border: none; background: none; color: inherit; cursor: pointer; font-size: 11px; opacity: .6; padding: 0 4px; border-radius: 50%; }
.chip-x:hover { opacity: 1; }
.cat-add { display: flex; gap: 8px; align-items: stretch; }
.qty-input { flex: 0 0 58px; min-height: 43px; box-sizing: border-box; padding: 8px; border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--ink); text-align: center; }

/* ---------- Autocomplete (gear search) ---------- */
.autocomplete { position: relative; flex: 1; min-width: 0; }
.cat-input { width: 100%; box-sizing: border-box; min-height: 43px; padding: 9px 11px; border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--ink); }
.cat-input:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.suggestions {
  display: none; position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 50;
  background: var(--panel); border: 1px solid var(--line); border-radius: 9px; box-shadow: var(--shadow);
  max-height: 240px; overflow-y: auto; padding: 4px;
}
.suggestions.open { display: block; }
.suggestion { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 7px; cursor: pointer; font-size: 14px; }
.suggestion:hover { background: var(--accent-soft); color: var(--accent); }
.sugg-meta { font-size: 12px; color: var(--ink-soft); flex: 0 0 auto; }
.suggestion:hover .sugg-meta { color: var(--accent); }

/* ---------- Avatars ---------- */
.avatar {
  display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto;
  border-radius: 50%; color: #fff; font-weight: 700; line-height: 1;
  background-size: cover; background-position: center; overflow: hidden;
}
.avatar.is-empty { background: transparent; border: 1.5px dashed var(--ink-soft); color: var(--ink-soft); padding: 0; }
.avatar.is-empty.plus { border-style: solid; border-color: var(--accent); color: var(--accent); }
.avatar-btn { border: none; background: none; padding: 0; cursor: pointer; border-radius: 50%; display: inline-flex; }
.avatar-btn:hover { box-shadow: 0 0 0 2px var(--accent-soft); }

/* ---------- Popup menu (person picker) ---------- */
.menu {
  position: fixed; z-index: 60; min-width: 190px; max-width: 260px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 11px; box-shadow: var(--shadow); padding: 5px;
}
.menu-row { display: flex; align-items: center; gap: 9px; padding: 7px 9px; border-radius: 8px; cursor: pointer; }
.menu-row:hover { background: var(--hover); }
.menu-label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.menu-photo { border: none; background: none; cursor: pointer; font-size: 13px; opacity: .6; padding: 2px 4px; border-radius: 6px; }
.menu-photo:hover { opacity: 1; background: var(--accent-soft); }

/* ---------- Collapsible card ---------- */
.card-head { display: flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; }
.card-title { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); }
.caret { color: var(--ink-soft); line-height: 0; transition: transform .15s; display: inline-flex; align-items: center; }
.caret.collapsed { transform: rotate(-90deg); }
.day-head .caret { color: var(--accent); }
.card-body { margin-top: 12px; }

/* ---------- Task rows on project page ---------- */
.task { gap: 10px; }
.task .t-title { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.task[draggable=true] { cursor: grab; }
.task.dragging { opacity: .4; }
.t-due-input { flex: 0 0 132px; padding: 5px 7px; border: 1px solid var(--line); border-radius: 7px; background: var(--bg); color: var(--ink); font-size: 12px; }
.t-due-input.overdue { border-color: var(--danger); color: var(--danger); }
.task-phase { border-radius: 8px; }
.task-phase.drop-hover { outline: 2px dashed var(--accent); outline-offset: 6px; background: transparent; }
.task-quickadd { width: 100%; margin-top: 6px; padding: 7px 9px; border: 1px dashed var(--line); border-radius: 8px; background: transparent; color: var(--ink); font-size: 13px; }
.task-quickadd:focus { outline: none; border-style: solid; border-color: var(--accent); background: var(--bg); }

/* drag handle + linked shoot tasks */
.drag-handle { flex: 0 0 auto; width: 14px; text-align: center; color: var(--ink-soft); cursor: grab; font-size: 14px; line-height: 1; opacity: .5; user-select: none; }
.task:hover .drag-handle { opacity: 1; }
.drag-handle.placeholder { cursor: default; opacity: 0; }
.drag-handle.shoot-icon { cursor: default; opacity: 1; font-size: 12px; }
.avatar-btn.unset { opacity: .9; }
.avatar-btn.unset:hover { opacity: 1; }
.shoot-link { border: none; background: none; padding: 0; text-align: left; flex: 1; min-width: 0; color: var(--ink); font: inherit; cursor: pointer; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.shoot-link:hover { color: var(--accent); }
.t-due-static { flex: 0 0 auto; font-size: 12px; color: var(--ink-soft); padding-right: 4px; }

/* collapsible shoot-day header */
.day-head { cursor: pointer; user-select: none; border-radius: 8px; padding: 4px 6px; margin: -2px -6px 8px; }
.day-head:hover { background: var(--bg); }
.day-gearcount { font-size: 12px; color: var(--ink-soft); }
.day-body { padding-top: 2px; }

/* upcoming shoots on the dashboard */
.shoot-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.shoot-card { display: flex; align-items: center; gap: 12px; text-align: left; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 12px 14px; cursor: pointer; }
.shoot-card:hover { border-color: var(--accent); }
.shoot-date { flex: 0 0 auto; width: 46px; text-align: center; background: var(--accent-soft); border-radius: 9px; padding: 6px 0; color: var(--accent); }
.sd-day { font-size: 19px; font-weight: 750; line-height: 1; }
.sd-mon { font-size: 11px; text-transform: uppercase; letter-spacing: .3px; }
.shoot-info { min-width: 0; }
.shoot-proj { font-weight: 650; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.shoot-sub { font-size: 12px; color: var(--ink-soft); }

/* equipment table: fixed layout so columns line up across category groups */
.eq-table { table-layout: fixed; }
.eq-table th:nth-child(1), .eq-table td:nth-child(1) { width: 40%; }
.eq-table th:nth-child(2), .eq-table td:nth-child(2) { width: 16%; }
.eq-table th:nth-child(3), .eq-table td:nth-child(3) { width: 10%; }
.eq-table th:nth-child(4), .eq-table td:nth-child(4) { width: 15%; }
.eq-table th:nth-child(5), .eq-table td:nth-child(5) { width: 19%; }
.eq-table td { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.eq-table td .badge { display: inline-block; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; vertical-align: middle; }

/* shoot-day overview table (auto-sized, has its own columns incl. Crew) */
.sched-table { width: 100%; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); border-collapse: separate; border-spacing: 0; overflow: hidden; }
.sched-table th, .sched-table td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--line); }
.sched-table th { font-size: 12px; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); }
.sched-table tr:last-child td { border-bottom: none; }
.sched-table tr.clickable:hover td { background: var(--bg); cursor: pointer; }
.sched-table .past-row td { opacity: .55; }

.unit-label { flex: 0 0 56px; font-size: 12px; color: var(--ink-soft); }
.shoot-crew { display: flex; align-items: center; gap: 6px; margin-top: 6px; }
.crew-names { font-size: 12px; color: var(--ink-soft); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* make every form control the same height/box as a text input */
.field input, .field select { box-sizing: border-box; min-height: 43px; }
.field select { width: 100%; }

/* stacked avatars (multiple assignees) */
.avatar-stack { display: inline-flex; align-items: center; }
.avatar-stack > * { margin-left: -7px; box-shadow: 0 0 0 2px var(--panel); }
.avatar-stack > *:first-child { margin-left: 0; }
.avatar.more { background: var(--ink-soft); color: #fff; }

/* multi-select check + the day fields/time/loc */
.menu-row.checked { background: var(--accent-soft); }
.menu-check { flex: 0 0 16px; text-align: center; color: var(--accent); font-weight: 700; }
.day-time, .day-loc { font-size: 12px; color: var(--ink-soft); }
.day-add { flex-wrap: wrap; }

/* custom date picker button + calendar popup */
.date-btn { box-sizing: border-box; width: 100%; min-height: 43px; text-align: left; padding: 9px 11px; border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--ink); cursor: pointer; }
.date-btn:hover { border-color: var(--accent); }
.date-btn.empty { color: var(--ink-soft); }
.task-date { width: auto; min-height: 0; flex: 0 0 auto; padding: 5px 9px; font-size: 12px; }
.task-date.overdue { border-color: var(--danger); color: var(--danger); }

.menu.calendar { width: 258px; padding: 10px; }
.cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.cal-title { font-weight: 700; font-size: 14px; }
.cal-nav { border: none; background: var(--bg); color: var(--ink); width: 28px; height: 28px; border-radius: 7px; cursor: pointer; font-size: 17px; line-height: 1; }
.cal-nav:hover { background: var(--accent-soft); color: var(--accent); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cal-wd { text-align: center; font-size: 11px; color: var(--ink-soft); padding: 4px 0; }
.cal-day { border: none; background: none; color: var(--ink); height: 32px; border-radius: 7px; cursor: pointer; font-size: 13px; padding: 0; }
.cal-day:hover { background: var(--accent-soft); color: var(--accent); }
.cal-day.blank { visibility: hidden; cursor: default; }
.cal-day.today { font-weight: 700; box-shadow: inset 0 0 0 1px var(--line); }
.cal-day.past { color: var(--ink-soft); opacity: .45; }
.cal-day.past:hover { opacity: 1; }
.cal-day.sel { background: var(--accent); color: var(--on-accent); opacity: 1; }
.cal-foot { display: flex; justify-content: space-between; margin-top: 8px; }
.cal-clear, .cal-today-btn { border: none; background: none; color: var(--ink-soft); cursor: pointer; font-size: 13px; padding: 5px 8px; border-radius: 7px; }
.cal-clear:hover, .cal-today-btn:hover { background: var(--bg); color: var(--accent); }

/* ---------- Centered modal ---------- */
.modal-scrim { position: fixed; inset: 0; background: rgba(15,20,28,.45); display: flex; align-items: center; justify-content: center; z-index: 50; opacity: 0; pointer-events: none; transition: opacity .18s; padding: 20px; }
.modal-scrim.open { opacity: 1; pointer-events: auto; }
.modal { width: 460px; max-width: 100%; max-height: 90vh; overflow-y: auto; background: var(--panel); border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow); transform: translateY(8px); transition: transform .18s; }
.modal-scrim.open .modal { transform: none; }
.modal.modal-sheet { width: 520px; }
.modal.modal-file { width: 720px; max-width: 94vw; }
.btn.danger-btn { background: var(--red); color: #fff; border-color: var(--red); }
.btn.danger-btn:hover { filter: brightness(1.05); color: #fff; }
.confirm-msg { font-size: 14px; line-height: 1.55; color: var(--ink); }

/* file preview */
.file-preview { padding: 0; }
.fp-frame { width: 100%; height: 60vh; border: none; display: block; background: var(--bg); }
.fp-img { width: 100%; max-height: 60vh; object-fit: contain; display: block; background: var(--bg); }
.modal-head { display: flex; align-items: center; gap: 10px; padding: 16px 20px; border-bottom: 1px solid var(--line); position: sticky; top: 0; background: var(--panel); }
.modal-head h2 { margin: 0; font-size: 17px; }
.modal-body { padding: 18px 20px; }
.modal-foot { display: flex; align-items: center; gap: 10px; padding: 14px 20px; border-top: 1px solid var(--line); }

/* bottom toast (in-app replacement for native alert) */
#toast {
  position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 16px);
  background: var(--ink); color: var(--panel);
  padding: 11px 16px 11px 18px; border-radius: 10px; font-size: 14px; font-weight: 500;
  box-shadow: var(--shadow); z-index: 80; opacity: 0; pointer-events: none; max-width: 80vw;
  transition: opacity .18s ease, transform .18s ease;
}
#toast.show { opacity: 1; transform: translate(-50%, 0); }
#toast.ok { border-left: 3px solid var(--green); }
#toast.warn { border-left: 3px solid var(--orange); }
#toast.error { border-left: 3px solid var(--red); }
.add-day-btn { margin-top: 6px; width: 100%; border-style: dashed; }
.person-form-top { display: flex; align-items: flex-end; gap: 14px; }

/* project attachments */
.attach-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); }
.attach-link { border: none; background: none; color: var(--accent); cursor: pointer; flex: 1; min-width: 0; text-align: left; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 14px; padding: 0; }
.attach-link:hover { text-decoration: underline; }
.attach-size { font-size: 12px; color: var(--ink-soft); flex: 0 0 auto; }

/* ---------- Custom time picker popup ---------- */
.menu.time-pop { padding: 8px; }
.time-cols { display: flex; gap: 6px; }
.time-col { display: flex; flex-direction: column; max-height: 220px; overflow-y: auto; width: 66px; }
.time-h { font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--ink-soft); text-align: center; padding: 2px 0 5px; position: sticky; top: 0; background: var(--panel); }
.time-opt { border: none; background: none; color: var(--ink); padding: 6px 0; border-radius: 7px; cursor: pointer; font-size: 14px; }
.time-opt:hover { background: var(--accent-soft); color: var(--accent); }
.time-opt.sel { background: var(--accent); color: var(--on-accent); }
.time-foot { display: flex; justify-content: space-between; margin-top: 6px; }

/* ---------- Pull sheet ---------- */
.ps-head { margin-bottom: 10px; }
.ps-proj { font-size: 18px; font-weight: 700; }
.ps-meta { color: var(--ink-soft); font-size: 13px; margin-top: 2px; }
.ps-cat { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: var(--ink-soft); margin: 14px 0 4px; border-bottom: 1px solid var(--line); padding-bottom: 3px; }
.ps-item { display: flex; justify-content: space-between; padding: 4px 0; font-size: 14px; }
.ps-qty { color: var(--ink-soft); }
.ps-sub { font-size: 12px; color: var(--ink-soft); padding: 1px 0 1px 16px; }

/* ---------- Kit contents popup ---------- */
.kit-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.kit-list { display: flex; flex-direction: column; }
.kit-row { display: flex; justify-content: space-between; gap: 10px; padding: 6px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.chip-name { cursor: pointer; }
.chip-name:hover { text-decoration: underline; }

@media print {
  body * { visibility: hidden !important; }
  .pull-sheet, .pull-sheet * { visibility: visible !important; }
  .modal-head, .modal-foot { display: none !important; }
  .modal-scrim { position: absolute !important; inset: 0; background: none !important; padding: 0 !important; display: block !important; }
  .modal { box-shadow: none !important; border: none !important; max-height: none !important; width: 100% !important; }
  .pull-sheet { position: absolute; left: 0; top: 0; width: 100%; }
}

/* editable kit sub-items + per-unit serials */
.sub-row { display: flex; gap: 8px; align-items: center; padding: 5px 0; }
.sub-row input { padding: 9px 11px; min-height: 43px; box-sizing: border-box; border: 1px solid var(--line); border-radius: 8px; background: var(--bg); color: var(--ink); }
.sub-row input:focus { outline: 2px solid var(--accent-soft); border-color: var(--accent); }
.sub-row input:first-child { flex: 1; min-width: 0; }

/* gear pill quantity stepper */
.gear-chip { padding: 3px 5px 3px 11px; }
.chip-name { white-space: nowrap; }
.chip-stepper { display: inline-flex; align-items: center; gap: 1px; background: rgba(255,255,255,.45); border-radius: 20px; padding: 1px; }
.gear-chip.rental .chip-stepper, .gear-chip.over .chip-stepper { background: rgba(255,255,255,.4); }
@media (prefers-color-scheme: dark) { .chip-stepper { background: rgba(255,255,255,.12); } }
.chip-step { border: none; background: none; color: inherit; cursor: pointer; width: 18px; height: 18px; border-radius: 50%; font-size: 13px; line-height: 1; }
.chip-step:hover { background: rgba(0,0,0,.12); }
.chip-qty { min-width: 14px; text-align: center; font-size: 12px; font-weight: 600; }

/* gear-clash banner (dashboard + project page) */
.conflict-box { background: var(--alert-soft); border: 1px solid var(--alert-line); border-radius: var(--radius); padding: 12px 14px; margin-bottom: 18px; }
.conflict-box .conflict { background: none; border: none; padding: 3px 0; color: var(--alert); }
.conflict-title { font-weight: 700; color: var(--alert); margin-bottom: 4px; }
@media (prefers-color-scheme: dark) { .conflict-box { background: var(--alert-soft); border-color: var(--alert-line); } .conflict-box .conflict, .conflict-title { color: var(--alert); } }
