
  [data-theme="twilight"]{
    --bg:#0e1623; --panel:#15202f; --panel2:#1c2a3b; --line:#2b3d52;
    --ink:#e7eef7; --dim:#9fb4cb; --faint:#637689;
    --accent:#79b8e0; --accentDeep:#3f86c2; --accentInk:#06121e;
    --warm:#e0a96a; --info:#7cc0e8; --gate:#cdb05f;
  }
  [data-theme="sunset"]{
    --bg:#1a1117; --panel:#241820; --panel2:#2f2029; --line:#43303a;
    --ink:#f3e9ec; --dim:#ccaab4; --faint:#8c6f7b;
    --accent:#e79a7e; --accentDeep:#c96f56; --accentInk:#1c0f0a;
    --warm:#e0b074; --info:#c79bd0; --gate:#cda45f;
  }
  [data-theme="pine"]{
    --bg:#0f1411; --panel:#161d18; --panel2:#1c2620; --line:#2a382f;
    --ink:#eaf2ec; --dim:#9db3a6; --faint:#5f7468;
    --accent:#5ec98c; --accentDeep:#3f9d6b; --accentInk:#06140c;
    --warm:#e8a55c; --info:#74b3e6; --gate:#c9a24b;
  }
  /* semantic color aliases used across redesign */
  :root{--green:#45a872;--amber:#d9a45e;--red:#c75656;
    --tb:#4eb87a;
    /* V2 entity edge colors -- canonical per entity */
    --wren-color:#3f86c2;--trailbuildr-color:#4eb87a;--theline-color:#ea7513;
    --chip-pos-bg:color-mix(in srgb,var(--accentDeep) 16%,var(--panel2));--chip-pos:hsl(202,65%,62%);
    --chip-mktg-bg:color-mix(in srgb,var(--warm) 16%,var(--panel2));--chip-mktg:var(--warm);
    --chip-creative-bg:color-mix(in srgb,var(--info) 16%,var(--panel2));--chip-creative:var(--info);
    --chip-brand-bg:color-mix(in srgb,var(--gate) 16%,var(--panel2));--chip-brand:var(--gate);
    --chip-build-bg:color-mix(in srgb,#9d80f0 16%,var(--panel2));--chip-build:#9d80f0;
    --chip-console-bg:color-mix(in srgb,var(--faint) 22%,var(--panel2));--chip-console:var(--dim);}
  *{box-sizing:border-box}
  body{margin:0;background:var(--bg);color:var(--ink);transition:background .35s;
    font:17px/1.55 'Arimo',Arial,sans-serif;-webkit-font-smoothing:antialiased}
  h1,h2,h3,h4,.sectitle,.ctitle,.stage-title,.on-name,.ghdr{font-family:'League Spartan',sans-serif}
  header{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:12px;
    padding:14px 20px;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
  .logo{display:flex;align-items:center;gap:10px;font-weight:650;font-size:18px}
  .mark{width:26px;height:26px}
  .swatches{margin-left:auto;display:flex;gap:8px;align-items:center}
  .sw{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0}
  .sw.on{border-color:var(--ink)}
  .sw.tw{background:#3f86c2}.sw.su{background:#c96f56}.sw.pi{background:#3f9d6b}
  .live{display:flex;align-items:center;gap:7px;color:var(--dim);font-size:13px;margin-left:14px}
  .clock{margin-left:12px;color:var(--faint);font-size:12.5px;font-variant-numeric:tabular-nums;white-space:nowrap}
  .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 55%,transparent)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
  main{max-width:780px;margin:0 auto;padding:18px 16px 80px}
  h2{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin:26px 4px 12px;font-weight:600}
  .sub{color:var(--faint);font-weight:500;text-transform:none;letter-spacing:0}

  .card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:15px 16px;margin-bottom:10px}
  .card.urgent{border-color:var(--warm)}
  .ctitle{font-weight:600;margin-bottom:5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--panel2)}
  .tag.now{color:var(--warm)} .tag.demo{color:var(--info)} .tag.q{color:var(--accent)}
  .detail{color:var(--ink);font-size:16px;margin-bottom:14px;line-height:1.6}
  .row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
  button{font:inherit;font-weight:600;border:1px solid var(--line);background:var(--panel2);color:var(--ink);
    padding:9px 16px;border-radius:10px;cursor:pointer;transition:.15s}
  button:hover{transform:translateY(-1px)}
  button.sm{padding:6px 12px;font-size:13px}
  button.go{background:var(--accentDeep);border-color:var(--accentDeep);color:var(--accentInk)}
  button.go:hover{filter:brightness(1.12)}
  button.opt{background:var(--panel2);text-align:left;width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-direction:column}
  button.opt:hover{border-color:var(--accent)}
  .opt-inner{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%}
  .opt-detail{font-size:12px;font-weight:400;color:var(--faint);line-height:1.35;margin-top:2px}
  .opt-freetype{display:flex;gap:7px;align-items:center;margin-top:10px}
  .opt-freetype input{flex:1;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:8px;
    padding:7px 10px;font:inherit;font-size:13px}
  .opt-freetype input:focus{outline:none;border-color:var(--accent)}
  .opt-freetype input::placeholder{color:var(--faint)}
  .opt-freetype button{flex:none;padding:7px 13px;font-size:13px}
  /* recommended option: accent border + pill badge */
  button.opt.recopt{border-color:color-mix(in srgb,var(--accent) 45%,var(--line));
    background:color-mix(in srgb,var(--accent) 7%,var(--panel2))}
  button.opt.recopt:hover{border-color:var(--accent);
    background:color-mix(in srgb,var(--accent) 15%,var(--panel2));filter:none}
  button.opt .pick{flex:none;font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;
    background:var(--accent);color:var(--accentInk);letter-spacing:.03em;white-space:nowrap;
    font-family:'League Spartan',sans-serif}
  /* tap feedback -- opacity-only, no transform */
  @keyframes tap{0%{opacity:1}35%{opacity:.72}100%{opacity:1}}
  button.opt.tapped{animation:tap .3s ease;border-color:var(--accent);
    background:color-mix(in srgb,var(--accent) 18%,var(--panel2))}

  /* FIX2: in-button confirm states */
  /* opt button: armed = first tap, shows "Tap again to confirm" */
  button.opt.opt-selected-pending{
    border-color:var(--accent);
    background:color-mix(in srgb,var(--accent) 18%,var(--panel2));
    box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 36%,transparent);
  }
  /* armed text inside the opt button */
  .opt-arm-text{
    font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.01em;
  }
  button.opt.opt-dimmed-pending{
    opacity:.38;
    pointer-events:none;
  }
  /* btn-armed: in-button confirm state for primary/go action buttons */
  button.btn-armed{
    background:color-mix(in srgb,var(--accent) 22%,var(--panel2));
    border-color:var(--accent);
    color:var(--accent);
    font-weight:700;
    box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 28%,transparent);
    animation:arm-pulse 0.22s ease;
  }
  @keyframes arm-pulse{from{transform:scale(.97)}to{transform:scale(1)}}

  /* FIX1: unified card input zone */
  .card-input-zone{
    margin-top:14px;border-top:1px solid var(--line);padding-top:12px;
  }
  .card-unified-textarea{
    width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:9px;
    padding:9px 11px;font:inherit;font-size:13.5px;resize:vertical;min-height:48px;
  }
  .card-unified-textarea:focus{outline:none;border-color:var(--accent);}
  .card-unified-textarea::placeholder{color:var(--faint);}
  .card-input-actions{
    display:flex;align-items:center;gap:8px;margin-top:7px;flex-wrap:wrap;
  }
  button.card-input-send{
    margin-left:auto;padding:6px 16px;font-size:13px;background:var(--panel2);
  }
  button.card-input-send:hover{border-color:var(--accent);}
  .card-attach-btn{
    display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--faint);
    cursor:pointer;padding:4px 9px;border:1px solid var(--line);border-radius:8px;
    background:var(--panel2);font-weight:500;white-space:nowrap;
  }
  .card-attach-btn:hover{border-color:var(--accent);color:var(--dim);}
  .card-attach-icon{font-weight:700;font-size:14px;line-height:1;}
  .card-drop-zone{
    flex:1;display:flex;align-items:center;justify-content:center;
    border:1.5px dashed var(--line);border-radius:8px;
    padding:6px 10px;color:var(--faint);font-size:12px;cursor:pointer;min-width:120px;
  }
  .card-drop-zone:hover,.card-drop-zone.over{border-color:var(--accent);color:var(--dim);}
  .card-input-sent{
    font-size:12px;color:var(--accent);font-weight:600;min-width:32px;
  }
  /* past notes shown above the input zone */
  .card-footer-notes{margin-top:10px;border-top:1px solid var(--line);padding-top:8px;}
  .card-footer-notes:empty{display:none;}
  /* answered choose — stays visible, your pick marked */
  .card.answered{opacity:.96}
  .opt.ans{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:1px solid var(--line);
    border-radius:10px;padding:9px 13px;background:transparent;color:var(--faint);font-weight:500;font-size:14px}
  .opt.ans.sel{color:var(--ink);font-weight:600;border-color:var(--accent);
    background:color-mix(in srgb,var(--accent) 12%,var(--panel2))}
  .opt.ans .chk{color:var(--accent);font-weight:800;flex:none}
  .opt.ans .chk.empty{color:var(--line)}
  .greet{margin:4px 4px 2px;font-size:18px;font-family:'League Spartan',sans-serif;font-weight:600;color:var(--ink)}
  .greet b{font-weight:700;border-bottom:1px dashed var(--faint);cursor:pointer}
  .greet .gsub{font-size:14px;font-weight:400;color:var(--faint);font-family:'Arimo',sans-serif}
  .greet .waiting{color:var(--accentDeep);font-weight:800}
  button.ghost{color:var(--dim)}
  .done{opacity:.55}
  .badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:9px;background:var(--panel2)}
  .badge.ok{color:var(--accent)} .badge.hold{color:var(--gate)} .badge.dismiss{color:var(--faint)}

  details.more{margin-top:8px;border-top:1px dashed var(--line);padding-top:10px}
  details.more>summary{cursor:pointer;color:var(--accent);font-size:13px;font-weight:600;list-style:none}
  details.more>summary::-webkit-details-marker{display:none}
  details.more>summary::before{content:'＋ ';color:var(--faint)}
  details.more[open]>summary::before{content:'－ '}
  .morebody{color:var(--dim);font-size:13.5px;margin-top:9px}
  /* full draft well — long body scrolls, mockup thumbnail below */
  .draft-well{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:12px 13px;margin-top:8px}
  .draft-body{white-space:pre-wrap;word-break:break-word;font-size:13.5px;line-height:1.6;color:var(--ink);
    max-height:420px;overflow-y:auto;scrollbar-width:thin}
  .draft-mockup{margin-top:10px;border-radius:8px;overflow:hidden;max-width:100%}
  .draft-mockup img{width:100%;height:auto;display:block;border-radius:8px}

  details.bundle>summary{cursor:pointer;color:var(--accent);font-size:13px;font-weight:600;list-style:none;margin:4px 0 6px}
  details.bundle>summary::-webkit-details-marker{display:none}
  details.bundle>summary::before{content:'▸ ';}
  details.bundle[open]>summary::before{content:'▾ ';}
  .item{border:1px solid var(--line);border-radius:11px;padding:11px 12px;margin:8px 0;background:var(--panel2)}
  .item .it{font-weight:600;font-size:14px}.item .ip{color:var(--dim);font-size:13px;margin:3px 0 9px}

  /* compare options */
  .cmprow{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
  .cmp{border:1px solid var(--line);border-radius:11px;padding:13px;background:var(--panel2);
    flex:1 1 210px;min-width:200px;display:flex;flex-direction:column}
  .cmp .why{margin-top:auto}
  .cmp>button{margin-top:10px}
  .cmp.rec{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--panel2))}
  .cmp .cl{font-weight:600;margin-bottom:3px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .pick{font-size:10.5px;font-weight:700;color:var(--accentInk);background:var(--accent);padding:2px 9px;border-radius:20px;letter-spacing:.03em}
  .pc{display:flex;flex-direction:column;gap:8px;margin:9px 0 4px}
  .plist{list-style:none;margin:0;padding:0;flex:1;min-width:150px}
  .plist .hd{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
  .plist li{font-size:13px;line-height:1.45;padding-left:18px;position:relative;margin:3px 0}
  .pro{color:var(--ink)} .pro::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700}
  .con{color:var(--dim)} .con::before{content:'–';position:absolute;left:1px;color:var(--gate);font-weight:700}
  .why{font-size:12.5px;color:var(--dim);margin:9px 0;padding:8px 11px;border-left:2px solid var(--accent);
    background:color-mix(in srgb,var(--accent) 9%,transparent);border-radius:0 7px 7px 0}
  .why b{color:var(--accent);font-weight:700}

  /* rank list */
  .rank{border:1px solid var(--line);border-radius:11px;background:var(--panel2);margin:4px 0 10px;overflow:hidden}
  .rk{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--line)}
  .rk:last-child{border-bottom:none}
  .rk .pos{width:20px;color:var(--accent);font-weight:700;flex:none}
  .rk .lbl{flex:1}
  .rk .arr{display:flex;gap:4px}
  .rk .arr button{padding:3px 9px;font-size:13px}

  /* thoughts + uploads footer */
  .feed{margin:6px 0}
  .nt{font-size:13px;color:var(--ink);background:var(--panel2);border-left:2px solid var(--accent);border-radius:6px;padding:6px 10px;margin:5px 0}
  .nt .na{color:var(--faint);font-size:11px}
  textarea{width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:9px;
    padding:9px 11px;font:inherit;font-size:13.5px;resize:vertical;min-height:42px}
  .drop{display:flex;align-items:center;gap:8px;justify-content:center;border:1.5px dashed var(--line);border-radius:9px;
    padding:10px;color:var(--faint);font-size:13px;cursor:pointer;margin-top:8px}
  .drop:hover,.drop.over{border-color:var(--accent);color:var(--dim)}
  .chip{display:inline-flex;gap:6px;align-items:center;background:var(--panel2);border:1px solid var(--line);
    border-radius:8px;padding:4px 9px;font-size:12px;margin:6px 6px 0 0;color:var(--dim);text-decoration:none}

  details.ws{border:1px solid var(--line);border-radius:12px;margin-bottom:8px;background:var(--panel);overflow:hidden}
  details.ws>summary{cursor:pointer;display:flex;align-items:center;gap:12px;padding:12px 14px;list-style:none}
  details.ws>summary::-webkit-details-marker{display:none}
  .caret{color:var(--faint);transition:.15s;flex:none}
  details.ws[open] .caret{transform:rotate(90deg)}
  .num{width:24px;height:24px;flex:none;border-radius:7px;background:var(--panel2);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--accent)}
  .ws .t{font-weight:600}.ws .n{color:var(--dim);font-size:12.5px}
  .ws .meta{display:flex;flex-direction:column;min-width:0}
  .st{margin-left:auto;font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;flex:none;background:var(--panel2)}
  .st.active,.st.ready,.st.done{color:var(--accent)} .st.next{color:var(--info)} .st.planned{color:var(--dim)}
  .st.done{background:color-mix(in srgb,var(--accent) 14%,var(--panel2))}
  .st.later,.st.gated{color:var(--gate)} .st.parked{color:var(--faint)}
  .steps{padding:4px 16px 14px 50px;border-top:1px solid var(--line)}
  .step{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:13.5px}
  .sdot{width:8px;height:8px;border-radius:50%;flex:none;background:var(--line)}
  .sdot.done{background:var(--accent)} .sdot.active{background:var(--warm);box-shadow:0 0 0 3px color-mix(in srgb,var(--warm) 18%,transparent)}
  .step.planned{color:var(--dim)}

  .mk{border:1px solid var(--line);border-radius:10px;padding:12px;background:var(--bg);margin-top:10px;max-width:420px}
  .mk-meta{font-size:10.5px;letter-spacing:.1em;color:var(--faint)}
  .mk-q{font-weight:600;margin:6px 0 10px}
  .mk-opt{border:1px solid var(--line);border-radius:8px;padding:8px 10px;margin:6px 0;font-size:13px;color:var(--dim)}
  .mk-opt.sel{border-color:var(--accent);color:var(--ink)}

  .upd{border-left:2px solid var(--line);padding:2px 0 2px 13px;margin:0 4px 14px}
  .upd .ut{font-weight:600;font-size:14px}.upd .ub{color:var(--dim);font-size:13px}
  .upd .ud{color:var(--faint);font-size:11px;letter-spacing:.04em}

  /* collapsible section headers */
  details.section{margin-top:14px}
  details.section>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:10px;
    padding:13px 15px;background:var(--panel);border:1px solid var(--line);border-radius:12px}
  details.section>summary:hover{border-color:var(--accentDeep)}
  details.section>summary::-webkit-details-marker{display:none}
  details.section>summary::before{content:'▸';color:var(--faint);font-size:13px}
  details.section[open]>summary::before{content:'▾'}
  details.section>summary .sectitle{font-size:15px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);font-weight:700}
  details.section>summary .seccount{margin-left:auto;font-size:11px;color:var(--faint);font-weight:600;letter-spacing:.02em}
  details.section>summary .dtidy{flex:none}
  details.section>summary .dtidy button{padding:5px 11px;font-size:12px}
  details.section>summary .seccol{flex:none;display:flex;gap:5px}
  details.section>summary .seccol button{padding:3px 11px;font-size:16px;font-weight:700;line-height:1.1}
  details.section[open]>summary{margin-bottom:10px}

  /* top toolbar: greeting + master expand/nest */
  .topbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:2px 4px 2px}
  .allctl{margin-left:auto;display:flex;gap:5px}
  .allctl button{padding:3px 13px;font-size:17px;font-weight:700;line-height:1.1}

  /* live session mirror (console) */
  .console{font:12px/1.55 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:var(--bg);
    border:1px solid var(--line);border-radius:10px;padding:11px 13px;max-height:320px;overflow:auto}
  .console:empty::before{content:'No session activity yet.';color:var(--faint)}
  .cl-line{padding:2px 0;white-space:pre-wrap;word-break:break-word;color:var(--dim)}
  .cl-ts{color:var(--faint);margin-right:7px}
  .cl-perm{color:var(--gate)} .cl-issue{color:var(--warm)} .cl-tool{color:var(--accent)} .cl-done{color:var(--accent)}

  /* attention chip — small, dismissible, taps through to Claude; muted/neutral palette */
  #attn:empty{display:none}
  .attn-wrap{margin-bottom:8px}
  .attn-chip{display:inline-flex;align-items:center;gap:7px;padding:5px 7px 5px 11px;
    background:color-mix(in srgb,var(--dim) 10%,var(--panel2));border:1px solid var(--line);border-radius:20px;
    color:var(--dim);font-weight:600;font-size:12px;text-decoration:none;letter-spacing:.02em}
  .attn-chip .adot{width:7px;height:7px;border-radius:50%;background:var(--faint);flex:none}
  .attn-chip .ax{cursor:pointer;color:var(--faint);font-weight:700;font-size:14px;line-height:1;padding:0 4px}
  .attn-chip .ax:hover{color:var(--ink)}
  /* inline flock inside the now-bar — replaces the old standalone .statusbar block */
  .now-status-inline{display:flex;align-items:center;gap:5px;flex:none;margin-left:auto}
  .now-flock{display:flex;align-items:center;gap:6px}
  .now-flock .bird{display:inline-flex}
  .now-flock .wing{width:16px;height:9px;color:var(--accent);opacity:.35;transform-origin:center;display:block}
  .now-flock .wing.fly{opacity:.6;animation:flutter ease-in-out infinite}
  @keyframes flutter{
    0%,100%{transform:scaleY(1) translateY(0) rotate(0)}
    50%    {transform:scaleY(.62) translateY(-3px) rotate(2deg)}}
  .now-state-word{font-size:11px;font-style:italic;color:var(--faint);letter-spacing:.03em;white-space:nowrap}
  /* legacy sbar styles kept for safety — element no longer rendered */
  .flutter{display:flex;align-items:center;justify-content:center;gap:13px}
  .flutter .bird{display:inline-flex}
  .flutter .wing{width:24px;height:14px;color:var(--accent);opacity:.45;transform-origin:center;display:block}
  .flutter .wing.fly{opacity:.8;animation:flutter ease-in-out infinite}

  /* decision group headers */
  .ghdr{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700;
    margin:18px 4px 9px;display:flex;align-items:center;gap:8px}
  .ghdr::after{content:'';flex:1;height:1px;background:var(--line)}
  .ghdr:first-child{margin-top:6px}
  /* collapsible decision groups */
  details.dgroup{margin:0}
  details.dgroup>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:8px;
    font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700;margin:18px 4px 9px}
  details.dgroup:first-of-type>summary{margin-top:6px}
  details.dgroup>summary::-webkit-details-marker{display:none}
  details.dgroup>summary::before{content:'▸';color:var(--faint);font-size:10px}
  details.dgroup[open]>summary::before{content:'▾'}
  details.dgroup>summary .gcount{color:var(--faint);font-weight:600;letter-spacing:.02em;text-transform:none}
  details.dgroup>summary .gline{flex:1;height:1px;background:var(--line)}
  footer{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:9px;font-size:12px;color:var(--faint);
    background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(6px);border-top:1px solid var(--line)}

  /* "From Wren" — Recent + Live session side by side */
  .fromwren{display:flex;gap:12px;align-items:stretch}
  .fromwren .fw-mod{flex:1 1 0;min-width:0;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px 14px}
  .fromwren .fw-h{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:7px}
  .fromwren .fw-h .fc{color:var(--faint);font-weight:600;letter-spacing:.02em;text-transform:none}
  .fromwren .fw-mod .upd:last-child{margin-bottom:0}
  .fromwren .fw-mod .console{max-height:260px}

  /* From Wren — three collapsible groups (org chart · recent · live session) */
  details.fw-group{background:var(--panel);border:1px solid var(--line);border-radius:12px;margin-bottom:10px}
  details.fw-group>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:9px;padding:11px 14px}
  details.fw-group>summary:hover{border-radius:12px}
  details.fw-group>summary::-webkit-details-marker{display:none}
  details.fw-group>summary::before{content:'▸';color:var(--faint);font-size:11px}
  details.fw-group[open]>summary::before{content:'▾'}
  details.fw-group>summary .fg-t{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);font-weight:700}
  details.fw-group>summary .fg-c{font-size:11px;color:var(--faint);font-weight:600;letter-spacing:.02em}
  details.fw-group>summary .fg-col{margin-left:auto;display:flex;gap:5px;flex:none}
  details.fw-group>summary .fg-col button{padding:2px 10px;font-size:15px;font-weight:700;line-height:1.1}
  details.fw-group>.fg-body{padding:2px 14px 14px}

  /* org chart — team flow chart: Alex -> Wren -> lanes -> members, connector lines + per-lane color */
  .org{display:flex;flex-direction:column;align-items:center;width:100%}
  .org-conn{width:2px;height:16px;background:linear-gradient(var(--line),var(--accentDeep))}
  .org-node{position:relative;width:100%;max-width:260px;text-align:left;cursor:pointer;background:var(--panel2);
    border:1px solid var(--line);border-left:3px solid var(--nc,var(--line));border-radius:10px;padding:8px 11px;
    transition:transform .12s,box-shadow .15s,border-color .15s}
  .org-node:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.28);border-color:var(--nc,var(--accentDeep))}
  .org-node.hot{box-shadow:0 0 0 1.5px var(--nc,var(--accent)) inset,0 0 14px -4px var(--nc,var(--accent))}
  .org-node.top{max-width:200px;text-align:center;border-left-width:1px;border-top:3px solid var(--nc)}
  .org-node.top .on-row{justify-content:center}
  .org-node.lead.wren{max-width:236px;background:color-mix(in srgb,var(--nc) 12%,var(--panel2))}
  .on-row{display:flex;align-items:baseline;gap:7px}
  .on-name{font-weight:700;font-size:13.5px;color:var(--ink)}
  .on-title{font-size:11px;color:var(--faint)}
  .on-most{margin-left:auto;font-size:8.5px;font-weight:800;letter-spacing:.05em;color:var(--nc,var(--accent));
    text-transform:uppercase;flex:none;background:color-mix(in srgb,var(--nc,var(--accent)) 16%,transparent);
    padding:1px 6px;border-radius:20px}
  .on-meter{height:3px;border-radius:3px;background:var(--line);margin-top:6px;overflow:hidden}
  .on-meter>span{display:block;height:100%;background:var(--nc,var(--accent));border-radius:3px;transition:width .3s}
  .on-role{font-size:12px;color:var(--dim);margin-top:7px;line-height:1.45;display:none}
  .org-node.open .on-role{display:block}
  /* branching area under Wren */
  .org-stem{width:2px;height:16px;background:var(--accentDeep);margin:0 auto}
  .org-lanes{display:flex;gap:10px;width:100%;align-items:flex-start;position:relative;padding-top:16px}
  .org-lanes::before{content:'';position:absolute;top:0;left:16.67%;right:16.67%;height:2px;
    background:color-mix(in srgb,var(--accentDeep) 70%,var(--line))}
  .org-lane{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:stretch;gap:8px;position:relative;--lane:var(--accent)}
  .org-lane::before{content:'';position:absolute;top:-16px;left:50%;transform:translateX(-50%);width:2px;height:16px;background:var(--lane)}
  .org-lane-label{align-self:center;font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:800;
    color:var(--lane);background:color-mix(in srgb,var(--lane) 16%,transparent);
    padding:3px 10px;border-radius:20px;border:1px solid color-mix(in srgb,var(--lane) 35%,transparent)}
  .org-node.role{padding:6px 10px;background:var(--panel)}
  .org-node.role .on-name{font-size:12.5px;font-weight:600}
  /* members tree with a colored left rail */
  .org-members{position:relative;display:flex;flex-direction:column;gap:7px;padding:6px 0 0 16px}
  .org-members::before{content:'';position:absolute;left:6px;top:-2px;bottom:13px;width:2px;
    background:color-mix(in srgb,var(--lane) 60%,var(--line))}
  .org-members .org-node::after{content:'';position:absolute;left:-10px;top:50%;width:10px;height:2px;
    background:color-mix(in srgb,var(--lane) 60%,var(--line))}
  /* mobile: vertical flow, each lane a colored-top card */
  @media (max-width:640px){
    .org-node{max-width:none}
    .org-lanes{flex-direction:column;gap:18px;padding-top:0}
    .org-lanes::before{display:none}
    .org-lane{padding:14px 12px 12px;border:1px solid var(--line);border-top:3px solid var(--lane);
      border-radius:12px;background:color-mix(in srgb,var(--lane) 7%,var(--panel))}
    .org-lane::before{top:-18px;height:18px}
    .org-lane:first-child::before{display:none}
    .org-lane-label{align-self:flex-start}
  }
  /* entity-based org layout */
  .org-entities{display:flex;flex-direction:column;gap:18px;width:100%;margin-top:2px}
  .org-entity{border:1px solid var(--line);border-top:3px solid var(--entity-color,var(--accent));
    border-radius:13px;overflow:hidden;background:var(--panel)}
  .org-entity-header{display:flex;align-items:baseline;gap:10px;padding:10px 14px 10px;
    background:color-mix(in srgb,var(--entity-color,var(--accent)) 7%,var(--panel))}
  .org-entity-label{font-family:'League Spartan',sans-serif;font-size:13px;font-weight:800;
    letter-spacing:.08em;text-transform:uppercase;color:var(--entity-color,var(--accent));flex:none}
  .org-entity-desc{font-size:12px;color:var(--faint);font-family:'Arimo',sans-serif;font-style:italic}
  .org-entity-lead{padding:10px 14px 6px;border-bottom:1px solid var(--line)}
  .org-entity-lead .org-node{max-width:none;width:100%}
  .org-entity-groups{padding:10px 14px 14px;display:flex;flex-direction:column;gap:14px}
  .org-group{display:flex;flex-direction:column;gap:8px}
  .org-group-lead .org-node{max-width:none}
  /* tighten nodes within entity context */
  .org-entity .org-node{max-width:none}
  /* AG entity: no-team notice */
  .org-entity-note{font-size:13px;color:var(--faint);font-style:italic;padding:10px 14px 14px;
    font-family:'Arimo',sans-serif;line-height:1.5}

  /* recent updates — title leads, details collapse under it */
  details.upd2{border-left:2px solid var(--line);padding:0 0 0 12px;margin:0 2px 9px}
  details.upd2>summary{cursor:pointer;list-style:none;display:flex;align-items:baseline;gap:9px}
  details.upd2>summary::-webkit-details-marker{display:none}
  details.upd2>summary::before{content:'▸';color:var(--faint);font-size:10px;flex:none}
  details.upd2[open]>summary::before{content:'▾'}
  details.upd2>summary .ut{font-weight:600;font-size:14px;color:var(--ink)}
  details.upd2>summary .ud{margin-left:auto;color:var(--faint);font-size:11px;letter-spacing:.04em;flex:none}
  details.upd2>.ub{color:var(--dim);font-size:13px;margin:5px 0 0;line-height:1.5}

  /* marketing draft card — full inline view, no expander */
  .draft-card{border:1px solid var(--line);border-radius:13px;padding:14px 15px;margin:10px 0;background:var(--panel2)}
  .draft-card .dc-header{margin-bottom:4px}
  .draft-card .dc-title{font-weight:600;font-size:14.5px;color:var(--ink)}
  .draft-card .dc-preview{color:var(--dim);font-size:13px;margin:3px 0 10px;line-height:1.4}
  .draft-card .dc-body{margin-bottom:14px}
  /* action zone: clear separation, nothing close enough to mis-tap */
  .draft-actions{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--line);padding-top:14px;margin-top:4px}
  .draft-action-row{display:flex;gap:10px;align-items:center}
  .draft-revise{display:flex;flex-direction:column;gap:7px}
  .draft-revise textarea{min-height:52px;resize:vertical;font-size:13.5px}
  .draft-revise-row{display:flex;gap:8px;align-items:center}
  .draft-card.status-approved{border-color:var(--accent);opacity:.75}
  .draft-card.status-dismissed{opacity:.45}
  .draft-card.status-revise{border-color:var(--gate);opacity:.75}
  .draft-status-label{font-size:12px;font-weight:700;color:var(--faint);letter-spacing:.04em;text-transform:uppercase;margin-left:auto}
  .draft-status-label.ok{color:var(--accent)}.draft-status-label.gate{color:var(--gate)}
  /* marketing approval pipeline — staged gating */
  .pipeline-stage{margin-bottom:4px}
  .stage-header{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:12px;
    background:var(--panel);border:1px solid var(--line);margin-bottom:8px}
  .stage-num{width:26px;height:26px;border-radius:8px;background:var(--panel2);
    display:grid;place-items:center;font-size:11px;font-weight:800;color:var(--accent);flex:none}
  .stage-title{font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase}
  .stage-sub{color:var(--faint);font-size:12px;font-weight:400;text-transform:none;letter-spacing:0}
  .stage-status{margin-left:auto;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;
    background:var(--panel2);letter-spacing:.04em;text-transform:uppercase;flex:none}
  .stage-status.locked{color:var(--gate)} .stage-status.active{color:var(--warm);animation:pulse 2s infinite}
  .stage-status.done{color:var(--accent)}
  /* locked card — greyed, padlock, not interactive */
  .card.stage-locked{opacity:.42;pointer-events:none;border-style:dashed;position:relative}
  .stage-lock-overlay{position:absolute;inset:0;border-radius:14px;display:flex;align-items:center;
    justify-content:center;pointer-events:none}
  .lock-badge{background:var(--panel2);border:1px solid var(--gate);border-radius:20px;
    padding:4px 12px;font-size:11.5px;font-weight:700;color:var(--gate);letter-spacing:.04em}
  /* positioning-lock card — the marquee, full content readable */
  .pos-well{background:var(--bg);border:1px solid var(--line);border-radius:10px;
    padding:14px 15px;margin:10px 0;max-height:380px;overflow-y:auto;scrollbar-width:thin}
  .pos-well .pw-section{margin-bottom:14px}
  .pos-well .pw-section:last-child{margin-bottom:0}
  .pos-well .pw-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;
    color:var(--faint);font-weight:700;margin-bottom:5px}
  .pos-well .pw-body{font-size:13.5px;line-height:1.6;color:var(--ink)}
  .pos-well .pw-spine{font-size:14px;font-weight:600;color:var(--ink);
    border-left:3px solid var(--accent);padding-left:10px;margin:6px 0;line-height:1.5}
  .pos-well .pw-bullets{list-style:none;margin:6px 0;padding:0}
  .pos-well .pw-bullets li{font-size:13px;color:var(--dim);padding-left:16px;position:relative;margin:4px 0;line-height:1.45}
  .pos-well .pw-bullets li::before{content:'—';position:absolute;left:0;color:var(--faint)}
  .pos-well .pw-arc{display:flex;flex-direction:column;gap:7px;margin:8px 0}
  .pos-well .pw-arc-beat{border:1px solid var(--line);border-radius:9px;padding:9px 11px;background:var(--panel2)}
  .pos-well .pw-arc-beat .pab-label{font-size:10.5px;font-weight:800;letter-spacing:.08em;
    text-transform:uppercase;color:var(--accent);margin-bottom:3px}
  .pos-well .pw-arc-beat .pab-hook{font-weight:600;font-size:13px;color:var(--ink);margin-bottom:2px}
  .pos-well .pw-arc-beat .pab-msg{font-size:12.5px;color:var(--dim);line-height:1.45}
  .pos-well .pw-dont{font-size:12.5px;color:var(--dim);line-height:1.5}
  /* approve-with-feedback action zone — used on positioning-lock + all approve cards */
  /* CTA TUNING: reduced so buttons are proportional, not dominant */
  .awf-actions{display:flex;flex-direction:column;gap:9px;border-top:1px solid var(--line);padding-top:12px;margin-top:10px}
  .awf-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
  .awf-actions button.go{padding:6px 14px;font-size:13px}
  .awf-actions button.ghost{padding:6px 12px;font-size:13px}
  .awf-revise{display:flex;flex-direction:column;gap:7px;margin-top:2px}
  .awf-revise textarea{min-height:54px;resize:vertical;font-size:13.5px}
  .awf-revise-row{display:flex;gap:8px;align-items:center}
  /* approve-with-note: optional note textarea that ships alongside the approval tap */
  .awn-note-row{display:flex;flex-direction:column;gap:4px;margin-bottom:4px}
  .awn-note{width:100%;min-height:44px;resize:vertical;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:8px;padding:8px 10px;font:inherit;font-size:13px;
    line-height:1.45;transition:border-color .15s}
  .awn-note:focus{outline:none;border-color:var(--accent)}
  .awn-note::placeholder{color:var(--faint);font-style:italic}

  .gate{position:fixed;inset:0;background:var(--bg);display:none;align-items:center;justify-content:center;z-index:20;padding:20px}
  .gatecard{max-width:380px;width:100%;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;text-align:center}
  .glogo{font-weight:650;font-size:20px;margin-bottom:10px}
  .gatemsg{color:var(--dim);font-size:13.5px;margin-bottom:14px;line-height:1.5}
  .gate input{width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:12px;font:inherit;font-size:16px;margin-bottom:10px}
  .gatehelp{color:var(--faint);font-size:12px;margin-top:13px}

  /* fluttering-birds wordmark */
  .logo-birds{display:flex;align-items:center;gap:5px;margin-left:5px}
  .logo-bird{width:14px;height:10px;color:var(--accentDeep);opacity:.65;flex:none}
  .logo-bird:nth-child(1){animation:birdflap 3.4s ease-in-out infinite;animation-delay:0s}
  .logo-bird:nth-child(2){animation:birdflap 3.4s ease-in-out infinite;animation-delay:.6s;opacity:.45}
  .logo-bird:nth-child(3){animation:birdflap 3.4s ease-in-out infinite;animation-delay:1.1s;opacity:.3}
  @keyframes birdflap{
    0%,100%{transform:translateY(0) rotate(0deg)}
    30%{transform:translateY(-2px) rotate(-6deg)}
    60%{transform:translateY(1px) rotate(3deg)}}

  /* static chirp row */
  .chirp-static-row{margin:0 4px 14px}
  .chirp-static-btn{display:inline-flex;align-items:center;gap:7px;background:none;
    border:1px solid color-mix(in srgb,var(--accentDeep) 40%,var(--line));
    color:var(--dim);font-family:'League Spartan',sans-serif;font-size:12px;font-weight:700;
    letter-spacing:.04em;padding:5px 13px;border-radius:20px;cursor:pointer;transition:.15s}
  .chirp-static-btn:hover{color:var(--accent);border-color:var(--accentDeep);
    background:color-mix(in srgb,var(--accentDeep) 8%,transparent)}
  .chirp-static-btn svg{width:14px;height:14px;flex:none;color:var(--accentDeep)}

  /* topic chips */
  .topic-chip{display:inline-flex;align-items:center;font-size:10px;font-weight:700;padding:2px 8px;
    border-radius:20px;letter-spacing:.05em;text-transform:uppercase;font-family:'League Spartan',sans-serif;
    white-space:nowrap;flex-shrink:0}
  .topic-chip.positioning{background:var(--chip-pos-bg);color:var(--chip-pos)}
  .topic-chip.marketing{background:var(--chip-mktg-bg);color:var(--chip-mktg)}
  .topic-chip.creative{background:var(--chip-creative-bg);color:var(--chip-creative)}
  .topic-chip.brand{background:var(--chip-brand-bg);color:var(--chip-brand)}
  .topic-chip.build{background:var(--chip-build-bg);color:var(--chip-build)}
  .topic-chip.console{background:var(--chip-console-bg);color:var(--chip-console)}

  /* card title row (redesign style) */
  .card-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
  .card-title{font-weight:700;font-family:'League Spartan',sans-serif;font-size:18px;flex:1;min-width:0;letter-spacing:-0.01em;line-height:1.2}
  .kind-tag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--panel2);
    white-space:nowrap;flex-shrink:0;font-family:'League Spartan',sans-serif;letter-spacing:.04em}
  .kind-tag.pick{color:var(--accent)}.kind-tag.compare{color:var(--info)}.kind-tag.review{color:var(--warm)}
  .kind-tag.lock{color:var(--gate)}.kind-tag.approve{color:var(--gate)}
  .card-series{font-size:11px;color:var(--faint);margin-top:-3px;margin-bottom:6px;font-style:italic}
  .card-detail{color:var(--dim);font-size:15px;margin-bottom:12px;font-family:'Arimo',sans-serif}

  /* inline context block (legacy, kept for backward compat) */
  .ctx-block{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:11px 13px;margin-bottom:12px}
  .ctx-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);
    font-family:'League Spartan',sans-serif;margin-bottom:6px;font-weight:700}
  .ctx-spine{border-left:3px solid var(--accentDeep);padding-left:10px;font-size:13.5px;font-weight:500;
    color:var(--ink);line-height:1.6;margin-bottom:10px;white-space:pre-wrap;word-break:break-word}
  .ctx-items{list-style:none;padding:0;margin:0}
  .ctx-items li{font-size:13px;color:var(--dim);padding:3px 0 3px 16px;position:relative}
  .ctx-items li span{position:absolute;left:0;color:var(--faint)}
  .ctx-sub-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);
    font-family:'League Spartan',sans-serif;margin-bottom:5px;font-weight:700}
  /* bounded scroll context box — renders d.expand.context inline on every pending card */
  .ctx-scroll{background:var(--bg);border:1px solid var(--line);border-radius:9px;
    padding:13px 15px;margin-bottom:14px;
    max-height:260px;overflow-y:auto;scrollbar-width:thin;
    font-size:15px;line-height:1.65;color:var(--ink);
    white-space:pre-wrap;word-break:break-word;
    border-left:3px solid color-mix(in srgb,var(--accentDeep) 50%,var(--line))}

  /* answer-next strip */
  .answer-next-strip{margin-bottom:16px}
  .answer-next-label{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;
    color:var(--accentDeep);font-family:'League Spartan',sans-serif;margin-bottom:8px;
    display:flex;align-items:center;gap:8px}
  .answer-next-label::after{content:'';flex:1;height:1px;background:color-mix(in srgb,var(--accentDeep) 30%,var(--line))}
  .card.answer-next-card{border-top:2px solid var(--accentDeep)}

  /* tidy callout */
  .tidy-callout{display:flex;align-items:center;gap:12px;
    background:color-mix(in srgb,var(--accentDeep) 9%,var(--panel));
    border:1px solid color-mix(in srgb,var(--accentDeep) 28%,var(--line));border-radius:12px;
    padding:11px 14px;margin-bottom:12px;flex-wrap:wrap}
  .tidy-callout .tc-msg{flex:1;font-size:13.5px;color:var(--dim);min-width:160px}
  .tidy-callout .tc-msg b{color:var(--accentDeep);font-weight:700}
  .tidy-callout .tc-btns{display:flex;gap:8px;flex-shrink:0}
  .tidy-callout.hidden{display:none}

  /* edit button on answered cards (kept for backward compat, may still exist in DOM) */
  button.edit-btn{background:none;border:1px solid var(--line);color:var(--faint);
    padding:3px 10px;font-size:11px;border-radius:8px;font-family:'League Spartan',sans-serif;
    font-weight:700;letter-spacing:.03em;cursor:pointer;transition:.15s;flex:none}
  button.edit-btn:hover{color:var(--accent);border-color:var(--accent);transform:none;filter:none}

  /* undo button -- small, on answered cards and the archive list */
  button.undo-btn-sm{background:none;border:1px solid color-mix(in srgb,var(--warm) 45%,var(--line));
    color:var(--warm);padding:3px 10px;font-size:11px;border-radius:8px;
    font-family:'League Spartan',sans-serif;font-weight:700;letter-spacing:.03em;
    cursor:pointer;transition:.15s;flex:none}
  button.undo-btn-sm:hover{background:color-mix(in srgb,var(--warm) 14%,var(--panel2));
    border-color:var(--warm);transform:none;filter:none}
  button.undo-btn-sm:disabled{opacity:.5;cursor:not-allowed}

  /* undo-strip -- inline banner shown right after a fresh submit (clears after 30s or on undo) */
  .undo-strip{display:flex;align-items:center;gap:10px;margin-top:10px;
    padding:8px 12px;border-radius:9px;
    background:color-mix(in srgb,var(--warm) 10%,var(--panel2));
    border:1px solid color-mix(in srgb,var(--warm) 32%,var(--line))}
  .undo-strip-msg{font-size:13px;color:var(--dim);font-family:'Arimo',sans-serif;flex:1}
  /* prominent Undo button inside the strip */
  button.undo-btn{background:color-mix(in srgb,var(--warm) 18%,var(--panel2));
    border:1.5px solid var(--warm);color:var(--warm);
    padding:5px 15px;font-size:13px;border-radius:9px;
    font-family:'League Spartan',sans-serif;font-weight:700;letter-spacing:.03em;
    cursor:pointer;transition:.15s;flex:none;white-space:nowrap}
  button.undo-btn:hover{background:color-mix(in srgb,var(--warm) 28%,var(--panel2));transform:none;filter:none}
  button.undo-btn:disabled{opacity:.5;cursor:not-allowed}

  /* answered-done card: not fully faded -- Undo button needs to be discoverable */
  .card.answered-done{opacity:.72}
  .card.answered-done:hover{opacity:.95}

  .answered-header-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}
  .answered-opts{display:grid;gap:6px;margin:8px 0}
  .opt-ans{border:1px solid var(--line);border-radius:10px;padding:9px 13px;color:var(--faint);
    font-size:14px;font-weight:500;display:flex;align-items:center;gap:9px}
  .opt-ans.sel{color:var(--ink);font-weight:700;border-color:var(--accentDeep);
    background:color-mix(in srgb,var(--accentDeep) 11%,var(--panel2))}
  .opt-ans .chk{color:var(--accentDeep);font-weight:800;flex-shrink:0}

  /* locked stages row (minimizable) */
  .locked-stages-row{border:1px dashed color-mix(in srgb,var(--gate) 42%,var(--line));border-radius:12px;
    overflow:hidden;margin-bottom:8px}
  .locked-stages-summary{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;
    background:color-mix(in srgb,var(--gate) 5%,var(--panel));list-style:none;user-select:none}
  .locked-stages-summary::-webkit-details-marker{display:none}
  .lsr-icon{font-size:14px;color:var(--gate)}
  .lsr-label{font-size:13px;color:var(--gate);font-weight:700;font-family:'League Spartan',sans-serif;letter-spacing:.02em;flex:1}
  .lsr-hint{font-size:11px;color:var(--faint);font-family:'Arimo',sans-serif}
  .lsr-caret{font-size:11px;color:var(--faint)}
  .locked-stages-body{padding:10px 14px 14px;border-top:1px dashed color-mix(in srgb,var(--gate) 28%,var(--line))}
  .locked-stage-preview{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--line)}
  .locked-stage-preview:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
  .lsp-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
  .lsp-num{width:22px;height:22px;border-radius:6px;background:var(--panel2);display:grid;place-items:center;
    font-size:10px;font-weight:800;color:var(--gate);flex:none;font-family:'League Spartan',sans-serif}
  .lsp-title{font-size:12.5px;font-weight:700;color:var(--faint);font-family:'League Spartan',sans-serif}
  .lsp-lock{font-size:10px;color:var(--gate);background:color-mix(in srgb,var(--gate) 14%,var(--panel2));
    padding:1px 8px;border-radius:20px;font-weight:700;font-family:'League Spartan',sans-serif}
  .lsp-items{display:flex;flex-direction:column;gap:4px}
  .lsp-item{font-size:12px;color:var(--faint);padding:4px 0;border-bottom:1px solid var(--line)}
  .lsp-item:last-child{border-bottom:none}

  /* entity sub-section headers inside Decisions */
  .entity-section{margin-bottom:4px}
  .entity-section-hdr{display:flex;align-items:center;gap:10px;margin:20px 4px 11px;
    padding-bottom:7px;border-bottom:2px solid color-mix(in srgb,var(--ehdr-color,var(--accent)) 35%,var(--line))}
  .entity-section-hdr:first-child{margin-top:6px}
  .entity-section-label{font-family:'League Spartan',sans-serif;font-size:12px;font-weight:800;
    letter-spacing:.1em;text-transform:uppercase;color:var(--ehdr-color,var(--accent))}
  .entity-section-count{font-size:11px;color:var(--faint);font-weight:600;font-family:'Arimo',sans-serif;
    background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:1px 9px;letter-spacing:.02em}
  .entity-section-empty{font-size:13px;color:var(--faint);font-style:italic;padding:8px 4px 12px;
    font-family:'Arimo',sans-serif}

  /* entity filter row */
  .entity-filter-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:14px;padding:0 2px}
  .entity-filter-chip{font-size:11px;font-weight:700;padding:4px 13px;border-radius:20px;border:1.5px solid var(--line);
    background:var(--panel2);color:var(--dim);cursor:pointer;transition:.12s;font-family:'League Spartan',sans-serif;
    letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
  .entity-filter-chip:hover{border-color:var(--ef-color,var(--dim));color:var(--ef-color,var(--dim))}
  .entity-filter-chip.active{border-color:var(--ef-color,var(--accent));color:var(--ef-color,var(--accent));
    background:color-mix(in srgb,var(--ef-color,var(--accent)) 13%,var(--panel2))}
  .entity-filter-chip.ef-all{--ef-color:var(--dim)}
  .entity-filter-chip.ef-wren{--ef-color:var(--wren-color)}
  .entity-filter-chip.ef-trailbuildr{--ef-color:var(--trailbuildr-color)}
  .entity-filter-chip.ef-theline{--ef-color:var(--theline-color)}

  /* entity label chip (inside decision cards) */
  .entity-chip{display:inline-flex;align-items:center;font-size:10px;font-weight:800;padding:2px 9px;
    border-radius:20px;letter-spacing:.05em;text-transform:uppercase;font-family:'League Spartan',sans-serif;
    white-space:nowrap;flex-shrink:0;border:1px solid transparent}
  .entity-chip.ec-wren{background:color-mix(in srgb,var(--wren-color) 16%,var(--panel2));color:var(--wren-color);border-color:color-mix(in srgb,var(--wren-color) 30%,var(--line))}
  .entity-chip.ec-trailbuildr{background:color-mix(in srgb,var(--trailbuildr-color) 16%,var(--panel2));color:var(--trailbuildr-color);border-color:color-mix(in srgb,var(--trailbuildr-color) 30%,var(--line))}
  .entity-chip.ec-theline{background:color-mix(in srgb,var(--theline-color) 16%,var(--panel2));color:var(--theline-color);border-color:color-mix(in srgb,var(--theline-color) 30%,var(--line))}

  /* action-type tag (right side of card header) */
  .action-tag{font-size:10px;font-weight:800;padding:2px 9px;border-radius:20px;background:var(--panel2);
    white-space:nowrap;flex-shrink:0;font-family:'League Spartan',sans-serif;letter-spacing:.05em;
    margin-left:auto;border:1px solid var(--line);color:var(--faint)}

  /* card redesign: colored left edge */
  .card.entity-edged{border-left:4px solid var(--entity-edge,var(--line))}

  /* V2 entity edge -- driven by data-entity attribute on card element */
  [data-entity="wren"]        {--entity-edge:var(--wren-color)}
  [data-entity="trailbuildr"] {--entity-edge:var(--trailbuildr-color)}
  [data-entity="theline"]     {--entity-edge:var(--theline-color)}

  /* three-lane entity section inside decisions */
  .entity-lane{border:1px solid var(--line);border-top:3px solid var(--el-color,var(--accent));
    border-radius:13px;overflow:hidden;background:var(--panel);margin-bottom:18px}
  .entity-lane-hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;
    background:color-mix(in srgb,var(--el-color,var(--accent)) 7%,var(--panel));
    cursor:pointer;user-select:none;list-style:none}
  .entity-lane-hdr::-webkit-details-marker{display:none}
  .entity-lane-hdr::before{content:'▸';color:var(--faint);font-size:11px;flex:none;transition:.15s}
  .entity-lane[open] .entity-lane-hdr::before{content:'▾'}
  .entity-lane-label{font-family:'League Spartan',sans-serif;font-size:12px;font-weight:800;
    letter-spacing:.09em;text-transform:uppercase;color:var(--el-color,var(--accent));flex:none}
  .entity-lane-count{font-size:11px;color:var(--faint);font-weight:600;font-family:'Arimo',sans-serif;
    background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:1px 9px;margin-left:4px}
  .entity-lane-empty{font-size:13px;color:var(--faint);font-style:italic;padding:10px 14px 12px;font-family:'Arimo',sans-serif}
  .entity-lane-body{padding:10px 14px 14px}

  /* archive expander */
  .archive-expander{border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:16px}
  .archive-expander summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:9px;
    padding:11px 14px;background:var(--panel2)}
  .archive-expander summary::-webkit-details-marker{display:none}
  .archive-expander summary::before{content:'▸';color:var(--faint);font-size:10px}
  .archive-expander[open] summary::before{content:'▾'}
  .archive-expander .ae-title{font-size:12px;font-weight:700;color:var(--faint);letter-spacing:.06em;
    text-transform:uppercase;font-family:'League Spartan',sans-serif}
  .archive-expander .ae-count{font-size:11px;color:var(--faint);margin-left:auto}
  .archive-body{padding:8px 14px 14px}
  .archived-card{border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin-bottom:6px;
    background:var(--panel);opacity:.6}
  .archived-card:last-child{margin-bottom:0}
  .archived-card .ac-title{font-size:13.5px;font-weight:600;color:var(--ink);font-family:'League Spartan',sans-serif}
  .archived-card .ac-answer{font-size:12px;color:var(--faint);margin-top:3px}
  .archived-card .ac-badge{font-size:10px;font-weight:700;color:var(--accent);margin-left:auto;
    background:color-mix(in srgb,var(--accent) 12%,var(--panel2));padding:2px 8px;border-radius:20px}

  /* health rows (The work) */
  .work-rollup{font-size:13px;color:var(--dim);padding:7px 4px 10px;font-family:'Arimo',sans-serif;line-height:1.55}
  .work-rollup b{color:var(--ink);font-weight:600}
  /* health rows (workstreams with health data) */
  .health-row{background:var(--panel);border:1px solid var(--line);border-radius:11px;margin-bottom:7px;overflow:hidden}
  .health-row.needs-you{border-left:3px solid var(--amber)}
  .health-row.blocked{border-left:3px solid var(--red)}
  .health-row.on-track{border-left:3px solid var(--green)}
  .health-row.done-row{border-left:3px solid var(--faint);opacity:.6}
  .health-row-main{display:flex;flex-direction:column;padding:10px 13px;gap:0}
  .health-row-top{display:flex;align-items:center;gap:10px}
  .health-dot{width:9px;height:9px;border-radius:50%;flex:none}
  .health-dot.green{background:var(--green)}
  .health-dot.amber{background:var(--amber)}
  .health-dot.red{background:var(--red)}
  .health-dot.grey{background:var(--faint)}
  .hr-main{flex:1;min-width:0}
  .hr-name{font-weight:700;font-family:'League Spartan',sans-serif;font-size:14px;color:var(--ink)}
  .hr-next{font-size:12.5px;color:var(--dim);margin-top:2px;line-height:1.35;font-family:'Arimo',sans-serif}
  .hr-steps-rollup{font-size:11px;color:var(--faint);margin-top:3px;font-family:'Arimo',sans-serif;font-style:italic}
  .hr-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex:none;min-width:80px}
  .hr-lead{font-size:11px;font-weight:700;color:var(--accent);font-family:'League Spartan',sans-serif;text-align:right}
  .hr-progress{font-size:10.5px;color:var(--faint);font-family:'Arimo',sans-serif;white-space:nowrap}
  .hr-bar{width:60px;height:3px;background:var(--line);border-radius:3px;overflow:hidden;margin-top:2px}
  .hr-bar>span{display:block;height:100%;border-radius:3px}
  .hr-bar>span.green{background:var(--green)}
  .hr-bar>span.amber{background:var(--amber)}
  .hr-bar>span.red{background:var(--red)}
  .hr-bar>span.grey{background:var(--faint)}
  .hr-obj{font-size:10px;font-weight:700;padding:1px 7px;border-radius:20px;background:var(--panel2);
    color:var(--faint);font-family:'League Spartan',sans-serif;letter-spacing:.03em;white-space:nowrap;
    text-align:right;margin-top:1px}
  /* action flag: tappable "needs you"/"blocked" link or quiet "preparing" text */
  .hr-action-wrap{text-align:right}
  .hr-action-flag--link{font-size:11px;font-weight:700;font-family:'League Spartan',sans-serif;
    letter-spacing:.05em;text-transform:uppercase;color:var(--amber);text-decoration:underline;
    text-underline-offset:2px;cursor:pointer;white-space:nowrap}
  .hr-action-flag--link:hover{color:var(--warm)}
  .health-row.blocked .hr-action-flag--link{color:var(--red)}
  .health-row.blocked .hr-action-flag--link:hover{color:var(--gate)}
  .hr-action-flag--quiet{font-size:10.5px;color:var(--faint);font-family:'Arimo',sans-serif;
    font-style:italic;white-space:nowrap}
  /* step-detail toggle inside health rows */
  .ws-steps-detail{border-top:1px solid var(--line);margin-top:8px;padding-top:6px}
  .ws-steps-detail-toggle{cursor:pointer;list-style:none;font-size:11.5px;font-weight:700;color:var(--accentDeep);
    font-family:'League Spartan',sans-serif;letter-spacing:.04em;display:flex;align-items:center;gap:5px;
    text-transform:uppercase}
  .ws-steps-detail-toggle::-webkit-details-marker{display:none}
  .ws-steps-detail-toggle::before{content:'Steps ▸';color:var(--faint)}
  .ws-steps-detail[open] .ws-steps-detail-toggle::before{content:'Steps ▾'}
  .ws-steps-detail-toggle{list-style:none}
  .ws-steps-detail-body{padding-top:8px}
  /* step buckets -- grouped view of done/active/planned */
  .ws-step-rollup{font-size:12px;color:var(--faint);font-style:italic;margin-bottom:8px;font-family:'Arimo',sans-serif}
  .ws-bucket{margin-bottom:8px}
  .ws-bucket:last-child{margin-bottom:0}
  .ws-bucket-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:800;
    font-family:'League Spartan',sans-serif;margin-bottom:4px;padding:2px 0}
  .ws-bucket-active{color:var(--warm)}
  .ws-bucket-planned{color:var(--faint)}
  .ws-bucket-done{color:var(--accent)}
  .ws-bucket-steps{padding-left:4px}
  /* collapsible done bucket */
  details.ws-bucket-collapsible{margin-bottom:8px}
  details.ws-bucket-collapsible:last-child{margin-bottom:0}
  .ws-bucket-summary{cursor:pointer;list-style:none;display:block}
  .ws-bucket-summary::-webkit-details-marker{display:none}

  /* from wren: digest + now + recent */
  .digest-line{font-size:14px;color:var(--dim);
    background:color-mix(in srgb,var(--accentDeep) 7%,var(--panel));
    border:1px solid color-mix(in srgb,var(--accentDeep) 20%,var(--line));border-radius:10px;
    padding:9px 13px;margin-bottom:12px;font-family:'Arimo',sans-serif}
  .digest-line b{color:var(--accentDeep);font-weight:700}
  .now-bar{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--line);
    border-radius:10px;padding:10px 13px;margin-bottom:10px}
  .now-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex:none;animation:pulse 2s infinite}
  .now-dot.idle{background:var(--faint);animation:none}
  .now-text{font-size:13.5px;color:var(--ink);font-family:'Arimo',sans-serif;flex:1}
  .now-text .now-label{font-weight:700;color:var(--green);font-family:'League Spartan',sans-serif;
    font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-right:6px}
  .now-text .now-label.idle-lbl{color:var(--faint)}
  .now-ago{font-size:11px;color:var(--faint);flex:none}
  .recent-list{display:flex;flex-direction:column;gap:6px}
  .recent-item{display:flex;align-items:baseline;gap:10px;padding:8px 12px;
    background:var(--panel);border:1px solid var(--line);border-radius:9px}
  .ri-tag{font-size:10px;font-weight:700;font-family:'League Spartan',sans-serif;
    padding:2px 7px;border-radius:20px;flex:none;white-space:nowrap}
  .ri-tag.shipped{background:color-mix(in srgb,var(--green) 16%,var(--panel2));color:var(--green)}
  .ri-tag.parked{background:color-mix(in srgb,var(--amber) 16%,var(--panel2));color:var(--amber)}
  .ri-tag.decided{background:color-mix(in srgb,var(--accent) 16%,var(--panel2));color:var(--accent)}
  .ri-body{flex:1;min-width:0}
  .ri-title{font-size:13.5px;color:var(--ink);font-family:'Arimo',sans-serif;font-weight:600}
  .ri-artifact{font-size:11.5px;color:var(--accentDeep);font-family:'Arimo',sans-serif;margin-top:1px}
  .ri-date{font-size:11px;color:var(--faint);flex:none;white-space:nowrap}

  /* team section header */
  .team-section-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
  .team-section-header h3{font-family:'League Spartan',sans-serif;font-size:14px;letter-spacing:.08em;
    text-transform:uppercase;color:var(--dim);font-weight:700;margin:0}
  .show-roles-btn{margin-left:auto;padding:5px 12px;font-size:12px;background:var(--panel2);
    border:1px solid var(--line);border-radius:8px;color:var(--accent);cursor:pointer;
    font-family:'League Spartan',sans-serif;font-weight:700}
  /* activity legend */
  .org-activity-legend{font-size:11px;color:var(--faint);font-family:'Arimo',sans-serif;
    margin-bottom:12px;padding:6px 10px;background:var(--panel2);border:1px solid var(--line);
    border-radius:8px;line-height:1.5}
  .org-activity-legend b{color:var(--dim);font-weight:600}
  /* quiet meter state */
  .on-meter.quiet{background:color-mix(in srgb,var(--line) 55%,transparent)}

  /* chirp modal */
  .chirp-modal-overlay{position:fixed;inset:0;background:rgba(7,16,28,.72);z-index:50;
    display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
  .chirp-modal-overlay.open{display:flex}
  .chirp-modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;
    padding:24px;width:100%;max-width:440px;box-shadow:0 24px 56px rgba(0,0,0,.55)}
  .chirp-modal-title{font-family:'League Spartan',sans-serif;font-size:17px;font-weight:700;
    color:var(--ink);margin-bottom:4px;display:flex;align-items:center;gap:9px}
  .chirp-modal-title svg{width:18px;height:18px;color:var(--accentDeep);flex:none}
  .chirp-modal-sub{font-size:13px;color:var(--faint);font-family:'Arimo',sans-serif;margin-bottom:14px;line-height:1.5}
  .chirp-modal textarea{width:100%;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:10px;padding:11px 13px;
    font-family:'Arimo',sans-serif;font-size:14px;resize:vertical;min-height:90px;
    line-height:1.5;outline:none;transition:.15s}
  .chirp-modal textarea:focus{border-color:var(--accentDeep)}
  .chirp-modal-note{font-size:12px;color:var(--faint);font-family:'Arimo',sans-serif;
    font-style:italic;margin:8px 0 14px;line-height:1.45}
  .chirp-modal-actions{display:flex;gap:8px;justify-content:flex-end}

  /* team section — rendered from bus.org; hidden entirely when absent */
  .team-top{display:flex;align-items:baseline;gap:10px;padding:10px 12px 11px;
    background:var(--panel2);border:1px solid var(--line);border-radius:10px;margin-bottom:6px}
  .team-top .tn{font-weight:700;font-size:14px;color:var(--ink)}
  .team-top .tt{font-size:12px;color:var(--faint);margin-left:2px}
  .team-lead-row{display:flex;align-items:baseline;gap:10px;padding:9px 12px 10px;
    background:color-mix(in srgb,var(--accent) 9%,var(--panel2));
    border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));border-radius:10px;margin-bottom:10px}
  .team-lead-row .tn{font-weight:700;font-size:14px;color:var(--ink)}
  .team-lead-row .tt{font-size:12px;color:var(--faint);margin-left:2px}
  .team-group{margin-bottom:10px}
  .team-group-label{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:800;
    color:var(--dim);margin:0 2px 6px;display:flex;align-items:center;gap:7px}
  .team-group-label::after{content:'';flex:1;height:1px;background:var(--line)}
  .team-members{display:flex;flex-direction:column;gap:5px}
  .team-member{display:flex;align-items:baseline;gap:8px;padding:6px 10px;
    background:var(--panel2);border:1px solid var(--line);border-radius:8px}
  .team-member .mn{font-weight:600;font-size:13.5px;color:var(--ink)}
  .team-member .mt{font-size:12px;color:var(--faint)}

  /* held cards -- muted, clearly parked */
  .held-card{opacity:.6;border-style:dashed!important}
  .held-tag{font-size:10px;font-weight:800;padding:2px 9px;border-radius:20px;
    font-family:'League Spartan',sans-serif;letter-spacing:.05em;white-space:nowrap;flex-shrink:0;margin-left:auto}
  .held-tag-ren{background:color-mix(in srgb,var(--gate) 14%,var(--panel2));color:var(--gate);border:1px solid color-mix(in srgb,var(--gate) 30%,var(--line))}
  .held-tag-you{background:color-mix(in srgb,var(--warm) 14%,var(--panel2));color:var(--warm);border:1px solid color-mix(in srgb,var(--warm) 30%,var(--line))}
  .held-reason{font-size:12.5px;color:var(--faint);font-style:italic;margin-top:6px;font-family:'Arimo',sans-serif;line-height:1.4}
  /* hold button -- subdued, never loud */
  button.held-action-btn{font-size:12px;padding:6px 11px;color:var(--faint);border-color:var(--line)}
  button.held-action-btn:hover{color:var(--gate);border-color:var(--gate);transform:none}

  /* attachment thumbnails + list */
  .att-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
  .att-thumb{display:inline-block;border-radius:8px;overflow:hidden;border:1px solid var(--line);flex:none}
  .att-thumb img{width:72px;height:72px;object-fit:cover;display:block}

  /* chirp modal: attach row */
  .chirp-attach-row{display:flex;align-items:center;gap:8px;margin:6px 0 10px}
  .chirp-attach-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:5px 11px;color:var(--dim);border-color:var(--line)}
  .chirp-attach-btn svg{width:13px;height:13px;flex:none;color:var(--accentDeep)}
  .chirp-attach-btn:hover{color:var(--accent);border-color:var(--accentDeep);transform:none}
  .chirp-file-badge{font-size:11.5px;color:var(--accent);font-family:'Arimo',sans-serif;
    background:color-mix(in srgb,var(--accent) 12%,var(--panel2));
    border:1px solid color-mix(in srgb,var(--accent) 28%,var(--line));
    border-radius:20px;padding:2px 10px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* update-available banner -- subtle pill anchored at the top of the page */
  .update-banner{
    position:fixed;top:0;left:0;right:0;z-index:9999;
    display:flex;align-items:center;justify-content:center;gap:10px;
    padding:9px 16px;
    background:color-mix(in srgb,var(--accentDeep) 92%,var(--bg));
    color:var(--accentInk);
    font-family:'Arimo',sans-serif;font-size:13.5px;font-weight:500;
    border-bottom:1.5px solid color-mix(in srgb,var(--accent) 55%,transparent);
    box-shadow:0 2px 10px rgba(0,0,0,.35);
    animation:banner-slide-in .22s ease-out both;
  }
  @keyframes banner-slide-in{from{transform:translateY(-100%)}to{transform:translateY(0)}}
  .update-banner-msg{flex:1;text-align:center}
  .update-banner-tap{
    cursor:pointer;font-weight:700;
    text-decoration:underline;text-underline-offset:2px;
    white-space:nowrap;
  }
  .update-banner-dismiss{
    cursor:pointer;opacity:.65;font-size:15px;line-height:1;
    padding:2px 5px;border-radius:4px;
    background:none;border:none;color:inherit;
    transition:opacity .15s;
  }
  .update-banner-dismiss:hover{opacity:1}

  /* ---- Part A: workstream sorting + Next line ---- */
  .hr-next-label{font-size:12px;color:var(--dim);margin-top:3px;font-family:'Arimo',sans-serif}
  .hr-next-label .hr-next-step{color:var(--ink);font-weight:600}
  .hr-next-link{color:var(--accentDeep);font-size:11px;text-decoration:none;font-weight:700;margin-left:4px}
  .hr-next-link:hover{text-decoration:underline}
  .hr-note{font-size:12.5px;color:var(--dim);margin-top:2px;line-height:1.35;font-family:'Arimo',sans-serif}
  /* done streams group -- collapsed by default */
  .ws-done-group{border:1px dashed var(--line);border-radius:11px;margin-top:8px;overflow:hidden}
  .ws-done-group-summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;
    padding:9px 13px;font-size:12px;font-weight:700;color:var(--faint);font-family:'League Spartan',sans-serif;
    letter-spacing:.05em;text-transform:uppercase;background:var(--panel)}
  .ws-done-group-summary::-webkit-details-marker{display:none}
  .ws-done-group-summary::before{content:'▸';font-size:10px;color:var(--faint)}
  .ws-done-group[open] .ws-done-group-summary::before{content:'▾'}
  .ws-done-group-body{padding:8px 0 4px}
  /* flash highlight for scroll-to-decision */
  @keyframes hl-flash{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 3px var(--accentDeep)}}
  .hl-flash{animation:hl-flash .9s ease-out}

  /* ---- Part B: code-mirror activity block ---- */
  .fw-mirror-wrap{margin-bottom:12px}
  .fw-mirror-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;
    color:var(--faint);font-family:'League Spartan',sans-serif;margin-bottom:6px}
  .code-mirror{font:12px/1.6 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
    background:var(--bg);border:1px solid var(--line);border-radius:10px;
    padding:10px 13px;max-height:200px;overflow-y:auto;scrollbar-width:thin}
  .code-mirror.cm-empty::before{content:attr(class);display:none}
  .code-mirror.cm-empty{color:var(--faint);font-style:italic}
  .cm-line{padding:1px 0;white-space:pre-wrap;word-break:break-word;display:flex;gap:6px;align-items:baseline}
  .cm-ts{color:var(--faint);font-size:11px;flex:none;min-width:34px}
  .cm-kind{font-size:10.5px;font-weight:700;flex:none;opacity:.75}
  .cm-text{color:var(--dim);font-size:11.5px;flex:1}
  .cm-perm{color:var(--gate)}
  .cm-issue{color:var(--warm)}
  .cm-tool{color:var(--accent)}
  .cm-done{color:var(--green)}
  .cm-info{color:var(--faint)}
  .cm-health{opacity:.5}

  /* ---- Part C: chirp modal redesign + ack + history ---- */
  .chirp-modal-overlay{position:fixed;inset:0;background:rgba(7,16,28,.80);z-index:50;
    display:none;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(6px)}
  @media (min-width:560px){
    .chirp-modal-overlay{align-items:center;padding:20px}
  }
  .chirp-modal-overlay.open{display:flex}
  .chirp-modal{background:var(--panel);border:1px solid var(--line);
    border-radius:20px 20px 0 0;width:100%;max-width:520px;
    box-shadow:0 -8px 40px rgba(0,0,0,.55);padding:20px 20px 32px;
    border-top:3px solid var(--accentDeep)}
  @media (min-width:560px){
    .chirp-modal{border-radius:20px;border-top:3px solid var(--accentDeep);padding:24px}
  }
  .chirp-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
  .chirp-modal-icon{width:38px;height:38px;flex:none;border-radius:12px;
    background:color-mix(in srgb,var(--accentDeep) 18%,var(--panel2));
    display:flex;align-items:center;justify-content:center;
    border:1px solid color-mix(in srgb,var(--accentDeep) 35%,var(--line))}
  .chirp-modal-icon svg{width:20px;height:20px;color:var(--accentDeep)}
  .chirp-modal-title-text{display:flex;flex-direction:column;gap:2px}
  .chirp-modal-title{font-family:'League Spartan',sans-serif;font-size:17px;font-weight:700;color:var(--ink)}
  .chirp-modal-sub{font-size:12.5px;color:var(--faint);font-family:'Arimo',sans-serif;line-height:1.4}
  .chirp-modal textarea{width:100%;background:var(--bg);color:var(--ink);
    border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;
    font-family:'Arimo',sans-serif;font-size:14px;resize:vertical;min-height:96px;
    line-height:1.55;outline:none;transition:.15s;margin-bottom:0}
  .chirp-modal textarea:focus{border-color:var(--accentDeep);
    box-shadow:0 0 0 3px color-mix(in srgb,var(--accentDeep) 14%,transparent)}
  /* acknowledgment strip */
  .chirp-ack{font-size:13px;color:var(--accentDeep);font-family:'Arimo',sans-serif;
    font-weight:600;background:color-mix(in srgb,var(--accentDeep) 10%,var(--panel2));
    border:1px solid color-mix(in srgb,var(--accentDeep) 25%,var(--line));
    border-radius:9px;padding:8px 12px;margin-top:10px;line-height:1.4}
  /* chirp history (recent chirps list) */
  .chirp-history{margin-top:18px;border-top:1px solid var(--line);padding-top:14px;display:flex;flex-direction:column;gap:0}
  .chirp-history:empty{display:none}
  .ch-history-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;
    color:var(--faint);font-family:'League Spartan',sans-serif;margin-bottom:8px}
  .ch-item{padding:7px 0;border-bottom:1px solid var(--line)}
  .ch-item:last-child{border-bottom:none}
  .ch-item-row{display:flex;align-items:center;gap:8px}
  .ch-item-text{font-size:13px;color:var(--dim);font-family:'Arimo',sans-serif;flex:1;min-width:0;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .ch-status{font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;flex:none;
    font-family:'League Spartan',sans-serif;letter-spacing:.04em;text-transform:uppercase}
  .ch-new{background:color-mix(in srgb,var(--faint) 14%,var(--panel2));color:var(--faint)}
  .ch-seen{background:color-mix(in srgb,var(--accent) 14%,var(--panel2));color:var(--accent)}
  .ch-processing{background:color-mix(in srgb,var(--warm) 16%,var(--panel2));color:var(--warm)}
  .ch-done{background:color-mix(in srgb,var(--green) 14%,var(--panel2));color:var(--green)}
  .ch-item-note{font-size:12px;color:var(--accent);font-family:'Arimo',sans-serif;margin-top:3px;font-style:italic}
  .ch-item-ts{font-size:11px;color:var(--faint);font-family:'Arimo',sans-serif;margin-top:2px}

  /* ---- Part D: desktop breakpoints ---- */
  /* 900px+: wider layout, calmer spacing */
  @media (min-width:900px){
    main{max-width:920px;padding:24px 28px 90px}
    .card{padding:17px 18px}
    details.section>summary{padding:15px 20px}
    /* org chart: entities side by side horizontally on desktop */
    .org-entities{flex-direction:row;align-items:flex-start;gap:14px}
    .org-entity{flex:1 1 0;min-width:0}
    /* entity lane groups become 2-col grid inside each entity */
    .org-entity-groups{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px 12px 12px}
    /* chirp button more generous on desktop */
    .chirp-static-btn{padding:6px 16px;font-size:13px}
    /* health rows: slightly taller */
    .health-row-main{padding:11px 14px}
  }
  /* 1100px+: substantially wider, use the screen */
  @media (min-width:1100px){
    main{max-width:1160px;padding:28px 36px 100px}
    .card{padding:18px 20px}
    /* creative cards: two-column layout (mockup left, text+CTAs right) */
    .card.has-creative{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
    .card.has-creative .creative-col{grid-column:1}
    .card.has-creative .content-col{grid-column:2;display:flex;flex-direction:column;gap:14px}
    .card.has-creative .card-full-row{grid-column:1/-1}
  }
  /* 1440px+: widen to ~1300px reading area */
  @media (min-width:1440px){
    main{max-width:1300px;padding:32px 40px 100px}
    .card{padding:20px 24px}
    /* 1200px+: two-column main sections possible, even wider org */
    .org-entities{gap:18px}
    /* work + from-wren can sit side by side if both are open */
    .console-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
  }

  /* ---- Build S: held sub-list inside decisions ---- */
  .held-sub-expander{border:1px dashed color-mix(in srgb,var(--gate) 38%,var(--line));border-radius:11px;
    overflow:hidden;margin-top:10px}
  .held-sub-expander>summary{display:flex;align-items:center;gap:8px;padding:8px 13px;cursor:pointer;
    list-style:none;background:color-mix(in srgb,var(--gate) 5%,var(--panel))}
  .held-sub-expander>summary::-webkit-details-marker{display:none}
  .hse-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
    color:var(--gate);font-family:'League Spartan',sans-serif}
  .hse-count{font-size:11px;color:var(--faint);margin-left:auto;font-family:'Arimo',sans-serif}
  .held-sub-body{padding:8px 12px 12px;display:flex;flex-direction:column;gap:6px}
  .held-sub-card{background:var(--panel2);border:1px solid var(--line);border-radius:11px;
    padding:10px 13px;opacity:.7}

  /* ---- Build S: workstream entity groups ---- */
  .ws-entity-group{border:1px solid var(--line);border-top:3px solid var(--ws-entity-color,var(--accent));
    border-radius:13px;overflow:hidden;background:var(--panel);margin-bottom:14px}
  .ws-entity-group>summary.ws-entity-group-hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;
    background:color-mix(in srgb,var(--ws-entity-color,var(--accent)) 7%,var(--panel));
    cursor:pointer;user-select:none;list-style:none}
  .ws-entity-group>summary.ws-entity-group-hdr::-webkit-details-marker{display:none}
  .ws-entity-group>summary.ws-entity-group-hdr::before{content:'▸';color:var(--faint);font-size:11px;flex:none;transition:.15s}
  .ws-entity-group[open]>summary.ws-entity-group-hdr::before{content:'▾'}
  .ws-entity-label{font-family:'League Spartan',sans-serif;font-size:12px;font-weight:800;
    letter-spacing:.09em;text-transform:uppercase;color:var(--ws-entity-color,var(--accent));flex:none}
  .ws-entity-count{font-size:11px;color:var(--faint);font-weight:600;font-family:'Arimo',sans-serif;
    background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:1px 9px;margin-left:4px}
  .ws-entity-body{padding:10px 14px 14px}

  /* ---- Build S: ops board (From Ren) ---- */
  .ops-board{display:flex;flex-direction:column;gap:14px}
  .ops-section{display:flex;flex-direction:column;gap:6px}
  .ops-section-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;
    color:var(--faint);font-family:'League Spartan',sans-serif;margin-bottom:2px}
  .ops-running-list{display:flex;flex-direction:column;gap:5px}
  .ops-running-row{display:flex;align-items:flex-start;gap:8px;font-size:13px;
    background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:8px 11px}
  .ops-running-name{font-weight:600;font-family:'League Spartan',sans-serif;font-size:13px;flex:none}
  .ops-running-note{font-size:12.5px;color:var(--faint);font-family:'Arimo',sans-serif;
    margin-left:auto;text-align:right;line-height:1.35}
  .ops-now-row{display:flex;align-items:center;gap:10px;background:var(--panel2);
    border:1px solid var(--line);border-radius:10px;padding:10px 13px}
  .ops-now-label{font-weight:700;color:var(--green);font-family:'League Spartan',sans-serif;
    font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-right:4px}
  .ops-now-text{font-size:13.5px;color:var(--ink);font-family:'Arimo',sans-serif}
  .ops-shipped-row{display:flex;align-items:center;gap:8px;padding:5px 0;
    border-bottom:1px solid var(--line);font-size:13px}
  .ops-shipped-row:last-child{border-bottom:none}
  .ops-shipped-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex:none}
  .ops-shipped-what{flex:1;color:var(--dim);font-family:'Arimo',sans-serif}
  .ops-shipped-when{font-size:11.5px;color:var(--faint);flex:none;font-family:'Arimo',sans-serif}

  /* ---- Creative post preview: visual-first social card ---- */
  /* CARD CONTRACT: any approve decision with d.creative.imageUrl renders this.
     Visual order: meta bar → LARGE image → view-fullscreen button → caption → account row.
     The renderer (creativePostPreview in console.js) checks for d.creative before
     rendering so non-creative approve cards are not affected. */
  .creative-block{margin:0 0 18px;border:1px solid var(--line);border-radius:13px;overflow:hidden;background:var(--panel2)}
  /* meta bar above image */
  .creative-meta-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;
    border-bottom:1px solid var(--line);background:var(--panel2)}
  .creative-meta-platform{font-size:11px;font-weight:800;font-family:'League Spartan',sans-serif;
    letter-spacing:.07em;text-transform:uppercase;color:var(--chip-creative);
    background:var(--chip-creative-bg);padding:3px 10px;border-radius:20px;flex:none}
  .creative-meta-format{font-size:11px;color:var(--faint);font-family:'Arimo',sans-serif;margin-left:auto}
  /* the image: contained preview thumbnail, click to enlarge via lightbox */
  .creative-image-wrap{max-width:380px;max-height:480px;overflow:hidden;border-radius:10px;
    cursor:zoom-in;margin:0 auto}
  .creative-image-wrap img{width:100%;height:100%;object-fit:contain;display:block;background:var(--panel2)}
  /* view fullscreen bar below image */
  .creative-fullscreen-bar{display:flex;align-items:center;justify-content:center;
    padding:8px 14px;border-bottom:1px solid var(--line);background:var(--panel2)}
  .creative-fullscreen-btn{display:inline-flex;align-items:center;gap:7px;
    background:var(--accentDeep);color:var(--accentInk);font-weight:700;font-size:13px;
    border:none;border-radius:9px;padding:8px 18px;cursor:pointer;font-family:'League Spartan',sans-serif;
    letter-spacing:.03em;transition:.15s}
  .creative-fullscreen-btn:hover{filter:brightness(1.14);transform:translateY(-1px)}
  /* caption section */
  .creative-post-preview{padding:14px 16px}
  .creative-account-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
  .creative-account-avatar{width:30px;height:30px;border-radius:50%;
    background:color-mix(in srgb,var(--warm) 22%,var(--panel2));
    border:2px solid var(--warm);display:flex;align-items:center;justify-content:center;
    flex:none;font-size:12px;font-weight:800;color:var(--warm);font-family:'League Spartan',sans-serif}
  .creative-account-name{font-size:14px;font-weight:700;color:var(--ink);font-family:'Arimo',sans-serif}
  .creative-account-handle{font-size:12px;color:var(--faint);font-family:'Arimo',sans-serif}
  .creative-caption{font-size:15px;color:var(--ink);font-family:'Arimo',sans-serif;
    line-height:1.7;white-space:pre-wrap;word-break:break-word;
    background:var(--bg);border:1px solid var(--line);border-radius:9px;
    padding:12px 14px}
  /* error state when image fails to load */
  .creative-img-error{display:flex;align-items:center;justify-content:center;
    padding:36px;color:var(--faint);font-size:14px;font-family:'Arimo',sans-serif;
    font-style:italic;background:var(--bg);min-height:160px}

  /* ---- Lightbox overlay ---- */
  .lightbox-overlay{display:none;position:fixed;inset:0;z-index:9000;
    background:rgba(0,0,0,.92);align-items:center;justify-content:center;cursor:zoom-out}
  .lightbox-overlay.open{display:flex}
  .lightbox-overlay img{max-width:94vw;max-height:94vh;object-fit:contain;border-radius:6px;
    box-shadow:0 20px 80px rgba(0,0,0,.6)}
  .lightbox-close{position:fixed;top:18px;right:22px;background:rgba(255,255,255,.13);
    border:1px solid rgba(255,255,255,.2);border-radius:50%;width:38px;height:38px;
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    color:#fff;font-size:20px;font-weight:700;transition:.15s;z-index:9001}
  .lightbox-close:hover{background:rgba(255,255,255,.24)}

  /* ---- TYPED CARD SYSTEM (Pass 1: 2026-06-17h) ---- */

  /* ops topic chip */
  :root{
    --chip-ops-bg:color-mix(in srgb,var(--green) 15%,var(--panel2));
    --chip-ops:color-mix(in srgb,var(--green) 120%,#5cc48a);
  }
  .topic-chip.ops{background:var(--chip-ops-bg);color:var(--chip-ops)}

  /* card-type-tag: replaces old action-tag when cardType is set */
  .card-type-tag{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
    padding:2px 9px;border-radius:20px;
    background:var(--panel2);
    flex:none;white-space:nowrap;border:1px solid var(--line);
  }
  .card-type-tag.approve  {color:var(--green);border-color:color-mix(in srgb,var(--green) 30%,var(--line))}
  .card-type-tag.choose   {color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,var(--line))}
  .card-type-tag.compare  {color:var(--info);border-color:color-mix(in srgb,var(--info) 30%,var(--line))}
  .card-type-tag.strategy {color:var(--gate);border-color:color-mix(in srgb,var(--gate) 30%,var(--line))}
  .card-type-tag.rank     {color:var(--amber);border-color:color-mix(in srgb,var(--amber) 30%,var(--line))}
  .card-type-tag.creative {color:var(--warm);border-color:color-mix(in srgb,var(--warm) 30%,var(--line))}
  .card-type-tag.info     {color:var(--dim);border-color:var(--line)}
  .card-type-tag.walkthrough{color:var(--info);border-color:color-mix(in srgb,var(--info) 30%,var(--line))}

  /* owner chip + deadline chip + unlocks chip */
  .chip-owner{display:inline-flex;align-items:center;font-size:10px;font-weight:700;
    padding:2px 8px;border-radius:20px;background:var(--panel2);color:var(--faint);
    font-family:'League Spartan',sans-serif;letter-spacing:.04em;white-space:nowrap;flex:none}
  .chip-deadline{display:inline-flex;align-items:center;font-size:10px;font-weight:700;
    padding:2px 8px;border-radius:20px;
    background:color-mix(in srgb,var(--amber) 18%,var(--panel2));color:var(--amber);
    font-family:'League Spartan',sans-serif;letter-spacing:.04em;white-space:nowrap;flex:none}
  .chip-stage{display:inline-flex;align-items:center;font-size:10px;font-weight:700;
    padding:2px 8px;border-radius:20px;background:var(--panel2);color:var(--dim);
    font-family:'League Spartan',sans-serif;letter-spacing:.04em;white-space:nowrap;flex:none}
  .chip-unlocks{display:inline-flex;align-items:center;font-size:10px;font-weight:700;
    padding:2px 8px;border-radius:20px;
    background:color-mix(in srgb,var(--green) 13%,var(--panel2));color:var(--green);
    font-family:'League Spartan',sans-serif;letter-spacing:.04em;white-space:nowrap;flex:none}

  /* wrens-pick-pill */
  .wrens-pick-pill{
    display:inline-flex;align-items:center;
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:700;letter-spacing:.03em;
    background:var(--accentDeep);color:#ddeeff;
    padding:2px 9px;border-radius:20px;flex:none;white-space:nowrap;
  }

  /* field grid (TYPE 1/7/8) */
  .tc-field-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
    gap:6px 10px;
    background:var(--bg);border:1px solid var(--line);border-radius:10px;
    padding:11px 13px;margin-bottom:12px;
  }
  .tc-field-row{display:flex;align-items:baseline;gap:7px}
  .tc-field-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
    color:var(--faint);white-space:nowrap;flex:none;font-family:'League Spartan',sans-serif}
  .tc-field-value{font-size:13px;color:var(--dim);font-family:'Arimo',sans-serif}

  /* excerpt block (TYPE 1/4) */
  .tc-excerpt{
    background:var(--panel2);border:1px solid var(--line);
    border-left:3px solid var(--faint);border-radius:0 9px 9px 0;
    padding:10px 13px;margin-bottom:12px;
    font-size:13.5px;color:var(--dim);font-family:'Arimo',sans-serif;
    font-style:italic;line-height:1.55;
  }
  .tc-excerpt-label{font-family:'League Spartan',sans-serif;font-size:10px;font-weight:700;
    letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:5px;font-style:normal}

  /* what-happens / why-now line */
  .tc-what-happens{font-size:13px;color:var(--faint);margin-bottom:12px;
    line-height:1.45;font-family:'Arimo',sans-serif}
  .tc-what-happens b{color:var(--dim);font-weight:600}

  /* consequence line (per-option) */
  .tc-consequence{font-size:12.5px;color:var(--dim);margin-top:5px;
    line-height:1.4;font-family:'Arimo',sans-serif}

  /* plus-button accordion */
  .plus-btn{
    display:inline-flex;align-items:center;gap:5px;
    background:none;border:none;color:var(--faint);
    font-family:'League Spartan',sans-serif;
    font-size:11px;font-weight:700;letter-spacing:.04em;
    padding:4px 0;cursor:pointer;margin-bottom:12px;
    transition:color .12s;
  }
  .plus-btn:hover{color:var(--accent);transform:none;filter:none}
  .plus-btn .plus-icon{font-size:13px;line-height:1}
  .plus-content{
    background:var(--bg);border:1px solid var(--line);border-radius:9px;
    padding:11px 13px;margin-bottom:12px;
  }
  .plus-content.hidden{display:none}

  /* TYPE 2 CHOOSE: typed option items */
  .tc-opts-list{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
  .tc-opt-item{
    border:1px solid var(--line);border-radius:11px;padding:11px 13px;
    background:var(--panel2);transition:border-color .12s;
  }
  .tc-opt-item:hover{border-color:var(--accentDeep)}
  .tc-opt-item.recommended{
    border-color:var(--accentDeep);
    background:color-mix(in srgb,var(--accentDeep) 7%,var(--panel2));
  }
  .tc-opt-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .tc-opt-label{font-size:14px;font-weight:700;color:var(--ink);
    font-family:'League Spartan',sans-serif;flex:1;min-width:0}
  button.tc-opt-pick{
    background:var(--accentDeep);color:#ddeeff;border-color:var(--accentDeep);
    font-size:13px;padding:7px 13px;margin-top:9px;width:100%;font-weight:700;
  }
  button.tc-opt-ghost{
    background:none;border-color:var(--line);color:var(--dim);
    font-size:13px;padding:7px 13px;margin-top:9px;width:100%;
  }
  button.tc-opt-ghost:hover{border-color:var(--accent);color:var(--ink)}

  /* free-input row (bottom of TYPE 2/3) */
  .tc-free-row{display:flex;gap:8px;margin-top:8px}
  .tc-free-row input{
    flex:1;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:8px;
    padding:8px 10px;font-family:'Arimo',sans-serif;font-size:13px;
    outline:none;transition:.12s;
  }
  .tc-free-row input:focus{border-color:var(--accentDeep)}
  .tc-free-row input::placeholder{color:var(--faint)}

  /* TYPE 3 COMPARE: columns */
  .tc-compare-cols{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
  .tc-compare-col{
    flex:1 1 200px;min-width:180px;
    border:1px solid var(--line);border-radius:11px;padding:13px;
    background:var(--panel2);display:flex;flex-direction:column;
  }
  .tc-compare-col.recommended{
    border-color:var(--accentDeep);
    background:color-mix(in srgb,var(--accentDeep) 8%,var(--panel2));
  }
  .tc-compare-col-title{
    font-family:'League Spartan',sans-serif;font-size:14px;font-weight:700;color:var(--ink);
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;
  }
  .tc-pros-cons-section-label{
    font-family:'League Spartan',sans-serif;font-size:10px;font-weight:700;
    letter-spacing:.07em;text-transform:uppercase;color:var(--faint);margin-bottom:4px;
  }
  .tc-pros-cons-list{list-style:none;padding:0;margin-bottom:10px}
  .tc-pros-cons-list li{
    font-size:13px;color:var(--dim);padding:3px 0 3px 18px;
    position:relative;line-height:1.4;font-family:'Arimo',sans-serif;
  }
  .tc-pros-cons-list li.pro::before{content:'+';position:absolute;left:0;color:var(--green);font-weight:700;font-size:11px}
  .tc-pros-cons-list li.con::before{content:'!';position:absolute;left:0;color:var(--warm);font-weight:700;font-size:11px}
  .tc-wren-reason{
    font-size:13px;color:var(--dim);
    background:color-mix(in srgb,var(--accentDeep) 8%,transparent);
    border-left:2px solid var(--accentDeep);border-radius:0 8px 8px 0;
    padding:8px 11px;margin-bottom:10px;font-family:'Arimo',sans-serif;line-height:1.5;
  }
  .tc-wren-reason b{color:var(--accentDeep)}
  button.tc-compare-pick{margin-top:auto;padding-top:10px;
    background:var(--accentDeep);color:#ddeeff;border-color:var(--accentDeep);
    font-size:13px;padding:7px 13px;font-weight:700;width:100%;margin-top:10px;
  }
  button.tc-compare-ghost{
    background:none;border-color:var(--line);color:var(--dim);
    font-size:13px;padding:7px 13px;width:100%;margin-top:10px;
  }
  button.tc-compare-ghost:hover{border-color:var(--accent);color:var(--ink)}

  /* TYPE 4 STRATEGY: statement block */
  .tc-statement-block{
    background:var(--panel2);border:1px solid var(--line);
    border-left:3px solid var(--accentDeep);border-radius:0 10px 10px 0;
    padding:14px 16px;margin-bottom:13px;
    font-size:16px;color:var(--ink);font-family:'Arimo',sans-serif;
    line-height:1.6;font-weight:500;
  }
  .tc-evidence-list{list-style:none;padding:0;margin-bottom:13px}
  .tc-evidence-list li{
    font-size:13px;color:var(--dim);padding:5px 0;
    border-bottom:1px solid var(--line);
    display:flex;gap:8px;align-items:baseline;
    font-family:'Arimo',sans-serif;line-height:1.45;
  }
  .tc-evidence-list li:last-child{border-bottom:none}
  .tc-evidence-label{
    font-family:'League Spartan',sans-serif;font-size:10px;font-weight:700;
    letter-spacing:.05em;text-transform:uppercase;color:var(--faint);white-space:nowrap;flex:none;
  }
  .tc-variation-row{
    display:flex;align-items:center;gap:8px;
    padding:8px 10px;border:1px solid var(--line);border-radius:9px;
    background:var(--panel2);margin-bottom:6px;
  }
  .tc-variation-label{font-size:11px;font-weight:700;color:var(--faint);
    font-family:'League Spartan',sans-serif;flex:none;width:16px}
  .tc-variation-text{font-size:13.5px;color:var(--ink);flex:1;font-family:'Arimo',sans-serif}

  /* TYPE 5 RANK: rank list */
  .tc-rank-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}
  .tc-rank-item{
    display:flex;align-items:center;gap:10px;
    border:1px solid var(--line);border-radius:10px;
    padding:10px 13px;background:var(--panel2);
  }
  .tc-rank-num{
    width:26px;height:26px;border-radius:7px;
    background:var(--bg);border:1px solid var(--line);
    display:grid;place-items:center;
    font-size:12px;font-weight:800;color:var(--accentDeep);
    font-family:'League Spartan',sans-serif;flex:none;
  }
  .tc-rank-body{flex:1;min-width:0}
  .tc-rank-label{font-size:14px;font-weight:700;color:var(--ink);font-family:'League Spartan',sans-serif}
  .tc-rank-reason{font-size:12px;color:var(--faint);margin-top:2px;font-family:'Arimo',sans-serif}
  .tc-rank-controls{display:flex;flex-direction:column;gap:3px;flex:none}
  button.tc-rank-ctrl{
    padding:3px 7px;font-size:11px;
    background:none;border:1px solid var(--line);border-radius:5px;
    color:var(--faint);cursor:pointer;transition:color .12s,border-color .12s;
  }
  button.tc-rank-ctrl:hover{color:var(--accent);border-color:var(--accent);transform:none;filter:none}
  button.tc-rank-ctrl:disabled{opacity:.3;pointer-events:none}

  /* TYPE 6 CREATIVE REVIEW: carousel */
  .tc-carousel-shell{
    background:var(--panel2);border:1px solid var(--line);border-radius:11px;
    overflow:hidden;margin-bottom:12px;
  }
  .tc-carousel-image-area{
    display:flex;align-items:center;justify-content:center;
    min-height:200px;max-height:280px;padding:16px;
    background:var(--bg);position:relative;overflow:hidden;
  }
  .tc-carousel-image-area img{
    max-height:248px;max-width:100%;width:auto;height:auto;
    object-fit:contain;border-radius:6px;border:1px solid var(--line);display:block;
  }
  .tc-carousel-placeholder{
    width:100%;max-height:248px;min-height:160px;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    border:1px dashed var(--line);border-radius:8px;gap:8px;color:var(--faint);
  }
  .tc-carousel-placeholder-label{
    font-family:'League Spartan',sans-serif;font-size:12px;font-weight:700;
    letter-spacing:.05em;text-transform:uppercase;color:var(--faint);
  }
  .tc-carousel-controls{
    display:flex;align-items:center;justify-content:center;gap:16px;
    padding:9px 14px;border-top:1px solid var(--line);background:var(--panel2);
  }
  button.tc-carousel-arrow{
    width:32px;height:32px;border-radius:8px;
    border:1px solid var(--line);background:var(--bg);
    display:grid;place-items:center;cursor:pointer;
    color:var(--dim);font-size:14px;font-weight:700;
    transition:border-color .12s,color .12s;
  }
  button.tc-carousel-arrow:hover{border-color:var(--accent);color:var(--accent);transform:none;filter:none}
  .tc-carousel-indicator{
    font-size:12px;color:var(--faint);
    font-family:'League Spartan',sans-serif;font-weight:700;letter-spacing:.04em;
  }
  .tc-frame-info{padding:10px 14px;border-top:1px solid var(--line)}
  .tc-frame-name{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px;
    font-family:'League Spartan',sans-serif}
  .tc-frame-note{
    font-size:12.5px;color:var(--dim);
    border-left:2px solid var(--faint);padding-left:9px;margin-bottom:10px;
    font-family:'Arimo',sans-serif;line-height:1.5;
  }
  .tc-review-label{font-size:11px;color:var(--faint);margin-bottom:5px;
    font-family:'League Spartan',sans-serif;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
  .tc-reaction-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
  button.tc-reaction-btn{
    padding:6px 12px;font-size:12px;border-radius:20px;
    border:1px solid var(--line);background:var(--panel);
    color:var(--dim);cursor:pointer;font-family:'Arimo',sans-serif;font-weight:600;
    transition:border-color .12s,color .12s,background .12s;
  }
  button.tc-reaction-btn:hover{transform:none;filter:none}
  button.tc-reaction-btn.love:hover,button.tc-reaction-btn.love.active{
    border-color:var(--green);color:var(--green);
    background:color-mix(in srgb,var(--green) 12%,var(--panel));
  }
  button.tc-reaction-btn.almost:hover,button.tc-reaction-btn.almost.active{
    border-color:var(--amber);color:var(--amber);
    background:color-mix(in srgb,var(--amber) 12%,var(--panel));
  }
  button.tc-reaction-btn.restart:hover,button.tc-reaction-btn.restart.active{
    border-color:var(--red);color:var(--red);
    background:color-mix(in srgb,var(--red) 10%,var(--panel));
  }
  .tc-frame-notes textarea{
    width:100%;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:8px;
    padding:8px 10px;font-size:13px;font-family:'Arimo',sans-serif;
    resize:vertical;min-height:36px;outline:none;transition:.12s;line-height:1.45;
  }
  .tc-frame-notes textarea:focus{border-color:var(--accentDeep)}
  .tc-review-count{font-size:12px;color:var(--faint);
    font-family:'League Spartan',sans-serif;font-weight:700;letter-spacing:.04em}

  /* TYPE 7 PROVIDE INFO: question fields */
  .tc-needed-for{
    font-size:12.5px;color:var(--faint);
    background:var(--panel2);border:1px solid var(--line);border-radius:8px;
    padding:6px 11px;margin-bottom:12px;font-family:'Arimo',sans-serif;
  }
  .tc-needed-for b{color:var(--dim)}
  .tc-info-questions{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
  .tc-info-question label{
    display:block;font-size:13px;font-weight:600;color:var(--dim);
    margin-bottom:5px;font-family:'Arimo',sans-serif;
  }
  .tc-info-question input[type="text"]{
    width:100%;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:8px;
    padding:8px 11px;font-family:'Arimo',sans-serif;font-size:13.5px;
    outline:none;transition:.12s;
  }
  .tc-info-question input:focus{border-color:var(--accentDeep)}
  .tc-chip-toggle-row{display:flex;gap:6px;flex-wrap:wrap}
  button.tc-chip-toggle{
    padding:6px 13px;border:1px solid var(--line);border-radius:20px;
    background:var(--panel2);color:var(--dim);
    font-size:13px;cursor:pointer;font-family:'Arimo',sans-serif;font-weight:600;
    transition:border-color .12s,color .12s,background .12s;
  }
  button.tc-chip-toggle:hover{border-color:var(--accent);color:var(--accent);transform:none;filter:none}
  button.tc-chip-toggle.active{
    border-color:var(--accentDeep);color:var(--accentDeep);
    background:color-mix(in srgb,var(--accentDeep) 12%,var(--panel2));
  }
  .tc-info-textarea{
    width:100%;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:8px;
    padding:8px 10px;font-size:13px;font-family:'Arimo',sans-serif;
    resize:vertical;min-height:48px;outline:none;transition:.12s;line-height:1.5;
  }
  .tc-info-textarea:focus{border-color:var(--accentDeep)}

  /* TYPE 8 WALKTHROUGH: steps list */
  .tc-steps-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
  .tc-step-item{display:flex;gap:10px;align-items:flex-start}
  .tc-step-num{
    width:22px;height:22px;border-radius:6px;
    background:var(--panel2);border:1px solid var(--line);
    display:grid;place-items:center;flex:none;
    font-family:'League Spartan',sans-serif;font-size:11px;font-weight:800;color:var(--accentDeep);
  }
  .tc-step-text{
    font-size:13.5px;color:var(--dim);font-family:'Arimo',sans-serif;
    line-height:1.5;padding-top:2px;flex:1;
  }
  .tc-step-text code{
    background:var(--panel2);border:1px solid var(--line);border-radius:4px;
    padding:1px 5px;font-size:12px;color:var(--accent);
    font-family:'Courier New',monospace;
  }

  /* typed card action row -- CTA TUNING: proportional to card density, not dominant */
  .tc-action-row{display:flex;gap:7px;flex-wrap:wrap;align-items:center;margin-top:11px}
  .tc-action-row button.primary{
    background:var(--accentDeep);border-color:var(--accentDeep);
    color:#ddeeff;font-weight:700;
    padding:6px 14px;font-size:13px;
  }
  .tc-action-row button.secondary{background:none;border-color:var(--line);color:var(--dim);
    padding:6px 12px;font-size:13px;}
  .tc-action-row button.secondary:hover{color:var(--ink);border-color:var(--accent)}
  /* sm variant inside tc-action-row keeps consistent small size */
  .tc-action-row button.primary.sm,.tc-action-row button.secondary.sm{padding:5px 11px;font-size:12px}

  /* typed card inline note (always-visible in TYPE 4, toggled in TYPE 1) */
  .tc-inline-note{margin-top:10px;display:flex;flex-direction:column;gap:6px}
  .tc-inline-note textarea{
    width:100%;background:var(--bg);color:var(--ink);
    border:1px solid var(--line);border-radius:9px;
    padding:9px 11px;font-family:'Arimo',sans-serif;font-size:13.5px;
    resize:vertical;min-height:40px;outline:none;transition:.13s;line-height:1.5;
  }
  .tc-inline-note textarea:focus{border-color:var(--accentDeep)}
  .tc-inline-note.hidden{display:none}

  /* ---- TYPED ANSWERED STATE (Pass 4) ---- */
  .card.tc-answered{opacity:.76;transition:opacity .2s}
  .card.tc-answered:hover{opacity:.9}
  .tc-answered-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}
  .tc-answered-title{
    font-size:13.5px;font-weight:600;color:var(--dim);
    font-family:'League Spartan',sans-serif;flex:1;min-width:0;
  }
  .tc-answered-summary{
    font-size:13px;color:var(--dim);margin-bottom:4px;
    font-family:'Arimo',sans-serif;line-height:1.45;
  }
  .tc-answered-summary b{color:var(--ink);font-weight:600}
  .tc-answered-note{
    font-size:12px;color:var(--faint);font-style:italic;
    padding:6px 10px;background:var(--panel2);border-radius:7px;
    margin-top:6px;font-family:'Arimo',sans-serif;
  }
  button.tc-edit-btn{
    background:none;border:1px solid var(--line);color:var(--faint);
    padding:3px 10px;font-size:11px;border-radius:8px;
    font-family:'League Spartan',sans-serif;font-weight:700;letter-spacing:.03em;
    cursor:pointer;flex:none;
  }
  button.tc-edit-btn:hover{color:var(--accent);border-color:var(--accent);transform:none;filter:none}

  /* answer-next strip: top-3 typed cards are pre-opened; remaining cards show a count label */
  .answer-next-more{
    font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
    color:var(--faint);font-family:'League Spartan',sans-serif;
    text-align:center;padding:10px 0 4px;
  }

  /* ---- END TYPED CARD SYSTEM ---- */

  /* mobile + tablet */
  @media (max-width:900px){ .cmp{flex:1 1 46%} }
  @media (max-width:640px){
    main{padding:14px 12px 100px}
    header{padding:11px 13px;gap:8px}
    .logo{font-size:17px}
    .live{margin-left:8px}
    h2{margin:20px 2px 10px}
    .card{padding:14px 13px}
    button{padding:12px 16px}
    button.sm{padding:9px 13px}
    .cmprow{gap:8px}
    .cmp{flex:1 1 100%}
    textarea{font-size:16px}            /* stops iOS zoom-on-focus */
    .rk .arr button{padding:6px 12px}
    .steps{padding:4px 14px 14px 40px}
    .ws .n{font-size:12px}
    details.section>summary .sectitle{font-size:16px}
    .fromwren{flex-direction:column}
    /* mobile org chart: always vertical stack */
    .org-entities{flex-direction:column!important}
    .org-entity-groups{grid-template-columns:1fr!important}
    /* TYPE 3 compare cols stack on mobile */
    .tc-compare-cols{flex-direction:column}
    .tc-compare-col{flex:1 1 100%}
    /* TYPE 6 carousel image area smaller on mobile */
    .tc-carousel-image-area{max-height:220px}
    /* TYPE 7 field grid single col on narrow */
    .tc-field-grid{grid-template-columns:1fr}
  }

  /* ==========================================================
     V2 CARD LAYOUT (Passes 1+2, 2026-06-17j)
     Five-zone structure: header row / title / subhead / meta row / field block
     ========================================================== */

  /* V2 header row: type tag left, entity chip right */
  .v2-card-header{
    display:flex;align-items:center;gap:8px;
    margin-bottom:10px;flex-wrap:nowrap;
  }

  /* V2 type tag -- replaces card-type-tag for typed cards */
  .v2-type-tag{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;
    padding:3px 9px;border-radius:20px;border:1px solid transparent;
    flex-shrink:0;white-space:nowrap;
  }
  .v2-type-tag.pick     {background:color-mix(in srgb,var(--wren-color) 16%,var(--panel2));color:var(--wren-color);border-color:color-mix(in srgb,var(--wren-color) 30%,var(--line))}
  .v2-type-tag.approve  {background:color-mix(in srgb,var(--gate) 16%,var(--panel2));color:var(--gate);border-color:color-mix(in srgb,var(--gate) 30%,var(--line))}
  .v2-type-tag.review   {background:color-mix(in srgb,var(--warm) 16%,var(--panel2));color:var(--warm);border-color:color-mix(in srgb,var(--warm) 30%,var(--line))}
  .v2-type-tag.compare  {background:color-mix(in srgb,var(--info) 16%,var(--panel2));color:var(--info);border-color:color-mix(in srgb,var(--info) 30%,var(--line))}
  .v2-type-tag.decide   {background:color-mix(in srgb,var(--gate) 16%,var(--panel2));color:var(--gate);border-color:color-mix(in srgb,var(--gate) 30%,var(--line))}
  .v2-type-tag.rank     {background:color-mix(in srgb,var(--amber) 16%,var(--panel2));color:var(--amber);border-color:color-mix(in srgb,var(--amber) 30%,var(--line))}
  .v2-type-tag.info     {background:var(--panel2);color:var(--faint);border-color:var(--line)}
  .v2-type-tag.steps    {background:color-mix(in srgb,var(--info) 16%,var(--panel2));color:var(--info);border-color:color-mix(in srgb,var(--info) 30%,var(--line))}

  /* V2 card title -- 18px, already set on .card-title; this names the zone */
  .v2-card-title{
    font-family:'League Spartan',sans-serif;
    font-size:18px;font-weight:700;color:var(--ink);
    line-height:1.2;letter-spacing:-0.01em;
    margin:0 0 8px;
  }

  /* V2 card subhead -- one sentence, lighter */
  .v2-card-subhead{
    font-family:'Arimo',sans-serif;
    font-size:15px;font-weight:400;color:var(--dim);
    line-height:1.45;margin:0 0 10px;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }

  /* V2 meta row: deadline + owner + topic */
  .v2-meta-row{
    display:flex;gap:8px;align-items:center;
    margin-bottom:12px;flex-wrap:nowrap;
    overflow-x:auto;scrollbar-width:none;
  }
  .v2-meta-row::-webkit-scrollbar{display:none}

  /* deadline chip in meta row */
  .v2-meta-deadline{
    font-family:'League Spartan',sans-serif;
    font-size:12px;font-weight:800;letter-spacing:0.05em;text-transform:uppercase;
    padding:3px 10px;border-radius:20px;white-space:nowrap;flex-shrink:0;
    background:color-mix(in srgb,var(--entity-edge,var(--wren-color)) 12%,var(--panel2));
    color:var(--entity-edge,var(--wren-color));
    border:1px solid color-mix(in srgb,var(--entity-edge,var(--wren-color)) 30%,var(--line));
  }
  .v2-meta-deadline.overdue{
    background:color-mix(in srgb,var(--red) 14%,var(--panel2));
    color:var(--red);
    border-color:color-mix(in srgb,var(--red) 28%,var(--line));
  }
  .v2-meta-deadline.no-date{
    color:var(--faint);background:var(--panel2);border-color:var(--line);
  }

  /* owner chip in meta row */
  .v2-meta-owner{
    font-family:'Arimo',sans-serif;
    font-size:13px;font-weight:600;
    padding:3px 10px;border-radius:20px;
    background:var(--panel2);color:var(--ink);border:1px solid var(--line);
    white-space:nowrap;flex-shrink:0;
  }

  /* V2 structured field block */
  .v2-card-fields{
    display:grid;
    grid-template-columns:max-content 1fr;
    gap:5px 14px;
    margin-bottom:14px;
    padding:10px 12px;
    background:var(--panel2);
    border-radius:6px;
  }
  .v2-field-label{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;
    color:var(--entity-edge,var(--faint));
    align-self:center;white-space:nowrap;
  }
  .v2-field-value{
    font-family:'Arimo',sans-serif;
    font-size:13px;font-weight:500;color:var(--ink);
    align-self:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  }

  /* state flag for held/blocked -- rendered alongside type tag */
  .v2-state-flag{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;
    padding:3px 9px;border-radius:20px;flex-shrink:0;white-space:nowrap;
    background:color-mix(in srgb,var(--red) 14%,var(--panel2));
    color:var(--red);
    border:1px solid color-mix(in srgb,var(--red) 28%,var(--line));
  }
  .v2-state-flag.urgent{
    background:color-mix(in srgb,var(--warm) 14%,var(--panel2));
    color:var(--warm);
    border-color:color-mix(in srgb,var(--warm) 28%,var(--line));
  }

  /* ==========================================================
     PASS 4 (2026-06-17k): anatomy upgrades, gates, strips
     ========================================================== */

  /* Zone 0: decorative entity bar -- a 3px left strip showing entity color.
     NOT accent. The card border is already entity-edged (4px left).
     The bar appears as an inner top strip for visual rhythm. */
  .v2-deco-bar{
    height:3px;border-radius:3px;margin:-2px 0 12px;
    display:flex;align-items:center;gap:6px;
    /* background set inline via style= */
  }

  /* Lock icon in the decorative bar for gated cards */
  .v2-gate-lock{
    font-size:11px;line-height:1;
    /* positioned below the bar for gated cards -- the bar itself carries the color */
    display:none; /* hidden inside the 3px bar; lock shown in stakes badge instead */
  }

  /* Stakes badge: distinct chip next to type tag for hard-gated cards */
  .v2-stakes-badge{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;
    padding:3px 9px;border-radius:20px;flex-shrink:0;white-space:nowrap;
    background:color-mix(in srgb,var(--gate) 18%,var(--panel2));
    color:var(--gate);
    border:1.5px solid color-mix(in srgb,var(--gate) 40%,var(--line));
  }

  /* Gated card: distinct border treatment (gate color accent on left edge) */
  .card.gated-card{
    border-left:4px solid var(--gate) !important;
    background:color-mix(in srgb,var(--gate) 4%,var(--panel));
  }
  /* Override entity-edge on gated cards so gate color wins */
  .card.gated-card.entity-edged{border-left:4px solid var(--gate) !important;}

  /* Zone 2A: lineage chip row (breadcrumb, quiet -- entity color tint, not accent) */
  .v2-lineage-row{
    display:flex;align-items:center;gap:6px;margin-bottom:8px;
  }
  .v2-lineage-chip{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;
    color:var(--faint);padding:2px 9px;border-radius:20px;
    background:var(--panel2);border:1px solid var(--line);
    white-space:nowrap;
  }
  /* small arrow between lineage steps if we ever chain them */
  .v2-lineage-sep{color:var(--faint);font-size:10px;flex:none}

  /* Zone 2B: mini-stepper row.
     ACCENT RULE: only the active step uses accent. Done = greyscale. Locked = dim. */
  .v2-stepper-row{
    display:flex;align-items:center;gap:4px;margin-bottom:12px;
    flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding:6px 10px;
    background:var(--panel2);border-radius:8px;border:1px solid var(--line);
  }
  .v2-stepper-row::-webkit-scrollbar{display:none}
  .v2-step-item{
    display:inline-flex;align-items:center;gap:3px;
    font-family:'Arimo',sans-serif;font-size:12px;font-weight:500;
    white-space:nowrap;flex-shrink:0;
  }
  .v2-step-done{color:var(--faint);text-decoration:line-through;opacity:.7}
  /* Active step: THE ONE accent use per card from the stepper */
  .v2-step-active{
    color:var(--accent);font-weight:700;
    background:color-mix(in srgb,var(--accent) 12%,transparent);
    padding:1px 6px;border-radius:20px;
    border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));
  }
  .v2-step-pending{color:var(--dim)}
  .v2-step-locked{color:var(--faint);opacity:.55}
  .v2-step-sep{color:var(--line);font-size:10px;flex:none;margin:0 2px}

  /* V2 type tag: ALL greyscale (accent-twice rule -- no color here) */
  .v2-type-grey{
    background:var(--panel2);
    color:var(--faint);
    border-color:var(--line);
  }

  /* Three-way control: labeled "Send back with notes" textarea */
  .tc-sbwn-label{
    display:block;
    font-family:'League Spartan',sans-serif;font-size:10px;font-weight:700;
    letter-spacing:0.07em;text-transform:uppercase;
    color:var(--faint);margin-bottom:5px;
  }

  /* Per-entity what's-moving strips */
  .entity-strips-block{
    display:flex;flex-direction:column;gap:5px;margin-bottom:14px;
  }
  .entity-strip-row{
    display:flex;align-items:center;gap:8px;
    padding:6px 12px;border-radius:8px;
    background:color-mix(in srgb,var(--ec,var(--accent)) 6%,var(--panel));
    border:1px solid color-mix(in srgb,var(--ec,var(--accent)) 18%,var(--line));
    font-family:'Arimo',sans-serif;font-size:12px;color:var(--dim);
    white-space:nowrap;overflow:hidden;
  }
  .entity-strip-row .es-label{
    font-family:'League Spartan',sans-serif;font-size:11px;font-weight:800;
    letter-spacing:0.08em;text-transform:uppercase;
    color:var(--ec,var(--accent));flex:none;
  }
  .entity-strip-row .es-divider{color:var(--line);flex:none}
  .es-needs-badge{
    font-family:'League Spartan',sans-serif;font-size:10px;font-weight:800;
    letter-spacing:0.05em;text-transform:uppercase;
    background:color-mix(in srgb,var(--ec,var(--accent)) 14%,var(--panel2));
    color:var(--ec,var(--accent));
    padding:2px 8px;border-radius:20px;flex:none;
    border:1px solid color-mix(in srgb,var(--ec,var(--accent)) 28%,var(--line));
  }
  .es-needs-badge.es-all-clear{
    background:var(--panel2);color:var(--faint);border-color:var(--line);
  }
  .es-last-update{
    font-size:11px;color:var(--faint);overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1;
    font-family:'Arimo',sans-serif;
  }

  /* ---- Pass 5b: Decision map - edges ---- */
  .map-outer{padding:0 0 4px 0;}
  .map-subtitle{
    font-family:'Arimo',sans-serif;font-size:12px;color:var(--faint);
    padding:0 0 12px 0;margin:0;
  }
  .map-swimlanes{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:12px;
    width:100%;
    overflow-x:auto;
    align-items:start;
  }
  .map-lane{display:flex;flex-direction:column;gap:10px;min-width:0;}
  .map-lane-header{
    font-family:'League Spartan',sans-serif;font-size:10px;font-weight:800;
    letter-spacing:0.1em;text-transform:uppercase;
    color:var(--ec,var(--accent));
    padding:4px 0 6px 0;
    border-bottom:1.5px solid color-mix(in srgb,var(--ec,var(--accent)) 25%,var(--line));
    margin-bottom:2px;
  }
  .map-flow-group{display:flex;flex-direction:column;gap:4px;}
  .map-flow-label{
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:700;
    letter-spacing:0.06em;text-transform:uppercase;
    color:var(--dim);padding:2px 0 2px 0;
  }
  .map-node{
    display:flex;align-items:center;gap:6px;
    padding:5px 8px;border-radius:6px;
    background:var(--panel2);
    border:1px solid var(--line);
    cursor:pointer;
    min-width:0;overflow:hidden;
    transition:background 0.12s,border-color 0.12s;
  }
  .map-node:hover{
    background:color-mix(in srgb,var(--accent) 8%,var(--panel2));
    border-color:color-mix(in srgb,var(--accent) 25%,var(--line));
  }
  .map-node.mn-now{
    background:color-mix(in srgb,var(--ec,var(--accent)) 10%,var(--panel));
    border-color:color-mix(in srgb,var(--ec,var(--accent)) 40%,var(--line));
    box-shadow:0 0 0 1px color-mix(in srgb,var(--ec,var(--accent)) 18%,transparent);
  }
  .map-node.mn-done{opacity:0.5;}
  .map-node.mn-blocked{
    border-color:color-mix(in srgb,#d97706 35%,var(--line));
  }
  .map-node.mn-future{opacity:0.4;}
  .map-node-icon{flex:none;font-size:11px;width:14px;text-align:center;}
  .map-node-title{
    font-family:'Arimo',sans-serif;font-size:12px;color:var(--fg,var(--ink));
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    flex:1;min-width:0;
  }
  .map-node.mn-now .map-node-title{color:var(--ec,var(--accent));font-weight:600;}
  .map-node.mn-done .map-node-title{color:var(--faint);text-decoration:line-through;}
  .map-node-state{
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:800;
    letter-spacing:0.06em;text-transform:uppercase;flex:none;
  }
  .mn-now .map-node-state{color:var(--ec,var(--accent));}
  .mn-done .map-node-state{color:var(--faint);}
  .mn-blocked .map-node-state{color:#d97706;}
  .mn-future .map-node-state{color:var(--faint);}
  .map-rung-chip{
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:700;
    letter-spacing:0.05em;text-transform:uppercase;
    color:var(--faint);background:var(--panel);
    border:1px solid var(--line);border-radius:3px;padding:0 4px;
    flex:none;line-height:16px;
  }
  .map-lane-empty{
    font-family:'Arimo',sans-serif;font-size:11px;color:var(--faint);
    font-style:italic;padding:6px 0;
  }
  /* Within-flow vertical connector */
  .map-edge{
    display:flex;flex-direction:column;align-items:flex-start;
    padding-left:16px;/* indented to align with node content */
    height:14px;position:relative;
  }
  .map-edge-line{
    width:1px;height:100%;
    background:var(--line);
    position:relative;
  }
  .map-edge-line::after{
    content:'';
    position:absolute;bottom:0;left:-3px;
    border-left:3px solid transparent;
    border-right:3px solid transparent;
    border-top:5px solid var(--line);
  }
  /* Cross-lane link chip */
  .map-cross-chip{
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:700;
    letter-spacing:0.05em;text-transform:uppercase;
    color:var(--dim);
    border:1px dashed var(--line);
    border-radius:3px;padding:1px 6px;
    margin-top:3px;
    display:inline-block;
    cursor:default;
  }
  @media(max-width:600px){.map-swimlanes{grid-template-columns:1fr;}}

  /* ==========================================================
     PASS 4 VISUAL TREE SYSTEM (2026-06-17t)
     Color taxonomy: Entity owns hue (3px rail + chip).
     Status = fixed 3-set, always icon-paired.
     Kind/stage/parent/unblocks = neutral glyph, no new hue.
     ========================================================== */

  /* ---- STATUS PILL: 3-set, always icon-paired, ALL-CAPS ---- */
  .tree-status{
    display:inline-flex;align-items:center;gap:4px;
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:800;letter-spacing:0.07em;text-transform:uppercase;
    padding:2px 8px;border-radius:20px;flex:none;white-space:nowrap;
  }
  .tree-status-icon{font-size:9px;flex:none;line-height:1}
  /* pending = amber */
  .tree-status.ts-pending{
    background:color-mix(in srgb,var(--amber) 14%,var(--panel2));
    color:var(--amber);
    border:1px solid color-mix(in srgb,var(--amber) 28%,var(--line));
  }
  /* answered/approved/resolved/dismissed = green */
  .tree-status.ts-answered{
    background:color-mix(in srgb,var(--green) 13%,var(--panel2));
    color:var(--green);
    border:1px solid color-mix(in srgb,var(--green) 25%,var(--line));
  }
  /* blocked/held = red-muted */
  .tree-status.ts-blocked{
    background:color-mix(in srgb,var(--red) 12%,var(--panel2));
    color:var(--red);
    border:1px solid color-mix(in srgb,var(--red) 25%,var(--line));
  }

  /* ---- KIND CHIP: neutral glyph, NO hue ---- */
  .tree-kind{
    display:inline-flex;align-items:center;gap:3px;
    font-family:'Arimo',sans-serif;
    font-size:10px;font-weight:600;letter-spacing:0.03em;
    padding:2px 8px;border-radius:20px;
    background:var(--panel2);color:var(--faint);
    border:1px solid var(--line);
    flex:none;white-space:nowrap;
  }
  .tree-kind-glyph{font-size:9px;flex:none;line-height:1}

  /* ---- PILL ROW: fixed 3-slot order [Entity][Kind][Status] ---- */
  .tree-pill-row{
    display:flex;align-items:center;gap:6px;flex-wrap:wrap;
    margin:6px 0 6px;
  }

  /* ---- PARENT BREADCRUMB: top of card, quiet text ---- */
  .tree-breadcrumb{
    display:flex;align-items:center;gap:4px;
    font-family:'Arimo',sans-serif;
    font-size:11px;color:var(--faint);
    margin-bottom:6px;flex-wrap:wrap;
  }
  .tree-breadcrumb-arrow{font-size:10px;color:var(--faint);flex:none}
  .tree-breadcrumb-path{
    font-weight:500;color:var(--faint);
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px;
  }
  /* breadcrumb dot = entity-tinted, not full hue */
  .tree-breadcrumb-dot{
    width:6px;height:6px;border-radius:50%;flex:none;
    background:var(--entity-edge,var(--faint));
    opacity:.6;
  }

  /* ---- STAGE DOTS: sequence indicator ---- */
  /* shape is the primary encoding; entity hue only on current dot */
  .tree-stage-row{
    display:flex;align-items:center;gap:5px;
    margin:4px 0 8px;
    font-family:'Arimo',sans-serif;font-size:11px;color:var(--faint);
  }
  .tree-stage-dots{display:flex;align-items:center;gap:3px;flex:none}
  .tree-stage-dot{
    width:7px;height:7px;border-radius:50%;flex:none;
  }
  /* done dot: accent-green at 60% opacity */
  .tree-stage-dot.sd-done{
    background:color-mix(in srgb,var(--green) 60%,var(--faint));
  }
  /* current/active dot: entity hue (the one allowed color borrow for stage) */
  .tree-stage-dot.sd-active{
    background:var(--entity-edge,var(--accent));
    box-shadow:0 0 0 2px color-mix(in srgb,var(--entity-edge,var(--accent)) 22%,transparent);
  }
  /* future dot: faint hollow ring */
  .tree-stage-dot.sd-future{
    background:transparent;
    border:1.5px solid var(--faint);
    opacity:.5;
  }
  .tree-stage-label{
    font-size:10px;color:var(--faint);
    font-family:'League Spartan',sans-serif;font-weight:600;letter-spacing:.04em;
  }

  /* ---- UNBLOCKS CONNECTOR: forward link, bottom of card ---- */
  .tree-unblocks{
    display:inline-flex;align-items:center;gap:6px;
    font-family:'Arimo',sans-serif;font-size:12px;color:var(--faint);
    margin-top:7px;flex-wrap:wrap;
  }
  .tree-unblocks-arrow{font-size:13px;color:var(--faint);flex:none}
  /* BIGGER unblocks chip per Round-3 feedback */
  .tree-unblocks-count{
    font-family:'League Spartan',sans-serif;
    font-size:12px;font-weight:800;letter-spacing:.05em;
    padding:3px 11px;border-radius:20px;
    background:var(--panel2);color:var(--faint);
    border:1px solid var(--line);flex:none;white-space:nowrap;
  }
  .tree-unblocks-names{
    font-size:12px;color:var(--faint);
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px;
  }

  /* ---- RELATED-TO CHIP: cross-entity links (outline, no fill) ---- */
  .tree-related-row{
    display:flex;align-items:center;gap:5px;flex-wrap:wrap;
    margin-top:5px;
  }
  .tree-related-chip{
    display:inline-flex;align-items:center;gap:3px;
    font-family:'League Spartan',sans-serif;
    font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
    padding:1px 7px;border-radius:20px;
    border:1px dashed var(--line);
    background:transparent;color:var(--faint);
    white-space:nowrap;flex:none;cursor:pointer;
    transition:border-color .12s,color .12s;
  }
  .tree-related-chip:hover{border-color:var(--dim);color:var(--dim)}
  .tree-related-label{font-size:9px;opacity:.65;flex:none}

  /* ---- INTRA-ENTITY WORKSTREAM CLUSTER HEADER ---- */
  /* Groups sequential/batch cards under a labeled cluster within an entity lane */
  .ws-cluster{margin-bottom:14px}
  .ws-cluster:last-child{margin-bottom:0}
  .ws-cluster-hdr{
    display:flex;align-items:center;gap:8px;
    margin-bottom:6px;padding:2px 0;
  }
  .ws-cluster-label{
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
    color:var(--faint);white-space:nowrap;
  }
  .ws-cluster-line{flex:1;height:1px;background:var(--line)}
  .ws-cluster-type{
    font-family:'League Spartan',sans-serif;
    font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
    padding:1px 7px;border-radius:20px;
    background:var(--panel2);color:var(--faint);border:1px solid var(--line);
    flex:none;white-space:nowrap;
  }
  .ws-cluster-type.sequential{color:var(--accentDeep);border-color:color-mix(in srgb,var(--accentDeep) 28%,var(--line))}
  .ws-cluster-type.batch{color:var(--amber);border-color:color-mix(in srgb,var(--amber) 28%,var(--line))}
  .ws-cluster-cards{display:flex;flex-direction:column;gap:0}

  /* Demote old colored topic chips to neutral (SPEC: demote function/domain chip palette) */
  /* The existing colored .topic-chip.positioning/.marketing/.creative/.brand/.build/.console
     are kept for backward compat but we layer a neutral override via the tree chip context.
     New topic chips authored going forward should use .tree-kind instead. */
  .topic-chip.neutral-override{
    background:var(--panel2)!important;
    color:var(--faint)!important;
    border:1px solid var(--line)!important;
  }

  /* ==========================================================
     PART A: VISUAL TUNING (Alex round-2 feedback, 2026-06-17v)
     MORE COLOR: richer semantic color that differentiates
     flow/task/parent. Alex's call overrides the conservative
     research recommendation. Still WCAG AA readable.
     ========================================================== */

  /* --- COLORED TYPE TAGS: restore semantic hue per type (overrides v2-type-grey) ---
     The v2-type-grey class was applied globally; these more-specific rules win. */
  .v2-type-tag:not(.v2-type-grey-force) {
    /* Re-enable per-type coloring when a type class is also present */
  }
  /* type-color classes explicitly assigned in tcHeader per cardType */
  .v2-type-tag.type-approve{background:color-mix(in srgb,var(--gate) 16%,var(--panel2));color:var(--gate);border-color:color-mix(in srgb,var(--gate) 32%,var(--line))}
  .v2-type-tag.type-choose{background:color-mix(in srgb,var(--wren-color) 15%,var(--panel2));color:var(--wren-color);border-color:color-mix(in srgb,var(--wren-color) 30%,var(--line))}
  .v2-type-tag.type-compare{background:color-mix(in srgb,var(--info) 15%,var(--panel2));color:var(--info);border-color:color-mix(in srgb,var(--info) 30%,var(--line))}
  .v2-type-tag.type-strategy{background:color-mix(in srgb,var(--accentDeep) 15%,var(--panel2));color:var(--accentDeep);border-color:color-mix(in srgb,var(--accentDeep) 30%,var(--line))}
  .v2-type-tag.type-rank{background:color-mix(in srgb,var(--amber) 15%,var(--panel2));color:var(--amber);border-color:color-mix(in srgb,var(--amber) 30%,var(--line))}
  .v2-type-tag.type-creative{background:color-mix(in srgb,var(--warm) 15%,var(--panel2));color:var(--warm);border-color:color-mix(in srgb,var(--warm) 30%,var(--line))}
  .v2-type-tag.type-info{background:color-mix(in srgb,var(--faint) 18%,var(--panel2));color:var(--dim);border-color:var(--line)}
  .v2-type-tag.type-walkthrough{background:color-mix(in srgb,var(--info) 13%,var(--panel2));color:var(--info);border-color:color-mix(in srgb,var(--info) 28%,var(--line))}

  /* --- COLORED KIND CHIPS: semantic per card type (RICHER, Alex's call) --- */
  .tree-kind.kind-approve{color:var(--gate);border-color:color-mix(in srgb,var(--gate) 30%,var(--line));background:color-mix(in srgb,var(--gate) 10%,var(--panel2))}
  .tree-kind.kind-choose{color:var(--wren-color);border-color:color-mix(in srgb,var(--wren-color) 28%,var(--line));background:color-mix(in srgb,var(--wren-color) 10%,var(--panel2))}
  .tree-kind.kind-compare{color:var(--info);border-color:color-mix(in srgb,var(--info) 28%,var(--line));background:color-mix(in srgb,var(--info) 10%,var(--panel2))}
  .tree-kind.kind-strategy{color:var(--accentDeep);border-color:color-mix(in srgb,var(--accentDeep) 28%,var(--line));background:color-mix(in srgb,var(--accentDeep) 10%,var(--panel2))}
  .tree-kind.kind-rank{color:var(--amber);border-color:color-mix(in srgb,var(--amber) 28%,var(--line));background:color-mix(in srgb,var(--amber) 10%,var(--panel2))}
  .tree-kind.kind-creative{color:var(--warm);border-color:color-mix(in srgb,var(--warm) 28%,var(--line));background:color-mix(in srgb,var(--warm) 10%,var(--panel2))}
  .tree-kind.kind-walkthrough{color:var(--info);border-color:color-mix(in srgb,var(--info) 28%,var(--line));background:color-mix(in srgb,var(--info) 10%,var(--panel2))}
  .tree-kind.kind-info{color:var(--dim);border-color:var(--line);background:var(--panel2)}

  /* --- COLORED BREADCRUMBS: entity-tinted path text (not just faint) --- */
  .tree-breadcrumb-path{
    color:color-mix(in srgb,var(--entity-edge,var(--faint)) 70%,var(--dim))!important;
  }
  .tree-breadcrumb-dot{opacity:.8}

  /* --- COLORED STAGE DOTS: current dot stays entity-hued, done dots richer green --- */
  .tree-stage-dot.sd-done{
    background:color-mix(in srgb,var(--green) 75%,var(--faint));
  }
  .tree-stage-dot.sd-active{
    background:var(--entity-edge,var(--accent));
    box-shadow:0 0 0 3px color-mix(in srgb,var(--entity-edge,var(--accent)) 28%,transparent);
  }

  /* --- COLORED UNBLOCKS: entity-tinted arrow + count chip --- */
  .tree-unblocks-count{
    background:color-mix(in srgb,var(--entity-edge,var(--accent)) 11%,var(--panel2))!important;
    color:color-mix(in srgb,var(--entity-edge,var(--accent)) 80%,var(--faint))!important;
    border-color:color-mix(in srgb,var(--entity-edge,var(--accent)) 25%,var(--line))!important;
  }
  .tree-unblocks-arrow{color:var(--entity-edge,var(--faint))!important}

  /* --- COLORED CLUSTER HEADERS by entity: sequential=accent, batch=amber --- */
  /* These are overrides on top of the neutral base .ws-cluster-* rules */
  .ws-cluster-type.sequential{
    color:var(--accent);
    border-color:color-mix(in srgb,var(--accent) 35%,var(--line));
    background:color-mix(in srgb,var(--accent) 10%,var(--panel2));
  }
  .ws-cluster-type.batch{
    color:var(--amber);
    border-color:color-mix(in srgb,var(--amber) 35%,var(--line));
    background:color-mix(in srgb,var(--amber) 10%,var(--panel2));
  }
  /* cluster label: entity-colored, not plain faint */
  .ws-cluster-hdr .ws-cluster-label{
    color:var(--ec,var(--dim));
  }

  /* --- STATUS PILLS: richer tints (bump mix percentage) --- */
  .tree-status.ts-pending{
    background:color-mix(in srgb,var(--amber) 18%,var(--panel2))!important;
    border-color:color-mix(in srgb,var(--amber) 35%,var(--line))!important;
  }
  .tree-status.ts-answered{
    background:color-mix(in srgb,var(--green) 18%,var(--panel2))!important;
    border-color:color-mix(in srgb,var(--green) 32%,var(--line))!important;
  }
  .tree-status.ts-blocked{
    background:color-mix(in srgb,var(--red) 16%,var(--panel2))!important;
    border-color:color-mix(in srgb,var(--red) 32%,var(--line))!important;
  }

  /* --- ENTITY LANE HEADERS: colored header bg, not just tint --- */
  /* Boost entity-lane header vibrancy */
  .entity-lane-hdr{
    background:color-mix(in srgb,var(--el-color,var(--accent)) 11%,var(--panel))!important;
  }

  /* ==========================================================
     PART A: RESPONSIVE LAYOUT (Alex round-2, 2026-06-17v)
     Desktop: wider canvas, 2-column decision lanes where it helps.
     Mobile: single column. Configurable via CSS custom props.
     ========================================================== */

  /* Responsive breakpoints summary:
     <640px  : single col, tighter padding (already in @media max-width:640px)
     640-900 : current single-col layout (780px max)
     900-1100: 920px main, entity lanes get 2-col inner grid (NEW)
     1100+   : 1160px main (was already present), decisions 2-col grid (ENHANCED)
     1440+   : 1300px main (already present) */

  @media (min-width:900px){
    /* Decision section: entity lanes flow as 2-col (side by side) */
    /* The entity-strips stay above, decision content fills wider */
    #entity-strips{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:14px;
      align-items:start;
    }
    /* But answer-next strip spans full width */
    #answer-next{
      grid-column:1/-1;
    }
    /* entity-lane: no margin-bottom since grid handles spacing */
    .entity-lane{margin-bottom:0}
    /* Cluster headers: bump label size slightly on desktop */
    .ws-cluster-label{font-size:11px}
    /* card-title bigger on desktop */
    .v2-card-title{font-size:19px}
    /* breadcrumb path wider on desktop */
    .tree-breadcrumb-path{max-width:340px}
    .tree-unblocks-names{max-width:260px}
  }

  @media (min-width:1100px){
    /* 3-col decision lanes (Wren / The Line / Trailbuildr side by side) */
    #entity-strips{
      grid-template-columns:repeat(3,1fr);
      gap:16px;
    }
    /* Decision cards inside lanes: subtle grid within each lane */
    .entity-lane-body{display:flex;flex-direction:column;gap:10px;padding:12px 14px 16px}
    .v2-card-title{font-size:20px}
  }

  /* Mobile: collapse multi-col decision layout */
  @media (max-width:640px){
    #entity-strips{display:flex;flex-direction:column;gap:10px}
    /* CTA buttons stay proportional on mobile too */
    .tc-action-row button.primary,.tc-action-row button.secondary{font-size:14px;padding:9px 16px}
    .awf-actions button.go,.awf-actions button.ghost{font-size:14px;padding:9px 16px}
    /* entity lane shows full width */
    .entity-lane{margin-bottom:10px}
  }

  /* ==========================================================
     DESIGN-REVIEW SAMPLE CARDS: labeled showcase set (2026-06-17v)
     Cards in the "Design review" group/workstream get a distinct
     header tint so Alex knows they're sample/showcase cards.
     ========================================================== */
  .card.design-review-sample{
    border:2px dashed color-mix(in srgb,var(--wren-color) 40%,var(--line))!important;
    border-left:5px solid var(--wren-color)!important;
    background:color-mix(in srgb,var(--wren-color) 4%,var(--panel));
  }
  .design-review-badge{
    display:inline-flex;align-items:center;gap:4px;
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:800;
    letter-spacing:.1em;text-transform:uppercase;
    padding:2px 8px;border-radius:20px;
    background:color-mix(in srgb,var(--wren-color) 18%,var(--panel2));
    color:var(--wren-color);
    border:1px solid color-mix(in srgb,var(--wren-color) 35%,var(--line));
    white-space:nowrap;flex:none;
  }

  /* cta-sm-proportional: applied to CTA buttons per Part A -- assert class in QA */
  .cta-sm-proportional{
    padding:6px 14px!important;font-size:13px!important;
  }
  /* cta-sm-sec: secondary variant */
  .cta-sm-sec{
    padding:6px 12px!important;font-size:13px!important;
  }

  /* responsive-decisions: wrapper that flips to grid on desktop -- assert class in QA */
  .responsive-decisions{
    display:flex;flex-direction:column;gap:10px;
  }
  @media (min-width:900px){
    .responsive-decisions{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start;}
  }
  @media (min-width:1100px){
    .responsive-decisions{grid-template-columns:repeat(3,1fr);gap:16px;}
  }

  /* ==========================================================
     NOTE-ALWAYS-SENDS HINT (Round-3 apply pass, 2026-06-17w)
     Tells Alex her typed note sends with any button she taps.
     ========================================================== */
  .note-always-hint{
    font-family:'Arimo',sans-serif;
    font-size:11.5px;color:var(--faint);
    font-style:italic;
    margin:7px 0 5px;
    padding:4px 10px;
    border-left:2px solid var(--entity-edge,var(--accent));
    background:color-mix(in srgb,var(--entity-edge,var(--accent)) 5%,var(--panel));
    border-radius:0 5px 5px 0;
  }

  /* ==========================================================
     DESIGN-REVIEW VISUAL BLOCK (SHOW-DON'T-TELL, 2026-06-17w)
     Renders actual visual elements inside design-review cards so
     Alex approves what she sees, not what she reads.
     ========================================================== */
  .dr-visual-wrap{
    margin:8px 0 12px;
    border:1px solid color-mix(in srgb,var(--wren-color) 28%,var(--line));
    border-radius:9px;
    overflow:hidden;
    pointer-events:none;   /* entire block is inert -- demo buttons cannot be clicked */
    user-select:none;
    position:relative;
  }
  /* PREVIEW label bar that appears above every visual block */
  .dr-visual-preview-bar{
    display:flex;align-items:center;gap:6px;
    padding:4px 10px;
    background:color-mix(in srgb,var(--wren-color) 12%,var(--panel2));
    border-bottom:1px solid color-mix(in srgb,var(--wren-color) 22%,var(--line));
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:800;
    letter-spacing:.12em;text-transform:uppercase;color:var(--wren-color);
  }
  .dr-visual-preview-bar::before{
    content:'';width:7px;height:7px;border-radius:50%;
    background:var(--wren-color);opacity:.6;flex:none;
  }
  .dr-visual-block{
    padding:12px 14px;
    background:color-mix(in srgb,var(--wren-color) 5%,var(--panel));
  }
  .dr-visual-label{
    font-family:'League Spartan',sans-serif;
    font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
    color:var(--wren-color);margin-bottom:9px;
  }
  .dr-visual-caption{
    font-family:'Arimo',sans-serif;font-size:11px;color:var(--faint);
    font-style:italic;margin-top:9px;
    border-top:1px solid color-mix(in srgb,var(--wren-color) 15%,var(--line));
    padding-top:7px;
  }

  /* Demo card inside visual block */
  .dr-demo-card{
    display:flex;gap:0;
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:7px;overflow:hidden;
  }
  .dr-demo-rail{width:5px;flex:none}
  .dr-demo-inner{flex:1;padding:10px 12px}
  .dr-demo-breadcrumb{display:flex;align-items:center;gap:4px;margin-bottom:6px}
  .dr-demo-unblocks{display:flex;align-items:center;gap:5px;margin-top:7px}

  /* Generic chip for visual demos */
  .dr-chip{
    display:inline-flex;align-items:center;gap:3px;
    font-family:'League Spartan',sans-serif;
    font-size:10px;font-weight:700;letter-spacing:.04em;
    padding:2px 8px;border-radius:20px;
    border:1px solid var(--line);background:var(--panel2);color:var(--faint);
    white-space:nowrap;flex:none;
  }
  .dr-chip.kind{color:var(--dim);border-color:var(--line)}
  .dr-chip.status-pending{
    background:color-mix(in srgb,#d97706 14%,var(--panel2));
    color:#b45309;border-color:color-mix(in srgb,#d97706 30%,var(--line));
  }
  .dr-chip.status-answered{
    background:color-mix(in srgb,#16a34a 14%,var(--panel2));
    color:#15803d;border-color:color-mix(in srgb,#16a34a 30%,var(--line));
  }
  .dr-chip.status-blocked{
    background:color-mix(in srgb,#dc2626 12%,var(--panel2));
    color:#b91c1c;border-color:color-mix(in srgb,#dc2626 28%,var(--line));
  }
  .dr-chip.entity{flex:none}

  /* Approve kind chip tints per type */
  .dr-chip.approve-swatch{background:rgba(16,185,129,.1);color:#059669;border-color:rgba(16,185,129,.28)}
  .dr-chip.choose-swatch{background:rgba(59,130,246,.1);color:#2563eb;border-color:rgba(59,130,246,.25)}
  .dr-chip.compare-swatch{background:rgba(20,184,166,.1);color:#0d9488;border-color:rgba(20,184,166,.25)}
  .dr-chip.strategy-swatch{background:rgba(139,92,246,.1);color:#7c3aed;border-color:rgba(139,92,246,.25)}
  .dr-chip.rank-swatch{background:rgba(249,115,22,.1);color:#ea580c;border-color:rgba(249,115,22,.25)}
  .dr-chip.info-swatch{background:rgba(14,165,233,.1);color:#0284c7;border-color:rgba(14,165,233,.25)}
  .dr-chip.walkthrough-swatch{background:rgba(168,85,247,.1);color:#9333ea;border-color:rgba(168,85,247,.25)}

  /* Bigger unblocks chip in visual demos */
  .dr-unblocks-chip{
    font-family:'League Spartan',sans-serif;
    font-size:12px;font-weight:800;letter-spacing:.05em;
    padding:3px 11px;border-radius:20px;
    background:color-mix(in srgb,var(--wren-color) 11%,var(--panel2));
    color:color-mix(in srgb,var(--wren-color) 80%,var(--faint));
    border:1px solid color-mix(in srgb,var(--wren-color) 25%,var(--line));
    flex:none;white-space:nowrap;
  }

  /* Stage dots in visual demos */
  .dr-dot{
    display:inline-block;width:9px;height:9px;border-radius:50%;flex:none;
  }
  .dr-dot.done{background:var(--dim)}
  .dr-dot.active{background:var(--wren-color);box-shadow:0 0 0 3px rgba(63,134,194,.22)}
  .dr-dot.future{background:transparent;border:2px solid var(--line)}

  /* All buttons inside the visual wrap are inert demo props */
  .dr-visual-wrap button{
    cursor:default!important;opacity:.55;pointer-events:none;
  }

  /* Density comparison row */
  .dr-density-row{
    display:flex;gap:10px;flex-wrap:wrap;
  }
  .dr-density-col{
    flex:1;min-width:110px;
    padding:10px;border-radius:7px;
    background:var(--panel2);border:1px solid var(--line);
  }
  .dr-density-col.dr-density-selected{
    border-color:var(--wren-color);
    background:color-mix(in srgb,var(--wren-color) 6%,var(--panel));
  }
  .dr-density-badge{
    font-family:'League Spartan',sans-serif;
    font-size:9px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
    color:var(--faint);margin-bottom:6px;
  }
  .dr-density-badge.selected{color:var(--wren-color)}

  /* CTA compare row */
  .dr-cta-compare-row{display:flex;gap:10px;flex-wrap:wrap}
  .dr-cta-col{
    flex:1;min-width:130px;
    padding:10px;border-radius:7px;
    background:var(--panel2);border:1px solid var(--line);
  }
  .dr-cta-col.dr-density-selected{
    border-color:var(--wren-color);
    background:color-mix(in srgb,var(--wren-color) 6%,var(--panel));
  }

  /* Primary/secondary DEMO buttons -- these are sample/preview only, NOT real controls.
     pointer-events:none is inherited from .dr-visual-wrap; cursor/opacity reinforce inert state. */
  .dr-btn-primary{
    background:var(--accent);color:#fff;
    border:none;border-radius:6px;
    padding:6px 14px;font-size:13px;font-weight:600;
    cursor:default;opacity:.55;
  }
  .dr-btn-secondary{
    background:transparent;color:var(--accent);
    border:1.5px solid var(--accent);border-radius:6px;
    padding:6px 14px;font-size:13px;font-weight:600;
    cursor:default;opacity:.55;
  }

  /* ==========================================================
     PASS A: CARD-UX OVERHAUL -- LEGIBILITY + GLANCEABLE
     2026-06-18a
     Priority fixes:
       1. v2-card-subhead truncation removed (was 1-line ellipsis)
       2. Type scale up: title 18->20, subhead 15->16, detail 15->16
       3. Textareas: 13.5->15px across all note areas
       4. Stage dots: 7->9px, unblocks chip bigger
       5. Breadcrumb: 11->13px for readability
       6. Theme panels slightly lighter for contrast
       7. Body base 17->18px
     ========================================================== */

  /* Lighten the twilight theme panels slightly for easier reading */
  [data-theme="twilight"]{
    --panel:#172233;
    --panel2:#1f2f40;
  }

  /* Base body font: 17 -> 18px */
  body{
    font-size:18px;
  }

  /* ---- TITLE: 18 -> 20px ---- */
  .v2-card-title{
    font-size:20px;
  }

  /* ---- SUBHEAD: fix truncation + bump size 15->16px ----
     The white-space:nowrap was cutting the body to one line.
     This is the single largest legibility fix. */
  .v2-card-subhead{
    font-size:16px;
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
    line-height:1.55;
  }

  /* ---- CARD DETAIL (legacy cards): 15->16px ---- */
  .card-detail{
    font-size:16px;
    line-height:1.6;
  }

  /* ---- ctx-scroll context block: bump to 15.5px ---- */
  .ctx-scroll{
    font-size:15.5px;
    line-height:1.7;
  }

  /* ---- TEXTAREAS: all note areas 13.5->15px ---- */
  .card-unified-textarea{
    font-size:15px;
    min-height:54px;
  }
  .tc-inline-note textarea{
    font-size:15px;
    min-height:48px;
  }
  .awn-note{
    font-size:15px;
    min-height:50px;
  }
  /* also catch any global textarea not already covered */
  textarea{
    font-size:15px;
  }

  /* ---- STAGE DOTS: 7->9px, active shadow bigger ---- */
  .tree-stage-dot{
    width:9px;
    height:9px;
  }
  .tree-stage-dot.sd-active{
    box-shadow:0 0 0 3px color-mix(in srgb,var(--entity-edge,var(--accent)) 28%,transparent);
  }

  /* ---- BREADCRUMB: 11->13px, more legible ---- */
  .tree-breadcrumb{
    font-size:13px;
  }
  .tree-breadcrumb-path{
    font-size:13px;
  }
  .tree-stage-label{
    font-size:11.5px;
  }

  /* ---- UNBLOCKS CHIP: bigger font + padding ---- */
  .tree-unblocks-count{
    font-size:14px;
    padding:4px 14px;
    letter-spacing:.04em;
  }
  .tree-unblocks{
    font-size:13.5px;
  }
  .tree-unblocks-names{
    font-size:13.5px;
  }

  /* ---- v2-field-value: allow wrapping for long values ---- */
  .v2-field-value{
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
    font-size:14px;
    line-height:1.45;
  }

  /* ---- NOTE-ALWAYS-HINT: clearer, slightly taller ---- */
  .note-always-hint{
    font-size:13px;
    padding:5px 12px;
    margin:8px 0 6px;
  }

  /* ---- Desktop bumps: title even larger on wide screens ---- */
  @media (min-width:900px){
    .v2-card-title{font-size:21px}
    .v2-card-subhead{font-size:16.5px}
  }
  @media (min-width:1100px){
    .v2-card-title{font-size:22px}
  }

  /* ============================================================
     CARD COLLAPSE / DEFER (2026-06-18c)
     Per-card collapse: Alex can collapse individual cards to defer
     them without archiving. Collapsed state persists in localStorage
     across auto-refresh and page reloads.
     ============================================================ */

  /* Collapse toggle button -- lives in the card header row, right edge */
  .card-collapse-btn{
    flex:none;
    background:none;
    border:1px solid var(--line);
    border-radius:6px;
    padding:2px 5px;
    font-size:10px;
    font-weight:600;
    color:var(--faint);
    cursor:pointer;
    line-height:1;
    transition:.15s;
    margin-left:auto;
    font-family:'Arimo',sans-serif;
    letter-spacing:.01em;
    min-width:20px;
    text-align:center;
  }
  .card-collapse-btn:hover{
    color:var(--ink);
    border-color:var(--dim);
    transform:none;
  }
  /* chevron rotates when expanded */
  .card-collapse-btn .cc-chevron{
    display:inline-block;
    font-size:9px;
    transition:transform .15s;
    font-style:normal;
  }
  .card.card-is-collapsed .card-collapse-btn .cc-chevron{
    transform:rotate(-90deg);
  }

  /* Collapsed card: only show the summary row (title + parent chip + child chips).
     Full-strength styling -- collapse is a temporary visual fold, not a status or deferral. */
  .card.card-is-collapsed{
    padding:10px 14px;
    cursor:pointer;
  }
  .card.card-is-collapsed:hover{
    border-color:var(--accentDeep);
  }
  /* Hide all body content when collapsed */
  .card.card-is-collapsed .card-collapse-body{
    display:none;
  }
  /* Show the collapsed summary strip (always in DOM, hidden when expanded) */
  .card-collapse-summary{
    display:none;
    align-items:flex-start;
    gap:8px;
    flex-wrap:wrap;
    margin-top:5px;
  }
  .card.card-is-collapsed .card-collapse-summary{
    display:flex;
  }
  /* Parent chip (breadcrumb / ladders-to) inside collapsed summary */
  .cc-parent-chip{
    font-size:11px;
    font-weight:600;
    color:var(--faint);
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:20px;
    padding:2px 9px;
    letter-spacing:.02em;
    white-space:nowrap;
  }
  .cc-parent-chip::before{
    content:'from ';
    opacity:.55;
    font-weight:400;
  }
  /* Child chips (unblocks / entity) inside collapsed summary */
  .cc-child-chip{
    font-size:11px;
    font-weight:600;
    color:var(--accent);
    background:color-mix(in srgb,var(--accent) 10%,var(--panel2));
    border:1px solid color-mix(in srgb,var(--accent) 25%,var(--line));
    border-radius:20px;
    padding:2px 9px;
    white-space:nowrap;
  }
  /* .cc-deferred-badge removed: collapse is a visual fold only, not a deferral status */
  /* Collapsed card header row: title + toggle side by side */
  .card.card-is-collapsed .card-title-row,
  .card.card-is-collapsed .v2-card-header{
    margin-bottom:0;
  }
  /* Touch target: make the whole collapsed card clickable to expand */
  .card.card-is-collapsed{
    user-select:none;
  }

  /* ---- ZONE 1-3 SPEC (2026-06-18d, Mica) ---- */
  /* Zone 1 row: ACTION TYPE ... DUE ... STATUS ... owner ... [chevron far right] */
  .v2-z1-row{
    display:flex;
    align-items:center;
    gap:6px;
    flex-wrap:wrap;
    padding:10px 0 10px 0;
  }
  /* Entity chip: right-aligned in its own span */
  .v2-z1-entity-right{
    margin-left:auto;
    display:flex;
    align-items:center;
    gap:4px;
    flex:none;
  }
  /* Zone 1: entity chip -- same colors as .entity-chip, just zone-1 sizing */
  .v2-z1-entity{
    font-family:'League Spartan',sans-serif;
    font-size:11px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    padding:2px 9px;
    border-radius:999px;
    border:1px solid;
    display:inline-flex;
    align-items:center;
    line-height:1.4;
  }
  /* Zone 1: action type chip -- muted filled pill */
  .v2-z1-action{
    font-family:'League Spartan',sans-serif;
    font-size:11px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    padding:2px 9px;
    border-radius:999px;
    background:var(--panel2);
    color:var(--dim);
    border:1px solid var(--line);
    display:inline-flex;
    align-items:center;
    line-height:1.4;
    flex:none;
  }
  /* Zone 1: due chip -- outline only, no fill */
  .v2-z1-due{
    font-family:'Arimo',sans-serif;
    font-size:11px;
    font-weight:600;
    padding:2px 9px;
    border-radius:999px;
    background:transparent;
    color:var(--dim);
    border:1px solid var(--line);
    display:inline-flex;
    align-items:center;
    line-height:1.4;
    flex:none;
  }
  .v2-z1-due-overdue{
    color:#C03B2B;
    border-color:#C03B2B;
  }
  /* Zone 1: status chip -- On track / At risk / Behind. Muted colors, no entity clash. */
  .v2-z1-status{
    font-family:'Arimo',sans-serif;
    font-size:11px;
    font-weight:600;
    padding:2px 9px;
    border-radius:999px;
    background:transparent;
    border:1px solid;
    display:inline-flex;
    align-items:center;
    line-height:1.4;
    flex:none;
  }
  .v2-z1-status-on-track{
    color:#2A7A4B;
    border-color:color-mix(in srgb,#2A7A4B 40%,var(--line));
    background:color-mix(in srgb,#2A7A4B 10%,transparent);
  }
  .v2-z1-status-at-risk{
    color:#9A6200;
    border-color:color-mix(in srgb,#9A6200 40%,var(--line));
    background:color-mix(in srgb,#9A6200 8%,transparent);
  }
  .v2-z1-status-behind{
    color:#C03B2B;
    border-color:color-mix(in srgb,#C03B2B 40%,var(--line));
    background:color-mix(in srgb,#C03B2B 8%,transparent);
  }
  /* Zone 1: owner -- plain text, no chip frame */
  .v2-z1-owner{
    font-family:'Arimo',sans-serif;
    font-size:11px;
    font-weight:500;
    color:var(--faint);
    display:inline-flex;
    align-items:center;
    line-height:1.4;
    flex:none;
  }
  /* Zone 2: title -- largest element on the card */
  .v2-z2-title{
    font-family:'League Spartan',sans-serif;
    font-size:18px;
    font-weight:600;
    color:var(--ink);
    line-height:1.1;
    letter-spacing:-.01em;
    text-transform:none;
    margin:0 0 4px 0;
  }
  /* Zone 2: subtitle line -- workstream name, step dots, unblocks count */
  .v2-z2-sub{
    font-family:'Arimo',sans-serif;
    font-size:12.5px;
    font-weight:500;
    color:var(--dim);
    line-height:1.6;
    margin:2px 0 0 0;
    display:flex;
    align-items:center;
    gap:4px;
    flex-wrap:wrap;
  }
  .v2-z2-sub-ws{
    color:var(--dim);
    font-weight:500;
  }
  .v2-z2-sub-sep{
    color:var(--faint);
    font-weight:400;
  }
  .v2-z2-sub-unblocks{
    color:var(--dim);
    font-weight:500;
  }
  /* Step dots in subtitle: small inline circles */
  .v2-z2-sub-dots{
    display:inline-flex;
    align-items:center;
    gap:3px;
  }
  .v2-sub-dot{
    width:7px;
    height:7px;
    border-radius:50%;
    display:inline-block;
    flex:none;
  }
  .v2-sub-dot.sd-done{
    background:var(--dim);
    opacity:.5;
  }
  .v2-sub-dot.sd-active{
    background:var(--accent);
    opacity:1;
  }
  .v2-sub-dot.sd-future{
    background:transparent;
    border:1.5px solid var(--faint);
  }
  /* Chevron-only row for legacy cards (no v2-z1-row) */
  .card-collapse-chevron-row{
    display:flex;
    justify-content:flex-end;
    margin-bottom:4px;
  }
  /* Zone 3: the ask -- one line summary */
  .v2-z3-ask{
    font-family:'Arimo',sans-serif;
    font-size:14px;
    font-weight:400;
    color:var(--ink);
    line-height:1.4;
    margin:8px 0 0 0;
  }
  /* Zone 3: gated stakes parenthetical */
  .v2-z3-gated{
    color:#C03B2B;
  }
  /* Zone 4: substance box -- warmer, readable body (not a code-like label-value grid) */
  .substance-box,.an-substance-box{
    background:var(--bg);
    border:1px solid var(--line);
    border-radius:8px;
    padding:12px 13px;
    margin:12px 0 0 0;
    font-family:'Arimo',sans-serif;
    font-size:13px;
    color:var(--dim);
    line-height:1.6;
    max-height:280px;
    overflow-y:auto;
  }
  /* View draft expand content: warmer pre-wrap body */
  .plus-content[id^="tc-plus-"]{
    font-family:'Arimo',sans-serif;
    font-size:13px;
    color:var(--dim);
    line-height:1.6;
    white-space:pre-wrap;
    background:var(--bg);
    border:1px solid var(--line);
    border-radius:8px;
    padding:12px 13px;
    max-height:280px;
    overflow-y:auto;
    margin-top:6px;
  }
  /* tc-excerpt: warmer skin -- Arimo body, comfortable line-height, not code-like */
  .tc-excerpt{
    background:var(--bg);
    border:1px solid var(--line);
    border-radius:8px;
    padding:12px 13px;
    margin:12px 0 0 0;
    font-family:'Arimo',sans-serif;
    font-size:13px;
    color:var(--dim);
    line-height:1.6;
    max-height:240px;
    overflow-y:auto;
    white-space:pre-wrap;
  }
  /* tc-excerpt label: kept for field label style */
  .tc-excerpt .tc-excerpt-label{
    font-family:'League Spartan',sans-serif;
    font-size:10px;
    font-weight:700;
    letter-spacing:.1em;
    text-transform:uppercase;
    color:var(--faint);
    margin-bottom:6px;
  }
  /* Chevron in Zone 1 row (injected by wrapWithCollapse): push it to far right */
  .v2-z1-row .card-collapse-btn{
    margin-left:auto;
    color:var(--faint);
    font-size:13px;
  }
  /* When .v2-z1-entity-right exists, it already uses margin-left:auto, so chevron
     (added after it by wrapWithCollapse) stacks correctly at far right */
  .v2-z1-entity-right + .card-collapse-btn{
    margin-left:4px;
  }
  /* Zone 1 action chip color variants -- reuse v2-type-tag color token set */
  .v2-z1-action.type-approve{background:color-mix(in srgb,var(--gate) 16%,var(--panel2));color:var(--gate);border-color:color-mix(in srgb,var(--gate) 32%,var(--line))}
  .v2-z1-action.type-choose{background:color-mix(in srgb,var(--wren-color) 15%,var(--panel2));color:var(--wren-color);border-color:color-mix(in srgb,var(--wren-color) 30%,var(--line))}
  .v2-z1-action.type-compare{background:color-mix(in srgb,var(--info) 15%,var(--panel2));color:var(--info);border-color:color-mix(in srgb,var(--info) 30%,var(--line))}
  .v2-z1-action.type-strategy{background:color-mix(in srgb,var(--accentDeep) 15%,var(--panel2));color:var(--accentDeep);border-color:color-mix(in srgb,var(--accentDeep) 30%,var(--line))}
  .v2-z1-action.type-rank{background:color-mix(in srgb,var(--amber) 15%,var(--panel2));color:var(--amber);border-color:color-mix(in srgb,var(--amber) 30%,var(--line))}
  .v2-z1-action.type-creative{background:color-mix(in srgb,var(--warm) 15%,var(--panel2));color:var(--warm);border-color:color-mix(in srgb,var(--warm) 30%,var(--line))}
  .v2-z1-action.type-info{background:color-mix(in srgb,var(--faint) 18%,var(--panel2));color:var(--dim);border-color:var(--line)}
  .v2-z1-action.type-walkthrough{background:color-mix(in srgb,var(--info) 13%,var(--panel2));color:var(--info);border-color:color-mix(in srgb,var(--info) 28%,var(--line))}
  .v2-z1-action.type-decide{background:color-mix(in srgb,var(--gate) 16%,var(--panel2));color:var(--gate);border-color:color-mix(in srgb,var(--gate) 32%,var(--line))}

  /* ---- 2026-06-18e: entity-accordion (per-entity decision groups) ---- */
  .entity-accordion{
    margin-bottom:8px;
    border:1px solid var(--line);
    border-radius:12px;
    background:var(--panel);
    overflow:hidden;
  }
  .entity-accordion > summary{
    list-style:none;
    cursor:pointer;
    display:flex;
    align-items:center;
    gap:10px;
    padding:11px 14px;
    user-select:none;
  }
  .entity-accordion > summary::-webkit-details-marker{display:none;}
  .entity-accordion[open] > summary{border-bottom:1px solid var(--line);}
  .eacc-rail{
    width:4px;
    height:20px;
    border-radius:2px;
    background:var(--entity-edge);
    flex:none;
  }
  .eacc-label{
    font-family:'League Spartan',sans-serif;
    font-size:13px;
    font-weight:700;
    letter-spacing:0.06em;
    text-transform:uppercase;
    color:var(--ink);
  }
  .eacc-count{
    font-family:'Arimo',sans-serif;
    font-size:12px;
    color:var(--dim);
    font-weight:600;
  }
  .eacc-col{
    display:flex;
    gap:2px;
    margin-left:4px;
  }
  .eacc-col button{
    font-size:12px;
    padding:1px 5px;
    opacity:0.65;
  }
  .eacc-chevron{
    margin-left:auto;
    font-size:11px;
    color:var(--faint);
    transition:transform 120ms;
  }
  details.entity-accordion[open] .eacc-chevron{transform:rotate(180deg);}
  .eacc-body{padding:10px 0 6px;}
  .eacc-empty{
    padding:12px 14px;
    font-family:'Arimo',sans-serif;
    font-size:13px;
    color:var(--faint);
  }

  /* ---- 2026-06-18i: entity compact titles list (collapsed state) ---- */
  /* Compact list is ALWAYS rendered in the DOM; CSS shows/hides it based on [open]. */
  .eacc-compact{
    display:none; /* hidden when accordion is open */
    padding:6px 0 8px;
    border-top:1px solid var(--line);
  }
  details.entity-accordion:not([open]) .eacc-compact{
    display:block; /* visible when accordion is closed */
  }
  details.entity-accordion[open] .eacc-compact{
    display:none;
  }
  /* Also hide the full body when accordion is closed (it is inside a details so it is
     naturally hidden, but be explicit for clarity) */
  details.entity-accordion:not([open]) .eacc-body{
    display:none;
  }
  .eacc-compact-empty{
    padding:10px 16px;
    font-family:'Arimo',sans-serif;
    font-size:13px;
    color:var(--faint);
  }
  .ectl-row{
    display:flex;
    align-items:center;
    gap:9px;
    padding:7px 16px;
    cursor:pointer;
    border-bottom:1px solid var(--line);
    transition:background 80ms;
  }
  .ectl-row:last-child{
    border-bottom:none;
  }
  .ectl-row:hover{
    background:var(--panel2);
  }
  .ectl-row:focus{
    outline:2px solid var(--accent);
    outline-offset:-2px;
  }
  .ectl-dot{
    width:7px;
    height:7px;
    border-radius:50%;
    flex:none;
  }
  .ectl-dot-pending{
    /* background set inline via entity color */
    opacity:0.85;
  }
  .ectl-dot-held{
    background:var(--warm);
    opacity:0.8;
  }
  .ectl-dot-done{
    background:var(--ok);
    opacity:0.7;
  }
  .ectl-title{
    font-family:'Arimo',sans-serif;
    font-size:13.5px;
    font-weight:500;
    color:var(--ink);
    flex:1 1 0;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .ectl-action{
    font-family:'League Spartan',sans-serif;
    font-size:10px;
    font-weight:700;
    letter-spacing:0.05em;
    text-transform:uppercase;
    color:var(--faint);
    flex:none;
    white-space:nowrap;
  }
  /* Narrow viewport: let title wrap instead of clipping */
  @media(max-width:480px){
    .ectl-title{
      white-space:normal;
      overflow:visible;
      text-overflow:clip;
    }
    .ectl-action{
      display:none; /* remove action word on very narrow screens to save space */
    }
  }

  /* ---- 2026-06-18e: card-context-block and card-draft-block ---- */
  .card-context-block{
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:8px;
    padding:10px 13px;
    margin-bottom:12px;
    font-family:'Arimo',sans-serif;
    font-size:13.5px;
    line-height:1.6;
    color:var(--dim);
  }
  .card-context-label{
    font-family:'League Spartan',sans-serif;
    font-size:10px;
    font-weight:700;
    letter-spacing:0.10em;
    text-transform:uppercase;
    color:var(--faint);
    margin-bottom:6px;
  }
  .card-context-body{
    white-space:pre-wrap;
    word-break:break-word;
    max-height:200px;
    overflow-y:auto;
    scrollbar-width:thin;
  }
  .card-draft-block{
    background:color-mix(in srgb,var(--accent) 5%,var(--panel2));
    border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));
    border-radius:8px;
    padding:10px 13px;
    margin-bottom:12px;
  }
  .card-draft-label{
    font-family:'League Spartan',sans-serif;
    font-size:10px;
    font-weight:700;
    letter-spacing:0.10em;
    text-transform:uppercase;
    color:var(--accent);
    margin-bottom:6px;
  }
  .card-draft-body{
    font-family:'Arimo',sans-serif;
    font-size:13.5px;
    line-height:1.6;
    color:var(--ink);
    white-space:pre-wrap;
    word-break:break-word;
    max-height:280px;
    overflow-y:auto;
    scrollbar-width:thin;
  }

  /* ---- 2026-06-18e: card-hold-row (hold button below action row) ---- */
  .card-hold-row{
    display:flex;
    margin-top:6px;
    padding-top:6px;
    border-top:1px solid var(--line);
  }
  .card-hold-row button{
    font-size:11.5px;
    opacity:0.75;
  }
  .card-hold-row button:hover{opacity:1;}

  /* ---- 2026-06-18e: equal-width Attach + Drop ---- */
  .card-attach-btn,
  .card-drop-zone{flex:1 1 0;min-width:0;}

  /* ---- 2026-06-18e: held-resurface display ---- */
  .held-resurface{
    font-family:'Arimo',sans-serif;
    font-size:12px;
    color:var(--dim);
    margin-top:6px;
    padding:5px 8px;
    background:color-mix(in srgb,var(--accent) 8%,var(--panel2));
    border-radius:5px;
    display:inline-block;
  }
  .held-resurface b{color:var(--ink);}

  /* ============================================================
     LOCKED CARD DESIGN SYSTEM (2026-06-18m)
     Alex's picks from the reskin training.
     ============================================================ */

  /* ---- TYPE 1: APPROVE -- Option A (compact, tight) ---- */
  .tc-approve-compact .card-context-block{padding:10px 14px 8px;}
  .tc-approve-compact .card-draft-block{margin:0 14px 10px;}

  /* ---- TYPE 2: CHOOSE -- Option A (stacked cards, letter + description) ---- */
  .tc-choose-list{display:flex;flex-direction:column;gap:7px;padding:0 14px 12px;}
  .tc-choose-opt{
    display:flex;align-items:center;gap:10px;
    background:var(--panel2);border:1.5px solid var(--line);
    border-radius:10px;padding:9px 10px;
    transition:border-color .15s;
  }
  .tc-choose-opt.recommended{
    border-color:color-mix(in srgb,var(--accent) 45%,var(--line));
    background:color-mix(in srgb,var(--accent) 7%,var(--panel2));
  }
  .tc-choose-opt-letter{
    width:22px;height:22px;border-radius:5px;flex:none;
    display:flex;align-items:center;justify-content:center;
    font-family:'League Spartan',sans-serif;font-size:11px;font-weight:800;
    background:var(--panel);border:1px solid var(--line);color:var(--dim);
  }
  .tc-choose-opt.recommended .tc-choose-opt-letter{
    background:color-mix(in srgb,var(--accent) 18%,var(--panel2));
    border-color:color-mix(in srgb,var(--accent) 38%,var(--line));
    color:var(--accent);
  }
  .tc-choose-opt-body{flex:1;min-width:0;}
  .tc-choose-opt-title{
    font-family:'League Spartan',sans-serif;font-size:12.5px;font-weight:700;
    color:var(--ink);display:flex;align-items:center;gap:6px;
  }
  .tc-choose-opt-desc{font-size:11.5px;color:var(--dim);margin-top:2px;line-height:1.4;}
  .tc-opt-pick,.tc-opt-ghost{
    font-family:'League Spartan',sans-serif;font-size:11px;font-weight:700;
    padding:5px 12px;border-radius:8px;cursor:pointer;flex:none;
    transition:all .15s;
  }
  .tc-opt-pick{
    background:var(--accent);color:#fff;border:none;
  }
  [data-entity="theline"] .tc-opt-pick{background:var(--warm);}
  [data-entity="trailbuildr"] .tc-opt-pick{background:var(--tb);}
  .tc-opt-ghost{
    background:transparent;border:1px solid var(--line);color:var(--dim);
  }
  .tc-opt-ghost:hover{border-color:var(--dim);color:var(--ink);}

  /* ---- TYPE 5: RANK -- Option B (big numbers + handle arrows) ---- */
  .tc-rank-list-b{display:flex;flex-direction:column;gap:6px;padding:0 14px 12px;}
  .tc-rank-item-b{
    display:flex;align-items:center;gap:10px;
    background:var(--panel2);border:1px solid var(--line);
    border-radius:10px;padding:8px 10px;
  }
  .tc-rank-num-b{
    font-family:'League Spartan',sans-serif;font-size:28px;font-weight:900;
    color:var(--amber);width:36px;flex:none;text-align:center;line-height:1;
    letter-spacing:-0.02em;
  }
  .tc-rank-body-b{flex:1;min-width:0;}
  .tc-rank-label-b{
    font-family:'League Spartan',sans-serif;font-size:13px;font-weight:700;color:var(--ink);
  }
  .tc-rank-reason-b{font-size:11.5px;color:var(--dim);margin-top:2px;}
  .tc-rank-handles{display:flex;flex-direction:column;gap:3px;flex:none;}
  .tc-rank-handle{
    display:flex;align-items:center;justify-content:center;
    width:24px;height:20px;border-radius:5px;
    border:1px solid var(--line);background:var(--panel);
    color:var(--dim);cursor:pointer;transition:all .12s;
  }
  .tc-rank-handle:hover:not([disabled]){border-color:var(--dim);color:var(--ink);}
  .tc-rank-handle[disabled]{opacity:.3;cursor:default;}

  /* ---- TYPE 4: STRATEGY -- Option B (summary first, brief behind tap) ---- */
  .tc-strategy-summary{
    font-family:'Arimo',sans-serif;font-size:14.5px;color:var(--ink);
    line-height:1.6;padding:12px 14px;font-weight:500;
  }
  .tc-strategy-brief-toggle{padding:0 14px 12px;}
  .tc-strategy-brief-btn{
    font-family:'League Spartan',sans-serif;font-size:11.5px;font-weight:700;
    letter-spacing:.04em;
    border:1px solid var(--line);background:transparent;color:var(--dim);
    padding:6px 12px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
    transition:all .15s;margin-bottom:8px;
  }
  .tc-strategy-brief-btn:hover{border-color:var(--dim);color:var(--ink);}
  .tc-strategy-brief-body{
    font-family:'Arimo',sans-serif;font-size:13px;color:var(--dim);
    line-height:1.65;white-space:pre-wrap;word-break:break-word;
    background:var(--panel2);border:1px solid var(--line);border-radius:8px;
    padding:10px 12px;max-height:260px;overflow-y:auto;scrollbar-width:thin;
  }

  /* ---- TYPE 8: WALKTHROUGH -- Option A (thin segmented progress bar) ---- */
  .wt-progress-bar{
    display:flex;align-items:center;gap:8px;
    padding:0 14px 10px;
  }
  .wt-segs{display:flex;gap:4px;align-items:center;}
  .wt-seg{
    height:4px;flex:1;min-width:16px;max-width:36px;border-radius:999px;
    background:var(--line);transition:background .2s;
  }
  .wt-seg-done{background:var(--accent);}
  .wt-seg-active{background:var(--accent);opacity:.6;}
  [data-entity="theline"] .wt-seg-done,
  [data-entity="theline"] .wt-seg-active{background:var(--warm);}
  [data-entity="trailbuildr"] .wt-seg-done,
  [data-entity="trailbuildr"] .wt-seg-active{background:var(--tb);}
  .wt-step-label{
    font-family:'Arimo',sans-serif;font-size:11px;color:var(--faint);white-space:nowrap;
  }

  /* ---- TYPE 9: COMMS / EMAIL -- Option B (Copy + Approve side by side) ---- */
  .tc-comms-draft-panel{
    margin:0 14px 12px;
    background:var(--panel2);border:1px solid var(--line);border-radius:10px;overflow:hidden;
  }
  .tc-comms-draft-label{
    font-family:'League Spartan',sans-serif;font-size:9px;font-weight:800;letter-spacing:.14em;
    text-transform:uppercase;color:var(--faint);
    padding:6px 12px 5px;border-bottom:1px solid var(--line);
  }
  .tc-comms-draft-body{
    font-family:'Arimo',sans-serif;font-size:13.5px;color:var(--ink);
    line-height:1.65;padding:12px;white-space:pre-wrap;word-break:break-word;
    max-height:220px;overflow-y:auto;scrollbar-width:thin;
  }
  .tc-comms-action-row{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;
    padding:0 14px 12px;
  }
  .tc-comms-action-row .primary{flex:1;}
  .tc-comms-action-row .secondary{flex:none;}
  /* "Approve and copy" label is set directly in renderCommsCard -- no extra CSS needed */

  /* ---- COPY DRAFT BUTTON (generic) ---- */
  .copy-draft-btn{
    font-family:'League Spartan',sans-serif;font-size:11px;font-weight:700;
    letter-spacing:.05em;text-transform:uppercase;
    padding:7px 13px;border-radius:8px;
    border:1px solid var(--line);background:transparent;color:var(--dim);
    cursor:pointer;transition:all .15s;
  }
  .copy-draft-btn:hover{border-color:var(--dim);color:var(--ink);}
  .copy-draft-btn.copied{color:var(--green);border-color:var(--green);}
