:root {
  --sidebar-w: 260px;
  --sidebar-pad: 18px;
  --radius: 12px;
  --speed: .22s;
  --easing: cubic-bezier(.2,.8,.2,1);
  --bg:#0f172a;
  --card:#111827;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --accent:#22c55e;
  --btn:#2563eb;
  --panel:#0b1220;
  --danger:#ef4444;
  --border:#1f2937;
  --sidebar-bg: var(--panel);
  --sidebar-text: var(--text);
  --sidebar-nav-bg:#0f172a;
  --sidebar-border: var(--border);
  --msg-bg:#0b1220;
}
* { box-sizing: border-box; }
body { margin:0; font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif; color: var(--text); background: linear-gradient(180deg,#0b1220,#0f172a 60%); }
a { color: #93c5fd; text-decoration: none; }
.topbar {
  position: sticky;
  top: 0;
  z-index: 1000;
  width: 100%;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(6px);
}
.topbar__inner {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1.25rem;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}
.topbar__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  color: var(--text);
  font-size: 1.05rem;
}
.topbar__logo { font-size: 1.2rem; }
.topbar__toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 10px;
  padding: 0.5rem 0.65rem;
  cursor: pointer;
  transition: border-color var(--speed), background var(--speed), color var(--speed);
}
.topbar__toggle:hover,
.topbar__toggle:focus-visible {
  border-color: color-mix(in oklab, var(--accent) 55%, transparent);
  background: color-mix(in oklab, var(--accent) 18%, transparent);
  outline: none;
}
.topbar__menu {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-left: auto;
}
.topbar__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 0.9rem;
  border-radius: var(--radius);
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 65%, transparent);
  color: var(--text);
  font-weight: 500;
  box-shadow: none;
  transition: background var(--speed), border-color var(--speed), color var(--speed);
  white-space: nowrap;
}
.topbar__btn:hover,
.topbar__btn:focus-visible {
  background: color-mix(in oklab, var(--accent) 16%, var(--panel));
  border-color: color-mix(in oklab, var(--accent) 55%, transparent);
  outline: none;
}
.topbar__btn[aria-expanded="true"] {
  background: color-mix(in oklab, var(--accent) 22%, transparent);
  border-color: color-mix(in oklab, var(--accent) 60%, transparent);
}
.topbar-panels {
  position: relative;
  display: grid;
  gap: 0.75rem;
  padding: 0.75rem 1.25rem 0;
  isolation: isolate;
}
.topbar-panel[hidden] { display: none; }
.topbar-panel {
  position: relative;
  justify-self: end;
  inline-size: min(100%, clamp(420px, 70vw, 980px));
  padding: 12px 16px;
  background: #0f1115;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  display: block;
  box-sizing: border-box;
  z-index: 10;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.18s ease, transform 0.18s ease;
  pointer-events: none;
}
.topbar-panel:not([hidden]) {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.topbar-panel__nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 12px;
  width: 90%;
  max-inline-size: 90%;
}
.topbar-panel__nav a {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.65rem 0.95rem;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  transition: transform 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
  scroll-snap-align: start;
}
.topbar-panel__nav a:hover,
.topbar-panel__nav a:focus-visible {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.12);
  outline: none;
}
.topbar-meta {
  justify-self: stretch;
  width: min(100%, 1200px);
  margin: 0 auto;
  padding: 0.75rem 1.25rem;
  background: color-mix(in oklab, var(--panel) 96%, transparent);
  border: 1px solid var(--border);
  border-radius: 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.topbar-meta__info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: 0.9rem;
  color: var(--muted);
}
.topbar-meta__logout { color: var(--danger); }
.topbar-meta__mode { margin-left: auto; }
.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: var(--sidebar-w);
  background: var(--panel);
  color: var(--text);
  padding: var(--sidebar-pad);
  border-right: 1px solid var(--border);
  height: 100dvh;
  overflow: auto;
  transition: transform var(--speed) var(--easing), box-shadow var(--speed), width var(--speed);
  will-change: transform;
  z-index: 50;
  display: flex;
  flex-direction: column;
}
.sidebar__header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.sidebar__header h1{
  font-size: 20px;
  line-height: 1.1;
  margin: 0;
  color: var(--sidebar-text);
}
.sidebar__header + nav {
  margin-top: 12px;
}
.sidebar__toggle{
  font: inherit;
  color: var(--muted);
  background: transparent;
  border: 1px solid var(--border);
  padding: 6px 10px;
  border-radius: 999px;
  line-height: 1;
  cursor: pointer;
  transition: color var(--speed), border-color var(--speed), background var(--speed);
}
.sidebar__toggle:hover{
  color: var(--text);
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 12%, transparent);
}
.sidebar nav{
  display: grid;
  gap: 6px;
  margin-bottom: 8px;
}
.sidebar nav a{
  display: block;
  padding: 8px 10px;
  border-radius: 10px;
  color: var(--text);
  text-decoration: none;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid color-mix(in oklab, var(--border) 45%, transparent);
  background: color-mix(in oklab, var(--panel) 88%, rgba(255,255,255,0.05));
  transition: background var(--speed), border-color var(--speed), color var(--speed);
}
.sidebar nav a:hover{
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.45);
  background: color-mix(in oklab, var(--accent) 16%, var(--panel));
  border-color: color-mix(in oklab, var(--accent) 45%, transparent);
}
.sidebar .btn{
  width: 100%;
  text-align: left;
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: var(--radius);
  margin: 6px 0 8px;
  cursor: pointer;
  transition: border-color var(--speed), background var(--speed);
}
.sidebar .btn:hover{
  border-color: var(--accent);
  background: rgba(34, 197, 94, 0.1);
  background: color-mix(in oklab, var(--accent) 10%, transparent);
}
.content {
  margin: 0 auto;
  padding: 24px 24px 48px;
  max-width: 1200px;
  width: 100%;
  transition: padding var(--speed) var(--easing);
}
.sidebar{ scrollbar-gutter: stable; }
.sidebar::-webkit-scrollbar{ width: 10px; }
.sidebar::-webkit-scrollbar-thumb{
  background: color-mix(in oklab, var(--muted) 25%, transparent);
  border-radius: 8px;
}
.sidebar h1 { margin: 0; }

@media (min-width: 1025px) {
  .sidebar[data-state="closed"]{
    transform: translateX(calc(-1 * var(--sidebar-w) + 42px));
    box-shadow: none;
  }
  .sidebar[data-state="closed"] .sidebar__header{
    position: sticky;
    top: var(--sidebar-pad);
    z-index: 2;
  }
  .sidebar[data-state="closed"] .sidebar__toggle{
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    padding: 10px 6px;
    border-radius: 12px;
    background: var(--panel);
    border-color: var(--border);
    color: var(--muted);
  }
  .sidebar[data-state="closed"] ~ .content{
    margin-left: calc(42px + 20px);
  }
}
.card { background: var(--card); border:1px solid var(--sidebar-border); border-radius:14px; padding:14px; margin: 12px 0;}
.card.card--actions { display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.card.card--actions .btn { margin-right:0; }
.grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(320px,1fr)); gap: 12px; }
.btn { background: var(--btn); color: #fff; padding: 10px 14px; border:0; border-radius: 10px; cursor: pointer; margin-right: 8px;}
.btn[data-group] {
  background: color-mix(in oklab, var(--muted) 65%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
  box-shadow: 2px 2px 4px rgba(0,0,0,0.5);
}
.topbar__btn.btn[data-group] {
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 65%, transparent);
  box-shadow: none;
}
.topbar__btn.btn[data-group][aria-expanded="true"] {
  background: color-mix(in oklab, var(--accent) 22%, transparent);
  border-color: color-mix(in oklab, var(--accent) 60%, transparent);
}
.sidebar .btn[data-group] {
  display: block;
  width: 100%;
  margin-top: 12px;
  background: transparent;
  border: 1px solid var(--border);
  box-shadow: none;
  color: var(--text);
}
.sidebar .btn[data-group]:hover {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 10%, transparent);
}
.sidebar__header + .btn[data-group] { margin-top: 20px; }
.btn.mini { padding: 6px 10px; }
.topbar-meta__mode,
.topbar__btn,
.topbar-panel__nav a {
  cursor: pointer;
}

@media (max-width: 1024px){
  .topbar__inner {
    flex-wrap: wrap;
    align-items: center;
  }
  .topbar__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .topbar__menu {
    display: none;
    width: 100%;
    order: 3;
    flex-direction: column;
    align-items: stretch;
    margin-left: 0;
    padding-top: 0.5rem;
  }
  .topbar__menu.is-open {
    display: flex;
  }
  .topbar__btn {
    width: 100%;
    justify-content: flex-start;
  }
  .topbar-panels {
    padding: 0.5rem 1rem 0;
    justify-items: stretch;
  }
  .topbar-panel {
    inline-size: 100%;
    padding: 0.75rem 1rem;
  }
  .topbar-panel__nav {
    justify-content: center;
    align-items: stretch;
    flex-wrap: wrap;
    overflow: visible;
    padding-bottom: 0;
    gap: 10px;
  }
  .topbar-panel__nav a {
    flex: 1 1 min(240px, 48%);
    min-inline-size: 0;
    justify-content: center;
  }
  .topbar-meta {
    padding: 0.75rem 1rem;
  }
  .topbar-meta__mode {
    width: 100%;
    margin-left: 0;
  }
}

@media (max-width: 720px){
  .topbar-panel {
    padding: 0.6rem 0.8rem;
    border-radius: 10px;
  }
  .topbar-panel__nav {
    gap: 6px 10px;
  }
}

@media (max-width: 560px){
  .topbar-panel__nav {
    justify-content: center;
  }
  .topbar-panel__nav a {
    flex: 1 1 100%;
    font-size: 0.9rem;
    padding: 0.6rem 0.85rem;
  }
}
textarea.bb { width:100%; height:100px; margin-top:8px; }
.msgs { margin-bottom: 10px; }
.msg { background: var(--msg-bg); border-left:4px solid #22d3ee; padding:8px 12px; margin:4px 0; border-radius:8px; }
.msg.success { border-left-color:#22c55e;} .msg.error{border-left-color:#ef4444;} .msg.warning{border-left-color:#f59e0b;}
.tablewrap { overflow:auto; max-height: 400px; border:1px solid var(--sidebar-border); border-radius:10px;}
table { width:100%; border-collapse: collapse; }
th, td { padding:6px 8px; border-bottom:1px solid var(--sidebar-border); text-align:left; font-size: 14px;}

table[data-role="burzenie-table"][data-extra-visible="0"] th[data-extra-col="1"],
table[data-role="burzenie-table"][data-extra-visible="0"] td[data-extra-col="1"] {
  display: none;
}

table[data-role="burzenie-table"][data-extra-visible="1"] th[data-extra-col="1"],
table[data-role="burzenie-table"][data-extra-visible="1"] td[data-extra-col="1"] {
  display: table-cell;
}

/* Light Mode */
body.light-mode {
  --bg: #ffffff;
  --card: #ffffff;
  --text: #000000;
  --muted: #666666;
  --accent: #79aec8;
  --btn: #79aec8;
  --panel: #ffffff;
  --border: #e7eaf1;
  --danger: #dc2626;
  --sidebar-bg: #f8f8f8;
  --sidebar-text: #000000;
  --sidebar-nav-bg: #ffffff;
  --sidebar-border: #cccccc;
  --msg-bg: #f8f8f8;
  background: #ffffff;
}


/* Szczegoly pagination */
.szczegoly-section {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.szczegoly-controls,
.szczegoly-pagination,
.szczegoly-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.szczegoly-pagination .pager-buttons {
  display: flex;
  gap: 8px;
}

.szczegoly-section.is-loading .tablewrap {
  opacity: 0.55;
  pointer-events: none;
}

.szczegoly-section.is-loading::after {
  content: 'Ładowanie...';
  position: absolute;
  top: 12px;
  right: 16px;
  padding: 4px 10px;
  border-radius: 8px;
  background: rgba(15, 23, 42, 0.9);
  border: 1px solid var(--sidebar-border);
  font-size: 12px;
  color: var(--muted);
}


/* Registration page */
.register-hero {
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.35), rgba(59, 130, 246, 0.1));
  border: 1px solid rgba(37, 99, 235, 0.35);
  border-radius: 18px;
  padding: 28px;
  margin: 16px 0 24px;
  position: relative;
  overflow: hidden;
}
.register-hero::after {
  content: "";
  position: absolute;
  inset: -40% 40% auto -30%;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(59,130,246,0.25), transparent 60%);
  opacity: 0.8;
}
.register-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: rgba(34, 197, 94, 0.15);
  border: 1px solid rgba(34, 197, 94, 0.4);
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.register-hero h2 {
  margin: 12px 0 10px;
  font-size: 28px;
}
.register-hero p {
  margin: 0;
  max-width: 720px;
  color: var(--muted);
}

.register-card {
  background: rgba(17, 24, 39, 0.85);
  border: 1px solid rgba(37, 99, 235, 0.25);
  border-radius: 20px;
  padding: 28px;
  box-shadow: 0 25px 50px -12px rgba(37, 99, 235, 0.25);
}

.register-layout {
  display: grid;
  gap: 24px;
}

@media (min-width: 1024px) {
  .register-layout {
    grid-template-columns: minmax(0, 2.5fr) minmax(260px, 1fr);
    align-items: start;
  }
}

.register-main {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.register-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.register-step {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(15, 23, 42, 0.75);
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: inset 0 1px 0 rgba(148, 163, 184, 0.12);
}

.register-step h3 {
  margin: 0 0 6px;
  font-size: 18px;
}

.register-step p {
  margin: 0;
  font-size: 14px;
  color: var(--muted);
}

.register-step__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.35), rgba(59, 130, 246, 0.25));
  color: #bfdbfe;
  font-weight: 600;
  font-size: 16px;
  flex-shrink: 0;
  box-shadow: 0 8px 18px -10px rgba(37, 99, 235, 0.65);
}

.register-aside {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.register-info-card {
  background: rgba(15, 23, 42, 0.8);
  border: 1px solid rgba(148, 163, 184, 0.25);
  border-radius: 18px;
}

.register-info-card h3 {
  margin-top: 0;
  margin-bottom: 14px;
}

.register-feature-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.register-feature-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.register-feature__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(37, 99, 235, 0.18);
  box-shadow: 0 6px 18px -10px rgba(37, 99, 235, 0.65);
  font-size: 18px;
  flex-shrink: 0;
}

.register-feature-list p {
  margin: 4px 0 0;
  font-size: 13px;
  color: var(--muted);
}

.register-process-list {
  margin: 0 0 16px;
  padding-left: 20px;
  display: grid;
  gap: 6px;
  font-size: 14px;
}

.register-process-list strong {
  color: #bfdbfe;
}

body.light-mode .register-info-card {
  background: #ffffff;
  border-color: rgba(148, 163, 184, 0.35);
}

body.light-mode .register-process-list strong {
  color: #1d4ed8;
}

body.light-mode .register-step {
  background: #ffffff;
  border-color: rgba(148, 163, 184, 0.35);
  box-shadow: inset 0 1px 0 rgba(15, 23, 42, 0.05);
}

body.light-mode .register-step__icon {
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.25), rgba(96, 165, 250, 0.18));
  color: #1d4ed8;
}

body.light-mode .register-feature__icon {
  background: rgba(37, 99, 235, 0.12);
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-bottom: 28px;
}

.form-section:last-of-type {
  margin-bottom: 32px;
}

.form-section__header h3 {
  margin: 0 0 6px;
  font-size: 20px;
}

.form-section__header p {
  margin: 0;
  font-size: 14px;
  color: var(--muted);
}

.register-alert {
  border-radius: 14px;
  padding: 18px 20px;
  margin-bottom: 22px;
  background: rgba(34, 197, 94, 0.12);
  border: 1px solid rgba(34, 197, 94, 0.35);
  color: #bbf7d0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.register-alert__hint {
  font-size: 13px;
  color: rgba(226, 232, 240, 0.75);
}

.pending-wait-card {
  max-width: 520px;
  margin: 60px auto;
  background: rgba(17, 24, 39, 0.92);
  border: 1px solid rgba(59, 130, 246, 0.25);
  border-radius: 20px;
  padding: 26px 30px;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.pending-wait-card__meta {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
  font-size: 14px;
}

.pending-wait-card__hint {
  font-size: 13px;
  color: var(--muted);
}

.register-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px 20px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.form-field input,
.form-field textarea,
.form-field select {
  background: rgba(15, 23, 42, 0.95);
  border: 1px solid rgba(148, 163, 184, 0.25);
  border-radius: 12px;
  padding: 10px 12px;
  color: var(--text);
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
  outline: none;
  border-color: rgba(59, 130, 246, 0.6);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
}

.podglad-section-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.podglad-section-info {
  font-size: 14px;
  color: var(--muted, #94a3b8);
}

.targets-map-container {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 12px;
}

.targets-map-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.targets-map-wrapper {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 14px;
  border: 1px solid var(--sidebar-border, rgba(148, 163, 184, 0.4));
  border-radius: 14px;
  background: rgba(15, 23, 42, 0.55);
}

body.light-mode .targets-map-wrapper {
  background: rgba(255, 255, 255, 0.9);
}

.targets-map-body {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
}

.targets-map-viewport {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  gap: 6px;
}

.targets-map-viewport canvas {
  width: 320px;
  height: 320px;
  border: 1px solid var(--sidebar-border, rgba(148, 163, 184, 0.4));
  border-radius: 10px;
  image-rendering: pixelated;
  background-color: rgba(8, 13, 23, 0.85);
}

body.light-mode .targets-map-viewport canvas {
  background-color: rgba(226, 232, 240, 0.85);
}

.targets-map-sidebar {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 220px;
  max-width: 320px;
}

.targets-map-corners {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--muted, #94a3b8);
}

.targets-map-legend {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 14px;
}

.targets-map-legend div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.targets-map-legend hr {
  width: 100%;
  border: 0;
  border-top: 1px solid rgba(148, 163, 184, 0.35);
  margin: 6px 0;
}

body.light-mode .targets-map-legend hr {
  border-top-color: rgba(148, 163, 184, 0.5);
}

.targets-map-legend p {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--muted, #94a3b8);
  max-width: 220px;
}

.targets-map-meta {
  font-size: 12px;
  color: var(--muted, #94a3b8);
}

.targets-map-swatch {
  width: 16px;
  height: 16px;
  border-radius: 4px;
  box-shadow: 0 0 8px rgba(255, 255, 255, 0.15);
}

.targets-map-swatch--friendly {
  background: #3b82f6;
}

.targets-map-swatch--enemy {
  background: #ef4444;
}

.targets-map-swatch--neutral {
  background: #84cc16;
}

.targets-map-swatch--barbarian {
  background: #94a3b8;
}

.targets-map-swatch--off {
  background: #ef4444;
}

.targets-map-swatch--szlachcic {
  background: #facc15;
}

.targets-map-swatch--burzak {
  background: #3b82f6;
}

.targets-map-status {
  font-size: 13px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(59, 130, 246, 0.35);
  background: rgba(59, 130, 246, 0.12);
  color: #bfdbfe;
}

.targets-map-status[data-tone="success"] {
  border-color: rgba(34, 197, 94, 0.4);
  background: rgba(34, 197, 94, 0.12);
  color: #bbf7d0;
}

.targets-map-status[data-tone="warning"] {
  border-color: rgba(245, 158, 11, 0.45);
  background: rgba(245, 158, 11, 0.16);
  color: #fcd34d;
}

.targets-map-status[data-tone="error"] {
  border-color: rgba(248, 113, 113, 0.5);
  background: rgba(248, 113, 113, 0.18);
  color: #fecaca;
}

body.light-mode .targets-map-status {
  color: #1d4ed8;
  background: rgba(59, 130, 246, 0.12);
}

body.light-mode .targets-map-status[data-tone="success"] {
  color: #166534;
  background: rgba(34, 197, 94, 0.16);
}

body.light-mode .targets-map-status[data-tone="warning"] {
  color: #b45309;
  background: rgba(245, 158, 11, 0.18);
}

body.light-mode .targets-map-status[data-tone="error"] {
  color: #b91c1c;
  background: rgba(248, 113, 113, 0.2);
}

.targets-map-tribe-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 13px;
}

.targets-map-tribe-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.targets-map-tribe-form input {
  background: rgba(15, 23, 42, 0.85);
  border: 1px solid rgba(148, 163, 184, 0.35);
  border-radius: 8px;
  padding: 6px 10px;
  color: inherit;
}

body.light-mode .targets-map-tribe-form input {
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(148, 163, 184, 0.4);
}

.targets-map-feedback {
  font-size: 12px;
  padding: 6px 8px;
  border-radius: 8px;
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: rgba(15, 23, 42, 0.4);
  color: var(--muted, #94a3b8);
}

.targets-map-feedback--success {
  border-color: rgba(34, 197, 94, 0.45);
  background: rgba(34, 197, 94, 0.16);
  color: #bbf7d0;
}

.targets-map-feedback--error {
  border-color: rgba(248, 113, 113, 0.5);
  background: rgba(248, 113, 113, 0.16);
  color: #fecaca;
}

.targets-map-feedback--info {
  border-color: rgba(59, 130, 246, 0.45);
  background: rgba(59, 130, 246, 0.16);
  color: #bfdbfe;
}

.targets-map-feedback--muted {
  border-color: rgba(148, 163, 184, 0.35);
  background: rgba(148, 163, 184, 0.12);
}

body.light-mode .targets-map-feedback {
  background: rgba(248, 250, 252, 0.9);
  color: #334155;
}

.targets-map-ally-list {
  font-size: 12px;
  color: var(--muted, #94a3b8);
  margin: 0;
}

.vault-label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.45);
  font-size: 12px;
  background: rgba(15, 23, 42, 0.45);
  color: rgba(226, 232, 240, 0.9);
  margin: 2px 4px 2px 0;
}

.vault-label--off {
  border-color: rgba(239, 68, 68, 0.6);
  color: #fecaca;
}

.vault-label--deff {
  border-color: rgba(34, 197, 94, 0.6);
  color: #bbf7d0;
}

.vault-label--noble {
  border-color: rgba(59, 130, 246, 0.65);
  color: #bfdbfe;
}

.vault-label--catapult {
  border-color: rgba(245, 158, 11, 0.65);
  color: #fcd34d;
}

.vault-label--ram {
  border-color: rgba(139, 92, 246, 0.65);
  color: #ddd6fe;
}

body.light-mode .vault-label {
  background: rgba(226, 232, 240, 0.85);
  color: #1f2937;
}

body.light-mode .vault-label--off {
  color: #b91c1c;
  background: rgba(239, 68, 68, 0.12);
}

body.light-mode .vault-label--deff {
  color: #166534;
  background: rgba(34, 197, 94, 0.12);
}

body.light-mode .vault-label--noble {
  color: #1d4ed8;
  background: rgba(59, 130, 246, 0.12);
}

body.light-mode .vault-label--catapult {
  color: #b45309;
  background: rgba(245, 158, 11, 0.15);
}

body.light-mode .vault-label--ram {
  color: #6d28d9;
  background: rgba(139, 92, 246, 0.15);
}
.form-field small {
  color: var(--muted);
}
.form-field.full-width {
  grid-column: 1 / -1;
}

.required-indicator {
  color: var(--danger);
  margin-left: 4px;
  font-weight: 600;
}

.required-note {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 16px;
}

.form-error-list {
  margin-bottom: 12px;
}
.form-error {
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.4);
  border-radius: 12px;
  padding: 8px 12px;
  font-size: 13px;
  margin-top: 4px;
}

.recaptcha-wrap {
  margin: 20px 0;
  display: flex;
  justify-content: flex-start;
}

.btn-primary {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  border: none;
  padding: 12px 20px;
  border-radius: 12px;
  font-size: 16px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 20px -10px rgba(37, 99, 235, 0.5);
}

.btn-secondary {
  background: linear-gradient(135deg, #10b981, #059669);
  border: none;
}

.btn-approve {
  background: linear-gradient(135deg, #a855f7, #7c3aed);
  border: none;
}

.btn-danger,
.btn.danger {
  background: linear-gradient(135deg, #ef4444, #b91c1c);
  border: none;
}

.login-meta {
  margin-top: 16px;
  font-size: 13px;
  color: var(--muted);
}

.register-meta {
  margin-top: 18px;
  padding-top: 12px;
  border-top: 1px solid rgba(148, 163, 184, 0.2);
}
.register-meta .muted {
  color: var(--muted);
  font-size: 13px;
}

/* Admin registration dashboard */
.registration-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  margin: 24px 0;
}
.stat-card {
  position: relative;
  padding: 20px;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: rgba(15, 23, 42, 0.85);
  overflow: hidden;
}
.stat-card::after {
  content: "";
  position: absolute;
  inset: auto -30% -40% auto;
  width: 160px;
  height: 160px;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.15), transparent 60%);
}
.stat-card__label {
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}
.stat-card__value {
  font-size: 34px;
  font-weight: 700;
  display: block;
  margin: 6px 0;
}
.stat-card__hint {
  font-size: 13px;
  color: var(--muted);
}
.stat-card--pending { border-color: rgba(59, 130, 246, 0.35); }
.stat-card--admin { border-color: rgba(168, 85, 247, 0.35); }
.stat-card--member { border-color: rgba(16, 185, 129, 0.35); }
.stat-card--rejected { border-color: rgba(239, 68, 68, 0.35); }

.pending-section {
  margin: 36px 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.pending-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 18px;
}
.pending-card {
  background: rgba(17, 24, 39, 0.9);
  border: 1px solid rgba(148, 163, 184, 0.25);
  border-radius: 18px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
}
.pending-card__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}
.pending-card__time {
  font-size: 12px;
  color: var(--muted);
}
.pending-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(59, 130, 246, 0.35);
  font-size: 12px;
}
.badge--neutral { background: rgba(148, 163, 184, 0.15); border-color: rgba(148, 163, 184, 0.3); }
.badge--accent { background: rgba(34, 197, 94, 0.15); border-color: rgba(34, 197, 94, 0.3); }

.pending-note {
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-radius: 12px;
  padding: 12px;
  font-size: 14px;
}

.decision-panel {
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid rgba(37, 99, 235, 0.2);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.decision-panel + .decision-panel {
  margin-top: 12px;
}
.decision-panel[open] {
  border-color: rgba(59, 130, 246, 0.45);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.55);
}
.decision-panel__summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  padding: 16px 18px;
}
.decision-panel__summary::-webkit-details-marker {
  display: none;
}
.decision-panel__summary h5 {
  margin: 0 0 6px;
}
.decision-panel__summary p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.decision-panel__icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(59, 130, 246, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-top: 4px;
}
.decision-panel__icon::before,
.decision-panel__icon::after {
  content: "";
  position: absolute;
  background: rgba(191, 219, 254, 0.9);
  transition: transform 0.2s ease;
}
.decision-panel__icon::before {
  width: 10px;
  height: 2px;
}
.decision-panel__icon::after {
  width: 2px;
  height: 10px;
}
.decision-panel[open] .decision-panel__icon::after {
  transform: scaleY(0);
}
.decision-panel[open] .decision-panel__summary {
  border-bottom: 1px solid rgba(37, 99, 235, 0.2);
}
.decision-panel--reject {
  border-color: rgba(239, 68, 68, 0.35);
}
.decision-panel--reject .decision-panel__summary {
  color: var(--danger);
}
.decision-form {
  padding: 16px 18px 20px;
  display: block;
}
.decision-form__controls {
  display: grid;
  gap: 10px;
}
.decision-form__controls select,
.decision-form__controls textarea {
  width: 100%;
  background: rgba(15, 23, 42, 0.95);
  border: 1px solid rgba(148, 163, 184, 0.25);
  border-radius: 12px;
  padding: 10px 12px;
  color: var(--text);
}
.decision-form__controls button {
  justify-self: start;
}

.history-section {
  margin: 40px 0 60px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.history-timeline {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.history-item {
  display: flex;
  gap: 16px;
  position: relative;
  padding-left: 12px;
}
.history-item::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 0;
  bottom: -16px;
  width: 2px;
  background: linear-gradient(180deg, rgba(148, 163, 184, 0.25), transparent);
}
.history-item:last-child::before {
  bottom: 12px;
}
.history-item__icon {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(59, 130, 246, 0.8);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2);
  margin-top: 6px;
}
.history-item--team_admin .history-item__icon { background: rgba(168, 85, 247, 0.9); box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.25); }
.history-item--team_member .history-item__icon { background: rgba(16, 185, 129, 0.9); box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.25); }
.history-item--rejected .history-item__icon { background: rgba(239, 68, 68, 0.9); box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.25); }

.history-item__content {
  background: rgba(15, 23, 42, 0.8);
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: 14px;
  padding: 14px 18px;
  flex: 1;
}
.history-item__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.history-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 8px 0;
  font-size: 12px;
  color: var(--muted);
}
.history-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

/* === Klinowanie (theme aware) === */
#klinowanieRoot {
  --sb-gap: 16px;
  --sb-gap-lg: 22px;
  --sb-radius: 14px;
  --sb-radius-lg: 18px;
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: var(--sb-gap-lg);
  background: linear-gradient(180deg, var(--sb-card, #14192b) 0%, var(--sb-card-soft, #101528) 100%);
  border: 1px solid var(--sb-border, #222a44);
  border-radius: var(--sb-radius-lg);
  box-shadow: var(--sb-shadow, 0 8px 22px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.02));
  padding: clamp(16px, 2.2vw, 28px);
  color: var(--sb-txt, #e7ecff);
}

#klinowanieRoot .klinowanie-form {
  display: block;
}

#klinowanieRoot .klinowanie-fieldset {
  border: 0;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--sb-gap-lg);
}

#klinowanieRoot .klinowanie-form-section {
  background: linear-gradient(180deg, color-mix(in oklab, var(--sb-accent, #7eef50) 8%, transparent) 0%, color-mix(in oklab, var(--sb-accent-2, #5ac8fa) 8%, transparent) 100%);
  border: 1px solid var(--sb-border-soft, #1a2140);
  border-radius: var(--sb-radius);
  padding: clamp(12px, 1.6vw, 18px);
  display: flex;
  flex-direction: column;
  gap: var(--sb-gap);
}

#klinowanieRoot .klinowanie-form-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 12px;
  font-weight: 700;
  letter-spacing: .2px;
  color: var(--sb-txt, #e7ecff);
  font-size: clamp(15px, 1.2rem, 18px);
  position: relative;
}

#klinowanieRoot .klinowanie-form-section-title::after {
  content: "";
  flex: 1 1 auto;
  height: 2px;
  background: linear-gradient(90deg, var(--sb-accent, #7eef50) 0%, rgba(126, 239, 80, 0) 70%);
  border-radius: 2px;
}

#klinowanieRoot .klinowanie-form-section-title::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(126, 239, 80, .15);
  background: var(--sb-accent, #7eef50);
}

#klinowanieRoot .klinowanie-form-section:has(#klinowanieMaxTopor) .klinowanie-form-section-title::before,
#klinowanieRoot .klinowanie-form-section:has(#klinowanieMaxTaran) .klinowanie-form-section-title::before {
  background: var(--sb-warning, #ffb020);
  box-shadow: 0 0 0 4px rgba(255, 176, 32, .18);
}

#klinowanieRoot .klinowanie-form-section:has(#klinowanieMinPik) .klinowanie-form-section-title::before,
#klinowanieRoot .klinowanie-form-section:has(#klinowanieMinCiezka) .klinowanie-form-section-title::before {
  background: var(--sb-accent-2, #5ac8fa);
  box-shadow: 0 0 0 4px rgba(90, 200, 250, .18);
}

#klinowanieRoot .klinowanie-form-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sb-gap);
}

@media (max-width: 980px) {
  #klinowanieRoot .klinowanie-form-grid { grid-template-columns: repeat(6, 1fr); }
}

@media (max-width: 640px) {
  #klinowanieRoot .klinowanie-form-grid { grid-template-columns: repeat(2, 1fr); }
}

#klinowanieRoot .klinowanie-form-grid > label {
  grid-column: span 4;
  display: grid;
  gap: 6px;
  color: var(--sb-txt-dim, #aab3d9);
  font-size: 13px;
}

@media (max-width: 980px) {
  #klinowanieRoot .klinowanie-form-grid > label { grid-column: span 6; }
}

@media (max-width: 640px) {
  #klinowanieRoot .klinowanie-form-grid > label { grid-column: span 2; }
}

#klinowanieRoot .klinowanie-form-grid > label > select,
#klinowanieRoot .klinowanie-form-grid > label > input[type="number"],
#klinowanieRoot .klinowanie-form-grid > label > input[type="text"] {
  width: 100%;
  appearance: none;
  border: 1px solid var(--sb-input-border, #2a3356);
  background: var(--sb-input-bg, #0e1426);
  color: var(--sb-txt, #e7ecff);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 14px;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

#klinowanieRoot .klinowanie-form-grid select:focus,
#klinowanieRoot .klinowanie-form-grid input:focus {
  outline: none;
  border-color: var(--sb-input-focus, #36407a);
  box-shadow: var(--sb-focus-ring, 0 0 0 3px rgba(126, 239, 80, .2));
}

#klinowanieRoot .klinowanie-form-grid select:disabled,
#klinowanieRoot .klinowanie-form-grid input:disabled {
  opacity: .6;
  cursor: not-allowed;
}

#klinowanieRoot .klinowanie-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  padding-top: 6px;
  border-top: 1px dashed var(--sb-border, #222a44);
  margin-top: -4px;
}

#klinowanieRoot .klinowanie-actions .btn {
  border-radius: 12px;
  border: 1px solid var(--sb-accent, #7eef50);
  background: linear-gradient(180deg, color-mix(in oklab, var(--sb-accent, #7eef50) 15%, transparent) 0%, color-mix(in oklab, var(--sb-accent, #7eef50) 6%, transparent) 100%);
  color: var(--sb-txt, #e7ecff);
  font-weight: 700;
  padding: 10px 14px;
  transition: transform .06s ease, box-shadow .2s ease, background .2s ease;
}

#klinowanieRoot .klinowanie-actions .btn:hover {
  box-shadow: 0 6px 16px rgba(126, 239, 80, .18);
  transform: translateY(-1px);
}

#klinowanieRoot .klinowanie-actions .btn:active {
  transform: translateY(0);
}

#klinowanieRoot .klinowanie-actions .btn.secondary {
  border-color: var(--sb-input-border, #2a3356);
  background: linear-gradient(180deg, rgba(255, 255, 255, .06) 0%, rgba(255, 255, 255, .02) 100%);
}

#klinowanieRoot .klinowanie-status {
  margin-top: var(--sb-gap);
  padding: 10px 12px;
  border: 1px solid var(--sb-border, #222a44);
  border-radius: 10px;
  background: rgba(255, 255, 255, .02);
  color: var(--sb-txt-dim, #aab3d9);
  min-height: 38px;
}

#klinowanieRoot .klinowanie-status.is-loading {
  border-color: var(--sb-input-focus, #36407a);
  box-shadow: 0 0 0 3px rgba(90, 200, 250, .12) inset;
}

#klinowanieRoot .klinowanie-status.is-success {
  border-color: var(--sb-accent, #7eef50);
  color: var(--sb-txt, #e7ecff);
  box-shadow: 0 0 0 3px rgba(126, 239, 80, .12) inset;
}

#klinowanieRoot .klinowanie-status.is-error {
  border-color: var(--sb-danger, #ff5b5b);
  box-shadow: 0 0 0 3px rgba(255, 91, 91, .12) inset;
}

#klinowanieRoot .klinowanie-bbcode {
  margin-top: var(--sb-gap-lg);
  border: 1px dashed var(--sb-border, #222a44);
  border-radius: var(--sb-radius);
  padding: 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .03) 0%, rgba(255, 255, 255, .015) 100%);
}

#klinowanieRoot .klinowanie-bbcode-title {
  margin: 0 0 8px;
  font-weight: 700;
  color: var(--sb-txt, #e7ecff);
}

#klinowanieRoot .klinowanie-bbcode-list {
  display: grid;
  gap: 8px;
}

#klinowanieRoot .klinowanie-bbcode [data-role="bbcode-item"] {
  background: var(--sb-code-bg, #0b1020);
  border: 1px solid var(--sb-code-border, var(--sb-border, #222a44));
  border-radius: 10px;
  padding: 8px 10px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 12.5px;
  color: var(--sb-code-color, var(--sb-txt, #e7ecff));
}

#klinowanieNotes,
#klinowanieTargetGroups,
#klinowanieResults {
  margin-top: var(--sb-gap-lg);
}

#klinowanieResults .result-card {
  background: var(--sb-card, #14192b);
  border: 1px solid var(--sb-border, #222a44);
  border-radius: 12px;
  padding: 12px;
}

#klinowanieResults .result-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--sb-gap);
}

@media (max-width: 980px) {
  #klinowanieResults .result-grid { grid-template-columns: repeat(6, 1fr); }
}

@media (max-width: 640px) {
  #klinowanieResults .result-grid { grid-template-columns: repeat(2, 1fr); }
}

#klinowanieRoot .klinowanie-form-grid input[type="number"]::-webkit-outer-spin-button,
#klinowanieRoot .klinowanie-form-grid input[type="number"]::-webkit-inner-spin-button {
  opacity: .5;
}

#klinowanieRoot .klinowanie-form-grid input[type="number"]::placeholder {
  color: var(--sb-input-placeholder, #7e88b3);
}

#klinowanieRoot .btn {
  line-height: 1.1;
}

.theme-dark #klinowanieRoot {
  --sb-card: color-mix(in oklab, var(--card, #111827) 86%, #14192b);
  --sb-card-soft: color-mix(in oklab, var(--panel, #0b1220) 80%, #101528);
  --sb-border: color-mix(in oklab, var(--border, #1f2937) 92%, #222a44);
  --sb-border-soft: color-mix(in oklab, var(--border, #1f2937) 68%, #1a2140);
  --sb-txt: var(--text, #e5e7eb);
  --sb-txt-dim: var(--muted, #aab3d9);
  --sb-accent: #7eef50;
  --sb-accent-2: #5ac8fa;
  --sb-danger: var(--danger, #ef4444);
  --sb-warning: #ffb020;
  --sb-shadow: 0 8px 22px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .02);
  --sb-input-bg: #0e1426;
  --sb-input-border: #2a3356;
  --sb-input-focus: #36407a;
  --sb-focus-ring: 0 0 0 3px rgba(126, 239, 80, .2);
  --sb-code-bg: #0b1020;
  --sb-code-border: color-mix(in oklab, var(--border, #1f2937) 75%, #222a44);
  --sb-code-color: var(--text, #e5e7eb);
  --sb-input-placeholder: #7e88b3;
}

.theme-light #klinowanieRoot,
body.light-mode #klinowanieRoot {
  --sb-card: var(--card, #ffffff);
  --sb-card-soft: color-mix(in oklab, var(--card, #ffffff) 70%, #f8fafc);
  --sb-border: var(--border, rgba(148, 163, 184, .45));
  --sb-border-soft: color-mix(in oklab, var(--border, rgba(148, 163, 184, .45)) 65%, #ffffff);
  --sb-txt: var(--text, #0f172a);
  --sb-txt-dim: var(--muted, #475569);
  --sb-accent: var(--accent, #79aec8);
  --sb-accent-2: color-mix(in oklab, var(--accent, #79aec8) 45%, #38bdf8);
  --sb-danger: var(--danger, #dc2626);
  --sb-warning: #f59e0b;
  --sb-shadow: 0 12px 28px rgba(15, 23, 42, .12), inset 0 1px 0 rgba(255, 255, 255, .4);
  --sb-input-bg: #ffffff;
  --sb-input-border: color-mix(in oklab, var(--border, rgba(148, 163, 184, .45)) 80%, #ffffff);
  --sb-input-focus: rgba(37, 99, 235, .45);
  --sb-focus-ring: 0 0 0 3px rgba(37, 99, 235, .18);
  --sb-code-bg: rgba(15, 23, 42, 0.05);
  --sb-code-border: color-mix(in oklab, var(--border, rgba(148, 163, 184, .45)) 75%, #ffffff);
  --sb-code-color: var(--text, #0f172a);
  --sb-input-placeholder: color-mix(in oklab, var(--muted, #475569) 85%, #94a3b8);
}

.klinowanie-target-groups {
  display: grid;
  gap: 1rem;
  margin: 1rem 0;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.klinowanie-target-group {
  border: 1px solid var(--border, rgba(148, 163, 184, 0.35));
  border-radius: 10px;
  background: rgba(37, 99, 235, 0.04);
  padding: 0.85rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  box-shadow: 0 10px 24px -18px rgba(15, 23, 42, 0.4);
}

.klinowanie-target-group-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--primary, #2563eb);
}

.klinowanie-target-group-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.klinowanie-target-group-empty {
  margin: 0;
  font-size: 0.9rem;
  color: var(--muted, #64748b);
}

.klinowanie-target-entry {
  display: flex;
  gap: 0.75rem;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  border: 1px solid var(--border, rgba(148, 163, 184, 0.35));
  border-radius: 8px;
  background: var(--surface, rgba(15, 23, 42, 0.05));
  padding: 0.75rem 0.9rem;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
  text-align: left;
}

.klinowanie-target-entry:hover {
  background: rgba(37, 99, 235, 0.12);
  transform: translateY(-1px);
}

.klinowanie-target-entry:focus-visible {
  outline: 2px solid var(--primary, #2563eb);
  outline-offset: 2px;
}

.klinowanie-target-entry-col {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.klinowanie-target-entry-col--times {
  align-items: flex-start;
}

.klinowanie-target-entry-coord {
  font-weight: 600;
  font-size: 0.95rem;
}

.klinowanie-target-entry-player {
  font-size: 0.9rem;
  color: var(--muted, #64748b);
}

.klinowanie-target-entry-arrival {
  font-size: 0.9rem;
  color: var(--primary, #2563eb);
}

.klinowanie-target-entry-series {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.klinowanie-target-entry-series-label {
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--muted, #64748b);
}

.klinowanie-target-entry-times {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-variant-numeric: tabular-nums;
}

.klinowanie-target-entry-empty {
  font-size: 0.85rem;
  color: var(--muted, #64748b);
}

@media (max-width: 640px) {
  .klinowanie-target-entry {
    flex-direction: column;
    gap: 0.5rem;
  }
}

.klinowanie-results {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.klinowanie-player {
  border: 1px solid var(--border, rgba(148, 163, 184, 0.4));
  border-radius: 10px;
  padding: 0.75rem 1rem;
  background: rgba(37, 99, 235, 0.05);
}

.klinowanie-player summary {
  font-weight: 600;
  cursor: pointer;
}

.klinowanie-player summary::marker {
  color: var(--primary, #2563eb);
}

.klinowanie-player-body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 0.75rem;
}

.klinowanie-entry {
  border: 1px solid var(--border, rgba(148, 163, 184, 0.35));
  border-radius: 8px;
  padding: 0.85rem 1rem;
  background: var(--surface, rgba(15, 23, 42, 0.05));
  box-shadow: 0 8px 18px -12px rgba(15, 23, 42, 0.35);
}

.klinowanie-entry h3 {
  margin-bottom: 0.5rem;
  font-size: 1.05rem;
}

.klinowanie-entry-deadline {
  margin: 0 0 0.5rem;
  font-weight: 600;
  color: var(--primary, #2563eb);
}

.klinowanie-route,
.klinowanie-recommended,
.klinowanie-distance {
  margin: 0.35rem 0;
}

.klinowanie-nobles ul,
.klinowanie-note-list {
  margin: 0.35rem 0 0 1.2rem;
  padding: 0;
  list-style: disc;
}

.klinowanie-support-link {
  display: inline-block;
  margin: 0.35rem 0;
  font-weight: 600;
  color: var(--primary, #2563eb);
}

.klinowanie-unit-options {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.klinowanie-unit-option summary {
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.klinowanie-unit-option summary::marker {
  color: var(--primary, #2563eb);
}

.klinowanie-unit-summary-tail {
  font-weight: 400;
  color: var(--muted, #64748b);
}

.klinowanie-unit-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  font-size: 1.1rem;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.12);
}

.klinowanie-unit-label {
  font-weight: 600;
}

.klinowanie-unit-speed {
  font-size: 0.85rem;
  color: var(--muted, #64748b);
  margin-left: 0.15rem;
}

.klinowanie-unit-body {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
}

.klinowanie-unit-meta {
  list-style: disc;
  margin: 0 0 0 1.2rem;
  padding: 0;
}

.klinowanie-unit-meta li {
  margin: 0.15rem 0;
}

.klinowanie-time-ms {
  font-weight: 700;
}

.klinowanie-noble-series {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.klinowanie-noble-series-block strong {
  display: block;
  margin-bottom: 0.25rem;
}

.klinowanie-noble-series-block ul {
  list-style: disc;
  margin: 0.25rem 0 0 1.2rem;
  padding: 0;
}

.klinowanie-summary {
  margin-bottom: 0.5rem;
}

@media (max-width: 1024px) {
  .sidebar__toggle { display: none; }
  .content { margin-left: 0; padding: 18px; }
  .register-card { padding: 22px; }
  .decision-form__content { flex-direction: column; }
  .decision-form__controls { width: 100%; }
  .history-item::before { left: 8px; }
}
