/* Premium mobile refinement layer. Loaded after the exported inline CSS. */
:root {
  --mp-ink: #0d1a1e;
  --mp-teal: #172c31;
  --mp-teal-deep: #071416;
  --mp-gold: #d0b190;
  --mp-gold-soft: #ead6c0;
  --mp-paper: #fffaf2;
  --mp-paper-warm: #f5efe6;
  --mp-muted: #5c554c;
  --mp-line: rgba(151, 122, 91, 0.2);
  --mp-radius: 14px;
  --mp-shadow: 0 18px 50px rgba(13, 26, 30, 0.12);
}

html {
  scroll-padding-top: 84px !important;
}

body {
  background: var(--mp-paper) !important;
}

a,
button,
input,
select,
textarea {
  -webkit-tap-highlight-color: transparent;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--mp-gold) !important;
  outline-offset: 4px !important;
}

img {
  image-rendering: auto;
}

.btn-primary,
.nav-cta,
.pg-button,
.footer-map-link,
.test-source a,
#perigallo a[href*="perigallo.com"] {
  border-radius: 999px !important;
  min-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  padding: 0 28px !important;
  border: 1px solid rgba(255, 253, 248, 0.22) !important;
  background: linear-gradient(135deg, #e2c7aa 0%, var(--mp-gold) 52%, #b99770 100%) !important;
  color: var(--mp-ink) !important;
  box-shadow: 0 14px 34px rgba(13, 26, 30, 0.16), 0 8px 24px rgba(208, 177, 144, 0.16) !important;
  font-size: 11px !important;
  font-weight: 650 !important;
  letter-spacing: 0.18em !important;
  line-height: 1.15 !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease !important;
}

.btn-primary:hover,
.nav-cta:hover,
.pg-button:hover,
.footer-map-link:hover,
.test-source a:hover,
#perigallo a[href*="perigallo.com"]:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 18px 44px rgba(13, 26, 30, 0.2), 0 12px 30px rgba(208, 177, 144, 0.2) !important;
}

.btn-ghost,
.srv-link {
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 22px !important;
  border: 1px solid rgba(205, 177, 151, 0.34) !important;
  border-radius: 999px !important;
  background: rgba(255, 253, 248, 0.06) !important;
  color: inherit !important;
  text-decoration: none !important;
  line-height: 1.2 !important;
}

.body-text,
.srv p,
.gast-desc,
.test-intro,
.review-text,
.ft-desc {
  color: var(--mp-muted) !important;
  font-weight: 350 !important;
}

.eyebrow,
.srv-tag,
.gallery-kicker,
.test-feature-kicker,
.pg-kicker,
.form-heading,
.fc-title {
  font-weight: 500 !important;
}

.real-img,
.em-item img,
.bodas-photo-grid img,
.srv.img-card img,
.gallery-slide img,
.gallery-thumb img {
  filter: saturate(0.92) contrast(1.04) brightness(0.96);
}

.hero-bg-img {
  filter: saturate(0.86) contrast(1.08) brightness(0.82);
  object-position: 52% 48% !important;
}

.intro-main-img img { object-position: 50% 52% !important; }
.em-item:nth-child(1) img { object-position: 50% 44% !important; }
.em-item:nth-child(2) img { object-position: 50% 46% !important; }
.em-item:nth-child(3) img { object-position: 50% 42% !important; }
.em-item:nth-child(4) img { object-position: 55% 52% !important; }
.em-item:nth-child(5) img { object-position: 50% 45% !important; }
.bodas-photo-grid .ph:nth-child(1) img { object-position: 50% 48% !important; }
.bodas-photo-grid .ph:nth-child(2) img { object-position: 50% 58% !important; }
.bodas-photo-grid .ph:nth-child(3) img { object-position: 50% 52% !important; }
.srv.img-card:nth-child(2) img { object-position: 54% 50% !important; }
.srv.img-card:nth-child(3) img { object-position: 50% 47% !important; }
.gallery-slide:nth-child(3) img { object-position: 50% 43% !important; }

.suite-form-frame {
  width: min(100%, 1080px) !important;
  margin: 56px auto 0 !important;
  overflow: hidden !important;
  border: 1px solid rgba(205, 177, 151, 0.18) !important;
  border-radius: 26px !important;
  background:
    linear-gradient(145deg, rgba(255, 253, 248, 0.08), rgba(255, 253, 248, 0.035)),
    rgba(7, 20, 22, 0.42) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.22), inset 0 1px 0 rgba(255, 253, 248, 0.05) !important;
  position: relative !important;
}

.suite-form-frame::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(205, 177, 151, 0.14), transparent 44%),
    linear-gradient(90deg, transparent, rgba(255, 253, 248, 0.08), transparent) !important;
  pointer-events: none !important;
}

.suite-form-card {
  position: relative !important;
  z-index: 1 !important;
  display: block !important;
  padding: clamp(32px, 5vw, 54px) !important;
  text-align: center !important;
  color: rgba(255, 250, 242, 0.76) !important;
}

.suite-form-card h3 {
  margin: 0 0 18px !important;
  font-family: 'Cormorant Garamond', serif !important;
  font-size: clamp(34px, 4vw, 52px) !important;
  font-weight: 300 !important;
  line-height: 1.05 !important;
  color: #fff8ed !important;
}

.suite-form-card p {
  max-width: 620px !important;
  margin: 0 auto 28px !important;
  font-size: 15px !important;
  line-height: 1.78 !important;
  color: rgba(255, 250, 242, 0.68) !important;
}

.suite-form-note {
  margin-top: 18px !important;
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: 0.24em !important;
  line-height: 1.5 !important;
  text-transform: uppercase !important;
  color: rgba(234, 214, 192, 0.56) !important;
}

@media (min-width: 981px) {
  .hero-awards {
    top: 124px !important;
    right: clamp(48px, 6vw, 96px) !important;
    z-index: 4 !important;
    width: min(390px, 30vw) !important;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 14px !important;
    border: 1px solid rgba(205, 177, 151, 0.2) !important;
    border-radius: 26px !important;
    background:
      linear-gradient(145deg, rgba(7, 20, 22, 0.78), rgba(7, 20, 22, 0.54)),
      radial-gradient(circle at 80% 0%, rgba(205, 177, 151, 0.16), transparent 46%) !important;
    box-shadow: 0 24px 58px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 253, 248, 0.06) !important;
    backdrop-filter: blur(16px) saturate(1.05) !important;
    -webkit-backdrop-filter: blur(16px) saturate(1.05) !important;
  }

  .hero-awards .award-badge {
    display: flex !important;
    min-height: 38px !important;
    width: 100% !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 10px 18px 9px !important;
    border: 1px solid rgba(205, 177, 151, 0.3) !important;
    border-radius: 999px !important;
    background: rgba(13, 26, 30, 0.68) !important;
    color: rgba(245, 239, 230, 0.86) !important;
    font-size: 8.5px !important;
    font-weight: 500 !important;
    line-height: 1.55 !important;
    letter-spacing: 0.24em !important;
    text-align: center !important;
    white-space: nowrap !important;
    box-shadow: inset 0 1px 0 rgba(255, 253, 248, 0.05) !important;
  }

  .hero-awards .award-badge:first-child {
    min-height: 42px !important;
    background: rgba(205, 177, 151, 0.12) !important;
    color: #ecd4b7 !important;
    font-size: 9px !important;
    letter-spacing: 0.26em !important;
  }

  .hero-actions .btn-ghost {
    color: rgba(255, 250, 242, 0.82) !important;
    border-color: rgba(255, 253, 248, 0.32) !important;
    background: rgba(7, 20, 22, 0.22) !important;
  }

  .hero-actions .btn-ghost:hover {
    color: #ecd4b7 !important;
    border-color: rgba(205, 177, 151, 0.68) !important;
    background: rgba(7, 20, 22, 0.34) !important;
  }
}

@media (max-width: 980px) {
  body {
    padding-bottom: 0 !important;
  }

  body.menu-open {
    overflow: hidden !important;
    touch-action: none !important;
  }

  .mobile-bottom-cta {
    display: none !important;
  }

  #mainNav {
    height: 78px !important;
    padding: 0 18px !important;
    background: linear-gradient(180deg, rgba(7, 20, 22, 0.76), rgba(7, 20, 22, 0.52)) !important;
    border-bottom: 1px solid rgba(205, 177, 151, 0.14) !important;
    box-shadow: none !important;
    backdrop-filter: blur(18px) saturate(1.08) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.08) !important;
    transition: background 220ms ease, height 220ms ease, border-color 220ms ease, box-shadow 220ms ease !important;
  }

  #mainNav::before {
    content: "" !important;
    position: absolute !important;
    inset: 10px 12px !important;
    border: 1px solid rgba(205, 177, 151, 0.12) !important;
    border-radius: 999px !important;
    background: rgba(255, 253, 248, 0.035) !important;
    pointer-events: none !important;
  }

  #mainNav::after {
    display: none !important;
  }

  #mainNav.is-scrolled,
  #mainNav.nav-open {
    background: rgba(7, 20, 22, 0.88) !important;
    border-bottom-color: rgba(205, 177, 151, 0.2) !important;
    box-shadow: 0 14px 40px rgba(0, 0, 0, 0.24) !important;
  }

  #mainNav .nav-logo {
    z-index: 30 !important;
    height: 78px !important;
    padding-left: 6px !important;
  }

  #mainNav .nav-logo::before {
    width: 92px !important;
    height: 58px !important;
    opacity: 0.7 !important;
  }

  #mainNav .nav-logo-img {
    height: 64px !important;
    max-width: 112px !important;
    transform: scale(1.24) !important;
    transform-origin: left center !important;
    filter: drop-shadow(0 12px 26px rgba(0, 0, 0, 0.34)) !important;
  }

  #mainNav .nav-ham {
    position: relative !important;
    right: auto !important;
    top: auto !important;
    z-index: 30 !important;
    width: 48px !important;
    height: 48px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    border: 1px solid rgba(205, 177, 151, 0.28) !important;
    border-radius: 999px !important;
    background: rgba(255, 253, 248, 0.07) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 10px 26px rgba(0, 0, 0, 0.18) !important;
    color: transparent !important;
    font-size: 0 !important;
    cursor: pointer !important;
  }

  #mainNav .nav-ham::before,
  #mainNav .nav-ham::after {
    display: none !important;
  }

  #mainNav .nav-ham span {
    display: block !important;
    position: absolute !important;
    left: 14px !important;
    width: 20px !important;
    height: 1px !important;
    background: var(--mp-paper) !important;
    transform-origin: center !important;
    transition: transform 220ms ease, opacity 180ms ease, background 180ms ease !important;
  }

  #mainNav .nav-ham span:nth-child(1) { transform: translateY(-6px) !important; }
  #mainNav .nav-ham span:nth-child(2) { transform: translateY(0) !important; }
  #mainNav .nav-ham span:nth-child(3) { transform: translateY(6px) !important; }

  #mainNav.nav-open .nav-ham {
    background: var(--mp-gold) !important;
    border-color: var(--mp-gold) !important;
  }

  #mainNav.nav-open .nav-ham span {
    background: var(--mp-ink) !important;
  }

  #mainNav.nav-open .nav-ham span:nth-child(1) { transform: rotate(42deg) !important; }
  #mainNav.nav-open .nav-ham span:nth-child(2) { opacity: 0 !important; }
  #mainNav.nav-open .nav-ham span:nth-child(3) { transform: rotate(-42deg) !important; }

  #mainNav .nav-links {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    min-height: 100svh !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 112px 26px 138px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background:
      radial-gradient(circle at 50% 12%, rgba(208, 177, 144, 0.18), transparent 34%),
      linear-gradient(180deg, rgba(8, 19, 22, 0.98), rgba(5, 12, 14, 0.99)) !important;
    box-shadow: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(-12px) scale(0.985) !important;
    transition: opacity 260ms ease, visibility 260ms ease, transform 260ms ease !important;
    z-index: 20 !important;
  }

  #mainNav .nav-links::before {
    content: "La Finca La Llaguna" !important;
    display: block !important;
    margin: 0 0 18px !important;
    color: var(--mp-gold) !important;
    font-family: "Cormorant Garamond", serif !important;
    font-size: clamp(34px, 9vw, 44px) !important;
    font-weight: 300 !important;
    line-height: 0.95 !important;
    text-align: center !important;
  }

  #mainNav .nav-links::after {
    content: "Bodas, eventos y gastronomia mediterranea en Crevillente" !important;
    order: -1 !important;
    display: block !important;
    margin-bottom: 12px !important;
    max-width: 300px !important;
    color: rgba(245, 239, 230, 0.52) !important;
    font-size: 10px !important;
    letter-spacing: 0.24em !important;
    line-height: 1.7 !important;
    text-align: center !important;
    text-transform: uppercase !important;
  }

  #mainNav.nav-open .nav-links {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) scale(1) !important;
  }

  #mainNav .nav-links li,
  #mainNav.nav-open .nav-links li {
    width: min(100%, 320px) !important;
    display: block !important;
  }

  #mainNav .nav-links li + li::before {
    display: none !important;
  }

  #mainNav .nav-links a,
  #mainNav.nav-open .nav-links a {
    min-height: 54px !important;
    width: 100% !important;
    justify-content: center !important;
    border: 1px solid rgba(205, 177, 151, 0.14) !important;
    border-radius: 999px !important;
    background: rgba(255, 253, 248, 0.055) !important;
    color: rgba(255, 253, 248, 0.92) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.2em !important;
    opacity: 1 !important;
  }

  #mainNav .nav-links a:active {
    background: var(--mp-gold) !important;
    color: var(--mp-ink) !important;
  }

  #mainNav .nav-cta {
    display: none !important;
  }

  #mainNav.nav-open .nav-cta {
    display: none !important;
  }
}

@media (max-width: 760px) {
  :root {
    --nav-offset: 78px;
  }

  .hero {
    min-height: 690px !important;
    height: 100svh !important;
    background: var(--mp-teal-deep) !important;
  }

  .hero-overlay {
    background:
      linear-gradient(180deg, rgba(7, 20, 22, 0.34) 0%, rgba(7, 20, 22, 0.1) 26%, rgba(7, 20, 22, 0.62) 62%, rgba(7, 20, 22, 0.95) 100%) !important;
  }

  .hero-overlay2 {
    background:
      radial-gradient(circle at 52% 38%, transparent 0%, rgba(7, 20, 22, 0.22) 44%, rgba(7, 20, 22, 0.56) 100%),
      linear-gradient(100deg, rgba(7, 20, 22, 0.44), transparent 58%) !important;
  }

  .hero-content {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 22px calc(140px + env(safe-area-inset-bottom)) !important;
  }

  .hero-eyebrow,
  .hero h1,
  .hero-sub,
  .hero-actions,
  .btn-primary,
  .btn-ghost {
    max-width: 100% !important;
  }

  .hero-eyebrow {
    margin-bottom: 16px !important;
    color: var(--mp-gold-soft) !important;
    font-size: 9px !important;
    font-weight: 500 !important;
    letter-spacing: 0.24em !important;
    line-height: 1.5 !important;
  }

  .hero h1 {
    max-width: 100% !important;
    margin-bottom: 18px !important;
    color: #fff8ed !important;
    font-size: clamp(42px, 11.2vw, 56px) !important;
    line-height: 0.96 !important;
    letter-spacing: 0 !important;
    text-shadow: 0 18px 44px rgba(0, 0, 0, 0.42) !important;
  }

  .hero h1 em {
    color: var(--mp-gold-soft) !important;
  }

  .hero-sub {
    display: block !important;
    width: 100% !important;
    max-width: 34rem !important;
    margin-bottom: 24px !important;
    overflow: visible !important;
    color: rgba(255, 250, 242, 0.84) !important;
    font-size: 15px !important;
    line-height: 1.72 !important;
    letter-spacing: 0.01em !important;
    -webkit-line-clamp: unset !important;
  }

  .hero-actions {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .hero-actions .btn-primary,
  .hero-actions .btn-ghost {
    width: 100% !important;
    min-height: 54px !important;
  }

  .hero-actions .btn-primary {
    display: inline-flex !important;
  }

  .hero-actions .btn-ghost {
    color: #fff8ed !important;
    background: rgba(7, 20, 22, 0.34) !important;
    border-color: rgba(255, 253, 248, 0.32) !important;
    backdrop-filter: blur(10px) !important;
  }

  .hero-awards {
    position: absolute !important;
    top: auto !important;
    right: 18px !important;
    bottom: calc(24px + env(safe-area-inset-bottom)) !important;
    left: 18px !important;
    z-index: 4 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    pointer-events: none !important;
  }

  .hero-awards .award-badge {
    display: inline-flex !important;
    min-height: 32px !important;
    max-width: min(320px, calc(100vw - 44px)) !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 9px 18px 8px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(205, 177, 151, 0.28) !important;
    background: rgba(12, 28, 30, 0.82) !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
    color: rgba(226, 196, 166, 0.96) !important;
    font-size: 8px !important;
    font-weight: 500 !important;
    line-height: 1.55 !important;
    letter-spacing: 0.22em !important;
    text-align: center !important;
    white-space: nowrap !important;
    overflow: visible !important;
    backdrop-filter: blur(14px) saturate(1.05) !important;
    -webkit-backdrop-filter: blur(14px) saturate(1.05) !important;
  }

  .section,
  .section-full,
  .bodas,
  .test-bg,
  .cta-bg,
  #perigallo.perigallo-main {
    padding: 64px 20px !important;
  }

  #finca,
  #servicios,
  .gal-bg {
    background:
      linear-gradient(180deg, rgba(245, 239, 230, 0.7), rgba(255, 250, 242, 0.98) 18%, rgba(255, 250, 242, 1)) !important;
  }

  .espacios-bg {
    background:
      linear-gradient(180deg, #efe3d5, #fff8ef 22%, #f5efe6 100%) !important;
  }

  .bodas,
  .test-bg,
  .cta-bg,
  #gastro {
    background:
      radial-gradient(circle at 50% 0%, rgba(208, 177, 144, 0.13), transparent 34%),
      linear-gradient(180deg, #13272c, #071416 100%) !important;
  }

  .intro-grid,
  .bodas-inner,
  #servicios .servicios-grid,
  .test-top,
  .test-board,
  .gal-bg .gal-header,
  #perigallo.perigallo-main {
    gap: 34px !important;
  }

  .eyebrow {
    margin-bottom: 14px !important;
    color: #9e7b58 !important;
    font-size: 9px !important;
    letter-spacing: 0.28em !important;
    line-height: 1.55 !important;
  }

  .big-title,
  #finca .big-title,
  #espacios .big-title,
  #perigallo h2,
  .gal-bg .gal-header .big-title {
    color: var(--mp-teal) !important;
    font-size: clamp(38px, 10.5vw, 50px) !important;
    line-height: 1.02 !important;
    letter-spacing: 0 !important;
  }

  .bodas .big-title,
  #perigallo h2,
  .test-bg .big-title,
  .cta-bg .big-title {
    color: #fff8ed !important;
  }

  .gold-line {
    margin: 22px 0 !important;
    background: linear-gradient(90deg, var(--mp-gold), rgba(208, 177, 144, 0)) !important;
  }

  .body-text,
  #finca .body-text,
  #espacios .body-text,
  #perigallo p,
  .test-intro {
    max-width: 100% !important;
    font-size: 16px !important;
    line-height: 1.78 !important;
  }

  .bodas .body-text,
  #perigallo p,
  .test-intro,
  .cta-bg .body-text {
    color: rgba(255, 250, 242, 0.72) !important;
  }

  .intro-main-img,
  .em-item,
  .bodas-photo-grid .ph,
  .srv.img-card,
  .gallery-stage,
  .test-feature,
  .review-card,
  .pg-shell {
    border-radius: var(--mp-radius) !important;
    overflow: hidden !important;
  }

  .intro-main-img,
  .bodas-photo-grid .ph,
  .em-item,
  .srv.img-card,
  .gallery-stage {
    box-shadow: var(--mp-shadow) !important;
  }

  .intro-main-img {
    height: min(108vw, 460px) !important;
    min-height: 350px !important;
  }

  .intro-accent {
    border: 1px solid rgba(151, 122, 91, 0.18) !important;
    background: linear-gradient(135deg, #e4c8aa, #cfad8b) !important;
    box-shadow: 0 14px 34px rgba(13, 26, 30, 0.1) !important;
    font-size: 16px !important;
    line-height: 1.45 !important;
  }

  .intro-data,
  #perigallo .perigallo-metrics {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-top: 28px !important;
  }

  .data-item,
  #perigallo .perigallo-metrics > div,
  .gst,
  .cred,
  .test-score {
    display: grid !important;
    grid-template-columns: auto 1fr !important;
    align-items: center !important;
    gap: 18px !important;
    min-height: 74px !important;
    padding: 18px 20px !important;
    border: 1px solid var(--mp-line) !important;
    border-radius: var(--mp-radius) !important;
    background: rgba(255, 253, 248, 0.68) !important;
    text-align: left !important;
    box-shadow: 0 14px 34px rgba(13, 26, 30, 0.07) !important;
  }

  .data-item:not(:last-child) {
    border-right: 1px solid var(--mp-line) !important;
  }

  .data-num,
  .cred-num,
  .gst-num,
  #perigallo .perigallo-metrics > div > div:first-child {
    font-size: 38px !important;
    color: var(--mp-teal) !important;
  }

  .data-label,
  .cred-label,
  .gst-label,
  #perigallo .perigallo-metrics > div > div:last-child {
    margin-top: 0 !important;
    color: #7b6c5d !important;
    font-size: 10px !important;
    letter-spacing: 0.2em !important;
    line-height: 1.4 !important;
  }

  #espacios .espacios-mosaic {
    gap: 16px !important;
    margin-top: 34px !important;
  }

  #espacios .em-item {
    min-height: 295px !important;
    grid-column: auto !important;
    grid-row: auto !important;
  }

  #espacios .em-item:nth-child(1) {
    min-height: 410px !important;
  }

  .em-label {
    padding: 28px 22px 22px !important;
    background: linear-gradient(to top, rgba(7, 20, 22, 0.88), rgba(7, 20, 22, 0.08)) !important;
    color: rgba(255, 250, 242, 0.9) !important;
    font-size: 10px !important;
    letter-spacing: 0.2em !important;
    line-height: 1.5 !important;
  }

  .em-item:nth-child(1) .em-label {
    font-size: 22px !important;
    line-height: 1.18 !important;
  }

  .bodas-promises {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin: 30px 0 !important;
  }

  .bodas-promise {
    min-height: 48px !important;
    align-items: flex-start !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid rgba(205, 177, 151, 0.16) !important;
    color: rgba(255, 250, 242, 0.78) !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
  }

  .bodas-photo-grid {
    gap: 14px !important;
  }

  .bodas-photo-grid .ph {
    height: 286px !important;
  }

  .bodas-photo-grid .ph:nth-child(1) {
    height: 360px !important;
  }

  .boda-badge {
    border-radius: var(--mp-radius) !important;
    padding: 20px !important;
    background: linear-gradient(135deg, #e4c8aa, #caa581) !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.16) !important;
  }

  #servicios .section > .reveal:first-child {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  #servicios .srv {
    padding: 26px 22px !important;
    border: 1px solid rgba(151, 122, 91, 0.18) !important;
    border-radius: var(--mp-radius) !important;
    background: rgba(255, 253, 248, 0.62) !important;
    box-shadow: 0 14px 34px rgba(13, 26, 30, 0.06) !important;
  }

  #servicios .srv h3 {
    font-size: 29px !important;
    line-height: 1.08 !important;
  }

  #servicios .srv p {
    font-size: 15px !important;
    line-height: 1.72 !important;
  }

  #servicios .srv.img-card {
    min-height: 320px !important;
    padding: 0 !important;
  }

  .srv.img-card .overlay {
    padding: 28px 22px !important;
    background: linear-gradient(to top, rgba(7, 20, 22, 0.9), rgba(7, 20, 22, 0.16) 64%, transparent) !important;
  }

  #perigallo.perigallo-main {
    padding-top: 72px !important;
  }

  #perigallo .perigallo-brand-lockup img {
    height: 108px !important;
  }

  #perigallo .perigallo-slogan-card {
    max-width: 100% !important;
    margin-bottom: 28px !important;
    padding: 0 4px 22px !important;
    color: var(--mp-gold-soft) !important;
    font-size: clamp(29px, 8.5vw, 38px) !important;
    line-height: 1.12 !important;
  }

  #perigallo .eyebrow {
    color: rgba(208, 177, 144, 0.72) !important;
  }

  #perigallo .perigallo-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  #perigallo .perigallo-metrics > div {
    grid-template-columns: 1fr !important;
    min-height: 98px !important;
    background: rgba(255, 253, 248, 0.055) !important;
    border-color: rgba(205, 177, 151, 0.16) !important;
    text-align: center !important;
  }

  #perigallo .perigallo-metrics > div > div:first-child {
    color: var(--mp-gold-soft) !important;
  }

  #perigallo .perigallo-metrics > div > div:last-child {
    color: rgba(255, 250, 242, 0.52) !important;
  }

  .dish-stage {
    height: 460px !important;
    border-radius: var(--mp-radius) !important;
  }

  .dish-caption {
    padding: 18px 20px !important;
  }

  .gallery-stage {
    height: 480px !important;
    border-color: rgba(151, 122, 91, 0.22) !important;
  }

  .gallery-controls {
    left: 18px !important;
    top: 18px !important;
  }

  .gallery-btn,
  .dish-arrow {
    width: 48px !important;
    height: 48px !important;
    border-radius: 999px !important;
    background: rgba(7, 20, 22, 0.5) !important;
    backdrop-filter: blur(10px) !important;
  }

  .gallery-count {
    top: 23px !important;
    right: 20px !important;
    font-size: 26px !important;
  }

  .gallery-caption {
    left: 20px !important;
    right: 20px !important;
    bottom: 22px !important;
  }

  .gallery-title {
    font-size: clamp(34px, 10vw, 44px) !important;
    line-height: 1.02 !important;
  }

  .gallery-strip {
    gap: 12px !important;
    margin-top: 14px !important;
    padding-bottom: 12px !important;
  }

  .gallery-thumb {
    flex: 0 0 154px !important;
    height: 92px !important;
    border-radius: 10px !important;
  }

  .test-score {
    grid-template-columns: auto 1fr !important;
    background: rgba(255, 253, 248, 0.055) !important;
    border-color: rgba(205, 177, 151, 0.16) !important;
    box-shadow: none !important;
  }

  .test-score-num,
  .test-feature-rating,
  .review-rating {
    color: var(--mp-gold-soft) !important;
  }

  .test-score-copy,
  .review-date {
    color: rgba(255, 250, 242, 0.52) !important;
  }

  .test-feature {
    padding: 28px 24px 112px !important;
    background: linear-gradient(145deg, rgba(255, 253, 248, 0.085), rgba(255, 253, 248, 0.035)) !important;
    border-color: rgba(205, 177, 151, 0.16) !important;
  }

  .test-feature-title {
    font-size: clamp(34px, 9.4vw, 46px) !important;
  }

  .test-feature-text {
    color: rgba(255, 250, 242, 0.78) !important;
    font-size: 22px !important;
    line-height: 1.45 !important;
  }

  .test-feature-meta {
    left: 24px !important;
    right: 24px !important;
    bottom: 28px !important;
  }

  .test-review-grid {
    gap: 12px !important;
  }

  .review-card {
    flex: 0 0 min(86vw, 336px) !important;
    padding: 22px !important;
    background: rgba(255, 253, 248, 0.055) !important;
    border-color: rgba(205, 177, 151, 0.16) !important;
  }

  .review-title {
    font-size: 25px !important;
    color: var(--mp-gold-soft) !important;
  }

  .review-text {
    color: rgba(255, 250, 242, 0.66) !important;
    font-size: 14px !important;
  }

  .test-source {
    color: rgba(255, 250, 242, 0.5) !important;
    letter-spacing: 0.16em !important;
    line-height: 1.6 !important;
  }

  .cta-bg {
    padding-bottom: 72px !important;
  }

  .cta-inner .body-text {
    color: rgba(255, 250, 242, 0.74) !important;
  }

  .suite-form-frame {
    margin-top: 34px !important;
  }

  .suite-form-card {
    padding: 30px 20px !important;
  }

  .suite-form-card h3 {
    font-size: 34px !important;
  }

  .suite-form-card p {
    font-size: 14px !important;
    line-height: 1.66 !important;
  }

  .suite-form-note {
    margin-top: 16px !important;
    font-size: 9px !important;
    letter-spacing: 0.18em !important;
  }

  .pg-shell {
    display: grid !important;
    grid-template-columns: 1fr !important;
    background: linear-gradient(145deg, rgba(255, 253, 248, 0.08), rgba(255, 253, 248, 0.035)) !important;
    border-color: rgba(205, 177, 151, 0.16) !important;
  }

  .pg-header,
  .pg-body {
    padding: 28px 22px !important;
  }

  .pg-header {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(205, 177, 151, 0.16) !important;
  }

  .pg-title {
    font-size: clamp(38px, 10.6vw, 50px) !important;
  }

  .pg-subtitle {
    color: rgba(255, 250, 242, 0.74) !important;
    font-size: 15px !important;
    line-height: 1.72 !important;
  }

  .pg-grid,
  .pg-grid-2,
  .pg-options {
    grid-template-columns: 1fr !important;
  }

  .pg-input,
  .pg-select,
  .pg-textarea {
    min-height: 54px !important;
    font-size: 16px !important;
    border-radius: 10px !important;
  }

  .pg-option {
    min-height: 96px !important;
    border-radius: 10px !important;
    padding: 20px !important;
  }

  .footer-top {
    gap: 22px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  footer {
    padding: 54px 20px 28px !important;
  }

  .ft-brand-lockup {
    gap: 16px !important;
  }

  .ft-brand-lockup img {
    height: 58px !important;
  }

  .fc-phone {
    font-size: clamp(30px, 10vw, 42px) !important;
  }

  .footer-map {
    grid-template-columns: 1fr !important;
    border-radius: var(--mp-radius) !important;
  }

  .ft-managed a,
  .fc-list a,
  .footer-bottom a,
  .fc-phone {
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
  }
}

@media (min-width: 761px) and (max-width: 1180px) {
  .section,
  .section-full,
  .bodas,
  .test-bg,
  .cta-bg,
  #perigallo.perigallo-main {
    padding-left: 42px !important;
    padding-right: 42px !important;
  }

  .hero-content {
    padding-left: 42px !important;
    padding-right: 42px !important;
  }

  .intro-grid,
  .bodas-inner,
  .gal-header,
  #perigallo.perigallo-main {
    gap: 48px !important;
  }
}

@media (min-width: 761px) and (max-width: 820px) {
  .test-top,
  .test-board {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .test-feature {
    min-height: auto !important;
    padding: 34px 34px 118px !important;
    border-radius: var(--mp-radius) !important;
  }

  .test-feature-meta {
    left: 34px !important;
    right: 34px !important;
    bottom: 34px !important;
  }

  .test-review-grid {
    display: flex !important;
    gap: 14px !important;
    max-height: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 2px 2px 14px !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .review-card {
    flex: 0 0 min(48vw, 340px) !important;
    min-height: 230px !important;
    border-radius: var(--mp-radius) !important;
    scroll-snap-align: start !important;
  }

  .review-card:nth-child(n+9) {
    display: none !important;
  }

  .ft-managed a,
  .fc-list a,
  .footer-bottom a,
  .fc-phone {
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
  }
}

@media (max-width: 390px) {
  #mainNav {
    height: 74px !important;
    padding: 0 14px !important;
  }

  #mainNav::before {
    inset: 9px 10px !important;
  }

  #mainNav .nav-logo-img {
    height: 58px !important;
    max-width: 102px !important;
    transform: scale(1.32) !important;
  }

  #mainNav .nav-ham {
    width: 46px !important;
    height: 46px !important;
  }

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

  .hero-content {
    padding-left: 18px !important;
    padding-right: 18px !important;
    padding-bottom: calc(126px + env(safe-area-inset-bottom)) !important;
  }

  .hero h1 {
    font-size: clamp(40px, 12vw, 48px) !important;
  }

  .hero-sub {
    font-size: 14px !important;
    line-height: 1.62 !important;
  }

  .hero-awards {
    right: 14px !important;
    bottom: calc(20px + env(safe-area-inset-bottom)) !important;
    left: 14px !important;
    gap: 7px !important;
  }

  .hero-awards .award-badge {
    min-height: 30px !important;
    max-width: calc(100vw - 36px) !important;
    padding: 8px 14px 7px !important;
    font-size: 7.4px !important;
    line-height: 1.55 !important;
    letter-spacing: 0.18em !important;
  }

  .section,
  .section-full,
  .bodas,
  .test-bg,
  .cta-bg,
  #perigallo.perigallo-main {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}
