:root {
	--bg: #f6f2eb;
	--bg-soft: #fbf8f3;
	--surface: rgba(255, 255, 255, 0.84);
	--surface-solid: #ffffff;
	--text: #171717;
	--muted: #66615a;
	--accent: #eb1f27;
	--accent-dark: #b01218;
	--line: rgba(23, 23, 23, .08);
	--line-strong: rgba(23, 23, 23, .14);
	--shadow: 0 24px 80px rgba(17, 17, 17, .08);
	--shadow-soft: 0 10px 32px rgba(17, 17, 17, .06);
	--radius-xl: 30px;
	--radius-lg: 22px;
	--radius-md: 16px;
	--container-wide: min(1720px, calc(100% - 64px));
	--container: min(1560px, calc(100% - 64px));
	--container-narrow: min(1040px, calc(100% - 64px));
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: Inter, "Segoe UI", Arial, sans-serif;
	color: var(--text);
	line-height: 1.58;
	background:
		radial-gradient(circle at 90% 8%, rgba(235, 31, 39, .08), transparent 18%),
		radial-gradient(circle at 0% 100%, rgba(235, 31, 39, .06), transparent 20%),
		linear-gradient(180deg, #fcfaf7 0%, var(--bg) 48%, #efe7da 100%);
}

img {
	max-width: 100%;
	display: block;
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
textarea,
select {
	font: inherit;
}

.container-wide,
.container,
.container-narrow {
	margin: 0 auto;
	width: 100%;
}

.container-wide {
	max-width: var(--container-wide);
}

.container {
	max-width: var(--container);
}

.container-narrow {
	max-width: var(--container-narrow);
}

.topbar {
	position: sticky;
	top: 0;
	z-index: 100;
	backdrop-filter: blur(18px);
	background: rgba(248, 245, 240, .82);
	border-bottom: 1px solid var(--line);
}

.nav {
	min-height: 82px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.brand {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
}

.brand-mark {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	padding: 10px;
	background: rgba(255, 255, 255, .95);
	box-shadow: var(--shadow-soft);
	flex: 0 0 auto;
}

.brand-title {
	font-size: 1.15rem;
	font-weight: 800;
	letter-spacing: -.02em;
}

.brand-subtitle {
	color: var(--muted);
	font-size: .92rem;
}

.nav-links {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	justify-content: flex-end;
}

.nav-links a {
	padding: 11px 16px;
	border-radius: 999px;
	color: var(--muted);
	transition: .24s ease;
}

.nav-links a:hover,
.nav-links a.active {
	background: rgba(255, 255, 255, .96);
	color: var(--text);
	box-shadow: var(--shadow-soft);
}

.panel,
.card,
.hero-copy,
.hero-media,
.section-card,
.placeholder,
.feature-card,
.gallery-card,
.property-card,
.doc-card,
.policy-card,
.contact-card,
.price-card,
.plan-card,
.cta-card,
.stat-card,
.form-wrap,
.summary-card {
	background: var(--surface);
	border: 1px solid rgba(255, 255, 255, .72);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow);
	backdrop-filter: blur(18px);
	overflow: hidden;
}

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 9px 14px;
	border-radius: 999px;
	background: rgba(235, 31, 39, .09);
	color: var(--accent-dark);
	font-weight: 700;
	font-size: .9rem;
}

.eyebrow::before {
	content: "";
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--accent);
}

h1,
h2,
h3,
h4,
h5 {
	margin: 0;
	line-height: 1.04;
}

h1 {
	font-size: clamp(3rem, 5.7vw, 6rem);
	letter-spacing: -.055em;
	margin-bottom: 20px;
}

h2.section-title,
.page-hero h1 {
	font-size: clamp(2.6rem, 4.8vw, 5rem);
	letter-spacing: -.05em;
}

h3 {
	font-size: clamp(1.35rem, 2vw, 1.8rem);
	letter-spacing: -.03em;
}

.accent,
.section-title span,
h1 span,
.page-hero h1 span {
	color: var(--accent);
}

.lead {
	font-size: clamp(1.08rem, 1.4vw, 1.22rem);
	color: var(--muted);
	max-width: 62ch;
}

.muted {
	color: var(--muted);
}

.muted-light {
	color: rgba(255, 255, 255, .82);
}

.small {
	font-size: .94rem;
}

.button,
.button-secondary,
.button-ghost {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 0 24px;
	border-radius: 999px;
	border: 1px solid transparent;
	font-weight: 750;
	transition: .25s ease;
	cursor: pointer;
}

.button {
	color: #fff;
	background: linear-gradient(135deg, var(--accent), #ff3a42);
	box-shadow: 0 14px 30px rgba(235, 31, 39, .28);
}

.button-secondary {
	background: rgba(255, 255, 255, .92);
	border-color: var(--line);
}

.button-ghost {
	border-color: var(--line-strong);
	background: transparent;
}

.button:hover,
.button-secondary:hover,
.button-ghost:hover {
	transform: translateY(-2px);
}

.actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
}

.hero {
	padding: 54px 0 28px;
}

.hero-grid {
	display: grid;
	grid-template-columns: 1.04fr .96fr;
	gap: 30px;
	align-items: start;
}

.hero-copy {
	padding: 40px;
	display: flex;
	flex-direction: column;
	gap: 26px;
	justify-content: space-between;
}

.hero-stats {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

.hero-stat {
	background: rgba(255, 255, 255, .78);
	border: 1px solid rgba(23, 23, 23, .06);
	border-radius: 20px;
	padding: 18px;
}

.hero-stat strong {
	display: block;
	font-size: 1.2rem;
	margin-bottom: 4px;
}

@media (min-width: 1180px) {
  .hero .hero-grid {
    --hero-gap: 20px;
    --hero-media-width: clamp(470px, 39vw, 700px);
    --hero-card-pad-x: clamp(28px, 2.25vw, 34px);
    --hero-card-pad-top: clamp(32px, 2.7vw, 40px);
    --hero-card-pad-bottom: clamp(22px, 2vw, 28px);
    --hero-notch-height: clamp(360px, 35vw, 430px);
    --hero-card-radius: 24px;
    --hero-card-bg: #fff;

    position: relative;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) var(--hero-media-width) !important;
    column-gap: var(--hero-gap) !important;
    row-gap: 0 !important;
    align-items: start !important;
  }

  .hero .hero-copy {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
    position: relative !important;
    isolation: isolate;
    z-index: 1;

    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: var(--hero-card-pad-top)
             calc(var(--hero-media-width) + var(--hero-gap) + var(--hero-card-pad-x))
             var(--hero-card-pad-bottom)
             var(--hero-card-pad-x) !important;

    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    filter: none !important;
    overflow: visible !important;
    clip-path: none !important;
  }

  .hero .hero-copy::before,
  .hero .hero-copy::after {
    content: "";
    position: absolute;
    z-index: -1;
    pointer-events: none;
    background: var(--hero-card-bg);
  }

  /* Вертикальная часть L. Здесь скругляется верхний правый угол у выреза под фото. */
  .hero .hero-copy::before {
    left: 0;
    top: 0;
    bottom: 0;
    width: calc(100% - var(--hero-media-width) - var(--hero-gap));
    border-radius: var(--hero-card-radius);
    box-shadow: 0 22px 52px rgba(20, 16, 14, .07);
  }

  /* Нижняя полка L. Верхний правый угол тоже скруглен. */
  .hero .hero-copy::after {
    left: 0;
    right: 0;
    top: var(--hero-notch-height);
    bottom: 0;
    border-radius: 0 var(--hero-card-radius) var(--hero-card-radius) var(--hero-card-radius);
    box-shadow: 0 22px 52px rgba(20, 16, 14, .07);
  }

  .hero .hero-copy > * {
    position: relative;
    z-index: 2;
  }

  .hero .hero-copy > div:first-child,
  .hero .hero-copy .actions {
    max-width: min(690px, calc(100vw - var(--hero-media-width) - 150px)) !important;
  }

  .hero .hero-copy h1 {
    font-size: clamp(54px, 4.45vw, 72px) !important;
    line-height: .96 !important;
    letter-spacing: -.065em !important;
    max-width: 100% !important;
  }

  .hero .hero-copy .lead {
    max-width: 660px !important;
  }

  .hero .hero-copy .actions {
    margin-top: clamp(22px, 2.1vw, 30px) !important;
  }

  .hero .hero-media {
    grid-column: 2 !important;
    grid-row: 1 !important;
    position: relative !important;
    z-index: 3;
    width: 100% !important;
    align-self: start !important;
    margin: 0 !important;
  }

  .hero .hero-slideshow {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    aspect-ratio: 1.42 / 1 !important;
  }

  .hero .hero-stats {
    position: relative !important;
    inset: auto !important;
    z-index: 2;

    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;

    width: auto !important;
    margin: clamp(22px, 2vw, 28px)
            calc(-1 * (var(--hero-media-width) + var(--hero-gap)))
            0
            0 !important;
    padding: 0 !important;
  }

  .hero .hero-stat {
    min-height: 84px !important;
  }
}

@media (min-width: 1180px) and (max-width: 1320px) {
  .hero .hero-grid {
    --hero-media-width: clamp(455px, 38vw, 500px);
    --hero-notch-height: 358px;
  }

  .hero .hero-copy > div:first-child,
  .hero .hero-copy .actions {
    max-width: min(650px, calc(100vw - var(--hero-media-width) - 140px)) !important;
  }

  .hero .hero-copy h1 {
    font-size: clamp(52px, 4.25vw, 62px) !important;
  }
}

@media (min-width: 1600px) {
  .hero .hero-grid {
    --hero-media-width: 700px;
    --hero-notch-height: 430px;
  }

  .hero .hero-copy > div:first-child,
  .hero .hero-copy .actions {
    max-width: 740px !important;
  }
}

.hero-media {
	padding: 24px;
	background: linear-gradient(160deg, rgba(17, 17, 17, .88), rgba(17, 17, 17, .68));
	color: #fff;
	position: relative;
	overflow: hidden;
}

.hero-media .media-frame {
	min-height: 620px;
	border-radius: 26px;
	border: 1px solid rgba(255, 255, 255, .14);
	background:
		linear-gradient(rgba(255, 255, 255, .04), rgba(255, 255, 255, .02)),
		radial-gradient(circle at 50% 30%, rgba(255, 255, 255, .07), transparent 36%),
		rgba(255, 255, 255, .04);
	display: grid;
	place-items: center;
	text-align: center;
	padding: 40px;
	position: relative;
	overflow: hidden;
}

.hero-slideshow {
  position: relative;
  width: 100%;
  min-height: 520px;
  border-radius: 28px;
  overflow: hidden;
  background: #111;
}

.hero-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.035);
  transition: opacity 2.2s ease, transform 7s ease;
}

.hero-slide.is-active {
  opacity: 1;
  transform: scale(1);
}

.hero-tour-link {
  position: absolute;
  left: 50%;
  bottom: 34px;
  transform: translateX(-50%);
  z-index: 5;
  padding: 16px 26px;
  border-radius: 999px;
  background: #fff;
  color: #000;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 14px 35px rgba(255, 46, 46, 0.35);
  white-space: nowrap;
}

@media (max-width: 768px) {
  .hero-slideshow {
    min-height: 360px;
  }

  .hero-tour-link {
    width: calc(100% - 36px);
    text-align: center;
    bottom: 20px;
  }
}


.play-badge {
	width: 86px;
	height: 86px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .12);
	border: 1px solid rgba(255, 255, 255, .18);
	display: grid;
	place-items: center;
	font-size: 1.35rem;
	margin: 0 auto 20px;
}

.floating {
	position: absolute;
	max-width: 270px;
	padding: 16px 18px;
	border-radius: 20px;
	background: rgba(255, 255, 255, .1);
	border: 1px solid rgba(255, 255, 255, .14);
	box-shadow: var(--shadow-soft);
}

.floating.top {
	top: 18px;
	right: 18px;
}

.floating.bottom {
	left: 18px;
	bottom: 18px;
}

.section {
	padding: 28px 0;
}

.section-head {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
	gap: 26px;
	align-items: end;
	margin-bottom: 22px;
}

.two-col {
	display: grid;
	grid-template-columns: minmax(0, 1.06fr) minmax(320px, .94fr);
	gap: 24px;
}

.three-col,
.grid-3 {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}

.grid-4 {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.feature-card,
.gallery-card,
.doc-card,
.price-card,
.plan-card,
.stat-card,
.summary-card {
	padding: 28px;
}

.feature-card p,
.gallery-card p,
.doc-card p,
.price-card p,
.plan-card p,
.summary-card p {
	margin: 12px 0 0;
}

.icon-chip,
.letter-chip {
	width: 54px;
	height: 54px;
	border-radius: 18px;
	display: grid;
	place-items: center;
	color: var(--accent);
	background: rgba(235, 31, 39, .08);
	font-weight: 800;
	font-size: 1.7rem;
	margin-bottom: 18px;
}

.placeholder {
	padding: 24px;
	min-height: 100%;
}

.placeholder .tag {
	display: inline-flex;
	padding: 8px 12px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .16);
	background: rgba(255, 255, 255, .08);
	color: #fff;
	font-size: .92rem;
	margin-bottom: 18px;
}

.placeholder-frame,
.visual {
	min-height: 320px;
	border-radius: 24px;
	border: 1px dashed rgba(23, 23, 23, .18);
	display: grid;
	place-items: center;
	text-align: center;
	color: var(--muted);
	overflow: hidden;
}

.visual.large {
	min-height: 420px;
}

.visual.dark {
	background: linear-gradient(145deg, rgba(17, 17, 17, .88), rgba(17, 17, 17, .74));
	color: rgba(255, 255, 255, .86);
	border-color: rgba(255, 255, 255, .12);
}
.visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.property-card {
	padding: 28px;
	display: flex;
	flex-direction: column;
	justify-content: end;
	gap: 20px;
}

.property-top {
	display: flex;
	flex-direction: column;
	gap: 14px;
	margin-bottom: auto;
}

.property-badge {
	display: inline-flex;
	width: fit-content;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(235, 31, 39, .09);
	color: var(--accent-dark);
	font-weight: 700;
}

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

.spec {
	padding: 9px 12px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .86);
	border: 1px solid var(--line);
	font-size: .94rem;
}

.page-hero {
	padding: 54px 0 24px;
}

.breadcrumbs {
	color: var(--muted);
	margin-bottom: 18px;
}

.page-hero-card {
	padding: 36px;
}

.price-table {
	display: grid;
	gap: 14px;
}

.price-row {
	display: grid;
	grid-template-columns: 1.2fr .8fr .7fr;
	gap: 12px;
	align-items: center;
	padding: 18px 20px;
	background: rgba(255, 255, 255, .84);
	border: 1px solid var(--line);
	border-radius: 20px;
}

.price-label {
	font-weight: 700;
}

.price-value {
	font-weight: 800;
}

.check-list {
	display: grid;
	gap: 12px;
	margin: 16px 0 0;
}

.check-item {
	display: grid;
	grid-template-columns: 22px 1fr;
	gap: 12px;
	align-items: start;
}

.check-item::before {
	content: "✓";
	color: var(--accent);
	font-weight: 900;
}

.form-wrap {
	padding: 30px;
}

.form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.form-group.full {
	grid-column: 1 / -1;
}

.form-group label {
	font-weight: 700;
}

input,
textarea,
select {
	width: 100%;
	min-height: 58px;
	padding: 0 18px;
	border-radius: 18px;
	border: 1px solid rgba(23, 23, 23, .12);
	background: rgba(255, 255, 255, .94);
	color: var(--text);
	outline: none;
	transition: .2s ease;
}

textarea {
	padding: 16px 18px;
	resize: vertical;
	min-height: 132px;
}

input:focus,
textarea:focus,
select:focus {
	border-color: rgba(235, 31, 39, .45);
	box-shadow: 0 0 0 4px rgba(235, 31, 39, .08);
}

.contact-field {
	display: none;
}

.contact-field.active {
	display: block;
}

.form-note {
	color: var(--muted);
	font-size: .95rem;
}

.checks {
	display: grid;
	gap: 10px;
	margin-top: 8px;
}

.checks label {
	display: grid;
	grid-template-columns: 18px 1fr;
	gap: 10px;
	align-items: start;
	font-weight: 500;
	color: var(--muted);
}

.checks input[type="checkbox"] {
	min-height: auto;
	width: 18px;
	height: 18px;
	margin-top: 4px;
}

.submit-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: 10px;
}

.doc-list {
	display: grid;
	gap: 16px;
}

.doc-item {
	display: grid;
	grid-template-columns: 80px 1fr auto;
	gap: 18px;
	align-items: center;
	padding: 22px;
	border-radius: 22px;
	background: rgba(255, 255, 255, .86);
	border: 1px solid var(--line);
}

.doc-icon {
	width: 80px;
	height: 80px;
	border-radius: 24px;
	display: grid;
	place-items: center;
	background: rgba(235, 31, 39, .08);
	color: var(--accent);
	font-size: 1.15rem;
	font-weight: 800;
}

.policy-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 20px;
	margin-top: 22px;
}

.policy-card {
	padding: 30px;
}

.policy-card ol,
.policy-card ul {
	margin: 12px 0 0 20px;
}

.contact-layout {
	display: grid;
	grid-template-columns: .88fr 1.12fr;
	gap: 24px;
}

.contact-card {
	padding: 30px;
}

.contact-list {
	display: grid;
	gap: 14px;
	margin-top: 18px;
}

.contact-list a,
.contact-list div {
	padding: 14px 16px;
	background: rgba(255, 255, 255, .86);
	border: 1px solid var(--line);
	border-radius: 18px;
}

.cta-band {
	padding: 28px 0 56px;
}

.cta-card {
	padding: 34px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 20px;
	align-items: center;
}

.footer {
	padding: 26px 0 42px;
}

.footer-inner {
	display: flex;
	gap: 16px;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	color: var(--muted);
}

.footer-links {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.reveal {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity .6s ease, transform .6s ease;
}

.reveal.visible {
	opacity: 1;
	transform: translateY(0);
}

@media (max-width: 1180px) {

	.hero-grid,
	.two-col,
	.contact-layout,
	.section-head,
	.cta-card,
	.policy-layout {
		grid-template-columns: 1fr;
	}

	.grid-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 920px) {
	:root {
		--container-wide: calc(100% - 32px);
		--container: calc(100% - 32px);
		--container-narrow: calc(100% - 32px);
	}

	.nav {
		min-height: 74px;
		align-items: flex-start;
		padding: 14px 0;
	}

	.nav-links {
		gap: 6px;
	}

	.hero-copy,
	.hero-media,
	.page-hero-card,
	.feature-card,
	.gallery-card,
	.doc-card,
	.policy-card,
	.contact-card,
	.form-wrap,
	.property-card,
	.plan-card,
	.price-card,
	.summary-card {
		padding: 24px;
	}

	.hero-stats,
	.grid-3,
	.three-col {
		grid-template-columns: 1fr;
	}

	.grid-4 {
		grid-template-columns: 1fr;
	}

	.form-grid {
		grid-template-columns: 1fr;
	}

	.price-row,
	.doc-item {
		grid-template-columns: 1fr;
	}

	.hero-media .media-frame {
		min-height: 440px;
	}

	.floating {
		position: static;
		margin-top: 12px;
		max-width: none;
	}
}

@media (max-width: 640px) {
	body {
		line-height: 1.5;
	}

	h1 {
		font-size: clamp(2.35rem, 12vw, 3.7rem);
	}

	h2.section-title,
	.page-hero h1 {
		font-size: clamp(2rem, 10vw, 3.1rem);
	}

	.brand-title {
		font-size: 1rem;
	}

	.brand-subtitle {
		font-size: .82rem;
	}

	.hero {
		padding-top: 28px;
	}

	.hero-copy {
		gap: 22px;
	}

	.button,
	.button-secondary,
	.button-ghost {
		width: 100%;
	}

	.actions {
		flex-direction: column;
	}

	.hero-stat {
		padding: 16px;
	}

	.visual.large,
	.placeholder-frame,
	.hero-media .media-frame {
		min-height: 300px;
	}
}

/* Added after client corrections */
.tour-panel {
	padding: 24px;
	background: linear-gradient(160deg, rgba(17, 17, 17, .92), rgba(17, 17, 17, .72));
	color: #fff;
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow-card);
}

.tour-panel-head {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 18px;
	align-items: start;
	margin-bottom: 20px;
}

.tour-panel h2 {
	margin-top: 14px;
	font-size: clamp(1.8rem, 3vw, 2.8rem);
	letter-spacing: -.05em;
}

.tour-button {
	border: 1px solid rgba(255, 255, 255, .18);
	background: rgba(255, 255, 255, .12);
	color: #fff;
	border-radius: 999px;
	padding: 14px 18px;
	font-weight: 800;
	cursor: pointer;
	white-space: nowrap;
}

.tour-gallery {
	display: grid;
	grid-template-columns: minmax(0, 1.16fr) minmax(220px, .84fr);
	gap: 16px;
}

.tour-image-card {
	position: relative;
	min-height: 250px;
	margin: 0;
	border-radius: 26px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, .14);
	background: rgba(255, 255, 255, .06);
}

.tour-image-card.large {
	min-height: 520px;
}

.tour-image-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	position: absolute;
	inset: 0;
}

.tour-image-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 42%, rgba(0, 0, 0, .62));
}

.tour-image-card figcaption {
	position: absolute;
	left: 18px;
	right: 18px;
	bottom: 18px;
	z-index: 1;
	font-weight: 800;
	color: #fff;
}

.image-visual {
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
	color: #fff;
	border: 0;
}

.image-visual::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, .08), rgba(0, 0, 0, .52));
}

.image-visual[data-label]::before {
	position: relative;
	z-index: 1;
	align-self: end;
	background: rgba(0, 0, 0, .45);
	color: #fff;
	padding: 10px 14px;
	border-radius: 999px;
	backdrop-filter: blur(10px);
}

@media (max-width: 920px) {

	.tour-panel-head,
	.tour-gallery {
		grid-template-columns: 1fr;
	}

	.tour-button {
		width: fit-content;
	}

	.tour-image-card.large,
	.tour-image-card {
		min-height: 300px;
	}
}


.contact-card-bright {
	background:
		radial-gradient(circle at 18% 0%, rgba(255, 255, 255, .9), transparent 34%),
		linear-gradient(135deg, rgba(235, 31, 39, .12), rgba(255, 255, 255, .94) 42%, rgba(255, 255, 255, .86));
	border: 1px solid rgba(235, 31, 39, .18);
}

.contact-card-bright .contact-list a,
.contact-card-bright .contact-list div {
	background: rgba(255, 255, 255, .96);
	border-color: rgba(235, 31, 39, .16);
	box-shadow: 0 10px 26px rgba(235, 31, 39, .06);
}

.contact-card-bright .contact-list a:hover {
	transform: translateY(-2px);
	border-color: rgba(235, 31, 39, .32);
}

.map-card {
	padding: 30px;
	display: grid;
	grid-template-columns: .88fr 1.12fr;
	gap: 24px;
	align-items: stretch;
	background: var(--surface);
	border: 1px solid rgba(255, 255, 255, .72);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow);
	overflow: hidden;
}

.map-copy {
	padding: 8px;
}

.map-details {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: 22px;
}

.map-details span {
	padding: 10px 14px;
	border-radius: 999px;
	background: rgba(235, 31, 39, .08);
	color: var(--accent-dark);
	font-weight: 700;
}

.map {
	min-height: 420px;
	border-radius: 26px;
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(23, 23, 23, .08);
}

#map {
  height: 100%;
}


.road-main {
	width: 120%;
	height: 34px;
	left: -10%;
	top: 56%;
	transform: rotate(-13deg);
}

.road-second {
	width: 78%;
	height: 24px;
	right: -10%;
	top: 34%;
	transform: rotate(35deg);
	opacity: .72;
}

@media (max-width: 900px) {
	.map-card {
		grid-template-columns: 1fr;
	}

	.map-demo {
		min-height: 320px;
	}
}

.request-phone-box {
	margin: 10px 0 4px;
	padding: 26px 22px;
	border-radius: 30px;
	text-align: center;
	background: linear-gradient(135deg, rgba(235, 31, 39, .1), rgba(255, 255, 255, .9));
	border: 1px solid rgba(235, 31, 39, .18);
	box-shadow: 0 18px 50px rgba(235, 31, 39, .08);
}

.request-phone-caption {
	font-weight: 800;
	color: var(--accent-dark);
	margin-bottom: 8px;
}

.request-phone-link {
	display: inline-block;
	font-size: clamp(2rem, 4vw, 3.7rem);
	line-height: 1;
	letter-spacing: -.05em;
	font-weight: 900;
	color: var(--text);
	text-decoration: none;
}

.request-phone-link:hover {
	color: var(--accent);
}

.request-phone-text {
	max-width: 560px;
	margin: 12px auto 0;
	color: var(--muted);
	font-size: 1rem;
	line-height: 1.55;
}

.next-page-section {
	padding: 22px 0 48px;
}

.next-page-card {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 24px;
	align-items: center;
	min-height: 190px;
	padding: clamp(26px, 4vw, 42px);
	border-radius: var(--radius-xl);
	text-decoration: none;
	color: var(--text);
	background:
		radial-gradient(circle at 86% 50%, rgba(235, 31, 39, .2), transparent 24%),
		linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(255, 246, 246, .92));
	border: 1px solid rgba(235, 31, 39, .18);
	box-shadow: 0 24px 70px rgba(80, 42, 20, .12);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.next-page-card:hover {
	transform: translateY(-4px);
	border-color: rgba(235, 31, 39, .34);
	box-shadow: 0 30px 84px rgba(80, 42, 20, .18);
}

.next-page-card h2 {
	margin: 14px 0 8px;
	font-size: clamp(2.1rem, 5vw, 4.4rem);
	letter-spacing: -.06em;
}

.next-page-card p {
	max-width: 760px;
	color: var(--muted);
	font-size: 1.08rem;
	line-height: 1.65;
}

.next-arrow {
	width: 86px;
	height: 86px;
	border-radius: 999px;
	display: grid;
	place-items: center;
	font-size: 3.2rem;
	color: #fff;
	background: var(--accent);
	box-shadow: 0 18px 42px rgba(235, 31, 39, .28);
	animation: nextArrowPulse 1.8s ease-in-out infinite;
}

@keyframes nextArrowPulse {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(8px);
	}
}

.scroll-next-toast {
	position: fixed;
	left: 50%;
	bottom: 24px;
	z-index: 80;
	transform: translate(-50%, 20px);
	opacity: 0;
	pointer-events: none;
	width: min(620px, calc(100vw - 32px));
	padding: 16px 20px;
	border-radius: 22px;
	background: rgba(23, 23, 23, .92);
	color: #fff;
	box-shadow: 0 22px 70px rgba(0, 0, 0, .26);
	transition: opacity .25s ease, transform .25s ease;
	text-align: center;
	font-weight: 700;
}

.scroll-next-toast.visible {
	opacity: 1;
	transform: translate(-50%, 0);
}

.contact-card-bright {
	background:
		radial-gradient(circle at 82% 8%, rgba(235, 31, 39, .2), transparent 28%),
		linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(255, 239, 239, .9) 46%, rgba(255, 255, 255, .92));
	border: 1px solid rgba(235, 31, 39, .25);
	box-shadow: 0 26px 80px rgba(235, 31, 39, .12), var(--shadow);
}

.contact-card-bright .eyebrow {
	background: rgba(235, 31, 39, .14);
}

.contact-card-bright h2 {
	color: var(--accent-dark);
}

@media (max-width: 760px) {
	.next-page-card {
		grid-template-columns: 1fr;
	}

	.next-arrow {
		width: 72px;
		height: 72px;
		font-size: 2.7rem;
	}

	.request-phone-link {
		font-size: clamp(1.8rem, 9vw, 2.7rem);
	}
}

body.is-pulling-next {
	transform: translateY(var(--pull-distance, -34px));
	transition: transform .42s cubic-bezier(.2, .8, .2, 1);
}

body.page-leaving-next {
	transform: translateY(-70px);
	opacity: .88;
	transition: transform .22s ease, opacity .22s ease;
}

.scroll-next-toast strong {
	display: block;
	margin-bottom: 4px;
	font-size: .88rem;
	color: #fff;
}

.scroll-next-toast span {
	display: block;
	color: rgba(255, 255, 255, .86);
	font-weight: 600;
	line-height: 1.45;
}


/* Floor schema wide block */
.floor-schema-card {
	padding: clamp(26px, 4vw, 46px);
	background: linear-gradient(145deg, rgba(255, 255, 255, .98), rgba(250, 247, 241, .94));
	border: 1px solid rgba(255, 255, 255, .76);
	border-radius: var(--radius-xl);
	box-shadow: var(--shadow);
	overflow: hidden;
}

.floor-schema-head {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
	gap: 24px;
	align-items: end;
	margin-bottom: 28px;
}

.floor-schema-head h2 {
	margin-top: 18px;
	font-size: clamp(2.2rem, 4.5vw, 4.2rem);
	letter-spacing: -.055em;
}

.floor-schema-note {
	padding: 22px;
	border-radius: 26px;
	background: rgba(235, 31, 39, .075);
	border: 1px solid rgba(235, 31, 39, .12);
}

.floor-schema-note strong {
	display: block;
	font-size: 1.25rem;
	margin-bottom: 8px;
	color: var(--text);
}

.floor-schema-note span {
	display: block;
	color: var(--muted);
	line-height: 1.55;
}

.floor-schema-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.floor-plan-box {
	padding: 18px;
	border-radius: 28px;
	background: rgba(255, 255, 255, .72);
	border: 1px solid rgba(23, 23, 23, .08);
}

.floor-plan-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-bottom: 14px;
}

.floor-plan-top span {
	width: 42px;
	height: 42px;
	border-radius: 16px;
	display: grid;
	place-items: center;
	background: rgba(235, 31, 39, .1);
	color: var(--accent);
	font-weight: 900;
}

.floor-plan-top strong {
	flex: 1;
	font-size: 1.05rem;
}

.floor-plan-placeholder {
	min-height: 360px;
	border-radius: 22px;
	border: 1px dashed rgba(23, 23, 23, .22);
	background:
		linear-gradient(90deg, rgba(23, 23, 23, .035) 1px, transparent 1px),
		linear-gradient(180deg, rgba(23, 23, 23, .035) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, .9), rgba(243, 240, 233, .9));
	background-size: 28px 28px, 28px 28px, 100% 100%;
	display: grid;
	place-items: center;
	text-align: center;
	color: var(--muted);
	padding: 22px;
}

.floor-plan-placeholder b {
	display: block;
	color: var(--text);
	margin-bottom: 6px;
}

.floor-plan-placeholder span {
	display: block;
	font-size: .92rem;
}

.floor-plan-box p {
	margin: 14px 0 0;
	color: var(--muted);
	line-height: 1.55;
}

@media (max-width: 1180px) {
	.floor-schema-head {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.floor-schema-grid {
		grid-template-columns: 1fr;
	}

	.floor-plan-placeholder {
		min-height: 300px;
	}
}

@media (max-width: 640px) {
	.floor-schema-card {
		padding: 22px;
	}

	.floor-schema-head {
		gap: 18px;
		margin-bottom: 20px;
	}

	.floor-plan-box {
		padding: 14px;
		border-radius: 22px;
	}

	.floor-plan-placeholder {
		min-height: 240px;
	}

	.floor-plan-top {
		align-items: flex-start;
	}
}

/* v14 document visuals */
.schema-house-block {
	margin-top: 28px;
	padding-top: 24px;
	border-top: 1px solid rgba(20, 20, 20, .08);
}

.schema-house-title {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	align-items: flex-end;
	margin-bottom: 18px;
}

.schema-house-title span {
	display: inline-flex;
	align-items: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(255, 47, 61, .10);
	color: var(--accent-dark);
	font-weight: 800;
	font-size: .9rem;
}

.schema-house-title strong {
	max-width: 720px;
	font-size: .98rem;
	line-height: 1.5;
	color: var(--text);
	text-align: right;
}

.doc-plan-img {
	width: 100%;
	height: 310px;
	object-fit: contain;
	background: #fff;
	border: 1px solid rgba(20, 20, 20, .08);
	border-radius: 22px;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .7);
}

.doc-visual-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	margin-top: 24px;
}

.doc-visual-grid-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.doc-visual-card {
	padding: 16px;
	border-radius: 28px;
	background: rgba(255, 255, 255, .72);
	border: 1px solid rgba(20, 20, 20, .08);
	box-shadow: 0 18px 60px rgba(60, 45, 30, .08);
}

.doc-visual-card img {
	width: 100%;
	height: 390px;
	object-fit: contain;
	display: block;
	border-radius: 20px;
	background: #fff;
	border: 1px solid rgba(20, 20, 20, .08);
}

.doc-visual-card h3 {
	margin: 16px 0 8px;
	font-size: 1.25rem;
	letter-spacing: -.03em;
}

.doc-visual-card p {
	margin: 0;
	color: var(--muted);
	line-height: 1.55;
}

.doc-visual-card-wide img {
	height: min(72vw, 720px);
}

@media (max-width: 980px) {
	.schema-house-title {
		align-items: flex-start;
		flex-direction: column;
	}

	.schema-house-title strong {
		text-align: left;
	}

	.doc-visual-grid,
	.doc-visual-grid-2 {
		grid-template-columns: 1fr;
	}

	.doc-plan-img {
		height: 300px;
	}

	.doc-visual-card img {
		height: 360px;
	}
}

@media (max-width: 560px) {
	.doc-plan-img {
		height: 240px;
	}

	.doc-visual-card {
		padding: 12px;
		border-radius: 22px;
	}

	.doc-visual-card img {
		height: 260px;
		border-radius: 16px;
	}

	.doc-visual-card-wide img {
		height: 340px;
	}
}

/* v15 clickable schemes */
.scheme-pair {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(160px, .72fr);
	gap: 12px;
	align-items: stretch;
}

.scheme-thumb,
.scheme-placeholder-mini {
	width: 100%;
	padding: 0;
	border: 0;
	background: transparent;
	text-align: left;
	cursor: pointer;
	font: inherit;
}

.scheme-thumb {
	position: relative;
	display: block;
}

.scheme-thumb span {
	position: absolute;
	left: 12px;
	bottom: 12px;
	display: inline-flex;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(17, 17, 17, .78);
	color: #fff;
	font-size: .82rem;
	font-weight: 800;
	opacity: 0;
	transform: translateY(6px);
	transition: .22s ease;
}

.scheme-thumb:hover span {
	opacity: 1;
	transform: translateY(0);
}

.scheme-thumb:hover .doc-plan-img,
.scheme-placeholder-mini:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 50px rgba(60, 45, 30, .12);
}

.scheme-placeholder-mini {
	min-height: 310px;
	border-radius: 22px;
	border: 1px dashed rgba(235, 31, 39, .36);
	display: grid;
	place-items: center;
	text-align: center;
	padding: 18px;
	transition: .22s ease;
}

.scheme-placeholder-mini.large {
	min-height: 360px;
}

.scheme-placeholder-mini b {
	display: block;
	color: var(--text);
	margin-bottom: 8px;
}

.scheme-placeholder-mini small {
	display: block;
	color: var(--muted);
	line-height: 1.4;
}

.scheme-modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background: rgba(20, 16, 12, .72);
	backdrop-filter: blur(12px);
}

.scheme-modal.visible {
	display: flex;
}

.scheme-modal-card {
	width: min(1180px, 96vw);
	max-height: 92vh;
	overflow: hidden;
	border-radius: 30px;
	background: #fff;
	box-shadow: 0 30px 100px rgba(0, 0, 0, .35);
	border: 1px solid rgba(255, 255, 255, .5);
}

.scheme-modal-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 18px;
	padding: 16px 18px;
	border-bottom: 1px solid rgba(20, 20, 20, .08);
}

.scheme-modal-title {
	font-weight: 900;
	letter-spacing: -.02em;
}

.scheme-modal-close {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: 1px solid rgba(20, 20, 20, .12);
	background: rgba(250, 247, 241, .95);
	cursor: pointer;
	font-size: 22px;
	line-height: 1;
}

.scheme-modal-body {
	padding: 18px;
	max-height: calc(92vh - 76px);
	overflow: auto;
	background: linear-gradient(180deg, #fff, #faf7f1);
}

.scheme-modal-body img {
	width: 100%;
	height: auto;
	max-height: 78vh;
	object-fit: contain;
	display: block;
	background: #fff;
	border-radius: 18px;
}

.scheme-modal-placeholder {
	min-height: 68vh;
	border-radius: 22px;
	border: 1px dashed rgba(235, 31, 39, .4);
	background:
		linear-gradient(90deg, rgba(23, 23, 23, .04) 1px, transparent 1px),
		linear-gradient(180deg, rgba(23, 23, 23, .04) 1px, transparent 1px),
		linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(248, 244, 236, .96));
	background-size: 34px 34px, 34px 34px, 100% 100%;
	display: grid;
	place-items: center;
	text-align: center;
	padding: 28px;
}

.scheme-modal-placeholder b {
	font-size: clamp(1.6rem, 4vw, 3rem);
	letter-spacing: -.05em;
}

.scheme-modal-placeholder span {
	display: block;
	margin-top: 10px;
	color: var(--muted);
}

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

	.scheme-placeholder-mini,
	.scheme-placeholder-mini.large {
		min-height: 220px;
	}
}

/* Затемнённый фон */
.pano-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: rgba(10, 10, 12, 0.85);
	backdrop-filter: blur(8px);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.35s ease;
}

.pano-modal.visible {
	opacity: 1;
	pointer-events: auto;
}

/* Контейнер для iframe с анимацией раскрытия */
.pano-modal-frame {
	width: 92vw;
	height: 92vh;
	background: #000;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
	transform: scale(0.7);
	transform-origin: var(--ox, 50%) var(--oy, 50%);
	transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.pano-modal.visible .pano-modal-frame {
	transform: scale(1);
}

.pano-modal-frame iframe {
	width: 100%;
	height: 100%;
	border: none;
	display: block;
}

/* Кнопка закрытия */
.pano-modal-close {
	position: absolute;
	top: 24px;
	right: 24px;
	z-index: 10000;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.15);
	border: 1px solid rgba(255, 255, 255, 0.2);
	color: #fff;
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, transform 0.2s;
}

.pano-modal-close:hover {
	background: rgba(255, 255, 255, 0.3);
	transform: scale(1.1);
}



/* === Валидация формы === */
.form-group.error input,
.form-group.error select,
.form-group.error textarea {
	border-color: #e74c3c;
	background-color: #fff5f5;
}

.form-group.error label {
	color: #e74c3c;
}

.error-message {
	color: #e74c3c;
	font-size: 0.85rem;
	margin-top: 4px;
	display: none;
}

.form-group.error .error-message {
	display: block;
}

/* === Попап успеха === */
.form-success-popup {
	position: fixed;
	top: 0; left: 0;
	width: 100%; height: 100%;
	background: rgba(0,0,0,0.7);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10000;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
}

.form-success-popup.active {
	opacity: 1;
	visibility: visible;
}

.form-success-popup__content {
	background: #fff;
	padding: 30px 40px;
	border-radius: 12px;
	text-align: center;
	max-width: 400px;
	position: relative;
}

.form-success-popup__close {
	position: absolute;
	top: 10px; right: 15px;
	font-size: 24px;
	cursor: pointer;
	color: #999;
}

.form-success-popup__close:hover {
	color: #333;
}

.form-success-popup__icon {
	font-size: 48px;
	color: #27ae60;
	margin-bottom: 15px;
}

.form-success-popup__title {
	font-size: 1.3rem;
	margin-bottom: 10px;
}

.form-success-popup__text {
	color: #666;
}

/* Скрытие полей контакта */
.contact-field {
	display: none;
}

.contact-field.active {
	display: block;
}

/* Состояние кнопки */
.button:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.button.loading {
	position: relative;
	pointer-events: none;
}

.button.loading::after {
	content: "";
	position: absolute;
	width: 16px; height: 16px;
	border: 2px solid transparent;
	border-top-color: #fff;
	border-radius: 50%;
	animation: spin 0.6s linear infinite;
	right: 15px; top: 50%;
	transform: translateY(-50%);
}

@keyframes spin {
	to { transform: translateY(-50%) rotate(360deg); }
}

/* ===== Бургер-меню ===== */
.burger {
	display: none;               /* на десктопе скрыт */
	width: 44px;
	height: 44px;
	padding: 10px 8px;
	border: 1px solid var(--line);
	border-radius: 14px;
	background: rgba(255,255,255,.9);
	cursor: pointer;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	align-items: center;
	transition: background .2s ease;
}
.burger:hover { background: #fff; }

.burger span {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--text);
	border-radius: 2px;
	transition: transform .25s ease, opacity .2s ease;
}

/* Анимация крестика */
.burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger.is-open span:nth-child(2) { opacity: 0; }
.burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Скрываем меню на мобильном по умолчанию */
@media (max-width: 920px) {
	.burger {
		display: flex;
	}

	.nav-links {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		padding: 10px 16px 16px;
		background: rgba(248, 245, 240, .98);
		backdrop-filter: blur(18px);
		border-bottom: 1px solid var(--line);
		box-shadow: 0 18px 40px rgba(17,17,17,.08);
		border-radius: 0 0 22px 22px;

		/* скрыто */
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		pointer-events: none;
		transform: translateY(-6px);
		transition: max-height .35s ease, opacity .25s ease, transform .25s ease, padding .25s ease;
		padding-top: 0;
		padding-bottom: 0;
	}

	.nav-links.is-open {
		max-height: 400px;
		opacity: 1;
		pointer-events: auto;
		transform: translateY(0);
		padding: 10px 16px 16px;
	}

	.nav-links a {
		padding: 14px 18px;
		border-radius: 14px;
		font-size: 1.02rem;
	}
	.nav-links a + a { margin-top: 4px; }
}

/* ===== Фикс карточек недвижимости на мобильном ===== */
/* Инлайн-стиль grid-template-columns: repeat(2, ...) перекрывал медиа-запрос.
   Добавляем !important, чтобы на мобильном всегда была одна колонка. */
@media (max-width: 920px) {
	.three-col[style*="repeat(2"],
	.three-col {
		grid-template-columns: 1fr !important;
	}

	.property-card {
		padding: 22px;
	}
	.property-card .visual.large {
		min-height: 280px;
	}
}

@media (max-width: 640px) {
	.property-card {
		padding: 18px;
		gap: 16px;
	}
	.property-card .visual.large {
		min-height: 220px;
	}
	.specs {
		gap: 8px;
	}
	.spec {
		font-size: .86rem;
		padding: 8px 10px;
	}
}

.parking-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.parking-col:first-child {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
}
.parking img {
    width: 100%;
    max-width: none;
    height: 100%;
    object-fit: cover;
}
@media (max-width: 920px) {
  .parking-cols {
    grid-template-columns: 1fr;
  }
}