* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  background: #101014;
  color: #ffffff;
}

.app {
  max-width: 760px;
  margin: 0 auto;
  padding: 24px;
}

.hero {
  padding: 28px 0;
}

.badge {
  display: inline-block;
  padding: 8px 14px;
  border-radius: 999px;
  background: #ff2d2d;
  color: #ffffff;
  font-weight: bold;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
}

h1 {
  font-size: 42px;
  margin: 0;
}

.subtitle {
  color: #c8c8d0;
  font-size: 16px;
  line-height: 1.5;
}

.card {
  background: #1b1b23;
  border: 1px solid #2d2d38;
  border-radius: 18px;
  padding: 22px;
  margin-bottom: 18px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
}

.card h2 {
  margin-top: 0;
  margin-bottom: 18px;
}

label {
  display: block;
  margin-bottom: 14px;
  color: #d7d7df;
  font-weight: bold;
}

select,
input {
  width: 100%;
  margin-top: 7px;
  padding: 13px;
  border-radius: 12px;
  border: 1px solid #343442;
  background: #111118;
  color: #ffffff;
  font-size: 16px;
}

button {
  width: 100%;
  margin-top: 8px;
  padding: 15px;
  border: none;
  border-radius: 14px;
  background: #ff2d2d;
  color: #ffffff;
  font-size: 17px;
  font-weight: bold;
  cursor: pointer;
}

button:hover {
  background: #ff4949;
}

.result {
  border-color: #ff2d2d;
}

.result-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
}

.result-item {
  background: #111118;
  border: 1px solid #30303c;
  border-radius: 14px;
  padding: 14px;
}

.result-item span {
  display: block;
  color: #a9a9b5;
  font-size: 13px;
  margin-bottom: 4px;
}

.result-item strong {
  font-size: 18px;
}

.note {
  margin-top: 16px;
  padding: 14px;
  border-radius: 14px;
  background: rgba(255, 45, 45, 0.12);
  border: 1px solid rgba(255, 45, 45, 0.35);
  line-height: 1.5;
}

@media (max-width: 600px) {
  .app {
    padding: 16px;
  }

  h1 {
    font-size: 34px;
  }

  .result-grid {
    grid-template-columns: 1fr;
  }
}
textarea {
  width: 100%;
  min-height: 90px;
  margin-top: 7px;
  padding: 13px;
  border-radius: 12px;
  border: 1px solid #343442;
  background: #111118;
  color: #ffffff;
  font-size: 16px;
  font-family: Arial, Helvetica, sans-serif;
  resize: vertical;
}

.log-entry {
  background: #111118;
  border: 1px solid #30303c;
  border-radius: 14px;
  padding: 14px;
  margin-bottom: 12px;
}

.log-entry h3 {
  margin: 0 0 8px 0;
  font-size: 18px;
}

.log-entry p {
  margin: 6px 0;
  color: #d7d7df;
  line-height: 1.4;
}

.log-meta {
  color: #a9a9b5;
  font-size: 13px;
}
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.section-header h2 {
  margin: 0;
}

.small-button {
  width: auto;
  margin: 0;
  padding: 9px 12px;
  border-radius: 10px;
  font-size: 13px;
}

.danger {
  background: #7a1f1f;
}

.danger:hover {
  background: #a32929;
}

.log-actions {
  margin-top: 12px;
  display: flex;
  justify-content: flex-end;
}

.delete-button {
  width: auto;
  margin: 0;
  padding: 8px 11px;
  border-radius: 10px;
  font-size: 13px;
  background: #2d2d38;
}

.delete-button:hover {
  background: #444455;
}
.favorites-list {
  margin-top: 16px;
}

.favorite-entry {
  background: #111118;
  border: 1px solid #30303c;
  border-radius: 14px;
  padding: 14px;
  margin-bottom: 12px;
}

.favorite-entry h3 {
  margin: 0 0 8px 0;
  font-size: 18px;
}

.favorite-entry p {
  margin: 6px 0;
  color: #d7d7df;
  line-height: 1.4;
}

.favorite-badge {
  display: inline-block;
  margin-top: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 45, 45, 0.15);
  border: 1px solid rgba(255, 45, 45, 0.35);
  color: #ffffff;
  font-size: 13px;
}
.tabs {
  position: sticky;
  top: 0;
  z-index: 10;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  background: #101014;
  padding: 10px 0 14px;
  margin-bottom: 16px;
}

.tab-button {
  margin: 0;
  padding: 12px 10px;
  border-radius: 999px;
  background: #1b1b23;
  border: 1px solid #2d2d38;
  color: #c8c8d0;
  font-size: 14px;
}

.tab-button.active {
  background: #ff2d2d;
  color: #ffffff;
  border-color: #ff2d2d;
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

.pressure-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 600px) {
  .pressure-grid {
    grid-template-columns: 1fr;
  }
}

.import-label {
  display: block;
  margin-top: 14px;
  padding: 15px;
  border-radius: 14px;
  background: #2d2d38;
  color: #ffffff;
  text-align: center;
  cursor: pointer;
}

.import-label input {
  display: none;
}
body {
  padding-bottom: 84px;
}

.app-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;
  padding: 18px 22px;
  background: rgba(12, 14, 18, 0.96);
  border-bottom: 1px solid #24242e;
  backdrop-filter: blur(10px);
}

.logo-block {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  width: auto;
  max-width: max-content;
  padding: 0;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

.header-logo {
  height: 52px;
  width: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.65));
}
.header-title {
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: 1px;
  color: #ffffff;
  text-align: center;
}

.header-title strong {
  color: #ff2d2d;
}

.header-title {
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: 1px;
  color: #ffffff;
}

.header-title strong {
  color: #ff2d2d;
}

.menu-button {
  justify-self: end;
  width: auto;
  margin: 0;
  padding: 8px 12px;
  background: transparent;
  color: #ffffff;
  font-size: 26px;
  border: none;
}

.bottom-nav {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 30;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  background: rgba(12, 14, 18, 0.98);
  border-top: 1px solid #2d2d38;
  padding: 8px 8px 12px;
  backdrop-filter: blur(10px);
}

.bottom-nav-button {
  width: auto;
  margin: 0;
  padding: 8px 4px;
  border-radius: 12px;
  background: transparent;
  color: #a9a9b5;
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  align-items: center;
}

.bottom-nav-button span {
  font-size: 18px;
}

.bottom-nav-button.active {
  color: #ff2d2d;
  background: rgba(255, 45, 45, 0.08);
}

.gearbox-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.gearbox-control {
  background: #111118;
  border: 1px solid #30303c;
  border-radius: 14px;
  padding: 14px;
}

.gearbox-control span {
  display: block;
  color: #a9a9b5;
  font-size: 13px;
  margin-bottom: 10px;
}

.stepper {
  display: grid;
  grid-template-columns: 44px 1fr 44px;
  align-items: center;
  gap: 8px;
}

.stepper button {
  margin: 0;
  padding: 10px 0;
  border-radius: 12px;
  font-size: 20px;
}

.stepper strong {
  text-align: center;
  font-size: 28px;
}

.gear-result {
  margin-top: 16px;
  padding: 14px;
  border-radius: 14px;
  font-weight: bold;
  text-align: center;
}

.gear-result.valid {
  background: rgba(51, 180, 100, 0.12);
  border: 1px solid rgba(51, 180, 100, 0.35);
  color: #75e6a0;
}

.gear-result.invalid {
  background: rgba(255, 45, 45, 0.12);
  border: 1px solid rgba(255, 45, 45, 0.35);
  color: #ff8a8a;
}

@media (max-width: 600px) {
  .gearbox-grid {
    grid-template-columns: 1fr;
  }
}
.setup-preview {
  margin-bottom: 16px;
  padding: 14px;
  border-radius: 14px;
  background: rgba(255, 45, 45, 0.10);
  border: 1px solid rgba(255, 45, 45, 0.28);
}

.setup-preview p {
  margin: 0;
  color: #d7d7df;
  line-height: 1.5;
}

.setup-preview strong {
  color: #ffffff;
}
.track-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 18px;
}

.track-card {
  margin: 0;
  padding: 16px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
  color: #ffffff;
  text-align: left;
}

.track-card span {
  display: block;
  font-size: 17px;
  font-weight: 900;
  margin-bottom: 6px;
}

.track-card small {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  line-height: 1.3;
}

.track-card.active {
  background: rgba(255, 45, 45, 0.14);
  border-color: #ff2d2d;
  box-shadow: 0 0 0 1px rgba(255, 45, 45, 0.25);
}

@media (max-width: 600px) {
  .track-cards {
    grid-template-columns: 1fr;
  }
}

.form-section-title {
  margin: 18px 0 10px;
  color: #ff2d2d;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.compact-label {
  opacity: 0.72;
  font-size: 13px;
}

.compact-label select {
  font-size: 14px;
  padding: 11px;
}

.hidden-helper {
  display: none;
}

.weather-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.weather-card {
  margin: 0;
  padding: 14px 8px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
  color: #ffffff;
  font-size: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
}

.weather-card span {
  font-size: 24px;
}

.weather-card.active {
  background: rgba(255, 45, 45, 0.14);
  border-color: #ff2d2d;
  box-shadow: 0 0 0 1px rgba(255, 45, 45, 0.25);
}

.tire-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}

.tire-card {
  margin: 0;
  padding: 16px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
  color: #ffffff;
  text-align: center;
}

.tire-card span {
  display: block;
  font-size: 24px;
  font-weight: 900;
  margin-bottom: 4px;
}

.tire-card small {
  color: #a9a9b5;
  font-size: 12px;
}

.tire-card.active {
  background: rgba(255, 45, 45, 0.14);
  border-color: #ff2d2d;
  box-shadow: 0 0 0 1px rgba(255, 45, 45, 0.25);
}

.problem-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 14px;
}

.problem-card {
  margin: 0;
  padding: 14px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
  color: #ffffff;
  text-align: left;
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 4px 10px;
  align-items: center;
}

.problem-card span {
  grid-row: 1 / 3;
  font-size: 24px;
}

.problem-card strong {
  font-size: 15px;
}

.problem-card small {
  color: #a9a9b5;
  font-size: 12px;
}

.problem-card.active {
  background: rgba(255, 45, 45, 0.14);
  border-color: #ff2d2d;
  box-shadow: 0 0 0 1px rgba(255, 45, 45, 0.25);
}

@media (min-width: 720px) {
  .problem-cards {
    grid-template-columns: 1fr 1fr;
  }
}

.engine-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}

.engine-card {
  margin: 0;
  padding: 16px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
  color: #ffffff;
  text-align: center;
}

.engine-card span {
  display: block;
  font-size: 22px;
  font-weight: 900;
  margin-bottom: 4px;
}

.engine-card small {
  color: #a9a9b5;
  font-size: 12px;
}

.engine-card.active {
  background: rgba(255, 45, 45, 0.14);
  border-color: #ff2d2d;
  box-shadow: 0 0 0 1px rgba(255, 45, 45, 0.25);
}

.active-selection {
  margin-bottom: 16px;
  padding: 14px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
}

.active-selection span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.active-selection strong {
  display: block;
  color: #ffffff;
  font-size: 15px;
  line-height: 1.4;
}

.helper-text {
  margin: 10px 0 0;
  color: #a9a9b5;
  font-size: 13px;
  line-height: 1.4;
  text-align: center;
}

.setup-hero-card {
  margin-bottom: 14px;
  padding: 20px;
  border-radius: 18px;
  background: rgba(255, 45, 45, 0.14);
  border: 1px solid rgba(255, 45, 45, 0.38);
  text-align: center;
}

.setup-hero-card span {
  display: block;
  color: #c8c8d0;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 8px;
}

.setup-hero-card strong {
  display: block;
  color: #ffffff;
  font-size: 44px;
  line-height: 1;
  margin-bottom: 8px;
}

.setup-hero-card small {
  display: block;
  color: #d7d7df;
  font-size: 13px;
}

.setup-detail-list {
  display: grid;
  gap: 10px;
}

.setup-detail-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border-radius: 14px;
  background: #111118;
  border: 1px solid #30303c;
}

.setup-detail-row span {
  color: #a9a9b5;
  font-size: 13px;
}

.setup-detail-row strong {
  color: #ffffff;
  font-size: 14px;
  text-align: right;
}

@media (max-width: 600px) {
  .setup-detail-row {
    flex-direction: column;
    gap: 4px;
  }

  .setup-detail-row strong {
    text-align: left;
  }

  .setup-hero-card strong {
    font-size: 38px;
  }
}
.tire-pressure-card {
  padding: 16px;
  border-radius: 18px;
  background: #111118;
  border: 1px solid #30303c;
  margin-bottom: 16px;
}

.pressure-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.pressure-row label {
  margin: 0;
  text-align: center;
}

.pressure-row label span {
  display: block;
  color: #ff2d2d;
  font-weight: 900;
  margin-bottom: 6px;
}

.pressure-row input {
  text-align: center;
  font-size: 18px;
  font-weight: 800;
}

.kart-centerline {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  margin: 14px 0;
  color: #a9a9b5;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
}

.kart-centerline div {
  height: 1px;
  background: #30303c;
}
.version-box {
  margin-bottom: 16px;
  padding: 16px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
  text-align: center;
}

.version-box span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 6px;
}

.version-box strong {
  display: block;
  color: #ff2d2d;
  font-size: 28px;
  margin-bottom: 4px;
}

.version-box small {
  display: block;
  color: #d7d7df;
  font-size: 13px;
}
.tire-pressure-card {
  padding: 16px;
  border-radius: 18px;
  background: #111118;
  border: 1px solid #30303c;
  margin-bottom: 16px;
}

.pressure-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.pressure-row label {
  margin: 0;
  text-align: center;
}

.pressure-row label span {
  display: block;
  color: #ff2d2d;
  font-weight: 900;
  margin-bottom: 6px;
}

.pressure-row input {
  text-align: center;
  font-size: 18px;
  font-weight: 800;
}

.kart-centerline {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  margin: 14px 0;
  color: #a9a9b5;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
}

.kart-centerline div {
  height: 1px;
  background: #30303c;
}

.setup-input-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}

@media (max-width: 600px) {
  .setup-input-grid {
    grid-template-columns: 1fr;
  }
}

.log-card {
  padding: 16px;
  border-radius: 18px;
  background: #111118;
  border: 1px solid #30303c;
  margin-bottom: 16px;
}

.log-card-header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.log-card-header h3 {
  margin: 0 0 4px;
  color: #ffffff;
  font-size: 20px;
}

.log-card-header p {
  margin: 0;
  color: #a9a9b5;
  font-size: 13px;
}

.log-best-time {
  text-align: right;
  min-width: 110px;
}

.log-best-time span {
  display: block;
  color: #a9a9b5;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 4px;
}

.log-best-time strong {
  color: #ffffff;
  font-size: 18px;
}

.log-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.log-badges span {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 45, 45, 0.12);
  border: 1px solid rgba(255, 45, 45, 0.28);
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
}

.log-summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}

.log-summary-grid div {
  padding: 12px;
  border-radius: 14px;
  background: #181820;
  border: 1px solid #30303c;
}

.log-summary-grid span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 4px;
}

.log-summary-grid strong {
  display: block;
  color: #ffffff;
  font-size: 14px;
}

.log-detail-box,
.log-note-box {
  padding: 13px;
  border-radius: 14px;
  background: #181820;
  border: 1px solid #30303c;
  margin-bottom: 12px;
}

.log-detail-box p,
.log-note-box p {
  margin: 0 0 7px;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

.log-detail-box p:last-child,
.log-note-box p:last-child {
  margin-bottom: 0;
}

.log-note-box span {
  display: block;
  color: #ff2d2d;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 6px;
}

@media (max-width: 600px) {
  .log-card-header {
    flex-direction: column;
  }

  .log-best-time {
    text-align: left;
  }

  .log-summary-grid {
    grid-template-columns: 1fr;
  }
}

.compare-status {
  padding: 13px;
  border-radius: 14px;
  background: #111118;
  border: 1px solid #30303c;
  margin-bottom: 14px;
}

.compare-status p {
  margin: 0;
  color: #d7d7df;
}

.compare-card {
  padding: 16px;
  border-radius: 18px;
  background: #111118;
  border: 1px solid #30303c;
}

.compare-card h3 {
  margin: 0 0 14px;
  color: #ffffff;
}

.compare-header-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}

.compare-header-grid div {
  padding: 13px;
  border-radius: 14px;
  background: #181820;
  border: 1px solid #30303c;
}

.compare-header-grid span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 4px;
}

.compare-header-grid strong {
  display: block;
  color: #ffffff;
  font-size: 17px;
}

.compare-header-grid small {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-top: 4px;
}

.compare-table {
  display: grid;
  gap: 8px;
}

.compare-row {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 8px;
  align-items: center;
  padding: 10px;
  border-radius: 12px;
  background: #181820;
  border: 1px solid #30303c;
}

.compare-row.different {
  border-color: rgba(255, 45, 45, 0.45);
  background: rgba(255, 45, 45, 0.08);
}

.compare-row span {
  color: #a9a9b5;
  font-size: 12px;
}

.compare-row strong {
  color: #ffffff;
  font-size: 13px;
  word-break: break-word;
}

.compare-note {
  margin-top: 14px;
  padding: 13px;
  border-radius: 14px;
  background: #181820;
  border: 1px solid #30303c;
}

.compare-note span {
  display: block;
  color: #ff2d2d;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin: 10px 0 4px;
}

.compare-note span:first-child {
  margin-top: 0;
}

.compare-note p {
  margin: 0;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

@media (max-width: 600px) {
  .compare-header-grid {
    grid-template-columns: 1fr;
  }

  .compare-row {
    grid-template-columns: 1fr;
  }
}
.compare-good {
  color: #75e6a0 !important;
}

.compare-warning {
  color: #ffd36a !important;
}

.compare-bad {
  color: #ff8a8a !important;
}

.compare-analysis {
  margin-top: 14px;
  padding: 13px;
  border-radius: 14px;
  background: rgba(51, 180, 100, 0.10);
  border: 1px solid rgba(51, 180, 100, 0.28);
}

.compare-analysis span {
  display: block;
  color: #75e6a0;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 6px;
}

.compare-analysis p {
  margin: 0 0 6px;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

.compare-analysis p:last-child {
  margin-bottom: 0;
}

.compare-select-button.selected {
  background: rgba(51, 180, 100, 0.22);
  border: 1px solid rgba(51, 180, 100, 0.55);
  color: #75e6a0;
}

.compare-select-button.selected:hover {
  background: rgba(51, 180, 100, 0.32);
}

.setup-hero-card em {
  display: inline-block;
  margin-top: 8px;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #a9a9b5;
  font-size: 11px;
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.track-profile-box {
  margin-top: 14px;
  margin-bottom: 14px;
  padding: 14px;
  border-radius: 14px;
  background: #111118;
  border: 1px solid #30303c;
}

.track-profile-box span {
  display: block;
  color: #ff2d2d;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 6px;
}

.track-profile-box strong {
  display: block;
  color: #ffffff;
  font-size: 16px;
  margin-bottom: 6px;
}

.track-profile-box p {
  margin: 0 0 7px;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

.track-profile-box small {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 7px;
}

.track-profile-note {
  color: #ffd36a !important;
}

.weather-data-card {
  margin-bottom: 16px;
  padding: 14px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
}

.weather-data-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}

.weather-data-header span {
  color: #ff2d2d;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
}

.weather-data-header strong {
  color: #d7d7df;
  font-size: 13px;
}

.weather-data-card .setup-input-grid {
  margin-bottom: 0;
}

.weather-hint-box {
  margin-top: 14px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 211, 106, 0.10);
  border: 1px solid rgba(255, 211, 106, 0.28);
}

.weather-hint-box span {
  display: block;
  color: #ffd36a;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 7px;
}

.weather-hint-box p {
  margin: 0 0 7px;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

.weather-hint-box p:last-child {
  margin-bottom: 0;
}


.carb-hint-box {
  margin-top: 14px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(117, 230, 160, 0.10);
  border: 1px solid rgba(117, 230, 160, 0.28);
}

.carb-hint-box span {
  display: block;
  color: #75e6a0;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 7px;
}

.carb-hint-box p {
  margin: 0 0 7px;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

.carb-hint-box p:last-of-type {
  margin-bottom: 8px;
}

.carb-hint-box small {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  line-height: 1.4;
}


.next-test-box {
  margin-top: 14px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(120, 160, 255, 0.10);
  border: 1px solid rgba(120, 160, 255, 0.28);
}

.next-test-box span {
  display: block;
  color: #9bb7ff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 7px;
}

.next-test-box p {
  margin: 0 0 7px;
  color: #d7d7df;
  font-size: 13px;
  line-height: 1.45;
}

.next-test-box p:last-child {
  margin-bottom: 0;
}


.test-plan-card {
  margin-bottom: 16px;
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 45, 45, 0.10);
  border: 1px solid rgba(255, 45, 45, 0.35);
}

.test-plan-card > span,
.test-plan-section span,
.test-plan-focus span {
  display: block;
  color: #ff2d2d;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 8px;
}

.test-plan-card > strong {
  display: block;
  color: #ffffff;
  font-size: 18px;
  margin-bottom: 12px;
}

.test-plan-section {
  margin-top: 12px;
  padding: 12px;
  border-radius: 14px;
  background: #111118;
  border: 1px solid #30303c;
}

.test-plan-section p {
  margin: 6px 0;
  color: #d7d7df;
  line-height: 1.45;
}

.test-plan-focus {
  margin-top: 12px;
  padding: 14px;
  border-radius: 14px;
  background: rgba(51, 180, 100, 0.10);
  border: 1px solid rgba(51, 180, 100, 0.32);
}

.test-plan-focus p {
  margin: 0;
  color: #ffffff;
  line-height: 1.45;
  font-weight: 700;
}

.test-plan-card small {
  display: block;
  margin-top: 12px;
  color: #a9a9b5;
  line-height: 1.45;
}


.test-plan-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.test-plan-actions .small-button {
  margin: 0;
}

@media (max-width: 600px) {
  .test-plan-actions {
    width: 100%;
    justify-content: stretch;
  }

  .test-plan-actions .small-button {
    flex: 1 1 100%;
  }
}


.session-evaluation-card {
  margin-bottom: 16px;
  padding: 18px;
  border-radius: 18px;
  background: #111118;
  border: 1px solid #30303c;
}

.session-evaluation-card > span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
}

.session-evaluation-card > strong {
  display: block;
  color: #ffffff;
  font-size: 20px;
  margin-bottom: 8px;
}

.session-evaluation-card > p {
  margin: 0 0 12px;
  color: #d7d7df;
  line-height: 1.5;
}

.session-evaluation-good {
  border-color: rgba(51, 180, 100, 0.45);
  background: rgba(51, 180, 100, 0.08);
}

.session-evaluation-critical {
  border-color: rgba(255, 45, 45, 0.45);
  background: rgba(255, 45, 45, 0.08);
}

.session-evaluation-neutral {
  border-color: rgba(255, 255, 255, 0.14);
}

.session-evaluation-points {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  margin-bottom: 12px;
}

.session-evaluation-points p {
  margin: 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.05);
  color: #d7d7df;
  line-height: 1.45;
}



.personal-best-box {
  margin-top: 14px;
  padding: 14px;
  border-radius: 14px;
  background: rgba(51, 180, 100, 0.10);
  border: 1px solid rgba(51, 180, 100, 0.30);
}

.personal-best-box span {
  display: block;
  color: #75e6a0;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  margin-bottom: 6px;
}

.personal-best-box strong {
  display: block;
  color: #ffffff;
  font-size: 16px;
  margin-bottom: 6px;
}

.personal-best-box p {
  margin: 0;
  color: #d7d7df;
  line-height: 1.5;
}

.personal-best-new,
.personal-best-first {
  background: rgba(51, 180, 100, 0.14);
  border-color: rgba(51, 180, 100, 0.45);
}

.personal-best-missed {
  background: rgba(255, 255, 255, 0.05);
  border-color: #30303c;
}

.personal-best-equal {
  background: rgba(255, 190, 80, 0.10);
  border-color: rgba(255, 190, 80, 0.35);
}



.track-dashboard {
  display: grid;
  gap: 14px;
  margin-top: 16px;
}

.dashboard-empty {
  padding: 16px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
}

.dashboard-empty strong {
  display: block;
  margin-bottom: 8px;
  color: #ffffff;
}

.dashboard-empty p {
  margin: 0;
  color: #c8c8d0;
  line-height: 1.5;
}

.track-dashboard-card {
  padding: 16px;
  border-radius: 18px;
  background: #111118;
  border: 1px solid #30303c;
}

.track-dashboard-header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.track-dashboard-header span,
.dashboard-best-time span,
.dashboard-stat-grid span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 5px;
}

.track-dashboard-header strong {
  display: block;
  color: #ffffff;
  font-size: 22px;
  margin-bottom: 4px;
}

.track-dashboard-header small {
  display: block;
  color: #c8c8d0;
  line-height: 1.4;
}

.dashboard-best-time {
  min-width: 112px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(51, 180, 100, 0.12);
  border: 1px solid rgba(51, 180, 100, 0.35);
  text-align: right;
}

.dashboard-best-time strong {
  color: #75e6a0;
  font-size: 20px;
}

.dashboard-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 12px;
}

.dashboard-stat-grid div {
  padding: 12px;
  border-radius: 14px;
  background: #1b1b23;
  border: 1px solid #2d2d38;
}

.dashboard-stat-grid strong {
  display: block;
  color: #ffffff;
  font-size: 14px;
  line-height: 1.35;
}

.dashboard-detail-box {
  padding: 14px;
  border-radius: 14px;
  background: rgba(255, 45, 45, 0.08);
  border: 1px solid rgba(255, 45, 45, 0.24);
}

.dashboard-detail-box p {
  margin: 7px 0;
  color: #d7d7df;
  line-height: 1.45;
}

.dashboard-detail-box p:first-child {
  margin-top: 0;
}

.dashboard-detail-box p:last-child {
  margin-bottom: 0;
}

@media (max-width: 600px) {
  .track-dashboard-header {
    flex-direction: column;
  }

  .dashboard-best-time {
    width: 100%;
    text-align: left;
  }

  .dashboard-stat-grid {
    grid-template-columns: 1fr;
  }

  .bottom-nav-button {
    font-size: 11px;
  }
}


.dashboard-trend-box {
  margin-top: 14px;
  padding: 14px;
  border-radius: 14px;
  background: rgba(255, 45, 45, 0.10);
  border: 1px solid rgba(255, 45, 45, 0.28);
}

.dashboard-trend-box span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  margin-bottom: 5px;
}

.dashboard-trend-box strong {
  display: block;
  color: #ffffff;
  font-size: 16px;
  margin-bottom: 8px;
}

.dashboard-trend-box p {
  margin: 6px 0;
  color: #d7d7df;
  line-height: 1.45;
}

.dashboard-trend-times {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.dashboard-trend-times span {
  margin: 0;
  padding: 6px 9px;
  border-radius: 999px;
  background: #111118;
  border: 1px solid #30303c;
  color: #ffffff;
  font-size: 12px;
  text-transform: none;
  letter-spacing: 0;
}

.trend-improving,
.trend-improving-variable {
  background: rgba(51, 180, 100, 0.11);
  border-color: rgba(51, 180, 100, 0.34);
}

.trend-variable {
  background: rgba(255, 184, 77, 0.10);
  border-color: rgba(255, 184, 77, 0.32);
}

.trend-slower {
  background: rgba(255, 45, 45, 0.12);
  border-color: rgba(255, 45, 45, 0.36);
}


.profile-mini-card,
.profile-active-card,
.database-note-box {
  margin-bottom: 16px;
  padding: 14px;
  border-radius: 16px;
  background: #111118;
  border: 1px solid #30303c;
}

.profile-mini-card span,
.profile-active-card span,
.database-note-box span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.profile-mini-card strong,
.profile-active-card strong {
  display: block;
  color: #ffffff;
  font-size: 16px;
  line-height: 1.4;
}

.profile-mini-card small,
.profile-active-card small {
  display: block;
  color: #c8c8d0;
  font-size: 12px;
  line-height: 1.4;
  margin-top: 4px;
}

.profile-active-card {
  background: rgba(255, 45, 45, 0.10);
  border-color: rgba(255, 45, 45, 0.32);
}

.profile-storage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 16px 0;
}

.profile-storage-grid div {
  padding: 14px;
  border-radius: 14px;
  background: #111118;
  border: 1px solid #30303c;
}

.profile-storage-grid span {
  display: block;
  color: #a9a9b5;
  font-size: 12px;
  margin-bottom: 5px;
}

.profile-storage-grid strong {
  color: #ffffff;
  font-size: 18px;
}

.secondary-button {
  background: #2d2d38;
}

.secondary-button:hover {
  background: #444455;
}

.database-note-box {
  margin-top: 16px;
  line-height: 1.5;
  color: #d7d7df;
}

.database-note-box p {
  margin: 0;
}

@media (max-width: 600px) {
  .profile-storage-grid {
    grid-template-columns: 1fr;
  }

  .bottom-nav-button {
    font-size: 10px;
  }
}

.database-sync-status {
  margin: 14px 0;
  padding: 13px 14px;
  border-radius: 14px;
  background: #111118;
  border: 1px solid #30303c;
  color: #d7d7df;
  font-size: 14px;
  line-height: 1.4;
}

.database-sync-status.ok {
  background: rgba(51, 180, 100, 0.12);
  border-color: rgba(51, 180, 100, 0.35);
  color: #75e6a0;
}

.database-sync-status.error {
  background: rgba(255, 45, 45, 0.12);
  border-color: rgba(255, 45, 45, 0.35);
  color: #ff8a8a;
}

.database-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 10px 0 16px;
}

@media (max-width: 600px) {
  .database-action-row {
    grid-template-columns: 1fr;
  }
}

.compact-test-plan-card {
  margin-top: 12px;
  padding: 14px;
}

.compact-test-plan-card h3 {
  margin: 0;
  font-size: 16px;
}


.ai-context-preview {
  margin-top: 16px;
}

.ai-context-card {
  background: #111118;
  border: 1px solid #30303c;
  border-radius: 16px;
  padding: 16px;
}

.ai-context-summary-box {
  margin-top: 14px;
  margin-bottom: 14px;
}

.ai-context-json {
  margin-top: 14px;
  max-height: 320px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  background: #08080c;
  border: 1px solid #30303c;
  border-radius: 14px;
  padding: 14px;
  color: #d7d7df;
  font-size: 12px;
}
