.elementor-14532 .elementor-element.elementor-element-1cf816f{--display:flex;}@media(min-width:768px){.elementor-14532 .elementor-element.elementor-element-1cf816f{--width:100%;}}/* Start custom CSS for html, class: .elementor-element-3c58c6d */:root {
      --gold: #c8b478;
      --dark: #1d2a3f;
      --text: #222;
      --bg-light: #f7f6f2;
      --bg-gray: #f6f6f6;
      --border: #edeadf;
      --white: #fff;
      --radius: 16px;
      --radius-sm: 8px;
      --radius-pill: 800px;
      --font: 'TT Norms Pro', 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
      --section-gap: 140px;
    }

    .container {
      max-width: 1312px;
      margin: 0 auto;
      padding: 0 20px;
    }

    .sections {
      display: flex;
      flex-direction: column;
      gap: var(--section-gap);
      padding-top: 120px;
      padding-bottom: 120px;
    }

    .section-title {
      font-size: 36px;
      font-weight: 500;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 28px;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      height: 53px;
      padding: 16px 32px;
      background: var(--gold);
      border-radius: var(--radius-sm);
      font-size: 14px;
      font-weight: 500;
      text-transform: uppercase;
      color: var(--text);
      text-decoration: none;
      white-space: nowrap;
      transition: opacity 0.2s;
    }
    .btn:hover { opacity: 0.85; }

    .btn-pill {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 8px 16px;
      border-radius: var(--radius-pill);
      font-size: 14px;
      font-weight: 500;
      text-transform: uppercase;
      color: var(--text);
      transition: all 0.2s;
      white-space: nowrap;
      border: none;
    }
    .btn-pill.active { background: var(--gold); }
    .btn-pill:not(.active) { background: var(--white); }

    /* ===== HERO ===== */
    .hero {
      position: relative;
      width: 100%;
      height: 100vh;
      min-height: 660px;
      overflow: hidden;
    }
    .hero__bg {
      position: absolute;
      inset: 0;
      z-index: 0;
    }
    .hero__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .hero__overlay-top {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(0,0,0,0.24) 0%, rgba(0,0,0,0) 100%);
      z-index: 1;
    }
    .hero__overlay-bottom {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.6) 100%);
      z-index: 1;
    }
    .hero__content {
      position: absolute;
      bottom: 100px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 2;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 24px;
      max-width: 664px;
      text-align: center;
    }
    .hero__title {
      font-size: 46px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--white);
      letter-spacing: -0.46px;
    }
    .hero__subtitle {
      font-size: 28px;
      font-weight: 400;
      line-height: 1.2;
      color: var(--white);
    }
    .hero__arrows {
      position: absolute;
      top: 50%;
      left: 0;
      right: 0;
      transform: translateY(-50%);
      z-index: 3;
      display: flex;
      justify-content: space-between;
      padding: 0 232px;
      pointer-events: none;
    }
    .hero__arrow {
      width: 48px;
      height: 34px;
      pointer-events: auto;
      cursor: pointer;
      opacity: 0.7;
      transition: opacity 0.2s;
    }
    .hero__arrow:hover { opacity: 1; }

    /* ===== ADVANTAGE CARDS ===== */
    .advantages {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
    }
    .adv-card {
      position: relative;
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 20px;
      min-height: 258px;
      overflow: hidden;
    }
    .adv-card__title {
      font-size: 24px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .adv-card__text {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
    }
    .adv-card__icon {
      position: absolute;
      bottom: -64px;
      right: -2px;
      width: 224px;
      height: 224px;
      object-fit: cover;
    }

    /* ===== SERVICE CARDS (Wedding Options) ===== */
    .wedding-options__cards {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
    }
    .service-card {
      position: relative;
      width: 100%;
      height: 580px;
      border-radius: var(--radius);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 32px 48px 32px;
    }
    .service-card__bg {
      position: absolute;
      inset: 0;
      z-index: 0;
    }
    .service-card__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .service-card__overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(36,24,13,0) 47.93%, rgba(36,24,13,0.9) 100%);
      z-index: 1;
    }
    .service-card__content {
      position: relative;
      z-index: 2;
      text-align: center;
      color: var(--white);
    }
    .service-card__title {
      font-size: 26px;
      font-weight: 500;
      line-height: 1.1;
      margin-bottom: 8px;
    }
    .service-card__text {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
    }

    .wide-banner {
      position: relative;
      height: 254px;
      border-radius: var(--radius);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 48px;
      margin-top: 20px;
    }
    .wide-banner__bg {
      position: absolute;
      inset: 0;
    }
    .wide-banner__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .wide-banner__overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(36,24,13,0.9) 0%, rgba(36,24,13,0) 66.15%);
    }
    .wide-banner__content {
      position: relative;
      z-index: 1;
      color: var(--white);
      max-width: 444px;
    }

    /* ===== VENUE CARDS ===== */
    .venues__top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      margin-bottom: 28px;
    }
    .venues__top .section-title {
      margin-bottom: 0;
    }
    .venues__controls {
      display: flex;
      align-items: center;
      gap: 12px;
      flex-shrink: 0;
    }
    .venues__arrow {
        width: 48px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0.9;
    transition: opacity 0.2s;
    border: none;
    background: transparent;
    padding: 0;
    }
    .venues__arrow img {
      width: 48px;
      height: 34px;
      object-fit: contain;
      display: block;
    }
    .venues__arrow:hover {
      opacity: 1;
    }
    .venues__arrow:disabled {
      opacity: 0.35;
      cursor: not-allowed;
    }
    .venues__viewport {
      overflow: hidden;
      touch-action: pan-y;
    }
    .venues__grid {
      display: flex;
      gap: 20px;
      transition: transform 0.45s cubic-bezier(0.33, 1, 0.68, 1);
      will-change: transform;
    }
    .venue-card {
      flex: 0 0 calc((100% - 40px) / 3);
      min-width: 0;
      background: var(--white);
      border-radius: var(--radius);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      height: 100%;
    }
    .venue-card__img {
      width: 100%;
      aspect-ratio: 424/282;
      object-fit: cover;
      object-position: center;
      display: block;
      transform: translateZ(0);
    }
    .venue-card__body {
      padding: 16px;
      background: var(--bg-light);
      margin-top: -1px;
      flex: 1;
    }
    .venue-card__title {
      font-size: 20px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .venue-card__text {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
    }


    :root {
  --container-pad: 32px;
}

.container {
  max-width: 1312px;
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--container-pad);
}

.banquet-card > *:not(.bg-overlay):not(.bg-pattern) {
  position: relative;
  z-index: 2;
}

.special-offer-bar > *:not(.bg-overlay):not(.bg-pattern) {
  position: relative;
  z-index: 2;
}

.art-hall-card > *:not(.bg-overlay):not(.bg-pattern) {
  position: relative;
  z-index: 2;
}

@media (max-width: 767px) {
  :root {
  --container-pad: 16px;
  }

  .container {
  padding: 0 var(--container-pad);
  }
}

.cta-buttons {
  display: flex;
  justify-content: center;
  gap: 16px;
  padding: 48px 0;
}

.cta-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 17px 32px;
  background: #c8b478;
  border: 1px solid #c8b478;
  border-radius: 8px;
  font-family: 'TT Norms Pro', sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 21px;
  text-transform: uppercase;
  color: #222;
  text-decoration: none;
  transition: opacity 0.2s;
}

.cta-btn-primary:hover {
  opacity: 0.85;
}

.cta-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 17px 32px;
  background: transparent;
  border: 1px solid #c8b478;
  border-radius: 8px;
  font-family: 'TT Norms Pro', sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 21px;
  text-transform: uppercase;
  color: #222;
  text-decoration: none;
  transition: opacity 0.2s;
}

.cta-btn-outline:hover {
  opacity: 0.7;
}

@media (max-width: 767px) {
  .cta-buttons {
  padding: 32px 0;
  gap: 12px;
  flex-wrap: wrap;
  }

  .cta-btn-primary, .cta-btn-outline {
  padding: 14px 24px;
  font-size: 13px;
  }
}

    /* ===== BONUS BANNER ===== */
    .bonus-banner {
      position: relative;
      border-radius: var(--radius);
      overflow: hidden;
      background: var(--bg-light);
    }
    .bonus-banner__bg {
      position: absolute;
      inset: 0;
    }
    .bonus-banner__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .bonus-banner__gradient {
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(36,24,13,0.8) 0%, rgba(36,24,13,0.8) 29.33%, rgba(36,24,13,0.6) 63.64%, rgba(36,24,13,0) 100%);
    }
    .bonus-banner__content {
        position: relative;
    z-index: 1;
    padding: 38px 44px;
    gap: 14px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    }
    .bonus-banner__title {
      font-family: 'ALS Alumna', var(--font);
      font-size: 45px;
      font-weight: 400;
      line-height: 1.1;
      color: var(--white);
      max-width: 996px;
      margin: 0;
    }
    .bonus-banner__list {
      display: flex;
      flex-direction: column;
      gap: 17px;
      width: 740px;
      max-width: 100%;
    }
    .bonus-banner__item {
        display: flex;
    align-items: center;
    gap: 8px;
    font-size: 19px;
    font-weight: 400;
    line-height: 1.1;
    color: var(--white);
    }
    .bonus-banner__item svg {
      flex-shrink: 0;
      margin-top: 2px;
    }

    /* ===== PACKAGES SECTION ===== */
    .packages-section__intro {
      margin-bottom: 28px;
    }
    .packages-section__intro h2 {
      font-size: 36px;
      font-weight: 500;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 12px;
    }
    .packages-section__intro p {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--text);
      max-width: 846px;
    }
    .packages-list {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    .package {
      display: flex;
      border-radius: var(--radius);
      overflow: hidden;
      transition: background 0.3s;
      background: var(--white);
      cursor: pointer;
    }
    .package:hover { opacity: 0.97; }
    .package.open {
      background: var(--bg-light);
    }
    .package__image-wrap {
      flex-shrink: 0;
      width: 500px;
      height: 140px;
      overflow: hidden;
      border-radius: var(--radius);
      align-self: center;
      transition: height 0.5s cubic-bezier(0.33, 1, 0.68, 1);
    }
    .packages-list .package__image {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      border-radius: var(--radius);
    }
    .package__content {
      flex: 1;
      display: flex;
      flex-direction: column;
      min-width: 0;
    }
    .package__header {
      display: flex;
      align-items: center;
      gap: 32px;
      padding: 0 16px 0 32px;
    }
    .package__info {
      flex: 1;
      padding: 32px 0;
    }
    .package__title {
      font-size: 24px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .package__subtitle {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
    }
    .package__toggle-btn {
      flex-shrink: 0;
      width: 56px;
      height: 56px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--bg-light);
      transition: all 0.3s;
    }
    .package.open .package__toggle-btn {
      background: var(--white);
    }
    .package__toggle-btn svg {
      width: 32px;
      height: 32px;
      transition: transform 0.3s;
    }
    .package.open .package__toggle-btn svg {
      transform: rotate(180deg);
    }
    .package__body {
      display: grid;
      grid-template-rows: 0fr;
      transition: grid-template-rows 0.5s cubic-bezier(0.33, 1, 0.68, 1);
    }
    .package.open .package__body {
      grid-template-rows: 1fr;
    }
    .package__body-inner {
      overflow: hidden;
      padding: 0 16px 0 32px;
    }
    .package.open .package__body-inner {
      padding-bottom: 32px;
    }
    .package__body ul {
      padding-left: 27px;
    }
    .package__body ul li {
      font-size: 18px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 5px;
    }
    .package__body-title {
      font-size: 18px;
      font-weight: 500;
      line-height: 1.4;
      color: var(--dark);
      margin-top: 16px;
    }

    /* ===== BOOKING CONDITIONS ===== */
    .booking-conditions {
      display: flex;
      gap: 20px;
      height: 480px;
    }
    .booking-conditions__cards {
      flex: 1;
      display: flex;
      gap: 20px;
    }
    .booking-cond-card {
      flex: 1;
      position: relative;
      border-radius: var(--radius);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      padding: 24px;
    }
    .booking-cond-card__bg {
      position: absolute;
      inset: 0;
    }
    .booking-cond-card__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .booking-cond-card__overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(36,24,13,0) 27.46%, rgba(36,24,13,0.9) 100%);
      z-index: 1;
    }
    .booking-cond-card__content {
      position: relative;
      z-index: 2;
      color: var(--white);
    }
    .booking-cond-card__content h3 {
      font-size: 26px;
      font-weight: 500;
      line-height: 1.1;
      margin-bottom: 8px;
    }
    .booking-cond-card__content p {
      font-size: 18px;
      line-height: 1.4;
    }
    .booking-cond-card__content .booking-cond-card__note {
      font-size: 14px;
      opacity: 0.7;
      margin-top: 8px;
    }

    .booking-cta-card {
      flex: 1;
      position: relative;
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 24px;
      overflow: hidden;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }
    .booking-cta-card__flower {
      position: absolute;
      bottom: -203px;
      right: -151px;
      width: 619px;
      height: 619px;
      object-fit: cover;
      pointer-events: none;
    }
    .booking-cta-card h3 {
      font-size: 26px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .booking-cta-card p {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
    }

    /* ===== BRIDE'S MORNING ===== */
    .bride-morning {
      display: flex;
      gap: 20px;
      align-items: stretch;
    }
    .bride-morning__info {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 24px;
    }
    .bride-morning__info h3 {
      font-size: 24px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .bride-morning__info > div p {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
    }
    .bride-morning__info ul {
      padding-left: 27px;
      margin-top: 16px;
    }
    .bride-morning__info ul li {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 5px;
    }
    .bride-morning__image {
      flex: 1;
      border-radius: var(--radius);
      overflow: hidden;
    }
    .bride-morning__image img {
        width: 100%;
    height: 100%;
    aspect-ratio: 64 / 46;
    object-fit: cover;
    border-radius: var(--radius);
    }

    /* ===== BACHELORETTE ===== */
    .bachelorette {
      display: flex;
      gap: 28px;
      align-items: center;
    }
    .bachelorette__image {
      flex-shrink: 0;
      width: 565px;
      height: 680px;
      border-radius: var(--radius);
      overflow: hidden;
    }
    .bachelorette__image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .bachelorette__info {
      flex: 1;
    }
    .bachelorette__info h3 {
      font-size: 26px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 12px;
    }
    .bachelorette__info > p {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 20px;
    }
    .bachelorette__info ul {
      padding-left: 27px;
    }
    .bachelorette__info ul li {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 5px;
    }
    .bachelorette__pricing-title {
      font-size: 24px;
      font-weight: 500;
      line-height: 1.4;
      color: var(--dark);
      margin-top: 48px;
      margin-bottom: 16px;
    }
    .bachelorette__prices {
      display: flex;
      gap: 12px;
    }
    .price-card {
      flex: 1;
      display: flex;
      align-items: center;
      gap: 16px;
      background: var(--bg-light);
      border-radius: var(--radius);
      padding: 16px;
    }
    .price-card__count {
      width: 54px;
      height: 54px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--white);
      border-radius: 12px;
      font-size: 20px;
      font-weight: 500;
      color: var(--dark);
      flex-shrink: 0;
    }
    .price-card__amount {
      font-size: 20px;
      font-weight: 500;
      line-height: 1.4;
      color: var(--dark);
    }
    .price-card__old {
      font-size: 16px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
      opacity: 0.5;
      text-decoration: line-through;
    }

    /* ===== CALCULATOR ===== */
    .calculator {
      display: flex;
      gap: 20px;
      align-items: stretch;
    }
    .calculator__form {
      flex: 1;
      background: var(--bg-light);
      border-radius: var(--radius);
      padding: 24px;
    }
    .calculator__form-title {
      font-size: 20px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 16px;
    }
    .calculator__fields {
      display: flex;
      gap: 20px;
      margin-bottom: 20px;
    }
    .field {
      flex: 1;
    }
    .field__label {
      display: block;
      font-size: 16px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 12px;
    }
    .field__input {
      display: flex;
      align-items: center;
      gap: 10px;
      width: 100%;
      height: 52px;
      padding: 16px;
      background: var(--white);
      border: 1px solid #dedaca;
      border-radius: var(--radius-sm);
      font-size: 16px;
      font-family: var(--font);
      color: var(--dark);
    }
    .field__input input {
      flex: 1;
      border: none;
      outline: none;
      font-size: 16px;
      font-family: var(--font);
      color: var(--dark);
      background: transparent;
    }
    .field__input svg {
      flex-shrink: 0;
    }

    .service-type {
      margin-bottom: 32px;
    }
    .service-type__label {
      font-size: 16px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
      margin-bottom: 12px;
    }
    .service-type__buttons {
      display: flex;
      gap: 8px;
    }

    .additional {
      margin-top: 32px;
    }
    .additional__title {
      font-size: 20px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 16px;
    }
    .additional__toggles {
      display: flex;
      gap: 32px;
    }

    .toggle-option {
      display: flex;
      align-items: center;
      gap: 12px;
      cursor: pointer;
    }
    .toggle-switch {
      position: relative;
      width: 54px;
      height: 30px;
      border-radius: 48px;
      background: var(--white);
      transition: background 0.3s;
      flex-shrink: 0;
    }
    .toggle-switch.active {
      background: var(--gold);
    }
    .toggle-switch__circle {
      position: absolute;
      top: 50%;
      left: 3px;
      transform: translateY(-50%);
      width: 24px;
      height: 24px;
      border-radius: 50%;
      background: #ccc;
      transition: all 0.3s;
    }
    .toggle-switch.active .toggle-switch__circle {
      left: auto;
      right: 3px;
      background: var(--white);
    }
    .toggle-option__label {
      font-size: 16px;
      font-weight: 400;
      line-height: 1.4;
      color: var(--dark);
    }
    .toggle-option.active .toggle-option__label {
      font-weight: 500;
      color: var(--gold);
    }

    .calculator__result {
        flex: 1;
    position: relative;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    }
    .calculator__result-flower {
      position: absolute;
      z-index: 0;
      bottom: -32px;
      right: -12px;
      width: 220px;
      height: 220px;
      object-fit: contain;
      object-position: right bottom;
      pointer-events: none;
    }
    .calculator__result-body {
      position: relative;
      z-index: 1;
      padding-right: 180px;
      box-sizing: border-box;
    }
    .calculator__result h3 {
      font-size: 26px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .calculator__result p {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
    }
    .calculator__result-detail {
      font-size: 15px;
      line-height: 1.45;
      color: var(--dark);
      opacity: 0.88;
      margin-bottom: 10px;
      max-width: 100%;
    }
    .field__input input[type="date"] {
      min-width: 0;
      cursor: pointer;
    }
    .field__input input[type="date"]::-webkit-calendar-picker-indicator {
      opacity: 0.6;
      cursor: pointer;
    }
    .calculator__result .btn {
      position: relative;
      z-index: 1;
    }

    /* ===== GALLERY ===== */
    .gallery__grid {
      display: flex;
      gap: 20px;
    }
    .gallery-card {
      flex: 1;
      aspect-ratio: 1;
      position: relative;
      border-radius: var(--radius);
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .gallery-card__bg {
      position: absolute;
      inset: 0;
    }
    .gallery-card__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .gallery-card__overlay {
      position: absolute;
      inset: 0;
      background: rgba(36,24,13,0.5);
      z-index: 1;
    }
    .gallery-card__content {
      position: relative;
      z-index: 2;
      text-align: center;
      color: var(--white);
      padding: 48px;
    }
    .gallery-card__content h3 {
      font-size: 26px;
      font-weight: 500;
      line-height: 1.1;
      margin-bottom: 8px;
    }
    .gallery-card__content p {
      font-size: 18px;
      line-height: 1.4;
    }

    /* ===== FAQ ===== */
    .faq-list {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .faq-item {
      background: var(--bg-light);
      border-radius: 12px;
      overflow: hidden;
    }
    .faq-item__header {
        display: flex;
    background-color: #F7F6F2;
    border: none;
    align-items: flex-start;
    gap: 16px;
    padding: 16px;
    cursor: pointer;
    width: 100%;
    text-align: left;
    }
    .faq-item__question {
      flex: 1;
      font-size: 18px;
      font-weight: 500;
      line-height: 1.5;
      color: var(--text);
    }
    .faq-item__icon {
      flex-shrink: 0;
      width: 24px;
      height: 24px;
      transition: transform 0.3s;
    }
    .faq-item.open .faq-item__icon {
      transform: rotate(45deg);
    }
    .faq-item__answer {
      display: grid;
      grid-template-rows: 0fr;
      transition: grid-template-rows 0.4s cubic-bezier(0.33, 1, 0.68, 1);
    }
    .faq-item.open .faq-item__answer {
      grid-template-rows: 1fr;
    }
    .faq-item__answer-inner {
      overflow: hidden;
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
      padding: 0 16px;
    }
    .faq-item.open .faq-item__answer-inner {
      padding-bottom: 16px;
    }

    /* ===== ADDRESS ===== */
    .address {
      display: flex;
      gap: 32px;
      align-items: stretch;
    }
    .address__map {
      flex: 1;
      border-radius: var(--radius);
      overflow: hidden;
      min-height: 430px;
    }
    .address__map img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .address__info {
      flex: 1;
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 24px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }
    .address__block {
      margin-bottom: 24px;
    }
    .address__block h4 {
      font-size: 24px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .address__block p {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
    }
    .address__buttons {
      display: flex;
      gap: 20px;
    }

    /* ===== CTA BANNER ===== */
    .cta-banner {
      position: relative;
      height: 550px;
      border-radius: var(--radius);
      overflow: hidden;
    }
    .cta-banner__bg {
      position: absolute;
      inset: 0;
    }
    .cta-banner__bg img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .cta-banner__content {
      position: absolute;
      top: 50%;
      right: 200px;
      transform: translateY(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 24px;
      max-width: 403px;
      text-align: center;
      z-index: 1;
    }
    .cta-banner__title {
      font-size: 36px;
      font-weight: 500;
      line-height: 1.1;
      color: var(--gold);
      margin-bottom: 12px;
    }
    .cta-banner__text {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
    }

    /* ===== USEFUL ARTICLES ===== */
    .articles-list {
      display: flex;
      flex-direction: column;
      gap: 20px;
    }
    .article-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--radius);
      padding: 24px;
    }
    .article-card__title {
      font-size: 24px;
      font-weight: 500;
      line-height: 1.2;
      color: var(--dark);
      margin-bottom: 8px;
    }
    .article-card__excerpt {
      font-size: 18px;
      line-height: 1.4;
      color: var(--dark);
      max-height: 106px;
      overflow: hidden;
      margin-bottom: 12px;
    }
    .article-card__link {
      font-size: 14px;
      font-weight: 500;
      text-transform: uppercase;
      color: var(--gold);
      text-decoration: none;
      cursor: pointer;
    }
    .article-card__link:hover { text-decoration: underline; }

    /* ===== SVG Icons ===== */
    .icon-chevron {
      fill: none;
      stroke: var(--dark);
      stroke-width: 2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    /* ==========================================
       LAPTOP — max-width: 1440px
       ========================================== */
    @media (max-width: 1440px) {
      :root { --section-gap: 100px; }

      .hero__title { font-size: 40px; }
      .hero__subtitle { font-size: 24px; }
      .hero__arrows { padding: 0 80px; }

      .section-title { font-size: 32px; }

      .wedding-options__cards { grid-template-columns: repeat(3, minmax(0, 1fr)); }
      .service-card { height: 480px; }

      .venue-card { flex: 0 0 calc((100% - 40px) / 3); min-width: 0; }

      .bonus-banner__title { font-size: 38px; }

      .package__image-wrap { width: 400px; }

      .booking-conditions { height: auto; }
      .booking-cond-card { min-height: 400px; }

      .bachelorette__image { width: 460px; height: 580px; }

      .cta-banner__content { right: 100px; }
    }

    /* ==========================================
       TABLET — max-width: 1024px
       ========================================== */
    @media (max-width: 1024px) {
      :root { --section-gap: 80px; }

      .hero { min-height: 600px; }
      .hero__title { font-size: 34px; }
      .hero__subtitle { font-size: 20px; }
      .hero__content { max-width: 520px; bottom: 80px; }
      .hero__arrows { padding: 0 40px; }
      .hero__arrow { width: 40px; height: 28px; }

      .section-title { font-size: 28px; margin-bottom: 20px; }

      .advantages { grid-template-columns: repeat(2, 1fr); }
      .adv-card { min-height: 220px; }
      .adv-card__title { font-size: 20px; }
      .adv-card__text { font-size: 16px; }
      .adv-card__icon { width: 180px; height: 180px; }

      .wedding-options__cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .service-card { height: 420px; padding: 24px 32px 24px; }
      .service-card__title { font-size: 22px; text-align: center;}
      .service-card__text { font-size: 16px; text-align: center;}
      .wide-banner { height: 220px; padding: 32px; }

      .venues__top { margin-bottom: 20px; }
      .venue-card { flex: 0 0 calc((100% - 20px) / 2); min-width: 0; }
      .venue-card__title { font-size: 18px; }
      .venue-card__text { font-size: 16px; }

      .bonus-banner__title { font-size: 32px; max-width: 700px; }
      .bonus-banner__list { gap: 12px; }
      .bonus-banner__item { font-size: 16px; }

      .packages-section__intro h2 { font-size: 28px; }
      .packages-section__intro p { font-size: 16px; }
      .package__image-wrap { width: 300px; }
      .package__header { gap: 20px; padding: 0 12px 0 20px; }
      .package__info { padding: 24px 0; }
      .package__title { font-size: 20px; }
      .package__subtitle { font-size: 16px; }
      .package__toggle-btn { width: 48px; height: 48px; }
      .package__body-inner { padding: 0 12px 0 20px; }
      .package.open .package__body-inner { padding-bottom: 24px; }
      .package__body ul li { font-size: 16px; }

      .booking-conditions { flex-direction: column; height: auto; }
      .booking-conditions__cards { flex: none; height: 360px; }
      .booking-cond-card { min-height: auto; }
      .booking-cta-card { min-height: 280px; }
      .booking-cta-card h3 { font-size: 22px; }
      .booking-cta-card__flower { width: 400px; height: 400px; bottom: -140px; right: -100px; }

      .bride-morning { flex-direction: column-reverse; }
      .bride-morning__image { min-height: 360px; }
      .bride-morning__info h3 { font-size: 22px; }
      .bride-morning__info ul li { font-size: 16px; }

      .bachelorette { flex-direction: column; }
      .bachelorette__image { width: 100%; height: 420px; }
      .bachelorette__info h3 { font-size: 22px; }
      .bachelorette__info > p { font-size: 16px; }
      .bachelorette__info ul li { font-size: 16px; }
      .bachelorette__pricing-title { font-size: 20px; margin-top: 32px; }

      .calculator { flex-direction: column; }
      .calculator__result { min-height: 280px; }
      .calculator__result-body { padding-right: 120px; }
      .calculator__result-flower {
        width: 200px;
        height: 200px;
        bottom: -28px;
        right: -8px;
      }

      .gallery__grid { flex-wrap: wrap; }
      .gallery-card { flex: 1 1 calc(50% - 10px); min-width: 200px; }

      .address { flex-direction: column; }
      .address__map { min-height: 300px; }

      .cta-banner { height: 450px; }
      .cta-banner__content { right: 50%; transform: translate(50%, -50%); max-width: 380px; }

      .btn { height: 48px; padding: 14px 24px; font-size: 13px; }
    }

    /* ==========================================
       MOBILE — max-width: 767px
       ========================================== */
    @media (max-width: 767px) {
      :root { --section-gap: 60px; }

      .container { padding: 0 16px; }
      .sections { padding-top: 60px; padding-bottom: 60px; }

      .hero { min-height: 520px; }
      .hero__title { font-size: 28px; }
      .hero__subtitle { font-size: 18px; }
      .hero__content { max-width: 90%; width: 90%; bottom: 60px; gap: 16px; }
      .hero__arrows { display: none; }

      .section-title { font-size: 24px; margin-bottom: 16px; }

      .advantages { grid-template-columns: repeat(2, 1fr); gap: 8px; }
      .adv-card { min-height: 180px; padding: 16px 16px 70px 16px; }
      .adv-card__title { font-size: 18px; }
      .adv-card__text { font-size: 14px; }
      .adv-card__icon { width: 140px; height: 140px; bottom: -50px; }

      .wedding-options__cards { grid-template-columns: 1fr; }
      .service-card { width: 100%; height: 360px; padding: 24px; }
      .service-card__title { font-size: 20px; }
      .service-card__text { font-size: 15px; }
      .wide-banner { height: 200px; padding: 24px; }
      .wide-banner__content { max-width: 100%; }

      .venues__top {
        gap: 12px;
        margin-bottom: 16px;
      }
      .venues__controls { gap: 8px; }
      .venues__arrow { width: 40px; height: 28px; }
      .venues__arrow img { width: 40px; height: 28px; }
      .venue-card { flex: 0 0 100%; width: 100%; }

      .bonus-banner { height: auto; min-height: 380px; }
      .bonus-banner__content { padding: 24px; gap: 20px; }
      .bonus-banner__title { font-size: 26px; }
      .bonus-banner__list { gap: 10px; }
      .bonus-banner__item { font-size: 15px; }

      .packages-section__intro h2 { font-size: 24px; }
      .packages-section__intro p { font-size: 15px; }

      .package { flex-direction: column; }
      .package__image-wrap {
        width: 100%;
        height: 200px !important;
        align-self: stretch;
        transition: none;
      }
      .package__content { width: 100%; }
      .package__header { padding: 0 16px; gap: 16px; }
      .package__info { padding: 16px 0; }
      .package__title { font-size: 18px; }
      .package__subtitle { font-size: 15px; }
      .package__toggle-btn { width: 40px; height: 40px; }
      .package__toggle-btn svg { width: 24px; height: 24px; }
      .package__body-inner { padding: 0 16px; }
      .package.open .package__body-inner { padding-bottom: 20px; }
      .package__body ul li { font-size: 15px; }

      .booking-conditions { flex-direction: column; }
      .booking-conditions__cards { flex-direction: column; height: auto; gap: 12px; }
      .booking-cond-card { min-height: 280px; }
      .booking-cta-card { min-height: 260px; }
      .booking-cta-card h3 { font-size: 20px; }
      .booking-cta-card p { font-size: 16px; }
      .booking-cta-card__flower { width: 260px; height: 260px; bottom: -125px; right: -110px; }

      .bride-morning__info h3 { font-size: 20px; }
      .bride-morning__info > div p { font-size: 15px; }
      .bride-morning__info ul li { font-size: 15px; }
      .bride-morning__image { min-height: 280px; }

      .bachelorette__image { height: 320px; }
      .bachelorette__info h3 { font-size: 20px; }
      .bachelorette__info > p { font-size: 15px; }
      .bachelorette__info ul li { font-size: 15px; }
      .bachelorette__pricing-title { font-size: 18px; }
      .bachelorette__prices { flex-direction: column; }
      .price-card { padding: 12px; }
      .price-card__count { width: 44px; height: 44px; font-size: 18px; }
      .price-card__amount { font-size: 18px; }

      .calculator__form { padding: 16px; }
      .calculator__form-title { font-size: 18px; }
      .calculator__fields { flex-direction: column; gap: 16px; }
      .field__label { font-size: 15px; }
      .field__input { height: 48px; font-size: 15px; }
      .field__input input { font-size: 15px; }
      .additional__toggles { flex-direction: column; gap: 16px; }
      .calculator__result { min-height: 240px; padding: 20px; padding-bottom: 132px; }
      .calculator__result-body { padding-right: 0; }
      .calculator__result h3 { font-size: 22px; }
      .calculator__result p { font-size: 15px; }
      .calculator__result-flower {
        width: 140px;
        height: 140px;
        bottom: 8px;
        right: 8px;
      }

      .gallery__grid { flex-wrap: wrap; }
      .gallery-card { flex: 1 1 calc(50% - 10px); min-width: 0; }
      .gallery-card__content h3 { font-size: 20px; }
      .gallery-card__content p { font-size: 15px; }
      .gallery-card__content { padding: 24px; }

      .faq-item__question { font-size: 16px; }
      .faq-item__answer-inner { font-size: 15px; padding: 0 12px; }
      .faq-item.open .faq-item__answer-inner { padding-bottom: 12px; }

      .address__map { min-height: 240px; }
      .address__info { padding: 20px; }
      .address__block h4 { font-size: 20px; }
      .address__block p { font-size: 16px; }
      .address__buttons { flex-direction: column; gap: 12px; }

      .cta-banner { height: 400px; }
      .cta-banner__content { max-width: 320px; }
      .cta-banner__title { font-size: 28px; }
      .cta-banner__text { font-size: 15px; }

      .article-card { padding: 16px; }
      .article-card__title { font-size: 20px; }
      .article-card__excerpt { font-size: 15px; }

      .btn { height: 46px; padding: 12px 20px; font-size: 13px; }
    }/* End custom CSS */