/* Local fonts */
@font-face {
  font-family: 'Jost';
  src: url('../fonts/Jost-Variable.woff2') format('woff2');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Aro';
  src: url('../fonts/Aro-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Prata';
  src: url('../fonts/Prata-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}



/* Design tokens */
:root {
  /* colors */
  --ml-primary: #343537;
  --ml-secondary: #DAA14C;
  --ml-text: #666666;
  --ml-muted: #666666;
  --ml-accent: #30373E;
  --ml-lighter: #888888;
  --ml-dark: #202020;
  --ml-highlight: #cccccc;
  --ml-border: #E3E3E3;
  --ml-background-light: #F8F6F4;
  --ml-background-field: #DADADA20;

  /* typography */
  --ml-font-base: 'Jost', Helvetica, Arial, sans-serif;
  --ml-font-secondary: 'Aro', Helvetica, Arial, sans-serif;
  --ml-font-title: 'Prata', Helvetica, Arial, sans-serif;

  /* layout */
  --ml-container-max: 1200px;
  --ml-radius: 12px;
  --ml-radius-sm: 8px;
  --ml-spacing: 24px;
  --ml-spacing-lg: 56px;
}

/* Base */
html { box-sizing: border-box; }
*, *::before, *::after { box-sizing: inherit; }

body {
  margin: 0;
  font-family: var(--ml-font-base);
  color: #343537; /* global character color */
  background: #f8f6f4; /* global background */
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 { 
  margin: 0 0 0.5em; 
  line-height: 1.2; 
  font-family: var(--ml-font-secondary);
}

.font-secondary { font-family: var(--ml-font-secondary); }

.container {
  width: 100%;
  max-width: var(--ml-container-max);
  margin: 0 auto;
  padding: 0 20px;
}

.section {
  padding: var(--ml-spacing-lg) 0;
}

.site-header { padding: 12px 0; border-bottom: 1px solid #e5e7eb; }
.site-footer { padding: 24px 0; background: var(--ml-primary); color: #fff; border-top: none; }
.footer__grid { display: flex; gap: 16px; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.footer__links, .footer__brand, .footer__copy { flex: 1 1 0; }
.footer__links { justify-content: flex-start; }
.footer__brand { text-align: center; }
.footer__copy { display: flex; flex-direction: column; align-items: flex-end; text-align: right; gap: 4px; }
.footer__logo { height: 36px; width: auto; display: block; }
.footer__links { display: flex; gap: 16px; }
.site-footer a { color: var(--ml-secondary); text-decoration: none; }
.site-footer a:visited { color: var(--ml-lighter); }
.site-footer a:hover, .site-footer a:active { color: var(--ml-lighter); text-decoration: none; }
@media (max-width: 640px) {
	.footer__grid { flex-direction: column; align-items: center; gap: 8px; }
	.footer__links, .footer__brand, .footer__copy { flex: none; }
	.footer__copy { text-align: center; align-items: center; }
}
.btn-primary:hover { filter: brightness(0.95); }
.muted { color: var(--ml-muted); }

/* (hero moved to style.css for highest priority and cache control) */

/* Section title */
.section-title { font-family: var(--ml-font-title); font-size: clamp(28px, 4.5vw, 48px); margin: 0 0 22px; color: var(--ml-secondary); text-align: center; }
.section-kicker { text-align: center; color: var(--ml-muted); font-size: 20px; letter-spacing: 2px; margin-bottom: 8px; }

/* Exclusive */
.site-section--exclusive { padding: calc(var(--ml-spacing-lg) * 1.1) 0; background: #fff; overflow-x: hidden; }
.exclusive__content { max-width: 960px; margin-left: auto; margin-right: auto; text-align: center; }
.exclusive__content p { margin: 0 0 10px; color: var(--ml-text); font-size: clamp(18px, 2vw, 24px); line-height: 1.7; }
.exclusive__images { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; align-items: center; justify-items: center; margin: 16px auto; max-width: 1100px; }
.exclusive__imgwrap { width: 100%; }
.exclusive__imgwrap img { display: block; width: 100%; height: auto; object-fit: cover; }
.exclusive__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 16px; justify-content: center; }
.exclusive__ctas .btn { flex: 1 1 200px; max-width: 200px; }
@media (max-width: 640px) { .exclusive__ctas .btn { width: 100%; max-width: 100%; flex: 1 1 100%; } }
@media (max-width: 960px) { .exclusive__images { grid-template-columns: 1fr; } }

/* Exclusive motion (like storytelling timing) */
.exclusive__images .exclusive__imgwrap:nth-child(1) img {
  opacity: 0;
  transform: translateY(-80px);
  transition: opacity .5s ease .25s, transform 1.4s ease;
  will-change: transform, opacity;
}
.exclusive__images .exclusive__imgwrap:nth-child(2) img {
  opacity: 0;
  transform: translateY(80px);
  transition: opacity .5s ease .25s, transform 1.4s ease;
  will-change: transform, opacity;
}
.exclusive__images .exclusive__imgwrap.is-active img {
  opacity: 1;
  transform: translateY(0);
}

/* Gallery */
.site-section--gallery { padding: calc(var(--ml-spacing-lg) * 1.1) 0; overflow-x: hidden; }
.gallery { position: relative; padding: 0 28px; }
.gallery__track { display: grid; grid-auto-flow: column; grid-auto-columns: calc((100% - 48px) / 3); gap: 24px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 6px; scroll-behavior: smooth; scrollbar-width: none; -ms-overflow-style: none; }
.gallery__track::-webkit-scrollbar { display: none; }
.gallery__slide { scroll-snap-align: center; transform: scale(.9); transition: transform .3s ease, opacity .3s ease; opacity: .9; }
.gallery__slide.is-current { transform: scale(1); opacity: 1; }
.gallery__media { display: block; width: 100%; height: auto; aspect-ratio: 2 / 3; object-fit: cover; border-radius: 0; background: #fff; }
/* arrows like reviews */
.gallery__arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 5; background: transparent; border: none; color: var(--ml-secondary); font-size: 36px; font-weight: 800; line-height: 1; padding: 0; cursor: pointer; }
.gallery__arrow[data-gallery-prev] { left: 0; }
.gallery__arrow[data-gallery-next] { right: 0; }
.gallery__arrow[data-gallery-prev]::after { content: "<"; }
.gallery__arrow[data-gallery-next]::after { content: ">"; }

@media (max-width: 1024px) {
  .gallery__track { grid-auto-columns: calc((100% - 24px) / 2); }
}
@media (max-width: 640px) { .gallery__track { grid-auto-columns: 100%; } }

/* Natale */
.site-section--natale { position: relative; padding: 0; min-height: 60vh; background-size: cover; background-position: center; background-repeat: no-repeat; overflow-x: hidden; }
.site-section--natale::before { content: ""; position: absolute; inset: 0; background: var(--ml-secondary); opacity: .5; z-index: 0; }
.natale__overlay { position: relative; inset: 0; display: grid; place-items: center; padding: 24px 4px; min-height: 60vh; }
.natale__box { background: transparent; color: #fff; padding: 24px; text-align: center; max-width: 720px; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: space-between; gap: 16px; box-shadow: 0 10px 30px rgba(0,0,0,.25); min-height: 380px; }
@media (max-width: 767px) { .natale__box { min-height: 320px; } }
.natale__text { background: transparent; padding: 0; text-align: center; color: #fff; }
.natale__text .section-title { margin-bottom: 24px; color: #fff; flex: 1 1 0%; text-shadow: 0 2px 8px rgba(0,0,0,0.4); }
.natale__copy-wrapper {
	background: rgba(52, 53, 55, 0.5);
	padding: 24px 28px;
	border-radius: 0;
	max-width: 640px;
	margin: 0 auto 24px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.natale__copy { 
	font-size: clamp(16px, 2vw, 20px); 
	line-height: 1.7; 
	color: #fff; 
	margin: 0;
	font-weight: 400;
}
.natale__text .btn { display: inline-flex; }

@media (max-width: 767px) {
	.natale__copy-wrapper {
		padding: 20px 20px;
		margin-bottom: 20px;
	}
	.natale__text .section-title {
		margin-bottom: 20px;
	}
}
.natale__cta { width: 100%; display: flex; justify-content: center; }
.natale__cta .btn { display: inline-flex; }

/* Natale CTA override: transparent bg, white border, hover secondary */
.site-section--natale .natale__cta .btn--phone { background: rgba(255, 255, 255, 0.88); border: 1px solid rgba(32, 32, 32, 0.08); color: var(--ml-secondary); border-radius: 0; }
.site-section--natale .natale__cta .btn--phone:hover { background: rgba(255, 255, 255, 0.94); }
@media (max-width: 767px) { .site-section--natale { min-height: 50vh; } }
@media (max-width: 960px) { .natale__grid { grid-template-columns: 1fr; } }

/* Map & Info */
.site-section--mapinfo { padding: calc(var(--ml-spacing-lg) * 1.1) 0; background: #fff; overflow-x: hidden; }
.mapinfo__grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 24px; align-items: stretch; }
.mapinfo__info { display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; }
.map-embed { position: relative; width: 100%; aspect-ratio: 16 / 9; background: #f0f0f0; overflow: hidden; border: none; border-radius: 0; }
.map-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
.section-subtitle {color: var(--ml-muted); font-family: var(--ml-font-title); margin: 0 0 12px; }
.site-section--mapinfo .section-subtitle { color: var(--ml-muted); }
.info-list { list-style: none; padding: 0; margin: 0 0 16px; }
.info-list li { margin: 0 0 8px; }
@media (max-width: 960px) { .mapinfo__grid { grid-template-columns: 1fr; } }

/* Reviews */
.site-section--reviews { padding: calc(var(--ml-spacing-lg) * 1.1) 0; overflow-x: hidden; }
.reviews { position: relative; }
.reviews__track { display: grid; grid-auto-flow: column; grid-auto-columns: calc((100% - 72px) / 4); gap: 24px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 6px; scroll-behavior: smooth; scrollbar-width: none; -ms-overflow-style: none; }
.reviews__track::-webkit-scrollbar { display: none; }
.review { scroll-snap-align: start; }
.reviews__track { scroll-snap-stop: always; }
.gcard { background: #fff; border: 1px solid var(--ml-border); padding: 16px; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.gcard__header { display: grid; grid-template-columns: auto 1fr auto; gap: 10px; align-items: start; margin-bottom: 8px; }
.gcard__avatar { align-self: start; }
.gcard__brand { align-self: start; }
.gcard__avatar { width: 40px; height: 40px; border-radius: 999px; background: var(--ml-highlight); color: var(--ml-dark); display: grid; place-items: center; font-weight: 700; }
.gcard__name { font-weight: 600; }
.gcard__time { font-size: 12px; color: var(--ml-muted); }
.gcard__rating { display: flex; gap: 2px; margin-bottom: 8px; }
.gcard__body { max-height: 120px; overflow: auto; font-size: 14px; line-height: 1.6; color: var(--ml-text); }
.reviews__controls { position: absolute; inset: 0; display: flex; align-items: center; justify-content: space-between; pointer-events: none; }
.reviews__prev, .reviews__next { pointer-events: auto; background: transparent; border: none; width: auto; height: auto; padding: 0 6px; }

/* Side arrows */
.reviews { position: relative; padding: 0 28px; }
.reviews [data-reviews-prev], .reviews [data-reviews-next] { position: absolute; top: 50%; transform: translateY(-50%); z-index: 5; display: grid; place-items: center; background: transparent; border: none; cursor: pointer; color: var(--ml-secondary); font-size: 36px; line-height: 1; padding: 0; user-select: none; font-weight: 800; text-shadow: 0 1px 2px rgba(0,0,0,.15); }
.reviews [data-reviews-prev] { left: 0; }
.reviews [data-reviews-next] { right: 0; }
.reviews [data-reviews-prev]::after { content: "<"; font-weight: 700; }
.reviews [data-reviews-next]::after { content: ">"; font-weight: 700; }

@media (max-width: 1024px) {
  .reviews__track { grid-auto-columns: calc((100% - 48px) / 3); }
}
@media (max-width: 640px) {
  .reviews__track { grid-auto-columns: 100%; }
}
@media (max-width: 1024px) { .reviews__track { grid-auto-columns: calc((100% - 24px) / 3); } }
@media (max-width: 640px) { .reviews__track { grid-auto-columns: 100%; } }

/* Storytelling */
.site-section--story { padding: calc(var(--ml-spacing-lg) * 1.25) 0; overflow-x: hidden; }
.story__title { font-family: var(--ml-font-title); margin: 0 0 28px; text-align: center; font-size: clamp(28px, 4.5vw, 48px); color: var(--ml-secondary); }
.story__grid { display: grid; gap: 36px; }
.story__item { display: grid; grid-template-columns: 1.2fr 1fr; gap: 24px; align-items: center; }
.story__item--reverse { grid-template-columns: 1fr 1.2fr; }
.story__item--reverse .story__text { order: 2; }
.story__item--reverse .story__media { order: 1; }
.story__step { font-family: var(--ml-font-title); font-size: clamp(20px, 2.8vw, 28px); margin: 0 0 10px; color: var(--ml-secondary); }
.story__text p { margin: 0 0 10px; color: var(--ml-text); }
.story__media { position: relative; overflow: hidden; background: #fff; border: none; border-radius: 0; }
.story__media img { border-radius: 0; }

/* Storytelling block 1 scroll-in motion */
.story__grid .story__item:nth-child(1) .story__text { opacity: 0; transform: translateX(-80px); transition: opacity .4s ease .2s, transform 1s ease; will-change: transform, opacity; }
.story__grid .story__item:nth-child(1) .story__media { opacity: 0; transform: translateX(80px); transition: opacity .4s ease .2s, transform 1s ease; will-change: transform, opacity; }
.story__grid .story__item:nth-child(1).is-active .story__text,
.story__grid .story__item:nth-child(1).is-active .story__media { opacity: 1; transform: translateX(0); }

/* Storytelling block 2 scroll-in motion (invert directions) */
.story__grid .story__item:nth-child(2) .story__text { opacity: 0; transform: translateX(80px); transition: opacity .4s ease .2s, transform 1s ease; will-change: transform, opacity; }
.story__grid .story__item:nth-child(2) .story__media { opacity: 0; transform: translateX(-80px); transition: opacity .4s ease .2s, transform 1s ease; will-change: transform, opacity; }
.story__grid .story__item:nth-child(2).is-active .story__text,
.story__grid .story__item:nth-child(2).is-active .story__media { opacity: 1; transform: translateX(0); }

/* Storytelling block 3 scroll-in motion (same as block 1) */
.story__grid .story__item:nth-child(3) .story__text { opacity: 0; transform: translateX(-80px); transition: opacity .4s ease .2s, transform 1s ease; will-change: transform, opacity; }
.story__grid .story__item:nth-child(3) .story__media { opacity: 0; transform: translateX(80px); transition: opacity .4s ease .2s, transform 1s ease; will-change: transform, opacity; }
.story__grid .story__item:nth-child(3).is-active .story__text,
.story__grid .story__item:nth-child(3).is-active .story__media { opacity: 1; transform: translateX(0); }
.story__media img { display: block; width: 100%; height: auto; }

@media (max-width: 960px) {
  .story__item, .story__item--reverse { grid-template-columns: 1fr; }
  .story__item--reverse .story__text, .story__item--reverse .story__media { order: unset; }
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 20px;
  border-radius: var(--ml-radius-sm);
  border: 1px solid var(--ml-border);
  background: #fff;
  color: var(--ml-secondary);
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
  cursor: pointer;
  font-weight: 700;
  letter-spacing: 1px;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 4px 10px rgba(0,0,0,0.08); }
.btn:active { transform: translateY(0); box-shadow: 0 1px 2px rgba(0,0,0,0.05); }
.btn--primary { background: var(--ml-primary); color: #fff; border-color: var(--ml-primary); }
.btn--dark { background: var(--ml-secondary); color: #fff; border-color: var(--ml-secondary); }
.btn--ghost { background: transparent; }

/* CTA Phone custom styling */
.btn--phone { background: transparent; color: var(--ml-secondary); border: 2px solid var(--ml-secondary); border-radius: 0; }
.btn--phone:hover { background: rgba(255, 255, 255, 1); }
.btn--phone .btn__icon { display: inline-flex; align-items: center; justify-content: center; }
.btn--phone .btn__icon svg { width: 24px; height: 24px; display: block; }
.btn--phone .btn__text { text-transform: uppercase; letter-spacing: .02em; }

.hero .hero__cta { margin-top: 16px; display: flex; justify-content: center; }
.hero .btn--phone { background: rgba(255, 255, 255, 0.88); border: 2px solid var(--ml-secondary); color: var(--ml-secondary); border-radius: 0; }
.hero .btn--phone:hover { background: rgba(255, 255, 255, 0.94); }
.hero .btn--phone .btn__icon,
.hero .btn--phone .btn__icon svg { color: var(--ml-secondary); }
.hero .btn--phone .btn__icon svg path { stroke: var(--ml-secondary); }

.btn--map { background: transparent; color: var(--ml-lighter); border: 2px solid var(--ml-lighter); border-radius: 0; }
.btn--map:hover { background: rgba(255, 255, 255, 1); }
.btn--map .btn__icon { display: inline-flex; align-items: center; justify-content: center; }
.btn--map .btn__icon svg { width: 24px; height: 24px; display: block; }
.btn--map .btn__text { text-transform: uppercase; letter-spacing: .02em; }