/* =========================
   Homepage — Section 1 (Hero)
   ========================= */

main{ padding-top: 68px; } /* space for fixed header */

.hero-section{
  position:relative;
  padding: clamp(28px, 6vw, 64px) 0 clamp(32px, 8vw, 96px) 0;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr 1.1fr;
  gap: clamp(20px, 4vw, 40px);
  align-items:center;
}

.hero-title{
  font-family:"Playfair Display", serif;
  font-size: clamp(28px, 3.6vw, 44px);
  line-height:1.2;
  margin:0 0 10px 0;
  text-shadow:0 2px 18px rgba(93,211,255,.18);
}
.hero-lead{
  font-size: clamp(15px, 1.5vw, 18px);
  color: var(--ink);
  margin: 0 0 10px 0;
}
.hero-text{ color:var(--muted); margin:0 0 12px 0; }
.hero-promise{ margin:0; padding-left: 18px; color:var(--muted); }

.hero-canvas{
  position:relative;
  min-height: 420px;
  border-radius: var(--radius);
  background:
    radial-gradient(600px 260px at 70% 10%, rgba(255,209,102,.10), transparent 60%),
    radial-gradient(460px 240px at 30% 90%, rgba(138,255,193,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0) 60%);
  outline:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}

/* SVG route styling */
.route-svg{
  position:absolute; inset:0; width:100%; height:100%;
  filter: drop-shadow(0 6px 18px rgba(0,0,0,.45));
}
.route-svg path{
  fill:none;
  stroke: var(--brand);
  stroke-width: 3;
  stroke-dasharray: 6 10;
  animation: dash 10s linear infinite;
  opacity:.9;
}
@keyframes dash{
  to { stroke-dashoffset: -16; }
}
.pin{ fill: var(--brand-2); }
.pin--start{ filter: drop-shadow(0 0 8px rgba(255,209,102,.6)); }
.pin--end{ filter: drop-shadow(0 0 8px rgba(255,209,102,.6)); }

/* Moving plane (✈) */
.plane{
  position:absolute;
  font-size: 22px;
  translate: -50% -50%;
  text-shadow: 0 4px 10px rgba(0,0,0,.45);
}

/* Collage tiles placed around the route (non-card layout) */
.tile{
  position:absolute;
  max-width: min(92%, 350px);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  padding:10px;
  transform: rotate(var(--r, 0deg));
  transition: transform .35s ease, box-shadow .35s ease, translate .35s ease;
}
.tile figcaption{
  font-size: 13px; color:var(--muted); margin-top: 8px;
}
.tile:hover{
  transform: rotate(var(--r, 0deg)) translateY(-6px);
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
}

/* Specific placements for desktop; JS reflows on smaller screens */
.t1{ left: 22px;  top: 24px;  --r:-2deg; }
.t2{ right: 16px; top: 56%;   --r: 2deg; }
.t3{ left: 14%;   bottom: 12px; --r: -1.5deg; }
.t4{ right: 20%;  top: 12%;   --r: 1.5deg; }

/* Noscript note */
.noscript-note{
  color:var(--muted);
  margin-top: 12px;
  font-size: 14px;
}

/* Responsive adjustments */
@media (max-width: 1100px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-canvas{ min-height: 520px; }
  .t1{ left: 10px; top: 20px; }
  .t2{ right: 10px; top: 64%; }
  .t3{ left: 8%; bottom: 16px; }
  .t4{ right: 10%; top: 12%; }
}

@media (max-width: 780px){
  .hero-canvas{ min-height: 560px; }
  .tile{ max-width: 320px; }
  .t3{ left: 6%; }
  .t4{ right: 6%; }
}

@media (max-width: 560px){
  .hero-canvas{ min-height: 640px; }
  .tile{ position:static; margin: 14px auto; display:block; transform: none; }
  .tile:hover{ transform: translateY(-4px); }
  .route-svg{ opacity:.55; }
}
/* === HERO MOSAIC (no-overlap) === */
.hero-canvas{
  position: relative;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-template-rows: auto auto;      /* две строки мозаики */
  gap: clamp(12px, 2.4vw, 18px);
  padding: clamp(12px, 2vw, 16px);
  align-items: stretch;
}

/* маршрут под всем, не мешает кликам */
.route-svg{ position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.35; }
.plane{ position:absolute; z-index:1; pointer-events:none; }

/* карточки — обычные grid-элементы, никаких absolute */
.hero-canvas .tile{
  position: relative !important;
  left:auto !important; right:auto !important; top:auto !important; bottom:auto !important;
  z-index: 2;
  transform: none !important;          /* убираем поворот, чтобы швы были ровные */
  box-shadow: var(--shadow);
}

/* аккуратные подписи и изображение */
.hero-canvas .tile img{
  width:100%; height:auto; max-width:350px;
  aspect-ratio: 16 / 11;               /* одинаковая высота ряда */
  object-fit: cover; border-radius: calc(var(--radius) - 4px);
}
.hero-canvas .tile figcaption{ margin-top:8px; font-size:13px; color:var(--muted); }

/* размещение 4 плиток по сетке (desktop ≥1100px) */
.t1{ grid-column: 1 / span 5; grid-row: 1; justify-self:start;  }
.t2{ grid-column: 7 / span 6; grid-row: 1; justify-self:end;    }
.t3{ grid-column: 2 / span 6; grid-row: 2; justify-self:start;  }
.t4{ grid-column: 9 / span 4; grid-row: 2; justify-self:end;    }

/* hover — лёгкое приподнятие без смещений соседей */
.hero-canvas .tile:hover{ transform: translateY(-6px) !important; }

/* планшеты */
@media (max-width:1100px){
  .hero-canvas{ grid-template-columns: repeat(8, minmax(0,1fr)); }
  .t1{ grid-column: 1 / span 4; grid-row: 1; }
  .t2{ grid-column: 5 / span 4; grid-row: 1; }
  .t3{ grid-column: 1 / span 5; grid-row: 2; }
  .t4{ grid-column: 6 / span 3; grid-row: 2; }
}

/* мелкие экраны — три столбца */
@media (max-width:780px){
  .hero-canvas{ grid-template-columns: repeat(3, minmax(0,1fr)); grid-template-rows: auto auto; }
  .t1{ grid-column: 1 / span 3; grid-row: auto; }
  .t2{ grid-column: 1 / span 3; grid-row: auto; }
  .t3{ grid-column: 1 / span 3; grid-row: auto; }
  .t4{ grid-column: 1 / span 3; grid-row: auto; }
  .route-svg{ opacity:.28; } /* ещё мягче подложка */
}

/* самые маленькие — ровная колонка */
@media (max-width:560px){
  .hero-canvas{ display:block; }
  .hero-canvas .tile{ margin:14px auto; max-width:350px; }
  .route-svg{ opacity:.22; }
}
/* ===== Sections 2–4 ===== */

/* Shared section headers */
.sec-head{ margin-bottom: clamp(16px, 3vw, 28px); }
.sec-title{
  font-family:"Playfair Display", serif;
  font-size: clamp(22px, 3vw, 32px);
  margin:0 0 6px 0;
  text-shadow:0 2px 14px rgba(93,211,255,.15);
}
.sec-lead{ color:var(--muted); margin:0; }

/* --- SECTION 2: Ribbon --- */
.ribbon-section{ padding: clamp(28px, 6vw, 70px) 0; position:relative; }
.ribbon-steps{
  list-style:none; margin:0; padding: clamp(8px, 2vw, 12px) 0;
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px, 2vw, 22px);
  position:relative;
}
.rs-item{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  padding:12px;
  display:grid; grid-template-columns: auto 1fr; gap:12px; align-items:center;
  box-shadow: var(--shadow);
}
.rs-item figure{ margin:0; }
.rs-item figcaption{ font-size:12px; color:var(--muted); margin-top:6px; }
.rs-text h3{ margin:.2rem 0; font-size: clamp(16px, 1.8vw, 18px); }
.rs-text p{ margin:0; color:var(--muted); }

/* размещение по зигзагу */
.ribbon-steps > :nth-child(1){ grid-column: 1 / span 6; }
.ribbon-steps > :nth-child(2){ grid-column: 7 / span 6; }
.ribbon-steps > :nth-child(3){ grid-column: 2 / span 6; }
.ribbon-steps > :nth-child(4){ grid-column: 8 / span 5; }

/* декоративная волнистая линия под карточками */
.ribbon-line{
  position:absolute; inset: auto 0 18px 0; height: 90px; pointer-events:none;
  background:
    radial-gradient(40px 40px at 6% 60%, rgba(255,209,102,.55), transparent 60%),
    radial-gradient(32px 32px at 94% 30%, rgba(255,209,102,.45), transparent 60%),
    conic-gradient(from 180deg at 50% 50%, rgba(93,211,255,.45), rgba(93,211,255,.2) 30%, transparent 30% 70%, rgba(93,211,255,.45));
  mask:
    radial-gradient(80px 50px at 10% 70%, black 60%, transparent 62%) ,
    radial-gradient(80px 50px at 30% 30%, black 60%, transparent 62%) ,
    radial-gradient(80px 50px at 50% 65%, black 60%, transparent 62%) ,
    radial-gradient(80px 50px at 70% 35%, black 60%, transparent 62%) ,
    radial-gradient(80px 50px at 90% 60%, black 60%, transparent 62%);
  opacity:.35; filter: blur(1px);
}

@media (max-width:1100px){
  .ribbon-steps{ grid-template-columns: repeat(8, minmax(0,1fr)); }
  .ribbon-steps > :nth-child(1){ grid-column: 1 / span 8; }
  .ribbon-steps > :nth-child(2){ grid-column: 1 / span 8; }
  .ribbon-steps > :nth-child(3){ grid-column: 1 / span 8; }
  .ribbon-steps > :nth-child(4){ grid-column: 1 / span 8; }
  .ribbon-line{ display:none; }
}

/* --- SECTION 3: Culture Weave --- */
.weave-section{ padding: clamp(28px, 6vw, 72px) 0; position:relative; }
.weave-section::before{
  content:""; position:absolute; inset:0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.04) 0 6px, rgba(255,255,255,0) 6px 18px),
    radial-gradient(600px 200px at 80% 0%, rgba(138,255,193,.08), transparent 60%);
  pointer-events:none;
}
.weave-grid{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr));
  gap: clamp(14px, 2.2vw, 22px);
}
.weave-poster{
  grid-column: span 4;
  padding:16px;
  border-radius: calc(var(--radius) + 4px);
  border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)),
    radial-gradient(1200px 200px at 50% -20%, rgba(93,211,255,.09), transparent 60%);
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.weave-poster img{ width:100%; max-width:350px; aspect-ratio: 16/15; object-fit: cover; }
.weave-poster h3{ margin:10px 0 6px 0; font-size: clamp(16px, 2vw, 20px); }
.weave-poster p{ margin:0; color:var(--muted); }

/* «аудио»-полоски */
.weave-poster .bars{
  position:absolute; right:10px; bottom:10px; display:flex; gap:4px; opacity:.8;
}
.weave-poster .bars i{
  display:block; width:4px; height:22px; background:var(--brand);
  animation: beat 1.2s ease-in-out infinite;
}
.weave-poster .bars i:nth-child(2){ animation-delay:.1s; height:16px; }
.weave-poster .bars i:nth-child(3){ animation-delay:.2s; height:20px; }
.weave-poster .bars i:nth-child(4){ animation-delay:.3s; height:14px; }
@keyframes beat{ 50%{ transform: scaleY(1.9); } }

@media (max-width:1100px){
  .weave-poster{ grid-column: span 6; }
}
@media (max-width:780px){
  .weave-poster{ grid-column: span 12; }
}

/* --- SECTION 4: Film Strip --- */
.filmstrip-section{ padding: clamp(28px, 6vw, 72px) 0; }
.film-strip{
  display:flex; gap: clamp(14px, 2vw, 20px);
  overflow:auto;
  scroll-snap-type: x mandatory;
  padding: 0 clamp(16px, 3vw, 28px) clamp(10px, 2vw, 18px);
  -webkit-overflow-scrolling: touch;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
}
.reel-frame{
  flex: 0 0 auto; width: min(86vw, 350px);
  scroll-snap-align: start;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  padding:10px; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow); transition: transform .25s ease;
}
.reel-frame:hover{ transform: translateY(-6px); }
.reel-frame figcaption{ font-size:12px; color:var(--muted); margin-top:6px; }
/* === FIX: центрируем киноленту как gs-wrap и убираем "прилипание" слева === */
.filmstrip-section .film-strip{
  width: min(1200px, 100%);   /* та же ширина, что и у .gs-wrap */
  margin-inline: auto;        /* центрируем */
  padding-inline: clamp(16px, 3vw, 28px);       /* одинаковые внутренние поля */
  scroll-padding-left: clamp(16px, 3vw, 28px);  /* первый кадр не прилипает */
  scroll-padding-right: clamp(16px, 3vw, 28px); /* последний тоже аккуратно */
  border-radius: calc(var(--radius) + 6px);
}

/* на очень широких — слегка увеличиваем зазор между кадрами */
@media (min-width: 1400px){
  .filmstrip-section .film-strip{ gap: 22px; }
}

/* на мобильных всё остаётся на 100% ширины, центрирование сохраняется */
@media (max-width: 780px){
  .filmstrip-section .film-strip{ width: 100%; }
}
/* ===== SECTION 5: Switchbacks ===== */
.switchbacks-section{ padding: clamp(28px, 6vw, 72px) 0; }
.elev-chart{
  position: relative;
  border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  padding: 10px;
  overflow: hidden;
  box-shadow: var(--shadow);
}
.elev-svg{ width:100%; height:auto; display:block; filter: drop-shadow(0 6px 16px rgba(0,0,0,.35)); }
.hiker{
  position:absolute; left:0; top:0;
  width:18px; height:18px; line-height:18px; text-align:center;
  font-size:12px; color:#0b0e13; background:var(--brand-2);
  border-radius:50%; box-shadow: 0 6px 16px rgba(0,0,0,.35);
  transform: translate(-50%,-50%);
}
.elev-note{ color:var(--muted); font-size:13px; margin:6px 2px 0; }

.peaks-grid{
  margin-top: clamp(16px, 3vw, 22px);
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px, 2vw, 20px);
}
.peak{ grid-column: span 4; padding:10px; border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow); transition: transform .25s ease;
}
.peak:hover{ transform: translateY(-6px); }
.peak figcaption{ font-size:12px; color:var(--muted); margin-top:6px; }
@media (max-width:1100px){ .peak{ grid-column: span 6; } }
@media (max-width:780px){ .peak{ grid-column: span 12; } }

/* ===== SECTION 6: Rail Window ===== */
.rail-section{ padding: clamp(28px, 6vw, 72px) 0; }
.rail-window{ width:min(1200px, 100%); margin-inline:auto; }
.window-mask{
  border-radius: 28px;
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(1200px 300px at 50% -10%, rgba(93,211,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}
.window-strip{
  display:flex; gap: clamp(14px, 2vw, 18px);
  overflow:auto; padding: clamp(12px, 2vw, 16px);
  scroll-snap-type: x mandatory; scroll-padding-left: clamp(12px, 2vw, 16px);
}
.pane{ flex:0 0 auto; width:min(86vw, 350px); scroll-snap-align: start; border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08); padding:10px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.pane figcaption{ font-size:12px; color:var(--muted); margin-top:6px; }
.window-hint{ color:var(--muted); font-size:13px; margin:8px 2px 0; }

/* ===== SECTION 7: Monsoon Compass ===== */
.compass-section{ padding: clamp(28px, 6vw, 72px) 0; }
.dial-grid{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px, 2vw, 20px);
}
.dial-card{
  grid-column: span 4; padding:14px; border-radius: calc(var(--radius) + 4px);
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(600px 200px at 50% -10%, rgba(138,255,193,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.dial-card h3{ margin:10px 0 6px 0; font-size: clamp(16px, 2vw, 20px); }
.dial-card p{ margin:0; color:var(--muted); }

.dial{
  width:110px; height:110px; border-radius:50%;
  background:
    conic-gradient(from 210deg, rgba(93,211,255,.25), rgba(93,211,255,.05) 60%, rgba(255,209,102,.35) 60% 80%, rgba(93,211,255,.25) 80% 100%);
  border:1px solid rgba(255,255,255,.12);
  position:relative;
  margin-bottom:10px;
}
.dial .needle{
  position:absolute; left:50%; top:50%; width:2px; height:44%;
  background:var(--ink); transform-origin: bottom center;
  animation: spin 6s linear infinite;
  box-shadow: 0 0 8px rgba(255,255,255,.5);
}
@keyframes spin{ to{ transform: translate(-50%, -100%) rotate(360deg); } }
.dial-card img{ width:100%; max-width:350px; aspect-ratio: 16/11; object-fit: cover; border-radius: calc(var(--radius) - 4px); }

@media (max-width:1100px){ .dial-card{ grid-column: span 6; } }
@media (max-width:780px){ .dial-card{ grid-column: span 12; } }
/* === FIX: стрелка компаса строго из центра === */
.compass-section .dial{
  position: relative;
  aspect-ratio: 1 / 1; /* на всякий случай, ровный круг */
}

/* базовое положение + ось поворота снизу по центру */
.compass-section .dial .needle{
  left: 50%;
  top: 50%;
  transform-origin: 50% 100%;
  transform: translate(-50%, -100%) rotate(0deg); /* теперь нижняя точка ровно в центре */
  will-change: transform;
}

/* анимация с явным from/to в том же положении */
@keyframes spin{
  0%   { transform: translate(-50%, -100%) rotate(0deg); }
  100% { transform: translate(-50%, -100%) rotate(360deg); }
}

/* маленькая ось в центре (визуальный хаб) */
.compass-section .dial::after{
  content:"";
  position:absolute;
  left:50%; top:50%;
  width:8px; height:8px; border-radius:50%;
  background: var(--ink);
  transform: translate(-50%, -50%);
  box-shadow: 0 0 6px rgba(255,255,255,.45);
}

/* ===== 9) Courtyard (без SVG) — уже был без SVG, оставляем ===== */
.courtyard-section{ padding: clamp(28px, 6vw, 72px) 0; }
.rhythm-grid{ display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px, 2vw, 20px); }
.rhythm-card{
  grid-column: span 6; padding:14px; border-radius: calc(var(--radius) + 4px);
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(800px 200px at 50% -10%, rgba(93,211,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.rhythm-card img{ width:100%; max-width:350px; aspect-ratio:16/11; object-fit:cover; border-radius: calc(var(--radius) - 4px); }
.rhythm-card h3{ margin:10px 0 6px 0; font-size: clamp(16px,2vw,20px); }
.rhythm-card p{ margin:0; color:var(--muted); }
.rhythm-line{ display:flex; gap:6px; margin-bottom:10px; opacity:.9; }
.rhythm-line span{
  display:block; width:10px; height:10px; border-radius:50%;
  background:var(--brand); animation: clap 1.2s ease-in-out infinite;
}
.rhythm-line span:nth-child(2){ animation-delay:.1s }
.rhythm-line span:nth-child(3){ animation-delay:.2s }
.rhythm-line span:nth-child(4){ animation-delay:.3s }
.rhythm-line span:nth-child(5){ animation-delay:.4s }
@media (max-width:900px){ .rhythm-card{ grid-column: span 12; } }
@keyframes clap{ 50%{ transform: scale(1.8); background:var(--brand-2); } }

/* ===== 10) Skyline Siesta без SVG ===== */
.siesta-section{ padding: clamp(28px, 6vw, 72px) 0; }
.siesta-scene{
  position:relative; border:1px solid rgba(255,255,255,.08); border-radius: var(--radius);
  padding:10px; background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow); overflow:hidden;
}

/* орбита — квадрат, видна только верхняя половина */
.orbit{
  position:absolute; inset:6px 6px auto 6px; height: min(48vw, 260px); aspect-ratio: 1 / 1;
  margin-inline:auto; left:0; right:0; pointer-events:none; z-index:0;
  clip-path: inset(0 0 50% 0); /* показываем верхнюю половину */
}
.arc-track{
  position:absolute; inset:0; border-radius:50%;
  /* «дорожка» без SVG: пунктир через градиент */
  background:
    radial-gradient(closest-side, transparent calc(100% - 2px), var(--brand-2) calc(100% - 2px)),
    conic-gradient(from 0deg, transparent 0 180deg, transparent 0 360deg);
  opacity:.45;
}
.arm{ position:absolute; left:50%; top:50%; width:0; height:0; transform-origin:0 0; }
.sun{
  position:absolute; left:0; top:0; width:14px; height:14px; border-radius:50%;
  background: var(--brand-2); box-shadow: 0 0 16px rgba(255,209,102,.65);
  transform: translateX(var(--orbitR, 120px)) translate(-50%, -50%);
}
.skyline{
  position:relative; z-index:2; width:100%; max-width:350px;
  border-radius: calc(var(--radius) - 4px);
  filter: brightness(var(--daylight, .95)) saturate(calc(.8 + var(--daylight, .95) * .4));
}
.siesta-note{ color:var(--muted); font-size:13px; margin-top:6px; }
/* ===== SECTION 11: Desert Night Caravan ===== */
.caravan-section{ padding: clamp(28px, 6vw, 72px) 0; }
.night{
  position:relative; width:min(1200px,100%); margin-inline:auto;
  border:1px solid rgba(255,255,255,.08); border-radius: calc(var(--radius) + 6px);
  background:
    radial-gradient(900px 260px at 20% -10%, rgba(93,211,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  padding: clamp(14px, 3vw, 22px);
  overflow:hidden;
}
/* звездная пыль — чисто CSS без SVG */
.night::before, .night::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(2px 2px at 10% 20%, rgba(255,255,255,.8) 50%, transparent 51%),
    radial-gradient(2px 2px at 30% 70%, rgba(255,255,255,.7) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 60% 40%, rgba(255,255,255,.6) 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 85% 30%, rgba(255,255,255,.7) 50%, transparent 51%);
  animation: twinkle 4s ease-in-out infinite alternate;
  opacity:.35;
}
.night::after{ filter: blur(1px); opacity:.22; animation-duration:6s; }
@keyframes twinkle{ to{ opacity:.6; transform: translateY(-2px); } }

/* ступенчатая мозаика */
.step-mosaic{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr));
  gap: clamp(12px, 2vw, 18px);
}
.step-mosaic .dune{ 
  grid-column: span 4;
  padding:10px; border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow); transition: transform .25s ease;
}
.step-mosaic .dune:hover{ transform: translateY(-6px); }
.step-mosaic .dune img{
  width:100%; max-width:350px; aspect-ratio:16/11; object-fit:cover;
  border-radius: calc(var(--radius) - 4px);
}
.step-mosaic .dune figcaption{ font-size:12px; color:var(--muted); margin-top:6px; }

/* ступени по рядам */
.step-mosaic .dune:nth-child(1){ grid-column: 1 / span 4; }
.step-mosaic .dune:nth-child(2){ grid-column: 3 / span 4; }
.step-mosaic .dune:nth-child(3){ grid-column: 6 / span 4; }

@media (max-width:1100px){
  .step-mosaic{ grid-template-columns: repeat(8, minmax(0,1fr)); }
  .step-mosaic .dune:nth-child(1){ grid-column: 1 / span 8; }
  .step-mosaic .dune:nth-child(2){ grid-column: 1 / span 8; }
  .step-mosaic .dune:nth-child(3){ grid-column: 1 / span 8; }
}

/* ===== SECTION 12: City Intervals ===== */
.intervals-section{ padding: clamp(28px, 6vw, 72px) 0; }
.intervals-grid{
  display:grid; grid-template-columns: 260px 1fr; gap: clamp(16px, 3vw, 28px);
}
.meter-col{
  display:flex; flex-direction:column; gap:10px;
  padding:10px; border:1px solid rgba(255,255,255,.08); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.meter{
  height:36px; border-radius:999px; border:1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(90deg, rgba(93,211,255,.22), rgba(138,255,193,.22));
  position:relative; overflow:hidden;
}
.meter i{
  position:absolute; left:0; top:0; bottom:0; width:22%;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  border-radius: inherit;
  animation: fillA 3.6s ease-in-out infinite;
}
.meter:nth-child(2) i{ animation: fillB 3.9s ease-in-out infinite .2s; }
.meter:nth-child(3) i{ animation: fillC 3.4s ease-in-out infinite .1s; }
.meter:nth-child(4) i{ animation: fillD 4.2s ease-in-out infinite .3s; }
.meter:nth-child(5) i{ animation: fillE 3.2s ease-in-out infinite .15s; }

@keyframes fillA{ 0%{width:18%} 50%{width:72%} 100%{width:22%} }
@keyframes fillB{ 0%{width:12%} 50%{width:64%} 100%{width:18%} }
@keyframes fillC{ 0%{width:26%} 50%{width:78%} 100%{width:30%} }
@keyframes fillD{ 0%{width:16%} 50%{width:58%} 100%{width:20%} }
@keyframes fillE{ 0%{width:22%} 50%{width:86%} 100%{width:26%} }

.urban-cards{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px, 2vw, 20px);
}
.urban{ grid-column: span 6; padding:12px; border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow); transition: transform .25s ease;
}
.urban:hover{ transform: translateY(-6px); }
.urban img{ width:100%; max-width:350px; aspect-ratio:16/11; object-fit:cover; border-radius: calc(var(--radius) - 4px); }
.urban figcaption{ font-size:12px; color:var(--muted); margin-top:6px; }
.urban h3{ margin:10px 0 6px 0; font-size: clamp(16px, 2vw, 20px); }
.urban p{ margin:0; color:var(--muted); }

@media (max-width:900px){
  .intervals-grid{ grid-template-columns: 1fr; }
  .urban{ grid-column: span 12; }
}

/* ===== SECTION 13: Tea House Vignettes ===== */
.chai-section{ padding: clamp(28px, 6vw, 72px) 0; }
.chai-grid{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px, 2vw, 20px);
}
.chai-card{
  grid-column: span 6; padding:14px; border-radius: calc(var(--radius) + 4px);
  border:1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(700px 220px at 50% -15%, rgba(255,209,102,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.chai-card img{ width:100%; max-width:350px; aspect-ratio:16/11; object-fit:cover; border-radius: calc(var(--radius) - 4px); }
.chai-card h3{ margin:10px 0 6px 0; font-size: clamp(16px, 2vw, 20px); }
.chai-card p{ margin:0; color:var(--muted); }

@media (max-width:900px){ .chai-card{ grid-column: span 12; } }

/* бегущий тикер цитат */
.quote-ticker{
  overflow:hidden; border:1px solid rgba(255,255,255,.08);
  border-radius: var(--radius); margin-top: clamp(12px, 2vw, 16px);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}
.ticker-track{
  display:flex; gap:60px; padding:10px 16px; white-space:nowrap;
  animation: ticker 24s linear infinite;
}
.ticker-track p{ margin:0; color:var(--muted); }
@keyframes ticker{ to{ transform: translateX(-50%); } }
/* ===== SECTION 14: Manifest ===== */
.manifest-section{ padding: clamp(28px,6vw,72px) 0; }
.manifest-stack{
  position:relative; counter-reset: step; margin:0; padding:0; list-style:none;
  border-left:2px dashed rgba(93,211,255,.55);
  margin-left: clamp(10px,2vw,16px); padding-left: clamp(14px,2vw,18px);
}
.m-line{
  position:relative; margin: 14px 0; padding:14px 16px;
  border:1px solid rgba(255,255,255,.08); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.m-line::before{
  counter-increment: step; content: counter(step);
  position:absolute; left: -28px; top: 16px;
  width:22px; height:22px; border-radius:50%;
  background: var(--brand-2); color:#0b0e13; font-weight:700; display:grid; place-items:center;
  box-shadow: 0 0 10px rgba(255,209,102,.55);
}
.m-line h3{ margin:0 0 6px 0; font-size: clamp(16px,2vw,20px); }
.m-line p{ margin:0; color:var(--muted); }
.m-line.is-on{ outline: 2px solid rgba(93,211,255,.35); background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); }

/* ===== SECTION 15: Weights ===== */
.weights-section{ padding: clamp(28px,6vw,72px) 0; }
.weights-board{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr));
  gap: clamp(14px,2vw,20px);
}
.weight{
  grid-column: span 6; padding:14px; border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.weight h3{ margin:0 0 8px 0; font-size: clamp(16px,2vw,20px); }
.weight p{ margin:0 0 10px 0; color:var(--muted); }
.bar{
  height:14px; border-radius:999px; border:1px solid rgba(255,255,255,.1);
  background: linear-gradient(90deg, rgba(93,211,255,.18), rgba(138,255,193,.18));
  overflow:hidden; position:relative;
}
.fill{
  display:block; height:100%; width:0%;
  background: linear-gradient(90deg, var(--brand), var(--brand-2));
  border-radius: inherit; box-shadow: 0 6px 16px rgba(0,0,0,.25);
  transition: width 1.2s cubic-bezier(.2,.8,.2,1);
}
@media (max-width:900px){ .weight{ grid-column: span 12; } }

/* ===== SECTION 16: Doors ===== */
.closing-section{ padding: clamp(28px,6vw,72px) 0; }
.doors{
  display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(14px,2vw,20px);
}
.door{
  grid-column: span 4; position:relative; display:flex; flex-direction:column; gap:6px;
  padding:18px; text-decoration:none; color:var(--ink);
  border:1px solid rgba(255,255,255,.08); border-radius: calc(var(--radius) + 4px);
  background:
    radial-gradient(700px 220px at 50% -10%, rgba(93,211,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: var(--shadow); overflow:hidden;
  perspective: 800px;
}
.door .leaf{
  position:absolute; inset:10px; border-radius: calc(var(--radius) - 2px);
  background: linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  transform-origin: left center; transform: rotateY(0deg);
  transition: transform .6s cubic-bezier(.2,.8,.2,1);
}
.door:hover .leaf{ transform: rotateY(-24deg); }
.door strong{ font-size: clamp(16px,2vw,20px); z-index:1; }
.door em{ color:var(--muted); font-style:normal; z-index:1; }
@media (max-width:900px){ .door{ grid-column: span 12; } }
/* ===== CONTACT FORM (Section 15) ===== */
.contact-section{ padding: clamp(28px,6vw,72px) 0; }
.contact-form{
  border:1px solid rgba(255,255,255,.08);
  border-radius: calc(var(--radius) + 4px);
  background:
    radial-gradient(900px 260px at 60% -10%, rgba(93,211,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  padding: clamp(16px,3vw,24px);
  display:grid; gap: clamp(12px,2vw,18px);
}

.fields-row{ display:grid; grid-template-columns: repeat(12, minmax(0,1fr)); gap: clamp(12px,2vw,18px); }
.field{ grid-column: span 6; display:grid; gap:6px; }
.field--area{ grid-column: 1 / -1; position:relative; }
.label{ font-size:14px; color:var(--muted); }

.contact-form input,
.contact-form textarea{
  width:100%; color:var(--ink);
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding: 12px 14px;
  outline: none;
  transition:border-color .2s ease, box-shadow .2s ease, transform .08s ease;
}
.contact-form textarea{ min-height: 140px; resize: vertical; }

.contact-form input:focus,
.contact-form textarea:focus{
  border-color: rgba(93,211,255,.5);
  box-shadow: var(--ring);
}

.contact-form input:invalid:focus,
.contact-form textarea:invalid:focus{
  border-color: #ff8b8b;
  box-shadow: 0 0 0 2px rgba(255,139,139,.25);
}

.form-checkbox{ display:flex; align-items:center; gap:10px; font-size:14px; color:var(--muted); }
.form-checkbox a{ color:var(--brand); text-decoration:none; }
.form-checkbox a:hover{ text-decoration:underline; }

.cta-button{
  justify-self:start;
  border:1px solid rgba(255,255,255,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  color:var(--ink); padding:12px 18px; border-radius:16px; cursor:pointer;
  transition: transform .15s ease, box-shadow .2s ease, opacity .2s ease;
}
.cta-button:hover{ transform: translateY(-2px); box-shadow: var(--shadow); }
.cta-button[disabled]{ opacity:.55; cursor:not-allowed; }

.counter{
  position:absolute; right:12px; bottom:12px; font-size:12px; color:var(--muted);
  background: rgba(0,0,0,.25); padding:2px 6px; border-radius:10px;
}
.form-note{ color:var(--muted); font-size:13px; margin: 6px 2px 0; }

@media (max-width:900px){
  .field{ grid-column: span 12; }
}
/* === CONTACT FORM — FIX checkbox + nicer CTA === */

/* 1) Ограничим общие поля только текст/почта/textarea */
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form textarea{
  width:100%;
}

/* 2) Красивый чекбокс (не растягивается) */
.form-checkbox input[type="checkbox"]{
  appearance: none;
  width:18px; height:18px;
  margin:0; padding:0;
  border:1.5px solid rgba(255,255,255,.6);
  border-radius:4px;
  background: rgba(255,255,255,.03);
  box-shadow: none;
  display:inline-grid; place-items:center;
  transition: border-color .2s ease, background-color .2s ease, box-shadow .2s ease;
}
.form-checkbox input[type="checkbox"]:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(93,211,255,.35);
  border-color: var(--brand);
}
.form-checkbox input[type="checkbox"]::after{
  content:"";
  width:10px; height:10px; border-radius:2px;
  transform: scale(0); transition: transform .16s ease;
  background: linear-gradient(180deg, var(--brand), var(--brand-2));
  box-shadow: 0 0 8px rgba(255,209,102,.45);
}
.form-checkbox input[type="checkbox"]:checked::after{ transform: scale(1); }

/* Текст справа от чекбокса */
.form-checkbox{ gap:10px; align-items:center; }
.form-checkbox span{ color:var(--muted); line-height:1.4; }
.form-checkbox a{ color:var(--brand); text-decoration:none; }
.form-checkbox a:hover{ text-decoration:underline; }

/* 3) Кнопка — компактнее и выразительнее */
.cta-button{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid rgba(255,255,255,.18);
  background:
    linear-gradient(180deg, rgba(93,211,255,.22), rgba(93,211,255,.10)),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  color:var(--ink);
  padding:12px 18px;
  border-radius:16px;
  cursor:pointer;
  box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .2s ease, opacity .2s ease, filter .2s ease;
}
.cta-button:hover{ transform: translateY(-2px); box-shadow: 0 16px 40px rgba(0,0,0,.35); }
.cta-button[disabled]{ opacity:.55; cursor:not-allowed; filter: grayscale(.25); }
/* === FIX: Contact form layout (stack items, stop button stretching) === */
.contact-form{
  display: grid;                         /* гарантируем грид у формы */
  grid-template-columns: repeat(12, minmax(0,1fr));
  grid-auto-flow: row;                   /* всё — построчно */
  align-items: start;                    /* не растягивать по высоте */
}

.contact-form .fields-row{ grid-column: 1 / -1; }
.contact-form .form-checkbox{ grid-column: 1 / -1; }
.contact-form .cta-button{ 
  grid-column: 1 / -1; 
  justify-self: start; 
  align-self: start; 
  height: auto; 
  min-height: 44px;                      /* удобнее жать */
}
.contact-form .form-note{ grid-column: 1 / -1; }

/* гарантируем, что внутренности не «выпирают» */
.contact-form *{ min-width: 0; }

/* мобильная колонка (если вдруг не было) */
@media (max-width: 900px){
  .contact-form .field{ grid-column: span 12; }
}
