/* assets/css/components.css
 * Reusable UI components. Buttons, inputs, cards, progress bar,
 * score panels, check stream cards, lead capture form.
 */

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space_2);
  padding: 14px 28px;
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.20em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid var(--bone);
  background: var(--bone);
  color: var(--ink);
  cursor: pointer;
  transition: all var(--duration_fast) var(--ease_out);
  position: relative;
  overflow: hidden;
}
.btn:hover { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

.btn_ghost {
  background: transparent;
  border: 1px solid var(--rule_strong);
  color: var(--bone_dim);
}
.btn_ghost:hover { background: transparent; border-color: var(--gold); color: var(--gold); }

.btn_gold { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.btn_gold:hover { background: var(--bone); border-color: var(--bone); color: var(--ink); }

/* Inputs */
.input_group {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--rule_strong);
  background: var(--ink_2);
  transition: border-color var(--duration_fast) var(--ease_out);
}
.input_group:focus-within { border-color: var(--gold); box-shadow: 0 0 0 3px var(--gold_glow); }

.input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  padding: 18px 22px;
  font-family: var(--font_mono);
  font-size: var(--size_md);
  color: var(--bone);
  min-width: 0;
}
.input::placeholder { color: var(--bone_faint); }
.input_group .btn { border: none; }

.input_block {
  display: flex;
  flex-direction: column;
  gap: var(--space_2);
}
.input_block label {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone_faint);
}
.input_solo {
  background: var(--ink_2);
  border: 1px solid var(--rule_strong);
  padding: 14px 18px;
  font-family: var(--font_mono);
  font-size: var(--size_base);
  color: var(--bone);
}
.input_solo:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px var(--gold_glow); }

/* Capability cards */
.cap_card {
  position: relative;
  padding: var(--space_5) var(--space_5) var(--space_6);
}
.cap_card .cap_n {
  position: absolute;
  top: var(--space_4);
  right: var(--space_5);
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.20em;
  color: var(--bone_faint);
}
.cap_card .cap_title {
  font-family: var(--font_display);
  font-size: var(--size_lg);
  line-height: 1.1;
  margin: var(--space_5) 0 var(--space_3);
  font-variation-settings: 'opsz' 36, 'SOFT' 50;
}
.cap_card .cap_title em { color: var(--gold); font-style: italic; font-variation-settings: 'opsz' 36, 'SOFT' 100; }
.cap_card .cap_desc {
  font-family: var(--font_body);
  font-size: var(--size_sm);
  color: var(--bone_dim);
  line-height: 1.5;
}

/* Progress bar */
.progress_track {
  position: relative;
  height: 6px;
  background: var(--rule);
  margin: var(--space_4) 0;
  overflow: hidden;
}
.progress_fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), var(--ember));
  width: 0%;
  transition: width 600ms var(--ease_out);
  box-shadow: 0 0 12px var(--gold_glow);
}

.progress_meta {
  display: flex;
  justify-content: space-between;
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bone_faint);
}
.progress_meta .pct { color: var(--gold); font-variant-numeric: tabular-nums; }

/* Check stream cards (during audit) */
.check_stream {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--rule);
  margin-top: var(--space_6);
}
.check {
  background: var(--ink);
  padding: var(--space_4) var(--space_5);
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: var(--space_4);
  align-items: center;
  opacity: 0.4;
  transition: opacity var(--duration_base) var(--ease_out);
}
.check.is_active { opacity: 1; background: var(--ink_2); }
.check.is_done { opacity: 1; }
.check_index {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  color: var(--bone_faint);
}
.check_label {
  font-family: var(--font_body);
  font-size: var(--size_md);
}
.check_status {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone_faint);
  display: flex;
  align-items: center;
  gap: var(--space_2);
}
.check.is_done .check_status { color: var(--sage); }
.check.is_active .check_status { color: var(--gold); }

.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--bone_faint);
}
.check.is_active .dot { background: var(--gold); animation: pulse 1.4s infinite; }
.check.is_done .dot { background: var(--sage); }

/* Score panel (results page) */
.score_hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space_8);
  align-items: end;
  padding: var(--space_8) 0 var(--space_7);
  border-bottom: 1px solid var(--rule);
}
@media (max-width: 900px) { .score_hero { grid-template-columns: 1fr; gap: var(--space_5); } }

.score_number {
  font-family: var(--font_display);
  font-size: clamp(8rem, 16vw, 14rem);
  font-weight: 300;
  line-height: 0.85;
  font-variant-numeric: tabular-nums;
  font-variation-settings: 'opsz' 144, 'SOFT' 30;
}
.score_number .denom { font-size: 0.25em; color: var(--bone_faint); margin-left: 8px; }

.score_meta { padding-bottom: var(--space_5); }
.score_meta .verdict {
  font-family: var(--font_display);
  font-style: italic;
  font-size: var(--size_2xl);
  color: var(--gold);
  font-variation-settings: 'opsz' 60, 'SOFT' 80;
  margin-bottom: var(--space_3);
}
.score_meta .verdict_blurb {
  font-family: var(--font_body);
  color: var(--bone_dim);
  font-size: var(--size_md);
  max-width: 28rem;
  line-height: 1.45;
}

/* Section score grid */
.section_grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--rule);
  margin-top: var(--space_6);
}
@media (max-width: 1100px) { .section_grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px)  { .section_grid { grid-template-columns: repeat(2, 1fr); } }

.section_score {
  background: var(--ink);
  padding: var(--space_5) var(--space_4);
  display: flex;
  flex-direction: column;
  gap: var(--space_3);
  position: relative;
}
.section_score::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 28px;
  height: 2px;
  background: var(--gold);
}
.section_score.is_pass::before { background: var(--sage); }
.section_score.is_fail::before { background: var(--crimson); }

.section_score .label {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone_faint);
}
.section_score .value {
  font-family: var(--font_display);
  font-size: var(--size_2xl);
  font-weight: 300;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  font-variation-settings: 'opsz' 60, 'SOFT' 50;
}
.section_score .value .denom { font-size: 0.45em; color: var(--bone_faint); margin-left: 4px; }

/* Detail cards (per section) */
.detail_card {
  background: var(--ink_2);
  border: 1px solid var(--rule);
  padding: var(--space_6);
  margin-top: var(--space_5);
}
.detail_card h3 {
  font-family: var(--font_display);
  font-size: var(--size_xl);
  font-weight: 400;
  margin-bottom: var(--space_4);
  font-variation-settings: 'opsz' 48, 'SOFT' 50;
}
.detail_card .detail_meta {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.16em;
  color: var(--bone_faint);
  margin-bottom: var(--space_4);
  text-transform: uppercase;
}

/* Tables */
.tbl {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font_mono);
  font-size: var(--size_sm);
}
.tbl th, .tbl td {
  text-align: left;
  padding: 10px 14px;
  border-bottom: 1px solid var(--rule);
}
.tbl th {
  font-size: var(--size_xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bone_faint);
  font-weight: 500;
}
.tbl td.right { text-align: right; }
.tbl td.pass { color: var(--sage); }
.tbl td.warn { color: var(--gold); }
.tbl td.fail { color: var(--ember); }

/* Recommendations */
.rec_list { display: flex; flex-direction: column; gap: 1px; background: var(--rule); margin-top: var(--space_5); }
.rec_item {
  background: var(--ink_2);
  padding: var(--space_5) var(--space_6);
  border-left: 3px solid var(--gold);
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--space_5);
  align-items: start;
}
@media (max-width: 700px) { .rec_item { grid-template-columns: 1fr; gap: var(--space_3); } }

.rec_item.high { border-left-color: var(--crimson); }
.rec_item.medium { border-left-color: var(--gold); }
.rec_item.low { border-left-color: var(--sage); }

.rec_priority {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--gold);
  padding-top: 4px;
}
.rec_item.high .rec_priority { color: var(--ember); }
.rec_item.low .rec_priority { color: var(--sage); }

.rec_title {
  font-family: var(--font_display);
  font-size: var(--size_lg);
  font-weight: 400;
  margin-bottom: var(--space_2);
  font-variation-settings: 'opsz' 36, 'SOFT' 50;
}
.rec_detail { font-size: var(--size_base); color: var(--bone_dim); line-height: 1.5; }

/* Lead capture */
.lead_form {
  background: var(--ink_2);
  border: 1px solid var(--gold_dim);
  padding: var(--space_7);
  margin-top: var(--space_7);
  display: grid;
  gap: var(--space_5);
}
.lead_form_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space_4);
}
@media (max-width: 700px) { .lead_form_grid { grid-template-columns: 1fr; } }

.lead_form .consent {
  display: flex;
  align-items: flex-start;
  gap: var(--space_3);
  font-size: var(--size_sm);
  color: var(--bone_dim);
}
.lead_form .consent input { margin-top: 4px; accent-color: var(--gold); }

.lead_pitch {
  border: 1px solid var(--gold);
  padding: var(--space_6);
  margin-top: var(--space_7);
  background: linear-gradient(135deg, rgba(212, 162, 76, 0.05), transparent);
}
.lead_pitch .price {
  font-family: var(--font_display);
  font-size: var(--size_2xl);
  font-weight: 400;
  color: var(--gold);
}

/* States */
.empty_state {
  padding: var(--space_8);
  text-align: center;
  color: var(--bone_faint);
  font-family: var(--font_mono);
  font-size: var(--size_sm);
  letter-spacing: 0.10em;
}

.error_box {
  border: 1px solid var(--crimson);
  background: rgba(139, 46, 32, 0.08);
  padding: var(--space_4) var(--space_5);
  font-size: var(--size_sm);
  color: var(--ember);
  margin-top: var(--space_4);
}

.notice_box {
  border: 1px solid var(--gold_dim);
  background: rgba(212, 162, 76, 0.05);
  padding: var(--space_4) var(--space_5);
  font-size: var(--size_sm);
  color: var(--bone_dim);
  margin-top: var(--space_4);
}

/* Pillar summary (T1 through T14 audit) */
.pillar_summary {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--rule);
  margin-top: var(--space_5);
}
@media (max-width: 900px) { .pillar_summary { grid-template-columns: repeat(2, 1fr); } }

.pillar_card {
  background: var(--ink_2);
  padding: var(--space_4) var(--space_5);
  display: flex;
  flex-direction: column;
  gap: var(--space_2);
  border-top: 2px solid var(--gold_dim);
}
.pillar_card.is_strong { border-top-color: var(--sage); }
.pillar_card.is_weak  { border-top-color: var(--ember); }

.pillar_card .pillar_label {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--bone_faint);
}
.pillar_card .pillar_value {
  font-family: var(--font_display);
  font-size: var(--size_xl);
  font-weight: 400;
  font-variant-numeric: tabular-nums;
  font-variation-settings: 'opsz' 36, 'SOFT' 50;
}
.pillar_card .pillar_value .denom { font-size: 0.6em; color: var(--bone_faint); }

/* Tier grid (T1 through T14 individual tiers) */
.tier_grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--rule);
}
@media (max-width: 900px) { .tier_grid { grid-template-columns: 1fr; } }

.tier_card {
  background: var(--ink_2);
  padding: var(--space_5) var(--space_6);
  border-left: 4px solid var(--bone_faint);
}
.tier_card.is_complete { border-left-color: var(--sage); }
.tier_card.is_partial  { border-left-color: var(--gold); }
.tier_card.is_missing  { border-left-color: var(--crimson); }

.tier_head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space_4);
  margin-bottom: var(--space_3);
}
.tier_id {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
}
.tier_id .pillar_tag {
  margin-left: var(--space_2);
  padding: 2px 8px;
  border: 1px solid var(--rule_strong);
  color: var(--bone_faint);
}
.tier_status {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.tier_card.is_complete .tier_status { color: var(--sage); }
.tier_card.is_partial  .tier_status { color: var(--gold); }
.tier_card.is_missing  .tier_status { color: var(--ember); }

.tier_name {
  font-family: var(--font_display);
  font-size: var(--size_xl);
  font-weight: 400;
  margin-bottom: var(--space_2);
  font-variation-settings: 'opsz' 48, 'SOFT' 50;
}
.tier_intent {
  font-family: var(--font_body);
  color: var(--bone_dim);
  font-size: var(--size_sm);
  line-height: 1.5;
  margin-bottom: var(--space_4);
}

.tier_progress {
  height: 4px;
  background: var(--rule);
  margin-bottom: var(--space_4);
  position: relative;
  overflow: hidden;
}
.tier_progress_fill {
  height: 100%;
  background: var(--gold);
  transition: width 800ms var(--ease_out);
}
.tier_card.is_complete .tier_progress_fill { background: var(--sage); }
.tier_card.is_missing  .tier_progress_fill { background: var(--crimson); }

.tier_check_list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  list-style: none;
}
.tier_check_list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space_3);
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.04em;
  color: var(--bone_dim);
}
.tier_check_list li .glyph {
  flex-shrink: 0;
  width: 14px;
  font-weight: 700;
  font-family: var(--font_mono);
}
.tier_check_list li.is_pass { color: var(--bone); }
.tier_check_list li.is_pass .glyph { color: var(--sage); }
.tier_check_list li.is_fail .glyph { color: var(--ember); }

/* Framework comparison matrix table */
.matrix_tbl { font-size: var(--size_xs); }
.matrix_tbl th, .matrix_tbl td {
  white-space: nowrap;
  padding: 8px 12px;
}
.matrix_tbl th:first-child, .matrix_tbl td:first-child {
  position: sticky;
  left: 0;
  background: var(--ink);
  text-align: left;
  white-space: normal;
  min-width: 220px;
  border-right: 1px solid var(--rule_strong);
}
.matrix_tbl tr.is_current td:first-child { background: var(--ink_2); border-left: 3px solid var(--gold); }
.matrix_tbl tr.is_current td { background: var(--ink_2); color: var(--bone); font-weight: 500; }
.matrix_tbl tr.is_tdg_pref td:first-child::before {
  content: 'TDG';
  display: inline-block;
  padding: 2px 6px;
  font-size: 9px;
  background: var(--gold);
  color: var(--ink);
  font-family: var(--font_mono);
  letter-spacing: 0.12em;
  margin-right: 8px;
}
.matrix_tag {
  display: inline-block;
  padding: 2px 8px;
  border: 1px solid var(--rule_strong);
  font-family: var(--font_mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.matrix_tag.high      { border-color: var(--sage);    color: var(--sage); }
.matrix_tag.medium    { border-color: var(--gold);    color: var(--gold); }
.matrix_tag.low       { border-color: var(--ember);   color: var(--ember); }
.matrix_tag.unlimited { border-color: var(--sage);    color: var(--sage); }
.matrix_tag.partial   { border-color: var(--gold);    color: var(--gold); }
.matrix_tag.none, .matrix_tag.unsupported { border-color: var(--crimson); color: var(--ember); }
.matrix_tag.native    { border-color: var(--sage);    color: var(--sage); }
.matrix_tag.manual    { border-color: var(--bone_dim); color: var(--bone_dim); }
.matrix_tag.platform, .matrix_tag.plugin, .matrix_tag.module, .matrix_tag.extension { border-color: var(--bone_dim); color: var(--bone_dim); }

/* Per-check fix text inside tier cards */
.tier_check_list li .check_fix {
  margin-top: 4px;
  font-family: var(--font_body);
  font-size: var(--size_sm);
  color: var(--bone_dim);
  line-height: 1.5;
  font-weight: 300;
  letter-spacing: 0;
  text-transform: none;
}

/* Tier explanation expandable */
.tier_explanation {
  margin-top: var(--space_4);
  padding-top: var(--space_4);
  border-top: 1px solid var(--rule);
}
.tier_explanation summary {
  cursor: pointer;
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space_2);
}
.tier_explanation summary::-webkit-details-marker { display: none; }
.tier_explanation summary::before {
  content: '+';
  display: inline-block;
  width: 14px;
  font-family: var(--font_mono);
  font-weight: 700;
}
.tier_explanation[open] summary::before { content: '\2212'; }
.tier_explanation summary:hover { color: var(--bone); }

.tier_explanation_body { padding-top: var(--space_4); }
.expl_headline {
  font-family: var(--font_display);
  font-style: italic;
  font-size: var(--size_lg);
  color: var(--gold);
  font-variation-settings: 'opsz' 36, 'SOFT' 80;
  margin-bottom: var(--space_3);
}
.expl_para {
  font-family: var(--font_body);
  font-size: var(--size_base);
  color: var(--bone_dim);
  line-height: 1.55;
  margin-bottom: var(--space_4);
}
.expl_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space_4);
}
@media (max-width: 700px) { .expl_grid { grid-template-columns: 1fr; } }

.expl_label {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone_faint);
  margin-bottom: var(--space_2);
}
.expl_text {
  font-family: var(--font_body);
  font-size: var(--size_sm);
  color: var(--bone);
  line-height: 1.5;
  margin-bottom: var(--space_4);
}

/* Section summaries */
.section_summaries {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--rule);
}
.summary_line {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--space_5);
  padding: var(--space_4) var(--space_5);
  background: var(--ink_2);
  align-items: start;
}
@media (max-width: 700px) { .summary_line { grid-template-columns: 1fr; gap: var(--space_2); } }

.summary_key {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--gold);
}
.summary_text {
  font-family: var(--font_body);
  font-size: var(--size_md);
  color: var(--bone);
  line-height: 1.5;
}

/* Framework note block */
.fw_note {
  margin-top: var(--space_5);
  padding: var(--space_5);
  border-left: 3px solid var(--gold);
  background: rgba(212, 162, 76, 0.04);
}
.fw_note h4 {
  font-family: var(--font_display);
  font-size: var(--size_xl);
  font-weight: 400;
  margin-bottom: var(--space_3);
  font-variation-settings: 'opsz' 48, 'SOFT' 50;
}
.fw_note_label {
  font-family: var(--font_mono);
  font-size: var(--size_xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone_faint);
  margin-top: var(--space_3);
  margin-bottom: var(--space_2);
}
.fw_note_list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.fw_note_list li {
  padding: 4px 0 4px 18px;
  position: relative;
  font-family: var(--font_body);
  font-size: var(--size_sm);
  color: var(--bone_dim);
  line-height: 1.5;
}
.fw_note_list.strengths li::before {
  content: '+';
  position: absolute;
  left: 0;
  color: var(--sage);
  font-family: var(--font_mono);
  font-weight: 700;
}
.fw_note_list.gaps li::before {
  content: '\2212';
  position: absolute;
  left: 0;
  color: var(--ember);
  font-family: var(--font_mono);
  font-weight: 700;
}
.fw_note_para {
  font-family: var(--font_body);
  font-size: var(--size_sm);
  color: var(--bone_dim);
  line-height: 1.55;
  margin-bottom: var(--space_3);
}
