/* Fix: Wellen blockieren keine Klicks mehr auf das Login-Feld */
.spectrum-waves-container.top,
.spectrum-wave,
.spectrum-wave svg,
.spectrum-wave path {
  pointer-events: none !important;
}
/* ==========================================================================
   SPR THEME – Variant B (HUD / crisper separation) – FIXED + FORMATTED
   - Mini-Header bleibt im Stripe-Block (kein eigener Balken)
   - Bilderzeile übernimmt exakt die gleiche Stripe-Farbe wie Datensatzzeile
   - Separator nur Linie (kein grauer Balken)
   - Banner: Bild + Overlay + Noise + sauberer Übergang
   - Scroll: nur Index-Seite bekommt eigenen Scroll-Container (nicht global)
   - Dropdown: dunkel + del rot
   - Notes: kein Doppelrahmen-Effekt mehr
   ========================================================================== */

/* ==========================================================================
   Variables
   ========================================================================== */

:root{
  /* Steam-inspired palette */
  --steam-dark: #171a21;
  --steam-blue: #66c0f4;
  --steam-slate: #1b2838;
  --steam-slate-2: #2a475e;
  --steam-light: #c7d5e0;

  --spr-bg: var(--steam-dark);
  --spr-header-bg: var(--steam-dark);
  --spr-navbar-height: 4.6rem;
  --spr-nav-glass: rgba(8,9,11,.28);
  --spr-nav-glass-strong: rgba(8,9,11,.36);
  --spr-nav-text: rgba(199,213,224,.7);
  --spr-nav-text-strong: var(--steam-light);
  --spr-nav-text-dim: rgba(199,213,224,.45);
  --spr-nav-text-quiet: rgba(199,213,224,.55);

  --spr-text: var(--steam-light);
  --spr-muted: rgba(199,213,224,.7);
  --spr-dim: rgba(199,213,224,.5);
  --spr-table-text: var(--steam-light);

  --spr-border: rgba(199,213,224,.12);
  --spr-border-strong: rgba(199,213,224,.22);

  --spr-blue: rgba(102,192,244,.35);
  --spr-blue-hover: rgba(102,192,244,.5);

  --spr-red: rgba(220,53,69,.34);
  --spr-red-hover: rgba(220,53,69,.48);

  --spr-green: rgba(34,197,94,.10);
  --spr-green-border: rgba(74,222,128,.34);

  --spr-shadow: 0 18px 48px rgba(0,0,0,.72);
  --spr-nav-input-bg: var(--steam-dark);

  /* Table palette (neutral, aligned with background) */
  --spr-table-head-bg: var(--steam-slate-2);
  --spr-table-stripe-even: rgba(255,255,255,.02);
  --spr-table-stripe-odd: rgba(255,255,255,.04);
  --spr-table-border: rgba(255,255,255,.08);
  --spr-table-border-strong: rgba(255,255,255,.16);
  --spr-table-hover: rgba(102,192,244,.10);

  --spr-font-base: var(--bs-body-font-family);
  --spr-font-mono: var(--bs-font-monospace);
  --spr-track-tight: .06em;
  --spr-track-medium: .12em;
  --spr-track-wide: .20em;
  --spr-track-wider: .26em;
}

/* ==========================================================================
   Global base
   ========================================================================== */

body{
  margin: 0;
  background: var(--spr-bg);
  background-color: var(--spr-bg);
  background-image: none;
  color: var(--spr-text);
  font-size: 0.9rem;
  font-family: var(--spr-font-base);
  overflow-x: auto;
}

/* Force a single solid background for body + page areas */
.main-wrapper,
main,
.content-container,
.spr-table-scroll{
  background: var(--spr-bg) !important;
  background-color: var(--spr-bg) !important;
  background-image: none !important;
}

/* Global background */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  background: url("/static/img/nav_bg_hud.webp") center/cover no-repeat;
  opacity: .14;
  filter: blur(1.8px) contrast(.95) saturate(0);
  transform: scale(1.05);
  z-index: -2;
}

body::after{
  content:"";
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 50% 35%,
    rgba(0,0,0,.12),
    rgba(0,0,0,.88)
  );
  z-index: -1;
}

/* Neutral background override (keep original art in code, disable visuals) */
body::before,
body::after{
  background: none !important;
  opacity: 0 !important;
  filter: none !important;
}

/* Layout helpers */
.main-wrapper{
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main{ flex: 1 0 auto; }

.content-container{
  width: 100%;
  min-width: 1440px;
  max-width: 1600px;
  margin: 0 auto;
}


.spr-login-shell,
.spr-login-shell-inner{
  width: 100%;
  max-width: 100%;
  min-width: 0;
  padding-left: 0;
  padding-right: 0;
  margin: 0;
}

.spr-main-login{
  padding: 0 !important;
}

.page-login .content-container{
  min-width: 0;
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
}

@media (max-width: 1400px){
  .content-container{
    width: 100%;
    min-width: 1440px;
    max-width: 1600px;
    padding-left: .5rem;
    padding-right: .5rem;
  }
}

/* ==========================================================================
   Surfaces
   ========================================================================== */

.spr-surface{
  background: rgba(10,12,16,.55);
  border: 1px solid rgba(185,185,185,.10);
  border-radius: 0;
  box-shadow: var(--spr-shadow);
  padding: 14px;
}

.spr-surface.spr-surface-table{
  box-shadow: none;
  position: relative;
  background: transparent;
  border: 0;
  padding: 0;
}

.page-index .spr-surface.spr-surface-table{
  margin-top: 2.0rem;
}

.spr-surface.spr-surface-table.spr-surface-limited{
  height: 2700px;
  overflow: hidden;
}

.spr-surface.spr-surface-table.spr-surface-limited .spr-table-blur-wrap,
.spr-surface.spr-surface-table.spr-surface-limited .table-responsive{
  height: 100%;
  overflow: hidden;
}

.spr-surface.spr-surface-table.spr-surface-empty{
  min-height: 0;
}

.spr-table-blur-wrap.is-blurred{
  filter: blur(7px) brightness(0.6) saturate(0.6);
  opacity: 0.55;
  pointer-events: none;
}

.spr-table-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  text-align: center;
  padding: 11.5rem 1.5rem 2.5rem;
  z-index: 5;
}

.spr-table-overlay::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(6,8,12,.35);
  z-index: 0;
}

.spr-table-overlay--inline{
  inset: auto 0 0 0;
  top: 0;
  bottom: 0;
  padding: 0;
}

.spr-table-overlay--inline::before{
  background: transparent;
}

.spr-table-overlay--inline .spr-table-overlay-row{
  max-width: none;
  justify-content: center;
  min-height: 100%;
}


.spr-table-overlay-row{
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.8rem;
  width: 100%;
  max-width: 1150px;
}

.spr-table-overlay-waves{
  position: relative;
  flex: 1 1 38%;
  max-width: 42%;
  height: 19rem;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 1;
  transform: translateY(6.8rem) scaleY(2.2);
}


.spr-table-overlay-waves-digital{
  position: relative;
  flex: 1 1 38%;
  max-width: 42%;
  height: 9.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 3;
}

.spr-table-overlay-waves-digital svg{
  width: 100%;
  height: 100%;
  display: block;
}

.spr-navbar-digital{
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.55rem;
  transform: translateY(2px);
}

.spr-navbar-digital .spr-table-overlay-waves-digital{
  width: 6.4rem;
  height: 1.4rem;
  flex: 0 0 auto;
  max-width: none;
}

.spr-navbar-analog{
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.55rem;
  transform: translateY(2px);
}

.spr-navbar-analog .spr-table-overlay-waves{
  width: 6.4rem;
  height: 1.4rem;
  flex: 0 0 auto;
  max-width: none;
  transform: none;
}

.spr-navbar-analog .spectrum-waves-container{
  height: 100%;
}

.spr-navbar-analog .spectrum-wave{
  width: 100%;
}

.spr-table-overlay-waves-digital .spr-digital-line{
  fill: none;
  stroke: rgba(88,166,255,0.12);
  stroke-width: 1.8;
  stroke-linecap: square;
  stroke-linejoin: miter;
  vector-effect: non-scaling-stroke;
  animation: spr-digital-pulse 2.2s ease-in-out infinite;
}

.spr-table-overlay-waves-digital .spr-digital-line--ghost{
  stroke: rgba(255,210,90,0.035);
  animation-delay: -0.7s;
}

.spr-table-overlay-waves-digital .spr-digital-line--ghost2{
  stroke: rgba(80,200,120,0.03);
  animation-delay: -1.4s;
}

.spr-table-overlay-waves-digital .spr-digital-line--ghost3{
  stroke: rgba(255,90,90,0.03);
  animation-delay: -2.1s;
}

.spr-table-overlay-waves .spectrum-waves-container{
  position: relative;
  width: 100%;
  height: 9.8rem;
  overflow: visible;
  pointer-events: none;
}

.spr-table-overlay-waves .spectrum-waves-container::before{
  display: none;
}

.spr-table-overlay-waves .spectrum-wave{
  position: absolute;
  width: 100%;
  z-index: 1;
}

.spr-table-overlay-waves .spectrum-wave svg{
  width: 100%;
  height: 100%;
  display: block;
}

.spr-table-overlay-waves .spectrum-wave path{
  fill: none;
  stroke: rgba(255,255,255,0.015);
  stroke-width: 1.4;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
}

.spr-table-overlay-waves .spectrum-wave:nth-child(1) path{
  animation: spr-wave-oscillate-1phase 2.7s ease-in-out infinite;
  animation-delay: -0.3s;
  stroke: rgba(255,159,67,0.035);
}

.spr-table-overlay-waves .spectrum-wave:nth-child(2) path{
  animation: spr-wave-oscillate-2 3.9s ease-in-out infinite;
  animation-delay: -1.9s;
  stroke: rgba(255,90,90,0.04);
}

.spr-table-overlay-waves .spectrum-wave:nth-child(3) path{
  animation: spr-wave-oscillate-3phase 5.5s ease-in-out infinite;
  animation-delay: -3.1s;
  stroke: rgba(88,166,255,0.12);
}

.spr-table-overlay-waves .spectrum-wave:nth-child(3){
  transform: none;
  width: 100%;
  left: 0;
}

.spr-table-overlay-waves .spectrum-wave:nth-child(4) path{
  animation: spr-wave-oscillate-1 3.1s ease-in-out infinite;
  animation-delay: -1.1s;
  stroke: rgba(80,200,120,0.035);
}

.spr-table-overlay-waves .spectrum-wave:nth-child(5) path{
  animation: spr-wave-oscillate-2phase 4.6s ease-in-out infinite;
  animation-delay: -2.4s;
  stroke: rgba(255,210,90,0.035);
}

.spr-table-overlay-waves .spectrum-wave:nth-child(6) path{
  animation: spr-wave-oscillate-3 6.8s ease-in-out infinite;
  animation-delay: -4.5s;
  stroke: rgba(255,159,67,0.03);
}

.spr-table-overlay-text{
  color: rgba(248,249,250,.60);
  font-weight: 600;
  font-size: .68rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
  text-shadow: 0 10px 26px rgba(0,0,0,.75);
  background: transparent;
  border: none;
  padding: .2rem .5rem;
  position: relative;
  z-index: 2;
  text-align: center;
  font-family: var(--spr-font-base);
  margin-top: 0;
}

.spr-table-overlay-text span:first-child{
  color: rgba(70,220,140,0.80);
}

.spr-table-overlay-text span.spr-overlay-empty:first-child{
  color: rgba(210, 90, 90, 0.85);
}

.spr-table-overlay-text span{
  display: block;
  line-height: 1.45;
}

@keyframes spr-wave-oscillate-1 {
  0%, 100% { d: path('M0,30 Q50,-3 100,30 T200,30 T300,30 T400,30 T500,30'); }
  35% { d: path('M0,30 Q50,42 100,30 T200,30 T300,30 T400,30 T500,30'); }
  70% { d: path('M0,30 Q50,-4 100,30 T200,30 T300,30 T400,30 T500,30'); }
}

@keyframes spr-wave-oscillate-2 {
  0%, 100% { d: path('M0,30 Q50,-8 100,30 T200,30 T300,30 T400,30 T500,30'); }
  28% { d: path('M0,30 Q50,52 100,30 T200,30 T300,30 T400,30 T500,30'); }
  62% { d: path('M0,30 Q50,-9 100,30 T200,30 T300,30 T400,30 T500,30'); }
}

@keyframes spr-wave-oscillate-3 {
  0%, 100% { d: path('M0,30 Q50,-14 100,30 T200,30 T300,30 T400,30 T500,30'); }
  20% { d: path('M0,30 Q50,68 100,30 T200,30 T300,30 T400,30 T500,30'); }
  58% { d: path('M0,30 Q50,-16 100,30 T200,30 T300,30 T400,30 T500,30'); }
  82% { d: path('M0,30 Q50,65 100,30 T200,30 T300,30 T400,30 T500,30'); }
}

@keyframes spr-wave-oscillate-3phase {
  0%, 100% { d: path('M0,30 Q50,72 100,30 T200,30 T300,30 T400,30 T500,30'); }
  50% { d: path('M0,30 Q50,-18 100,30 T200,30 T300,30 T400,30 T500,30'); }
}

@keyframes spr-wave-oscillate-1phase {
  0%, 100% { d: path('M0,30 Q50,42 100,30 T200,30 T300,30 T400,30 T500,30'); }
  50% { d: path('M0,30 Q50,-3 100,30 T200,30 T300,30 T400,30 T500,30'); }
}

@keyframes spr-wave-oscillate-2phase {
  0%, 100% { d: path('M0,30 Q50,64 100,30 T200,30 T300,30 T400,30 T500,30'); }
  50% { d: path('M0,30 Q50,8 100,30 T200,30 T300,30 T400,30 T500,30'); }
}

@keyframes spr-digital-pulse {
  0%, 100% {
    d: path('M0,28 H18 V6 H30 V28 H120 V6 H150 V28 H210 V6 H230 V28 H290 V6 H320 V28 H380 V6 H410 V28 H470 V6 H500 V28');
  }
  50% {
    d: path('M0,28 H25 V6 H40 V28 H90 V6 H130 V28 H170 V6 H190 V28 H260 V6 H300 V28 H330 V6 H360 V28 H430 V6 H460 V28 H500');
  }
}

.spr-empty-note{
  text-align: center;
  padding: 3rem 1rem;
  color: rgba(248,249,250,.82);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}


/* ==========================================================================
   Navbar (Banner)
   ========================================================================== */

.navbar-banner{
  display: flex;
  position: sticky !important;
  top: 0;
  z-index: 1030;
  overflow: visible;

  height: auto;
  min-height: var(--spr-navbar-height);
  background: var(--spr-bg);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
}

/* “Kante” unter dem Banner */
.navbar-banner::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:2px;
  background: linear-gradient(
    90deg,
    rgba(199,213,224,0),
    rgba(199,213,224,.18),
    rgba(199,213,224,0)
  );
  opacity: 1;
  pointer-events: none;
}

/* braucht relative + hidden für ::before/::after */
.navbar-banner-inner{
  position: relative;
  min-height: var(--spr-navbar-height);
  overflow: visible;
  background: var(--spr-bg);
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

/* ==========================================================================
   Navbar Banner – Background Image + Overlay + Noise (sauber & sichtbar)
   ========================================================================== */

/* Banner Background Image */
.navbar-banner-inner::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background: var(--spr-bg);
  opacity: 1;
  filter: none;
  transform: none;
}

/* Banner Overlay (dunkelt ab, aber lässt Bild noch durch) */
.navbar-banner-inner::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background: var(--spr-bg);
  border-bottom: 0;
  box-shadow: none;
}

/* Noise Layer */
.navbar-banner-inner .banner-noise{
  display: none;
}


/* Navbar content above layers */
.navbar-banner-inner > .navbar-content{
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  min-height: var(--spr-navbar-height);
}

.navbar.navbar-dark.bg-secondary{
  padding-top: .35rem;
  padding-bottom: .30rem;
  background-color: transparent !important;
  min-height: var(--spr-navbar-height);
}

.spr-nav-stack{
  padding-top: 0;
  padding-bottom: 0;
}

.navbar-brand{
  font-size: 1.45rem;
  color: rgba(248,249,250,0.88);
  letter-spacing: .25px;
}

.navbar-version{
  font-size: .7rem;
  color: rgba(248,249,250,0.50);
  margin-top: -0.2rem;
}

.navbar-right{
  flex: 1 1 auto;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  min-width: 0;
}

.navbar-search-row{
  display: flex;
  align-items: center;
  gap: .7rem;
  flex-wrap: wrap;
  justify-content: flex-start;
  row-gap: .35rem;
  min-height: 2.2rem;
  padding: .25rem 0 .35rem;
  border-radius: 8px;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
  position: relative;
  overflow: hidden;
}

/* Searchbar container: always transparent */
.spr-header-row .navbar-search-row{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Searchbar: fully transparent, no color accents */
.navbar-search-row,
.navbar-search-row *{
  background: transparent !important;
  box-shadow: none !important;
}

.navbar-search-row *{
  color: inherit !important;
  border-color: transparent !important;
}

.navbar-search-row .form-control.navbar-input,
.navbar-search-row select.navbar-input,
.navbar-search-row .spr-select-trigger{
  border: 0 !important;
  outline: none !important;
}

.navbar-search-row .spr-nav-toggle input,
.navbar-search-row .spr-nav-toggle input:checked{
  background: transparent !important;
  border: 0 !important;
}

.navbar-search-row .spr-nav-toggle input:checked::before,
.navbar-search-row .spr-nav-toggle input:checked::after,
.navbar-search-row .spr-select-trigger::after{
  background: currentColor !important;
  border-color: currentColor !important;
}

.navbar-search-row .navbar-input::placeholder{
  color: inherit !important;
  opacity: .6;
}

/* Menu + search row should be fully transparent */
.spr-nav-menu,
.btn-action-menu{
  background: transparent !important;
  box-shadow: none !important;
}

/* Fully transparent menu + searchbar (no bars/lines) */
.navbar-search-row::before{
  display: none !important;
}

.navbar-sep,
.navbar-sep.spr-group-sep{
  border-left: 0 !important;
  background: transparent !important;
}

.navbar-search-row .form-control.navbar-input{
  border-bottom: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.navbar-input:hover,
.navbar-input:focus{
  background: transparent !important;
  border-bottom-color: transparent !important;
  box-shadow: none !important;
}

select.navbar-input,
select.navbar-input:focus{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Restore visible prev/next buttons */
.spr-nav-chev-btn{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.spr-nav-chev-icon{
  width: .85rem;
  height: .85rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  display: block;
}

/* Force search inputs to stay neutral (no dark/colored accents) */
.navbar-search-row .form-control.navbar-input,
.navbar-search-row select.navbar-input{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.navbar-search-row .form-control.navbar-input:focus,
.navbar-search-row .form-control.navbar-input:hover,
.navbar-search-row select.navbar-input:focus,
.navbar-search-row select.navbar-input:hover{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

/* Inline navbar search: restore visible controls */
.navbar-search-row--inline{
  display: inline-flex;
  align-items: center;
  gap: .9rem;
  padding: .35rem .2rem;
  background: rgba(10,12,16,.35);
  border-radius: 10px;
  justify-content: flex-start;
  width: fit-content !important;
  max-width: 100%;
  margin-left: 0 !important;
  margin-right: auto !important;
  padding-left: .8rem;
  padding-right: .8rem;
  position: relative;
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  --nav-control-h: 2.0rem;
  --nav-search-row-h: calc(var(--nav-control-h) + 1.2rem);
  text-align: center;
  line-height: 1;
}

.spr-nav-search-form--placeholder{
  min-width: 1px;
  background: transparent;
  border-radius: 0;
  visibility: hidden;
  height: var(--nav-search-row-h);
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.navbar-search-row--inline .navbar-sep{
  display: none !important;
}

/* Soft grouping blocks for search controls */
.navbar-search-row--inline > .spr-nav-group{
  padding: .2rem .35rem;
  border-radius: 8px;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.navbar-search-row--inline .form-control.navbar-input,
.navbar-search-row--inline select.navbar-input,
.navbar-search-row--inline .spr-select-trigger{
  background: var(--spr-nav-input-bg) !important;
  border: 1px solid rgba(199,213,224,.18) !important;
  box-shadow: none;
  border-radius: 6px !important;
  color: var(--steam-light) !important;
  height: var(--nav-control-h);
}

/* Inputs only: subtle dark fill for clarity */
.navbar-search-row--inline .form-control.navbar-input{
  background: var(--spr-nav-input-bg) !important;
}

.navbar-search-row--inline .spr-nav-icon{
  margin-right: .25rem;
  color: rgba(248,249,250,.6);
  width: 1.1rem;
  height: var(--nav-control-h);
}

.navbar-search-row--inline .spr-nav-group{
  align-items: center;
}

.navbar-search-row--inline .spr-nav-group--spaced{
  padding: .15rem .35rem;
}

.navbar-search-row--inline .spr-nav-cluster{
  padding: .1rem .4rem;
  border-radius: 10px;
  background: rgba(255,255,255,.08) !important;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
}

.navbar-search-row--inline .spr-nav-field-row{
  align-items: center;
}

.navbar-search-row--inline .spr-nav-field-row .spr-select{
  transform: none;
}

/* Strong override: input fields in navbar search should be visibly dark */
.navbar-search-row.navbar-search-row--inline input.navbar-input{
  background-color: var(--spr-nav-input-bg) !important;
  border-color: rgba(185,185,185,.38) !important;
}

.navbar-search-row.navbar-search-row--inline input.navbar-input:focus,
.navbar-search-row.navbar-search-row--inline input.navbar-input:not(:placeholder-shown){
  background-color: var(--spr-nav-input-bg) !important;
  border-color: rgba(88,166,255,.38) !important;
  box-shadow: none !important;
}

.navbar-search-row--inline .form-control.navbar-input{
  height: var(--nav-control-h) !important;
  padding: .2rem .5rem !important;
  border: 1px solid rgba(185,185,185,.38) !important;
  box-shadow: inset 0 0 0 1px transparent !important;
  outline: none !important;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.navbar-search-row--inline .form-control.navbar-input{
  border: 1px solid rgba(185,185,185,.16) !important;
  border-radius: 6px !important;
}

.navbar-search-row--inline input.navbar-input{
  background-color: var(--spr-nav-input-bg) !important;
  border-color: rgba(185,185,185,.16) !important;
  box-shadow: none !important;
  transition: none !important;
}

.navbar-search-row--inline .spr-select-trigger{
  height: var(--nav-control-h);
}

.navbar-search-row--inline .spr-select .spr-select-trigger{
  min-height: var(--nav-control-h);
  height: var(--nav-control-h);
  display: inline-flex;
  align-items: center;
  line-height: calc(var(--nav-control-h) - 2px);
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  background: rgba(0,0,0,.55) !important;
  border: 0 !important;
  border-radius: 6px !important;
}

.navbar-search-row--inline .spr-select .spr-select-trigger:hover,
.navbar-search-row--inline .spr-select .spr-select-trigger:focus{
  background: rgba(18,22,28,.6) !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}

.navbar-search-row--inline .spr-select .spr-select-trigger::after{
  width: 0 !important;
  height: 0 !important;
  border-left: 4px solid transparent !important;
  border-right: 4px solid transparent !important;
  border-bottom: 5px solid rgba(248,249,250,.7) !important;
  border-top: 0 !important;
  background: transparent !important;
  transform: translateY(-40%) rotate(180deg) !important;
  right: .6rem !important;
}

.navbar-search-row--inline .spr-select.is-open .spr-select-trigger{
  border: 0 !important;
  box-shadow: none !important;
}

.navbar-search-row--inline .navbar-input::placeholder{
  color: rgba(248,249,250,.22) !important;
  opacity: 1 !important;
}

.navbar-search-row--inline input.navbar-input::placeholder{
  color: rgba(248,249,250,.22) !important;
  opacity: 1 !important;
}

/* Firefox placeholder */
.navbar-search-row--inline input.navbar-input::-moz-placeholder{
  color: rgba(248,249,250,.22) !important;
  opacity: 1 !important;
}

.navbar-search-row--inline input.navbar-input:hover,
.navbar-search-row--inline input.navbar-input:focus,
.navbar-search-row--inline input.navbar-input:focus-visible,
.navbar-search-row--inline input.navbar-input:active{
  background-color: var(--spr-nav-input-bg) !important;
  border-color: rgba(185,185,185,.38) !important;
  box-shadow: none !important;
  outline: none !important;
}

.navbar-search-row--inline .form-control.navbar-input:hover,
.navbar-search-row--inline .form-control.navbar-input:focus,
.navbar-search-row--inline .form-control.navbar-input:focus-visible,
.navbar-search-row--inline .form-control.navbar-input:active{
  background-color: rgba(0,0,0,.45) !important;
  border-color: rgba(185,185,185,.38) !important;
  box-shadow: none !important;
  outline: none !important;
}

.navbar-search-row--inline .form-control:focus,
.navbar-search-row--inline .form-control:focus-visible{
  background-color: rgba(0,0,0,.45) !important;
  border: 1px solid rgba(185,185,185,.38) !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Prevent browser autofill from changing colors */
.navbar-search-row--inline input.navbar-input:-webkit-autofill,
.navbar-search-row--inline input.navbar-input:-webkit-autofill:hover,
.navbar-search-row--inline input.navbar-input:-webkit-autofill:focus,
.navbar-search-row--inline input.navbar-input:-webkit-autofill:active{
  -webkit-text-fill-color: rgba(248,249,250,.9) !important;
  transition: background-color 9999s ease-out 0s !important;
  box-shadow: 0 0 0 1000px var(--spr-nav-input-bg) inset !important;
  border-color: rgba(185,185,185,.38) !important;
}

.navbar-search-row--inline .spr-nav-field{
  align-items: center;
}

.navbar-search-row--inline .spr-nav-field-row{
  align-items: center;
}

.navbar-search-row--inline .spr-nav-caption{
  text-align: center;
}

.navbar-search-row--inline .spr-nav-chev{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.navbar-search-row--inline .spr-nav-chev--left{
  left: .25rem;
}

.navbar-search-row--inline .spr-nav-chev--right{
  right: .25rem;
}

.navbar-search-row--inline .spr-nav-chev-btn{
  width: 1.9rem;
  height: 1.9rem;
}

.navbar-search-row--inline .spr-nav-clear{
  height: calc(var(--nav-control-h) - .15rem) !important;
  min-height: calc(var(--nav-control-h) - .15rem) !important;
  line-height: calc(var(--nav-control-h) - .15rem) !important;
  margin-top: 0 !important;
  align-self: center;
  width: calc(var(--nav-control-h) - .2rem) !important;
  min-width: calc(var(--nav-control-h) - .2rem) !important;
  font-size: .78rem;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  box-sizing: border-box;
}
.navbar-search-row > .spr-nav-group{
  padding: 0;
  border-radius: 0;
  background: transparent;
  position: relative;
  z-index: 2;
}

.navbar-search-row::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity: 0;
  background: transparent;
}


.spr-paging-compact .navbar-search-row,
.spr-paging-compact .navbar-search-row .form-control,
.spr-paging-compact .navbar-search-row .spr-select-trigger{
  font-size: .78rem;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: var(--spr-nav-text);
}

.spr-nav-group{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 6px;
}

.spr-nav-field{
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .2rem;
}

.spr-nav-field-row{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.spr-nav-field-row .spr-select{
  align-self: flex-end;
  transform: translateY(2px);
}

.spr-nav-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.05rem;
  height: 1.05rem;
  color: rgba(248,249,250,.55);
}

.spr-nav-icon svg{
  width: 100%;
  height: 100%;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.spr-nav-group--plain{
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

.spr-nav-toggles{
  display: grid;
  grid-template-columns: repeat(2, auto);
  column-gap: .9rem;
  row-gap: .35rem;
  padding: .35rem .6rem;
}

.spr-nav-toggles--stacked{
  grid-template-columns: 1fr;
  row-gap: .18rem;
  column-gap: 0;
  padding: .28rem .45rem .08rem 0;
}

.spr-nav-toggles-grid{
  display: grid;
  grid-template-columns: auto auto;
  column-gap: .55rem;
  row-gap: .2rem;
  align-items: start;
  margin-right: 1.1rem;
}

.spr-nav-toggles-col{
  display: inline-flex;
  flex-direction: column;
  gap: .55rem;
  align-items: flex-start;
  justify-content: flex-start;
}

/* Filter strip (left) */
.navbar-search-row .spr-nav-group--plain{
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.spr-nav-toggles-col .spr-type-info{
  align-self: flex-start;
}

.spr-nav-break{
  flex-basis: 100%;
  height: 0;
}

 .spr-filter-bar{
  position: relative;
  z-index: 5;
}

.spr-filter-summary{
  border: 1px solid rgba(150,170,200,.18);
  background: rgba(130,150,180,.08);
  color: rgba(210,220,232,.82);
  border-radius: 999px;
  height: 1.05rem;
  padding: 0 .6rem;
  font-size: .72rem;
  line-height: 1;
  letter-spacing: .01em;
  cursor: pointer;
  pointer-events: auto;
}

.spr-filter-summary.is-empty{
  opacity: .45;
}

.spr-filter-popover{
  position: absolute;
  right: 0;
  top: calc(100% + .25rem);
  min-width: 16rem;
  max-width: 28rem;
  padding: .4rem;
  border: 1px solid rgba(150,170,200,.18);
  background: rgba(10,12,16,.92);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  display: none;
  gap: .35rem;
  flex-wrap: wrap;
  z-index: 50;
  pointer-events: auto;
}

.spr-filter-popover.is-open{
  display: flex;
}

.spr-filter-chip{
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: .28rem;
  height: .95rem;
  padding: 0 .55rem;
  border-radius: 999px;
  border: 1px solid rgba(150,170,200,.18);
  background: rgba(130,150,180,.08);
  color: rgba(220,230,242,.78);
  font-size: .72rem;
  letter-spacing: .01em;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transform: none;
}


.spr-filter-chip:hover{
  color: rgba(245,248,252,.95);
  border-color: rgba(170,180,195,.32);
  background: rgba(255,255,255,.05);
}

.spr-filter-chip-x{
  color: rgba(240,120,120,.88);
  font-weight: 700;
  cursor: pointer;
  pointer-events: auto;
}

 .spr-nav-clear{
  margin-left: 0 !important;
}

.spr-nav-clear{
  border: 1px solid rgba(120,140,170,.22);
  background: rgba(10,12,16,.45);
  color: rgba(200,210,220,.7);
  width: 1.9rem;
  min-width: 1.9rem;
  padding: 0;
  font-size: .8rem;
  letter-spacing: 0;
  text-transform: none;
  border-radius: 5px;
  text-align: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.spr-nav-clear.btn-reset-active{
  border-color: rgba(220,53,69,.35);
  color: rgba(220,53,69,.85);
  background: rgba(220,53,69,.08);
}

.navbar-search-row--inline .spr-nav-clear.btn-reset-active{
  color: rgba(255,120,120,.75) !important;
  background: rgba(255,120,120,.08) !important;
  border-color: rgba(255,120,120,.32) !important;
}

.spr-nav-clear.btn-reset-disabled{
  opacity: .45;
}

.spr-nav-clear{
  margin-top: -0.22rem;
}

.spr-nav-toggles-row{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: .9rem;
  padding: .16rem .6rem .08rem;
  justify-content: flex-start;
}

.spr-nav-bottom{
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0,1fr) auto 0;
  align-items: center;
  gap: .35rem;
  min-height: .36rem;
  flex-basis: 100%;
}

.spr-nav-bottom .spr-nav-group{
  justify-self: start;
}

.spr-nav-bottom .spr-status-flash{
  justify-self: end;
}

.spr-nav-bottom-spacer{
  width: 0;
  min-width: 0;
}

#spr-filter-chips-host{
  min-width: 0;
  width: 100%;
  align-self: center;
  padding-left: 0;
  margin-top: 0;
}

/* Keep navbar layout stable on small viewport / browser zoom:
   no wrap-shifts, use horizontal scroll instead. */
@media (max-width: 1500px){
  .spr-paging-compact .spr-header-row{
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
  }

  .spr-paging-compact .spr-header-row::-webkit-scrollbar{
    height: 6px;
  }

  .spr-paging-compact .navbar-search-row{
    flex-wrap: nowrap;
    row-gap: 0;
    min-width: max-content;
    width: max-content;
  }

  .spr-paging-compact .spr-nav-bottom{
    min-width: max-content;
  }
}

.spr-type-info{
  margin-left: .2rem;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid rgba(185,185,185,.25);
  background: rgba(0,0,0,.15);
  color: rgba(248,249,250,.8);
  font-size: .7rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}

.spr-status-center{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .2rem;
  margin-top: 0;
}

.spr-status-center--placeholder{
  visibility: hidden;
}

.spr-status-center--inline{
  margin-left: .3rem;
  justify-content: flex-start;
}

.spr-type-info:hover{
  color: #fff;
  border-color: rgba(185,185,185,.5);
  background: rgba(255,255,255,.08);
}

.spr-type-modal-body{
  display: grid;
  gap: .75rem;
  color: rgba(248,249,250,.82);
}

.spr-type-item-title{
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(248,249,250,.9);
  margin-bottom: .2rem;
}

.spr-type-item-text{
  font-size: .78rem;
  line-height: 1.35;
  color: rgba(248,249,250,.72);
}

.spr-type-filters{
  margin-left: 1.4rem;
  display: flex;
  align-items: center;
}


.spr-type-filter-grid{
  display: grid;
  grid-template-columns: repeat(2, auto);
  column-gap: .9rem;
  row-gap: .35rem;
}

.spr-nav-toggle{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: var(--spr-nav-text-dim);
  font-size: .6rem;
  letter-spacing: var(--spr-track-wide);
  text-transform: uppercase;
  cursor: pointer;
  user-select: none;
}

/* Searchbar: match dropdown (Band) typography */
.navbar-search-row .spr-nav-toggle{
  color: rgba(248,249,250,.88);
  font-size: .875rem;
  letter-spacing: 0;
  text-transform: none;
  line-height: 1.2;
}

.spr-compact-toggle{
  font-size: .66rem;
  letter-spacing: .08em;
}

.spr-nav-toggle input{
  width: 14px;
  height: 14px;
  border-radius: 2px;
  background: transparent;
  border: 1px solid rgba(255,255,255,.12);
  appearance: none;
  display: inline-block;
  position: relative;
}

.spr-nav-toggle input:checked{
  background: rgba(120,180,255,.12);
  border-color: rgba(120,180,255,.45);
}

.spr-nav-toggle input:checked::before,
.spr-nav-toggle input:checked::after{
  content: "";
  position: absolute;
  left: 2px;
  right: 2px;
  top: 50%;
  height: 1.5px;
  background: rgba(120,180,255,.55);
  transform-origin: center;
}

.spr-nav-toggle input:checked::before{
  transform: translateY(-50%) rotate(45deg);
}

.spr-nav-toggle input:checked::after{
  transform: translateY(-50%) rotate(-45deg);
}


.navbar-sep.spr-group-sep{
  color: transparent;
  padding: 0 .5rem;
  display: inline-block;
  width: 1px;
  height: 1.1rem;
  background: transparent;
  border-left: 1px solid rgba(255,255,255,.14);
}

.navbar-sep{
  color: transparent;
  padding: 0 .4rem;
  display: inline-block;
  width: 1px;
  height: 1.0rem;
  background: transparent;
  border-left: 1px solid rgba(255,255,255,.10);
  user-select: none;
  white-space: nowrap;
}

.navbar-search-row .navbar-sep{
  display: none;
}

.spr-nav-chev{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.spr-nav-chev--left{
  left: .35rem;
}

.spr-nav-chev--right{
  right: .35rem;
}

.spr-nav-chev-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  background: var(--spr-nav-glass);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--spr-nav-text-strong);
  text-decoration: none;
  box-shadow: 0 1px 0 rgba(255,255,255,0.04);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  cursor: pointer;
  padding: 0;
  font: inherit;
}

.spr-nav-chev-btn.is-disabled,
.spr-nav-chev-btn:disabled{
  opacity: .45;
  cursor: default;
  pointer-events: none;
}

/* Inputs: opaker für bessere Lesbarkeit */
.navbar-search-row .form-control.navbar-input{
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(185,185,185,.18) !important;
  border-radius: 0 !important;
  color: rgba(248,249,250,.92) !important;
  outline: none !important;
  box-shadow: none !important;
  height: 1.55rem !important;
  line-height: 1.2;
  font-size: .875rem;
  padding: .2rem .5rem !important;
}

.navbar-input:hover,
.navbar-input:focus{
  background: rgba(255,255,255,.03) !important;
  border-bottom-color: rgba(185,185,185,.45) !important;
}


.navbar-input::placeholder{
  color: rgba(248,249,250,.12) !important;
}

.navbar-input:focus{
  outline: none;
  border-bottom-color: rgba(88,166,255,.45);
  box-shadow: inset 0 -1px 0 rgba(88,166,255,.35);
}

select.navbar-input{
  background: rgba(8,10,14,.40) !important;
  color: rgba(248,249,250,.88) !important;
  border: 1px solid rgba(185,185,185,.14) !important;
  border-radius: 4px !important;
  outline: none !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
  padding: .22rem .45rem !important;
  height: 1.6rem;
  font-size: .78rem;
  line-height: 1.2;
}

select.navbar-input:focus{
  border-color: rgba(185,185,185,.26) !important;
  outline: none !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

select.navbar-input option{
  background: rgba(8,10,14,.92);
  color: rgba(248,249,250,.82);
  font-size: .78rem;
  line-height: 1.2;
  padding: .2rem .45rem;
}

select.navbar-input option:checked,
select.navbar-input option:focus,
select.navbar-input option:hover{
  background: rgba(255,255,255,.05);
  color: rgba(248,249,250,.92);
}

/* Searchbar hard reset: no backgrounds, borders, or color accents */
.navbar-search-row,
.navbar-search-row *{
  background: transparent !important;
  box-shadow: none !important;
  border-color: transparent !important;
}

.navbar-search-row,
.navbar-search-row *{
  color: inherit !important;
}

.navbar-search-row .form-control.navbar-input,
.navbar-search-row select.navbar-input,
.navbar-search-row .spr-select-trigger,
.navbar-search-row .spr-nav-chev-btn,
.navbar-search-row .spr-nav-toggle input{
  border: 0 !important;
  outline: none !important;
}

.navbar-search-row .navbar-input::placeholder{
  color: inherit !important;
  opacity: .6;
}

.navbar-search-row .spr-select-menu{
  background: var(--spr-nav-input-bg) !important;
  border: 1px solid rgba(185,185,185,.16) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.navbar-search-row .spr-select-option{
  background: transparent !important;
  border-color: transparent !important;
  color: inherit !important;
}



.navbar-freq { width: 8.5rem; }
.navbar-tol  { width: fit-content; min-width: 2.0rem; }
.navbar-q    { width: 8.5rem; }
.navbar-x    { width: 8.5rem; }
.navbar-unit { width: 7rem; }
.navbar-xtol { width: fit-content; min-width: 1.8rem; }
.navbar-struktur { width: 6.5rem; }
.navbar-mod { width: 6.0rem; }
.navbar-band { width: 4.6rem; }

.spr-native-select{
  position: absolute;
  opacity: 0;
  pointer-events: none;
  height: 0;
  width: 0;
}

.spr-select{
  position: relative;
  display: inline-flex;
  align-items: center;
  align-self: center;
}

.spr-select .spr-select-trigger{
  background: rgba(8,10,14,.28) !important;
  border: 0 !important;
  border-bottom: 0 !important;
  border-radius: 0 !important;
  color: rgba(248,249,250,.88) !important;
  padding: .2rem 1rem .2rem .5rem !important;
  min-height: 1.35rem;
  height: 1.35rem;
  line-height: 1.2;
  font-size: .875rem;
  display: inline-flex;
  align-items: center;
  text-align: left;
  cursor: pointer;
  width: 100%;
}

.spr-select .spr-select-trigger:focus,
.spr-select .spr-select-trigger:active,
.spr-select.is-open .spr-select-trigger{
  border-bottom: 0 !important;
  box-shadow: none !important;
  outline: none !important;
}

.spr-select .spr-select-trigger::after{
  content: "";
  position: absolute;
  right: .35rem;
  top: 50%;
  width: 6px;
  height: 6px;
  border-right: 1px solid rgba(248,249,250,.45);
  border-bottom: 1px solid rgba(248,249,250,.45);
  opacity: .8;
  transform: translateY(-50%) rotate(45deg);
  pointer-events: none;
}

.spr-select.is-open .spr-select-trigger{
  border-bottom-color: transparent !important;
  color: rgba(248,249,250,.92) !important;
}

.spr-select-menu{
  position: fixed;
  top: 0;
  left: 0;
  min-width: 4.5rem;
  background: var(--spr-nav-input-bg);
  border: 1px solid rgba(185,185,185,.16);
  border-radius: 6px;
  padding: .2rem;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  display: none;
  z-index: 1100;
}

.spr-select-menu.is-open{
  display: block;
}

.spr-select-option{
  width: 100%;
  text-align: left;
  background: transparent;
  border: 1px solid transparent;
  color: rgba(248,249,250,.82);
  font-size: .78rem;
  padding: .28rem .45rem;
  border-radius: 4px;
}

.spr-select-option:hover,
.spr-select-option:focus{
  background: rgba(120,160,210,.12);
  border-color: rgba(140,180,230,.18);
  color: rgba(255,255,255,.96);
}

.spr-select-option.is-selected{
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.95);
}

.spr-select.navbar-tol,
.spr-select.navbar-xtol{
  width: 4.6rem;
  min-width: 4.6rem;
}

.spr-select.navbar-unit{
  width: 5.2rem;
  min-width: 5.2rem;
}

.spr-select.navbar-band{
  width: 5.2rem;
  min-width: 5.2rem;
}

.spr-select.spr-select-form{
  min-width: 4.8rem;
  width: 100%;
  display: block;
}

.spr-select.spr-select-form .spr-select-trigger{
  width: 100%;
  padding: .42rem 1.1rem .42rem .6rem !important;
  min-height: 2.1rem;
  height: 2.1rem;
  font-size: .82rem;
  line-height: 1.3;
  display: inline-flex;
  align-items: center;
}

.spr-select.spr-select-form .spr-select-menu{
  position: absolute;
  top: calc(100% + .35rem);
  left: 0;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
}

.navbar-count{
  font-size: .78rem;
  color: rgba(70,220,140,0.80);
  white-space: nowrap;
  margin: 0 1rem;
  flex: 1;
  text-align: center;
}

/* ==========================================================================
   Navbar Actions: + Button + Dropdown (muted, kantiger)
   ========================================================================== */

.spr-nav-plus,
.spr-nav-menu{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: 1.875rem;
  min-width: 1.875rem;
  padding: 0 .45rem;

  border-radius: var(--spr-btn-radius); /* nutzt deine 5px */
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.045);
  color: rgba(255,255,255,.90);

  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  transition: background .14s ease, border-color .14s ease, transform .08s ease, color .14s ease;
}

.spr-nav-plus{
  font-weight: 950;
  font-size: 1.1rem;
  line-height: 1.875rem;
  padding: 0 .50rem; /* minimal “dicker” */
}

.spr-nav-plus:hover,
.spr-nav-menu:hover{
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.96);
}

.spr-nav-plus:active,
.spr-nav-menu:active{
  transform: translateY(1px);
}

.spr-nav-plus:focus-visible,
.spr-nav-menu:focus-visible{
  outline: none;
  box-shadow:
    0 0 0 .22rem var(--spr-btn-focus),
    inset 0 1px 0 rgba(255,255,255,.05);
}

/* Button reset (weil <button>) */
.spr-nav-menu{
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}



/* Reset button */
.btn-reset{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--spr-btn-h);
  width: var(--spr-btn-h);
  min-width: var(--spr-btn-h);
  padding: 0;
  border-radius: var(--spr-btn-radius);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.45);
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  transition: background .14s ease, border-color .14s ease, transform .08s ease, color .14s ease;
  font-weight: 600;
  font-size: .8rem;
  line-height: 1;
  vertical-align: middle;
}

.btn-reset--clear{
  width: auto;
  min-width: auto;
  height: var(--spr-btn-h);
  padding: 0 .55rem;
  margin-left: auto;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .62rem;
}

/* Compact icon variant used in navbar */
.btn-reset--clear.spr-nav-clear{
  width: 1.9rem;
  min-width: 1.9rem;
  padding: 0;
  margin-left: 0;
  letter-spacing: 0;
  text-transform: none;
}

.btn-reset-active{
  color: #ff5a5a;
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
}

.btn-reset-active:hover{
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.18);
  color: #ff6d6d;
}

.btn-reset--clear:not(.btn-reset-active):not(.btn-reset-disabled):hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
  color: rgba(255,255,255,.80);
}

.btn-reset-disabled{
  opacity: .45;
  pointer-events: none;
}

.btn-reset:active{
  transform: translateY(1px);
}

.btn-reset:active{ transform: translateY(1px); }
.btn-reset-hidden{
  opacity: 0;
  pointer-events: none;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

/* ==========================================================================
   Buttons (MONO HUD – muted/grey, weniger “poppig”)
   ========================================================================== */

:root{
  --spr-btn-radius: 5px;
  --spr-btn-h: 1.9rem;

  --spr-btn-bg: rgba(255,255,255,.045);
  --spr-btn-bg-hover: rgba(255,255,255,.070);
  --spr-btn-bg-active: rgba(255,255,255,.090);

  --spr-btn-border: rgba(255,255,255,.11);
  --spr-btn-border-hover: rgba(255,255,255,.18);

  --spr-btn-text: rgba(248,249,250,.86);
  --spr-btn-text-strong: rgba(255,255,255,.96);

  --spr-btn-shadow: 0 10px 20px rgba(0,0,0,.30);
  --spr-btn-shadow-inset: inset 0 1px 0 rgba(255,255,255,.05);

  /* “Primary” sehr zurückhaltend (slate/steel) */
  --spr-btn-accent-bg: rgba(148,163,184,.14);
  --spr-btn-accent-bg-hover: rgba(148,163,184,.18);
  --spr-btn-accent-border: rgba(148,163,184,.34);
  --spr-btn-accent-border-hover: rgba(148,163,184,.48);

  /* Info minimal unterscheidbar, aber nicht bunt */
  --spr-btn-info-bg: rgba(94,234,212,.20);        /* Erhöht von .10 */
  --spr-btn-info-bg-hover: rgba(94,234,212,.28);
  --spr-btn-info-border: rgba(94,234,212,.35);    /* Erhöht von .20 */
  --spr-btn-info-border-hover: rgba(94,234,212,.48);

  /* Focus Ring: neutral-grau statt knallblau */
  --spr-btn-focus: rgba(148,163,184,.26);
}

.btn-add,
.btn-cancel,
.btn-action,
.btn-action-menu,
.spr-login-btn,
.btn-reset{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--spr-btn-h);
  line-height: 1;
  text-align: center;
  transition:
    background .14s ease,
    border-color .14s ease,
    box-shadow .14s ease,
    transform .08s ease,
    color .14s ease;
}

@media (prefers-reduced-motion: reduce){
  .btn-add,
  .btn-cancel,
  .btn-action,
  .btn-action-menu,
  .spr-login-btn,
  .btn-reset{ transition: none; }
}

.btn-add:active,
.btn-cancel:active,
.btn-action:active,
.btn-action-menu:active,
.spr-login-btn:active,
.btn-reset:active{
  transform: translateY(1px);
  background: var(--spr-btn-bg-active);
}

.btn-add:focus-visible,
.btn-cancel:focus-visible,
.btn-action:focus-visible,
.btn-action-menu:focus-visible,
.spr-login-btn:focus-visible,
.btn-reset:focus-visible{
  outline: none;
  box-shadow:
    0 0 0 .22rem var(--spr-btn-focus),
    var(--spr-btn-shadow-inset);
}

/* Pagination info (lighter than full white but more visible than .text-muted) */
.spr-paging-info{
  color: var(--spr-nav-text);
  font-weight: 700;
  font-size: .78rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

/* small variants for app buttons to match compact pagination */
.btn-add.btn-sm, .btn-cancel.btn-sm{
  padding: .16rem .6rem;
  font-size: .78rem;
  line-height: 1.1;
  height: var(--spr-btn-h);
}

/* Compact paging adjustments */
.spr-paging-compact{
  position: relative;
}
.spr-paging-compact .btn-action{ padding: .18rem .5rem; font-size: .80rem; }
.spr-paging-compact .spr-paging-info{ color: rgba(120,160,130,0.75); font-weight:700; }

/* Page indicator button (dezent und dunkler) */
.spr-page-indicator{
  background: var(--spr-nav-glass) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: var(--spr-nav-text-strong) !important;
  font-weight: 600;
  opacity: 0.95;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: 0 1px 0 rgba(255,255,255,0.04);
  padding: .2rem .6rem;
  font-size: .82rem;
  line-height: 1.2;
  border-radius: 7px;
}

/* --------------------------------------------------------------------------
   Primary (add/save) – muted slate statt “Neon-Blau”
   -------------------------------------------------------------------------- */
.btn-add{
  padding: 0 .7rem;
  font-size: .85rem;
  line-height: 1;
  border-radius: var(--spr-btn-radius);
  font-weight: 850;

  color: var(--spr-btn-text-strong);
  background: var(--spr-btn-accent-bg);
  border: 1px solid var(--spr-btn-accent-border);

  box-shadow: var(--spr-btn-shadow), var(--spr-btn-shadow-inset);
}

.btn-add:hover{
  background: var(--spr-btn-accent-bg-hover);
  border-color: var(--spr-btn-accent-border-hover);
}

/* --------------------------------------------------------------------------
   Neutral (cancel/close/export/import/logout)
   -------------------------------------------------------------------------- */
.btn-cancel{
  padding: 0 .7rem;
  font-size: .85rem;
  line-height: 1;
  border-radius: var(--spr-btn-radius);
  font-weight: 800;

  color: var(--spr-btn-text);
  background: var(--spr-btn-bg);
  border: 1px solid var(--spr-btn-border);

  box-shadow: var(--spr-btn-shadow), var(--spr-btn-shadow-inset);
}

.btn-cancel:hover{
  background: var(--spr-btn-bg-hover);
  border-color: var(--spr-btn-border-hover);
  color: var(--spr-btn-text-strong);
}

/* --------------------------------------------------------------------------
   Table action buttons (kompakt, flach)
   -------------------------------------------------------------------------- */
.btn-action{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: var(--spr-btn-h);
  padding: 0 .55rem;
  font-size: .72rem;
  line-height: 1;
  font-weight: 850;
  border-radius: 5px;
  white-space: nowrap;

  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(248,249,250,.86);

  box-shadow: var(--spr-btn-shadow-inset);
}

.btn-action:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.95);
}

/* Info button (leicht abgesetzt, aber sehr dezent) */
.btn-action-info{
  min-width: 2.10rem;
  padding: 0 .55rem;

  background: var(--spr-btn-info-bg);
  border-color: var(--spr-btn-info-border);
  color: rgba(236,254,255,.88);
}
.btn-action-info:hover{
  background: var(--spr-btn-info-bg-hover);
  border-color: var(--spr-btn-info-border-hover);
  color: rgba(236,254,255,.96);
}

/* Menu (⋯) – neutral */
.btn-action-menu{
  min-width: 1.9rem;
  height: 1.6rem;
  padding: 0 .4rem;

  background: rgba(255,255,255,.10);  /* Erhöht von .04 */
  border: 1px solid rgba(255,255,255,.22);  /* Erhöht von .12 */
  color: rgba(248,249,250,.88);

  box-shadow: var(--spr-btn-shadow-inset);
}
.btn-action-menu:hover{
  background: rgba(255,255,255,.15);  /* Erhöht von .07 */
  border-color: rgba(255,255,255,.32);  /* Erhöht von .18 */
  color: rgba(255,255,255,.98);
}

/* Alerts (minimal toast) */
.spr-alerts{
  position: fixed;
  top: 0.6rem;
  right: 1rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
  z-index: 1050;
}

.spr-alert{
  background: rgba(10,12,16,.92);
  color: rgba(248,249,250,.85);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.12);
  padding: .35rem .55rem;
  font-size: .8rem;
  letter-spacing: .04em;
  box-shadow: 0 12px 26px rgba(0,0,0,.32);
  max-width: 22rem;
}

.spr-status-flash{
  justify-self: end;
  text-align: right;
}

.spr-status-flash .spr-alert{
  display: inline-block;
  border-radius: 6px;
  box-shadow: none;
  font-size: .72rem;
  padding: 0;
  background: transparent;
  border: none;
  color: rgba(248,249,250,.72);
  letter-spacing: .06em;
}

.spr-status-flash .spr-alert span{
  display: block;
  margin-top: .3rem;
}



/* ==========================================================================
   Forms
   ========================================================================== */

.spr-title{
  font-size: 1.15rem;
  color: rgba(248,249,250,0.32);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  line-height: 1.1;
  text-shadow: 0 4px 14px rgba(0,0,0,0.78);
}

.spr-title.spr-title-strong{
  color: rgba(248,249,250,0.48);
  text-shadow: 0 6px 18px rgba(0,0,0,0.92);
}

.spr-form-panel{
  border: 0 !important;
  border-radius: 0;
  padding: .45rem .75rem;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

.spr-form-panel .form-control,
.spr-form-panel .form-select{
  width: 100%;
}

.spr-form-panel .d-flex > .form-control,
.spr-form-panel .d-flex > .form-select{
  flex: 1 1 0;
  min-width: 0;
}

.spr-form-panel .spr-input-pair > .form-control{
  flex: 2 1 0;
  min-width: 0;
}

.spr-form-panel .spr-input-pair > .form-select{
  flex: 1 1 0;
  min-width: 6.5rem;
}

.spr-form-panel .spr-input-pair > .spr-select{
  flex: 0 0 4.8rem;
  min-width: 4.8rem;
}

.spr-file{
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}

.spr-file-cell{
  text-align: left;
}

.spr-file-cell .spr-file{
  justify-content: flex-start;
}

.spr-file-input{
  font-size: .78rem;
  color: rgba(228,236,248,.92);
  background: transparent !important;
  border: 0 !important;
  padding: 0;
  margin: 0;
  outline: none !important;
  appearance: none;
}

.spr-file-input::file-selector-button,
.spr-file-input::-webkit-file-upload-button{
  display: none;
}

.spr-file-picker{
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  width: 100%;
  max-width: 22rem;
}

.spr-file-row{
  display: block;
  margin-top: .4rem;
}

.spr-file-picker--table{
  max-width: 100%;
}

.spr-file-btn{
  height: var(--spr-btn-h);
  min-width: 8.4rem;
  padding: 0 .95rem;
  border-radius: 7px;
  border: 1px solid rgba(185,185,185,.18);
  color: rgba(220,228,238,.85);
  background: rgba(10,12,16,.35);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: .72rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  user-select: none;
  transition: border-color .18s ease, background .18s ease, color .18s ease;
}

.spr-file-count{
  flex: 1 1 auto;
  min-height: 2.2rem;
  display: inline-flex;
  align-items: center;
  padding: 0 .65rem;
  font-size: .72rem;
  letter-spacing: .03em;
  color: rgba(190,202,218,.78);
  border-bottom: 1px solid rgba(150,165,185,.25);
  background: transparent;
  line-height: 1.1;
}

.spr-file-picker:focus-within .spr-file-btn{
  border-color: rgba(210,220,235,.45);
  color: rgba(240,245,255,1);
}

.spr-file-picker:focus-within .spr-file-count{
  border-bottom-color: rgba(160,190,235,.6);
  color: rgba(210,222,240,.92);
}

.spr-file-btn:hover{
  border-color: rgba(220,230,245,.45);
  background: rgba(255,255,255,.04);
}

.spr-file-name{
  display: inline-flex;
  align-items: center;
  height: var(--spr-btn-h);
  line-height: 1;
  padding: 0 .6rem;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(200,210,220,.7);
  border: 1px solid rgba(185,185,185,.16);
  background: rgba(0,0,0,.35);
  border-radius: 5px;
  min-width: 10rem;
}

.spr-file-input--hidden{
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}

.spr-form-actions{
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  margin-bottom: 1rem;
}

.spr-form-actions .btn-reset--clear{
  margin-left: 0;
}

.spr-edit-images-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: .5rem;
  align-items: end;
}

.spr-edit-image-card{
  display: flex;
  flex-direction: column;
  gap: .25rem;
  text-decoration: none;
  color: rgba(200,210,220,.75);
  align-items: center;
  justify-content: flex-end;
}

.spr-edit-image-remove{
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  font-size: .68rem;
  color: rgba(190,200,210,.72);
}

.spr-edit-docs-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .6rem;
}

.spr-edit-doc-card{
  display: grid;
  gap: .4rem;
  padding: .45rem .5rem;
  border: 1px solid rgba(185,185,185,.12);
  background: rgba(0,0,0,.25);
  border-radius: 6px;
}

.spr-doc-chip{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .72rem;
  color: rgba(210,220,232,.85);
}

.spr-doc-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 1.2rem;
  min-width: 2.1rem;
  padding: 0 .35rem;
  border: 1px solid rgba(185,185,185,.16);
  border-radius: 5px;
  background: rgba(0,0,0,.25);
  letter-spacing: .08em;
  font-size: .65rem;
  text-transform: uppercase;
}

.spr-doc-name{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.spr-edit-doc-card .spr-doc-name{
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  word-break: break-word;
  font-size: .78rem;
  line-height: 1.25;
}

.spr-edit-doc-remove{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .72rem;
  color: rgba(200,210,220,.7);
}

.signal-docs{
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .6rem;
}

.signal-doc-chip{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 2.1rem;
  padding: .3rem .55rem;
  border: 1px solid rgba(185,185,185,.18);
  border-radius: 6px;
  background: rgba(8,10,14,.35);
  font-size: .72rem;
  color: rgba(210,220,232,.85);
  text-decoration: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}

.signal-doc-chip:hover{
  border-color: rgba(185,185,185,.32);
  color: rgba(235,240,245,.95);
}

.signal-doc-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 1.25rem;
  min-width: 2.2rem;
  padding: 0 .35rem;
  border: 1px solid rgba(185,185,185,.2);
  border-radius: 5px;
  background: rgba(8,10,14,.45);
  letter-spacing: .08em;
  font-size: .65rem;
  text-transform: uppercase;
}

.signal-doc-name{
  max-width: 16rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Tighter form layout for full-HD */
.spr-form-panel .row{
  row-gap: .3rem;
}

.spr-form-panel .form-label{
  margin-bottom: .1rem;
}

.spr-form-panel .field-help{
  margin-top: .05rem;
  font-size: .84rem;
  letter-spacing: .45px;
}

.spr-form-panel + .spr-form-panel{
  border-top: 1px solid rgba(255,255,255,.06) !important;
  padding-top: .6rem;
  margin-top: .2rem;
}

.spr-form-panel .form-control,
.spr-form-panel .form-select{
  padding: .42rem .6rem;
  font-size: .82rem;
  line-height: 1.3;
}

.spr-select-compact{
  background: transparent !important;
  border: 0 !important;
  border-bottom: 0 !important;
  border-radius: 0 !important;
  color: rgba(248,249,250,.88) !important;
  padding: .2rem 1rem .2rem .5rem !important;
  min-height: 1.35rem;
  height: 1.35rem;
  line-height: 1.2;
  font-size: .875rem;
  box-shadow: none !important;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(248,249,250,.45) 50%),
    linear-gradient(135deg, rgba(248,249,250,.45) 50%, transparent 50%);
  background-position: calc(100% - .55rem) 52%, calc(100% - .35rem) 52%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.spr-form-panel .form-select.spr-select-compact{
  background: transparent !important;
  border: 0 !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
}

.spr-form-panel .form-select.spr-select-compact:focus{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.spr-select-compact option{
  background: rgba(8,10,14,.92);
  color: rgba(248,249,250,.82);
  font-size: .78rem;
  line-height: 1.2;
  padding: .2rem .45rem;
}

.spr-select-compact option:checked,
.spr-select-compact option:focus,
.spr-select-compact option:hover{
  background: rgba(255,255,255,.05);
  color: rgba(248,249,250,.92);
}

.spr-select-compact:focus{
  outline: none !important;
  border-bottom-color: transparent !important;
}

.spr-brand-title{
  font-size: 1.30rem;
  letter-spacing: 0.15em;
  line-height: 1.05;
  font-weight: 600;
  text-shadow: 0 4px 14px rgba(0,0,0,0.78);
}

.form-label {
  font-size: .70rem;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: rgba(248,249,250,.62) !important;
  margin-bottom: .25rem;
  font-weight: 600;
}

.field-help {
  font-size: .70rem;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: rgba(248,249,250,.62) !important;
  margin-top: .15rem;
  font-weight: 500;
  opacity: 0.6;
}

.form-control-dark,
.form-select-dark{
  background: rgba(0,0,0,.55) !important;
  color: rgba(248,249,250,.92) !important;
  border-radius: 0;
  border: 1px solid rgba(185,185,185,.16) !important;
}

.form-control-dark:focus,
.form-select-dark:focus{
  background: rgba(0,0,0,.55) !important;
  color: #fff !important;
  border-color: rgba(88,166,255,.55) !important;
  box-shadow:
    0 0 0 .22rem rgba(13,110,253,.22),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
  outline: none !important;
}

.form-control-dark::placeholder,
.form-select-dark::placeholder{
  color: rgba(248,249,250,.12) !important;
}

/* Remove number input spinners */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  appearance: none;
  -moz-appearance: textfield;
}

/* Required field indicators */
.required {
  color: #dc3545;
  font-weight: bold;
}

/* Required field hint */
.required-hint {
  color: #b86b6b;
  font-size: 0.9rem;
  font-weight: 500;
}

/* ==========================================================================
   Badges
   ========================================================================== */

.badge-pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .12rem .5rem;
  border-radius: 6px;
  border: 1px solid rgba(185,185,185,.06);
  background: rgba(255,255,255,.015);
  color: rgba(248,249,250,.68);
  font-size: .82rem;
  line-height: 1.1;
  text-transform: none;
  letter-spacing: .01em;
  font-weight: 500;
  font-family: var(--spr-font-base);
  min-width: 1.8rem;
}

.badge-band-hf{ color: var(--spr-text); }
.badge-band-vhf{ color: var(--spr-text); }
.badge-band-uhf{ color: var(--spr-text); }
.badge-band-shf{ color: var(--spr-text); }
.badge-band-l{ color: var(--spr-text); }
.badge-band-s{ color: var(--spr-text); }
.badge-band-c{ color: var(--spr-text); }
.badge-band-x{ color: var(--spr-text); }
.badge-band-ku{ color: var(--spr-text); }
.badge-band-ka{ color: var(--spr-text); }
.badge-band-range{ color: var(--spr-text); }
.badge-mod{ color: var(--spr-text); }

.spr-record-type{
  display: inline-block;
  margin-left: .45rem;
  padding: .12rem .5rem;
  border-radius: 6px;
  border: 1px solid rgba(185,185,185,.06);
  background: rgba(255,255,255,.015);
  color: rgba(248,249,250,.68);
  font-size: .82rem;
  line-height: 1.1;
  letter-spacing: .01em;
  text-transform: none;
  font-weight: 500;
  font-family: var(--spr-font-base);
}

.spr-record-type-classifier{ color: rgba(255,210,90,.85); border-color: rgba(255,210,90,.25); }
.spr-record-type-overview{ color: rgba(112,181,255,.85); border-color: rgba(112,181,255,.25); }
.spr-record-type-bandplan{ color: rgba(80,200,120,.85); border-color: rgba(80,200,120,.25); }
.spr-record-type-allocation{ color: rgba(255,130,90,.85); border-color: rgba(255,130,90,.25); }

/* ==========================================================================
   Table – CLEAR separation per record (FIXED)
   ========================================================================== */

.table-responsive{
  overflow-x: auto !important;
  overflow-y: visible !important;
  border-radius: 0;
}


.table-signals{
  background: transparent !important;
}

.table-signals td,
.table-signals th{
  color: var(--spr-table-text);
  border-color: var(--spr-table-border) !important;
}

.table-signals thead th,
.table-signals tbody td{
  padding: .38rem .58rem;
  vertical-align: middle;
  text-align: left;
  border: 0;
}

.table-signals thead th{
  position: sticky;
  top: 0;
  z-index: 4;
  text-align: center !important;
  background: rgba(10,12,16,.35);
  border-bottom: 0 !important;
  box-shadow: none;
  color: rgba(248,249,250,.60);
  font-size: .66rem;
  letter-spacing: .03em;
  text-transform: uppercase;
}

/* Stripe block: Header + Data + Images = exakt gleich */
.signal-row-even td{
  background: var(--spr-table-stripe-even) !important;
}

.signal-row-odd td{
  background: var(--spr-table-stripe-odd) !important;
}

.signal-images-row-even td{
  background: var(--spr-table-stripe-even) !important;
}

.signal-images-row-odd td{
  background: var(--spr-table-stripe-odd) !important;
}

/* Data/Image row spacing */
.table-signals tbody tr.signal-row td{ border-bottom-width: 0; }

.table-signals tbody tr.signal-images-row td{
  border-top: 0;
  border-bottom-width: 0;
  padding-top: .15rem;
  padding-bottom: .45rem;
}

/* Subtle separators around each (+) block */
/* Minimal lines: subtle horizontal only */
.table-signals tbody tr.signal-row td{
  border-top: 1px solid var(--spr-table-border);
  border-left: 0;
  border-right: 0;
}
.table-signals tbody tr.signal-images-row td{
  border-bottom: 1px solid var(--spr-table-border);
  border-left: 0;
  border-right: 0;
}
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row) td{
  border-bottom: 0;
}
.table-signals tbody tr.signal-row:not(:has(+ tr.signal-images-row)) td{
  border-bottom: 1px solid var(--spr-table-border);
}
.spr-compact .table-signals tbody tr.signal-row td{
  border-top: 1px solid var(--spr-table-border);
  border-bottom: 1px solid var(--spr-table-border);
}
.spr-compact .table-signals tbody tr.signal-row:last-child td{
  border-bottom: 1px solid var(--spr-table-border);
}

/* Bilder-Cell erbt Stripe-Farbe */
.signal-images-cell{
  background: inherit !important;
  padding-top: 0.6rem;
}

.table-signals tbody tr.signal-images-row:hover .signal-images-cell,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row .signal-images-cell,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) .signal-images-cell,
.table-signals tbody tr.signal-images-row.is-hovered .signal-images-cell,
.table-signals tbody tr.is-hovered .signal-images-cell{
  background: transparent !important;
}

/* Separator: nur Linie */
.signal-images-separator{
  background: transparent !important;
  height: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  margin: .35rem 0 .6rem;
}

.signal-images{
  margin-left: .5rem;
  margin-top: .2rem;
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  justify-content: flex-start;
  align-items: flex-end;
}

.spectrum-thumb{
  max-width: 120px;
  max-height: 80px;
  object-fit: cover;
  border-radius: 10px;
}

.img-thumbnail{
  background: transparent !important;
  border: 1px solid rgba(185,185,185,0.16) !important;
  border-radius: 10px !important;
  padding: .2rem !important;
  box-shadow: none !important;
}

/* Spacer */
.table-signals tbody tr.signal-spacer-row td{
  padding: .5rem 0 !important;
  background: transparent !important;
  border-top: 1px solid rgba(185,185,185,.14) !important;
}

.signal-attach-row{
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
}

.signal-attach-col{
  flex: 1 1 0;
  min-width: 0;
}

.signal-attach-col .signal-docs{
  margin-top: .1rem;
  display: grid;
  grid-auto-flow: row;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  grid-template-rows: repeat(3, auto);
  gap: .35rem .6rem;
  width: 100%;
  align-content: start;
}

.signal-attach-col .signal-docs .signal-doc-chip{
  width: 100%;
}

.signal-attach-col .signal-images{
  gap: .5rem;
}

.signal-attach-col .signal-images .spectrum-thumb{
  width: 80px;
  height: 60px;
  object-fit: cover;
}

/* Very light horizontal separators */
.table-signals tbody tr.signal-row td{
  border-top: 1px solid rgba(255,255,255,.025);
}

.table-signals tbody tr.signal-images-row td{
  border-bottom: 1px solid rgba(255,255,255,.025);
}

.table-signals tbody tr.signal-row:has(+ tr.signal-images-row) td{
  border-bottom: 1px solid rgba(255,255,255,.025);
}

/* Subtle always-on row outline */
.table-signals tbody tr.signal-row,
.table-signals tbody tr.signal-images-row{
  outline: none;
}

/* Subtle outline, excluding Typ column */
.table-signals tbody tr.signal-row td:not(.spr-col-type),
.table-signals tbody tr.signal-images-row td{
  box-shadow: none;
}

/* No glow/shadow for minimal table */
.table-signals tbody tr.signal-row{
  box-shadow: none;
}

/* Compact view */
.spr-compact .signal-spacer-row,
.spr-compact .signal-images-row{
  display: none;
}

.spr-compact .table-signals tbody td{
  padding-top: .2rem;
  padding-bottom: .2rem;
}

.spr-compact .table-signals tbody tr.signal-images-row td{
  padding-top: .1rem;
  padding-bottom: .25rem;
}

/* ==========================================================================
   Table – Action column (more space for data)
   ========================================================================== */

.spr-col-actions{
  width: 40px;
  min-width: 40px;
  max-width: 40px;
  padding-left: .25rem !important;
  padding-right: .25rem !important;
  white-space: nowrap;
}

/* Compact/Comfort toggle */
.spr-density-toggle{
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  font-size: .72rem;
  letter-spacing: var(--spr-track-wide);
  text-transform: uppercase;
  color: rgba(248,249,250,.55);
  user-select: none;
}

.spr-density-link{
  color: var(--spr-nav-text);
  text-decoration: none;
  font-size: .95rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .06rem .1rem .08rem;
  border-bottom: 1px solid transparent;
  transition: color .14s ease, border-color .14s ease;
}

.spr-density-link:hover{
  color: var(--spr-nav-text-strong);
  border-color: rgba(255,255,255,.14);
}

.spr-density-link.is-active{
  color: rgba(120,180,255,.95);
  border-color: rgba(120,180,255,.55);
}

.spr-density-sep{
  color: var(--spr-nav-text-dim);
  margin: 0 .25rem;
}

.spr-menu-label{
  color: var(--spr-nav-text-quiet);
  text-transform: uppercase;
  letter-spacing: .55px;
  font-size: .7rem;
  border-bottom: 0;
  padding: .02rem .1rem .02rem;
  margin-right: .25rem;
}

.spr-menu-tab{
  display: inline-flex;
  align-items: center;
  padding: .16rem .5rem;
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--spr-nav-text);
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
  transition: color .14s ease, border-color .14s ease, background .14s ease;
}

.spr-menu-tab:hover{
  color: var(--spr-nav-text-strong);
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
}

.spr-menu-tab.is-active{
  color: rgba(120,180,255,.95);
  border-color: rgba(120,180,255,.7);
  background: rgba(120,180,255,.12);
}

.spr-nav-stack{
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}

.spr-nav-row{
  display: flex;
  align-items: center;
  gap: .6rem;
  width: 100%;
}

.spr-nav-row--with-search{
  flex-wrap: wrap;
  row-gap: .4rem;
}

.spr-nav-single{
  padding: .08rem 0;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.spr-nav-links{
  flex: 1 1 auto;
  min-width: 0;
}

.spr-nav-label{
  color: rgba(220,228,238,.55);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .7rem;
  user-select: none;
  pointer-events: none;
  margin-right: .04rem;
}

.spr-nav-label--disabled{
  color: rgba(200,210,220,.28) !important;
}

.spr-nav-right-group{
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .35rem;
  margin-left: auto;
  white-space: nowrap;
}

.spr-nav-right-group--inline{
  flex-direction: row;
  align-items: center;
  gap: .45rem;
}

.spr-type-filters--menu{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-right: .3rem;
}


.spr-nav-label + .spr-type-filters--menu{
  margin-left: 0;
}

.spr-type-toggle{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.0rem;
  height: 2.0rem;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  background: transparent;
  color: var(--spr-nav-text);
  cursor: pointer;
  transition: color .14s ease, border-color .14s ease, background .14s ease;
}

.spr-type-toggle input{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.spr-type-toggle svg{
  width: 1.05rem;
  height: 1.05rem;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
  color: inherit;
}

.spr-type-toggle:hover{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
}

.spr-type-toggle--signal input:checked + svg{
  color: rgba(150,255,196,.95);
}

.spr-type-toggle--reference input:checked + svg{
  color: rgba(233,196,106,.95);
}

.spr-type-toggle--military input:checked + svg{
  color: rgba(255,170,170,.95);
}

.spr-nav-search-inline{
  width: 100%;
  order: 2;
  margin-top: .35rem;
  padding-top: .35rem;
  padding-bottom: .35rem;
  border-top: 0;
  border-bottom: 0;
  background: var(--spr-bg);
  position: relative;
  display: flex;
  justify-content: center;
}

.spr-nav-search-form--hidden{
  visibility: hidden;
  pointer-events: none;
}

.spr-nav-mode-placeholder{
  min-width: 4.8rem;
  min-height: 2.0rem;
}

.spr-nav-mode{
  min-width: 4.8rem;
  min-height: 2.0rem;
}

/* Full-width separator between menu row and search row */
.spr-nav-search-inline::before{
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 100vw;
  height: 2px;
  transform: translateX(-50%);
  background: linear-gradient(
    90deg,
    rgba(199,213,224,0),
    rgba(199,213,224,.18),
    rgba(199,213,224,0)
  );
  pointer-events: none;
}

/* Soft shadow under search row to separate table while scrolling */
.spr-nav-search-inline::after{
  content: none;
}

.spr-role-dot{
  width: .6rem;
  height: .6rem;
  border-radius: 999px;
  display: inline-block;
  box-shadow: 0 0 0 1px rgba(255,255,255,.18), 0 0 6px rgba(0,0,0,.4);
}

.spr-role-dot--admin{
  background: rgba(220,53,69,.85);
}

.spr-role-dot--viewer{
  background: rgba(34,197,94,.85);
}

.spr-nav-mode{
  display: inline-flex;
  align-items: center;
  gap: .15rem;
  white-space: nowrap;
  padding: .12rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: transparent;
}

.spr-nav-mode .spr-density-sep{
  display: none;
}

.spr-nav-mode .spr-menu-tab{
  border: 0;
  border-radius: 999px;
  background: transparent;
  padding: .22rem .72rem;
  font-size: .7rem;
  letter-spacing: .03em;
}

.spr-menu-tab--icon{
  width: 2.2rem;
  height: 2.0rem;
  padding: .2rem;
  justify-content: center;
  gap: 0;
}

.spr-menu-tab--icon svg{
  width: 1.1rem;
  height: 1.1rem;
  display: block;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.spr-nav-disabled{
  opacity: .45;
  pointer-events: none;
}

.spr-menu-tab--disabled{
  opacity: .6;
  pointer-events: none;
}

.spr-menu-tab--logout{
  color: rgba(255,120,120,.75);
}

.spr-menu-tab--logout:hover{
  color: rgba(255,120,120,.95);
}

/* Full view: card layout */
.signal-card-list{
  display: flex;
  flex-direction: column;
  gap: .5rem;
  margin-top: .4rem;
}

.signal-card{
  border: 1px solid rgba(185,185,185,.08);
  border-radius: 12px;
  padding: .55rem .7rem;
  background: rgba(10,12,16,.48);
  box-shadow: none;
}

.signal-card-even{
  background: rgba(255,255,255,.02);
}

.signal-card-odd{
  background: rgba(255,255,255,.035);
}

.signal-card-shell{
  display: flex;
  gap: .9rem;
  align-items: flex-start;
}

.signal-card-type{
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 32px;
  padding-top: .1rem;
}

.spr-type-badge--card{
  width: 24px;
  height: 24px;
  padding: 0;
  border-radius: 7px;
  border: 1px solid rgba(185,185,185,.14);
  background: rgba(255,255,255,.03);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.spr-type-badge--card .spr-type-icon{
  width: 14px;
  height: 14px;
}

.signal-card-content{
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: .45rem;
}

.signal-card-top{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .6rem;
}

.signal-card-title{
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: .15rem;
}

.signal-card-name{
  font-size: .95rem;
  font-weight: 600;
  color: rgba(248,249,250,.92);
}

.signal-card-sub{
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  font-size: .74rem;
  color: rgba(248,249,250,.65);
}

.signal-card-sub span{
  padding: .1rem .4rem;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 6px;
  background: rgba(255,255,255,.02);
}

.signal-card-actions .btn-action{
  opacity: .6;
}

.signal-card-actions .btn-action:hover{
  opacity: 1;
}

.signal-card-fields{
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: .4rem;
}

.signal-field{
  padding: .35rem .5rem;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 7px;
  background: rgba(255,255,255,.015);
}

.signal-field-label{
  font-size: .58rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(248,249,250,.45);
}

.signal-field-value{
  margin-top: .14rem;
  font-size: .82rem;
  color: rgba(248,249,250,.86);
  font-family: var(--spr-font-mono);
}

.signal-card-media,
.signal-card-docs{
  margin-top: .45rem;
  margin-left: 3.0rem;
}

.signal-card .signal-images{
  margin-left: 0;
  gap: .5rem;
}

.signal-card .signal-images img{
  width: 96px;
  height: 64px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(185,185,185,.12);
  padding: .15rem;
  background: rgba(255,255,255,.02);
}

@media (max-width: 1200px){
  .signal-card-fields{
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 900px){
  .signal-card-shell{
    gap: .6rem;
  }

  .signal-card-type{
    width: 32px;
  }

  .signal-card-top{
    flex-direction: column;
    align-items: flex-start;
  }

  .signal-card-media,
  .signal-card-docs{
    margin-left: 0;
  }
}

/* Table minimal lines + more air (override) */
.table-signals tbody tr.signal-row td,
.table-signals tbody tr.signal-images-row td{
  border-top: 1px solid rgba(185,185,185,.06) !important;
  border-bottom: 1px solid rgba(185,185,185,.06) !important;
}

.table-signals tbody tr td:last-child{
  border-top: 0 !important;
  border-bottom: 0 !important;
}

.table-signals tbody tr.signal-row td{
  padding-top: .36rem !important;
  padding-bottom: .36rem !important;
}

.spr-compact .table-signals tbody tr.signal-row td{
  padding-top: .22rem !important;
  padding-bottom: .22rem !important;
}

/* Variant 4: keep numeric columns aligned without switching fonts */
.table-signals .spr-col-freq,
.table-signals .spr-col-bandwidth,
.table-signals .spr-col-symbolrate,
.table-signals .spr-col-shift{
  font-variant-numeric: tabular-nums;
  font-family: var(--spr-font-base);
  letter-spacing: normal;
}

.table-signals .spr-col-bandwidth,
.table-signals .spr-col-symbolrate,
.table-signals .spr-col-shift,
.table-signals .spr-col-struktur{
  text-align: center !important;
}

.spr-nav-mode .spr-menu-tab:hover{
  background: rgba(255,255,255,.10);
}

.spr-nav-mode .spr-menu-tab.is-active{
  background: rgba(120,180,255,.12);
  border: 0;
  color: rgba(120,180,255,.95);
}

.spr-density-link--danger{
  color: rgba(255,120,120,.75);
}

.spr-density-link--danger:hover{
  color: rgba(255,120,120,.95);
  border-color: rgba(255,120,120,.45);
}



.spr-density-link--status{
  color: rgba(70,220,140,.75);
}

.spr-density-link--status:hover{
  color: rgba(70,220,140,.92);
  border-color: rgba(70,220,140,.45);
}

.spr-inline-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: .9rem;
  height: .9rem;
  margin-right: .18rem;
  transform: translateY(1px);
}

.spr-inline-icon svg{
  width: 100%;
  height: 100%;
  display: block;
}

.spr-mini-nav{
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  font-size: .78rem;
  letter-spacing: var(--spr-track-wide);
  text-transform: uppercase;
}

.spr-header-title{
  font-size: .72rem;
  letter-spacing: var(--spr-track-wide);
  text-transform: uppercase;
  color: rgba(248,249,250,.75);
  line-height: 1.2;
}

.spr-sticky-header{
  position: sticky !important;
  top: calc(var(--spr-navbar-height) + .6rem);
  z-index: 1025;
  left: 0;
  right: 0;
  width: 100%;
  box-shadow: 0 12px 26px -22px rgba(0,0,0,0.85);
  overflow: visible;
  background: rgba(11,12,14,.92);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-top: 1px solid rgba(255,255,255,0.04);
  border-bottom: 1px solid rgba(185,185,185,.10);
}

.spr-sticky-header::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-36px;
  height:36px;
  background: linear-gradient(
    to bottom,
    rgba(8,9,11,.42),
    rgba(8,9,11,.12) 55%,
    rgba(8,9,11,0)
  );
  pointer-events:none;
  box-shadow: 0 24px 38px -18px rgba(0,0,0,.68);
}

.spr-gap-blur{
  position: sticky;
  top: var(--spr-navbar-height);
  height: .6rem;
  z-index: 1024;
  background: rgba(11,12,14,.92);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.spr-gap-blur::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity: .04;
  background:
    repeating-linear-gradient(
      to bottom,
      rgba(255,255,255,0.06) 0px,
      rgba(255,255,255,0.06) 1px,
      rgba(0,0,0,0.00) 3px,
      rgba(0,0,0,0.00) 6px
    );
  mix-blend-mode: soft-light;
}

.spr-header-brand{
  display: flex;
  align-items: center;
  width: 100%;
  font-size: .64rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
  color: rgba(248,249,250,.6);
  margin-bottom: 0;
  justify-content: space-between;
  height: 2rem;
  line-height: 2rem;
  padding: 0 1rem;
  background: rgba(10,12,16,.45);
  backdrop-filter: blur(8px) saturate(1.05);
  -webkit-backdrop-filter: blur(8px) saturate(1.05);
}

.spr-header-brand-link{
  color: inherit;
  text-decoration: none;
}

.spr-header-brand-link:hover{
  color: rgba(255,255,255,.85);
}

.spr-header-role{
  margin-left: auto;
  font-size: .6rem;
  letter-spacing: var(--spr-track-wide);
  line-height: 1;
  display: inline-flex;
  align-items: center;
}

.spr-header-version{
  font-size: .6rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
  color: rgba(88,166,255,.75);
  margin-left: .35rem;
  text-shadow: 0 0 6px rgba(88,166,255,.35);
}

.spr-status-sep{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: .9rem;
  margin: 0 .2rem;
  color: rgba(248,249,250,.35);
}

.spr-status-sep-bottom{
  margin: 0 .2rem;
}

.spr-status-count{
  white-space: nowrap;
  color: rgba(200,210,222,.7);
  font-weight: 500;
  font-size: .9rem;
  line-height: 1;
  border: 0;
  background: transparent;
  padding: 0;
  border-radius: 0;
}

.spr-mini-toggle{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}

.spr-status-pages{
  font-size: .9rem;
}

.spr-status-right{
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: .2rem;
  white-space: nowrap;
}

.spr-status-inline{
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  line-height: 1;
}

.spr-status-left{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  white-space: nowrap;
}

.spr-status-entries{
  color: rgba(200,210,222,.7);
  font-size: .9rem;
}


/* Compact top paging controls without affecting other action buttons */
.spr-status-center .btn-action{
  height: 1.14rem;
  min-width: 1.2rem;
  padding: 0 .30rem;
  font-size: .64rem;
  border-radius: 4px;
}

.spr-add-btn{
  display: inline;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
  color: inherit !important;
  font-weight: inherit;
  font-size: inherit;
  text-transform: none;
  line-height: inherit;
  box-shadow: none;
}

.spr-add-btn:hover{
  color: rgba(248,249,250,.92) !important;
}

.spr-wiki-card{
  background: rgba(10,12,16,.45);
  border: 1px solid rgba(185,185,185,.10);
  border-radius: 0;
}

.spr-wiki-form .form-control{
  background: rgba(8,10,14,.35);
  border-color: rgba(160,170,180,.14);
}

.spr-wiki-form .form-label{
  color: rgba(200,210,220,.6);
  font-size: .68rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
}

.spr-wiki-form .card-body{
  display: block;
}

.spr-wiki-back{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-size: .72rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
  color: rgba(200,210,220,.7);
  text-decoration: none;
}

.spr-wiki-back:hover{
  color: rgba(230,235,240,.9);
  text-decoration: underline;
}

.spr-wiki-insert{
  display: flex;
  gap: .5rem;
  align-items: center;
}

.spr-wiki-insert .spr-wiki-image-size{
  width: 3.4rem !important;
  min-width: 3.4rem !important;
  max-width: 3.4rem !important;
  padding-right: 0.2rem;
}

.spr-wiki-insert--side{
  flex-direction: column;
  align-items: stretch;
  gap: .65rem;
}

.spr-wiki-insert--side .spr-wiki-image-size{
  max-width: 100%;
}

.spr-wiki-field-slim{
  padding: .28rem .45rem;
  font-size: .72rem;
  line-height: 1.2;
}

.spr-wiki-image-input{
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.spr-wiki-image-row{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  width: 100%;
}

.spr-wiki-file-btn{
  font-size: .62rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 0 .55rem;
  height: var(--spr-btn-h);
  width: auto;
  justify-content: center;
}

.spr-wiki-insert-btn{
  align-self: center;
  margin-left: auto;
  margin-right: auto;
  width: auto;
  min-width: 7.5rem;
  justify-content: center;
}

.spr-wiki-table-btn{
  align-self: center;
  margin-left: auto;
  margin-right: auto;
  min-width: 9rem;
}


.spr-wiki-table-config{
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: .35rem;
  display: flex;
  flex-direction: column;
  gap: .3rem;
}

.spr-wiki-table-fields{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .45rem;
  justify-items: center;
}

.spr-wiki-field-wrap{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .25rem;
}

.spr-wiki-field-label{
  font-size: .6rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(200,210,220,.55);
}

.spr-wiki-table-fields .spr-wiki-field-slim{
  max-width: 100%;
}

.spr-wiki-table-preview{
  font-size: .7rem;
  color: rgba(200,210,220,.55);
  text-align: center;
}

.spr-wiki-size-hint{
  font-size: .68rem;
  color: rgba(200,210,220,.55);
  text-align: center;
}

.spr-wiki-table{
  width: 100%;
  border-collapse: collapse;
  margin: .35rem 0;
}

.spr-wiki-table--auto{
  width: auto;
  display: inline-table;
  max-width: 100%;
}

.spr-wiki-table th,
.spr-wiki-table td{
  border: 1px solid rgba(255,255,255,0.14);
  padding: .35rem .45rem;
  text-align: left;
  font-size: .78rem;
  color: rgba(230,235,240,.85);
}

.spr-wiki-table th{
  color: rgba(200,210,220,.75);
  font-weight: 600;
}

.spr-wiki-modal-body img{
  max-width: 100%;
  height: auto;
}

.spr-wiki-shell{
  border: 1px solid rgba(185,185,185,.10);
  background: rgba(8,10,14,.42);
  padding: .5rem .65rem;
  margin: .35rem 0 .5rem;
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02);
}

.spr-wiki-toolbar{
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
  width: 100%;
  justify-content: flex-start;
}

.spr-wiki-shell .spr-wiki-menu{
  margin-left: 0;
  justify-content: flex-start;
  text-align: left;
}

.spr-wiki-shell--plain{
  border: none;
  background: transparent;
  padding: 0;
  margin: 0 0 .6rem;
}

.spr-wiki-menu{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .7rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
  color: rgba(200,210,220,.6);
}

.spr-wiki-menu .spr-density-link{
  font-size: inherit;
  letter-spacing: inherit;
}

.spr-wiki-new{
  white-space: nowrap;
  text-decoration: none;
  height: var(--spr-btn-h);
  line-height: 1;
  display: inline-flex;
  align-items: center;
}


.spr-wiki-search{
  min-width: 12rem;
}

.spr-wiki-select-wrap{
  width: 20rem;
  min-width: 20rem;
}

.spr-wiki-select-wrap .spr-select-trigger{
  width: 100%;
  justify-content: space-between;
}

.spr-wiki-search{
  width: 20rem;
  min-width: 20rem;
}

.spr-wiki-search-input{
  width: 20rem !important;
  min-width: 20rem !important;
  flex: 0 0 20rem;
}

.spr-wiki-filter{
  margin-right: 0;
}

.spr-wiki-select-wrap{
  width: 10.5rem;
  min-width: 10.5rem;
}



.spr-wiki-search .form-control{
  background: var(--spr-nav-input-bg) !important;
  border: 1px solid rgba(199,213,224,.18) !important;
  color: var(--steam-light) !important;
  font-size: .8rem;
  padding: .35rem .55rem;
  border-radius: 6px !important;
}

.spr-wiki-search .form-control::placeholder{
  color: rgba(248,249,250,.22) !important;
}

.spr-wiki-list{
  margin-top: 1rem;
}

.spr-wiki-alpha{
  display: flex;
  flex-wrap: wrap;
  gap: .35rem .5rem;
  margin: 0 0 .8rem;
  font-size: .65rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(200,210,220,.45);
}

.spr-wiki-alpha-wrap--top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .8rem;
}

.spr-wiki-alpha-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: .6rem;
}

.spr-wiki-alpha--page{
  justify-content: center;
  flex: 1 1 auto;
  height: var(--spr-btn-h);
  align-self: center;
}

.spr-wiki-alpha-buttons{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  align-self: center;
  margin-top: -18px;
}

.spr-wiki-alpha-buttons .btn-reset{
  height: var(--spr-btn-h);
  min-height: var(--spr-btn-h);
  line-height: var(--spr-btn-h);
  padding-top: 0;
  padding-bottom: 0;
  align-items: center;
}

.spr-wiki-alpha-buttons .spr-nav-clear{
  margin-top: 0;
}

.spr-wiki-alpha-wrap{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  height: var(--nav-control-h);
}

.navbar-search-row--inline .spr-wiki-alpha-wrap{
  padding: .1rem .4rem;
  border-radius: 10px;
  background: rgba(255,255,255,.08) !important;
  align-items: center;
}

.spr-wiki-alpha-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--nav-control-h);
  width: var(--nav-control-h);
  border-radius: 6px;
  background: var(--spr-nav-input-bg);
  border: 1px solid rgba(199,213,224,.28);
  color: rgba(248,249,250,.7);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}


.navbar-search-row--inline .spr-wiki-alpha-wrap{
  margin-top: 0;
}

.spr-wiki-alpha-link{
  color: rgba(200,210,220,.75);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.2rem;
  height: 1.6rem;
  font-size: .74rem;
  line-height: 1;
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 0 .25rem;
}

.spr-wiki-alpha-link:hover{
  color: rgba(240,245,250,.95);
  background: rgba(255,255,255,.06);
}

.spr-wiki-alpha-link.is-active{
  color: rgba(255,255,255,.96);
  background: rgba(120,160,210,.18);
  border-color: rgba(140,180,230,.28);
  text-decoration: none;
}

.spr-wiki-alpha-reset{
  height: var(--spr-btn-h);
}


.spr-wiki-group{
  display: flex;
  align-items: center;
  margin: 0.9rem 0 0.35rem;
}

.spr-wiki-group-letter{
  font-size: .7rem;
  letter-spacing: var(--spr-track-wider);
  text-transform: uppercase;
  color: rgba(200,210,220,.6);
}

.spr-wiki-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(13.5rem, 1fr));
  gap: .7rem;
  margin-bottom: .7rem;
}


.spr-wiki-tile{
  border: 1px solid rgba(120,130,140,.16);
  background: linear-gradient(180deg, rgba(14,18,24,.48), rgba(10,12,16,.36));
  padding: .65rem .7rem .7rem;
  border-radius: 10px;
  cursor: pointer;
  min-height: 3.6rem;
  display: flex;
  flex-direction: column;
  gap: .15rem;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}


.spr-wiki-tile:hover{
  border-color: rgba(130,150,180,.45);
  background: linear-gradient(180deg, rgba(18,24,34,.58), rgba(12,16,22,.46));
  box-shadow:
    inset 1px 0 0 rgba(120,180,255,.55),
    inset -1px 0 0 rgba(120,180,255,.55),
    inset 0 1px 0 rgba(120,180,255,.55),
    inset 0 -1px 0 rgba(120,180,255,.55),
    0 8px 18px rgba(0,0,0,.28),
    0 0 0 1px rgba(140,160,190,.18);
  transform: none;
}

.spr-wiki-tile-catline{
  font-size: .62rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(200,210,220,.55);
  margin-top: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.spr-wiki-tile-title{
  font-size: .8rem;
  font-weight: 600;
  color: rgba(235,240,245,.9);
  letter-spacing: .01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.spr-wiki-tile-subtitle{
  font-size: .7rem;
  color: rgba(185,198,210,.66);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.spr-wiki-tile-footer{
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
}

.spr-wiki-tile-category{
  font-size: .62rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(200,210,220,.6);
  padding: .05rem .35rem;
  border: 1px solid rgba(150,160,170,.18);
  border-radius: 999px;
  background: rgba(8,10,14,.35);
}

.spr-wiki-tile-actions{
  margin-top: auto;
  display: flex;
  gap: .6rem;
  align-items: center;
}

.spr-wiki-body-data{
  display: none;
}

.spr-wiki-modal-footer{
  border-top: 0;
  display: flex;
  justify-content: space-between;
  gap: .8rem;
  padding: .75rem 1rem;
}

.spr-wiki-modal-actions{
  display: flex;
  align-items: center;
  gap: .8rem;
}
.spr-wiki-modal-footer .btn-reset{
  min-width: 5.5rem;
  font-size: .72rem;
}

/* Modal footer buttons match global style */

.spr-wiki-modal-content{
  background: transparent;
  border: 0;
}

.spr-wiki-modal-header{
  border-bottom: 0;
}

.spr-wiki-modal-subtitle{
  color: rgba(200,210,220,0.65);
  font-size: .85rem;
  margin-top: .15rem;
}

.spr-wiki-modal-body{
  color: rgba(230,235,240,.88);
  line-height: 1.95;
  white-space: pre-wrap;
}

.modal-backdrop.show{
  opacity: .85;
}

.spr-wiki-modal-content .btn-close{
  filter: invert(1) opacity(.7);
}

.spr-wiki-empty-card{
  margin-top: 1rem;
}

.spr-wiki-subtitle{
  color: rgba(180,190,200,.6);
  letter-spacing: .01em;
}

.spr-wiki-empty-inline{
  display: none;
  margin: 2.5rem auto 0;
  text-align: center;
  color: rgba(200,210,220,.6);
  letter-spacing: .12em;
  font-size: .75rem;
  text-transform: uppercase;
}

.spr-wiki-file-input{
  max-width: 14rem;
}

.spr-wiki-editor{
  margin-top: .2rem;
}

.spr-wiki-panel{
  border: 1px solid rgba(120,130,140,.18);
  background: linear-gradient(180deg, rgba(16,20,26,.7), rgba(12,14,18,.55));
  border-radius: 12px;
  padding: .85rem .9rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

.spr-wiki-panel + .spr-wiki-panel{
  margin-top: .7rem;
}

.spr-wiki-panel-title{
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(200,210,220,.6);
  margin-bottom: .7rem;
  text-align: center;
  position: relative;
  padding-bottom: .45rem;
}

.spr-wiki-panel-title::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 36%;
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, rgba(120,180,255,0), rgba(120,180,255,.4), rgba(120,180,255,0));
}

.spr-wiki-panel-body{
  display: grid;
  gap: .55rem;
}

.spr-wiki-field{
  display: grid;
  gap: .25rem;
}

.spr-wiki-editor-textarea{
  min-height: 520px;
}

.spr-wiki-actions{
  display: flex;
  justify-content: flex-start !important;
  gap: .5rem;
}

.spr-wiki-actions .btn-reset--clear{
  margin-left: 0 !important;
}

.spr-wiki-cancel{
  margin-left: auto !important;
}

.spr-wiki-actions{
  width: 100%;
}

.spr-wiki-actions-spacer{
  flex: 1 1 auto;
}

.spr-wiki-size-row{
  display: flex;
  align-items: center;
  gap: .5rem;
}

.spr-wiki-size-row .form-label{
  margin: 0;
  min-width: 6rem;
}

.spr-wiki-size-row .spr-wiki-image-size{
  max-width: 9.5rem;
  height: var(--spr-btn-h);
  line-height: 1;
  padding-top: .25rem;
  padding-bottom: .25rem;
}

.spr-wiki-upload-row{
  display: flex;
  align-items: center;
  gap: .5rem;
}

.spr-wiki-image-picker{
  max-width: 18rem;
}

.spr-wiki-upload-row .spr-wiki-image-size{
  max-width: 7.5rem;
}

.spr-config-table{
  background: transparent;
}

.spr-config-table thead th{
  background: rgba(10,12,16,.65);
  color: rgba(220,225,230,.85);
  border-bottom: 1px solid rgba(185,185,185,.22);
}

.spr-config-table tbody td{
  background: rgba(10,12,16,.45);
  color: rgba(230,235,240,.85);
  border-bottom: 1px solid rgba(185,185,185,.12);
  vertical-align: middle;
}

.spr-config-table form{
  margin: 0;
}

.spr-config-table tbody tr:hover td{
  background: rgba(12,15,20,.55);
}

.spr-config-table .spr-config-action{
  min-width: 9.5rem;
  justify-content: center;
}

.spr-wiki-body{
  line-height: 1.6;
  color: rgba(230,235,240,.88);
}

.spr-wiki-actions{
  display: flex;
  align-items: center;
  gap: .8rem;
  justify-content: flex-end;
  margin-top: .6rem;
}

.spr-wiki-actions--top{
  margin-top: 0;
  margin-bottom: .6rem;
}

.spr-wiki-inline-form{
  margin: 0;
}

.spr-wiki-empty{
  color: rgba(200,205,210,.6);
}

.spr-config-section{
  padding: .2rem 0 .6rem;
}

.spr-config-divider{
  height: 1px;
  background: rgba(185,185,185,.12);
  margin: .8rem 0 1rem;
}

.spr-config-block{
  padding-bottom: .6rem;
  margin-bottom: .6rem;
  border-bottom: 1px solid rgba(185,185,185,.10);
}

.spr-config-block:last-child{
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 0;
}

.spr-config-title{
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(235,240,245,.9);
  margin: .4rem 0 .9rem;
}

.spr-config-subtitle{
  font-size: .75rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(200,210,220,.65);
  margin: .2rem 0 .55rem;
}

.spr-config-mini{
  font-size: .68rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(200,210,220,.55);
  margin: .55rem 0 .4rem;
}

.spr-config-inline{
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .6rem;
}

.spr-config-inline .form-control{
  max-width: 210px;
}

.spr-config-inline{
  justify-content: flex-start;
}

.spr-config-inline .btn-reset--clear{
  margin-left: 0;
}

.spr-config-wrap{
  max-width: 1100px;
  margin: 0 auto;
}

/* Compact columns for admin config tables */
.spr-config-table th,
.spr-config-table td{
  white-space: nowrap;
}

.spr-config-table td{
  white-space: normal;
}

.spr-config-table{
  table-layout: fixed;
}

.spr-config-table--wikiio thead th:nth-child(1),
.spr-config-table--wikiio tbody td:nth-child(1),
.spr-config-table--dbio thead th:nth-child(1),
.spr-config-table--dbio tbody td:nth-child(1){
  width: 28%;
}

.spr-config-table--wikiio thead th:nth-child(2),
.spr-config-table--wikiio tbody td:nth-child(2),
.spr-config-table--dbio thead th:nth-child(2),
.spr-config-table--dbio tbody td:nth-child(2){
  width: 44%;
}

.spr-config-table--wikiio thead th:nth-child(3),
.spr-config-table--wikiio tbody td:nth-child(3),
.spr-config-table--dbio thead th:nth-child(3),
.spr-config-table--dbio tbody td:nth-child(3){
  width: 170px;
  text-align: center;
}

.spr-config-table--cats thead th:nth-child(1),
.spr-config-table--cats tbody td:nth-child(1){
  width: 260px !important;
}

.spr-config-table--cats thead th:nth-child(2),
.spr-config-table--cats tbody td:nth-child(2){
  width: 110px !important;
  text-align: center;
}

.spr-config-table--cats thead th:nth-child(3),
.spr-config-table--cats tbody td:nth-child(3){
  width: 320px !important;
}

.spr-config-table--cats thead th:nth-child(4),
.spr-config-table--cats tbody td:nth-child(4){
  width: 150px !important;
  text-align: center;
}

.spr-config-table td .spr-file-picker{
  min-width: 220px;
}

.spr-config-table .spr-file-cell{
  width: auto;
}

.spr-config-table .btn-reset,
.spr-config-table .spr-config-action{
  justify-content: center;
}

.spr-config-table--cats td{
  overflow: visible;
}

.spr-config-table--cats form.d-flex{
  width: 100%;
  flex-wrap: nowrap;
}

.spr-config-table--cats form.d-flex input.form-control{
  flex: 1 1 auto;
  min-width: 135px;
}

.spr-config-table--cats tbody tr.spr-config-row td{
  border-bottom: 1px solid rgba(185,185,185,.12);
}

.spr-config-table--cats tbody tr.spr-config-row:last-child td{
  border-bottom: 0;
}

.spr-config-table--cats form.d-flex .btn-reset{
  white-space: nowrap;
  min-width: 88px;
}

/* Two-column config tables (ID + Titel) */
.spr-config-table th:nth-child(1):nth-last-child(2),
.spr-config-table td:nth-child(1):nth-last-child(2){
  width: 80px;
}

.spr-config-table--missing th:nth-child(2),
.spr-config-table--missing td:nth-child(2){
  width: 70%;
}

/* Missing entries table uses same column layout as categories table */

.spr-wiki-link-row{
  margin: 0.35rem 0 0.9rem;
}


.spr-header-row{
  min-height: .9rem;
  justify-content: space-between;
  gap: .75rem;
  overflow: visible;
}

.spr-menu-row{
  min-height: .9rem;
  margin-bottom: .04rem;
  overflow: visible;
}

.spr-paging-info--placeholder{
  opacity: 0;
  min-width: 6rem;
}

.spr-page-indicator-placeholder .spr-page-indicator{
  opacity: 0;
  min-width: 3.5rem;
}

.spr-btn-disabled{
  opacity: .45;
  pointer-events: none;
}

.spr-link-disabled{
  opacity: .45;
  pointer-events: none;
}

.spr-page-header{
  margin-top: 1.1rem;
  margin-bottom: 1.6rem;
}

.spr-topmark.spr-page-header,
.spectrum-topmark.spr-page-header{
  text-align: center;
}

.spr-page-row{
  margin-top: 1.0rem;
}

.spr-page-row > .col-xl-8,
.spr-page-row > .col-lg-10{
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.spr-page-header .spr-title,
.spr-page-header .spr-page-title{
  font-size: 1.1rem;
  letter-spacing: var(--spr-track-medium);
}

.spr-page-header .form-label,
.spr-page-header .spr-page-subtitle{
  margin-top: .35rem;
  color: rgba(248,249,250,.72);
}


.spr-type-badge{
  display: inline-flex;
  align-items: center;
  padding: .12rem .5rem;
  font-size: .82rem;
  line-height: 1.1;
  text-transform: none;
  border-radius: 6px;
  border: 1px solid rgba(185,185,185,.12);
  background: rgba(255,255,255,.04);
  color: rgba(248,249,250,.82);
  letter-spacing: .01em;
  font-weight: 500;
  font-family: var(--spr-font-base);
  white-space: nowrap;
  justify-content: center;
  min-width: 1.8rem;
}

.spr-type-badge--table{
  padding: 0;
  min-width: 0;
  width: 26px;
  height: 26px;
  border: 0;
  background: transparent;
}

.spr-type-badge--table .spr-type-icon{
  width: 18px;
  height: 18px;
}

.spr-type-icon{
  width: 14px;
  height: 14px;
  display: block;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.spr-type-badge-signal{
  border-color: rgba(88,166,255,.28);
  color: rgba(168,209,255,.82);
}

.spr-type-badge-zivil{
  border-color: rgba(74,222,128,.35);
  color: rgba(150,255,196,.9);
}

.spr-type-badge-reference{
  border-color: rgba(233,196,106,.28);
  color: rgba(233,196,106,.82);
}

.spr-type-badge-referenz{
  border-color: rgba(233,196,106,.28);
  color: rgba(233,196,106,.82);
}

.spr-type-badge-militaer{
  border-color: rgba(220,90,90,.30);
  color: rgba(255,170,170,.85);
}


.table-signals{
  table-layout: fixed;
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.spr-col-attach{
  width: 150px;
}

.spr-attach-stack{
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

.spr-attach-images{
  display: flex;
  flex-wrap: wrap;
  gap: .25rem;
}

.spr-attach-thumb{
  display: inline-flex;
  border: 1px solid rgba(185,185,185,.12);
  border-radius: 6px;
  padding: .1rem;
  background: rgba(255,255,255,.02);
}

.spr-attach-thumb img{
  width: 56px;
  height: 40px;
  object-fit: cover;
  border-radius: 4px;
}

.spr-attach-docs{
  display: flex;
  flex-direction: column;
  gap: .2rem;
}

.spr-attach-doc{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .3rem;
  align-items: center;
  text-decoration: none;
  color: var(--spr-table-text);
  font-size: .72rem;
}

.spr-attach-doc-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 18px;
  border-radius: 6px;
  border: 1px solid rgba(185,185,185,.14);
  background: rgba(255,255,255,.03);
  font-size: .6rem;
  letter-spacing: .08em;
  color: rgba(248,249,250,.7);
}

.spr-attach-doc-name{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.table-signals th,
.table-signals td{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-left: .62rem;
  padding-right: .62rem;
  border-right: 0;
  box-shadow: none;
}

/* Very subtle vertical separators */
/* No outer left/right frame (structure is last column) */
.table-signals thead th,
.table-signals tbody td{
  border-right: 0 !important;
}

/* Typo/spacing separation (no vertical lines) */
.table-signals thead th{
  letter-spacing: .04em;
  font-size: .76rem;
  color: rgba(199,213,224,.9);
}

.table-signals tbody td{
  letter-spacing: .01em;
  color: rgba(199,213,224,.88);
}

.table-signals .spr-col-type,
.table-signals .spr-col-band,
.table-signals .spr-col-mod,
.table-signals .spr-col-bandwidth,
.table-signals .spr-col-symbolrate,
.table-signals .spr-col-shift,
.table-signals .spr-col-struktur,
.table-signals .spr-col-actions{
  font-size: .82rem;
}

.table-signals .spr-col-name{
  font-size: .88rem;
}

.table-signals thead th{
  color: var(--steam-light);
}

.table-signals .spr-col-actions{
  background: transparent !important;
}

.table-signals th:last-child,
.table-signals td:last-child{
  border-right: 0;
  box-shadow: none;
}

.spr-col-type{
  width: 42px;
  min-width: 42px;
  text-align: center !important;
}

.spr-col-freq{
  width: 200px;
  min-width: 200px;
}

.spr-col-band{
  width: 94px;
  min-width: 94px;
  text-align: center !important;
}

.spr-col-name{
  width: 306px;
  min-width: 306px;
}

.spr-col-mod{
  width: 94px;
  min-width: 94px;
  text-align: center !important;
}


.spr-col-bandwidth{
  width: 120px;
  min-width: 120px;
  text-align: center !important;
  font-variant-numeric: tabular-nums;
}

.spr-col-symbolrate{
  width: 130px;
  min-width: 130px;
  text-align: center !important;
  font-variant-numeric: tabular-nums;
}

.spr-col-shift{
  width: 120px;
  min-width: 120px;
  text-align: center !important;
  font-variant-numeric: tabular-nums;
}

.spr-col-struktur{
  width: 120px;
  min-width: 120px;
  text-align: center !important;
  font-variant-numeric: tabular-nums;
}

.spr-col-freq{
  font-variant-numeric: tabular-nums;
}

.spr-col-actions{
  width: 38px;
  min-width: 38px;
}

.table-signals .spr-col-actions{
  opacity: .15;
  transition: opacity .15s ease;
}

.table-signals tbody tr:hover .spr-col-actions{
  opacity: 1;
}

.table-signals tbody tr:hover .spr-col-actions .btn-action{
  color: rgba(248,249,250,.9);
}

.table-signals tbody tr.is-hovered .spr-col-actions{
  opacity: 1;
}

.table-signals tbody tr.is-hovered .spr-col-actions .btn-action{
  color: rgba(248,249,250,.9);
}



.spr-paging-info-right{
  margin-right: .35rem;
  white-space: nowrap;
  text-align: right;
}

.spr-header-row .navbar-search-row{
  flex: 1;
  justify-content: center;
  min-width: 0;
}

.spr-header-row .spr-header-right{
  margin-left: auto;
  text-align: right;
}

.spr-info-link{
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

/* Keep ellipsis clickable, but only over text width (not full cell width) */
.spr-info-link.spr-tip{
  display: inline-block;
  max-width: 100%;
  text-decoration: none;
}

.spr-info-link:hover,
.spr-info-link:focus{
  color: rgba(255,255,255,0.95);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.spr-actions-spacer{
  display:inline-block;
  width: 1px;
  height: 1.55rem;
  opacity: 0;
}

/* ==========================================================================
   Modal + Lightbox
   ========================================================================== */

.spr-notes-modal{ max-width: 1200px; }

@media (min-width: 1600px){
  .spr-notes-modal{ max-width: 1400px; }
}

.spr-notes-title{
  font-size: .95rem;
  font-weight: 900;
  margin: 0;
  color: var(--spr-text);
}

.spr-modal-content{
  background: linear-gradient(180deg, rgba(22,26,32,.96), rgba(16,18,22,.96));
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  box-shadow: 0 24px 70px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.03);
  overflow: hidden;
}

.spr-modal-header{
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(14,16,20,.6);
  padding: .85rem 1.1rem;
}

.spr-modal-footer{
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(14,16,20,.6);
  padding: .7rem 1.1rem;
}

.spr-modal-content .modal-body{
  padding: 1rem 1.1rem;
  color: rgba(230,235,240,.9);
}

.spr-modal-content .btn-close{
  filter: invert(1) opacity(.7);
}

/* Lightbox */
.spr-lightbox{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background: rgba(0,0,0,0.86);
  z-index: 5000;
}

.spr-lightbox.is-open{ display: flex; }

.spr-lightbox-content{
  position: relative;
  max-width: 94vw;
  max-height: 92vh;
}

.spr-lightbox-img{
  display: block;
  max-width: 94vw;
  max-height: 86vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 24px 70px rgba(0,0,0,0.7);
  background: rgba(255,255,255,0.04);
}

.spr-lightbox-caption{
  margin-top: .55rem;
  text-align: center;
  font-size: .8rem;
  color: rgba(248,249,250,0.65);
}


.spr-lightbox-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: var(--spr-btn-h, 2.25rem);
  min-width: 2.6rem;
  padding: 0 .55rem;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.18);
  background: linear-gradient(180deg, rgba(26,30,36,.92), rgba(16,18,22,.92));
  color: rgba(235,240,245,.92);
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .08em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  user-select: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.02),
              0 6px 14px rgba(0,0,0,.35);
}

.spr-lightbox-nav:hover{
  background: linear-gradient(180deg, rgba(34,40,48,.95), rgba(20,22,28,.95));
  border-color: rgba(120,180,255,.35);
  color: rgba(245,250,255,.98);
}

.spr-lightbox-icon{
  width: 1.15rem;
  height: 1.15rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.spr-lightbox-prev{ left: -3.2rem; }
.spr-lightbox-next{ right: -3.2rem; }

@media (max-width: 700px){
  .spr-lightbox-prev{ left: 0; }
  .spr-lightbox-next{ right: 0; }
}

/* ==========================================================================
   Login (compatible)
   ========================================================================== */

.spr-bg{
  min-height: 100vh;
  position: relative;
  display: flex;
  align-items: center;
}

.spr-card-boost{ position: relative; overflow: hidden; }

.spr-card-boost::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:12px;
  background: url("/static/img/login.webp") center/cover no-repeat;
  opacity: .36;
  filter: contrast(0.95) brightness(.70) saturate(0.05);
  transform: none;
  z-index:0;
}

.spr-card-boost::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:12px;
  background: radial-gradient(circle at 50% 35%,
    rgba(0,0,0,0.15),
    rgba(0,0,0,0.48)
  );
  z-index:0;
}

.spr-card-boost > *{ position: relative; z-index: 1; }

.spr-login-card{
  background: rgba(10,12,16,.75) !important;
  border-radius: 12px !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  box-shadow: none !important;
}

.spr-login-input{
  background: rgba(0,0,0,.55) !important;
  border: 1px solid rgba(185,185,185,.16) !important;
  color: rgba(248,249,250,.92) !important;
  border-radius: 8px !important;
  text-align: center;
}

.spr-login-input:focus{
  outline: none !important;
  border-color: rgba(88,166,255,.55) !important;
  box-shadow:
    0 0 0 .22rem rgba(13,110,253,.22) !important;
}

.spr-login-btn{
  height: 2.15rem;
  padding: 0 1.2rem;
  font-size: .9rem;
  font-weight: 850;
  color: rgba(248,249,250,.92);
  background: rgba(10,12,16,.35) !important;
  border: 1px solid rgba(140,160,200,.28) !important;
  border-radius: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: var(--spr-btn-shadow-inset);
}

.spr-login-btn:hover{
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(160,180,220,.38) !important;
  color: rgba(255,255,255,.95);
}

/* ==========================================================================
   Index-only (dein aktueller Stand: kein eigener Scroll-Container)
   ========================================================================== */

.spr-table-scroll{
  height: auto;
  overflow: visible;
  padding-top: .6rem;
  scrollbar-gutter: auto;
}

/* Soft fade at top of table content */
.spr-table-scroll::before{
  content: none;
}

.spr-table-meta{
  margin-top: .4rem;
  margin-bottom: 3.4rem;
  width: 100%;
  padding-bottom: 0;
  position: relative;
  z-index: 5;
}

.spr-table-meta::before{
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 100vw;
  height: 100%;
  transform: translateX(-50%);
  background: var(--spr-bg);
  pointer-events: none;
  z-index: -1;
}

.spr-table-meta--audit{
  margin-bottom: 3.4rem;
}

.spr-table-meta::after{
  content: "";
  display: block;
  height: 0;
}

/* keep table meta consistent with base status styles */

.spr-table-meta .btn-action{
  padding: .18rem .55rem;
  font-size: .85rem;
  min-width: 1.8rem;
  background: transparent;
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(248,249,250,.7);
  border-radius: 4px;
  box-shadow: none;
  transition: color .14s ease, border-color .14s ease, background .14s ease;
}

.spr-table-meta .btn-action:hover{
  color: rgba(248,249,250,.9);
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.18);
}

.spr-table-meta .btn-action:active{
  background: rgba(255,255,255,.06);
}

.spr-table-meta .spr-btn-disabled{
  opacity: .4;
  background: transparent;
  border-color: rgba(255,255,255,.06);
}

.spr-table-meta-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
  width: 100%;
  position: relative;
  padding-left: 2.4rem;
  padding-right: 2.4rem;
}

.spr-table-meta-side{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 2.6rem;
}

.spr-table-meta-side.is-right{
  justify-content: flex-end;
}

.spr-table-meta-center{
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  flex: 0 0 auto;
  width: max-content;
}

.spr-table-meta-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.spr-table-meta-nav--left{
  left: 0;
}

.spr-table-meta-nav--right{
  right: 0;
}

.spr-table-meta-center .spr-status-count{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  text-align: center;
  letter-spacing: .02em;
  text-transform: none;
}

/* no extra overrides for table paging */

.spr-paging-compact{
  position: relative;
  background: var(--spr-nav-glass);
  border: 1px solid rgba(120,180,255,.12);
  border-bottom: 1px solid rgba(120,180,255,.16);
  border-radius: 0;
  box-shadow:
    0 0 0 1px rgba(120,180,255,.05) inset,
    0 8px 22px rgba(0,0,0,0.28);
  padding: .22rem 1rem .18rem;
  margin-bottom: .12rem;
  overflow: hidden;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  min-height: 2.2rem;
}

.spr-paging-compact .spr-header-row{
  min-height: 1.45rem;
}

.spr-paging-compact .spr-nav-bottom{
  min-height: 1.25rem;
}

.spr-paging-compact::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background: linear-gradient(180deg,
    rgba(120,180,255,.05),
    rgba(120,180,255,0)
  );
  filter: blur(3px);
  transform: scale(1.03);
  opacity: .45;
}

.spr-paging-compact::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background: linear-gradient(rgba(10,12,16,.30), rgba(10,12,16,.30));
}

.spr-paging-compact > *{
  position: relative;
  z-index: 2;
}

.page-index main{
  padding-top: .1rem !important;
  padding-bottom: .75rem !important;
}

.spr-main{
  padding-top: 0 !important;
}

.page-index main{
  padding-top: 0 !important;
}

/* ==========================================================================
   Dropdown Actions (⋯) – dunkel + del rot
   ========================================================================== */

.btn-action-menu{
  background: rgba(0,0,0,.24);
  color: rgba(235,240,248,.72);
  border: 1px solid rgba(185,185,185,.10);
  padding: 0 .4rem;
  min-width: 1.9rem;
  height: 1.6rem;
  border-radius: 6px;
  text-decoration: none;
}
.btn-action-menu:hover{
  background: rgba(255,255,255,.045);
  border-color: rgba(185,185,185,.17);
  color: rgba(248,249,250,.92);
}

.spr-actions-caret{
  display: inline-block;
  font-size: .68rem;
  line-height: 1;
  transform: translateY(-.02rem);
}

.spr-actions-icon{
  width: 1rem;
  height: 1rem;
  fill: rgba(225,230,236,.85);
}

/* Signal rows: consistent height */
.table-signals tbody tr.signal-row{
  min-height: 2.1rem;
  max-height: 2.6rem;
}

.table-signals tbody tr.signal-row td{
  height: 2.2rem;
  line-height: 1.2;
  padding-top: .28rem;
  padding-bottom: .28rem;
}

/* Dropdown menu “HUD / glass” */
.spr-dropdown{
  background: rgba(8,10,14,.92);
  border: 1px solid rgba(120,140,170,.16);
  border-radius: 8px;
  padding: .2rem;
  box-shadow: 0 18px 46px rgba(0,0,0,.65);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  min-width: 8.5rem;
  width: max-content;
}


.spr-dd-item{
  position: relative;
  border-radius: 6px;
  color: rgba(248,249,250,.80);
  padding: .36rem .5rem;
  font-weight: 600;
  text-transform: lowercase;

  background: transparent;
  border: 1px solid transparent;

  transition: background .14s ease, border-color .14s ease, transform .08s ease;
}

.spr-dd-item:active{
  transform: translateY(1px);
}


.spr-dd-item:hover,
.spr-dd-item:focus{
  background: rgba(255,255,255,.05);
  border-color: rgba(120,140,170,.16);
  color: rgba(255,255,255,.92);
}

.spr-dd-item--disabled{
  opacity: .45;
  pointer-events: none;
}

.spr-dd-item--disabled:hover,
.spr-dd-item--disabled:focus{
  background: transparent;
  border-color: transparent;
  color: rgba(248,249,250,.80);
}

.spr-dd-divider{
  border-top: 1px solid rgba(120,140,170,.16);
  margin: .28rem .2rem;
}

.spr-dropdown .dropdown-header{
  color: rgba(248,249,250,.55);
  font-size: .62rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .3rem .5rem .2rem;
}

/* del rot */
.spr-dd-danger{
  color: rgba(255,120,120,.95) !important;
}
.spr-dd-danger:hover,
.spr-dd-danger:focus{
  background: rgba(220,53,69,.20) !important;
  border-color: rgba(220,53,69,.26) !important;
  color: #fff !important;
}



/* ==========================================================================
   Notes (Usage + Notes) – FIX: kein Doppelrahmen
   ========================================================================== */

.spr-notes-usage-wrap,
.spr-notes-notes-wrap{
  background: linear-gradient(180deg, rgba(18,22,28,.78), rgba(12,14,18,.7));
  border: 1px solid rgba(120,130,140,.18);
  border-radius: 12px;
  padding: .65rem .75rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 6px 18px rgba(0,0,0,.25);
}

.spr-notes-usage-label,
.spr-notes-notes-label{
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(205,215,230,.6);
  margin-bottom: .35rem;
  font-weight: 800;
}

.spr-notes-usage{
  color: rgba(248,249,250,.90);
  font-weight: 700;
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.7;
}

/* WICHTIG:
   Du hast im HTML für Notes: <div class="spr-notes-body spr-notes-box" ...>
   Damit das NICHT doppelt gerahmt aussieht, machen wir spr-notes-box "neutral".
   (Du kannst die Klasse später ganz entfernen, aber musst du nicht.)
*/
.spr-notes-box{
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}

/* Notes Text */
.spr-notes-body{
  white-space: pre-wrap;
  word-break: break-word;
  font-size: .95rem;
  line-height: 1.85;
  color: rgba(248,249,250,0.88);
  min-height: 40vh;
  margin: 0;
}

.spr-notes-legend{
  margin-top: 1rem;
  padding: 0;
  border: 0;
  background: transparent;
}

.spr-notes-legend-title{
  font-size: .7rem;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: rgba(248,249,250,.62);
  margin-bottom: .35rem;
  font-weight: 600;
}

.spr-notes-legend-row{
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: .5rem;
  align-items: start;
  padding: .2rem 0;
}

.spr-notes-legend-row:first-of-type{
  border-top: 0;
}

.spr-notes-legend-label{
  color: rgba(248,249,250,.62);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .55px;
}

.spr-notes-legend-text{
  color: rgba(248,249,250,.55);
  font-size: .7rem;
  line-height: 1.35;
}

/* Optional / legacy (kannst du später löschen, stört nicht) */
.spr-notes-meta{
  padding: .55rem .65rem;
  border-radius: 10px;
  border: 1px solid rgba(185,185,185,.12);
  background: rgba(0,0,0,.25);
}

.spr-notes-meta-label{
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(248,249,250,.50);
  margin-bottom: .2rem;
  font-weight: 800;
}

.spr-notes-meta-value{
  font-size: .95rem;
  font-weight: 700;
  color: rgba(248,249,250,.92);
  white-space: pre-wrap;
  word-break: break-word;
}

/* ==========================================================================
   Tooltip + Ellipsis (HUD) – EINMALIG, ohne Duplikate
   ========================================================================== */

.table-signals{
  table-layout: fixed;
  width: 100%;
}

/* Ellipsis */
.spr-tip{
  position: relative;
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
  line-height: 1.2;
  padding-bottom: 1px;
}

/* Tooltip nur wenn Inhalt da ist */
.spr-tip[data-tip]:not([data-tip=""]):hover::after{
  content: attr(data-tip);
  position: absolute;
  left: 0;
  top: calc(100% + 6px);
  max-width: 680px;
  white-space: normal;
  padding: .45rem .55rem;
  border-radius: 10px;
  background: rgba(10,12,16,.96);
  border: 1px solid rgba(185,185,185,.18);
  color: rgba(248,249,250,.92);
  box-shadow: 0 18px 48px rgba(0,0,0,.75);
  z-index: 9999;
}

.spr-tip[data-tip]:not([data-tip=""]):hover::before{
  content:"";
  position:absolute;
  left: 14px;
  top: calc(100% + 2px);
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  background: rgba(10,12,16,.96);
  border-left: 1px solid rgba(185,185,185,.18);
  border-top: 1px solid rgba(185,185,185,.18);
  z-index: 10000;
}



/* Dropdown immer über Inhalt */
.dropdown-menu.spr-dropdown{
  z-index: 9999;
}

/* del rot (dein Wunsch) */
.spr-dropdown .spr-dd-danger{
  color: rgba(255,120,120,.95) !important;
}
.spr-dropdown .spr-dd-danger:hover,
.spr-dropdown .spr-dd-danger:focus{
  background: rgba(220,53,69,.20) !important;
  color: #fff !important;
}

/* Role badge (minimal) */
.spr-role-badge{
  background: transparent !important;
  color: rgba(248,249,250,.75) !important;
  border: 0;
  letter-spacing: .16em;
  font-weight: 600;
  padding: .1rem .3rem;
}

.spr-role-badge[data-role="viewer"]{
  color: rgba(70,220,140,.75) !important;
}

.spr-role-badge[data-role="admin"]{
  color: rgba(255,120,120,.75) !important;
}

/* Row focus */
/* Unified hover across main row + attachments row */
.table-signals tbody tr.signal-row:hover td,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row td,
.table-signals tbody tr.signal-images-row:hover td,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td,
.table-signals tbody tr.is-hovered td{
  background: transparent !important;
  color: inherit;
}

/* Ensure attachments row gets the same hover tint */
.table-signals tbody tr.signal-images-row:hover td,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row td,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td,
.table-signals tbody tr.signal-images-row.is-hovered td{
  background: var(--spr-table-hover) !important;
}

.table-signals tbody tr.signal-row:hover td:last-child,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td:last-child,
.table-signals tbody tr.signal-row.is-hovered td:last-child{
  background: transparent !important;
}

/* Force hover tint on attachments row (override stripe/inherit) */
.table-signals tbody tr.signal-images-row:hover td,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row td,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td,
.table-signals tbody tr.signal-images-row.is-hovered td,
.table-signals tbody tr.is-hovered + tr.signal-images-row td{
  background: transparent !important;
}

/* Full table: add top/bottom blue hover lines */
.table-signals tbody tr.signal-row:hover td,
.table-signals tbody tr.signal-row.is-hovered td{
  box-shadow:
    inset 0 1px 0 rgba(120,180,255,.55),
    inset 0 -1px 0 rgba(120,180,255,.55);
}

/* For rows with attachments: top line on main row, bottom line on attachments row */
.table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td,
.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td{
  box-shadow: inset 0 1px 0 rgba(120,180,255,.55) !important;
}

.table-signals tbody tr.signal-images-row:hover td,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row td,
.table-signals tbody tr.signal-images-row.is-hovered td,
.table-signals tbody tr.is-hovered + tr.signal-images-row td{
  box-shadow: inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

/* Hover style: left accent bar (main row only) */
.table-signals tbody tr.signal-row:hover td:first-child,
.table-signals tbody tr.is-hovered td:first-child{
  box-shadow:
    inset 2px 0 0 rgba(120,180,255,.55),
    inset 0 1px 0 rgba(120,180,255,.55),
    inset 0 -1px 0 rgba(120,180,255,.55);
}

/* If attachments exist: left accent should only draw the top line on main row */
.table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td:first-child,
.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td:first-child,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td:first-child{
  box-shadow:
    inset 2px 0 0 rgba(120,180,255,.55),
    inset 0 1px 0 rgba(120,180,255,.55) !important;
}

/* Hover style: right accent bar (end of Struktur column) */
.table-signals tbody tr.signal-row:hover td.spr-col-struktur,
.table-signals tbody tr.signal-row.is-hovered td.spr-col-struktur{
  box-shadow:
    inset -2px 0 0 rgba(120,180,255,.55),
    inset 0 1px 0 rgba(120,180,255,.55),
    inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

/* If attachments exist: right accent should only draw the top line on main row */
.table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td.spr-col-struktur,
.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td.spr-col-struktur,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td.spr-col-struktur{
  box-shadow:
    inset -2px 0 0 rgba(120,180,255,.55),
    inset 0 1px 0 rgba(120,180,255,.55) !important;
}

/* Ensure action column never shows the top line in full table hover */
.table-signals tbody tr.signal-row:hover td.spr-col-actions,
.table-signals tbody tr.signal-row.is-hovered td.spr-col-actions,
.table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td.spr-col-actions,
.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td.spr-col-actions,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td.spr-col-actions{
  box-shadow: none !important;
}
/* Suppress top/bottom lines on actions column */
.table-signals tbody tr.signal-row:hover td.spr-col-actions,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td.spr-col-actions,
.table-signals tbody tr.signal-row.is-hovered td.spr-col-actions{
  box-shadow: none !important;
}

/* Hover style: attachments row gets both left + right accents (single colspan cell) */
.table-signals tbody tr.signal-images-row:hover td.signal-images-cell,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row td.signal-images-cell,
.table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td.signal-images-cell,
.table-signals tbody tr.signal-images-row.is-hovered td.signal-images-cell,
.table-signals tbody tr.is-hovered + tr.signal-images-row td.signal-images-cell{
  box-shadow: inset 2px 0 0 rgba(120,180,255,.55),
              inset -2px 0 0 rgba(120,180,255,.55),
              inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

/* Hard override: no blue inner seam between main row and attachments row */
.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td{
  box-shadow: inset 0 1px 0 rgba(120,180,255,.55) !important;
}

.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td:first-child{
  box-shadow: inset 2px 0 0 rgba(120,180,255,.55),
              inset 0 1px 0 rgba(120,180,255,.55) !important;
}

.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td.spr-col-struktur{
  box-shadow: inset -2px 0 0 rgba(120,180,255,.55),
              inset 0 1px 0 rgba(120,180,255,.55) !important;
}

.table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td.spr-col-actions{
  box-shadow: none !important;
}

.table-signals tbody tr.signal-images-row.is-hovered td.signal-images-cell{
  box-shadow: inset 2px 0 0 rgba(120,180,255,.55),
              inset -2px 0 0 rgba(120,180,255,.55),
              inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

/* Compact view: attachments row hidden, so keep bottom line on main row */
.spr-compact .table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td,
.spr-compact .table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td,
.spr-compact .table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td{
  box-shadow: inset 0 1px 0 rgba(120,180,255,.55),
              inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

.spr-compact .table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td:first-child,
.spr-compact .table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td:first-child,
.spr-compact .table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td:first-child{
  box-shadow: inset 2px 0 0 rgba(120,180,255,.55),
              inset 0 1px 0 rgba(120,180,255,.55),
              inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

.spr-compact .table-signals tbody tr.signal-row:hover:has(+ tr.signal-images-row) td.spr-col-struktur,
.spr-compact .table-signals tbody tr.signal-row.is-hovered:has(+ tr.signal-images-row) td.spr-col-struktur,
.spr-compact .table-signals tbody tr.signal-row:has(+ tr.signal-images-row:hover) td.spr-col-struktur{
  box-shadow: inset -2px 0 0 rgba(120,180,255,.55),
              inset 0 1px 0 rgba(120,180,255,.55),
              inset 0 -1px 0 rgba(120,180,255,.55) !important;
}

/* Full table borders (consistent in full view) */
.table-signals tbody td{
  border-bottom: 1px solid rgba(255,255,255,.025) !important;
  border-right: 0 !important;
}

.table-signals tbody td:last-child{
  border-right: 0 !important;
}

.table-signals tbody tr.signal-images-row td{
  border-left: 0 !important;
  border-right: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.025) !important;
}

/* Attachments layout polish */
/* Hover style: left + right accent bar for attachments row (same Struktur edge) */
/* No left/right hover frames */

/* Audit table: slightly clearer horizontal separators */
.spr-audit-table tbody tr td{
  border-top: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.025) !important;
  border-left: 0 !important;
  border-right: 0 !important;
  box-shadow: none !important;
}

/* ==========================================================================
   Theme preview
   ========================================================================== */

.spr-theme-page{
  padding-bottom: 2rem;
}

.spr-theme-header{
  margin: .2rem 0 1rem;
}

.spr-theme-title{
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.spr-theme-subtitle{
  color: rgba(200,210,220,.6);
  font-size: .8rem;
  margin-top: .25rem;
}

.spr-theme-section{
  margin: 1rem 0 1.4rem;
}

.spr-theme-section-title{
  font-size: .7rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(200,210,220,.55);
  margin-bottom: .6rem;
}

.spr-theme-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: .8rem;
}

.spr-theme-grid--inputs{
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.spr-theme-card{
  border: 1px solid rgba(120,130,140,.18);
  background: linear-gradient(180deg, rgba(16,20,26,.7), rgba(12,14,18,.55));
  border-radius: 12px;
  padding: .8rem .9rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}

.spr-theme-card--raised{
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03), 0 10px 26px rgba(0,0,0,.35);
}

.spr-theme-row{
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
}

.spr-theme-swatch{
  height: 46px;
  border-radius: 10px;
  border: 1px solid rgba(120,130,140,.2);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.spr-theme-swatch--bg{
  background: #0f1115;
}

.spr-theme-swatch--surface{
  background: #151922;
}

.spr-theme-swatch--accent{
  background: rgba(120,180,255,.55);
}

.spr-theme-swatch--text{
  background: rgba(240,245,255,.85);
}

.spr-theme-label{
  margin-top: .45rem;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(200,210,220,.6);
}

.spr-theme-checkboxes{
  display: grid;
  gap: .35rem;
}

.spr-theme-text-row{
  display: grid;
  gap: .35rem;
}

.spr-theme-h1{
  font-size: 1rem;
  font-weight: 800;
}

.spr-theme-h2{
  font-size: .9rem;
  font-weight: 700;
  color: rgba(210,220,235,.8);
}

.spr-theme-body{
  font-size: .82rem;
  color: rgba(230,235,240,.86);
}

.spr-theme-muted{
  font-size: .76rem;
  color: rgba(200,210,220,.55);
}

.spr-theme-card-title{
  font-size: .9rem;
  font-weight: 700;
  margin-bottom: .25rem;
}

.spr-theme-card-body{
  font-size: .8rem;
  color: rgba(220,230,240,.8);
}

.spr-theme-card-actions{
  margin-top: .7rem;
}

.spr-theme-card--dataset{
  display: flex;
  flex-direction: column;
  gap: .45rem;
}

.spr-theme-dataset-row{
  display: flex;
  justify-content: space-between;
  gap: .6rem;
  font-size: .75rem;
}

.spr-theme-dataset-label{
  color: rgba(200,210,220,.6);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .62rem;
}

.spr-theme-dataset-value{
  color: rgba(230,235,240,.9);
}

.spr-theme-card--detail{
  display: grid;
  gap: .75rem;
}

.spr-theme-detail-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: .4rem;
  border-bottom: 1px solid rgba(120,130,140,.15);
}

.spr-theme-detail-title{
  font-size: 1rem;
  font-weight: 800;
}

.spr-theme-detail-subtitle{
  color: rgba(200,210,220,.65);
  font-size: .82rem;
  margin-top: .15rem;
}

.spr-theme-detail-actions{
  display: flex;
  gap: .5rem;
  align-items: center;
}

.spr-theme-detail-body{
  display: grid;
  gap: .6rem;
}

.spr-theme-detail-section{
  background: linear-gradient(180deg, rgba(18,22,28,.78), rgba(12,14,18,.7));
  border: 1px solid rgba(120,130,140,.18);
  border-radius: 12px;
  padding: .7rem .8rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.spr-theme-detail-label{
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(205,215,230,.6);
  font-weight: 800;
  margin-bottom: .35rem;
}

.spr-theme-detail-text{
  color: rgba(230,235,240,.9);
  font-size: .8rem;
  line-height: 1.7;
}

.spr-theme-detail-footer{
  display: flex;
  justify-content: flex-end;
  gap: .5rem;
}

.spr-theme-table-card .table{
  margin: 0;
}

.spr-theme-table-card thead th{
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(200,210,220,.6);
}

.spr-theme-file-row{
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}

.spr-theme-card .spr-nav-mode{
  justify-content: flex-start;
  gap: .5rem;
}

.spr-theme-card .spr-menu-tab{
  pointer-events: none;
}

.spr-audit-table thead th{
  border-bottom: 1px solid var(--spr-table-border) !important;
  border-left: 1px solid var(--spr-table-border) !important;
  border-right: 1px solid var(--spr-table-border) !important;
}

.spr-audit-table .spr-col-time{
  width: 100px;
  white-space: nowrap;
  text-align: center;
}

.spr-audit-table .spr-col-action{
  width: 120px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.7rem;
  text-align: center;
}

.spr-audit-table .spr-col-id{
  width: 90px;
  text-align: center;
}


.spr-audit-table tbody tr td:last-child,
.spr-audit-table thead th:last-child{
  border-right: 0 !important;
}

.table-signals tbody tr:hover td:last-child,
.table-signals tbody tr.signal-images-row:hover td:last-child,
.table-signals tbody tr.signal-row:hover + tr.signal-images-row td:last-child,
.spr-audit-table tbody tr:hover td:last-child{
  border-right: 0 !important;
}
.spr-audit-table tbody tr:last-child td{
  border-bottom: 1px solid var(--spr-table-border) !important;
}

/* ========================================================================
   Spectrum View
   ======================================================================== */

.spectrum-card{
  position: relative;
  overflow: hidden;
}

.spr-spectrum-layout{
  display: grid;
  grid-template-columns: 380px minmax(0, 1fr);
  gap: 1.3rem;
  align-items: start;
  max-width: 1600px;
  margin: 0 auto;
}

.spr-spectrum-rail{
  background: var(--spr-bg);
  border: 1px solid var(--spr-table-border);
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
  min-height: 680px;
  height: 680px;
  max-height: 680px;
  box-shadow: inset 0 0 0 1px rgba(23,26,33,.6);
  align-self: start;
}


.spr-spectrum-list-wrap{
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  min-height: 0;
}

.spr-spectrum-rail .spectrum-list-head{
  background: var(--spr-nav-input-bg);
  border: 1px solid var(--spr-table-border);
  border-radius: 8px;
  padding: .5rem .65rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .65rem;
  color: rgba(199,213,224,.85);
}

.spr-spectrum-rail .spectrum-list-head--table{
  background: rgba(10,12,16,.35);
  border: 1px solid var(--spr-table-border);
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: .03em;
  font-size: .66rem;
  font-weight: 600;
  color: rgba(248,249,250,.60);
  text-align: center;
}

.spr-spectrum-rail .spectrum-select-list{
  background: var(--spr-nav-input-bg);
  border: 1px solid var(--spr-table-border);
  border-radius: 10px;
  padding: .4rem .3rem;
  min-height: 520px;
  flex: 1 1 auto;
  max-height: 520px;
}

.spr-spectrum-actions{
  display: flex;
  align-items: center;
  gap: .5rem;
  border-top: 1px solid var(--spr-table-border);
  padding-top: .7rem;
}

.spr-spectrum-actions-right{
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.spectrum-rail-actions{
  display: flex !important;
  grid-template-columns: none !important;
  justify-content: space-between;
  align-items: center;
  gap: .6rem;
  margin-top: auto;
  padding-top: .6rem;
  flex-wrap: nowrap;
}

.spectrum-rail-actions .spr-nav-clear{
  margin-top: 0;
}

.spectrum-rail-actions .btn-reset--clear,
.spectrum-canvas-head .btn-reset--clear{
  height: var(--spr-btn-h);
}

.spectrum-canvas-head{
  width: 100%;
  justify-content: flex-end;
  align-items: center;
  display: flex;
  margin-bottom: 0;
}

.spectrum-canvas-head.spectrum-list-head--table{
  background: rgba(10,12,16,.35);
  border: 1px solid var(--spr-table-border);
  border-radius: 8px;
  padding: .5rem .65rem;
}

.spectrum-canvas-head--bottom{
  margin-top: auto;
  margin-bottom: 0;
}

.spr-spectrum-auto{
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .62rem;
  padding: 0 .55rem;
}

.btn-reset--clear.spr-spectrum-auto{
  height: var(--spr-btn-h);
  min-width: auto;
  line-height: 1;
}

.spr-reset-icon{
  width: 14px;
  height: 14px;
  margin-right: .35rem;
  vertical-align: -2px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.spr-spectrum-canvas{
  min-height: 680px;
  padding: 1.05rem 1.2rem;
  border-radius: 12px;
  background: var(--spr-bg);
  border: 1px solid var(--spr-table-border);
  box-shadow: none;

  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.spr-spectrum-canvas::before{
  content: "";
  position: absolute;
  inset: 0;
  background: url("../img/bg.webp") center center / cover no-repeat;
  opacity: 0.1;
  pointer-events: none;
}

.spr-spectrum-canvas > *{
  position: relative;
  z-index: 1;
}

@media (max-width: 1100px){
  .spr-spectrum-layout{
    grid-template-columns: 1fr;
  }
  .spr-spectrum-rail,
  .spr-spectrum-canvas{
    min-height: unset;
  }
}

/* Sticky header should block table scroll with body color (no dark band) */
.navbar-banner,
.navbar-banner-inner,
.navbar.navbar-dark.bg-secondary,
.spr-nav-search-inline,
.spr-header-row .navbar-search-row,
.navbar-search-row{
  background: var(--spr-bg) !important;
  background-color: var(--spr-bg) !important;
  background-image: none !important;
}

.navbar-banner-inner > .navbar-content,
.spr-nav-stack,
.spr-header-row{
  background: var(--spr-bg) !important;
  background-color: var(--spr-bg) !important;
  background-image: none !important;
}

/* Modulationsarten: Inhaltsverzeichnis */
.spr-mod-index{
  display: flex;
  flex-wrap: wrap;
  gap: 1.6rem;
  margin: 1.35rem 0 1.35rem;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(248,249,250,.6);
}

.spr-mod-index-wrap{
  display: block;
  padding-top: 1.1rem;
}

.spr-mod-index-col{
  flex: 1 1 16%;
  max-width: 16.66%;
  min-width: 150px;
  padding-top: .4rem;
  position: relative;
}

.spr-mod-index-col::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: rgba(248,249,250,.08);
}

.spr-mod-index-letter{
  display: block;
  margin-bottom: .35rem;
  color: rgba(248,249,250,.4);
  font-size: .62rem;
  letter-spacing: .2em;
}

.spr-mod-index a{
  display: block;
  margin-bottom: .4rem;
  color: rgba(248,249,250,.65);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: .08rem;
}

.spr-mod-index a:hover{
  color: rgba(88,166,255,.9);
  border-bottom-color: rgba(88,166,255,.45);
}

.spr-mod-index-sep{
  display: none;
}

.spectrum-chart{
  position: relative;
  min-height: 520px;
  border: 0;
  border-radius: 10px;
  background: transparent;
}

.spectrum-chart > *{
  position: relative;
  z-index: 1;
}

.spectrum-svg{ width: 100%; height: 100%; display: block; }

.spectrum-bar-name{
  pointer-events: none;
}

.spectrum-bar-name.is-clickable{
  pointer-events: auto;
  cursor: pointer;
  text-decoration: none;
  opacity: 0.9;
  transition: color 0.15s ease, opacity 0.15s ease;
}

.spectrum-bar-name.is-clickable:hover{
  color: rgba(88,166,255,0.95);
  opacity: 1;
}

.spectrum-tick{
  fill: var(--spr-text);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.55px;
  text-transform: uppercase;
  text-anchor: middle;
}

.spectrum-tooltip{
  position: absolute;
  pointer-events: none;
  padding: 3px 8px;
  color: var(--spr-text);
  font-size: 0.85rem;
  font-weight: 600;
  background: var(--spr-nav-input-bg);
  border: 1px solid var(--spr-table-border);
  border-radius: 6px;
  text-shadow: none;
  transform: translate(4px, -10px);
  max-width: 320px;
  white-space: nowrap;
}

.spectrum-empty,
.spectrum-error{
  margin-top: 10px;
}

.spectrum-counter{
  min-width: 180px;
  padding: .25rem .6rem;
  border-radius: 8px;
  background: rgba(23,26,33,.6);
  border: 1px solid rgba(199,213,224,.08);
}

.spectrum-scale{
  margin-top: 8px;
  padding: .25rem .6rem;
  border-radius: 8px;
  background: rgba(23,26,33,.6);
  border: 1px solid rgba(199,213,224,.08);
  text-align: right;
}

.spectrum-axis-label{
  fill: rgba(248,249,250,.45);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.55px;
  text-transform: uppercase;
  text-anchor: middle;
}

.spectrum-toggle .form-check-input{
  background-color: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.25);
}

.spectrum-toggle .form-check-input:checked{
  background-color: rgba(112,181,255,0.65);
  border-color: rgba(112,181,255,0.80);
}

.spectrum-card .text-muted{
  color: rgba(248,249,250,0.90) !important;
}

.spectrum-hint{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  color: rgba(248,249,250,0.96);
  text-transform: uppercase;
  letter-spacing: .55px;
  font-size: .70rem;
  font-weight: 600;
}

.spectrum-hint-block{
  display: block;
  margin-top: .4rem;
}

.spectrum-topmark{
  text-align: center;
  margin: 1.1rem 0 1.6rem;
}

.spectrum-select{
  min-width: 6.5rem;
  min-height: 150px;
  background: rgba(10,12,16,.65);
  border: 1px solid rgba(185,185,185,.18);
  color: rgba(248,249,250,0.92);
  border-radius: 0;
  cursor: pointer;
}

.spectrum-select:disabled{
  background: rgba(10,12,16,.35);
  border: 1px solid rgba(185,185,185,.10);
  color: rgba(248,249,250,0.35);
  opacity: 1;
}

.spectrum-select option{
  background: rgba(20,22,26,0.98);
  color: rgba(248,249,250,0.92);
}

.spectrum-select option:hover{
  background: rgba(58, 84, 120, 0.35);
  color: #f1f6ff;
}

.spectrum-select option:checked{
  background: rgba(64, 98, 150, 0.55);
  color: #ffffff;
}

.spectrum-list-head{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  padding: 0.4rem 0.65rem;
  background: rgba(10,12,16,.55);
  border: 1px solid rgba(185,185,185,.18);
  border-bottom: 0;
  color: rgba(248,249,250,0.65);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.spectrum-select-list{
  display: block;
  min-height: 150px;
  max-height: 210px;
  overflow-y: auto;
  background: rgba(10,12,16,.65);
  border: 1px solid rgba(185,185,185,.18);
  color: rgba(248,249,250,0.92);
}

.spectrum-select-list[data-disabled="true"]{
  opacity: 0.5;
  pointer-events: none;
}

.spectrum-list-row{
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  align-items: center;
  padding: 0.38rem 0.65rem;
  border-bottom: 1px solid rgba(185,185,185,.08);
  cursor: pointer;
}

.spectrum-list-row:last-child{
  border-bottom: 0;
}

.spectrum-list-row:hover{
  background: rgba(58, 84, 120, 0.28);
}

.spectrum-list-row.is-selected{
  background: rgba(64, 98, 150, 0.45);
}

.spectrum-col{
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.spectrum-freq-input{
  background: rgba(0,0,0,.55) !important;
  border: 1px solid rgba(185,185,185,.16) !important;
  color: rgba(248,249,250,.92) !important;
  min-width: 200px;
}

.spectrum-freq-input::placeholder{
  color: rgba(248,249,250,.12) !important;
}

.spectrum-freq-input:focus{
  outline: none;
  border-color: rgba(88,166,255,.55) !important;
  box-shadow:
    0 0 0 .22rem rgba(13,110,253,.22),
    inset 0 1px 0 rgba(255,255,255,.06);
}

.spectrum-tol-select{
  background: rgba(0,0,0,.55) !important;
  border: 1px solid rgba(185,185,185,.16) !important;
  color: rgba(248,249,250,.92) !important;
  width: fit-content;
  min-width: 5rem;
}

.spectrum-tol-select:focus{
  outline: none;
  border-color: rgba(88,166,255,.55) !important;
  box-shadow: 0 0 0 .22rem rgba(13,110,253,.22);
}



.spr-faq-list {
  margin: 0;
  padding-left: 1.1rem;
  font-size: .84rem;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: rgba(248,249,250,.62);
  opacity: .6;
}

.spr-faq-list li {
  margin: 0.15rem 0;
}

.spr-faq-accent{
  color: rgba(255,140,140,.82);
}

.spr-faq-page .form-label,
.spr-faq-page .field-help,
.spr-faq-page .spr-faq-list{
  font-size: .84rem;
}

.spr-faq-card{
  border: 1px solid rgba(120,130,140,.18);
  border-radius: 14px;
  padding: .6rem;
  background:
    linear-gradient(180deg, rgba(14,18,24,.85), rgba(10,12,16,.75)),
    url("../img/bg2.webp") center/cover no-repeat;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03), 0 12px 26px rgba(0,0,0,.35);
}

.spr-faq-card .spr-form-panel{
  background: rgba(10,12,16,.65);
  border: 1px solid rgba(120,130,140,.18);
  border-radius: 12px;
}
