/* Design Journey app — chooser + builder. Tokens come from tokens.css. */

/* ---------- Chooser ---------- */
.dj-chooser-wrap{min-height:100vh;padding:44px 28px 56px}
.dj-chooser{max-width:1360px;margin:0 auto}
.dj-chooser-brand{font-family:var(--display);font-weight:800;font-size:13px;letter-spacing:.02em;color:var(--magenta)}
.dj-chooser-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px}
.dj-chooser-h{font-family:var(--display);font-weight:600;font-size:32px;letter-spacing:-.02em;color:var(--ink);margin:0;text-wrap:balance}
.dj-chooser-sub{margin:12px 0 32px;font-size:16px;line-height:1.55;color:var(--muted);max-width:640px;text-wrap:pretty}
.dj-mode-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;align-items:stretch}
@media(max-width:1180px){.dj-mode-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:780px){.dj-mode-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.dj-mode-grid{grid-template-columns:1fr}}
.dj-ccard{display:flex;flex-direction:column;align-items:stretch;text-align:left;background:#fff;border:1px solid var(--line);border-top:3px solid var(--ac);border-radius:var(--r-lg);padding:18px 17px 17px;cursor:pointer;transition:transform .14s,box-shadow .14s,border-color .14s}
.dj-ccard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--ac) 50%,var(--line))}
.dj-ccard.is-started{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ac) 30%,transparent)}
.dj-cc-head{display:block;margin-bottom:15px}
.dj-cc-namewrap{display:flex;flex-direction:column;gap:7px}
.dj-mode-name{display:inline-flex;align-items:center;flex-wrap:wrap;gap:9px;font-family:var(--display);font-weight:600;font-size:16px;line-height:1.18;letter-spacing:-.01em;color:var(--ink)}
.dj-cc-ribbon{align-self:flex-start;font-family:var(--display);font-weight:600;font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--ac)}
.dj-cc-bestfor{min-height:2.9em;font-size:12.5px;line-height:1.45;color:var(--ink-2);text-wrap:pretty;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line-soft)}
.dj-cc-sec{display:block;margin-bottom:14px}
.dj-cc-sec + .dj-cc-sec{padding-top:14px;border-top:1px solid var(--line-soft)}
.dj-cc-eyebrow{display:flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.085em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.dj-cc-eyebrow svg{flex:0 0 auto;color:var(--ac)}
.dj-phaserow{display:flex;flex-wrap:wrap;gap:5px 11px}
.dj-pchip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--ink-2);white-space:nowrap}
.dj-pchip .dj-dot{width:7px;height:7px}
.dj-vfeats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.dj-vfeats li{position:relative;padding-left:12px;font-size:11.5px;line-height:1.4;color:var(--muted);text-wrap:pretty}
.dj-vfeats li::before{content:"";position:absolute;left:0;top:6px;width:3px;height:3px;border-radius:50%;background:var(--ac);opacity:.55}
.dj-cc-foot{margin-top:auto;display:flex;flex-direction:column;gap:7px;padding-top:14px;border-top:1px solid var(--line-soft)}
.dj-cc-meta{font-size:12px;line-height:1.42;color:var(--muted)}
.dj-cc-meta + .dj-cc-meta{margin-top:7px}
.dj-cc-metalab{display:flex;align-items:center;gap:5px;font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink);margin-bottom:3px}
.dj-cc-metalab svg{flex:0 0 auto;width:11px;height:11px;color:var(--ac)}
.dj-cc-cta{display:flex;flex-direction:column;gap:7px;margin-top:5px}
.dj-cc-status{font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:color-mix(in srgb,var(--ac) 72%,var(--ink))}
.dj-vbtn{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--ac);background:none;border:1px solid color-mix(in srgb,var(--ac) 38%,var(--line));border-radius:var(--r-pill);padding:9px 14px;cursor:pointer;transition:background .12s,color .12s,border-color .12s}
.dj-vbtn svg{flex:0 0 auto;width:14px;height:14px}
.dj-ccard:hover .dj-vbtn{background:var(--ac);color:#fff;border-color:var(--ac)}
.dj-opttag{display:inline-flex;align-items:center;padding:2px 6px;border-radius:4px;border:1px solid color-mix(in srgb,currentColor 30%,transparent);color:inherit;opacity:.6;font-family:var(--display);font-weight:600;font-size:8.5px;letter-spacing:.07em;text-transform:uppercase;line-height:1;white-space:nowrap}
.dj-ccard .dj-opttag{border-color:color-mix(in srgb,var(--ac) 38%,transparent);background:color-mix(in srgb,var(--ac) 9%,#fff);color:var(--ac);opacity:1}
.dj-opttag-accent{border-color:color-mix(in srgb,var(--ac) 38%,transparent);background:color-mix(in srgb,var(--ac) 10%,#fff);color:var(--ac);opacity:1}
.dj-opttag-compact{padding:1px 7px;font-weight:600;border-radius:5px}
.dj-mode-sub{display:block;font-size:13px;line-height:1.45;color:var(--muted);margin:4px 0 0;text-wrap:pretty}
.dj-mode-eyebrow{display:block;font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.085em;text-transform:uppercase;color:color-mix(in srgb,var(--ac) 60%,var(--ink));margin:0 0 7px}
.dj-mode-bestfor{display:block;margin:16px 0 0;padding:11px 12px;background:color-mix(in srgb,var(--ac) 6%,#fff);border:1px solid color-mix(in srgb,var(--ac) 18%,var(--line-soft));border-radius:var(--r)}
.dj-mode-bestfor .dj-mode-eyebrow{color:color-mix(in srgb,var(--ac) 78%,var(--ink));margin-bottom:4px}
.dj-mode-bestfor-tx{display:block;font-size:13px;line-height:1.42;font-weight:550;color:var(--ink-2);text-wrap:pretty}
.dj-mode-block{display:block;margin:16px 0 0}
.dj-mode-phasestrip{display:flex;flex-wrap:wrap;gap:5px}
.dj-mode-chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);font-weight:600;font-size:11px;color:var(--ink-2);background:var(--wash);border:1px solid var(--line-soft);border-radius:var(--r-pill);padding:3px 8px 3px 7px}
.dj-mode-feats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.dj-mode-feats li{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;line-height:1.4;color:var(--ink-2);text-wrap:pretty}
.dj-mode-tick{flex:0 0 auto;display:grid;place-items:center;width:16px;height:16px;margin-top:.5px;border-radius:50%;color:#fff;background:var(--ac)}
.dj-mode-meta{display:flex;flex-direction:column;gap:12px;margin:16px 0 0;padding-top:14px;border-top:1px solid var(--line-soft)}
.dj-mode-meta .dj-mode-eyebrow{margin:0 0 6px}
.dj-mode-modechip{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);font-weight:600;font-size:10.5px;color:var(--ink-2);background:var(--wash);border:1px solid var(--line-soft);border-radius:var(--r-pill);padding:3px 9px 3px 7px}
.dj-mode-modechip svg{flex:0 0 auto;width:11px;height:11px;color:var(--ac)}
.dj-mode-metarow{display:block}
.dj-mode-modes{display:flex;flex-wrap:wrap;gap:5px}
.dj-mode-exportbadge{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:12px;color:color-mix(in srgb,var(--ac) 86%,var(--ink));background:color-mix(in srgb,var(--ac) 8%,#fff);border:1px solid color-mix(in srgb,var(--ac) 24%,var(--line-soft));border-radius:var(--r-pill);padding:5px 12px 5px 9px}
.dj-mode-exportbadge svg{flex:0 0 auto;color:var(--ac)}
.dj-mode-foot{display:flex;flex-direction:column;gap:9px;margin-top:auto;padding-top:18px}
.dj-mode-status{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:11.5px;letter-spacing:.01em;color:color-mix(in srgb,var(--ac) 72%,var(--ink))}
.dj-mode-livedot{width:8px;height:8px;border-radius:50%;background:var(--ac);box-shadow:0 0 0 0 color-mix(in srgb,var(--ac) 60%,transparent);animation:dj-pulse 2s ease-out infinite}
@media(prefers-reduced-motion:reduce){.dj-mode-livedot{animation:none}}
@keyframes dj-pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--ac) 55%,transparent)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
.dj-mode-cta{display:inline-flex;align-items:center;justify-content:center;gap:7px;align-self:stretch;font-family:var(--display);font-weight:600;font-size:13.5px;color:#fff;background:var(--ac);border-radius:var(--r-pill);padding:10px 14px;transition:filter .14s}
.dj-mode:hover .dj-mode-cta{filter:brightness(.94)}
.dj-mode-cta.resume{box-shadow:0 4px 14px -4px color-mix(in srgb,var(--ac) 60%,transparent)}

.dj-dot{width:9px;height:9px;border-radius:var(--r-pill);flex:0 0 auto;background:var(--ac)}

/* ---------- App shell ---------- */
.dj-app{min-height:100vh;display:flex;flex-direction:column}
.dj-top{display:flex;align-items:center;gap:10px;padding:13px 22px;background:#fff;border-bottom:1px solid var(--line)}
.dj-brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:14.5px;letter-spacing:-.015em;color:var(--ink)}
.dj-logo{display:inline-flex;align-items:center;justify-content:center;width:25px;height:25px;border-radius:7px;background:var(--magenta);flex:0 0 auto;box-shadow:0 1px 2px rgba(204,0,121,.28)}
.dj-logo svg{display:block}
.dj-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 12px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--ink);cursor:pointer}
.dj-pill:hover{border-color:var(--ink-2);background:var(--wash)}
.dj-pill.is-open{border-color:var(--ink-2);background:var(--wash)}
.dj-pill-wrap{position:relative;display:inline-flex}
.dj-menu.dj-pill-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:62;width:max-content;min-width:212px;animation:dj-pop .14s ease}
.dj-track-item{justify-content:flex-start}
.dj-track-item .dj-track-nm{flex:1;display:inline-flex;align-items:center;gap:9px}
.dj-menu-item.is-active{background:var(--wash);color:var(--ink)}
.dj-menu-item.is-active svg{color:var(--green)}
.dj-menu-item.is-disabled{opacity:.4;cursor:not-allowed}
.dj-menu-item.is-disabled:hover{background:none}
.dj-menu-sep{height:1px;background:var(--line);margin:5px 4px}
.dj-chooser-panel{flex:1 1 auto;min-height:0;overflow-y:auto;background:var(--paper);position:relative}
.dj-chooser-panel .dj-chooser-back{position:sticky;top:0;z-index:2;display:inline-flex;align-items:center;gap:6px;margin:16px 0 0 22px;font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--ink-2);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);border-radius:var(--r-pill);padding:8px 15px 8px 11px;cursor:pointer}
.dj-chooser-panel .dj-chooser-back:hover{background:var(--wash)}
.dj-chooser-wrap.is-inline{min-height:auto;padding:14px 24px 48px}
.dj-spacer{margin-left:auto}
.dj-lang{display:inline-flex;background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px;gap:2px}
.dj-lang button{font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.02em;color:var(--muted);background:none;border:0;padding:5px 9px;border-radius:var(--r-pill);cursor:pointer;line-height:1}
.dj-lang button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.dj-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:8px 15px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-btn:hover{border-color:var(--ink-2);background:var(--wash)}
.dj-btn:disabled{opacity:.42;cursor:not-allowed;background:#fff;border-color:var(--line)}
.dj-btn:disabled:hover{border-color:var(--line);background:#fff}

/* ---- Save / Open journey — plain nav pills (match the toolbar). ---- */
.dj-file-grp{display:inline-flex;align-items:center;gap:8px}
.dj-open-btn{color:var(--ink-2)}
/* ---- Toolbar responsive collapse: icon-only buttons, then drop wordmark ---- */
.dj-btn-lab{display:inline}
@media(max-width:1080px){
  .dj-top{gap:7px;padding:12px 15px}
  .dj-file-grp{gap:7px}
  .dj-top .dj-btn .dj-btn-lab{display:none}
  .dj-top .dj-btn{padding:8px 11px}
  .dj-pill{max-width:210px}
}
@media(max-width:840px){
  .dj-brand-tx{display:none}
  .dj-pill{max-width:160px}
}

/* Designed hover/focus tooltip under the Save / Open buttons */
.dj-tip-wrap{position:relative;display:inline-flex}
.dj-tip{position:absolute;top:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(-4px) scale(.98);transform-origin:top center;width:248px;max-width:248px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);padding:14px 16px;z-index:60;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .15s ease,transform .15s ease;text-align:left}
.dj-tip::before{content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-bottom-color:var(--line)}
.dj-tip::after{content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(1.5px);border:5px solid transparent;border-bottom-color:var(--surface)}
.dj-tip-wrap:hover .dj-tip,.dj-tip-wrap:focus-within .dj-tip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0) scale(1)}
.dj-tip-t{display:flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink);margin-bottom:4px}
.dj-tip-t svg{flex:0 0 auto;color:var(--ink-2)}
.dj-tip-d{display:block;font-family:var(--text);font-size:12px;line-height:1.5;color:var(--muted)}

/* Global styled tooltip (controller in core/tooltip.js) — replaces native title tooltips */
.dj-tipf{position:fixed;z-index:300;max-width:340px;white-space:pre-line;text-wrap:pretty;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);padding:12px 15px;font-family:var(--text);font-size:12px;line-height:1.5;color:var(--ink-2);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-3px);transition:opacity .14s ease,transform .14s ease}
.dj-tipf.on{opacity:1;visibility:visible;transform:translateY(0)}
.dj-tipf.flip{transform:translateY(3px)}
.dj-tipf.flip.on{transform:translateY(0)}
.dj-tipf::before{content:"";position:absolute;bottom:100%;left:var(--ax,50%);transform:translateX(-50%);border:6px solid transparent;border-bottom-color:var(--line)}
.dj-tipf::after{content:"";position:absolute;bottom:100%;left:var(--ax,50%);transform:translateX(-50%) translateY(1.5px);border:5px solid transparent;border-bottom-color:var(--surface)}
.dj-tipf.flip::before{bottom:auto;top:100%;border-bottom-color:transparent;border-top-color:var(--line)}
.dj-tipf.flip::after{bottom:auto;top:100%;transform:translateX(-50%) translateY(-1.5px);border-bottom-color:transparent;border-top-color:var(--surface)}
/* "Learning insight" term + its richer tooltip card */
.dj-li-term{font-weight:600;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;text-decoration-thickness:1.5px;text-decoration-color:color-mix(in srgb,var(--li-c,var(--blue)) 55%,transparent);cursor:help;transition:color .12s,text-decoration-color .12s}
.dj-li-term:hover,.dj-li-term:focus-visible{color:var(--li-c,var(--blue));text-decoration-color:var(--li-c,var(--blue));outline:none}
/* dotted-underline learning-insight colour follows the surrounding phase/accent context */
.dj-step{--li-c:var(--ac,var(--blue))}
.dj-field{--li-c:var(--fc,var(--blue))}
.dj-litip{position:fixed;z-index:320;width:max-content;max-width:320px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md,12px);box-shadow:var(--shadow-lg);overflow:hidden;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-4px);transition:opacity .15s ease,transform .15s ease,visibility .15s}
.dj-litip.on{opacity:1;visibility:visible;transform:translateY(0)}
.dj-litip-eb{display:flex;align-items:center;gap:6px;padding:11px 18px;background:color-mix(in srgb,var(--blue) 9%,#fff);color:var(--blue);font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.09em;text-transform:uppercase;border-bottom:1px solid color-mix(in srgb,var(--blue) 16%,transparent)}
.dj-litip-eb svg{flex:0 0 auto}
.dj-litip-t{padding:15px 18px 0;font-family:var(--display);font-weight:600;font-size:14.5px;letter-spacing:-.01em;color:var(--ink)}
.dj-litip-b{padding:7px 18px 18px;font-family:var(--text);font-size:12.8px;line-height:1.52;color:var(--ink-2);text-wrap:pretty}
.dj-litip.wide{max-width:500px}
.dj-litip.wide .dj-litip-b{padding-bottom:14px}
.dj-litip-lenses{counter-reset:lens;list-style:none;margin:0;padding:2px 18px 18px;display:flex;flex-direction:column;gap:10px}
.dj-litip-lens{counter-increment:lens;position:relative;padding-left:24px}
.dj-litip-lens::before{content:counter(lens);position:absolute;left:0;top:1px;width:17px;height:17px;border-radius:50%;background:color-mix(in srgb,var(--blue) 13%,#fff);color:var(--blue);font-family:var(--display);font-weight:600;font-size:9.5px;display:flex;align-items:center;justify-content:center}
.dj-litip-lens-h{display:flex;flex-wrap:wrap;align-items:baseline;gap:3px 7px}
.dj-litip-lens-n{font-family:var(--display);font-weight:600;font-size:12.6px;letter-spacing:-.005em;color:var(--ink)}
.dj-litip-lens-v{font-family:var(--text);font-style:italic;font-size:11px;color:var(--blue)}
.dj-litip-lens-d{font-family:var(--text);font-size:12px;line-height:1.46;color:var(--ink-2);margin-top:2px;text-wrap:pretty}
/* Language row inside the ··· More menu */
.dj-menu-lang{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:5px 8px 5px 10px}
.dj-menu-lang-lab{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink)}
.dj-menu-lang-lab svg{color:var(--muted);flex:0 0 auto}

.dj-more-wrap{position:relative;display:inline-flex}
.dj-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.dj-icon-btn:hover{border-color:var(--ink-2);color:var(--ink);background:var(--wash)}
.dj-menu{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lg);padding:6px;display:flex;flex-direction:column;gap:2px;z-index:5}
.dj-menu.dj-menu-right{position:absolute;top:calc(100% + 6px);left:auto;right:0;width:max-content;min-width:206px}
.dj-menu-danger{color:var(--magenta-deep)}
.dj-menu-danger:hover{background:var(--magenta-wash)}

/* data-safety alert: full-bleed amber bar flush under the nav (re-shows each landing) */
.dj-alert{display:flex;align-items:center;gap:10px;padding:11px 20px;background:#FDF4DE;border-bottom:1px solid #ECD7A0}
.dj-alert-ic{flex:0 0 auto;display:inline-flex;color:#B5790B}
.dj-alert-txt{flex:1;min-width:0;font-family:var(--text);font-size:13px;line-height:1.5;color:#5C3D04}
.dj-alert-txt b{font-family:var(--display);font-weight:600;color:#33250A}
/* contextual save nudge: clearly distinct branded (pink) bar vs the amber empty-start warning */
.dj-alert.is-progress{background:var(--magenta-wash);border-bottom-color:color-mix(in srgb,var(--magenta) 28%,transparent)}
.dj-alert.is-progress .dj-alert-ic{color:var(--magenta-deep)}
.dj-alert.is-progress .dj-alert-txt{color:var(--ink)}
.dj-alert.is-progress .dj-alert-txt b{color:var(--magenta-deep)}
.dj-alert.is-progress .dj-alert-dl{background:#fff;color:var(--magenta-deep);box-shadow:0 1px 2px rgba(163,0,97,.14)}
.dj-alert.is-progress .dj-alert-x{color:var(--magenta-deep)}
.dj-alert.is-progress .dj-alert-x:hover{background:color-mix(in srgb,var(--magenta) 14%,transparent)}
.dj-alert-dl{font-family:var(--display);font-weight:600;font-size:13px;color:#33250A;white-space:nowrap;background:#FAD86B;padding:1.5px 0}
.dj-alert-dl svg{vertical-align:-3px;margin-right:2px}
.dj-alert-mark{font-family:var(--display);font-weight:600;color:#33250A;background:#FAD86B;padding:1.5px 0}
.dj-alert-x{flex:0 0 auto;width:26px;height:26px;border:0;background:none;color:#9A7B33;border-radius:8px;cursor:pointer;display:grid;place-items:center;transition:background .12s,color .12s}
.dj-alert-x:hover{background:rgba(120,90,10,.12);color:#5C3D04}
@media(max-width:680px){.dj-alert{padding:10px 14px}}

.dj-bar2{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:30px 20px 12px;flex-wrap:wrap}
.dj-bar2-head{min-width:0}
.dj-titlerow{display:flex;align-items:center;gap:10px}
.dj-jname-row{display:flex;align-items:center;gap:8px;margin-top:11px}
.dj-jname{font-family:var(--display);font-weight:500;font-size:14.5px;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:7px 14px;min-width:280px;max-width:420px;width:38vw;transition:border-color .14s,box-shadow .14s}
.dj-jname::placeholder{color:var(--faint);font-weight:400}
.dj-jname:hover{border-color:var(--muted)}
.dj-jname:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 0 3px var(--magenta-wash)}
.dj-jname-count{font-size:11px;color:var(--faint);font-variant-numeric:tabular-nums;flex:0 0 auto}
.dj-bar2-meta{display:flex;flex-direction:column;align-items:flex-end;gap:7px}
.dj-bar2-stats{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:flex-end}
/* Narrow / tablet: the split header wraps — stack everything flush-left to match the title + board */
@media(max-width:960px){
  .dj-bar2{flex-direction:column;align-items:flex-start;gap:13px}
  .dj-bar2-meta{align-items:flex-start}
  .dj-bar2-stats{justify-content:flex-start}
}
.dj-jname-show{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-0.2px;color:var(--ink);background:none;border:0;padding:2px 0;cursor:pointer;max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .14s}
.dj-jname-show:hover{color:var(--magenta)}
.dj-title{position:relative;font-family:var(--display);font-weight:600;font-size:25px;letter-spacing:-.02em;padding-bottom:7px}
.dj-title::after{content:"";position:absolute;left:0;bottom:0;width:36px;height:3px;border-radius:var(--r-pill);background:var(--magenta)}
.dj-title-tip{display:inline-flex;align-self:center;margin-bottom:5px}
.dj-title-tip .dj-info svg{width:15px;height:15px}
.dj-title-tip .dj-info-pop{left:0;transform:none;top:calc(100% + 9px);bottom:auto;width:330px}
.dj-title-tip .dj-info-pop::before{top:auto;bottom:100%;left:14px;transform:translateX(-50%);border-top-color:transparent;border-bottom-color:var(--line)}
.dj-title-tip .dj-info-pop::after{top:auto;bottom:100%;left:14px;transform:translateX(-50%) translateY(1.5px);border-top-color:transparent;border-bottom-color:var(--surface)}
.dj-about{display:inline-flex;align-items:center;gap:6px;align-self:center;margin-bottom:4px;padding:4px 11px 4px 9px;border:1px solid color-mix(in srgb,var(--blue) 26%,var(--line));border-radius:var(--r-pill);background:color-mix(in srgb,var(--blue) 7%,#fff);color:var(--blue);font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:-.005em;cursor:help;transition:background .14s,border-color .14s,box-shadow .14s}
.dj-about:hover,.dj-about:focus-visible{background:color-mix(in srgb,var(--blue) 13%,#fff);border-color:color-mix(in srgb,var(--blue) 46%,var(--line));box-shadow:0 1px 7px color-mix(in srgb,var(--blue) 17%,transparent);outline:none}
.dj-about svg{flex:0 0 auto}
.dj-stat{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);font-size:12.5px;color:var(--muted)}
.dj-stat b{color:var(--ink);font-weight:600}
.dj-saved{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--green)}
.dj-saved.is-fail{color:#B5790B}
.dj-alert.is-fail{background:#FBEAE4;border-bottom-color:#E9C3B0}
.dj-alert.is-fail .dj-alert-ic{color:#B5360B}
.dj-alert.is-fail .dj-alert-txt{color:#5C2604}
.dj-alert.is-fail .dj-alert-txt b{color:#B5360B}
.dj-alert.is-fail .dj-alert-dl{background:#F6C6A8;color:#5C2604}
.dj-guide-btn{display:inline-flex;align-items:center;gap:6px;align-self:center;margin-bottom:4px;padding:4px 11px;font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:-.005em;color:var(--ink-2);background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);cursor:pointer;transition:background .14s,border-color .14s,box-shadow .14s}
.dj-guide-btn:hover{border-color:var(--ink-2);background:var(--wash);box-shadow:0 1px 7px rgba(22,19,26,.07)}
.dj-guide-btn:active{background:var(--line-soft)}
.dj-guide-btn:focus-visible{outline:2px solid var(--ink-2);outline-offset:2px}
.dj-guide-open{display:inline-flex;margin-left:1px;color:var(--faint);transition:transform .14s}
.dj-guide-btn:hover .dj-guide-open{transform:translateX(2px);color:var(--ink-2)}
.dj-guide-ov{position:fixed;inset:0;z-index:210;background:rgba(22,19,26,.42);display:flex;align-items:flex-start;justify-content:center;padding:48px 20px;overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:dj-pv-fade .15s ease}
.dj-guide-drawer{width:100%;max-width:1000px;max-height:calc(100vh - 96px);background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:dj-pop .16s ease}
.dj-guide-dhead{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--line-soft)}
.dj-guide-dbody{flex:1 1 auto;min-height:0;overflow-y:auto;padding:22px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:stretch}
@media(max-width:880px){.dj-guide-dbody{grid-template-columns:repeat(2,1fr)}}
.dj-guide-htitle{display:inline-flex;align-items:center;gap:11px;font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-0.3px;color:var(--ink)}
.dj-guide-hicon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--magenta-wash);color:var(--magenta-deep);flex:0 0 auto}
.dj-guide-dfoot{flex:0 0 auto;display:flex;justify-content:flex-end;padding:14px 22px 18px;border-top:1px solid var(--line-soft)}
.dj-guide-gotit{font-family:var(--display);font-weight:600;font-size:14px;color:#fff;background:var(--ink);border:0;border-radius:var(--r-pill);padding:11px 28px;cursor:pointer;transition:background .14s,transform .1s,box-shadow .14s}
.dj-guide-gotit:hover{background:var(--magenta);box-shadow:0 4px 14px color-mix(in srgb,var(--magenta) 38%,transparent)}
.dj-guide-gotit:active{transform:translateY(1px);box-shadow:none}
.dj-guide-gotit:focus-visible{outline:2px solid var(--magenta);outline-offset:2px}
.dj-guide-gotit:disabled{opacity:.4;cursor:not-allowed;background:var(--ink);box-shadow:none;transform:none}
.dj-guide-gotit:disabled:hover{background:var(--ink);box-shadow:none}
.dj-name-req{display:flex;align-items:center;gap:7px;margin:10px 0 0;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--magenta-deep)}
.dj-name-req svg{flex:0 0 auto}
/* onboarding choice screen: Start new vs. See example */
.dj-guide-choice{display:block;padding:22px 26px 22px}
.dj-choice-intro{margin:0 0 16px;font-family:var(--text);font-size:14px;line-height:1.55;color:var(--ink-2);text-wrap:pretty}
.dj-choice-card{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;margin:0 0 12px;cursor:pointer;transition:border-color .14s,background .14s,box-shadow .14s}
.dj-choice-card:last-child{margin-bottom:0}
.dj-choice-card:hover{border-color:var(--ink-2);box-shadow:var(--shadow-sm)}
.dj-choice-card.is-new{background:var(--magenta-wash);border-color:color-mix(in srgb,var(--magenta) 26%,transparent)}
.dj-choice-card.is-new:hover{border-color:color-mix(in srgb,var(--magenta) 46%,transparent);background:color-mix(in srgb,var(--magenta) 12%,#fff)}
.dj-choice-ic{flex:0 0 auto;display:inline-grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--wash);color:var(--ink);box-shadow:var(--shadow-sm)}
.dj-choice-card.is-new .dj-choice-ic{background:#fff;color:var(--magenta-deep)}
.dj-choice-tx{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.dj-choice-tx b{font-family:var(--display);font-weight:600;font-size:15.5px;letter-spacing:-.01em;color:var(--ink)}
.dj-choice-tx small{font-family:var(--text);font-size:12.5px;line-height:1.45;color:var(--ink-2);text-wrap:pretty}
.dj-choice-go{flex:0 0 auto;display:inline-flex;color:var(--muted)}
.dj-choice-card:hover .dj-choice-go{color:var(--ink-2)}
.dj-choice-card.is-new .dj-choice-go{color:var(--magenta-deep)}

/* onboarding step 0: the four "how this works" cards on one row, three start options on one row beneath */
.dj-guide-drawer.is-start0{max-width:1000px}
.dj-guide-start0{display:block;padding:22px 26px 24px}
.dj-guide-start0 .dj-guide-hiw{border-top:0;padding-top:0;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.dj-start-opts{margin-top:22px;padding-top:18px;border-top:1px solid var(--line-soft)}
.dj-opts-label{margin:0 0 12px;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint)}
.dj-choice-set{display:flex;flex-direction:column;gap:11px}
.dj-choice-set .dj-choice-card{margin:0}
.dj-choice-set-sm{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.dj-choice-set-sm .dj-choice-card{margin:0;padding:13px 15px;gap:12px;align-items:center;box-shadow:var(--shadow-sm);transition:transform .14s ease,box-shadow .16s ease,border-color .14s ease,background .14s ease}
.dj-choice-set-sm .dj-choice-card:hover{transform:translateY(-3px)}
.dj-choice-set-sm .dj-choice-card:active{transform:translateY(-1px)}
.dj-guide-start0 .dj-choice-card.is-open:hover{box-shadow:0 10px 22px color-mix(in srgb,var(--blue) 30%,transparent)}
.dj-guide-start0 .dj-choice-card.is-new:hover{box-shadow:0 10px 22px color-mix(in srgb,var(--magenta) 30%,transparent)}
.dj-guide-start0 .dj-choice-card.is-example:hover{box-shadow:0 10px 22px color-mix(in srgb,#067e7a 30%,transparent)}
.dj-choice-set-sm .dj-choice-ic{width:38px;height:38px;border-radius:10px}
.dj-choice-set-sm .dj-choice-tx b{font-size:14px;font-weight:600}
.dj-choice-set-sm .dj-choice-tx small{font-size:12px}
.dj-choice-set-sm .dj-choice-go{display:inline-flex;flex:0 0 auto;margin-left:auto;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;color:#fff}
.dj-guide-start0 .dj-choice-card.is-open .dj-choice-go{background:var(--blue);color:#fff}
.dj-guide-start0 .dj-choice-card.is-new .dj-choice-go{background:var(--magenta);color:#fff}
.dj-guide-start0 .dj-choice-card.is-example .dj-choice-go{background:#067e7a;color:#fff}
.dj-guide-start0 .dj-choice-card.is-open{background:var(--blue-wash);border-color:color-mix(in srgb,var(--blue) 26%,transparent)}
.dj-guide-start0 .dj-choice-card.is-open:hover{border-color:color-mix(in srgb,var(--blue) 46%,transparent);background:color-mix(in srgb,var(--blue) 12%,#fff)}
.dj-guide-start0 .dj-choice-card.is-open .dj-choice-ic{background:#fff;color:var(--blue-deep)}
.dj-guide-start0 .dj-choice-card.is-example{background:var(--teal-wash);border-color:color-mix(in srgb,var(--teal) 30%,transparent)}
.dj-guide-start0 .dj-choice-card.is-example:hover{border-color:color-mix(in srgb,var(--teal) 50%,transparent);background:color-mix(in srgb,var(--teal) 12%,#fff)}
.dj-guide-start0 .dj-choice-card.is-example .dj-choice-ic{background:#fff;color:#067e7a}
@media(max-width:880px){.dj-guide-start0 .dj-guide-hiw{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.dj-guide-start0 .dj-guide-hiw,.dj-choice-set-sm{grid-template-columns:1fr}}

/* ===== Full-screen About page ===== */
.dj-aboutfull{position:fixed;inset:0;z-index:150;background:var(--paper);display:flex;flex-direction:column}
.dj-aboutfull-bar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:13px 22px;background:#fff;border-bottom:1px solid var(--line)}
.dj-af-brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.015em;color:var(--ink)}
.dj-af-logo{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:7px;background:var(--magenta);box-shadow:0 1px 2px rgba(204,0,121,.28)}
.dj-af-x{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;color:var(--ink-2);cursor:pointer}
.dj-af-x:hover{border-color:var(--ink-2);color:var(--ink);background:var(--wash)}
.dj-aboutfull-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.dj-af-back{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 14px 0 10px;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--display);font-weight:600;font-size:14px;cursor:pointer}
.dj-af-back:hover{border-color:var(--ink-2);background:var(--wash)}
.dj-af-back svg{flex:0 0 auto}
.dj-af-col{max-width:1140px;margin:0 auto;padding:48px clamp(22px,5vw,48px) 88px}
.dj-af-hero{padding-bottom:8px}
.dj-af-eyebrow{display:inline-block;font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--magenta);margin-bottom:14px}
.dj-af-h1{font-family:var(--display);font-weight:600;font-size:clamp(28px,4vw,40px);line-height:1.08;letter-spacing:-.025em;color:var(--ink);margin:0}
.dj-af-lead{font-family:var(--text);font-size:clamp(16px,1.8vw,19px);line-height:1.55;color:var(--ink-2);margin:16px 0 0;text-wrap:pretty}
.dj-af-sec{margin-top:40px;padding-top:34px;border-top:1px solid var(--line)}
.dj-af-h2{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-.015em;color:var(--ink);margin:0 0 12px}
.dj-af-p{font-family:var(--text);font-size:16px;line-height:1.62;color:var(--ink-2);margin:0 0 12px;text-wrap:pretty}
/* Background section: alternating feature rows with animated visuals (landing-inspired) */
.dj-af-show{display:flex;flex-direction:column;margin-top:14px}
.dj-af-srow{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center;padding:40px 0;border-top:1px solid var(--line-soft)}
.dj-af-srow:first-child{border-top:0;padding-top:10px}
.dj-af-srow:nth-child(even) .dj-af-stx{order:2}
.dj-af-stx{min-width:0}
.dj-af-snum{display:inline-block;font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--mark)}
.dj-af-sh{font-family:var(--display);font-weight:600;font-size:26px;line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin:9px 0 13px;text-wrap:balance}
.dj-af-sp{font-family:var(--text);font-size:15.5px;line-height:1.62;color:var(--ink-2);margin:0;text-wrap:pretty;overflow-wrap:break-word}
.dj-af-link{color:inherit;font-weight:600;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:2px;text-decoration-color:color-mix(in srgb,currentColor 40%,transparent);transition:text-decoration-color .14s}
.dj-af-link:hover{text-decoration-color:currentColor}
.dj-af-cite{vertical-align:super;font-size:.66em;line-height:0;white-space:nowrap;margin-left:4px}
.dj-af-cite a{display:inline-grid;place-items:center;min-width:15px;height:15px;padding:0 3px;margin-left:3px;border-radius:5px;background:var(--magenta-wash);color:var(--magenta-deep);font-weight:600;text-decoration:none;line-height:1;transition:background .14s,color .14s}
.dj-af-cite a:first-child{margin-left:0}
.dj-af-cite a:hover{background:var(--magenta);color:#fff}
.dj-af-cited{background:var(--magenta-wash);color:var(--magenta-deep);font-weight:600;padding:1px 5px;border-radius:5px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.dj-af-svis{position:relative;background:linear-gradient(150deg,#fff,var(--mark-wash));border:1px solid var(--line);border-radius:18px;padding:20px 24px;box-shadow:0 12px 32px rgba(22,19,26,.07);aspect-ratio:3/2;display:grid;place-items:center;overflow:hidden}
.dj-af-svis svg{width:100%;height:100%;overflow:visible}
.dj-af-svis .af-draw{fill:none}
@media(max-width:760px){.dj-af-srow{grid-template-columns:1fr;gap:22px;padding:30px 0}.dj-af-srow:nth-child(even) .dj-af-stx{order:0}.dj-af-sh{font-size:23px}}
@media (prefers-reduced-motion: no-preference){
  .dj-aboutfull .af-draw{stroke-dasharray:700;stroke-dashoffset:700;animation:afDraw 1.5s cubic-bezier(.4,0,.2,1) .15s forwards}
  @keyframes afDraw{to{stroke-dashoffset:0}}
  .dj-aboutfull .af-pop{opacity:0;transform-box:fill-box;transform-origin:center;animation:afPop .5s cubic-bezier(.2,1.4,.4,1) forwards}
  @keyframes afPop{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
  .dj-aboutfull .af-rise{opacity:0;animation:afRise .6s cubic-bezier(.2,.7,.3,1) forwards}
  @keyframes afRise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
}
.dj-af-grouplab{font-family:var(--display);font-weight:600;font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin:22px 0 11px}
.dj-af-tracks{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dj-af-track{background:#fff;border:1px solid var(--line);border-left:4px solid var(--tac);border-radius:var(--r);padding:14px 16px}
.dj-af-track-tx{display:flex;flex-direction:column;gap:3px}
.dj-af-track-tx b{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink)}
.dj-af-track-tx small{font-family:var(--text);font-size:12.5px;line-height:1.4;color:var(--ink-2);text-wrap:pretty}
.dj-af-note{font-family:var(--text);font-size:13.5px;line-height:1.55;color:var(--muted);margin:13px 0 0;text-wrap:pretty}
.dj-af-feats{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dj-af-feat{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;transition:transform .14s,box-shadow .16s,border-color .14s}
.dj-af-feat:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(22,19,26,.08);border-color:color-mix(in srgb,var(--fc) 40%,var(--line))}
.dj-af-feat-ic{flex:0 0 auto;display:inline-grid;place-items:center;width:46px;height:46px;border-radius:13px;background:color-mix(in srgb,var(--fc) 13%,#fff);color:var(--fc)}
.dj-af-feat-tx{min-width:0}
.dj-af-feat-tx b{display:block;font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-.01em;color:var(--ink);margin-bottom:4px}
.dj-af-feat-tx p{font-family:var(--text);font-size:13.5px;line-height:1.52;color:var(--ink-2);margin:0;text-wrap:pretty}
.dj-af-made{display:flex;gap:18px;align-items:flex-start;margin-top:46px;padding:28px 30px;border-radius:20px;background:var(--ink);color:#fff;overflow:hidden}
.dj-af-made-ic{flex:0 0 auto;display:inline-grid;place-items:center;width:50px;height:50px;border-radius:14px;background:var(--magenta);color:#fff;box-shadow:0 4px 16px rgba(204,0,121,.4)}
.dj-af-made-tx{min-width:0}
.dj-af-made-h{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.015em;margin:0 0 7px;color:#fff}
.dj-af-made p{font-family:var(--text);font-size:14px;line-height:1.58;color:rgba(255,255,255,.82);margin:0;text-wrap:pretty}
.dj-af-by{display:inline-flex;align-items:center;gap:11px}
.dj-af-foot{margin-top:42px;padding-top:22px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.dj-af-by{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink-2)}
.dj-af-foot-actions{display:flex;gap:9px}
.dj-af-footbtn{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:8px 15px;cursor:pointer}
.dj-af-footbtn:hover{border-color:var(--ink-2);background:var(--wash)}
.dj-af-footbtn svg{flex:0 0 auto;color:var(--muted)}
@media(max-width:620px){.dj-af-tracks,.dj-af-feats{grid-template-columns:1fr}}
/* About: Contact/Privacy modal layered on the page */
.dj-af-modal-back{position:absolute;inset:0;z-index:20;background:rgba(22,19,26,.46);display:flex;align-items:flex-start;justify-content:center;padding:48px 20px;overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.dj-af-modal{width:100%;max-width:540px;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.dj-af-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--line-soft)}
.dj-af-modal-title{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.dj-af-modal-body{padding:20px 22px 24px}
.dj-af-modal-body.dj-legalpage{max-height:min(64vh,560px);overflow-y:auto}
/* redesigned contact modal: balanced equal-width actions + signature footer */
.dj-contactpage .dj-contact-lead{font-family:var(--text);font-size:15px;line-height:1.55;color:var(--ink-2);margin:0 0 18px;text-wrap:pretty}
.dj-contact-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dj-contact-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;height:48px;border-radius:13px;border:1px solid var(--line);font-family:var(--display);font-weight:600;font-size:14.5px;cursor:pointer;text-decoration:none;transition:transform .12s,box-shadow .14s,background .14s,border-color .14s}
.dj-contact-btn svg{flex:0 0 auto}
.dj-contact-btn:active{transform:translateY(1px)}
.dj-contact-linkedin{background:#0A66C2;border-color:#0A66C2;color:#fff;box-shadow:0 1px 2px rgba(10,102,194,.3)}
.dj-contact-linkedin:hover{background:#085296;border-color:#085296}
.dj-contact-email{background:#fff;color:var(--ink)}
.dj-contact-email:hover{border-color:var(--ink-2);background:var(--wash)}
.dj-contact-by{display:flex;align-items:center;gap:11px;margin-top:20px;padding-top:16px;border-top:1px solid var(--line-soft);font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink-2)}
.dj-contact-ava{flex:0 0 auto;display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--magenta);color:#fff;font-size:12px;font-weight:600;letter-spacing:.02em}
/* contact body sizes to its content so the modal doesn't leave a big empty gap above 'Got it' */
.dj-guide-dbody.dj-contactpage{flex:0 0 auto;overflow:visible;padding-bottom:8px}
.dj-contactpage .dj-contact-by{margin-top:18px;padding-top:15px}
.dj-guide-drawer:has(.dj-contactpage) .dj-guide-dfoot{border-top:0;padding-top:2px}
@media(max-width:460px){.dj-contact-actions{grid-template-columns:1fr}}
.dj-guide-back{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink-2);background:none;border:0;padding:11px 14px;margin-right:auto;cursor:pointer;border-radius:var(--r-pill);transition:background .14s}
.dj-guide-back:hover{background:var(--wash)}
.dj-guide-drawer.is-name{max-width:520px}
.dj-guide-namebody{display:block;padding:24px 26px 22px}
.dj-name-intro{margin:0 0 16px;font-size:14px;line-height:1.55;color:var(--ink-2)}
.dj-aboutpage{display:block;padding:22px 26px 8px}
.dj-aboutpage p{margin:0 0 13px;font-size:14.5px;line-height:1.62;color:var(--ink-2);text-wrap:pretty}
.dj-aboutpage-by{margin:4px 0 20px;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink)}
.dj-aboutpage-contact{border-top:1px solid var(--line-soft);padding-top:16px}
.dj-aboutpage-ctitle{font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink);margin-bottom:6px}
.dj-aboutpage-link{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:14px;color:#fff;background:#0a66c2;border-radius:var(--r-pill);padding:9px 16px;text-decoration:none;transition:filter .14s}
.dj-aboutpage-link:hover{filter:brightness(1.07)}
.dj-aboutpage-link svg{flex:0 0 auto}
.dj-aboutpage-actions{display:flex;flex-wrap:wrap;gap:10px}
.dj-aboutpage-email{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:9px 16px;cursor:pointer;transition:border-color .14s,background .14s}
.dj-aboutpage-email:hover{border-color:var(--ink-2);background:var(--wash)}
.dj-aboutpage-email svg{flex:0 0 auto;color:var(--muted)}
.dj-name-field{display:flex;align-items:center;gap:10px}
.dj-name-field .dj-jname{flex:1 1 auto;font-family:var(--display);font-weight:500;font-size:16px;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:11px 16px;transition:border-color .14s,box-shadow .14s}
.dj-name-field .dj-jname::placeholder{color:var(--faint);font-weight:400}
.dj-name-field .dj-jname:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 0 3px var(--magenta-wash)}
.dj-name-field .dj-jname-count{font-size:11px;color:var(--faint);font-variant-numeric:tabular-nums;flex:0 0 auto}
.dj-guide-eyebrow{font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.dj-guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:820px){.dj-guide-grid{grid-template-columns:1fr;gap:12px}}
.dj-gcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:16px 17px}
.dj-gcard-ic{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:10px;background:var(--gcw);color:var(--gc);margin-bottom:12px}
/* first-run onboarding: load-an-example CTA inside the guide */
.dj-guide-example{grid-column:1/-1;display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:var(--magenta-wash);border:1px solid color-mix(in srgb,var(--magenta) 26%,transparent);border-radius:var(--r);padding:14px 16px;cursor:pointer;transition:background .14s,border-color .14s}
.dj-guide-example:hover{background:color-mix(in srgb,var(--magenta) 12%,#fff);border-color:color-mix(in srgb,var(--magenta) 44%,transparent)}
.dj-guide-ex-ic{flex:0 0 auto;display:inline-grid;place-items:center;width:38px;height:38px;border-radius:11px;background:#fff;color:var(--magenta-deep);box-shadow:var(--shadow-sm)}
.dj-guide-ex-tx{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:2px}
.dj-guide-ex-tx b{font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-.01em}
.dj-guide-ex-tx small{font-family:var(--text);font-size:12.5px;line-height:1.45;color:var(--ink-2)}
.dj-guide-ex-go{flex:0 0 auto;display:inline-flex;color:var(--magenta-deep)}
/* privacy & terms page (reuses .dj-aboutpage prose) */
.dj-legalpage h4{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink);margin:18px 0 6px}
.dj-legalpage h4:first-of-type{margin-top:4px}
.dj-legal-updated{font-family:var(--display);font-weight:600;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);margin:0 0 6px}
.dj-legal-note{margin-top:18px;font-size:12.5px;color:var(--muted)}
.dj-gcard-t{display:block;font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);margin-bottom:5px}
.dj-gcard p{margin:0;font-size:12.5px;line-height:1.55;color:var(--ink-2)}
.dj-gcard-save{background:#FDF4DE;border-color:#ECD7A0}
.dj-gcard-save .dj-gcard-t{color:#33250A}
.dj-gcard-save p{color:#5C3D04}
.dj-gcard-save p b{font-family:var(--display);font-weight:600;color:#33250A;background:#FAD86B;padding:1px 0;white-space:nowrap}
.dj-gcard-save p b svg{vertical-align:-2px;margin-right:1px}
.dj-guide-hide{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--ink-2);font-family:var(--display);font-weight:600;font-size:12px;border-radius:var(--r-pill);padding:6px 13px;cursor:pointer;transition:border-color .12s,color .12s,background .12s}
.dj-guide-hide:hover{border-color:var(--ink-2);color:var(--ink);background:var(--wash)}

/* ---------- Scroll: route + board aligned over columns ---------- */
.dj-scroll{flex:1 1 auto;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;padding:24px 20px 28px;cursor:grab}
.dj-scroll.dj-grabbing{cursor:grabbing;user-select:none}
.dj-route{display:flex;gap:22px;align-items:center;width:max-content;margin-bottom:24px}
.dj-rcell{flex:0 0 340px;display:flex;align-items:center;min-width:0}
.dj-rcell-spacer{flex-basis:240px}
.dj-chip{display:inline-flex;align-items:center;gap:7px;flex:0 1 auto;min-width:0;background:#fff;border:1.5px solid var(--ac);border-radius:var(--r-pill);padding:6px 13px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink);white-space:nowrap;cursor:default}
.dj-chip .dj-dot{background:var(--ac)}
.dj-chip-tx{overflow:hidden;text-overflow:ellipsis}
.dj-arw{flex:1;display:flex;align-items:center;gap:7px;margin:0 -12px 0 14px;color:var(--rule-color);min-width:30px}
.dj-arw-line{flex:1;min-width:24px;height:var(--rule-dot);background-image:radial-gradient(circle,var(--rule-color) calc(var(--rule-dot)/2),transparent calc(var(--rule-dot)/2 + .6px));background-size:var(--rule-gap) var(--rule-dot);background-repeat:repeat-x;background-position:left center;opacity:.9}
.dj-arw-h{flex:0 0 auto;opacity:.85}
.dj-rcell-end .dj-arw{display:none}

/* ---------- Board ---------- */
.dj-board{display:flex;gap:22px;align-items:flex-start;width:max-content}
/* trailing spacer: padding/margin at a scroll container's end is clipped, but a flex
   item is counted in max-content width — keeps the board off the viewport edge */
.dj-board::after,.dj-route::after{content:"";flex:0 0 2px;align-self:stretch}
.dj-col{flex:0 0 340px;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.dj-col.collapsed .dj-col-h{border-bottom:0}
.dj-col-h{display:flex;align-items:center;gap:9px;padding:12px 12px;border-bottom:1px solid var(--line-soft);border-top:3px solid var(--ac);background:#fff;min-height:50px}
.dj-col-dot{width:10px;height:10px;border-radius:var(--r-pill);flex:0 0 auto;background:var(--ac)}
.dj-col-name{flex:1;min-width:0;font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-col-ctrls{display:flex;gap:3px;opacity:0;transition:opacity .12s;flex:0 0 auto}
.dj-col:hover .dj-col-ctrls{opacity:1}
.dj-cbtn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:8px;cursor:pointer;transition:.12s}
.dj-cbtn:hover:not(:disabled){border-color:var(--ink-2);color:var(--ink);box-shadow:var(--shadow-sm)}
.dj-cbtn:disabled{opacity:.35;cursor:default}
.dj-col-b{padding:13px;display:flex;flex-direction:column;gap:12px}

.dj-x{border:0;background:none;color:var(--faint);cursor:pointer;padding:4px;border-radius:7px;display:inline-flex;flex:0 0 auto}
.dj-x:hover{background:var(--wash);color:var(--magenta-deep)}

.dj-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:13px 14px}
.dj-card-display{cursor:pointer;transition:border-color .12s,box-shadow .12s}
.dj-card-display:hover{border-color:color-mix(in srgb,var(--ac) 45%,var(--line));box-shadow:var(--shadow-sm)}
.dj-cardtitle-d{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ac);padding-right:48px;margin-bottom:4px;min-height:18px}
.dj-empty{color:var(--faint);font-weight:600}
.dj-val{font-family:var(--text);font-size:13.4px;line-height:1.5;color:var(--ink-2);white-space:pre-wrap;text-wrap:pretty}
.dj-empty-hint{font-size:12px;color:var(--faint)}
.dj-card-eyebrow{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:-.01em;line-height:1.3;margin:0 30px 7px 0;text-wrap:pretty}
.dj-card-q{font-family:var(--display);font-weight:600;font-size:14.5px;line-height:1.34;color:var(--ink);white-space:pre-wrap;text-wrap:pretty;margin:0 0 2px}
.dj-flab-sp{margin-top:10px}
.dj-card-det{margin-top:11px;border-top:1px solid var(--line-soft);padding-top:9px}
.dj-card-det>summary{display:flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:12px;color:var(--ink-2);cursor:pointer;list-style:none}
.dj-card-det>summary::-webkit-details-marker{display:none}
.dj-card-det>summary:hover{color:var(--ink)}
.dj-card-det-ic{width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);transition:transform .15s;flex:0 0 auto;margin-left:1px}
.dj-card-det[open]>summary .dj-card-det-ic{transform:rotate(45deg)}
.dj-card-det-in{margin-top:9px;display:flex;flex-direction:column;gap:9px}
.dj-reframe-meta{display:inline-flex;align-items:center;gap:5px;margin-top:9px;font-family:var(--display);font-weight:600;font-size:11.5px;color:var(--magenta-deep);background:#fff;border:1px solid color-mix(in srgb,var(--magenta) 30%,#fff);border-radius:var(--r-pill);padding:4px 10px 4px 8px;cursor:pointer;transition:background .12s}
.dj-reframe-meta:hover{background:var(--magenta-wash)}
.dj-card:focus-within{border-color:color-mix(in srgb,var(--ac) 45%,var(--line));box-shadow:var(--shadow-sm)}
.dj-num{position:absolute;top:11px;right:34px;width:21px;height:21px;border-radius:var(--r-pill);background:var(--ac);color:#fff;font-family:var(--display);font-weight:600;font-size:11.5px;display:inline-flex;align-items:center;justify-content:center}
.dj-card-x{position:absolute;top:9px;right:8px}
.dj-cardtitle{width:100%;border:0;outline:0;background:none;font-family:var(--display);font-weight:600;font-size:14px;color:var(--ac);padding:0 64px 0 0;margin-bottom:4px}
.dj-cardtitle::placeholder{color:var(--faint)}
.dj-field{margin-top:8px}
.dj-flab{font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);margin-bottom:2px}
.dj-area{width:100%;border:0;outline:0;background:none;resize:none;overflow:hidden;font-family:var(--text);font-size:13.6px;line-height:1.5;color:var(--ink-2);padding:0}
.dj-area::placeholder{color:var(--faint)}

.dj-add{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;border:1.5px dashed var(--line);background:none;color:var(--muted);font-family:var(--display);font-weight:600;font-size:12.5px;border-radius:11px;padding:9px;cursor:pointer}
.dj-add:hover{border-color:var(--ac);color:var(--ac)}

/* milestones */
.dj-ms{border-radius:var(--r);padding:13px 14px;border:1px solid}
.dj-ms-lab{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.dj-ms-labrow{display:flex;align-items:center;justify-content:space-between;gap:8px}
.dj-ms-text{font-family:var(--text);font-size:14px;line-height:1.5;color:var(--ink);white-space:pre-wrap;text-wrap:pretty}
.dj-ms-challenge .dj-ms-text{font-family:var(--display);font-weight:500;font-size:14.5px}
.dj-ms-click{cursor:pointer;transition:border-color .12s,box-shadow .12s}
.dj-ms-click:hover{box-shadow:var(--shadow-sm)}
.dj-ms-challenge{background:var(--magenta-wash);border-color:color-mix(in srgb,var(--magenta) 30%,#fff)}
.dj-ms-challenge .dj-ms-lab{color:var(--magenta-deep)}
.dj-ms-challenge .dj-area{font-family:var(--display);font-weight:500;font-size:14.5px;color:var(--ink)}
.dj-ms-neutral{background:var(--wash);border-color:var(--line)}
.dj-ms-neutral .dj-ms-lab{color:var(--ink-2)}
.dj-ms-blue{background:var(--blue-wash);border-color:color-mix(in srgb,var(--blue) 30%,#fff)}
.dj-ms-blue .dj-ms-lab{color:var(--blue-deep)}
.dj-deliv,.dj-wrap{display:flex;flex-direction:column;gap:12px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.dj-th-grp{margin-top:6px}
.dj-th-grp:first-child{margin-top:0}
.dj-sub-lab{font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--blue-deep);opacity:.75;margin-bottom:6px}
.dj-numlist{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px;counter-reset:n}
.dj-numlist li{position:relative;padding-left:24px;counter-increment:n}
.dj-numlist li::before{content:counter(n);position:absolute;left:0;top:1px;width:17px;height:17px;border-radius:var(--r-pill);background:var(--blue);color:#fff;font-family:var(--display);font-weight:600;font-size:10px;display:inline-flex;align-items:center;justify-content:center}
.dj-numrow{display:flex;align-items:flex-start;gap:6px}
.dj-numrow .dj-area{flex:1}
.dj-strong{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.35}
.dj-litem{cursor:pointer;border-radius:9px;padding:3px 5px;margin:-3px -5px;transition:background .12s}
.dj-litem:hover{background:color-mix(in srgb,var(--blue) 9%,transparent)}
.dj-li-ph{color:var(--faint);font-weight:500}
.dj-lelab{font-family:var(--text);font-size:12.6px;line-height:1.45;color:var(--ink-2);margin-top:2px;white-space:pre-wrap;text-wrap:pretty}
.dj-mini-x{padding:2px;margin-top:1px}
.dj-add-sm{margin-top:8px;padding:7px;font-size:11.5px}

/* add-phase: a native ghost column at the end of the board */
.dj-addcol{flex:0 0 300px;max-width:300px;align-self:flex-start}
.dj-addcol-cta{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;min-height:128px;padding:24px 18px;border:1.5px dashed color-mix(in srgb,var(--slate) 32%,var(--line));border-radius:var(--r-lg);background:transparent;color:var(--slate);font-family:var(--display);font-weight:600;font-size:14px;cursor:pointer;transition:background .14s,border-color .14s,color .14s}
.dj-addcol-cta:hover{border-color:var(--slate);background:var(--slate-wash)}
.dj-addcol-plus{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;border-radius:var(--r-pill);background:var(--slate-wash);color:var(--slate);transition:background .14s}
.dj-addcol-cta:hover .dj-addcol-plus{background:#fff}
.dj-addcol-ctatx{text-align:center;line-height:1.4;max-width:210px}
.dj-addcol-pick{border:1.5px dashed color-mix(in srgb,var(--slate) 32%,var(--line));border-radius:var(--r-lg);background:var(--surface);overflow:hidden}
.dj-addcol-head{display:flex;align-items:flex-start;gap:8px;padding:14px 14px 11px}
.dj-addcol-lab{flex:1;font-family:var(--display);font-weight:600;font-size:13.5px;letter-spacing:-.005em;color:var(--ink);line-height:1.32}
.dj-addcol-head .dj-cbtn{font-size:15px;font-weight:600;line-height:1;flex:0 0 auto}
.dj-addcol-chips{display:flex;flex-wrap:wrap;gap:8px;padding:2px 14px 16px}
.dj-pick-chip{cursor:pointer;flex:0 0 auto;transition:background .12s,color .12s,border-color .12s}
.dj-pick-chip:hover{background:var(--ac);color:#fff}
.dj-pick-chip:hover .dj-dot{background:#fff}
.dj-pick-used{cursor:default;opacity:.42;filter:grayscale(.5)}
.dj-pick-locked{cursor:not-allowed;opacity:.34;filter:grayscale(.7)}
.dj-pick-locked:hover{background:none;color:inherit}
.dj-pick-locked:hover .dj-dot{background:var(--ac)}
.dj-pick-used:hover{background:none;color:inherit}
.dj-pick-used:hover .dj-dot{background:var(--ac)}
.dj-pick-tick{margin-left:5px;font-size:11px;font-weight:800;line-height:1}
.dj-pick-outcome{flex-basis:100%;justify-content:center}
.dj-pick-div{flex-basis:100%;height:var(--rule-dot);margin:5px 0 1px;background-image:radial-gradient(circle,color-mix(in srgb,var(--slate) 50%,var(--line)) calc(var(--rule-dot)/2),transparent calc(var(--rule-dot)/2 + .6px));background-size:var(--rule-gap) var(--rule-dot);background-repeat:repeat-x;background-position:left center;opacity:.9}
.dj-menu-item{display:flex;align-items:center;gap:9px;border:0;background:none;text-align:left;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink);padding:9px 10px;border-radius:9px;cursor:pointer}
.dj-menu-item:hover{background:var(--wash)}
.dj-menu-grouplab{display:flex;align-items:center;gap:8px;padding:9px 10px 3px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.dj-menu-grouplab svg{color:var(--muted);flex:0 0 auto;width:13px;height:13px}
.dj-menu-subitem{padding:6px 10px 6px 14px;gap:10px;font-weight:600;font-size:13px;color:var(--ink)}
.dj-menu-subitem .dj-menu-subdot{width:5px;height:5px;border-radius:50%;background:var(--magenta);flex:0 0 auto;margin:0 1px}

/* ---------- Modal ---------- */
.dj-modal-ov{position:fixed;inset:0;z-index:100;background:rgba(22,19,26,.42);display:flex;align-items:flex-start;justify-content:center;padding:48px 20px;overflow-y:auto;backdrop-filter:blur(2px)}
.dj-modal{width:100%;max-width:560px;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:dj-pop .16s ease}
@keyframes dj-pop{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}
.dj-modal-h{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line-soft)}
.dj-modal-title{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-.01em;color:var(--ink);position:relative;padding-left:14px}
.dj-modal-title::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:var(--r-pill);background:var(--ac)}
.dj-modal-b{padding:18px;display:flex;flex-direction:column;gap:15px;max-height:62vh;overflow-y:auto}
.dj-modal-field{display:flex;flex-direction:column;gap:5px}
.dj-modal-flab{display:flex;align-items:center;justify-content:space-between;gap:8px}
.dj-field-x{border:0;background:none;color:var(--faint);cursor:pointer;display:inline-flex;padding:2px;border-radius:6px}
.dj-field-x:hover{background:var(--wash);color:var(--magenta-deep)}
.dj-addrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px;padding-top:14px;border-top:1px dashed var(--line)}
.dj-chip-add{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink-2);background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:6px 12px;cursor:pointer}
.dj-chip-add:hover{border-color:var(--magenta);color:var(--magenta-deep);background:var(--magenta-wash)}
.dj-modal-input,.dj-modal-area{width:100%;border:1px solid var(--line);border-radius:10px;background:var(--paper);padding:10px 12px;font-family:var(--text);font-size:14px;color:var(--ink);outline:none;transition:border-color .12s,box-shadow .12s}
.dj-modal-input{font-family:var(--display);font-weight:600}
.dj-modal-area{resize:none;overflow:hidden;line-height:1.5;min-height:48px}
.dj-modal-input:focus,.dj-modal-area:focus{border-color:var(--magenta);box-shadow:0 0 0 3px var(--magenta-wash)}
.dj-modal-input::placeholder,.dj-modal-area::placeholder{color:var(--faint)}
.dj-modal-f{display:flex;align-items:center;gap:10px;padding:14px 18px;border-top:1px solid var(--line-soft);background:var(--paper)}
.dj-btn.dj-primary{background:var(--ac);border-color:var(--ac);color:#fff}
.dj-btn.dj-primary:hover{filter:brightness(1.06)}
.dj-btn.dj-danger{color:var(--magenta-deep);border-color:var(--magenta-wash);background:var(--magenta-wash)}
.dj-btn.dj-danger:hover{border-color:var(--magenta)}
.dj-confirm-back{position:fixed;inset:0;z-index:400;background:rgba(22,19,26,.5);display:flex;align-items:center;justify-content:center;padding:20px;animation:dj-pv-fade .16s ease}
.dj-confirm{width:100%;max-width:400px;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:24px 24px 20px;text-align:center;animation:dj-pop .16s ease}
.dj-confirm-ic{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--r-pill);background:var(--cf-tint,var(--magenta-wash));color:var(--cf-accent,var(--magenta-deep));margin-bottom:12px}
.dj-confirm-title{display:block;font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:-.01em;color:var(--ink)}
.dj-confirm-msg{margin:8px 0 0;font-size:13.5px;line-height:1.55;color:var(--ink-2)}
.dj-confirm-btns{display:flex;gap:10px;justify-content:center;margin-top:18px}
.dj-confirm-cancel{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink-2);background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:10px 20px;cursor:pointer;transition:.14s}
.dj-confirm-cancel:hover{background:var(--line-soft)}
.dj-confirm-del{font-family:var(--display);font-weight:600;font-size:13.5px;color:#fff;background:var(--cf-accent,var(--magenta));border:1.5px solid var(--cf-accent,var(--magenta));border-radius:var(--r-pill);padding:10px 20px;cursor:pointer;transition:.14s}
.dj-confirm-del:hover{filter:brightness(.92)}

/* ---------- Present view (read-only Journey overview) ---------- */
.dj-btn.dj-present-btn{display:inline-flex;align-items:center;gap:6px;background:var(--magenta);border-color:var(--magenta);color:#fff;font-weight:600}
.dj-btn.dj-present-btn:hover{background:var(--magenta-deep);border-color:var(--magenta-deep)}
.dj-btn.dj-present-btn:disabled{background:var(--magenta);border-color:var(--magenta)}
/* Present dropdown */
.dj-present-wrap{position:relative;display:inline-flex}
.dj-present-chev{display:inline-flex;margin-left:1px;transition:transform .15s}
.dj-present-chev.up{transform:rotate(180deg)}
.dj-present-backdrop{position:fixed;inset:0;z-index:60}
.dj-present-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:61;width:340px;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:6px;animation:dj-pop .14s ease}
@keyframes dj-pop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.dj-present-item{display:flex;align-items:center;gap:14px;width:100%;min-height:81px;box-sizing:border-box;text-align:left;background:none;border:0;padding:13px 14px;border-radius:var(--r);cursor:pointer;transition:background .12s}
.dj-present-item:hover{background:var(--wash)}
.dj-present-item-feat{background:var(--magenta-wash)}
.dj-present-item-feat:hover{background:color-mix(in srgb,var(--magenta) 14%,#fff)}
.dj-present-item-feat .dj-present-it-txt b{color:var(--magenta-deep)}
.dj-report-create{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;margin-top:6px;border:1.5px solid var(--magenta);background:var(--magenta);color:#fff;font-family:var(--display);font-weight:600;font-size:14.5px;padding:13px 20px;border-radius:var(--r-pill);cursor:pointer;transition:.14s}
.dj-report-create:hover{filter:brightness(.95)}
.dj-report-create svg{flex:0 0 auto}
.dj-present-ic{flex:0 0 auto;width:26px;display:inline-flex;align-items:center;justify-content:center;color:var(--magenta)}
.dj-present-it-txt{min-width:0}
.dj-present-it-txt b{display:block;font-family:var(--display);font-weight:600;font-size:15px;line-height:1.3;letter-spacing:-.01em;color:var(--ink)}
.dj-present-it-txt small{display:block;font-family:var(--text);font-weight:400;font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.35}
.dj-pv-ov{position:fixed;inset:0;z-index:200;background:var(--paper);display:flex;flex-direction:column;overflow:hidden;animation:dj-pv-fade .18s ease}
@keyframes dj-pv-fade{from{opacity:0}to{opacity:1}}
.dj-pv-top{flex:0 0 auto;background:#fff;border-bottom:1px solid var(--line);padding:14px 22px 0;z-index:2}
.dj-pv-top-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.dj-pv-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--ink-2);background:none;border:0;cursor:pointer;padding:7px 10px 7px 4px;border-radius:var(--r-pill);transition:color .12s,background .12s}
.dj-pv-back:hover{color:var(--magenta-deep);background:var(--wash)}
.dj-pv-titlewrap{min-width:0}
.dj-pv-title{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-.02em;margin:0;color:var(--ink)}
.dj-pv-sub{display:block;font-family:var(--text);font-weight:500;font-size:12.5px;color:var(--muted);margin-top:2px}
.dj-pv-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dj-pv-badge{display:inline-flex;align-items:center;font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.01em;color:var(--ac,var(--blue));background:color-mix(in srgb,var(--ac,var(--blue)) 13%,#fff);border-radius:var(--r-pill);padding:6px 13px;white-space:nowrap}
.dj-pv-scope{display:inline-flex;background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px;gap:2px}
.dj-pv-scope-btn{font-family:var(--display);font-weight:600;font-size:12px;color:var(--muted);background:none;border:0;padding:5px 12px;border-radius:var(--r-pill);cursor:pointer;line-height:1;transition:.12s}
.dj-pv-scope-btn:hover{color:var(--ink)}
.dj-pv-scope-btn.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}
.dj-pv-xbtn{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:13px;color:#fff;background:var(--magenta);border:1.5px solid var(--magenta);border-radius:var(--r-pill);padding:7px 15px;cursor:pointer;transition:.14s;white-space:nowrap}
.dj-pv-xbtn:hover:not(:disabled){background:var(--magenta-deep);border-color:var(--magenta-deep)}
.dj-pv-xbtn:disabled{opacity:.5;cursor:default}
.dj-pv-xbtn.busy{opacity:.6;pointer-events:none}
.dj-pv-close{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:9px;cursor:pointer;transition:.12s}
.dj-pv-close:hover{border-color:var(--ink-2);color:var(--ink)}
.dj-pv-ribbon{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:12px 0 13px;overflow-x:auto}
.dj-pv-rib-chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink-2);background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:6px 12px;cursor:pointer;white-space:nowrap;transition:.12s}
.dj-pv-rib-chip:hover{border-color:var(--ink-2);background:#fff}
.dj-pv-rib-dot{width:8px;height:8px;border-radius:var(--r-pill);flex:0 0 auto}
.dj-pv-rib-sep{color:var(--faint);font-size:13px;flex:0 0 auto}
.dj-pv-board{flex:1 1 auto;min-height:0;display:flex;gap:16px;align-items:stretch;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:78px 22px 96px;cursor:grab}
.dj-pv-board.dj-grabbing{cursor:grabbing;user-select:none}
.dj-pv-col{flex:0 0 340px;display:flex;flex-direction:column;min-height:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.dj-pv-col-h{display:flex;align-items:center;gap:9px;padding:14px 16px;border-bottom:1px solid var(--line-soft);border-top:3px solid var(--ac);background:#fff;flex:0 0 auto}
.dj-pv-col-dot{width:10px;height:10px;border-radius:var(--r-pill);flex:0 0 auto}
.dj-pv-col-name{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink)}
.dj-pv-col-body{flex:1;min-height:0;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:13px;scrollbar-width:thin}
.dj-pv-col-body::-webkit-scrollbar{width:8px}
.dj-pv-col-body::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px;border:2px solid var(--surface)}
.dj-pv-empty-col{color:var(--faint);font-size:14px;text-align:center;padding:18px 0}
.dj-pv-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:15px 16px}
.dj-pv-num{position:absolute;top:13px;right:13px;width:22px;height:22px;border-radius:var(--r-pill);color:#fff;font-family:var(--display);font-weight:600;font-size:12px;display:grid;place-items:center}
.dj-pv-eyebrow{font-family:var(--display);font-weight:600;font-size:13.5px;letter-spacing:-.01em;margin:0 30px 7px 0;line-height:1.3}
.dj-pv-flab{font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);margin:0 0 3px}
.dj-pv-flab-sp{margin-top:11px}
.dj-pv-q{font-family:var(--display);font-weight:600;font-size:15.5px;line-height:1.32;color:var(--ink);margin:0 0 2px;white-space:pre-wrap;text-wrap:pretty;padding-right:28px}
.dj-pv-c{font-size:13.8px;line-height:1.55;color:var(--ink-2);white-space:pre-wrap;text-wrap:pretty}
.dj-pv-det{margin-top:12px;border-top:1px solid var(--line-soft);padding-top:10px}
.dj-pv-det summary{display:flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:12px;color:var(--magenta-deep);cursor:pointer;list-style:none}
.dj-pv-det summary::-webkit-details-marker{display:none}
.dj-pv-det-ic{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);transition:transform .15s;flex:0 0 auto;margin-left:2px}
.dj-pv-det[open] .dj-pv-det-ic{transform:rotate(45deg)}
.dj-pv-det-in{margin-top:9px;display:flex;flex-direction:column;gap:9px}
.dj-pv-det-wrap{border-top-color:color-mix(in srgb,var(--pc) 22%,transparent)}
.dj-pv-det-wrap summary{color:var(--pc)}
.dj-pv-body{font-size:13.2px;line-height:1.55;color:var(--ink-2);white-space:pre-wrap;text-wrap:pretty}
.dj-pv-ms-lab{display:flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.dj-pv-deliv-ic{display:inline-grid;place-items:center;flex:0 0 auto}
.dj-pv-ms-text{font-size:14.5px;line-height:1.5;color:var(--ink);font-weight:500;white-space:pre-wrap;text-wrap:pretty}
.dj-pv-ms-challenge{background:var(--magenta-wash);border-color:color-mix(in srgb,var(--magenta) 30%,#fff)}
.dj-pv-ms-challenge .dj-pv-ms-lab{color:var(--magenta-deep)}
.dj-pv-ms-matter,.dj-pv-ms-outcome{background:var(--wash);border-color:var(--line)}
.dj-pv-ms-matter .dj-pv-ms-lab,.dj-pv-ms-outcome .dj-pv-ms-lab{color:var(--ink-2)}
.dj-pv-ms-redef,.dj-pv-ms-blue{background:var(--blue-wash);border-color:color-mix(in srgb,var(--blue) 30%,#fff)}
.dj-pv-ms-redef .dj-pv-ms-lab,.dj-pv-ms-blue .dj-pv-ms-lab{color:var(--blue-deep)}
.dj-pv-thgrp{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--blue-deep);opacity:.8;margin:11px 0 8px}
.dj-pv-ms-lab + div .dj-pv-thgrp,.dj-pv-ms-blue > div:first-of-type .dj-pv-thgrp{margin-top:0}
.dj-pv-prlist{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px;counter-reset:pr}
.dj-pv-prlist li{position:relative;padding-left:24px;counter-increment:pr}
.dj-pv-prlist li::before{content:counter(pr);position:absolute;left:0;top:1px;width:17px;height:17px;border-radius:var(--r-pill);background:var(--blue);color:#fff;font-family:var(--display);font-weight:600;font-size:10px;display:grid;place-items:center}
.dj-pv-prst{font-family:var(--display);font-weight:600;font-size:14px;line-height:1.35;color:var(--ink)}
.dj-pv-prel{font-size:12.8px;line-height:1.5;color:var(--ink-2);margin-top:3px;white-space:pre-wrap;text-wrap:pretty}
.dj-pv-wrap{border:1px solid color-mix(in srgb,var(--pc) 26%,#fff);background:color-mix(in srgb,var(--pc) 7%,#fff)}
.dj-pv-subq .dj-pv-prlist li::before{background:var(--pc)}
.dj-pv-wrap-lab{display:flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--pc);margin-bottom:6px}
.dj-pv-wrap-ic{display:inline-flex;flex:0 0 auto}
.dj-pv-det-wrap summary .dj-pv-wrap-ic{margin-right:2px}
.dj-pv-empty{flex:1;display:grid;place-items:center;text-align:center;color:var(--muted);font-size:15px;padding:0 24px}
.dj-pv-export{overflow:visible;width:max-content;align-items:flex-start}
.dj-pv-export .dj-pv-col{height:auto;max-height:none}
.dj-pv-export .dj-pv-col-body{overflow:visible;max-height:none}
@media(max-width:900px){.dj-pv-col{flex-basis:300px}.dj-pv-top{padding:12px 16px 0}.dj-pv-board{padding:76px 16px 92px;gap:13px}}
@media(max-width:680px){.dj-pv-ov{overflow:auto}.dj-pv-board{flex-direction:column;overflow:visible;gap:14px;padding:16px}.dj-pv-col{flex:1 1 auto;width:100%}.dj-pv-col-body{overflow:visible}}

/* ===== Present: mode switcher ===== */
.dj-pv-modes{display:inline-flex;background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:3px;gap:2px}
.dj-pv-mode-btn{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--muted);background:none;border:0;padding:6px 13px;border-radius:var(--r-pill);cursor:pointer;line-height:1;transition:.12s;white-space:nowrap}
.dj-pv-mode-btn:hover{color:var(--ink)}
.dj-pv-mode-btn.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}

/* ===== Present: diagram stage (diamond + organic share the scaler) ===== */
.dj-pv-diagram{flex:1 1 auto;min-height:0;overflow:auto;position:relative;display:flex;flex-direction:column;justify-content:center}
.dj-pv-backfloat{position:absolute;top:22px;left:20px;z-index:30}
/* shared/normal present: top-left cluster holds Back + Share */
.dj-pv-topleft{position:absolute;top:22px;left:20px;z-index:30;display:flex;align-items:center;gap:10px}
.dj-pv-share{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--display);font-weight:600;font-size:12.5px;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .14s,color .14s,border-color .14s}
.dj-pv-share:hover{background:var(--ink);color:#fff;border-color:transparent}
.dj-pv-share svg{flex:0 0 auto;width:14px;height:14px}
@media(max-width:560px){.dj-pv-share-lab{display:none}.dj-pv-share{padding:0 11px}}
/* reflection pre-flight modal (asked before a present mode opens, research tracks) */
.dj-reflask{position:relative;width:min(440px,calc(100vw - 36px));background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:30px 28px 24px;text-align:center;animation:dj-pop .16s ease}
.dj-reflask-ic{display:inline-flex;width:46px;height:46px;border-radius:50%;align-items:center;justify-content:center;background:var(--slate-wash);color:var(--slate);margin-bottom:15px}
.dj-reflask-title{margin:0;font-family:var(--display);font-weight:600;font-size:21px;color:var(--ink);letter-spacing:-.01em}
.dj-reflask-msg{margin:10px 0 22px;font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.dj-reflask-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dj-reflask-hide,.dj-reflask-show{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:44px;border-radius:10px;font-family:var(--display);font-weight:600;font-size:14px;cursor:pointer;transition:background .12s,border-color .12s,color .12s}
.dj-reflask-hide{border:1.5px solid var(--line);background:#fff;color:var(--ink)}
.dj-reflask-hide:hover{border-color:var(--slate);background:var(--wash)}
.dj-reflask-show{border:0;background:var(--slate);color:#fff}
.dj-reflask-show:hover{background:var(--ink)}
.dj-reflask-x{position:absolute;top:12px;right:12px;border:0;background:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;display:inline-flex}
.dj-reflask-x:hover{background:var(--wash);color:var(--ink)}
.dj-reflask svg{flex:0 0 auto}
/* share modal */
.dj-share-back{position:fixed;inset:0;z-index:160;background:rgba(22,19,26,.5);display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.dj-share-card{position:relative;width:min(480px,100%);background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:28px 28px 24px}
.dj-share-x{position:absolute;top:13px;right:13px;width:32px;height:32px;border:0;background:transparent;font-size:21px;line-height:1;color:var(--muted);cursor:pointer;border-radius:8px}
.dj-share-x:hover{background:var(--wash);color:var(--ink)}
.dj-share-h{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.01em;color:var(--ink);margin:0 0 9px}
.dj-share-p{font-family:var(--text);font-size:14px;line-height:1.55;color:var(--ink-2);margin:0 0 16px}
.dj-share-linkrow{display:flex;gap:8px}
.dj-share-input{flex:1 1 auto;min-width:0;height:40px;padding:0 12px;border:1px solid var(--line);border-radius:10px;background:var(--wash);font-family:var(--text);font-size:12.5px;color:var(--ink-2)}
.dj-share-copy{flex:0 0 auto;height:40px;padding:0 17px;border:0;border-radius:10px;background:var(--ink);color:#fff;font-family:var(--display);font-weight:600;font-size:13.5px;cursor:pointer}
.dj-share-copy:hover{background:var(--magenta)}
.dj-share-note{display:flex;gap:8px;align-items:flex-start;margin:15px 0 0;font-family:var(--text);font-size:12px;line-height:1.5;color:var(--muted)}
.dj-share-note svg{flex:0 0 auto;margin-top:1px;color:var(--faint)}
.dj-share-toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%);z-index:170;background:var(--ink);color:#fff;font-family:var(--display);font-weight:600;font-size:13.5px;padding:10px 18px;border-radius:var(--r-pill);box-shadow:var(--shadow-lg)}
/* shared-link loading + invalid states (full-page takeover) */
.dj-share-load{position:fixed;inset:0;display:grid;place-items:center;background:var(--paper);z-index:200}
.dj-share-spin{width:34px;height:34px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--magenta);animation:dj-spin .8s linear infinite}
@keyframes dj-spin{to{transform:rotate(360deg)}}
.dj-share-bad{position:fixed;inset:0;display:grid;place-items:center;background:var(--paper);padding:24px;text-align:center;z-index:200}
.dj-share-bad h1{font-family:var(--display);font-weight:600;font-size:24px;letter-spacing:-.01em;color:var(--ink);margin:0 0 10px}
.dj-share-bad p{font-family:var(--text);font-size:15px;line-height:1.55;color:var(--ink-2);margin:0 auto 20px;max-width:420px}
.dj-share-badlink{display:inline-flex;height:42px;align-items:center;padding:0 22px;border-radius:var(--r-pill);background:var(--ink);color:#fff;text-decoration:none;font-family:var(--display);font-weight:600;font-size:14px}
.dj-share-badlink:hover{background:var(--magenta)}
/* portrait-only nudge: present surfaces are designed for landscape */
.dj-rotate-hint{display:none}
@media (orientation:portrait) and (pointer:coarse){
  .dj-rotate-hint{display:inline-flex;align-items:center;gap:8px;position:absolute;top:18px;left:50%;transform:translateX(-50%);z-index:40;background:var(--ink);color:#fff;font-family:var(--display);font-weight:600;font-size:12.5px;letter-spacing:-.005em;padding:8px 15px;border-radius:var(--r-pill);box-shadow:var(--shadow);pointer-events:none;max-width:88vw;text-align:center}
}
/* ===== Present: Sprint Week timeline (sprint only) ===== */
.dj-sp-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.dj-sp-rail{stroke:var(--line);stroke-width:3}
.dj-sp-arrow{fill:none;stroke:var(--faint);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.dj-sp-html{position:absolute;inset:0}
.dj-sp-term{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:7px;background:none;border:0;cursor:pointer;padding:0}
.dj-sp-term-ring{width:52px;height:52px;border-radius:50%;background:#fff;border:1.5px solid currentColor;display:grid;place-items:center;transition:box-shadow .14s}
.dj-sp-term:hover .dj-sp-term-ring{box-shadow:0 0 0 4px color-mix(in srgb,var(--phase-bookend) 12%,#fff)}
.dj-sp-term-lab{font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}
.dj-sp-card{position:absolute;background:#fff;border:1px solid var(--line);border-top:3px solid var(--pc);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.dj-sp-cardhead{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:0;border-bottom:1px solid var(--line-soft);padding:13px 14px;cursor:pointer;transition:background .12s}
.dj-sp-cardhead:hover{background:color-mix(in srgb,var(--pc) 6%,#fff)}
.dj-sp-num{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--pc);color:#fff;font-family:var(--display);font-weight:600;font-size:13px;display:grid;place-items:center}
.dj-sp-headtx{min-width:0;display:flex;flex-direction:column;gap:1px}
.dj-sp-name{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-sp-pass{font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.dj-sp-body{display:flex;flex-direction:column;gap:6px;padding:10px}
.dj-sp-act{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:var(--wash);border:1px solid transparent;border-radius:9px;padding:8px 10px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-sp-act:hover{background:#fff;border-color:color-mix(in srgb,var(--pc) 40%,var(--line))}
.dj-sp-actnum{flex:0 0 auto;width:18px;height:18px;border-radius:50%;background:var(--pc);color:#fff;font-family:var(--display);font-weight:600;font-size:10.5px;display:grid;place-items:center}
.dj-sp-acttx{min-width:0;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-sp-empty{color:var(--faint);font-weight:600;font-size:13px;padding:4px 2px}
.dj-sp-wrap{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;margin-top:2px;background:color-mix(in srgb,var(--pc) 8%,#fff);border:1px solid color-mix(in srgb,var(--pc) 26%,#fff);color:var(--pc);border-radius:var(--r-pill);padding:5px 11px;font-family:var(--display);font-weight:600;font-size:11px;cursor:pointer}
.dj-sp-wrap:hover{background:color-mix(in srgb,var(--pc) 14%,#fff)}
.dj-sp-wrapic{display:inline-flex}
.dj-pv-backfloat .dj-pv-back{background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--line);padding:8px 15px 8px 11px}
.dj-pv-backfloat .dj-pv-back:hover{background:var(--wash)}
/* floating phase pager (replaces the old top ribbon): a non-scrolling rounded pill that
   shrinks to its content (capped, inset from the viewport edges) wrapping an inner
   horizontal scroller. Edge fades signal hidden chips, and only on the side that can
   still scroll (toggled via data-l / data-r). */
.dj-pv-nav{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:30;display:flex;max-width:82vw;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);box-shadow:var(--shadow)}
.dj-pv-nav-scroll{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:12px;overflow-x:auto;padding:9px 20px;scrollbar-width:none}
.dj-pv-nav-scroll::-webkit-scrollbar{display:none}
.dj-pv-nav::before,.dj-pv-nav::after{content:"";position:absolute;top:1px;bottom:1px;width:42px;pointer-events:none;z-index:1;opacity:0;transition:opacity .18s ease}
.dj-pv-nav::before{left:1px;border-radius:var(--r-pill) 0 0 var(--r-pill);background:linear-gradient(to right,#fff 30%,rgba(255,255,255,0))}
.dj-pv-nav::after{right:1px;border-radius:0 var(--r-pill) var(--r-pill) 0;background:linear-gradient(to left,#fff 30%,rgba(255,255,255,0))}
.dj-pv-nav[data-l="1"]::before{opacity:1}
.dj-pv-nav[data-r="1"]::after{opacity:1}
.dj-pv-nav-chip{display:inline-flex;align-items:center;gap:8px;flex:0 0 auto;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink-2);background:none;border:0;border-radius:var(--r-pill);padding:6px 12px;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s}
.dj-pv-nav-chip:hover{background:var(--wash);color:var(--ink)}
.dj-pv-nav-dot{width:9px;height:9px;border-radius:var(--r-pill);flex:0 0 auto}

/* ===== Present: animated slide deck ===== */
.dj-deck{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 120% at 50% 0%,#fff 0%,var(--wash) 100%);overflow:hidden}
.dj-deck-stage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center center;width:1120px;height:720px;display:flex;align-items:center}
.dj-deck-slide{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:40px 56px}
.dj-deck-slide.from-r{animation:dj-deck-inr .52s cubic-bezier(.22,.7,.2,1) both}
.dj-deck-slide.from-l{animation:dj-deck-inl .52s cubic-bezier(.22,.7,.2,1) both}
@keyframes dj-deck-inr{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes dj-deck-inl{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:none}}
.dj-deck-a{animation:dj-deck-up .6s cubic-bezier(.22,.7,.2,1) both}
.dj-deck-a:nth-child(1){animation-delay:.08s}
.dj-deck-a:nth-child(2){animation-delay:.17s}
.dj-deck-a:nth-child(3){animation-delay:.26s}
.dj-deck-a:nth-child(4){animation-delay:.35s}
@keyframes dj-deck-up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
/* title slide */
.dj-deck-title,.dj-deck-pad{width:100%}
.dj-deck-brandrow{display:flex;align-items:center;gap:12px;margin-bottom:30px}
.dj-deck-logo{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:12px;background:var(--magenta);box-shadow:0 2px 8px rgba(204,0,121,.3)}
.dj-deck-brandtxt{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-.02em;color:var(--ink);line-height:1.05}
.dj-deck-brandtxt small{display:block;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-top:3px}
.dj-deck-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--acc)}
.dj-deck-h1{font-family:var(--display);font-weight:600;font-size:54px;line-height:1.05;letter-spacing:-.025em;color:var(--ink);margin:0 0 26px;text-wrap:balance}
.dj-deck-challenge{margin-top:30px;max-width:60rem;background:color-mix(in srgb,var(--magenta) 6%,#fff);border:1.5px solid color-mix(in srgb,var(--magenta) 22%,transparent);border-radius:18px;padding:24px 30px 28px}
.dj-deck-challenge .dj-deck-eyebrow{color:var(--magenta)}
.dj-deck-challenge p{margin:12px 0 0;font-family:var(--display);font-size:34px;line-height:1.34;color:var(--ink);font-weight:600;letter-spacing:-.015em;text-wrap:pretty}
.dj-deck-eyebrow.big{font-size:14px}
.dj-deck-startcue{margin-top:34px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--faint);display:flex;align-items:center;gap:9px}
.dj-deck-kbd{display:inline-grid;place-items:center;min-width:26px;height:26px;padding:0 7px;border-radius:7px;border:1px solid var(--line);background:#fff;box-shadow:0 1px 0 var(--line);color:var(--ink-2);font-size:14px}
/* headings */
.dj-deck-h2{font-family:var(--display);font-weight:600;font-size:46px;line-height:1.06;letter-spacing:-.02em;color:var(--ink);margin:6px 0 0;text-wrap:balance}
.dj-deck-head{margin-bottom:30px}
/* overview roadmap */
.dj-deck-flow{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:32px 12px;margin-top:44px}
.dj-deck-node{position:relative;flex:0 0 auto;display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:14px;border-left:5px solid var(--nc);padding:15px 22px 15px 17px;box-shadow:var(--shadow-sm)}
.dj-deck-node.end{background:color-mix(in srgb,var(--nc) 5%,#fff);border-color:color-mix(in srgb,var(--nc) 22%,var(--line))}
.dj-deck-node-badge{flex:0 0 auto;display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--nc);color:#fff;font-family:var(--display);font-weight:600;font-size:16px}
.dj-deck-node-tx{display:flex;flex-direction:column;gap:3px;min-width:0}
.dj-deck-node-name{font-family:var(--display);font-weight:600;font-size:19px;line-height:1.1;color:var(--ink);letter-spacing:-.01em;white-space:nowrap}
.dj-deck-node-sub{display:inline-block;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:color-mix(in srgb,var(--nc) 70%,#000)}
.dj-deck-arrow{display:inline-flex;align-self:center;color:var(--faint)}
/* phase columns */
.dj-deck-cols{display:flex;gap:38px;align-items:flex-start}
.dj-deck-left{flex:1 1 42%;min-width:0}
.dj-deck-block{margin-bottom:22px}
.dj-deck-blab{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--acc);margin-bottom:14px}
.dj-deck-blab.on-acc{color:#fff;opacity:.92}
.dj-deck-sq{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:18px}
.dj-deck-sq li{display:flex;gap:16px;align-items:flex-start;font-size:25px;font-weight:600;line-height:1.38;color:var(--ink);font-family:var(--display);letter-spacing:-.01em;text-wrap:pretty}
.dj-deck-sqn{flex:0 0 auto;display:inline-grid;place-items:center;width:31px;height:31px;border-radius:50%;background:var(--acc);color:#fff;font-size:15px;font-weight:600;margin-top:3px}
.dj-deck-acts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.dj-deck-acts li{display:flex;gap:12px;align-items:flex-start;font-size:19px;line-height:1.4;color:var(--ink-2);text-wrap:pretty}
.dj-deck-bullet{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--acc);margin-top:9px}
.dj-deck-takeaway{flex:1 1 58%;align-self:stretch;background:var(--acc);border-radius:20px;padding:30px 32px;display:flex;flex-direction:column;box-shadow:0 12px 30px -12px color-mix(in srgb,var(--acc) 60%,transparent)}
.dj-deck-takeaway p{margin:0;font-size:25px;line-height:1.5;color:#fff;font-weight:500;text-wrap:pretty}
/* phase intro (section divider) */
.dj-deck-intro{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.dj-deck-intronum{display:inline-grid;place-items:center;width:64px;height:64px;border-radius:18px;background:var(--nc);color:#fff;font-family:var(--display);font-weight:600;font-size:30px;margin-bottom:22px;box-shadow:0 10px 24px -10px var(--nc)}
.dj-deck-introname{font-family:var(--display);font-weight:600;font-size:64px;line-height:1.04;letter-spacing:-.025em;color:var(--ink);margin:6px 0 0;text-wrap:balance}
.dj-deck-introblurb{margin:20px 0 0;font-size:24px;line-height:1.5;color:var(--ink-2);font-weight:500;max-width:62ch;text-wrap:pretty}
.dj-deck-introsq{margin-top:30px;width:100%;max-width:1180px}
/* enlarged intro (Thinking / Sprint / Double Diamond) + phase metrics */
.dj-deck-intro.big .dj-deck-intronum{width:78px;height:78px;border-radius:22px;font-size:38px;margin-bottom:26px}
.dj-deck-intro.big .dj-deck-introname{font-size:86px;line-height:1}
.dj-deck-metrics{display:flex;gap:48px;margin-top:40px}
.dj-deck-metric{display:flex;flex-direction:column;gap:4px;padding-left:18px;border-left:4px solid var(--nc)}
.dj-deck-metric-n{font-family:var(--display);font-weight:600;font-size:52px;line-height:1;letter-spacing:-.03em;color:var(--ink)}
.dj-deck-metric-l{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
/* activities detail + define deliverables (deck) */
.dj-deck-acthead{margin-bottom:26px}
.dj-deck-actgrid{display:flex;flex-direction:column;gap:18px;margin-top:0}
.dj-deck-actgrid.two{display:grid;grid-template-columns:1fr 1fr;gap:20px 30px;margin-top:0}
.dj-deck-actcard{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--acc);border-radius:16px;padding:26px 30px;box-shadow:var(--shadow-sm)}
.dj-deck-actnum{flex:0 0 auto;display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--acc);color:#fff;font-family:var(--display);font-weight:600;font-size:15px;vertical-align:middle;margin-right:13px;transform:translateY(-2px)}
.dj-deck-actbody{min-width:0}
.dj-deck-acttitle{font-family:var(--display);font-weight:600;font-size:23px;line-height:1.3;color:var(--ink);letter-spacing:-.01em;margin-bottom:16px;text-wrap:pretty}
.dj-deck-actnote{font-size:19px;line-height:1.55;color:var(--ink-2);text-wrap:pretty;padding-top:16px;border-top:1px solid var(--line)}
.dj-deck-actnote-lab{display:block;font-family:var(--display);font-weight:600;font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--acc);margin-bottom:8px}
/* deck — involved-avatar row on an activity card (label + avatars on one line) */
.dj-deck-actstk{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.dj-deck-actstk-lab{display:flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.dj-deck-actstk-lab svg{color:var(--slate);flex:0 0 auto}
.dj-deck-actstk-avs{display:flex;align-items:center}
.dj-deck-actstk-avs .dj-stk-av{margin-left:-8px;border:2.5px solid #fff;width:30px;height:30px;font-size:11.5px}
.dj-deck-actstk-avs .dj-stk-av:first-child{margin-left:0}
.dj-deck-actstk-more{margin-left:-8px;border:2.5px solid #fff;background:var(--slate-wash);color:var(--slate);width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:11.5px}
/* deck — stakeholder roster slide */
.dj-deck-stkgrid{display:flex;flex-direction:column;gap:16px;margin-top:22px;max-width:60rem}
.dj-deck-stkgrid.two{display:grid;grid-template-columns:1fr 1fr;gap:16px 28px;max-width:none}
.dj-deck-stkcard{display:flex;gap:16px;align-items:center;background:#fff;border:1px solid var(--line);border-left:4px solid var(--sc,var(--slate));border-radius:16px;padding:18px 22px;box-shadow:var(--shadow-sm)}
.dj-deck-stkcard-tx{flex:1;min-width:0}
.dj-deck-stkcard-nm{font-family:var(--display);font-weight:600;font-size:21px;line-height:1.2;color:var(--ink);letter-spacing:-.01em}
.dj-deck-stkcard-role{font-size:15.5px;color:var(--ink-2);margin-top:3px}
.dj-deck-stkcard-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px 10px;margin-top:11px}
.dj-deck-stkcard-type{display:inline-flex;font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:var(--r-pill)}
.dj-deck-stkcard-inv{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink-2)}
/* deck — power/interest slide (reuse the manager Grid component at deck scale) */
.dj-deck-stkgridwrap{margin-top:18px;max-width:64rem}
.dj-deck-stkgridwrap .dj-stk-pi{margin:0;max-width:430px}
.dj-deck-takeaway.solo{flex:none;max-width:none;margin-top:26px}
/* themes */
.dj-deck-themecols{display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;margin-top:24px}
.dj-deck-themelist{display:flex;flex-direction:column;gap:11px;margin-top:12px}
.dj-deck-themelist.wide{margin-top:24px}
.dj-deck-themecard{background:#fff;border:1px solid var(--line);border-left:4px solid var(--acc);border-radius:12px;padding:13px 16px;font-family:var(--display);font-weight:600;font-size:18px;line-height:1.3;color:var(--ink);letter-spacing:-.01em;text-wrap:pretty}
/* redefined challenge hero */
.dj-deck-redef{justify-content:flex-start}
.dj-deck-redefcard{position:relative;margin-top:30px;max-width:60rem;background:color-mix(in srgb,var(--acc) 7%,#fff);border:1.5px solid color-mix(in srgb,var(--acc) 26%,transparent);border-radius:22px;padding:42px 48px}
.dj-deck-redefcard p{margin:0;font-family:var(--display);font-weight:600;font-size:32px;line-height:1.32;letter-spacing:-.02em;color:var(--ink);text-wrap:balance}
.dj-deck-quote{position:absolute;top:6px;left:24px;font-family:var(--display);font-weight:800;font-size:80px;line-height:1;color:color-mix(in srgb,var(--acc) 26%,transparent);pointer-events:none}
/* principles */
.dj-deck-pringrid{display:flex;flex-direction:column;gap:14px;margin-top:24px;max-width:60rem}
.dj-deck-pringrid.two{display:grid;grid-template-columns:1fr 1fr;gap:16px 26px;max-width:none}
.dj-deck-princard{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--acc);border-radius:14px;padding:16px 18px}
.dj-deck-princard-txt{min-width:0;font-family:var(--display);font-weight:600;font-size:18px;line-height:1.35;color:var(--ink);letter-spacing:-.01em;text-wrap:pretty}
/* outcome */
.dj-deck-outcome-body{margin:20px 0 0;font-size:26px;line-height:1.5;color:var(--ink-2);font-weight:500;max-width:58rem;text-wrap:pretty}
.dj-deck-ohead{display:flex;justify-content:space-between;align-items:flex-end;gap:28px;flex-wrap:wrap}
.dj-deck-otoggle{display:inline-flex;gap:4px;background:color-mix(in srgb,var(--acc) 9%,#fff);border:1px solid color-mix(in srgb,var(--acc) 22%,transparent);border-radius:999px;padding:5px;flex:0 0 auto}
.dj-deck-otab{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-.01em;padding:9px 22px;border-radius:999px;border:0;background:none;color:color-mix(in srgb,var(--acc) 78%,#000);cursor:pointer;transition:background .14s,color .14s}
.dj-deck-otab.on{background:var(--acc);color:#fff}
.dj-deck-otoggle-tr{position:absolute;top:22px;right:20px;z-index:30}
/* nav + rail */
.dj-deck-progress{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:5;width:min(420px,52vw);height:5px;border-radius:999px;background:var(--line);overflow:hidden}
.dj-deck-progress-fill{height:100%;border-radius:999px;transition:width .32s cubic-bezier(.22,.7,.2,1)}
.dj-deck-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);color:var(--ink-2);cursor:pointer;transition:background .14s,color .14s,opacity .14s}
.dj-deck-nav:hover{background:var(--acc);color:#fff;border-color:var(--acc)}
.dj-deck-nav.prev{left:20px}.dj-deck-nav.next{right:20px}
.dj-deck-nav.off{opacity:0;pointer-events:none}
.dj-deck-rail{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:5;display:flex;align-items:center;gap:8px;max-width:94vw;flex-wrap:nowrap;justify-content:center}
.dj-deck-dot{position:relative;width:9px;height:9px;border-radius:50%;border:0;padding:0;background:var(--line);cursor:pointer;transition:transform .14s,background .14s}
.dj-deck-dot::before{content:"";position:absolute;inset:-13px -3px;border-radius:8px}
.dj-deck-dot:hover{background:var(--faint);transform:scale(1.3)}
.dj-deck-dot::after{content:attr(data-tip);position:absolute;bottom:20px;left:50%;transform:translateX(-50%) translateY(4px);background:var(--ink);color:#fff;font-family:var(--display);font-weight:600;font-size:12px;white-space:nowrap;padding:5px 10px;border-radius:7px;box-shadow:var(--shadow-md,0 4px 14px rgba(0,0,0,.18));opacity:0;pointer-events:none;transition:opacity .12s,transform .12s;z-index:10}
.dj-deck-dot:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
.dj-deck-dot.on{transform:scale(1.35)}
.dj-deck-dot.key{width:13px;height:13px;opacity:.55}
.dj-deck-dot.key.on,.dj-deck-dot.key:hover{opacity:1}
.dj-deck-count{position:absolute;right:22px;bottom:18px;z-index:5;font-family:var(--display);font-weight:600;font-size:13px;color:var(--faint);font-variant-numeric:tabular-nums}
@media(max-width:760px){.dj-deck-cols{flex-direction:column;gap:22px}.dj-deck-takeaway{width:100%}.dj-deck-nav{width:40px;height:40px}.dj-deck-nav.prev{left:8px}.dj-deck-nav.next{right:8px}}
@media(prefers-reduced-motion:reduce){.dj-deck-slide,.dj-deck-a{animation-duration:.01ms!important}}
.dj-pv-nav-sep{color:var(--faint);font-size:13px;flex:0 0 auto}
.dj-pv-stagewrap{position:relative;width:100%;flex:0 0 auto}
.dj-pv-stage{position:absolute;top:0;left:50%;transform-origin:top center}
.dj-pv-hint{position:absolute;left:0;right:0;bottom:0;text-align:center;font-size:12px;color:var(--muted);padding:14px 16px 16px;pointer-events:none}

/* ===== Double Diamond ===== */
.dj-dd-svg{position:absolute;inset:0;overflow:visible}
.dj-dd-tri{cursor:pointer;transition:opacity .12s}
.dj-dd-tri:hover{opacity:.9}
.dj-dd-conn{stroke:var(--faint);stroke-width:2.5;stroke-dasharray:0.1 8;stroke-linecap:round;opacity:.85}
.dj-dd-bridge{stroke:var(--line);stroke-width:2}
.dj-dd-journeybar{flex:0 0 auto;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;margin:0 auto;padding:32px 16px 6px}
.dj-dd-outer{flex:1 1 auto;min-height:0;width:100%;display:flex;flex-direction:column}
.dj-dd-stagehost{flex:1 1 auto;min-height:0;position:relative;display:flex;flex-direction:column;justify-content:center}
.dj-dd-pill,.dj-dd-stepnum,.dj-dd-leader,.dj-dd-leader-w{transition:opacity .16s ease,transform .12s ease,border-color .14s ease}
.dj-dd-jb-arrow{display:flex;align-items:center;color:var(--faint);opacity:.8}
.dj-dd-jb-step{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:0;color:#fff;font-family:var(--display);font-weight:600;font-size:13.5px;display:grid;place-items:center;cursor:pointer;transition:transform .12s}
.dj-dd-jb-step:hover{transform:scale(1.14)}
.dj-dd-jb-cap{position:relative;display:flex;align-items:center;justify-content:center;background:none;border:0;padding:0;cursor:pointer}
.dj-dd-jb-ring{width:32px;height:32px;border-radius:50%;background:#fff;border:1.5px solid var(--phase-bookend);color:var(--phase-bookend);display:grid;place-items:center;transition:background .14s,color .14s}
.dj-dd-jb-cap:hover .dj-dd-jb-ring{background:var(--phase-bookend);color:#fff}
.dj-dd-jb-caplab{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);white-space:nowrap;font-family:var(--display);font-weight:600;font-size:9px;letter-spacing:.08em;color:var(--ink-2)}
.dj-dd-tri{transition:opacity .16s ease}
.dj-dd-phasename{transition:opacity .16s ease}
.dj-dd-delivchip{position:absolute;transform:translate(-50%,-50%);background:#fff;border:1.5px solid var(--blue);color:var(--blue-deep);border-radius:var(--r-pill);padding:7px 14px;font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.04em;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.07)}
.dj-dd-delivchip:hover{background:var(--blue);color:#fff}
.dj-dd-loopg{transition:opacity .16s ease}
.dj-dd-loopconn{stroke-width:3;stroke-dasharray:0.1 7;stroke-linecap:round}
.dj-dd-loop{cursor:pointer;transition:opacity .12s}
.dj-dd-loop:hover{opacity:.9}
.dj-dd-loopglyph rect{fill:#fff;pointer-events:none}
.dj-dd-loophit{cursor:pointer}
.dj-dd-cyc path,.dj-dd-cyc polygon{pointer-events:none}
.dj-dd-looplab{position:absolute;transform:translate(-50%,-50%);background:none;border:0;cursor:pointer;font-family:var(--display);font-weight:600;font-size:23px;letter-spacing:-.01em;text-align:centerr;white-space:normal;width:170px;line-height:1.08;transition:opacity .16s ease}
.dj-dd-flow{fill:none;stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:.92}
.dj-dd-loop-head{fill:none;stroke:var(--muted);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.8}
.dj-dd-leader{stroke-width:2.6;stroke-dasharray:0.1 8;stroke-linecap:round;opacity:.95}
.dj-dd-leader-w{stroke:#fff;stroke-width:2.6;stroke-dasharray:0.1 8;stroke-linecap:round;opacity:.9}
.dj-dd-pinch{stroke:#fff;stroke-width:2;stroke-dasharray:5 7;opacity:.5}
.dj-dd-html{position:absolute;inset:0;pointer-events:none}
.dj-dd-html button{pointer-events:auto}
.dj-dd-zonecap{position:absolute;transform:translateX(-50%);text-align:center}
.dj-dd-motion{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.16em;text-transform:uppercase;opacity:.85}
.dj-dd-regionname{font-family:var(--display);font-weight:600;font-size:29px;letter-spacing:-.01em;margin-top:4px}
.dj-dd-phasename{position:absolute;transform:translate(-50%,-50%);background:none;border:0;cursor:pointer;color:#fff;font-family:var(--display);font-weight:600;font-size:30px;letter-spacing:-.01em;text-align:center;white-space:nowrap;text-shadow:0 1px 10px rgba(22,19,26,.18)}
.dj-dd-phasename.sm{font-size:20px;line-height:1.05;white-space:normal;width:150px}
.dj-dd-stepnum{position:absolute;transform:translate(-50%,-50%);border-radius:50%;background:#fff;border:0;cursor:pointer;font-family:var(--display);font-weight:600;font-size:15px;display:grid;place-items:center;transition:transform .12s;box-shadow:0 1px 3px rgba(22,19,26,.12)}
.dj-dd-stepnum:hover{transform:translate(-50%,-50%) scale(1.14)}
.dj-dd-delivcard{position:absolute;transform:translate(-50%,-50%);width:158px;background:#fff;border:2px solid var(--blue);border-radius:var(--r-lg);padding:16px 12px;display:flex;flex-direction:column;gap:10px}
.dj-dd-delivlab{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-deep);text-align:center;line-height:1.3;margin-bottom:3px}
.dj-dd-delivbtn{font-family:var(--display);font-weight:600;font-size:12.5px;color:#fff;background:var(--blue);border:0;border-radius:var(--r);padding:10px 9px;cursor:pointer;text-align:center;line-height:1.25;transition:.12s}
.dj-dd-delivbtn:hover{background:var(--blue-deep)}
.dj-dd-framing{position:absolute;transform:translateX(-50%);font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:.13em;text-transform:uppercase;opacity:.9}
.dj-dd-loopvariant .dj-dd-motion{font-size:19px;letter-spacing:.12em}
.dj-dd-loopvariant .dj-dd-framing{font-size:18px}

/* shared diagram pills + anchors (diamond + organic) */
.dj-dd-pill,.dj-og-pill{position:absolute;display:flex;align-items:center;gap:8px;height:32px;padding:0 12px 0 4px;background:#fff;border:1.5px solid color-mix(in srgb,var(--pc) 42%,#fff);border-radius:var(--r-pill);cursor:pointer;text-align:left;transition:border-color .12s}
.dj-dd-pill:hover,.dj-og-pill:hover{border-color:var(--pc)}
.dj-dd-pillnum,.dj-og-pillnum{flex:0 0 auto;width:24px;height:24px;border-radius:50%;color:#fff;font-family:var(--display);font-weight:600;font-size:12px;display:grid;place-items:center}
.dj-dd-pilltxt,.dj-og-pilltxt{flex:1;min-width:0;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-dd-anchor,.dj-og-anchor{position:absolute;transform:translate(-50%,-50%);width:44px;height:44px;pointer-events:none}
button.dj-dd-anchor,button.dj-og-anchor{background:none;border:0;padding:0;font:inherit;cursor:pointer}
.dj-dd-ring,.dj-og-ring{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--faint);background:#fff;color:var(--ink-2);display:grid;place-items:center;transition:box-shadow .12s}
button.dj-dd-anchor:hover .dj-dd-ring,button.dj-og-anchor:hover .dj-og-ring{box-shadow:0 0 0 4px color-mix(in srgb,var(--phase-bookend) 12%,#fff)}
button.dj-dd-anchor:hover .dj-dd-anchor-lab,button.dj-og-anchor:hover .dj-og-anchor-lab{color:var(--ink-2);text-decoration:underline}
.dj-dd-anchor-lab,.dj-og-anchor-lab{position:absolute;top:calc(100% + 9px);left:50%;transform:translateX(-50%);white-space:nowrap;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.3}
/* Double Diamond pills sit a touch larger than the organic ones (reference scale).
   `top` is the pill's CENTRE (leaders terminate at it), so centre it vertically. */
.dj-dd-pill{height:38px;padding:0 15px 0 5px;gap:9px;border-width:1.5px;transform:translateY(-50%)}
.dj-dd-pillnum{width:26px;height:26px;font-size:13px}
.dj-dd-pilltxt{font-size:14.5px;font-weight:600}

/* ===== Route map (transit / rail line) ===== */
.dj-og-svg{position:absolute;inset:0;overflow:visible}
.dj-og-leg-casing{fill:none;stroke:var(--paper);stroke-width:10;stroke-linecap:round}
.dj-og-leg{fill:none;stroke-width:5.5;stroke-linecap:round}
.dj-og-spur{stroke-width:2;stroke-dasharray:0.1 7;stroke-linecap:round;opacity:.85}
.dj-og-html{position:absolute;inset:0;pointer-events:none}
.dj-og-html button{pointer-events:auto}
.dj-og-station{position:absolute;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;background:#fff;border:3px solid var(--pc);display:grid;place-items:center;cursor:pointer;transition:transform .12s,box-shadow .12s}
.dj-og-station:hover{transform:translate(-50%,-50%) scale(1.09);box-shadow:0 0 0 5px color-mix(in srgb,var(--pc) 14%,#fff)}
.dj-og-stnum{font-family:var(--display);font-weight:800;font-size:17px;color:var(--pc)}
.dj-og-wrap{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;background:var(--pc);border:2.5px solid #fff;display:grid;place-items:center;cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:0 1px 4px rgba(22,19,26,.22)}
.dj-og-wrap:hover{transform:translate(-50%,-50%) scale(1.14);box-shadow:0 0 0 4px color-mix(in srgb,var(--pc) 18%,#fff)}
.dj-og-deliv{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;background:var(--pc);border:2.5px solid #fff;display:grid;place-items:center;cursor:pointer;transition:transform .12s,box-shadow .12s}
.dj-og-deliv:hover{transform:translate(-50%,-50%) scale(1.14);box-shadow:0 0 0 4px color-mix(in srgb,var(--pc) 18%,#fff)}
.dj-og-stname{position:absolute;white-space:nowrap;font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-.01em}
.dj-og-stname.b{transform:translate(-50%,0)}
.dj-og-stname.t{transform:translate(-50%,-100%)}
.dj-og-stname.r{transform:translate(0,-50%)}
.dj-og-stname.l{transform:translate(-100%,-50%)}
/* route-map activity pills sit a touch larger than the base for legibility */
.dj-og-pill{height:36px;padding:0 14px 0 5px;gap:9px;border-width:1.5px}
.dj-og-pillnum{width:26px;height:26px;font-size:13px}
.dj-og-pilltxt{font-size:13.5px;font-weight:600}

/* ===== Shared drill-down panel ===== */
.dj-pn-back{position:fixed;inset:0;z-index:240;background:rgba(22,19,26,.34);display:grid;place-items:center;padding:24px;animation:dj-pv-fade .15s ease}
.dj-pn{width:min(680px,94vw);max-height:88vh;display:flex;flex-direction:column;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.dj-pn-head{position:relative;padding:24px 28px 20px;background:var(--pt);border-bottom:2px solid var(--pc)}
.dj-pn-x{position:absolute;top:14px;right:14px;width:30px;height:30px;border:0;background:none;color:var(--muted);border-radius:8px;cursor:pointer;display:grid;place-items:center}
.dj-pn-x:hover{background:rgba(0,0,0,.06);color:var(--ink)}
.dj-pn-eyebrow{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--pc);margin-right:34px}
.dj-pn-title{font-family:var(--display);font-weight:600;font-size:29px;letter-spacing:-.02em;color:var(--ink);margin:7px 0 0}
.dj-pn-sub{font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--pc);margin-top:6px;opacity:.85}
.dj-pn-body{padding:20px 28px 26px;overflow-y:auto}
.dj-pn-rows{display:flex;flex-direction:column;gap:8px}
.dj-pn-delivnote{font-family:var(--display);font-weight:600;font-size:12px;color:var(--blue-deep);background:var(--blue-wash);border-radius:var(--r-sm,10px);padding:8px 12px;margin-bottom:13px;letter-spacing:-.005em}
.dj-pn-passseg{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.dj-pn-passtab{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--muted);background:var(--wash);border:1px solid var(--line);border-radius:var(--r-pill);padding:6px 14px;cursor:pointer;transition:background .14s,color .14s,border-color .14s}
.dj-pn-passtab:hover{border-color:var(--pc);color:var(--ink)}
.dj-pn-passtab.is-active{background:var(--pc);border-color:var(--pc);color:#fff}
.dj-pn-row{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:var(--pt);border:1px solid color-mix(in srgb,var(--pc) 16%,#fff);border-radius:var(--r);padding:12px 14px;cursor:pointer;transition:border-color .12s}
.dj-pn-row:hover{border-color:var(--pc)}
.dj-pn-rownum,.dj-pn-rowcheck,.dj-pn-rowdiamond{flex:0 0 auto;width:30px;height:30px;border-radius:50%;color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:14px}
.dj-pn-rowsec{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.09em;text-transform:uppercase;color:var(--faint);margin:14px 2px 1px}
.dj-pn-subqs{background:var(--pt);border:1px solid color-mix(in srgb,var(--pc) 22%,transparent);border-radius:var(--r-sm);padding:11px 14px 12px;margin-bottom:4px}
.dj-pn-subqs-lab{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.09em;text-transform:uppercase;color:var(--pc);margin-bottom:8px}
.dj-pn-subqlist{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px;counter-reset:sq}
.dj-pn-subqlist li{position:relative;padding-left:22px;counter-increment:sq}
.dj-pn-subqlist li::before{content:counter(sq);position:absolute;left:0;top:1px;width:16px;height:16px;border-radius:50%;background:var(--pc);color:#fff;font-family:var(--display);font-weight:600;font-size:9.5px;display:grid;place-items:center}
.dj-pn-subq-tx{font-family:var(--display);font-weight:600;font-size:13.6px;line-height:1.38;color:var(--ink)}
.dj-pn-subq-el{font-size:12.3px;color:var(--ink-2);margin-top:3px;line-height:1.5}
.dj-pn-band{display:flex;align-items:center;gap:10px;margin:15px 2px 1px}
.dj-pn-rows>.dj-pn-band:first-child{margin-top:1px}
.dj-pn-bandpass{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;flex:0 0 auto}
.dj-pn-bandrule{flex:1;height:1.5px;border-radius:2px}
.dj-pn-bandstep{font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);flex:0 0 auto}
.dj-pn-rowtxt{flex:1;font-family:var(--display);font-weight:600;font-size:16px;color:var(--ink)}
.dj-pn-chev{color:var(--faint);font-size:18px;flex:0 0 auto}
.dj-pn-crumb{display:inline-flex;align-items:center;gap:5px;background:none;border:0;color:var(--ink-2);font-family:var(--display);font-weight:600;font-size:14.5px;cursor:pointer;padding:2px 8px 2px 0;margin-bottom:var(--sp-3)}
.dj-pn-crumb:hover{color:var(--pc)}
.dj-pn-kicker{display:flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 var(--sp-2)}
.dj-pn-kdot{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.dj-pn-acttitle{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--ink);margin:4px 0 14px}
.dj-pn-accs{display:flex;flex-direction:column;gap:10px}
.dj-pn-acc{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:#fff;transition:border-color .14s,box-shadow .14s}
.dj-pn-acc[open]{border-color:color-mix(in srgb,var(--pc) 32%,var(--line));box-shadow:var(--shadow-sm)}
.dj-pn-acc summary{display:flex;align-items:center;gap:11px;padding:11px 13px;cursor:pointer;list-style:none;background:color-mix(in srgb,var(--pc) 6%,#fff);transition:background .12s}
.dj-pn-acc summary::-webkit-details-marker{display:none}
.dj-pn-acc summary:hover{background:color-mix(in srgb,var(--pc) 12%,#fff)}
.dj-pn-acc-ic{flex:0 0 auto;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:color-mix(in srgb,var(--pc) 15%,#fff);color:var(--pc);font-size:14px;font-weight:600;line-height:1}
.dj-pn-acc-lab{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.dj-pn-acc-name{font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:.005em;color:var(--ink)}
.dj-pn-acc-cap{font-size:12px;line-height:1.3;color:var(--muted)}
.dj-pn-accsign{position:relative;width:12px;height:12px;flex:0 0 auto}
.dj-pn-accsign::before,.dj-pn-accsign::after{content:"";position:absolute;background:var(--pc);border-radius:2px}
.dj-pn-accsign::before{top:5px;left:0;width:12px;height:2px}
.dj-pn-accsign::after{top:0;left:5px;width:2px;height:12px;transition:transform .15s}
.dj-pn-acc[open] .dj-pn-accsign::after{transform:scaleY(0)}
.dj-pn-accbody{padding:15px 18px 17px;font-size:15.5px;line-height:1.62;color:var(--ink-2);white-space:pre-wrap;text-wrap:pretty;border-top:1px solid var(--line-soft)}
.dj-pn-hero{position:relative;display:flex;gap:15px;align-items:flex-start;background:var(--pt);border-radius:var(--r-lg);padding:22px 24px}
.dj-pn-hero-mark{font-family:Georgia,'Times New Roman',serif;font-size:56px;line-height:.66;color:color-mix(in srgb,var(--pc) 45%,transparent);flex:0 0 auto;margin-top:2px}
.dj-pn-hero-ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--pc);color:#fff}
.dj-pn-hero-text{margin:0;font-family:var(--display);font-weight:600;font-size:22px;line-height:1.42;letter-spacing:-.01em;color:var(--ink);text-wrap:pretty}
.dj-pn-metas{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-top:10px}
.dj-pn-meta{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:12px;color:var(--pc);background:color-mix(in srgb,var(--pc) 12%,#fff);border-radius:var(--r-pill);padding:4px 11px 4px 9px}
.dj-pn-framing-tag{display:inline-flex;align-items:center;font-family:var(--display);font-weight:600;font-size:12px;color:var(--pc);border:1px solid color-mix(in srgb,var(--pc) 30%,transparent);border-radius:var(--r-pill);padding:3px 11px}
.dj-clamp{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:var(--clamp-lines,3);overflow:hidden}
.dj-clamp.is-exp{display:block;overflow:visible}
.dj-clamp-tog{display:inline-flex;align-items:center;gap:4px;margin-top:6px;background:none;border:0;padding:0;cursor:pointer;font-family:var(--display);font-weight:600;font-size:12px;color:var(--pc);transition:color .12s}
.dj-clamp-tog:hover{color:var(--ink)}
.dj-clamp-chev{display:inline-block;transition:transform .15s;font-size:10px}
.dj-clamp-chev.up{transform:rotate(180deg)}
.dj-pn-spacegrp{border-radius:var(--r);padding:13px 14px 14px;margin-bottom:12px}
.dj-pn-spacegrp--problem{background:var(--magenta-wash)}
.dj-pn-spacegrp--solution{background:var(--teal-wash)}
.dj-pn-spacelab{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;margin-bottom:10px}
.dj-pn-spacegrp--problem .dj-pn-spacelab{color:var(--magenta-deep)}
.dj-pn-spacegrp--solution .dj-pn-spacelab{color:var(--teal)}
.dj-pn-spacedot{width:9px;height:9px;border-radius:2px;flex:0 0 auto}
.dj-pn-spacegrp--problem .dj-pn-spacedot{background:var(--magenta)}
.dj-pn-spacegrp--solution .dj-pn-spacedot{background:var(--teal)}
.dj-pn-themes{display:flex;flex-direction:column;gap:8px}
.dj-pn-theme{background:#fff;border:1px solid rgba(22,19,26,.06);border-radius:var(--r-sm);padding:11px 13px}
.dj-pn-theme-tx{font-family:var(--display);font-weight:600;font-size:14.5px;line-height:1.35;color:var(--ink)}
.dj-pn-theme-el{font-size:12.5px;line-height:1.45;color:var(--muted);margin-top:4px;text-wrap:pretty}
.dj-pn-ms{font-size:16.5px;line-height:1.6;color:var(--ink);white-space:pre-wrap;text-wrap:pretty}
.dj-pn-ms-empty{color:var(--muted);font-style:italic}
.dj-pn-prlist{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px;counter-reset:pr}
.dj-pn-prlist li{position:relative;padding:12px 14px 12px 44px;counter-increment:pr;background:var(--pt);border-radius:var(--r-sm)}
.dj-pn-prlist li::before{content:counter(pr);position:absolute;left:13px;top:11px;width:22px;height:22px;border-radius:50%;background:var(--pc);color:#fff;font-family:var(--display);font-weight:600;font-size:11px;display:grid;place-items:center}
.dj-pn-prst{font-family:var(--display);font-weight:600;font-size:14.5px;line-height:1.35;color:var(--ink)}
.dj-pn-prel{font-size:12.5px;color:var(--ink-2);margin-top:3px;line-height:1.5}

/* ============ Journey board: step columns + summary rows (ProPro IA) ============ */
.dj-step{flex:0 0 360px;min-width:0;max-width:360px;display:flex;flex-direction:column;align-self:flex-start}
.dj-step-end{flex-basis:330px;max-width:330px}
.dj-step-body{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--ac);border-radius:var(--r-lg);overflow:hidden}
.dj-step-head{display:flex;align-items:center;gap:8px;padding:16px 16px 15px;border-bottom:1px solid var(--line-soft);background:#fff}
.dj-step-headmain{flex:1;min-width:0}
.dj-step-name{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:-.01em;color:var(--ink)}
.dj-coldot{width:9px;height:9px;border-radius:var(--r-pill);flex:0 0 auto}
.dj-step-ctrls{display:flex;gap:3px;flex:0 0 auto;opacity:0;transition:opacity .12s}
.dj-step:hover .dj-step-ctrls,.dj-step.is-collapsed .dj-step-ctrls{opacity:1}
.dj-step-ctrls .dj-cbtn{font-family:var(--display);font-weight:600;font-size:15px;line-height:1}
.dj-cbtn-x:hover:not(:disabled){border-color:var(--magenta);color:var(--magenta-deep)}
.dj-step.is-collapsed .dj-step-body{background:#fff}
.dj-step.is-collapsed .dj-step-head{border-bottom:0;cursor:pointer}
.dj-step-content{padding:16px 15px 18px;display:flex;flex-direction:column;gap:18px}
.dj-insights{display:flex;flex-direction:column;gap:11px}

/* summary row */
.dj-irow.dj-ms-matter{background:var(--wash);border-color:var(--line)}
.dj-irow.dj-ms-challenge{background:var(--magenta-wash);border-color:color-mix(in srgb,var(--magenta) 28%,#fff)}
.dj-irow{position:relative;display:flex;gap:12px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--ac);border-radius:11px;padding:14px 14px 14px 15px;cursor:pointer;transition:border-color .12s,box-shadow .12s;text-align:left}
.dj-irow:hover{box-shadow:var(--shadow-sm);border-color:color-mix(in srgb,var(--ac,#999) 40%,var(--line))}
.dj-irow-tag{flex:0 0 auto;display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 5px;border-radius:var(--r-pill);font-family:var(--display);font-weight:600;font-size:12px;line-height:1}
.dj-irow-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.dj-irow-t{font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:-.01em;line-height:1.3}
.dj-flab2b{font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.dj-flab2b-c{margin-top:9px}
.dj-ms-matter .dj-flab2b{color:var(--ink-2);font-weight:600}
.dj-ms-challenge .dj-flab2b{color:var(--magenta-deep);font-weight:600}
.dj-irow-q{font-family:var(--display);font-weight:600;font-size:14.5px;line-height:1.4;color:var(--ink);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-wrap:pretty}
.dj-irow-q.muted{font-weight:500;color:var(--faint)}
.dj-irow-q.full{display:block;-webkit-line-clamp:unset;overflow:visible}
.dj-irow-c{font-size:14px;line-height:1.55;color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-wrap:pretty;white-space:pre-wrap}
.dj-irow-c.muted{color:var(--faint)}
.dj-irow-evo{display:inline-flex;align-self:flex-start;align-items:center;gap:3px;margin-top:8px;font-family:var(--display);font-weight:600;font-size:11px;color:var(--magenta-deep);background:var(--magenta-wash);border-radius:var(--r-pill);padding:2px 9px}
.dj-irow-right{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;gap:2px}
.dj-irow-move{display:flex;flex-direction:column;gap:2px}
.dj-irow-move button{width:20px;height:18px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:6px;font-size:10px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.dj-irow-move button:hover:not(:disabled){border-color:var(--ink-2);color:var(--ink)}
.dj-irow-move button:disabled{opacity:.3;cursor:default}
.dj-irow-x{width:20px;height:18px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:6px;font-size:13px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:border-color .12s,color .12s}
.dj-irow-x:hover{border-color:var(--magenta);color:var(--magenta-deep)}
/* rows whose first line is a small eyebrow label: nudge the × to centre on it */
.dj-srow .dj-irow-right,.dj-ms-matter .dj-irow-right,.dj-ms-challenge .dj-irow-right{margin-top:-3px}

/* section (wrap) row: tinted, no left ribbon, label-as-eyebrow, compact */
.dj-srows{display:flex;flex-direction:column;gap:10px}
.dj-srow{border:1px solid color-mix(in srgb,var(--pc) 26%,var(--line));background:color-mix(in srgb,var(--pc) 6%,#fff);padding:14px 15px}
.dj-srow .dj-irow-q{display:flex;align-items:center;gap:5px;white-space:nowrap;overflow:hidden;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--pc);-webkit-line-clamp:unset}
.dj-irow-qic{display:inline-flex;align-items:center;flex:0 0 auto}
.dj-irow-qic svg{display:block}
.dj-srow .dj-irow-c{-webkit-line-clamp:5}
.dj-irow-q.soft{font-family:var(--text);font-weight:400;font-size:14px;line-height:1.55;color:var(--ink-2);-webkit-line-clamp:3}
/* involved-stakeholder footer on a board activity row */
.dj-irow-stk{display:flex;align-items:center;gap:8px;margin-top:11px;padding-top:11px;border-top:1px solid var(--line-soft)}
.dj-irow-stk-ic{display:inline-flex;flex:0 0 auto;color:var(--slate);cursor:help}
.dj-irow-stk-stack .dj-stk-av{width:26px;height:26px;font-size:10px;margin-left:-7px;border:2px solid #fff}
.dj-irow-stk-stack .dj-stk-av:first-child{margin-left:0}
.dj-irow-stk-stack .dj-stk-more{width:26px;height:26px;font-size:9.5px;margin-left:-7px;border:2px solid #fff}

/* add buttons */
.dj-add-insight,.dj-add-dp,.dj-add-row-btn{display:inline-flex;align-items:center;gap:7px;width:100%;justify-content:flex-start;border:1.5px dashed var(--line);background:none;border-radius:10px;padding:10px 12px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--muted);cursor:pointer;transition:.12s}
.dj-add-insight:hover,.dj-add-row-btn:hover{border-color:var(--pc,var(--magenta));color:var(--pc,var(--magenta));background:color-mix(in srgb,var(--pc,var(--magenta)) 7%,#fff)}
.dj-add-insight{justify-content:center;min-height:50px;border-color:color-mix(in srgb,var(--pc) 55%,var(--line));color:var(--pc);font-size:14px;font-weight:600}
.dj-add-insight:hover{border-color:var(--pc);background:color-mix(in srgb,var(--pc) 9%,#fff)}
.dj-add-insight .dj-plus{font-size:18px}
.dj-add-dp{width:auto;align-self:flex-start;padding:6px 12px;font-size:11.5px;border-style:dashed;border-radius:var(--r-pill);color:var(--blue)}
.dj-add-dp:hover{border-color:var(--blue);background:var(--blue-wash)}
.dj-plus{font-size:15px;line-height:1;font-weight:600}
.dj-add-opt{margin-left:auto;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--wash);border-radius:var(--r-pill);padding:3px 8px}

/* deliverable sub-sections */
.dj-addons{display:flex;flex-direction:column;gap:var(--sp-3)}
.dj-dpsec{border:1px solid color-mix(in srgb,var(--blue) 18%,var(--line));border-radius:var(--r);background:color-mix(in srgb,var(--blue) 4%,#fff);padding:11px 11px 12px}
.dj-dpsec-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:9px}
.dj-dpsec-lab{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--blue-deep)}
.dj-dpsec-x{width:20px;height:18px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:6px;font-size:13px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:border-color .12s,color .12s}
.dj-dpsec-x:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.dj-dpsec-list{display:flex;flex-direction:column;gap:6px}
.dj-thgroup{display:flex;flex-direction:column;gap:6px}
.dj-thgroup + .dj-thgroup{margin-top:13px}
.dj-thgroup-lab{font-family:var(--display);font-weight:600;font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:var(--blue-deep);opacity:.7}

/* phase-level sub-questions (DBR) — phase-coloured, sits above the activities */
.dj-subqs{border:1px solid color-mix(in srgb,var(--ac) 22%,var(--line));border-radius:var(--r);background:color-mix(in srgb,var(--ac) 4%,#fff);padding:11px 11px 12px}
.dj-subqs-head{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.dj-subqs-lab{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ac)}
.dj-subqs-list{display:flex;flex-direction:column;gap:6px}
.dj-subqs .dj-drow-tag{background:color-mix(in srgb,var(--ac) 13%,#fff);color:var(--ac)}
.dj-subqs .dj-drow:hover{border-color:color-mix(in srgb,var(--ac) 42%,var(--line));background:color-mix(in srgb,var(--ac) 5%,#fff)}
.dj-subqs .dj-drow:hover .dj-drow-x:hover{border-color:var(--ac);color:var(--ac)}
.dj-subqs .dj-add-dp{color:var(--ac)}
.dj-subqs .dj-add-dp:hover{border-color:var(--ac);background:color-mix(in srgb,var(--ac) 8%,#fff)}
/* compact deliverable row — one line, click to open detail */
.dj-drow{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 9px 7px 11px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-drow:hover{border-color:color-mix(in srgb,var(--blue) 42%,var(--line));background:color-mix(in srgb,var(--blue) 5%,#fff)}
.dj-drow-tag{flex:0 0 auto;display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 4px;border-radius:var(--r-pill);background:var(--blue-wash);color:var(--blue);font-family:var(--display);font-weight:600;font-size:10px;line-height:1}
.dj-drow-tx{flex:1;min-width:0;font-family:var(--display);font-weight:600;font-size:12px;line-height:1.35;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-drow-tx.muted{font-weight:500;color:var(--faint)}
.dj-drow.full{align-items:flex-start}
.dj-drow.full .dj-drow-tag{margin-top:1px}
.dj-drow-tx.full{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.45}
.dj-drow-x{flex:0 0 auto;width:18px;height:18px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:5px;font-size:12px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;opacity:0;transition:opacity .12s,border-color .12s,color .12s}
.dj-drow:hover .dj-drow-x{opacity:1}
.dj-drow-x:hover{border-color:var(--magenta);color:var(--magenta-deep)}

/* deliverable add-chip row */
.dj-deliv2{border:1px dashed color-mix(in srgb,var(--blue) 28%,var(--line));border-radius:var(--r);padding:10px 11px}
.dj-deliv2-lab{display:flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.dj-deliv2-chips,.dj-add-row{display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.dj-add-row{padding-top:2px}
.dj-add-lead{flex-basis:100%;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin-bottom:2px}
.dj-addchip{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:12px;color:var(--blue);background:#fff;border:1px solid color-mix(in srgb,var(--blue) 30%,#fff);border-radius:var(--r-pill);padding:5px 11px;cursor:pointer;transition:.12s}
.dj-addchip:hover{background:var(--blue-wash);border-color:var(--blue)}
.dj-addchip-ic{display:inline-flex;font-weight:600}
.dj-addchip-sec{color:var(--pc);border-color:color-mix(in srgb,var(--pc) 32%,#fff)}
.dj-addchip-sec:hover{background:color-mix(in srgb,var(--pc) 9%,#fff);border-color:var(--pc)}

/* info tooltip */
.dj-info{position:relative;display:inline-flex;align-items:center;color:var(--muted);cursor:help;border:0;background:none;padding:0;font:inherit;line-height:0}
.dj-info:hover{color:var(--ink)}
.dj-info-pop{position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);z-index:30;width:230px;background:var(--surface);color:var(--ink-2);border:1px solid var(--line);font-family:var(--text);font-weight:400;font-size:12px;line-height:1.5;letter-spacing:0;text-transform:none;padding:9px 12px;border-radius:var(--r-sm);box-shadow:var(--shadow-lg);text-align:left}
.dj-info-pop::before{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--line)}
.dj-info-pop::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-1.5px);border:5px solid transparent;border-top-color:var(--surface)}

/* ============ Bespoke modal (numbered fields, hints, pickers) ============ */
.dj-modal-back{position:fixed;inset:0;z-index:300;background:rgba(22,19,26,.42);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;overflow:auto;padding:5vh 20px 40px;animation:dj-pv-fade .16s ease}
.dj-modal2{width:100%;max-width:620px;background:var(--surface);border-top:4px solid var(--magenta);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:dj-pop .16s ease}
.dj-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px 0}
.dj-modal-tag{font-family:var(--display);font-weight:600;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:var(--r-pill);padding:5px 13px}
.dj-modal-close{flex:0 0 auto;width:32px;height:32px;border:0;border-radius:var(--r-pill);background:var(--wash);color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:.14s}
.dj-modal-close:hover{background:var(--line);color:var(--ink)}
.dj-modal-body2{padding:18px 20px 16px;display:flex;flex-direction:column;max-height:62vh;overflow:auto}
.dj-modal-body2 > *{margin-top:12px}
.dj-modal-body2 > :first-child{margin-top:0}
.dj-field{display:flex;flex-direction:column;border:1.5px dashed var(--line);border-radius:12px;padding:13px 15px;transition:border-color .12s,background .12s}
.dj-flab2{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:-.005em;margin-bottom:6px}
.dj-fnum{display:inline-grid;place-items:center;min-width:19px;height:19px;padding:0 4px;border-radius:var(--r-pill);font-size:11px;font-weight:600;line-height:1;flex:0 0 auto}
.dj-field-x{border:0;background:none;color:var(--faint);cursor:pointer;padding:3px;border-radius:6px;display:inline-flex}
.dj-field-x:hover{color:var(--magenta-deep);background:var(--wash)}
.dj-flab2-tx{flex:1;min-width:0}
.dj-flab2.clickable{cursor:pointer}
.dj-fchev{flex:0 0 auto;border:0;background:none;color:var(--muted);cursor:pointer;padding:2px;border-radius:6px;display:inline-flex;transition:color .12s}
.dj-fchev:hover{color:var(--ink);background:var(--wash)}
.dj-fchev svg{transition:transform .15s}
.dj-field.is-collapsed .dj-fchev svg{transform:rotate(-90deg)}
.dj-field.is-collapsed{border-color:color-mix(in srgb,var(--fc,var(--line)) 40%,var(--line));cursor:pointer}
.dj-field.is-collapsed:hover{border-color:var(--fc,var(--ink-2));background:color-mix(in srgb,var(--fc) 4%,#fff)}
.dj-field.is-collapsed .dj-flab2{margin-bottom:0}
.dj-fpreview{display:block;margin:6px 0 0 27px;font-family:var(--text);font-size:13px;line-height:1.45;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-fpreview.empty{color:var(--faint)}
.dj-fhint{font-size:13.5px;line-height:1.55;color:var(--ink-2);margin:0 0 11px;text-wrap:pretty}
.dj-lenses-link{color:var(--ink);font-weight:600;border-bottom:1.5px dotted var(--muted);cursor:help}
.dj-lenses-link:hover,.dj-lenses-link:focus{border-bottom-color:var(--ink);outline:none}
.dj-finput{width:100%;box-sizing:border-box;font-family:var(--text);font-size:14px;line-height:1.55;color:var(--ink);background:#FAFAFB;border:1.5px solid var(--line);border-radius:10px;padding:10px 12px;resize:none;outline:none;transition:border-color .12s,background .12s}
.dj-finput:focus{border-color:color-mix(in srgb,var(--ink) 30%,var(--line));background:#fff}
.dj-finput::placeholder{color:var(--faint)}
.dj-redef-prev{font-size:12.5px;line-height:1.5;color:var(--ink-2);background:var(--wash);border:1px solid var(--line-soft);border-radius:9px;padding:8px 11px;margin:0 0 10px}
.dj-redef-prev i{color:var(--ink);font-style:italic}
.dj-redef-prev .dj-prev-text{display:inline}
.dj-redef-prev .dj-prev-text.is-clamp{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.dj-prev-toggle{display:inline-block;margin-top:5px;background:none;border:0;padding:0;font-family:var(--display);font-weight:600;font-size:11.5px;color:var(--ink-2);cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.dj-prev-toggle:hover{color:var(--ink)}
.dj-add-field{display:inline-flex;align-items:center;gap:8px;width:100%;justify-content:flex-start;border:1.5px dashed var(--line);background:none;border-radius:12px;padding:13px 15px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--muted);cursor:pointer;transition:.12s}
.dj-add-field:hover{border-color:var(--pc);color:var(--pc);background:color-mix(in srgb,var(--pc) 7%,#fff)}
.dj-add-field-plus{font-size:16px;font-weight:600;line-height:1}
.dj-add-field-tx{flex:1;min-width:0;text-align:left}
.dj-add-field-opt{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--wash);border-radius:var(--r-pill);padding:3px 8px;transition:background .14s,color .14s}
.dj-add-field:hover .dj-add-field-opt{background:color-mix(in srgb,var(--pc) 15%,#fff);color:var(--pc)}
.dj-modal-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px 18px;border-top:1px solid var(--line-soft);margin-top:6px;background:var(--paper);border-radius:0 0 var(--r-lg) var(--r-lg)}
.dj-modal-del{border:0;background:transparent;color:var(--muted);font-family:var(--display);font-weight:600;font-size:13.5px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:.14s}
.dj-modal-del:hover{background:var(--magenta-wash);color:var(--magenta-deep)}
.dj-modal-done{border:1.5px solid var(--magenta);background:var(--magenta);color:#fff;font-family:var(--display);font-weight:600;font-size:14px;padding:10px 28px;border-radius:var(--r-pill);cursor:pointer}
.dj-modal-done:hover{filter:brightness(.95)}

/* two-up card picker (space / diverge-converge) */
.dj-dvpick{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.dj-dvcard{display:flex;flex-direction:column;gap:4px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;cursor:pointer;transition:.12s}
.dj-dvcard:hover{border-color:color-mix(in srgb,var(--pc) 40%,var(--line));background:color-mix(in srgb,var(--pc) 3%,#fff)}
.dj-dvcard.on{border-color:var(--pc);background:color-mix(in srgb,var(--pc) 7%,#fff)}
.dj-dvcard-ic{color:var(--pc);margin-bottom:3px}
.dj-dvcard-t{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink)}
.dj-dvcard-s{font-size:12px;line-height:1.45;color:var(--ink-2)}

/* ===== PDF export (rendered off-screen, captured via html-to-image) ===== */
.djx-boardwrap{display:inline-block;padding:26px 24px;background:#fff}
.djx-title{font-family:var(--display);font-weight:800;font-size:24px;letter-spacing:-.01em;color:var(--ink);margin:0 2px 18px}
.djx-board{display:flex;gap:16px;align-items:flex-start;padding:0!important;overflow:visible}
.djx-board .dj-pv-col{flex:0 0 340px;width:340px;max-width:340px;min-width:0;height:auto;max-height:none}
.djx-board .dj-pv-col-body{overflow:visible;max-height:none;height:auto}
.djx-board .dj-pv-card{min-width:0}
.djx-board .dj-pv-q,.djx-board .dj-pv-c,.djx-board .dj-pv-body,.djx-board .dj-pv-ms-text,.djx-board .dj-pv-prst,.djx-board .dj-pv-prel,.djx-poster .dj-pv-q,.djx-poster .dj-pv-c,.djx-poster .dj-pv-body,.djx-poster .dj-pv-ms-text{display:block;-webkit-line-clamp:unset;overflow:visible;overflow-wrap:anywhere}
.djx-poster{background:#fff}
.djx-page{box-sizing:border-box;width:794px;padding:54px 60px;background:#fff}
.djx-poster-h{border-bottom:2px solid var(--line);padding-bottom:16px;margin-bottom:24px}
.djx-poster-eyebrow{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.djx-poster-title{font-family:var(--display);font-weight:800;font-size:30px;letter-spacing:-.015em;color:var(--ink);margin:6px 0 0}
.djx-poster-body{display:flex;flex-direction:column;gap:16px}
/* Double Diamond export */
.djx-diawrap{display:inline-block;width:1180px;padding:28px 32px 36px;background:#fff}
.djx-diahost{position:relative;width:1116px;height:560px;margin:8px 0 14px}
.djx-an-sec{margin-top:6px}
.djx-an-h{font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:-.01em;color:var(--ink);margin:0 0 16px}
.djx-an-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
.djx-an-card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--muted);border-radius:var(--r-lg);padding:16px 18px}
.djx-an-head{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:16px;letter-spacing:-.01em;color:var(--ink);margin-bottom:10px}
.djx-an-dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.djx-an-sub{font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin:14px 0 8px}
.djx-an-acts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.djx-an-acts li{display:flex;align-items:flex-start;gap:9px;font-size:13.5px;line-height:1.4;color:var(--ink-2)}
.djx-an-num{flex:0 0 auto;width:20px;height:20px;border-radius:50%;color:#fff;font-family:var(--display);font-weight:600;font-size:11px;display:grid;place-items:center;margin-top:1px}
.djx-an-concl{font-size:13.5px;line-height:1.55;color:var(--ink);white-space:pre-wrap;text-wrap:pretty}

/* ============ Stakeholders ============ */
/* avatars */
.dj-stk-av{flex:0 0 auto;display:inline-grid;place-items:center;width:32px;height:32px;border-radius:50%;font-family:var(--display);font-weight:700;font-size:12px;color:#fff;letter-spacing:.01em;line-height:1}
.dj-stk-av-sm{width:26px;height:26px;font-size:10.5px}
.dj-stk-av-lg{width:48px;height:48px;font-size:17px}
.dj-stk-av.is-group{border-radius:32%}
/* Start-column roster summary */
.dj-stk-roster{border:1px solid color-mix(in srgb,var(--slate) 20%,var(--line));border-radius:var(--r);padding:12px 13px;background:#fff;cursor:pointer;transition:border-color .14s,background .14s}
.dj-stk-roster:hover{border-color:color-mix(in srgb,var(--slate) 42%,var(--line));background:color-mix(in srgb,var(--slate) 4%,#fff)}
.dj-stk-roster-h{display:flex;align-items:center;gap:7px;margin-bottom:11px}
.dj-stk-roster-ic{display:inline-flex;flex:0 0 auto;color:var(--slate)}
.dj-stk-eyebrow{font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate)}
.dj-stk-stack{display:flex;align-items:center}
.dj-stk-stack .dj-stk-av{margin-left:-8px;border:2px solid #fff}
.dj-stk-stack .dj-stk-av:first-child{margin-left:0}
.dj-stk-more{margin-left:-8px;border:2px solid #fff;background:var(--slate-wash);color:var(--slate);width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:11px}
.dj-stk-roster-count{margin-top:10px;font-size:11.5px;color:var(--muted);font-family:var(--display);font-weight:600}
/* manager modal */
.dj-stk-modal{max-width:640px}
.dj-stk-modal.wide{max-width:min(980px,94vw)}
.dj-stk-modal .dj-modal-head{padding:22px 30px 0}
.dj-stk-modal .dj-modal-body2{padding:22px 30px 20px;max-height:76vh}
.dj-stk-modal .dj-stk-tabs{padding:0 30px}
@media (max-width:640px){
  .dj-stk-modal .dj-modal-head{padding:16px 18px 0}
  .dj-stk-modal .dj-modal-body2{padding:18px 18px 16px;max-height:82vh}
  .dj-stk-modal .dj-stk-tabs{padding:0 18px}
  .dj-stk-modal .dj-stk-foot{padding:14px 18px}
}
.dj-stk-tabs{display:flex;gap:4px;padding:0 22px;border-bottom:1px solid var(--line-soft)}
.dj-stk-tab{border:0;background:none;font-family:var(--display);font-weight:600;font-size:13px;color:var(--muted);padding:11px 6px;margin-right:10px;cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s}
.dj-stk-tab:hover{color:var(--ink-2)}
.dj-stk-tab.on{color:var(--slate);border-bottom-color:var(--slate)}
.dj-stk-empty{padding:34px 8px;text-align:center;color:var(--muted);font-size:13.5px;line-height:1.6}
/* list */
.dj-stk-list{display:flex;flex-direction:column;gap:7px}
.dj-stk-item{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:11px;padding:9px 11px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-stk-item:hover{border-color:color-mix(in srgb,var(--slate) 40%,var(--line));background:color-mix(in srgb,var(--slate) 4%,#fff)}
.dj-stk-item-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.dj-stk-item-tx b{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--ink)}
.dj-stk-item-tx small{font-size:11.5px;color:var(--muted)}
.dj-stk-ptype{flex:0 0 auto;font-family:var(--display);font-weight:600;font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-pill)}
/* foot */
.dj-stk-foot{display:flex;align-items:center;justify-content:flex-end;gap:14px;padding:16px 30px;border-top:1px solid var(--line-soft);flex-wrap:wrap}
.dj-stk-addbtn{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:700;font-size:13px;color:#fff;background:var(--slate);border:1.5px solid var(--slate);border-radius:var(--r-pill);padding:9px 16px;cursor:pointer;transition:background .12s}
.dj-stk-addbtn:hover{background:var(--slate-2);border-color:var(--slate-2)}
/* profile editor */
.dj-stk-profile{display:flex;flex-direction:column;gap:14px}
.dj-stk-profile .dj-fnum{min-width:25px;height:25px;font-size:13px;font-weight:700}
.dj-stk-back{align-self:flex-start;display:inline-flex;align-items:center;gap:5px;border:0;background:none;color:var(--muted);font-family:var(--display);font-weight:600;font-size:13px;cursor:pointer;padding:5px 9px 5px 5px;margin-left:-5px;border-radius:8px;transition:background .12s,color .12s}
.dj-stk-back:hover{background:var(--wash);color:var(--ink)}
.dj-stk-phead{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--line-soft)}
.dj-stk-hr{height:1px;background:var(--line-soft);margin:2px 0}
.dj-stk-phead-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.dj-stk-kindseg{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}
.dj-stk-kindsegb{display:flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid var(--line);background:#fff;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--muted);padding:11px 10px;border-radius:11px;cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.dj-stk-kindsegb:hover{border-color:color-mix(in srgb,var(--slate) 45%,var(--line));color:var(--ink-2)}
.dj-stk-kindsegb.on{border-color:color-mix(in srgb,var(--slate) 45%,var(--line));background:var(--slate-wash);color:var(--slate)}
.dj-stk-nameinput{border:0;border-bottom:1.5px solid transparent;font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;color:var(--ink);padding:2px 0;background:none;outline:none}
.dj-stk-nameinput:hover{border-bottom-color:var(--line-soft)}
.dj-stk-nameinput:focus{border-bottom-color:var(--sc,var(--slate))}
.dj-stk-roleinput{border:0;font-family:var(--text);font-size:13px;color:var(--ink-2);padding:2px 0;background:none;outline:none}
.dj-stk-prow2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dj-stk-meter{display:flex;flex-direction:column;min-width:0}
.dj-stk-meter-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:12px}
.dj-stk-meterval{font-family:var(--display);font-weight:700;font-size:13px;color:var(--sc,var(--slate))}
.dj-stk-sublab{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.dj-field-derived{border-style:solid;border-color:var(--line);background:var(--paper)}
/* segmented control — stakeholder type (one clear, sizeable choice per level) */
.dj-stk-seg{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}
.dj-stk-segb{display:flex;align-items:center;justify-content:center;border:1.5px solid var(--line);background:#fff;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--muted);padding:11px 10px;border-radius:11px;cursor:pointer;transition:border-color .12s,background .12s,color .12s}
.dj-stk-segb:hover{border-color:color-mix(in srgb,var(--sc,var(--slate)) 45%,var(--line));color:var(--ink-2)}
.dj-stk-segb.on{border-color:var(--sc,var(--slate));background:var(--sc,var(--slate));color:#fff;box-shadow:var(--shadow-sm)}
/* swatches */
.dj-stk-swatches{display:flex;gap:8px;flex-wrap:wrap}
.dj-stk-sw{width:26px;height:26px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer;transition:box-shadow .12s;padding:0}
.dj-stk-sw.on{box-shadow:0 0 0 2px #fff,0 0 0 4px currentColor}
/* profile description textarea (a clear, bordered input inside its field card) */
.dj-stk-pdesc{width:100%;border:1.5px solid var(--line);outline:none;background:var(--surface);border-radius:10px;resize:vertical;font-family:var(--text);font-size:13.6px;line-height:1.5;color:var(--ink-2);min-height:74px;padding:10px 12px;box-sizing:border-box;transition:border-color .12s,box-shadow .12s}
.dj-stk-pdesc::placeholder{color:var(--faint)}
.dj-stk-pdesc:focus{border-color:var(--slate);box-shadow:0 0 0 3px color-mix(in srgb,var(--slate) 14%,#fff)}
/* range */
.dj-stk-range{-webkit-appearance:none;appearance:none;width:100%;height:7px;border-radius:var(--r-pill);background:linear-gradient(to right,var(--sc,var(--slate)) var(--v,50%),var(--line-soft) var(--v,50%));outline:none;cursor:pointer}
.dj-stk-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:17px;height:17px;border-radius:50%;background:#fff;border:2.5px solid var(--sc,var(--slate));cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.dj-stk-range::-moz-range-thumb{width:17px;height:17px;border-radius:50%;background:#fff;border:2.5px solid var(--sc,var(--slate));cursor:pointer}
.dj-stk-scale{display:flex;justify-content:space-between;font-family:var(--display);font-weight:600;font-size:10px;color:var(--faint);margin-top:6px}
/* touchpoints */
.dj-stk-touches{display:flex;flex-direction:column;gap:9px;margin-bottom:9px}
.dj-stk-touch{border:1px solid var(--line);border-radius:11px;padding:10px 11px;background:#fff}
.dj-stk-touch-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.dj-stk-select{flex:1;min-width:0;font-family:var(--display);font-weight:600;font-size:12px;color:var(--ink-2);border:1px solid var(--line);border-radius:8px;padding:6px 8px;background:#fff;cursor:pointer;outline:none}
.dj-stk-touch-x{flex:0 0 auto;width:24px;height:24px;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:7px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.dj-stk-touch-x:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.dj-stk-prem{margin-top:6px;padding-top:14px;border-top:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:14px}
.dj-stk-done{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:700;font-size:13px;color:#fff;background:var(--slate);border:1.5px solid var(--slate);border-radius:var(--r-pill);padding:9px 18px;cursor:pointer;transition:background .12s,border-color .12s}
.dj-stk-done:hover{background:var(--slate-2);border-color:var(--slate-2)}
/* matrix */
.dj-stk-mxwrap{display:flex;flex-direction:column}
.dj-stk-mxscroll{overflow:auto;max-height:56vh;margin:0 -2px;padding:0 2px;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--slate-2) var(--line-soft);overscroll-behavior:contain}
.dj-stk-mxscroll::-webkit-scrollbar{width:9px;height:9px}
.dj-stk-mxscroll::-webkit-scrollbar-track{background:var(--line-soft);border-radius:99px}
.dj-stk-mxscroll::-webkit-scrollbar-thumb{background:var(--slate-2);border-radius:99px;border:2px solid var(--line-soft)}
.dj-stk-mxscroll::-webkit-scrollbar-thumb:hover{background:var(--slate)}
.dj-stk-mx{display:grid;align-items:stretch;min-width:max-content}
/* pin the phase-header row (top) and the stakeholder column (left) while scrolling */
.dj-stk-mx-hc{position:sticky;top:0;z-index:3;background:var(--surface)}
.dj-stk-mx-rn{position:sticky;left:0;z-index:3;background:var(--surface);box-shadow:1px 0 0 var(--line-soft)}
.dj-stk-mx-corner{position:sticky;top:0;left:0;z-index:4;background:var(--surface);box-shadow:1px 0 0 var(--line)}
.dj-stk-mx-corner{font-family:var(--display);font-weight:700;font-size:9.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--faint);align-self:end;padding-bottom:11px;border-bottom:2px solid var(--line)}
.dj-stk-mx-hc{font-family:var(--display);font-weight:700;font-size:10px;letter-spacing:.02em;text-transform:uppercase;text-align:center;padding:0 2px 9px;border-bottom:2px solid currentColor}
.dj-stk-mx-rn{display:flex;align-items:center;gap:9px;padding:11px 10px 11px 0;border-top:1px solid var(--line-soft);min-width:0}
.dj-stk-mx-rn-tx{min-width:0;overflow:hidden}
.dj-stk-mx-rn-tx b{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.dj-stk-mx-cell{border-top:1px solid var(--line-soft);border-left:1px solid var(--line-soft);display:grid;place-items:center}
.dj-stk-mx-hc{border-left:1px solid var(--line-soft)}
.dj-stk-mx-dot{width:6px;height:6px;border-radius:50%;background:var(--line)}
.dj-stk-mk{display:grid;place-items:center}
.dj-stk-mk.active{min-width:21px;height:21px;padding:0 5px;border-radius:11px;color:#fff;font-family:var(--display);font-weight:700;font-size:10.5px;box-shadow:0 0 0 2.5px #fff,0 1px 3px rgba(22,19,26,.18)}
.dj-stk-mx-legend{display:flex;gap:16px;margin-top:15px;padding-top:13px;border-top:1px solid var(--line-soft);flex-wrap:wrap}
.dj-stk-lg{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--muted)}
.dj-stk-lgs{display:grid;place-items:center}
.dj-stk-lgs.active{min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--slate);color:#fff;font-family:var(--display);font-weight:700;font-size:10px}
.dj-stk-note{margin-top:12px;font-size:11.5px;line-height:1.5;color:var(--faint)}
/* derived involvement overview (profile) — compact phase strip */
.dj-stk-invwrap{display:flex;flex-direction:column;gap:10px}
.dj-stk-invstrip{display:flex;flex-wrap:wrap;gap:7px}
.dj-stk-invpill{display:inline-flex;align-items:center;gap:7px;padding:5px 8px 5px 9px;border-radius:var(--r-pill);background:color-mix(in srgb,var(--pc) 9%,#fff);border:1px solid color-mix(in srgb,var(--pc) 24%,var(--line));cursor:default}
.dj-stk-invpill-dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--pc)}
.dj-stk-invpill-nm{font-family:var(--display);font-weight:700;font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--pc)}
.dj-stk-invpill-ct{min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--pc);color:#fff;font-family:var(--display);font-weight:700;font-size:10px;display:grid;place-items:center}
.dj-stk-invsum{font-family:var(--display);font-weight:600;font-size:11.5px;color:var(--muted)}
.dj-stk-invnote{display:flex;align-items:flex-start;gap:9px;font-size:13px;line-height:1.5;color:var(--muted)}
.dj-stk-invnote > svg{flex:0 0 auto;margin-top:1px;color:var(--faint)}
/* activity-modal stakeholder picker */
.dj-stk-pick{display:flex;flex-wrap:wrap;gap:8px}
.dj-stk-pickchip{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-pill);padding:5px 12px 5px 5px;cursor:pointer;font-family:var(--text);transition:border-color .12s,background .12s}
.dj-stk-pickchip:hover{border-color:var(--ink-2)}
.dj-stk-pickchip.on{border-color:var(--sc,var(--slate));background:color-mix(in srgb,var(--sc,var(--slate)) 8%,#fff)}
.dj-stk-pickchip-nm{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink)}
.dj-stk-pickchip-tick{display:inline-flex;color:var(--sc,var(--slate))}
.dj-stk-pick-empty{display:inline-flex;align-items:center;width:100%;justify-content:flex-start;border:1.5px dashed var(--line);background:none;border-radius:10px;padding:11px 13px;color:var(--muted);font-family:var(--text);font-size:13px;cursor:pointer}
.dj-stk-pick-empty:hover{border-color:var(--slate);color:var(--slate)}
/* present-mode read-only stakeholder blocks (activity panel + Start panel) */
.dj-pn-stk{margin-top:18px;padding-top:16px;border-top:1px solid var(--line-soft)}
.dj-pn-stk-lab{display:flex;align-items:center;gap:6px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:11px}
.dj-pn-stk-lab svg{color:var(--slate);flex:0 0 auto}
.dj-pn-stk-chips{display:flex;flex-wrap:wrap;gap:8px}
.dj-pn-stkchip{display:inline-flex;align-items:center;gap:8px;background:color-mix(in srgb,var(--sc,var(--slate)) 8%,#fff);border:1.5px solid color-mix(in srgb,var(--sc,var(--slate)) 34%,var(--line));border-radius:var(--r-pill);padding:4px 13px 4px 4px}
.dj-pn-stkchip-nm{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink)}
.dj-pn-startstk{margin-top:18px;padding-top:18px;border-top:1px solid var(--line-soft)}
.dj-pn-stk-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:13px}
.dj-pn-stk-count{font-family:var(--display);font-weight:600;font-size:11.5px;color:var(--muted);flex:0 0 auto}
.dj-pn-stkstack{margin-bottom:18px}
/* present Start: compact stakeholder profile cards + matrix launchers */
.dj-pn-stkcards{display:flex;flex-direction:column;gap:8px}
.dj-pn-stkcard{display:flex;align-items:flex-start;gap:12px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--sc,var(--slate));border-radius:12px;padding:12px 14px}
.dj-pn-stkcard-tx{flex:1;min-width:0}
.dj-pn-stkcard-nm{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-pn-stkcard-role{font-family:var(--text);font-size:12px;color:var(--muted);line-height:1.3;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dj-pn-stkcard-meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-top:6px}
.dj-pn-stkcard-type{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.03em;padding:3px 9px;border-radius:var(--r-pill)}
.dj-pn-stkcard-inv{font-family:var(--display);font-weight:600;font-size:11px;color:var(--muted)}
.dj-pn-stk-views{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:14px}
.dj-pn-stk-viewbtn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid var(--line);background:#fff;color:var(--slate);font-family:var(--display);font-weight:600;font-size:13px;padding:11px 12px;border-radius:11px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-pn-stk-viewbtn:hover{border-color:color-mix(in srgb,var(--slate) 45%,var(--line));background:var(--slate-wash)}
.dj-pn-stk-viewbtn svg{flex:0 0 auto}
/* nested overlay holding a matrix, layered above the drill-down panel */
.dj-pn-stkoverlay{z-index:260}
.dj-stkov{width:min(960px,94vw);max-height:90vh;display:flex;flex-direction:column;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:dj-pop .16s ease}
.dj-stkov-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;border-bottom:1px solid var(--line-soft)}
.dj-stkov-lab{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.02em;color:var(--ink)}
.dj-stkov-lab svg{color:var(--slate)}
.dj-stkov-head .dj-pn-x{position:static}
.dj-stkov-body{flex:1 1 auto;min-height:0;overflow:auto;padding:22px}
/* board present — involved-avatar row on an activity card */
.dj-pv-stk{display:flex;align-items:center;gap:9px;margin-top:12px;padding-top:11px;border-top:1px solid var(--line-soft)}
.dj-pv-stk-ic{display:inline-flex;flex:0 0 auto;color:var(--slate);cursor:help}
.dj-pv-stk .dj-stk-more{width:26px;height:26px;font-size:10px}
/* board present — Start-column stakeholder roster card */
.dj-pv-stkcard{border:1px solid color-mix(in srgb,var(--slate) 20%,var(--line))}
.dj-pv-stkcard-lab{display:flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:13px}
.dj-pv-stkcard-lab svg{color:var(--slate);flex:0 0 auto}
.dj-pv-stkcard-count{margin-top:11px;font-size:11.5px;color:var(--muted);font-family:var(--display);font-weight:600}
.dj-pv-stkcard-views{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:13px}
.dj-pv-stkcard-viewbtn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1.5px solid var(--line);background:#fff;color:var(--slate);font-family:var(--display);font-weight:600;font-size:12px;padding:8px 6px;border-radius:10px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-pv-stkcard-viewbtn:hover{border-color:color-mix(in srgb,var(--slate) 45%,var(--line));background:var(--slate-wash)}
.dj-pv-stkcard-viewbtn svg{flex:0 0 auto;color:var(--slate)}
/* clickable stakeholder avatar (board activity card + Start roster) */
.dj-pv-stkav{padding:0;border:0;background:none;cursor:pointer;display:inline-flex;border-radius:50%;margin-left:-8px;transition:transform .12s ease}
.dj-pv-stkav:first-child{margin-left:0}
.dj-pv-stkav .dj-stk-av{border:2.5px solid #fff}
.dj-pv-stkav:hover{transform:translateY(-2px)}
.dj-pv-stkav:hover .dj-stk-av{box-shadow:0 0 0 2px var(--slate)}
.dj-pv-stkav:focus-visible{outline:none}
.dj-pv-stkav:focus-visible .dj-stk-av{box-shadow:0 0 0 2px var(--slate)}
.dj-pv-stkav-lg{margin-left:-10px}
/* ===== Read-only stakeholder detail (present mode) ===== */
.dj-stkd{position:relative;width:min(640px,calc(100vw - 36px));max-height:calc(100vh - 64px);overflow-y:auto;background:#fff;border-radius:var(--r-lg);border-top:4px solid var(--sc,var(--slate));box-shadow:var(--shadow-lg);padding:30px 28px 26px;animation:dj-pop .18s ease}
.dj-stkd .dj-pn-x{position:absolute;top:16px;right:16px}
.dj-stkd-head{display:flex;gap:16px;align-items:center}
.dj-stkd-head .dj-stk-av-lg{flex:0 0 auto}
.dj-stkd-id{min-width:0}
.dj-stkd-nm{font-family:var(--display);font-weight:600;font-size:23px;line-height:1.15;color:var(--ink);letter-spacing:-.01em}
.dj-stkd-role{font-size:15px;color:var(--ink-2);margin-top:3px}
.dj-stkd-type{display:inline-flex;margin-top:9px;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:var(--r-pill)}
.dj-stkd-desc{margin:18px 0 0;font-size:15px;line-height:1.6;color:var(--ink-2)}
.dj-stkd-meters{margin-top:20px}
.dj-stkd-sec-h{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:13px}
.dj-stkd-sec-h svg{color:var(--slate);flex:0 0 auto}
.dj-stkd-meterrow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.dj-stkd-meter-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:6px}
.dj-stkd-meter-lab{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--ink-2)}
.dj-stkd-meter-val{font-family:var(--display);font-weight:600;font-size:16px;color:var(--sc,var(--slate))}
.dj-stkd-meter-bar{height:7px;border-radius:var(--r-pill);background:var(--wash);overflow:hidden}
.dj-stkd-meter-fill{display:block;height:100%;border-radius:inherit;background:var(--sc,var(--slate))}
.dj-stkd-inv{margin-top:22px;padding-top:18px;border-top:1px solid var(--line-soft)}
.dj-stkd-inv-h{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.dj-stkd-inv-h svg{color:var(--slate);flex:0 0 auto}
.dj-stkd-inv-sum{margin-left:auto;text-transform:none;letter-spacing:0;font-size:13px;color:var(--ink-2)}
.dj-stkd-phases{margin-top:16px;position:relative;display:flex;flex-direction:column}
.dj-stkd-phases::before{content:"";position:absolute;left:11px;top:11px;bottom:11px;width:2px;background:var(--line-soft)}
.dj-stkd-ph{position:relative;display:flex;gap:14px;padding-bottom:18px}
.dj-stkd-ph:last-child{padding-bottom:0}
.dj-stkd-ph-node{position:relative;z-index:1;flex:0 0 auto;width:23px;height:23px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--display);font-weight:600;font-size:12.5px;line-height:1;box-shadow:0 0 0 4px #fff}
.dj-stkd-ph-main{flex:1 1 auto;min-width:0;padding-top:1px}
.dj-stkd-ph-h{font-family:var(--display);font-weight:600;font-size:15px;color:var(--ink)}
.dj-stkd-acts{margin:7px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:5px}
.dj-stkd-acts li{position:relative;padding-left:15px;font-size:14px;line-height:1.5;color:var(--ink-2)}
.dj-stkd-acts li::before{content:"";position:absolute;left:2px;top:8px;width:5px;height:5px;border-radius:50%;background:var(--pc,var(--muted))}
.dj-stkd-empty{margin-top:13px;font-size:14px;line-height:1.55;color:var(--muted)}
/* activity-modal stakeholder picker — larger rosters (search + dense checklist) */
.dj-stk-pick2{display:flex;flex-direction:column;gap:9px}
.dj-stk-pick2-sum{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:32px}
.dj-stk-pick2-none{font-size:12.5px;color:var(--muted);font-family:var(--text)}
.dj-stk-pick2-count{flex:0 0 auto;font-family:var(--display);font-weight:600;font-size:11.5px;color:var(--muted)}
.dj-stk-pick2-search{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:10px;padding:0 10px;background:#fff;color:var(--faint)}
.dj-stk-pick2-search:focus-within{border-color:var(--slate);color:var(--slate)}
.dj-stk-pick2-search input{flex:1;border:0;outline:none;background:none;padding:9px 0;font-family:var(--text);font-size:13px;color:var(--ink)}
.dj-stk-pick2-clear{border:0;background:none;cursor:pointer;color:var(--faint);display:inline-flex;padding:2px}
.dj-stk-pick2-clear:hover{color:var(--ink-2)}
.dj-stk-pick2-list{display:flex;flex-direction:column;gap:6px;max-height:248px;overflow-y:auto;padding:1px}
.dj-stk-pick2-row{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:11px;padding:7px 10px;cursor:pointer;transition:border-color .12s,background .12s}
.dj-stk-pick2-row:hover{border-color:color-mix(in srgb,var(--sc,var(--slate)) 40%,var(--line))}
.dj-stk-pick2-row.on{border-color:var(--sc,var(--slate));background:color-mix(in srgb,var(--sc,var(--slate)) 7%,#fff)}
.dj-stk-pick2-box{flex:0 0 auto;width:22px;height:22px;border-radius:6px;border:1.5px solid var(--line);display:grid;place-items:center;color:#fff;background:#fff}
.dj-stk-pick2-row.on .dj-stk-pick2-box{background:var(--sc,var(--slate));border-color:var(--sc,var(--slate))}
.dj-stk-pick2-empty{font-size:12.5px;color:var(--muted);text-align:center;padding:16px}
/* power/interest grid */
.dj-stk-pi{width:100%;max-width:min(620px,64vh);margin:0 auto}
.dj-stk-pi-row{display:grid;grid-template-columns:30px 1fr;gap:9px;align-items:stretch}
.dj-stk-pi-yax{position:relative;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:3px 0}
.dj-stk-pi-axt{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(180deg);writing-mode:vertical-rl;font-family:var(--display);font-weight:700;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);white-space:nowrap}
.dj-stk-pi-ytk{font-family:var(--display);font-weight:600;font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.dj-stk-plot{display:flex;flex-direction:column;gap:6px;min-width:0}
.dj-stk-quad{position:relative;aspect-ratio:1/1;border:1px solid var(--line);border-radius:16px;overflow:visible;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;box-shadow:0 4px 16px rgba(22,19,26,.07),inset 0 1px 0 rgba(255,255,255,.7)}
/* crisp centre axes */
.dj-stk-quad::before{content:'';position:absolute;left:50%;top:6px;bottom:6px;width:1.5px;transform:translateX(-50%);background:color-mix(in srgb,var(--slate) 22%,#fff);z-index:1}
.dj-stk-quad::after{content:'';position:absolute;top:50%;left:6px;right:6px;height:1.5px;transform:translateY(-50%);background:color-mix(in srgb,var(--slate) 22%,#fff);z-index:1}
.dj-stk-q{position:relative;z-index:2;display:flex;flex-direction:column;gap:2px;padding:12px 14px}
.dj-stk-ql{font-family:var(--display);font-weight:700;font-size:11.5px;line-height:1.2;color:var(--ink-2);display:block}
.dj-stk-qs{font-size:9.5px;line-height:1.3;color:var(--muted)}
.dj-stk-q.tl{background:color-mix(in srgb,var(--slate) 6%,#fff);align-items:flex-start;border-top-left-radius:15px}
.dj-stk-q.tr{background:color-mix(in srgb,var(--slate) 13%,#fff);align-items:flex-end;text-align:right;border-top-right-radius:15px}
.dj-stk-q.bl{background:#fff;justify-content:flex-end;align-items:flex-start;border-bottom-left-radius:15px}
.dj-stk-q.br{background:color-mix(in srgb,var(--slate) 6%,#fff);justify-content:flex-end;align-items:flex-end;text-align:right;border-bottom-right-radius:15px}
.dj-stk-q.tr .dj-stk-ql{color:var(--ink)}
.dj-stk-pi-xtk{display:flex;justify-content:space-between;padding:0 3px;font-family:var(--display);font-weight:600;font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.dj-stk-pi-xax{padding-left:39px;text-align:center;margin-top:3px;font-family:var(--display);font-weight:700;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate)}
/* plotted stakeholders */
.dj-stk-pi-av{position:absolute;transform:translate(-50%,-50%);z-index:3}
.dj-stk-pi-av .dj-stk-av{width:30px;height:30px;font-size:11.5px;border:2.5px solid #fff;box-shadow:0 2px 7px rgba(22,19,26,.24);transition:transform .12s}
.dj-stk-pi-av:hover{z-index:6}
.dj-stk-pi-av:hover .dj-stk-av{transform:scale(1.14)}
.dj-stk-pi-tip{position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-family:var(--display);font-weight:600;font-size:10.5px;white-space:nowrap;padding:3px 9px;border-radius:7px;opacity:0;pointer-events:none;transition:opacity .12s;z-index:7}
.dj-stk-pi-tip::before{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:4px solid transparent;border-bottom-color:var(--ink)}
.dj-stk-pi-av:hover .dj-stk-pi-tip{opacity:1}

