:root {
  color-scheme: dark;
  --gap: 12px;
  --radius: 16px;
  --page-bg: #000000;
  --panel-bg: #111214;
  --panel-soft: #111214;
  --panel-strong: #0b5176;
  --border: rgba(245, 251, 255, 0.08);
  --border-strong: rgba(245, 251, 255, 0.14);
  --border-subtle: rgba(245, 251, 255, 0.06);
  --accent: #019fff;
  --accent-strong: #019fff;
  --accent-soft: rgba(1, 159, 255, 0.18);
  --danger: #ff6b6b;
  --danger-soft: rgba(255, 107, 107, 0.18);
  --danger-ring: rgba(255, 107, 107, 0.35);
  --success: #4ce3b0;
  --success-soft: rgba(76, 227, 176, 0.16);
  --success-ring: rgba(76, 227, 176, 0.35);
  --warning: #fbbf24;
  --warning-soft: rgba(251, 191, 36, 0.18);
  --warning-ring: rgba(251, 191, 36, 0.35);
  --info-soft: rgba(1, 159, 255, 0.18);
  --info-ring: rgba(1, 159, 255, 0.35);
  --text-primary: #f5fbff;
  --text-secondary: rgba(245, 251, 255, 0.72);
  --text-muted: rgba(245, 251, 255, 0.55);
  --shadow: 0 24px 48px rgba(8, 15, 31, 0.35);
  --shadow-soft: 0 18px 36px rgba(8, 15, 31, 0.28);
  --header-glass: rgba(11, 24, 41, 0.68);
  --surface-muted: rgba(9, 24, 38, 0.6);
  --surface-muted-strong: rgba(9, 24, 38, 0.75);
  --input-bg: rgba(3, 15, 25, 0.7);
  --input-border: rgba(245, 251, 255, 0.12);
  --focus-ring: rgba(1, 159, 255, 0.25);
  --pill-bg: rgba(9, 20, 35, 0.72);
  --pill-border: rgba(245, 251, 255, 0.1);
  --badge-owner-bg: rgba(12, 48, 30, 0.78);
  --badge-owner-border: rgba(58, 199, 132, 0.45);
  --badge-owner-text: #8ef2c2;
  --badge-bg: rgba(9, 24, 40, 0.65);
  --badge-border: rgba(245, 251, 255, 0.12);
  --button-text-contrast: #ffffff;
  --modal-backdrop: rgba(8, 10, 12, 0.68);
  --overlay-glass: rgba(11, 24, 41, 0.86);
  --logo-bg: var(--panel-soft);
  --logo-shadow: 0 12px 28px rgba(8, 15, 31, 0.4), 0 1px 0 rgba(245, 251, 255, 0.05) inset;

  /* legacy mappings */
  --bg: var(--page-bg);
  --card: var(--panel-bg);
  --btn: var(--accent);
  --btn-2: rgba(1, 159, 255, 0.16);
  --text: var(--text-primary);
  --text-dim: var(--text-secondary);
  --muted: var(--text-muted);
  --surface-border: var(--border);
  --surface-border-strong: var(--border-strong);
  --ok: var(--success);
  --err: var(--danger);
  --page-background: var(--page-bg);
}

:root[data-theme="light"] {
  color-scheme: light;
  --page-bg: #f4f7fb;
  --panel-bg: #ffffff;
  --panel-soft: #ffffff;
  --panel-strong: #2364a0;
  --border: rgba(17, 24, 39, 0.08);
  --border-strong: rgba(17, 24, 39, 0.14);
  --border-subtle: rgba(17, 24, 39, 0.05);
  --accent: #019fff;
  --accent-strong: #019fff;
  --accent-soft: rgba(1, 159, 255, 0.14);
  --danger: #d13a3a;
  --danger-soft: rgba(209, 58, 58, 0.14);
  --danger-ring: rgba(209, 58, 58, 0.28);
  --success: #0f9150;
  --success-soft: rgba(15, 145, 80, 0.12);
  --success-ring: rgba(15, 145, 80, 0.28);
  --warning: #c68410;
  --warning-soft: rgba(198, 132, 16, 0.14);
  --warning-ring: rgba(198, 132, 16, 0.28);
  --info-soft: rgba(1, 159, 255, 0.12);
  --info-ring: rgba(1, 159, 255, 0.25);
  --text-primary: #0b1a2b;
  --text-secondary: rgba(11, 26, 43, 0.72);
  --text-muted: rgba(11, 26, 43, 0.55);
  --shadow: 0 20px 40px rgba(17, 36, 68, 0.18);
  --shadow-soft: 0 14px 32px rgba(17, 36, 68, 0.12);
  --header-glass: rgba(255, 255, 255, 0.9);
  --surface-muted: rgba(31, 44, 68, 0.1);
  --surface-muted-strong: rgba(31, 44, 68, 0.18);
  --input-bg: rgba(255, 255, 255, 0.98);
  --input-border: rgba(17, 24, 39, 0.14);
  --focus-ring: rgba(1, 159, 255, 0.25);
  --pill-bg: rgba(234, 240, 255, 0.9);
  --pill-border: rgba(31, 44, 68, 0.18);
  --badge-owner-bg: rgba(15, 145, 80, 0.12);
  --badge-owner-border: rgba(15, 145, 80, 0.32);
  --badge-owner-text: #0f9150;
  --badge-bg: rgba(31, 44, 68, 0.08);
  --badge-border: rgba(31, 44, 68, 0.12);
  --button-text-contrast: #ffffff;
  --modal-backdrop: rgba(11, 26, 43, 0.48);
  --overlay-glass: rgba(255, 255, 255, 0.96);
  --logo-bg: var(--panel-soft);
  --logo-shadow: 0 10px 22px rgba(17, 36, 68, 0.16), 0 1px 0 rgba(255, 255, 255, 0.68) inset;

  /* legacy mappings */
  --bg: var(--page-bg);
  --card: var(--panel-bg);
  --btn: var(--accent);
  --btn-2: rgba(31, 44, 68, 0.08);
  --text: var(--text-primary);
  --text-dim: var(--text-secondary);
  --muted: var(--text-muted);
  --surface-border: var(--border);
  --surface-border-strong: var(--border-strong);
  --ok: var(--success);
  --err: var(--danger);
  --page-background: var(--page-bg);
}
html,

body {

  height: 100%;

}

body {

  margin: 0;

  padding: env(safe-area-inset-top) 0 env(safe-area-inset-bottom);

  background: var(--page-background);

  color: var(--text);

  font-family: system-ui, Segoe UI, Roboto, Arial, sans-serif;

  -webkit-font-smoothing: antialiased;

}

.wrap {

  max-width: 720px;

  margin: 0 auto;

  padding: 16px;

  display: flex;

  flex-direction: column;

  gap: var(--gap);

}

header {

  position: sticky;

  top: 0;

  z-index: 10;

  backdrop-filter: blur(8px);

  background: var(--panel-bg);

  border-bottom: 1px solid var(--border);

}

header .inner {

  max-width: 720px;

  margin: 0 auto;

  padding: 12px 16px;

  display: flex;

  align-items: center;

  gap: 12px;

}

.profile {

  margin-left: auto;

  display: flex;

  align-items: center;

  gap: 10px;

}

.profile-trigger {

  display: inline-flex;

  align-items: center;

  justify-content: center;

  width: 36px;

  height: 36px;

  border-radius: 999px;

  border: 1px solid var(--border-strong);

  background: var(--pill-bg);

  color: rgba(245, 251, 255, 0.9);

  text-decoration: none;

  font-size: 13px;

  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;

}

.profile-trigger:hover,

.profile-trigger:focus-visible {

  color: var(--text);

  border-color: var(--accent);

  outline: none;

}

.avatar {

  width: 100%;

  height: 100%;

  border-radius: inherit;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  color: var(--accent-strong);

  font-weight: 700;

}

.avatar-img {

  width: 100%;

  height: 100%;

  border-radius: inherit;

  object-fit: cover;

  display: block;

}

header img.logo {

  width: 52px;

  height: 52px;

  border-radius: 14px;

  padding: 8px;

  background: var(--logo-bg);

  border: 1px solid var(--border-strong);

  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35),

    0 1px 0 rgba(255, 255, 255, 0.04) inset;

  object-fit: contain;

  filter: saturate(1.05) contrast(1.05);

}

header h1 {

  font-size: 18px;

  margin: 0;

  font-weight: 600;

  letter-spacing: 0.2px;

}

header .sub {

  font-size: 12px;

  color: rgba(245, 251, 255, 0.9);

}

.steps {

  display: flex;

  gap: 6px;

  align-items: center;

}

.dot {

  width: 8px;

  height: 8px;

  border-radius: 999px;

  background: var(--border-strong);

  transition: all 0.2s;

}

.dot.on {

  background: var(--accent);

  box-shadow: 0 0 0 4px var(--accent-soft);

}

.card {

  background: var(--card);

  border: 1px solid var(--border);

  border-radius: var(--radius);

  padding: 16px;

  position: relative;

  overflow: hidden;

  box-shadow: var(--shadow);

}

.card::before {

  content: none;

}

.card > * {

  position: relative;

  z-index: 1;

}

.card h2 {

  margin: 0 0 8px;

  font-size: 18px;

  font-weight: 700;

  color: var(--text-secondary);

}

.grid2 {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 8px;

}

@media (max-width: 640px) {

  .grid2 {

    grid-template-columns: 1fr;

  }

}

label {

  font-size: 12px;

  color: rgba(245, 251, 255, 0.9);

  margin-bottom: 4px;

  display: block;

}

input,

select {

  width: 100%;

  box-sizing: border-box;

  padding: 12px 14px;

  border-radius: 12px;

  border: 1px solid var(--border-strong);

  background: var(--input-bg);

  color: var(--text);

  outline: none;

}

input:focus {

  border-color: var(--accent);

  box-shadow: 0 0 0 3px var(--focus-ring);

}

button {

  width: 100%;

  padding: 14px 16px;

  border-radius: 12px;

  border: 0;

  font-weight: 600;

  background: var(--accent);

  color: var(--button-text-contrast);

  cursor: pointer;

}
:root[data-theme="light"] button {

  color: var(--button-text-contrast);

}


button.secondary {

  background: var(--btn-2);

  color: rgba(245, 251, 255, 0.9);

  border: 1px solid var(--border);

}

button.ghost {

  background: transparent;

  border: 1px dashed var(--border-strong);

  color: rgba(245, 251, 255, 0.9);

}

button[disabled] {

  opacity: 0.6;

  cursor: not-allowed;

}



.auth-modal {

  border: 1px solid var(--border);

  border-radius: 20px;

  background: var(--card);

  color: var(--text);

  padding: 0;

  width: min(640px, calc(100vw - 40px));

  max-width: 640px;

}

.auth-modal::backdrop {

  background: rgba(8, 15, 31, 0.65);

  backdrop-filter: blur(4px);

}

.auth-shell {

  position: relative;

  padding: 56px 32px 32px;

  display: flex;

  flex-direction: column;

  gap: 24px;

}

.auth-close {

  position: absolute;

  top: 16px;

  right: 16px;

  width: auto;

  padding: 0;

  border: none;

  background: transparent;

  color: rgba(245, 251, 255, 0.9);

  font-size: 26px;

  line-height: 1;

  cursor: pointer;

}

.auth-close:hover {

  color: var(--text);

}

.auth-tabs {

  display: flex;

  gap: 8px;

  background: var(--surface-muted);

  padding: 6px;

  border-radius: 16px;

  align-self: center;

}

.auth-tab {

  width: auto;

  padding: 10px 18px;

  border-radius: 12px;

  border: 1px solid transparent;

  background: transparent;

  color: rgba(245, 251, 255, 0.9);

  font-weight: 600;

  cursor: pointer;

  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;

}

.auth-tab.is-active {

  color: var(--text);

  background: rgba(1, 159, 255, 0.12);

  border-color: rgba(1, 159, 255, 0.4);

}

.auth-panel {

  display: none;

  flex-direction: column;

  gap: 12px;

  background: var(--surface-muted);

  border: 1px solid var(--border);

  border-radius: 18px;

  padding: 22px 24px;

  box-shadow: var(--shadow);

}

.auth-modal[data-mode="login"] .auth-panel--login,

.auth-modal[data-mode="register"] .auth-panel--register {

  display: flex;

}

.auth-subline {

  margin: 0;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}

.auth-panel label {

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}

.auth-panel input {

  width: 100%;

  padding: 12px 14px;

  border-radius: 12px;

  border: 1px solid var(--border);

  background: var(--input-bg);

  color: var(--text);

  font-size: 15px;

}

.auth-panel input::placeholder {

  color: var(--text-muted);

}

.auth-grid {

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));

  gap: 12px;

}

.auth-msg {

  min-height: 18px;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}

.auth-msg.is-error {

  color: var(--err);

}

.auth-msg.is-success {

  color: var(--ok);

}

.auth-note {

  font-size: 12px;

  color: rgba(245, 251, 255, 0.9);

  background: var(--surface-muted);

  padding: 10px 14px;

  border-radius: 12px;

  line-height: 1.5;

}

.auth-cta {

  display: flex;

  align-items: center;

  gap: 8px;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}

.auth-link {

  width: auto;

  padding: 0;

  background: none;

  border: none;

  color: var(--accent-strong);

  font-size: 13px;

  font-weight: 600;

  cursor: pointer;

}

.auth-link:hover {

  text-decoration: underline;

}

.auth-panel button {

  width: 100%;

}



.actions {

  display: grid;

  grid-template-columns: 1fr;

  gap: 8px;

  margin-top: 12px;

}

.inline {

  display: flex;

  align-items: center;

  gap: 8px;

  font-size: 13px;

}

.badge {

  padding: 6px 10px;

  border-radius: 999px;

  background: var(--pill-bg);

  border: 1px solid var(--border);

  font-size: 12px;

  color: var(--text-secondary);

}

.badge--owner {

  background: var(--badge-owner-bg);

  border-color: var(--badge-owner-border);

  color: var(--success);

  font-weight: 700;

}

.price {

  display: flex;

  flex-wrap: wrap;

  gap: 6px;

  margin-top: 8px;

}

.terms-wrap {

  margin-top: 8px;

}

.terms {

  width: 100%;

  border-collapse: collapse;

  background: var(--surface-high, rgba(255, 255, 255, 0.03));

  border-radius: 12px;

  overflow: hidden;

}

.terms th,

.terms td {

  padding: 10px 12px;

}

.terms th {

  text-align: left;

  font-weight: 500;

  color: rgba(245, 251, 255, 0.9);

}

.terms td {

  text-align: right;

  font-weight: 600;

}

.terms-info {

  display: inline-flex;

  align-items: center;

  justify-content: center;

  width: 18px;

  height: 18px;

  margin-left: 6px;

  border-radius: 50%;

  border: 1px solid rgba(255, 255, 255, 0.5);

  color: rgba(255, 255, 255, 0.9);

  font-size: 11px;

  cursor: help;

  background: rgba(255, 255, 255, 0.06);

}

.terms tr + tr th,

.terms tr + tr td {

  border-top: 1px solid rgba(255, 255, 255, 0.08);

}

.terms-subline td {

  color: rgba(255, 255, 255, 0.72);

}

.battery-vert {

  position: relative;

  display: flex;

  align-items: center;

  justify-content: center;

  width: 64px;

  height: 80px;

  margin-right: 18px;

}

.battery-vert .pct {

  position: absolute;

  z-index: 2;

  font-weight: 600;

  font-size: 18px;

  color: var(--text);

}

.battery-vert .icon {

  position: relative;

  width: 36px;

  height: 64px;

  border: 2px solid rgba(255, 255, 255, 0.18);

  border-radius: 12px;

  background: rgba(255, 255, 255, 0.05);

  box-sizing: border-box;

}

.battery-vert .icon i {

  position: absolute;

  left: 4px;

  right: 4px;

  bottom: 4px;

  height: 0;

  border-radius: 6px;

  background: var(--accent);

  transition: height 0.3s ease;

}

.battery-vert .icon .cap {

  position: absolute;

  top: -7px;

  left: 50%;

  transform: translateX(-50%);

  width: 18px;

  height: 6px;

  border-radius: 3px 3px 0 0;

  border: 2px solid rgba(255, 255, 255, 0.18);

  border-bottom: none;

  background: rgba(255, 255, 255, 0.05);

}

.modal-backdrop {

  position: fixed;

  inset: 0;

  background: rgba(8, 10, 12, 0.6);

  backdrop-filter: blur(4px);

  display: flex;

  align-items: center;

  justify-content: center;

  z-index: 2000;

}

.modal-backdrop.hidden {

  display: none;

}

.modal-window {

  position: relative;

  width: min(420px, 90vw);

  background: var(--card);

  border-radius: 18px;

  padding: 18px 24px 24px;

  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.35);

  border: 1px solid rgba(255, 255, 255, 0.08);

  overflow: hidden;

}

.modal-header {

  display: flex;

  justify-content: flex-end;

  margin-bottom: 12px;

}

.modal-close {

  background: none;

  border: none;

  color: rgba(245, 251, 255, 0.9);

  font-size: 28px;

  cursor: pointer;

  line-height: 1;

  transition: color 0.2s ease, background 0.2s ease;

  width: 38px;

  height: 38px;

  display: inline-flex;

  align-items: center;

  justify-content: center;

  padding: 0;

  border-radius: 12px;

  pointer-events: auto;

  touch-action: manipulation;

}

.modal-close:hover {

  color: var(--text);

  background: rgba(148, 163, 184, 0.12);

}

.modal-body h3 {

  margin: 0 0 16px;

  font-size: 20px;

  text-align: center;

}

.modal-status {

  display: flex;

  align-items: center;

  justify-content: center;

  gap: 6px;

  font-size: 16px;

  color: rgba(245, 251, 255, 0.9);

}

.modal-status.waiting #cableModalStatusText {

  color: rgba(245, 251, 255, 0.9);

}

.modal-status.success {

  color: var(--ok);

  font-weight: 600;

}

.modal-status.success::before {

  content: "\2714";

  font-size: 18px;

}

.modal-status.error {

  color: var(--err);

  font-weight: 600;

}



.info {

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

  display: flex;

  gap: 8px;

  flex-wrap: wrap;

}

.ok {

  color: var(--ok);

}

.err {

  color: var(--err);

}

.stripe-field {

  padding: 12px 14px;

  border-radius: 12px;

  border: 1px solid var(--border-strong);

  background: var(--input-bg);

}

.sim-toggle {

  display: flex;

  align-items: center;

  justify-content: space-between;

  gap: 16px;

  margin: 12px 0 16px;

}

.sim-toggle-info {

  flex: 1;

}

.sim-toggle-hint {

  font-size: 13px;

  color: var(--text-muted);

  margin-top: 2px;

}

.switch {

  display: inline-flex;

  align-items: center;

  gap: 10px;

  cursor: pointer;

  user-select: none;

}

.switch input {

  display: none;

}

.switch .slider {

  position: relative;

  width: 46px;

  height: 24px;

  background: var(--pill-bg);

  border-radius: 999px;

  transition: background 0.2s ease;

  box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.25);

}

.switch .slider::after {

  content: "";

  position: absolute;

  top: 3px;

  left: 3px;

  width: 18px;

  height: 18px;

  border-radius: 50%;

 	background: var(--panel-soft);

  transition: transform 0.2s ease;

  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.4);

}

.switch input:checked + .slider {

  background: var(--accent);

}

.switch input:checked + .slider::after {

  transform: translateX(22px);

}

.switch .switch-text {

  font-size: 13px;

  color: var(--text-secondary);

  min-width: 36px;

  text-align: right;

}

.switch input:checked + .slider + .switch-text {

  color: var(--accent);

  font-weight: 600;

}

.progress {

  height: 6px;

  background: var(--pill-bg);

  border-radius: 999px;

  overflow: hidden;

  margin: 8px 0 0;

}

.progress > i {

  display: block;

  height: 100%;

  width: 0%;

  background: var(--accent);

  transition: width 0.2s;

}

.kpi {

  display: flex;

  gap: 12px;

  flex-wrap: wrap;

  margin-top: 8px;

}

.kpi .box {

  flex: 1 1 auto;

  min-width: 140px;

  padding: 10px 12px;

  background: var(--pill-bg);

  border: 1px solid var(--border);

  border-radius: 12px;

}

.big {

  font-size: 24px;

  font-weight: 700;

  letter-spacing: 0.3px;

}

.sticky-footer {

  position: sticky;

  bottom: 0;

  z-index: 5;

  background: var(--panel-bg);

  backdrop-filter: blur(8px);

  padding: 10px 16px;

  border-top: 1px solid var(--border);

}

.sticky-footer a {

  color: var(--accent);

  text-decoration: underline;

}

.sticky-footer-links {

  margin-top: 10px;

  text-align: center;

  font-size: 13px;

}

.hint {

  font-size: 12px;

  color: rgba(245, 251, 255, 0.9);

}

.hidden {

  display: none !important;

  visibility: hidden;

  pointer-events: none;

}

.admin {

  margin-top: 10px;

  background: var(--pill-bg);

  border: 1px dashed var(--border-strong);

  border-radius: 12px;

  padding: 10px;

}

.admin-title {

  font-weight: 700;

  font-size: 13px;

  color: var(--accent-strong);

  margin-bottom: 6px;

}

.admin-row {

  display: flex;

  flex-wrap: wrap;

  gap: 6px;

}

.chip {

  padding: 8px 10px;

  border-radius: 999px;

  border: 1px solid var(--border-strong);

  background: var(--pill-bg);

  color: rgba(245, 251, 255, 0.9);

  cursor: pointer;

}

.chip:hover {

  filter: brightness(1.1);

}

#walletWrap.hidden {

  display: none !important;

}

#payment-request-button {

  width: 100%;

}

#paySelector.hidden,

#cardBlock.hidden {

  display: none !important;

}

.seg {

  display: flex;

  background: var(--pill-bg);

  border: 1px solid var(--border);

  border-radius: 10px;

  overflow: hidden;

}

.seg-btn {

  flex: 1;

  padding: 8px 10px;

  border: 0;

  background: transparent;

  color: rgba(245, 251, 255, 0.9);

  cursor: pointer;

}

.seg-btn.active {

  background: var(--surface-muted-strong);

  font-weight: 700;

}

.status-pill {

  display: inline-flex;

  align-items: center;

  gap: 6px;

  font-weight: 600;

  font-size: 14px;

  border-radius: 999px;

  padding: 6px 12px;

  border: 1px solid var(--border);

  background: var(--badge-owner-bg);

  color: var(--success);

}

.status-pill .dot {

  width: 10px;

  height: 10px;

  border-radius: 999px;

  background: currentColor;

}

.status-pill.is-free {

  color: var(--success);

  border-color: var(--success-ring);

  background: rgba(14, 181, 105, 0.12);

}

.status-pill.is-busy {

  color: var(--warning);

  border-color: var(--warning-ring);

  background: rgba(245, 158, 11, 0.1);

}

.status-pill.is-busy .dot {

  background: var(--warning-soft);

}

.status-pill.is-charging {

  color: var(--accent);

  border-color: var(--info-ring);

}

.status-pill.is-charging .dot {

  background: var(--info-soft);

}

.status-pill.is-faulted,

.status-pill.is-offline {

  color: var(--danger);

  border-color: var(--danger-ring);

}

.status-pill.is-faulted .dot,

.status-pill.is-offline .dot {

  background: var(--danger-soft);

}

.status-pill.is-unknown {

  color: var(--text-secondary);

}

.status-pill.is-paused {

  color: var(--warning);

  border-color: var(--warning-ring);

}

.status-pill.is-paused .dot {

  background: var(--warning-soft);

}



@media (max-width: 540px) {

  .auth-shell {

    padding: 48px 20px 28px;

  }

  .auth-tabs {

    flex-direction: column;

    align-self: stretch;

  }

  .auth-tab {

    width: 100%;

    text-align: center;

  }

  .auth-panel {

    padding: 20px 18px;

  }

  .auth-grid {

    grid-template-columns: 1fr;

  }

}



/* Profile page ----------------------------------------------------------- */

body.profile-page {

  background: var(--page-background);

  color: var(--text);

  min-height: 100vh;

  margin: 0;

}



.profile-shell {

  max-width: 1240px;

  margin: 48px auto 72px;

  padding: 0 32px;

  display: flex;

  align-items: flex-start;

  gap: 32px;

}



.profile-sidebar {

  width: 280px;

  flex-shrink: 0;

  display: flex;

  flex-direction: column;

  gap: 28px;

  padding: 28px 24px;

  border-radius: 24px;

  border: 1px solid var(--surface-border);

  background: linear-gradient(

      180deg,

      rgba(1, 159, 255, 0.12),

      rgba(1, 159, 255, 0.05)

    ),

    rgba(13, 18, 32, 0.92);

  box-shadow: 0 18px 40px rgba(2, 6, 23, 0.35);

  position: sticky;

  top: 32px;

  align-self: flex-start;

  max-height: calc(100vh - 64px);

  overflow-y: auto;

}



.sidebar-top {

  display: flex;

  gap: 14px;

  align-items: center;

}



.sidebar-brand img {

  width: 54px;

  height: 54px;

  border-radius: 16px;

  padding: 10px;

  background: var(--logo-bg);

  border: 1px solid var(--border);

  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.55);

}



.sidebar-user-meta {

  display: flex;

  flex-direction: column;

  gap: 4px;

}



.sidebar-label {

  font-size: 12px;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: rgba(245, 251, 255, 0.9);

}



.sidebar-user-meta h2 {

  margin: 0;

  font-size: 18px;

  font-weight: 600;

}



.sidebar-user-meta p {

  margin: 0;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}



.profile-nav {

  display: flex;

  flex-direction: column;

  gap: 6px;

}



.profile-nav-link {

  display: block;

  padding: 12px 18px;

  border-radius: 14px;

  border: 1px solid transparent;

  color: rgba(245, 251, 255, 0.9);

  text-decoration: none;

  font-weight: 500;

  transition: all 0.2s ease;

}



.profile-nav-link:hover {

  color: var(--text);

  background: rgba(1, 159, 255, 0.12);

}



.profile-nav-link.is-active {

  color: var(--text);

  background: linear-gradient(

    120deg,

    rgba(1, 159, 255, 0.28),

    rgba(1, 159, 255, 0.18)

  );

  border-color: rgba(1, 159, 255, 0.4);

  box-shadow: 0 0 0 1px rgba(1, 159, 255, 0.25);

}



.sidebar-actions {

  display: flex;

  flex-direction: column;

  gap: 12px;

}

 .sidebar-support {

  margin-top: 24px;

  padding: 18px 16px;

  border-radius: 18px;

  background: rgba(15, 23, 42, 0.7);

  border: 1px solid rgba(59, 130, 246, 0.18);

  display: grid;

  gap: 8px;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}



.sidebar-support h3 {

  margin: 0;

  font-size: 14px;

  color: var(--text);

}



.sidebar-support a {

  color: var(--accent);

  text-decoration: none;

}



.profile-content {

  flex: 1;

  display: flex;

  flex-direction: column;

  gap: 28px;

}



.profile-panels {

  position: relative;

  flex: 1 1 auto;

}



.profile-panel {

  display: none;

}



.profile-panel.is-active {

  display: block;

}



.profile-banner {

  display: flex;

  justify-content: space-between;

  align-items: stretch;

  gap: 24px;

  padding: 32px 36px;

  border-radius: 28px;

  border: 1px solid rgba(1, 159, 255, 0.25);

  background: radial-gradient(

      860px 320px at 10% 10%,

      rgba(1, 159, 255, 0.22),

      transparent 65%

    ),

    rgba(11, 16, 28, 0.92);

  box-shadow: 0 24px 50px rgba(2, 6, 23, 0.45);

}



.banner-copy h1 {

  margin: 0 0 8px;

  font-size: 26px;

  font-weight: 700;

}



.banner-copy p {

  margin: 0;

  color: rgba(245, 251, 255, 0.9);

  max-width: 460px;

  font-size: 15px;

}



.banner-user {

  display: flex;

  gap: 24px;

  align-items: center;

}



.banner-meta {

  display: flex;

  flex-direction: column;

  gap: 12px;

}



.banner-name {

  font-size: 22px;

  font-weight: 600;

}



.banner-meta dl {

  margin: 0;

  display: grid;

  gap: 10px 18px;

  grid-template-columns: repeat(2, minmax(0, 1fr));

}



.banner-meta dt {

  margin: 0;

  font-size: 12px;

  text-transform: uppercase;

  letter-spacing: 0.05em;

  color: rgba(245, 251, 255, 0.9);

}



.banner-meta dd {

  margin: 2px 0 0;

  font-size: 14px;

  color: var(--text);

}



.banner-avatar .profile-avatar {

  width: 120px;

  height: 120px;

}



.profile-avatar {

  width: 112px;

  height: 112px;

  border-radius: 999px;

  background: rgba(14, 22, 41, 0.75);

  border: 1px solid var(--surface-border);

  display: flex;

  align-items: center;

  justify-content: center;

  position: relative;

  color: var(--accent-strong);

  font-weight: 700;

  font-size: 28px;

  text-transform: uppercase;

  overflow: hidden;

}



.profile-avatar.large {

  width: 132px;

  height: 132px;

  font-size: 34px;

}



.profile-avatar img {

  width: 100%;

  height: 100%;

  object-fit: cover;

  display: none;

}



.profile-avatar.has-image img {

  display: block;

}



.profile-avatar.has-image .avatar-fallback {

  display: none;

}



.avatar-fallback {

  pointer-events: none;

}



.profile-card {

  padding: 32px 36px;

  border-radius: 24px;

  border: 1px solid rgba(58, 82, 120, 0.28);

  background: rgba(14, 22, 39, 0.92);

  box-shadow: 0 20px 44px rgba(2, 6, 23, 0.35);

}



.section-header {

  display: flex;

  align-items: flex-start;

  justify-content: space-between;

  gap: 18px;

  margin-bottom: 24px;

}



.section-header h2 {

  margin: 0;

  font-size: 22px;

  font-weight: 600;

}



.section-header p {

  margin: 6px 0 0;

  color: rgba(245, 251, 255, 0.9);

  font-size: 14px;

}



.section-actions {

  display: flex;

  flex-wrap: wrap;

  gap: 12px;

  margin-left: auto;

  justify-content: flex-end;

}

.section-actions.section-actions--stacked {

  flex-direction: column;

  align-items: flex-end;

}

.section-actions.section-actions--stacked button {

  width: auto;

  min-width: 180px;

}

.section-actions.section-actions--stacked button + button {

  margin-top: 6px;

}



.session-range-toggle {

  display: flex;

  flex-wrap: wrap;

  gap: 10px;

  margin-top: 10px;

}

.session-range-button {

  width: auto;

  padding: 0.6rem 1.3rem;

  border-radius: 18px;

  border: 1px solid var(--border);

  background: var(--card);

  color: var(--text-primary);

  font-size: 13px;

  font-weight: 600;

  line-height: 1.3;

  cursor: pointer;

  transition: transform 0.2s ease, filter 0.2s ease, border-color 0.2s ease,

    box-shadow 0.2s ease;

  box-shadow: var(--shadow-soft);
}

.session-range-button:hover {

  filter: brightness(1.05);

}

.session-range-button.is-active,
.session-range-button[aria-pressed="true"] {

  background: var(--accent-soft);

  border-color: var(--accent);

  color: var(--accent-strong);

  box-shadow: 0 0 0 1px rgba(1, 159, 255, 0.18), var(--shadow-soft);

}

.session-range-button:disabled {

  opacity: 0.55;

  cursor: not-allowed;

  box-shadow: none;

}
:root[data-theme="light"] .session-range-button {
  background: #ffffff;
  border-color: rgba(17, 24, 39, 0.08);
  color: var(--text-primary);
}




.summary-grid {

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));

  gap: 16px;

  margin-bottom: 20px;

}



.summary-card {

  padding: 16px 18px;

  border-radius: 18px;

  border: 1px solid var(--border);

  background: var(--card);

  box-shadow: var(--shadow-soft);

}



.summary-card dt {

  margin: 0 0 6px;

  font-size: 11px;

  text-transform: uppercase;

  letter-spacing: 0.06em;

  color: rgba(245, 251, 255, 0.9);

}



.summary-card dd {

  margin: 0;

  font-size: 18px;

  font-weight: 600;

}



.profile-table-wrap {

  overflow-x: auto;

  border-radius: 18px;

  border: 1px solid rgba(148, 163, 184, 0.12);

}



.session-table {

  width: 100%;

  border-collapse: collapse;

  min-width: 680px;

  background: rgba(10, 16, 28, 0.7);

}



.session-table thead {

  background: rgba(30, 41, 59, 0.85);

}



.session-table th,

.session-table td {

  padding: 14px 18px;

  text-align: left;

  font-size: 13px;

  border-bottom: 1px solid rgba(51, 65, 85, 0.6);

}



.session-table tbody tr:nth-child(odd) {

  background: var(--surface-muted);

}



.session-table tbody tr:hover {

  background: rgba(1, 159, 255, 0.14);

}



.preferences-grid {

  display: grid;

  gap: 18px;

}



.pref-item {

  display: flex;

  justify-content: space-between;

  gap: 18px;

  padding-bottom: 16px;

  border-bottom: 1px solid rgba(148, 163, 184, 0.1);

}



.pref-item:last-child {

  border-bottom: none;

  padding-bottom: 0;

}



.pref-item h3 {

  margin: 0 0 6px;

  font-size: 15px;

}



.pref-item p {

  margin: 0;

  color: rgba(245, 251, 255, 0.9);

  font-size: 13px;

}



.pref-toggle {

  position: relative;

  width: 50px;

  height: 28px;

}



.pref-toggle input {

  opacity: 0;

  width: 0;

  height: 0;

  position: absolute;

}



.pref-toggle .slider {

  position: absolute;

  cursor: pointer;

  inset: 0;

  border-radius: 999px;

  background: var(--pill-bg);

  border: 1px solid var(--border-strong);

  transition: all 0.2s ease;

}



.pref-toggle .slider::after {

  content: "";

  position: absolute;

  top: 3px;

  left: 3px;

  width: 20px;

  height: 20px;

  border-radius: 999px;

  background: var(--panel-soft);

  transition: transform 0.2s ease, background 0.2s ease;

}



.pref-toggle input:checked + .slider {

  background: var(--accent);

  border-color: var(--accent);

}



.pref-toggle input:checked + .slider::after {

  transform: translateX(22px);

  background: var(--panel-soft);

}



.section-lead {

  margin: 0 0 16px;

  color: rgba(245, 251, 255, 0.9);

  font-size: 14px;

}



.theme-options {

  display: flex;

  flex-wrap: wrap;

  gap: 12px;

}



.theme-options label {

  display: inline-flex;

  align-items: center;

  gap: 10px;

  padding: 10px 14px;

  border-radius: 14px;

  border: 1px solid rgba(148, 163, 184, 0.16);

  background: rgba(15, 23, 42, 0.5);

  cursor: pointer;

  font-size: 13px;

}



.theme-options input {

  width: auto;

}



.profile-avatar-actions {

  display: flex;

  flex-wrap: wrap;

  gap: 14px;

  align-items: center;

}



.profile-avatar-actions .btn-file {

  display: inline-flex;

  align-items: center;

  gap: 10px;

  padding: 10px 16px;

  border-radius: 14px;

  border: 1px solid rgba(148, 163, 184, 0.18);

  background: rgba(15, 23, 42, 0.65);

  color: var(--text);

  font-weight: 600;

  cursor: pointer;

}



.profile-avatar-actions .btn-file:hover {

  filter: brightness(1.1);

}



.profile-avatar-actions .btn-file.is-disabled {

  opacity: 0.6;

  cursor: not-allowed;

  pointer-events: none;

}



.profile-details {

  margin: 0;

  padding: 0;

  list-style: none;

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));

  gap: 16px 20px;

}



.profile-details dt {

  margin: 0 0 4px;

  font-size: 12px;

  letter-spacing: 0.05em;

  text-transform: uppercase;

  color: rgba(245, 251, 255, 0.9);

}



.profile-details dd {

  margin: 0;

  font-size: 14px;

  color: var(--text);

}

.personal-info-grid {

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));

  gap: 18px;

  max-width: 900px;

}

.personal-info-group {

  padding: 18px 20px;

  border-radius: 16px;

  border: 1px solid var(--border);

  background: rgba(9, 14, 24, 0.85);

}

.personal-info-group h3 {

  margin: 0 0 12px;

  font-size: 15px;

  font-weight: 600;

  color: var(--text);

}

.personal-info-group dl {

  margin: 0;

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));

  gap: 12px;

}

.personal-info-group dl div {

  display: flex;

  flex-direction: column;

  gap: 4px;

}

.personal-info-group dt {

  margin: 0;

  font-size: 11px;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: rgba(245, 251, 255, 0.9);

}

.personal-info-group dd {

  margin: 0;

  font-size: 15px;

  font-weight: 600;

  color: var(--text);

}

.profile-stats {

  display: flex;

  flex-direction: column;

  gap: 18px;

  margin: 12px 0 32px;

}

#statsContent.hidden {

  display: none;

}

.stats-layout {

  display: grid;

  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);

  gap: 20px;

}

@media (max-width: 1024px) {

  .stats-layout {

    grid-template-columns: 1fr;

  }

}

.stats-grid {

  display: grid;

  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));

  gap: 16px;

}

.stat-card {

  padding: 18px 20px;

  border-radius: 16px;

  border: 1px solid var(--border);

  background: rgba(8, 13, 23, 0.65);

}

.stat-title {

  margin: 0;

  font-size: 11px;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: rgba(245, 251, 255, 0.9);

}

.stat-value {

  margin: 6px 0 4px;

  font-size: 24px;

  font-weight: 600;

  color: var(--text);

}

.stat-meta {

  margin: 0;

  font-size: 12px;

  color: rgba(245, 251, 255, 0.9);

}

.stats-side {

  display: flex;

  flex-direction: column;

  gap: 18px;

}

.stats-section {

  padding: 18px 22px 22px;

  border-radius: 18px;

  border: 1px solid rgba(255, 255, 255, 0.08);

  background: rgba(7, 12, 22, 0.9);

  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.35);

  display: flex;

  flex-direction: column;

  gap: 16px;

}

.stats-section-header {

  display: flex;

  justify-content: space-between;

  align-items: baseline;

  gap: 12px;

}

.stats-section-header h3 {

  margin: 0;

  font-size: 15px;

  font-weight: 600;

}

.stats-section-header span {

  font-size: 12px;

  color: rgba(245, 251, 255, 0.9);

}

.stats-chart-bars {

  display: flex;

  align-items: flex-end;

  gap: 18px;

  min-height: 220px;

  width: 100%;

}

.chart-bar {

  flex: 1;

  min-width: 38px;

  display: flex;

  flex-direction: column;

  align-items: center;

  justify-content: flex-end;

  gap: 6px;

}

.chart-bar-track {

  width: 22px;

  flex: 1;

  background: rgba(255, 255, 255, 0.05);

  border-radius: 12px;

  border: 1px solid rgba(255, 255, 255, 0.08);

  display: flex;

  align-items: flex-end;

  padding: 2px;

}

.chart-bar-value {

  font-size: 11px;

  color: rgba(245, 251, 255, 0.9);

}

.chart-bar-fill {

  width: 100%;

  border-radius: 10px;

  background: linear-gradient(180deg, var(--accent), rgba(1, 159, 255, 0.2));

  box-shadow: 0 8px 18px rgba(1, 159, 255, 0.35);

  transition: height 0.3s ease;

  min-height: 6px;

}

.chart-bar-label {

  font-size: 11px;

  color: rgba(245, 251, 255, 0.9);

}

.stats-chart-empty {

  margin: 0;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}

.stats-top-list {

  list-style: none;

  margin: 0;

  padding: 0;

  display: flex;

  flex-direction: column;

  gap: 10px;

}

.stats-top-list li {

  display: flex;

  justify-content: space-between;

  align-items: center;

  gap: 12px;

  font-size: 14px;

  color: var(--text);

}

.stats-top-name {

  display: inline-flex;

  align-items: center;

  gap: 8px;

  font-weight: 500;

  word-break: break-word;

}

.stats-top-name::before {

  content: '';

  width: 6px;

  height: 6px;

  border-radius: 50%;

  background: var(--accent);

}

.stats-top-value {

  color: rgba(245, 251, 255, 0.9);

  font-size: 13px;

  text-align: right;

}

.stats-top-empty {

  justify-content: flex-start;

  color: rgba(245, 251, 255, 0.9);

  font-style: italic;

}

.stats-top-empty::before,
.stats-top-empty .stats-top-value {

  display: none;

}

.stats-top-empty::before {

  content: none;

}

.vehicle-gate-list {
  display: grid;
  gap: 14px;
}

.vehicle-select-buttons {
  display: grid;
  gap: 12px;
}

.vehicle-select-button {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(148, 163, 184, 0.24);
  background: linear-gradient(180deg, rgba(1, 159, 255, 0.14), rgba(1, 159, 255, 0.08));
  color: #f7f7f7;
  padding: 14px 16px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
}

.vehicle-select-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

.vehicle-select-button.is-active {
  border-color: rgba(1, 159, 255, 0.75);
  box-shadow: 0 10px 28px rgba(1, 159, 255, 0.25);
}

.vehicle-select-main {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.vehicle-color {
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: var(--vehicle-color, #60a5fa);
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.04);
  flex-shrink: 0;
}

.vehicle-select-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.vehicle-select-name {
  font-weight: 700;
  font-size: 16px;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vehicle-select-sub {
  color: rgba(236, 245, 255, 0.9);
  font-size: 0.95rem;
}

.vehicle-select-tag {
  padding: 6px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
  font-weight: 600;
  font-size: 0.95rem;
}

.vehicle-gate-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}



.vehicle-list {

  list-style: none;

  margin: 0;

  padding: 0;

  display: grid;

  gap: 14px;

}



.vehicle-item {

  padding: 14px 16px;

  border-radius: 14px;

  border: 1px solid rgba(148, 163, 184, 0.12);

  background: rgba(10, 16, 28, 0.75);

  display: grid;

  gap: 6px;

}



.vehicle-item h3 {

  margin: 0;

  font-size: 15px;

}



.vehicle-item span {

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}



.profile-empty {

  text-align: center;

  padding: 24px;

  border: 1px dashed rgba(148, 163, 184, 0.25);

  border-radius: 16px;

  color: rgba(245, 251, 255, 0.9);

}



.hint {

  margin-top: 10px;

  font-size: 13px;

  color: rgba(245, 251, 255, 0.9);

}



.hint.is-error {

  color: var(--danger);

}



.hint.is-success {

  color: var(--success);

}



.hint.is-info {

  color: var(--accent);

}



.profile-login-card {

  max-width: 420px;

  margin: 60px auto;

  padding: 36px;

  border-radius: 24px;

  border: 1px solid rgba(1, 159, 255, 0.3);

  background: linear-gradient(

      150deg,

      rgba(1, 159, 255, 0.2),

      rgba(2, 6, 23, 0.75)

    ),

    rgba(11, 16, 28, 0.9);

  text-align: center;

  display: grid;

  gap: 18px;

  box-shadow: 0 22px 48px rgba(2, 6, 23, 0.45);

}



.profile-login-card p {

  margin: 0;

  color: rgba(245, 251, 255, 0.9);

  font-size: 14px;

}



.profile-modal {

  border: 1px solid var(--surface-border);

  border-radius: 22px;

  background: rgba(11, 16, 28, 0.98);

  color: var(--text);

  padding: 26px;

  width: min(500px, calc(100vw - 44px));

  box-shadow: 0 24px 60px rgba(2, 6, 23, 0.45);

}



.profile-modal::backdrop {

  background: rgba(8, 11, 18, 0.65);

}



.profile-modal form {

  display: grid;

  gap: 14px;

}



.profile-modal footer {

  display: flex;

  justify-content: flex-end;

  gap: 12px;

}



.profile-modal .double {

  display: grid;

  grid-template-columns: repeat(2, minmax(0, 1fr));

  gap: 12px;

}



.profile-modal .hint {

  margin-top: 0;

}



@media (max-width: 1180px) {

  .profile-shell {

    flex-direction: column;

  }

  .profile-sidebar {

    width: 100%;

    flex-direction: row;

    flex-wrap: wrap;

    align-items: flex-start;

    position: static;

    max-height: none;

    overflow: visible;

  }

  .profile-nav {

    flex: 1 1 100%;

    order: 3;

    flex-direction: row;

    flex-wrap: wrap;

  }

  .profile-nav-link {

    flex: 1 1 220px;

  }

  .sidebar-support {

    order: 4;

    width: 100%;

  }

}



@media (max-width: 900px) {

  .profile-banner {

    flex-direction: column;

    align-items: flex-start;

  }

  .banner-user {

    width: 100%;

    justify-content: space-between;

  }

  .banner-meta dl {

    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));

  }

}



@media (max-width: 640px) {

  .profile-shell {

    padding: 0 18px;

  }

  .profile-banner {

    padding: 24px;

  }

  .profile-card {

    padding: 22px 20px;

  }

  .section-actions {

    width: 100%;

    margin-left: 0;

    justify-content: flex-start;

  }

  .section-actions.section-actions--stacked {

    align-items: stretch;

  }

  .section-actions button {

    flex: 1 1 auto;

  }

  .pref-item {

    flex-direction: column;

    align-items: flex-start;

  }

  .pref-toggle {

    align-self: flex-end;

  }

}


#btnToggleStats {
  padding: 0.6rem 1.3rem;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text-primary);
  box-shadow: var(--shadow-soft);
  transition: transform 0.2s ease, filter 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease;
}

#btnToggleStats:hover {
  filter: brightness(1.05);
}

#btnToggleStats[aria-pressed="true"] {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-strong);
  box-shadow: 0 0 0 1px rgba(1, 159, 255, 0.18), var(--shadow-soft);
}

#btnToggleStats:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

:root[data-theme="light"] #btnToggleStats {
  background: #ffffff;
  border-color: rgba(17, 24, 39, 0.08);
  color: var(--text-primary);
}
