/* =========================================================
   K-TERM 2026 — Konfigurátor page styles · v5
   Table-style compact listing with color-coded stripes.
   ========================================================= */

.cfg-page-body { background: #F3F5F8; }
.cfg-page { min-height: 100vh; display: flex; flex-direction: column; }
.cfg-page .container { max-width: 1280px; }

/* ---------- Header ---------- */
.cfg-header {
  background: #fff;
  border-bottom: 1px solid var(--k-border);
  position: sticky;
  top: 0;
  z-index: 50;
  box-shadow: 0 1px 3px rgba(6,42,79,0.04);
}
.cfg-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 0;
  gap: 24px;
}
.cfg-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: #062A4F;
  font-weight: 600;
  font-size: 14px;
  padding: 6px 10px 6px 6px;
  border-radius: 6px;
  transition: background 150ms ease;
}
.cfg-back:hover { background: #F0F3F7; color: #0E7FB8; }
.cfg-header-logo img { height: 36px; display: block; }
.cfg-share {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #062A4F;
  color: #fff;
  border: 0;
  padding: 8px 14px;
  border-radius: 6px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  font-weight: 700;
  cursor: pointer;
}
.cfg-share:hover { background: #0E7FB8; }

/* ---------- Hero (compact) ---------- */
.cfg-hero {
  padding: 36px 0 18px;
  background: linear-gradient(180deg, #fff 0%, #F3F5F8 100%);
}
.cfg-hero .caption {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #0E7FB8;
  font-weight: 700;
}
.cfg-hero h1 {
  font-size: clamp(24px, 3.2vw, 34px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #062A4F;
  margin: 8px 0 14px;
}
.cfg-disclaimer {
  padding: 10px 14px;
  background: #FFF7E6;
  border: 1px solid #FAD588;
  border-left: 3px solid #D97706;
  border-radius: 6px;
  font-size: 13px;
  line-height: 1.5;
  color: #5C3A0C;
  margin: 0;
}
.cfg-disclaimer strong { color: #92400E; }

/* ---------- Sticky toolbar v6 ---------- */
.cfg-toolbar {
  background: #fff;
  border-top: 1px solid var(--k-border);
  border-bottom: 1px solid var(--k-border);
  position: sticky;
  top: 60px;
  z-index: 40;
  box-shadow: 0 2px 6px -3px rgba(6,42,79,0.08);
}

/* Filter cards row (3 columns) */
.cfg-filter-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 14px;
  padding: 16px 0 12px;
  border-bottom: 1px dashed var(--k-border-soft);
}
@media (max-width: 980px) { .cfg-filter-row { grid-template-columns: 1fr; gap: 10px; } }

.cfg-fcard {
  background: #fff;
  border: 1px solid var(--k-border);
  border-radius: 10px;
  padding: 11px 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}
.cfg-fcard.is-active {
  border-color: #0E7FB8;
  background: linear-gradient(180deg, #F0F7FB 0%, #fff 70%);
  box-shadow: 0 1px 3px rgba(14,127,184,0.1);
}
.cfg-fcard-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6B7280;
  font-weight: 700;
  white-space: nowrap;
}
.cfg-fcard.is-active .cfg-fcard-label { color: #0E7FB8; }

/* Slider header (label + value) */
.cfg-slider-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.cfg-slider-val {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: #062A4F;
  letter-spacing: -0.012em;
  white-space: nowrap;
}
.cfg-slider-val.is-off {
  font-weight: 500;
  font-style: italic;
  color: #9097A0;
  font-size: 13px;
}

/* Slider bar with filled track */
.cfg-bar {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 7px;
  border-radius: 4px;
  background: #E4E8EC;
  outline: none;
  cursor: pointer;
  margin: 2px 0 1px;
}
.cfg-bar::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #0E7FB8;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(14,127,184,0.35);
  transition: transform 100ms ease;
  margin-top: -1px;
}
.cfg-bar::-webkit-slider-thumb:hover { transform: scale(1.12); }
.cfg-bar::-webkit-slider-thumb:active { transform: scale(1.2); }
.cfg-bar::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #0E7FB8;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(14,127,184,0.35);
}
.cfg-bar::-moz-range-track { height: 7px; border-radius: 4px; }

/* Dual-handle range slider */
.cfg-range2 {
  position: relative;
  height: 22px;
  margin: 2px 0 0;
}
.cfg-range2-track {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0; right: 0;
  height: 7px;
  border-radius: 4px;
  background: #E4E8EC;
}
.cfg-range2-fill {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 7px;
  border-radius: 4px;
  background: #0E7FB8;
}
.cfg-range2-input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 22px;
  margin: 0;
  background: none;
  pointer-events: none;
  -webkit-appearance: none;
  appearance: none;
}
.cfg-range2-input::-webkit-slider-runnable-track { background: none; border: none; }
.cfg-range2-input::-moz-range-track { background: none; border: none; }
.cfg-range2-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  pointer-events: auto;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #0E7FB8;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(14,127,184,0.35);
  transition: transform 100ms ease;
}
.cfg-range2-input::-webkit-slider-thumb:hover { transform: scale(1.12); }
.cfg-range2-input::-moz-range-thumb {
  pointer-events: auto;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #0E7FB8;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(14,127,184,0.35);
}
.cfg-range2-bounds {
  display: flex;
  justify-content: space-between;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  color: #9097A0;
  letter-spacing: 0.04em;
  margin-top: 1px;
}

.cfg-fcard-select {
  width: 100%;
  font-family: inherit;
  font-size: 13.5px;
  font-weight: 600;
  color: #062A4F;
  background: #fff;
  border: 1px solid var(--k-border);
  border-radius: 7px;
  padding: 10px 32px 10px 12px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%230E7FB8' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.cfg-fcard-select:hover { border-color: #B6D5E8; }
.cfg-fcard-select:focus { outline: none; border-color: #0E7FB8; box-shadow: 0 0 0 2px rgba(14,127,184,0.18); }
.cfg-fcard.is-active .cfg-fcard-select { border-color: #0E7FB8; }

.cfg-reset:disabled { opacity: 0.4; cursor: not-allowed; border-color: var(--k-border); color: #9097A0; }

/* Sub-filter row */
.cfg-sub-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px 0;
  flex-wrap: wrap;
}
.cfg-tb-group {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cfg-sort-group { margin-left: auto; }
.cfg-tb-mini-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6B7280;
  font-weight: 600;
}
.cfg-sort-select {
  font-family: "Inter", sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #062A4F;
  background: #fff;
  border: 1px solid var(--k-border);
  border-radius: 6px;
  padding: 6px 26px 6px 10px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23062A4F' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 9px center;
}
.cfg-reset-count {
  display: inline-grid;
  place-items: center;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: #C45A1F;
  color: #fff;
  border-radius: 8px;
  font-size: 10px;
  font-weight: 700;
  margin-left: 2px;
}

.cfg-range {
  flex: 1;
  width: 100%;
  height: 5px;
  background: #ECEEF1;
  border-radius: 3px;
  appearance: none;
  outline: none;
}
.cfg-range:disabled { opacity: 0.4; cursor: not-allowed; }
.cfg-range::-webkit-slider-thumb {
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #0E7FB8;
  cursor: pointer;
  box-shadow: 0 1px 4px rgba(14,127,184,0.3);
}
.cfg-range::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #0E7FB8;
  cursor: pointer;
}

/* Pillset (typ + VSG) */
.cfg-pillset { display: inline-flex; gap: 3px; }
.cfg-pillset button {
  background: #fff;
  border: 1px solid var(--k-border);
  color: #062A4F;
  padding: 6px 12px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  transition: all 150ms ease;
}
.cfg-pillset button:hover { border-color: #B6D5E8; }
.cfg-pillset button.on {
  background: #0E7FB8;
  border-color: #0E7FB8;
  color: #fff;
}
.cfg-reset {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 1px solid var(--k-border);
  color: #6B7280;
  padding: 6px 12px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  margin-left: auto;
  transition: all 150ms ease;
}
.cfg-reset:hover { border-color: #C45A1F; color: #C45A1F; }

/* ---------- Results ---------- */
.cfg-results-section { padding: 20px 0 56px; }
.cfg-results-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--k-border-soft);
  font-size: 14px;
  color: #3D4551;
  flex-wrap: wrap;
  gap: 12px;
}
.cfg-results-bar strong { font-size: 16px; color: #062A4F; margin-right: 6px; }
.cfg-sort-info {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  color: #6B7280;
}
.cfg-results-meta {
  font-size: 12.5px;
  color: #6B7280;
  font-style: italic;
}

.cfg-empty-state {
  padding: 36px 24px;
  background: #fff;
  border: 1px dashed var(--k-border);
  border-radius: 12px;
  text-align: center;
  color: #3D4551;
}
.cfg-empty-state p { margin: 6px 0; font-size: 14.5px; }
.cfg-link {
  background: none; border: 0; color: #0E7FB8; font-weight: 600;
  cursor: pointer; font-size: inherit; padding: 0; text-decoration: underline;
}

/* ---------- TABLE ---------- */
.cfg-table-wrap {
  background: #fff;
  border: 1px solid var(--k-border);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(6,42,79,0.03);
}
.cfg-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  table-layout: fixed;
}
.cfg-table thead th {
  background: #F8FAFC;
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6B7280;
  font-weight: 700;
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--k-border);
}
.cfg-table th em {
  font-style: normal;
  font-weight: 500;
  font-size: 9.5px;
  opacity: 0.7;
  margin-left: 3px;
}
.th-type    { width: 92px; }
.th-code    { /* flex */ }
.th-thick   { width: 56px; text-align: right; }
.th-ug      { width: 64px; text-align: right; }
.th-num     { width: 50px; text-align: right; }
.th-rw      { width: 138px; text-align: right; }
.th-actions { width: 150px; text-align: right; }
@media (max-width: 720px) { .th-dim { display: none; } }

/* Sortable header */
.cfg-th-sort { cursor: pointer; user-select: none; transition: background 150ms ease, color 150ms ease; }
.cfg-th-sort:hover { background: #ECF3F8; color: #0E7FB8; }
.cfg-th-sort.is-sorted { color: #0E7FB8; background: #F0F7FB; }
.cfg-th-inner {
  display: inline-flex;
  align-items: baseline;
  gap: 3px;
  justify-content: flex-end;
  width: 100%;
}
.cfg-th-arrow {
  font-size: 9px;
  opacity: 0.5;
  margin-left: 2px;
}
.cfg-th-sort.is-sorted .cfg-th-arrow { opacity: 1; }

/* Row */
.cfg-row {
  cursor: pointer;
  transition: background 120ms ease;
  border-left: 4px solid transparent;
}
.cfg-row:hover { background: #F8FAFC; }
.cfg-row.is-expanded { background: #F0F7FB; }
.cfg-row.is-compared { background: #E8F3F9; }

.cfg-row.stripe-dvojsklo { border-left-color: #5FA6C8; }
.cfg-row.stripe-trojsklo { border-left-color: #062A4F; }
.cfg-row.stripe-vsg      { border-left-color: #2F7D4A; }
.cfg-row.stripe-acoustic { border-left-color: #C45A1F; }
.cfg-row.stripe-solar    { border-left-color: #D97706; }

.cfg-row td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--k-border-soft);
  vertical-align: middle;
}
.cfg-row:last-child td { border-bottom: none; }

/* Cell: type */
.cfg-cell-type { padding-left: 14px; }
.cfg-type-pill {
  display: inline-block;
  padding: 3px 8px;
  background: #F0F7FB;
  border: 1px solid #B6D5E8;
  color: #0E7FB8;
  border-radius: 4px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
}
.cfg-row.stripe-vsg .cfg-type-pill { background: #E7F3EA; border-color: #A6CFB1; color: #2F7D4A; }
.cfg-row.stripe-acoustic .cfg-type-pill { background: #FFE7D6; border-color: #FAB87A; color: #C45A1F; }
.cfg-row.stripe-solar .cfg-type-pill { background: #FFF7E6; border-color: #FAD588; color: #D97706; }
.cfg-row.stripe-trojsklo .cfg-type-pill { background: #E2E8F0; border-color: #8595A8; color: #062A4F; }

/* Cell: code */
.cfg-cell-code {
  font-family: "JetBrains Mono", monospace;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.cfg-cell-code code {
  font-size: 13px;
  font-weight: 600;
  color: #062A4F;
  background: transparent;
  letter-spacing: -0.005em;
}
.cfg-row-badges {
  display: inline-flex;
  gap: 3px;
  flex-wrap: wrap;
}
.cfg-row-badges .cfg-badge {
  font-size: 9px;
  padding: 2px 5px;
}

/* Cell: thickness */
.cfg-cell-thick {
  text-align: right;
  font-family: "Inter Tight", sans-serif;
  white-space: nowrap;
}
.cfg-cell-thick strong {
  font-size: 16px;
  font-weight: 800;
  color: #062A4F;
  letter-spacing: -0.018em;
}
.cfg-cell-thick span {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  color: #6B7280;
  margin-left: 2px;
  letter-spacing: 0.06em;
}

/* Cell: numeric (Ug, Lt, g) */
.cfg-cell-num {
  text-align: right;
  font-weight: 700;
  font-size: 13.5px;
  color: #062A4F;
  letter-spacing: -0.005em;
  font-family: "JetBrains Mono", monospace;
}
.cfg-cell-dim { color: #6B7280; font-weight: 600; }
@media (max-width: 720px) { .cfg-cell-dim { display: none; } }

/* Cell: Rw */
.cfg-cell-rw {
  text-align: right;
  font-weight: 600;
  font-size: 13px;
  color: #062A4F;
  font-family: "JetBrains Mono", monospace;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.cfg-cell-rw.is-primary { color: #0E7FB8; background: rgba(14,127,184,0.05); }

/* Cell: actions */
.cfg-cell-actions {
  text-align: right;
  white-space: nowrap;
}
.cfg-cell-actions > * { vertical-align: middle; }
.cfg-icon-btn {
  background: #fff;
  border: 1px solid var(--k-border);
  color: #062A4F;
  width: 30px;
  height: 30px;
  border-radius: 6px;
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  margin-right: 3px;
  transition: all 150ms ease;
}
.cfg-icon-btn:hover:not(:disabled) {
  border-color: #B6D5E8;
  background: #F0F7FB;
}
.cfg-icon-btn.on {
  background: #0E7FB8;
  border-color: #0E7FB8;
  color: #fff;
}
.cfg-icon-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.cfg-expand-btn { color: #6B7280; }
.cfg-expand-btn svg { transition: transform 180ms ease; }
.btn.btn-xs {
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 700;
  border-radius: 6px;
  margin: 0 3px;
}

/* Detail row (expanded) */
.cfg-row-detail {
  background: #FBFCFE !important;
  border-left: 4px solid var(--k-border);
}
.cfg-row-detail.stripe-dvojsklo { border-left-color: #5FA6C8; }
.cfg-row-detail.stripe-trojsklo { border-left-color: #062A4F; }
.cfg-row-detail.stripe-vsg      { border-left-color: #2F7D4A; }
.cfg-row-detail.stripe-acoustic { border-left-color: #C45A1F; }
.cfg-row-detail.stripe-solar    { border-left-color: #D97706; }
.cfg-row-detail td {
  padding: 0;
  border-bottom: 2px solid var(--k-border);
}
.cfg-detail-inner {
  padding: 16px 20px 20px;
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 20px;
  align-items: start;
}
@media (max-width: 800px) {
  .cfg-detail-inner { grid-template-columns: 1fr; }
}
.cfg-detail-schema { display: flex; flex-direction: column; gap: 8px; }
.cfg-detail-codeline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 12px;
  background: #0A2540;
  border-radius: 6px;
  cursor: pointer;
  transition: background 150ms ease;
}
.cfg-detail-codeline:hover { background: #0E2D50; }
.cfg-detail-codeline code {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  color: #C8E0EB;
  font-weight: 600;
  background: transparent;
  word-break: break-word;
  letter-spacing: -0.005em;
}
.cfg-copy-mini {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px;
  color: rgba(200,224,235,0.5);
  letter-spacing: 0.14em;
  font-weight: 700;
  flex-shrink: 0;
  margin-left: 10px;
}
.cfg-detail-codeline:hover .cfg-copy-mini { color: #C8E0EB; }

.cfg-detail-specs {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px 16px;
}
.cfg-detail-specs > div { display: flex; flex-direction: column; gap: 1px; }
.cfg-detail-specs > div.full { grid-column: 1 / -1; }
.cfg-detail-specs dt {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px;
  color: #6B7280;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0;
  font-weight: 600;
}
.cfg-detail-specs dd {
  font-size: 13px;
  font-weight: 600;
  color: #062A4F;
  margin: 0;
  display: inline-flex;
  gap: 4px;
  flex-wrap: wrap;
}

/* ---------- Layer schema ---------- */
.cfg-schema {
  display: flex;
  height: 30px;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid #D5DCE3;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.6);
}
.cfg-schema-layer {
  position: relative;
  display: grid;
  place-items: center;
  min-width: 4px;
  overflow: hidden;
  border-right: 1px solid rgba(8,84,128,0.08);
}
.cfg-schema-layer:last-child { border-right: none; }
.cfg-schema-layer .schema-label {
  font-family: "JetBrains Mono", monospace;
  font-size: 9px;
  color: rgba(6,42,79,0.6);
  white-space: nowrap;
  letter-spacing: 0.02em;
  font-weight: 600;
  padding: 0 2px;
}
.schema-glass   { background: linear-gradient(180deg, #E0EEF5 0%, #C8E0EB 100%); }
.schema-cgp     { background: linear-gradient(180deg, #95C9E0 0%, #5FA6C8 100%); }
.schema-cgp-sc  { background: linear-gradient(180deg, #4B7EA0 0%, #2D5C7E 100%); }
.schema-cgp-sc .schema-label,
.schema-cgp .schema-label { color: rgba(255,255,255,0.92); }
.schema-gap-ar  { background: repeating-linear-gradient(135deg, #F2F4F7 0 5px, #E4E7EA 5px 10px); }
.schema-gap-air { background: repeating-linear-gradient(135deg, #FAFBFC 0 5px, #F0F2F4 5px 10px); }
.schema-gap-kr  { background: repeating-linear-gradient(135deg, #EFE9F8 0 5px, #DBCFEF 5px 10px); }
.schema-pvb     { background: repeating-linear-gradient(90deg, #FFE7A6 0 3px, #F4C95E 3px 6px); }
.schema-sf      { background: repeating-linear-gradient(90deg, #FFB880 0 3px, #FA7D2B 3px 6px); }
.schema-sf .schema-label { color: #5A2200; }

/* ---------- Badges ---------- */
.cfg-badge {
  display: inline-block;
  padding: 2px 6px;
  background: #0E7FB8;
  color: #fff;
  border-radius: 3px;
  font-family: "JetBrains Mono", monospace;
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
}
.cfg-badge-guardian { background: linear-gradient(90deg, #C45A1F 0%, #A23F0E 100%); }
.cfg-badge-solar    { background: linear-gradient(90deg, #D9A205 0%, #B47F03 100%); }
.cfg-badge-safety   { background: linear-gradient(90deg, #2F7D4A 0%, #1E5E33 100%); }
.cfg-badge-top      { background: linear-gradient(90deg, #0E7FB8 0%, #062A4F 100%); }
.cfg-badge-passive  { background: linear-gradient(90deg, #0E7FB8 0%, #062A4F 100%); }
.cfg-badge-lowe     { background: #5FA6C8; }
.cfg-badge-acoustic { background: linear-gradient(90deg, #6B47D1 0%, #4B2A9E 100%); }

/* ---------- Compare section ---------- */
.cfg-compare-section { padding: 12px 0 16px; }
.cfg-compare {
  background: #fff;
  border: 1.5px solid #0E7FB8;
  border-radius: 12px;
  padding: 18px 20px 20px;
  box-shadow: 0 4px 18px -10px rgba(14,127,184,0.25);
}
.cfg-compare-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  flex-wrap: wrap;
  gap: 12px;
}
.cfg-compare-head h3 {
  font-size: 16px;
  color: #062A4F;
  margin: 0;
  font-weight: 700;
}
.cfg-compare-clear {
  background: #F8FAFC;
  border: 1px solid var(--k-border);
  color: #6B7280;
  padding: 5px 11px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}
.cfg-compare-clear:hover { border-color: #C45A1F; color: #C45A1F; }
.cfg-compare-grid {
  display: grid;
  font-size: 12.5px;
  border-top: 1px solid var(--k-border-soft);
}
.cfg-compare-corner { border-right: 1px solid var(--k-border-soft); }
.cfg-compare-header {
  position: relative;
  padding: 10px 12px 12px;
  border-bottom: 1px solid var(--k-border-soft);
  background: #F8FAFC;
}
.cmp-title {
  font-family: "JetBrains Mono", monospace;
  font-weight: 700;
  color: #062A4F;
  font-size: 12px;
  padding-right: 24px;
  line-height: 1.35;
  word-break: break-word;
}
.cmp-sub { font-size: 10.5px; color: #6B7280; margin-top: 4px; }
.cfg-compare-remove {
  position: absolute;
  top: 6px;
  right: 6px;
  background: rgba(0,0,0,0.06);
  border: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  cursor: pointer;
  color: #6B7280;
  display: grid;
  place-items: center;
}
.cfg-compare-remove:hover { background: #FEE2E2; color: #B42318; }
.cfg-compare-rowkey {
  padding: 9px 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #6B7280;
  border-bottom: 1px solid var(--k-border-soft);
  border-right: 1px solid var(--k-border-soft);
  background: #FBFCFE;
}
.cfg-compare-cell {
  padding: 9px 12px;
  border-bottom: 1px solid var(--k-border-soft);
  color: #1F2328;
  word-break: break-word;
  font-size: 12.5px;
}
.cfg-compare-cell code {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: #062A4F;
  background: #F0F3F7;
  padding: 2px 5px;
  border-radius: 3px;
}
.cfg-compare-cell.is-best {
  background: linear-gradient(180deg, #E7F3EA 0%, #fff 100%);
  font-weight: 700;
  color: #16A34A;
  position: relative;
}
.cfg-compare-cell.is-best::before {
  content: '★';
  position: absolute;
  top: 5px;
  right: 7px;
  color: #16A34A;
  font-size: 10px;
}

/* ---------- Footer ---------- */
.cfg-page-footer {
  margin-top: auto;
  padding: 24px 0;
  background: #062A4F;
  color: rgba(255,255,255,0.7);
  font-size: 13px;
}
.cfg-footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.cfg-page-footer strong { color: #fff; }
.cfg-page-footer .cfg-back {
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.08);
}
.cfg-page-footer .cfg-back:hover {
  background: rgba(255,255,255,0.15);
  color: #fff;
}
.cfg-footer-meta { max-width: 520px; line-height: 1.55; }
.cfg-page-footer a {
  color: #7AC4E5;
  font-weight: 600;
  text-decoration: none;
}
.cfg-page-footer a:hover { color: #fff; }

/* ---------- Inquiry Modal ---------- */
.cfg-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(6, 42, 79, 0.55);
  backdrop-filter: blur(3px);
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 20px;
  animation: fadeIn 180ms ease;
}
@keyframes fadeIn { from { opacity: 0 } to { opacity: 1 } }
.cfg-modal {
  background: #fff;
  border-radius: 14px;
  max-width: 600px;
  width: 100%;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  box-shadow: 0 20px 60px -10px rgba(6,42,79,0.4);
  animation: slideUp 220ms ease;
}
@keyframes slideUp { from { transform: translateY(20px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }

.cfg-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 24px 18px;
  border-bottom: 1px solid var(--k-border);
  background: linear-gradient(180deg, #F8FAFC 0%, #fff 100%);
}
.cfg-modal-eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #0E7FB8;
  font-weight: 700;
}
.cfg-modal-head h2 {
  font-family: "JetBrains Mono", monospace;
  font-size: 18px;
  font-weight: 700;
  color: #062A4F;
  margin: 6px 0 6px;
  letter-spacing: -0.01em;
  word-break: break-word;
}
.cfg-modal-skladba-meta {
  font-size: 12.5px;
  color: #6B7280;
}
.cfg-modal-close {
  background: rgba(0,0,0,0.05);
  border: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  cursor: pointer;
  color: #6B7280;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.cfg-modal-close:hover { background: #FEE2E2; color: #B42318; }

.cfg-modal-body {
  padding: 18px 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cfg-modal-block {
  border: 1px solid var(--k-border);
  border-radius: 8px;
  padding: 14px 16px 14px;
  margin: 0;
}
.cfg-modal-block legend {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #6B7280;
  font-weight: 700;
  padding: 0 6px;
}
.cfg-modal-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
.cfg-modal-block:first-of-type .cfg-modal-grid { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 520px) {
  .cfg-modal-grid,
  .cfg-modal-block:first-of-type .cfg-modal-grid { grid-template-columns: 1fr 1fr; }
}
.cfg-modal-grid label,
.cfg-modal-body textarea ~ * {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cfg-modal-grid label span,
.cfg-modal-block textarea + span {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6B7280;
  font-weight: 600;
}
.cfg-modal-grid input,
.cfg-modal-block textarea {
  font-family: inherit;
  font-size: 13.5px;
  color: #062A4F;
  background: #fff;
  border: 1px solid var(--k-border);
  border-radius: 6px;
  padding: 9px 11px;
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.cfg-modal-grid input:focus,
.cfg-modal-block textarea:focus {
  border-color: #0E7FB8;
  box-shadow: 0 0 0 2px rgba(14,127,184,0.18);
}
.cfg-modal-block textarea {
  width: 100%;
  resize: vertical;
  min-height: 60px;
  margin-top: 6px;
  font-family: inherit;
}

.cfg-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 4px;
}
.cfg-modal-foot .btn {
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 700;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cfg-modal-note {
  font-size: 11.5px;
  color: #6B7280;
  line-height: 1.5;
  margin: 6px 0 0;
}
.cfg-modal-note strong { color: #062A4F; }

/* Sent state */
.cfg-modal-sent { text-align: center; padding: 32px 24px; }
.cfg-modal-sent-icon {
  width: 56px; height: 56px;
  margin: 0 auto 14px;
  background: #16A34A;
  color: #fff;
  border-radius: 50%;
  display: grid;
  place-items: center;
  box-shadow: 0 4px 16px -4px rgba(22,163,74,0.4);
}
.cfg-modal-sent-icon svg { width: 28px; height: 28px; }
.cfg-modal-sent h3 {
  font-size: 18px;
  color: #062A4F;
  margin: 0 0 8px;
  font-weight: 700;
}
.cfg-modal-sent p {
  font-size: 14px;
  color: #3D4551;
  line-height: 1.55;
  margin: 0 0 18px;
}
.cfg-modal-sent a { color: #0E7FB8; font-weight: 600; }

/* Results bar add-ons */
.cfg-results-total {
  font-family: "JetBrains Mono", monospace;
  color: #6B7280;
  font-weight: 600;
}
.cfg-link {
  background: none; border: 0; color: #0E7FB8; font-weight: 600;
  cursor: pointer; font-size: inherit; padding: 0; text-decoration: underline;
}
