:root {
  --petrol: #0F3D3E;
  --ivory: #f6f1e6;
  --copper-deep: #6B3811;
  --copper-light: #e0b07b;
  --copper-mid: #C07A3E;
  --copper-dark: #8a4a17;
  --copper-highlight: #f3d7b3;
}

html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  overflow-x: hidden;
  /* Background coerente con il sito (petrol + nero) */
  background-color: #070708;
  background-image:
    radial-gradient(1100px 700px at 18% 0%, rgba(15,61,62,.88), transparent 58%),
    radial-gradient(900px 620px at 82% 18%, rgba(15,61,62,.88), transparent 60%),
    radial-gradient(700px 480px at 50% 110%, rgba(15,61,62,.28), transparent 55%);
  background-attachment: fixed;

  color: var(--ivory);
  font-family: 'Inter', system-ui, sans-serif;
  padding-bottom: 96px; /* evita che la sticky-bar copra l'ultima sezione */
}

.title-font { font-family: 'Cinzel', serif; }

/* Glass system */
.glass {
  background: rgba(9, 49, 52, .42);
  border: 1px solid rgba(246, 241, 230, .14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.panel {
  background: rgba(6, 20, 20, .62);
  border: 1px solid rgba(246, 241, 230, .14);
  border-radius: 18px;
  box-shadow: 0 18px 40px rgba(0, 0, 0, .28);
}

/* Metallic Shimmer Text */
.shimmer-text {
  background: linear-gradient(
    110deg,
    var(--copper-dark) 0%,
    var(--copper-light) 45%,
    var(--copper-highlight) 50%,
    var(--copper-light) 55%,
    var(--copper-dark) 100%
  );
  background-size: 300% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: metal-shift 8s ease-in-out infinite alternate;
}

@keyframes metal-shift {
  0% { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}

/* Buttons Base */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  border-radius: 9999px;
  padding: .75rem 1.05rem;
  font-weight: 700;
  transition: all .35s cubic-bezier(0.16, 1, 0.3, 1);
  border: 1px solid rgba(246, 241, 230, .16);
}

.btn-ghost {
  background: rgba(246, 241, 230, .06);
  color: var(--ivory);
}

.btn-ghost:hover {
  background: rgba(246, 241, 230, .10);
  transform: translateY(-1px);
}

.link-underline {
  border-bottom: 1px solid rgba(246, 241, 230, .25);
  padding-bottom: 2px;
}
.btn-rame{
    color: var(--ivory);
    border-color: rgba(184,115,51,.85);
    background: linear-gradient(135deg,
      #6F3A12 0%,
      #B87333 18%,
      #E0A86B 35%,
      #B87333 52%,
      #8B4B1E 72%,
      #F0C38C 88%,
      #B87333 100%
    );
    box-shadow:
      0 14px 34px rgba(0,0,0,.25),
      inset 0 1px 0 rgba(255,255,255,.22),
      inset 0 -10px 18px rgba(0,0,0,.18);
    text-shadow: 0 2px 10px rgba(0,0,0,.35);
    position: relative;
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    transform: translateZ(0);
  }
  .btn-rame::before{
    content:"";
    position:absolute;
    inset:-40%;
    background: linear-gradient(45deg,
      rgba(255,255,255,0) 35%,
      rgba(255,255,255,.22) 50%,
      rgba(255,255,255,0) 65%
    );
    transform: translateX(-60%) rotate(8deg);
    transition: transform .55s ease;
    pointer-events:none;
  }
  .btn-rame:hover::before{ transform: translateX(60%) rotate(8deg); }
  .btn-rame:hover{ filter: brightness(1.06) contrast(1.04); }

/* Metallic Copper Button - PIÙ SCURO */
.btn-primary {
  background: linear-gradient(
    110deg,
    var(--copper-deep) 0%,
    var(--copper-dark) 25%,
    var(--copper-highlight) 50%,
    var(--copper-dark) 75%,
    var(--copper-deep) 100%
  );
  background-size: 200% 100%;
  animation: metal-shift 3s ease-in-out infinite alternate;
  color: #f6f1e6;

  border: 1px solid rgba(224, 176, 123, .35);

  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 10px 22px rgba(107, 56, 17, 0.35);

  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
  position: relative;
  overflow: hidden;
}

.btn-primary:hover {
  transform: translateY(-2px);
  filter: brightness(1.15);
  box-shadow: 0 14px 30px rgba(107, 56, 17, 0.4), 0 0 24px rgba(192, 122, 62, 0.2);
}

.btn-primary::before,
.btn-primary::after {
  content: none !important;
  display: none !important;
}

/* Sticky bar + floating WhatsApp */
.sticky-bar {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 90;
  padding: .75rem .9rem;
  background: rgba(6, 20, 20, .78);
  border-top: 1px solid rgba(246, 241, 230, .14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.fab-whatsapp {
  position: fixed; right: 18px; bottom: 84px;
  z-index: 95;
  width: 56px; height: 56px;
  border-radius: 9999px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(120deg, #1f9a4a, #0b5d2b);
  border: 1px solid rgba(255, 255, 255, .18);
  box-shadow: 0 16px 30px rgba(0, 0, 0, .35);
  transition: transform .3s ease;
}

.fab-whatsapp:hover { transform: translateY(-2px); filter: brightness(1.08); }

/* Flatpickr dark styling */
.flatpickr-calendar {
  background: rgba(6, 20, 20, .92);
  border: 1px solid rgba(246, 241, 230, .14);
  box-shadow: 0 22px 50px rgba(0, 0, 0, .45);
}

.flatpickr-months .flatpickr-month,
.flatpickr-weekdays,
.flatpickr-weekday {
  color: var(--ivory);
}

.flatpickr-day { color: var(--ivory); }

.flatpickr-day:hover { background: rgba(246, 241, 230, .10); }

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
  background: var(--copper-mid);
  border-color: var(--copper-mid);
  color: #0b0b0b;
}

/* Mobile: evita sovrapposizione con widget in basso a destra (iubenda) */
@media (max-width: 640px){
  .sticky-bar{
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: min(92vw, 520px) !important;
    padding-right: 72px !important;
  }

  .sticky-bar .mx-auto{
    max-width: none !important;
  }
}

/* NAV buttons: su hover/focus diventano IDENTICI a .btn-primary */
.nav-cta{
  /* base resta ghost */
}

.nav-cta:hover,
.nav-cta:focus-visible {
  background: linear-gradient(
    110deg,
    var(--copper-deep) 0%,
    var(--copper-dark) 25%,
    var(--copper-highlight) 50%,
    var(--copper-dark) 75%,
    var(--copper-deep) 100%
  );
  background-size: 200% 100%;
  animation: metal-shift 3s ease-in-out infinite alternate;

  color: #f6f1e6;
  border: 1px solid rgba(224, 176, 123, .35);

  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.2),
    0 10px 22px rgba(107, 56, 17, 0.35);

  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);

  transform: translateY(-2px);
  filter: brightness(1.12);
}

.nav-cta::before,
.nav-cta::after{
  content: none !important;
  display: none !important;
}

/* Stato selezionato (JS mette .is-active) */
.nav-cta.is-active {
  background: rgba(246, 241, 230, .10);
  border-color: rgba(224, 176, 123, .28);
}

/* --------- MULTILINE ELLIPSIS (3 righe) - con "…" visibile --------- */
/* Taglia a 3 righe e aggiunge i puntini in modo “garantito” con overlay */
.menu-clamp-3{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;

  overflow: hidden;
  position: relative;
  padding-right: 1.1em; /* spazio per i puntini */
}

/* puntini + piccola sfumatura per evitare che si “intraveda” testo sotto */
.menu-clamp-3::after{
  content: "…";
  position: absolute;
  right: 0;
  bottom: 0;

  /* finezza: sfumatura coerente con la base #070708 */
  padding-left: .35em;
  background: linear-gradient(to right, rgba(7,7,8,0), rgba(7,7,8,.95) 60%);

  line-height: 1.1;
  font-weight: 800;
  color: rgba(246,241,230,.92);
}


img, video { max-width: 100%; height: auto; }

/* --- DICONO DI NOI: badge premio + TripAdvisor widget --- */
.award-badge{
  width: 88px;
  height: 88px;
  border-radius: 18px;
  background: rgba(246, 241, 230, .06);
  border: 1px solid rgba(184,115,51,.22);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  overflow: hidden;
  flex: 0 0 auto;
}
.award-badge img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.35));
}

.ta-shell{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(246, 241, 230, .14);
  background: rgba(6, 20, 20, .62);
}

/* Tentativo “soft” di allineare il widget allo stile (dipende da come TripAdvisor inietta il DOM) */
#TA_selfserveprop310{
  width: 100% !important;
  max-width: 100% !important;
}
#TA_selfserveprop310 .TA_selfserveprop{
  margin: 0 auto !important;
  background: transparent !important;
  border: 0 !important;
}
#TA_selfserveprop310 img{
  max-height: 22px;
  width: auto;
}
#TA_selfserveprop310 a{
  color: var(--ivory) !important;
}
.fieldInput{
  color:#000;
  background:#fff;
}
.fieldInput::placeholder{
  color: rgba(0,0,0,.45);
}

/* ===== Flatpickr — tema scuro/copper coerente col sito ===== */
.flatpickr-calendar {
  background: #0b0b0c !important;
  border: 1px solid rgba(224, 176, 123, 0.18) !important;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(224, 176, 123, 0.05) !important;
  border-radius: 14px !important;
  color: var(--ivory) !important;
  overflow: hidden;
}
.flatpickr-calendar.arrowTop:before { border-bottom-color: rgba(224, 176, 123, 0.30) !important; }
.flatpickr-calendar.arrowTop:after { border-bottom-color: #0b0b0c !important; }
.flatpickr-calendar.arrowBottom:before { border-top-color: rgba(224, 176, 123, 0.30) !important; }
.flatpickr-calendar.arrowBottom:after { border-top-color: #0b0b0c !important; }

/* Header (mese + frecce) */
.flatpickr-months {
  background: linear-gradient(180deg, rgba(224, 176, 123, 0.08), transparent);
  padding: 8px 4px 6px;
}
.flatpickr-months .flatpickr-month {
  color: var(--ivory) !important;
  fill: var(--ivory) !important;
}
.flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
  color: var(--ivory) !important;
  font-weight: 700;
}
.flatpickr-monthDropdown-months {
  background: transparent !important;
}
.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month {
  background: #0b0b0c !important;
  color: var(--ivory) !important;
}
.flatpickr-current-month .numInputWrapper span.arrowUp:after { border-bottom-color: var(--copper-light) !important; }
.flatpickr-current-month .numInputWrapper span.arrowDown:after { border-top-color: var(--copper-light) !important; }
.flatpickr-prev-month,
.flatpickr-next-month {
  color: var(--copper-light) !important;
  fill: var(--copper-light) !important;
}
.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
  color: var(--copper-highlight) !important;
  fill: var(--copper-highlight) !important;
}

/* Giorni settimana */
.flatpickr-weekdays { background: transparent !important; }
span.flatpickr-weekday {
  color: rgba(246, 241, 230, 0.55) !important;
  background: transparent !important;
  font-weight: 600 !important;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Giorni */
.flatpickr-day {
  color: var(--ivory) !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  font-weight: 500;
  transition: all 0.15s ease;
}
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
  background: rgba(224, 176, 123, 0.12) !important;
  border-color: rgba(224, 176, 123, 0.35) !important;
  color: var(--copper-highlight) !important;
}
.flatpickr-day.today {
  border-color: rgba(224, 176, 123, 0.45) !important;
  color: var(--copper-light) !important;
}
.flatpickr-day.today:hover { background: rgba(224, 176, 123, 0.18) !important; }

.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
  background: linear-gradient(135deg, var(--copper-mid), var(--copper-light)) !important;
  border-color: var(--copper-light) !important;
  color: #1a0f08 !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 14px rgba(192, 122, 62, 0.40);
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
  color: rgba(246, 241, 230, 0.20) !important;
  background: transparent !important;
}

.flatpickr-day.inRange,
.flatpickr-day.inRange:hover {
  background: rgba(224, 176, 123, 0.18) !important;
  border-color: rgba(224, 176, 123, 0.35) !important;
  color: var(--ivory) !important;
  box-shadow: none !important;
}

/* Time picker (se attivo) */
.flatpickr-time input,
.flatpickr-time .flatpickr-time-separator,
.flatpickr-time .flatpickr-am-pm {
  color: var(--ivory) !important;
  background: transparent !important;
}
.flatpickr-time input:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time .flatpickr-am-pm:focus {
  background: rgba(224, 176, 123, 0.10) !important;
}
.flatpickr-time {
  border-top: 1px solid rgba(224, 176, 123, 0.18) !important;
}
