/* verdeaux-interview.css
   Component-only styles for the embedded Research interview module.
   Loaded by verdeaux-local.html AFTER the main SPA stylesheet. The SPA
   provides all design tokens (--green, --gold, --ff-d, --ff-b, --ff-m,
   --border, --radius-lg, etc.), fonts, body background, and the
   header/step-bar/identity-pill chrome. This file only styles interview
   components (phase-nav, question rows, compare table, verdict, etc.).

   Legacy --sage-* aliases below keep older selectors rendering correctly
   without renaming every rule. Scoped locally with :where() so they
   never leak to the SPA. */

:where(:root) {
  --sage:          var(--green-lt);
  --sage-light:    #A8C2B4;
  --sage-pale:     var(--green-pale);
  --sage-dark:     var(--green);
  --sage-deep:     #1a3328;
  --font-display:  var(--ff-d);
  --font-body:     var(--ff-b);
  --charcoal-soft: var(--text-mid);
  --ease:          cubic-bezier(0.4,0,0.2,1);
  --rose-light:    rgba(185,64,64,.25);
  --cream-warm:    #F5EFE3;
}

/* ── Phase (Prepare/Compare/Interview/Negotiate) tab nav ─────────────── */
.phase-nav{background:transparent;border:none;margin:1.5rem auto 0;max-width:1100px;padding:0 clamp(20px,5vw,48px);position:relative;z-index:1}
.phase-nav-inner{display:flex;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:6px;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:0 2px 10px var(--shadow)}
.phase-tab{flex:1;min-width:160px;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 18px;font-family:var(--ff-b);font-size:.88rem;font-weight:400;color:var(--text-mid);background:none;border:none;border-radius:14px;cursor:pointer;position:relative;transition:all .2s var(--ease);white-space:nowrap}
.phase-tab:hover{color:var(--green);background:var(--green-pale)}
.phase-tab.active{color:var(--white);background:var(--green);font-weight:500}
.phase-tab.active:hover{background:var(--green-deep)}
.phase-number{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-m);font-size:.66rem;font-weight:500;flex-shrink:0}
.phase-tab .phase-number{background:rgba(44,74,62,.06);color:var(--text-muted)}
.phase-tab.active .phase-number{background:rgba(255,255,255,.2);color:var(--white)}
.phase-tab.completed .phase-number{background:var(--green-pale);color:var(--green)}
.phase-connector{display:none}

/* ── Sub-event tabs (Related Events only) ────────────────────────────── */
.subevent-nav{max-width:1100px;margin:.75rem auto 0;padding:0 clamp(20px,5vw,48px);position:relative;z-index:1;background:transparent;border:none}
.subevent-nav-inner{display:flex;gap:6px;padding:0;flex-wrap:wrap}
.subevent-tab{padding:7px 14px;border-radius:100px;border:1px solid var(--border-g);background:var(--white);font-family:var(--ff-b);font-size:.78rem;color:var(--text-mid);cursor:pointer;transition:all .2s var(--ease)}
.subevent-tab.active{border-color:var(--green);background:var(--green);color:var(--white);font-weight:500}

/* ── Content frame ─ each phase section is a Budget-card-style card ──── */
.content{max-width:1100px;margin:0 auto;padding:1.75rem clamp(20px,5vw,48px) 80px;position:relative;z-index:1}
.phase-section{display:none;background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:22px;padding:clamp(22px,3.5vw,36px);box-shadow:0 2px 16px var(--shadow)}
.phase-section.active{display:block}

/* ── Mode bar (Quick / Full) ─────────────────────────────────────────── */
.mode-bar{display:flex;align-items:stretch;gap:0;margin-bottom:24px;background:var(--cream);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.mode-option{flex:1;display:flex;align-items:center;gap:14px;padding:16px 22px;cursor:pointer;transition:all .2s var(--ease);border:none;background:none;font-family:var(--ff-b);text-align:left;position:relative}
.mode-option:first-child{border-right:1px solid var(--border)}
.mode-option.active{background:var(--green-pale)}
.mode-option.active::before{content:'';position:absolute;left:0;top:12px;bottom:12px;width:3px;background:var(--green);border-radius:0 3px 3px 0}
.mode-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-g);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}
.mode-option.active .mode-radio{border-color:var(--green)}
.mode-option.active .mode-radio::after{content:'';width:8px;height:8px;border-radius:50%;background:var(--green)}
.mode-text h4{font-family:var(--ff-b);font-size:.9rem;font-weight:500;color:var(--charcoal);margin-bottom:2px}
.mode-text p{font-size:.78rem;color:var(--text-muted);line-height:1.4}
.mode-badge{margin-left:auto;padding:3px 11px;border-radius:100px;font-family:var(--ff-m);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;flex-shrink:0}
.mode-badge.quick{background:var(--gold-pale);color:var(--gold-deep)}
.mode-badge.full{background:var(--green-pale);color:var(--green)}
.mode-badge.rehearsal{background:rgba(200,169,110,.18);color:var(--gold-deep,#A07840)}
.mode-option:not(:first-child){border-left:1px solid var(--border)}

/* ── 10-minute Rehearsal mode (idea #7, 2026-04-29) ────────────────── */
.vdx-rehearsal-host{padding:8px 0 16px}
.vdx-r-head-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}
.vdx-r-eyebrow{font-family:var(--ff-m);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--green);font-weight:600}
.vdx-r-refresh{appearance:none;background:transparent;border:1px solid var(--border-g);color:var(--text-mid);font-family:var(--ff-b);font-size:.74rem;padding:4px 11px;border-radius:6px;cursor:pointer}
.vdx-r-refresh:hover{border-color:var(--green);color:var(--green)}
.vdx-r-intro{font-size:.86rem;color:var(--text-mid);line-height:1.55;margin:0 0 18px}
.vdx-r-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;margin-bottom:16px;box-shadow:0 2px 12px rgba(44,74,62,.04)}
.vdx-r-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:10px}
.vdx-r-num{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--green);color:var(--cream,#FAF7F2);font-family:var(--ff-d);font-size:1rem;font-weight:500;display:flex;align-items:center;justify-content:center;font-style:italic}
.vdx-r-q{font-family:var(--ff-d);font-size:1.1rem;font-weight:400;color:var(--charcoal);line-height:1.35;margin:2px 0 0}
.vdx-r-why{font-size:.84rem;color:var(--text-mid);line-height:1.55;padding:8px 12px;background:rgba(200,169,110,.07);border-left:2.5px solid var(--gold);border-radius:0 6px 6px 0;margin-bottom:10px}
.vdx-r-why strong{color:var(--green);font-weight:600}
.vdx-r-bad,.vdx-r-push{margin-top:8px}
.vdx-r-lbl{font-family:var(--ff-m);font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft,#7A7A7A);margin-bottom:3px}
.vdx-r-bad-quote{font-style:italic;font-size:.86rem;color:var(--rose,#C97B3A);line-height:1.5;padding-left:12px;border-left:2px solid var(--rose,#C97B3A)}
.vdx-r-push-quote{font-size:.88rem;font-weight:500;color:var(--green);line-height:1.5;padding:8px 12px;background:var(--green-pale,rgba(44,74,62,.07));border-radius:6px}
.vdx-r-loading{display:flex;align-items:center;gap:12px;padding:24px;color:var(--text-mid);font-size:.88rem;font-style:italic}
.vdx-r-spin{width:18px;height:18px;border:2px solid var(--border-g);border-top-color:var(--green);border-radius:50%;animation:vdx-r-spin .9s linear infinite;flex-shrink:0}
@keyframes vdx-r-spin{to{transform:rotate(360deg)}}
.vdx-r-error{padding:14px 18px;background:rgba(220,80,80,.08);border:1px solid rgba(220,80,80,.25);border-radius:8px;color:#a23030;font-size:.85rem;margin-bottom:10px}
.vdx-r-retry{appearance:none;background:var(--green);color:var(--white);border:none;padding:8px 18px;border-radius:6px;font-family:var(--ff-b);font-size:.82rem;cursor:pointer}
@media(max-width:600px){
 .mode-bar{flex-direction:column}
 .mode-option{flex:1 1 auto;width:100%;border-right:none !important;border-left:none !important;border-bottom:1px solid var(--border)}
 .mode-option:last-child{border-bottom:none}
 .vdx-r-q{font-size:1rem}
}

/* ── Vendor selector (5-tab, one per vendor slot) ─────────────────────── */
.vendor-selector{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}
.vendor-tab{padding:8px 18px;border-radius:100px;border:1px solid var(--border-g);background:var(--white);font-family:var(--ff-b);font-size:.82rem;color:var(--text-mid);cursor:pointer;transition:all .2s var(--ease)}
.vendor-tab.active{border-color:var(--green);background:var(--green);color:var(--white);font-weight:500}
.vendor-tab.empty{border-style:dashed;opacity:.55}

/* ── Question groups + rows ──────────────────────────────────────────── */
.question-group{margin-bottom:28px}
.question-group.hidden-group{display:none}
.group-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border-g)}
.group-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.group-icon.info{background:var(--green-pale)}
.group-icon.include{background:#E3F0E8}
.group-icon.cost{background:var(--rose-pale)}
.group-icon.tent,.group-icon.cake{background:var(--gold-pale)}
.group-icon.notes{background:#EDE8F5}
.group-header h3{font-family:var(--ff-d);font-size:1.35rem;font-weight:500;color:var(--green);letter-spacing:-.005em}
.group-header .q-count{margin-left:auto;font-family:var(--ff-m);font-size:.62rem;color:var(--text-muted);letter-spacing:.08em}

.question-row{display:grid;grid-template-columns:28px 1fr;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--border);transition:all .3s var(--ease)}
.question-row:last-child{border-bottom:none}
.question-row.nice-hidden{display:none}
.must-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:100px;font-family:var(--ff-m);font-size:.56rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;vertical-align:middle;margin-left:6px}
.must-badge.must{background:var(--rose-pale);color:var(--rose)}
.must-badge.nice{background:var(--cream-warm);color:#B0A898}
.q-num{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-m);font-size:.62rem;font-weight:500;flex-shrink:0;margin-top:2px}
.q-num.base{background:var(--green-pale);color:var(--green)}
.q-num.cost-n{background:var(--rose-pale);color:var(--rose)}
.q-num.tent-n,.q-num.cake-n{background:var(--gold-pale);color:var(--gold-deep)}
.q-num.notes-n{background:#EDE8F5;color:#6B5CA5}
.q-num.inc-n{background:#E3F0E8;color:#3D7A4F}
.question-content{display:flex;flex-direction:column;gap:6px}
.question-text{font-size:.9rem;color:var(--charcoal);line-height:1.5}
.question-hint{font-size:.74rem;color:var(--gold-deep);font-style:italic}

/* Phase 2 MVP — market_items metadata bar above the answer field.
   Surfaces inclusion chip + "X% of couples include this" microcopy +
   item label so couples see WHY each question matters. */
.vdx-q-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:2px 0 4px;font-family:var(--ff-m);font-size:.62rem;letter-spacing:.04em}
.vdx-q-meta-item{color:var(--text-muted);font-style:italic;letter-spacing:.02em}
.vdx-q-meta-item:not(:last-child)::after{content:"·";margin-left:6px;color:var(--border-g);font-style:normal}
.vdx-q-meta-chip{display:inline-flex;align-items:center;padding:1px 8px;border-radius:100px;font-weight:500;text-transform:uppercase;font-size:.56rem;letter-spacing:.08em}
.vdx-q-meta-chip.vdx-incl-extra{background:var(--rose-pale);color:var(--rose)}
.vdx-q-meta-chip.vdx-incl-bundled{background:var(--green-pale);color:var(--green)}
.vdx-q-meta-chip.vdx-incl-varies{background:var(--gold-pale);color:var(--gold-deep)}
.vdx-q-meta-util{color:var(--text-muted);font-style:italic;letter-spacing:.02em}
.vdx-q-meta-core{color:var(--green);font-weight:500;text-transform:uppercase;font-size:.56rem;letter-spacing:.08em;padding:1px 6px;border:1px solid var(--green-pale);border-radius:100px}
/* Phase 3c — surfaces when a question's market_item is checked in the
   couple's Budget plan. Tells them why this question is promoted to
   "must inquire" — they planned for it. */
.vdx-q-meta-budget{display:inline-flex;align-items:center;gap:5px;padding:1px 8px;border-radius:100px;font-family:var(--ff-m,monospace);font-size:.55rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;color:var(--gold-deep,#A07F38);background:rgba(200,169,110,.14);border:1px solid rgba(200,169,110,.4)}
.vdx-q-meta-budget::before{content:"$";font-size:.7rem;font-style:italic;letter-spacing:0;font-weight:400}

.answer-input,.answer-select{width:100%;padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--ff-b);font-size:.88rem;color:var(--charcoal);background:var(--cream);transition:all .2s var(--ease);outline:none}
.answer-input:focus,.answer-select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(90,140,122,.12);background:var(--white)}
.answer-input::placeholder{color:#C8C4BE}
.answer-input.filled,.answer-select.filled{border-color:var(--green-lt);background:rgba(232,237,229,.15)}
textarea.answer-input{resize:vertical;min-height:36px}
.inline-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.answer-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='7' viewBox='0 0 12 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%234A4A4A' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}

/* ── Compare table ───────────────────────────────────────────────────── */
.compare-table-wrap{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;box-shadow:0 2px 14px var(--shadow);margin-bottom:22px}
.compare-table-header{background:var(--green);padding:14px 0;display:grid;grid-template-columns:200px repeat(5,1fr)}
.compare-table-header span{color:var(--white);font-family:var(--ff-m);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:0 14px;text-align:center}
.compare-table-header span:first-child{text-align:left;opacity:.7}
.ct-section-header{grid-column:1/-1;padding:10px 14px;font-family:var(--ff-m);font-size:.58rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.ct-section-header.info{background:var(--green-pale);color:var(--green)}
.ct-section-header.include{background:#E3F0E8;color:#3D7A4F}
.ct-section-header.cost{background:var(--rose-pale);color:var(--rose)}
.ct-section-header.cake,.ct-section-header.tent{background:var(--gold-pale);color:var(--gold-deep)}
.ct-section-header.notes{background:#EDE8F5;color:#6B5CA5}
.ct-section-header.facts{background:#EAF0ED;color:var(--green)}

.compare-table-header span.vendor-col-running{opacity:1}
.compare-table-header span.vendor-col-done{color:var(--gold-light)}
.compare-table-header span.vendor-col-failed{color:rgba(255,255,255,.55)}

.ct-cell span.cell-fade-in,.ct-cell .ct-rating.cell-fade-in{animation:vdx-fade-in 450ms var(--ease)}
@keyframes vdx-fade-in{0%{opacity:.15;transform:translateY(-2px)}100%{opacity:1;transform:translateY(0)}}

.ct-row{display:grid;grid-template-columns:200px repeat(5,1fr);border-bottom:1px solid var(--border)}
.ct-row:last-child{border-bottom:none}
.ct-label{padding:10px 14px;font-family:var(--ff-m);font-size:.62rem;font-weight:500;color:var(--text-mid);letter-spacing:.04em;background:var(--cream);border-right:1px solid var(--border)}
.ct-cell{padding:10px 14px;font-size:.78rem;color:var(--charcoal);text-align:center;border-right:1px solid rgba(44,74,62,.05);display:flex;align-items:center;justify-content:center}
.ct-cell:last-child{border-right:none}
.ct-rating{display:flex;gap:2px;justify-content:center}
.ct-star{color:var(--gold);font-size:13px}
.ct-star.empty{color:rgba(44,74,62,.2)}

/* ── Verdict bar ─────────────────────────────────────────────────────── */
.verdict-bar{background:var(--white);border-radius:var(--radius-lg);border:2px solid var(--green);padding:22px 26px;display:flex;align-items:flex-start;gap:18px}
.verdict-icon{width:42px;height:42px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;color:var(--green)}
.verdict-text{flex:1;min-width:0}
.verdict-text h3{font-family:var(--ff-d);font-size:1.35rem;font-weight:500;color:var(--green);margin-bottom:3px}
.verdict-text p{font-size:.82rem;color:var(--text-mid);line-height:1.55}
.verdict-action{margin-left:auto;padding:10px 22px;background:var(--green);color:var(--white);border:none;border-radius:100px;font-family:var(--ff-b);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s var(--ease);white-space:nowrap;align-self:flex-start;margin-top:6px}
.verdict-action:hover{background:var(--green-deep);transform:translateY(-1px)}

.verdict-confidence{display:inline-block;font-family:var(--ff-m);font-size:.58rem;font-weight:500;padding:3px 10px;border-radius:100px;margin-left:10px;vertical-align:middle;letter-spacing:.08em;text-transform:uppercase}
.verdict-confidence-high{background:var(--green-pale);color:var(--green)}
.verdict-confidence-medium{background:var(--gold-pale);color:var(--gold-deep)}
.verdict-confidence-low{background:var(--rose-pale);color:var(--rose)}

.verdict-concerns{margin-top:10px;padding:10px 14px;background:var(--cream-warm);border-radius:8px;border-left:3px solid var(--gold)}
.verdict-concerns-label{display:block;font-family:var(--ff-m);font-size:.58rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:4px}
.verdict-concerns ul{list-style:none;padding:0;margin:0}
.verdict-concerns li{font-size:.78rem;color:var(--charcoal);padding:2px 0;line-height:1.5;display:flex;gap:6px}
.verdict-concerns li::before{content:'→';color:var(--gold);flex-shrink:0}
.verdict-runner-up{margin-top:8px;font-size:.78rem;color:var(--text-muted);font-style:italic}

/* ── Dig-deeper bar ──────────────────────────────────────────────────── */
.dig-deeper-bar{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;margin:22px 0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dig-deeper-label{font-family:var(--ff-m);font-size:.58rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-right:4px;flex-shrink:0}
.dig-deeper-btn{padding:7px 13px;background:var(--white);color:var(--green);border:1px solid var(--green-pale);border-radius:100px;font-family:var(--ff-b);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s var(--ease);white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}
.dig-deeper-btn:not(:disabled):hover{background:var(--green-pale);border-color:var(--green)}
.dig-deeper-btn:disabled{opacity:.4;cursor:not-allowed}
.dig-deeper-btn.running{background:var(--gold-pale);color:var(--gold-deep);border-color:var(--gold-light);opacity:1}
.dig-deeper-btn.done{background:var(--green-pale);color:var(--green);border-color:var(--green);font-weight:600}
.dig-deeper-hint{font-family:var(--ff-m);font-size:.62rem;color:var(--text-muted);font-style:italic;margin-left:auto;letter-spacing:.04em}

/* ── Reset Research button ───────────────────────────────────────────── */
.reset-research-btn{border-color:var(--rose-light)!important;color:var(--rose)!important}
.reset-research-btn:hover:not(:disabled){background:var(--rose-pale)!important;border-color:var(--rose)!important}
.reset-research-btn:disabled{opacity:.45;cursor:not-allowed}
.reset-research-btn.reset-research-btn-muted{opacity:.55;border-style:dashed!important}
.reset-research-btn.reset-research-btn-muted:hover:not(:disabled){opacity:1;border-style:solid!important}

.filter-change-nudge{margin:14px 0 0;padding:12px 16px;background:var(--gold-pale);border:1px solid var(--gold-light);border-left:3px solid var(--gold);border-radius:8px;font-size:.82rem;color:var(--charcoal);line-height:1.55}
.filter-change-nudge strong{color:var(--gold-deep);font-weight:600}
.filter-change-nudge a{color:var(--green);font-weight:600;text-decoration:underline;cursor:pointer}
.filter-change-nudge a:hover{color:var(--green-deep)}
@media(max-width:640px){
  .dig-deeper-hint{width:100%;margin-left:0;margin-top:4px;text-align:left}
}

/* ── Prepare ─────────────────────────────────────────────────────────── */
.prepare-intro{background:var(--gold-pale);border:1px solid var(--gold-light);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:28px;display:flex;gap:16px;align-items:flex-start}
.prepare-intro h3{font-family:var(--ff-d);font-size:1.2rem;font-weight:500;color:var(--green);margin-bottom:4px}
.prepare-intro p{font-size:.82rem;color:var(--text-mid);line-height:1.6}
.prepare-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:28px}
.prepare-grid.three{grid-template-columns:repeat(3,1fr)}
.prep-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:all .2s var(--ease)}
.prep-card:hover{box-shadow:0 4px 18px var(--shadow);border-color:var(--green-lt)}
.prep-card-tag{font-family:var(--ff-m);font-size:.58rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--green);margin-bottom:10px}
.prep-card h4{font-family:var(--ff-d);font-size:1.1rem;font-weight:500;margin-bottom:8px;color:var(--green)}
.prep-items{list-style:none}
.prep-items li{font-size:.82rem;color:var(--text-mid);padding:4px 0;display:flex;align-items:flex-start;gap:6px;line-height:1.45}
.prep-items li::before{content:'•';color:var(--green-lt);font-weight:700;flex-shrink:0}

.alert-card{background:var(--rose-pale);border:1px solid var(--rose-light);border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:20px}
.alert-card h4{font-family:var(--ff-d);font-size:1.05rem;font-weight:500;color:var(--rose);margin-bottom:8px}
.alert-card ul{list-style:none}
.alert-card ul li{font-size:.82rem;color:var(--text-mid);padding:3px 0;display:flex;gap:6px;line-height:1.45}
.alert-card ul li::before{content:'⚠';color:var(--rose);flex-shrink:0}

.search-tip{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 22px;margin-bottom:26px}
.search-tip-label{font-family:var(--ff-m);font-size:.58rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:8px}
.search-tip code{display:block;background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-family:var(--ff-m);font-size:.78rem;color:var(--text-mid);line-height:1.6;word-break:break-word}
.search-tip code em{color:var(--green);font-style:normal;font-weight:500;background:var(--green-pale);padding:1px 5px;border-radius:3px}

/* ── Phase action buttons ────────────────────────────────────────────── */
.phase-actions{display:flex;justify-content:space-between;align-items:center;padding:22px 0 0;margin-top:14px;border-top:1px solid var(--border)}
.btn-next{display:inline-flex;align-items:center;gap:10px;padding:11px 26px;background:var(--green);color:var(--white);border:none;border-radius:100px;font-family:var(--ff-b);font-size:.88rem;font-weight:500;cursor:pointer;transition:all .2s var(--ease)}
.btn-next:hover{background:var(--green-deep);transform:translateY(-1px)}
.btn-back{font-size:.82rem;color:var(--text-mid);background:none;border:none;cursor:pointer;font-family:var(--ff-b)}
.btn-back:hover{color:var(--green)}
.btn-pdf{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:100px;font-family:var(--ff-b);font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s var(--ease);border:none}
.btn-pdf-outline{background:var(--white);color:var(--green);border:1px solid var(--border-g)}
.btn-pdf-outline:hover{background:var(--green-pale);border-color:var(--green)}

/* ── Research banner (sticky progress under header during Claude runs) ──
   2026-04-28: top bumped from 60px → 130px so the banner clears the
   SPA's 3-tier fixed chrome instead of being tucked behind it.
   z-index 120 sits above body content but below header (z-index higher)
   and the auth overlay (z-index 9999).
   2026-05-03: aligned top values with actual chrome stack:
     Desktop: header 0+74 → profile-bar 74+54 → step-bar 129+54 → banner 183
     ≤768:    header 0+68 → profile-bar 68+55 → step-bar 123+54 → banner 177
     ≤600:    header 0+55 → profile-bar 55+55 → step-bar 110+54 → banner 164
   Banner sits flush below the step bar so body content scrolls under it. */
.research-banner{position:fixed;top:183px;left:0;right:0;z-index:120;background:var(--green);color:#fff;padding:10px 22px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 16px rgba(44,74,62,.22);font-family:var(--ff-b);font-size:.82rem;transition:opacity .3s,transform .3s}
@media (max-width:768px){.research-banner{top:177px}}
@media (max-width:600px){.research-banner{top:164px;padding:9px 16px}}
.research-banner.research-banner-success{background:var(--green-lt)}
.research-banner.research-banner-error{background:var(--rose)}
.research-banner .research-banner-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.28);border-top-color:#fff;border-radius:50%;animation:vdx-spin .9s linear infinite;flex-shrink:0}
.research-banner-body{flex:1;min-width:0}
.research-banner-text{font-weight:500;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.research-banner-progress-bar{height:3px;background:rgba(255,255,255,.22);border-radius:2px;margin-top:5px;overflow:hidden}
.research-banner-progress-bar-fill{height:100%;background:var(--gold-light);border-radius:2px;transition:width .4s ease-out;width:0%}
.research-banner.research-banner-success .research-banner-progress-bar-fill{background:rgba(255,255,255,.6)}
.research-banner-dismiss{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.32);padding:4px 12px;border-radius:100px;font-family:var(--ff-b);font-size:.7rem;cursor:pointer}
.research-banner-dismiss:hover{background:rgba(255,255,255,.12)}
@keyframes vdx-spin{to{transform:rotate(360deg)}}

/* ── Engagement modal ────────────────────────────────────────────────── */
.engagement-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(250,247,242,.82);backdrop-filter:blur(6px);z-index:2000}
.engagement-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px 30px;max-width:420px;width:92%;box-shadow:0 12px 32px rgba(44,44,44,.14);text-align:center;position:relative;overflow:hidden}
.engagement-title{font-family:var(--ff-d);font-size:1.4rem;font-weight:500;color:var(--green);margin-bottom:10px}
.engagement-message{font-size:.88rem;color:var(--text-mid);min-height:48px}
.engagement-dots{margin-top:14px;display:flex;justify-content:center;gap:6px}
.engagement-dots span{width:8px;height:8px;border-radius:50%;background:var(--green-pale);animation:pulse 1.2s ease-in-out infinite}
.engagement-dots span:nth-child(2){animation-delay:.2s}
.engagement-dots span:nth-child(3){animation-delay:.4s}
.engagement-modal.complete .engagement-dots{display:none}
.engagement-modal.complete .engagement-message{color:var(--green);font-weight:500}
.engagement-modal.complete .engagement-card::before,
.engagement-modal.complete .engagement-card::after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:var(--gold-light);box-shadow:0 0 0 0 rgba(200,169,110,.4);animation:sparkle .7s ease-out forwards}
.engagement-modal.complete .engagement-card::before{top:18px;right:22px}
.engagement-modal.complete .engagement-card::after{bottom:18px;left:26px}

@keyframes pulse{0%,100%{opacity:.35;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}
@keyframes sparkle{0%{transform:scale(.2);opacity:0}60%{transform:scale(1);opacity:1}100%{transform:scale(1.2);opacity:0}}

button:disabled{opacity:.55;cursor:not-allowed}
.rating-stars{display:flex;gap:4px}
.star{font-size:24px;cursor:pointer;color:rgba(44,74,62,.15);transition:color .2s;user-select:none}
.star.lit{color:var(--gold)}

/* ── Checklist panel (Marriage License) ──────────────────────────────── */
.checklist-panel{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;margin-bottom:22px}
.checklist-panel h3{font-family:var(--ff-d);font-size:1.3rem;font-weight:500;color:var(--green);margin-bottom:12px}
.checklist-panel ul{list-style:none}
.checklist-panel li{padding:8px 0;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:10px;font-size:.88rem}
.checklist-panel li:last-child{border-bottom:none}
.checklist-panel li input[type=checkbox]{margin-top:4px;accent-color:var(--green)}

.shared-badge{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:100px;font-family:var(--ff-m);font-size:.56rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;background:var(--green-pale);color:var(--green);vertical-align:middle}

/* ── Share-scope modal ("apply to all guides or just this one?") ─────── */
.share-scope-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(44,44,44,.38);backdrop-filter:blur(4px);z-index:2100}
.share-scope-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 26px;max-width:480px;width:92%;box-shadow:0 12px 32px rgba(44,44,44,.18)}
.share-scope-card h3{font-family:var(--ff-d);font-size:1.35rem;font-weight:500;color:var(--green);margin-bottom:10px}
.share-scope-card p{font-size:.88rem;color:var(--charcoal);margin-bottom:6px;line-height:1.5}
.share-scope-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;align-items:center}
.share-scope-actions .btn-next{padding:9px 16px;font-size:.82rem}
.share-scope-actions .btn-pdf{padding:9px 16px;font-size:.82rem}
.share-scope-actions .btn-back{margin-left:auto;font-size:.82rem}

/* ── Print ───────────────────────────────────────────────────────────── */
@media print{
  .phase-nav,.phase-actions,.btn-pdf,.mode-bar,.subevent-nav,.research-banner{display:none!important}
  .phase-section{display:block!important;box-shadow:none!important;border:1px solid #ccc!important}
  .vendor-selector{display:none!important}
  .question-group{page-break-inside:avoid}
  .content{padding:20px!important}
}

/* ── Mobile ──────────────────────────────────────────────────────────── */
@media(max-width:768px){
  .phase-nav-inner{padding:4px;gap:2px}
  .phase-tab{min-width:auto;padding:10px 12px;font-size:.78rem}
  .prepare-grid,.prepare-grid.three{grid-template-columns:1fr}
  .inline-fields{grid-template-columns:1fr}
  .content{padding:1.25rem 1rem 60px}
  .verdict-bar{flex-direction:column;text-align:left}
  .verdict-action{margin-left:0}
  .mode-bar{flex-direction:column}
  .mode-option:first-child{border-right:none;border-bottom:1px solid var(--border)}
  .compare-table-header,.ct-row{grid-template-columns:140px repeat(5,1fr);font-size:.7rem}
}
