/* =========================
   GŁÓWNE STYLE APLIKACJI
   Aplikacja działa wyłącznie w ciemnym motywie.
   ========================= */

:root {
  --bg: #f5f7fb;
  --bg-accent: radial-gradient(circle at top left, #dbeafe 0, rgba(219,234,254,0) 38%), radial-gradient(circle at bottom right, #ede9fe 0, rgba(237,233,254,0) 32%), #f5f7fb;
  --panel: rgba(255,255,255,0.9);
  --panel-strong: #ffffff;
  --panel-soft: #f8fafc;
  --text: #111827;
  --text-soft: #64748b;
  --line: #e2e8f0;
  --primary: #2563eb;
  --primary-soft: #dbeafe;
  --success: #16a34a;
  --success-soft: #dcfce7;
  --danger: #dc2626;
  --danger-soft: #fee2e2;
  --warning: #d97706;
  --warning-soft: #ffedd5;
  --shadow: 0 18px 48px rgba(15, 23, 42, 0.12);
  --radius-xl: 28px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --radius-sm: 12px;
}

body.dark {
  --bg: #0b1120;
  --bg-accent: radial-gradient(circle at top left, rgba(37,99,235,0.16) 0, rgba(37,99,235,0) 38%), radial-gradient(circle at bottom right, rgba(168,85,247,0.18) 0, rgba(168,85,247,0) 30%), #0b1120;
  --panel: rgba(15,23,42,0.88);
  --panel-strong: #111827;
  --panel-soft: #172033;
  --text: #f8fafc;
  --text-soft: #94a3b8;
  --line: #243246;
  --primary: #60a5fa;
  --primary-soft: rgba(96,165,250,0.16);
  --success: #4ade80;
  --success-soft: rgba(34,197,94,0.16);
  --danger: #f87171;
  --danger-soft: rgba(239,68,68,0.16);
  --warning: #fb923c;
  --warning-soft: rgba(249,115,22,0.18);
  --shadow: 0 20px 50px rgba(2, 6, 23, 0.45);
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; }
body {
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg-accent);
  color: var(--text);
  transition: background .25s ease, color .25s ease;
}
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
input, select, textarea {
  width: 100%;
  border: 1px solid var(--line);
  background: var(--panel-strong);
  color: var(--text);
  border-radius: var(--radius-sm);
  padding: 0.9rem 1rem;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.14);
}
textarea { resize: vertical; min-height: 110px; }
.hidden { display: none !important; }
.muted { color: var(--text-soft); }
.small { font-size: .88rem; }
.small, .small-label { font-size: .85rem; }
.compact-text { margin: .4rem 0 0; }
.badge, .eyebrow {
  display: inline-flex;
  align-items: center;
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--primary);
}
.badge {
  padding: .35rem .7rem;
  border-radius: 999px;
  background: var(--primary-soft);
  font-weight: 700;
}
.badge.subtle { background: transparent; padding-left: 0; }
.eyebrow { font-weight: 700; }

.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 2rem;
}
.auth-card {
  width: min(980px, 100%);
  background: var(--panel);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: var(--shadow);
  border-radius: var(--radius-xl);
  padding: clamp(1.3rem, 3vw, 2.2rem);
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 1.5rem;
}
.auth-brand {
  padding: clamp(1rem, 3vw, 2rem);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, rgba(11,17,32,.84), rgba(37,99,235,.28));
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #eef4ff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.auth-brand h1 { margin: .85rem 0 .75rem; font-size: clamp(2rem, 4vw, 3.1rem); line-height: 1.05; color: #f8fbff; text-wrap: balance; }
.auth-brand p { margin: 0; max-width: 34rem; color: rgba(226,232,240,.9); }

.auth-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.auth-toolbar-label {
  font-size: .88rem;
  color: var(--text-soft);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.auth-switch {
  display: inline-grid;
  grid-template-columns: 1fr 1fr;
  gap: .5rem;
  background: var(--panel-soft);
  padding: .4rem;
  border-radius: 999px;
  margin-bottom: 1rem;
}
.tab-btn {
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--text-soft);
  font-weight: 700;
  padding: .8rem 1rem;
}
.tab-btn.active {
  background: var(--panel-strong);
  color: var(--text);
  box-shadow: 0 6px 18px rgba(15,23,42,.08);
}
.auth-form { display: none; align-content: start; gap: 1rem; }
.auth-form.active { display: grid; }

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
}
.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 1.2rem;
  border-right: 1px solid var(--line);
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(14px);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
body.dark .sidebar { background: rgba(11,17,32,.82); }
.sidebar-head, .topbar, .section-head, .inline-end, .topbar-left, .topbar-actions, .button-row, .filters-row, .checkbox-row, .goal-head, .goal-bottom, .goal-overview, .legend-row {
  display: flex;
  align-items: center;
}
.sidebar-head, .inline-end, .topbar, .section-head, .goal-head, .goal-bottom { justify-content: space-between; }
.user-card, .card-soft {
  background: var(--panel-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 1rem;
}
.sidebar-nav { display: grid; gap: .42rem; }
.nav-link {
  border: 0;
  background: transparent;
  color: var(--text-soft);
  border-radius: var(--radius-sm);
  padding: .95rem 1rem;
  text-align: left;
  font-weight: 700;
}
.nav-link:hover, .nav-link.active {
  background: var(--panel-soft);
  color: var(--text);
  transform: translateX(2px);
}
.sidebar-bottom { margin-top: auto; display: grid; gap: .8rem; }
.main-shell { min-width: 0; display: flex; flex-direction: column; }
.topbar {
  padding: 1.2rem 1.5rem 0;
  gap: 1rem;
}
.topbar-actions { gap: .7rem; }
.content {
  padding: 1.5rem;
  display: grid;
}
.view { display: none; gap: 1.25rem; }
.view.active { display: grid; }
.card {
  background: var(--panel);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: var(--shadow);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  backdrop-filter: blur(10px);
}
.reveal {
  animation: fadeUp .38s ease both;
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.primary-btn, .secondary-btn, .ghost-btn, .icon-btn {
  border: 0;
  border-radius: 999px;
  transition: transform .2s ease, opacity .2s ease, box-shadow .2s ease;
}
.primary-btn:hover, .secondary-btn:hover, .ghost-btn:hover, .icon-btn:hover, .nav-link:hover { transform: translateY(-1px); }
.primary-btn {
  background: linear-gradient(135deg, var(--primary), #4f46e5);
  color: #fff;
  padding: .9rem 1.2rem;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(37, 99, 235, 0.22);
}
.secondary-btn {
  background: var(--panel-soft);
  color: var(--text);
  padding: .82rem 1rem;
  border: 1px solid var(--line);
}
.ghost-btn, .icon-btn {
  background: transparent;
  color: var(--text);
  padding: .78rem 1rem;
  border: 1px solid var(--line);
}
.icon-btn { width: 44px; height: 44px; display: inline-grid; place-items: center; padding: 0; border-radius: 14px; }
.full { width: 100%; }
.mobile-only { display: none; }

.field { display: grid; gap: .45rem; }
.field label { font-size: .92rem; font-weight: 600; }
.field-grid { display: grid; gap: 1rem; }
.field-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.field-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.field-grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.align-end { align-content: end; }
.checkbox-row { gap: .7rem; justify-content: flex-start; }
.checkbox-row input { width: auto; }
.inline-field { margin-top: 1rem; }
.button-row { gap: .75rem; flex-wrap: wrap; }
.compact-row { gap: .55rem; }
.wrap { flex-wrap: wrap; }
.stack-mobile { gap: 1rem; flex-wrap: wrap; }
.compact-grid { align-items: end; }

.stats-grid, .mini-grid, .dashboard-grid, .analysis-grid, .tools-grid, .goals-layout, .planning-layout, .plan-summary-grid {
  display: grid;
  gap: 1rem;
}
.stats-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.stat-card {
  border-radius: var(--radius-lg);
  padding: 1.2rem;
  color: #fff;
  display: grid;
  gap: .55rem;
}
.stat-card strong { font-size: clamp(1.4rem, 2vw, 2rem); }
.stat-card.income { background: linear-gradient(135deg, #16a34a, #22c55e); }
.stat-card.expense { background: linear-gradient(135deg, #dc2626, #fb7185); }
.stat-card.balance { background: linear-gradient(135deg, #2563eb, #06b6d4); }
.stat-card.carry { background: linear-gradient(135deg, #7c3aed, #a855f7); }
.alert-stack { display: grid; gap: .8rem; }
.alert {
  border-radius: var(--radius-md);
  padding: 1rem 1.1rem;
  border: 1px solid transparent;
  display: flex;
  align-items: center;
  gap: .8rem;
  animation: fadeUp .28s ease both;
}
.alert.success { background: var(--success-soft); color: var(--success); border-color: rgba(34,197,94,.24); }
.alert.warning { background: var(--warning-soft); color: var(--warning); border-color: rgba(249,115,22,.24); }
.alert.danger { background: var(--danger-soft); color: var(--danger); border-color: rgba(239,68,68,.24); }
.dashboard-grid { grid-template-columns: 1.15fr .85fr; }
.lower-grid { grid-template-columns: 1fr 1fr; }
.mini-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.mini-tile, .plan-box {
  background: var(--panel-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 1rem;
  display: grid;
  gap: .4rem;
}
.mini-tile strong, .plan-box strong { font-size: 1.18rem; }
.recent-list, .goal-overview-list, .goal-insight-list, .goal-editor-list, .quick-list { display: grid; gap: .85rem; }
.recent-item, .goal-overview, .goal-card, .goal-insight {
  background: var(--panel-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 1rem;
}
.recent-item { display: flex; justify-content: space-between; gap: 1rem; }
.recent-item strong { display: block; }
.goal-overview { display: grid; gap: .8rem; }
.goal-topline, .goal-inline-meta { display: flex; justify-content: space-between; gap: .75rem; flex-wrap: wrap; }
.progress-track {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: var(--line);
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary), #4f46e5);
  transition: width .35s ease;
}
.goal-meta { color: var(--text-soft); font-size: .92rem; }
.plan-summary-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.analysis-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.wide-card { grid-column: 1 / -1; }
.chart-holder {
  position: relative;
  min-height: 320px;
}
.chart-tall { min-height: 360px; }
.chart-holder canvas { width: 100% !important; height: 100% !important; }
.table-wrap { overflow: auto; border-radius: var(--radius-md); border: 1px solid var(--line); }
.table-wrap table { width: 100%; border-collapse: collapse; min-width: 860px; }
.table-wrap th, .table-wrap td { padding: .95rem .85rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.table-wrap thead { background: var(--panel-soft); }
.pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  border-radius: 999px;
  padding: .35rem .65rem;
  font-size: .82rem;
  font-weight: 700;
}
.pill.income { background: rgba(34,197,94,.16); color: var(--success); }
.pill.expense { background: rgba(239,68,68,.16); color: var(--danger); }
.filters-row { gap: .75rem; flex-wrap: wrap; }
.filters-row > * { min-width: 160px; }
.goal-editor-list { margin-bottom: 1rem; }
.goal-card { display: grid; gap: .85rem; }
.goal-card .field-grid { gap: .75rem; }
.goal-actions { display: flex; justify-content: flex-end; }
.result-box {
  margin-top: 1rem;
  background: var(--panel-soft);
  border: 1px dashed var(--line);
  border-radius: var(--radius-md);
  padding: 1rem;
}
.toast {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  background: var(--text);
  color: #fff;
  padding: .95rem 1.05rem;
  border-radius: 16px;
  box-shadow: var(--shadow);
  z-index: 1000;
  min-width: 260px;
}
.toast.success { background: #166534; }
.toast.error { background: #991b1b; }
.toast.info { background: #1d4ed8; }
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15,23,42,.52);
  z-index: 25;
}
.sidebar-overlay.active { display: block; }

@media (max-width: 1180px) {
  .stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dashboard-grid, .lower-grid, .analysis-grid, .goals-layout, .planning-layout, .tools-grid { grid-template-columns: 1fr; }
  .plan-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .field-grid.four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 980px) {
  .auth-card { grid-template-columns: 1fr; }
  .app-shell { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 30;
    width: min(320px, 90vw);
    transform: translateX(-102%);
    transition: transform .25s ease;
  }
  .sidebar.open { transform: translateX(0); }
  .mobile-only { display: inline-grid; }
  .topbar { padding-top: 1rem; }
}

@media (max-width: 720px) {
  .auth-shell, .content { padding: 1rem; }
  .topbar { padding-inline: 1rem; }
  .field-grid.two, .field-grid.three, .field-grid.four, .stats-grid, .mini-grid, .plan-summary-grid { grid-template-columns: 1fr; }
  .filters-row > * { min-width: 100%; }
  .recent-item { flex-direction: column; }
}

@media (min-width: 1800px) {
  .app-shell { grid-template-columns: 360px minmax(0, 1fr); }
  .content { padding: 2rem; }
  .stats-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .card { padding: 1.5rem; }
  .chart-holder { min-height: 380px; }
}

/* =========================
   EKRAN LOGOWANIA I REJESTRACJI
   Style formularzy dostępu do aplikacji
   ========================= */
.auth-card {
  width: min(1180px, 100%);
  grid-template-columns: 1.05fr minmax(420px, .95fr);
  gap: clamp(1.25rem, 2.6vw, 2rem);
  padding: clamp(1.1rem, 2.5vw, 1.6rem);
  background: linear-gradient(180deg, rgba(9,16,38,.92), rgba(7,13,31,.92));
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 26px 80px rgba(2, 6, 23, 0.52);
}
.auth-brand {
  position: relative;
  min-height: 100%;
  padding: clamp(1.4rem, 3vw, 2.2rem);
  background:
    radial-gradient(circle at top right, rgba(99,102,241,.24), transparent 34%),
    radial-gradient(circle at bottom left, rgba(56,189,248,.16), transparent 30%),
    linear-gradient(145deg, rgba(30,41,59,.92), rgba(15,23,42,.84));
  border: 1px solid rgba(148,163,184,.12);
}
.auth-brand .badge {
  display: inline-flex;
  width: fit-content;
  padding: .6rem 1rem;
  border-radius: 999px;
  background: rgba(59,130,246,.15);
  border: 1px solid rgba(96,165,250,.18);
  color: #60a5fa;
}
.auth-brand h1 { font-size: clamp(2.3rem, 4.8vw, 4.4rem); margin-bottom: 1rem; }
.auth-brand p { color: rgba(226,232,240,.72); font-size: 1.15rem; line-height: 1.55; }
.auth-panel {
  padding: clamp(1rem, 2.5vw, 1.6rem);
  background: linear-gradient(180deg, rgba(15,23,42,.88), rgba(8,15,31,.82));
  border: 1px solid rgba(148,163,184,.12);
  border-radius: var(--radius-lg);
  display: grid;
  align-content: start;
  gap: 1rem;
}
.auth-helper {
  display: grid;
  gap: .35rem;
  padding: .2rem .15rem .35rem;
  color: rgba(226,232,240,.88);
}
.auth-helper span { color: rgba(148,163,184,.85); line-height: 1.45; }

.auth-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.auth-toolbar-label {
  font-size: .88rem;
  color: var(--text-soft);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.auth-switch {
  width: 100%;
  gap: .6rem;
  padding: .5rem;
  background: rgba(15,23,42,.92);
  border: 1px solid rgba(148,163,184,.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.tab-btn {
  min-height: 56px;
  padding: 1rem 1.2rem;
  color: rgba(203,213,225,.78);
  letter-spacing: .01em;
}
.tab-btn.active {
  background: linear-gradient(135deg, rgba(37,99,235,.92), rgba(99,102,241,.92));
  color: #fff;
  box-shadow: 0 14px 34px rgba(37,99,235,.32);
}
.auth-form { gap: 1.1rem; }
.auth-form .field label { color: rgba(226,232,240,.92); font-weight: 700; }
.auth-form input {
  background: rgba(248,250,252,.96);
  border: 1px solid rgba(203,213,225,.9);
  color: #0f172a !important;
}
.auth-form .primary-btn { margin-top: .2rem; }

.sidebar-actions {
  display: grid;
  gap: .75rem;
  margin-top: .25rem;
}
.sidebar-actions .primary-btn {
  box-shadow: 0 16px 36px rgba(99,102,241,.26);
}

.nav-link {
  position: relative;
  overflow: hidden;
}
.nav-link.active::before,
.nav-link:hover::before {
  content: '';
  position: absolute;
  inset: 8px auto 8px 10px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, #60a5fa, #8b5cf6);
}
.nav-link.active,
.nav-link:hover {
  padding-left: 1.3rem;
}

.stat-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(15,23,42,.96), rgba(10,15,29,.96));
  border: 1px solid rgba(148,163,184,.12);
  box-shadow: 0 18px 42px rgba(2,6,23,.34);
}
.stat-card::after {
  content: '';
  position: absolute;
  inset: auto 14px 0 14px;
  height: 64px;
  border-radius: 999px 999px 0 0;
  opacity: .24;
  filter: blur(22px);
}
.stat-card.income { box-shadow: 0 18px 42px rgba(2,6,23,.34), 0 0 0 1px rgba(34,197,94,.12), 0 0 34px rgba(34,197,94,.22); }
.stat-card.expense { box-shadow: 0 18px 42px rgba(2,6,23,.34), 0 0 0 1px rgba(248,113,113,.12), 0 0 34px rgba(248,113,113,.22); }
.stat-card.balance { box-shadow: 0 18px 42px rgba(2,6,23,.34), 0 0 0 1px rgba(56,189,248,.12), 0 0 34px rgba(56,189,248,.22); }
.stat-card.carry { box-shadow: 0 18px 42px rgba(2,6,23,.34), 0 0 0 1px rgba(168,85,247,.12), 0 0 34px rgba(168,85,247,.22); }
.stat-card.income::before,
.stat-card.expense::before,
.stat-card.balance::before,
.stat-card.carry::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
}
.stat-card.income::before { background: linear-gradient(90deg, #22c55e, #4ade80); }
.stat-card.expense::before { background: linear-gradient(90deg, #ef4444, #fb7185); }
.stat-card.balance::before { background: linear-gradient(90deg, #3b82f6, #22d3ee); }
.stat-card.carry::before { background: linear-gradient(90deg, #8b5cf6, #c084fc); }
.stat-card.income::after { background: rgba(34,197,94,.92); }
.stat-card.expense::after { background: rgba(248,113,113,.92); }
.stat-card.balance::after { background: rgba(56,189,248,.92); }
.stat-card.carry::after { background: rgba(168,85,247,.92); }
.stat-card span { color: rgba(226,232,240,.72); font-weight: 600; }
.stat-card strong { color: #fff; letter-spacing: -.02em; }

.settings-grid .mini-tile,
.settings-tips .tip-item {
  min-height: 110px;
}
.tip-item {
  background: var(--panel-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 1rem;
  display: grid;
  gap: .45rem;
}
.tip-item span { color: var(--text-soft); line-height: 1.45; }

@media (max-width: 980px) {
  .auth-card {
    grid-template-columns: 1fr;
  }
  .auth-panel {
    order: 2;
  }
}

@media (max-width: 640px) {
  .auth-shell { padding: 1rem; }
  .auth-card { width: 100%; }
  .auth-panel, .auth-brand { padding: 1rem; }
  
.auth-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.auth-toolbar-label {
  font-size: .88rem;
  color: var(--text-soft);
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.auth-switch { grid-template-columns: 1fr; }
}


body:not(.dark) .auth-card {
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(148,163,184,.26);
}
body:not(.dark) .auth-panel {
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(148,163,184,.18);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  box-shadow: 0 16px 38px rgba(15,23,42,.08);
}
body:not(.dark) .auth-switch {
  background: #eaf0fb;
}
body:not(.dark) .tab-btn.active {
  background: linear-gradient(135deg, #2563eb, #6366f1);
  color: #fff;
  box-shadow: 0 10px 25px rgba(37,99,235,.22);
}
body:not(.dark) .auth-helper strong { color: #0f172a; }
body:not(.dark) .auth-helper span { color: #475569; }
body:not(.dark) .auth-brand {
  background: linear-gradient(145deg, rgba(15,23,42,.96), rgba(30,41,59,.93));
}
body:not(.dark) .auth-toolbar-label { color: #475569; }
body.dark .auth-panel {
  background: rgba(5,10,24,.72);
  border: 1px solid rgba(96,165,250,.12);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03), 0 14px 40px rgba(2,6,23,.35);
}
body.dark .auth-switch { background: rgba(15,23,42,.75); }
body.dark .tab-btn.active {
  background: linear-gradient(135deg, #2563eb, #6366f1);
  color: #fff;
  box-shadow: 0 12px 26px rgba(37,99,235,.28);
}
@media (max-width: 720px) {
  .auth-toolbar { flex-direction: column; align-items: stretch; }
  .auth-toolbar .ghost-btn { width: 100%; }
}


/* =========================
   WYMUSZENIE CIEMNEGO MOTYWU
   Ukrycie ewentualnych pozostałości po ustawieniach motywu
   ========================= */
body{background: radial-gradient(circle at top left, rgba(37,99,235,.18), transparent 30%), radial-gradient(circle at bottom right, rgba(124,58,237,.18), transparent 25%), #020817;}
body:not(.dark){background: radial-gradient(circle at top left, rgba(37,99,235,.18), transparent 30%), radial-gradient(circle at bottom right, rgba(124,58,237,.18), transparent 25%), #020817;}
[data-view="settings"], #themeToggleBtn, #authThemeToggleBtn, #settingsThemeBtn{display:none !important;}
/* Wymuszenie ciemnego tła dla pól autouzupełnianych przez przeglądarkę */
input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus, 
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 30px var(--panel-soft) inset !important;
    -webkit-text-fill-color: var(--text) !important;
    transition: background-color 5000s ease-in-out 0s;
}
