:root {
  --ain-green: #2F4F3D;
  --ain-green-dark: #243d2f;
  --ain-beige: #FAF9F6;
  --ain-text: #7a7a7a;
  --ain-dark: #0f1410;
  --ain-white: #ffffff;
  --ain-border: #e7e5e4;
  --ain-heading: "Playfair Display", serif;
  --ain-body: "Inter", sans-serif;
}

body {
  font-family: var(--ain-body);
  color: var(--ain-text);
}

.elementor-location-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 60;
  width: 100%;
  height: 0;
  min-height: 0 !important;
  overflow: visible;
  background: transparent !important;
}

.elementor-location-header > .elementor,
.elementor-location-header .e-con,
.elementor-location-header .elementor-element,
.elementor-location-header .elementor-widget-container {
  background: transparent !important;
}

.ain-section {
  position: relative;
}

.ain-container {
  width: min(1280px, calc(100% - 3rem));
  margin: 0 auto;
}

.ain-centered {
  text-align: center;
}

.ain-media-bg,
.ain-split__media,
.ain-room-preview__media,
.ain-season-card,
.ain-map-placeholder,
.ain-gallery-grid__item {
  position: relative;
  overflow: hidden;
}

.ain-media-bg img,
.ain-split__media img,
.ain-room-preview__media img,
.ain-season-card img,
.ain-map-placeholder img,
.ain-gallery-grid__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ain-overlay {
  position: absolute;
  inset: 0;
  background: #000;
}

.ain-overlay--hero {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.75));
}

.ain-overlay--green {
  background: linear-gradient(135deg, rgba(47, 79, 61, 0.88), rgba(30, 48, 36, 0.78));
}

.ain-overlay--dark {
  background: rgba(15, 20, 16, 0.84);
}

.ain-eyebrow {
  margin: 0 0 1rem;
  font-size: 0.68rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ain-green);
}

.ain-eyebrow--light {
  color: rgba(255, 255, 255, 0.75);
}

.ain-eyebrow--dim {
  color: rgba(255, 255, 255, 0.35);
}

.ain-button,
.ain-button:visited {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.6rem;
  background: var(--ain-green);
  color: var(--ain-white);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.74rem;
  transition: 0.2s ease;
}

.ain-button:hover {
  background: var(--ain-green-dark);
  color: var(--ain-white);
}

.ain-button--ghost,
.ain-button--ghost:visited {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.55);
  color: var(--ain-white);
}

.ain-button--ghost:hover {
  background: var(--ain-white);
  color: var(--ain-green);
}

.ain-link,
.ain-link:visited {
  color: var(--ain-green);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.8rem;
}

.ain-link--light,
.ain-link--light:visited {
  color: var(--ain-white);
}

.ain-site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: transparent;
  padding: 1.5rem 0;
  min-height: 0 !important;
  height: 0;
  overflow: visible;
  transition: all 0.5s ease;
}

.ain-site-header.is-scrolled,
body:not(.home) .ain-site-header {
  background: rgba(15, 20, 16, 0.97);
  backdrop-filter: blur(8px);
  padding: 1rem 0;
}

.ain-site-header__inner {
  min-height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  width: min(1320px, calc(100% - 3rem));
  margin: 0 auto;
}

.ain-header-desktop,
.ain-header-mobile {
  display: flex;
  align-items: center;
}

.ain-header-desktop {
  gap: 1rem;
  margin-left: auto;
}

.ain-header-mobile {
  display: none !important;
  gap: 1rem;
  margin-left: auto;
}

.ain-header-mobile .elementor-widget,
.ain-header-mobile .elementor-widget-container,
.ain-e-nav-mobile .elementor-menu-toggle,
.ain-e-nav-mobile .elementor-nav-menu--dropdown {
  display: none !important;
}

.ain-site-header .elementor-widget,
.ain-site-header .elementor-widget-container {
  width: auto;
}

.ain-site-header__brand,
.ain-site-header__brand:visited {
  color: var(--ain-white);
  text-decoration: none;
  font-family: var(--ain-heading);
  font-size: 1.1rem;
}

.ain-header-nav,
.ain-footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ain-header-nav {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.ain-header-nav a,
.ain-header-nav a:visited,
.ain-footer-nav a,
.ain-footer-nav a:visited {
  color: inherit;
  text-decoration: none;
}

.ain-header-nav a {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.82rem;
}

.ain-site-footer {
  background: var(--ain-dark);
  color: rgba(255, 255, 255, 0.58);
}

.ain-site-footer__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3rem;
  padding: 4rem 0 3rem;
}

.ain-site-footer__brand {
  font-family: var(--ain-heading);
  font-size: 1.2rem;
  color: var(--ain-white);
}

.ain-footer-nav li + li {
  margin-top: 0.55rem;
}

.ain-site-footer__grid > div:last-child {
  text-align: right;
}

.ain-site-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
  padding: 1rem 0 1.5rem;
  font-size: 0.78rem;
}

.ain-site-footer__meta {
  margin-top: 1rem;
}

.ain-home-hero {
  min-height: 100svh;
  overflow: hidden;
}

.ain-home-hero .ain-media-bg {
  position: absolute;
  inset: 0;
}

.ain-home-hero__inner {
  position: relative;
  z-index: 1;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 7rem 0 3rem;
}

.ain-home-hero__center {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
}

.ain-home-hero__brandplate {
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.88);
  font-family: var(--ain-heading);
  font-size: clamp(3rem, 10vw, 6.5rem);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: center;
}

.ain-vertical-rule {
  width: 1px;
  height: 2.25rem;
  background: rgba(255, 255, 255, 0.2);
}

.ain-home-hero__bottom h1,
.ain-page-header h1,
.ain-green-cta h2,
.ain-split h2,
.ain-copy-intro h2,
.ain-activities-hero h2,
.ain-section-head h2,
.ain-dark-panel h3,
.ain-room-preview__content h2,
.ain-room-preview__content h3,
.ain-season-card h3,
.ain-map-panel h2,
.ain-booking-shell h2,
.ain-price-table h2 {
  margin: 0;
  font-family: var(--ain-heading);
  color: #1c1c1c;
  line-height: 1.05;
}

.ain-home-hero__bottom h1 {
  color: var(--ain-white);
  font-size: clamp(3rem, 8vw, 6rem);
  max-width: 18ch;
  margin-bottom: 1.5rem;
}

.ain-booking-bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ain-booking-bar > div,
.ain-booking-bar > a {
  padding: 1.35rem 1.15rem;
}

.ain-booking-bar > div {
  border-right: 1px solid rgba(255, 255, 255, 0.15);
}

.ain-booking-bar label {
  display: block;
  margin-bottom: 0.55rem;
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.48);
}

.ain-booking-bar span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.92rem;
}

.ain-booking-bar input,
.ain-booking-bar select {
  width: 100%;
  background: transparent;
  color: var(--ain-white);
  font-size: 0.875rem;
  padding: 0 0 0.25rem;
  border: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  outline: none;
  box-shadow: none;
}

.ain-booking-bar input:focus,
.ain-booking-bar select:focus {
  border-bottom-color: rgba(255, 255, 255, 0.7);
}

.ain-booking-bar input {
  color-scheme: dark;
}

.ain-booking-bar select option {
  background: #1c1917;
}

.ain-booking-bar__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: var(--ain-green);
  color: var(--ain-white);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-size: 0.75rem;
  transition: background 0.2s ease;
}

.ain-booking-bar__cta:hover {
  background: var(--ain-green-dark);
  color: var(--ain-white);
}

.ain-split,
.ain-room-preview,
.ain-two-col,
.ain-activities-hero__grid,
.ain-address-strip__inner,
.ain-map-panel__inner,
.ain-two-col--contact {
  display: grid;
  gap: 0;
}

.ain-split {
  grid-template-columns: 55% 45%;
  min-height: 480px;
}

.ain-split__text,
.ain-room-preview__content,
.ain-copy-intro .ain-two-col,
.ain-map-panel__inner,
.ain-two-col,
.ain-two-col--contact {
  gap: 3rem;
}

.ain-split__text,
.ain-room-preview__content {
  padding: 5rem 4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.ain-split__text p,
.ain-room-preview__content p,
.ain-copy-intro p,
.ain-two-col p,
.ain-glass-card p,
.ain-season-card p,
.ain-code-note p,
.ain-form__actions p,
.ain-contact-details p {
  line-height: 1.7;
}

.ain-split__text h2,
.ain-copy-intro h2,
.ain-green-cta h2 {
  font-size: clamp(2rem, 4vw, 3.6rem);
  margin-bottom: 1rem;
}

.ain-split__text p:not(.ain-eyebrow) {
  margin: 0 0 1.5rem;
}

.ain-split__media {
  min-height: 380px;
}

.ain-activities-hero,
.ain-dark-panel,
.ain-green-cta {
  overflow: hidden;
}

.ain-activities-hero .ain-media-bg,
.ain-dark-panel .ain-media-bg {
  position: absolute;
  inset: 0;
}

.ain-activities-hero__grid,
.ain-dark-panel .ain-two-col {
  position: relative;
  z-index: 1;
  grid-template-columns: 55% 45%;
  gap: 4rem;
  padding: 7rem 0;
  align-items: center;
}

.ain-activities-hero__grid h2,
.ain-dark-panel h3,
.ain-green-cta h2,
.ain-season-card h3 {
  color: var(--ain-white);
}

.ain-activities-hero__grid > div > p:not(.ain-eyebrow),
.ain-dark-panel p:not(.ain-eyebrow) {
  color: rgba(255, 255, 255, 0.78);
}

.ain-card-list {
  display: grid;
  gap: 1rem;
}

.ain-glass-card {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(10px);
  padding: 1.5rem;
}

.ain-glass-card h3 {
  color: var(--ain-white);
  font-family: var(--ain-heading);
  margin: 0 0 0.5rem;
}

.ain-facts {
  background: var(--ain-white);
  border-top: 1px solid var(--ain-border);
  border-bottom: 1px solid var(--ain-border);
}

.ain-facts-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 3rem 0;
}

.ain-fact {
  padding: 0 2rem;
  border-left: 1px solid var(--ain-border);
}

.ain-fact:first-child {
  border-left: 0;
  padding-left: 0;
}

.ain-fact__num {
  margin: 0 0 0.5rem;
  font-family: var(--ain-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--ain-green);
  line-height: 1;
}

.ain-fact__label,
.ain-info-box__label,
.ain-room-preview__num,
.ain-table__head,
.ain-code-note pre,
.ain-form label span {
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.ain-fact__label {
  margin: 0;
  font-size: 0.68rem;
}

.ain-rooms-preview,
.ain-home-info,
.ain-page-header,
.ain-copy-intro,
.ain-map-panel,
.ain-price-table,
.ain-gallery-grid,
.ain-address-strip {
  background: var(--ain-beige);
}

.ain-section-head,
.ain-room-preview-stack,
.ain-gallery-grid,
.ain-nearby-list {
  width: min(1280px, calc(100% - 3rem));
  margin: 0 auto;
}

.ain-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 2rem;
  padding: 4rem 0 2rem;
}

.ain-room-preview-stack {
  display: grid;
}

.ain-room-preview {
  display: grid;
  grid-template-columns: 62% 38%;
}

.ain-room-preview--reverse {
  grid-template-columns: 38% 62%;
}

.ain-room-preview--reverse .ain-room-preview__media {
  order: 2;
}

.ain-room-preview--reverse .ain-room-preview__content {
  order: 1;
  background: #f8f7f5;
}

.ain-room-preview__media {
  min-height: 420px;
}

.ain-room-preview__num {
  display: block;
  color: #c7c3bc;
  margin-bottom: 1.2rem;
  font-size: 0.68rem;
}

.ain-room-preview__content h2,
.ain-room-preview__content h3 {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  margin-bottom: 1rem;
}

.ain-room-preview__content ul,
.ain-simple-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ain-room-preview__content li,
.ain-simple-list li {
  margin-bottom: 0.55rem;
}

.ain-room-preview__size {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--ain-border);
  font-size: 0.85rem;
}

.ain-season-cards {
  background: var(--ain-white);
  padding: 5rem 0;
}

.ain-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

.ain-season-card {
  min-height: 360px;
}

.ain-season-card > div,
.ain-season-card > .e-con {
  position: absolute;
  inset: auto 0 0 0;
  padding: 2.5rem;
  z-index: 2;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0.1));
}

.ain-season-card h3 {
  margin-bottom: 0.75rem;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
}

.ain-home-info {
  background: var(--ain-white);
  padding: 3rem 0 4rem;
}

.ain-info-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--ain-border);
  background: var(--ain-border);
}

.ain-info-box {
  background: var(--ain-white);
  padding: 1.5rem;
}

.ain-info-box__label {
  margin: 0 0 0.5rem;
  font-size: 0.63rem;
}

.ain-info-box__value {
  margin: 0;
  color: #444;
}

.ain-green-cta {
  background: var(--ain-green);
  color: var(--ain-white);
  padding: 6rem 0;
}

.ain-green-cta .ain-button {
  margin-top: 1.5rem;
}

.ain-page-header {
  position: relative;
}

.ain-page-header .ain-media-bg {
  position: absolute;
  inset: 0;
}

.ain-page-header .ain-container {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: end;
  padding: 7rem 0 2.5rem;
}

.ain-page-header__content {
  max-width: 860px;
}

.ain-page-header h1 {
  color: var(--ain-white);
  font-size: clamp(2.3rem, 5vw, 4.2rem);
}

.ain-copy-intro {
  padding: 3.5rem 0;
  background: var(--ain-white);
}

.ain-copy-intro .ain-two-col,
.ain-two-col,
.ain-two-col--contact,
.ain-map-panel__inner {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}

.ain-map-panel {
  padding: 4rem 0;
  background: #f2f1ef;
}

.ain-map-placeholder {
  min-height: 360px;
}

.ain-map-panel__inner,
.ain-address-strip__inner {
  align-items: center;
}

.ain-address-strip {
  background: var(--ain-white);
  border-bottom: 1px solid var(--ain-border);
}

.ain-address-strip__inner {
  grid-template-columns: 1fr auto;
  gap: 2rem;
  padding: 1.2rem 0;
}

.ain-price-table {
  background: var(--ain-white);
  padding: 1.5rem 0 3rem;
  border-top: 1px solid var(--ain-border);
}

.ain-table {
  border-top: 1px solid var(--ain-border);
  margin-top: 1.25rem;
}

.ain-table__head,
.ain-table__row {
  display: grid;
  grid-template-columns: 1.5fr 0.75fr 0.75fr;
  gap: 1rem;
  align-items: center;
  padding: 1rem 0;
  border-bottom: 1px solid var(--ain-border);
}

.ain-table__head {
  font-size: 0.7rem;
  color: #888;
}

.ain-nearby-list {
  display: grid;
  gap: 0;
}

.ain-nearby-list__row {
  display: grid;
  grid-template-columns: 1.2fr 0.6fr 0.6fr 1.6fr;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--ain-border);
}

.ain-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
  padding: 2rem 0 4rem;
}

.ain-gallery-grid__item {
  min-height: 220px;
}

.ain-gallery-grid__item img {
  transition: transform 0.35s ease;
}

.ain-gallery-grid__item:hover img {
  transform: scale(1.04);
}

.ain-contact-details a {
  color: var(--ain-green);
}

.ain-form {
  display: grid;
  gap: 1.25rem;
}

.ain-form__row {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ain-form__row:last-of-type {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ain-form label span {
  display: block;
  margin-bottom: 0.45rem;
  font-size: 0.62rem;
}

.ain-form input,
.ain-form select,
.ain-form textarea {
  width: 100%;
  padding: 0.85rem 0.95rem;
  border: 1px solid var(--ain-border);
  background: var(--ain-white);
  font: inherit;
  color: #222;
}

.ain-form textarea {
  resize: vertical;
}

.ain-form__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.ain-form__actions p {
  margin: 0;
  font-size: 0.82rem;
}

.ain-form-status {
  margin-bottom: 1rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--ain-border);
}

.ain-form-status--success {
  background: #eef5ef;
  color: var(--ain-green-dark);
}

.ain-form-status--error {
  background: #fdf0f0;
  color: #8b2e2e;
}

.ain-booking-shell {
  background: var(--ain-white);
  border: 1px solid var(--ain-border);
  padding: 2rem;
  margin-bottom: 2rem;
}

.ain-code-note {
  background: var(--ain-white);
  border: 1px solid var(--ain-border);
  padding: 1.5rem;
}

.ain-code-note pre {
  overflow-x: auto;
  background: #111827;
  color: #f5f5f5;
  padding: 1rem;
  font-size: 0.72rem;
}

@media (max-width: 1024px) {
  .ain-site-footer__grid,
  .ain-card-grid,
  .ain-info-grid,
  .ain-facts-grid,
  .ain-gallery-grid,
  .ain-nearby-list__row,
  .ain-booking-bar,
  .ain-room-preview,
  .ain-room-preview--reverse,
  .ain-split,
  .ain-activities-hero__grid,
  .ain-dark-panel .ain-two-col,
  .ain-copy-intro .ain-two-col,
  .ain-two-col,
  .ain-two-col--contact,
  .ain-map-panel__inner,
  .ain-address-strip__inner,
  .ain-form__row,
  .ain-form__row:last-of-type {
    grid-template-columns: 1fr;
  }

  .elementor-element.e-con.ain-split,
  .elementor-element.e-con.ain-activities-hero__grid,
  .elementor-element.e-con.ain-facts-grid,
  .elementor-element.e-con.ain-card-grid,
  .elementor-element.e-con.ain-room-preview,
  .elementor-element.e-con.ain-room-preview.ain-room-preview--reverse,
  .elementor-element.e-con.ain-two-col,
  .elementor-element.e-con.ain-copy-intro.ain-two-col,
  .elementor-element.e-con.ain-info-grid,
  .elementor-element.e-con.ain-site-footer__grid {
    grid-template-columns: 1fr !important;
  }

  .ain-room-preview--reverse .ain-room-preview__media,
  .ain-room-preview--reverse .ain-room-preview__content {
    order: initial;
  }

  .ain-site-footer__bottom,
  .elementor-element.e-con.ain-site-footer__bottom,
  .ain-form__actions,
  .ain-section-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .ain-home-hero__inner,
  .ain-page-header .ain-container {
    width: min(1280px, calc(100% - 2rem));
  }

  .ain-room-preview__content,
  .ain-split__text {
    padding: 3rem 1.5rem;
  }

  .ain-header-desktop {
    display: flex !important;
    gap: 0.75rem;
  }

  .ain-header-divider,
  .ain-e-header-cta {
    display: none !important;
  }

  .ain-e-nav .elementor-menu-toggle {
    display: inline-flex !important;
  }

  .ain-e-nav .elementor-nav-menu--main {
    display: none !important;
  }

  .ain-e-nav .elementor-nav-menu--dropdown {
    margin-top: 1rem;
    padding: 1.25rem 1.5rem 1.5rem;
    background: rgba(15, 20, 16, 0.99);
  }

  .ain-e-nav .elementor-nav-menu--dropdown a,
  .ain-e-nav .elementor-nav-menu--dropdown a:visited {
    color: rgba(255, 255, 255, 0.65);
  }

  .ain-e-nav .elementor-nav-menu--dropdown a:hover,
  .ain-e-nav .elementor-nav-menu--dropdown a.elementor-item-active {
    color: var(--ain-white);
  }

  .ain-site-header {
    padding: 1rem 0;
    background: rgba(15, 20, 16, 0.97);
    backdrop-filter: blur(8px);
  }

  .ain-site-footer__grid > div:last-child {
    text-align: left;
  }
}

.ain-e-nav .elementor-nav-menu,
.ain-e-footer-nav .elementor-nav-menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.ain-e-nav .elementor-nav-menu--main .elementor-nav-menu {
  display: flex;
  align-items: center;
  gap: 1.15rem;
}

.ain-e-nav .elementor-menu-toggle {
  display: none !important;
}

.ain-e-nav .elementor-item,
.ain-e-nav .elementor-item:visited {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.82rem;
  text-decoration: none;
  letter-spacing: 0.05em;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
}

.ain-e-nav .elementor-item:hover,
.ain-e-nav .elementor-item.elementor-item-active {
  color: var(--ain-white);
  border-bottom-color: rgba(255, 255, 255, 0.5);
}

.ain-e-nav .menu-item:first-child,
.ain-e-nav-mobile .menu-item:first-child {
  display: none;
}

.ain-e-nav-mobile {
  display: none !important;
}

.ain-e-nav-mobile .elementor-menu-toggle {
  padding: 0.25rem;
  background: transparent;
  color: var(--ain-white);
  border: 0;
}

.ain-e-nav-mobile .elementor-nav-menu--dropdown {
  margin-top: 1rem;
  padding: 1.25rem 1.5rem 1.5rem;
  background: rgba(15, 20, 16, 0.99);
}

.ain-e-nav-mobile .elementor-nav-menu--dropdown a,
.ain-e-nav-mobile .elementor-nav-menu--dropdown a:visited {
  color: rgba(255, 255, 255, 0.65);
}

.ain-e-nav-mobile .elementor-nav-menu--dropdown a:hover,
.ain-e-nav-mobile .elementor-nav-menu--dropdown a.elementor-item-active {
  color: var(--ain-white);
}

.ain-header-divider .elementor-widget-container {
  width: 1px;
  height: 14px;
  background: rgba(255, 255, 255, 0.15);
}

.ain-lang-switcher .elementor-widget-container {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  color: rgba(255, 255, 255, 0.35);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ain-lang-switcher button {
  color: inherit;
  background: none;
  border: none;
  cursor: default;
  padding: 2px 3px;
  font: inherit;
  border-bottom: 1px solid transparent;
}

.ain-lang-switcher button.is-active {
  color: #fff;
  font-weight: 600;
  border-bottom-color: rgba(255, 255, 255, 0.5);
}

.ain-lang-switcher span {
  color: rgba(255, 255, 255, 0.2);
  font-size: 0.6rem;
}

.ain-lang-switcher--mobile .elementor-widget-container {
  gap: 0.25rem;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
}

.ain-lang-switcher .elementor-text-editor {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.ain-lang-switcher .is-active {
  color: #fff;
  font-weight: 600;
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}

.ain-lang-switcher .is-inactive {
  color: rgba(255, 255, 255, 0.35);
}

.ain-header-divider .elementor-text-editor {
  width: 1px;
  height: 14px;
  background: rgba(255, 255, 255, 0.15);
  text-indent: -9999px;
  overflow: hidden;
}

.ain-header-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem;
  color: var(--ain-white);
  background: none;
  border: 0;
  cursor: pointer;
}

.ain-header-toggle svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
}

.ain-header-toggle .ain-icon-close {
  display: none;
}

.ain-site-header.is-menu-open .ain-header-toggle .ain-icon-menu {
  display: none;
}

.ain-site-header.is-menu-open .ain-header-toggle .ain-icon-close {
  display: block;
}

.ain-mobile-menu {
  display: none;
  padding: 1.25rem 1.5rem 1.5rem;
  background: rgba(15, 20, 16, 0.99);
}

.ain-mobile-menu nav {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.ain-mobile-menu a,
.ain-mobile-menu a:visited {
  color: rgba(255, 255, 255, 0.65);
  text-decoration: none;
  transition: color 0.2s ease;
}

.ain-mobile-menu a:hover {
  color: var(--ain-white);
}

.ain-mobile-menu__cta,
.ain-mobile-menu__cta:visited {
  margin-top: 0.5rem;
  display: block;
  text-align: center;
  padding: 0.75rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--ain-white);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-size: 0.72rem;
  text-decoration: none;
}

.ain-site-header.is-menu-open .ain-mobile-menu {
  display: block;
}

.ain-e-footer-nav .elementor-item,
.ain-e-footer-nav .elementor-item:visited {
  color: inherit;
  text-decoration: none;
}

.ain-e-footer-nav .elementor-nav-menu {
  display: grid;
  gap: 0.55rem;
}

.ain-e-header-cta .elementor-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.55) !important;
  color: var(--ain-white) !important;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.74rem;
  padding: 0.45rem 1.3rem;
  box-shadow: none !important;
}

.ain-e-header-cta .elementor-button:hover {
  background: var(--ain-white) !important;
  color: var(--ain-green) !important;
}

.ain-button-widget .elementor-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.95rem 1.6rem;
  background: var(--ain-green);
  color: var(--ain-white);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.74rem;
  border-radius: 0;
}

.ain-button-widget .elementor-button:hover {
  background: var(--ain-green-dark);
  color: var(--ain-white);
}

.ain-button-widget--ghost .elementor-button {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.55);
  color: var(--ain-white);
}

.ain-button-widget--ghost .elementor-button:hover {
  background: var(--ain-white);
  color: var(--ain-green);
}

.ain-brand-link .elementor-heading-title,
.ain-brand-link .elementor-heading-title a,
.ain-brand-link .elementor-heading-title a:visited {
  color: var(--ain-white);
  text-decoration: none;
  font-family: var(--ain-heading);
}

.ain-footer-brand .elementor-widget-container {
  font-family: var(--ain-heading);
  font-size: 1.2rem;
  color: var(--ain-white);
}

.ain-bg-hero,
.ain-bg-guesthouse,
.ain-bg-breakfast,
.ain-bg-hiking,
.ain-bg-room-double,
.ain-bg-room-family,
.ain-bg-room-large,
.ain-bg-alps,
.ain-bg-summer,
.ain-bg-ski,
.ain-bg-rafting,
.ain-bg-road,
.ain-bg-mtb,
.ain-bg-room-view,
.ain-bg-village {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.ain-bg-hero {
  background-image: url("./hero-aineterhof.jpg");
}

.ain-bg-guesthouse {
  background-image: url("https://images.unsplash.com/photo-1770932345647-ca6f3ddd6309?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-breakfast {
  background-image: url("https://images.unsplash.com/photo-1628412277158-f0f551fc47c3?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-hiking {
  background-image: url("https://images.unsplash.com/photo-1767556313435-425c24ad6f67?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-room-double {
  background-image: url("https://images.unsplash.com/photo-1762779943673-fcb177e7fe56?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-room-family {
  background-image: url("https://images.unsplash.com/photo-1648766378129-11c3d8d0da05?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-room-large {
  background-image: url("https://images.unsplash.com/photo-1558277872-bb3f50054da2?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-alps {
  background-image: url("https://images.unsplash.com/photo-1767458254184-8c5ba8f8bbe4?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-summer {
  background-image: url("https://images.unsplash.com/photo-1766489556448-2324f5d675dc?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-ski {
  background-image: url("https://images.unsplash.com/photo-1768752125340-6011e3317377?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-rafting {
  background-image: url("https://images.unsplash.com/photo-1630119297605-cf35866c25c0?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-road {
  background-image: url("https://images.unsplash.com/photo-1761849164174-a1d89eac4398?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-mtb {
  background-image: url("https://images.unsplash.com/photo-1768347442974-48a0af01980d?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-room-view {
  background-image: url("https://images.unsplash.com/photo-1632518741173-9c2d8e962704?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-bg-village {
  background-image: url("https://images.unsplash.com/photo-1772966200682-a1ad3d1bf352?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&q=80&w=1080");
}

.ain-home-hero-native,
.ain-page-header-native,
.ain-activities-hero-native,
.ain-dark-panel-native,
.ain-season-card,
.ain-gallery-grid__item,
.ain-map-placeholder,
.ain-room-preview__media {
  position: relative;
  overflow: hidden;
}

.ain-home-hero-native::before,
.ain-page-header-native::before,
.ain-activities-hero-native::before,
.ain-dark-panel-native::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.ain-home-hero-native::before {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.75));
}

.ain-page-header-native::before {
  background: rgba(0, 0, 0, 0.52);
}

.ain-activities-hero-native::before {
  background: linear-gradient(135deg, rgba(47, 79, 61, 0.88), rgba(30, 48, 36, 0.78));
}

.ain-dark-panel-native::before {
  background: rgba(15, 20, 16, 0.72);
}

.ain-home-hero-native > .e-con,
.ain-page-header-native > .e-con,
.ain-activities-hero-native > .e-con,
.ain-dark-panel-native > .e-con {
  position: relative;
  z-index: 1;
}

.ain-home-hero-native {
  min-height: 100svh;
}

.ain-page-header-native {
  min-height: 42vh;
}

.ain-page-header-native .ain-container {
  min-height: 42vh;
}

.ain-booking-bar__cta {
  padding: 0;
}

.ain-booking-bar__cta .elementor-widget-button,
.ain-booking-bar__cta .elementor-widget-container,
.ain-booking-bar__cta .elementor-button-wrapper,
.ain-booking-bar__cta .elementor-button {
  height: 100%;
}

.ain-booking-bar__cta .elementor-button {
  width: 100%;
  border-radius: 0;
}

.ain-booking-bar__col .elementor-widget-container label,
.ain-booking-bar__col .elementor-widget-container span {
  display: block;
}

.ain-booking-bar__col .elementor-widget-container label {
  margin-bottom: 0.55rem;
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.48);
}

.ain-booking-bar__col .elementor-widget-container span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.92rem;
}

.ain-gallery-grid__item {
  min-height: 220px;
}

.ain-gallery-grid__item:hover {
  transform: scale(1.01);
}

/* Elementor alapértelmezés: flex konténerek. A React design grid-et használ — felül kell írni. */
.elementor-element.e-con.ain-split {
  display: grid !important;
  grid-template-columns: 55% 45%;
  min-height: 480px;
  align-items: stretch;
}

.elementor-element.e-con.ain-activities-hero__grid {
  display: grid !important;
  grid-template-columns: 55% 45%;
  gap: 4rem;
  align-items: center;
}

.elementor-element.e-con.ain-facts-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.elementor-element.e-con.ain-card-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

.elementor-element.e-con.ain-room-preview-stack {
  display: grid !important;
  gap: 0;
}

.elementor-element.e-con.ain-room-preview {
  display: grid !important;
  grid-template-columns: 62% 38%;
}

.elementor-element.e-con.ain-room-preview.ain-room-preview--reverse {
  grid-template-columns: 38% 62%;
}

.elementor-element.e-con.ain-two-col {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 3.5rem;
  align-items: start;
}

.elementor-element.e-con.ain-copy-intro.ain-two-col {
  align-items: center;
  gap: 4rem;
}

.elementor-element.e-con.ain-info-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

/* Hero brand block: grows to fill space, pushing headline+booking to bottom */
.ain-hero-brand-block {
  flex: 1 1 auto !important;
}

/* Admin bar compensation — WP admin bar is 32px, displaces the hero bottom */
.admin-bar .ain-main-hero {
  min-height: calc(100vh - 32px) !important;
}

/* Headline: clamp a referencia designból */
.elementor-9 .elementor-element-85e88b2 .elementor-heading-title {
  font-size: clamp(3rem, 8vw, 6.5rem) !important;
  line-height: 1 !important;
}

/* Booking bar: max-w-2xl (672px), bal oldalra igazítva — a referencia alapján */
.ain-home-hero__booking {
  max-width: 42rem;
  width: 100%;
}

/* Form widget kitölti a booking containert */
.elementor-9 .elementor-element-4868842 {
  width: 100% !important;
  --container-widget-width: 100% !important;
}

.elementor-9 .elementor-element-4868842 .elementor-widget-container,
.elementor-9 .elementor-element-4868842 form.elementor-form {
  width: 100% !important;
}

/* ── Booking bar belső stílus — referencia design alapján ── */
.elementor-9 .elementor-element-4868842 .elementor-form-fields-wrapper {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  flex-wrap: nowrap !important;
  margin: 0 !important;
  width: 100% !important;
}

.elementor-9 .elementor-element-4868842 .elementor-field-group {
  flex: 1 !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 22px 28px !important;
  border-right: 1px solid rgba(255,255,255,0.10) !important;
}

.elementor-9 .elementor-element-4868842 .elementor-field-group:last-of-type {
  border-right: none !important;
}

.elementor-9 .elementor-element-4868842 .elementor-field-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.5) !important;
  margin-bottom: 8px !important;
  display: block !important;
}

.elementor-9 .elementor-element-4868842 .elementor-field {
  background: transparent !important;
  border: none !important;
  color: white !important;
  font-size: 14px !important;
  padding: 0 !important;
  width: 100% !important;
  outline: none !important;
}

.elementor-9 .elementor-element-4868842 select.elementor-field {
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='white' stroke-width='2' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 4px center !important;
  padding-right: 20px !important;
}

.elementor-9 .elementor-element-4868842 .elementor-button-wrapper {
  flex: 0 0 200px !important;
  margin: 0 !important;
  display: flex !important;
  align-items: stretch !important;
}

.elementor-9 .elementor-element-4868842 .elementor-button-wrapper .elementor-button {
  height: 100% !important;
  width: 100% !important;
  border-radius: 0 !important;
  padding: 0 28px !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  background-color: #2F4F3D !important;
}

@media (max-width: 767px) {
  .elementor-9 .elementor-element-4868842 .elementor-form-fields-wrapper {
    flex-direction: column !important;
  }
  .elementor-9 .elementor-element-4868842 .elementor-field-group {
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,0.10) !important;
    padding: 18px 20px !important;
  }
  .elementor-9 .elementor-element-4868842 .elementor-button-wrapper {
    flex: 0 0 auto !important;
    width: 100% !important;
    min-height: 56px !important;
  }
}

.elementor-element.e-con.ain-site-footer__grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 3rem;
  padding: 4rem 0 3rem;
  align-items: start;
}

.elementor-element.e-con.ain-site-footer__bottom {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.07);
  padding: 1rem 0 1.5rem;
  font-size: 0.78rem;
}

.elementor-element.e-con.ain-site-footer__legal {
  display: flex !important;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 1.5rem;
  align-items: center;
}

.ain-footer-legal-link .elementor-button,
.ain-footer-legal-link .elementor-button:focus,
.ain-footer-legal-link .elementor-button:active {
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: rgba(255, 255, 255, 0.58) !important;
  font-size: 0.78rem;
  text-transform: none;
  letter-spacing: normal;
}

.ain-footer-legal-link .elementor-button:hover {
  color: var(--ain-white) !important;
}

.ain-home-hero__headline-stack {
  display: grid;
  gap: 0;
  margin-bottom: 1.25rem;
}

.ain-home-hero__headline-line h1 {
  margin: 0;
  line-height: 1;
}

.ain-link-button .elementor-button,
.ain-link-button .elementor-button:focus,
.ain-link-button .elementor-button:active {
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: var(--ain-green) !important;
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.ain-link-button .elementor-button-content-wrapper {
  align-items: center;
  gap: 0.55rem;
}

.ain-link-button .elementor-button-icon {
  font-size: 0.72rem;
}

.ain-link-button--muted .elementor-button,
.ain-link-button--muted .elementor-button:focus,
.ain-link-button--muted .elementor-button:active {
  color: #8f8a83 !important;
}

.ain-link-button--light .elementor-button,
.ain-link-button--light .elementor-button:focus,
.ain-link-button--light .elementor-button:active {
  color: rgba(255, 255, 255, 0.92) !important;
}

.ain-button-widget--ghost .elementor-button,
.ain-card-booking-button .elementor-button {
  background: transparent !important;
  color: var(--ain-white) !important;
  border: 1px solid rgba(255, 255, 255, 0.6) !important;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
  padding: 0.95rem 1.4rem;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.ain-card-booking-button .elementor-button {
  padding: 0.75rem 1rem;
  font-size: 0.64rem;
}

.ain-button-widget--ghost .elementor-button:hover,
.ain-card-booking-button .elementor-button:hover {
  background: rgba(255, 255, 255, 0.1) !important;
}

.ain-booking-bar .elementor-form-fields-wrapper {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  background: rgba(0, 0, 0, 0.38);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.ain-booking-bar .elementor-field-group {
  margin: 0;
  padding: 1.25rem 1.25rem 1rem;
  border-right: 1px solid rgba(255, 255, 255, 0.15);
}

.ain-booking-bar .elementor-field-group > label {
  margin-bottom: 0.55rem;
  font-size: 0.65rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.48);
}

.ain-booking-bar .elementor-field-group .elementor-field,
.ain-booking-bar .elementor-field-group .elementor-select-wrapper select {
  padding: 0 0 0.3rem;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: 0 !important;
  color: rgba(255, 255, 255, 0.92) !important;
  font-size: 0.92rem;
  min-height: auto;
}

.ain-booking-bar .elementor-field-group .elementor-field:focus,
.ain-booking-bar .elementor-field-group .elementor-select-wrapper select:focus {
  border-bottom-color: rgba(255, 255, 255, 0.72) !important;
}

.ain-booking-bar .elementor-field-group .elementor-select-wrapper::before {
  color: rgba(255, 255, 255, 0.72);
}

.ain-booking-bar .e-form__buttons {
  padding: 0;
  border-right: 0;
}

.ain-booking-bar .e-form__buttons .elementor-button {
  height: 100%;
  width: 100%;
  border-radius: 0 !important;
  background: var(--ain-green) !important;
  color: var(--ain-white) !important;
  box-shadow: none !important;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.72rem;
}

.ain-booking-bar .e-form__buttons .elementor-button:hover {
  background: var(--ain-green-dark) !important;
}

.ain-simple-list-native {
  display: grid;
  gap: 0.55rem;
}

.ain-simple-list-native__item p {
  margin: 0;
  color: #8f8a83;
  font-size: 0.87rem;
}

.ain-activity-card__icon .elementor-icon {
  color: rgba(255, 255, 255, 0.9);
  font-size: 1.35rem;
}

.ain-activity-card__title h3 {
  margin: 0 0 0.25rem;
}

.ain-activity-card__desc p,
.ain-location-distance__text p {
  margin: 0;
}

.ain-location-distance__icon .elementor-icon,
.ain-info-box__icon .elementor-icon {
  color: #bdb7af;
}

.ain-info-box__icon .elementor-icon {
  font-size: 0.95rem;
}

.elementor-element.ain-fact__label .elementor-widget-container p {
  margin: 0;
}

@media (max-width: 1024px) {
  .ain-header-mobile,
  .ain-e-nav-mobile {
    display: none !important;
  }

  .ain-booking-bar .elementor-form-fields-wrapper {
    grid-template-columns: 1fr;
  }

  .ain-booking-bar .elementor-field-group {
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  }

  .ain-booking-bar .e-form__buttons {
    border-bottom: 0;
  }

  .elementor-element.e-con.ain-glass-card.ain-activity-card {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 1rem !important;
  }
}

/* ==========================================================================
   FIGMA PARITY OVERRIDES — Home hero booking bar
   --------------------------------------------------------------------------
   Magas specificitású szabályok (.elementor.elementor-9 = 2 class compound)
   amelyek felülírják a 4868842 form widget saját custom_css beállításait.
   Ezek nélkül a widget custom_css érvényesül és a Figma layout nem stimmel.
   ========================================================================== */

/* AINETERHOF nameplate vertically centered in hero (Figma: justify-center) */
.elementor.elementor-9 .ain-hero-brand-block {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
}

/* Booking container — Figma max-w-2xl (42rem), left-aligned */
.elementor.elementor-9 .ain-home-hero__booking {
  width: 100% !important;
  max-width: 42rem !important;
  align-self: flex-start !important;
  margin: 0 !important;
}

.elementor.elementor-9 .ain-home-hero__booking .elementor-widget-form,
.elementor.elementor-9 .elementor-element-4868842 {
  width: 100% !important;
  max-width: 100% !important;
  --container-widget-width: 100% !important;
  --container-widget-flex-grow: 1 !important;
}

.elementor.elementor-9 .elementor-element-4868842 .elementor-widget-container,
.elementor.elementor-9 .elementor-element-4868842 form.elementor-form {
  width: 100% !important;
  max-width: 100% !important;
}

/* Form fields wrapper — flex row, glass morphism (Figma exact) */
.elementor.elementor-9 .elementor-element-4868842 .elementor-form-fields-wrapper {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: rgba(0, 0, 0, 0.38) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

/* Field groups — equal flex, vertical stack of label+input */
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 1.25rem 1.25rem 1rem !important;
  border-right: 1px solid rgba(255, 255, 255, 0.15) !important;
  border-bottom: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
}

/* Field labels */
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group > label,
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-label {
  display: block !important;
  margin: 0 0 0.5rem !important;
  padding: 0 !important;
  font-size: 0.65rem !important;
  line-height: 1 !important;
  letter-spacing: 0.3em !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.5) !important;
  font-weight: 400 !important;
  font-family: var(--ain-body, "Inter", sans-serif) !important;
}

/* Inputs */
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group .elementor-field,
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group input.elementor-field,
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group select.elementor-field {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 0 0.25rem !important;
  background: transparent !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: 0 !important;
  color: rgba(255, 255, 255, 0.92) !important;
  font-size: 0.875rem !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
  outline: none !important;
  color-scheme: dark !important;
  font-family: var(--ain-body, "Inter", sans-serif) !important;
}

.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group .elementor-field:focus,
.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group select.elementor-field:focus {
  border-bottom-color: rgba(255, 255, 255, 0.7) !important;
  outline: none !important;
}

.elementor.elementor-9 .elementor-element-4868842 .elementor-field-group select.elementor-field option {
  background: #1c1917 !important;
  color: #ffffff !important;
}

/* Submit button cell — auto width (Figma: shrink-0) */
.elementor.elementor-9 .elementor-element-4868842 .e-form__buttons {
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  display: flex !important;
  align-items: stretch !important;
  min-width: 0 !important;
}

.elementor.elementor-9 .elementor-element-4868842 .e-form__buttons .elementor-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100% !important;
  width: auto !important;
  margin: 0 !important;
  padding: 1.25rem 1.75rem !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: var(--ain-green, #2F4F3D) !important;
  background-color: var(--ain-green, #2F4F3D) !important;
  color: #ffffff !important;
  box-shadow: none !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-size: 0.75rem !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  font-family: var(--ain-body, "Inter", sans-serif) !important;
  transition: background-color 0.2s ease !important;
}

.elementor.elementor-9 .elementor-element-4868842 .e-form__buttons .elementor-button:hover {
  background: var(--ain-green-dark, #243d2f) !important;
  background-color: var(--ain-green-dark, #243d2f) !important;
  color: #ffffff !important;
}

/* Mobile breakpoint — stack vertically */
@media (max-width: 1024px) {
  .elementor.elementor-9 .ain-home-hero__booking {
    max-width: 100% !important;
  }

  .elementor.elementor-9 .elementor-element-4868842 .elementor-form-fields-wrapper {
    flex-direction: column !important;
  }

  .elementor.elementor-9 .elementor-element-4868842 .elementor-field-group {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
  }

  .elementor.elementor-9 .elementor-element-4868842 .e-form__buttons {
    border-bottom: 0 !important;
    width: 100% !important;
  }

  .elementor.elementor-9 .elementor-element-4868842 .e-form__buttons .elementor-button {
    width: 100% !important;
    padding: 1.25rem 1.5rem !important;
  }
}
