/* Kerberos Guide theme — gold accent for the golden ticket motif
 *
 * Palette:
 *   Background:  #0a1628 → #0d1117 (deep navy, shared with wolf family)
 *   Accent:      #ffd740 / #ffab00 (gold — golden tickets, Cerberus)
 *   Glow:        #ffe082 (warm gold)
 *   Text:        #c9d1d9
 *   Circuit:     #2a4a6b (steel blue)
 */

/* ---------- Custom primary color (both schemes) ---------- */

:root>* {
  --md-primary-fg-color: #0d1b2a;
  --md-primary-fg-color--light: #1b2838;
  --md-primary-fg-color--dark: #060e18;
}

/* ---------- Dark mode (slate — default) ---------- */

[data-md-color-scheme="slate"] {
  /* Tune the slate hue to match deep navy */
  --md-hue: 215;

  /* Accent — gold from the golden ticket motif */
  --md-accent-fg-color: #ffd740;
  --md-accent-fg-color--transparent: #ffd7401a;

  /* Deep navy background */
  --md-default-bg-color: #0d1117;
  --md-default-bg-color--light: #111d2b;
  --md-default-bg-color--lighter: #162234;
  --md-default-bg-color--lightest: #1c2d42;

  /* Code blocks — slightly lighter navy */
  --md-code-bg-color: #0d1a2d;
  --md-code-fg-color: #c9d1d9;
  --md-code-hl-color: #ffd7401a;

  /* Footer */
  --md-footer-bg-color: #060e18;
  --md-footer-bg-color--dark: #040a12;
  --md-footer-fg-color: #ffffffb3;
  --md-footer-fg-color--light: #ffffff73;
  --md-footer-fg-color--lighter: #ffffff42;

  /* Typeset */
  --md-typeset-color: #c9d1d9;
  --md-typeset-a-color: #ffd740;
}

/* Header bar — deep navy */
[data-md-color-scheme="slate"] .md-header {
  background-color: #0a1628;
}

/* Tabs bar — same deep navy */
[data-md-color-scheme="slate"] .md-tabs {
  background-color: #0a1628;
}

/* Left sidebar — subtle navy */
[data-md-color-scheme="slate"] .md-sidebar {
  background-color: #0d1117;
}

/* Nav link hover — gold glow */
[data-md-color-scheme="slate"] .md-nav__link:hover {
  color: #ffd740;
}

/* Active nav item — gold */
[data-md-color-scheme="slate"] .md-nav__link--active {
  color: #ffd740;
}

/* Search bar */
[data-md-color-scheme="slate"] .md-search__input {
  background-color: #162234;
}

/* Admonitions — steel blue border */
[data-md-color-scheme="slate"] .md-typeset .admonition,
[data-md-color-scheme="slate"] .md-typeset details {
  border-color: #2a4a6b;
}

/* Tables — deep navy headers */
[data-md-color-scheme="slate"] .md-typeset table:not([class]) th {
  background-color: #1b2838;
  color: #e0e0e0;
}

[data-md-color-scheme="slate"] .md-typeset table:not([class]) td {
  border-color: #1c2d42;
}

/* Announcement bar — dark navy with gold accent */
[data-md-color-scheme="slate"] .md-banner {
  background-color: #060e18;
  color: #ffffffb3;
}

/* ---------- Header title — make site name clickable via logo link ---------- */

.md-header__title {
  cursor: pointer;
  pointer-events: none;
}

.md-header__ellipsis {
  pointer-events: auto;
}

/* Wrap the logo link over the adjacent title text */
.md-header__button.md-logo {
  position: relative;
  z-index: 1;
}

.md-header__button.md-logo::after {
  content: "";
  position: absolute;
  top: 0;
  right: -200px;
  bottom: 0;
  left: 0;
  z-index: 1;
}

/* ---------- Wider content area on large screens ---------- */

/* Default max-width is 61rem (~976px).  On wide displays this wastes space
   and squeezes tables with many columns (e.g. the etype inputs table).
   Use a percentage with a floor so the content scales with the viewport
   while keeping comfortable margins at every width. */
@media screen and (min-width: 76.25em) {
  .md-grid {
    max-width: min(90%, 100rem);
  }
}

/* Let wide tables scroll horizontally instead of wrapping into unreadable
   columns on mid-size screens. */
.md-typeset table:not([class]) {
  display: block;
  overflow-x: auto;
  white-space: normal;
}

/* Keep header cells from wrapping on wide tables so column labels stay on
   one line — the body cells wrap naturally. */
.md-typeset table:not([class]) th {
  white-space: nowrap;
}

/* ---------- Light mode ---------- */

[data-md-color-scheme="default"] {
  --md-accent-fg-color: #f57f17;
  --md-typeset-a-color: #f57f17;
}

/* Header + tabs in light mode — same deep navy */
[data-md-color-scheme="default"] .md-header {
  background-color: #0d1b2a;
}

[data-md-color-scheme="default"] .md-tabs {
  background-color: #0d1b2a;
}

/* ---------- Etype calculator ---------- */

/* Tab bar */
.etype-tabs {
  display: flex;
  gap: 0;
  /* Use inset box-shadow instead of border-bottom for the divider line.
     overflow-x:auto forces overflow-y:auto (CSS spec), which clips the
     margin-bottom:-2px trick that made tab borders overlap the container
     border.  An inset shadow renders inside the padding box and is not
     affected by overflow clipping. */
  box-shadow: inset 0 -2px 0 0 var(--md-default-bg-color--lightest, #1c2d42);
  margin-bottom: 1rem;
  overflow-x: auto;
}

.etype-tab {
  padding: 0.6rem 1rem;
  border: none;
  background: none;
  color: var(--md-typeset-color, #c9d1d9);
  font-family: var(--md-text-font-family, inherit);
  font-size: 0.8rem;
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
}

.etype-tab:hover {
  color: var(--md-accent-fg-color, #ffd740);
}

.etype-tab--active {
  color: var(--md-accent-fg-color, #ffd740);
  border-bottom-color: var(--md-accent-fg-color, #ffd740);
}

/* Setting description */
.etype-setting-desc {
  font-size: 0.85rem;
  opacity: 0.8;
  margin: 0 0 1rem;
}

/* Status badge */
.etype-status {
  display: inline-block;
  padding: 0.25rem 0.75rem;
  border-radius: 1rem;
  font-size: 0.8rem;
  font-weight: 600;
  margin-bottom: 1rem;
}

.etype-status--secure {
  background: #1a3a2a;
  color: #4ade80;
  border: 1px solid #22633a;
}

.etype-status--transitional {
  background: #3a3520;
  color: #fbbf24;
  border: 1px solid #6b5c1f;
}

.etype-status--insecure {
  background: #3a1a1a;
  color: #f87171;
  border: 1px solid #7f1d1d;
}

.etype-status--notset {
  background: #1c2d42;
  color: #94a3b8;
  border: 1px solid #2a4a6b;
}

/* Light mode status badges */
[data-md-color-scheme="default"] .etype-status--secure {
  background: #dcfce7;
  color: #166534;
  border-color: #86efac;
}

[data-md-color-scheme="default"] .etype-status--transitional {
  background: #fef9c3;
  color: #854d0e;
  border-color: #fde047;
}

[data-md-color-scheme="default"] .etype-status--insecure {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fca5a5;
}

[data-md-color-scheme="default"] .etype-status--notset {
  background: #f1f5f9;
  color: #475569;
  border-color: #cbd5e1;
}

/* Two-column layout */
.etype-calc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 60em) {
  .etype-calc-grid {
    grid-template-columns: 1fr;
  }
}

/* Bit checkbox rows */
.etype-bits h3,
.etype-values h3 {
  margin-top: 0;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.7;
  border: none;
}

.etype-bit-row {
  padding: 0.4rem 0.5rem;
  border-radius: 4px;
  margin-bottom: 2px;
  transition: background 0.1s;
}

.etype-bit-row:hover {
  background: var(--md-default-bg-color--lighter, #162234);
}

.etype-bit-row label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.85rem;
}

.etype-bit-row input[type="checkbox"] {
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  accent-color: var(--md-accent-fg-color, #ffd740);
}

.etype-bit-info {
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.75rem;
  min-width: 7rem;
  opacity: 0.7;
}

.etype-bit-name {
  flex: 1;
}

.etype-bit-etype {
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.7rem;
  opacity: 0.5;
  min-width: 5rem;
  text-align: right;
}

/* Bit badges */
.etype-bit-badge {
  font-size: 0.65rem;
  padding: 0.1rem 0.4rem;
  border-radius: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.etype-bit-badge--removed {
  background: #3a1a1a;
  color: #f87171;
}

.etype-bit-badge--deprecated {
  background: #3a3520;
  color: #fbbf24;
}

.etype-bit-badge--recommended {
  background: #1a3a2a;
  color: #4ade80;
}

.etype-bit-badge--special {
  background: #1a2a3a;
  color: #60a5fa;
}

.etype-bit-badge--feature {
  background: #1a2a3a;
  color: #a78bfa;
}

.etype-bit-badge--neutral {
  background: #1c2d42;
  color: #94a3b8;
}

/* Light mode badges */
[data-md-color-scheme="default"] .etype-bit-badge--removed {
  background: #fee2e2;
  color: #991b1b;
}

[data-md-color-scheme="default"] .etype-bit-badge--deprecated {
  background: #fef9c3;
  color: #854d0e;
}

[data-md-color-scheme="default"] .etype-bit-badge--recommended {
  background: #dcfce7;
  color: #166534;
}

[data-md-color-scheme="default"] .etype-bit-badge--special {
  background: #dbeafe;
  color: #1e40af;
}

[data-md-color-scheme="default"] .etype-bit-badge--feature {
  background: #ede9fe;
  color: #5b21b6;
}

[data-md-color-scheme="default"] .etype-bit-badge--neutral {
  background: #f1f5f9;
  color: #475569;
}

/* Ignored bit styling */
.etype-bit--ignored {
  opacity: 0.45;
}

.etype-bit-ignored-note {
  font-size: 0.7rem;
  color: #60a5fa;
  margin-left: 2rem;
  display: block;
}

/* Value input fields */
.etype-field {
  margin-bottom: 0.75rem;
}

.etype-field>label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  opacity: 0.6;
  margin-bottom: 0.25rem;
}

.etype-input-row {
  display: flex;
  gap: 0.5rem;
}

.etype-input-row input {
  flex: 1;
  padding: 0.5rem 0.75rem;
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.9rem;
  background: var(--md-code-bg-color, #0d1a2d);
  color: var(--md-code-fg-color, #c9d1d9);
  border: 1px solid var(--md-default-bg-color--lightest, #1c2d42);
  border-radius: 4px;
  outline: none;
}

.etype-input-row input:focus {
  border-color: var(--md-accent-fg-color, #ffd740);
}

.etype-input-row input.etype-input--invalid {
  border-color: #f87171;
  background: #3a1a1a;
}

.etype-input-row input[readonly] {
  cursor: default;
}

/* Copy buttons */
.etype-copy-btn {
  padding: 0.4rem 0.75rem;
  font-size: 0.75rem;
  font-family: var(--md-text-font-family, inherit);
  background: var(--md-default-bg-color--lightest, #1c2d42);
  color: var(--md-typeset-color, #c9d1d9);
  border: 1px solid var(--md-default-bg-color--lightest, #1c2d42);
  border-radius: 4px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}

.etype-copy-btn:hover {
  background: var(--md-accent-fg-color, #ffd740);
  color: #000;
}

.etype-copy-btn--copied {
  background: #1a3a2a;
  color: #4ade80;
  border-color: #22633a;
}

.etype-copy-btn--failed {
  background: #3a1a1a;
  color: #f87171;
  border-color: #7f1d1d;
}

/* Preset buttons */
.etype-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 1rem;
}

.etype-preset-btn {
  padding: 0.35rem 0.7rem;
  font-size: 0.75rem;
  font-family: var(--md-code-font-family, monospace);
  background: var(--md-default-bg-color--lighter, #162234);
  color: var(--md-typeset-color, #c9d1d9);
  border: 1px solid var(--md-default-bg-color--lightest, #1c2d42);
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.etype-preset-btn:hover {
  border-color: var(--md-accent-fg-color, #ffd740);
}

/* Active preset — matches the current value */
.etype-preset-btn--active {
  border-color: var(--md-accent-fg-color, #ffd740);
  background: var(--md-default-bg-color--lightest, #1c2d42);
}

/* Warnings */
.etype-warnings {
  border-left: 3px solid #fbbf24;
  padding: 0.5rem 0.75rem;
  margin-bottom: 1rem;
  background: var(--md-default-bg-color--lighter, #162234);
  border-radius: 0 4px 4px 0;
}

.etype-warning-item {
  font-size: 0.8rem;
  padding: 0.25rem 0;
  color: #fbbf24;
}

.etype-warning-item+.etype-warning-item {
  border-top: 1px solid var(--md-default-bg-color--lightest, #1c2d42);
}

.etype-no-warnings {
  font-size: 0.8rem;
  opacity: 0.5;
  margin: 0 0 1rem;
}

[data-md-color-scheme="default"] .etype-warnings {
  background: #fffbeb;
  border-left-color: #d97706;
}

[data-md-color-scheme="default"] .etype-warning-item {
  color: #92400e;
}

[data-md-color-scheme="default"] .etype-preset-btn--active {
  border-color: #f57f17;
  background: #fff8e1;
}

[data-md-color-scheme="default"] .etype-copy-btn--failed {
  background: #fee2e2;
  color: #991b1b;
  border-color: #fca5a5;
}

[data-md-color-scheme="default"] .etype-input-row input.etype-input--invalid {
  border-color: #f87171;
  background: #fee2e2;
}

/* PowerShell block */
.etype-ps-block {
  position: relative;
}

.etype-ps-block pre {
  margin: 0;
  padding: 0.75rem;
  background: var(--md-code-bg-color, #0d1a2d);
  border: 1px solid var(--md-default-bg-color--lightest, #1c2d42);
  border-radius: 4px;
  overflow-x: auto;
}

.etype-ps-block code {
  font-size: 0.8rem;
  white-space: pre;
}

.etype-ps-block .etype-copy-btn {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
}

/* Hide back-to-top button on the calculator page.
   CSS :has() for modern browsers; body class fallback set by JS init. */
body:has(#etype-calculator) .md-top,
body.etype-calculator-page .md-top {
  display: none !important;
}

/* Disabled checkboxes in ignored rows */
.etype-bit--ignored label {
  cursor: default;
}

/* ================================================================== */
/*  Event Decoder                                                      */
/* ================================================================== */

/* Hide back-to-top on the decoder page */
body:has(#event-decoder) .md-top,
body.event-decoder-page .md-top {
  display: none !important;
}

/* --- Input section --- */

.evdec-label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
}

.evdec-textarea {
  width: 100%;
  min-height: 8rem;
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.8rem;
  line-height: 1.45;
  padding: 0.75rem;
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.3rem;
  background: var(--md-code-bg-color);
  color: var(--md-code-fg-color);
  resize: vertical;
  box-sizing: border-box;
}

.evdec-textarea:focus {
  outline: none;
  border-color: var(--md-accent-fg-color);
  box-shadow: 0 0 0 2px rgba(var(--md-accent-fg-color--rgb, 255 183 77), 0.25);
}

.evdec-textarea::placeholder {
  color: var(--md-default-fg-color--lighter);
  opacity: 0.7;
}

.evdec-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
  flex-wrap: wrap;
}

.evdec-hint {
  font-size: 0.75rem;
  color: var(--md-default-fg-color--lighter);
  margin-left: auto;
}

/* --- Buttons --- */

.evdec-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.9rem;
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.25rem;
  background: var(--md-code-bg-color);
  color: var(--md-default-fg-color--light);
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.8rem;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.evdec-btn:hover {
  border-color: var(--md-accent-fg-color);
  color: var(--md-accent-fg-color);
}

.evdec-btn--primary {
  background: var(--md-accent-fg-color);
  color: var(--md-accent-bg-color, #000);
  border-color: var(--md-accent-fg-color);
  font-weight: 600;
}

.evdec-btn--primary:hover {
  filter: brightness(1.1);
  color: var(--md-accent-bg-color, #000);
}

.evdec-btn--copied {
  background: #2e7d32 !important;
  border-color: #2e7d32 !important;
  color: #fff !important;
}

/* --- Example buttons --- */

.evdec-examples {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.75rem;
  flex-wrap: wrap;
}

.evdec-examples-label {
  font-size: 0.8rem;
  color: var(--md-default-fg-color--lighter);
  margin-right: 0.2rem;
}

.evdec-example-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.2rem;
  background: transparent;
  color: var(--md-default-fg-color--light);
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.75rem;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}

.evdec-example-btn:hover {
  border-color: var(--md-accent-fg-color);
  color: var(--md-accent-fg-color);
}

/* --- Error display --- */

.evdec-error {
  margin-top: 1rem;
  padding: 0.6rem 0.8rem;
  border-left: 4px solid #e53935;
  background: rgba(229, 57, 53, 0.08);
  border-radius: 0 0.3rem 0.3rem 0;
  color: var(--md-default-fg-color);
  font-size: 0.85rem;
}

/* --- Results area --- */

.evdec-results {
  margin-top: 1.25rem;
}

/* --- Header --- */

.evdec-header {
  margin-bottom: 1rem;
}

.evdec-header-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.evdec-event-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3rem;
  padding: 0.3rem 0.6rem;
  background: var(--md-accent-fg-color);
  color: var(--md-accent-bg-color, #000);
  font-family: var(--md-code-font-family, monospace);
  font-size: 1.1rem;
  font-weight: 700;
  border-radius: 0.3rem;
}

.evdec-header-title {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.evdec-event-name {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--md-default-fg-color);
}

.evdec-event-desc {
  font-size: 0.8rem;
  color: var(--md-default-fg-color--light);
}

.evdec-status {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.7rem;
  border-radius: 1rem;
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.8rem;
  font-weight: 600;
  margin-left: auto;
}

.evdec-status--success {
  background: rgba(46, 125, 50, 0.15);
  color: #2e7d32;
  border: 1px solid rgba(46, 125, 50, 0.3);
}

.evdec-status--failure {
  background: rgba(229, 57, 53, 0.12);
  color: #e53935;
  border: 1px solid rgba(229, 57, 53, 0.3);
}

.evdec-header-meta {
  display: flex;
  gap: 1rem;
  margin-top: 0.3rem;
  flex-wrap: wrap;
}

.evdec-meta-item {
  font-size: 0.78rem;
  color: var(--md-default-fg-color--lighter);
  font-family: var(--md-code-font-family, monospace);
}

/* --- Result actions bar (Copy Details) --- */

.evdec-result-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

/* --- Warnings --- */

.evdec-warnings {
  margin-bottom: 1rem;
  padding: 0.6rem 0.8rem;
  border-left: 4px solid var(--md-accent-fg-color);
  background: rgba(255, 183, 77, 0.08);
  border-radius: 0 0.3rem 0.3rem 0;
}

.evdec-warning-item {
  padding: 0.3rem 0;
  font-size: 0.85rem;
  color: var(--md-default-fg-color);
  line-height: 1.4;
}

.evdec-warning-item::before {
  content: "\26a0\fe0f ";
}

.evdec-warning-item+.evdec-warning-item {
  border-top: 1px solid var(--md-default-fg-color--lightest);
}

/* --- Fields table --- */

.evdec-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  table-layout: fixed;
}

.evdec-table th {
  text-align: left;
  padding: 0.5rem 0.6rem;
  border-bottom: 2px solid var(--md-default-fg-color--lightest);
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--md-default-fg-color--light);
}

.evdec-table th:nth-child(1) {
  width: 22%;
}

.evdec-table th:nth-child(2) {
  width: 28%;
}

.evdec-table th:nth-child(3) {
  width: 50%;
}

.evdec-table td {
  padding: 0.45rem 0.6rem;
  border-bottom: 1px solid var(--md-default-fg-color--lightest);
  vertical-align: top;
  line-height: 1.45;
  word-break: break-word;
}

.evdec-table tbody tr:hover {
  background: rgba(var(--md-accent-fg-color--rgb, 255 183 77), 0.06);
}

.evdec-field-name {
  font-weight: 600;
  color: var(--md-default-fg-color);
  white-space: nowrap;
}

.evdec-field-raw code {
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.82rem;
  background: var(--md-code-bg-color);
  padding: 0.1rem 0.3rem;
  border-radius: 0.2rem;
  word-break: break-all;
}

.evdec-field-decoded {
  color: var(--md-default-fg-color);
}

.evdec-causes {
  margin-top: 0.25rem;
  font-size: 0.78rem;
  color: var(--md-default-fg-color--light);
  font-style: italic;
}

.evdec-field-source {
  margin-top: 0.3rem;
  padding-top: 0.25rem;
  font-size: 0.73rem;
  line-height: 1.35;
  color: var(--md-default-fg-color--lighter);
  border-top: 1px dashed var(--md-default-fg-color--lightest);
}

.evdec-note {
  font-size: 0.78rem;
  color: var(--md-default-fg-color--lighter);
}

/* --- Badges (encryption type security assessment) --- */

.evdec-badge {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  border-radius: 0.2rem;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  vertical-align: middle;
}

.evdec-badge--removed {
  background: rgba(229, 57, 53, 0.12);
  color: #e53935;
}

.evdec-badge--deprecated {
  background: rgba(255, 152, 0, 0.12);
  color: #ef6c00;
}

.evdec-badge--recommended {
  background: rgba(46, 125, 50, 0.12);
  color: #2e7d32;
}

.evdec-badge--error {
  background: rgba(229, 57, 53, 0.12);
  color: #e53935;
}

.evdec-badge--neutral {
  background: rgba(120, 120, 120, 0.12);
  color: var(--md-default-fg-color--light);
}

/* --- Ticket Options breakdown --- */

.evdec-ticket-options {
  margin-top: 1.25rem;
}

.evdec-section-title {
  font-size: 0.9rem;
  font-weight: 600;
  margin: 0 0 0.5rem 0;
  color: var(--md-default-fg-color);
}

.evdec-flag-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.evdec-flag-item {
  display: flex;
  align-items: baseline;
  gap: 0.6rem;
  padding: 0.35rem 0.5rem;
  background: var(--md-code-bg-color);
  border-radius: 0.25rem;
  border-left: 3px solid var(--md-accent-fg-color);
}

.evdec-flag-bit {
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.75rem;
  color: var(--md-default-fg-color--lighter);
  min-width: 3rem;
  flex-shrink: 0;
}

.evdec-flag-name {
  font-weight: 600;
  font-size: 0.82rem;
  color: var(--md-default-fg-color);
  min-width: 10rem;
  flex-shrink: 0;
}

.evdec-flag-desc {
  font-size: 0.78rem;
  color: var(--md-default-fg-color--light);
  line-height: 1.35;
}

/* --- Etype negotiation pipeline --- */

.evdec-pipeline {
  margin-bottom: 1.25rem;
}

.evdec-pipe {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.evdec-pipe-stage {
  width: 100%;
  max-width: 32rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.3rem;
  background: var(--md-code-bg-color);
}

.evdec-pipe-stage--input {
  border-left: 3px solid var(--md-accent-fg-color);
}

.evdec-pipe-stage--fallback {
  border-left: 3px solid var(--md-default-fg-color--lighter);
  opacity: 0.8;
}

.evdec-pipe-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--md-default-fg-color--light);
  margin-bottom: 0.15rem;
}

.evdec-pipe-value {
  font-family: var(--md-code-font-family, monospace);
  font-size: 0.8rem;
  color: var(--md-default-fg-color);
  word-break: break-word;
}

.evdec-pipe-source {
  font-size: 0.7rem;
  color: var(--md-default-fg-color--lighter);
  margin-top: 0.15rem;
}

.evdec-pipe-arrow {
  font-size: 1rem;
  color: var(--md-default-fg-color--lighter);
  line-height: 1;
  padding: 0.15rem 0;
}

.evdec-pipe-arrow-result {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.4rem 0;
  color: var(--md-accent-fg-color);
  font-size: 1rem;
}

.evdec-pipe-arrow-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.evdec-pipe-result {
  width: 100%;
  max-width: 32rem;
  padding: 0.5rem 0.75rem;
  border: 2px solid var(--md-accent-fg-color);
  border-radius: 0.3rem;
  background: rgba(var(--md-accent-fg-color--rgb, 255 183 77), 0.06);
}

.evdec-pipe-result-item {
  padding: 0.2rem 0;
  font-size: 0.82rem;
}

.evdec-pipe-result-label {
  font-weight: 600;
  color: var(--md-default-fg-color--light);
}

.evdec-pipe-result-value {
  font-family: var(--md-code-font-family, monospace);
  color: var(--md-default-fg-color);
}

/* --- Responsive --- */

@media (max-width: 50em) {

  .evdec-table th:nth-child(1),
  .evdec-table th:nth-child(2),
  .evdec-table th:nth-child(3) {
    width: auto;
  }

  .evdec-field-name {
    white-space: normal;
  }

  .evdec-flag-item {
    flex-wrap: wrap;
  }

  .evdec-flag-name {
    min-width: auto;
  }

  .evdec-status {
    margin-left: 0;
  }
}