:root {
  --color-bg: #fbfaf7;
  --color-bg-soft: #f4efe9;
  --color-text: #262226;
  --color-muted: #6f666c;
  --color-line: rgba(99, 72, 82, 0.16);
  --color-wine: #7a1738;
  --color-wine-dark: #551024;
  --color-wine-soft: #f3e4e9;
  --color-card: rgba(255, 255, 255, 0.72);
  --shadow-soft: 0 24px 70px rgba(73, 42, 52, 0.13);
  --radius-lg: 28px;
  --radius-md: 18px;
  --container: 1320px;
  --font-serif: Georgia, "Times New Roman", serif;
  --font-sans: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  color: var(--color-text);
  background:
    radial-gradient(circle at 82% 8%, rgba(122, 23, 56, 0.08), transparent 34%),
    linear-gradient(180deg, #fffdfa 0%, var(--color-bg) 100%);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  text-rendering: optimizeLegibility;
}

body::selection {
  color: #fff;
  background: var(--color-wine);
}

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

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

.container {
  width: min(calc(100% - 56px), var(--container));
  margin-inline: auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(251, 250, 247, 0.84);
  border-bottom: 1px solid var(--color-line);
  backdrop-filter: blur(18px);
}

.site-header__inner {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: max-content;
  letter-spacing: 0.02em;
}

.site-logo__main {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1;
  color: #2e2930;
}

.site-logo__sep {
  width: 18px;
  height: 1px;
  background: rgba(122, 23, 56, 0.4);
}

.site-logo__sub {
  font-size: 13px;
  color: var(--color-muted);
}

.site-header__right {
  display: flex;
  align-items: center;
  gap: 22px;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 26px;
  font-size: 14px;
  color: #342d33;
}

.site-nav a {
  position: relative;
  padding: 8px 0;
}

.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 4px;
  width: 0;
  height: 1px;
  background: var(--color-wine);
  transition: width 0.22s ease;
}

.site-nav a:hover::after {
  width: 100%;
}

.site-socials {
  display: flex;
  align-items: center;
  gap: 8px;
}

.site-socials a {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-wine);
  font-size: 11px;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.58);
}

.site-header__cta,
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 24px;
  border-radius: 4px;
  border: 1px solid transparent;
  font-size: 13px;
  font-weight: 650;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  transition:
    transform 0.22s ease,
    background 0.22s ease,
    border-color 0.22s ease,
    color 0.22s ease;
}

.site-header__cta,
.button--primary {
  color: #fff;
  background: var(--color-wine);
  box-shadow: 0 16px 40px rgba(122, 23, 56, 0.2);
}

.site-header__cta:hover,
.button--primary:hover {
  background: var(--color-wine-dark);
  transform: translateY(-1px);
}

.button--secondary {
  color: var(--color-wine);
  background: rgba(255, 255, 255, 0.64);
  border-color: rgba(122, 23, 56, 0.22);
}

.button--secondary:hover {
  background: #fff;
  border-color: rgba(122, 23, 56, 0.42);
  transform: translateY(-1px);
}

.site-header__toggle,
.site-header__burger {
  display: none;
}

.hero {
  position: relative;
  overflow: hidden;
  min-height: calc(100svh - 78px);
  display: flex;
  align-items: center;
  padding: 64px 0 58px;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 8% -12% auto auto;
  width: 720px;
  height: 720px;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.82), transparent 56%),
    radial-gradient(circle, rgba(122, 23, 56, 0.1), transparent 68%);
  pointer-events: none;
}

.hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 120px;
  background: linear-gradient(180deg, transparent, rgba(244, 239, 233, 0.75));
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.84fr) minmax(420px, 1.16fr);
  align-items: center;
  gap: clamp(42px, 6vw, 92px);
}

.hero__content {
  padding-top: 16px;
}

.hero__eyebrow {
  margin: 0 0 24px;
  color: var(--color-muted);
  font-size: 14px;
  letter-spacing: 0.04em;
}

.hero__title {
  max-width: 680px;
  margin: 0;
  font-family: var(--font-serif);
  font-size: clamp(44px, 5vw, 82px);
  line-height: 0.98;
  font-weight: 400;
  letter-spacing: -0.04em;
  color: #2b2630;
}

.hero__title span {
  display: block;
  color: var(--color-wine);
}

.hero__text {
  max-width: 520px;
  margin-top: 30px;
}

.hero__lead {
  margin: 0 0 14px;
  color: var(--color-wine);
  font-family: var(--font-serif);
  font-size: clamp(22px, 2vw, 31px);
  line-height: 1.16;
}

.hero__text p:not(.hero__lead) {
  margin: 0;
  color: #514950;
  font-size: 17px;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 36px;
}

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

.hero-feature {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.hero-feature__icon {
  position: relative;
  width: 38px;
  height: 38px;
  border: 1px solid rgba(122, 23, 56, 0.34);
  border-radius: 14px;
}

.hero-feature__icon::before {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 999px;
  background: rgba(122, 23, 56, 0.12);
}

.hero-feature h3 {
  margin: 0 0 4px;
  font-size: 14px;
  line-height: 1.25;
}

.hero-feature p {
  margin: 0;
  color: var(--color-muted);
  font-size: 13px;
  line-height: 1.45;
}

.hero__media {
  position: relative;
  min-height: min(72svh, 760px);
}

.hero__image-frame,
.hero__showcase {
  position: relative;
  min-height: min(72svh, 760px);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.hero__image-frame {
  margin: 0;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(244, 239, 233, 0.42));
  box-shadow: var(--shadow-soft);
}

.hero__image-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(251, 250, 247, 0.52), transparent 34%),
    radial-gradient(circle at 78% 22%, rgba(255, 255, 255, 0.42), transparent 34%);
  pointer-events: none;
}

.hero__image-frame img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  object-position: center;
}

.hero__showcase {
  background:
    radial-gradient(circle at 55% 20%, rgba(255, 255, 255, 0.94), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.72), rgba(244, 239, 233, 0.92));
  box-shadow: var(--shadow-soft);
}

.hero__showcase::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(251, 250, 247, 0.62), transparent 36%),
    radial-gradient(circle at 70% 28%, rgba(122, 23, 56, 0.08), transparent 38%);
}

.hero__dress {
  position: absolute;
  bottom: 52px;
  width: 26%;
  border-radius: 44% 44% 18px 18px;
  box-shadow: 0 34px 80px rgba(50, 25, 34, 0.16);
  overflow: hidden;
}

.hero__dress::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 36% 24%, rgba(255, 255, 255, 0.5), transparent 18%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.28), transparent 44%);
}

.hero__dress--left {
  left: 6%;
  height: 54%;
  background:
    radial-gradient(circle at 72% 16%, #f8dce3 0 3px, transparent 4px),
    linear-gradient(160deg, #bf1339 0%, #8a1236 42%, #2d2341 100%);
}

.hero__dress--center {
  left: 34%;
  bottom: 34px;
  width: 33%;
  height: 72%;
  background:
    radial-gradient(circle at 66% 18%, #fff 0 3px, transparent 4px),
    linear-gradient(145deg, #b81433 0%, #de1e44 36%, #f5d6dc 52%, #9d1438 100%);
}

.hero__dress--right {
  right: 6%;
  height: 58%;
  background:
    radial-gradient(circle at 50% 18%, #f7d9a6 0 3px, transparent 4px),
    linear-gradient(145deg, #161821 0%, #1e2434 46%, #9b4b1f 100%);
}

.page-content {
  padding: 80px 0;
}

.site-footer {
  color: rgba(255, 255, 255, 0.82);
  background:
    radial-gradient(circle at 88% 32%, rgba(255, 255, 255, 0.18), transparent 20%),
    linear-gradient(135deg, #201d24 0%, #151419 100%);
}

.site-footer__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.8fr 1fr;
  gap: 56px;
  padding: 64px 0;
}

.site-footer__logo {
  margin-bottom: 14px;
  color: #fff;
  font-family: var(--font-serif);
  font-size: 30px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.site-footer p {
  max-width: 340px;
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.66);
}

.site-footer strong {
  display: block;
  margin-bottom: 14px;
  color: #fff;
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 400;
}

.site-footer a:not(.button) {
  display: block;
  width: fit-content;
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.74);
}

.button--footer {
  margin-top: 22px;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.24);
}

.button--footer:hover {
  background: rgba(255, 255, 255, 0.08);
}

@media (max-width: 1180px) {
  .site-socials {
    display: none;
  }

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

  .hero__features {
    grid-template-columns: 1fr;
    max-width: 520px;
  }
}

@media (max-width: 920px) {
  .container {
    width: min(calc(100% - 32px), var(--container));
  }

  .site-header__inner {
    min-height: 68px;
  }

  .site-logo {
    gap: 8px;
  }

  .site-logo__sub,
  .site-logo__sep,
  .site-header__cta {
    display: none;
  }

  .site-header__burger {
    width: 42px;
    height: 42px;
    display: grid;
    place-content: center;
    gap: 6px;
    border: 1px solid var(--color-line);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.68);
    cursor: pointer;
  }

  .site-header__burger span {
    width: 18px;
    height: 1px;
    background: var(--color-text);
  }

  .site-nav {
    position: absolute;
    left: 16px;
    right: 16px;
    top: calc(100% + 10px);
    display: grid;
    gap: 4px;
    padding: 18px;
    border: 1px solid var(--color-line);
    border-radius: 22px;
    background: rgba(251, 250, 247, 0.96);
    box-shadow: var(--shadow-soft);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition:
      opacity 0.18s ease,
      visibility 0.18s ease,
      transform 0.18s ease;
  }

  .site-header__toggle:checked ~ .site-nav {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  .site-nav a {
    padding: 10px 8px;
  }

  .hero {
    min-height: auto;
    padding: 54px 0 48px;
  }

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

  .hero__media {
    min-height: 420px;
    order: -1;
  }

  .hero__image-frame,
  .hero__showcase {
    min-height: 420px;
  }

  .hero__title {
    font-size: clamp(42px, 12vw, 64px);
  }

  .hero__text {
    margin-top: 24px;
  }

  .site-footer__inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 48px 0;
  }
}

@media (max-width: 560px) {
  .hero__actions {
    display: grid;
  }

  .button {
    width: 100%;
  }

  .hero__media {
    min-height: 340px;
  }

  .hero__image-frame,
  .hero__showcase {
    min-height: 340px;
    border-radius: 22px;
  }

  .hero__dress--left {
    left: 2%;
  }

  .hero__dress--center {
    left: 31%;
  }

  .hero__dress--right {
    right: 2%;
  }
}

/* Services */

.services-section {
  position: relative;
  padding: 78px 0 82px;
  background:
    linear-gradient(180deg, rgba(244, 239, 233, 0.55), rgba(251, 250, 247, 0.96));
}

.section-head {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  margin-bottom: 34px;
}

.section-head span {
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(99, 72, 82, 0.28),
    transparent
  );
}

.section-head h2 {
  margin: 0;
  color: #2f2930;
  font-family: var(--font-serif);
  font-size: clamp(24px, 2.4vw, 38px);
  font-weight: 400;
  line-height: 1.12;
  letter-spacing: 0.04em;
  text-align: center;
  text-transform: uppercase;
}

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

.service-card {
  position: relative;
  min-height: 330px;
  overflow: hidden;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 12px;
  background:
    radial-gradient(circle at 70% 18%, rgba(255, 255, 255, 0.74), transparent 30%),
    linear-gradient(135deg, #f8f1ed 0%, #e8d7dc 100%);
  box-shadow: 0 18px 54px rgba(73, 42, 52, 0.08);
}

.service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 78% 20%, rgba(255, 255, 255, 0.72) 0 2px, transparent 3px),
    radial-gradient(circle at 62% 34%, rgba(255, 255, 255, 0.5) 0 1px, transparent 2px),
    linear-gradient(145deg, transparent 0 45%, rgba(122, 23, 56, 0.2) 46%, transparent 57%);
  opacity: 0.95;
}

.service-card--1 {
  background:
    linear-gradient(145deg, rgba(135, 11, 43, 0.82), transparent 48%),
    linear-gradient(135deg, #f7ebe7 0%, #c21d42 58%, #791736 100%);
}

.service-card--2 {
  background:
    linear-gradient(145deg, rgba(19, 21, 34, 0.92), transparent 54%),
    linear-gradient(135deg, #fff7f0 0%, #252236 48%, #9d5026 100%);
}

.service-card--3 {
  background:
    linear-gradient(135deg, #fff9f4 0%, #eee4db 42%, #b41435 100%);
}

.service-card--4 {
  background:
    linear-gradient(145deg, rgba(20, 18, 25, 0.92), transparent 58%),
    linear-gradient(135deg, #f7ece6 0%, #27202a 48%, #7a1738 100%);
}

.service-card--5 {
  background:
    linear-gradient(135deg, #fff4ef 0%, #f1c9d3 44%, #9b1538 100%);
}

.service-card--6 {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.82), transparent 40%),
    linear-gradient(135deg, #f8efe8 0%, #c22b4b 52%, #1f1f2b 100%);
}

.service-card img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.service-card__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(180deg, transparent 24%, rgba(251, 250, 247, 0.9) 100%),
    linear-gradient(90deg, rgba(251, 250, 247, 0.82), transparent 58%);
}

.service-card__content {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  z-index: 3;
}

.service-card h3 {
  max-width: 310px;
  margin: 0 0 10px;
  color: #332b31;
  font-family: var(--font-serif);
  font-size: clamp(24px, 2vw, 34px);
  font-weight: 400;
  line-height: 1.04;
  letter-spacing: -0.02em;
}

.service-card p {
  max-width: 300px;
  margin: 0;
  color: #5d535a;
  font-size: 15px;
  line-height: 1.5;
}

.service-card:hover img {
  transform: scale(1.045);
}

@media (max-width: 980px) {
  .services-section {
    padding: 62px 0;
  }

  .section-head {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .section-head span {
    display: none;
  }

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

  .service-card {
    min-height: 300px;
  }
}

@media (max-width: 620px) {
  .services-grid {
    grid-template-columns: 1fr;
  }

  .service-card {
    min-height: 280px;
  }

  .service-card__content {
    left: 22px;
    right: 22px;
    bottom: 22px;
  }
}

/* Works */

.works-section {
  position: relative;
  padding: 78px 0 88px;
  background:
    radial-gradient(circle at 16% 20%, rgba(122, 23, 56, 0.055), transparent 28%),
    linear-gradient(180deg, rgba(251, 250, 247, 0.96), #fffdfa 100%);
}

.section-head--works {
  margin-bottom: 36px;
}

.works-grid {
  display: grid;
  grid-template-columns: 1.16fr 1fr 1fr;
  grid-auto-rows: 245px;
  gap: 18px;
}

.work-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 12px;
  background:
    radial-gradient(circle at 52% 18%, rgba(255, 255, 255, 0.84), transparent 28%),
    linear-gradient(145deg, #f7eee9 0%, #d5b8c0 45%, #7a1738 100%);
  box-shadow: 0 18px 54px rgba(73, 42, 52, 0.08);
}

.work-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.76) 0 2px, transparent 3px),
    radial-gradient(circle at 64% 38%, rgba(255, 255, 255, 0.5) 0 1px, transparent 2px),
    linear-gradient(135deg, transparent 0 44%, rgba(255, 255, 255, 0.22) 45%, transparent 55%);
  opacity: 0.95;
}

.work-card--1 {
  grid-row: span 2;
  min-height: 508px;
  background:
    linear-gradient(150deg, rgba(255, 255, 255, 0.7), transparent 40%),
    linear-gradient(135deg, #fff4ef 0%, #c91f43 48%, #761634 100%);
}

.work-card--2 {
  grid-column: span 2;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.76), transparent 38%),
    linear-gradient(135deg, #f7ece6 0%, #b91638 42%, #183058 100%);
}

.work-card--3 {
  background:
    linear-gradient(145deg, rgba(18, 20, 30, 0.84), transparent 58%),
    linear-gradient(135deg, #f8eadf 0%, #1b1f2e 48%, #a65a24 100%);
}

.work-card--4 {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.72), transparent 42%),
    linear-gradient(135deg, #f8e7e7 0%, #c51d42 58%, #6c1430 100%);
}

.work-card--5 {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.68), transparent 40%),
    linear-gradient(135deg, #f9eee6 0%, #ac1838 45%, #25345c 100%);
}

.work-card--6 {
  background:
    linear-gradient(145deg, rgba(18, 20, 30, 0.86), transparent 58%),
    linear-gradient(135deg, #f5e7dc 0%, #211e2a 52%, #8b431f 100%);
}

.work-card img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 0.55s ease,
    filter 0.55s ease;
}

.work-card__shade {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(180deg, transparent 36%, rgba(251, 250, 247, 0.88) 100%),
    linear-gradient(90deg, rgba(251, 250, 247, 0.55), transparent 54%);
  pointer-events: none;
}

.work-card__content {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  z-index: 3;
}

.work-card__content h3 {
  max-width: 330px;
  margin: 0 0 8px;
  color: #322b31;
  font-family: var(--font-serif);
  font-size: clamp(25px, 2.2vw, 36px);
  font-weight: 400;
  line-height: 1.04;
}

.work-card__content p {
  max-width: 310px;
  margin: 0;
  color: #5d535a;
  font-size: 15px;
}

.work-card:hover img {
  transform: scale(1.045);
  filter: saturate(1.03) contrast(1.02);
}

.works-section__action {
  display: flex;
  justify-content: center;
  margin-top: 36px;
}

@media (max-width: 980px) {
  .works-section {
    padding: 62px 0 70px;
  }

  .works-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 250px;
  }

  .work-card--1 {
    grid-column: span 1;
    grid-row: span 2;
    min-height: auto;
  }

  .work-card--2 {
    grid-column: span 1;
  }
}

@media (max-width: 620px) {
  .works-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 280px;
  }

  .work-card,
  .work-card--1,
  .work-card--2 {
    grid-column: auto;
    grid-row: auto;
    min-height: 280px;
  }

  .work-card__content {
    left: 22px;
    right: 22px;
    bottom: 22px;
  }

  .works-section__action {
    margin-top: 28px;
  }
}

/* Levels */

.levels-section {
  position: relative;
  padding: 76px 0 86px;
  background:
    radial-gradient(circle at 50% 0%, rgba(122, 23, 56, 0.05), transparent 28%),
    linear-gradient(180deg, #fffdfa 0%, #f7f3ef 100%);
}

.levels-section__head {
  margin-bottom: 34px;
}

.levels-section__head > div {
  max-width: 720px;
  text-align: center;
}

.levels-section__head p {
  max-width: 620px;
  margin: 12px auto 0;
  color: var(--color-muted);
  font-size: 16px;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0;
}

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

.level-card {
  position: relative;
  min-height: 245px;
  padding: 34px 26px 30px;
  overflow: hidden;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 12px;
  background:
    radial-gradient(circle at 78% 14%, rgba(122, 23, 56, 0.055), transparent 28%),
    rgba(255, 255, 255, 0.76);
  box-shadow: 0 18px 52px rgba(73, 42, 52, 0.07);
  transition:
    transform 0.24s ease,
    border-color 0.24s ease,
    box-shadow 0.24s ease;
}

.level-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), transparent 42%),
    radial-gradient(circle at 18% 100%, rgba(122, 23, 56, 0.08), transparent 32%);
  pointer-events: none;
}

.level-card > * {
  position: relative;
  z-index: 1;
}

.level-card__icon {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  margin-bottom: 26px;
  border: 1px solid rgba(122, 23, 56, 0.24);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(243, 228, 233, 0.66));
  color: var(--color-wine);
}

.level-card__icon svg {
  width: 34px;
  height: 34px;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.level-card h3 {
  max-width: 220px;
  margin: 0 0 12px;
  color: #302930;
  font-family: var(--font-serif);
  font-size: clamp(22px, 1.7vw, 29px);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.02em;
}

.level-card p {
  margin: 0;
  color: #625960;
  font-size: 15px;
  line-height: 1.55;
}

.level-card:hover {
  transform: translateY(-4px);
  border-color: rgba(122, 23, 56, 0.24);
  box-shadow: 0 24px 64px rgba(73, 42, 52, 0.11);
}

@media (max-width: 1080px) {
  .levels-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .level-card {
    min-height: 230px;
  }
}

@media (max-width: 620px) {
  .levels-section {
    padding: 62px 0 68px;
  }

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

  .level-card {
    min-height: auto;
    padding: 28px 22px 26px;
  }

  .level-card__icon {
    margin-bottom: 20px;
  }
}

/* Reviews */

.reviews-section {
  position: relative;
  padding: 78px 0 88px;
  background:
    radial-gradient(circle at 86% 18%, rgba(122, 23, 56, 0.06), transparent 28%),
    linear-gradient(180deg, #f7f3ef 0%, #fffdfa 100%);
}

.reviews-section__head {
  margin-bottom: 36px;
}

.reviews-section__head > div {
  max-width: 720px;
  text-align: center;
}

.reviews-section__head p {
  max-width: 620px;
  margin: 12px auto 0;
  color: var(--color-muted);
  font-size: 16px;
  line-height: 1.55;
}

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

.review-card {
  position: relative;
  min-height: 315px;
  padding: 34px 30px 28px;
  overflow: hidden;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 12px;
  background:
    radial-gradient(circle at 86% 14%, rgba(122, 23, 56, 0.055), transparent 28%),
    rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 54px rgba(73, 42, 52, 0.075);
}

.review-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), transparent 42%),
    radial-gradient(circle at 10% 100%, rgba(122, 23, 56, 0.07), transparent 30%);
  pointer-events: none;
}

.review-card > * {
  position: relative;
  z-index: 1;
}

.review-card__quote {
  height: 58px;
  color: rgba(122, 23, 56, 0.18);
  font-family: var(--font-serif);
  font-size: 96px;
  line-height: 0.75;
}

.review-card__text {
  margin: 16px 0 34px;
  color: #443b42;
  font-family: var(--font-serif);
  font-size: clamp(20px, 1.65vw, 27px);
  line-height: 1.22;
}

.review-card__footer {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: auto;
}

.review-card__avatar {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border: 1px solid rgba(122, 23, 56, 0.24);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(243, 228, 233, 0.7));
  color: var(--color-wine);
  font-family: var(--font-serif);
  font-size: 22px;
}

.review-card h3 {
  margin: 0 0 2px;
  color: #302930;
  font-size: 15px;
  line-height: 1.25;
}

.review-card__footer p {
  margin: 0;
  color: var(--color-muted);
  font-size: 13px;
  line-height: 1.35;
}

@media (max-width: 980px) {
  .reviews-section {
    padding: 62px 0 72px;
  }

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

  .review-card {
    min-height: auto;
  }
}

@media (max-width: 560px) {
  .review-card {
    padding: 28px 22px 24px;
  }

  .review-card__text {
    margin-bottom: 28px;
  }
}

/* Final CTA */

.final-cta {
  position: relative;
  padding: 82px 0 92px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.16), transparent 26%),
    linear-gradient(135deg, #2b2028 0%, #5e102a 48%, #2b2028 100%);
}

.final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 20%, rgba(255, 255, 255, 0.18), transparent 22%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.06), transparent 42%);
  pointer-events: none;
}

.final-cta__box {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: center;
  min-height: 460px;
  padding: clamp(34px, 5vw, 64px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 18px;
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.14), transparent 30%),
    rgba(255, 255, 255, 0.055);
  box-shadow: 0 28px 90px rgba(27, 12, 20, 0.24);
}

.final-cta__eyebrow {
  margin: 0 0 20px;
  color: rgba(255, 255, 255, 0.68);
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.final-cta h2 {
  max-width: 720px;
  margin: 0;
  color: #fff;
  font-family: var(--font-serif);
  font-size: clamp(38px, 5vw, 72px);
  font-weight: 400;
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.final-cta__text {
  max-width: 590px;
  margin: 28px 0 0;
  color: rgba(255, 255, 255, 0.76);
  font-size: 18px;
  line-height: 1.6;
}

.final-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 36px;
}

.final-cta .button--primary {
  background: #fff;
  color: var(--color-wine);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.16);
}

.final-cta .button--primary:hover {
  background: #f5ecef;
}

.final-cta .button--secondary {
  color: #fff;
  background: transparent;
  border-color: rgba(255, 255, 255, 0.28);
}

.final-cta .button--secondary:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.42);
}

.final-cta__cards {
  display: grid;
  gap: 14px;
}

.final-cta-card {
  position: relative;
  padding: 24px 24px 22px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
}

.final-cta-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.13), transparent 44%),
    radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.12), transparent 30%);
  pointer-events: none;
}

.final-cta-card > * {
  position: relative;
  z-index: 1;
}

.final-cta-card span {
  display: block;
  margin-bottom: 18px;
  color: rgba(255, 255, 255, 0.48);
  font-family: var(--font-serif);
  font-size: 18px;
}

.final-cta-card h3 {
  margin: 0 0 8px;
  color: #fff;
  font-family: var(--font-serif);
  font-size: 24px;
  font-weight: 400;
  line-height: 1.08;
}

.final-cta-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.68);
  font-size: 15px;
  line-height: 1.5;
}

@media (max-width: 980px) {
  .final-cta {
    padding: 62px 0 72px;
  }

  .final-cta__box {
    grid-template-columns: 1fr;
    min-height: auto;
  }
}

@media (max-width: 560px) {
  .final-cta__box {
    padding: 30px 22px;
    border-radius: 14px;
  }

  .final-cta__actions {
    display: grid;
  }

  .final-cta__text {
    font-size: 16px;
  }
}

/* Footer final */

.site-footer {
  position: relative;
  color: rgba(255, 255, 255, 0.78);
  background:
    radial-gradient(circle at 84% 16%, rgba(122, 23, 56, 0.32), transparent 24%),
    linear-gradient(135deg, #17151b 0%, #241922 48%, #111116 100%);
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 42%),
    radial-gradient(circle at 12% 100%, rgba(255, 255, 255, 0.08), transparent 24%);
  pointer-events: none;
}

.site-footer .container {
  position: relative;
  z-index: 1;
}

.site-footer__top {
  display: grid;
  grid-template-columns: minmax(260px, 1.28fr) minmax(140px, 0.62fr) minmax(190px, 0.78fr) minmax(250px, 1fr);
  gap: clamp(28px, 4vw, 62px);
  padding: 70px 0 48px;
}

.site-footer__brand p,
.site-footer__cta p {
  max-width: 360px;
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.62);
  font-size: 15px;
  line-height: 1.65;
}

.site-footer__logo {
  display: inline-block;
  margin: 0;
  color: #fff;
  font-family: var(--font-serif);
  font-size: clamp(27px, 2.7vw, 42px);
  line-height: 1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site-footer h3 {
  margin: 0 0 18px;
  color: #fff;
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 400;
  line-height: 1.1;
}

.site-footer__nav,
.site-footer__contacts,
.site-footer__cta {
  min-width: 0;
}

.site-footer__nav a,
.site-footer__contacts > a,
.site-footer__socials a,
.site-footer__bottom a {
  display: block;
  width: fit-content;
  color: rgba(255, 255, 255, 0.68);
  font-size: 14px;
  line-height: 1.45;
  transition: color 0.2s ease;
}

.site-footer__nav a + a,
.site-footer__contacts > a + a {
  margin-top: 11px;
}

.site-footer__nav a:hover,
.site-footer__contacts > a:hover,
.site-footer__socials a:hover,
.site-footer__bottom a:hover {
  color: #fff;
}

.site-footer__socials {
  margin-top: 28px;
}

.site-footer__socials h3 {
  margin-bottom: 14px;
}

.site-footer__socials div {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.site-footer__socials a {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  padding: 0 13px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.045);
}

.site-footer__socials a:hover {
  border-color: rgba(255, 255, 255, 0.32);
  background: rgba(255, 255, 255, 0.075);
}

.site-footer__cta {
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 255, 255, 0.12), transparent 34%),
    rgba(255, 255, 255, 0.055);
}

.site-footer__cta p {
  margin-top: 12px;
}

.site-footer .button--footer {
  margin-top: 22px;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.24);
  background: transparent;
}

.site-footer .button--footer:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.38);
}

.site-footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 22px 0 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.11);
}

.site-footer__bottom p {
  margin: 0;
  color: rgba(255, 255, 255, 0.46);
  font-size: 13px;
}

.site-footer__bottom a {
  color: rgba(255, 255, 255, 0.52);
  font-size: 13px;
}

@media (max-width: 1080px) {
  .site-footer__top {
    grid-template-columns: 1.2fr 0.8fr;
  }
}

@media (max-width: 680px) {
  .site-footer__top {
    grid-template-columns: 1fr;
    padding: 54px 0 38px;
  }

  .site-footer__cta {
    padding: 22px;
  }

  .site-footer__bottom {
    display: grid;
    gap: 10px;
  }
}

/* Hero background image */

.hero--has-bg {
  background-image:
    linear-gradient(90deg, rgba(251, 250, 247, 0.94) 0%, rgba(251, 250, 247, 0.82) 42%, rgba(251, 250, 247, 0.36) 100%),
    var(--hero-bg);
  background-size: cover;
  background-position: var(--hero-bg-position);
  background-repeat: no-repeat;
}

.hero--has-bg::before {
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.68), transparent 56%),
    radial-gradient(circle, rgba(122, 23, 56, 0.08), transparent 68%);
}

@media (max-width: 920px) {
  .hero--has-bg {
    background-image:
      linear-gradient(180deg, rgba(251, 250, 247, 0.96) 0%, rgba(251, 250, 247, 0.82) 54%, rgba(251, 250, 247, 0.5) 100%),
      var(--hero-bg);
  }
}

/* Portfolio archive */

.portfolio-hero {
  padding: 96px 0 58px;
  background:
    radial-gradient(circle at 84% 18%, rgba(122, 23, 56, 0.08), transparent 28%),
    linear-gradient(180deg, #fffdfa 0%, #f7f3ef 100%);
}

.portfolio-hero__eyebrow {
  margin: 0 0 18px;
  color: var(--color-muted);
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.portfolio-hero h1 {
  max-width: 860px;
  margin: 0;
  color: #2b2630;
  font-family: var(--font-serif);
  font-size: clamp(48px, 6vw, 92px);
  font-weight: 400;
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.portfolio-hero p:not(.portfolio-hero__eyebrow) {
  max-width: 660px;
  margin: 28px 0 0;
  color: #5d535a;
  font-size: 18px;
  line-height: 1.6;
}

.portfolio-section {
  padding: 42px 0 92px;
  background: #f7f3ef;
}

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

.portfolio-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 54px rgba(73, 42, 52, 0.075);
  transition:
    transform 0.24s ease,
    box-shadow 0.24s ease,
    border-color 0.24s ease;
}

.portfolio-card__media {
  position: relative;
  min-height: 410px;
  overflow: hidden;
  background:
    radial-gradient(circle at 52% 18%, rgba(255, 255, 255, 0.84), transparent 28%),
    linear-gradient(145deg, #f7eee9 0%, #d5b8c0 45%, #7a1738 100%);
}

.portfolio-card__media::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.76) 0 2px, transparent 3px),
    linear-gradient(135deg, transparent 0 44%, rgba(255, 255, 255, 0.22) 45%, transparent 55%);
  opacity: 0.95;
}

.portfolio-card__media img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.portfolio-card__content {
  padding: 24px 24px 26px;
}

.portfolio-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.portfolio-card__meta span {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border: 1px solid rgba(122, 23, 56, 0.16);
  border-radius: 999px;
  color: var(--color-wine);
  background: rgba(243, 228, 233, 0.54);
  font-size: 12px;
}

.portfolio-card h2 {
  margin: 0 0 10px;
  color: #302930;
  font-family: var(--font-serif);
  font-size: clamp(24px, 2vw, 34px);
  font-weight: 400;
  line-height: 1.06;
}

.portfolio-card p {
  margin: 0;
  color: #625960;
  font-size: 15px;
  line-height: 1.55;
}

.portfolio-card__link,
.work-card__link {
  display: inline-block;
  margin-top: 18px;
  color: var(--color-wine);
  font-size: 13px;
  font-weight: 650;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.portfolio-card:hover {
  transform: translateY(-4px);
  border-color: rgba(122, 23, 56, 0.22);
  box-shadow: 0 26px 68px rgba(73, 42, 52, 0.12);
}

.portfolio-card:hover img {
  transform: scale(1.045);
}

.portfolio-empty {
  padding: 54px;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.76);
  text-align: center;
}

.portfolio-empty h2 {
  margin: 0 0 10px;
  font-family: var(--font-serif);
  font-size: 36px;
  font-weight: 400;
}

.portfolio-empty p {
  margin: 0;
  color: var(--color-muted);
}

/* Work detail */

.work-detail__hero {
  padding: 54px 0 72px;
  background:
    radial-gradient(circle at 84% 18%, rgba(122, 23, 56, 0.08), transparent 28%),
    linear-gradient(180deg, #fffdfa 0%, #f7f3ef 100%);
}

.work-detail__back {
  display: inline-block;
  margin-bottom: 34px;
  color: var(--color-wine);
  font-size: 14px;
  font-weight: 650;
}

.work-detail__hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(420px, 1.08fr);
  gap: clamp(34px, 5vw, 72px);
  align-items: center;
}

.work-detail__eyebrow {
  margin: 0 0 18px;
  color: var(--color-muted);
  font-size: 14px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.work-detail h1 {
  max-width: 720px;
  margin: 0;
  color: #2b2630;
  font-family: var(--font-serif);
  font-size: clamp(42px, 5vw, 78px);
  font-weight: 400;
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.work-detail__lead {
  max-width: 560px;
  margin: 28px 0 0;
  color: #514950;
  font-size: 18px;
  line-height: 1.6;
}

.work-detail__facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 34px;
}

.work-detail__facts div {
  padding: 18px;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.66);
}

.work-detail__facts span {
  display: block;
  margin-bottom: 6px;
  color: var(--color-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.work-detail__facts strong {
  display: block;
  color: #302930;
  font-size: 15px;
  line-height: 1.35;
}

.work-detail__cover {
  position: relative;
  min-height: 620px;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(99, 72, 82, 0.12);
  border-radius: 16px;
  background:
    radial-gradient(circle at 52% 18%, rgba(255, 255, 255, 0.84), transparent 28%),
    linear-gradient(145deg, #f7eee9 0%, #d5b8c0 45%, #7a1738 100%);
  box-shadow: 0 24px 70px rgba(73, 42, 52, 0.12);
}

.work-detail__cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.76) 0 2px, transparent 3px),
    linear-gradient(135deg, transparent 0 44%, rgba(255, 255, 255, 0.22) 45%, transparent 55%);
}

.work-detail__cover img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.work-detail__body {
  padding: 74px 0 92px;
  background: #fffdfa;
}

.work-detail__text {
  max-width: 820px;
  margin: 0 auto 46px;
  color: #443b42;
  font-family: var(--font-serif);
  font-size: clamp(22px, 2vw, 32px);
  line-height: 1.35;
  text-align: center;
}

.work-detail__text p {
  margin: 0;
}

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

.work-gallery__item {
  position: relative;
  min-height: 390px;
  margin: 0;
  overflow: hidden;
  border-radius: 12px;
  background:
    radial-gradient(circle at 52% 18%, rgba(255, 255, 255, 0.84), transparent 28%),
    linear-gradient(145deg, #f7eee9 0%, #d5b8c0 45%, #7a1738 100%);
}

.work-gallery__item img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.work-detail__cta {
  max-width: 820px;
  margin: 58px auto 0;
  padding: 42px;
  border-radius: 16px;
  background:
    radial-gradient(circle at 90% 10%, rgba(122, 23, 56, 0.08), transparent 28%),
    #f7f3ef;
  text-align: center;
}

.work-detail__cta h2 {
  margin: 0 0 12px;
  color: #302930;
  font-family: var(--font-serif);
  font-size: clamp(30px, 3vw, 46px);
  font-weight: 400;
  line-height: 1.05;
}

.work-detail__cta p {
  max-width: 560px;
  margin: 0 auto 24px;
  color: var(--color-muted);
  font-size: 16px;
  line-height: 1.6;
}

@media (max-width: 980px) {
  .portfolio-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .work-detail__hero-grid {
    grid-template-columns: 1fr;
  }

  .work-detail__cover {
    min-height: 480px;
  }

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

@media (max-width: 620px) {
  .portfolio-hero {
    padding: 68px 0 42px;
  }

  .portfolio-section {
    padding: 32px 0 68px;
  }

  .portfolio-grid,
  .work-gallery,
  .work-detail__facts {
    grid-template-columns: 1fr;
  }

  .portfolio-card__media,
  .work-gallery__item {
    min-height: 320px;
  }

  .work-detail__hero {
    padding: 42px 0 56px;
  }

  .work-detail__cover {
    min-height: 380px;
  }

  .work-detail__body {
    padding: 56px 0 68px;
  }

  .work-detail__cta {
    padding: 30px 22px;
  }
}
