/* ============================================================
   schedule.css — output (Day/Week/Month) views + print
   ============================================================ */
.app-out{max-width:1280px;margin:0 auto;padding:26px 30px 80px}

/* ---------- masthead ---------- */
.out-mast{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:20px}
.out-brand{display:flex;align-items:center;gap:13px}
.out-brand .logos{display:flex;align-items:center;gap:8px}
.out-brand .logos img{height:46px;width:auto;display:block;mix-blend-mode:multiply}
.out-brand h1{font-family:var(--hero);font-weight:400;font-size:23px;margin:0;letter-spacing:-.01em;line-height:1}
.out-brand .sub{font-size:12px;color:var(--ink-2);margin-top:3px}
.out-mast .right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.loc-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:3px;box-shadow:var(--shadow-card)}
.loc-toggle button{border:0;background:transparent;padding:7px 14px;border-radius:7px;font-size:12.5px;font-weight:500;color:var(--ink-2);cursor:pointer;display:flex;align-items:center;gap:7px}
.loc-toggle button .pin{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.4}
.loc-toggle button.active{color:#fff}.loc-toggle button.active .pin{opacity:1;background:#fff}
.loc-toggle button.active[data-loc=nwdc]{background:var(--nwdc)}
.loc-toggle button.active[data-loc=bcdc]{background:var(--bcdc)}

.print-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line);border-radius:9px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:500;cursor:pointer;box-shadow:var(--shadow-card)}
.calendar-link{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--ink-2);font-size:12.5px;font-weight:500;text-decoration:none;box-shadow:var(--shadow-card)}
.calendar-link:hover{color:var(--ink);border-color:var(--line-strong)}

/* ---------- control bar ---------- */
.out-controls{display:flex;align-items:center;justify-content:space-between;gap:18px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:12px 16px;margin-bottom:20px;flex-wrap:wrap}
.ctrl-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.ctrl-right{display:flex;align-items:center;gap:12px}

#viewToggle{display:inline-flex;background:var(--canvas);border:1px solid var(--line);border-radius:9px;padding:3px}
#viewToggle button{border:0;background:transparent;padding:7px 16px;border-radius:7px;font-size:13px;font-weight:500;color:var(--ink-2);cursor:pointer}
#viewToggle button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-card)}

.nav{display:inline-flex;align-items:center;gap:10px}
.nav button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--surface);cursor:pointer;color:var(--ink-2);font-size:15px;line-height:1}
.nav .nlabel{font-weight:600;font-size:13.5px;min-width:150px;text-align:center}

#groupChips{display:inline-flex;gap:6px;flex-wrap:wrap;transition:opacity .15s}
#groupChips button{border:1px solid var(--line);background:var(--surface);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500;color:var(--ink-2);cursor:pointer}
#groupChips button.on{background:var(--ink);color:#fff;border-color:var(--ink)}

.indiv{display:inline-flex;align-items:center;gap:7px}
.indiv .eyebrow{font-size:9.5px}
#indivPick{font-family:var(--ui);font-size:12.5px;color:var(--ink);border:1px solid var(--line-strong);border-radius:8px;padding:7px 9px;background:var(--surface);cursor:pointer;max-width:190px}
#clearIndiv{border:1px solid var(--line);background:var(--surface);border-radius:7px;width:28px;height:28px;cursor:pointer;color:var(--ink-2);font-size:13px}

/* ---------- shared output canvas ---------- */
.out-canvas{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:24px 26px;min-height:300px}
.out-rangecap{font-family:var(--hero);font-size:21px;font-weight:400;letter-spacing:-.01em;margin-bottom:16px}
.out-empty{color:var(--ink-3);font-size:13px;padding:36px;text-align:center}

/* ---------- DAY VIEW ---------- */
.out-dayhead{display:flex;align-items:baseline;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.out-dayhead .out-dow{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--ink-3)}
.out-dayhead .out-date{font-family:var(--hero);font-size:26px}
.out-tag.sat{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--bcdc);background:var(--bcdc-soft);padding:3px 9px;border-radius:20px;align-self:center}
.day-cols{columns:2;column-gap:22px}
.day-card{break-inside:avoid;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}
.day-card-h{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);background:#FCFAF6;padding:9px 14px;border-bottom:1px solid var(--line)}
.day-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:9px 14px;border-bottom:1px solid var(--line)}
.day-row:last-child{border-bottom:0}
.day-row.is-out{background:repeating-linear-gradient(135deg,var(--off),var(--off) 4px,#fff 4px,#fff 8px)}
.dr-name{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.dr-nm{font-size:13.5px;font-weight:500}
.dr-detail{text-align:right;font-size:12.5px}
.dr-main{font-weight:500;color:var(--ink)}
.dr-sub{color:var(--ink-2);margin-left:5px}

/* ---------- today bar (all views) ---------- */
.today-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.today-bar .td-dot{width:9px;height:9px;border-radius:50%;background:var(--nwdc)}
body.loc-bcdc .today-bar .td-dot{background:var(--bcdc)}
.today-bar .td-txt{font-size:13px;font-weight:600;color:var(--ink)}
.today-bar .td-jump{margin-left:4px;border:1px solid var(--line);background:var(--surface);border-radius:7px;padding:4px 11px;font-size:11.5px;font-weight:500;color:var(--ink-2);cursor:pointer}
.today-bar .td-jump:hover{color:var(--ink);border-color:var(--line-strong)}

/* today / open pills */
.pill-today{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.06em;color:#fff;background:var(--nwdc);padding:2px 7px;border-radius:20px}
body.loc-bcdc .pill-today{background:var(--bcdc)}
.pill-today.sm{font-size:8px;padding:1px 5px}
.pill-sat{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.06em;color:var(--bcdc);background:var(--bcdc-soft);padding:2px 7px;border-radius:20px}
.out-tag.today{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:#fff;background:var(--nwdc);padding:3px 9px;border-radius:20px;align-self:center}
.out-tag.past{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-3);background:var(--canvas);padding:3px 9px;border-radius:20px;align-self:center}

/* ---------- WEEK VIEW (day columns) ---------- */
.wk2-cols{display:grid;grid-template-columns:repeat(var(--n),1fr);gap:12px}
.wk2-col{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);display:flex;flex-direction:column}
.wk2-col.sat{background:#FFFDF9}
.wk2-col.today{border-color:var(--nwdc);box-shadow:0 0 0 1px var(--nwdc)}
body.loc-bcdc .wk2-col.today{border-color:var(--bcdc);box-shadow:0 0 0 1px var(--bcdc)}
.wk2-col.past{opacity:.55}
.wk2-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-bottom:1px solid var(--line);background:#FCFAF6}
.wk2-col.today .wk2-head{background:var(--nwdc-soft)}
body.loc-bcdc .wk2-col.today .wk2-head{background:var(--bcdc-soft)}
.wk2-dow{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--ink-3)}
.wk2-dom{font-size:14px;font-weight:600;margin-top:1px}
.wk2-grouph{font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);padding:8px 12px 3px;font-weight:600}
.wk2-row{padding:3px 12px 6px}
.wk2-row.is-out{opacity:.6}
.wk2-name{display:flex;align-items:center;gap:7px}
.wk2-name .chip{width:8px;height:8px}
.wk2-nm{font-size:12.5px;font-weight:500}
.wk2-det{font-size:11px;color:var(--ink-2);margin-left:15px;line-height:1.3}
.wk2-empty{color:var(--ink-3);font-size:12px;padding:16px 12px;text-align:center}

/* past/today on month cells */
.mo-cell.past{background:#FAF8F4}
.mo-cell.past .mo-people,.mo-cell.past .mo-dn{opacity:.5}
.mo-cell.today{box-shadow:inset 0 0 0 2px var(--nwdc)}
body.loc-bcdc .mo-cell.today{box-shadow:inset 0 0 0 2px var(--bcdc)}
.mo-dn{font-size:12.5px;font-weight:600;color:var(--ink-2)}
.mo-cell.today .mo-dn{color:var(--nwdc)}
body.loc-bcdc .mo-cell.today .mo-dn{color:var(--bcdc)}

/* ---------- MONTH VIEW ---------- */
.mo-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.mo-dowh{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-3);text-align:center;padding:9px 0;background:#FCFAF6;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.mo-dowh.we{background:#FBF4EA}
.mo-dowh:nth-child(7n){border-right:0}
.mo-cell{min-height:104px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:7px 8px;background:var(--surface);position:relative}
.mo-cell:nth-child(7n){border-right:0}
.mo-cell.pad{background:#FCFBF9}
.mo-cell.closed{background:#FBFAF7}
.mo-cell.sat{background:#FFFDF9}
.mo-dnum{font-size:12.5px;font-weight:600;color:var(--ink-2);display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.mo-cell.closed .mo-dnum{color:var(--ink-3)}
.mo-holtag{font-family:var(--mono);font-size:8.5px;font-weight:600;letter-spacing:.05em;color:var(--ink-3)}
.mo-people{display:flex;flex-direction:column;gap:3px}
.mo-person{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--ink);line-height:1.25}
.mo-person .dot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.mo-more{font-size:10.5px;color:var(--ink-3);margin-top:1px}

/* ---------- PRINT ---------- */
@media print{
  @page{size:landscape;margin:12mm}
  body{background:#fff}
  .out-controls,.print-btn,.calendar-link,.loc-toggle,.out-mast .right{display:none !important}
  .app-out{max-width:none;padding:0}
  .out-canvas{border:0;box-shadow:none;padding:0}
  .out-mast{margin-bottom:10px}
  .wk-table{font-size:11px}
  .mo-cell{min-height:88px}
  .day-cols{columns:2}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}
