/*
 * roadmap-view.css — Application Workspace: RoadmapView component styles
 * Prefix: rv-
 *
 * C1 (2026-05-13): Skeleton file. No visual styles yet — the C1 dispatch stub
 * delegates to WorkspacePane's existing workbench render, which uses wsp-
 * prefixed classes defined in workspace-pane.css.
 *
 * C3 will add: rv-phase, rv-phase__header, rv-phase__content, rv-phase--locked,
 *              rv-phase__lock-note, rv-phase--collapsed, rv-phase__chevron
 * C4 will add: rv-step, rv-step__check, rv-step__text, rv-step__note
 * C5 will add: rv-submit, rv-submit__portal, rv-submit__countdown,
 *              rv-submit__copy, rv-submit__checklist, rv-submit__checklist-item
 * C6 will add: rv-group--collapsed, rv-group__items, rv-group__pill
 *
 * Load: dashboard.html <link rel="stylesheet" href="/css/roadmap-view.css?v=...">
 * Must load AFTER workspace-pane.css so rv- overrides are cascade-safe.
 */

/* ── Progress bar ────────────────────────────────────────────────────────── */
.mk-bar { height: 6px; border-radius: 999px; background: var(--paper-2, #f0f0f0); overflow: hidden; }
.mk-bar > i { display: block; height: 100%; background: var(--forest, #2d6a4f); border-radius: 999px; transition: width .3s ease; }
.mk-bar--thin { height: 4px; }

/* ── Phase card ──────────────────────────────────────────────────────────── */
.mk-phase { border: 1px solid var(--rule, #e5e7eb); border-radius: 11px; background: var(--paper, #fff); overflow: hidden; }
/* V2.1.1 round 4 polish (2026-05-14): set phase-to-phase margin to 0 so
   the outline's flex `gap` is the single source of truth for inter-card
   spacing. Previously the outline had gap:36px AND the cards had
   margin-top:18px, stacking to 54px between every phase card. Closed
   phases (Phase 4 / 5 / 5.5 / 6) looked too far apart. The outline gap
   was reduced to 20px in workspace-pane.css to compensate. */
.mk-phase + .mk-phase { margin-top: 0; }
.mk-phase__head { display: flex; align-items: center; gap: 11px; padding: 14px 14px; cursor: pointer; transition: background .12s; }
.mk-phase__head:hover { background: var(--paper-2, #f9fafb); }
.mk-phase__num { width: 22px; height: 22px; border-radius: 7px; background: var(--forest-l, #d1fae5); color: var(--forest, #2d6a4f); display: inline-flex; align-items: center; justify-content: center; font-family: var(--f-mono, monospace); font-size: 11px; font-weight: 500; flex-shrink: 0; }
.mk-phase.is-done .mk-phase__num { background: var(--forest, #2d6a4f); color: #fff; }
.mk-phase.is-current .mk-phase__num { background: var(--sienna-l, #fee2d5); color: var(--sienna-d, #9a3412); }
.mk-phase__name { font-family: var(--f-display, Georgia, serif); font-weight: 500; font-size: 15px; color: var(--ink, #111); letter-spacing: -.005em; min-width: 0; flex: 1; }
/* P1-18 (2026-05-15, Lens 5 a11y): #9ca3af on white = 2.85:1 — fails WCAG AA.
   #6b7280 = 4.74:1, clears AA while still reading as visually distinct from
   active phases. Same bump on .mk-phase__count below. */
.mk-phase.is-done .mk-phase__name { color: #6b7280; }
.mk-phase__count { font-family: var(--f-mono, monospace); font-size: 10.5px; color: #6b7280; letter-spacing: .03em; flex-shrink: 0; }
.mk-phase.is-current .mk-phase__count { color: var(--sienna-d, #9a3412); }
.mk-phase__caret { color: var(--ink-3, #9ca3af); transition: transform .2s; flex-shrink: 0; }
.mk-phase.is-open .mk-phase__caret { transform: rotate(90deg); }
.mk-phase__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .25s ease; }
.mk-phase.is-open .mk-phase__body { grid-template-rows: 1fr; }
.mk-phase__inner { overflow: hidden; }
/* V2.1.1 (2026-05-14): bumped phase content padding 4/8/10 → 10/12/14 so
   the inner content has visual breathing room from the phase header. */
.mk-phase__pad { padding: 10px 12px 14px; border-top: 1px solid var(--rule, #e5e7eb); }
.mk-phase.is-current { border-color: var(--sienna-l, #fee2d5); box-shadow: 0 1px 2px rgba(196,83,43,.06), 0 8px 22px -12px rgba(196,83,43,.18); }

/* ── Step row ────────────────────────────────────────────────────────────── */
.mk-step { display: grid; grid-template-columns: 18px 16px 1fr auto; gap: 9px; align-items: start; padding: 9px 8px; border-radius: 8px; border: 1px solid transparent; transition: background .12s, border-color .12s; }
.mk-step:hover { background: var(--paper-2, #f9fafb); }
.mk-step.is-current { background: var(--sienna-ll, #fff7f5); border-color: var(--sienna-l, #fee2d5); }
/* P1-18 (2026-05-15, Lens 5): bump from .62 to .72 to push contrast closer
   to WCAG AA on a 13px font. Done state still reads as visually faded. */
.mk-step.is-done { opacity: .72; }
.mk-step__chk { width: 16px; height: 16px; border-radius: 5px; border: 1.5px solid var(--rule-2, #d1d5db); display: inline-flex; align-items: center; justify-content: center; color: #fff; background: var(--paper, #fff); margin-top: 1px; flex-shrink: 0; cursor: pointer; }
.mk-step.is-done .mk-step__chk { background: var(--forest, #2d6a4f); border-color: var(--forest, #2d6a4f); }
.mk-step.is-done .mk-step__chk svg { width: 10px; height: 10px; }
.mk-step.is-current .mk-step__chk { border-color: var(--sienna, #c4532b); }
.mk-step__type { font-size: 13px; line-height: 1.3; margin-top: 1px; opacity: .85; flex-shrink: 0; }
.mk-step__body { min-width: 0; }
.mk-step__title { font-size: 13px; color: var(--ink-2, #374151); line-height: 1.35; }
.mk-step.is-current .mk-step__title { color: var(--ink, #111); font-weight: 500; }
/* P1-18 followup (2026-05-15, sprint-2 verification): ink-4 #d1d5db on
   white = 1.42:1 — fails WCAG AA. Strikethrough + light-gray was making
   done-step titles essentially invisible to low-vision users. Use the
   same #6b7280 (4.74:1) we used for done-phase names; strikethrough
   stays for the visual "done" signal. */
.mk-step.is-done .mk-step__title { text-decoration: line-through; color: #6b7280; }
.mk-step__desc { font-size: 11px; color: var(--ink-4, #9ca3af); line-height: 1.3; margin-top: 2px; }
.mk-step__action { font-family: var(--f-mono, monospace); font-size: 10px; color: var(--sienna, #c4532b); letter-spacing: .02em; margin-top: 4px; display: inline-flex; align-items: center; gap: 4px; text-decoration: none; }
.mk-step__action:hover { text-decoration: underline; }
.mk-step__meta { font-family: var(--f-mono, monospace); font-size: 9.5px; color: var(--ink-4, #9ca3af); letter-spacing: .03em; text-align: right; margin-top: 2px; flex-shrink: 0; }
/* P1-18 (2026-05-15, Lens 5): .5 was 1.71:1 — fails WCAG AA. */
.mk-step--conditional { opacity: .72; }
.mk-step--conditional .mk-step__chk { border-style: dashed; }

/* ── Divider note (EOI gate) ─────────────────────────────────────────────── */
.mk-divider-note { font-family: var(--f-mono, monospace); font-size: 10px; color: var(--amber, #b45309); text-transform: none; letter-spacing: .01em; padding: 8px 8px 4px; display: flex; align-items: center; gap: 7px; line-height: 1.4; }
.mk-divider-note::before { content: ''; flex: 1; height: 1px; background: var(--amber-line, #fde68a); opacity: .7; }
.mk-divider-note::after { content: ''; flex: 1; height: 1px; background: var(--amber-line, #fde68a); opacity: .7; }
.mk-divider-note span { flex-shrink: 0; max-width: 62%; }

/* ── Submit bridge card (Phase 5 editor) ─────────────────────────────────── */
.mk-submit { display: flex; flex-direction: column; gap: 12px; }
.mk-submit__hero { background: linear-gradient(150deg, var(--forest, #2d6a4f) 0%, var(--forest-d, #1b4332) 100%); color: #fff; border-radius: 13px; padding: 20px; position: relative; overflow: hidden; }
.mk-submit__lbl { font-family: var(--f-mono, monospace); font-size: 10px; text-transform: uppercase; letter-spacing: .14em; color: rgba(255,255,255,.65); }
.mk-submit__h { font-family: var(--f-display, Georgia, serif); font-weight: 500; font-size: 20px; line-height: 1.2; margin: 6px 0; letter-spacing: -.01em; }
.mk-submit__p { font-size: 13px; color: rgba(255,255,255,.85); line-height: 1.55; max-width: 54ch; }
.mk-submit__hrow { display: flex; align-items: center; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.mk-submit__dl { margin-left: auto; font-family: var(--f-mono, monospace); font-size: 11px; color: rgba(255,255,255,.8); display: inline-flex; align-items: center; gap: 6px; }
.mk-submit__dl strong { color: #fff; font-weight: 500; }
.mk-submit__card { background: var(--paper, #fff); border: 1px solid var(--rule, #e5e7eb); border-radius: 12px; padding: 14px; margin-top: 8px; }
.mk-submit__card-h { font-family: var(--f-mono, monospace); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3, #9ca3af); display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.mk-submit__exports { margin-left: auto; display: flex; gap: 6px; }
.mk-sec-acc { border: 1px solid var(--rule, #e5e7eb); border-radius: 9px; overflow: hidden; }
.mk-sec-acc + .mk-sec-acc { margin-top: 7px; }
.mk-sec-acc__head { display: flex; align-items: center; gap: 10px; padding: 9px 11px; cursor: pointer; transition: background .12s; }
.mk-sec-acc__head:hover { background: var(--paper-2, #f9fafb); }
.mk-sec-acc__chk { width: 14px; height: 14px; border-radius: 50%; background: var(--forest, #2d6a4f); color: #fff; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mk-sec-acc__chk svg { width: 9px; height: 9px; }
.mk-sec-acc__name { font-size: 13px; color: var(--ink-2, #374151); flex: 1; min-width: 0; }
.mk-sec-acc__words { font-family: var(--f-mono, monospace); font-size: 10px; color: var(--ink-4, #9ca3af); letter-spacing: .02em; flex-shrink: 0; }
.mk-sec-acc__caret { color: var(--ink-3, #9ca3af); transition: transform .2s; flex-shrink: 0; }
.mk-sec-acc.is-open .mk-sec-acc__caret { transform: rotate(90deg); }
.mk-sec-acc__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .25s ease; }
.mk-sec-acc.is-open .mk-sec-acc__body { grid-template-rows: 1fr; }
.mk-sec-acc__inner { overflow: hidden; }
.mk-sec-acc__pad { padding: 11px; border-top: 1px solid var(--rule, #e5e7eb); }
.mk-sec-acc__text { font-size: 12px; color: var(--ink-2, #374151); line-height: 1.6; background: var(--paper-2, #f9fafb); border: 1px solid var(--rule, #e5e7eb); border-radius: 8px; padding: 10px 12px; max-height: 130px; overflow: auto; }
.mk-sec-acc__foot { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.mk-checklist { display: flex; flex-direction: column; gap: 6px; }
.mk-checklist__item { display: flex; align-items: center; gap: 9px; font-size: 12.5px; color: var(--ink-2, #374151); }
.mk-checklist__pip { width: 14px; height: 14px; border-radius: 4px; border: 1.5px solid var(--rule-2, #d1d5db); display: inline-flex; align-items: center; justify-content: center; color: #fff; flex-shrink: 0; }
.mk-checklist__pip.is-on { background: var(--forest, #2d6a4f); border-color: var(--forest, #2d6a4f); }
.mk-checklist__pip.is-on svg { width: 9px; height: 9px; }
.mk-checklist__item.is-off { color: var(--ink-4, #9ca3af); }

/* ── C6: Fallback workbench collapsible groups (fb-group) ────────────────── */
/* Used in _renderFbWorkbench for SECTIONS / DOCUMENTS / OTHER groups.       */
.fb-workbench { display: flex; flex-direction: column; gap: 8px; }
.fb-group { border: 1px solid var(--rule, #e5e7eb); border-radius: 10px; background: var(--paper, #fff); overflow: hidden; }
.fb-group__head { display: flex; align-items: center; gap: 9px; padding: 10px 12px; cursor: pointer; user-select: none; transition: background .12s; }
.fb-group__head:hover { background: var(--paper-2, #f9fafb); }
.fb-group__head:focus-visible { outline: 2px solid var(--forest, #2d6a4f); outline-offset: -2px; border-radius: 9px; }
.fb-group__icon { font-size: 13px; opacity: .75; flex-shrink: 0; }
.fb-group__label { font-family: var(--f-mono, monospace); font-size: 10.5px; text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3, #9ca3af); flex: 1; }
.fb-group.is-open .fb-group__label { color: var(--ink-2, #374151); }
.fb-group__count { font-family: var(--f-mono, monospace); font-size: 10px; background: var(--paper-2, #f3f4f6); color: var(--ink-3, #6b7280); border-radius: 10px; padding: 1px 6px; letter-spacing: .04em; flex-shrink: 0; }
.fb-group__caret { color: var(--ink-3, #9ca3af); transition: transform .2s; flex-shrink: 0; }
/* Chevron animates 0→90deg on expand. Respects prefers-reduced-motion. */
.fb-group.is-open .fb-group__caret { transform: rotate(90deg); }
@media (prefers-reduced-motion: reduce) { .fb-group__caret { transition: none; } }
/* Body collapses via display:none — clean, no animation (brief says "pick the cleaner one for the brand aesthetic"). */
.fb-group__body { display: none; }
.fb-group.is-open .fb-group__body { display: block; }
.fb-group__inner { padding: 4px 10px 10px; border-top: 1px solid var(--rule, #e5e7eb); }

/* ── C7-part-B: Finalize & Submit entry inside OTHER group ───────────────── */
.fb-finalize-entry { margin-top: 6px; }
.fb-finalize__btn { display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; background: none; border: 1px solid var(--forest, #2d6a4f); border-radius: 8px; padding: 9px 12px; cursor: pointer; font-size: 13px; font-weight: 600; color: var(--forest, #2d6a4f); transition: background .12s; }
.fb-finalize__btn:hover, .fb-finalize__btn.is-active { background: var(--forest-ll, #f0faf5); }
.fb-finalize__btn:focus-visible { outline: 2px solid var(--forest, #2d6a4f); outline-offset: 2px; }
.fb-finalize__hint { margin-left: auto; font-size: 11px; font-weight: 400; color: var(--ink-3, #9ca3af); }

/* ── multiStream note ────────────────────────────────────────────────────── */
.rv-multistream-note { font-size: 12px; color: var(--amber, #b45309); background: var(--amber-ll, #fffbeb); border: 1px solid var(--amber-line, #fde68a); border-radius: 9px; padding: 9px 12px; margin-bottom: 14px; line-height: 1.55; }

/* ── Roadmap button (generic) ────────────────────────────────────────────── */
.rv-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 7px; font-size: 12px; border: 1px solid var(--rule-2, #d1d5db); background: var(--paper, #fff); color: var(--ink-2, #374151); cursor: pointer; text-decoration: none; transition: background .12s; }
.rv-btn:hover { background: var(--paper-2, #f9fafb); }
.rv-btn--forest { background: var(--forest, #2d6a4f); color: #fff; border-color: var(--forest, #2d6a4f); }
.rv-btn--forest:hover { background: var(--forest-d, #1b4332); }
.rv-btn--sm { font-size: 11px; padding: 4px 9px; }
