/* =========================================================
   Agentic Bid Package — shared design tokens & primitives
   Matches Qi Sourcing prototype design language.
   ========================================================= */

:root{
  /* Surfaces */
  --bg:#FFFFFF;
  --bg-canvas:#F7F8FA;
  --bg-subtle:#F4F5F7;
  --bg-row:#FAFBFC;

  /* Text */
  --t-1:#0F1115;
  --t-2:#3F4651;
  --t-3:#6B7380;
  --t-4:#98A0AC;
  --t-link:#1F4FD9;

  /* Borders */
  --bd:#E5E7EB;
  --bd-strong:#D1D5DB;
  --bd-soft:#EEF0F3;

  /* Brand / button */
  --black:#0A0A0F;
  --black-hover:#1A1A20;

  /* Severity */
  --danger:#D92D20;
  --danger-bg:#FEF3F2;
  --danger-bd:#FDA29B;
  --warn:#B54708;
  --warn-bg:#FFFAEB;
  --warn-bd:#FEDF89;
  --success:#067647;
  --success-bg:#ECFDF3;
  --success-bd:#ABEFC6;
  --info:#0E7090;
  --info-bg:#ECFDFF;
  --info-bd:#A5F0FC;

  /* Qi / AI */
  --qi:#7C3AED;
  --qi-deep:#5B21B6;
  --qi-soft:#F5F3FF;
  --qi-soft-2:#EDE8FF;
  --qi-bd:#DDD0FF;
  --qi-grad: linear-gradient(92deg,#F59E0B 0%,#EC4899 36%,#8B5CF6 70%,#4F46E5 100%);

  /* Radii */
  --r-xs:4px;
  --r-sm:6px;
  --r:8px;
  --r-lg:12px;
  --r-xl:16px;
  --r-pill:999px;

  /* Shadow */
  --sh-1:0 1px 2px rgba(15,17,21,.04);
  --sh-2:0 1px 3px rgba(15,17,21,.06), 0 1px 2px rgba(15,17,21,.04);
  --sh-3:0 8px 24px rgba(15,17,21,.08);
  --sh-pop:0 12px 32px rgba(15,17,21,.10), 0 2px 6px rgba(15,17,21,.06);

  /* Layout */
  --header-h:60px;
  --side-w:420px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg-canvas);color:var(--t-1);font-family:'Inter',system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;font-size:14px;line-height:20px;-webkit-font-smoothing:antialiased;font-feature-settings:'cv11','ss01','ss03'}
body{min-height:100vh}

button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;font-size:inherit}
a{color:var(--t-link);text-decoration:none}
a:hover{text-decoration:underline}
input,textarea,select{font-family:inherit;font-size:14px;color:var(--t-1)}
:focus-visible{outline:2px solid var(--qi);outline-offset:2px;border-radius:6px}

/* ===== Header ===== */
.app-h{height:var(--header-h);background:#fff;border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 20px;gap:16px;position:sticky;top:0;z-index:30}
.app-h .logo{font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--t-1);display:flex;align-items:center;gap:6px}
.app-h .logo .o{color:#1F4FD9}
.app-h .spacer{flex:1}
.app-h .pill-tasks{height:36px;border:1px solid var(--bd-strong);border-radius:var(--r);padding:0 14px;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--t-2);background:#fff}
.app-h .pill-tasks .ic{width:16px;height:16px;color:var(--t-3)}
.app-h .icon-btn{width:36px;height:36px;border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;color:var(--t-2)}
.app-h .icon-btn:hover{background:var(--bg-subtle)}
.app-h .qi-icon{width:28px;height:28px;border-radius:var(--r-pill);background:var(--qi-grad);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;letter-spacing:-.02em}
.app-h .avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#FFD2A1,#F39A6B);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}
.app-h .divider{width:1px;height:24px;background:var(--bd);margin:0 4px}

/* ===== Page chrome ===== */
.page{padding:24px;margin:0}
.crumbs{font-size:12px;color:var(--t-3);margin-bottom:8px;display:flex;gap:6px;align-items:center}
.crumbs a{color:var(--t-3)}
.crumbs .sep{color:var(--t-4)}
.title-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:4px}
.back-btn{width:32px;height:32px;border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;color:var(--t-2);background:transparent}
.back-btn:hover{background:var(--bg-subtle)}
h1.doc-title{margin:0;font-size:24px;font-weight:700;line-height:32px;letter-spacing:-.01em}
.status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--bd-strong);border-radius:var(--r-pill);font-size:12px;font-weight:500;color:var(--t-2);background:#fff;height:24px}
.status-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--warn)}
.title-meta{font-size:12px;color:var(--t-3);margin-left:44px}
.title-actions{margin-left:auto;display:flex;align-items:center;gap:8px}

/* ===== Buttons ===== */
.btn{height:36px;padding:0 14px;border-radius:var(--r);border:1px solid var(--bd-strong);background:#fff;color:var(--t-1);font-weight:500;display:inline-flex;align-items:center;gap:6px;font-size:13px;white-space:nowrap;transition:all .12s ease}
.btn:hover{border-color:var(--t-3)}
.btn.primary{background:var(--black);color:#fff;border-color:var(--black)}
.btn.primary:hover{background:var(--black-hover);border-color:var(--black-hover)}
.btn.ghost{border-color:transparent}
.btn.ghost:hover{background:var(--bg-subtle)}
.btn.sm{height:30px;padding:0 10px;font-size:12px;border-radius:var(--r-sm)}
.btn.qi{background:#fff;color:var(--qi-deep);border:1px solid var(--qi-bd);font-weight:600}
.btn.qi:hover{background:var(--qi-soft)}
.btn.qi-solid{background:var(--qi-grad);color:#fff;border-color:transparent;font-weight:600;box-shadow:0 2px 8px rgba(124,58,237,.20)}
.btn.qi-solid:hover{filter:brightness(1.05)}
.btn .caret{width:12px;height:12px;opacity:.7}
.icon-btn{width:36px;height:36px;border-radius:var(--r);background:#fff;border:1px solid var(--bd-strong);display:inline-flex;align-items:center;justify-content:center;color:var(--t-2)}
.icon-btn:hover{background:var(--bg-subtle)}
.icon-btn.ghost{border-color:transparent;background:transparent}
.icon-btn.ghost:hover{background:var(--bg-subtle)}

/* ===== Stage progress ===== */
.stages{display:grid;grid-template-columns:repeat(6,1fr) auto;gap:24px;align-items:center;padding:18px 0 4px;margin-top:14px;border-top:1px solid var(--bd-soft)}
.stage{position:relative}
.stage .bar{height:3px;background:var(--bd);border-radius:2px;margin-bottom:10px}
.stage.done .bar{background:#11C56A}
.stage.active .bar{background:#F59E0B}
.stage.active .bar{background:linear-gradient(90deg,#F59E0B 0%,#FDBA74 100%)}
.stage .lbl{font-size:13px;color:var(--t-3);display:flex;align-items:center;gap:6px}
.stage.active .lbl{color:var(--t-1);font-weight:600}
.stage .lbl .ring{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--bd-strong)}
.stage.done .lbl .ring{background:#11C56A;border-color:#11C56A}
.stage.active .lbl .ring{background:#F59E0B;border-color:#F59E0B;box-shadow:0 0 0 3px #FEF3C7}

/* ===== Tabs ===== */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--bd);margin-top:18px;margin-bottom:24px}
.tabs .tab{padding:12px 18px;font-size:14px;color:var(--t-3);font-weight:500;border-bottom:2px solid transparent;cursor:pointer;background:none}
.tabs .tab:hover{color:var(--t-1)}
.tabs .tab.active{color:var(--t-1);border-bottom-color:var(--t-1);font-weight:600}

/* ===== AI Summary card ===== */
.qi-summary{position:relative;border-radius:14px;padding:1.5px;background:var(--qi-grad);margin-bottom:20px}
.qi-summary-in{background:#fff;border-radius:12.5px;padding:20px 22px}
.qi-summary .row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.qi-summary .row h2{margin:0;font-size:14px;font-weight:600;color:var(--t-1);display:flex;align-items:center;gap:8px}
.qi-summary .row .resolve{margin-left:auto;display:inline-flex;align-items:center;gap:6px;color:var(--qi-deep);font-weight:600;font-size:13px;background:transparent;padding:0}
.qi-summary p{margin:0 0 6px;color:var(--t-2);font-size:14px;line-height:22px}
.qi-summary p strong{color:var(--t-1);font-weight:600}
.qi-summary .kpi{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:18px;padding-top:16px;border-top:1px solid var(--bd-soft)}
.qi-summary .kpi .l{font-size:12px;color:var(--t-3);margin-bottom:4px;font-weight:500}
.qi-summary .kpi .v{font-size:24px;font-weight:700;color:var(--t-1);letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.qi-summary .kpi .v small{font-size:13px;font-weight:500;color:var(--t-3);margin-left:6px}
.qi-summary .disc{margin-top:14px;padding-top:14px;border-top:1px solid var(--bd-soft);font-size:12px;color:var(--t-4);font-style:italic}

/* ===== Insight cards ===== */
.insights-h{display:flex;align-items:center;gap:12px;margin:8px 0 14px}
.insights-h h2{margin:0;font-size:16px;font-weight:600}
.insights-h .count{color:var(--t-3);font-weight:500;font-size:14px}
.insights{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:32px}
.insight{background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column}
.insight-h{padding:14px 16px 10px;display:flex;align-items:flex-start;gap:8px}
.insight-h h3{margin:0;font-size:14px;font-weight:600;color:var(--t-1);line-height:20px;flex:1}
.insight .desc{padding:0 16px 14px;color:var(--t-2);font-size:13px;line-height:20px;flex:1}
.insight .ai-foot{background:var(--qi-soft);border-top:1px solid var(--qi-bd);padding:12px 16px;display:flex;align-items:flex-start;gap:8px;flex-direction:column}
.insight .ai-foot .row{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--qi-deep);font-weight:600;width:100%}
.insight .ai-foot .row .pill{margin-left:auto;font-size:11px;font-weight:500;color:var(--t-3);background:#fff;border:1px solid var(--bd);padding:2px 8px;border-radius:var(--r-pill)}
.insight .ai-foot .body{font-size:13px;color:var(--t-2);line-height:19px}
.insight .ai-foot .body strong{color:var(--t-1)}
.insight .ai-foot .actions{display:flex;align-items:center;gap:8px;width:100%}
.insight .ai-foot .btn.qi{height:32px}
.insight .ai-foot .skip{margin-left:auto;color:var(--t-3);font-size:12px;font-weight:500;background:none;padding:4px 8px;border-radius:var(--r-sm)}
.insight .ai-foot .skip:hover{background:#fff}

/* Severity pill */
.sev{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--r-pill);font-size:11px;font-weight:600;border:1px solid;letter-spacing:.02em}
.sev.blocker{color:var(--danger);border-color:var(--danger-bd);background:var(--danger-bg)}
.sev.warning{color:var(--warn);border-color:var(--warn-bd);background:var(--warn-bg)}
.sev.info{color:var(--info);border-color:var(--info-bd);background:var(--info-bg)}
.sev.ok{color:var(--success);border-color:var(--success-bd);background:var(--success-bg)}

/* ===== Section card (list block) ===== */
.section{background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);overflow:hidden;margin-bottom:18px;box-shadow:var(--sh-1)}
.section-h{padding:14px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--bd-soft)}
.section-h .chev{color:var(--t-3);width:18px;height:18px}
.section-h h2{margin:0;font-size:15px;font-weight:600}
.section-h .count{color:var(--t-3);font-weight:500;font-size:14px}
.section-h .actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.section-h .qi-line{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--qi-deep);font-weight:500;padding:4px 8px;background:var(--qi-soft);border:1px solid var(--qi-bd);border-radius:var(--r-pill)}
.search-input{height:32px;border:1px solid var(--bd-strong);border-radius:var(--r);padding:0 12px 0 32px;width:240px;font-size:13px;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7380' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>") no-repeat 10px 50%}

/* ===== Tables ===== */
table.list{width:100%;border-collapse:collapse;font-size:13px}
table.list th{background:var(--bg-row);text-align:left;padding:10px 16px;font-weight:600;color:var(--t-2);border-bottom:1px solid var(--bd-soft);font-size:12px}
table.list td{padding:14px 16px;border-bottom:1px solid var(--bd-soft);color:var(--t-1);vertical-align:middle}
table.list tr:last-child td{border-bottom:0}
table.list tr:hover td{background:#FCFCFD}
table.list .name a{color:var(--t-link);font-weight:500}
table.list .check{width:36px}
table.list .check input{accent-color:var(--qi)}
table.list .row-status{display:inline-flex;align-items:center;gap:6px}
table.list .ai-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--qi-deep);background:var(--qi-soft);border:1px solid var(--qi-bd);padding:2px 8px;border-radius:var(--r-pill)}
table.list .ai-tag .dot{width:5px;height:5px;border-radius:50%;background:var(--qi)}

/* Coverage bar */
.cov{display:flex;align-items:center;gap:8px}
.cov-bar{width:80px;height:6px;border-radius:3px;background:var(--bd-soft);overflow:hidden}
.cov-bar .fill{display:block;height:100%;border-radius:3px}
.cov.good .fill{background:#11C56A}
.cov.warn .fill{background:#F59E0B}
.cov.bad .fill{background:#E5484D}
.cov .num{font-size:12px;color:var(--t-2);font-variant-numeric:tabular-nums;font-weight:500}

/* Avatar mini */
.who{display:flex;align-items:center;gap:8px}
.who .av{width:24px;height:24px;border-radius:50%;background:#E5E7EB;color:var(--t-2);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}

/* ===== Qi side panel ===== */
.qi-panel{position:fixed;top:0;right:0;height:100vh;width:var(--side-w);background:#fff;border-left:1px solid var(--bd);box-shadow:var(--sh-pop);display:flex;flex-direction:column;z-index:50;transform:translateX(0);transition:transform .25s cubic-bezier(.2,.8,.2,1)}
.qi-panel.hidden{transform:translateX(100%)}
.qi-panel-h{height:56px;padding:0 12px 0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--bd)}
.qi-panel-h .toggle{width:32px;height:32px;border-radius:var(--r);display:inline-flex;align-items:center;justify-content:center;color:var(--t-3)}
.qi-panel-h .toggle:hover{background:var(--bg-subtle)}
.qi-panel-h h3{margin:0;font-size:14px;font-weight:600;flex:1;display:flex;align-items:center;gap:6px}
.qi-panel-h h3 .caret{color:var(--t-3)}
.qi-panel-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px}
.qi-msg{display:flex;gap:10px}
.qi-msg.user{justify-content:flex-end}
.qi-msg.user .bubble{background:var(--bg-subtle);border-radius:14px 14px 2px 14px;padding:8px 12px;font-size:13px;color:var(--t-1);max-width:280px}
.qi-msg .av{width:24px;height:24px;border-radius:50%;flex:0 0 auto;align-self:flex-start;margin-top:4px}
.qi-msg.user .av{background:linear-gradient(135deg,#FFD2A1,#F39A6B);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:11px}
.qi-msg.qi .av{background:var(--qi-grad);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:11px}
.qi-msg.qi .body{flex:1;font-size:13px;line-height:20px;color:var(--t-1)}
.qi-thoughts{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--t-3);font-weight:500;margin-bottom:6px;cursor:pointer}
.qi-thoughts:hover{color:var(--t-2)}
.qi-card{background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);padding:14px;margin-top:10px;box-shadow:var(--sh-1)}
.qi-card .hd{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.qi-card .hd .name{font-weight:600;font-size:13px;flex:1}
.qi-card .hd .arrow{color:var(--t-3)}
.qi-card .tags{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.qi-card .tag{font-size:11px;padding:2px 8px;border-radius:var(--r-pill);border:1px solid var(--info-bd);color:var(--info);background:var(--info-bg);font-weight:500}
.qi-card .conf{font-size:12px;color:var(--t-3);margin-top:6px}
.qi-card .conf strong{color:var(--qi-deep);font-weight:600}
.qi-card .reason{font-size:13px;color:var(--t-2);line-height:20px}
.qi-card .reason .lb{font-weight:600;color:var(--t-1);display:block;margin-bottom:2px}

.qi-panel-foot{border-top:1px solid var(--bd);padding:12px 14px}
.qi-input-wrap{position:relative;border:1px solid var(--bd-strong);border-radius:var(--r-lg);padding:8px 12px 8px 12px;background:#fff;display:flex;flex-direction:column;gap:6px}
.qi-input-wrap textarea{border:0;outline:none;resize:none;width:100%;font-size:13px;line-height:18px;color:var(--t-1);min-height:36px;padding:6px 0;background:transparent}
.qi-input-wrap textarea::placeholder{color:var(--t-4)}
.qi-input-tools{display:flex;align-items:center;gap:4px}
.qi-input-tools .send{margin-left:auto;width:28px;height:28px;border-radius:var(--r-sm);background:var(--black);color:#fff;display:inline-flex;align-items:center;justify-content:center}
.qi-disc{font-size:11px;color:var(--t-4);text-align:center;margin-top:8px;font-style:italic}

/* Reasoning trace */
.thoughts-trace{margin:6px 0 10px;background:var(--bg-subtle);border-left:2px solid var(--qi-bd);padding:8px 12px;font-size:12px;color:var(--t-3);line-height:18px;border-radius:0 var(--r-sm) var(--r-sm) 0}

/* ===== Quick action chips ===== */
.q-chips{display:flex;flex-wrap:wrap;gap:8px}
.q-chip{height:30px;padding:0 12px;border:1px solid var(--bd-strong);border-radius:var(--r-pill);background:#fff;font-size:12px;color:var(--t-2);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.q-chip:hover{border-color:var(--qi);color:var(--qi-deep);background:var(--qi-soft)}

/* ===== Editor split layout (questionnaire / pricesheet edit) ===== */
.edit-shell{display:grid;grid-template-columns:240px 1fr var(--side-w);gap:16px;align-items:flex-start}
.edit-shell.no-panel{grid-template-columns:240px 1fr}
.edit-side{position:sticky;top:calc(var(--header-h) + 16px);background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);padding:8px;max-height:calc(100vh - var(--header-h) - 32px);overflow-y:auto}
.edit-side .lbl{font-size:11px;color:var(--t-3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:8px 10px 6px}
.edit-side .li{padding:8px 10px;border-radius:var(--r-sm);display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--t-2);font-size:13px}
.edit-side .li:hover{background:var(--bg-subtle)}
.edit-side .li.active{background:var(--qi-soft);color:var(--qi-deep);font-weight:600}
.edit-side .li .num{width:20px;height:20px;border-radius:6px;background:var(--bg-subtle);color:var(--t-3);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.edit-side .li.active .num{background:var(--qi);color:#fff}
.edit-side .li .ai-flag{margin-left:auto;width:6px;height:6px;border-radius:50%;background:var(--warn)}
.edit-side .add{width:100%;text-align:left;padding:8px 10px;color:var(--t-3);font-size:13px;display:flex;align-items:center;gap:8px;border-radius:var(--r-sm);font-weight:500}
.edit-side .add:hover{color:var(--qi-deep);background:var(--qi-soft)}

.edit-main{background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-1)}

/* Question card (in builder) */
.qq{border:1px solid var(--bd);border-radius:var(--r-lg);padding:18px;margin-bottom:14px;background:#fff;position:relative}
.qq.focus{border-color:var(--qi);box-shadow:0 0 0 3px var(--qi-soft)}
.qq .meta{display:flex;align-items:center;gap:10px;margin-bottom:8px;font-size:12px;color:var(--t-3)}
.qq .meta .num{font-weight:600;color:var(--t-1)}
.qq .meta .star{color:var(--danger);font-weight:600}
.qq .meta .type{padding:2px 8px;background:var(--bg-subtle);border-radius:var(--r-sm);font-weight:500;color:var(--t-2)}
.qq .meta .qi-tag{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--qi-deep);font-weight:600;background:var(--qi-soft);padding:2px 8px;border-radius:var(--r-pill);border:1px solid var(--qi-bd)}
.qq h4{margin:0 0 12px;font-size:15px;font-weight:600;line-height:22px}
.qq .answer{background:var(--bg-subtle);border:1px dashed var(--bd-strong);border-radius:var(--r);padding:12px 14px;color:var(--t-3);font-size:13px;font-style:italic}
.qq .qi-ribbon{margin-top:12px;padding:10px 12px;background:var(--qi-soft);border:1px solid var(--qi-bd);border-radius:var(--r);display:flex;align-items:center;gap:10px;font-size:13px;color:var(--qi-deep)}
.qq .qi-ribbon .body{color:var(--t-2);flex:1}
.qq .qi-ribbon .body strong{color:var(--t-1)}
.qq .qi-ribbon .actions{display:flex;align-items:center;gap:6px}
/* Inline action buttons in meta row (replaces absolute toolbar) */
.qq .qq-actions{display:inline-flex;gap:2px;margin-left:6px;opacity:.6;transition:opacity .12s}
.qq:hover .qq-actions, .qq.focus .qq-actions{opacity:1}
.qq .qq-actions .icon-btn{width:28px;height:28px;border-radius:var(--r-sm);border-color:transparent;background:transparent}
.qq .qq-actions .icon-btn:hover{background:var(--bg-subtle);color:var(--t-1)}

/* ===== Editable inputs that look like static text in draft state ===== */
textarea.editable-h{font-family:inherit;font-size:15px;font-weight:600;line-height:22px;color:var(--t-1);width:100%;border:1px solid transparent;border-radius:var(--r-sm);padding:8px 10px;background:transparent;resize:none;display:block;margin:0 0 12px;outline:none;min-height:38px;transition:background .12s, border-color .12s, box-shadow .12s}
textarea.editable-h:hover{background:var(--bg-subtle);border-color:var(--bd-soft);cursor:text}
textarea.editable-h:focus{background:#FCFAFF;border-color:var(--qi);box-shadow:0 0 0 3px var(--qi-soft);cursor:text}

.editable-inline{font:inherit;background:transparent;border:1px solid transparent;border-radius:4px;padding:1px 6px;color:inherit;outline:none;min-width:30px;width:auto;transition:all .12s}
.editable-inline:hover{background:var(--bg-subtle);border-color:var(--bd-soft);cursor:text}
.editable-inline:focus{background:#fff;border-color:var(--qi);box-shadow:0 0 0 2px var(--qi-soft);cursor:text}
input[type=number].editable-inline{width:48px;text-align:right;font-variant-numeric:tabular-nums}

/* "Click to edit" hint icon */
.edit-hint{display:inline-flex;align-items:center;gap:4px;color:var(--t-4);font-size:11px;font-weight:500;cursor:pointer;padding:1px 6px;border-radius:4px;border:1px dashed var(--bd-strong);background:transparent}
.edit-hint:hover{color:var(--t-2);background:var(--bg-subtle);border-color:var(--bd-strong)}

/* Type/select chip — looks like a tag, click to change */
.type-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 8px;background:var(--bg-subtle);border:1px solid var(--bd);border-radius:var(--r-sm);color:var(--t-2);cursor:pointer;transition:all .12s}
.type-chip:hover{background:#fff;border-color:var(--bd-strong);color:var(--t-1)}
.type-chip .caret{width:10px;height:10px;opacity:.7}

/* ===== Qi "thinking" loading state (used after Generate is clicked) ===== */
.qi-thinking{background:#fff;border-radius:14px;padding:1.5px;background:var(--qi-grad);overflow:hidden;margin-bottom:18px}
.qi-thinking-in{background:#fff;border-radius:12.5px;padding:18px 20px}
.qi-thinking .head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.qi-thinking .head .av{width:24px;height:24px;border-radius:50%;background:var(--qi-grad);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;animation:qi-pulse 1.6s ease-in-out infinite}
.qi-thinking .head h3{margin:0;font-size:14px;font-weight:600}
.qi-thinking .head .pill{margin-left:auto;font-size:11px;color:var(--qi-deep);font-weight:600;background:var(--qi-soft);border:1px solid var(--qi-bd);padding:2px 8px;border-radius:var(--r-pill)}
.qi-thinking p.lede{margin:0 0 12px;color:var(--t-2);font-size:14px;line-height:22px}
@keyframes qi-pulse{0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,.45)}50%{box-shadow:0 0 0 6px rgba(124,58,237,0)}}

.thinking-steps{display:flex;flex-direction:column;gap:2px;padding-top:6px;border-top:1px solid var(--bd-soft)}
.thinking-steps .step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--t-2);padding:8px 0}
.thinking-steps .step .ic{width:20px;height:20px;border-radius:50%;background:var(--bg-subtle);display:inline-flex;align-items:center;justify-content:center;color:var(--t-3);font-size:11px;flex:0 0 auto;border:1.5px solid var(--bd)}
.thinking-steps .step.done{color:var(--t-2)}
.thinking-steps .step.done .ic{background:var(--success);border-color:var(--success);color:#fff}
.thinking-steps .step.active{color:var(--t-1);font-weight:500}
.thinking-steps .step.active .ic{background:var(--qi);border-color:var(--qi);color:#fff;animation:qi-pulse 1.2s ease-in-out infinite}
.thinking-steps .step.pending{color:var(--t-4)}
.thinking-steps .step .meta{margin-left:auto;font-size:11px;color:var(--t-4);font-variant-numeric:tabular-nums;font-weight:500}

.skel{background:linear-gradient(90deg,#EEF0F3 0%,#F8F9FB 50%,#EEF0F3 100%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== Suggest-3 inline panel ===== */
.qi-proposal{margin-top:14px;background:#fff;border:1.5px solid var(--qi-bd);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 4px 14px rgba(124,58,237,.08)}
.qi-proposal-h{padding:12px 16px;background:var(--qi-soft);border-bottom:1px solid var(--qi-bd);display:flex;align-items:center;gap:10px}
.qi-proposal-h .av{width:22px;height:22px;border-radius:50%;background:var(--qi-grad);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:10px;flex:0 0 auto}
.qi-proposal-h h4{margin:0;font-size:13px;font-weight:600;color:var(--qi-deep);flex:1}
.qi-proposal-h .pill{font-size:10px;font-weight:700;color:var(--qi-deep);background:#fff;border:1px solid var(--qi-bd);padding:2px 8px;border-radius:var(--r-pill)}
.qi-proposal-list{padding:6px 6px 12px}
.qi-prop{padding:12px;border-radius:var(--r);display:flex;flex-direction:column;gap:6px}
.qi-prop:hover{background:var(--bg-subtle)}
.qi-prop .pmeta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--t-3);font-weight:500}
.qi-prop .pmeta .num{font-weight:700;color:var(--qi-deep)}
.qi-prop .ptype{font-size:11px;color:var(--t-3);background:var(--bg-subtle);padding:1px 8px;border-radius:var(--r-sm);font-weight:500;border:1px solid var(--bd)}
.qi-prop .ptext{font-size:14px;color:var(--t-1);line-height:21px;font-weight:500;background:#fff;border:1px solid var(--bd);border-radius:var(--r-sm);padding:8px 10px;cursor:text}
.qi-prop .ptext:hover{border-color:var(--bd-strong)}
.qi-prop .pact{display:flex;align-items:center;gap:6px;margin-top:4px}
.qi-prop .pact .skip{margin-left:auto;color:var(--t-3);font-size:12px;background:none;padding:4px 8px;border-radius:4px}
.qi-prop .pact .skip:hover{color:var(--t-1);background:var(--bg-subtle)}
.qi-proposal-foot{padding:10px 16px;border-top:1px solid var(--bd-soft);background:#FAFBFC;display:flex;align-items:center;gap:8px}
.qi-proposal-foot .meta{font-size:12px;color:var(--t-3);flex:1}

/* ===== Pricesheet cell editable styling ===== */
table.grid input.cell-input{width:100%;height:38px;padding:0 12px;border:0;background:transparent;font-size:13px;color:var(--t-1);outline:none;font-variant-numeric:tabular-nums;font-feature-settings:'tnum'}
table.grid input.cell-input:focus{box-shadow:inset 0 0 0 2px var(--qi);background:#FCFAFF}
table.grid td.cell-num input.cell-input{text-align:right}
table.grid select.cell-input{appearance:none;-webkit-appearance:none;width:100%;height:38px;padding:0 12px;border:0;background:transparent;font-size:13px;color:var(--t-1);outline:none;cursor:pointer}
table.grid select.cell-input:hover{background:var(--bg-subtle)}
table.grid select.cell-input:focus{box-shadow:inset 0 0 0 2px var(--qi);background:#FCFAFF}
table.grid td.cell-baseline{position:relative}
table.grid td.cell-baseline input.cell-input{padding-left:48px;text-align:right}
table.grid td.cell-baseline .conf-chip{position:absolute;left:8px;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none}
table.grid td.cell-baseline .qi-dot{position:absolute;right:8px;top:50%;transform:translateY(-50%);pointer-events:none}
table.grid td.cell-baseline.has-qi input.cell-input{padding-right:32px}

/* Hidden util */
.is-hidden{display:none!important}

/* AI generate button row in builder */
.gen-row{display:flex;align-items:center;gap:10px;padding:18px;border:1.5px dashed var(--qi-bd);border-radius:var(--r-lg);background:linear-gradient(180deg,#fff,var(--qi-soft));margin-top:8px}
.gen-row .body{flex:1;font-size:13px;color:var(--t-2)}
.gen-row .body strong{color:var(--t-1)}

/* ===== Price sheet grid ===== */
.ps-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--bd-soft);flex-wrap:wrap}
.ps-toolbar .ai-band{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:var(--qi-soft);border:1px solid var(--qi-bd);border-radius:var(--r);font-size:12px;color:var(--qi-deep);font-weight:500}
.ps-toolbar .grow{flex:1}
.grid-wrap{overflow-x:auto}
table.grid{width:100%;border-collapse:collapse;font-size:13px;min-width:980px}
table.grid th{background:var(--bg-row);text-align:left;padding:10px 12px;font-weight:600;color:var(--t-2);border-bottom:1px solid var(--bd-soft);font-size:12px;white-space:nowrap;position:sticky;top:0}
table.grid th .req{color:var(--danger)}
table.grid td{padding:0;border-bottom:1px solid var(--bd-soft);vertical-align:middle}
table.grid td > div, table.grid td > span{padding:10px 12px;display:block}
table.grid td.cell-num{text-align:right;font-variant-numeric:tabular-nums;font-feature-settings:'tnum'}
table.grid td.cell-num > div{text-align:right}
table.grid td.cell-edit{padding:0}
table.grid td.cell-edit input{width:100%;height:38px;padding:0 12px;border:0;background:transparent;font-size:13px;color:var(--t-1);outline:none}
table.grid td.cell-edit input:focus{box-shadow:inset 0 0 0 2px var(--qi);background:#fff}
table.grid td .ai-fill{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:6px}
table.grid td .ai-fill .v{font-variant-numeric:tabular-nums;font-weight:500}
table.grid td .qi-dot{width:16px;height:16px;border-radius:4px;background:var(--qi-soft);border:1px solid var(--qi-bd);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
table.grid td .qi-dot svg{width:10px;height:10px;color:var(--qi)}
table.grid tr.row-flag td{background:var(--warn-bg)}
table.grid td.cell-flag{width:28px;text-align:center}
table.grid td.cell-flag svg{color:var(--warn);width:16px;height:16px;vertical-align:middle;display:inline-block;padding:0}
table.grid tr:hover td{background:#FCFCFD}
table.grid tr.row-flag:hover td{background:#FDF6E5}
table.grid td.cell-name{font-weight:500}
table.grid td.cell-name a{color:var(--t-link)}

/* Confidence chip in cell */
.conf-chip{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--qi-deep);background:var(--qi-soft);border:1px solid var(--qi-bd);padding:1px 6px;border-radius:var(--r-pill);font-weight:600}

/* Tooltip */
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--t-1);color:#fff;font-size:11px;padding:6px 10px;border-radius:var(--r-sm);white-space:nowrap;z-index:100;font-weight:500;box-shadow:var(--sh-3)}

/* Overlay toggle button at far right of header (for re-opening Qi) */
.qi-fab{position:fixed;right:20px;bottom:20px;height:44px;padding:0 16px;border-radius:var(--r-pill);background:var(--qi-grad);color:#fff;font-weight:600;display:inline-flex;align-items:center;gap:8px;border:0;box-shadow:var(--sh-pop);z-index:25;cursor:pointer;font-size:13px}
.qi-fab.hidden{display:none}

/* ===== Helpers ===== */
.ml-auto{margin-left:auto}
.flex{display:flex}
.gap-8{gap:8px}
.gap-12{gap:12px}
.mb-0{margin-bottom:0}
.mt-0{margin-top:0}
.mt-12{margin-top:12px}
.mt-20{margin-top:20px}
.muted{color:var(--t-3)}
.small{font-size:12px}
.sparkle{color:var(--qi)}
.nowrap{white-space:nowrap}
.kbd{font-family:'JetBrains Mono','Menlo',monospace;font-size:11px;padding:2px 6px;background:var(--bg-subtle);border:1px solid var(--bd);border-radius:4px;color:var(--t-2)}

/* When panel is open, push main content (optional, for desktop only) */
@media (min-width:1280px){
  body.panel-open .page{padding-right:calc(var(--side-w) + 24px)}
}

/* "Add" dropdown (Blank / From repository) */
.add-dd{position:relative;display:inline-block}
.add-dd summary{list-style:none;cursor:pointer}
.add-dd summary::-webkit-details-marker{display:none}
.add-dd details[open] summary, .add-dd[open] summary{background:var(--bg-subtle);border-color:var(--t-3)}
.add-dd .add-menu{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh-3);min-width:280px;padding:6px;z-index:50}
.add-dd .add-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--r-sm);text-decoration:none;color:var(--t-1)}
.add-dd .add-item:hover{background:var(--bg-subtle);text-decoration:none}
.add-dd .add-item:hover .add-name{color:var(--t-link)}
.add-dd .add-item svg{margin-top:2px;color:var(--t-3);flex-shrink:0}
.add-dd .add-name{font-size:13px;font-weight:500;color:var(--t-1)}
.add-dd .add-desc{font-size:11px;color:var(--t-3);margin-top:2px;line-height:14px}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#D9DBDF;border-radius:6px;border:2px solid var(--bg-canvas)}
::-webkit-scrollbar-thumb:hover{background:#B7BAC0}
::-webkit-scrollbar-track{background:transparent}

/* ============================================================
   v2 — Questionnaire builder (Technical Requirements pattern)
   - Questionnaire switcher
   - Section blocks with prominent weight
   - Question rows with type chip · AI/AI-REC · Req/Opt · Wt · Eff · Source
   ============================================================ */

/* Switcher: jump between questionnaires in the same RFP */
.q-switcher{display:flex;align-items:center;gap:14px;padding:10px 14px;background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);margin:14px 0 0;box-shadow:var(--sh-1)}
.q-switcher-label{font-size:11px;color:var(--t-3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}
.q-switcher-list{display:flex;align-items:center;gap:6px;flex:1;overflow-x:auto;scrollbar-width:none}
.q-switcher-list::-webkit-scrollbar{display:none}
.q-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;border:1px solid var(--bd-strong);border-radius:var(--r-pill);background:#fff;font-size:12px;color:var(--t-2);font-weight:500;text-decoration:none;white-space:nowrap;transition:all .12s;flex-shrink:0;cursor:pointer}
.q-pill:hover{border-color:var(--t-3);color:var(--t-1);text-decoration:none}
.q-pill.active{background:var(--t-1);color:#fff;border-color:var(--t-1)}
.q-pill.warn{border-color:var(--warn-bd);background:var(--warn-bg);color:var(--warn)}
.q-pill.qi{border-color:var(--qi-bd);background:var(--qi-soft);color:var(--qi-deep)}
.q-pill .pill-ic{width:20px;height:20px;border-radius:5px;background:rgba(15,17,21,.06);color:var(--t-2);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;letter-spacing:0}
.q-pill.active .pill-ic{background:rgba(255,255,255,.2);color:#fff}
.q-pill.warn .pill-ic{background:rgba(181,71,8,.14);color:var(--warn)}
.q-pill.qi .pill-ic{background:rgba(124,58,237,.14);color:var(--qi)}
.q-pill .pill-meta{font-size:10px;font-weight:500;opacity:.75;padding-left:8px;border-left:1px solid;border-color:rgba(0,0,0,.12)}
.q-pill.active .pill-meta{border-color:rgba(255,255,255,.25);opacity:.9}
.q-pill.warn .pill-meta{border-color:rgba(181,71,8,.25)}
.q-pill.qi .pill-meta{border-color:rgba(124,58,237,.25)}
.q-pill.add{border-style:dashed;color:var(--t-3);background:transparent}
.q-pill.add:hover{border-color:var(--qi);color:var(--qi-deep);background:var(--qi-soft)}
.q-switcher-arrows{display:flex;gap:4px;flex-shrink:0;border-left:1px solid var(--bd);padding-left:10px}
.q-switcher-arrows button{width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--bd-strong);background:#fff;color:var(--t-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.q-switcher-arrows button:hover{background:var(--bg-subtle);color:var(--t-1)}

/* Weight rollup banner above sections */
.weight-summary{display:flex;align-items:center;gap:10px;padding:10px 14px;background:linear-gradient(180deg,#fff,var(--qi-soft));border:1px solid var(--qi-bd);border-radius:var(--r-sm);font-size:12px;color:var(--t-2);margin-bottom:14px}
.weight-summary strong{color:var(--qi-deep);font-weight:700}
.weight-summary .bar{flex:1;height:6px;background:#fff;border:1px solid var(--qi-bd);border-radius:4px;overflow:hidden;min-width:120px}
.weight-summary .bar .fill{display:block;height:100%;background:var(--qi-grad);border-radius:3px}
.weight-summary .total{font-variant-numeric:tabular-nums;font-weight:700;color:var(--qi-deep);font-size:13px}

/* Section block */
.sec{background:#fff;border:1px solid var(--bd);border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px;box-shadow:var(--sh-1)}
.sec-h{padding:12px 16px;display:flex;align-items:center;gap:10px;background:var(--bg-row);border-bottom:1px solid transparent}
.sec.open .sec-h{border-bottom-color:var(--bd-soft)}
.sec-h .sec-toggle{width:24px;height:24px;border-radius:var(--r-sm);color:var(--t-3);display:inline-flex;align-items:center;justify-content:center;background:transparent;cursor:pointer}
.sec-h .sec-toggle:hover{background:var(--bg-subtle);color:var(--t-1)}
.sec-h .sec-toggle svg{transition:transform .15s}
.sec:not(.open) .sec-h .sec-toggle svg{transform:rotate(-90deg)}
.sec-h h3{margin:0;font-size:14px;font-weight:600;color:var(--t-1)}
.sec-h .sec-count{font-size:12px;color:var(--t-3);font-weight:500}
.sec-h .sec-meta{display:flex;align-items:center;gap:8px;margin-left:auto}
.sec-h .sec-wt-field{display:inline-flex;align-items:center;gap:2px;height:30px;padding:0 4px 0 10px;border:1px solid var(--qi-bd);border-radius:var(--r-sm);background:var(--qi-soft)}
.sec-h .sec-wt-field .lbl{font-size:11px;color:var(--qi-deep);font-weight:700;letter-spacing:.3px}
.sec-h .sec-wt-field input{width:42px;height:24px;padding:0 6px;border:0;background:transparent;font-size:13px;font-weight:700;color:var(--qi-deep);text-align:right;font-variant-numeric:tabular-nums;outline:none}
.sec-h .sec-wt-field input:focus{background:#fff;box-shadow:0 0 0 2px var(--qi-bd);border-radius:3px}
.sec-h .sec-wt-field .pct{font-size:11px;color:var(--qi-deep);font-weight:700}
.sec-body{padding:6px 8px 4px;display:none}
.sec.open .sec-body{display:block}
.sec-add{width:100%;padding:11px;border:0;border-top:1px solid var(--bd-soft);color:var(--qi-deep);font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;background:#FAFBFC;cursor:pointer}
.sec-add:hover{background:var(--qi-soft)}

/* Question card v2 */
.qq-v2{display:grid;grid-template-columns:24px 28px 1fr 28px;gap:8px;padding:12px 10px 14px;border-radius:var(--r-sm);align-items:start;background:#fff;border:1px solid transparent;margin-bottom:4px;transition:all .12s;position:relative}
.qq-v2:hover{background:var(--bg-row)}
.qq-v2.focus{border-color:var(--qi);background:#FCFAFF;box-shadow:0 0 0 2px var(--qi-soft)}
.qq-v2.added-qi{background:linear-gradient(180deg,#FCFAFF 0%,#fff 90%)}
.qq-v2.added-qi::before{content:"";position:absolute;left:2px;top:14px;bottom:14px;width:2px;background:var(--qi-grad);border-radius:2px}
.qq-v2 .qq-drag{width:24px;height:28px;border-radius:4px;color:var(--t-4);display:inline-flex;align-items:center;justify-content:center;cursor:grab;background:transparent;border:0;opacity:0;transition:opacity .12s}
.qq-v2:hover .qq-drag, .qq-v2.focus .qq-drag{opacity:.8}
.qq-v2 .qq-drag:hover{opacity:1;color:var(--t-2)}
.qq-v2 .qq-num{width:24px;height:24px;border-radius:50%;background:var(--bg-subtle);color:var(--t-2);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;margin-top:2px;flex-shrink:0;font-variant-numeric:tabular-nums}
.qq-v2.added-qi .qq-num{background:var(--qi-soft);color:var(--qi-deep);border:1px solid var(--qi-bd)}
.qq-v2 .qq-content{min-width:0}
.qq-v2 .qq-text-edit{font-family:inherit;font-size:14px;font-weight:500;line-height:21px;color:var(--t-1);width:100%;border:1px solid transparent;border-radius:var(--r-sm);padding:4px 8px;background:transparent;resize:none;outline:none;display:block;margin:0 0 8px;min-height:30px;transition:background .12s, border-color .12s, box-shadow .12s}
.qq-v2 .qq-text-edit:hover{background:var(--bg-subtle);border-color:var(--bd-soft);cursor:text}
.qq-v2 .qq-text-edit:focus{background:#fff;border-color:var(--qi);box-shadow:0 0 0 2px var(--qi-soft);cursor:text}
.qq-v2 .qq-del{width:24px;height:24px;border-radius:4px;color:var(--t-4);display:inline-flex;align-items:center;justify-content:center;background:transparent;border:0;margin-top:2px;opacity:0;cursor:pointer;transition:all .12s}
.qq-v2:hover .qq-del, .qq-v2.focus .qq-del{opacity:.8}
.qq-v2 .qq-del:hover{background:var(--danger-bg);color:var(--danger);opacity:1}

/* Controls row */
.qq-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-left:8px}

/* Type chip — visible & clickable */
.ctrl-type{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border:1px solid var(--bd-strong);border-radius:var(--r-sm);background:#fff;font-size:12px;color:var(--t-1);font-weight:500;cursor:pointer;transition:all .12s;line-height:1}
.ctrl-type:hover{background:var(--bg-subtle);border-color:var(--t-3)}
.ctrl-type.open{background:var(--bg-subtle);border-color:var(--qi);box-shadow:0 0 0 2px var(--qi-soft)}
.ctrl-type .ic{width:13px;height:13px;color:var(--t-2);flex-shrink:0}
.ctrl-type .caret{width:10px;height:10px;color:var(--t-4);margin-left:2px}

/* Type picker popover */
.type-picker{position:absolute;z-index:80;min-width:220px;background:#fff;border:1px solid var(--bd-strong);border-radius:var(--r);box-shadow:var(--sh-pop);padding:6px;display:none}
.type-picker.show{display:block}
.type-picker .opt{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:0;background:transparent;font-size:12px;font-weight:500;color:var(--t-1);text-align:left;border-radius:var(--r-sm);cursor:pointer}
.type-picker .opt:hover{background:var(--bg-subtle)}
.type-picker .opt.selected{background:var(--qi-soft);color:var(--qi-deep)}
.type-picker .opt svg.ic{width:13px;height:13px;color:var(--t-2);flex-shrink:0}
.type-picker .opt.selected svg.ic{color:var(--qi-deep)}
.type-picker .opt .check{width:13px;height:13px;margin-left:auto;color:var(--qi-deep);opacity:0}
.type-picker .opt.selected .check{opacity:1}

/* AI / AI-REC badges */
.ai-badge{display:inline-flex;align-items:center;height:24px;padding:0 8px;border-radius:var(--r-sm);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border:1px solid;line-height:1;cursor:help}
.ai-badge.ai{background:#EDE8FF;color:#6D28D9;border-color:#DDD0FF}
.ai-badge.ai-rec{background:#DCFCE7;color:#15803D;border-color:#BBF7D0}

/* Required / Optional toggle */
.ctrl-req{display:inline-flex;align-items:center;height:28px;border:1px solid var(--bd-strong);border-radius:var(--r-sm);overflow:hidden;background:var(--bg-subtle);padding:2px}
.ctrl-req button{height:22px;padding:0 9px;border:0;background:transparent;font-size:11px;font-weight:600;color:var(--t-3);display:inline-flex;align-items:center;gap:5px;cursor:pointer;border-radius:3px;letter-spacing:.02em}
.ctrl-req button:hover{color:var(--t-1)}
.ctrl-req button.active{background:#fff;box-shadow:var(--sh-1)}
.ctrl-req button.active.req{color:var(--danger)}
.ctrl-req button.active.opt{color:var(--warn)}
.ctrl-req .dot{width:5px;height:5px;border-radius:50%;background:currentColor;display:inline-block}

/* Weight field — prominent (amber) */
.ctrl-wt{display:inline-flex;align-items:center;gap:2px;height:28px;padding:0 4px 0 10px;background:#FFFBEB;border:1.5px solid #FBBF24;border-radius:var(--r-sm);box-shadow:0 1px 2px rgba(251,191,36,.18)}
.ctrl-wt .lbl{font-size:10px;color:#92400E;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.ctrl-wt input{width:40px;height:24px;padding:0 4px;border:0;background:transparent;font-size:13px;font-weight:700;color:#92400E;text-align:right;font-variant-numeric:tabular-nums;outline:none}
.ctrl-wt input:focus{background:#fff;box-shadow:0 0 0 2px #FDE68A;border-radius:3px}
.ctrl-wt .pct{font-size:11px;color:#92400E;font-weight:700}
.ctrl-wt.invalid{background:var(--danger-bg);border-color:var(--danger-bd)}
.ctrl-wt.invalid .lbl, .ctrl-wt.invalid input, .ctrl-wt.invalid .pct{color:var(--danger)}

/* Effective (read-only computed) */
.ctrl-eff{font-size:11px;color:var(--t-3);font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:0 4px}
.ctrl-eff strong{font-weight:700;color:var(--qi-deep);font-variant-numeric:tabular-nums}
.ctrl-eff.warn{color:var(--warn)}
.ctrl-eff.warn strong{color:var(--warn)}

/* Source / lineage tag */
.ctrl-src{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 8px;background:var(--qi-soft);border:1px solid var(--qi-bd);border-radius:var(--r-sm);font-size:11px;font-weight:600;color:var(--qi-deep);letter-spacing:.02em;cursor:help}
.ctrl-src.policy{background:var(--warn-bg);border-color:var(--warn-bd);color:var(--warn)}
.ctrl-src.peer{background:var(--info-bg);border-color:var(--info-bd);color:var(--info)}
.ctrl-src.user{background:var(--bg-subtle);border-color:var(--bd);color:var(--t-3)}
.ctrl-src svg{width:10px;height:10px;flex-shrink:0}
