:root {
  /*
  Uncomment these when you want to lock the palette locally instead of inheriting it from the host site.
  --site-primary: #e60566;
  --site-secondary: #8bcdf1;
  --site-dark: #1f2349;
  --site-muted: #99a8b3;
  --site-lilac: #8d79ab;
  --site-surface: #f5f2ed;
  */
  --site-primary: var(--primary-color, #e60566);
  --site-secondary: var(--secondary-color, #8bcdf1);
  --site-dark: var(--dark-color, #1f2349);
  --site-muted: var(--muted-color, #99a8b3);
  --site-lilac: var(--support-color, #8d79ab);
  --site-surface: var(--surface-color, #f5f2ed);
  --site-paper: var(--paper-color, #ffffff);
  --site-text: var(--text-color, #18203a);
  --site-text-soft: var(--text-soft-color, #5d657c);
  --site-outline: rgba(24, 32, 58, 0.12);
  --site-outline-strong: rgba(24, 32, 58, 0.18);
  --hero-gradient: linear-gradient(125deg, #d9005e 0%, #f05ea6 42%, #93d3f2 100%);
  --soft-shadow: 0 20px 50px rgba(15, 20, 40, 0.12);
  --card-shadow: 0 28px 80px rgba(15, 20, 40, 0.14);
  --radius-xl: 32px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 14px;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Segoe UI Variable Display", "Trebuchet MS", "Arial Narrow", sans-serif;
  color: var(--site-text);
  background:
    radial-gradient(circle at top left, rgba(230, 5, 102, 0.10), transparent 30%),
    radial-gradient(circle at top right, rgba(139, 205, 241, 0.18), transparent 28%),
    linear-gradient(180deg, #f8f6f1 0%, #ffffff 26%, #f3f6fa 100%);
}

img {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
}

.hero-section,
.periods-section,
.listings-section,
.final-cta-section {
  position: relative;
}

.hero-section {
  overflow: hidden;
  padding: 28px 0 76px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.45), rgba(255, 255, 255, 0)),
    linear-gradient(135deg, rgba(31, 35, 73, 0.04), rgba(31, 35, 73, 0));
}

.hero-orbit {
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  filter: blur(4px);
}

.hero-orbit-a {
  top: -90px;
  right: -110px;
  width: 340px;
  height: 340px;
  background: radial-gradient(circle, rgba(139, 205, 241, 0.56), rgba(139, 205, 241, 0));
}

.hero-orbit-b {
  bottom: -120px;
  left: -140px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, rgba(230, 5, 102, 0.18), rgba(230, 5, 102, 0));
}

.section-tag,
.resort-kicker,
.panel-tag,
.window-switch-label,
.summary-label,
.metric-label {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.section-tag,
.resort-kicker,
.panel-tag {
  color: var(--site-primary);
}

.hero-copy {
  position: relative;
  z-index: 1;
  padding: 1rem 0 0.4rem;
}

.section-heading h2,
.final-cta-card h2,
.resort-head h3 {
  margin: 0;
  font-weight: 900;
  line-height: 0.96;
  text-transform: uppercase;
  letter-spacing: -0.03em;
}

.hero-text,
.section-heading p,
.final-cta-card p,
.resort-subtitle,
.notes-list,
.benefits-list,
.notice-banner {
  font-size: 1.03rem;
  line-height: 1.65;
  color: var(--site-text-soft);
}

.hero-text {
  max-width: 62ch;
  margin: 0;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-top: 1.8rem;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: 0.01em;
  padding: 0.88rem 1.4rem;
}

.cta-btn {
  color: #ffffff;
  border: none;
  background: linear-gradient(135deg, var(--site-primary), #ff5f8b 78%);
  box-shadow: 0 18px 36px rgba(230, 5, 102, 0.24);
}

.cta-btn:hover,
.cta-btn:focus-visible {
  color: #ffffff;
  transform: translateY(-1px);
}

.ghost-btn {
  border: 1px solid rgba(24, 32, 58, 0.12);
  background: rgba(255, 255, 255, 0.78);
}

.ghost-btn:hover,
.ghost-btn:focus-visible {
  border-color: rgba(230, 5, 102, 0.26);
  background: rgba(255, 255, 255, 0.92);
}

.hero-comparison {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}

.summary-card {
  position: relative;
  display: grid;
  gap: 0.55rem;
  padding: 1.25rem 1.3rem;
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--site-text);
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(24, 32, 58, 0.08);
  box-shadow: 0 18px 40px rgba(15, 20, 40, 0.08);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.summary-card:hover,
.summary-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(230, 5, 102, 0.24);
  box-shadow: 0 22px 48px rgba(15, 20, 40, 0.12);
}

.summary-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 6px;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  background: linear-gradient(180deg, var(--site-primary), var(--site-secondary));
}

.summary-label {
  color: var(--site-text-soft);
}

.summary-title {
  font-size: 1.2rem;
  font-weight: 900;
  line-height: 1.05;
  text-transform: uppercase;
}

.summary-price {
  font-size: 1.55rem;
  font-weight: 900;
  line-height: 1;
}

.summary-note {
  color: var(--site-text-soft);
  font-weight: 700;
}

.periods-section,
.listings-section,
.final-cta-section {
  padding: 52px 0 82px;
}

.section-heading {
  display: grid;
  gap: 0.9rem;
  max-width: 55rem;
  margin-bottom: 2rem;
}

.section-heading h2 {
  font-size: clamp(2rem, 4vw, 3.3rem);
}

.period-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.period-card {
  display: grid;
  gap: 0.5rem;
  width: 100%;
  padding: 1.3rem 1.1rem;
  border: 1px solid rgba(24, 32, 58, 0.08);
  border-radius: var(--radius-md);
  text-align: left;
  color: var(--site-text);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--soft-shadow);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.period-card:hover,
.period-card:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(230, 5, 102, 0.26);
}

.period-card.is-active {
  color: #ffffff;
  border-color: transparent;
  background: var(--hero-gradient);
  box-shadow: 0 24px 52px rgba(15, 20, 40, 0.18);
}

.period-card-label,
.table-head-label {
  font-size: 1rem;
  font-weight: 900;
  text-transform: uppercase;
}

.period-card-label {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.period-card-range,
.table-head-range {
  font-size: 0.85rem;
  opacity: 0.84;
}

.period-card-copy {
  font-size: 0.92rem;
  line-height: 1.45;
  color: inherit;
  opacity: 0.88;
}

.resort-stack {
  display: grid;
  gap: 2rem;
}

.resort-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(24, 32, 58, 0.08);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--card-shadow);
  scroll-margin-top: 90px;
}

.resort-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 9px;
  background: linear-gradient(90deg, var(--accent), var(--accent-soft));
}

.resort-card[data-theme="vialattea"] {
  --accent: var(--site-primary);
  --accent-soft: var(--site-secondary);
  --panel-gradient: linear-gradient(135deg, rgba(230, 5, 102, 0.10), rgba(139, 205, 241, 0.14));
  --badge-bg: rgba(230, 5, 102, 0.14);
}

.resort-card[data-theme="bardonecchia"] {
  --accent: #ff0d71;
  --accent-soft: #5fc2ef;
  --panel-gradient: linear-gradient(135deg, rgba(255, 13, 113, 0.12), rgba(31, 35, 73, 0.08));
  --badge-bg: rgba(31, 35, 73, 0.10);
}

.resort-head {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 1.5rem;
  padding: 2.1rem 2rem 1.25rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0)),
    var(--panel-gradient);
}

.resort-head h3 {
  font-size: clamp(1.8rem, 3.5vw, 3.1rem);
}

.resort-subtitle {
  margin: 0.95rem 0 0;
  max-width: 54ch;
}

.resort-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
}

.metric-card {
  padding: 1rem 0.95rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(24, 32, 58, 0.08);
  box-shadow: 0 14px 30px rgba(15, 20, 40, 0.06);
}

.metric-heading {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.metric-label {
  color: var(--site-text-soft);
}

.metric-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  flex: 0 0 2rem;
  border-radius: 999px;
  background: rgba(24, 32, 58, 0.06);
  color: var(--accent);
  font-size: 1rem;
}

.metric-value {
  margin-top: 0.42rem;
  font-size: 1.24rem;
  font-weight: 900;
  line-height: 1.1;
}

.metric-note {
  margin-top: 0.38rem;
  font-size: 0.88rem;
  color: var(--site-text-soft);
  line-height: 1.45;
}

.resort-body {
  display: grid;
  grid-template-columns: minmax(300px, 0.92fr) minmax(0, 1.08fr);
  gap: 1.4rem;
  padding: 0 2rem 2rem;
}

.content-panel {
  position: relative;
  overflow: hidden;
  height: 100%;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(24, 32, 58, 0.08);
  background: rgba(255, 255, 255, 0.86);
}

.content-panel::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: linear-gradient(180deg, var(--accent), var(--accent-soft));
}

.benefits-panel {
  padding: 1.55rem 1.4rem 1.5rem 1.6rem;
}

.pricing-panel {
  padding: 1.55rem 1.2rem 1.3rem 1.45rem;
}

.panel-tag {
  margin-bottom: 0.55rem;
}

.panel-title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: 1.05;
  text-transform: uppercase;
}

.benefits-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.95rem 0.9rem;
  padding: 0;
  margin: 1.25rem 0 0;
  list-style: none;
}

.benefit-item {
  position: relative;
  min-height: 100%;
  padding: 1rem 1rem 1rem 1.1rem;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(245, 247, 252, 0.94));
  border: 1px solid rgba(24, 32, 58, 0.08);
  color: var(--site-text);
  font-weight: 800;
  line-height: 1.45;
}

.benefit-copy {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
}

.benefit-item::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  background: linear-gradient(180deg, var(--accent), var(--accent-soft));
}

.benefit-icon {
  margin-top: 0.12rem;
  color: var(--accent);
  font-size: 1rem;
  flex-shrink: 0;
}

.benefit-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.2rem;
  margin-bottom: 0.75rem;
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  background: var(--badge-bg);
  color: var(--accent);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.window-switch {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.9rem;
  align-items: center;
  margin: 1.2rem 0 1rem;
}

.window-switch-label {
  color: var(--site-text-soft);
}

.window-switch-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.window-switch-button {
  padding: 0.65rem 0.95rem;
  border-radius: 999px;
  border: 1px solid rgba(24, 32, 58, 0.08);
  background: rgba(255, 255, 255, 0.72);
  color: var(--site-text);
  font-size: 0.9rem;
  font-weight: 800;
  transition: border-color 180ms ease, background-color 180ms ease, color 180ms ease;
}

.window-switch-button.is-active {
  color: #ffffff;
  border-color: transparent;
  background: linear-gradient(135deg, var(--accent), var(--accent-soft));
}

.pricing-table-wrap {
  margin-top: 0.25rem;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(24, 32, 58, 0.08);
  background: rgba(246, 248, 252, 0.76);
  overflow: hidden;
}

.pricing-table {
  width: 100%;
  min-width: 760px;
  border-collapse: separate;
  border-spacing: 0;
  color: var(--site-text);
}

.pricing-table th,
.pricing-table td {
  padding: 1rem 0.75rem;
  text-align: center;
  border-right: 1px solid rgba(255, 255, 255, 0.7);
  border-bottom: 1px solid rgba(255, 255, 255, 0.7);
}

.pricing-table thead th {
  color: #ffffff;
  background: var(--site-dark);
}

.pricing-table .th-category {
  background: var(--site-lilac);
}

.pricing-table .window-head--earlyBird {
  background: #d94d9a;
}

.pricing-table .window-head--promo {
  background: #7fb4dd;
}

.pricing-table .window-head--softPromo {
  background: var(--site-dark);
}

.pricing-table .window-head--full {
  background: var(--site-muted);
}

.table-head-label,
.label-main,
.price-line,
.group-cell span {
  font-weight: 900;
}

.table-head-range {
  display: block;
  margin-top: 0.3rem;
}

.label-cell,
.group-cell {
  background: rgba(141, 121, 171, 0.92);
  color: #ffffff;
}

.label-cell {
  text-align: left;
}

.label-cell.is-wide {
  padding-left: 1.1rem;
}

.label-main {
  display: block;
  font-size: 1rem;
  line-height: 1.1;
  text-transform: uppercase;
}

.label-note {
  display: block;
  margin-top: 0.28rem;
  font-size: 0.78rem;
  line-height: 1.35;
  opacity: 0.9;
}

.group-cell {
  width: 52px;
  min-width: 52px;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.price-cell {
  position: relative;
  background: rgba(255, 255, 255, 0.85);
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.price-cell--earlyBird {
  background: rgba(217, 77, 154, 0.12);
}

.price-cell--promo {
  background: rgba(127, 180, 221, 0.16);
}

.price-cell--softPromo {
  background: rgba(31, 35, 73, 0.08);
}

.price-cell--full {
  background: rgba(153, 168, 179, 0.18);
}

.price-cell.is-window-active,
.pricing-table thead th.is-window-active {
  z-index: 1;
  filter: brightness(1.05);
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.92);
}

.price-stack {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
}

.price-line {
  font-size: 1.08rem;
  line-height: 1.1;
}

.mobile-pricing-grid {
  display: none;
  gap: 0.95rem;
  margin-top: 1rem;
}

.mobile-price-card {
  padding: 1.05rem;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(245, 247, 252, 0.92));
  border: 1px solid rgba(24, 32, 58, 0.08);
}

.mobile-group {
  margin: 0 0 0.22rem;
  color: var(--accent);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mobile-price-card h4 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1.1;
}

.mobile-note {
  margin: 0.32rem 0 0;
  color: var(--site-text-soft);
  font-size: 0.82rem;
  line-height: 1.35;
}

.mobile-price-panel,
.mobile-meta-line {
  display: none;
}

.mobile-price-panel.is-active,
.mobile-meta-line.is-active {
  display: block;
}

.mobile-price-panel {
  margin-top: 0.9rem;
}

.mobile-meta-line {
  margin-top: 0.42rem;
  color: var(--site-text-soft);
  font-size: 0.86rem;
  font-weight: 700;
}

.notice-banner {
  margin-top: 1.25rem;
  padding: 1.2rem 1.1rem;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(31, 35, 73, 0.96), rgba(31, 35, 73, 0.9));
  color: rgba(255, 255, 255, 0.88);
}

.notice-line {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.24;
  text-transform: uppercase;
}

.notice-line + .notice-line {
  margin-top: 0.16rem;
}

.notice-line.is-accent {
  color: #ffffff;
}

.accent-text {
  color: #ff7fb0;
}

.notes-list {
  display: grid;
  gap: 0.72rem;
  padding: 0;
  margin: 1.15rem 0 0;
  list-style: none;
}

.notes-list li {
  padding-left: 1rem;
  position: relative;
  font-size: 0.94rem;
  line-height: 1.55;
}

.notes-list li::before {
  content: "";
  position: absolute;
  top: 0.62rem;
  left: 0;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--accent), var(--accent-soft));
}

.final-cta-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: center;
  padding: 2rem;
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, rgba(230, 5, 102, 0.10), rgba(139, 205, 241, 0.18)),
    rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(24, 32, 58, 0.08);
  box-shadow: var(--card-shadow);
}

.cta-btn-large {
  white-space: nowrap;
}

.sticky-cta {
  position: fixed;
  inset: auto 0 0;
  z-index: 30;
  display: none;
  padding: 0.85rem 1rem calc(0.85rem + env(safe-area-inset-bottom));
  background: #ccc;
}

.sticky-cta a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  width: 100%;
  padding: 0.95rem 1.2rem;
  border-radius: 999px;
  text-align: center;
  text-decoration: none;
  color: #ffffff;
  font-weight: 900;
  background: linear-gradient(135deg, var(--site-primary), #ff5f8b 78%);
  box-shadow: 0 18px 36px rgba(230, 5, 102, 0.22);
}

.section-tag .bi,
.resort-kicker .bi,
.panel-tag .bi,
.window-switch-label .bi,
.summary-label .bi {
  color: currentColor;
}

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 420ms ease, transform 420ms ease;
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .reveal-on-scroll {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .summary-card,
  .period-card {
    transition: none;
  }
}

@media (max-width: 1199.98px) {
  .resort-head,
  .resort-body {
    grid-template-columns: 1fr;
  }

  .resort-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {
  .hero-section {
    padding-bottom: 56px;
  }

  .hero-comparison,
  .period-grid,
  .resort-metrics,
  .benefits-list,
  .final-cta-card {
    grid-template-columns: 1fr;
  }

  .resort-head,
  .resort-body {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }

  .benefits-panel,
  .pricing-panel {
    padding-left: 1.1rem;
    padding-right: 1rem;
  }

  .pricing-table-wrap {
    display: none;
  }

  .mobile-pricing-grid {
    display: grid;
  }

  .sticky-cta {
    display: block;
  }

  body {
    padding-bottom: 6rem;
  }
}

@media (max-width: 767.98px) {
  .hero-actions,
  .window-switch,
  .window-switch-buttons {
    width: 100%;
  }

  .hero-actions .btn,
  .window-switch-button {
    flex: 1 1 calc(50% - 0.45rem);
    justify-content: center;
  }

  .benefits-list {
    grid-template-columns: 1fr;
  }

  .periods-section,
  .listings-section,
  .final-cta-section {
    padding: 44px 0 68px;
  }

  .final-cta-card {
    padding: 1.4rem;
  }

  .cta-btn-large {
    white-space: normal;
  }
}

@media (max-width: 575.98px) {
  .section-heading h2,
  .resort-head h3,
  .final-cta-card h2 {
    font-size: clamp(1.7rem, 9vw, 2.5rem);
  }

  .resort-card,
  .final-cta-card {
    border-radius: 24px;
  }

  .hero-actions .btn,
  .window-switch-button {
    flex-basis: 100%;
  }

  .period-card,
  .summary-card,
  .mobile-price-card,
  .metric-card,
  .benefit-item,
  .notice-banner {
    border-radius: 18px;
  }
}

/* Host site hard overrides */
body.bardonecchia-listino-page {
  font-size: 16px !important;
  line-height: 1.4 !important;
}

body.bardonecchia-listino-page,
body.bardonecchia-listino-page * {
  box-sizing: border-box !important;
}

body.bardonecchia-listino-page img {
  max-width: 100% !important;
  /*height: auto !important;*/
}

body.bardonecchia-listino-page .hero-section,
body.bardonecchia-listino-page .periods-section,
body.bardonecchia-listino-page .listings-section,
body.bardonecchia-listino-page .final-cta-section,
body.bardonecchia-listino-page .hero-copy,
body.bardonecchia-listino-page .hero-comparison,
body.bardonecchia-listino-page .period-grid,
body.bardonecchia-listino-page .resort-stack,
body.bardonecchia-listino-page .resort-head,
body.bardonecchia-listino-page .resort-body,
body.bardonecchia-listino-page .resort-metrics,
body.bardonecchia-listino-page .benefits-list,
body.bardonecchia-listino-page .pricing-panel,
body.bardonecchia-listino-page .final-cta-card {
  min-width: 0 !important;
  max-width: 100% !important;
}

body.bardonecchia-listino-page .hero-text,
body.bardonecchia-listino-page .section-heading p,
body.bardonecchia-listino-page .final-cta-card p,
body.bardonecchia-listino-page .resort-subtitle,
body.bardonecchia-listino-page .benefit-item,
body.bardonecchia-listino-page .notes-list li,
body.bardonecchia-listino-page .notice-line,
body.bardonecchia-listino-page .summary-note,
body.bardonecchia-listino-page .metric-note,
body.bardonecchia-listino-page .mobile-note,
body.bardonecchia-listino-page .mobile-meta-line {
  font-size: 0.95rem !important;
  line-height: 1.45 !important;
  font-weight: 400 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

body.bardonecchia-listino-page .section-tag,
body.bardonecchia-listino-page .resort-kicker,
body.bardonecchia-listino-page .panel-tag,
body.bardonecchia-listino-page .window-switch-label,
body.bardonecchia-listino-page .summary-label,
body.bardonecchia-listino-page .metric-label,
body.bardonecchia-listino-page .mobile-group,
body.bardonecchia-listino-page .benefit-badge {
  font-size: 0.72rem !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
}

body.bardonecchia-listino-page .section-heading h2,
body.bardonecchia-listino-page .final-cta-card h2,
body.bardonecchia-listino-page .resort-head h3 {
  font-size: clamp(1.85rem, 3.6vw, 2.9rem) !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

body.bardonecchia-listino-page .panel-title,
body.bardonecchia-listino-page .summary-title,
body.bardonecchia-listino-page .metric-value,
body.bardonecchia-listino-page .price-line,
body.bardonecchia-listino-page .mobile-price-card h4,
body.bardonecchia-listino-page .label-main {
  line-height: 1.15 !important;
  font-weight: 800 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

body.bardonecchia-listino-page .panel-title {
  font-size: 1.28rem !important;
}

body.bardonecchia-listino-page .summary-title {
  font-size: 1.05rem !important;
}

body.bardonecchia-listino-page .summary-price {
  font-size: 1.32rem !important;
  line-height: 1.05 !important;
  font-weight: 800 !important;
  white-space: normal !important;
}

body.bardonecchia-listino-page .metric-value {
  font-size: 1.08rem !important;
}

body.bardonecchia-listino-page .period-card-label,
body.bardonecchia-listino-page .table-head-label {
  font-size: 0.84rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
}

body.bardonecchia-listino-page .period-card-range,
body.bardonecchia-listino-page .table-head-range,
body.bardonecchia-listino-page .label-note {
  line-height: 1.3 !important;
}

body.bardonecchia-listino-page .period-card-range,
body.bardonecchia-listino-page .table-head-range {
  font-size: 0.68rem !important;
}

body.bardonecchia-listino-page .period-card-copy {
  font-size: 0.84rem !important;
  line-height: 1.35 !important;
  font-weight: 400 !important;
}

body.bardonecchia-listino-page .label-main {
  font-size: 0.82rem !important;
}

body.bardonecchia-listino-page .label-note {
  font-size: 0.64rem !important;
  font-weight: 500 !important;
}

body.bardonecchia-listino-page .hero-actions,
body.bardonecchia-listino-page .window-switch-buttons {
  align-items: stretch !important;
}

body.bardonecchia-listino-page .btn,
body.bardonecchia-listino-page .window-switch-button,
body.bardonecchia-listino-page .sticky-cta a {
  min-height: 46px !important;
  /*padding: 0.72rem 1rem !important;*/
  font-size: 0.94rem !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
  white-space: normal !important;
  text-align: center !important;
}

body.bardonecchia-listino-page .window-switch-button {
  padding: 0.56rem 0.82rem !important;
}

body.bardonecchia-listino-page .hero-copy {
  padding: 0.7rem 0 0.25rem !important;
}

body.bardonecchia-listino-page .hero-actions {
  gap: 0.75rem !important;
  margin-top: 1.15rem !important;
}

body.bardonecchia-listino-page .hero-comparison {
  gap: 0.85rem !important;
  margin-top: 1.35rem !important;
}

body.bardonecchia-listino-page .section-heading {
  gap: 0.65rem !important;
  margin-bottom: 1.4rem !important;
}

body.bardonecchia-listino-page .summary-card,
body.bardonecchia-listino-page .period-card,
body.bardonecchia-listino-page .metric-card,
body.bardonecchia-listino-page .benefit-item,
body.bardonecchia-listino-page .mobile-price-card,
body.bardonecchia-listino-page .content-panel,
body.bardonecchia-listino-page .resort-card,
body.bardonecchia-listino-page .final-cta-card {
  min-width: 0 !important;
  overflow-wrap: anywhere !important;
}

body.bardonecchia-listino-page .summary-card {
  gap: 0.42rem !important;
  padding: 1rem 1rem 0.95rem !important;
}

body.bardonecchia-listino-page .period-card {
  gap: 0.4rem !important;
  padding: 1rem 0.9rem !important;
}

body.bardonecchia-listino-page .resort-head {
  gap: 1.1rem !important;
  padding: 1.7rem 1.5rem 1rem !important;
}

body.bardonecchia-listino-page .resort-body {
  gap: 1.1rem !important;
  padding: 0 1.5rem 1.5rem !important;
}

body.bardonecchia-listino-page .metric-card {
  padding: 0.85rem 0.8rem !important;
}

body.bardonecchia-listino-page .benefits-panel {
  padding: 1.2rem 1rem 1.1rem 1.15rem !important;
}

body.bardonecchia-listino-page .pricing-panel {
  padding: 1.2rem 0.9rem 1rem 1.1rem !important;
}

body.bardonecchia-listino-page .benefits-list {
  gap: 0.75rem !important;
  margin-top: 1rem !important;
}

body.bardonecchia-listino-page .benefit-item {
  padding: 0.85rem 0.85rem 0.85rem 0.95rem !important;
}

body.bardonecchia-listino-page .window-switch {
  gap: 0.75rem !important;
  margin: 0.95rem 0 0.85rem !important;
}

body.bardonecchia-listino-page .window-switch-buttons {
  gap: 0.45rem !important;
}

body.bardonecchia-listino-page .notice-banner {
  padding: 1rem 0.95rem !important;
}

body.bardonecchia-listino-page .notes-list {
  gap: 0.55rem !important;
  margin-top: 1rem !important;
}

body.bardonecchia-listino-page .notes-list li {
  padding-left: 0.9rem !important;
}

body.bardonecchia-listino-page .final-cta-card {
  gap: 1.2rem !important;
  padding: 1.45rem !important;
}

body.bardonecchia-listino-page .pricing-table-wrap,
body.bardonecchia-listino-page .table-responsive {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: thin !important;
}

body.bardonecchia-listino-page .pricing-table {
  width: 100% !important;
  min-width: 600px !important;
  table-layout: auto !important;
}

body.bardonecchia-listino-page .pricing-table th,
body.bardonecchia-listino-page .pricing-table td {
  padding: 0.44rem 0.3rem !important;
  font-size: 0.84rem !important;
  line-height: 1.15 !important;
}

body.bardonecchia-listino-page .pricing-table th,
body.bardonecchia-listino-page .pricing-table td,
body.bardonecchia-listino-page .price-line,
body.bardonecchia-listino-page .group-cell {
  white-space: nowrap !important;
}

body.bardonecchia-listino-page .price-line {
  font-size: 0.86rem !important;
}

body.bardonecchia-listino-page .label-cell,
body.bardonecchia-listino-page .label-cell *,
body.bardonecchia-listino-page .label-note {
  white-space: normal !important;
}

body.bardonecchia-listino-page .label-cell {
  min-width: 148px !important;
}

body.bardonecchia-listino-page .label-cell.is-wide {
  padding-left: 0.72rem !important;
}

body.bardonecchia-listino-page .group-cell {
  width: 46px !important;
  min-width: 46px !important;
  font-size: 0.72rem !important;
  font-weight: 800 !important;
}

@media (max-width: 991.98px) {
  body.bardonecchia-listino-page .pricing-table-wrap,
  body.bardonecchia-listino-page .table-responsive {
    display: block !important;
  }

  body.bardonecchia-listino-page .mobile-pricing-grid {
    display: none !important;
  }
}

@media (max-width: 575.98px) {
  body.bardonecchia-listino-page .section-heading h2,
  body.bardonecchia-listino-page .final-cta-card h2,
  body.bardonecchia-listino-page .resort-head h3 {
    font-size: 1.55rem !important;
    line-height: 1.02 !important;
  }

  body.bardonecchia-listino-page .hero-text,
  body.bardonecchia-listino-page .section-heading p,
  body.bardonecchia-listino-page .final-cta-card p,
  body.bardonecchia-listino-page .resort-subtitle,
  body.bardonecchia-listino-page .benefit-item,
  body.bardonecchia-listino-page .notes-list li,
  body.bardonecchia-listino-page .notice-line {
    font-size: 0.9rem !important;
  }

  body.bardonecchia-listino-page .pricing-table {
    min-width: 600px !important;
  }
}
