﻿:root {
  --bg0: #070a12;
  --bg1: #0a1224;
  --txt: rgba(255, 255, 255, 0.92);
  --mut: rgba(255, 255, 255, 0.68);

  --glass: rgba(255, 255, 255, 0.07);
  --stroke: rgba(255, 255, 255, 0.12);

  --a1: #2b8cff; /* твой синий */
  --a2: #19e6ff; /* неон */
  --a3: #b86cff; /* фиолетовый */

  --shadow: 0 18px 60px rgba(0, 0, 0, 0.45);
  --r: 18px;
}

* {
  box-sizing: border-box;
}
html,
body {
  height: 100%;
}
body {
  margin: 0;
  font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--txt);
  background: radial-gradient(
      1100px 800px at 15% 0%,
      rgba(43, 140, 255, 0.12),
      transparent 55%
    ),
    radial-gradient(
      900px 700px at 92% 8%,
      rgba(25, 230, 255, 0.12),
      transparent 55%
    ),
    radial-gradient(
      900px 700px at 55% 110%,
      rgba(184, 108, 255, 0.1),
      transparent 55%
    ),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x: hidden;
}

/* bg */
.bg {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
}
.blob {
  position: absolute;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  filter: blur(52px);
  opacity: 0.75;
  mix-blend-mode: screen;
}
.b1 {
  left: -180px;
  top: -160px;
  background: radial-gradient(
    circle at 30% 30%,
    rgba(43, 140, 255, 0.6),
    transparent 55%
  );
}
.b2 {
  right: -200px;
  top: 40px;
  background: radial-gradient(
    circle at 50% 40%,
    rgba(25, 230, 255, 0.55),
    transparent 55%
  );
}
.b3 {
  left: 35%;
  bottom: -240px;
  background: radial-gradient(
    circle at 50% 50%,
    rgba(184, 108, 255, 0.48),
    transparent 60%
  );
}

.grid {
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
  background-size: 56px 56px;
  opacity: 0.22;
  mask-image: radial-gradient(
    ellipse at center,
    rgba(0, 0, 0, 0.9),
    transparent 70%
  );
}
.noise {
  position: absolute;
  inset: 0;
  opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
}

/* layout */
.wrap {
  width: min(1180px, 92vw);
  margin: 0 auto;
}
.page {
  padding: 20px 0 10px;
}

/* header */
.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(14px);
  background: linear-gradient(
    180deg,
    rgba(7, 10, 18, 0.65),
    rgba(7, 10, 18, 0.35)
  );
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.topbar__in {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 14px;
  position: relative;
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--txt);
}
.brand__logo {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  object-fit: cover;
}
.brand__name {
  font-weight: 800;
  letter-spacing: 0.3px;
}

.nav {
  display: flex;
  gap: 12px;
  align-items: center;
}
.nav__link {
  text-decoration: none;
  color: rgba(255, 255, 255, 0.78);
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
  transition: 0.18s ease;
}
.nav__link:hover {
  color: var(--txt);
  border-color: rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
}
.nav__link.is-active {
  color: var(--txt);
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}

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

/* buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  color: var(--txt);
  text-decoration: none;
  transition: 0.18s ease;
  font-weight: 700;
}
.btn:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.07);
}
.btn--sm {
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 14px;
}
.btn--ghost {
  background: rgba(255, 255, 255, 0.03);
}
.btn--accent {
  border-color: rgba(25, 230, 255, 0.25);
  background: linear-gradient(
    135deg,
    rgba(25, 230, 255, 0.16),
    rgba(43, 140, 255, 0.12)
  );
  box-shadow: 0 18px 60px rgba(25, 230, 255, 0.08);
}

.burger {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  cursor: pointer;
}
.burger span {
  display: block;
  height: 2px;
  width: 18px;
  margin: 4px auto;
  background: rgba(255, 255, 255, 0.85);
  border-radius: 2px;
}

/* mobile nav */
.mnav {
  position: absolute;
  right: 0;
  top: 64px;
  width: min(320px, 92vw);
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(10, 18, 36, 0.55);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow);
  display: none;
}
.mnav.is-open {
  display: block;
}
.mnav__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.mnav__title {
  font-weight: 800;
}
.mnav__close {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.06);
  color: var(--txt);
  cursor: pointer;
}
.mnav__link {
  display: block;
  padding: 12px 12px;
  border-radius: 14px;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.82);
  border: 1px solid transparent;
}
.mnav__link:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
  color: var(--txt);
}
.mnav__link.is-active {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.12);
}
.mnav__hr {
  height: 1px;
  background: rgba(255, 255, 255, 0.1);
  margin: 12px 0;
}

/* panels */
.panel {
  border-radius: var(--r);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.07),
    rgba(255, 255, 255, 0.05)
  );
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow);
  padding: 18px;
}

/* hero */
.hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 14px;
  margin: 10px 0 16px;
}
.tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  margin-bottom: 10px;
}
.tag__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--a2), var(--a1));
  box-shadow: 0 0 0 6px rgba(25, 230, 255, 0.08);
}
.h1 {
  font-size: 38px;
  line-height: 1.08;
  margin: 0 0 8px;
}
.lead {
  margin: 0;
  color: var(--mut);
  line-height: 1.6;
  max-width: 720px;
}
.hero__hint {
  max-width: 360px;
}
.hint__t {
  font-weight: 800;
  margin-bottom: 6px;
}
.hint__d {
  color: var(--mut);
  line-height: 1.55;
}

/* main layout */
.layout {
  display: grid;
  grid-template-columns: 1.45fr 0.55fr;
  gap: 14px;
  align-items: start;
}
.mapwrap {
  padding: 14px;
}
.maphead {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.maphead__t {
  font-weight: 900;
}
.maphead__s {
  color: var(--mut);
  font-size: 12px;
  margin-top: 2px;
}
.map {
  height: 640px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.side {
  padding: 14px;
}
.side__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.side__t {
  font-weight: 900;
}
.side__s {
  color: var(--mut);
  font-size: 12px;
  margin-top: 2px;
}
.side__hr {
  height: 1px;
  background: rgba(255, 255, 255, 0.1);
  margin: 12px 0;
}
.side__listHead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.route-panel {
  display: grid;
  gap: 12px;
}

.route-panel__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.route-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.route-status--idle {
  background: rgba(255, 255, 255, 0.05);
  color: rgba(255, 255, 255, 0.78);
}

.route-status--loading {
  background: rgba(25, 230, 255, 0.12);
  border-color: rgba(25, 230, 255, 0.24);
  color: #9ff6ff;
}

.route-status--ready {
  background: rgba(46, 204, 113, 0.12);
  border-color: rgba(46, 204, 113, 0.24);
  color: #89efae;
}

.route-status--trip {
  background: rgba(43, 140, 255, 0.14);
  border-color: rgba(43, 140, 255, 0.28);
  color: #98c9ff;
}

.route-status--error {
  background: rgba(255, 107, 107, 0.12);
  border-color: rgba(255, 107, 107, 0.25);
  color: #ffb4b4;
}

.route-panel__empty {
  padding: 12px;
  border-radius: 16px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.02);
  color: var(--mut);
  line-height: 1.55;
}

.route-panel__body {
  display: grid;
  gap: 10px;
}

.route-panel__title {
  font-weight: 900;
  line-height: 1.35;
}

.route-panel__meta,
.route-panel__info {
  color: var(--mut);
  line-height: 1.55;
  font-size: 13px;
}

.route-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.route-panel .btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.card.is-active {
  border-color: rgba(25, 230, 255, 0.35);
  background: rgba(25, 230, 255, 0.09);
  box-shadow: 0 10px 30px rgba(25, 230, 255, 0.08);
}

.map-pin {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(10, 18, 36, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.28);
  font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.map-pin__dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
}

.map-pin--start .map-pin__dot {
  background: #2ecc71;
  box-shadow: 0 0 0 6px rgba(46, 204, 113, 0.16);
}

.map-pin--finish .map-pin__dot {
  background: #ff6b6b;
  box-shadow: 0 0 0 6px rgba(255, 107, 107, 0.14);
}

.map-pin--trip .map-pin__dot {
  background: #19e6ff;
  box-shadow: 0 0 0 6px rgba(25, 230, 255, 0.14);
}
.badge {
  min-width: 34px;
  height: 26px;
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(25, 230, 255, 0.22);
  background: rgba(25, 230, 255, 0.08);
  font-weight: 800;
  font-size: 13px;
}

/* filters */
.filters {
  display: grid;
  gap: 10px;
}
.field {
  display: grid;
  gap: 6px;
}
.field__l {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.78);
  font-weight: 700;
}
.field__c {
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.18);
  color: var(--txt);
  outline: none;
}
.field__c:focus {
  border-color: rgba(25, 230, 255, 0.28);
  box-shadow: 0 0 0 4px rgba(25, 230, 255, 0.08);
}

/* list */
.list {
  display: grid;
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
}
.card {
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
  cursor: pointer;
  transition: 0.16s ease;
}
.card:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.05);
}
.card__top {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
}
.card__route {
  font-weight: 900;
}
.card__type {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  margin-top: 2px;
}
.card__price {
  font-weight: 900;
  color: rgba(46, 204, 113, 0.95);
  white-space: nowrap;
}
.card__meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
  color: var(--mut);
  font-size: 12px;
}
.pill2 {
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
}

.empty {
  padding: 12px;
  border-radius: 16px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.02);
}
.empty__t {
  font-weight: 900;
  margin-bottom: 4px;
}
.empty__d {
  color: var(--mut);
  line-height: 1.55;
}

/* footer */
.footer {
  margin-top: 22px;
  padding: 22px 0 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(7, 10, 18, 0.35);
  backdrop-filter: blur(14px);
}
.footer__in {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}
.footer__b {
  font-weight: 900;
  letter-spacing: 0.8px;
}
.footer__s {
  color: var(--mut);
  font-size: 13px;
  margin-top: 4px;
}
.footer__nav {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.footer__nav a {
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
}
.footer__nav a:hover {
  color: var(--txt);
}

/* responsive */
@media (max-width: 980px) {
  .nav {
    display: none;
  }
  .burger {
    display: inline-block;
  }
  .layout {
    grid-template-columns: 1fr;
  }
  .map {
    height: 520px;
  }
  .hero {
    flex-direction: column;
    align-items: flex-start;
  }
  .hero__hint {
    max-width: none;
    width: 100%;
  }
}
@media (max-width: 520px) {
  .h1 {
    font-size: 32px;
  }
}
.no-scroll {
  overflow: hidden;
}
