/* ===========================================================
   Fristenprotokoll — Accountability / Deadline tracking
   Inherits tokens from styles.css, components from tracker.css
   =========================================================== */

/* ---------- deadline accent palette ---------- */
:root {
  --fp-good: #41d77f;
  --fp-late: #ffae4d;
  --fp-miss: #ff6b6b;
}

/* 4-up segmented (deadline type) */
.fp-seg4 { flex-wrap: wrap; }
.fp-seg4 button { flex: 1 1 calc(50% - 6px); min-width: 0; padding: 12px 8px; flex-direction: column; gap: 4px; line-height: 1.2; }
.fp-seg4 button .sub { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); }
.fp-seg4 button.active .sub { color: var(--accent); }
@media (min-width: 560px) { .fp-seg4 button { flex: 1; } }

.fp-due-resolved {
  margin-top: 11px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .03em;
  color: var(--accent-2); display: flex; align-items: center; gap: 8px;
}
.fp-due-resolved .ic { opacity: .7; }
.fp-due-resolved .warn { color: var(--fp-miss); }

/* ---------- attachments ---------- */
.fp-attach-list { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.fp-attach-list:empty { display: none; }
.fp-attach {
  display: flex; align-items: center; gap: 11px; padding: 9px 11px; border: 1px solid var(--line);
  border-radius: 11px; background: rgba(255,255,255,.025);
}
.fp-attach .ic {
  width: 38px; height: 38px; border-radius: 9px; flex: none; display: grid; place-items: center;
  font-size: 16px; color: var(--accent); background: color-mix(in oklab, var(--accent) 12%, transparent);
  background-size: cover; background-position: center; overflow: hidden;
}
.fp-attach .ic.has-thumb { color: transparent; }
.fp-attach .nm { flex: 1; min-width: 0; }
.fp-attach .nm b { display: block; font-size: 13px; font-weight: 600; letter-spacing: -.01em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fp-attach .nm span { font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; color: var(--faint); text-transform: uppercase; }
.fp-attach .ab { display: inline-flex; gap: 5px; flex: none; }
.fp-attach .ab button { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--line-strong); background: rgba(255,255,255,.03); color: var(--muted); cursor: pointer; font-size: 13px; transition: all .2s; display: grid; place-items: center; }
.fp-attach .ab button:hover { color: var(--fg); border-color: var(--accent); }
.fp-attach .ab .rm:hover { color: var(--fp-miss); border-color: color-mix(in oklab, var(--fp-miss) 45%, transparent); }

/* ---------- Open tasks view ---------- */
.fp-stage { padding: 18px var(--pad) 70px; max-width: 1280px; margin: 0 auto; }
.fp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 16px; }
@media (max-width: 760px) { .fp-grid { grid-template-columns: 1fr; } }

.fp-task {
  position: relative; border: 1px solid var(--line); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012));
  padding: 18px 20px 16px; padding-left: 24px; overflow: hidden;
  transition: border-color .2s, box-shadow .25s, transform .2s;
}
.fp-task::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px; background: var(--edge, var(--line-strong)); }
.fp-task:hover { border-color: var(--line-strong); box-shadow: 0 22px 50px -30px rgba(0,0,0,.9); }
.fp-task.is-soon { --edge: var(--fp-late); }
.fp-task.is-over { --edge: var(--fp-miss); }
.fp-task.is-future { --edge: var(--fp-good); }

.fp-task .ft-top { display: flex; align-items: flex-start; gap: 12px; }
.fp-task .ft-due {
  flex: none; text-align: center; min-width: 92px; padding: 9px 12px; border-radius: 12px;
  border: 1px solid var(--line); background: rgba(255,255,255,.03);
}
.fp-task .ft-due .cd { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -.02em; line-height: 1.05; }
.fp-task .ft-due .cd small { font-size: 11px; font-weight: 600; }
.fp-task .ft-due .lbl { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); margin-top: 5px; }
.fp-task.is-soon .ft-due { border-color: color-mix(in oklab, var(--fp-late) 40%, transparent); background: color-mix(in oklab, var(--fp-late) 9%, transparent); }
.fp-task.is-soon .ft-due .cd { color: var(--fp-late); }
.fp-task.is-over .ft-due { border-color: color-mix(in oklab, var(--fp-miss) 45%, transparent); background: color-mix(in oklab, var(--fp-miss) 11%, transparent); }
.fp-task.is-over .ft-due .cd { color: var(--fp-miss); }

.fp-task .ft-main { flex: 1; min-width: 0; }
.fp-task .ft-type { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--accent-2); display: inline-flex; align-items: center; gap: 6px; }
.fp-task .ft-title { font-size: 16px; font-weight: 600; letter-spacing: -.01em; line-height: 1.3; margin-top: 7px; text-wrap: pretty; cursor: pointer; }
.fp-task .ft-title:hover { color: var(--accent); }
.fp-task .ft-desc { color: var(--muted); font-size: 13px; line-height: 1.45; margin-top: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.fp-task .ft-meta { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; margin-top: 14px; }
.fp-who { display: inline-flex; align-items: center; gap: 8px; }
.fp-who .nm { font-size: 13px; font-weight: 600; }
.fp-who .ro { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); }
.fp-flag { font-family: var(--font-mono); font-size: 10px; letter-spacing: .04em; color: var(--muted); border: 1px solid var(--line); border-radius: 999px; padding: 4px 9px; display: inline-flex; align-items: center; gap: 5px; }
.fp-flag.att { color: var(--accent-2); border-color: color-mix(in oklab, var(--accent-2) 28%, transparent); }

.fp-task .ft-actions { display: flex; gap: 8px; margin-top: 15px; padding-top: 14px; border-top: 1px solid var(--line); }
.fp-act {
  flex: 1; padding: 10px 12px; border-radius: 10px; font-family: var(--font-body); font-size: 13px; font-weight: 600;
  border: 1px solid var(--line-strong); background: rgba(255,255,255,.03); color: var(--muted); cursor: pointer;
  transition: all .2s; display: inline-flex; align-items: center; justify-content: center; gap: 7px;
}
.fp-act:hover { color: var(--fg); border-color: var(--line-strong); }
.fp-act.done:hover { color: #06120b; background: var(--fp-good); border-color: var(--fp-good); }
.fp-act.miss:hover { color: #fff; background: var(--fp-miss); border-color: var(--fp-miss); }
.fp-act.detail { flex: 0 0 auto; padding: 10px 13px; }

/* ---------- Scoreboard / Mitarbeiter ---------- */
.fp-score { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; }
@media (max-width: 740px) { .fp-score { grid-template-columns: 1fr; } }

.fp-score-card {
  border: 1px solid var(--line); border-radius: var(--radius); padding: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012));
  position: relative; overflow: hidden;
}
.fp-score-card.flag::after { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--fp-miss); }
.fp-sc-head { display: flex; align-items: center; gap: 14px; }
.fp-sc-head .avatar { width: 48px; height: 48px; font-size: 16px; }
.fp-sc-head .who { flex: 1; min-width: 0; }
.fp-sc-head .who b { display: block; font-family: var(--font-display); font-weight: 700; font-size: 18px; letter-spacing: -.02em; }
.fp-sc-head .who span { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); }
.fp-sc-quote { text-align: right; flex: none; }
.fp-sc-quote .q { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -.03em; line-height: 1; }
.fp-sc-quote .ql { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); margin-top: 4px; }

.fp-sc-bar { height: 9px; border-radius: 999px; overflow: hidden; display: flex; margin: 18px 0 14px; background: rgba(255,255,255,.05); }
.fp-sc-bar i { height: 100%; display: block; transition: width .5s var(--ease-out); }
.fp-sc-bar .good { background: var(--fp-good); }
.fp-sc-bar .late { background: var(--fp-late); }
.fp-sc-bar .miss { background: var(--fp-miss); }

.fp-sc-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.fp-sc-stat { text-align: center; padding: 12px 8px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.02); }
.fp-sc-stat .n { font-family: var(--font-display); font-weight: 700; font-size: 24px; letter-spacing: -.03em; line-height: 1; }
.fp-sc-stat .l { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); margin-top: 6px; }
.fp-sc-stat.good .n { color: var(--fp-good); }
.fp-sc-stat.late .n { color: var(--fp-late); }
.fp-sc-stat.miss .n { color: var(--fp-miss); }

.fp-sc-foot { margin-top: 15px; padding-top: 14px; border-top: 1px solid var(--line); font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .03em; color: var(--faint); display: flex; align-items: center; gap: 8px; }
.fp-sc-foot.bad { color: var(--fp-miss); }
.fp-sc-foot .ic { opacity: .8; }

/* ---------- Protocol log ---------- */
.fp-log { max-width: 980px; margin: 0 auto; }
.fp-log-group { position: relative; padding-left: 34px; padding-bottom: 28px; }
.fp-log-group::before { content: ""; position: absolute; left: 7px; top: 8px; bottom: -6px; width: 2px; background: var(--line); }
.fp-log-group:last-child::before { display: none; }
.fp-log-group::after { content: ""; position: absolute; left: 1px; top: 5px; width: 14px; height: 14px; border-radius: 50%; background: var(--bg); border: 2px solid var(--line-strong); }
.fp-log-group.has-miss::after { border-color: var(--fp-miss); box-shadow: 0 0 0 4px color-mix(in oklab, var(--fp-miss) 13%, transparent); }
.fp-log-date { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -.02em; margin-bottom: 14px; display: flex; align-items: baseline; gap: 11px; }
.fp-log-date .sub { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); }
.fp-log-items { display: grid; gap: 10px; }

.fp-log-row {
  display: flex; gap: 13px; padding: 14px 16px; border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: rgba(255,255,255,.022); cursor: pointer; transition: border-color .2s, background .2s;
}
.fp-log-row:hover { border-color: var(--line-strong); background: rgba(255,255,255,.04); }
.fp-log-row .dot { width: 30px; height: 30px; border-radius: 9px; flex: none; display: grid; place-items: center; font-size: 14px; }
.fp-log-row.t-create .dot { color: var(--accent); background: color-mix(in oklab, var(--accent) 14%, transparent); }
.fp-log-row.t-done .dot { color: var(--fp-good); background: color-mix(in oklab, var(--fp-good) 14%, transparent); }
.fp-log-row.t-late .dot { color: var(--fp-late); background: color-mix(in oklab, var(--fp-late) 16%, transparent); }
.fp-log-row.t-miss .dot { color: var(--fp-miss); background: color-mix(in oklab, var(--fp-miss) 15%, transparent); }
.fp-log-row .lc { flex: 1; min-width: 0; }
.fp-log-row .lt { font-size: 14px; line-height: 1.4; }
.fp-log-row .lt b { font-weight: 600; }
.fp-log-row .lt .obj { color: var(--accent-2); }
.fp-log-row .lt .out-good { color: var(--fp-good); font-weight: 600; }
.fp-log-row .lt .out-late { color: var(--fp-late); font-weight: 600; }
.fp-log-row .lt .out-miss { color: var(--fp-miss); font-weight: 600; }
.fp-log-row .lm { font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; color: var(--faint); margin-top: 5px; text-transform: uppercase; }
.fp-log-row .reason {
  margin-top: 10px; padding: 10px 12px; border-radius: 10px; border-left: 3px solid var(--fp-miss);
  background: color-mix(in oklab, var(--fp-miss) 8%, transparent); font-size: 13px; color: var(--fg); line-height: 1.45;
}
.fp-log-row .reason.late { border-left-color: var(--fp-late); background: color-mix(in oklab, var(--fp-late) 9%, transparent); }
.fp-log-row .reason .rcat { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 4px; }
.fp-log-row .lat { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .06em; color: var(--faint); white-space: nowrap; flex: none; padding-top: 6px; }

/* ---------- reason modal ---------- */
.fp-reason-cats { display: flex; flex-wrap: wrap; gap: 8px; }
.fp-reason-cat {
  font-family: var(--font-body); font-size: 13px; font-weight: 600; color: var(--muted);
  padding: 9px 14px; border-radius: 999px; border: 1px solid var(--line-strong); background: rgba(255,255,255,.03);
  cursor: pointer; transition: all .2s;
}
.fp-reason-cat:hover { color: var(--fg); border-color: var(--line-strong); }
.fp-reason-cat.active { color: #fff; border-color: var(--fp-miss); background: color-mix(in oklab, var(--fp-miss) 16%, transparent); }
.fp-reason-head { display: flex; align-items: center; gap: 13px; padding: 14px 16px; border-radius: 13px; margin-bottom: 18px; border: 1px solid var(--line); background: rgba(255,255,255,.025); }
.fp-reason-head .ic { width: 40px; height: 40px; border-radius: 11px; flex: none; display: grid; place-items: center; font-size: 18px; }
.fp-reason-head.miss .ic { color: var(--fp-miss); background: color-mix(in oklab, var(--fp-miss) 14%, transparent); }
.fp-reason-head.late .ic { color: var(--fp-late); background: color-mix(in oklab, var(--fp-late) 16%, transparent); }
.fp-reason-head .tx b { display: block; font-family: var(--font-display); font-weight: 700; font-size: 16px; letter-spacing: -.01em; }
.fp-reason-head .tx span { font-size: 12.5px; color: var(--muted); }

/* outcome pill in detail */
.fp-outcome { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; padding: 5px 11px; border-radius: 999px; border: 1px solid var(--line); }
.fp-outcome.good { color: var(--fp-good); border-color: color-mix(in oklab, var(--fp-good) 40%, transparent); background: color-mix(in oklab, var(--fp-good) 10%, transparent); }
.fp-outcome.late { color: var(--fp-late); border-color: color-mix(in oklab, var(--fp-late) 42%, transparent); background: color-mix(in oklab, var(--fp-late) 11%, transparent); }
.fp-outcome.miss { color: var(--fp-miss); border-color: color-mix(in oklab, var(--fp-miss) 42%, transparent); background: color-mix(in oklab, var(--fp-miss) 11%, transparent); }
.fp-outcome.open { color: var(--accent-2); border-color: color-mix(in oklab, var(--accent-2) 38%, transparent); }

/* settings rows */
.fp-set-row { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 14px; padding: 13px 0; border-top: 1px solid var(--line); }
.fp-set-row:first-child { border-top: none; }
.fp-set-row .sl b { display: block; font-size: 14px; font-weight: 600; }
.fp-set-row .sl span { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--faint); }
.fp-set-row input[type=time] { width: 130px; padding: 10px 12px; border-radius: 11px; background: rgba(255,255,255,.04); border: 1px solid var(--line-strong); color: var(--fg); font-family: var(--font-body); font-size: 14px; outline: none; }
.fp-set-row input[type=time]:focus { border-color: var(--accent); }

/* sub-toolbar filter for employees */
.fp-sort { display: inline-flex; gap: 4px; padding: 4px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.02); }
.fp-sort button { font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); padding: 7px 13px; border-radius: 999px; border: none; background: transparent; cursor: pointer; transition: all .2s; }
.fp-sort button.active { color: #1c0f06; background: var(--accent); }

/* detail meta grid */
.fp-detail-meta { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 16px; }
.fp-dm { padding: 12px 14px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.02); }
.fp-dm .k { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); }
.fp-dm .v { font-size: 14px; font-weight: 600; margin-top: 5px; display: flex; align-items: center; gap: 8px; }

.fp-empty { text-align: center; padding: 70px 20px; color: var(--faint); }
.fp-empty .ic { font-size: 42px; margin-bottom: 14px; opacity: .5; }
.fp-empty b { display: block; font-family: var(--font-display); font-size: 19px; color: var(--muted); letter-spacing: -.01em; }
.fp-empty p { font-size: 13.5px; margin-top: 7px; }

@media (max-width: 640px) {
  .fp-detail-meta { grid-template-columns: 1fr; }
  .fp-task .ft-actions { flex-wrap: wrap; }
}
@media (prefers-reduced-motion: reduce) { .fp-sc-bar i { transition: none; } }

/* ===== additions: roles, trend, seen, escalation, lightbox, exports ===== */

/* sub-controls: range + group segments */
.fp-rangenote { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--faint); margin-bottom: 14px; }
.fp-rangenote b { color: var(--accent-2); }

/* group headers in open view */
.fp-group-head { display: flex; align-items: center; gap: 10px; margin: 24px 0 12px; }
.fp-group-head:first-child { margin-top: 0; }
.fp-group-head b { font-family: var(--font-display); font-weight: 700; font-size: 16px; letter-spacing: -.01em; }
.fp-group-head span { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); border: 1px solid var(--line); border-radius: 999px; padding: 3px 9px; }

/* seen / unseen flags */
.fp-flag.seen { color: var(--fp-good); border-color: color-mix(in oklab, var(--fp-good) 30%, transparent); }
.fp-flag.unseen { color: var(--faint); }

/* escalation */
.fp-task.is-escalate { border-color: color-mix(in oklab, var(--fp-miss) 40%, transparent); }
.ft-ribbon { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: #fff; background: var(--fp-miss); padding: 5px 12px; margin: -18px -20px 14px -24px; }
.fp-task.is-critical .ft-due .cd { animation: fp-pulse 1.1s ease-in-out infinite; }
@keyframes fp-pulse { 50% { opacity: .45; } }
.fp-act.seen { flex: 0 0 auto; }
.fp-act.seen:hover { color: #1c0f06; background: var(--accent); border-color: var(--accent); }

/* trend sparkline */
.fp-sc-trend { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--line); }
.fp-sc-trend .tl { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--faint); }
.fp-spark { display: block; flex: none; }

/* per-card exports */
.fp-sc-exports { display: flex; gap: 8px; margin-top: 13px; }
.fp-mini-btn { flex: 1; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .06em; color: var(--muted); border: 1px solid var(--line-strong); background: rgba(255,255,255,.03); border-radius: 9px; padding: 9px 10px; cursor: pointer; transition: all .2s; }
.fp-mini-btn:hover { color: var(--fg); border-color: var(--accent); background: color-mix(in oklab, var(--accent) 10%, transparent); }

/* recurrence select inherits .rt-select */

/* attachment viewable cursor */
.fp-attach .ic.viewable { cursor: zoom-in; }

/* readonly task modal note */
.fp-readonly-note { display: flex; align-items: center; gap: 9px; padding: 11px 14px; border-radius: 11px; margin-bottom: 16px; font-size: 12.5px; color: var(--muted); background: color-mix(in oklab, var(--accent) 8%, transparent); border: 1px solid color-mix(in oklab, var(--accent) 22%, transparent); }
.is-readonly .rt-input:disabled, .is-readonly .rt-textarea:disabled, .is-readonly .rt-select:disabled { opacity: .85; cursor: default; -webkit-text-fill-color: var(--muted); }
.is-readonly .rt-assignee:disabled { opacity: .7; cursor: default; }
.is-readonly .rt-seg button:disabled { opacity: .6; cursor: default; }

/* lightbox */
.fp-lightbox { position: fixed; inset: 0; z-index: 160; display: grid; place-items: center; padding: clamp(14px,3vw,40px); opacity: 0; transition: opacity .25s ease; }
.fp-lightbox.show { opacity: 1; }
.fp-lightbox .lb-scrim { position: absolute; inset: 0; background: rgba(5,5,7,.8); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.fp-lightbox .lb-card { position: relative; z-index: 1; width: min(1000px, 100%); max-height: 92svh; display: flex; flex-direction: column; background: color-mix(in oklab, var(--bg) 90%, transparent); border: 1px solid var(--line-strong); border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 40px 100px -30px rgba(0,0,0,.85); transform: scale(.985); transition: transform .25s var(--ease-out); }
.fp-lightbox.show .lb-card { transform: none; }
.fp-lightbox .lb-head { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.fp-lightbox .lb-head b { flex: 1; min-width: 0; font-family: var(--font-display); font-weight: 700; font-size: 15px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fp-lightbox .lb-actions { display: inline-flex; gap: 8px; flex: none; }
.fp-lightbox .lb-actions button { font-family: var(--font-body); font-size: 13px; font-weight: 600; color: var(--fg); border: 1px solid var(--line-strong); background: rgba(255,255,255,.04); border-radius: 9px; padding: 8px 13px; cursor: pointer; transition: all .2s; }
.fp-lightbox .lb-actions button:hover { border-color: var(--accent); background: rgba(255,255,255,.09); }
.fp-lightbox .lb-body { flex: 1; min-height: 0; overflow: auto; background: #08080a; display: grid; place-items: center; }
.fp-lightbox .lb-body img { max-width: 100%; max-height: 80svh; display: block; object-fit: contain; }
.fp-lightbox .lb-body iframe { width: 100%; height: 80svh; border: 0; background: #fff; }
.fp-lightbox .lb-noprev { padding: 60px; color: var(--muted); }
@media (prefers-reduced-motion: reduce) { .fp-task.is-critical .ft-due .cd { animation: none; } .fp-lightbox, .fp-lightbox .lb-card { transition: none; } }

/* ---------- team management ---------- */
.fp-team-toolbar { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 18px; }
.fp-team-toolbar .btn { margin-left: auto; }

.fp-emp-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 22px; }
.fp-emp-row { display: flex; align-items: center; gap: 12px; padding: 11px 13px; border: 1px solid var(--line); border-radius: 13px; background: rgba(255,255,255,.022); }
.fp-emp-row .ei { flex: 1; min-width: 0; }
.fp-emp-row .ei b { display: block; font-size: 14px; font-weight: 600; letter-spacing: -.01em; }
.fp-emp-row .ei span { font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--faint); }
.fp-emp-role { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); border: 1px solid var(--line); border-radius: 999px; padding: 4px 10px; flex: none; }
.fp-emp-role.lead { color: var(--accent); border-color: color-mix(in oklab, var(--accent) 36%, transparent); }
.fp-emp-lock { flex: none; width: 30px; text-align: center; font-size: 13px; opacity: .5; }
.fp-emp-del { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--line-strong); background: rgba(255,255,255,.03); color: var(--muted); cursor: pointer; font-size: 13px; flex: none; transition: all .2s; }
.fp-emp-del:hover { color: var(--fp-miss); border-color: color-mix(in oklab, var(--fp-miss) 42%, transparent); background: color-mix(in oklab, var(--fp-miss) 10%, transparent); }

.fp-emp-add { padding-top: 20px; border-top: 1px solid var(--line); }
.fp-emp-add-title { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }

/* access-denied screen (Teamlead-only) */
.fp-denied {
  position: fixed; inset: 0; z-index: 120; display: grid; place-items: center; padding: 24px;
  background: radial-gradient(1100px 760px at 80% -12%, color-mix(in oklab, var(--accent) 14%, transparent), transparent 60%),
    radial-gradient(820px 560px at -8% 16%, rgba(255,255,255,.04), transparent 55%), var(--bg);
}
.fp-denied-card {
  width: min(460px, 92vw); padding: 44px 40px 30px; text-align: center;
  background: rgba(255,255,255,.035); border: 1px solid var(--line); border-radius: var(--radius);
  backdrop-filter: blur(22px) saturate(120%); -webkit-backdrop-filter: blur(22px) saturate(120%);
  box-shadow: 0 30px 80px -30px rgba(0,0,0,.8);
}
.fp-denied-card .dn-ic { width: 58px; height: 58px; margin: 0 auto 18px; border-radius: 16px; display: grid; place-items: center; font-size: 26px; background: color-mix(in oklab, var(--fp-miss) 16%, transparent); border: 1px solid color-mix(in oklab, var(--fp-miss) 32%, transparent); }
.fp-denied-card h2 { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -.02em; margin-top: 10px; }
.fp-denied-card p { color: var(--muted); font-size: 14.5px; line-height: 1.55; margin-top: 12px; text-wrap: pretty; }
.fp-denied-card p b { color: var(--fg); }
.fp-denied-card .dn-actions { display: flex; flex-direction: column; gap: 10px; margin-top: 26px; }
.fp-denied-card .dn-actions .btn { width: 100%; justify-content: center; }
.fp-denied-card .dn-tag { display: inline-block; margin-top: 20px; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--faint); border: 1px solid var(--line); border-radius: 999px; padding: 5px 12px; }

/* task modal footer — single row, compact so nothing clips */
#taskModal { width: min(700px, 94vw); }
.fp-foot { flex-wrap: nowrap; row-gap: 10px; }
.fp-foot-grp { display: flex; gap: 8px; flex-wrap: nowrap; align-items: center; }
.fp-foot-grp.right { margin-left: auto; }
.fp-foot-grp:empty { display: none; }
.fp-foot .btn { white-space: nowrap; padding: 11px 15px; font-size: 13.5px; }
@media (max-width: 600px) {
  .fp-foot { flex-wrap: wrap; }
  .fp-foot-grp, .fp-foot-grp.right { width: 100%; margin-left: 0; }
  .fp-foot .btn { flex: 1; padding: 11px 10px; }
}
