@import url('fonts.css');
/* General styles */
:root {
  color-scheme: light dark;
  --brand-accent-color: #001589;
  --accent-color: var(--brand-accent-color);
  --logo-background-color: var(--accent-color);
  --logo-accent-color: var(--brand-accent-color);
  --logo-center-color: #ffffff;
  --link-color: var(--accent-color);
  --background-color: #f9f9f9;
  --surface-color: #ffffff;
  --text-color: #000000;
  --inverse-text-color: #ffffff;
  --control-bg: #f0f0f0;
  --control-text: #333333;
  --control-border: #dddddd;
  --control-hover-bg: #e0e0e0;
  --control-active-bg: #d0d0d0;
  --control-disabled-bg: #dddddd;
  --panel-bg: #f9f9f9;
  --panel-border: #ddd;
  --panel-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  --panel-shadow-hover: 0 6px 20px rgba(0, 0, 0, 0.12);
  --surface-1: color-mix(in srgb, var(--surface-color) 96%, transparent);
  --surface-2: color-mix(in srgb, var(--surface-color) 90%, transparent);
  --text-muted: var(--muted-text-color);
  --border-radius: 5px;
  --spacing-2xs: 2px;
  --spacing-xs: 4px;
  --spacing-sm: 5px;
  --spacing-md: 8px;
  --spacing-lg: 10px;
  --spacing-xl: 15px;
  --spacing-xxl: 20px;
  --page-padding: var(--spacing-xxl);
  --main-top-padding-multiplier: 1.5;
  --gap-size: var(--spacing-lg);
  --button-size: 30px;
  --select-height: var(--button-size);
  --button-icon-size: var(--icon-size-md);
  --button-line-height: 1.25;
  --button-padding-block: 0;
  --button-padding-inline: var(--spacing-md);
  --button-margin-block-start: var(--spacing-lg);
  --button-margin-inline: var(--spacing-sm);
  --button-margin-block-end: var(--spacing-sm);
  --button-link-padding-block: var(--button-padding-block);
  --button-link-padding-inline: 12px;
  --button-default-bg: var(--control-bg);
  --button-default-text: var(--control-text);
  --button-default-border: var(--control-border);
  --button-border-width: 0;
  --button-primary-bg: color-mix(in srgb, var(--accent-color) 94%, var(--surface-color) 6%);
  --button-primary-border: color-mix(in srgb, var(--accent-color) 70%, transparent);
  --button-danger-bg: color-mix(in srgb, var(--danger-color) 92%, var(--surface-color) 8%);
  --button-danger-border: color-mix(in srgb, var(--danger-color) 65%, transparent);
  --button-hover-brightness: 0.97;
  --button-active-brightness: 0.92;
  --button-disabled-opacity: 0.55;
  --button-shadow: none;
  --button-hover-shadow: var(--panel-shadow-hover);
  --icon-gap: 0.3em;
  --button-icon-gap: 0.375em;
  --install-banner-font-scale: var(--font-scale-xs);
  --install-banner-line-height: 1.3;
  --install-banner-padding-block: var(--spacing-2xs);
  --install-banner-padding-inline: var(--spacing-lg);
  --install-banner-gap: var(--spacing-xs);
  --install-banner-font-size: calc(var(--font-size-base) * var(--install-banner-font-scale));
  --install-banner-offset: calc(
    max(
        calc(var(--install-banner-line-height) * var(--install-banner-font-size)),
        var(--icon-size-md)
      ) +
    (var(--install-banner-padding-block) * 2) +
    env(safe-area-inset-top, 0px)
  );
  --form-control-font-size: var(--font-size-relative-base);
  --form-control-line-height: 1.3;
  --form-control-content-height: calc(
    var(--form-control-font-size) * var(--form-control-line-height)
  );
  --form-control-padding-inline: calc(var(--spacing-md) + var(--spacing-xs));
  --form-control-padding-block-min: 4px;
  --form-control-padding-block-base:
    calc((var(--button-size) - var(--form-control-content-height)) / 2);
  --form-control-padding-block: max(
    var(--form-control-padding-block-min),
    var(--form-control-padding-block-base)
  );
  --form-label-width: 150px;
  --form-label-min-width: 120px;
  --form-action-width: 110px;
  --font-family: 'Ubuntu', 'UiconsThinStraightV2', sans-serif;
  --cluster-gap: var(--gap-size);
  --section-padding: var(--spacing-xl);
  --section-margin-block-start: 1.5em;
  --paragraph-spacing: 1em;
  --tagline-padding-inline: var(--section-padding);
  --form-row-margin-block: var(--spacing-sm);
  /* Typography */
  --font-size-base: 1rem;
  --font-size-relative-base: 1em;
  --font-scale-compact: 0.8;
  --font-scale-xxs: 0.75;
  --font-scale-xs: 0.85;
  --font-scale-sm: 0.9;
  --font-scale-md: 0.95;
  --font-scale-lg: 1.1;
  --font-scale-xl: 1.2;
  --font-scale-xxl: 1.4;
  --font-scale-xxxl: 1.5;
  --font-scale-display: 1.8;
  --font-scale-icon-lg: 1.5;
  --font-scale-icon-sm: 0.625;
  --font-scale-diagram-label: 0.7;
  --font-scale-diagram-text: 0.8;
  --font-size-root: clamp(14px, 1vw + 10px, 16px);
  --icon-size-xs: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  --icon-size-sm: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  --icon-size-md: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  --icon-size-lg: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  --icon-size-xl: calc(var(--font-size-relative-base) * var(--font-scale-xxl));
  --font-weight-light: 300;
  --font-weight-regular: var(--font-weight-light);
  --font-weight-medium: var(--font-weight-bold);
  --font-weight-bold: 500;
  --font-weight-semibold: var(--font-weight-bold);
  --font-size-diagram-icon: calc(var(--font-size-base) * var(--font-scale-icon-lg));
  --font-size-diagram-label: calc(var(--font-size-base) * var(--font-scale-diagram-label));
  --font-size-diagram-text: calc(var(--font-size-base) * var(--font-scale-diagram-text));
  --diagram-node-fill: #f0f0f0;
  --power-color: #d33;
  --video-color: #369;
  --fiz-color: #090;
  --selected-row-bg: color-mix(in srgb, var(--accent-color) 18%, #ffffff 82%);
  --favorite-inactive-color: var(--control-text);
  --link-color: var(--accent-color);
  --muted-text-color: #555555;
  --border-strong-color: #ccc;
  --divider-color: #eee;
  --diagram-gridline-color: var(--divider-color);
  --diagram-button-active-bg: #ddd;
  --warning-color: #ff9f1c;
  --warning-text-color: #000000;
  --danger-color: #f44336;
  --danger-overlay-color: rgba(244, 67, 54, 0.4);
  --success-color: #4caf50;
  --info-color: #2196f3;
  --neutral-color: #9e9e9e;
  --offline-indicator-bg: #2f3437;
  --offline-indicator-text: #f5f7fa;
  --offline-indicator-border: rgba(245, 247, 250, 0.2);
  --line-height-base: 1.6;
  --line-height-supporting: 1.5;
  --line-height-relaxed: 1.65;
  --status-error-bg: #ff8a80;
  --status-warning-bg: #ff6b6b;
  --status-note-bg: #fff4b8;
  --status-success-bg: #dfd;
  --status-border-color: #ccc;
  --status-error-text-color: #000;
  --status-warning-text-color: #ffffff;
  --status-note-text-color: #000;
  --status-success-text-color: #000;
  --gear-extra-indicator-bg: color-mix(in srgb, var(--warning-color) 22%, transparent);
  --gear-extra-indicator-text: var(--warning-color);
  --camera-color: #4caf50;
  --monitor-color: #2196f3;
  --video-segment-color: #ffc107;
  --motor-color: #9c27b0;
  --controller-color: #ff5722;
  --distance-color: #795548;
  --power-conn-bg: rgba(221, 51, 51, 0.15);
  --fiz-conn-bg: rgba(0, 153, 0, 0.15);
  --video-conn-bg: rgba(51, 102, 153, 0.15);
  --neutral-conn-bg: rgba(158, 158, 158, 0.15);
  --connector-label-neutral-color: #000000;
  --auto-gear-highlight-bg: rgba(255, 210, 64, 0.35);
  --auto-gear-highlight-border: rgba(255, 181, 0, 0.7);
  --nd-grad-border-color: var(--accent-color);
  --auto-gear-highlight-text: var(--text-color);
  --person-card-gap: clamp(0.75rem, 1.6vw, 1.1rem);
  --person-card-padding-block: clamp(0.75rem, 1.5vw, 1rem);
  --person-card-padding-inline: clamp(0.85rem, 2.4vw, 1.5rem);
  --person-card-radius: 0.95rem;
  --onboarding-highlight-border: color-mix(in srgb, var(--accent-color) 82%, transparent);
  --onboarding-highlight-fill: color-mix(in srgb, var(--accent-color) 10%, transparent);
  --onboarding-label-color: color-mix(in srgb, var(--text-color) 88%, rgba(0, 0, 0, 0.22));
  --onboarding-hint-color: color-mix(in srgb, var(--text-color) 76%, rgba(0, 0, 0, 0.4));
  --onboarding-subtext-color: color-mix(in srgb, var(--text-color) 82%, rgba(0, 0, 0, 0.35));
  --onboarding-control-bg: color-mix(in srgb, var(--surface-color) 95%, rgba(255, 255, 255, 0.05) 5%);
  --onboarding-control-border: color-mix(in srgb, var(--accent-color) 35%, var(--control-border));
  --onboarding-control-text: var(--control-text);
  --onboarding-control-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
  --onboarding-control-focus-border: color-mix(in srgb, var(--accent-color) 70%, var(--control-border));
  --onboarding-control-focus-ring: 0 0 0 3px color-mix(in srgb, var(--accent-color) 35%, transparent);
  --onboarding-button-bg: var(--control-bg);
  --onboarding-button-text: var(--control-text);
  --onboarding-button-hover-bg: var(--control-hover-bg);
  --onboarding-button-active-bg: var(--control-active-bg);
  --onboarding-button-disabled-bg: var(--control-disabled-bg);
  --onboarding-button-disabled-text: color-mix(in srgb, var(--control-text) 70%, transparent);
}
@media (max-width: 600px) {
  :root {
    --page-padding: var(--spacing-sm);
    --button-size: 44px;
    --button-padding-block: var(--spacing-xs);
    --button-padding-inline: calc(var(--spacing-lg) + var(--spacing-xs));
    --button-link-padding-inline: calc(var(--spacing-lg) + var(--spacing-xs));
    --button-line-height: 1.35;
    --button-margin-block-start: var(--spacing-sm);
    --button-margin-block-end: var(--spacing-sm);
    --button-margin-inline: 0px;
  }
  main {
    max-width: none;
    margin: 0;
  }
  h2 {
    padding-bottom: 0.3em;
  }

  .button-row {
    gap: var(--spacing-sm);
    align-items: stretch;
  }

  .button-row > * {
    flex: 1 1 100%;
    min-width: 0;
  }

  .button-row button,
  .button-row .button-link {
    width: 100%;
    margin-inline: 0;
    text-align: center;
  }
}

@media (max-width: 768px) {
  :root {
    --font-scale-diagram-text: 0.7;
    --font-scale-diagram-label: 0.6;
    --font-scale-icon-lg: 1.35;
  }
}

@media (max-width: 480px) {
  :root {
    --font-scale-diagram-text: 0.6;
    --font-scale-diagram-label: 0.5;
    --font-scale-icon-lg: 1.2;
  }
}
html.pink-mode,
body.pink-mode {
  --accent-color: #ff69b4;
  --link-color: #ff69b4;
  --icon-color: var(--accent-color);
  --logo-accent-color: #f255a8;
  --logo-background-color: #f255a8;
  --logo-center-color: #ffffff;
}

html.reduce-motion,
body.reduce-motion {
  scroll-behavior: auto;
}

body.reduce-motion *,
body.reduce-motion *::before,
body.reduce-motion *::after {
  animation-duration: 0.001ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.001ms !important;
  transition-delay: 0ms !important;
}

body.relaxed-spacing {
  --line-height-base: 1.75;
  --line-height-supporting: 1.7;
  --gap-size: 14px;
  --form-label-width: 170px;
  --form-label-min-width: 140px;
  --button-size: 38px;
  --form-control-line-height: 1.4;
  --form-control-padding-inline: calc(var(--spacing-lg) + var(--spacing-sm));
  --form-control-padding-block-min: 6px;
  --button-line-height: 1.45;
  --button-icon-gap: 0.5em;
  --form-row-margin-block: 8px;
  --button-link-padding-inline: 16px;
}

body.relaxed-spacing .settings-hint {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
}

html {
  font-size: var(--font-size-root);
}

html,
body {
  background: var(--background-color);
  height: 100%;
  margin: 0;
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Ensure predictable sizing */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: var(--font-family);
  font-weight: var(--font-weight-light);
  margin: 0;
  background-color: var(--background-color);
  color: var(--text-color);
  font-size: var(--font-size-relative-base);
  line-height: var(--line-height-base);
}

main {
  max-width: 1200px;
  margin: 0 auto;
  padding: calc(var(--page-padding) * var(--main-top-padding-multiplier))
    var(--page-padding)
    var(--page-padding);
  position: relative;
}

section,
fieldset,
input,
select,
textarea {
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

@supports (padding: env(safe-area-inset-top)) {
  main {
    padding:
      calc(env(safe-area-inset-top) + var(--page-padding) * var(--main-top-padding-multiplier))
      calc(env(safe-area-inset-right) + var(--page-padding))
      calc(env(safe-area-inset-bottom) + var(--page-padding))
      calc(env(safe-area-inset-left) + var(--page-padding));
  }
}

.skip-link {
  position: absolute;
  left: -999px;
  top: -999px;
  background: var(--accent-color);
  color: var(--inverse-text-color);
  padding: 8px 12px;
  z-index: 100;
}
.skip-link:focus {
  left: 10px;
  top: 10px;
}

#offlineIndicator {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: var(--offline-indicator-bg);
  color: var(--offline-indicator-text);
  text-align: center;
  padding: 10px 16px;
  z-index: 1000;
  border-bottom: 1px solid var(--offline-indicator-border);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.18);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-size: calc(var(--font-size-base) * var(--font-scale-xs));
  font-weight: var(--font-weight-medium);
}

#offlineIndicator[hidden] {
  display: none !important;
}

#offlineIndicator:not([hidden]) ~ #topBar {
  margin-top: var(--install-banner-offset, 0px);
  --top-bar-offset: var(--install-banner-offset, 0px);
}

#offlineIndicator:not([hidden]) ~ #sideMenu {
  top: var(--install-banner-offset, 0px);
  height: calc(100% - var(--install-banner-offset, 0px));
}

#offlineIndicator:not([hidden]) ~ #menuOverlay {
  top: var(--install-banner-offset, 0px);
  height: calc(100% - var(--install-banner-offset, 0px));
}

#installPromptBanner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: var(--accent-color);
  color: var(--install-banner-text-color, var(--inverse-text-color));
  padding:
    calc(var(--install-banner-padding-block) + env(safe-area-inset-top, 0px))
    var(--install-banner-padding-inline)
    var(--install-banner-padding-block);
  z-index: 999;
  border-radius: 0;
  line-height: var(--install-banner-line-height);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);
  display: none;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: var(--install-banner-gap);
  text-align: center;
  font-size: var(--install-banner-font-size);
}

#installPromptBanner:not([hidden]) {
  display: flex;
}

@media (max-width: 480px) {
  #installPromptBanner {
    flex-wrap: wrap;
  }
  #installPromptBanner .install-banner-dismiss {
    align-self: flex-start;
  }
}

#installPromptBanner:not([hidden]) ~ #topBar {
  margin-top: var(--install-banner-offset);
  --top-bar-offset: var(--install-banner-offset);
}

#installPromptBanner:not([hidden]) ~ #sideMenu {
  top: var(--install-banner-offset);
  height: calc(100% - var(--install-banner-offset));
}

#installPromptBanner:not([hidden]) ~ #menuOverlay {
  top: var(--install-banner-offset);
  height: calc(100% - var(--install-banner-offset));
}

#installPromptBanner .install-banner-action,
#installPromptBanner .install-banner-dismiss {
  appearance: none;
  border: none;
  background: none;
  background-color: transparent;
  border-radius: 0;
  color: inherit;
  font: inherit;
  font-weight: var(--font-weight-medium);
  padding: 0;
  cursor: pointer;
  box-shadow: none;
  transition: color 120ms ease, text-decoration-color 120ms ease, opacity 120ms ease;
  margin: 0;
  min-height: 0;
}

#installPromptBanner .install-banner-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--install-banner-gap);
  text-align: center;
  flex: 0 1 auto;
  padding: 0;
  width: auto;
  max-width: min(100%, 32rem);
  white-space: normal;
}

#installPromptBanner .install-banner-action .install-banner-icon {
  font-size: var(--icon-size-md);
  --icon-color: #ffffff;
  color: #ffffff;
  flex-shrink: 0;
  text-decoration: none;
}

#installPromptBannerText {
  display: inline-block;
}

#installPromptBanner .install-banner-action:focus-visible,
#installPromptBanner .install-banner-dismiss:focus-visible {
  outline: none;
  text-decoration: underline;
  text-decoration-thickness: 0.12em;
  text-underline-offset: 0.18em;
  text-decoration-color: color-mix(
    in srgb,
    var(--install-banner-text-color, currentColor) 85%,
    transparent
  );
}

#installPromptBanner .install-banner-action:hover,
#installPromptBanner .install-banner-action:focus-visible,
#installPromptBanner .install-banner-dismiss:hover,
#installPromptBanner .install-banner-dismiss:focus-visible {
  text-decoration: underline;
  text-decoration-thickness: 0.12em;
  text-underline-offset: 0.18em;
  text-decoration-color: color-mix(
    in srgb,
    var(--install-banner-text-color, currentColor) 70%,
    transparent
  );
}

#installPromptBanner .install-banner-dismiss {
  min-width: 0;
  white-space: nowrap;
  flex: 0 0 auto;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0.9;
}

#installPromptBanner .install-banner-dismiss:hover,
#installPromptBanner .install-banner-dismiss:focus-visible {
  opacity: 1;
}

#installPromptBanner:not([hidden]) ~ #installGuideDialog {
  align-items: flex-start;
  padding-top: calc(var(--install-banner-offset) + 20px);
}

#installPromptBanner .install-banner-dismiss .btn-icon {
  margin-inline-end: 0;
  --icon-color: #ffffff;
  color: #ffffff;
  text-decoration: none;
}

#installPromptBanner .install-banner-dismiss .btn-icon.icon-glyph {
  --icon-size: var(--icon-size-md);
}

.visually-hidden {
  position: absolute !important;
  height: 1px; width: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

.hidden {
  /* Ensure hidden elements stay hidden even if other classes set display */
  display: none !important;
}

.status-message { 
  margin-top: 0.75em;
}

.status-message:empty {
  display: none;
}

.status-message--info,
.status-message--success,
.status-message--note,
.status-message--warning,
.status-message--danger {
  padding: 0.5em 0.75em;
  border-radius: var(--border-radius);
  border: 1px solid var(--status-border-color);
  background-color: var(--panel-bg);
  display: block;
}

#results #pinWarning,
#results #dtapWarning,
#results #hotswapWarning {
  display: inline-block;
  max-width: min(36rem, 100%);
}

.status-message--info {
  color: var(--text-color);
}

.status-message--success {
  background-color: var(--status-success-bg);
  color: var(--status-success-text-color);
}

.status-message--note {
  background-color: var(--status-note-bg);
  color: var(--status-note-text-color);
}

.status-message--warning {
  background-color: var(--status-warning-bg);
  color: var(--status-warning-text-color);
}

.status-message--danger {
  background-color: var(--status-error-bg);
  color: var(--status-error-text-color);
}

.results-plain-summary {
  margin-block: 1.5rem;
  padding: 1.25rem 1.5rem;
  border-radius: calc(var(--border-radius) * 2);
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  box-shadow: var(--panel-shadow);
  transition: box-shadow 120ms ease, border-color 120ms ease;
}

.results-plain-summary:hover,
.results-plain-summary:focus-within {
  box-shadow: var(--panel-shadow-hover);
  border-color: color-mix(in srgb, var(--panel-border) 70%, var(--accent-color));
}

.results-plain-summary-title,
#resultsPlainSummaryTitle {
  margin-block: 0 0.5rem;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
}

.results-plain-summary-text,
#resultsPlainSummaryText {
  margin-block: 0;
  line-height: var(--line-height-relaxed);
}

.results-plain-summary-note,
#resultsPlainSummaryNote {
  margin-block: 0.75rem 0 0;
  color: var(--muted-text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

body.dark-mode .results-plain-summary {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.15);
  box-shadow: none;
}

body.dark-mode .results-plain-summary:hover,
body.dark-mode .results-plain-summary:focus-within {
  border-color: color-mix(in srgb, rgba(255, 255, 255, 0.3) 70%, var(--accent-color));
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.35);
}

/* Improve keyboard accessibility by clearly showing focus outlines for links, inputs, and textareas */
button:focus,
a:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
}
a:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.button-group {
  margin-bottom: var(--spacing-lg);
}

.button-row {
  display: flex;
  gap: var(--cluster-gap);
  flex-wrap: wrap;
  align-items: center;
}

.flex-1 {
  flex: 1;
}

#exportOutput {
  display: none;
  width: 100%;
  height: 100px;
  margin-top: var(--spacing-lg);
}
h1, h2, h3 {
  font-family: var(--font-family);
  font-weight: var(--font-weight-regular);
  color: var(--accent-color);
}
h1 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-display));
  margin-bottom: 0.2em;
}
h2 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxl));
  margin-top: 1.3em;
  border-bottom: 1px solid var(--accent-color);
}

section > h2 {
  font-weight: var(--font-weight-light);
}

body.pink-mode:not(.dark-mode) h1,
body.pink-mode:not(.dark-mode) h2,
body.pink-mode:not(.dark-mode) h3 {
  color: var(--accent-color);
}

body.pink-mode:not(.dark-mode) h2 {
  border-bottom: 1px solid var(--accent-color);
}
h3 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  margin-top: 1em;
}

/* Paragraph text */
p {
  line-height: var(--line-height-base);
  margin: 0 0 var(--paragraph-spacing);
}

p + p {
  margin-top: var(--paragraph-spacing);
}

#tagline {
  margin: 0 0 1em;
  padding: 0 var(--tagline-padding-inline);
}

a {
  color: var(--link-color);
  font-weight: var(--font-weight-regular);
  text-decoration: none;
}

b,
strong {
  font-weight: var(--font-weight-bold);
}

a:visited {
  color: var(--link-color);
}

a:hover,
a:focus {
  text-decoration: underline;
}

html.dark-mode a,
body.dark-mode a,
.dark-mode a {
  color: var(--inverse-text-color);
  text-decoration: underline;
  text-decoration-color: currentColor;
}

html.dark-mode a:visited,
body.dark-mode a:visited,
.dark-mode a:visited {
  color: var(--inverse-text-color);
}

footer {
  text-align: center;
  padding: 20px 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

footer a {
  margin: 0 0.5em;
}

body.dark-mode:not(.pink-mode) footer {
  color: var(--inverse-text-color);
}

body.dark-mode:not(.pink-mode) footer a {
  color: var(--inverse-text-color);
}

body.dark-mode:not(.pink-mode) footer a:visited {
  color: var(--inverse-text-color);
}

/* Static legal pages */
body.static-page {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

body.static-page main {
  flex: 1;
}

main.legal-content {
  max-width: 960px;
}

.legal-language-nav {
  margin: 0 0 1.5em;
}

.legal-language-nav ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em;
  padding: 0;
  margin: 0;
}

.legal-language-nav a[aria-current="page"] {
  font-weight: var(--font-weight-semibold);
}

.legal-content h1 {
  margin-bottom: 0.6em;
}

.legal-card {
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 20px;
  box-shadow: var(--panel-shadow);
}

.legal-card h2:first-of-type {
  margin-top: 0;
}

.legal-card h2 {
  border-bottom: 1px solid var(--accent-color);
  padding-bottom: 0.4em;
}

.static-nav {
  display: flex;
  align-items: center;
  gap: var(--cluster-gap);
}

.button-link,
.button-link:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--button-size);
  height: auto;
  line-height: var(--button-line-height);
  padding: var(--button-link-padding-block) var(--button-link-padding-inline);
  border-radius: var(--border-radius);
  border-width: var(--button-border-width, 0);
  border-style: solid;
  border-color: var(--button-border, var(--button-default-border));
  background-color: var(--button-bg, var(--button-default-bg));
  color: var(--button-text, var(--button-default-text));
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  box-shadow: var(--button-shadow, var(--panel-shadow));
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    filter 0.2s ease,
    transform 0.1s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}

.button-link:hover,
.button-link:focus-visible {
  filter: brightness(var(--button-hover-factor, var(--button-hover-brightness)));
  box-shadow: var(--button-hover-shadow, var(--panel-shadow-hover));
  outline: 2px solid color-mix(in srgb, var(--accent-color) 65%, transparent);
  outline-offset: 2px;
}

.button-link:active {
  transform: translateY(var(--button-active-translate, 1px));
  filter: brightness(var(--button-active-factor, var(--button-active-brightness)));
}

/* Form layout */
.form-row {
  display: flex;
  align-items: center;
  margin: var(--form-row-margin-block) 0;
  gap: var(--gap-size);
  flex-wrap: wrap; /* allow inputs to wrap on smaller screens */
}
.form-row label,
.form-row .form-row-label {
  flex: 0 0 var(--form-label-width);
  min-width: var(--form-label-min-width);
  font-weight: var(--font-weight-light);
}
#setup-config .form-row label,
#setup-config .form-row .form-row-label {
  line-height: 1.3;
}
.form-row select,
.form-row input,
.form-row textarea {
  flex: 1;
  min-width: 0; /* allow shrinking inside flex container */
}

.input-with-datalist {
  flex: 1;
  min-width: 0;
  display: flex;
}

.input-with-datalist input {
  flex: 1;
  min-width: 0;
}

.form-row textarea {
  resize: vertical;
}

.form-row .auto-gear-scenarios {
  flex: 0 1 320px;
  width: min(100%, 320px);
  max-width: 100%;
  overflow-y: auto;
  min-height: 12rem;
  height: clamp(14rem, 45vh, 20rem);
}

.form-row .auto-gear-video-distribution {
  flex: 0 1 320px;
  width: min(100%, 320px);
  max-width: 100%;
  overflow-y: visible;
  min-height: auto;
  height: auto;
}

#crewContainer {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--person-card-gap);
  align-items: stretch;
  inline-size: 100%;
  max-inline-size: min(100%, 960px);
}

.person-row {
  display: grid;
  grid-template-columns: minmax(64px, clamp(5rem, 8vw, 5.5rem)) repeat(2, minmax(0, 1fr));
  column-gap: clamp(0.85rem, 2.5vw, 1.5rem);
  row-gap: clamp(0.65rem, 2vw, 1rem);
  align-items: center;
  padding-block: var(--person-card-padding-block);
  padding-inline: var(--person-card-padding-inline);
  border-radius: var(--person-card-radius);
  background: var(--surface-1);
  border: 1px solid color-mix(in srgb, var(--panel-border) 55%, transparent);
  box-shadow: var(--panel-shadow);
  transition: box-shadow 160ms ease, border-color 160ms ease;
}

.person-row:hover,
.person-row:focus-within {
  box-shadow: var(--panel-shadow-hover);
  border-color: color-mix(in srgb, var(--accent-color) 28%, var(--panel-border));
}

.person-avatar {
  position: relative;
  inline-size: clamp(64px, 9vw, 80px);
  block-size: clamp(64px, 9vw, 80px);
  border-radius: 999px;
  overflow: hidden;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  grid-row: 1 / span 6;
  grid-column: 1;
  justify-self: center;
}

.person-avatar-visual,
.contact-card-avatar-visual {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.person-avatar-initial,
.contact-card-avatar-initial {
  font-weight: 600;
  font-size: 1.25rem;
  text-transform: uppercase;
}

.person-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.person-avatar button {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  color: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease;
}

.person-avatar button:hover,
.person-avatar button:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  background-color: transparent;
}

.person-contact-select {
  min-height: var(--button-size);
  grid-column: 2;
  inline-size: 100%;
}

.person-linked-badge {
  grid-column: 3;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-color) 12%, var(--surface-2));
  color: var(--text-muted);
  font-size: 0.75rem;
  font-weight: 600;
}

.person-row[data-contact-id] .person-linked-badge {
  color: var(--accent-color);
}

.person-role-select,
.person-phone {
  grid-column: 2;
  inline-size: 100%;
}

.person-name,
.person-email {
  grid-column: 3;
  inline-size: 100%;
}

.person-role-select,
.person-name,
.person-phone,
.person-email {
  min-height: var(--button-size);
}

.person-actions {
  grid-column: 2 / span 2;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.5rem, 2vw, 0.85rem);
  align-items: center;
  justify-content: flex-start;
}

.person-actions button {
  margin: 0;
  min-height: var(--button-size);
  min-inline-size: clamp(140px, 28vw, 200px);
}

.person-actions .person-remove-btn {
  align-self: center;
}

.person-row:dir(rtl) {
  grid-template-columns: repeat(2, minmax(0, 1fr)) minmax(64px, clamp(5rem, 8vw, 5.5rem));
}

.person-row:dir(rtl) .person-avatar {
  grid-column: 3;
}

.person-row:dir(rtl) .person-contact-select,
.person-row:dir(rtl) .person-role-select,
.person-row:dir(rtl) .person-phone {
  grid-column: 2;
}

.person-row:dir(rtl) .person-linked-badge,
.person-row:dir(rtl) .person-name,
.person-row:dir(rtl) .person-email {
  grid-column: 1;
  justify-self: end;
}

.person-row:dir(rtl) .person-actions {
  grid-column: 1 / span 2;
  justify-content: flex-end;
}

@media screen and (max-width: 720px) {
  .person-row {
    grid-template-columns: minmax(56px, clamp(4.5rem, 10vw, 5rem)) minmax(0, 1fr);
    padding-block: clamp(0.65rem, 3vw, 0.9rem);
    padding-inline: clamp(0.75rem, 4vw, 1rem);
  }

  .person-row .person-avatar {
    grid-row: 1 / span 6;
  }

  .person-row .person-contact-select,
  .person-row .person-linked-badge,
  .person-row .person-role-select,
  .person-row .person-name,
  .person-row .person-phone,
  .person-row .person-email,
  .person-row .person-actions {
    grid-column: 2;
  }

  .person-actions {
    width: 100%;
    justify-content: stretch;
  }

  .person-actions button {
    flex: 1 1 auto;
    min-inline-size: auto;
  }

  .person-row:dir(rtl) {
    grid-template-columns: minmax(0, 1fr) minmax(56px, clamp(4.5rem, 10vw, 5rem));
  }

  .person-row:dir(rtl) .person-avatar {
    grid-column: 2;
  }

  .person-row:dir(rtl) .person-contact-select,
  .person-row:dir(rtl) .person-role-select,
  .person-row:dir(rtl) .person-phone,
  .person-row:dir(rtl) .person-linked-badge,
  .person-row:dir(rtl) .person-name,
  .person-row:dir(rtl) .person-email,
  .person-row:dir(rtl) .person-actions {
    grid-column: 1;
  }

  .person-row:dir(rtl) .person-actions {
    justify-content: stretch;
  }
}


.contacts-dialog {
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2.1vw, 1.25rem);
  width: min(92vw, 720px);
  min-width: min(720px, 92vw);
  padding: clamp(1.25rem, 3vw, 1.85rem);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
}

.contacts-dialog-header {
  gap: clamp(0.65rem, 1.8vw, 1rem);
}

.contacts-toolbar {
  justify-content: flex-start;
}

.contacts-import {
  display: inline-flex;
  gap: 0.5rem;
  align-items: center;
}


.contacts-dialog-body {
  gap: clamp(0.9rem, 2.2vw, 1.4rem);
}

.contacts-user-profile {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1.2rem);
  padding: clamp(0.9rem, 2.3vw, 1.4rem);
  border-radius: var(--border-radius);
  background: color-mix(in srgb, var(--surface-color) 96%, transparent);
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, transparent);
}

.contacts-user-profile-header {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.contacts-user-profile-description {
  margin: 0;
  color: var(--muted-text-color);
}

.contacts-user-card {
  display: grid;
  grid-template-columns: minmax(110px, 140px) 1fr;
  gap: clamp(0.75rem, 2vw, 1.2rem);
  align-items: start;
}

.contacts-user-card-fields {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.contacts-user-card-hint {
  margin: 0;
  color: var(--muted-text-color);
  font-size: 0.85rem;
}

.contacts-user-avatar-clear {
  align-self: flex-start;
  padding: 0.35rem 0.75rem;
  border-radius: var(--border-radius);
  border: 1px solid var(--control-border);
  background: var(--surface-1);
  color: inherit;
  font-weight: var(--font-weight-medium);
}

.contacts-user-avatar-clear[disabled],
.contacts-user-avatar-clear[aria-disabled="true"] {
  opacity: 0.6;
  cursor: not-allowed;
}

.contacts-user-card,
.contact-card {
  align-items: start;
}

@media screen and (max-width: 600px) {
  .contacts-user-card {
    grid-template-columns: 1fr;
  }

  .contacts-user-card-fields {
    width: 100%;
  }
}

.contacts-empty-state {
  margin: 0;
  padding: 1rem;
  border-radius: 0.75rem;
  background: var(--surface-2);
  color: var(--text-muted);
}

.contacts-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.contact-card {
  border-radius: 1rem;
  background: var(--surface-1);
  box-shadow: var(--panel-shadow);
  padding: 1rem;
  display: grid;
  gap: 0.75rem;
  grid-template-columns: minmax(120px, 160px) 1fr;
  align-items: start;
}

.contact-card-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.contact-card-avatar {
  position: relative;
  width: 96px;
  height: 96px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
}

.contact-card-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.contact-card-avatar button {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease;
}

.contact-card-avatar button:hover {
  background-color: transparent;
}

.contact-card-avatar button:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  background-color: transparent;
}

.avatar-change-icon {
  --icon-size: var(--icon-size-lg);
  pointer-events: none;
}

.avatar-options-surface {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2.6vw, 1.6rem);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  width: min(92vw, 520px);
  min-inline-size: min(320px, 92vw);
  max-height: min(92vh, 720px);
  border: 1px solid color-mix(in srgb, var(--accent-color) 45%, var(--panel-border));
  border-radius: calc(var(--border-radius) * 1.9);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.22);
  background: color-mix(in srgb, var(--surface-color) 95%, var(--panel-bg) 5%);
  overflow: hidden;
}

@supports (height: 100dvh) {
  .avatar-options-surface {
    max-height: min(92dvh, calc(100dvh - 2 * var(--modal-frame-padding, 20px)), 720px);
  }
}

.avatar-options-header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: clamp(0.6rem, 1.8vw, 0.95rem);
}

.avatar-options-toolbar {
  justify-self: end;
  align-items: flex-start;
}

.avatar-options-toolbar .ghost-button {
  margin: 0;
}

.avatar-options-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(1.1rem, 2.8vw, 1.75rem);
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  width: 100%;
}

.dark-mode .avatar-options-surface {
  background: color-mix(in srgb, var(--control-bg) 80%, var(--surface-color) 20%);
  border-color: color-mix(in srgb, var(--accent-color) 55%, var(--panel-border));
  box-shadow: 0 30px 64px rgba(0, 0, 0, 0.55);
}

.avatar-options-preview {
  width: clamp(160px, 45vw, 220px);
  height: clamp(160px, 45vw, 220px);
  border-radius: 999px;
  overflow: hidden;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-inline: auto;
}

.avatar-options-preview .contact-card-avatar-visual {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.avatar-options-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.avatar-options-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}

.avatar-edit {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: stretch;
}

@media (min-width: 640px) {
  .avatar-options-body {
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
  }

  .avatar-options-preview {
    width: clamp(180px, 28vw, 240px);
    height: clamp(180px, 28vw, 240px);
    margin-inline: 0;
  }

  .avatar-edit {
    max-width: 320px;
  }
}

.avatar-edit-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}

.avatar-edit-instructions {
  text-align: center;
  margin: 0;
  color: var(--text-muted);
}

.avatar-edit-stage {
  width: 100%;
  display: flex;
  justify-content: center;
}

.avatar-edit-viewport {
  width: clamp(180px, 50vw, 260px);
  height: clamp(180px, 50vw, 260px);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
  background: var(--surface-2);
  outline: none;
  touch-action: none;
  cursor: grab;
}

.avatar-edit-viewport img {
  position: absolute;
  top: 0;
  left: 0;
  user-select: none;
  pointer-events: none;
}

.avatar-edit-viewport:active {
  cursor: grabbing;
}

.avatar-edit-zoom {
  width: min(320px, 100%);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  align-items: stretch;
}

.avatar-edit-zoom input[type="range"] {
  width: 100%;
}

.avatar-edit-actions {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  justify-content: center;
}

.avatar-edit-actions button {
  min-inline-size: 140px;
}

.contact-card-fields {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.contact-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.contact-card-actions button {
  flex: 1 1 160px;
}

@media (max-width: 720px) {
  .person-row {
    padding: 0.5rem;
  }

  .person-actions {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .person-actions button {
    flex: 1 1 150px;
  }

  .contact-card {
    grid-template-columns: 1fr;
  }

  .contact-card-header {
    flex-direction: row;
    justify-content: flex-start;
  }
}

.storage-row {
  align-items: stretch;
}

.storage-row .storage-quantity {
  flex: 0 0 6rem;
  min-width: 5.5rem;
}

.storage-row .storage-type,
.storage-row .storage-variant,
.storage-row .storage-notes {
  flex: 1 1 180px;
  min-width: 160px;
}

.storage-row .storage-row-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
  margin-left: 0.5rem;
}

.storage-row .storage-row-actions button {
  flex: 0 0 auto;
  margin: 0;
  align-self: center;
}

#dynamicFields {
  margin-top: 10px;
}

.schema-attribute-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 15px 0;
}

.schema-form-row {
  align-items: flex-start;
}

.schema-control {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  width: 100%;
}

.schema-control-inline {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  flex-wrap: wrap;
  width: 100%;
}

.schema-control--checkbox .schema-control-inline {
  align-items: center;
}

.schema-input {
  flex: 1;
  width: 100%;
  padding: 6px 8px;
  border-radius: 4px;
  border: 1px solid var(--control-border);
  background: var(--control-bg);
  color: var(--control-text);
  font: inherit;
}

.schema-input:focus {
  outline: 2px solid var(--accent-color);
  outline-offset: 1px;
}

.schema-input--textarea {
  resize: vertical;
}

.schema-input--checkbox {
  width: auto;
  min-width: 16px;
  height: 16px;
  flex: 0 0 auto;
}

.schema-field-suffix {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--muted-text-color);
}

.schema-field-help {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: var(--muted-text-color);
  line-height: var(--line-height-supporting);
}

/* Keep controls aligned within Project Overview and Configure Devices */
#setup-manager .form-row,
#setup-config .form-row {
  align-items: stretch;
}

#setup-manager .form-row:not(.form-row-actions) > button:not(.clear-input-btn):not(.favorite-toggle),
#setup-config .form-row:not(.form-row-actions) > button:not(.clear-input-btn):not(.favorite-toggle) {
  align-self: stretch;
  flex: 0 0 auto;
  min-width: var(--form-action-width);
  margin: 0;
  white-space: nowrap;
}

.form-label-spacer {
  flex: 0 0 var(--form-label-width);
  min-width: var(--form-label-min-width);
}

#setup-manager .form-row.form-row-actions {
  flex-wrap: nowrap;
}

#setup-manager .form-row.form-row-actions .form-actions {
  display: flex;
  gap: var(--gap-size);
  flex: 1;
}

#setup-manager .form-row.form-row-actions .form-actions button,
#setup-manager .form-row.form-row-actions > button {
  flex: 1;
  margin: 0;
}

.share-import-group {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--gap-size);
  flex: 1 1 0;
  flex-wrap: wrap;
  min-width: 0;
}

.share-import-group label {
  flex: 0 1 auto;
  white-space: nowrap;
}

#setup-manager .form-row.form-row-actions .form-actions > .share-import-group:only-child,
#setup-manager .form-row.form-row-actions .form-actions > button.hidden + .share-import-group,
#setup-manager .form-row.form-row-actions .form-actions > button[hidden] + .share-import-group {
  flex: 1 1 100%;
  max-width: 100%;
}

#setup-manager .form-row.form-row-actions .form-actions > .share-import-group:only-child button,
#setup-manager .form-row.form-row-actions .form-actions > button.hidden + .share-import-group button,
#setup-manager .form-row.form-row-actions .form-actions > button[hidden] + .share-import-group button {
  width: 100%;
}


.share-option {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: calc(var(--font-size-base) * var(--font-scale-md));
  margin: 0;
}

.share-option input[type="checkbox"] {
  margin: 0;
}

.share-option.disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.share-dialog {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1rem);
  width: min(90vw, 420px);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
}

.own-gear-dialog .own-gear-surface {
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2.2vw, 1.4rem);
  width: min(92vw, 640px);
  padding: clamp(1.25rem, 3vw, 1.85rem);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
}

.own-gear-header {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.own-gear-description {
  margin: 0;
  color: var(--muted-text-color);
}

.own-gear-add {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1rem);
  padding: clamp(0.95rem, 2.5vw, 1.25rem);
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, var(--accent-color) 30%);
  background: color-mix(in srgb, var(--surface-color) 94%, var(--accent-color) 6%);
}

.own-gear-add-header {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.own-gear-help {
  margin: 0;
  color: var(--muted-text-color);
  font-size: 0.95em;
}

.own-gear-fields {
  display: grid;
  gap: clamp(0.75rem, 2vw, 1rem);
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
}

.own-gear-name input,
.own-gear-quantity input,
.own-gear-notes textarea {
  width: 100%;
}

.own-gear-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: flex-end;
}

.own-gear-list-section {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1rem);
}

.own-gear-list-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
}

.own-gear-list-summary {
  margin: 0;
  color: var(--muted-text-color);
  font-size: 0.95em;
}

.own-gear-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1rem);
}

.own-gear-empty {
  margin: 0;
  color: var(--muted-text-color);
  font-style: italic;
}

.own-gear-item {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
  padding: clamp(0.85rem, 2.3vw, 1.15rem);
  border-radius: var(--border-radius);
  border: 1px solid var(--panel-border);
  background: color-mix(in srgb, var(--surface-color) 96%, var(--accent-color) 4%);
}

.own-gear-item-body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.own-gear-item-title {
  margin: 0;
  font-weight: 600;
}

.own-gear-item-note {
  margin: 0;
  color: var(--muted-text-color);
  white-space: pre-wrap;
  word-break: break-word;
}

.own-gear-item-actions {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  align-items: flex-end;
}

.own-gear-item-action {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.6rem;
  border-radius: var(--border-radius);
  border: 1px solid transparent;
  background: none;
  color: var(--link-color);
  font: inherit;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.own-gear-item-action .btn-icon {
  font-size: 1rem;
}

.own-gear-item-action:hover,
.own-gear-item-action:focus-visible {
  background: color-mix(in srgb, var(--accent-color) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent-color) 40%, var(--panel-border) 60%);
  outline: none;
}

.own-gear-item-action:focus-visible {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 50%, transparent);
}

.own-gear-item-action[disabled],
.own-gear-item-action[aria-disabled='true'] {
  opacity: 0.55;
  cursor: not-allowed;
}

.own-gear-item-action-danger {
  color: var(--danger-color);
}

.own-gear-item-action-danger:hover,
.own-gear-item-action-danger:focus-visible {
  background: color-mix(in srgb, var(--danger-color) 20%, transparent);
  border-color: color-mix(in srgb, var(--danger-color) 40%, var(--panel-border) 60%);
}

.own-gear-footer {
  justify-content: flex-end;
}

@media (max-width: 640px) {
  .own-gear-fields {
    grid-template-columns: 1fr;
  }

  .own-gear-item {
    flex-direction: column;
  }

  .own-gear-item-actions {
    flex-direction: row;
    align-self: flex-end;
  }
}

html.dark-mode .own-gear-add,
body.dark-mode .own-gear-add,
.dark-mode .own-gear-add {
  background: color-mix(in srgb, var(--surface-color) 88%, var(--accent-color) 12%);
  border-color: color-mix(in srgb, var(--panel-border) 55%, var(--accent-color) 45%);
}

html.dark-mode .own-gear-item,
body.dark-mode .own-gear-item,
.dark-mode .own-gear-item {
  background: color-mix(in srgb, var(--surface-color) 90%, var(--accent-color) 10%);
  border-color: color-mix(in srgb, var(--panel-border) 60%, var(--accent-color) 40%);
}

.pink-mode .own-gear-item-action-danger,
body.pink-mode .own-gear-item-action-danger {
  color: color-mix(in srgb, var(--danger-color) 80%, var(--accent-color) 20%);
}

.pink-mode .own-gear-item-action-danger:hover,
.pink-mode .own-gear-item-action-danger:focus-visible,
body.pink-mode .own-gear-item-action-danger:hover,
body.pink-mode .own-gear-item-action-danger:focus-visible {
  background: color-mix(in srgb, var(--danger-color) 20%, var(--accent-color) 10%);
  border-color: color-mix(in srgb, var(--danger-color) 45%, var(--panel-border) 55%);
}

.gear-item-edit-dialog .gear-item-edit-form {
  --gear-item-edit-max-width: 520px;
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2.2vw, 1.25rem);
  width: min(
    var(--gear-item-edit-max-width),
    calc(100vw - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 24px)))
  );
  max-width: min(
    var(--gear-item-edit-max-width),
    calc(100vw - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 24px)))
  );
  max-height: min(640px, calc(100vh - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 24px))));
  padding: clamp(1.25rem, 3vw, 1.75rem);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
  overflow-y: auto;
  overscroll-behavior: contain;
}

@supports (width: 100dvw) {
  .gear-item-edit-dialog .gear-item-edit-form {
    width: min(
      var(--gear-item-edit-max-width),
      calc(100dvw - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 24px)))
    );
    max-width: min(
      var(--gear-item-edit-max-width),
      calc(100dvw - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 24px)))
    );
    max-height: min(640px, calc(100dvh - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 24px))));
  }
}

.gear-item-edit-header {
  gap: clamp(0.75rem, 2vw, 1rem);
  padding-bottom: clamp(0.75rem, 1.8vw, 1rem);
}

.gear-item-edit-header-body {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
}

.gear-item-edit-toolbar {
  justify-content: flex-start;
}

.gear-item-edit-reset {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--button-icon-gap);
  padding: 0.5rem 0.9rem;
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in srgb, var(--panel-border) 80%, transparent);
  background: color-mix(in srgb, var(--surface-color) 94%, transparent);
  color: var(--text-color);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
  text-decoration: none;
  flex-shrink: 0;
  white-space: normal;
  text-align: center;
  line-height: 1.3;
}

.gear-item-edit-reset:hover,
.gear-item-edit-reset:focus-visible {
  background: color-mix(in srgb, var(--accent-color) 18%, var(--surface-color) 82%);
  color: var(--text-color);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.gear-item-edit-reset:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent-color) 60%, #ffffff 40%);
  outline-offset: 2px;
}

.gear-item-edit-reset[disabled],
.gear-item-edit-reset[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.55;
  box-shadow: none;
}

.gear-item-edit-reset[disabled]:hover,
.gear-item-edit-reset[disabled]:focus-visible,
.gear-item-edit-reset[aria-disabled="true"]:hover,
.gear-item-edit-reset[aria-disabled="true"]:focus-visible {
  background: color-mix(in srgb, var(--surface-color) 94%, transparent);
  box-shadow: none;
}

.gear-item-edit-dialog h3 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  font-weight: var(--font-weight-semibold);
}

.gear-item-edit-preview {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
  color: var(--muted-text-color);
  word-break: break-word;
}

.gear-item-edit-fields {
  display: flex;
  flex-direction: column;
  gap: clamp(0.7rem, 1.8vw, 1rem);
}

.gear-item-edit-provider-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  align-items: stretch;
}

.gear-item-edit-provider-field select {
  width: 100%;
}

.gear-item-edit-camera-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  align-items: stretch;
}

.gear-item-edit-camera-field select {
  width: 100%;
}

.gear-item-edit-owned {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding-top: 0.25rem;
}

.gear-item-edit-help {
  margin: 0;
  color: var(--muted-text-color);
  font-size: 0.85rem;
}

.gear-item-edit-device {
  display: flex;
  flex-direction: column;
  gap: clamp(0.65rem, 1.6vw, 0.9rem);
  padding: clamp(0.75rem, 1.8vw, 1rem) clamp(0.6rem, 1.5vw, 0.85rem);
  border: 1px solid color-mix(in srgb, var(--panel-border) 85%, transparent);
  border-radius: var(--border-radius);
  background: color-mix(in srgb, var(--surface-color) 96%, transparent);
}

.gear-item-edit-device-header {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.gear-item-edit-device-title {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
  font-weight: var(--font-weight-semibold);
  color: var(--text-color);
}

.gear-item-edit-device-summary {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.35rem, 1vw, 0.55rem);
}

.gear-item-edit-device-summary .info-box,
.gear-item-edit-device-summary .connector-block {
  margin: 0;
}

.gear-item-edit-device-summary .info-box {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.gear-item-edit-device-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.gear-item-edit-device-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--button-icon-gap);
  padding: 0.55rem 1rem;
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in srgb, var(--accent-color) 45%, var(--panel-border) 55%);
  background: color-mix(in srgb, var(--accent-color) 12%, var(--surface-color) 88%);
  color: var(--text-color);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
  text-align: center;
  line-height: 1.35;
}

.gear-item-edit-device-button:hover,
.gear-item-edit-device-button:focus-visible {
  background: color-mix(in srgb, var(--accent-color) 22%, var(--surface-color) 78%);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.gear-item-edit-device-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent-color) 60%, #ffffff 40%);
  outline-offset: 2px;
}

.gear-item-edit-device-button[disabled],
.gear-item-edit-device-button[aria-disabled="true"] {
  cursor: not-allowed;
  opacity: 0.55;
  box-shadow: none;
}

.gear-item-edit-device-button[disabled]:hover,
.gear-item-edit-device-button[disabled]:focus-visible,
.gear-item-edit-device-button[aria-disabled="true"]:hover,
.gear-item-edit-device-button[aria-disabled="true"]:focus-visible {
  background: color-mix(in srgb, var(--surface-color) 92%, transparent);
  box-shadow: none;
}

.gear-item-edit-extra {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.gear-item-edit-extra-period {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-lg);
}

.gear-item-edit-extra-period-field {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  min-width: min(220px, 100%);
}

.gear-item-edit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(0.5rem, 1.5vw, 0.8rem) clamp(0.75rem, 1.8vw, 1rem);
}

.gear-item-edit-form .form-row {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.35rem;
  margin: 0;
}

.gear-item-edit-form .form-row label,
.gear-item-edit-form .form-row .form-row-label {
  flex: initial;
  min-width: 0;
  font-weight: var(--font-weight-medium);
  line-height: 1.25;
}

.gear-item-edit-form .form-row--full {
  grid-column: 1 / -1;
}

.gear-item-edit-form input,
.gear-item-edit-form textarea {
  width: 100%;
}

.gear-item-edit-form textarea {
  resize: vertical;
  min-height: 3.2rem;
}

.gear-item-edit-rental {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  padding: clamp(0.8rem, 2vw, 1rem);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: color-mix(in srgb, var(--surface-color) 94%, transparent);
}

.gear-item-edit-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  font-weight: var(--font-weight-medium);
}

.gear-item-edit-checkbox input[type="checkbox"] {
  margin: 0;
}

.gear-item-edit-rental-description {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--muted-text-color);
}

.gear-item-edit-rental-description:empty {
  display: none;
}

@media (max-width: 640px) {
  .gear-item-edit-grid {
    grid-template-columns: 1fr;
  }
}

html.dark-mode .gear-item-edit-reset,
body.dark-mode .gear-item-edit-reset,
.dark-mode .gear-item-edit-reset {
  background: color-mix(in srgb, var(--surface-color) 86%, transparent);
  border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
}

html.dark-mode .gear-item-edit-reset:hover,
body.dark-mode .gear-item-edit-reset:hover,
.dark-mode .gear-item-edit-reset:hover,
html.dark-mode .gear-item-edit-reset:focus-visible,
body.dark-mode .gear-item-edit-reset:focus-visible,
.dark-mode .gear-item-edit-reset:focus-visible {
  background: color-mix(in srgb, var(--accent-color) 26%, var(--surface-color) 74%);
}

html.dark-mode .gear-item-edit-preview,
body.dark-mode .gear-item-edit-preview,
.dark-mode .gear-item-edit-preview {
  color: color-mix(in srgb, var(--muted-text-color) 60%, #ffffff 40%);
}

html.dark-mode .gear-item-edit-rental,
body.dark-mode .gear-item-edit-rental,
.dark-mode .gear-item-edit-rental {
  background: color-mix(in srgb, var(--surface-color) 88%, transparent);
  border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
}

@media (max-width: 640px) {
  .form-row {
    flex-direction: column;
    align-items: stretch;
  }

  .form-row label,
  .form-row .form-row-label,
  .form-label-spacer {
    flex: 1 1 100%;
    min-width: 0;
  }

  .form-row select,
  .form-row input,
  .form-row textarea,
  .form-row .select-wrapper,
  .form-row .auto-gear-scenarios,
  .form-row .auto-gear-video-distribution {
    flex: 1 1 100%;
    width: 100%;
  }

  .form-row > button:not(.clear-input-btn):not(.favorite-toggle),
  .form-row > .inline-form-button {
    flex: 1 1 100%;
    width: 100%;
  }

  #setup-manager .form-row.form-row-actions,
  #setup-config .form-row.form-row-actions {
    flex-wrap: wrap;
    flex-direction: column;
    align-items: stretch;
    gap: var(--gap-size);
  }

  #setup-manager .form-row.form-row-actions .form-actions,
  #setup-config .form-row.form-row-actions .form-actions {
    flex-direction: column;
    gap: var(--gap-size);
  }

  #setup-manager .form-row.form-row-actions .form-actions button,
  #setup-manager .form-row.form-row-actions > button,
  #setup-config .form-row.form-row-actions .form-actions button,
  #setup-config .form-row.form-row-actions > button {
    width: 100%;
  }

  .share-import-group {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-sm);
    width: 100%;
  }

  .share-import-group label,
  .share-import-group button {
    width: 100%;
  }
}

.share-dialog h3 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  font-weight: var(--font-weight-semibold);
}

.share-dialog p {
  margin: 0;
  color: var(--muted-text-color);
  line-height: var(--line-height-supporting);
}

.share-dialog .form-row {
  align-items: center;
  gap: 0.75rem;
}

.dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  margin-top: clamp(0.75rem, 2vw, 1.25rem);
  flex-wrap: wrap;
  align-items: center;
}

.dialog-actions > * {
  flex: 0 0 auto;
}

#setup-manager .share-import-row {
  align-items: flex-start;
}

#setup-manager .share-import-options {
  flex: 1;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background-color: var(--surface-color);
}

#setup-manager .share-import-options legend {
  font-weight: var(--font-weight-semibold);
  font-size: calc(var(--font-size-base) * var(--font-scale-md));
  margin-bottom: 0.25rem;
}

#setup-manager .share-import-mode-select {
  width: 100%;
  min-height: 6.5rem;
}

#sharedImportDialog .share-import-dialog {
  width: min(90vw, 420px);
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2.5vw, 1.5rem);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
}

#sharedImportDialog .share-import-dialog h3 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  font-weight: var(--font-weight-semibold);
}

#sharedImportDialog .share-import-dialog p {
  margin: 0;
  color: var(--muted-text-color);
  line-height: 1.5;
}

#sharedImportDialog .share-import-metadata {
  margin: 0;
  color: var(--text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: 1.5;
}

#sharedImportDialog .share-import-options {
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background-color: var(--panel-bg);
}

#sharedImportDialog .share-import-options legend {
  font-weight: var(--font-weight-semibold);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
  margin-bottom: 0.25rem;
  color: var(--text-color);
}

#sharedImportDialog .share-import-mode-select {
  width: 100%;
  min-height: 6.5rem;
  border: 1px solid var(--control-border);
  border-radius: var(--border-radius);
  background-color: var(--control-bg);
  color: var(--control-text);
}

#sharedImportDialog .share-import-mode-select option {
  padding: 0.5rem 0.75rem;
}

#sharedImportDialog .dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
}

#sharedImportDialog .dialog-actions button {
  min-width: clamp(96px, 20vw, 128px);
}

.feedback-dialog {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 3vw, 1.5rem);
  width: min(95vw, 720px);
  padding: clamp(1.25rem, 3vw, 2rem);
  border-color: var(--panel-border);
}

.feedback-dialog h3 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  font-weight: var(--font-weight-semibold);
}

#setup-manager #shareLinkMessage {
  margin-left: calc(var(--form-label-width) + var(--gap-size));
}

@media (max-width: 600px) {
  .form-row {
    flex-direction: column;
    align-items: stretch;
  }
  .form-row label,
  .form-row .form-row-label {
    flex: 1 0 100%;
    min-width: unset;
  }
  .form-row select,
  .form-row input {
    margin: 0;
  }
  .form-label-spacer {
    display: none;
  }
  #setup-manager .form-row:not(.form-row-actions) > button:not(.clear-input-btn):not(.favorite-toggle),
  #setup-config .form-row:not(.form-row-actions) > button:not(.clear-input-btn):not(.favorite-toggle) {
    flex: 1 0 100%;
    width: 100%;
    margin: var(--gap-size) 0 0 0;
  }
  #setup-manager .form-row.form-row-actions {
    flex-direction: column;
    align-items: stretch;
  }
  #setup-manager .form-row.form-row-actions .form-actions {
    flex-direction: column;
  }
  #setup-manager .form-row.form-row-actions .form-actions button,
  #setup-manager .form-row.form-row-actions > button {
    width: 100%;
  }
  #setup-manager #shareLinkMessage {
    margin-left: 0;
  }

  .share-import-group {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .share-import-group label {
    width: 100%;
    white-space: normal;
  }

  .share-import-group button {
    width: 100%;
    align-self: stretch;
  }
  .share-import-group #applySharedLinkBtn {
    flex: 1 1 100%;
    width: 100%;
    align-self: stretch;
  }

  #setup-manager .share-import-row {
    flex-direction: column;
  }

  #setup-manager .share-import-options {
    width: 100%;
  }

  .settings-hint {
    margin-left: 0;
  }
}

@supports (-webkit-touch-callout: none) {
  select,
  input:not([type="checkbox"]):not([type="radio"]),
  textarea {
    background-image: none;
    -webkit-appearance: none;
    appearance: none;
  }
}

/* Align add/remove buttons in form rows with input fields */
.form-row > button:not(.clear-input-btn):not(.favorite-toggle) {
  align-self: flex-end;
  margin-top: 5px;
}

.form-row > .inline-form-button {
  align-self: center;
  margin-top: 0;
  white-space: nowrap;
  flex: 0 0 auto;
}

.form-row > button:not(.clear-input-btn):not(.favorite-toggle) + button:not(.clear-input-btn):not(.favorite-toggle) {
  margin-left: 0;
}

.settings-hint {
  flex-basis: 100%;
  margin: 0;
  margin-left: calc(var(--form-label-width) + var(--gap-size));
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  color: var(--control-text);
  opacity: 0.8;
}

.project-backups {
  display: flex;
  flex-direction: column;
  gap: var(--gap-size);
  margin-top: var(--gap-size);
  padding-top: var(--gap-size);
  border-top: 1px solid color-mix(in srgb, var(--panel-border) 60%, transparent);
}

.project-backups .settings-hint {
  margin-left: 0;
}

.project-backups-actions {
  align-items: center;
}

.full-backup-section {
  display: flex;
  flex-direction: column;
  gap: var(--gap-size);
  margin-top: var(--gap-size);
  padding-top: var(--gap-size);
  border-top: 1px solid color-mix(in srgb, var(--panel-border) 60%, transparent);
}

.full-backup-section .settings-hint {
  margin-left: 0;
}

.full-backup-actions {
  align-items: center;
}

.backup-diff-section {
  display: flex;
  flex-direction: column;
  gap: var(--gap-size);
  padding-block: calc(var(--gap-size) * 0.5);
  border-top: 1px solid color-mix(in srgb, var(--panel-border) 80%, transparent);
}

.backup-diff-section[hidden] {
  display: none;
}

.backup-diff-section h4 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.backup-diff-section .diff-summary {
  margin: 0;
  padding: 0.5rem 0.75rem;
  border-radius: var(--border-radius);
  background: color-mix(in srgb, var(--accent-color) 12%, transparent);
  color: var(--text-color);
}

.diff-list-container {
  border: 1px solid color-mix(in srgb, var(--panel-border) 65%, transparent);
  border-radius: var(--border-radius);
  padding: 0.75rem;
  max-height: 18rem;
  overflow: auto;
  background: color-mix(in srgb, var(--surface-color) 96%, var(--accent-color) 4%);
}

.diff-list-container[hidden] {
  display: none;
}

.diff-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.restore-rehearsal {
  display: flex;
  flex-direction: column;
  gap: var(--gap-size);
  margin-top: var(--gap-size);
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--panel-border) 65%, transparent);
  border-radius: var(--border-radius);
  background: color-mix(in srgb, var(--surface-color) 94%, var(--accent-color) 6%);
}

.restore-rehearsal[hidden] {
  display: none;
}

.restore-rehearsal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-size);
}

.restore-rehearsal-header h4 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.restore-rehearsal-modes {
  border: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--gap-size) * 0.75);
}

.restore-rehearsal-modes label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 500;
}

.restore-rehearsal-file {
  align-items: center;
}

.restore-rehearsal-file button {
  margin-left: auto;
}

.restore-rehearsal-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid color-mix(in srgb, var(--panel-border) 55%, transparent);
  border-radius: var(--border-radius);
  overflow: hidden;
  background: color-mix(in srgb, var(--surface-color) 96%, var(--accent-color) 4%);
}

.restore-rehearsal-table caption {
  text-align: left;
  font-weight: 600;
  padding: 0.75rem;
}

.restore-rehearsal-table th,
.restore-rehearsal-table td {
  padding: 0.5rem 0.75rem;
  text-align: left;
  border-top: 1px solid color-mix(in srgb, var(--panel-border) 45%, transparent);
}

.restore-rehearsal-table th:first-child,
.restore-rehearsal-table td:first-child {
  width: 35%;
}

.restore-rehearsal-table tbody tr:first-child th,
.restore-rehearsal-table tbody tr:first-child td {
  border-top: none;
}

.restore-rehearsal-table .restore-rehearsal-diff-match {
  color: color-mix(in srgb, var(--text-color) 85%, var(--accent-color) 15%);
}

.restore-rehearsal-table .restore-rehearsal-diff-positive {
  color: var(--danger-color, #b00020);
  font-weight: 600;
}

.restore-rehearsal-table .restore-rehearsal-diff-negative {
  color: var(--warning-color, #8a6d3b);
  font-weight: 600;
}

.restore-rehearsal-rule-preview {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--panel-border) 55%, transparent);
  border-radius: var(--border-radius);
  padding: 0.9rem;
  background: color-mix(in srgb, var(--surface-color) 96%, var(--accent-color) 4%);
}

.restore-rehearsal-rule-preview h5 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
}

.restore-rehearsal-rule-columns {
  display: grid;
  gap: 0.75rem;
}

.restore-rehearsal-rule-columns--split {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.restore-rehearsal-rule-column {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  border: 1px solid color-mix(in srgb, var(--panel-border) 65%, transparent);
  border-radius: calc(var(--border-radius) * 0.85);
  padding: 0.75rem;
  background: color-mix(in srgb, var(--surface-color) 98%, transparent);
}

.restore-rehearsal-rule-column--added {
  border-color: color-mix(in srgb, var(--success-color) 55%, var(--panel-border) 45%);
  background: color-mix(in srgb, var(--surface-color) 90%, var(--success-color) 10%);
}

.restore-rehearsal-rule-column--removed {
  border-color: color-mix(in srgb, var(--danger-color) 55%, var(--panel-border) 45%);
  background: color-mix(in srgb, var(--surface-color) 90%, var(--danger-color) 10%);
}

.restore-rehearsal-rule-column-title {
  font-weight: var(--font-weight-medium);
  color: color-mix(in srgb, var(--text-color) 92%, transparent);
}

.restore-rehearsal-rule-section {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.restore-rehearsal-rule-section-label {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: color-mix(in srgb, var(--text-color) 70%, transparent);
}

.restore-rehearsal-rule-list {
  margin: 0;
  padding-left: 1.1rem;
  list-style: disc;
  color: color-mix(in srgb, var(--text-color) 92%, transparent);
}

.restore-rehearsal-rule-list li {
  line-height: 1.4;
}

.restore-rehearsal-rule-list li + li {
  margin-top: 0.25rem;
}

.restore-rehearsal-rule-note {
  font-style: italic;
  color: color-mix(in srgb, var(--text-color) 70%, transparent);
}

.restore-rehearsal-actions {
  flex-wrap: wrap;
  justify-content: flex-start;
}

.restore-rehearsal-actions button {
  min-width: 12rem;
}

.diff-entry {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--panel-border) 65%, transparent);
  border-radius: calc(var(--border-radius) * 0.9);
  padding: 0.75rem;
  background: color-mix(in srgb, var(--surface-color) 96%, transparent);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

.diff-entry.diff-added {
  border-color: color-mix(in srgb, var(--success-color) 55%, var(--panel-border) 45%);
  background: color-mix(in srgb, var(--surface-color) 90%, var(--success-color) 10%);
}

.diff-entry.diff-removed {
  border-color: color-mix(in srgb, var(--danger-color) 55%, var(--panel-border) 45%);
  background: color-mix(in srgb, var(--surface-color) 90%, var(--danger-color) 10%);
}

.diff-entry.diff-changed {
  border-color: color-mix(in srgb, var(--info-color) 55%, var(--panel-border) 45%);
  background: color-mix(in srgb, var(--surface-color) 92%, var(--info-color) 8%);
}

.diff-entry-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.diff-path {
  font-weight: var(--font-weight-medium);
  color: var(--text-color);
  word-break: break-word;
}

.diff-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, transparent);
  background: color-mix(in srgb, var(--surface-color) 92%, transparent);
  color: color-mix(in srgb, var(--text-color) 90%, transparent);
}

.diff-status-added {
  border-color: color-mix(in srgb, var(--success-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 82%, var(--success-color) 18%);
  color: color-mix(in srgb, var(--success-color) 85%, var(--text-color) 15%);
}

.diff-status-removed {
  border-color: color-mix(in srgb, var(--danger-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 80%, var(--danger-color) 20%);
  color: color-mix(in srgb, var(--danger-color) 80%, var(--text-color) 20%);
}

.diff-status-changed {
  border-color: color-mix(in srgb, var(--info-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 84%, var(--info-color) 16%);
  color: color-mix(in srgb, var(--info-color) 80%, var(--text-color) 20%);
}

.diff-change-group {
  display: grid;
  gap: 0.75rem;
}

.diff-change-group--split {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.diff-change {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.diff-label {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: color-mix(in srgb, var(--text-color) 70%, transparent);
}

.diff-value {
  margin: 0;
  padding: 0.6rem 0.7rem;
  border-radius: calc(var(--border-radius) * 0.75);
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, transparent);
  background: color-mix(in srgb, var(--surface-color) 94%, transparent);
  font-family: "SFMono-Regular", "Roboto Mono", "Menlo", "Courier New", monospace;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 10rem;
  overflow: auto;
}

.diff-value-added {
  border-color: color-mix(in srgb, var(--success-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 86%, var(--success-color) 14%);
}

.diff-value-removed {
  border-color: color-mix(in srgb, var(--danger-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 84%, var(--danger-color) 16%);
}

.diff-value-changed {
  border-color: color-mix(in srgb, var(--info-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 88%, var(--info-color) 12%);
}

html.high-contrast .diff-entry,
body.high-contrast .diff-entry {
  background: var(--background-color);
  border-color: var(--text-color);
  box-shadow: none;
}

html.high-contrast .diff-entry.diff-added,
body.high-contrast .diff-entry.diff-added,
html.high-contrast .diff-entry.diff-removed,
body.high-contrast .diff-entry.diff-removed,
html.high-contrast .diff-entry.diff-changed,
body.high-contrast .diff-entry.diff-changed {
  background: var(--background-color);
}

html.high-contrast .restore-rehearsal-rule-column,
body.high-contrast .restore-rehearsal-rule-column {
  background: var(--background-color);
  border-color: var(--text-color);
}

html.high-contrast .diff-status-badge,
body.high-contrast .diff-status-badge {
  background: var(--background-color);
  border-color: var(--text-color);
  color: var(--text-color);
}

html.high-contrast .diff-value,
body.high-contrast .diff-value,
html.high-contrast .diff-value-added,
body.high-contrast .diff-value-added,
html.high-contrast .diff-value-removed,
body.high-contrast .diff-value-removed,
html.high-contrast .diff-value-changed,
body.high-contrast .diff-value-changed {
  background: var(--background-color);
  border-color: var(--text-color);
  color: var(--text-color);
}

.diff-actions {
  justify-content: flex-end;
  gap: var(--gap-size);
}

/* Ensure favorite star aligns with its select element without stretching */
.select-wrapper .favorite-toggle {
  align-self: center;
  min-height: var(--select-height);
  height: auto;
  margin-top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* Date range rows for prep and shooting days */
.period-row {
  display: flex;
  align-items: center;
  gap: var(--gap-size);
  flex-wrap: wrap;
  margin-bottom: var(--gap-size);
}
.period-row input {
  flex: 1;
  min-width: 120px;
}
.period-row span {
  white-space: nowrap;
}

.period-row button {
  margin: 0;
}

@media (max-width: 600px) {
  .period-row {
    flex-direction: column;
    align-items: stretch;
  }
  .period-row span {
    display: none;
  }
  .period-row button {
    align-self: flex-end;
  }
}


/* Small wrapper to show labels even when a value is present */
.field-with-label {
  display: flex;
  flex-direction: column;
  flex: 1;
  margin-right: 5px;
  min-width: 150px; /* prevent fields from becoming too narrow */
}
.field-with-label::before {
  content: attr(data-label);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  color: var(--muted-text-color);
  margin-bottom: 2px;
}

#helpDialog[hidden] {
  display: none;
}
#settingsDialog[hidden] {
  display: none;
}

/* Global modal layout */
.app-modal {
  border: none;
  padding: 0;
  background: transparent;
  color: inherit;
  max-width: none;
  width: 100vw;
  height: 100vh;
  margin: 0;
}

.app-modal::backdrop {
  background: rgba(0, 0, 0, 0.6);
}

.app-modal[open] {
  --modal-frame-padding: clamp(16px, 4vw, 24px);
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--modal-frame-padding);
  z-index: 200;
  overflow: hidden;
  overscroll-behavior: contain;
}

html.install-banner-visible .app-modal[open] {
  padding-top: calc(var(--modal-frame-padding) + var(--install-banner-offset, 0px));
}

.modal-surface {
  background: var(--surface-color);
  color: var(--text-color);
  border: 2px solid var(--accent-color);
  border-radius: var(--border-radius);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.modal-header {
  display: flex;
  flex-direction: column;
  gap: clamp(0.6rem, 1.8vw, 0.95rem);
  padding-bottom: clamp(0.85rem, 2.1vw, 1.2rem);
  border-bottom: 1px solid color-mix(in srgb, var(--panel-border) 75%, transparent);
}

.modal-header-main {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.modal-title {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  font-weight: var(--font-weight-semibold, var(--font-weight-medium));
  color: var(--text-color);
}

.modal-description {
  margin: 0;
  color: var(--muted-text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: 1.5;
}

.modal-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.5rem, 1.5vw, 0.75rem);
  align-items: center;
}

.modal-toolbar button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.modal-hint {
  margin: 0;
  color: var(--muted-text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.modal-body {
  display: flex;
  flex-direction: column;
  gap: clamp(0.9rem, 2.2vw, 1.35rem);
  padding-top: clamp(1rem, 2.5vw, 1.5rem);
}

.modal-section {
  display: flex;
  flex-direction: column;
  gap: clamp(0.75rem, 2vw, 1rem);
}

.modal-footer {
  margin-top: clamp(1rem, 2.6vw, 1.5rem);
}

.dark-mode .modal-title {
  color: var(--inverse-text-color);
}

.dark-mode .modal-description,
.dark-mode .modal-hint {
  color: color-mix(in srgb, var(--inverse-text-color) 75%, transparent);
}

.dark-mode .modal-header {
  border-bottom-color: color-mix(in srgb, var(--accent-color) 35%, var(--panel-border));
}


.print-options-dialog[open] {
  z-index: 205;
}

.print-options-surface {
  width: min(540px, calc(100vw - 2 * var(--modal-frame-padding, clamp(16px, 4vw, 28px))));
  max-width: 540px;
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: clamp(22px, 5vw, 30px);
  border-color: var(--panel-border);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.25);
  background: color-mix(in srgb, var(--surface-color) 92%, var(--panel-bg) 8%);
}

.dark-mode .print-options-surface,
.print-options-dialog.dark-mode .print-options-surface {
  background: color-mix(in srgb, var(--control-bg) 72%, var(--surface-color) 28%);
  border-color: color-mix(in srgb, var(--accent-color) 40%, var(--panel-border));
  color: var(--inverse-text-color);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
}

.print-options-body {
  gap: clamp(0.9rem, 2.1vw, 1.25rem);
}

.print-options-sections,
.print-options-layout {
  margin: 0;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--panel-border);
  border-radius: calc(var(--border-radius) * 0.9);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  background: color-mix(in srgb, var(--panel-bg) 88%, transparent);
}

.print-options-sections legend,
.print-options-layout legend {
  margin: 0 0 0.35rem;
  padding: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-text-color);
}

.dark-mode .print-options-sections,
.print-options-dialog.dark-mode .print-options-sections,
.dark-mode .print-options-layout,
.print-options-dialog.dark-mode .print-options-layout {
  border-color: color-mix(in srgb, var(--accent-color) 35%, var(--control-border));
  background: color-mix(in srgb, var(--control-bg) 78%, transparent);
}

.dark-mode .print-options-sections legend,
.print-options-dialog.dark-mode .print-options-sections legend,
.dark-mode .print-options-layout legend,
.print-options-dialog.dark-mode .print-options-layout legend {
  color: color-mix(in srgb, var(--inverse-text-color) 65%, transparent);
}

.print-options-section {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.4rem 0.55rem;
  border-radius: calc(var(--border-radius) * 0.75);
  border: 1px solid transparent;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  cursor: pointer;
}

.print-options-layout-options {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.print-options-section:hover,
.print-options-section:focus-within {
  background: color-mix(in srgb, var(--accent-color) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent-color) 28%, transparent);
}

.print-options-section input {
  width: 1.1rem;
  height: 1.1rem;
  flex: 0 0 auto;
  accent-color: var(--accent-color);
}

.print-options-section span {
  flex: 1 1 auto;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-medium);
  color: var(--text-color);
}

.dark-mode .print-options-section span,
.print-options-dialog.dark-mode .print-options-section span {
  color: var(--inverse-text-color);
}

.dark-mode .print-options-section:hover,
.dark-mode .print-options-section:focus-within,
.print-options-dialog.dark-mode .print-options-section:hover,
.print-options-dialog.dark-mode .print-options-section:focus-within {
  background: color-mix(in srgb, var(--accent-color) 28%, transparent);
  border-color: color-mix(in srgb, var(--accent-color) 45%, transparent);
}

.print-options-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.print-options-actions {
  justify-content: flex-end;
  gap: 0.5rem;
}

#printOptionsSelectAllBtn {
  border: none;
  background: none;
  color: var(--accent-color);
  padding: 0.25rem 0.35rem;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  text-decoration: underline;
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

#printOptionsSelectAllBtn:hover,
#printOptionsSelectAllBtn:focus-visible {
  color: color-mix(in srgb, var(--accent-color) 80%, var(--text-color));
  outline: none;
}

.dark-mode #printOptionsSelectAllBtn,
.print-options-dialog.dark-mode #printOptionsSelectAllBtn {
  color: color-mix(in srgb, var(--accent-color) 70%, var(--inverse-text-color));
}

.dark-mode #printOptionsSelectAllBtn:hover,
.dark-mode #printOptionsSelectAllBtn:focus-visible,
.print-options-dialog.dark-mode #printOptionsSelectAllBtn:hover,
.print-options-dialog.dark-mode #printOptionsSelectAllBtn:focus-visible {
  color: var(--inverse-text-color);
}

.print-options-actions button {
  min-width: 6.25rem;
}

@media (max-width: 540px) {
  .print-options-surface {
    width: min(100%, calc(100vw - 1.5rem));
    padding: clamp(18px, 6vw, 24px);
  }

  .print-options-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .print-options-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .print-options-actions button {
    flex: 1 1 auto;
  }
}


.power-warning-dialog {
  max-width: min(420px, 90vw);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem;
  border-color: var(--danger-color);
}

.power-warning-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--danger-color);
  color: var(--danger-color);
}

.power-warning-icon {
  font-size: 2.5rem;
  color: var(--danger-color);
  --icon-color: var(--danger-color);
}

.power-warning-title {
  margin: 0;
  color: inherit;
}


.power-warning-summary {
  border: 1px solid var(--danger-color);
  border-left-width: 4px;
  border-radius: var(--border-radius);
  background: var(--danger-overlay-color);
  padding: 0.75rem 1rem;
  color: var(--text-color);
  font-weight: var(--font-weight-bold);
}

.power-warning-summary p {
  margin: 0;
}

.power-warning-section {
  border: 1px solid var(--danger-color);
  border-radius: var(--border-radius);
  padding: 1rem;
  background: var(--surface-color);
  background: color-mix(in srgb, var(--surface-color) 75%, var(--danger-overlay-color));
}

.power-warning-section h4 {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  color: var(--danger-color);
}

.power-warning-details {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--text-color-secondary, inherit);
}

.power-warning-details li {
  margin-bottom: 0.25rem;
}

.power-warning-details li:last-child {
  margin-bottom: 0;
}

.power-warning-advice {
  margin: 0;
  font-weight: var(--font-weight-bold);
  color: var(--danger-color);
}

.dark-mode .power-warning-icon {
  color: var(--danger-color, #ff6666);
  --icon-color: var(--danger-color, #ff6666);
}

.help-content.modal-surface,
.settings-content.modal-surface {
  border: 2px solid var(--panel-border);
}

.modal-surface-scrollable {
  max-height: min(92vh, 960px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

@supports (height: 100dvh) {
  .modal-surface-scrollable {
    max-height: min(92dvh, calc(100dvh - 2 * var(--modal-frame-padding, 20px)), 960px);
  }
}

#installGuideDialog {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 205;
  padding: 20px;
  overflow: hidden;
  overscroll-behavior: contain;
}

#iosPwaHelpDialog {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 210;
  padding: 20px;
  overflow: hidden;
  overscroll-behavior: contain;
}

#feedbackForm fieldset {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 10px 20px;
}

#feedbackForm fieldset legend {
  grid-column: 1 / -1;
}

#feedbackForm .button-row {
  display: flex;
  justify-content: flex-end;
  gap: var(--cluster-gap);
  margin-top: var(--spacing-lg);
}

#installGuideDialog[hidden] {
  display: none;
}

#iosPwaHelpDialog[hidden] {
  display: none;
}

#settingsDialog[hidden] {
  display: none;
}

.help-content {
  padding: 20px;
  width: min(95vw, 900px);
}

body.dark-mode:not(.pink-mode) .help-content a {
  color: #fff;
  text-decoration: underline;
  text-decoration-color: currentColor;
}

body.dark-mode:not(.pink-mode) .help-content a:visited {
  color: #fff;
}

.help-content h3 {
  display: flex;
  align-items: center;
  gap: 0.35em;
}

.help-content h3 .help-icon {
  margin-right: 0;
  flex-shrink: 0;
}


.install-guide-content {
  padding: clamp(20px, 4vw, 32px);
  width: min(520px, 100%);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.install-guide-content ol {
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.install-guide-content section {
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.install-guide-content section h3 {
  margin: 0;
}

.install-guide-actions {
  justify-content: flex-end;
}


.ios-pwa-help-content {
  padding: clamp(20px, 4vw, 32px);
  width: min(480px, 100%);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ios-pwa-help-content ol {
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ios-pwa-help-actions {
  justify-content: flex-end;
}


.settings-content {
  padding: clamp(16px, 4vw, 24px);
  width: min(960px, calc(100vw - 2 * var(--modal-frame-padding, 20px)));
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

@supports (width: 100dvw) {
  .settings-content {
    width: min(960px, calc(100dvw - 2 * var(--modal-frame-padding, 20px)));
  }
}

.settings-layout {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.settings-sidebar {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

.settings-panels {
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}

.settings-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cluster-gap);
  padding: 0;
  margin: 0;
  list-style: none;
  align-items: stretch;
  flex: 0 0 auto;
}

.settings-tab {
  margin: 0;
  flex: 1 1 140px;
  min-width: 140px;
  justify-content: flex-start;
  align-items: center;
  text-align: left;
  white-space: normal;
  font-weight: var(--font-weight-medium);
  letter-spacing: normal;
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease,
    transform 0.2s ease;
  scroll-snap-align: start;
}

.settings-tab:hover,
.settings-tab:focus-visible {
  transform: translateY(-1px);
}

.settings-tab:active {
  transform: translateY(0);
}

.settings-tab:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.settings-tab[aria-selected="true"] {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent-color) 35%, transparent);
}

.settings-tab[aria-selected="true"]:hover,
.settings-tab[aria-selected="true"]:focus-visible {
  background-color: color-mix(in srgb, var(--accent-color) 90%, var(--control-hover-bg));
}

.settings-tab-icon {
  --icon-size: var(--button-icon-size);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-color);
  flex: 0 0 auto;
  margin-inline-end: 0;
  flex-shrink: 0;
  transition: color 0.2s ease;
}

.settings-tab:hover .settings-tab-icon,
.settings-tab:focus-visible .settings-tab-icon,
.settings-tab[aria-selected="true"] .settings-tab-icon {
  color: currentColor;
}

.settings-tab-label {
  font-size: var(--form-control-font-size);
  font-weight: var(--font-weight-medium);
  line-height: var(--button-line-height);
  color: inherit;
  text-align: left;
  flex: 1 1 auto;
  min-width: 0;
}

.settings-tab[aria-selected="true"] .settings-tab-label {
  font-weight: var(--font-weight-semibold);
}

body.high-contrast .settings-tab {
  border: 2px solid currentColor;
  background-color: var(--surface-color);
  color: inherit;
  box-shadow: none;
}

body.high-contrast .settings-tab:hover,
body.high-contrast .settings-tab:focus-visible {
  transform: none;
}

body.high-contrast .settings-tab[aria-selected="true"] {
  border-color: var(--accent-color);
  color: var(--inverse-text-color);
  box-shadow: none;
}

@media (max-width: 899.98px) {
  .settings-tabs {
    padding-bottom: 4px;
    gap: clamp(12px, 3vw, 20px);
  }

  .settings-tab {
    flex: 1 1 clamp(136px, 50%, 220px);
    min-width: clamp(136px, 56vw, 220px);
  }

  .settings-section-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .app-modal[open] {
    align-items: stretch;
  }

  .settings-content {
    border-radius: 0;
  }
}

@media (max-width: 640px) {
  .settings-content {
    width: 100%;
    max-width: none;
    padding: clamp(16px, 6vw, 24px);
  }

  .settings-layout {
    gap: clamp(16px, 5vw, 24px);
  }

  .settings-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x proximity;
    gap: clamp(10px, 4vw, 16px);
    padding-block-end: 4px;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
  }

  .settings-tabs::-webkit-scrollbar {
    height: 6px;
  }

  .settings-tab {
    flex: 0 0 clamp(160px, 75vw, 240px);
    min-width: clamp(160px, 65vw, 240px);
    scroll-snap-align: start;
  }

  .settings-field,
  .settings-field-toggle {
    align-items: stretch;
    gap: clamp(8px, 3vw, 12px);
  }

  .settings-field-toggle {
    flex-direction: column;
  }

  .settings-field-toggle input[type='checkbox'] {
    align-self: flex-start;
  }

  .settings-inline-controls {
    flex-direction: column;
    align-items: stretch;
  }

  .settings-inline-controls .inline-form-button {
    width: 100%;
  }

  .settings-inline-controls input[type='color'] {
    align-self: flex-start;
  }

  .settings-inline-actions {
    align-items: stretch;
  }

  .settings-inline-actions button,
  .settings-inline-actions .inline-form-button {
    width: 100%;
  }

  .settings-card .file-input-wrapper {
    align-items: stretch;
  }

  .settings-card .file-input-wrapper input[type='file'] {
    width: 100%;
  }

  .mount-voltage-header {
    flex-direction: column;
    align-items: stretch;
  }

  .mount-voltage-header button {
    width: 100%;
  }
}

@media (min-width: 900px) {
  .settings-layout {
    flex-direction: row;
    align-items: stretch;
    gap: 20px;
  }

  .settings-sidebar {
    flex: 0 0 clamp(180px, 28%, 240px);
    max-width: clamp(180px, 30%, 260px);
  }

  .settings-tabs {
    flex-direction: column;
    align-items: stretch;
    overflow-x: hidden;
    overflow-y: auto;
    max-height: min(68vh, 520px);
    padding-right: 4px;
  }

  .settings-tab {
    flex: 0 0 auto;
    flex-basis: auto;
    width: 100%;
    min-width: 0;
  }

  .settings-panels {
    flex: 1 1 auto;
    min-width: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .settings-tab {
    transition: none;
    transform: none;
  }
  .settings-tab-icon {
    transition: none;
  }
}

.settings-panel {
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  box-shadow: var(--panel-shadow);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.settings-panel h3 {
  margin: 0;
  font-weight: var(--font-weight-semibold);
}

.settings-section-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.settings-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 18px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  min-width: 0;
}

.settings-card h4 {
  margin: 0;
  font-weight: var(--font-weight-semibold);
  font-size: 1.05rem;
}

.settings-card-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.camera-color-settings {
  gap: 18px;
}

.camera-color-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 16px;
}

.camera-color-field label {
  font-weight: var(--font-weight-medium);
}

.settings-card-wide {
  grid-column: 1 / -1;
}

.settings-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.settings-field select,
.settings-field input:not([type='checkbox']):not([type='color']),
.settings-field textarea {
  width: 100%;
  max-width: 100%;
}

.settings-field-toggle {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.settings-field-toggle label {
  flex: 1 1 auto;
}

.settings-field-toggle input[type='checkbox'] {
  flex: 0 0 auto;
}

.settings-inline-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.settings-inline-controls input[type='color'] {
  padding: 0;
  width: 52px;
  height: var(--button-size);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--surface-color);
}

.settings-inline-controls .inline-form-button {
  flex: 0 0 auto;
}

.settings-inline-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.settings-inline-actions p {
  margin: 0;
}

.settings-inline-actions[hidden] {
  display: none;
}

.settings-card .settings-hint {
  margin: 0;
}

.settings-card .file-input-wrapper {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.documentation-tracker-card {
  gap: 14px;
}

.documentation-tracker-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.documentation-tracker-header h4 {
  margin: 0;
  font-weight: var(--font-weight-semibold);
}

.documentation-tracker-summary {
  margin: 0;
  font-weight: var(--font-weight-medium);
}

.documentation-tracker-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.documentation-release {
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--surface-color);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.documentation-release-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
}

.documentation-release-heading {
  display: grid;
  gap: 8px;
  min-width: 220px;
}

.documentation-release-heading label {
  font-weight: var(--font-weight-medium);
}

.documentation-release-heading input[type='text'] {
  font-weight: var(--font-weight-semibold);
}

.documentation-release-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 12px;
}

.documentation-release-meta .settings-hint {
  margin: 0;
}

.documentation-release-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.documentation-release-body {
  display: grid;
  gap: 16px;
}

.documentation-release-group {
  display: grid;
  gap: 12px;
}

.documentation-release-group h5 {
  margin: 0;
  font-size: 1rem;
  font-weight: var(--font-weight-semibold);
}

.documentation-release-items {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.documentation-release-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.documentation-release-item input[type='checkbox'] {
  margin-top: 3px;
}

.documentation-release-notes textarea {
  min-height: 96px;
  resize: vertical;
}

.documentation-release footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  align-items: center;
  justify-content: space-between;
}

.documentation-release-progress {
  font-weight: var(--font-weight-medium);
}

.documentation-release-updated {
  font-size: 0.85rem;
  color: var(--muted-text-color);
}

.documentation-release[data-archived='true'] {
  border-style: dashed;
  opacity: 0.9;
}

.documentation-release-count {
  font-size: 0.85rem;
  color: var(--muted-text-color);
  margin-left: 6px;
  font-weight: var(--font-weight-medium);
}

.documentation-release-archived-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border-radius: var(--border-radius-pill);
  padding: 2px 8px;
  background: var(--panel-border);
  color: var(--text-color);
  font-size: 0.75rem;
  font-weight: var(--font-weight-medium);
}

.documentation-release-archived-badge::before {
  content: '\26A0';
  font-size: 0.8rem;
}

.documentation-release[data-archived='true'] .documentation-release-notes textarea,
.documentation-release[data-archived='true'] input,
.documentation-release[data-archived='true'] textarea {
  background: var(--surface-subtle-color);
}

.documentation-release[data-archived='true'] label {
  color: var(--muted-text-color);
}

.documentation-tracker-card .settings-empty-state {
  margin: 0;
}

.settings-panel p {
  margin: 0;
}

.settings-support-links {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.settings-support-links a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: var(--font-weight-medium);
}

.settings-panel label {
  font-weight: var(--font-weight-light);
}

.mount-voltage-settings {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mount-voltage-settings .settings-hint {
  margin: 0;
}

.mount-voltage-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.mount-voltage-header h4 {
  margin: 0;
  font-weight: var(--font-weight-semibold);
}

.mount-voltage-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.mount-voltage-card {
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 12px;
  background: var(--panel-bg);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mount-voltage-card h5 {
  margin: 0;
  font-size: 1rem;
  font-weight: var(--font-weight-semibold);
}

.mount-voltage-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mount-voltage-input {
  width: 100%;
}

.settings-panel .button-row {
  justify-content: flex-start;
  flex-wrap: wrap;
}

.settings-panel[hidden] {
  display: none;
}

.auto-gear-rules {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

#settingsPanel-autoGear h3,
#settingsPanel-autoGear h4 {
  font-weight: var(--font-weight-semibold);
}

.auto-gear-preset-panel {
  position: relative;
  margin-top: 16px;
  margin-bottom: 16px;
  padding: 16px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-defaults {
  margin-top: 16px;
  margin-bottom: 16px;
  padding: 16px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.auto-gear-defaults-description {
  margin: 0;
  color: var(--muted-text);
}

.auto-gear-default-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.auto-gear-defaults .auto-gear-field select {
  width: 100%;
}

.auto-gear-preset-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.auto-gear-preset-name-dialog {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: color-mix(in srgb, var(--surface-color) 55%, transparent);
  z-index: 5;
}

.auto-gear-preset-name-dialog[hidden] {
  display: none;
}

.auto-gear-preset-name-card {
  width: min(100%, 360px);
  padding: 16px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  box-shadow: var(--panel-shadow);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.auto-gear-preset-name-label {
  font-weight: var(--font-weight-semibold);
}

.auto-gear-preset-name-input {
  width: 100%;
}

.auto-gear-preset-name-error {
  margin: 0;
  min-height: 1.25rem;
  color: var(--danger-color, #b00020);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
}

.auto-gear-preset-row label {
  flex: 0 0 auto;
  margin: 0;
}

.auto-gear-preset-select {
  flex: 1 1 200px;
  min-width: 160px;
}

.auto-gear-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 12px;
}

.auto-gear-filters .auto-gear-action-row {
  flex: 1 1 100%;
  margin-top: 0;
}

.auto-gear-highlight-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--icon-gap);
  margin: 0;
  border: 1px solid color-mix(in srgb, var(--accent-color) 45%, transparent);
  background: color-mix(in srgb, var(--surface-color) 92%, var(--accent-color) 8%);
  color: var(--control-text);
  font-weight: var(--font-weight-medium);
  justify-content: flex-start;
  padding-inline: calc(var(--button-padding-inline) * 0.9);
  min-width: 0;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.auto-gear-highlight-toggle .btn-icon {
  margin-inline-end: var(--icon-gap);
  color: currentColor;
}

.auto-gear-highlight-toggle:hover,
.auto-gear-highlight-toggle:focus-visible {
  background: var(--accent-color);
  color: var(--inverse-text-color);
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 35%, transparent);
}

.auto-gear-highlight-toggle:focus-visible {
  outline: none;
}

.auto-gear-highlight-toggle.is-active {
  background: var(--accent-color);
  color: var(--inverse-text-color);
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 45%, transparent);
}

.auto-gear-highlight-toggle:disabled {
  opacity: 0.65;
  cursor: not-allowed;
  box-shadow: none;
}

.auto-gear-highlight-state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-inline-start: calc(var(--icon-gap) * 1.4);
  padding: 0.15em 0.6em;
  border-radius: 999px;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  line-height: 1.2;
  font-weight: var(--font-weight-medium);
  border: 1px solid color-mix(in srgb, var(--accent-color) 35%, transparent);
  background: color-mix(in srgb, var(--accent-color) 18%, transparent);
  color: currentColor;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease,
    opacity 0.2s ease;
}

.auto-gear-highlight-toggle.is-active .auto-gear-highlight-state {
  background: color-mix(in srgb, var(--inverse-text-color) 18%, transparent);
  border-color: color-mix(in srgb, var(--inverse-text-color) 35%, transparent);
  color: var(--inverse-text-color);
}

.auto-gear-highlight-toggle:disabled .auto-gear-highlight-state {
  opacity: 0.7;
}

.auto-gear-backups {
  margin-top: 16px;
  padding: 16px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-backup-retention {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auto-gear-backup-retention-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.auto-gear-backup-retention-input {
  width: 90px;
}

.auto-gear-backup-warning {
  margin: 0;
  color: var(--warning-color, #ff9f1c);
  font-weight: 500;
}

.auto-gear-backup-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.auto-gear-backup-toggle-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.auto-gear-backup-toggle-row label {
  margin: 0;
}

.auto-gear-backups.auto-gear-backups-collapsed {
  gap: 4px;
}

.auto-gear-backups.auto-gear-backups-collapsed .auto-gear-backup-controls {
  display: none;
}

.auto-gear-backup-controls {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-backup-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.auto-gear-backup-select {
  flex: 1;
  min-width: 0;
}

.auto-gear-backup-empty {
  font-style: italic;
  color: var(--muted-text-color, #666);
  margin: 0;
}

.auto-gear-filters {
  margin-top: 16px;
  margin-bottom: 12px;
  padding: 12px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px;
}

.auto-gear-filter-field {
  flex: 1 1 220px;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auto-gear-filter-field label {
  margin: 0;
  font-weight: var(--font-weight-semibold);
}

.auto-gear-filter-field input[type='search'],
.auto-gear-filter-select {
  width: 100%;
}

.auto-gear-filter-clear {
  flex: 0 0 auto;
  align-self: flex-end;
  margin: 0 0 var(--button-margin-block-end);
  margin-left: auto;
  padding-inline: calc(var(--button-padding-inline) + 2px);
  background-color: var(--surface-color);
  border: 1px solid var(--panel-border);
  color: var(--control-text);
  box-shadow: none;
}

.auto-gear-filter-clear:hover {
  background-color: color-mix(in srgb, var(--accent-color) 12%, var(--surface-color));
  border-color: color-mix(in srgb, var(--accent-color) 55%, var(--panel-border));
  color: var(--control-text);
}

.auto-gear-filter-clear:active {
  background-color: color-mix(in srgb, var(--accent-color) 18%, var(--surface-color));
  border-color: color-mix(in srgb, var(--accent-color) 65%, var(--panel-border));
}

.auto-gear-filter-clear:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.auto-gear-summary {
  margin-top: 16px;
  margin-bottom: 16px;
  padding: 16px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: var(--panel-shadow);
}

.auto-gear-summary-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auto-gear-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.auto-gear-summary-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--panel-border) 85%, transparent);
  border-radius: var(--border-radius);
  background: color-mix(in srgb, var(--surface-color) 92%, var(--accent-color) 8%);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  font: inherit;
  text-align: left;
  color: inherit;
}

.auto-gear-summary-card p {
  margin: 0;
}

.auto-gear-summary-label {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--muted-text-color, #666);
}

.auto-gear-summary-value {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  font-weight: var(--font-weight-semibold);
}

.auto-gear-summary-description {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: var(--muted-text-color, #666);
}

.auto-gear-summary-action {
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.auto-gear-summary-action[disabled] {
  cursor: default;
  opacity: 0.65;
  background: color-mix(in srgb, var(--surface-color) 96%, var(--muted-text-color, #666) 4%);
}

.auto-gear-summary-action[aria-pressed='true'] {
  background: var(--accent-color);
  color: var(--inverse-text-color);
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 35%, transparent);
}

.auto-gear-summary-action[aria-pressed='true'] .auto-gear-summary-label,
.auto-gear-summary-action[aria-pressed='true'] .auto-gear-summary-description {
  color: inherit;
}

.auto-gear-summary-action:hover:not([disabled]),
.auto-gear-summary-action:focus-visible:not([disabled]) {
  background: var(--accent-color);
  color: var(--inverse-text-color);
  border-color: var(--accent-color);
}

.auto-gear-summary-action:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 45%, transparent);
}

.auto-gear-summary-details {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-summary-detail-title {
  margin: 0;
  font-weight: var(--font-weight-semibold);
}

.auto-gear-summary-detail-text {
  margin: 0;
  color: var(--muted-text-color, #666);
}

.auto-gear-summary-list {
  margin: 0;
  padding-left: 1.2em;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auto-gear-summary-list li {
  margin: 0;
}

.auto-gear-summary-list button {
  background: none;
  border: none;
  padding: 0;
  color: var(--link-color);
  cursor: pointer;
  font: inherit;
  text-align: left;
}

.auto-gear-summary-list button:hover,
.auto-gear-summary-list button:focus-visible {
  text-decoration: underline;
}

.auto-gear-summary-list button:focus-visible {
  outline: none;
}

.auto-gear-summary-details button[data-auto-gear-rule],
.auto-gear-summary-details button[data-auto-gear-scenario] {
  background: none;
  border: none;
  padding: 0;
  color: var(--link-color);
  cursor: pointer;
  font: inherit;
  text-align: left;
  border-radius: 4px;
}

.auto-gear-summary-details button[data-auto-gear-rule]:hover,
.auto-gear-summary-details button[data-auto-gear-scenario]:hover,
.auto-gear-summary-details button[data-auto-gear-rule]:focus-visible,
.auto-gear-summary-details button[data-auto-gear-scenario]:focus-visible {
  text-decoration: underline;
}

.auto-gear-summary-details button[data-auto-gear-rule]:focus-visible,
.auto-gear-summary-details button[data-auto-gear-scenario]:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent-color) 45%, transparent);
  outline-offset: 2px;
}

.auto-gear-summary-reset {
  align-self: flex-start;
  background: none;
  border: none;
  padding: 0;
  color: var(--link-color);
  cursor: pointer;
  font: inherit;
}

.auto-gear-summary-reset:hover,
.auto-gear-summary-reset:focus-visible {
  text-decoration: underline;
}

.auto-gear-summary-reset:focus-visible {
  outline: none;
}

body.dark-mode:not(.high-contrast) .auto-gear-summary {
  background: color-mix(in srgb, var(--surface-color) 85%, #000000 15%);
  border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
}

body.dark-mode:not(.high-contrast) .auto-gear-summary-card {
  background: color-mix(in srgb, var(--control-bg) 80%, #000000 20%);
  border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
  color: var(--inverse-text-color);
}

body.dark-mode:not(.high-contrast) .auto-gear-summary-list button,
body.dark-mode:not(.high-contrast) .auto-gear-summary-details button[data-auto-gear-rule],
body.dark-mode:not(.high-contrast) .auto-gear-summary-details button[data-auto-gear-scenario],
body.dark-mode:not(.high-contrast) .auto-gear-summary-reset {
  color: var(--inverse-text-color);
  text-decoration-color: currentColor;
}

body.dark-mode:not(.high-contrast) .auto-gear-summary-label,
body.dark-mode:not(.high-contrast) .auto-gear-summary-description,
body.dark-mode:not(.high-contrast) .auto-gear-summary-detail-text {
  color: color-mix(in srgb, var(--inverse-text-color) 85%, transparent);
}

@media (prefers-color-scheme: dark) {
  body:not(.light-mode):not(.high-contrast) .auto-gear-summary {
    background: color-mix(in srgb, var(--surface-color) 85%, #000000 15%);
    border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
  }

  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-card {
    background: color-mix(in srgb, var(--control-bg) 80%, #000000 20%);
    border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
    color: var(--inverse-text-color);
  }

  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-list button,
  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-details button[data-auto-gear-rule],
  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-details button[data-auto-gear-scenario],
  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-reset {
    color: var(--inverse-text-color);
    text-decoration-color: currentColor;
  }

  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-label,
  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-description,
  body:not(.light-mode):not(.high-contrast) .auto-gear-summary-detail-text {
    color: color-mix(in srgb, var(--inverse-text-color) 85%, transparent);
  }
}

@media (max-width: 600px) {
  .auto-gear-summary-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  }
}

.auto-gear-rule {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
}

.auto-gear-rule-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 0;
}

.auto-gear-rule-title {
  font-weight: var(--font-weight-semibold);
  margin: 0;
}

.auto-gear-rule-items-label {
  font-weight: var(--font-weight-semibold);
}

body.light-mode .auto-gear-rule-title,
body.light-mode #settingsPanel-autoGear h3,
body.light-mode #settingsPanel-autoGear h4,
body.light-mode #settingsPanel-autoGear .auto-gear-filter-field label,
body.light-mode #settingsPanel-autoGear .auto-gear-rule-items-label,
#overviewDialogContent:not(.dark-mode) .auto-gear-rule-title,
#overviewDialogContent:not(.dark-mode) .auto-gear-rule-items-label {
  color: var(--accent-color);
}

body.pink-mode .auto-gear-rule-title,
#overviewDialogContent.pink-mode .auto-gear-rule-title {
  color: var(--accent-color);
}

body.pink-mode:not(.dark-mode) #settingsPanel-autoGear h3,
body.pink-mode:not(.dark-mode) #settingsPanel-autoGear h4,
body.pink-mode:not(.dark-mode) #settingsPanel-autoGear .auto-gear-filter-field label,
body.pink-mode:not(.dark-mode) #settingsPanel-autoGear .auto-gear-rule-items-label,
#overviewDialogContent.pink-mode:not(.dark-mode) .auto-gear-rule-items-label {
  color: var(--accent-color);
}

.auto-gear-rule-meta {
  color: var(--muted-text-color, #666);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.auto-gear-rule-items-label {
  margin-top: 4px;
}

.auto-gear-rule-items {
  margin: 0;
  padding-left: 18px;
  color: var(--muted-text-color, #666);
}

.auto-gear-rule-item {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: var(--line-height-supporting);
  word-break: break-word;
}

.auto-gear-rule-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

@media (max-width: 600px) {
  .auto-gear-rule {
    flex-direction: column;
    align-items: stretch;
  }

  .auto-gear-rule-info,
  .auto-gear-rule-items,
  .auto-gear-rule-actions {
    width: 100%;
  }

  .auto-gear-rule-actions {
    justify-content: flex-start;
  }
}

.auto-gear-editor {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--panel-bg);
}

.auto-gear-editor[hidden] {
  display: none !important;
}

.auto-gear-conditions-row {
  padding: 0;
}

.auto-gear-conditions {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}

.auto-gear-condition-controls {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-condition-controls label {
  flex: 0 0 auto;
  min-width: 0;
}

.auto-gear-condition-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.auto-gear-condition-controls:focus-within {
  outline: 2px solid var(--accent-color, #007aff);
  outline-offset: 4px;
  border-radius: var(--border-radius);
}

.auto-gear-condition-select {
  min-width: min(220px, 100%);
}

.auto-gear-condition-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auto-gear-condition {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--surface-color);
}

.auto-gear-condition-flash {
  box-shadow: 0 0 0 2px var(--accent-color, #007aff);
  animation: auto-gear-condition-flash 1.2s ease-out;
}

@media (prefers-reduced-motion: reduce) {
  .auto-gear-condition-flash {
    animation: none;
  }
}

@keyframes auto-gear-condition-flash {
  0% {
    box-shadow: 0 0 0 0 rgba(0, 122, 255, 0.55);
    background-color: rgba(0, 122, 255, 0.08);
  }
  50% {
    box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.4);
    background-color: rgba(0, 122, 255, 0.12);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(0, 122, 255, 0);
    background-color: var(--surface-color);
  }
}

.auto-gear-condition[hidden] {
  display: none !important;
}

.auto-gear-condition-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.auto-gear-condition-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.auto-gear-condition-actions button {
  min-width: 40px;
  padding-inline: 10px;
}

.auto-gear-shooting-days-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.auto-gear-shooting-days-group select {
  flex: 1 1 160px;
  min-width: 140px;
}

.auto-gear-shooting-days-group input[type="number"] {
  flex: 0 1 120px;
  min-width: 100px;
}

.auto-gear-editor-columns {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

@media (min-width: 720px) {
  .auto-gear-editor-columns {
    flex-direction: row;
  }
}

.auto-gear-column {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.auto-gear-add-controls {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  align-items: end;
}

.auto-gear-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auto-gear-item-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-item-list .auto-gear-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--surface-color);
}

.auto-gear-item-list .auto-gear-item.auto-gear-item-editing {
  border-color: var(--accent-color, #007aff);
  box-shadow: 0 0 0 1px var(--accent-color, #007aff);
}

.auto-gear-item-list .auto-gear-item span {
  display: block;
}

.auto-gear-item-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.auto-gear-draft-impact {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  background: var(--surface-color);
}

.auto-gear-impact-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.auto-gear-impact-header h4,
.auto-gear-impact-warnings h5 {
  margin: 0;
}

.auto-gear-impact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-impact-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-left: 12px;
  border-left: 3px solid var(--panel-border);
}

.auto-gear-impact-item.auto-gear-impact-positive {
  border-left-color: var(--accent-color, #007aff);
}

.auto-gear-impact-item.auto-gear-impact-negative {
  border-left-color: var(--warning-color, #ff9f1c);
}

body.auto-gear-highlight-context .auto-gear-impact-item.auto-gear-impact-stacked,
.auto-gear-highlight-context .auto-gear-impact-item.auto-gear-impact-stacked {
  border-left-color: transparent;
  border-image: linear-gradient(
      180deg,
      var(--accent-color, #007aff),
      var(--warning-color, #ff9f1c)
    )
    1;
  padding: 8px 12px 8px 12px;
  gap: 6px;
  border-radius: var(--border-radius, 8px);
  background-color: var(--surface-color, #ffffff);
  background-image: linear-gradient(
    135deg,
    rgba(0, 122, 255, 0.16),
    rgba(255, 159, 28, 0.16)
  );
}

body.auto-gear-highlight-context.dark-mode .auto-gear-impact-item.auto-gear-impact-stacked,
.auto-gear-highlight-context.dark-mode .auto-gear-impact-item.auto-gear-impact-stacked {
  background-color: color-mix(in srgb, var(--surface-color, #111111) 85%, transparent);
}

.auto-gear-impact-summary {
  font-weight: 600;
}

.auto-gear-impact-totals,
.auto-gear-impact-delta {
  font-size: 0.95rem;
}

.auto-gear-impact-delta {
  font-weight: 600;
}

.auto-gear-impact-item.auto-gear-impact-negative .auto-gear-impact-delta {
  color: var(--warning-color, #ff9f1c);
}

.auto-gear-impact-item.auto-gear-impact-positive .auto-gear-impact-delta {
  color: var(--accent-color, #007aff);
}

.auto-gear-impact-meta {
  font-size: 0.85rem;
  color: var(--muted-text-color, #666666);
}

.auto-gear-impact-empty {
  color: var(--muted-text-color, #666666);
}

.auto-gear-impact-warnings {
  border-top: 1px solid var(--panel-border);
  padding-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.auto-gear-impact-warnings ul {
  margin: 0;
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.auto-gear-impact-warning-item {
  color: var(--warning-color, #ff9f1c);
  font-weight: 600;
}

.auto-gear-selector-container {
  display: inline-flex;
  flex-direction: column;
  align-items: stretch;
  gap: 4px;
  max-width: min(100%, 320px);
  vertical-align: top;
}

.auto-gear-scenario-settings {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap-size);
  margin-top: 12px;
}

.auto-gear-scenario-settings .auto-gear-field {
  flex: 1 1 220px;
  gap: 2px;
}

.auto-gear-scenario-settings .auto-gear-field select,
.auto-gear-scenario-settings .auto-gear-field input {
  flex: 0 0 auto;
}

.auto-gear-scenario-multiplier {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap-size);
  align-items: flex-end;
}

.auto-gear-scenario-multiplier .auto-gear-field {
  flex: 1 1 200px;
}

.auto-gear-selector,
.auto-gear-multiselect {
  width: 100%;
  height: auto;
  overflow-y: auto;
}

.auto-gear-selector {
  max-height: 18rem;
}

.auto-gear-multiselect {
  max-height: min(24rem, 60vh);
}

.auto-gear-device-multiselect {
  min-height: 14rem;
}

@media (max-width: 640px) {
  .auto-gear-device-multiselect {
    min-height: 12rem;
  }
}

.auto-gear-selector-hint {
  display: block;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: var(--muted-text-color, #666);
  line-height: var(--line-height-supporting);
}

.auto-gear-empty {
  font-style: italic;
  color: var(--muted-text-color, #666);
}

.storage-summary {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.storage-summary-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.storage-summary-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.storage-summary-label {
  font-weight: var(--font-weight-semibold);
}

.storage-summary-key {
  font-family: 'Courier New', Courier, monospace;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--control-bg);
  color: var(--control-text);
}

.storage-summary-value {
  margin: 0;
  font-weight: var(--font-weight-medium);
}

.storage-summary-note,
.storage-summary-description,
.storage-summary-extra {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: var(--control-text);
  opacity: 0.85;
}

.storage-summary-extra {
  padding-left: 0;
}

.storage-actions {
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.storage-actions-buttons {
  align-items: center;
}

.storage-status {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.storage-status-list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.storage-status-reminder {
  margin: 4px 0 0;
  padding: 12px 16px;
  border-radius: calc(var(--border-radius) * 1.1);
  border: 1px solid var(--panel-border);
  background: var(--panel-bg);
  display: grid;
  gap: 8px;
}

.storage-status-reminder[hidden] {
  display: none;
}

.storage-status-reminder-list {
  margin: 0;
  padding-left: 1.25em;
  display: grid;
  gap: 4px;
}

.storage-status-reminder-text {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
}

.storage-status-reminder--warning {
  box-shadow: inset 4px 0 0 0 var(--warning-color, #ff9f1c);
  border-color: color-mix(in srgb, var(--warning-color, #ff9f1c) 45%, transparent);
}

@supports not (color: color-mix(in srgb, red 50%, white)) {
  .storage-status-reminder--warning {
    border-color: rgba(255, 159, 28, 0.35);
  }
}

.storage-status-reminder--ok {
  box-shadow: inset 4px 0 0 0 var(--success-color, #4caf50);
  border-color: color-mix(in srgb, var(--success-color, #4caf50) 45%, transparent);
}

@supports not (color: color-mix(in srgb, red 50%, white)) {
  .storage-status-reminder--ok {
    border-color: rgba(76, 175, 80, 0.35);
  }
}

body.dark-mode .storage-status-reminder {
  background: rgba(255, 255, 255, 0.05);
}

.storage-status-item {
  display: grid;
  gap: 2px;
}

.storage-status-item dt {
  font-weight: var(--font-weight-semibold);
}

.storage-status-item dd {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: var(--control-text);
  opacity: 0.9;
}

.logging-section {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.logging-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.logging-filter {
  flex: 1 1 220px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.logging-filter input,
.logging-filter select {
  width: 100%;
}

.logging-toggles {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.logging-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.logging-actions button {
  align-self: flex-start;
}

.logging-history-container {
  max-height: 280px;
  overflow: auto;
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  padding: 8px;
  background: var(--panel-background-alt, rgba(0, 0, 0, 0.02));
}

.logging-history {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.log-entry {
  border: 1px solid var(--panel-border);
  border-left-width: 4px;
  border-radius: 6px;
  padding: 8px 10px;
  background: var(--panel-background, var(--surface-color));
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.log-entry-header {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: flex-start;
}

.log-entry-message {
  font-weight: var(--font-weight-medium);
  word-break: break-word;
}

.log-entry-level {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  white-space: nowrap;
}

.log-entry-meta {
  display: grid;
  gap: 4px;
  margin: 0;
}

.log-entry-meta-row {
  display: grid;
  gap: 2px;
}

.log-entry-meta-row dt {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--control-text);
  opacity: 0.9;
}

.log-entry-meta-row dd {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  word-break: break-word;
}

.log-entry-detail {
  margin: 0;
  font-family: var(--font-family-monospace, 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  background: color-mix(in srgb, var(--panel-border) 12%, transparent);
  border-radius: 4px;
  padding: 6px;
  overflow: auto;
  max-height: 160px;
}

.log-entry-details summary {
  cursor: pointer;
  font-weight: var(--font-weight-medium);
}

.log-entry-details[open] summary {
  margin-bottom: 4px;
}

.log-entry.level-debug {
  border-left-color: color-mix(in srgb, var(--panel-border) 70%, transparent);
}

.log-entry.level-info {
  border-left-color: var(--accent-color);
}

.log-entry.level-warn {
  border-left-color: var(--warning-color, #ff9f1c);
}

.log-entry.level-error {
  border-left-color: var(--status-error-bg, #ff3b30);
}

.log-entry.level-info .log-entry-level {
  background: color-mix(in srgb, var(--accent-color) 15%, transparent);
  color: var(--accent-color);
}

.log-entry.level-warn .log-entry-level {
  background: color-mix(in srgb, var(--warning-color, #ff9f1c) 20%, transparent);
  color: var(--warning-color, #ff9f1c);
}

.log-entry.level-error .log-entry-level {
  background: color-mix(in srgb, var(--status-error-bg, #ff3b30) 20%, transparent);
  color: var(--status-error-bg, #ff3b30);
}

.log-entry.level-debug .log-entry-level {
  background: color-mix(in srgb, var(--panel-border) 20%, transparent);
  color: var(--control-text);
}

@supports not (color-mix(in srgb, #000 50%, transparent)) {
  .log-entry-detail {
    background: rgba(0, 0, 0, 0.04);
  }

  .log-entry.level-info .log-entry-level {
    background: rgba(0, 0, 0, 0.03);
  }

  .log-entry.level-warn .log-entry-level {
    background: rgba(255, 159, 28, 0.15);
  }

  .log-entry.level-error .log-entry-level {
    background: rgba(255, 59, 48, 0.15);
  }

  .log-entry.level-debug .log-entry-level {
    background: rgba(0, 0, 0, 0.04);
  }
}

.settings-content .button-row {
  display: flex;
  gap: var(--cluster-gap);
  flex-wrap: wrap;
  align-items: center;
}

#settingsDialog button {
  flex-shrink: 0;
}

.settings-content .action-buttons {
  justify-content: flex-end;
  margin-top: auto;
}

.help-content p,
.help-content li {
  line-height: 1.7;
}


#helpSearchContainer {
  position: relative;
}

#helpPrimaryActions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cluster-gap);
  margin: 12px 0 20px;
}

#helpPrimaryActions > button {
  margin: 0;
}

#helpSearch {
  width: 100%;
  margin: 10px 0;
  padding: 5px calc(var(--button-size) + 12px) 5px 10px;
  box-sizing: border-box;
  border: 1px solid var(--panel-border);
}

#helpSearch:focus-visible {
  outline: none;
  border-color: var(--accent-color);
  box-shadow: 0 0 0 1px var(--accent-color);
}

#helpSearchClear {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  margin: 0;
  padding: 0;
  width: var(--button-size);
  height: var(--button-size);
  min-height: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: var(--font-size-base);
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
}

#helpSearchClear[hidden] {
  display: none;
}

#helpQuickLinks {
  margin: 16px 0;
  padding: 12px;
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
}

#helpResultsSummary {
  margin: 0 0 12px;
  color: var(--muted-text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
}

#helpResultsSummary[hidden] {
  display: none;
}

#helpQuickLinks[hidden] {
  display: none;
}

#helpQuickLinksHeading {
  margin: 0;
  font-size: var(--font-size-base);
}

#helpQuickLinksList {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr);
}

#helpQuickLinksList .help-quick-link-spacer {
  visibility: hidden;
  pointer-events: none;
  margin: 0;
  padding: 0;
}

@media (min-width: 560px) {
  #helpQuickLinksList {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

#helpQuickLinksList li {
  margin: 0;
}

.help-quick-link,
.help-quick-link:visited {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5em;
  width: 100%;
  margin: 0;
  text-align: left;
  white-space: normal;
}

.help-quick-link {
  border: none;
  padding: var(--button-link-padding-block) var(--button-link-padding-inline);
}

.help-quick-link-icon { 
  --icon-color: var(--accent-color);
  flex: 0 0 auto;
  font-size: var(--icon-size-md);
}

.help-quick-link-icon.icon-glyph {
  --icon-size: var(--icon-size-md);
}

.dark-mode .help-quick-link-icon {
  --icon-color: var(--inverse-text-color);
}

.help-quick-link.active .help-quick-link-icon {
  --icon-color: var(--inverse-text-color);
}

.help-quick-link:hover .help-quick-link-icon,
.help-quick-link:focus-visible .help-quick-link-icon {
  --icon-color: var(--inverse-text-color);
}

.help-quick-link-label {
  flex: 1 1 auto;
  min-width: 0;
  line-height: 1.3;
}

.help-quick-link:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.help-quick-link.active {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
}

.help-quick-link.active:focus-visible {
  outline-color: var(--inverse-text-color);
}

#helpSections section[hidden],
#helpSections details[hidden] {
  display: none;
}

#helpSections section {
  scroll-margin-top: 24px;
}

#helpSections section.help-section-focus {
  outline: 2px solid var(--accent-color);
  outline-offset: 4px;
  border-radius: var(--border-radius);
}

.help-link {
  text-decoration: none;
  transition:
    color 0.2s ease,
    text-decoration-color 0.2s ease;
  font-weight: var(--font-weight-regular);
}

.help-link:focus-visible {
  border-radius: calc(var(--border-radius) * 0.75);
}

.help-link:not(.button-link) {
  color: var(--accent-color);
  text-underline-offset: 0.2em;
  text-decoration-thickness: 0.12em;
}

.help-link {
  font-weight: var(--font-weight-regular);
}

.help-link:not(.button-link):visited {
  color: var(--accent-color);
}

.help-link:not(.button-link):hover,
.help-link:not(.button-link):focus-visible {
  text-decoration: underline;
}

.help-link strong,
.help-link b {
  font-weight: inherit;
}

.help-link.button-link,
.help-link.button-link:visited {
  display: inline;
  min-height: 0;
  padding: 0;
  background: none;
  color: var(--accent-color);
  font-family: inherit;
  font-size: inherit;
  font-weight: var(--font-weight-regular);
  line-height: inherit;
  text-decoration: none;
  text-underline-offset: 0.2em;
  text-decoration-thickness: 0.12em;
  transform: none;
}

.help-link.button-link:hover,
.help-link.button-link:focus-visible {
  background: none;
  color: var(--accent-color);
  text-decoration: underline;
  transform: none;
}

.help-link.button-link:active {
  background: none;
  color: var(--accent-color);
  transform: none;
}

.help-link.button-link:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.help-inline-links {
  margin: 0.75rem 0 0;
  line-height: 1.6;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.help-inline-links .button-link,
.help-inline-links .button-link:visited {
  background-color: transparent;
  color: var(--accent-color);
}

.help-inline-links .help-link:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

.help-callout {
  margin: 1.25rem 0;
  padding: 1rem 1.25rem;
  border-radius: calc(var(--border-radius) * 1.2);
  border: 1px solid var(--panel-border);
  background-color: var(--panel-bg);
  box-shadow: inset 4px 0 0 0 var(--accent-color);
  display: grid;
  gap: 0.75rem;
}

.help-callout.help-no-results {
  box-shadow: inset 4px 0 0 0 var(--warning-color, #ff9f1c);
  border-color: color-mix(in srgb, var(--warning-color, #ff9f1c) 45%, transparent);
}

@supports not (color: color-mix(in srgb, red 50%, white)) {
  .help-callout.help-no-results {
    border-color: rgba(255, 159, 28, 0.35);
  }
}

.help-callout.help-no-results h4 {
  color: var(--warning-color, #ff9f1c);
}

.help-no-results ul {
  display: grid;
  gap: 0.5rem;
  padding-left: 1.25em;
}

.help-callout h4 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
  font-weight: var(--font-weight-semibold);
}

.help-callout ol,
.help-callout ul {
  margin: 0;
  padding-left: 1.25em;
}

.help-callout-note {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--muted-text-color);
}

.help-onboarding-status {
  display: block;
  margin-top: 0.25rem;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--muted-text-color);
}

body.dark-mode .help-onboarding-status {
  color: rgba(255, 255, 255, 0.75);
}

body.dark-mode .help-callout {
  background-color: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}

.help-target-focus,
.feature-search-focus {
  outline: 2px solid var(--accent-color);
  outline-offset: 3px;
  border-radius: var(--border-radius);
  transition:
    outline-color 0.2s ease-in-out,
    background-color 0.2s ease-in-out,
    box-shadow 0.2s ease-in-out;
}

.help-target-focus:focus,
.help-target-focus:focus-visible,
.feature-search-focus:focus,
.feature-search-focus:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 3px;
}

@supports (outline-color: color-mix(in srgb, red 50%, transparent)) {
  .help-target-focus,
  .help-target-focus:focus,
  .help-target-focus:focus-visible,
  .feature-search-focus,
  .feature-search-focus:focus,
  .feature-search-focus:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--accent-color) 82%, transparent);
  }
}

.feature-search-focus {
  background-color: rgba(0, 0, 0, 0.03);
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.04);
}

.dark-mode .feature-search-focus {
  background-color: rgba(255, 255, 255, 0.07);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08);
}

@supports (background-color: color-mix(in srgb, red 10%, transparent)) {
  .feature-search-focus {
    background-color: color-mix(in srgb, var(--accent-color) 12%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-color) 24%, transparent);
  }

  .dark-mode .feature-search-focus {
    background-color: color-mix(in srgb, var(--accent-color) 18%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-color) 36%, transparent);
  }
}

.icon-glyph {
  font-family: 'UiconsThinStraightV2';
  font-style: normal;
  font-weight: var(--font-weight-regular);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  vertical-align: middle;
  font-size: var(--icon-size, 1em);
  width: var(--icon-size, 1em);
  height: var(--icon-size, 1em);
  inline-size: var(--icon-size, 1em);
  block-size: var(--icon-size, 1em);
  min-inline-size: var(--icon-size, 1em);
  min-block-size: var(--icon-size, 1em);
  flex: 0 0 var(--icon-size, 1em);
  color: var(--icon-color, currentColor);
}

.icon-glyph[data-icon-font='uicons'] {
  font-family: 'UiconsThinStraightV2';
}

.icon-glyph[data-icon-font='essential'] {
  font-family: 'EssentialIconsV2';
}

.icon-glyph[data-icon-font='film'] {
  font-family: 'FilmIndustryIconsV2';
}

.icon-glyph[data-icon-font='gadget'] {
  font-family: 'GadgetIconsV2';
}

.icon-glyph[data-icon-font='text'] {
  font-family: 'Ubuntu', sans-serif;
  font-weight: var(--font-weight-medium);
}

.icon-glyph.icon-text {
  font-family: 'Ubuntu', sans-serif;
  font-weight: var(--font-weight-medium);
}

.icon-glyph.icon-svg {
  font-family: inherit;
}

.icon-glyph.icon-svg svg {
  width: 1em;
  height: 1em;
  display: block;
}

.icon-glyph.icon-svg:not(.pink-mode-icon) svg {
  stroke: currentColor;
  fill: none;
}

.favorite-icon.icon-svg svg,
.favorite-star-icon svg {
  fill: currentColor;
  stroke-width: 0;
}

.icon-glyph.icon-svg .pink-mode-icon-image {
  width: 1em;
  height: 1em;
  display: block;
  object-fit: contain;
}

body.pink-mode .pink-mode-icon {
  color: var(--accent-color);
}

@keyframes pink-mode-icon-pop {
  0% {
    transform: scale(0.85);
    opacity: 0.6;
  }
  45% {
    transform: scale(1.15);
    opacity: 1;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.pink-mode-icon-pop {
  animation: pink-mode-icon-pop 420ms ease-out;
  transform-origin: center;
  will-change: transform;
}

.pink-mode-animation-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  overflow: visible;
}

.pink-mode-animation-layer.pink-mode-animation-layer--global {
  position: fixed;
}

.pink-mode-animation-instance {
  position: absolute;
  top: var(--pink-mode-animation-y, 50%);
  left: var(--pink-mode-animation-x, 50%);
  width: var(--pink-mode-animation-size, 72px);
  height: var(--pink-mode-animation-size, 72px);
  margin-top: calc(-0.5 * var(--pink-mode-animation-size, 72px));
  margin-left: calc(-0.5 * var(--pink-mode-animation-size, 72px));
  opacity: 0;
  animation: pink-mode-floating-icon var(--pink-mode-animation-duration, 7s) ease-in-out forwards;
  transform-origin: center;
  will-change: transform, opacity;
  filter: drop-shadow(0 4px 12px rgba(255, 105, 180, 0.25));
  pointer-events: none;
  cursor: default;
  touch-action: none;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  -webkit-user-drag: none;
}

.pink-mode-animation-instance svg {
  width: 100%;
  height: 100%;
  display: block;
}

.pink-mode-animation-instance.pink-mode-icon-rain {
  animation-name: pink-mode-rain-icon;
  animation-duration: var(--pink-mode-rain-duration, 4800ms);
  animation-timing-function: ease-in;
  pointer-events: none;
  cursor: default;
  touch-action: none;
  user-select: none;
  -webkit-user-drag: none;
}

.pink-mode-animation-instance.pink-mode-icon-rain svg {
  transform: scale(var(--pink-mode-rain-scale, 1))
    rotate(var(--pink-mode-rain-rotation, 0deg));
}

@keyframes pink-mode-floating-icon {
  0% {
    opacity: 0;
    transform: translate3d(0, 12%, 0) scale(0.75);
  }

  18% {
    opacity: 0.9;
    transform: translate3d(0, 0, 0) scale(1);
  }

  82% {
    opacity: 0.9;
    transform: translate3d(0, -4%, 0) scale(1.05);
  }

  100% {
    opacity: 0;
    transform: translate3d(0, -14%, 0) scale(0.85);
  }
}

@keyframes pink-mode-rain-icon {
  0% {
    opacity: 0;
    transform: translate3d(0, -18vh, 0)
      scale(var(--pink-mode-rain-scale, 1))
      rotate(var(--pink-mode-rain-rotation, 0deg));
  }

  12% {
    opacity: 1;
    transform: translate3d(0, -2vh, 0)
      scale(var(--pink-mode-rain-scale, 1))
      rotate(var(--pink-mode-rain-rotation, 0deg));
  }

  100% {
    opacity: 0;
    transform: translate3d(var(--pink-mode-rain-drift, 0vw), 112vh, 0)
      scale(var(--pink-mode-rain-scale, 1))
      rotate(var(--pink-mode-rain-rotation, 0deg));
  }
}

@media (prefers-reduced-motion: reduce) {
  .pink-mode-icon-pop {
    animation: none;
  }

  .pink-mode-animation-layer {
    display: none !important;
  }
}

#helpSearchClear .icon-glyph,
.clear-input-btn .icon-glyph,
.controls button .icon-glyph {
  --icon-size: var(--button-icon-size);
}

.help-icon,
.btn-icon,
.legend-icon,
.connector-icon,
.info-icon,
.category-icon,
.scenario-icon,
.icon-box .icon {
  margin-inline-end: var(--icon-gap);
}

button,
.button-link,
.button-link:visited {
  gap: var(--button-icon-gap);
}

button .btn-icon,
.button-link .btn-icon {
  margin-inline-end: 0;
}

.favorite-icon.icon-glyph {
  --icon-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
}

body.pink-mode button:hover,
body.pink-mode button:active,
body.pink-mode button:focus-visible,
body.pink-mode .button-link:hover,
body.pink-mode .button-link:active,
body.pink-mode .help-quick-link.active,
body.pink-mode .favorite-toggle.favorited,
body.pink-mode .favorite-toggle:hover,
body.pink-mode .favorite-toggle:active,
body.pink-mode .favorite-toggle.favorited:hover,
body.pink-mode .favorite-toggle.favorited:active {
  --icon-color: currentColor;
}

.help-icon.icon-glyph,
.btn-icon.icon-glyph,
.legend-icon.icon-glyph,
.connector-icon.icon-glyph,
.info-icon.icon-glyph,
.category-icon.icon-glyph,
.scenario-icon.icon-glyph,
.icon-box .icon.icon-glyph {
  --icon-size: var(--button-icon-size);
}

#hoverHelpTooltip {
  position: absolute;
  z-index: 1000;
  background: var(--surface-color);
  color: var(--text-color);
  border: 1px solid color-mix(in srgb, var(--accent-color) 70%, transparent);
  box-shadow: var(--panel-shadow);
  padding: 4px 8px;
  border-radius: 4px;
  --icon-color: var(--accent-color);
  /* Allow icon glyphs from all local fonts to render inside hover help */
  font-family: var(--font-family), 'EssentialIconsV2', 'FilmIndustryIconsV2', 'GadgetIconsV2';
  font-size: calc(var(--font-size-base) * var(--font-scale-compact));
  pointer-events: none;
  /* Allow longer hover help descriptions */
  max-width: 320px;
  white-space: normal;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

#hoverHelpTooltip[hidden] {
  display: none;
}

#hoverHelpTooltip .hover-help-heading {
  font-weight: 600;
  letter-spacing: 0.01em;
}

#hoverHelpTooltip .hover-help-details {
  line-height: 1.35;
  font-size: calc(var(--font-size-base) * var(--font-scale-compact));
  display: flex;
  flex-direction: column;
  gap: 4px;
}

#hoverHelpTooltip .hover-help-details p {
  margin: 0;
}

#hoverHelpTooltip .hover-help-details ul {
  margin: 0;
  padding-inline-start: 18px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

#hoverHelpTooltip .hover-help-details li {
  margin: 0;
}

#hoverHelpTooltip .hover-help-shortcuts {
  border-top: 1px solid color-mix(in srgb, var(--accent-color) 40%, transparent);
  padding-top: 4px;
  margin-top: 2px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

#hoverHelpTooltip .hover-help-hint {
  border-top: 1px solid color-mix(in srgb, var(--accent-color) 35%, transparent);
  padding-top: 4px;
  margin-top: 2px;
  font-size: calc(var(--font-size-base) * 0.82);
  color: color-mix(in srgb, var(--text-color) 70%, transparent);
}

#hoverHelpTooltip .hover-help-shortcuts-heading {
  font-weight: 600;
  font-size: calc(var(--font-size-base) * var(--font-scale-compact));
  letter-spacing: 0.01em;
}

#hoverHelpTooltip .hover-help-shortcuts-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

#hoverHelpTooltip .hover-help-shortcut {
  background: color-mix(in srgb, var(--accent-color) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-color) 45%, transparent);
  border-radius: 4px;
  padding: 2px 6px;
  font-family: var(--font-family-mono, var(--font-family));
  font-size: calc(var(--font-size-base) * 0.78);
  line-height: 1.2;
  white-space: nowrap;
}

body.dark-mode #hoverHelpTooltip .hover-help-shortcut {
  background: color-mix(in srgb, var(--accent-color) 35%, rgba(0, 0, 0, 0.45));
  border-color: color-mix(in srgb, var(--accent-color) 60%, transparent);
}


body.high-contrast #hoverHelpTooltip .hover-help-shortcut {
  background: color-mix(in srgb, var(--surface-color) 70%, transparent);
  border-color: currentColor;
}

body.high-contrast #hoverHelpTooltip .hover-help-hint {
  color: currentColor;
  border-color: currentColor;
}

.hover-help-highlight {
  outline: 2px solid color-mix(in srgb, var(--accent-color) 75%, transparent);
  outline-offset: 3px;
  border-radius: 6px;
  box-shadow: none !important;
  filter: none !important;
  transition: outline-color 120ms ease;
}

body.dark-mode .hover-help-highlight {
  outline-color: color-mix(in srgb, var(--accent-color) 80%, black 20%);
}

body.high-contrast .hover-help-highlight {
  outline-color: var(--accent-color);
}

/* Force help cursor when hover help is active */
body.hover-help-active,
body.hover-help-active * {
  cursor: help !important;
}

/* Ensure selects and inputs inside wrappers match normal form fields */
.field-with-label select,
.field-with-label input {
  flex: 1;
  margin: 5px 5px 0 0;
}

/* Give wrappers the same margin so favorite stars line up with selects */
.field-with-label .select-wrapper {
  margin: 5px 5px 0 0;
}

/* Remove the default margin from selects inside wrappers */
.field-with-label .select-wrapper select {
  margin: 0;
}

/* Wrapper for selects to allow flexible layout */
.select-wrapper {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0; /* allow wrapper to shrink on narrow screens */
  position: relative;
}

/* Ensure selects fill the available space next to the favorite star */
.select-wrapper select {
  flex: 1;
  width: 100%;
  max-width: 100%;
}

.device-category .list-filter {
  width: 100%;
  margin-bottom: 5px;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

/* Ensure form controls use consistent styling */
input,
select,
textarea {
  padding-block: var(--form-control-padding-block);
  padding-inline: var(--form-control-padding-inline);
  font-size: var(--form-control-font-size);
  line-height: var(--form-control-line-height);
  background-color: var(--control-bg);
  color: var(--control-text);
  border: none;
  border-radius: var(--border-radius);
}

/* Match input and select heights to standard buttons */
input:not([type="checkbox"]) {
  height: var(--button-size);
}

select:not([multiple]) {
  height: var(--select-height);
}

#accentColorInput {
  flex: 0 0 auto;
  width: calc(var(--button-size) * 1.25);
  height: calc(var(--button-size) * 1.25);
  min-width: calc(var(--button-size) * 1.25);
  min-height: calc(var(--button-size) * 1.25);
  max-width: calc(var(--button-size) * 1.25);
  max-height: calc(var(--button-size) * 1.25);
  aspect-ratio: 1 / 1;
  padding: 0;
  border-radius: calc(var(--border-radius) * 1.2);
  box-shadow: 0 0 0 1px var(--panel-border);
  overflow: hidden;
}

#accentColorInput::-webkit-color-swatch-wrapper {
  padding: 0;
}

#accentColorInput::-webkit-color-swatch,
#accentColorInput::-moz-color-swatch {
  border: none;
  border-radius: inherit;
}

input[type="file"] {
  padding: 2px 4px;
  height: auto;
  min-height: var(--button-size);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  line-height: 1.2;
}

.file-input-wrapper {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.file-input-wrapper input[type="file"] {
  width: 100%;
}

.logo-preview {
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 10px;
  background-color: var(--surface-color);
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-preview img {
  max-width: 100%;
  max-height: 120px;
}

input[type="checkbox"] {
  width: 1.1em;
  height: 1.1em;
  min-width: 1.1em;
  max-width: 1.1em;
  padding: 0;
  display: inline-grid;
  place-items: center;
  vertical-align: middle;
  cursor: pointer;
  border: 2px solid var(--control-border);
  border-radius: calc(var(--border-radius) * 0.75);
  background-color: var(--control-bg);
  color: var(--inverse-text-color);
  transition: background-color 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

input[type="checkbox"]::after {
  content: '';
  width: 0.35em;
  height: 0.65em;
  border: solid transparent;
  border-width: 0 0.15em 0.15em 0;
  transform: rotate(45deg) scale(0);
  transform-origin: center;
  opacity: 0;
  transition: transform 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
}

input[type="checkbox"]:hover:not(:disabled) {
  border-color: var(--accent-color);
}

input[type="checkbox"]:focus-visible {
  border-color: var(--accent-color);
}

input[type="checkbox"]:not(:checked):hover:not(:disabled) {
  background-color: var(--control-hover-bg);
}

input[type="checkbox"]:checked {
  background-color: var(--control-bg);
  border-color: var(--accent-color);
}

input[type="checkbox"]:checked::after {
  border-color: var(--accent-color);
  opacity: 1;
  transform: rotate(45deg) scale(1);
}

input[type="checkbox"]:checked:hover:not(:disabled) {
  background-color: var(--control-bg);
}

@supports (color: color-mix(in srgb, #000 50%, white)) {
  input[type="checkbox"]:hover:not(:disabled),
  input[type="checkbox"]:focus-visible {
    box-shadow: none;
  }

  input[type="checkbox"]:not(:checked):hover:not(:disabled) {
    background-color: color-mix(in srgb, var(--accent-color) 12%, var(--control-bg));
  }

  input[type="checkbox"]:checked {
    background-color: var(--control-bg);
  }

  input[type="checkbox"]:checked:hover:not(:disabled) {
    background-color: var(--control-bg);
  }

  input[type="checkbox"]:checked::after {
    border-color: var(--accent-color);
  }
}

input[type="checkbox"]:disabled {
  cursor: not-allowed;
  background-color: var(--control-disabled-bg);
  border-color: var(--control-border);
  color: var(--control-text);
  box-shadow: none;
}

input[type="checkbox"]:disabled::after {
  border-color: transparent;
  opacity: 0;
  transform: rotate(45deg) scale(0);
}

input[type="checkbox"]:disabled:checked {
  background-color: var(--control-disabled-bg);
  border-color: var(--control-border);
}

input[type="checkbox"]:disabled:checked::after {
  border-color: var(--control-text);
  opacity: 1;
  transform: rotate(45deg) scale(1);
}

select {
  background-image: none;
  -webkit-appearance: none;
  appearance: none;
}

/* Ensure multi-select lists remain legible across themes, including dark mode on mobile */
select[multiple] {
  background-color: var(--control-bg);
  color: var(--control-text);
  -webkit-text-fill-color: var(--control-text);
}

select[multiple] option {
  background-color: var(--control-bg);
  color: var(--control-text);
}

select[multiple] option:hover {
  background-color: var(--control-hover-bg);
}

select[multiple] option:checked {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
}

@supports (color: color-mix(in srgb, #000 50%, white)) {
  body.light-mode:not(.high-contrast) #projectDialog select[multiple] option:checked {
    background-color: color-mix(in srgb, var(--accent-color) 35%, white);
    color: var(--accent-color);
  }
}

html.high-contrast select[multiple] option:checked,
body.high-contrast select[multiple] option:checked {
  color: #000;
}

input:hover,
select:hover,
textarea:hover {
  background-color: var(--control-hover-bg);
}

input:active,
select:active,
textarea:active {
  background-color: var(--control-active-bg);
}

input:disabled,
select:disabled,
textarea:disabled {
  background-color: var(--control-disabled-bg);
  cursor: not-allowed;
}

.clear-input-btn {
  margin-left: 4px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: var(--font-size-relative-base);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--button-size);
  height: var(--button-size);
  padding: 0;
  line-height: 1;
  border-radius: var(--border-radius);
  color: inherit;
  --button-bg: transparent;
  --button-border: transparent;
  --button-shadow: none;
  --button-hover-shadow: none;
  --button-hover-factor: 1;
  --button-active-factor: 1;
}

.clear-input-btn:hover {
  color: var(--accent-color);
}

.favorite-toggle {
  margin: 0 0 0 4px;
  padding: 0;
  width: var(--button-size);
  height: var(--button-size);
  background-color: var(--control-bg);
  border-radius: var(--border-radius);
  border: none;
  outline: none;
  cursor: pointer;
  font-size: var(--font-size-base);
  color: var(--favorite-inactive-color);
  --icon-color: currentColor;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
  --button-bg: var(--control-bg);
  --button-border: transparent;
  --button-shadow: none;
  --button-hover-shadow: none;
  --button-hover-factor: 1;
  --button-active-factor: 1;
}

.favorite-toggle:focus-visible {
  outline: none;
}
.favorite-toggle:disabled {
  background-color: var(--control-bg);
  color: var(--muted-text-color);
  cursor: not-allowed;
  opacity: 0.7;
}
.favorite-toggle:hover {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
  transform: translateY(-2px);
}
.favorite-toggle:active {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
  filter: brightness(0.9);
  transform: translateY(0);
}
.favorite-toggle.favorited {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
}
.favorite-toggle.favorited:hover,
.favorite-toggle.favorited:active {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
}

.onboarding-overlay {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  pointer-events: none;
  border: none;
  box-shadow: none;
  background: transparent;
  padding: 0;
  margin: 0;
  color: inherit;
  outline: none;
}

.onboarding-overlay[open] {
  display: block;
}

.onboarding-overlay.active {
  display: block;
}

.onboarding-overlay::backdrop {
  background: transparent;
}

.onboarding-overlay--anchored {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.onboarding-highlight {
  position: absolute;
  border-radius: 16px;
  border: 1px solid var(--onboarding-highlight-border);
  background: var(--onboarding-highlight-fill);
  transition:
    transform 0.2s ease,
    width 0.2s ease,
    height 0.2s ease,
    opacity 0.2s ease,
    border-color 0.2s ease,
    background-color 0.2s ease;
  pointer-events: none;
  opacity: 0;
}

@supports not (color-mix(in srgb, black 50%, white 50%)) {
  .onboarding-highlight {
    border-width: 1px;
    border-color: var(--accent-color);
    background: transparent;
  }
}

.onboarding-overlay.onboarding-scroll-active .onboarding-highlight {
  transition: none;
}

.onboarding-card {
  position: absolute;
  --onboarding-card-border: color-mix(in srgb, var(--accent-color) 35%, transparent);
  --onboarding-card-padding: clamp(1rem, 0.75rem + 1vw, 1.25rem);
  --onboarding-card-max-height-factor: 0.8;
  --onboarding-card-viewport-offset: 3rem;
  width: min(26rem, calc(100vw - 3rem));
  inline-size: min(26rem, calc(100vw - 3rem));
  min-height: auto;
  min-block-size: auto;
  padding: var(--onboarding-card-padding);
  border-radius: 16px;
  background: var(--surface-color);
  color: var(--text-color);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
  pointer-events: auto;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  border: 1px solid var(--onboarding-card-border);
  max-height: min(
    calc(var(--onboarding-card-max-height-factor) * 100vh),
    calc(100vh - var(--onboarding-card-viewport-offset))
  );
  max-block-size: min(
    calc(var(--onboarding-card-max-height-factor) * 100vh),
    calc(100vh - var(--onboarding-card-viewport-offset))
  );
  overflow: visible;
  overscroll-behavior: contain;
  scrollbar-gutter: stable both-edges;
  transition: transform 0.2s ease, opacity 0.2s ease;
  isolation: isolate;
}

@supports (height: 1dvh) {
  .onboarding-card {
    max-height: min(
      calc(var(--onboarding-card-max-height-factor) * 100dvh),
      calc(100dvh - var(--onboarding-card-viewport-offset))
    );
    max-block-size: min(
      calc(var(--onboarding-card-max-height-factor) * 100dvh),
      calc(100dvh - var(--onboarding-card-viewport-offset))
    );
  }
}

.onboarding-card-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable both-edges;
  padding-inline-end: 0.125rem;
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
  .onboarding-card-content {
    scroll-behavior: auto;
  }
}

.onboarding-card::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  background: inherit;
  border: 1px solid var(--onboarding-card-border);
  transform: rotate(45deg);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.22);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: -1;
}

.onboarding-card[data-size='large'] {
  width: min(38rem, calc(100vw - 2rem));
  inline-size: min(38rem, calc(100vw - 2rem));
  --onboarding-card-padding: clamp(1.25rem, 1rem + 1.5vw, 1.75rem);
  gap: clamp(1.1rem, 0.9rem + 1vw, 1.6rem);
}

.onboarding-card[data-size='hero'] {
  --onboarding-card-hero-margin: 1.5rem;
  --onboarding-card-hero-available: calc(
    100vw - (var(--onboarding-card-hero-margin) * 2)
  );
  --onboarding-card-hero-inline: var(
    --onboarding-card-hero-inline-size,
    var(--onboarding-card-hero-available)
  );
  width: min(100%, var(--onboarding-card-hero-inline));
  inline-size: min(100%, var(--onboarding-card-hero-inline));
  max-width: min(100%, var(--onboarding-card-hero-inline));
  max-inline-size: min(100%, var(--onboarding-card-hero-inline));
  --onboarding-card-padding: clamp(1.5rem, 1.15rem + 2vw, 2.25rem);
  gap: clamp(1.35rem, 1.1rem + 1.5vw, 2rem);
  --onboarding-hero-heading-fluid-adjust: clamp(
    0px,
    2.1vw,
    calc(var(--font-size-relative-base) * var(--font-scale-lg))
  );
}

@supports (width: calc(100dvw - 1px)) {
  .onboarding-card[data-size='hero'] {
    --onboarding-card-hero-available: calc(
      100dvw - (var(--onboarding-card-hero-margin) * 2)
    );
  }
}

.onboarding-interaction--hero {
  gap: clamp(1.25rem, 1rem + 1vw, 1.75rem);
}

.onboarding-hero {
  display: grid;
  gap: clamp(1.5rem, 1.2rem + 1vw, 2.15rem);
  position: relative;
  width: 100%;
  max-width: 100%;
  margin-inline: auto;
}

.onboarding-hero-banner,
.onboarding-hero-highlights,
.onboarding-hero-language {
  min-width: 0;
}

.onboarding-hero-banner {
  display: grid;
  gap: clamp(1.15rem, 0.9rem + 0.9vw, 1.8rem);
  padding: clamp(1.4rem, 1.1rem + 1.2vw, 2.1rem);
  border-radius: clamp(1.4rem, 1.1rem + 1vw, 1.85rem);
  background: color-mix(in srgb, var(--panel-bg) 96%, transparent);
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, transparent);
  box-shadow: none;
  position: relative;
  width: 100%;
}

.onboarding-hero-banner::before,
.onboarding-hero-banner::after {
  content: none;
}

body.dark-mode .onboarding-hero-banner {
  background: color-mix(in srgb, var(--panel-bg) 92%, transparent);
  border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
  box-shadow: none;
}

.onboarding-hero-header {
  display: grid;
  gap: clamp(0.7rem, 0.55rem + 0.6vw, 1.1rem);
}

.onboarding-hero-heading {
  margin: 0;
  font-size: clamp(
    calc(var(--font-size-relative-base) * var(--font-scale-xxl)),
    calc(
      var(--font-size-relative-base) * var(--font-scale-display)
        + var(--onboarding-hero-heading-fluid-adjust, 0px)
    ),
    calc(var(--font-size-relative-base) * var(--font-scale-xxxl))
  );
  line-height: clamp(1.05, 1.02 + 0.03vw, 1.1);
  font-weight: var(--font-weight-extrabold, 800);
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text-color) 95%, rgba(0, 0, 0, 0.05));
}

body.dark-mode .onboarding-hero-heading {
  color: color-mix(in srgb, var(--inverse-text-color) 95%, rgba(255, 255, 255, 0.05));
}

.onboarding-hero-subheading {
  margin: 0;
  font-size: clamp(
    calc(var(--font-size-relative-base, 1em) * 1.1),
    calc(var(--font-size-relative-base, 1em) * 0.95 + 0.65vw),
    calc(var(--font-size-relative-base, 1em) * 1.5)
  );
  font-weight: var(--font-weight-semibold);
  color: color-mix(in srgb, var(--text-color) 88%, rgba(0, 0, 0, 0.25));
  letter-spacing: 0.02em;
}

body.dark-mode .onboarding-hero-subheading {
  color: color-mix(in srgb, var(--inverse-text-color) 90%, rgba(255, 255, 255, 0.2));
}

.onboarding-hero-summary {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: var(--line-height-relaxed);
  color: color-mix(in srgb, var(--text-color) 88%, rgba(0, 0, 0, 0.32));
}

body.dark-mode .onboarding-hero-summary {
  color: color-mix(in srgb, var(--inverse-text-color) 84%, rgba(255, 255, 255, 0.35));
}

body.dark-mode.pink-mode .onboarding-hero-heading {
  color: color-mix(in srgb, var(--accent-color) 92%, var(--inverse-text-color) 8%);
}

body.dark-mode.pink-mode .onboarding-hero-subheading,
body.dark-mode.pink-mode .onboarding-hero-highlight-title,
body.dark-mode.pink-mode .onboarding-hero-highlight-badge-label,
body.dark-mode.pink-mode .onboarding-hero-language-label {
  color: color-mix(in srgb, var(--accent-color) 85%, var(--inverse-text-color) 15%);
}

.onboarding-hero-highlight--badge {
  align-items: center;
}

.onboarding-hero-highlight-icon--badge {
  font-size: calc(var(--font-size-relative-base, 1em) * 1.8);
  line-height: 1;
  color: color-mix(in srgb, var(--accent-color) 82%, var(--text-color) 18%);
}

body.dark-mode .onboarding-hero-highlight-icon--badge {
  color: color-mix(in srgb, var(--accent-color) 85%, var(--inverse-text-color) 15%);
}

.onboarding-hero-highlight-text--badge {
  display: grid;
  gap: 0.25rem;
}

.onboarding-hero-highlight-badge-label {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
  font-weight: var(--font-weight-semibold);
  color: inherit;
}

.onboarding-hero-highlight-badge-description {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: color-mix(in srgb, var(--text-color) 72%, rgba(0, 0, 0, 0.4));
}

body.dark-mode .onboarding-hero-highlight-badge-description {
  color: color-mix(in srgb, var(--inverse-text-color) 72%, rgba(255, 255, 255, 0.38));
}

.onboarding-hero-highlights {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: clamp(1.05rem, 0.9rem + 0.9vw, 1.6rem);
  grid-template-columns: minmax(0, 1fr);
}

.onboarding-hero-highlight:first-child:not(.onboarding-hero-highlight--badge),
.onboarding-hero-highlight--badge + .onboarding-hero-highlight {
  grid-column: auto;
}

.onboarding-hero-highlight {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(0.8rem, 0.65rem + 0.6vw, 1rem);
  align-items: start;
  padding: clamp(0.95rem, 0.75rem + 0.75vw, 1.35rem);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel-bg) 96%, transparent);
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, transparent);
  box-shadow: none;
}

body.dark-mode .onboarding-hero-highlight {
  background: color-mix(in srgb, var(--panel-bg) 92%, transparent);
  border-color: color-mix(in srgb, var(--panel-border) 65%, transparent);
  box-shadow: none;
}

.onboarding-hero-highlight-icon {
  font-size: calc(var(--font-size-relative-base, 1em) * 1.6);
  line-height: 1;
  color: color-mix(in srgb, var(--accent-color) 78%, var(--text-color) 22%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.dark-mode .onboarding-hero-highlight-icon {
  color: color-mix(in srgb, var(--accent-color) 82%, var(--inverse-text-color) 18%);
}

.onboarding-hero-highlight-text {
  display: grid;
  gap: 0.35rem;
}

.onboarding-hero-highlight-title {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-md));
  font-weight: var(--font-weight-semibold);
}

.onboarding-hero-highlight-body {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: color-mix(in srgb, var(--text-color) 82%, rgba(0, 0, 0, 0.35));
}

body.dark-mode .onboarding-hero-highlight-body {
  color: color-mix(in srgb, var(--inverse-text-color) 80%, rgba(255, 255, 255, 0.35));
}

.onboarding-hero-language {
  display: grid;
  gap: clamp(0.55rem, 0.45rem + 0.4vw, 0.9rem);
  width: 100%;
}

.onboarding-hero-language-label {
  font-weight: var(--font-weight-light);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--onboarding-label-color);
}

.onboarding-hero-language-select {
  width: 100%;
  max-width: 100%;
  font-family: inherit;
  font-weight: var(--font-weight-light);
}

.onboarding-hero-language-hint {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: var(--onboarding-hint-color);
}

.onboarding-hero-offline {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  line-height: var(--line-height-relaxed);
  color: var(--onboarding-subtext-color);
}

@media (max-width: 48rem) {
  .onboarding-card {
    --onboarding-card-viewport-offset: calc(3.5rem + env(safe-area-inset-bottom, 0px));
  }

  .onboarding-card[data-size='hero'] {
    --onboarding-card-hero-margin: 1.15rem;
    --onboarding-card-hero-inline: min(32rem, calc(100vw - 3rem));
    width: min(100%, var(--onboarding-card-hero-inline));
    inline-size: min(100%, var(--onboarding-card-hero-inline));
    max-width: min(100%, var(--onboarding-card-hero-inline));
    max-inline-size: min(100%, var(--onboarding-card-hero-inline));
    margin-inline: auto;
    --onboarding-card-padding: clamp(1.1rem, 0.85rem + 2vw, 1.65rem);
    gap: clamp(1.05rem, 0.85rem + 1.4vw, 1.6rem);
  }

  .onboarding-hero {
    gap: clamp(1.15rem, 0.95rem + 1.1vw, 1.75rem);
  }

  .onboarding-hero-banner {
    padding: clamp(1.05rem, 0.85rem + 2.5vw, 1.6rem);
    border-radius: clamp(1rem, 0.85rem + 1vw, 1.4rem);
  }

  .onboarding-hero-heading {
    font-size: clamp(
      calc(var(--font-size-relative-base) * var(--font-scale-xl)),
      calc(var(--font-size-relative-base) * var(--font-scale-xxl)),
      calc(var(--font-size-relative-base) * var(--font-scale-xxl))
    );
  }

  .onboarding-hero-subheading {
    font-size: clamp(
      calc(var(--font-size-relative-base, 1em) * 1.05),
      calc(var(--font-size-relative-base, 1em) * 0.95 + 0.45vw),
      calc(var(--font-size-relative-base, 1em) * 1.3)
    );
  }

  .onboarding-hero-highlights {
    grid-template-columns: minmax(0, 1fr);
    gap: clamp(0.9rem, 0.75rem + 1vw, 1.35rem);
  }

  .onboarding-hero-highlight {
    padding: clamp(0.85rem, 0.7rem + 0.8vw, 1.15rem);
  }

  .onboarding-hero-highlight-icon {
    font-size: calc(var(--font-size-relative-base, 1em) * 1.4);
  }

  .onboarding-hero-language-select {
    max-width: 100%;
  }

  .onboarding-hero-language-hint,
  .onboarding-hero-offline {
    font-size: calc(var(--font-size-relative-base) * var(--font-scale-2xs));
  }

  .onboarding-overlay[data-step-list='visible'] {
    --onboarding-step-list-max-height: clamp(9rem, 34vh, 11rem);
  }

  .onboarding-overlay[data-step-list='visible'] .onboarding-step-list-container {
    left: calc(var(--onboarding-card-padding) * 0.65);
    right: calc(var(--onboarding-card-padding) * 0.65);
  }
}

@media (max-width: 32rem) {
  .onboarding-card {
    border-radius: 14px;
    --onboarding-card-max-height-factor: 0.88;
    --onboarding-card-viewport-offset: calc(1.25rem + env(safe-area-inset-bottom, 0px));
  }

  .onboarding-card-content {
    padding-inline-end: 0;
  }

  .onboarding-card-actions {
    flex-direction: column;
    align-items: stretch;
    gap: clamp(0.6rem, 0.45rem + 1vw, 0.85rem);
  }

  .onboarding-card-actions button {
    min-width: unset;
    width: 100%;
  }

  .onboarding-skip {
    padding-inline: 0;
    text-align: center;
    font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  }

  .onboarding-hero-heading {
    letter-spacing: -0.005em;
  }

  .onboarding-hero-highlight {
    grid-template-columns: minmax(0, 1fr);
  }

  .onboarding-hero-highlight-icon {
    justify-content: flex-start;
  }

  .onboarding-hero-highlight-text {
    gap: 0.25rem;
  }

  .onboarding-overlay[data-step-list='visible'] {
    --onboarding-step-list-padding: clamp(0.45rem, 0.35rem + 0.6vw, 0.65rem);
    --onboarding-step-list-max-height: clamp(8rem, 32vh, 10rem);
  }

  .onboarding-overlay[data-step-list='visible'] .onboarding-step-list {
    gap: clamp(0.45rem, 0.35rem + 0.6vw, 0.65rem);
  }
}

@media (max-width: 26rem) {
  .onboarding-card {
    width: min(100%, calc(100vw - 1rem));
    inline-size: min(100%, calc(100vw - 1rem));
  }

  .onboarding-card[data-size='hero'] {
    --onboarding-card-hero-margin: 0.75rem;
    --onboarding-card-padding: clamp(0.9rem, 0.75rem + 2vw, 1.35rem);
    gap: clamp(0.85rem, 0.7rem + 1vw, 1.2rem);
  }

  .onboarding-hero {
    gap: clamp(0.95rem, 0.8rem + 1vw, 1.35rem);
  }

  .onboarding-hero-heading {
    font-size: clamp(
      calc(var(--font-size-relative-base) * var(--font-scale-lg)),
      calc(var(--font-size-relative-base) * var(--font-scale-xl)),
      calc(var(--font-size-relative-base) * var(--font-scale-xl))
    );
    line-height: 1.1;
  }

  .onboarding-hero-subheading {
    font-size: clamp(
      calc(var(--font-size-relative-base, 1em) * 0.95),
      calc(var(--font-size-relative-base, 1em) * 0.85 + 0.4vw),
      calc(var(--font-size-relative-base, 1em) * 1.15)
    );
  }

  .onboarding-hero-language-hint,
  .onboarding-hero-offline {
    line-height: 1.4;
  }

  .onboarding-overlay[data-step-list='visible'] {
    --onboarding-step-button-min-height: 3rem;
  }
}

@media (min-width: 54rem) {
  .onboarding-hero {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
  }

  .onboarding-hero-language {
    align-self: start;
    justify-self: stretch;
    grid-column: 1 / -1;
    display: grid;
    gap: clamp(0.6rem, 0.5rem + 0.45vw, 0.95rem);
  }

  .onboarding-hero-language-select {
    max-width: 100%;
  }

  .onboarding-hero-offline {
    grid-column: 1 / -1;
  }
}

@media (min-width: 50rem) {
  .onboarding-hero-banner {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
  }
}

body.dark-mode .onboarding-card {
  --onboarding-card-border: color-mix(in srgb, var(--accent-color) 55%, rgba(255, 255, 255, 0.16));
  background: rgba(18, 22, 28, 0.95);
  color: var(--inverse-text-color);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.55);
}

.onboarding-card[data-placement^='top']::after,
.onboarding-card[data-placement$='-top']::after {
  bottom: -7px;
  left: clamp(1.5rem, 50%, calc(100% - 1.5rem));
  opacity: 1;
}

.onboarding-card[data-placement^='bottom']::after,
.onboarding-card[data-placement$='-bottom']::after {
  top: -7px;
  left: clamp(1.5rem, 50%, calc(100% - 1.5rem));
  opacity: 1;
}

.onboarding-card[data-placement^='left']::after,
.onboarding-card[data-placement$='-left']::after {
  right: -7px;
  top: clamp(1.5rem, 50%, calc(100% - 1.5rem));
  opacity: 1;
}

.onboarding-card[data-placement^='right']::after,
.onboarding-card[data-placement$='-right']::after {
  left: -7px;
  top: clamp(1.5rem, 50%, calc(100% - 1.5rem));
  opacity: 1;
}

.onboarding-card[data-placement='floating']::after {
  opacity: 0;
}

.onboarding-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.onboarding-progress {
  margin: 0;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.01em;
  flex: 1 1 auto;
}

.onboarding-progress-meter {
  flex: 1 0 100%;
  margin-top: 0.1rem;
  margin-bottom: 0;
  position: relative;
  height: 0.4rem;
  border-radius: 999px;
}

.onboarding-progress-track {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: color-mix(in srgb, var(--surface-color) 78%, rgba(0, 0, 0, 0.18) 22%);
  overflow: hidden;
}

.onboarding-progress-fill {
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: color-mix(in srgb, var(--accent-color) 85%, rgba(255, 255, 255, 0.12) 15%);
  transition: width 0.25s ease;
}

body.dark-mode .onboarding-progress-track {
  background: rgba(255, 255, 255, 0.12);
}

body.dark-mode .onboarding-progress-fill {
  background: color-mix(in srgb, var(--accent-color) 88%, rgba(255, 255, 255, 0.25) 12%);
}

.onboarding-card h2 {
  margin: 0;
  color: inherit;
  border: none;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
}

.onboarding-card p {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: var(--line-height-relaxed);
}

.onboarding-resume-hint {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  color: color-mix(in srgb, var(--text-color) 70%, rgba(0, 0, 0, 0.45));
}

.onboarding-interaction {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

.onboarding-field-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.onboarding-avatar-group {
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 0.5rem + 1vw, 1.25rem);
  flex-wrap: wrap;
}

.onboarding-avatar-preview {
  width: clamp(64px, 4vw + 56px, 88px);
  height: clamp(64px, 4vw + 56px, 88px);
  border-radius: 999px;
  overflow: hidden;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--panel-border) 75%, transparent);
}

.onboarding-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.onboarding-avatar-preview .contact-card-avatar-initial {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: clamp(1.35rem, 1.1rem + 0.8vw, 1.75rem);
}

.onboarding-avatar-button {
  flex: 1 1 180px;
  min-width: 180px;
}

.onboarding-field-label {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.01em;
  color: var(--onboarding-label-color);
}

.onboarding-active-target {
  position: relative;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-color) 28%, transparent);
  border-radius: 14px;
  transition: box-shadow 0.2s ease;
}

@supports not (color-mix(in srgb, black 50%, white 50%)) {
  .onboarding-active-target {
    box-shadow: 0 0 0 3px var(--accent-color);
  }
}

body.dark-mode .onboarding-active-target {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-color) 36%, rgba(0, 0, 0, 0.35));
}

.onboarding-field-input {
  width: calc(100% - var(--spacing-md));
  max-width: calc(100% - var(--spacing-md));
  margin-inline: auto;
}

.onboarding-field-select {
  width: calc(100% - var(--spacing-md));
  max-width: calc(100% - var(--spacing-md));
  margin-inline: auto;
}

.onboarding-interaction-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

.onboarding-interaction-button {
  flex: 1 1 220px;
  text-align: center;
}

.onboarding-resume-hint {
  margin: 0;
  padding: 0.625rem 0.875rem;
  border-radius: 12px;
  background: color-mix(in srgb, var(--accent-color) 12%, transparent);
  border: none;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  line-height: var(--line-height-snug);
  font-weight: var(--font-weight-medium);
  color: inherit;
}

body.dark-mode .onboarding-resume-hint {
  background: color-mix(in srgb, var(--accent-color) 28%, transparent);
  border: none;
  color: var(--inverse-text-color);
}

@keyframes onboarding-storage-pulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.95;
  }
  50% {
    transform: scale(1.25);
    opacity: 0.55;
  }
}

.onboarding-storage-status {
  margin: 0.75rem 0 0;
  padding: 0.75rem 1rem;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--panel-border, rgba(0, 0, 0, 0.15)) 85%, transparent);
  background: color-mix(in srgb, var(--surface-color) 92%, rgba(0, 0, 0, 0.02) 8%);
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  line-height: var(--line-height-snug);
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.onboarding-storage-status[data-state='checking'],
.onboarding-storage-status[data-state='requesting'],
.onboarding-storage-status[data-state='idle'] {
  border-color: color-mix(in srgb, var(--accent-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 88%, var(--accent-color) 12%);
  color: color-mix(in srgb, var(--accent-color) 45%, var(--text-color) 55%);
}

.onboarding-storage-status[data-state='granted'] {
  border-color: color-mix(in srgb, var(--success-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 82%, var(--success-color) 18%);
  color: color-mix(in srgb, var(--success-color) 60%, var(--text-color) 40%);
}

.onboarding-storage-status[data-state='denied'],
.onboarding-storage-status[data-state='error'],
.onboarding-storage-status[data-state='unsupported'] {
  border-color: color-mix(in srgb, var(--danger-color) 55%, transparent);
  background: color-mix(in srgb, var(--surface-color) 80%, var(--danger-color) 20%);
  color: color-mix(in srgb, var(--danger-color) 62%, var(--text-color) 38%);
}

.onboarding-storage-status[data-empty='true'] {
  opacity: 0.85;
}

.onboarding-storage-icon {
  width: 0.9rem;
  height: 0.9rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent-color) 75%, rgba(255, 255, 255, 0.4) 25%);
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--surface-color) 70%, transparent);
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.onboarding-storage-status[data-state='granted'] .onboarding-storage-icon {
  background: color-mix(in srgb, var(--success-color) 78%, rgba(255, 255, 255, 0.3) 22%);
}

.onboarding-storage-status[data-state='denied'] .onboarding-storage-icon,
.onboarding-storage-status[data-state='error'] .onboarding-storage-icon,
.onboarding-storage-status[data-state='unsupported'] .onboarding-storage-icon {
  background: color-mix(in srgb, var(--danger-color) 78%, rgba(255, 255, 255, 0.28) 22%);
}

.onboarding-storage-status[data-state='checking'] .onboarding-storage-icon,
.onboarding-storage-status[data-state='requesting'] .onboarding-storage-icon {
  animation: onboarding-storage-pulse 1.4s ease-in-out infinite;
}

.onboarding-storage-text {
  flex: 1 1 auto;
}

body.dark-mode .onboarding-storage-status {
  border-color: color-mix(in srgb, var(--panel-border, rgba(255, 255, 255, 0.2)) 70%, transparent);
  background: color-mix(in srgb, var(--surface-color) 82%, rgba(255, 255, 255, 0.08) 18%);
  color: var(--inverse-text-color);
}

body.dark-mode .onboarding-storage-status[data-state='checking'],
body.dark-mode .onboarding-storage-status[data-state='requesting'],
body.dark-mode .onboarding-storage-status[data-state='idle'] {
  background: color-mix(in srgb, var(--surface-color) 74%, var(--accent-color) 26%);
  color: color-mix(in srgb, var(--accent-color) 48%, var(--inverse-text-color) 52%);
}

body.dark-mode .onboarding-storage-status[data-state='granted'] {
  background: color-mix(in srgb, var(--surface-color) 68%, var(--success-color) 32%);
  color: color-mix(in srgb, var(--success-color) 40%, var(--inverse-text-color) 60%);
}

body.dark-mode .onboarding-storage-status[data-state='denied'],
body.dark-mode .onboarding-storage-status[data-state='error'],
body.dark-mode .onboarding-storage-status[data-state='unsupported'] {
  background: color-mix(in srgb, var(--surface-color) 68%, var(--danger-color) 32%);
  color: color-mix(in srgb, var(--danger-color) 48%, var(--inverse-text-color) 52%);
}

body.dark-mode .onboarding-storage-icon {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, rgba(0, 0, 0, 0.35) 65%, transparent);
}

.onboarding-step-list-container {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.onboarding-step-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.onboarding-overlay[data-step-list='visible'] {
  --onboarding-step-list-max-height: clamp(10rem, 24vh, 14rem);
  --onboarding-step-list-padding: clamp(0.6rem, 0.45rem + 0.5vw, 0.9rem);
}

.onboarding-overlay[data-step-list='visible'] .onboarding-card {
  padding-bottom: calc(
    var(--onboarding-card-padding)
    + var(--onboarding-step-list-max-height)
    + (var(--onboarding-step-list-padding) * 2)
  );
}

.onboarding-overlay[data-step-list='visible'] .onboarding-step-list-container {
  position: absolute;
  left: var(--onboarding-card-padding);
  right: var(--onboarding-card-padding);
  bottom: var(--onboarding-card-padding);
  width: auto;
  height: auto;
  margin: 0;
  clip: auto;
  white-space: normal;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--text-color) 16%, transparent);
  --onboarding-step-list-surface: color-mix(
    in srgb,
    var(--surface-color) 88%,
    rgba(255, 255, 255, 0.12) 12%
  );
  background: var(--onboarding-step-list-surface);
  box-shadow: inset 0 1px 2px rgba(15, 18, 24, 0.08);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.onboarding-overlay[data-step-list='visible'] .onboarding-step-list {
  display: flex;
  flex-direction: column;
  --onboarding-step-list-gap: 0.5rem;
  --onboarding-step-button-min-height: 3.4rem;
  gap: var(--onboarding-step-list-gap);
  padding: var(--onboarding-step-list-padding);
  max-height: var(--onboarding-step-list-max-height);
  overflow-y: auto;
  scrollbar-gutter: stable both-edges;
}

body.dark-mode .onboarding-overlay[data-step-list='visible'] .onboarding-step-list-container {
  border-color: color-mix(in srgb, var(--inverse-text-color) 22%, transparent);
  --onboarding-step-list-surface: color-mix(
    in srgb,
    rgba(18, 22, 28, 0.95) 92%,
    rgba(255, 255, 255, 0.08) 8%
  );
  background: var(--onboarding-step-list-surface);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.35);
}

.onboarding-step-item {
  position: relative;
  display: block;
  flex: 0 0 auto;
  min-width: 100%;
}

.onboarding-overlay[data-step-list='visible'] .onboarding-step-item--pinned {
  position: sticky;
  top: calc(
    var(--onboarding-step-list-padding)
      + var(--onboarding-step-pinned-index, 0)
        * (
          var(--onboarding-step-button-min-height)
          + (var(--onboarding-step-list-gap) * 1.15)
        )
  );
  z-index: 1;
}

.onboarding-overlay[data-step-list='visible'] .onboarding-step-item--pinned::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 12px 12px 10px 10px;
  background: var(--onboarding-step-list-surface);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--text-color) 12%, transparent);
  pointer-events: none;
  z-index: -1;
}

body.dark-mode
  .onboarding-overlay[data-step-list='visible']
  .onboarding-step-item--pinned::before {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--inverse-text-color) 18%, transparent);
}

.onboarding-step-button {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.35rem;
  width: 100%;
  --onboarding-step-button-min-height: 3.4rem;
  min-height: var(--onboarding-step-button-min-height);
  padding: var(--button-padding-block) var(--button-padding-inline);
  text-align: left;
  line-height: var(--line-height-snug);
  --button-border-width: 1px;
  --button-border: var(--button-default-border);
  --button-shadow: var(--panel-shadow);
  --button-hover-shadow: var(--panel-shadow-hover);
}

.onboarding-step-button[disabled] {
  cursor: default;
}

.onboarding-step-title {
  font-weight: var(--font-weight-medium);
  flex: 1 1 auto;
}

.onboarding-step-status {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  font-weight: var(--font-weight-medium);
  opacity: 0.85;
  white-space: nowrap;
  align-self: flex-start;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel-border) 55%, transparent);
}

.onboarding-step-item[data-status='current'] .onboarding-step-button {
  --button-bg: var(--button-primary-bg);
  --button-text: var(--inverse-text-color);
  --button-border: var(--button-primary-border);
  --button-shadow: var(--panel-shadow-hover);
}

.onboarding-step-item[data-status='complete'] .onboarding-step-button {
  --button-bg: color-mix(in srgb, var(--button-primary-bg) 22%, var(--button-default-bg));
  --button-border: color-mix(in srgb, var(--button-primary-border) 50%, transparent);
}

.onboarding-step-item[data-status='complete'] .onboarding-step-status {
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.onboarding-step-item[data-status='upcoming'] .onboarding-step-button {
  --button-border: color-mix(in srgb, var(--button-default-border) 55%, transparent);
  --button-shadow: none;
}

@media (max-width: 52rem) {
  .onboarding-overlay[data-step-list='visible'] {
    --onboarding-step-list-max-height: clamp(8.5rem, 38vh, 11.5rem);
  }

  .onboarding-overlay[data-step-list='visible'] .onboarding-step-list-container {
    left: calc(var(--onboarding-card-padding) * 0.75);
    right: calc(var(--onboarding-card-padding) * 0.75);
  }
}

.onboarding-step-item[data-status='upcoming'] .onboarding-step-button[disabled] {
  --button-text: color-mix(in srgb, var(--button-default-text) 65%, transparent);
}

body.dark-mode.pink-mode .onboarding-step-title,
body.dark-mode.pink-mode .onboarding-step-status {
  color: color-mix(in srgb, var(--accent-color) 85%, var(--inverse-text-color) 15%);
}

body:not(.dark-mode) .onboarding-hero-heading {
  color: color-mix(in srgb, var(--accent-color) 88%, var(--text-color) 12%);
}

body:not(.dark-mode) .onboarding-hero-subheading,
body:not(.dark-mode) .onboarding-hero-highlight-title,
body:not(.dark-mode) .onboarding-hero-highlight-badge-label,
body:not(.dark-mode) .onboarding-hero-language-label,
body:not(.dark-mode) .onboarding-step-title,
body:not(.dark-mode) .onboarding-step-status {
  color: color-mix(in srgb, var(--accent-color) 80%, var(--text-color) 20%);
}

.onboarding-card-actions {
  display: flex;
  gap: var(--spacing-md);
  justify-content: flex-end;
  flex-wrap: wrap;
}

.onboarding-card-actions button,
.onboarding-interaction-button,
.onboarding-step-button,
.onboarding-skip {
  margin: 0;
}

.onboarding-card-actions button {
  min-width: 130px;
}

.onboarding-card[data-step-key='intro'] .onboarding-back-button {
  display: none;
}

.onboarding-skip--intro {
  flex: 0 0 auto;
  min-width: auto;
  padding-inline: 0;
  align-self: center;
}

.onboarding-skip {
  padding-inline: var(--spacing-md);
  white-space: nowrap;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-regular);
}

@media (max-width: 640px) {
  .onboarding-card {
    max-width: calc(100vw - 1.5rem);
    padding: clamp(1rem, 2vw + 0.5rem, 1.5rem);
  }

  .onboarding-card-actions {
    justify-content: stretch;
  }

  .onboarding-card-actions button {
    flex: 1;
    min-width: unset;
  }

  .onboarding-skip--intro {
    flex: 0 0 auto;
  }
}

#setup-config .form-row:first-of-type {
  clear: both;
}

/* Specific style for setup controls */
#setupSelect,
#setupName {
  flex: 1; /* Allow them to grow */
}

/* FIZ group fieldset */
fieldset {
  border: 1px solid var(--accent-color);
  border-radius: var(--border-radius);
  padding: 10px;
  margin-top: 1em;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
legend {
  font-weight: var(--font-weight-medium);
  color: var(--accent-color);
  padding: 0 5px;
}

/* Sections */
section {
  background-color: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: var(--section-padding);
  margin-top: var(--section-margin-block-start);
  box-shadow: var(--panel-shadow);
  transition: transform 0.2s;
}

section:hover {
  box-shadow: var(--panel-shadow-hover);
  transform: translateY(-2px);
}

/* All Buttons */
button {
  background-color: var(--button-bg, var(--button-default-bg));
  color: var(--button-text, var(--button-default-text));
  border-width: var(--button-border-width, 0);
  border-style: solid;
  border-color: var(--button-border, var(--button-default-border));
  border-radius: var(--border-radius);
  padding: var(--button-padding-block) var(--button-padding-inline);
  margin: var(--button-margin-block-start) var(--button-margin-inline)
    var(--button-margin-block-end);
  cursor: pointer;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-medium);
  min-height: var(--button-size);
  height: auto;
  /* Keep single-line buttons consistent in every locale without preventing wrapping */
  line-height: var(--button-line-height);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--button-icon-gap);
  box-shadow: var(--button-shadow, var(--panel-shadow));
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    filter 0.2s ease,
    transform 0.1s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}

button:hover,
button:focus-visible {
  filter: brightness(var(--button-hover-factor, var(--button-hover-brightness)));
  box-shadow: var(--button-hover-shadow, var(--panel-shadow-hover));
}

button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent-color) 65%, transparent);
  outline-offset: 2px;
}

.share-import-group button {
  margin: 0;
  flex: 1 1 100%;
  width: 100%;
  align-self: center;
}
.share-import-group #applySharedLinkBtn {
  flex: 0 0 auto;
  width: auto;
  align-self: center;
}
button:active {
  transform: translateY(var(--button-active-translate, 1px));
  filter: brightness(var(--button-active-factor, var(--button-active-brightness)));
}

button:disabled {
  background-color: var(--button-disabled-bg, var(--control-disabled-bg));
  color: var(
    --button-disabled-text,
    color-mix(in srgb, var(--button-text, var(--button-default-text)) 70%, var(--surface-color))
  );
  border-color: var(
    --button-disabled-border,
    color-mix(in srgb, var(--button-border, var(--button-default-border)) 30%, transparent)
  );
  box-shadow: var(--button-disabled-shadow, none);
  cursor: not-allowed;
  opacity: var(--button-disabled-opacity);
  transform: none;
  filter: none;
}

button.primary,
.button-link.primary {
  --button-bg: var(--button-primary-bg);
  --button-text: var(--inverse-text-color);
  --button-border: var(--button-primary-border);
  --button-hover-factor: 1.05;
  --button-active-factor: 0.95;
  --button-shadow: none;
  --button-hover-shadow: var(--panel-shadow-hover);
}

button.secondary,
.button-link.secondary,
.back-btn,
.print-btn,
.export-pdf-btn {
  --button-bg: color-mix(in srgb, var(--surface-color) 85%, var(--accent-color) 15%);
  --button-border: color-mix(in srgb, var(--accent-color) 35%, transparent);
  --button-text: var(--control-text);
  --button-hover-factor: 0.98;
  --button-active-factor: 0.94;
}

button.danger,
.button-link.danger,
.overview-delete-gear-btn {
  --button-bg: var(--button-danger-bg);
  --button-text: var(--inverse-text-color);
  --button-border: var(--button-danger-border);
  --button-hover-factor: 0.95;
  --button-active-factor: 0.9;
  --button-shadow: none;
  --button-hover-shadow: var(--panel-shadow-hover);
}

.ghost-button {
  --button-bg: transparent;
  --button-text: var(--muted-text-color);
  --button-border: color-mix(in srgb, var(--panel-border) 70%, transparent);
  --button-border-width: 1px;
  --button-shadow: none;
  --button-hover-shadow: none;
  --button-hover-factor: 1;
  --button-active-factor: 1;
  padding-block: calc(var(--button-padding-block) + 2px);
  padding-inline: calc(var(--button-padding-inline) * 0.7);
  margin: 0;
  min-height: calc(var(--button-size) * 0.85);
}

.ghost-button:hover,
.ghost-button:focus-visible {
  --button-bg: color-mix(in srgb, var(--accent-color) 18%, transparent);
  --button-text: var(--text-color);
  --button-border: color-mix(in srgb, var(--accent-color) 45%, var(--panel-border));
}

.ghost-button:disabled {
  --button-bg: transparent;
  --button-text: color-mix(in srgb, var(--muted-text-color) 60%, transparent);
  --button-border: color-mix(in srgb, var(--panel-border) 55%, transparent);
  opacity: 0.7;
}

.dark-mode .ghost-button {
  --button-text: color-mix(in srgb, var(--inverse-text-color) 80%, transparent);
  --button-border: color-mix(in srgb, var(--accent-color) 30%, var(--panel-border));
}

.dark-mode .ghost-button:hover,
.dark-mode .ghost-button:focus-visible {
  --button-bg: color-mix(in srgb, var(--accent-color) 28%, transparent);
  --button-text: var(--inverse-text-color);
  --button-border: color-mix(in srgb, var(--accent-color) 55%, var(--panel-border));
}

.dark-mode .ghost-button:disabled {
  --button-text: color-mix(in srgb, var(--inverse-text-color) 55%, transparent);
  --button-border: color-mix(in srgb, var(--panel-border) 55%, transparent);
}

body:not(.dark-mode) button .btn-icon.icon-glyph,
body:not(.dark-mode) .button-link .btn-icon.icon-glyph {
  --icon-color: var(--accent-color);
}

body:not(.dark-mode) button:hover .btn-icon.icon-glyph,
body:not(.dark-mode) button:active .btn-icon.icon-glyph,
body:not(.dark-mode) button:focus-visible .btn-icon.icon-glyph,
body:not(.dark-mode) button:disabled .btn-icon.icon-glyph,
body:not(.dark-mode) .button-link:hover .btn-icon.icon-glyph,
body:not(.dark-mode) .button-link:active .btn-icon.icon-glyph,
body:not(.dark-mode) .button-link:focus-visible .btn-icon.icon-glyph,
body:not(.dark-mode) .button-link[aria-disabled='true'] .btn-icon.icon-glyph {
  --icon-color: currentColor;
}

/* Style file input buttons to match standard buttons */
input[type="file"]::file-selector-button,
input[type="file"]::-webkit-file-upload-button {
  background-color: var(--button-default-bg);
  color: var(--button-default-text);
  border-width: var(--button-border-width, 0);
  border-style: solid;
  border-color: var(--button-default-border);
  border-radius: var(--border-radius);
  padding: var(--button-padding-block) var(--button-padding-inline);
  margin-inline-end: var(--spacing-sm);
  cursor: pointer;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-medium);
  height: 100%;
  min-height: var(--button-size);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--panel-shadow);
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    filter 0.2s ease,
    transform 0.1s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease;
}

input[type="file"]::file-selector-button:hover,
input[type="file"]::-webkit-file-upload-button:hover {
  filter: brightness(var(--button-hover-brightness));
  box-shadow: var(--panel-shadow-hover);
}

input[type="file"]::file-selector-button:active,
input[type="file"]::-webkit-file-upload-button:active {
  transform: translateY(1px);
  filter: brightness(var(--button-active-brightness));
}

input[type="file"]:disabled::file-selector-button,
input[type="file"]:disabled::-webkit-file-upload-button {
  background-color: var(--control-disabled-bg);
  color: color-mix(in srgb, var(--button-default-text) 70%, var(--surface-color));
  border-color: color-mix(in srgb, var(--button-default-border) 30%, transparent);
  box-shadow: none;
  cursor: not-allowed;
  opacity: var(--button-disabled-opacity);
  transform: none;
  filter: none;
}


/* Device Manager specific styles */
.device-list-container {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-top: 15px;
  max-width: 100%;
  overflow-x: auto;
}

.device-category {
  flex: 1 1 calc(33% - 15px); /* Three columns, adjust as needed */
  min-width: 250px; /* Minimum width for each column */
  background-color: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 10px;
  box-shadow: var(--panel-shadow);
  transition: transform 0.2s;
  box-sizing: border-box;
}

.device-category:hover {
  box-shadow: var(--panel-shadow-hover);
  transform: translateY(-2px);
}

@media (max-width: 900px) {
  .device-category {
    flex: 1 1 calc(50% - 15px);
  }
}

.device-category h4 {
  font-family: var(--font-family);
  font-weight: var(--font-weight-regular);
  color: var(--accent-color);
  margin-top: 0;
  margin-bottom: 10px;
  border-bottom: 1px solid var(--divider-color);
  padding-bottom: 5px;
}

.device-ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.device-ul li {
  border-bottom: 1px dashed var(--divider-color);
  padding: 5px 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.device-summary {
  display: flex;
  justify-content: space-between;
  align-items: flex-start; /* keep buttons a constant height */
}

.detail-toggle {
  margin: 0 5px 0 0;
  background: none;
  border: 2px solid transparent;
  padding: 0;
  cursor: pointer;
}

.detail-toggle:focus,
.detail-toggle[aria-expanded="true"] {
  border-color: var(--accent-color);
}

.device-details {
  margin-left: 20px;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
}

/* Arrange top-level device details in two columns */
.device-details > .device-detail-list {
  column-count: 2;
  column-gap: 20px;
}


.device-detail-list {
  list-style: none;
  padding-left: 0;
  margin: 3px 0;
}

.device-detail-list ul {
  margin-left: 15px;
  list-style: none;
  padding-left: 0;
}

.device-detail-list li {
  margin: 2px 0;
  break-inside: avoid;
}

.device-detail-list strong {
  margin-right: 4px;
}

.device-ul li:last-child {
  border-bottom: none;
}

.device-summary span {
  flex-grow: 1;
  margin-right: 10px;
}


/* Top bar */
#topBar {
  position: sticky;
  top: var(--top-bar-offset, 0);
  padding: 5px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  row-gap: 12px;
  flex-wrap: wrap;
  background: linear-gradient(to bottom, var(--surface-color), var(--panel-bg));
  border-bottom: 1px solid var(--panel-border);
  box-shadow: var(--panel-shadow);
  z-index: 100;
}

#topBar h1 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxl));
  margin: 0;
  font-weight: var(--font-weight-light);
}

#topBar .branding {
  display: flex;
  align-items: center;
  gap: 10px;
  color: inherit;
  text-decoration: none;
  flex: 1 1 220px;
}

#topBar .branding:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  border-radius: 6px;
}

#topBar #logo {
  width: 32px;
  height: 32px;
  display: inline-flex;
}

#topBar #logo .logo-img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

#topBar #logo .logo-pink {
  display: none;
}

body.pink-mode #topBar #logo .logo-default {
  display: none;
}

body.pink-mode #topBar #logo .logo-pink {
  display: block;
}

#topBar .feature-search {
  flex: 1 1 280px;
  justify-content: flex-start;
  min-width: min(280px, 100%);
}

/* Search and control group styling */
.feature-search {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: stretch;
  width: 100%;
}

#sideMenu .feature-search {
  justify-content: flex-start;
  margin-bottom: 20px;
}

.controls {
  display: flex;
  gap: 5px;
  align-items: center;
  flex-wrap: wrap;
}

#topBar .controls {
  flex: 0 1 auto;
  justify-content: flex-end;
  margin-left: auto;
  row-gap: 6px;
}

@media (max-width: 1024px) {
  #topBar .controls {
    flex: 1 1 240px;
    justify-content: flex-start;
    margin-left: 0;
  }
}

#sideMenu .controls {
  margin-bottom: 20px;
  flex-wrap: nowrap;
}

#sideMenu .controls select {
  flex: 1 1 auto;
  min-width: 0;
  margin-bottom: 0;
}

#sideMenu .controls button {
  flex: 0 0 var(--button-size);
}

#featureSearchContainer {
  width: 100%;
  max-width: 520px;
}

#featureSearch {
  width: 100%;
  max-width: 520px;
  padding: 2px 10px 2px 6px;
  height: var(--button-size);
}

.feature-search-dropdown {
  position: absolute;
  inset-inline-start: 0;
  top: calc(100% + 4px);
  width: min(640px, calc(100vw - 32px));
  min-width: 100%;
  background: var(--panel-bg);
  color: inherit;
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  box-shadow: var(--panel-shadow);
  padding: 4px 0;
  max-height: min(480px, calc(100vh - 160px));
  overflow-y: auto;
  scrollbar-gutter: stable both-edges;
  z-index: 150;
}

.feature-search-dropdown[hidden] {
  display: none;
}

.feature-search-dropdown-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.feature-search-option {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  width: 100%;
  border: none;
  background: none;
  color: inherit;
  padding: 8px 12px;
  text-align: left;
  font: inherit;
  cursor: pointer;
  border-radius: 6px;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.feature-search-option:hover,
.feature-search-option:focus,
.feature-search-option:focus-visible {
  background: var(--control-hover-bg);
  outline: none;
}

.feature-search-option:active {
  background: var(--control-active-bg);
}

.feature-search-option-label {
  font-weight: var(--font-weight-medium);
}

.feature-search-option-value {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  color: var(--muted-text-color);
  word-break: break-word;
}

.feature-search-option mark.feature-search-highlight {
  background: color-mix(in srgb, var(--accent-color) 25%, transparent);
  color: inherit;
  padding: 0 2px;
  border-radius: 4px;
  font-weight: inherit;
}

body.dark-mode .feature-search-option mark.feature-search-highlight {
  background: color-mix(in srgb, var(--accent-color) 40%, transparent);
}

body.high-contrast .feature-search-option mark.feature-search-highlight {
  background: var(--control-active-bg);
  outline: 1px solid currentColor;
}

.feature-search.feature-search-open #featureSearch {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.controls select {
  height: var(--select-height);
  margin: 0;
  font-size: var(--font-size-relative-base);
  font-weight: var(--font-weight-light);
  font-family: inherit;
  padding: 2px 4px;
  text-align: center;
  text-align-last: center;
}

.controls button {
  height: var(--button-size);
  margin: 0;
  min-width: var(--button-size);
  width: var(--button-size);
  padding: 0;
  border-radius: 50%;
}

.controls button:hover {
  background-color: var(--control-hover-bg);
  color: var(--control-text);
}
.controls button:active {
  background-color: var(--control-active-bg);
  color: var(--control-text);
}

body.light-mode #topBar .controls button {
  color: var(--accent-color);
  --icon-color: currentColor;
}

body.light-mode #topBar .controls button:hover,
body.light-mode #topBar .controls button:active {
  color: var(--accent-color);
}

body.light-mode #topBar .controls button:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

body.light-mode #topBar select {
  color: var(--accent-color);
  font-weight: var(--font-weight-light);
}

body.light-mode #topBar select:hover,
body.light-mode #topBar select:focus {
  color: var(--accent-color);
}

body.light-mode #topBar select:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

@supports (padding: env(safe-area-inset-top)) {
  #topBar {
    padding:
      calc(5px + env(safe-area-inset-top))
      calc(20px + env(safe-area-inset-right))
      5px
      calc(20px + env(safe-area-inset-left));
  }
}

#helpButton {
  padding: 0 4px;
  font-size: var(--font-size-relative-base);
}

#helpButton .icon-text {
  font-weight: var(--font-weight-light);
}

/* Breakdown list */
#breakdownList {
  list-style: none;
  margin: 5px 0;
  padding-left: 0;
}
#breakdownList li {
  margin: 6px 0;
  line-height: 1.6;
}

/* Power diagram */
#powerDiagram,
.power-diagram {
  max-width: 300px;
  margin: 10px 0;
}

.power-bar {
  position: relative;
  display: flex;
  height: 20px;
  border: 1px solid var(--border-strong-color);
  overflow: visible;
}

.power-bar .segment {
  position: relative;
  z-index: 1;
  height: 100%;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--inverse-text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  overflow: hidden;
}

.power-bar .segment span {
  position: relative;
  z-index: 3;
  padding: 0 2px;
}

.power-bar .camera { background-color: var(--camera-color); }
.power-bar .monitor { background-color: var(--monitor-color); }
.power-bar .video { background-color: var(--video-segment-color); }
.power-bar .motors { background-color: var(--motor-color); }
.power-bar .controllers { background-color: var(--controller-color); }
.power-bar .distance { background-color: var(--distance-color); }

.power-bar .over-usage {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  background: var(--danger-overlay-color);
  z-index: 2;
  pointer-events: none;
}


.power-bar .limit-line {
  position: absolute;
  top: -4px;
  bottom: -4px;
  width: 2px;
  background: var(--danger-color);
  z-index: 4;
  overflow: visible;
}

.power-bar .limit-line .limit-label {
  position: absolute;
  top: -1.2em;
  left: 50%;
  transform: translateX(-50%);
  background: none;
  color: var(--danger-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  padding: 0 2px;
  white-space: nowrap;
}

#powerDiagram.over .power-bar,
.power-diagram.over .power-bar {
  border-color: var(--danger-color);
}


#maxPowerText,
.power-diagram-note {
  margin-top: 4px;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

/* Project diagram */
#setupDiagram {
  text-align: center;
  min-height: 440px;
  padding-top: 1em; /* prevent heading overlap */
}

#diagramArea {
  margin: 0.5em auto 0;
  position: relative;
  display: block;
  width: min(90%, var(--diagram-max-width, 100%));
  max-width: var(--diagram-max-width, 100%);
  text-align: left;
  overflow: hidden;
}

#diagramArea > * {
  flex: 0 0 auto;
}

#diagramArea > svg {
  overflow: visible;
}

#diagramArea > svg,
#diagramArea > canvas {
  margin-inline: auto;
  width: 100%;
  max-width: 100%;
  display: block;
}

#diagramArea .diagram-placeholder {
  text-align: center;
  width: 100%;
}

#diagramArea.grid-snap {
  background-size: 20px 20px;
  background-image: linear-gradient(var(--diagram-gridline-color) 1px, transparent 1px),
                    linear-gradient(90deg, var(--diagram-gridline-color) 1px, transparent 1px);
}

#diagramLegend {
  margin-top: 0.25em;
  font-size: var(--font-size-diagram-text);
}
#diagramLegend span {
  margin: 0 6px;
  display: inline-flex;
  align-items: center;
}
#diagramLegend .swatch {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  margin-right: 4px;
  display: inline-block;
}
#diagramLegend .power { background: var(--power-color); }
#diagramLegend .video { background: var(--video-color); }
#diagramLegend .fiz { background: var(--fiz-color); }

#powerDiagramLegend,
.power-diagram-legend {
  margin-top: 0.25em;
  font-size: var(--font-size-diagram-text);
}
#powerDiagramLegend span,
.power-diagram-legend span {
  margin: 0 6px;
  display: inline-flex;
  align-items: center;
}
#powerDiagramLegend .swatch,
.power-diagram-legend .swatch {
  width: 12px;
  height: 12px;
  border-radius: 2px;
  margin-right: 4px;
  display: inline-block;
}
#powerDiagramLegend .camera,
.power-diagram-legend .camera { background-color: var(--camera-color); }
#powerDiagramLegend .monitor,
.power-diagram-legend .monitor { background-color: var(--monitor-color); }
#powerDiagramLegend .video,
.power-diagram-legend .video { background-color: var(--video-segment-color); }
#powerDiagramLegend .motors,
.power-diagram-legend .motors { background-color: var(--motor-color); }
#powerDiagramLegend .controllers,
.power-diagram-legend .controllers { background-color: var(--controller-color); }
#powerDiagramLegend .distance,
.power-diagram-legend .distance { background-color: var(--distance-color); }

.diagram-controls {
  margin-top: 0.5em;
  display: flex;
  justify-content: center;
  gap: 0.5em;
  flex-wrap: wrap;
}

.diagram-controls button {
  min-width: var(--button-size);
  min-height: var(--button-size);
  height: auto;
}

.diagram-controls button.active {
  background: var(--diagram-button-active-bg);
}

@media (max-width: 600px) {
  .diagram-controls {
    display: grid;
    grid-template-columns: repeat(2, minmax(var(--button-size), 1fr));
    justify-content: center;
  }

  .diagram-controls button {
    min-width: 0;
  }

  .diagram-controls #zoomOut,
  .diagram-controls #zoomIn {
    width: var(--button-size);
    justify-self: center;
  }

  .diagram-controls #resetView,
  .diagram-controls #gridSnapToggle {
    justify-self: stretch;
    white-space: nowrap;
  }
}

#diagramHint {
  margin-top: 0.25em;
  font-size: var(--font-size-diagram-text);
  color: var(--muted-text-color);
}


.diagram-popup {
  display: none;
  position: fixed;
  pointer-events: auto;
  background: var(--surface-color);
  color: var(--text-color);
  border: 1px solid var(--panel-border);
  font-size: var(--font-size-relative-base);
  line-height: var(--line-height-supporting);
  padding: clamp(1rem, 2.4vw, 1.65rem);
  border-radius: calc(var(--border-radius) * 2);
  box-shadow: var(--panel-shadow);
  z-index: 10;
  --diagram-popup-columns: 1;
  --diagram-popup-min-column-width: 180px;
  width: min(var(--diagram-popup-dynamic-width, 400px), calc(100vw - clamp(2rem, 4vw, 3rem)));
  max-width: min(var(--diagram-popup-dynamic-width, 400px), calc(100vw - clamp(2rem, 4vw, 3rem)));
  max-height: min(92vh, calc(100vh - clamp(2rem, 4vw, 3rem)));
  overflow: auto;
  box-sizing: border-box;
}

.diagram-popup__layout {
  display: flex;
  flex-direction: column;
  gap: clamp(0.5rem, 1vw, 0.75rem);
  min-width: 0;
}

.diagram-popup__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  padding-bottom: 0.5rem;
  margin-bottom: 0.25rem;
  border-bottom: 1px solid var(--panel-border);
}

.diagram-popup__title {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * 1.05);
  font-weight: var(--font-weight-semibold);
  flex: 1 1 auto;
  min-width: 0;
}

.diagram-popup__back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid transparent;
  border-radius: var(--border-radius-sm, 4px);
  background: transparent;
  color: var(--accent-color);
  font-size: inherit;
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  padding: 0.25rem 0.6rem;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.diagram-popup__back .btn-icon {
  margin-inline-end: 0.25rem;
  --button-icon-size: 1.05em;
}

.diagram-popup__back:hover,
.diagram-popup__back:focus-visible {
  border-color: color-mix(in srgb, var(--accent-color) 25%, transparent);
  background-color: color-mix(in srgb, var(--accent-color) 12%, transparent);
  outline: none;
}

.diagram-popup__back:focus-visible {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 25%, transparent);
}

.diagram-popup__body {
  display: flex;
  flex-direction: column;
  gap: clamp(0.4rem, 0.9vw, 0.65rem);
  min-width: 0;
}

.diagram-popup__body > :first-child {
  margin-top: 0;
}

.diagram-popup__fallback {
  margin: 0;
}

.diagram-popup:focus,
.diagram-popup:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 0;
}

.diagram-popup--notice {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  text-align: center;
}

.diagram-popup-notice {
  font-size: var(--font-size-diagram-text);
  line-height: 1.4;
  margin: 0;
}

.diagram-popup[data-columns="1"] {
  --diagram-popup-columns: 1;
}

.diagram-popup[data-columns="2"] {
  --diagram-popup-columns: 2;
}

.diagram-popup[data-columns="3"] {
  --diagram-popup-columns: 3;
}

.diagram-popup[data-columns="4"] {
  --diagram-popup-columns: 4;
}

.diagram-popup--camera {
  --diagram-popup-dynamic-width: 520px;
  width: min(var(--diagram-popup-dynamic-width, 520px), calc(100vw - 24px));
  max-width: min(var(--diagram-popup-dynamic-width, 520px), calc(100vw - 24px));
}

.diagram-popup--camera .connector-summary,
.diagram-popup--camera .scenario-summary,
.diagram-popup--camera .icon-box-summary {
  display: grid;
  grid-template-columns: repeat(var(--diagram-popup-columns, 1), minmax(var(--diagram-popup-min-column-width, 180px), 1fr));
  column-gap: 6px;
  row-gap: 4px;
}

.diagram-popup--camera .connector-summary > *,
.diagram-popup--camera .scenario-summary > *,
.diagram-popup--camera .icon-box-summary > * {
  min-width: 0;
}

.diagram-popup--camera .connector-summary .info-label,
.diagram-popup--camera .connector-summary .port-table,
.diagram-popup--camera .connector-summary .lens-mount-box,
.diagram-popup--camera .connector-summary .tray-box {
  grid-column: 1 / -1;
}

.diagram-popup--camera .connector-summary .connector-block,
.diagram-popup--camera .connector-summary .info-box,
.diagram-popup--camera .connector-summary .scenario-box,
.diagram-popup--camera .connector-summary .icon-box {
  width: 100%;
}

.diagram-detail-dialog {
  padding: 0;
  width: min(640px, calc(100vw - 32px));
  max-width: min(720px, calc(100vw - 32px));
}

.diagram-detail-dialog__inner {
  display: flex;
  flex-direction: column;
}


.diagram-detail-dialog__header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 1rem 1.25rem 0.75rem;
  position: relative;
}

.diagram-detail-dialog__back {
  font-size: var(--font-size-relative-base);
  background: none;
  border: none;
  color: var(--accent-color);
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  border-radius: var(--border-radius-sm, 4px);
  position: absolute;
  left: 1.25rem;
}

.diagram-detail-dialog__back:hover,
.diagram-detail-dialog__back:focus-visible {
  text-decoration: underline;
}

.diagram-detail-dialog__title {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * 1.1);
  text-align: center;
}

.diagram-detail-dialog__content {
  padding: 0 1.25rem 1.25rem;
  max-height: min(70vh, calc(100vh - 160px));
  overflow: auto;
}

.diagram-detail-dialog__content .diagram-popup {
  position: static;
  display: block;
  width: 100%;
  max-width: none;
  max-height: none;
  padding: 0;
  border: none;
  box-shadow: none;
}

.diagram-detail-dialog__content .diagram-popup--camera {
  width: 100%;
}

.diagram-detail-dialog__content .diagram-popup__header {
  display: none;
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

.diagram-detail-dialog__content .diagram-popup__layout {
  gap: clamp(0.75rem, 1.2vw, 1rem);
}

.diagram-detail-dialog__content .diagram-popup__body {
  gap: clamp(0.65rem, 1.1vw, 0.85rem);
}


/* Device info lists inside diagram popups */
.connector-summary {
  margin-top: 4px;
  display: flex;
  flex-wrap: wrap;
}

.scenario-summary,
.icon-box-summary {
    margin-top: 4px;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

.connector-block,
.info-box {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  padding: 2px 6px;
  margin: 2px;
  border-radius: 3px;
  border: 1px solid;
  background-color: transparent;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
}

.info-box-list {
  gap: 4px;
  flex-wrap: nowrap;
}

.info-box-label {
  font-weight: var(--font-weight-bold);
  margin-right: 2px;
  color: var(--connector-label-neutral-color);
}

.info-box strong:first-child {
  color: var(--connector-label-neutral-color);
}

.info-box-list .info-box-label {
  flex: 0 0 auto;
}

.info-box-list .info-box-values {
  flex: 1 1 auto;
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
}
.lens-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px 12px;
}
.lens-info-grid .info-box {
  width: 100%;
}
@media (max-width: 600px) {
  .lens-info-grid {
    grid-template-columns: 1fr;
  }
}

.scenario-box,
.icon-box {
  display: flex;
  align-items: center;
  padding: 2px 6px;
  margin: 2px;
  border-radius: 3px;
  border: 1px solid;
  background-color: transparent;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
}

.scenario-box .scenario-icon,
.icon-box .icon {
  margin-right: 4px;
}

.tray-box {
  margin-top: 4px;
  padding: 4px;
  border-radius: 3px;
  background: transparent;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
}

.lens-mount-box {
  display: flex;
  flex-wrap: wrap;
}

.info-label {
  width: 100%;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxs));
  font-weight: var(--font-weight-bold);
  margin: 4px 2px 0;
}

.port-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 4px;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-compact));
}
.port-table th {
  text-align: left;
  padding: 2px 6px 2px 0;
  white-space: nowrap;
}
.port-table td {
  padding: 2px 0;
}

.port-table .power-row th,
.port-table .power-row td {
  color: var(--power-color);
}

.port-table .fiz-row th,
.port-table .fiz-row td {
  color: var(--fiz-color);
}

.port-table .video-row th,
.port-table .video-row td {
  color: var(--video-color);
}

.power-conn {
  border-color: var(--power-color);
  background-color: transparent;
  --icon-color: var(--power-color);
}
.fiz-conn {
  border-color: var(--fiz-color);
  background-color: transparent;
  --icon-color: var(--fiz-color);
}
.video-conn {
  border-color: var(--video-color);
  background-color: transparent;
  --icon-color: var(--video-color);
}
.neutral-conn {
  border-color: var(--neutral-color);
  background-color: transparent;
  --icon-color: var(--neutral-color);
}


.device-data { margin-left: 10px; }
.device-data ul { list-style: disc; margin-left: 20px; }

#setupDiagram svg {
  width: 100%;
  height: auto;
  touch-action: none;
}

#setupDiagram .node-box {
  fill: var(--diagram-node-fill);
  stroke: none;
}
#setupDiagram .node-box.first-fiz {
  stroke: none;
}

#setupDiagram .first-fiz-highlight {
  stroke: url(#firstFizGrad);
  stroke-width: 1px;
  fill: none;
}

#setupDiagram .node-icon {
  font-size: var(--font-size-diagram-icon);
  font-family: 'UiconsThinStraightV2', system-ui, sans-serif;
  font-style: normal;
  color: var(--accent-color);
  fill: var(--accent-color);
}
#setupDiagram .node-icon[data-icon-font='essential'] {
  font-family: 'EssentialIconsV2', system-ui, sans-serif;
}
#setupDiagram .node-icon[data-icon-font='text'] {
  font-family: 'Ubuntu', system-ui, sans-serif;
  font-weight: var(--font-weight-medium);
}
#setupDiagram .conn {
  stroke: none;
}
#setupDiagram .conn.red { fill: var(--power-color); }
#setupDiagram .conn.blue { fill: var(--video-color); }
#setupDiagram .conn.green { fill: var(--fiz-color); }

#setupDiagram .edge-label {
  font-size: var(--font-size-diagram-label);
  dominant-baseline: middle;
}

#setupDiagram line {
  stroke: var(--control-text);
  stroke-width: 2px;
}

#setupDiagram path.edge-path {
  stroke-width: 2px;
  fill: none;
}
#setupDiagram path.edge-path:not(.power):not(.video):not(.fiz) {
  stroke: var(--control-text);
}
#setupDiagram path.power {
  stroke: var(--power-color);
}
#setupDiagram path.video {
  stroke: var(--video-color);
}
#setupDiagram path.fiz {
  stroke: var(--fiz-color);
}

#setupDiagram .diagram-placeholder {
  font-style: italic;
  color: #666;
  margin: 0;
}


/* Temperature note table */
#temperatureNote {
  margin-top: 1em;
  overflow-x: auto;
}

#temperatureNote table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0.5em;
  min-width: 260px;
}

#temperatureNote th,
#temperatureNote td {
  padding: 6px 8px;
  text-align: center;
  border: 1px solid var(--panel-border);
  font-variant-numeric: tabular-nums;
}

#temperatureNote th {
  font-weight: var(--font-weight-bold);
  background-color: var(--surface-color);
}

#temperatureNote td {
  font-weight: var(--font-weight-light);
}

body:not(.light-mode) #temperatureNote th,
body:not(.light-mode) #temperatureNote td {
  border-color: var(--border-strong-color);
}

body:not(.light-mode) #temperatureNote th {
  background-color: var(--panel-bg);
}

/* Shared section description helper */
.section-description {
  margin: 0 0 0.75em;
  color: var(--muted-text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: var(--line-height-supporting);
}

/* Battery comparison section */
.battery-comparison-section {
  background: var(--panel-bg); /* Match section background */
  padding: 15px; /* Match section padding */
  margin-top: 1em; /* Match section margin */
  border: 1px solid var(--panel-border); /* Match section border */
  border-radius: var(--border-radius); /* Match section border-radius */
  box-shadow: var(--panel-shadow);
  transition: transform 0.2s;
}

.battery-comparison-section:hover {
  box-shadow: var(--panel-shadow-hover);
  transform: translateY(-2px);
}
.battery-table-container {
  overflow-x: auto;
}
.battery-comparison-section table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 5px;
}
.battery-comparison-section th,
.battery-comparison-section td {
  border: 1px solid var(--panel-border);
  padding: 8px;
  text-align: left;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}
.battery-comparison-section th:nth-child(1),
.battery-comparison-section td:nth-child(1) {
  width: 30%; /* Battery Name */
}

.battery-comparison-section th:nth-child(2),
.battery-comparison-section td:nth-child(2) {
  width: 25%; /* Estimated Runtime */
}

.battery-comparison-section th:nth-child(3),
.battery-comparison-section td:nth-child(3) {
  width: 45%; /* Bar column, takes remaining space */
}

.battery-comparison-section th {
  background-color: var(--surface-color);
}

/* User runtime feedback table */
#feedbackTableContainer {
  overflow-x: auto;
  max-width: 100%;
  margin-top: 1em;
}

#userFeedbackTable {
  width: auto; /* Allow the table to size to its content by default */
  width: fit-content; /* Prevent stretching across the full viewport on wide screens */
  max-width: 100%;
  border-collapse: collapse;
}

#userFeedbackTable th,
#userFeedbackTable td {
  border: 1px solid var(--panel-border);
  padding: 6px;
  white-space: nowrap;
  text-align: left;
}

#userFeedbackTable th {
  background-color: var(--surface-color);
}

body:not(.light-mode) #userFeedbackTable th {
  background-color: var(--panel-bg);
}

body:not(.light-mode) #userFeedbackTable th,
body:not(.light-mode) #userFeedbackTable td {
  border-color: var(--border-strong-color);
}

/* Accent handling for feedback table */
body.light-mode #userFeedbackTable th,
body.light-mode #userFeedbackTable td,
body.pink-mode #userFeedbackTable th,
body.pink-mode #userFeedbackTable td {
  border-color: var(--accent-color);
}
body.light-mode #userFeedbackTable th,
body.pink-mode #userFeedbackTable th {
  background-color: var(--accent-color);
  color: var(--inverse-text-color);
}

/* Battery comparison bars */
.barContainer {
  width: 100%;
  background-color: var(--surface-color);
  border-radius: 3px;
  overflow: hidden;
  height: 15px; /* Height of the bar */
}

.bar {
  height: 100%;
  background-color: var(--success-color);
  width: 0%; /* Will be set by JS */
  border-radius: 3px;
  transition: width 0.5s ease-out; /* Smooth transition for bar growth */
}

.bar-pins-only {
  background-color: var(--warning-color);
}

/* Runtime weighting */
.weightingRow {
  display: flex;
  align-items: center;
}
.weightBar {
  height: 100%;
  background-color: var(--info-color);
  border-radius: 3px;
  transition: width 0.5s ease-out;
}

.weightingPercent {
  margin-left: 0.5em;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
}

.selectedBatteryRow {
    background-color: var(--selected-row-bg); /* Mild accent highlight for selected row */
    font-weight: var(--font-weight-bold);
}

html.dark-mode,
.dark-mode {
  color-scheme: dark light;
  --background-color: #1c1c1e;
  --surface-color: #1c1c1e;
  --text-color: #f0f0f0;
  --control-bg: #2c2c2f;
  --control-text: #f0f0f0;
  --control-border: #444;
  --control-hover-bg: #3a3a3d;
  --control-active-bg: #4a4a4d;
  --control-disabled-bg: #333;
  --panel-bg: #1c1c1e;
  --panel-border: #333;
  --panel-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
  --panel-shadow-hover: 0 6px 20px rgba(0, 0, 0, 0.5);
  --link-color: var(--inverse-text-color);
  --muted-text-color: #bbb;
  --border-strong-color: #555;
  --divider-color: #444;
  --diagram-gridline-color: #444;
  --diagram-button-active-bg: #3a3a3d;
  --warning-text-color: #000000;
  --danger-color: #ff6666;
  --danger-overlay-color: rgba(255, 102, 102, 0.4);
  --success-color: #66bb6a;
  --info-color: #7ec8ff;
  --neutral-color: #bbbbbb;
  --status-error-bg: rgba(255, 120, 120, 0.45);
  --status-warning-bg: rgba(255, 107, 107, 0.65);
  --status-note-bg: rgba(255, 214, 102, 0.25);
  --status-success-bg: rgba(102, 187, 106, 0.2);
  --status-border-color: #444;
  --gear-extra-indicator-bg: color-mix(in srgb, var(--warning-color) 35%, transparent);
  --gear-extra-indicator-text: #000000;
  --status-error-text-color: #ffffff;
  --status-warning-text-color: #ffffff;
  --status-note-text-color: #ffe082;
  --status-success-text-color: #f0f0f0;
  --diagram-node-fill: #444;
  --power-color: #ff6666;
  --video-color: #7ec8ff;
  --fiz-color: #6f6;
  --camera-color: #66bb6a;
  --monitor-color: #7ec8ff;
  --video-segment-color: #ffd54f;
  --motor-color: #ce93d8;
  --controller-color: #ff8a65;
  --distance-color: #a1887f;
  --selected-row-bg: color-mix(in srgb, var(--accent-color) 42%, var(--surface-color) 58%);
  --power-conn-bg: rgba(255, 102, 102, 0.3);
  --fiz-conn-bg: rgba(102, 187, 106, 0.3);
  --video-conn-bg: rgba(126, 200, 255, 0.3);
  --neutral-conn-bg: rgba(187, 187, 187, 0.3);
  --connector-label-neutral-color: var(--text-color);
  --onboarding-highlight-border: color-mix(in srgb, var(--accent-color) 90%, rgba(255, 255, 255, 0.35));
  --onboarding-highlight-fill: color-mix(in srgb, var(--accent-color) 16%, transparent);
  --onboarding-label-color: color-mix(in srgb, var(--inverse-text-color) 88%, rgba(255, 255, 255, 0.24));
  --onboarding-hint-color: color-mix(in srgb, var(--inverse-text-color) 76%, rgba(255, 255, 255, 0.36));
  --onboarding-subtext-color: color-mix(in srgb, var(--inverse-text-color) 80%, rgba(255, 255, 255, 0.35));
  --onboarding-control-bg: color-mix(in srgb, rgba(24, 28, 34, 0.95) 85%, rgba(255, 255, 255, 0.08) 15%);
  --onboarding-control-border: color-mix(in srgb, var(--accent-color) 45%, rgba(255, 255, 255, 0.18));
  --onboarding-control-text: var(--inverse-text-color);
  --onboarding-control-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.25);
  --onboarding-control-focus-border: color-mix(in srgb, var(--accent-color) 65%, rgba(255, 255, 255, 0.18));
  --onboarding-control-focus-ring: 0 0 0 3px color-mix(in srgb, var(--accent-color) 45%, rgba(255, 255, 255, 0.1));
  --onboarding-button-text: var(--inverse-text-color);
}

html.high-contrast,
body.high-contrast {
  --accent-color: #fff;
  --background-color: #000;
  --surface-color: #000;
  --text-color: #fff;
  --control-bg: #000;
  --control-text: #fff;
  --control-border: #fff;
  --panel-bg: #000;
  --panel-border: #fff;
  --link-color: #0ff;
  --muted-text-color: #fff;
  --border-strong-color: #fff;
  --divider-color: #fff;
  --diagram-gridline-color: #fff;
  --diagram-button-active-bg: #444;
  --warning-color: #ff0;
  --warning-text-color: #000;
  --danger-color: #f00;
  --danger-overlay-color: rgba(255, 0, 0, 0.5);
  --success-color: #0f0;
  --info-color: #0ff;
  --neutral-color: #fff;
  --status-error-bg: #f00;
  --status-warning-bg: #ff0;
  --status-note-bg: #ff0;
  --status-success-bg: #0f0;
  --status-border-color: #fff;
  --status-error-text-color: #000;
  --status-warning-text-color: #000;
  --status-note-text-color: #000;
  --status-success-text-color: #000;
  --diagram-node-fill: #fff;
  --power-color: #f00;
  --video-color: #0ff;
  --fiz-color: #0f0;
  --camera-color: #0f0;
  --monitor-color: #0ff;
  --video-segment-color: #ff0;
  --motor-color: #f0f;
  --controller-color: #fff;
  --distance-color: #ff8800;
  --power-conn-bg: rgba(255, 0, 0, 0.5);
  --fiz-conn-bg: rgba(0, 255, 0, 0.5);
  --video-conn-bg: rgba(0, 255, 255, 0.5);
  --neutral-conn-bg: rgba(255, 255, 255, 0.5);
  --connector-label-neutral-color: #ffffff;
  --selected-row-bg: #fff;
}

html.high-contrast.pink-mode,
body.high-contrast.pink-mode {
  --accent-color: #ff69b4;
  --link-color: #ff69b4;
  --icon-color: var(--accent-color);
  --logo-accent-color: #f255a8;
  --logo-background-color: #f255a8;
  --logo-center-color: #ffffff;
}

html.dark-mode,
body.dark-mode {
  background-color: var(--background-color);
  color: var(--text-color);
  --auto-gear-highlight-bg: rgba(255, 196, 0, 0.28);
  --auto-gear-highlight-border: rgba(255, 208, 0, 0.72);
  --auto-gear-highlight-text: var(--inverse-text-color);
}

.dark-mode h1,
.dark-mode h2,
.dark-mode h3 {
  color: var(--inverse-text-color);
}
.dark-mode h2 {
  border-bottom: 1px solid var(--inverse-text-color);
}
body.dark-mode.pink-mode h1,
body.dark-mode.pink-mode h2,
body.dark-mode.pink-mode h3,
body.dark-mode.dark-accent-boost:not(.pink-mode) h1,
body.dark-mode.dark-accent-boost:not(.pink-mode) h2,
body.dark-mode.dark-accent-boost:not(.pink-mode) h3 {
  color: var(--accent-color);
}
body.dark-mode.pink-mode h2,
body.dark-mode.dark-accent-boost:not(.pink-mode) h2 {
  border-bottom: 1px solid var(--accent-color);
}

body.dark-mode.pink-mode {
  --link-color: var(--inverse-text-color);
}
.dark-mode section,
.dark-mode .device-category,
.dark-mode .battery-comparison-section {
  background-color: var(--panel-bg);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
}
.dark-mode fieldset { border-color: var(--inverse-text-color); }
.dark-mode legend { color: var(--inverse-text-color); }
.dark-mode .battery-comparison-section th { background-color: var(--control-bg); }
.dark-mode .barContainer { background-color: var(--panel-bg); }
.dark-mode .device-category h4 { color: var(--inverse-text-color); border-bottom: 1px solid var(--inverse-text-color); }
.dark-mode .connector-block,
.dark-mode .info-box { background-color: transparent; }
.dark-mode .scenario-box { background-color: transparent; }
.dark-mode .tray-box { background-color: transparent; }
.dark-mode #setupDiagram .first-fiz-highlight { stroke: url(#firstFizGrad); }
.dark-mode #setupDiagram text { fill: var(--inverse-text-color); }
.dark-mode #setupDiagram line { stroke: var(--inverse-text-color); }
.dark-mode #setupDiagram path.edge-path:not(.power):not(.video):not(.fiz) { stroke: var(--inverse-text-color); }
.dark-mode #setupDiagram marker polygon { fill: var(--inverse-text-color); }
.dark-mode #setupDiagram .diagram-placeholder { color: #bbb; }
.dark-mode .help-content.modal-surface,
.dark-mode .settings-content.modal-surface {
  border-color: var(--control-border);
}
body.dark-mode.pink-mode .help-content,
body.dark-mode.pink-mode .settings-content.modal-surface,
body.dark-mode.dark-accent-boost:not(.pink-mode) .help-content,
body.dark-mode.dark-accent-boost:not(.pink-mode) .settings-content.modal-surface {
  border-color: var(--control-border);
}

@media (prefers-color-scheme: dark) {
  html:not(.light-mode),
  body:not(.light-mode) {
    --background-color: #1c1c1e;
    --surface-color: #1c1c1e;
    --text-color: #f0f0f0;
    --control-bg: #2c2c2f;
    --control-text: #f0f0f0;
    --control-border: #444;
    --control-hover-bg: #3a3a3d;
    --control-active-bg: #4a4a4d;
    --control-disabled-bg: #333;
    --panel-bg: #1c1c1e;
    --panel-border: #333;
    --panel-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    --panel-shadow-hover: 0 6px 20px rgba(0, 0, 0, 0.5);
    --link-color: #7ec8ff;
    --muted-text-color: #bbb;
    --border-strong-color: #555;
    --divider-color: #444;
    --diagram-gridline-color: #444;
    --diagram-button-active-bg: #3a3a3d;
    --warning-text-color: #000000;
    --danger-color: #ff6666;
    --danger-overlay-color: rgba(255, 102, 102, 0.4);
    --success-color: #66bb6a;
    --info-color: #7ec8ff;
    --neutral-color: #bbbbbb;
    --status-error-bg: rgba(255, 120, 120, 0.45);
    --status-warning-bg: rgba(255, 107, 107, 0.65);
    --status-success-bg: rgba(102, 187, 106, 0.2);
    --status-border-color: #444;
    --status-error-text-color: #ffffff;
    --status-warning-text-color: #ffffff;
    --status-success-text-color: #f0f0f0;
    --favorite-inactive-color: var(--control-text);
    --diagram-node-fill: #444;
    --power-color: #ff6666;
    --video-color: #7ec8ff;
    --fiz-color: #6f6;
    --camera-color: #66bb6a;
    --monitor-color: #7ec8ff;
    --video-segment-color: #ffd54f;
    --motor-color: #ce93d8;
    --controller-color: #ff8a65;
    --distance-color: #a1887f;
    --selected-row-bg: #003366;
    --power-conn-bg: rgba(255, 102, 102, 0.3);
    --fiz-conn-bg: rgba(102, 187, 106, 0.3);
    --video-conn-bg: rgba(126, 200, 255, 0.3);
    --neutral-conn-bg: rgba(187, 187, 187, 0.3);
    background-color: var(--background-color);
    color: var(--text-color);
  }
  body:not(.light-mode) h1,
  body:not(.light-mode) h2,
  body:not(.light-mode) h3 {
    color: var(--inverse-text-color);
  }
  body:not(.light-mode) h2 {
    border-bottom: 1px solid var(--inverse-text-color);
  }
  body:not(.light-mode).pink-mode h1,
  body:not(.light-mode).pink-mode h2,
  body:not(.light-mode).pink-mode h3,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) h1,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) h2,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) h3 {
    color: var(--accent-color);
  }
  body:not(.light-mode).pink-mode h2,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) h2 {
    border-bottom: 1px solid var(--accent-color);
  }
  body:not(.light-mode) fieldset { border-color: var(--inverse-text-color); }
  body:not(.light-mode) legend { color: var(--inverse-text-color); }
  body:not(.light-mode) .battery-comparison-section th { background-color: var(--control-bg); }
  body:not(.light-mode) .barContainer { background-color: var(--panel-bg); }
  body:not(.light-mode) .device-category h4 { color: var(--inverse-text-color); border-bottom: 1px solid var(--inverse-text-color); }
  body:not(.light-mode) .connector-block,
  body:not(.light-mode) .info-box { background-color: transparent; }
  body:not(.light-mode) .scenario-box { background-color: transparent; }
  body:not(.light-mode) .tray-box { background-color: transparent; }
  body:not(.light-mode) #setupDiagram .first-fiz-highlight { stroke: url(#firstFizGrad); }
  body:not(.light-mode) #setupDiagram text { fill: var(--inverse-text-color); }
  body:not(.light-mode) #setupDiagram line { stroke: var(--inverse-text-color); }
  body:not(.light-mode) #setupDiagram path.edge-path:not(.power):not(.video):not(.fiz) { stroke: var(--inverse-text-color); }
  body:not(.light-mode) #setupDiagram marker polygon { fill: var(--inverse-text-color); }
  body:not(.light-mode) #setupDiagram .diagram-placeholder { color: var(--muted-text-color); }
  body:not(.light-mode) .help-content,
  body:not(.light-mode) .settings-content.modal-surface {
    border-color: var(--control-border);
  }
  body:not(.light-mode) .gear-table td {
    border-top: 1px solid var(--inverse-text-color);
    border-bottom: 1px solid var(--inverse-text-color);
  }
  body:not(.light-mode) .gear-table .category-row td {
    border-top: 1px solid var(--inverse-text-color);
    border-bottom: 1px solid var(--inverse-text-color);
    color: var(--inverse-text-color);
    font-weight: var(--font-weight-medium);
  }
  body:not(.light-mode).pink-mode .gear-table td,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) .gear-table td {
    border-top: 1px solid var(--accent-color);
    border-bottom: 1px solid var(--accent-color);
  }
  body:not(.light-mode).pink-mode .gear-table .category-row td,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) .gear-table .category-row td {
    border-top: 1px solid var(--accent-color);
    border-bottom: 1px solid var(--accent-color);
    color: var(--accent-color);
    font-weight: var(--font-weight-medium);
  }
  body:not(.light-mode).pink-mode .help-content,
  body:not(.light-mode).pink-mode .settings-content.modal-surface,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) .help-content,
  body:not(.light-mode).dark-accent-boost:not(.pink-mode) .settings-content.modal-surface {
    border-color: var(--control-border);
  }
}
/* Responsive layout adjustments */
@media (max-width: 768px) {
  #featureSearch {
    max-width: 100%;
  }
  #topBar .feature-search,
  #topBar .controls {
    display: none;
  }
}

@media (min-width: 769px) {
  #sideMenu .sidebar-controls {
    display: none;
  }
}

@media (max-width: 600px) {
  body {
    margin: 10px;
    font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  }

  .controls select {
    flex: 1 1 100%;
    margin-bottom: 5px;
  }

  .controls button {
    flex: 0 0 auto;
  }

  .form-row {
    flex-direction: column;
    align-items: stretch;
  }

  .form-row label,
  .form-row .form-row-label {
    width: auto;
    min-width: auto;
    margin-bottom: 4px;
  }
  #setup-config .form-row label,
  #setup-config .form-row .form-row-label {
    line-height: var(--line-height-base);
  }
  .form-row select,
  .form-row input {
    margin: 5px 0 0 0;
  }

  .form-row .select-wrapper {
    margin: 5px 0 0 0;
  }

  .form-row .select-wrapper select {
    margin: 0;
  }

  .form-row > button {
    width: 100%;
    margin: var(--gap-size) 0 0 0;
  }

  .form-row > button + button {
    margin-left: 0;
    margin-top: var(--gap-size);
  }

  .share-import-group {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .share-import-group label {
    width: 100%;
    white-space: normal;
  }

  .share-import-group button {
    width: 100%;
    align-self: stretch;
  }

  .device-list-container {
    flex-direction: column;
  }

  .device-category {
    flex: 1 1 100%;
    min-width: auto;
  }

  /* Stack device details vertically on small screens */
  .device-details > .device-detail-list {
    column-count: 1;
  }

  #setupDiagram {
    min-height: 300px;
  }

    /* Allow wrapping instead of horizontal scroll on small screens */
    #feedbackTableContainer,
    #batteryTableContainer {
      overflow-x: visible;
    }

  #userFeedbackTable th,
  #userFeedbackTable td,
  .port-table th,
  .port-table td,
  .battery-comparison-section th,
  .battery-comparison-section td {
    white-space: normal;
    overflow-wrap: anywhere;
  }
}

/* Project requirements dialog */
#projectDialog {
  --select-height: calc(var(--button-size) * 1.2);
  border: none;
  padding: 0;
  background: transparent;
  color: inherit;
}

#projectDialog::backdrop {
  background: rgba(0, 0, 0, 0.6);
}

#projectDialog .project-dialog {
  width: min(100%, 960px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 4vw, 28px);
  padding: clamp(20px, 4vw, 32px);
}

#projectDialog input,
#projectDialog select,
#projectDialog textarea {
  font-family: var(--font-family);
  font-size: var(--form-control-font-size);
  line-height: var(--line-height-base);
}

@media (min-width: 1024px) {
  #projectDialog .project-dialog {
    width: min(100%, 1100px);
  }
}

.project-dialog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.project-dialog-header h2 {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxl));
  font-weight: var(--font-weight-semibold);
}

.project-dialog-close {
  border: none;
  background: transparent;
  color: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(36px, 8vw, 44px);
  height: clamp(36px, 8vw, 44px);
  border-radius: 50%;
  transition: background-color 0.2s ease, color 0.2s ease;
  cursor: pointer;
}

.project-dialog-close:hover,
.project-dialog-close:focus-visible {
  background-color: var(--control-bg);
  color: var(--control-text);
}

.project-dialog-body {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 3vw, 24px);
}

.project-dialog-section {
  background: var(--panel-bg);
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  box-shadow: var(--panel-shadow);
  padding: clamp(16px, 2.5vw, 24px);
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 2vw, 16px);
}

.project-section-title {
  margin: 0;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  font-weight: var(--font-weight-semibold);
  color: var(--accent-color);
}

.project-section-content {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 2vw, 16px);
}

.project-section-content .form-row {
  margin: 0;
}

#projectDialog .form-row {
  display: grid;
  grid-template-columns: minmax(var(--form-label-min-width), var(--form-label-width)) minmax(0, 1fr);
  align-items: center;
  gap: var(--gap-size);
}

#projectDialog .form-row label,
#projectDialog .form-row .form-row-label {
  flex: initial;
  min-width: 0;
}

#projectDialog .form-row > :not(label):not(.form-row-label) {
  grid-column: 2;
  justify-self: stretch;
}

#projectDialog .form-row > button,
#projectDialog .form-row > .inline-form-button {
  justify-self: start;
}

#projectDialog select[multiple] {
  height: auto;
}

#projectDialog .form-row .select-wrapper {
  flex: 1 1 auto;
  width: 100%;
}

#projectDialog .form-row .select-wrapper select {
  flex: 1 1 auto;
  width: 100%;
}

.project-field-hint {
  margin: 4px 0 0;
  font-size: calc(var(--form-control-font-size) * 0.875);
  color: var(--muted-text-color);
}

body.high-contrast .project-field-hint {
  color: var(--text-color);
}

.address-form-row .form-row-label {
  align-self: start;
  padding-top: 2px;
}

.address-field-grid {
  display: grid;
  gap: var(--gap-size);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.address-field-grid .address-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.address-field-grid .address-field--full {
  grid-column: 1 / -1;
}

.address-field-grid .address-field label {
  font-size: clamp(12px, 1.4vw, 14px);
  color: var(--text-color-secondary, inherit);
}

.address-field-grid .address-field input {
  width: 100%;
}

#projectDialog select {
  font-family: var(--font-family);
  font-size: var(--form-control-font-size);
  font-weight: inherit;
  line-height: var(--button-line-height, 1.25);
  color: var(--control-text);
  background-color: var(--control-bg);
  border: 1px solid var(--control-border);
  border-radius: var(--border-radius);
  padding: 0.45em 0.75em;
  min-height: var(--select-height);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

#projectDialog select:focus-visible {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 25%, transparent);
}

@supports not (color: color-mix(in srgb, black 50%, white)) {
  #projectDialog select:focus-visible {
    box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.08);
  }
}

#projectDialog select.select-placeholder {
  color: var(--muted-text-color);
}

#projectDialog select.select-placeholder option[value=""],
#projectDialog select.select-placeholder option[disabled] {
  color: var(--muted-text-color);
}

#projectDialog .lens-workflow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(16px, 3vw, 24px);
  margin-bottom: clamp(16px, 3vw, 24px);
}

@media (min-width: 900px) {
  #projectDialog .lens-workflow {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

#projectDialog .lens-step {
  position: relative;
}

#projectDialog .lens-step-card {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 2vw, 16px);
  padding: clamp(16px, 3vw, 20px);
  border-radius: 16px;
  border: 1px solid var(--panel-border);
  background: var(--surface-elevated);
  box-shadow: var(--panel-shadow);
  min-height: 100%;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

#projectDialog .lens-step:not(.lens-step-disabled) .lens-step-card:hover,
#projectDialog .lens-step:not(.lens-step-disabled) .lens-step-card:focus-within {
  border-color: color-mix(in srgb, var(--panel-border) 55%, var(--accent-color) 45%);
  box-shadow: var(--panel-shadow-hover);
  transform: translateY(-2px);
}

#projectDialog .lens-step-header {
  display: flex;
  align-items: center;
  gap: clamp(10px, 2vw, 16px);
}

#projectDialog .lens-step label,
#projectDialog .lens-options-label {
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  margin: 0;
}

#projectDialog .lens-step-indicator {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(36px, 4vw, 44px);
  height: clamp(36px, 4vw, 44px);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-color) 18%, var(--surface-color) 82%);
  color: var(--accent-color);
  font-weight: var(--font-weight-semibold);
  font-size: clamp(1rem, 2vw, 1.125rem);
}

#projectDialog .lens-step-body {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 2vw, 12px);
}

.lens-step .select-wrapper {
  width: 100%;
}

.lens-step .select-wrapper select {
  width: 100%;
}

#projectDialog .lens-step-disabled {
  opacity: 0.55;
}

#projectDialog .lens-step-disabled .lens-step-card {
  box-shadow: none;
}

#projectDialog .lens-step-disabled select,
#projectDialog .lens-step-disabled .lens-options {
  pointer-events: none;
}

#projectDialog .lens-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(10px, 2.5vw, 16px);
  padding: clamp(10px, 2.5vw, 16px);
  border: 1px solid color-mix(in srgb, var(--panel-border) 70%, var(--accent-color) 30%);
  border-radius: 14px;
  background: color-mix(in srgb, var(--surface-elevated) 92%, var(--accent-color) 8%);
  max-height: 15rem;
  overflow-y: auto;
}

#projectDialog .lens-options-empty,
#projectDialog .lens-series-empty {
  margin: 0;
  font-size: var(--font-size-small);
  color: var(--text-muted);
}

#projectDialog .lens-option {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.45rem;
  border-radius: 10px;
  transition: background 0.2s ease;
}

#projectDialog .lens-option:hover {
  background: var(--surface-focus);
}

#projectDialog .lens-option:focus-within {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
  background: var(--surface-focus);
}

#projectDialog .lens-option input[type="checkbox"] {
  flex-shrink: 0;
}

#projectDialog .lens-option-label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.3;
}

#projectDialog .lens-option-name {
  font-weight: var(--font-weight-medium);
  color: var(--text-color);
}

#projectDialog .lens-option-meta {
  font-size: var(--font-size-small);
  color: var(--text-muted);
}

#projectDialog .lens-selection-summary {
  display: flex;
  flex-direction: column;
}

#projectDialog .lens-selection-card {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 2vw, 16px);
  padding: clamp(16px, 3vw, 20px);
  border-radius: 16px;
  border: 1px solid var(--panel-border);
  background: var(--surface-elevated);
  box-shadow: var(--panel-shadow);
}

#projectDialog .lens-selection-header {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

@media (min-width: 768px) {
  #projectDialog .lens-selection-header {
    align-items: center;
    flex-direction: row;
    justify-content: space-between;
  }
}

#projectDialog .lens-selection-heading {
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
}

#projectDialog .lens-selection-hint {
  font-size: var(--font-size-small);
  color: var(--text-muted);
}

#projectDialog .lens-selection-chips {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(8px, 2vw, 12px);
}

#projectDialog .lens-chip {
  display: inline-flex;
  align-items: center;
  gap: clamp(8px, 2vw, 12px);
  padding: clamp(6px, 1.5vw, 10px) clamp(12px, 3vw, 16px);
  border-radius: 999px;
  background: var(--surface-elevated);
  border: 1px solid var(--panel-border);
  box-shadow: var(--panel-shadow);
}

#projectDialog .lens-chip-label {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

#projectDialog .lens-chip-name {
  font-weight: var(--font-weight-medium);
  color: var(--text-color);
}

#projectDialog .lens-chip-focal {
  font-size: var(--font-size-small);
  color: var(--text-muted);
}

#projectDialog .lens-chip select {
  min-width: clamp(80px, 18vw, 128px);
}

#projectDialog .lens-chip-remove {
  border: none;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  color: var(--text-muted);
  transition: background 0.2s ease, color 0.2s ease;
}

#projectDialog .lens-chip-remove:hover,
#projectDialog .lens-chip-remove:focus-visible {
  background: var(--surface-focus);
  color: var(--accent-color);
  outline: none;
}

#projectDialog .lens-chip-remove .icon-glyph {
  font-size: 1.1rem;
  line-height: 1;
}

.project-dialog-footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  border-top: 1px solid var(--panel-border);
  padding-top: clamp(12px, 2vw, 16px);
}

/* Project requirement boxes */
.requirements-grid {
  display: grid;
  gap: 10px;
  margin-bottom: 1em;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  align-items: stretch;
}
.requirement-box {
  background: var(--surface-color);
  border: 1px solid var(--panel-border);
  border-radius: 8px;
  text-align: center;
  padding: 10px;
  box-shadow: var(--panel-shadow);
  --requirement-accent-color: var(--text-color);
  min-width: 0;
}
.requirement-box .req-icon {
  --req-icon-size: calc(var(--font-size-relative-base) * var(--font-scale-xxxl));
  --icon-size: var(--req-icon-size);
  font-size: var(--icon-size);
  width: var(--icon-size);
  height: var(--icon-size);
  min-width: var(--icon-size);
  min-height: var(--icon-size);
  max-width: var(--icon-size);
  max-height: var(--icon-size);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 5px;
  line-height: 1;
  flex-shrink: 0;
  color: var(--requirement-accent-color);
  --icon-color: var(--requirement-accent-color);
}

.requirement-box .req-icon svg {
  width: var(--icon-size);
  height: var(--icon-size);
  max-width: 100%;
  max-height: 100%;
  display: block;
}
.requirement-box .req-label {
  font-weight: var(--font-weight-bold);
  display: block;
  color: var(--requirement-accent-color);
}
.requirement-box .req-value {
  display: block;
  margin-top: 4px;
}
.requirement-box .req-value .req-primary-line {
  font-weight: var(--font-weight-medium);
}
.requirement-box .req-value .req-sub-label {
  font-weight: var(--font-weight-medium);
  color: var(--text-muted);
}
.requirement-box .req-value .req-sub-line {
  font-weight: var(--font-weight-regular);
}

body:not(.dark-mode) .requirement-box,
#overviewDialogContent:not(.dark-mode) .requirement-box,
body:not(.dark-mode) #projectRequirementsOutput .requirement-box {
  --requirement-accent-color: var(--accent-color);
}

body.dark-mode .requirement-box,
#overviewDialogContent.dark-mode .requirement-box {
  --requirement-accent-color: var(--inverse-text-color);
}

/* Expand production company details and let project scenarios span the full row for clarity */
.requirements-grid .requirement-box[data-field="productionCompany"][data-has-address="true"] {
  grid-column: span 2;
}

.requirements-grid .requirement-box[data-field="requiredScenarios"],
.requirements-grid .requirement-box[data-field="shootingScenarios"],
.requirements-grid .requirement-box[data-field="shootingScenario"] {
  grid-column: 1 / -1;
}

/* Overview dialog */
#overviewDialog {
  width: min(96vw, 210mm);
  max-width: none;
  padding: 0;
  border: none;
}
#overviewDialog::backdrop {
  background: rgba(0, 0, 0, 0.5);
}
#overviewDialogContent {
  padding: 20px;
  max-height: min(92vh, 1100px);
  overflow-y: auto;
  background: var(--surface-color);
  color: var(--control-text);
  font-family: var(--font-family);
  font-weight: var(--font-weight-light);
}

#overviewDialogContent:not(.dark-mode) {
  --surface-color: #ffffff;
  --panel-bg: #ffffff;
  background-color: #ffffff;
}
#overviewDialogContent h1,
#overviewDialogContent h2,
#overviewDialogContent h3 {
  font-family: var(--font-family);
  font-weight: var(--font-weight-regular);
  color: var(--text-color);
}

#overviewDialogContent:not(.dark-mode) h1,
#overviewDialogContent:not(.dark-mode) h2,
#overviewDialogContent:not(.dark-mode) h3 {
  color: var(--accent-color);
}
#overviewDialogContent h1 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-display));
  margin-bottom: 0.2em;
}

#printLogo {
  display: none;
}
#overviewDialogContent h2 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxl));
  margin-top: 1.3em;
  border-bottom: 1px solid var(--divider-color);
  padding-bottom: 5px;
}

#overviewDialogContent:not(.dark-mode) h2 {
  border-bottom: 1px solid var(--accent-color);
}
#overviewDialogContent h3 {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  margin-top: 1em;
}
#overviewDialogContent table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 5px;
  table-layout: fixed;
}
#overviewDialogContent th,
#overviewDialogContent td {
  border: 1px solid var(--panel-border);
  padding: 8px;
  text-align: left;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  overflow: hidden;
}
#overviewDialogContent th {
  background-color: var(--control-bg);
  font-weight: var(--font-weight-bold);
}
#overviewDialogContent tr:nth-child(even) {
  background-color: var(--panel-bg);
}
#overviewDialogContent .device-block {
  background: #ffffff;
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  padding: 6px 10px;
  box-shadow: var(--panel-shadow);
  font-size: var(--font-size-diagram-text);
}
#overviewDialogContent .device-block strong {
  display: block;
  margin-bottom: 4px;
  font-weight: var(--font-weight-bold);
}
#overviewDialogContent .device-category-container {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
#overviewDialogContent .device-category {
  background: #ffffff;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  padding: 10px;
  margin-bottom: 10px;
  flex: 1 1 calc((100% - 20px) / 3);
  box-sizing: border-box;
  box-shadow: var(--panel-shadow);
}
#overviewDialogContent .device-category h3 {
  font-family: var(--font-family);
  font-weight: var(--font-weight-regular);
  margin-top: 0;
  margin-bottom: 5px;
  border-bottom: 1px solid var(--divider-color);
  padding-bottom: 3px;
}
#overviewDialogContent .device-block-grid {
  display: grid;
  gap: 8px;
}
#overviewDialogContent .device-block-grid.single-column {
  grid-template-columns: 1fr;
}
#overviewDialogContent .device-block-grid.two-column {
  grid-template-columns: repeat(2, 1fr);
}
#overviewDialogContent .device-block-grid.fiz-single-column {
  grid-template-columns: 1fr;
}

@media screen and (max-width: 600px) {
  #overviewDialogContent .device-category-container {
    flex-direction: column;
  }

  #overviewDialogContent .device-category {
    flex: 1 1 100%;
  }

  #overviewDialogContent .device-block-grid.two-column {
    grid-template-columns: 1fr;
  }
}
#overviewDialogContent.pink-mode {
  --accent-color: #ff69b4;
  --logo-accent-color: var(--brand-accent-color);
}
#overviewDialogContent.dark-mode {
  background-color: var(--background-color);
  color: var(--text-color);
}
#overviewDialogContent.dark-mode h1,
#overviewDialogContent.dark-mode h2,
#overviewDialogContent.dark-mode h3 {
  color: var(--text-color);
}
#overviewDialogContent.dark-mode h2 {
  border-bottom: 1px solid var(--divider-color);
}
#overviewDialogContent.dark-mode th {
  background-color: var(--control-bg);
}
#overviewDialogContent.dark-mode tr:nth-child(even) {
  background-color: #1a1a1a;
}
#overviewDialogContent.dark-mode .device-category {
  background: var(--panel-bg);
  border-color: var(--panel-border);
  box-shadow: var(--panel-shadow);
}
#overviewDialogContent.dark-mode .device-block {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--control-border);
  box-shadow: var(--panel-shadow);
}

.gear-table {
  width: 100%;
  border-collapse: collapse;
}

.gear-table td {
  padding: 4px 0;
  border-left: none;
  border-right: none;
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
  background: var(--panel-bg);
  line-height: var(--line-height-relaxed);
  break-inside: avoid;
  page-break-inside: avoid;
}

.gear-table tbody {
  break-inside: avoid;
  page-break-inside: avoid;
}

.gear-table .category-row {
  break-after: avoid;
  break-after: avoid-page;
  page-break-after: avoid;
}

.gear-table .auto-gear-item {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  box-shadow: none;
  --auto-gear-rule-bg: var(--auto-gear-highlight-bg);
  --auto-gear-rule-border: var(--auto-gear-highlight-border);
  --auto-gear-rule-text: var(--auto-gear-highlight-text);
}

#gearListOutput .gear-item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: wrap;
  word-break: break-word;
}

#gearListOutput .gear-item .gear-item-text {
  display: inline;
}

#gearListOutput .gear-item-note:not([hidden]) {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.45rem;
  padding: 0.35rem 0.6rem;
  border-radius: calc(var(--border-radius) * 0.9);
  border: 1px solid color-mix(in srgb, var(--panel-border) 65%, var(--accent-color) 35%);
  background: color-mix(in srgb, var(--panel-bg) 88%, var(--accent-color) 12%);
  color: color-mix(in srgb, var(--text-color) 88%, var(--accent-color) 12%);
  font-size: 0.85rem;
  line-height: 1.4;
  letter-spacing: 0.01em;
  word-break: break-word;
  white-space: normal;
}

.dark-mode #gearListOutput .gear-item-note:not([hidden]) {
  border-color: color-mix(in srgb, var(--panel-border) 45%, var(--accent-color) 55%);
  background: color-mix(in srgb, var(--panel-bg) 75%, var(--accent-color) 25%);
  color: color-mix(in srgb, var(--text-color) 92%, var(--accent-color) 8%);
}

#gearListOutput .gear-item-note__label {
  flex: 0 0 auto;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.045em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent-color) 70%, var(--text-color) 30%);
  margin-top: 0.05rem;
}

#gearListOutput .gear-item-note__text {
  flex: 1 1 auto;
  min-width: 0;
  color: inherit;
  white-space: normal;
}

.gear-item-provider {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--button-icon-gap);
  min-height: calc(var(--button-size) * 0.8);
  line-height: var(--button-line-height);
  padding-block: calc(var(--button-padding-block) + 2px);
  padding-inline: max(calc(var(--button-link-padding-inline) - 4px), var(--spacing-sm));
  border-radius: var(--border-radius);
  border: none;
  background: none;
  color: color-mix(in srgb, var(--text-color) 88%, var(--accent-color) 12%);
  font-size: calc(var(--form-control-font-size) * 0.9);
  font-weight: inherit;
  letter-spacing: 0.01em;
  text-decoration: none;
  text-align: center;
  word-break: break-word;
  cursor: default;
  box-shadow: none;
}

.gear-item-provider[data-provider-type='rental'] {
  background: color-mix(in srgb, var(--control-bg) 78%, var(--surface-color) 22%);
  border: none;
  color: color-mix(in srgb, var(--text-color) 92%, var(--neutral-color) 8%);
  font-weight: var(--font-weight-semibold);
  box-shadow: none;
}

.dark-mode #gearListOutput .gear-item-provider {
  border-color: transparent;
  background: none;
  color: color-mix(in srgb, var(--text-color) 92%, var(--accent-color) 8%);
  box-shadow: none;
}

.dark-mode .gear-item-provider[data-provider-type='rental'] {
  background: color-mix(in srgb, var(--control-bg) 70%, var(--surface-color) 30%);
  border: none;
  color: color-mix(in srgb, var(--text-color) 94%, var(--neutral-color) 6%);
  box-shadow: none;
}

.dark-mode #gearListOutput .gear-item-provider[data-provider-type='rental'] {
  background: color-mix(in srgb, var(--control-bg) 70%, var(--surface-color) 30%);
  border: none;
  color: color-mix(in srgb, var(--text-color) 94%, var(--neutral-color) 6%);
  box-shadow: none;
}

.pink-mode .gear-item-provider[data-provider-type='rental'] {
  background: color-mix(in srgb, var(--accent-color) 78%, var(--surface-color) 22%);
  border: none;
  color: color-mix(in srgb, var(--inverse-text-color) 90%, var(--accent-color) 10%);
  box-shadow: none;
}

.pink-mode #gearListOutput .gear-item-provider[data-provider-type='rental'] {
  background: color-mix(in srgb, var(--accent-color) 78%, var(--surface-color) 22%);
  border: none;
  color: color-mix(in srgb, var(--inverse-text-color) 90%, var(--accent-color) 10%);
  box-shadow: none;
}

.dark-mode.pink-mode .gear-item-provider[data-provider-type='rental'],
.pink-mode .dark-mode .gear-item-provider[data-provider-type='rental'] {
  color: color-mix(in srgb, var(--text-color) 92%, var(--inverse-text-color) 8%);
  border: none;
  box-shadow: none;
}

.dark-mode.pink-mode #gearListOutput .gear-item-provider[data-provider-type='rental'],
.pink-mode .dark-mode #gearListOutput .gear-item-provider[data-provider-type='rental'] {
  color: color-mix(in srgb, var(--text-color) 92%, var(--inverse-text-color) 8%);
  border: none;
  box-shadow: none;
}

.gear-item-owned-export {
  margin-inline-start: 0.4rem;
  font-size: calc(var(--form-control-font-size) * 0.85);
  background: linear-gradient(
    to bottom,
    color-mix(in srgb, var(--panel-bg) 96%, var(--accent-color) 4%) 0%,
    color-mix(in srgb, var(--control-bg) 94%, var(--accent-color) 6%) 100%
  );
  border-color: color-mix(in srgb, var(--panel-border) 80%, var(--accent-color) 20%);
}

.dark-mode #gearListOutput .gear-item-owned-export {
  background: color-mix(in srgb, var(--panel-bg) 88%, var(--accent-color) 12%);
  border-color: color-mix(in srgb, var(--panel-border) 55%, var(--accent-color) 45%);
}

.gear-item-camera-link {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2xs);
  margin-inline-start: 0.35rem;
  font-size: 0.8rem;
  line-height: 1;
  --camera-link-color: var(--danger-color);
  --camera-link-text-color: var(--inverse-text-color);
}

.gear-item-camera-link[hidden] {
  display: none !important;
}

.gear-item-camera-link__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25em;
  min-height: 1.25em;
  padding-inline: 0.25em;
  border-radius: 0.35em;
  background: var(--camera-link-color, var(--danger-color));
  color: var(--camera-link-text-color, var(--inverse-text-color));
  font-weight: var(--font-weight-bold);
  font-size: 0.95em;
  letter-spacing: 0.02em;
}

#gearListOutput .auto-gear-rule-badge {
  display: none;
  margin-left: 0.75rem;
  padding: 0.1rem 0.6rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  background: color-mix(in srgb, var(--auto-gear-rule-bg, var(--auto-gear-highlight-bg)) 65%, transparent);
  border: 1px solid color-mix(in srgb, var(--auto-gear-rule-border, var(--auto-gear-highlight-border)) 75%, transparent);
  color: var(--auto-gear-rule-text, var(--auto-gear-highlight-text));
  white-space: nowrap;
}

#gearListOutput.show-auto-gear-highlight .auto-gear-rule-badge {
  display: inline-flex;
  align-items: center;
}

#gearListOutput.show-auto-gear-highlight .auto-gear-item {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5em;
  flex-wrap: wrap;
  max-width: 100%;
  padding: 0.1em 0.5em;
  margin-block: 0.15em;
  border-radius: calc(var(--border-radius) * 0.75);
  background: var(--auto-gear-rule-bg, var(--auto-gear-highlight-bg));
  box-shadow: 0 0 0 2px var(--auto-gear-rule-border, var(--auto-gear-highlight-border));
  color: var(--auto-gear-rule-text, var(--auto-gear-highlight-text));
  white-space: normal;
  word-break: break-word;
}

#gearListOutput.show-auto-gear-highlight .auto-gear-item select {
  border-color: var(--auto-gear-rule-border, var(--auto-gear-highlight-border));
  background: color-mix(in srgb, var(--auto-gear-rule-bg, var(--auto-gear-highlight-bg)) 60%, transparent);
  color: var(--auto-gear-rule-text, var(--auto-gear-highlight-text));
}

.dark-mode #gearListOutput.show-auto-gear-highlight .auto-gear-item select {
  background: color-mix(in srgb, var(--auto-gear-rule-bg, var(--auto-gear-highlight-bg)) 70%, transparent);
}

#gearListOutput .cage-select-wrapper {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
}

#gearListOutput .cage-select-wrapper > span {
  white-space: nowrap;
}

#gearListOutput .cage-select-wrapper select {
  flex: 0 1 auto;
  max-width: 100%;
}

#gearListOutput .gear-table select {
  padding-block: 0;
  padding-inline: 0.35rem;
}

.gear-table .category-row td {
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
  font-weight: var(--font-weight-regular);
  color: var(--accent-color);
  break-after: avoid;
  page-break-after: avoid;
}

#gearListOutput .gear-category-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

#gearListOutput .gear-standard-items + .gear-custom-section {
  margin-top: 0.75rem;
}

#gearListOutput .gear-standard-items .gear-item {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  width: 100%;
  white-space: normal;
}

#gearListOutput .gear-custom-section {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0;
}

#gearListOutput .gear-category-header + .gear-custom-section {
  margin-top: 0.5rem;
}

.gear-item-extra-indicator {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  padding: 0.1rem 0.55rem;
  border-radius: 999px;
  font-size: 0.85em;
  font-weight: var(--font-weight-semibold);
  background: var(--gear-extra-indicator-bg);
  color: var(--gear-extra-indicator-text);
  border: 1px solid color-mix(in srgb, var(--gear-extra-indicator-text) 45%, transparent);
  margin-right: 0.4rem;
  margin-bottom: 0.2rem;
}

.gear-item-extra-indicator[hidden] {
  display: none !important;
}

#gearListOutput .gear-custom-add-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: var(--button-size);
  min-width: var(--button-size);
  height: var(--button-size);
  min-height: var(--button-size);
  line-height: 1;
  background-color: var(--control-bg);
  color: var(--control-text);
  border: none;
  box-shadow: none;
  --button-bg: var(--control-bg);
  --button-text: var(--control-text);
  --button-border: transparent;
  --button-shadow: none;
  --button-hover-shadow: none;
  --button-hover-factor: 1;
  --button-active-factor: 1;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

#gearListOutput .gear-custom-add-btn:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  background-color: var(--control-hover-bg);
  color: var(--control-text);
}

#gearListOutput .gear-custom-add-btn:hover {
  background-color: var(--control-hover-bg);
  color: var(--control-text);
}

#gearListOutput .gear-custom-add-btn:active {
  background-color: var(--control-active-bg);
  color: var(--control-text);
  transform: translateY(0);
}

#gearListOutput .gear-custom-items {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

#gearListOutput .gear-custom-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.65rem 0.75rem;
  border-radius: calc(var(--border-radius) * 0.85);
  border: 1px dashed color-mix(in srgb, var(--accent-color) 40%, transparent);
  background: color-mix(in srgb, var(--panel-bg) 92%, transparent);
}

#gearListOutput .gear-custom-item-summary {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

#gearListOutput .gear-custom-item .gear-item-note:not([hidden]) {
  align-self: stretch;
}

#gearListOutput .gear-custom-item-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  flex-shrink: 0;
}

#gearListOutput .gear-item-edit-btn {
  margin: 0;
  margin-top: 0;
  align-self: center;
  padding: 0.15rem;
  min-height: 1.5rem;
  min-width: 1.5rem;
  line-height: 1;
  background-color: var(--control-bg);
  color: var(--control-text);
  border: none;
  box-shadow: none;
  --button-bg: var(--control-bg);
  --button-text: var(--control-text);
  --button-border: transparent;
  --button-shadow: none;
  --button-hover-shadow: none;
  --button-hover-factor: 1;
  --button-active-factor: 1;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

#gearListOutput .gear-item-edit-btn:hover,
#gearListOutput .gear-item-edit-btn:focus-visible {
  background-color: var(--control-hover-bg);
  color: var(--control-text);
}

#gearListOutput .gear-item-edit-btn:focus-visible {
  outline: none;
}

#gearListOutput .gear-item-edit-btn:active {
  background-color: var(--control-active-bg);
  color: var(--control-text);
  transform: translateY(0);
}

#gearListOutput .gear-item-edit-btn .btn-icon {
  --icon-size: calc(var(--button-icon-size) * 0.55);
  font-size: calc(var(--button-icon-size) * 0.7);
}

#gearListOutput .gear-item-rental-excluded {
  color: color-mix(in srgb, var(--text-color) 68%, var(--muted-text-color, #666) 32%);
}

#gearListOutput .gear-custom-item.gear-item-rental-excluded {
  border-style: solid;
  border-color: color-mix(in srgb, var(--accent-color) 42%, transparent);
  background: color-mix(in srgb, var(--panel-bg) 82%, var(--accent-color) 18%);
}

.dark-mode #gearListOutput .gear-custom-item.gear-item-rental-excluded,
body.dark-mode #gearListOutput .gear-custom-item.gear-item-rental-excluded {
  border-color: color-mix(in srgb, var(--accent-color) 58%, var(--control-border));
  background: color-mix(in srgb, var(--control-bg) 68%, var(--accent-color) 32%);
}

#overviewDialogContent .gear-item[data-rental-note]::after {
  display: none;
  content: attr(data-rental-note);
  margin-inline-start: 0.35rem;
  padding: 0.1rem 0.55rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  background: color-mix(in srgb, var(--accent-color) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent-color) 38%, transparent);
  color: color-mix(in srgb, var(--accent-color) 68%, var(--text-color));
  white-space: nowrap;
}

#overviewDialogContent.dark-mode .gear-item[data-rental-note]::after {
  background: color-mix(in srgb, var(--accent-color) 32%, transparent);
  border-color: color-mix(in srgb, var(--accent-color) 52%, transparent);
  color: var(--inverse-text-color);
}

#overviewDialogContent .gear-item-rental-excluded {
  color: color-mix(in srgb, var(--text-color) 62%, var(--muted-text-color, #666) 38%);
}

#overviewDialogContent .gear-item-rental-excluded::after {
  display: inline-flex;
  align-items: center;
}

#overviewDialogContent.rental-print-mode .gear-item-rental-excluded,
#overviewDialogContent.rental-print-mode .gear-item-rental-excluded::after {
  display: none !important;
}

#overviewDialogContent.rental-print-mode .gear-item-rental-excluded + br {
  display: none !important;
}

#overviewDialogContent.rental-print-mode .print-section-hidden {
  display: none !important;
}

#gearListOutput .gear-custom-item-preview {
  display: block;
  font-weight: var(--font-weight-medium);
  word-break: break-word;
}

#gearListOutput .gear-custom-remove-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.65rem;
  border-radius: var(--border-radius);
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-color);
  cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
  --button-bg: transparent;
  --button-text: var(--text-color);
  --button-border: transparent;
  --button-shadow: none;
  --button-hover-shadow: none;
  --button-hover-factor: 1;
  --button-active-factor: 1;
}

#gearListOutput .gear-custom-remove-btn:hover,
#gearListOutput .gear-custom-remove-btn:focus-visible {
  color: var(--accent-color);
  border-color: color-mix(in srgb, var(--accent-color) 45%, transparent);
  background: color-mix(in srgb, var(--accent-color) 10%, transparent);
}

#gearListOutput .gear-custom-remove-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 20%, transparent);
}

#gearListOutput .gear-custom-add-btn .btn-icon,
#gearListOutput .gear-custom-remove-btn .btn-icon {
  font-size: var(--button-icon-size);
  margin: 0;
}

#gearListOutput .gear-custom-remove-btn span {
  white-space: nowrap;
}

#gearListOutput .gear-category-label {
  font-weight: var(--font-weight-regular);
}

#gearListOutput .gear-custom-section:empty {
  display: none;
}

#gearListOutput .gear-custom-items:empty::before {
  content: '';
}

@media print {
  #gearListOutput .gear-custom-add-btn,
  #gearListOutput .gear-custom-remove-btn,
  #gearListOutput .gear-item-edit-btn,
  #gearListOutput .gear-custom-item-actions {
    display: none !important;
  }

  #gearListOutput .gear-custom-item {
    border: none;
    padding: 0.15rem 0;
    background: transparent;
  }

  #gearListOutput .gear-custom-item-preview {
    display: block;
  }

  #gearListOutput .gear-custom-item .gear-item-note:not([hidden]) {
    display: block;
    padding: 0;
    background: transparent;
    color: inherit;
  }
}

.gear-table .category-group[data-gear-table-category="Monitoring"] tr:not(.category-row) td,
.gear-table .category-group[data-gear-table-category="Monitoring Batteries"] tr:not(.category-row) td,
.gear-table .category-group[data-gear-table-category="Monitoring support"] tr:not(.category-row) td {
  color: var(--text-color);
}

#gearListOutput.show-auto-gear-highlight .category-group[data-gear-table-category="Monitoring"] .auto-gear-item,
#gearListOutput.show-auto-gear-highlight .category-group[data-gear-table-category="Monitoring Batteries"] .auto-gear-item,
#gearListOutput.show-auto-gear-highlight .category-group[data-gear-table-category="Monitoring support"] .auto-gear-item,
#gearListOutput.show-auto-gear-highlight .category-group[data-gear-table-category="Monitoring"] .auto-gear-item select,
#gearListOutput.show-auto-gear-highlight .category-group[data-gear-table-category="Monitoring Batteries"] .auto-gear-item select,
#gearListOutput.show-auto-gear-highlight .category-group[data-gear-table-category="Monitoring support"] .auto-gear-item select {
  color: var(--text-color);
}

.gear-item[data-gear-name^="ND Grad HE Filter Set"],
.gear-item[data-gear-name^="ND Grad SE Filter Set"] {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  padding: 0.15em 0.45em;
  border: 1px solid var(--nd-grad-border-color, var(--accent-color));
  border-radius: calc(var(--border-radius) * 0.75);
  background-color: color-mix(in srgb, var(--panel-bg) 88%, transparent);
}

#gearListFilterDetails .filter-detail[data-gear-name^="ND Grad HE Filter Set"],
#gearListFilterDetails .filter-detail[data-gear-name^="ND Grad SE Filter Set"] {
  padding: 0.35rem 0.5rem;
  border: 1px solid var(--nd-grad-border-color, var(--accent-color));
  border-radius: calc(var(--border-radius) * 0.75);
  background-color: color-mix(in srgb, var(--panel-bg) 88%, transparent);
  align-items: flex-start;
}

#gearListFilterDetails .filter-detail[data-gear-name^="ND Grad HE Filter Set"] .filter-detail-label,
#gearListFilterDetails .filter-detail[data-gear-name^="ND Grad SE Filter Set"] .filter-detail-label {
  display: block;
  padding: 0;
  margin: 0;
  border: none;
  background: none;
}

#gearListFilterDetails .filter-detail[data-gear-name^="ND Grad HE Filter Set"] .filter-detail-controls,
#gearListFilterDetails .filter-detail[data-gear-name^="ND Grad SE Filter Set"] .filter-detail-controls {
  width: 100%;
}

body.light-mode .gear-table strong,
#gearListOutput:not(.dark-mode) .gear-table strong,
#overviewDialogContent:not(.dark-mode) .gear-table strong {
  color: inherit;
}

.dark-mode .gear-table td {
  border-top: 1px solid var(--inverse-text-color);
  border-bottom: 1px solid var(--inverse-text-color);
}

.dark-mode .gear-table .category-row td {
  border-top: 1px solid var(--inverse-text-color);
  border-bottom: 1px solid var(--inverse-text-color);
  color: var(--inverse-text-color);
  font-weight: var(--font-weight-medium);
}

.dark-mode.pink-mode .gear-table td,
.dark-mode.dark-accent-boost:not(.pink-mode) .gear-table td {
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
}

.dark-mode.pink-mode .gear-table .category-row td,
.dark-mode.dark-accent-boost:not(.pink-mode) .gear-table .category-row td {
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
  color: var(--accent-color);
  font-weight: var(--font-weight-medium);
}

#overviewDialogContent .gear-table td {
  padding: 4px 0;
  border-left: none;
  border-right: none;
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
  background: var(--panel-bg);
  line-height: var(--line-height-relaxed);
  break-inside: avoid;
  page-break-inside: avoid;
}

#overviewDialogContent .gear-table .category-row td {
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
  font-weight: var(--font-weight-bold);
  color: var(--accent-color);
  break-after: avoid;
  page-break-after: avoid;
}

#overviewDialogContent.dark-mode .gear-table td {
  border-top: 1px solid var(--inverse-text-color);
  border-bottom: 1px solid var(--inverse-text-color);
}

#overviewDialogContent.dark-mode .gear-table .category-row td {
  border-top: 1px solid var(--inverse-text-color);
  border-bottom: 1px solid var(--inverse-text-color);
  color: var(--inverse-text-color);
}

#overviewDialogContent.dark-mode.pink-mode .gear-table td {
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
}

#overviewDialogContent.dark-mode.pink-mode .gear-table .category-row td {
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
  color: var(--accent-color);
}

#gearListOutput,
#projectRequirementsOutput {
  background: var(--panel-bg);
  color: var(--text-color);
  padding: 10px;
  border: 1px solid var(--panel-border);
  border-radius: var(--border-radius);
  margin-top: 10px;
  overflow-x: auto;
}

#gearListOutput h1,
#gearListOutput h2,
#gearListOutput h3 {
  color: var(--accent-color);
}

#gearListOutput h2 {
  border-bottom: 1px solid var(--accent-color);
}

body:not(.dark-mode) #gearListOutput h2,
#gearListOutput:not(.dark-mode) h2 {
  font-weight: var(--font-weight-medium);
}

.dark-mode #gearListOutput h1,
.dark-mode #gearListOutput h2,
.dark-mode #gearListOutput h3,
#gearListOutput.dark-mode h1,
#gearListOutput.dark-mode h2,
#gearListOutput.dark-mode h3 {
  color: var(--inverse-text-color);
}

.dark-mode #gearListOutput h2,
#gearListOutput.dark-mode h2 {
  border-bottom: 1px solid var(--inverse-text-color);
}

body.dark-mode.pink-mode #gearListOutput h1,
body.dark-mode.pink-mode #gearListOutput h2,
body.dark-mode.pink-mode #gearListOutput h3,
#gearListOutput.dark-mode.pink-mode h1,
#gearListOutput.dark-mode.pink-mode h2,
#gearListOutput.dark-mode.pink-mode h3 {
  color: var(--accent-color);
}

body.dark-mode.pink-mode #gearListOutput h2,
#gearListOutput.dark-mode.pink-mode h2 {
  border-bottom: 1px solid var(--accent-color);
}

#gearListFilterDetails {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  margin-top: 0.25rem;
  line-height: inherit;
}

#gearListFilterDetails.hidden {
  display: none;
}

#gearListFilterDetails .filter-detail {
  display: grid;
  grid-template-columns: minmax(6.5rem, max-content) minmax(0, 1fr);
  column-gap: 0.5rem;
  row-gap: 0.125rem;
  align-items: center;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
}

#gearListFilterDetails .filter-detail-label {
  font-size: inherit;
  font-weight: inherit;
  min-width: 0;
  margin-right: 0;
  line-height: inherit;
  align-items: center;
  gap: 0.35rem;
}

#gearListFilterDetails .filter-detail-controls {
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 0.375rem 0.5rem;
  align-items: center;
}

#gearListFilterDetails .filter-detail-size {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-weight: var(--font-weight-regular);
  padding: 0;
  border: none;
  background: none;
}

#gearListFilterDetails .filter-detail-size .select-wrapper {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

#gearListFilterDetails .filter-detail-size .select-wrapper select {
  min-width: 3.5rem;
  margin: 0;
  width: var(--gear-select-width, auto);
}

#gearListFilterDetails .filter-detail-size .select-wrapper select:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

#gearListFilterDetails .filter-detail-values {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  align-items: center;
}

#gearListFilterDetails .filter-detail-sublabel {
  font-weight: var(--font-weight-light);
}

#gearListFilterDetails .filter-detail-sublabel::after {
  content: ':';
}

#gearListFilterDetails .filter-values-container {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.25rem;
}

#gearListFilterDetails .filter-value-option {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.125rem 0.5rem;
  border-radius: var(--border-radius);
  border: 1px solid transparent;
  background-color: transparent;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

#gearListFilterDetails .filter-value-option:hover {
  border-color: var(--accent-color);
  background-color: var(--panel-bg);
}

#gearListFilterDetails .filter-value-option:focus-within {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 1px var(--accent-color);
  background-color: var(--panel-bg);
}

@media (max-width: 640px) {
  #gearListFilterDetails .filter-detail {
    grid-template-columns: minmax(0, 1fr);
  }

  #gearListFilterDetails .filter-detail-label {
    margin-bottom: 0.125rem;
  }
}

@supports (color: color-mix(in srgb, #000 50%, white)) {
  #gearListFilterDetails .filter-detail-size:focus-within {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 35%, transparent);
    background-color: color-mix(in srgb, var(--accent-color) 12%, var(--panel-bg));
  }

  #gearListFilterDetails .filter-value-option:hover {
    background-color: color-mix(in srgb, var(--accent-color) 8%, var(--panel-bg));
  }

  #gearListFilterDetails .filter-value-option:focus-within {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 35%, transparent);
    background-color: color-mix(in srgb, var(--accent-color) 12%, var(--panel-bg));
  }
}

#gearListFilterDetails .filter-value-option input[type="checkbox"] {
  margin: 0;
  padding: 0;
  accent-color: var(--accent-color);
}

#gearListFilterDetails .filter-value-option input[type="checkbox"]:focus-visible {
  outline: none;
}

#gearListOutput .select-wrapper,
#projectRequirementsOutput .select-wrapper {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
  vertical-align: middle;
}

#gearListOutput select,
#projectRequirementsOutput select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
}

#gearListOutput .select-wrapper select,
#projectRequirementsOutput .select-wrapper select {
  flex: 0 0 auto;
  width: var(--gear-select-width, auto);
  max-width: 100%;
}

#gearListOutput .select-wrapper .favorite-toggle,
#projectRequirementsOutput .select-wrapper .favorite-toggle {
  flex: 0 0 auto;
  margin-inline-end: var(--gap-size);
  margin-right: var(--gap-size);
}

#gearListActions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 1rem;
}

#gearListActions .gear-list-autosave-note {
  flex-basis: 100%;
  margin: 0;
  display: block;
  padding: 0.65rem calc(var(--button-padding-inline) * 0.9);
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in srgb, var(--accent-color) 45%, transparent);
  background: color-mix(in srgb, var(--surface-color) 92%, var(--accent-color) 8%);
  color: var(--control-text);
  font-size: calc(var(--font-size-base) * var(--font-scale-sm));
  font-weight: var(--font-weight-medium);
  line-height: 1.4;
  text-align: left;
  cursor: default;
  transition: none;
}

#gearListActions .gear-list-action-btn {
  margin: 0;
  border: 1px solid color-mix(in srgb, var(--accent-color) 45%, transparent);
  background: color-mix(in srgb, var(--surface-color) 92%, var(--accent-color) 8%);
  color: var(--control-text);
  font-weight: var(--font-weight-medium);
  justify-content: flex-start;
  padding-inline: calc(var(--button-padding-inline) * 0.9);
  min-width: 0;
}

#gearListActions .gear-list-action-btn .btn-icon {
  margin-inline-end: var(--icon-gap);
  color: currentColor;
}

#gearListActions .gear-list-action-btn:hover,
#gearListActions .gear-list-action-btn:focus-visible {
  background: var(--accent-color);
  color: var(--inverse-text-color);
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 35%, transparent);
}

#gearListActions .gear-list-action-btn:focus-visible {
  outline: none;
}

#gearListActions .gear-list-action-btn.is-active {
  background: var(--accent-color);
  color: var(--inverse-text-color);
  border-color: var(--accent-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-color) 45%, transparent);
}

.gear-list-autosave-note--overlay {
  position: fixed;
  left: 50%;
  bottom: calc(env(safe-area-inset-bottom, 0px) + clamp(1rem, 3vw, 2.5rem));
  transform: translate(-50%, 1rem);
  max-width: min(90vw, 40rem);
  padding: 0.75rem 1rem;
  border-radius: var(--border-radius);
  border: 2px solid var(--panel-border);
  background: var(--surface-color);
  color: var(--text-color);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
  text-align: center;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-sm));
  line-height: 1.4;
  pointer-events: none;
  z-index: 240;
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.gear-list-autosave-note--overlay.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

#settingsDialog.has-gear-list-note .settings-content {
  padding-bottom: clamp(6rem, 12vw, 8rem);
}

@media (max-width: 600px) {
  #settingsDialog.has-gear-list-note .settings-content {
    padding-bottom: clamp(7rem, 24vw, 10rem);
  }
}

@media (max-width: 600px) {
  .gear-list-autosave-note--overlay {
    padding: 0.75rem;
    font-size: calc(var(--font-size-relative-base) * var(--font-scale-xs));
  }
}

@media (max-width: 600px) {
  #gearListOutput,
  #projectRequirementsOutput {
    overflow-x: visible;
  }
  #gearListOutput table,
  #projectRequirementsOutput table,
  #gearListOutput select,
  #projectRequirementsOutput select {
    width: 100%;
    max-width: 100%;
  }
  #gearListOutput .cage-select-wrapper {
    width: 100%;
  }
  #gearListOutput .cage-select-wrapper select {
    width: auto;
    flex: 1 1 auto;
    min-width: 0;
  }
  #gearListOutput .select-wrapper,
  #projectRequirementsOutput .select-wrapper {
    display: flex;
    width: 100%;
  }
  #gearListFilterDetails .filter-detail-size .select-wrapper {
    display: inline-flex;
    width: auto;
  }
  #gearListOutput .select-wrapper select,
  #projectRequirementsOutput .select-wrapper select {
    flex: 1 1 auto;
  }
  #gearListFilterDetails .filter-detail-size .select-wrapper select {
    flex: 0 0 auto;
    width: var(--gear-select-width, auto);
  }
  #gearListOutput select,
  #projectRequirementsOutput select {
    box-sizing: border-box;
  }
  #gearListOutput td,
  #projectRequirementsOutput td {
    white-space: normal;
    overflow-wrap: anywhere;
  }
}

/* Sidebar menu */
#menuToggle {
  background: none;
  border: none;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xxxl));
}

#sideMenu .sidebar-header {
  display: none;
}

#sideMenuTitle {
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-xl));
  margin: 0;
}

#sideMenu .sidebar-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 6px;
  border: none;
  background: none;
  color: var(--text-color);
  font: inherit;
  cursor: pointer;
  border-radius: 8px;
  min-width: 44px;
  min-height: 44px;
}

#sideMenu .sidebar-close:hover {
  color: var(--accent-color);
  background: color-mix(in srgb, var(--accent-color) 12%, transparent);
}

#sideMenu .sidebar-close:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
  background: color-mix(in srgb, var(--accent-color) 16%, transparent);
}

#sideMenu {
  position: fixed;
  top: 0;
  right: 0;
  height: 100%;
  width: 250px;
  background: var(--surface-color);
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.3);
  padding: calc(var(--page-padding) + 10px);
  padding-left: calc(var(--page-padding) + 20px);
  z-index: 200;
  transition: transform 0.3s ease;
  transform: translateX(100%);
}

#sideMenu.open {
  transform: translateX(0);
}

#sideMenu ul {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--accent-color);
  border-bottom: 1px solid var(--accent-color);
}

#sideMenu li {
  margin: 0;
}

#sideMenu li + li {
  border-top: 1px solid var(--accent-color);
}

#sideMenu li.sidebar-divider {
  padding: 8px 0;
  margin: 12px 0;
}

#sideMenu li.sidebar-divider + li {
  border-top: none;
}

#sideMenu a {
  color: var(--text-color);
  text-decoration: none;
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  display: block;
  padding: 10px 0;
}

#sideMenu button[data-sidebar-action] {
  display: block;
  width: 100%;
  padding: 10px 0;
  background: none;
  border: none;
  color: var(--text-color);
  font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  font-weight: inherit;
  text-align: left;
  cursor: pointer;
}

#sideMenu button[data-sidebar-action]:hover {
  color: var(--accent-color);
}

#sideMenu button[data-sidebar-action]:focus-visible {
  outline: 2px solid var(--accent-color);
  outline-offset: 2px;
}

body.light-mode #sideMenu ul {
  border-top: 1px solid color-mix(in srgb, var(--accent-color) 55%, var(--surface-color));
  border-bottom: 1px solid color-mix(in srgb, var(--accent-color) 55%, var(--surface-color));
}

body.light-mode #sideMenu li + li {
  border-top: 1px solid color-mix(in srgb, var(--accent-color) 45%, var(--surface-color));
}

body.light-mode #sideMenu a,
body.light-mode #sideMenu button[data-sidebar-action] {
  color: color-mix(in srgb, var(--accent-color) 72%, var(--text-color));
}

body.light-mode #sideMenu a:hover,
body.light-mode #sideMenu button[data-sidebar-action]:hover {
  color: var(--accent-color);
}

body.light-mode #sideMenu a:focus-visible,
body.light-mode #sideMenu button[data-sidebar-action]:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent-color) 70%, var(--surface-color));
  outline-offset: 3px;
}

.dark-mode,
#gearListOutput.dark-mode,
#overviewDialogContent.dark-mode {
  --nd-grad-border-color: #ffffff;
}

html.pink-mode,
body.pink-mode,
#gearListOutput.pink-mode,
#overviewDialogContent.pink-mode {
  --nd-grad-border-color: #ff69b4;
}

.dark-mode #sideMenu ul {
  border-color: var(--accent-color);
}

.dark-mode #sideMenu li + li {
  border-color: var(--accent-color);
}

@media (max-width: 768px) {
  body.menu-open {
    overflow: hidden;
  }

  #sideMenu {
    left: 0;
    right: 0;
    bottom: 0;
    top: auto;
    width: auto;
    max-width: 100%;
    max-height: min(80vh, 640px);
    border-radius: 18px 18px 0 0;
    box-shadow: 0 -6px 24px rgba(0, 0, 0, 0.35);
    transform: translateY(100%);
    padding: clamp(16px, 5vw, 28px);
    padding-bottom: clamp(20px, 6vw, 32px);
    overflow-y: auto;
  }

  #sideMenu.open {
    transform: translateY(0);
  }

  #sideMenu .sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: clamp(12px, 3vw, 18px);
  }

  #sideMenuTitle {
    font-size: calc(var(--font-size-relative-base) * var(--font-scale-lg));
  }

  #sideMenu .sidebar-controls {
    margin-bottom: clamp(12px, 3vw, 18px);
  }

  #sideMenu ul {
    border: none;
    border-radius: 14px;
    padding: clamp(8px, 3vw, 12px) clamp(4px, 2vw, 8px);
    background: var(--background-color);
    box-shadow: inset 0 0 0 1px var(--panel-border);
  }

  #sideMenu li + li {
    border-top: 1px solid var(--panel-border);
  }

  body.light-mode #sideMenu ul {
    background: color-mix(in srgb, var(--surface-color) 92%, white 8%);
  }

  body.light-mode #sideMenu li + li {
    border-top: 1px solid color-mix(in srgb, var(--panel-border) 75%, transparent);
  }

  body.dark-mode #sideMenu ul,
  .dark-mode #sideMenu ul {
    background: color-mix(in srgb, var(--surface-color) 78%, black 22%);
  }

  body.dark-mode #sideMenu li + li,
  .dark-mode #sideMenu li + li {
    border-top: 1px solid color-mix(in srgb, var(--panel-border) 65%, transparent);
  }
}

@media (max-width: 768px) and (prefers-reduced-motion: reduce) {
  #sideMenu,
  #sideMenu.open {
    transition: none;
  }
}

#menuOverlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 150;
}

@supports (padding: env(safe-area-inset-top)) {
  @media (min-width: 769px) {
    #sideMenu {
      padding:
        calc(var(--page-padding) + 10px + env(safe-area-inset-top))
        calc(var(--page-padding) + 10px + env(safe-area-inset-right))
        calc(var(--page-padding) + 10px + env(safe-area-inset-bottom))
        calc(var(--page-padding) + 20px + env(safe-area-inset-left));
    }
  }

  @media (max-width: 768px) {
    #sideMenu {
      padding-top: calc(clamp(16px, 5vw, 28px) + env(safe-area-inset-top));
      padding-right: calc(clamp(16px, 5vw, 28px) + env(safe-area-inset-right));
      padding-left: calc(clamp(16px, 5vw, 28px) + env(safe-area-inset-left));
    }
  }
}

@supports (padding: env(safe-area-inset-bottom)) {
  @media (max-width: 768px) {
    #sideMenu {
      padding-bottom: calc(clamp(20px, 6vw, 32px) + env(safe-area-inset-bottom));
    }
  }
}

@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
  }
}

@media print {
  /* Hide everything except the overview dialog when printing */
  body > :not(#overviewDialog) {
    display: none !important;
  }

  html,
  body,
  #overviewDialogContent {
    --status-success-text-color: #000 !important;
    --status-warning-text-color: #000 !important;
    --status-error-text-color: #000 !important;
    --status-note-text-color: #000 !important;
  }

  .status-message--warning {
    color: #000 !important;
  }

  .status-message--success {
    color: #000 !important;
  }

  .status-message--note {
    color: #000 !important;
  }

  .status-message--danger {
    color: #000 !important;
  }

  #overviewDialog {
    display: block;
    position: static;
    width: auto;
    max-width: none;
    max-height: none;
    height: auto;
    overflow: visible;
  }

  #overviewDialogContent {
    max-height: none;
    overflow: visible;
  }
}
