/* ----- Reset ----- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; border: 0 solid var(--border); }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  background: var(--background);
  color: var(--foreground);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}
img, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; color: inherit; background: none; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 600; line-height: 1.15; }

/* ----- Utilities ----- */
.container { max-width: 1320px; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px) { .container { padding: 0 1.5rem; } .container-admin {  min-height: 212px;} }

.font-display { font-family: var(--font-display); }
.muted { color: var(--muted-foreground); }
.primary { color: var(--primary); }
.eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .25rem .75rem; border-radius: 9999px;
  font-size: 1rem; font-weight: 500;
  background: var(--primary-soft); color: var(--primary);
  border: 1px solid color-mix(in oklab, var(--primary) 10%, transparent);
}
.icon { width: 1rem; height: 1rem; flex-shrink: 0; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.icon-sm { width: .875rem; height: .875rem; }
.icon-xs { width: .75rem; height: .75rem; }
.icon-lg { width: 1.25rem; height: 1.25rem; }
.icon-xl { width: 1.5rem; height: 1.5rem; }

/* Anim — fade in on view.
   По умолчанию контент видим. Класс .js-reveal-ready ставится скриптом,
   только тогда применяется начальный opacity:0 — это страхует контент
   от исчезновения, если JS по какой-то причине не отработает. */
.reveal { opacity: 1; transform: none; transition: opacity .55s ease, transform .55s ease; }
.js-reveal-ready .reveal { opacity: 0; transform: translateY(16px); }
.js-reveal-ready .reveal.in { opacity: 1; transform: none; }

/* ============================================================
   PREHEADER
   ============================================================ */
.preheader {
  border-bottom: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  background: linear-gradient(90deg, oklch(0.95 0.05 350 / 0.65), oklch(0.96 0.06 85 / 0.6));
  color: color-mix(in oklab, var(--foreground) 90%, transparent);
}
.preheader-row { display: flex; align-items: center; gap: 1rem; min-height: 58px; }
.preheader-cell { display: flex; align-items: center; gap: .75rem; padding: .5rem 0; }
.preheader-cell + .preheader-cell { border-left: 1px solid color-mix(in oklab, var(--border) 50%, transparent); padding-left: 1rem; }
.preheader-icon {
  display: grid; place-items: center;
  width: 2.25rem; height: 2.25rem; border-radius: .5rem;
  background: var(--primary-soft); color: var(--primary); flex-shrink: 0;
}
.preheader-icon.brand { background: var(--gradient-brand); color: var(--primary-foreground); }
.preheader-icon.teal  { background: var(--accent-teal-soft); color: var(--accent-teal); }
.preheader-rotator { position: relative; height: 2.5rem; flex: 1; min-width: 0; overflow: hidden; }
.preheader-slide {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: center;
  line-height: 1.2; opacity: 0; transform: translateY(16px);
  transition: opacity .35s ease, transform .35s ease;
}
.preheader-slide.active { opacity: 1; transform: none; }
.preheader-slide.exit   { opacity: 0; transform: translateY(-16px); }
.preheader-line1 { font-size: .875rem; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.preheader-line2 { font-size: .75rem; color: var(--muted-foreground); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.preheader-phone { font-family: var(--font-display); font-weight: 600; font-size: 1rem; letter-spacing: -0.01em; transition: color .2s; }
.preheader-phone:hover { color: var(--primary); }
.preheader-hours-eyebrow { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted-foreground); }
.preheader-hours-value { font-size: .875rem; font-weight: 600; }

.preheader-mobile { display: none; padding: .5rem 0; align-items: center; gap: .5rem; font-size: .75rem; }
@media (max-width: 767px) {
  .preheader-row { display: none; }
  .preheader-mobile { display: flex; }
}
@media (min-width: 1024px) {
  .preheader-phone { font-size: 1.125rem; }
}

/* ============================================================
   HEADER
   ============================================================ */
.header {
  position: sticky; top: 0; z-index: 50; width: 100%;
  background: color-mix(in oklab, var(--background) 60%, transparent);
  backdrop-filter: blur(8px);
  transition: background .3s, box-shadow .3s, border-color .3s;
}
.header.scrolled {
  background: color-mix(in oklab, var(--background) 85%, transparent);
  backdrop-filter: blur(20px);
  box-shadow: 0 4px 20px -12px oklch(0.55 0.14 350 / 0.25);
  border-bottom: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
}

.header-utility { display: none; border-bottom: 1px solid color-mix(in oklab, var(--border) 50%, transparent); }
.header-utility-row { display: flex; align-items: center; height: 2.5rem; gap: 1.25rem; font-size: .75rem; color: var(--muted-foreground); }
.header-utility-row a { transition: color .2s; }
.header-utility-row a:hover { color: var(--primary); }
.header-utility-row a.accent { color: var(--primary); font-weight: 600; }
@media (min-width: 1024px) { .header-utility { display: block; } }

.header-main { display: flex; align-items: center; justify-content: space-between; height: 4rem; gap: 1.5rem; }
@media (min-width: 1024px) { .header-main { height: 5rem; } }

.header-logo { display: flex; align-items: center; flex-shrink: 0; }
.header-logo img { height: 2.5rem; width: auto; transition: transform .2s; }
.header-logo:hover img { transform: scale(1.02); }
@media (min-width: 1024px) { .header-logo img { height: 3.5rem; } }

.nav-desktop { display: none; align-items: center; gap: .25rem; }
@media (min-width: 1024px) { .nav-desktop { display: flex; } }
.nav-item { position: relative; }
.nav-link {
  display: inline-flex; align-items: center; gap: .25rem;
  padding: .5rem .75rem; border-radius: .5rem;
  font-size: .875rem; font-weight: 500; color: color-mix(in oklab, var(--foreground) 80%, transparent);
  transition: color .2s, background .2s;
}
.nav-link:hover, .nav-item.open .nav-link { color: var(--primary); background: var(--primary-soft); }
.nav-link.highlight { color: var(--primary); }
.nav-chevron { transition: transform .2s; }
.nav-item.open .nav-chevron { transform: rotate(180deg); }

.nav-submenu {
  position: absolute; left: 0; top: 100%; padding-top: .75rem; min-width: 280px; z-index: 50;
  opacity: 0; transform: translateY(8px); pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
.nav-item.open .nav-submenu { opacity: 1; transform: none; pointer-events: auto; }
.nav-submenu-inner {
  border-radius: 1rem; border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: color-mix(in oklab, var(--popover) 95%, transparent);
  backdrop-filter: blur(20px);
  padding: .5rem; box-shadow: var(--shadow-elegant);
}
.nav-submenu a {
  display: block; padding: .625rem .75rem; border-radius: .75rem;
  font-size: .875rem; color: var(--popover-foreground); transition: background .2s, color .2s;
}
.nav-submenu a:hover { background: var(--primary-soft); color: var(--primary); }

/* Mobile toggle */
.mobile-toggle {
  display: grid; place-items: center; width: 2.5rem; height: 2.5rem;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  border-radius: .75rem; transition: background .2s, color .2s;
}
.mobile-toggle:hover { background: var(--primary-soft); color: var(--primary); }
@media (min-width: 1024px) { .mobile-toggle { display: none; } }

/* Mobile drawer */
.mobile-overlay {
  position: fixed; inset: 0; z-index: 60;
  background: color-mix(in oklab, var(--foreground) 40%, transparent);
  backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none; transition: opacity .25s;
}
.mobile-drawer {
  position: fixed; inset-block: 0; right: 0; z-index: 61;
  width: 88%; max-width: 24rem;
  background: var(--background); border-left: 1px solid var(--border);
  box-shadow: var(--shadow-elegant);
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .25s ease;
}
body.menu-open .mobile-overlay { opacity: 1; pointer-events: auto; }
body.menu-open .mobile-drawer  { transform: none; }
body.menu-open { overflow: hidden; }
.mobile-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1rem; height: 4rem; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.mobile-drawer-header img { height: 2.25rem; }
.mobile-drawer-body { flex: 1; overflow-y: auto; padding: 1rem; }
.m-nav-item { border-bottom: 1px solid color-mix(in oklab, var(--border) 40%, transparent); }
.m-nav-item:last-child { border: 0; }
.m-nav-link, .m-nav-toggle {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: .75rem .5rem; font-size: 1rem; font-weight: 500; color: var(--foreground);
}
.m-nav-link.highlight, .m-nav-toggle.highlight { color: var(--primary); }
.m-nav-toggle .icon { transition: transform .2s; }
.m-nav-item.open .m-nav-toggle .icon { transform: rotate(180deg); }
.m-nav-children { display: none; padding: 0 0 .5rem .75rem; }
.m-nav-item.open .m-nav-children { display: block; }
.m-nav-children a {
  display: block; padding: .5rem; border-radius: .5rem;
  font-size: 1rem; font-weight: 500; color: var(--muted-foreground);
}
.m-nav-children a:hover { background: var(--primary-soft); color: var(--primary); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; overflow: hidden;
  border-bottom: 1px solid color-mix(in oklab, var(--border) 50%, transparent);
}
.hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(55% 45% at 85% 0%, oklch(0.62 0.24 350 / 0.14), transparent 60%),
    radial-gradient(45% 40% at 0% 30%, oklch(0.78 0.16 80 / 0.12), transparent 60%);
}
.hero-inner { padding: 3.5rem 0; }
@media (min-width: 1024px) { .hero-inner { padding: 5rem 0; } }
.breadcrumbs { display: flex; align-items: center; gap: .375rem; font-size: .75rem; color: var(--muted-foreground); }
.breadcrumbs a:hover { color: var(--primary); }
.hero h1 {
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  letter-spacing: -0.02em; line-height: 1.05; margin-top: 1.25rem;
}
.hero h1 .accent { color: var(--primary); }
.hero p {
  margin-top: 1.25rem; font-size: 1.125rem; color: var(--muted-foreground);
  max-width: 42rem; line-height: 1.65;
}

.hero-quick { margin-top: 2.5rem; display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .hero-quick { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .hero-quick { grid-template-columns: repeat(4, 1fr); } }
.hero-quick-card {
  height: 100%; border-radius: 1rem; padding: 1rem;
  background: color-mix(in oklab, var(--card) 70%, transparent);
  backdrop-filter: blur(6px);
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  transition: border-color .25s, box-shadow .25s;
}
.hero-quick-card:hover { border-color: color-mix(in oklab, var(--primary) 40%, transparent); box-shadow: var(--shadow-soft); }
.hero-quick-label {
  display: flex; align-items: center; gap: .5rem;
  font-size: .75rem; font-weight: 500; text-transform: uppercase; letter-spacing: .08em; color: var(--muted-foreground);
}
.hero-quick-label .icon { color: var(--primary); }
.hero-quick-value { margin-top: .5rem; font-size: 1rem; font-weight: 600; line-height: 1.3; }

/* ============================================================
   SECTIONS
   ============================================================ */
section { padding: 4rem 0; }
@media (min-width: 1024px) { section { padding: 6rem 0; } }
.section-alt { border-top: 1px solid color-mix(in oklab, var(--border) 50%, transparent); background: color-mix(in oklab, var(--secondary) 20%, transparent); }

.section-title { max-width: 49rem; scroll-margin-top: 7rem; }
.section-title h2 { font-size: clamp(1.875rem, 3.5vw, 2.5rem); letter-spacing: -0.02em; line-height: 1.1; margin-top: 1rem; text-align: left;}
.section-title p { margin-top: .75rem; font-size: 1.125rem; color: var(--muted-foreground); line-height: 1.65; }

/* ----- About + sticky aside ----- */
.about-grid { display: grid; gap: 2.5rem; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .about-grid { grid-template-columns: minmax(0,1fr) 360px; gap: 3.5rem; } }
.about-text { display: flex; flex-direction: column; gap: 1.25rem; margin-top: 2rem; font-size: 1rem; color: var(--muted-foreground); line-height: 1.7; text-align: justify;}

.about-aside .card {
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); border-radius: 1.5rem; padding: 1.5rem;
  box-shadow: var(--shadow-soft); position: sticky; top: 179px;
}
.about-aside dt { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted-foreground); }
.about-aside dd { margin-top: .25rem; font-size: .875rem; }
.about-aside dl > div + div { margin-top: 1rem; }
.about-aside .label { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--primary); font-weight: 600; }
.about-aside h3 { margin-top: .5rem; font-size: 1rem; font-weight: 600; line-height: 1.3; }
.about-aside dl { margin-top: 1.25rem; font-size: .875rem; }
.about-aside a:hover { color: var(--primary); }

/* ============================================================
   BRANCH CARDS
   ============================================================ */
.branches-grid { margin-top: 2.5rem; display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .branches-grid { grid-template-columns: repeat(2, 1fr); } }
.branch-card {
  position: relative; overflow: hidden;
  border-radius: 1.5rem; border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: color-mix(in oklab, var(--card) 80%, transparent);
  backdrop-filter: blur(6px);
  padding: 1.5rem; box-shadow: var(--shadow-soft);
  transition: box-shadow .3s;
}
@media (min-width: 640px) { .branch-card { padding: 1.75rem; } }
.branch-card:hover { box-shadow: var(--shadow-elegant); }
.branch-head { display: flex; align-items: flex-start; gap: .75rem; }
.branch-icon {
  display: grid; place-items: center; width: 2.75rem; height: 2.75rem;
  border-radius: 1rem; background: var(--primary-soft); color: var(--primary); flex-shrink: 0;
}
.branch-card h3 { font-size: 1.25rem; }
.branch-addr { margin-top: .25rem; display: flex; align-items: flex-start; gap: .375rem; font-size: .875rem; color: var(--muted-foreground); }
.branch-blocks { margin-top: 1.5rem; display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 640px) { .branch-blocks { grid-template-columns: repeat(2, 1fr); } }
.branch-block {
  border-radius: 1rem; border: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  background: color-mix(in oklab, var(--background) 60%, transparent);
  padding: 1rem;
}
.branch-block.paid {
  border-color: color-mix(in oklab, var(--accent-teal) 40%, transparent);
  background: color-mix(in oklab, var(--accent-teal-soft) 40%, transparent);
}
.branch-block-title {
  display: flex; align-items: center; gap: .5rem;
  font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--primary);
}
.branch-block.paid .branch-block-title { color: var(--accent-foreground); }
.branch-block ul { margin-top: .625rem; display: flex; flex-direction: column; gap: .375rem; }
.branch-block ul a { font-size: 1rem; font-weight: 500; transition: color .2s; }
.branch-block ul a:hover { color: var(--primary); }
.branch-block-hours { margin-top: .75rem; display: flex; align-items: flex-start; gap: .375rem; font-size: .75rem; color: var(--muted-foreground); }

/* ============================================================
   MAP
   ============================================================ */
.map-wrap {
  margin-top: 2.5rem; border-radius: 1.5rem; overflow: hidden;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  box-shadow: var(--shadow-soft);
}
.map-iframe { position: relative; aspect-ratio: 16/9; background: color-mix(in oklab, var(--secondary) 40%, transparent); }
@media (min-width: 640px) { .map-iframe { aspect-ratio: 21/9; } }
.map-iframe iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.map-pins { display: grid; grid-template-columns: 1fr; background: var(--card); }
@media (min-width: 640px) { .map-pins { grid-template-columns: repeat(3, 1fr); } }
.map-pin {
  display: flex; align-items: flex-start; gap: .75rem;
  padding: 1.25rem; transition: background .2s;
  border-top: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
}
@media (min-width: 640px) {
  .map-pin { border-top: 0; border-left: 1px solid color-mix(in oklab, var(--border) 60%, transparent); }
  .map-pin:first-child { border-left: 0; }
}
.map-pin:hover { background: color-mix(in oklab, var(--secondary) 40%, transparent); }
.map-pin-icon {
  display: grid; place-items: center; width: 2.5rem; height: 2.5rem;
  border-radius: .75rem; background: var(--primary-soft); color: var(--primary); flex-shrink: 0;
}
.map-pin-eyebrow { font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--primary); }
.map-pin-addr { margin-top: .25rem; font-size: .875rem; font-weight: 500; line-height: 1.3; }
.map-pin-cta { margin-top: .375rem; display: inline-flex; align-items: center; gap: .25rem; font-size: .75rem; color: var(--muted-foreground); transition: color .2s; }
.map-pin:hover .map-pin-cta { color: var(--primary); }

/* ============================================================
   ROUTE CARDS
   ============================================================ */
.routes-grid { margin-top: 2.5rem; display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .routes-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .routes-grid { grid-template-columns: repeat(3, 1fr); } }
.route-card {
  display: flex; flex-direction: column; overflow: hidden;
  border-radius: 1.5rem; border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); box-shadow: var(--shadow-soft); transition: box-shadow .3s;
}
.route-card:hover { box-shadow: var(--shadow-elegant); }
.route-image {
  position: relative; display: block; width: 100%;
  aspect-ratio: 4/3;
  background: color-mix(in oklab, var(--secondary) 30%, transparent); overflow: hidden;
  padding: 0; border: 0; margin: 0; text-align: left;
  cursor: pointer; font: inherit; color: inherit;
}
.route-image img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; transition: transform .5s;
}
.route-image:hover img { transform: scale(1.03); }
.route-badge {
  position: absolute; top: .75rem; left: .75rem;
  display: inline-flex; align-items: center; gap: .375rem;
  padding: .25rem .625rem; border-radius: 9999px;
  background: color-mix(in oklab, var(--card) 90%, transparent);
  backdrop-filter: blur(6px);
  font-size: 11px; font-weight: 600;
  border: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  box-shadow: 0 1px 2px rgb(0 0 0 / .04);
}
.route-badge .icon { color: var(--primary); }
.route-zoom-hint {
  position: absolute; bottom: .75rem; right: .75rem;
  display: inline-flex; align-items: center; gap: .375rem;
  padding: .375rem .625rem; border-radius: 9999px;
  background: color-mix(in oklab, var(--foreground) 85%, transparent);
  color: var(--background);
  font-size: 11px; font-weight: 600;
  border: 1px solid color-mix(in oklab, var(--foreground) 20%, transparent);
  box-shadow: 0 4px 12px rgb(0 0 0 / .15);
  opacity: 0; transition: opacity .2s;
}
.route-image:hover .route-zoom-hint,
.route-image:focus-visible .route-zoom-hint { opacity: 1; }

/* Route zoom modal */
#route-modal .modal {
  max-width: min(95vw, 1100px);
  padding: 0; overflow: hidden;
  background: var(--card);
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
}
.route-modal-image {
  width: 100%; max-height: 80vh; overflow: auto;
  background: color-mix(in oklab, var(--secondary) 30%, transparent);
}
.route-modal-image img { width: 100%; height: auto; display: block; object-fit: contain; }
.route-modal-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: .75rem; flex-wrap: wrap;
  padding: .875rem 1.25rem;
  border-top: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  background: var(--card);
}
.route-modal-title { font-weight: 600; font-size: .875rem; color: var(--foreground); }
.route-modal-addr { font-size: .75rem; color: var(--muted-foreground); margin-top: 2px; }
.route-modal-cta {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem .75rem; border-radius: .5rem;
  background: var(--primary-soft, color-mix(in oklab, var(--primary) 12%, transparent));
  color: var(--primary);
  font-size: .75rem; font-weight: 600;
  text-decoration: none; transition: all .2s;
}
.route-modal-cta:hover { background: var(--primary); color: var(--primary-foreground); }

.route-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.route-eyebrow { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--primary); font-weight: 600; }
.route-title { margin-top: .375rem; font-size: 1.125rem; font-weight: 600; line-height: 1.3; display: flex; align-items: flex-start; gap: .375rem; }
.route-title .icon { color: var(--primary); margin-top: .25rem; }
.route-metro { margin-top: .375rem; font-size: .875rem; color: var(--muted-foreground); }

.route-stops { margin-top: 1rem; display: flex; flex-direction: column; gap: .75rem; }
.route-stop {
  border-radius: 1rem;
  border: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  background: color-mix(in oklab, var(--secondary) 40%, transparent);
  padding: .75rem;
}
.route-stop-title {
  display: flex; align-items: center; gap: .375rem;
  font-size: .75rem; font-weight: 600;
  color: color-mix(in oklab, var(--foreground) 80%, transparent);
  margin-bottom: .5rem;
}
.route-stop-dot { display: inline-block; width: .375rem; height: .375rem; border-radius: 9999px; background: var(--primary); }
.route-line { display: flex; flex-wrap: wrap; align-items: flex-start; gap: .5rem; }
.route-line + .route-line { margin-top: .375rem; }
.route-line-label {
  display: inline-flex; align-items: center; gap: .25rem;
  font-size: 11px; font-weight: 600; color: var(--muted-foreground);
  flex-shrink: 0; padding-top: .125rem;
}
.route-chips { display: flex; flex-wrap: wrap; gap: .25rem; }
.route-chip {
  display: inline-flex; align-items: center;
  padding: .125rem .375rem; border-radius: .375rem;
  border: 1px solid; font-size: 11px; font-weight: 600;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
}
.route-chip.bus     { background: var(--primary-soft); color: var(--primary); border-color: color-mix(in oklab, var(--primary) 20%, transparent); }
.route-chip.tram    { background: var(--accent-teal-soft); color: var(--accent-foreground); border-color: color-mix(in oklab, var(--accent) 30%, transparent); }
.route-chip.trolley { background: var(--secondary); color: var(--secondary-foreground); border-color: var(--border); }
.route-chip.minibus { background: #fffbeb; color: #b45309; border-color: #fde68a; }

.route-cta {
  margin-top: 1rem;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .625rem 1rem; border-radius: .75rem;
  background: var(--primary-soft); color: var(--primary);
  font-size: .875rem; font-weight: 600; transition: background .2s, color .2s;
}
.route-cta:hover { background: var(--primary); color: var(--primary-foreground); }

/* ============================================================
   ADMIN CARDS + MODAL
   ============================================================ */
.admin-grid { margin-top: 2.5rem; display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .admin-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .admin-grid { grid-template-columns: repeat(3, 1fr); } }
.admin-card {
  display: flex; flex-direction: column; overflow: hidden;
  border-radius: 1.5rem; border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); box-shadow: var(--shadow-soft);
  transition: box-shadow .3s;
}
.admin-card:hover { box-shadow: var(--shadow-elegant); }
.admin-photo { position: relative; aspect-ratio: 4/5; overflow: hidden; background: color-mix(in oklab, var(--secondary) 40%, transparent); }
.admin-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; transition: transform .7s; }
.admin-card:hover .admin-photo img { transform: scale(1.03); }
.admin-photo::after {
  content: ""; position: absolute; inset-inline: 0; bottom: 0; height: 6rem;
  background: linear-gradient(to top, oklch(0.99 0.005 340 / 0.92), transparent);
}
.admin-experience {
  position: absolute; top: .75rem; left: .75rem;
  display: inline-flex; align-items: center;
  padding: .25rem .625rem; border-radius: 9999px;
  font-size: 11px; font-weight: 600;
  background: color-mix(in oklab, var(--background) 90%, transparent);
  color: var(--primary);
  border: 1px solid color-mix(in oklab, var(--primary) 15%, transparent);
  backdrop-filter: blur(6px);
}
.admin-body { flex: 1; display: flex; flex-direction: column; padding: 1.5rem; }
.admin-role { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--primary); font-weight: 600; }
.admin-name { margin-top: .375rem; font-size: 1.125rem; font-weight: 600; line-height: 1.2; }
.admin-note { margin-top: .75rem; font-size: .875rem; color: var(--muted-foreground); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.admin-meta { margin-top: 1.25rem; padding-top: 1rem; border-top: 1px solid color-mix(in oklab, var(--border) 60%, transparent); display: flex; flex-direction: column; gap: .5rem; font-size: .875rem; }
.admin-meta div { display: flex; align-items: flex-start; gap: .5rem; }
.admin-meta .icon { color: var(--primary); margin-top: .125rem; }
.admin-more {
  margin-top: 1.25rem;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .625rem 1rem; border-radius: .75rem;
  background: var(--primary-soft); color: var(--primary);
  font-size: .875rem; font-weight: 600; transition: background .2s, color .2s;
}
.admin-more:hover { background: var(--primary); color: var(--primary-foreground); }

/* Modal */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 100;
  display: none; place-items: center; padding: 1rem;
  background: color-mix(in oklab, var(--foreground) 40%, transparent);
  backdrop-filter: blur(4px);
}
.modal-backdrop.open { display: grid; }
.modal {
  position: relative; width: 100%; max-width: 48rem; max-height: 90vh; overflow: hidden;
  border-radius: 1.5rem; background: var(--background);
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  box-shadow: var(--shadow-elegant);
  display: flex; flex-direction: column;
  transform: translateY(20px) scale(.98); opacity: 0; transition: transform .25s, opacity .25s;
}
.modal-backdrop.open .modal { transform: none; opacity: 1; }
.modal-close {
  position: absolute; top: 1rem; right: 1rem; z-index: 10;
  display: grid; place-items: center; width: 2.25rem; height: 2.25rem; border-radius: 9999px;
  background: var(--secondary); color: var(--foreground);
  transition: background .2s, color .2s;
}
.modal-close:hover { background: var(--primary); color: var(--primary-foreground); }
.modal-scroll { overflow-y: auto; }
.modal-head {
  display: grid; grid-template-columns: 1fr; gap: 1.25rem;
  padding: 1.5rem; border-bottom: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  background: color-mix(in oklab, var(--secondary) 30%, transparent);
}
@media (min-width: 640px) { .modal-head { grid-template-columns: 200px 1fr; padding: 2rem; } }
.modal-photo { aspect-ratio: 4/5; max-height: 280px; border-radius: 1rem; overflow: hidden; background: var(--card); }
.modal-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.modal-head h2 { margin-top: .5rem; font-size: 1.5rem; line-height: 1.2; }
@media (min-width: 640px) { .modal-head h2 { font-size: 1.875rem; } }
.modal-body { padding: 1.5rem; display: flex; flex-direction: column; gap: 1.75rem; }
@media (min-width: 640px) { .modal-body { padding: 2rem; } }
.modal-section h3 { display: flex; align-items: center; gap: .5rem; font-size: 1rem; }
.modal-section ul { margin-top: .75rem; display: flex; flex-direction: column; gap: .375rem; font-size: .875rem; color: var(--muted-foreground); line-height: 1.6; }
.modal-section li { display: flex; gap: .5rem; }
.modal-section li::before { content: ""; flex-shrink: 0; width: .25rem; height: .25rem; border-radius: 9999px; background: var(--primary); margin-top: .375rem; }

/* ============================================================
   VIDEOS
   ============================================================ */
.videos-grid { margin-top: 2.5rem; display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .videos-grid { grid-template-columns: repeat(2, 1fr); } }
.video-card {
  border-radius: 1.5rem; overflow: hidden;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); box-shadow: var(--shadow-soft);
}
.video-frame { position: relative; aspect-ratio: 16/9; background: color-mix(in oklab, var(--foreground) 90%, transparent); }
.video-frame img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.video-frame button { position: absolute; inset: 0; width: 100%; height: 100%; }
.video-frame:hover img { transform: scale(1.04); }
.video-frame::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, oklch(0 0 0 / 0.55), oklch(0 0 0 / 0.1) 60%, transparent);
}
.video-play {
  position: absolute; inset: 0; display: grid; place-items: center;
  pointer-events: none;
}
.video-play span {
  display: grid; place-items: center; width: 4rem; height: 4rem; border-radius: 9999px;
  background: var(--gradient-brand); color: var(--primary-foreground);
  box-shadow: var(--shadow-elegant); transition: transform .3s;
}
@media (min-width: 640px) { .video-play span { width: 5rem; height: 5rem; } }
.video-frame:hover .video-play span { transform: scale(1.1); }
.video-play .icon { width: 1.75rem; height: 1.75rem; fill: currentColor; stroke: none; margin-left: .125rem; }
.video-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-cap { padding: 1.25rem; }
@media (min-width: 640px) { .video-cap { padding: 1.5rem; } }
.video-cap h3 { font-size: 1rem; line-height: 1.3; }
@media (min-width: 640px) { .video-cap h3 { font-size: 1.125rem; } }
.video-cap p { margin-top: .375rem; font-size: .875rem; color: var(--muted-foreground); line-height: 1.6; }

/* ============================================================
   LICENSE + REQUISITES
   ============================================================ */
.license-grid { display: grid; gap: 2.5rem; grid-template-columns: 1fr; }
@media (min-width: 1024px) { .license-grid { grid-template-columns: repeat(2, 1fr); } }
.license-card {
  margin-top: 2rem; border-radius: 1.5rem;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); padding: 1.5rem; box-shadow: var(--shadow-soft);
}
@media (min-width: 640px) { .license-card { padding: 1.75rem; } }
.license-head { display: flex; align-items: flex-start; gap: .75rem; }
.license-icon {
  display: grid; place-items: center; width: 2.75rem; height: 2.75rem;
  border-radius: 1rem; background: var(--accent-teal-soft); color: var(--accent-foreground); flex-shrink: 0;
}
.license-card h3 { font-size: 1.125rem; }
.license-card p.note { margin-top: .25rem; font-size: .875rem; color: var(--muted-foreground); }
.license-card p.body { margin-top: 1.25rem; font-size: .875rem; color: var(--muted-foreground); line-height: 1.65; }
.btn-primary {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .625rem 1rem; border-radius: .75rem;
  background: var(--primary); color: var(--primary-foreground);
  font-size: .875rem; font-weight: 500;
  box-shadow: var(--shadow-soft); transition: opacity .2s; margin-top: 1.5rem;
}
.btn-primary:hover { opacity: .9; }

.requisites {
  margin-top: 2rem; border-radius: 1.5rem;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); overflow: hidden; box-shadow: var(--shadow-soft);
}
.req-row {
  display: grid; gap: .5rem; grid-template-columns: 1fr;
  padding: 1rem 1.25rem;
  border-top: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
}
.req-row:first-child { border-top: 0; }
.req-row.alt { background: color-mix(in oklab, var(--secondary) 30%, transparent); }
@media (min-width: 640px) { .req-row { grid-template-columns: 200px 1fr; gap: 1.5rem; padding: 1rem 1.5rem; } }
.req-label { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted-foreground); font-weight: 600; padding-top: .125rem; }
.req-value { font-size: .875rem; line-height: 1.65; }
.req-link { display: inline-flex; align-items: center; gap: .25rem; color: var(--primary); font-weight: 500; }
.req-link:hover { text-decoration: underline; }

/* ============================================================
   SERVICES (accordion)
   ============================================================ */
.services-meta {
  display: flex; align-items: center; gap: .5rem;
  font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--primary);
}
.services-list { margin-top: 2.5rem; display: grid; gap: 1rem; }
.service-item {
  border-radius: 1rem; border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); overflow: hidden;
}
.service-toggle {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  width: 100%; padding: 1rem 1.25rem; text-align: left; transition: background .2s;
}
@media (min-width: 640px) { .service-toggle { padding: 1rem 1.5rem; } }
.service-toggle:hover { background: color-mix(in oklab, var(--secondary) 40%, transparent); }
.service-toggle-left { display: flex; align-items: flex-start; gap: .75rem; min-width: 0; }
.service-toggle-icon {
  display: grid; place-items: center; width: 2.25rem; height: 2.25rem; border-radius: .75rem;
  background: var(--primary-soft); color: var(--primary); flex-shrink: 0; margin-top: .125rem;
}
.service-toggle-title { font-family: var(--font-display); font-weight: 600; font-size: 1rem; line-height: 1.3; }
@media (min-width: 640px) { .service-toggle-title { font-size: 17px; } }
.service-toggle .icon-chevron { color: var(--muted-foreground); transition: transform .2s; flex-shrink: 0; width: 1.25rem; height: 1.25rem; }
.service-item.open .service-toggle .icon-chevron { transform: rotate(180deg); }
.service-content {
  display: none; padding: 0 1.25rem 1.25rem; padding-top: 1rem;
  border-top: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
  font-size: .875rem; color: var(--muted-foreground); line-height: 1.7;
}
@media (min-width: 640px) { .service-content { padding: 1rem 1.5rem 1.5rem; } }
.service-item.open .service-content { display: block; }

/* ============================================================
   LABOR SAFETY
   ============================================================ */
.labor-grid { margin-top: 2.5rem; display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .labor-grid { grid-template-columns: repeat(2, 1fr); } }
.labor-card {
  display: flex; align-items: flex-start; gap: 1rem;
  border-radius: 1.5rem; border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  background: var(--card); padding: 1.5rem;
  box-shadow: var(--shadow-soft); transition: box-shadow .3s, border-color .3s;
}
.labor-card:hover { box-shadow: var(--shadow-elegant); border-color: color-mix(in oklab, var(--primary) 40%, transparent); }
.labor-icon {
  display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 1rem;
  background: var(--accent-teal-soft); color: var(--accent-foreground); flex-shrink: 0;
  transition: transform .2s;
}
.labor-card:hover .labor-icon { transform: scale(1.05); }
.labor-year { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--primary); font-weight: 600; }
.labor-card h3 { margin-top: .375rem; font-size: 1rem; line-height: 1.3; }
.labor-cta { margin-top: .75rem; display: inline-flex; align-items: center; gap: .5rem; font-size: .875rem; color: var(--primary); font-weight: 500; }

/* ============================================================
   CTA
   ============================================================ */
.cta-section { padding-bottom: 5rem; }
.cta {
  position: relative; overflow: hidden;
  border-radius: 1.5rem; padding: 2rem;
  color: var(--primary-foreground); box-shadow: var(--shadow-elegant);
  background: var(--gradient-brand);
}
@media (min-width: 640px) { .cta { padding: 3rem; } }
.cta::before {
  content: ""; position: absolute; top: -6rem; right: -6rem;
  width: 18rem; height: 18rem; border-radius: 9999px;
  background: rgb(255 255 255 / 0.1); filter: blur(48px);
}
.cta-inner { position: relative; display: flex; flex-direction: column; gap: 1.5rem; }
@media (min-width: 1024px) { .cta-inner { flex-direction: row; align-items: center; justify-content: space-between; } }
.cta h2 { font-size: 1.875rem; letter-spacing: -0.02em; line-height: 1.15; }
@media (min-width: 640px) { .cta h2 { font-size: 2.25rem; } }
.cta p { margin-top: .75rem; font-size: 1rem; color: rgb(255 255 255 / 0.9); line-height: 1.65; }
@media (min-width: 640px) { .cta p { font-size: 1.125rem; } }
.cta-actions { display: flex; flex-wrap: wrap; gap: .75rem; flex-shrink: 0; }
.cta-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.25rem; border-radius: .75rem;
  font-size: .875rem; font-weight: 600; transition: background .2s, color .2s;
}
.cta-btn.solid { background: var(--background); color: var(--foreground); }
.cta-btn.solid:hover { background: color-mix(in oklab, var(--background) 90%, transparent); }
.cta-btn.outline { border: 1px solid rgb(255 255 255 / 0.3); color: var(--primary-foreground); }
.cta-btn.outline:hover { background: rgb(255 255 255 / 0.1); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  position: relative; border-top: 1px solid var(--border);
  background: var(--footer-bg);
}
.footer::before {
  content: ""; position: absolute; inset-inline: 0; top: 0; height: 3px; opacity: .65;
  background: linear-gradient(90deg, var(--primary) 0%, oklch(0.78 0.13 50) 50%, var(--accent-teal) 100%);
}
.footer-inner { padding: 4rem 0 1.75rem; }
.footer-grid { display: grid; grid-template-columns: repeat(12, 1fr); row-gap: 2.5rem; column-gap: 1.5rem; }
@media (min-width: 1024px) { .footer-grid { column-gap: 2rem; } }
.footer-col-brand { grid-column: span 12; }
.footer-col-help, .footer-col-info { grid-column: span 6; }
.footer-col-services { grid-column: span 6; }
.footer-col-journal { grid-column: span 6; }
@media (min-width: 1024px) {
  .footer-col-brand    { grid-column: span 4; }
  .footer-col-help     { grid-column: span 2; }
  .footer-col-services { grid-column: span 3; }
  .footer-col-info     { grid-column: span 2; }
  .footer-col-journal  { grid-column: span 1; }
}
.footer-logo { display: inline-flex; margin-bottom: 1.5rem; transition: transform .2s; }
.footer-logo img { height: 4rem; width: auto; }
@media (min-width: 1024px) { .footer-logo img { height: 5rem; } }
.footer-logo:hover { transform: scale(1.02); }
.footer-addresses { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 1.5rem; }
.footer-addresses li { display: flex; align-items: flex-start; gap: .75rem; }
.footer-address-icon {
  display: grid; place-items: center; width: 2.25rem; height: 2.25rem; border-radius: .5rem;
  background: var(--primary-soft); color: var(--primary); flex-shrink: 0; margin-top: .125rem;
}
.footer-address-line { font-size: 14.5px; font-weight: 600; }
.footer-address-meta { font-size: 12.5px; color: var(--muted-foreground); margin-top: .125rem; display: block; }
.footer-social { display: flex; gap: .625rem; }
.footer-social a {
  display: grid; place-items: center; width: 2.5rem; height: 2.5rem; border-radius: .5rem;
  background: var(--card); border: 1px solid var(--border); color: var(--muted-foreground);
  transition: color .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.footer-social a:hover { color: var(--primary); border-color: color-mix(in oklab, var(--primary) 50%, transparent); transform: translateY(-2px); box-shadow: var(--shadow-soft); }
.footer-heading {
  font-family: var(--font-display); font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; color: var(--muted-foreground);
  padding-bottom: .625rem; margin-bottom: 1rem; border-bottom: 1px solid var(--border);
}
.footer-list { display: flex; flex-direction: column; gap: .625rem; }
.footer-list a {
  display: inline-flex; align-items: center; font-size: .875rem;
  transition: color .2s, transform .2s;
}
.footer-list a:hover { color: var(--primary); transform: translateX(4px); }
.footer-bottom {
  margin-top: 3rem; padding-top: 1.25rem;
  border-top: 1px solid var(--border);
  display: grid; grid-template-columns: repeat(12, 1fr); column-gap: 1.5rem; row-gap: .75rem; align-items: center;
}
.footer-legal {
  grid-column: span 12; display: flex; flex-wrap: wrap; align-items: center;
  column-gap: .5rem; row-gap: .25rem; font-size: 13px; color: var(--muted-foreground);
}
.footer-legal .sep { color: var(--border); }
.footer-policy { grid-column: span 12; display: flex; flex-wrap: wrap; column-gap: 1.25rem; row-gap: .5rem; }
.footer-policy a { font-size: 13px; color: var(--muted-foreground); transition: color .2s; }
.footer-policy a:hover { color: var(--primary); }
@media (min-width: 1024px) {
  .footer-legal { grid-column: span 7; }
  .footer-policy { grid-column: span 5; justify-content: flex-end; }
}

/* ---------- МОДАЛКИ ---------- */

/* Подложка (фон затемнения) */
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;                /* по умолчанию скрыта */
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(30, 15, 25, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  overflow-y: auto;
  animation: modalFadeIn 0.25s ease-out;
}

/* Открытое состояние — добавляется JS-ом через classList.add('is-open') 
   ИЛИ если вы переключаете display напрямую — оставьте как есть */
.modal-backdrop.is-open {
  display: flex;
}

/* Если ваш JS просто ставит style.display = 'flex' — этот блок не нужен,
   но на всякий случай: */
.modal-backdrop[style*="display: flex"] {
  display: flex !important;
}

/* Карточка модалки */
.modal-card {
  position: relative;
  width: 100%;
  max-width: 880px;
  max-height: 90vh;
  overflow-y: auto;
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 25px 60px -15px rgba(180, 30, 90, 0.35);
  animation: modalSlideUp 0.3s ease-out;
}

/* Кнопка закрытия */
.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 10;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: none;
  border-radius: 50%;
  background: #f4eaef;
  color: #2a1822;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, transform 0.2s;
}
.modal-close:hover {
  background: #c2185b;
  color: #fff;
  transform: rotate(90deg);
}

/* ----- Контент модалки администратора ----- */
.modal-admin-header {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 24px;
  padding: 32px;
  border-bottom: 1px solid #f0e4ea;
  background: #faf5f8;
}
.modal-admin-photo {
  width: 100%;
  aspect-ratio: 4/5;
  max-height: 280px;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}
.modal-admin-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
.modal-admin-role {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  color: #c2185b;
}
.modal-admin-name {
  margin: 8px 0 12px;
  font-family: "Manrope", sans-serif;
  font-size: 28px;
  font-weight: 600;
  line-height: 1.2;
  color: #2a1822;
}
.modal-admin-note {
  font-size: 14px;
  line-height: 1.6;
  color: #6b5560;
  margin-bottom: 16px;
}
.modal-admin-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 14px;
}
.modal-admin-meta a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}
.modal-admin-meta a:hover {
  color: #c2185b;
}

.modal-admin-body {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.modal-admin-body h3 {
  font-family: "Manrope", sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: #2a1822;
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.modal-admin-body ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.modal-admin-body li {
  position: relative;
  padding-left: 16px;
  font-size: 14px;
  line-height: 1.6;
  color: #6b5560;
}
.modal-admin-body li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #c2185b;
}

/* ----- Модалка с маршрутом (зум схемы) ----- */
.modal-route-image {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
}

/* ----- Анимации ----- */
@keyframes modalFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes modalSlideUp {
  from { opacity: 0; transform: translateY(20px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Блокировка прокрутки body когда модалка открыта */
body.modal-open {
  overflow: hidden;
}

/* ----- Адаптив ----- */
@media (max-width: 640px) {
  .modal-card {
    border-radius: 18px;
    max-height: 95vh;
  }
  .modal-admin-header {
    grid-template-columns: 1fr;
    padding: 20px;
    gap: 16px;
  }
  .modal-admin-photo {
    max-width: 200px;
    margin: 0 auto;
  }
  .modal-admin-body {
    padding: 20px;
  }
  .modal-admin-name {
    font-size: 22px;
  }
  .modal-close {
    top: 10px;
    right: 10px;
  }
}
