/* ===== Page 2 (Harita) — base ===== */
.ha-section { padding: 68px 0; position: relative; }
.ha-wrap { width: min(1120px, 92vw); margin: 0 auto; }

/* ===== Bölüm 1: Katman Halkası ===== */
.ha-layers__grid{
  display: grid; gap: 22px;
  grid-template-columns: 1fr;
}
.ha-layers__copy h2{
  font-size: clamp(26px, 3.2vw, 38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(108,59,255,.35);
}
.ha-layers__stage{
  position: relative;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  min-height: 360px;
  overflow: hidden;
}
.ring{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  filter: drop-shadow(0 12px 28px rgba(108,59,255,.25));
}
.pin{
  position: absolute; width: 12px; height: 12px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #fff, var(--atlas-orange));
  box-shadow: 0 0 20px var(--atlas-orange);
  animation: pinPulse 1.8s ease-in-out infinite;
}
.pin--baku{ left: 28%; top: 42%; }
.pin--sumgait{ right: 22%; top: 58%; animation-delay: .4s; }
@keyframes pinPulse{
  0%,100%{ transform: scale(1); opacity: 1; }
  50%{ transform: scale(1.35); opacity: .85; }
}

/* sahne kartları — harita halkasına bağlanan görseller */
.stage-card{
  position: absolute;
  width: min(340px, 85vw);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border); border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .25s ease, box-shadow .25s ease, filter .2s ease;
}
.stage-card:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.stage-card figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }

.stage-card--baku{ left: 6%; bottom: 10%; }
.stage-card--sumgait{ right: 6%; top: 10%; }

@media (max-width: 900px){
  .ha-layers__grid{ grid-template-columns: 1fr; }
  .ha-layers__stage{ min-height: 420px; }
  .stage-card--baku{ left: 50%; transform: translateX(-50%); bottom: 8%; }
  .stage-card--sumgait{ left: 50%; transform: translateX(-50%); top: 8%; }
}

/* ===== Bölüm 2: Rota İzi ===== */
.ha-path__head h2{
  font-size: clamp(26px, 3.2vw, 38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(17,199,112,.30);
}
.ha-path__track{
  position: relative;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  min-height: 320px; overflow: hidden;
}
.path-svg{ position: absolute; inset: 0; width: 100%; height: 100%; }
.route{
  fill: none; stroke: rgba(255,255,255,.20); stroke-width: 3.5; stroke-linecap: round;
  stroke-dasharray: 1000; stroke-dashoffset: 1000;
  filter: drop-shadow(0 8px 18px rgba(17,199,112,.25));
  transition: stroke-dashoffset 1.6s cubic-bezier(.2,.8,.2,1);
}

/* düğüm görsel kartları */
.node{
  position: absolute;
  width: min(340px, 85vw);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border); border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .25s ease, box-shadow .25s ease, filter .2s ease;
}
.node:hover{ transform: translateY(-4px); filter: saturate(1.08); box-shadow: var(--shadow-float); }
.node figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }

.node--a{ left: 6%; top: 14%; }
.node--b{ right: 6%; bottom: 10%; }

@media (max-width: 900px){
  .node--a{ left: 50%; transform: translateX(-50%); top: 8%; }
  .node--b{ left: 50%; transform: translateX(-50%); bottom: 8%; }
}

/* ===== Bölüm 3: Panorama Karşılaştırma ===== */
.ha-compare__head h2{
  font-size: clamp(26px, 3.2vw, 38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(255,122,26,.30);
}
.compare-stage{
  position: relative;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow: hidden; min-height: 260px;
}
.cmp{ position: absolute; inset: 0; }
.cmp img{ width: 100%; height: 100%; object-fit: cover; max-width: none; }

/* маска — по умолчанию наполовину слева */
.cmp--right{ clip-path: polygon(50% 0, 100% 0, 100% 100%, 50% 100%); }
.compare-line{
  position: absolute; top: 0; bottom: 0; left: 50%;
  width: 2px; background: linear-gradient(180deg, var(--atlas-violet), var(--atlas-green));
  box-shadow: 0 0 22px rgba(108,59,255,.35);
  pointer-events: none;
}

/* адаптив: небольшой отступ по высоте */
@media (max-width: 720px){
  .compare-stage{ min-height: 220px; }
}
/* ===== 4) Şehir Hubı ===== */
.ha-hub__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(108,59,255,.32);
}
.hub-stage{
  position: relative;
  min-height: 400px;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow: hidden;
}
.hub-ring{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
.hub-dash{
  fill: none;
  stroke: rgba(255,255,255,.18);
  stroke-width: 2.5;
  stroke-dasharray: 8 10;
}
.hub-pulse{
  position:absolute; left:50%; top:50%;
  width:18px; height:18px; border-radius:50%;
  transform: translate(-50%,-50%);
  background: radial-gradient(circle at 35% 35%, #fff, var(--atlas-orange));
  box-shadow: 0 0 28px var(--atlas-orange);
  animation: hubPulse 1.8s ease-in-out infinite;
}
@keyframes hubPulse{
  0%,100%{ transform: translate(-50%,-50%) scale(1); opacity:1; }
  50%{ transform: translate(-50%,-50%) scale(1.35); opacity:.85; }
}
.hub-card{
  position:absolute; width:min(340px,85vw);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--atlas-border); border-radius:18px; padding:10px;
  box-shadow: var(--shadow-soft);
  transition: transform .25s ease, box-shadow .25s ease, filter .2s ease;
}
.hub-card:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.hub-card figcaption{ margin-top:6px; color:var(--atlas-dim); font-size:14px; }
.hub-card--nw{ left:6%;  top:8%;  }
.hub-card--ne{ right:6%; top:10%; }
.hub-card--s { left:50%; bottom:6%; transform: translateX(-50%); }
@media (max-width: 900px){
  .hub-stage{ min-height: 520px; }
  .hub-card--nw{ left:50%; top:8%; transform: translateX(-50%); }
  .hub-card--ne{ left:50%; top:38%; transform: translateX(-50%); }
  .hub-card--s { left:50%; bottom:8%; transform: translateX(-50%); }
}

/* ===== 5) Mahalle Yürüyüşü (serpentine) ===== */
.ha-serp__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(17,199,112,.30);
}
.serp-line{
  position: relative; height: 10px; margin: 10px 0 22px;
  background: linear-gradient(90deg, var(--atlas-violet), var(--atlas-green));
  box-shadow: 0 8px 22px rgba(108,59,255,.25);
  border-radius: 999px;
}
.serp-grid{
  display: grid; gap: 16px;
}
.serp-card{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border);
  border-radius: 18px; padding: 12px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
  max-width: 680px;
}
.serp-card:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.serp-card--left { margin-left: 0; margin-right: auto; }
.serp-card--right{ margin-left: auto; margin-right: 0; }
.serp-card p{ margin: 6px 0 0; color: var(--atlas-dim); }

@media (max-width: 820px){
  .serp-card--left, .serp-card--right{ margin: 0; }
}

/* ===== 6) Ulaşım Katmanı ===== */
.ha-transit__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(255,122,26,.30);
}
.transit-track{
  position: relative;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  padding: 22px 14px 18px;
}
.transit-track::before{
  content:""; position:absolute; left: 14px; right: 14px; top: 48px;
  height: 4px; border-radius: 4px;
  background: linear-gradient(90deg, var(--atlas-violet), var(--atlas-green));
  box-shadow: 0 8px 22px rgba(108,59,255,.25);
}
.transit-track .stop{
  display: grid; justify-items: center;
}
.transit-track .stop + .stop{ margin-top: 24px; }
.stop-dot{
  width: 16px; height: 16px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #fff, var(--atlas-orange));
  box-shadow: 0 0 22px var(--atlas-orange);
  translate: 0 -6px;
}
.transit-track figure{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border); border-radius: 16px;
  padding: 10px; width: min(340px, 90%);
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
}
.transit-track figure:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.transit-track figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }

/* более «линейный» вид на широких экранах */
@media (min-width: 960px){
  .transit-track{
    padding-top: 60px;
  }
  .transit-track::before{
    top: 34px; left: 40px; right: 40px;
  }
  .transit-track{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: start; }
  .transit-track .stop{ margin-top: 0; }
}
/* ===== 7) Pusula Matrisi ===== */
.ha-compass__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(108,59,255,.32);
}
.compass-grid{
  position: relative;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  min-height: 420px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(3, minmax(0, 1fr));
  place-items: center;
  overflow: hidden;
}
.diamond{
  width: 220px; height: 220px; border-radius: 18px;
  background:
    radial-gradient(140px 80px at 70% 20%, rgba(108,59,255,.18), transparent),
    radial-gradient(140px 80px at 20% 80%, rgba(17,199,112,.18), transparent),
    rgba(255,255,255,.03);
  border: 1px solid var(--atlas-border);
  transform: rotate(45deg);
  box-shadow: var(--shadow-soft);
}
.c-tile{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border);
  border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
  width: min(340px, 90%);
}
.c-tile:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.c-tile figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }

/* размещение «по сторонам света» */
.c-tile--n{ grid-column: 2; grid-row: 1; }
.c-tile--e{ grid-column: 3; grid-row: 2; justify-self: end; }
.c-tile--s{ grid-column: 2; grid-row: 3; }

@media (max-width: 900px){
  .compass-grid{
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
    padding: 12px;
  }
  .diamond{ order: 1; width: 180px; height: 180px; }
  .c-tile--n{ order: 0; grid-column: 1; grid-row: auto; }
  .c-tile--e{ order: 2; grid-column: 1; }
  .c-tile--s{ order: 3; grid-column: 1; }
}

/* ===== 8) İlçe Kolları (spokes) ===== */
.ha-spokes__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(17,199,112,.30);
}
.spokes-stage{
  position: relative; min-height: 420px;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background:
    conic-gradient(from 0deg, rgba(108,59,255,.08), rgba(17,199,112,.08), rgba(255,122,26,.08), rgba(108,59,255,.08));
  overflow: hidden;
}
.spokes-stage .hub{
  position: absolute; left: 50%; top: 50%;
  width: 18px; height: 18px; border-radius: 50%;
  transform: translate(-50%,-50%);
  background: radial-gradient(circle at 35% 35%, #fff, var(--atlas-orange));
  box-shadow: 0 0 28px var(--atlas-orange);
}
.spoke-card{
  position: absolute; width: min(340px, 88vw);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border); border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
}
.spoke-card:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.spoke-card p{ margin: 6px 0 0; color: var(--atlas-dim); }

/* позиционирование трёх «спиц» */
.spoke--a{ left: 6%;  top: 12%; }
.spoke--b{ right: 6%; top: 26%; }
.spoke--c{ left: 50%; bottom: 10%; transform: translateX(-50%); }

@media (max-width: 900px){
  .spokes-stage{ min-height: 560px; }
  .spoke--a{ left: 50%; top: 8%;  transform: translateX(-50%); }
  .spoke--b{ left: 50%; top: 40%; transform: translateX(-50%); }
  .spoke--c{ left: 50%; bottom: 8%; transform: translateX(-50%); }
}

/* ===== 9) Çekirdek Katmanları ===== */
.ha-cores__grid{
  display: grid; gap: 22px;
  grid-template-columns: 1fr 1fr;
}
.cores-copy h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(255,122,26,.30);
}
.cores-left{ display: grid; gap: 14px; align-content: start; }
.core-card{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border);
  border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
  width: min(350px, 100%);
}
.core-card:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.core-card figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }

.cores-right{ display: grid; align-content: start; }
.core-card--wide img{ max-width: 350px; }

@media (max-width: 980px){
  .ha-cores__grid{ grid-template-columns: 1fr; }
  .cores-right{ order: 3; }
}
/* ===== 8) İlçe Kolları (FIX: без наложений) ===== */

/* оставляем как было для мобилок — по одному столбиком */
@media (max-width: 900px){
  .spokes-stage{ min-height: 560px; }
  .spoke--a{ left: 50%; top: 8%;  transform: translateX(-50%); }
  .spoke--b{ left: 50%; top: 40%; transform: translateX(-50%); }
  .spoke--c{ left: 50%; bottom: 8%; transform: translateX(-50%); }
}

/* СРЕДНИЕ/ШИРОКИЕ: переводим сцену в grid, карточки респонсивно «ступеньками» */
@media (min-width: 901px){
  .spokes-stage{
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: minmax(160px, auto);
    gap: 16px;
    padding: 24px;
    min-height: auto;              /* высота под контент */
    position: relative;
  }

  /* декоративный хаб прячем или оставляем маленькой точкой — на выбор */
  .spokes-stage .hub{ display: none; }

  /* карточки больше НЕ абсолютные в grid-режиме */
  .spoke-card{
    position: relative;
    width: 100%;
    max-width: 350px;              /* соблюдаем лимит из ТЗ */
    transform: none !important;    /* убираем смещения от абсолютной версии */
  }

  /* «ступеньки» слева → центр → справа, без перекрытий */
  .spoke--a{ grid-column: 1 / span 4;  grid-row: 1; align-self: start; }
  .spoke--b{ grid-column: 5 / span 4;  grid-row: 2; align-self: start; }
  .spoke--c{ grid-column: 9 / span 4;  grid-row: 3; align-self: start; }
}

/* очень широкие — чуть увеличим шаг, чтобы смотрелось свободнее */
@media (min-width: 1280px){
  .spoke--a{ grid-column: 1 / span 4; }
  .spoke--b{ grid-column: 6 / span 4; }
  .spoke--c{ grid-column: 10 / span 3; }
}
/* ===== 8) İlçe Kolları — compact layout (desktop) ===== */
@media (min-width: 901px){
  .spokes-stage{
    display: grid;
    grid-template-columns: repeat(9, 1fr);  /* компактнее сетка */
    grid-auto-rows: auto;
    gap: 12px;
    padding: 16px 14px;
    min-height: auto;
    position: relative;
  }
  .spokes-stage .hub{ display: none; }

  .spoke-card{
    position: relative;
    width: 100%;
    max-width: 300px;          /* было 340 — делаем компактнее */
    padding: 10px;
    transform: none !important;
  }
  .spoke-card figure{ margin: 0; }
  .spoke-card p{ margin-top: 6px; font-size: 14px; }

  /* три колонки в одном ряду + лёгкая «ступенька» */
  .spoke--a{ grid-column: 1 / span 3; grid-row: 1; margin-top: 0; }
  .spoke--b{ grid-column: 4 / span 3; grid-row: 1; margin-top: 6px; }
  .spoke--c{ grid-column: 7 / span 3; grid-row: 1; margin-top: 12px; }
}

/* очень широкие — ещё чуть плотнее и по центру */
@media (min-width: 1280px){
  .spokes-stage{ grid-template-columns: repeat(12, 1fr); }
  .spoke--a{ grid-column: 3 / span 3; margin-top: 0;  }
  .spoke--b{ grid-column: 6 / span 3; margin-top: 6px; }
  .spoke--c{ grid-column: 9 / span 3; margin-top: 12px; }
}
/* ===== 10) Metro Matrisi ===== */
.ha-metro__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(108,59,255,.32);
}
.metro-board{
  position: relative;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow: hidden; min-height: 320px;
}
.metro-svg{ width: 100%; height: 360px; display: block; }
.metro-svg .grid line{
  stroke: rgba(255,255,255,.12); stroke-width: 1.4;
}
.metro-svg .route{
  fill:none; stroke-width: 4;
  stroke-dasharray: 820; stroke-dashoffset: 820; /* анимация прорисовки */
  filter: drop-shadow(0 10px 24px rgba(108,59,255,.28));
  transition: stroke-dashoffset 1.2s cubic-bezier(.2,.8,.2,1);
}
.reveal.is-visible .metro-svg .route{ stroke-dashoffset: 0; }
.metro-svg .dot{ fill: var(--atlas-orange); }

.mcard{
  position: absolute; width: min(340px, 88vw);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border); border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
}
.mcard:hover{ transform: translateY(-4px); filter: saturate(1.06); box-shadow: var(--shadow-float); }
.mcard figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }
.mcard--nw{ left: 6%; bottom: 10%; }
.mcard--se{ right: 6%; top: 10%; }

@media (max-width: 900px){
  .metro-svg{ height: 420px; }
  .mcard--nw{ left: 50%; transform: translateX(-50%); bottom: 8%; }
  .mcard--se{ left: 50%; transform: translateX(-50%); top: 8%; }
}

/* ===== 11) Süzgeç Şeridi ===== */
.ha-filter__grid{ display: grid; gap: 22px; grid-template-columns: 1fr 1fr; }
.filter-copy h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(17,199,112,.30);
}
.filter-mini{
  display: grid; gap: 14px; align-content: start;
}
.fcard{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border);
  border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
  width: min(350px, 100%);
}
.fcard:hover{ transform: translateY(-4px); box-shadow: var(--shadow-float); filter: saturate(1.06); }
.fcard figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }

@media (max-width: 980px){
  .ha-filter__grid{ grid-template-columns: 1fr; }
}

/* ===== 12) Çapraz Koridorlar ===== */
.ha-cross__head h2{
  font-size: clamp(26px,3.2vw,38px);
  margin: 0 0 10px;
  text-shadow: 0 8px 40px rgba(255,122,26,.30);
}
.cross-stage{
  position: relative; min-height: 300px;
  border: 1px solid var(--atlas-border);
  border-radius: 22px;
  background:
    conic-gradient(from 45deg, rgba(108,59,255,.10) 0 25%, transparent 25% 50%, rgba(17,199,112,.10) 50% 75%, transparent 75% 100%);
  overflow: hidden;
}
.xcard{
  position: absolute; width: min(340px, 90%);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--atlas-border); border-radius: 18px; padding: 10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
}
.xcard:hover{ transform: translateY(-4px); box-shadow: var(--shadow-float); filter: saturate(1.06); }
.xcard figcaption{ margin-top: 6px; color: var(--atlas-dim); font-size: 14px; }
.xcard--nw{ left: 6%; top: 8%; }
.xcard--se{ right: 6%; bottom: 8%; }

@media (max-width: 900px){
  .cross-stage{ min-height: 460px; }
  .xcard--nw{ left: 50%; top: 8%; transform: translateX(-50%); }
  .xcard--se{ left: 50%; bottom: 8%; transform: translateX(-50%); }
}
/* ===== 13) Mahalle Kümeleri — örgü ===== */
.ha-weave__head h2{ font-size: clamp(26px,3.2vw,38px); margin:0 0 10px; text-shadow:0 8px 40px rgba(108,59,255,.32);}
.weave-grid{
  position: relative;
  display: grid; gap: 14px;
  grid-template-columns: repeat(2, minmax(0,1fr));
  padding: 14px;
  border:1px solid var(--atlas-border); border-radius:22px;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 6px, rgba(255,255,255,.03) 6px 14px),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow: hidden;
  mask-image: radial-gradient(120% 120% at 50% 50%, black 60%, transparent 100%);
}
.wcard{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--atlas-border); border-radius:18px; padding:10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
  width:min(350px,100%);
}
.wcard:hover{ transform: translateY(-4px); filter:saturate(1.06); box-shadow: var(--shadow-float); }
.wcard figcaption{ margin-top:6px; color:var(--atlas-dim); font-size:14px; }
@media (max-width:820px){ .weave-grid{ grid-template-columns: 1fr; } }

/* ===== 14) Topo Kesit ===== */
.ha-topo__head h2{ font-size: clamp(26px,3.2vw,38px); margin:0 0 10px; text-shadow:0 8px 40px rgba(17,199,112,.30);}
.topo-stage{
  position: relative; border:1px solid var(--atlas-border); border-radius:22px;
  background:
    linear-gradient(-12deg, rgba(108,59,255,.10), transparent 50%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  overflow:hidden; min-height: 260px;
}
.topo-svg{ position:absolute; inset:0; width:100%; height:100%; }
.topo-route{
  fill:none; stroke: rgba(255,255,255,.85); stroke-width:2.6; stroke-linecap:round;
  stroke-dasharray: 720; stroke-dashoffset: 720;
  filter: drop-shadow(0 10px 24px rgba(17,199,112,.28));
  transition: stroke-dashoffset 1.2s cubic-bezier(.2,.8,.2,1);
}
.reveal.is-visible .topo-route{ stroke-dashoffset: 0; }

.tcard{
  position:absolute; right: 6%; bottom: 8%;
  width:min(350px, 88vw);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--atlas-border); border-radius:18px; padding:10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
}
.tcard:hover{ transform: translateY(-4px); filter:saturate(1.06); box-shadow: var(--shadow-float); }
.tcard figcaption{ margin-top:6px; color:var(--atlas-dim); font-size:14px; }
@media (max-width:900px){
  .tcard{ left:50%; right:auto; transform: translateX(-50%); }
}

/* ===== 15) Kademe Şeridi ===== */
.ha-tier__head h2{ font-size: clamp(26px,3.2vw,38px); margin:0 0 10px; text-shadow:0 8px 40px rgba(255,122,26,.30);}
.tier-track{
  position: relative; border:1px solid var(--atlas-border); border-radius:22px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  padding: 18px 14px 24px; overflow:hidden;
  display:grid; grid-template-columns: repeat(12, 1fr); gap: 12px; align-items:start;
}
.tier-glow{
  position:absolute; left:0; right:0; bottom:36px; height: 8px; border-radius:999px;
  background: linear-gradient(90deg, var(--atlas-violet), var(--atlas-green));
  box-shadow: 0 8px 26px rgba(108,59,255,.28);
}
.tier-card{
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--atlas-border); border-radius:18px; padding:10px;
  box-shadow: var(--shadow-soft);
  transition: transform .22s ease, box-shadow .22s ease, filter .2s ease;
  width:min(350px,100%);
}
.tier-card:hover{ transform: translateY(-4px); filter:saturate(1.06); box-shadow: var(--shadow-float); }
.tier-card figcaption{ margin-top:6px; color:var(--atlas-dim); font-size:14px; }

.tier-card--a{ grid-column: 2 / span 4; margin-top: 0; }
.tier-card--b{ grid-column: 7 / span 4; margin-top: 12px; }

@media (max-width: 900px){
  .tier-track{ grid-template-columns: 1fr; }
  .tier-card--a, .tier-card--b{ grid-column:auto; margin-top: 0; }
}

/* ===== 16) Harita Lejandı ===== */
.ha-legend__head h2{ font-size: clamp(26px,3.2vw,38px); margin:0 0 10px; text-shadow:0 8px 40px rgba(108,59,255,.32);}
.legend-board{
  position: relative; border:1px solid var(--atlas-border); border-radius:18px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  padding: 16px 14px; display:grid; gap:14px; grid-template-columns: 1fr 1fr; align-items:start;
}
.legend-card{
  position: sticky; top: calc(var(--hdr-h,72px) + 12px);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--atlas-border); border-radius:14px; padding:10px;
  box-shadow: var(--shadow-soft);
}
.legend-card::before, .legend-card::after{
  content:""; position:absolute; width:44px; height:12px; top:-6px;
  background: rgba(255,255,255,.2); filter: blur(.4px);
  border-radius:2px; transform: rotate(-4deg);
}
.legend-card::after{ right:12px; transform: rotate(6deg); }
.legend-card::before{ left:12px;  }

.legend-notes ul{ margin: 0; padding-left: 18px; color: var(--atlas-dim); }
@media (max-width: 900px){
  .legend-board{ grid-template-columns: 1fr; }
  .legend-card{ position: relative; top: auto; }
}
/* ================================
   HARITA — MOBILE IMAGE SAFETY PATCH
   Останавливает обрезание изображений
   ================================ */
@media (max-width: 560px){
  /* 1) Ни один мобильный контейнер не «режет» содержимое */
  .ha-section .stage,
  .ha-section .board,
  .ha-section .grid,
  .ha-section .rail,
  .ha-section .wrap,
  .ha-section figure,
  .ha-section [class*="card"]{
    overflow: visible !important;
  }

  /* 2) Картинки всегда вписываются, без фиксированной высоты */
  .ha-section img{
    display: block;
    width: min(100%, 350px);
    height: auto !important;      /* снимаем любые ранее заданные высоты */
    max-width: 350px;
    object-fit: contain !important; /* вместо cover, чтобы не «резало» */
  }

  /* 3) Карточки по центру и без наклонов/смещений */
  .ha-section [class*="card"]{
    width: min(350px, 100%);
    margin-inline: auto;
    transform: none !important;    /* выключаем декоративные повороты/сдвиги */
  }

  /* 4) Частые компоненты второй страницы */
  .ha-metro__card,
  .ha-route__card,
  .ha-topo__card,
  .ha-tier__card,
  .ha-legend__card,
  .ha-pin,
  .ha-chip{
    width: min(350px, 100%);
    transform: none !important;
    overflow: visible !important;
    margin-inline: auto;
  }

  /* 5) Лёгкая «подушка» внутри сцен, чтобы края не прилипали */
  .ha-section .stage,
  .ha-section .board{
    padding-left: 10px;
    padding-right: 10px;
  }
}

/* На очень узких экранах ещё мягче поля и без масок/маскировок */
@media (max-width: 380px){
  .ha-section .stage,
  .ha-section .board{ padding-inline: 8px; }

  /* если где-то использовали clip-path/mask, отключаем для мобилок */
  .ha-section [style*="clip-path"],
  .ha-section [style*="mask"],
  .ha-section .has-mask{
    clip-path: none !important;
    -webkit-mask: none !important;
            mask: none !important;
  }
}
/* ===== Seksyon 1: Odakları ve Branş Yoğunluğu — mobile align fix ===== */
#odaklar [class*="stage"],
#odaklar [class*="board"],
#odaklar [class*="wrap"]{
  display:grid;
  gap:12px;
  grid-template-columns: 1fr 1fr;          /* десктоп/планшет */
  align-items:center;
}

@media (max-width: 860px){
  #odaklar [class*="stage"],
  #odaklar [class*="board"],
  #odaklar [class*="wrap"]{
    grid-template-columns: 1fr;            /* на мобилке — в колонку */
    padding-inline: 10px;
  }
}

/* карточки с изображениями — по центру, без абсолютов/наклонов */
#odaklar [class*="card"]{
  position:relative !important;
  left:auto !important; right:auto !important; top:auto !important; bottom:auto !important;
  transform:none !important;
  width:min(350px,100%);
  margin-inline:auto;
  z-index:2;
}

/* сами изображения — вписываются, не режутся */
#odaklar img{
  display:block;
  width:100%;
  max-width:350px;
  height:auto !important;
  object-fit:contain !important;
}

/* круги/кольца/пины — под карточками и без смещения */
#odaklar [class*="ring"],
#odaklar [class*="orbit"],
#odaklar .pin,
#odaklar .pins{
  z-index:1;
  transform:none !important;
  margin-inline:auto;
  max-width:540px;
  overflow:visible !important;
}

/* чтобы ничего не обрезалось краями секции */
#odaklar [class*="stage"],
#odaklar [class*="board"]{ overflow:visible !important; }

/* очень узкие экраны */
@media (max-width: 560px){
  #odaklar [class*="card"]{ margin-inline:auto; }
  /* на всякий случай убираем clip-path/mask */
  #odaklar [style*="clip-path"],
  #odaklar [style*="mask"],
  #odaklar .has-mask{
    clip-path:none !important;
    -webkit-mask:none !important;
            mask:none !important;
  }
}
/* ===== 2) Rota İzi — mobile align/safety ===== */
@media (max-width: 860px){
  /* трек — из слоёв делаем колонку, всё по центру */
  #rota-iz .ha-path__track{
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: center;
    justify-items: center;
    padding-inline: 10px;
    overflow: visible !important;
  }

  /* линия маршрута — позади карточек, не мешает кликам */
  #rota-iz .path-svg{
    width: 100%;
    height: auto;
    min-height: 160px;
    z-index: 0;
    pointer-events: none;
  }

  /* карточки узлов — без абсолютов/сдвигов, по центру */
  #rota-iz .node{
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 auto;
    width: min(350px, 100%);
    z-index: 1;
    overflow: visible !important;
  }

  /* изображения в карточках — вписываются, не режутся */
  #rota-iz .node img{
    display: block;
    width: 100%;
    max-width: 350px;
    height: auto !important;
    object-fit: contain !important;
  }

  /* на очень узких отключаем возможные маски/клипы */
  @media (max-width: 560px){
    #rota-iz [style*="clip-path"],
    #rota-iz [style*="mask"],
    #rota-iz .has-mask{
      clip-path: none !important;
      -webkit-mask: none !important;
              mask: none !important;
    }
  }
}
/* ===== 4) Şehir Hubı — mobile align/safety ===== */
@media (max-width: 860px){
  /* сцена/борд → колонка, центрируем, ничего не режем */
  #sehir-hub [class*="stage"],
  #sehir-hub [class*="board"],
  #sehir-hub [class*="wrap"]{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: center;
    justify-items: center;
    padding-inline: 10px;
    overflow: visible !important;
  }

  /* круг/пульс/пины под карточками */
  #sehir-hub [class*="ring"],
  #sehir-hub [class*="orbit"],
  #sehir-hub .pin,
  #sehir-hub .pins{
    z-index: 0;
    pointer-events: none;
    transform: none !important;
    margin-inline: auto;
    max-width: 540px;
    overflow: visible !important;
  }

  /* карточки — без абсолютов/смещений, по центру */
  #sehir-hub [class*="card"]{
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    width: min(350px, 100%);
    margin: 0 auto;
    z-index: 1;
    overflow: visible !important;
  }

  /* изображения — вписываются, не режутся */
  #sehir-hub img{
    display: block;
    width: 100%;
    max-width: 350px;
    height: auto !important;
    object-fit: contain !important;
  }
}

/* очень узкие — выключаем возможные клипы/маски */
@media (max-width: 560px){
  #sehir-hub [style*="clip-path"],
  #sehir-hub [style*="mask"],
  #sehir-hub .has-mask{
    clip-path: none !important;
    -webkit-mask: none !important;
            mask: none !important;
  }
}
/* ===== 8) İlçe Kolları — mobile align/safety ===== */
@media (max-width: 860px){
  /* Сцена/борд → колонка, всё по центру, ничего не режем */
  #ilce-kollari [class*="stage"],
  #ilce-kollari [class*="board"],
  #ilce-kollari [class*="wrap"],
  #ilce-kollari [class*="grid"]{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: center;
    justify-items: center;
    padding-inline: 10px;
    overflow: visible !important;
  }

  /* Карточки «рукавов» — без абсолютов/поворотов, по центру */
  #ilce-kollari .arm-card,
  #ilce-kollari [class*="card"]{
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 auto;
    width: min(350px, 100%);
    z-index: 1;
    overflow: visible !important;
  }

  /* Изображения — вписываются, не режутся */
  #ilce-kollari .arm-card img,
  #ilce-kollari [class*="card"] img{
    display: block;
    width: 100%;
    max-width: 350px;
    height: auto !important;
    object-fit: contain !important;
  }

  /* Линии/узлы/свечения — под карточками и без смещений */
  #ilce-kollari .arm-line,
  #ilce-kollari .arm-dot,
  #ilce-kollari [class*="node"],
  #ilce-kollari [class*="pin"],
  #ilce-kollari [class*="ring"]{
    z-index: 0;
    pointer-events: none;
    transform: none !important;
    margin-inline: auto;
    overflow: visible !important;
  }
}

/* Очень узкие — на всякий случай отключаем клипы/маски */
@media (max-width: 560px){
  #ilce-kollari [style*="clip-path"],
  #ilce-kollari [style*="mask"],
  #ilce-kollari .has-mask{
    clip-path: none !important;
    -webkit-mask: none !important;
            mask: none !important;
  }
}
/* ===== 10) Metro Matrisi — mobile align/safety ===== */
@media (max-width: 860px){
  /* Сцена/борд/сетка → одна колонка, центрируем, ничего не режем */
  #metro-matrisi [class*="stage"],
  #metro-matrisi [class*="board"],
  #metro-matrisi [class*="grid"],
  #metro-matrisi [class*="wrap"]{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: center;
    justify-items: center;
    padding-inline: 10px;
    overflow: visible !important;
  }

  /* Диагональная линия/узлы — за карточками и не мешают кликам */
  #metro-matrisi .metro-diagonal,
  #metro-matrisi .diagonal,
  #metro-matrisi svg{
    z-index: 0;
    pointer-events: none;
    transform: none !important;
    width: 100%;
    height: auto;
  }

  /* Карточки углов — без абсолютов/наклонов, по центру */
  #metro-matrisi [class*="card"]{
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 auto;
    width: min(350px, 100%);
    z-index: 1;
    overflow: visible !important;
  }

  /* Картинки в карточках — вписываются, не «режутся» */
  #metro-matrisi [class*="card"] img{
    display: block;
    width: 100%;
    max-width: 350px;
    height: auto !important;
    object-fit: contain !important;
  }
}

/* Очень узкие — отключаем любые маски/клипы на всякий случай */
@media (max-width: 560px){
  #metro-matrisi [style*="clip-path"],
  #metro-matrisi [style*="mask"],
  #metro-matrisi .has-mask{
    clip-path: none !important;
    -webkit-mask: none !important;
            mask: none !important;
  }
}
/* ===== 12) Çapraz Koridorlar — mobile align/safety ===== */
@media (max-width: 860px){
  /* Сцена/борд → в одну колонку, центрируем, не режем содержимое */
  #capraz-koridorlar [class*="stage"],
  #capraz-koridorlar [class*="board"],
  #capraz-koridorlar [class*="wrap"],
  #capraz-koridorlar [class*="grid"]{
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: center;
    justify-items: center;
    padding-inline: 10px;
    overflow: visible !important;
  }

  /* Диагональный «X»-фон/градиенты — под карточками и без смещений */
  #capraz-koridorlar .cross-bg,
  #capraz-koridorlar .x-bg,
  #capraz-koridorlar svg,
  #capraz-koridorlar [class*="line"]{
    z-index: 0;
    pointer-events: none;
    transform: none !important;
    width: 100%;
    height: auto;
  }

  /* Карточки — по центру, без absolute/rotate/смещений */
  #capraz-koridorlar [class*="card"]{
    position: relative !important;
    inset: auto !important;
    transform: none !important;
    margin: 0 auto;
    width: min(350px, 100%);
    z-index: 1;
    overflow: visible !important;
  }

  /* Изображения в карточках — вписываются, не «режутся» */
  #capraz-koridorlar [class*="card"] img{
    display: block;
    width: 100%;
    max-width: 350px;
    height: auto !important;
    object-fit: contain !important;
  }
}

/* Очень узкие экраны — отключаем возможные маски/клип */
@media (max-width: 560px){
  #capraz-koridorlar [style*="clip-path"],
  #capraz-koridorlar [style*="mask"],
  #capraz-koridorlar .has-mask{
    clip-path: none !important;
    -webkit-mask: none !important;
            mask: none !important;
  }
}
/* ===== 8) İlçe Kolları — DESKTOP align/overflow fix ===== */
@media (min-width: 861px){
  /* сам борд держит контент внутри рамки */
  #ilce-kollari [class*="board"],
  #ilce-kollari [class*="stage"]{
    padding: 18px 20px;
    overflow: hidden;                  /* ничего не выходит за границу */
  }

  /* ряд карточек без наложений */
  #ilce-kollari .arm-grid,
  #ilce-kollari [class*="grid"]{
    display: flex;
    flex-wrap: nowrap;
    gap: 16px;
    justify-content: space-between;    /* три колонки по ширине борда */
    align-items: flex-start;
  }

  /* сами карточки: фиксируем размеры и убираем декоративные сдвиги */
  #ilce-kollari .arm-card,
  #ilce-kollari [class*="card"]{
    position: relative !important;
    transform: none !important;
    inset: auto !important;
    flex: 0 1 340px;                   /* ≤ 350px по ТЗ, берём 340 для запаса */
    max-width: 350px;
    width: 100%;
    margin: 0;
    overflow: hidden;                  /* крайняя тень не вылезает */
    box-sizing: border-box;
  }

  /* изображения вписываются внутрь карточки */
  #ilce-kollari .arm-card img,
  #ilce-kollari [class*="card"] img{
    display: block;
    width: 100%;
    height: auto;                      /* без фиксированных высот */
    max-width: 350px;
    object-fit: cover;                 /* карта не «дрыгается», но не растягивается */
  }
}
