/* Box sizing globale */
/* Force light color scheme across UA components */
:root{
  color-scheme: light;
  /* Footer sizing tweaks (compact) */
  --footer-col-min: 220px;
  --footer-col-gap: 10px;
  --footer-row-gap: 6px;
}
@media (prefers-color-scheme: dark){
  :root{ color-scheme: light; }
  html, body{ background-color:#f5f5f5; color:#333; }
}
*, *::before, *::after {
    box-sizing: border-box;
}

html, body {
    height: 100%;
}

body {
    margin: 0;
    font-family: 'Poppins', sans-serif;
    background-color: #f5f5f5;
    color: #333;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100vh; /* ensure footer sticks on short content */
}

/* Page loader + entrance reveal */
html.page-loading body nav,
html.page-loading body main,
html.page-loading body header,
html.page-loading body footer,
body.page-loading nav,
body.page-loading main,
body.page-loading header,
body.page-loading footer{
    opacity: 0;
    transform: translateY(10px);
}
html.page-ready body nav,
html.page-ready body main,
html.page-ready body header,
html.page-ready body footer,
body.page-ready nav,
body.page-ready main,
body.page-ready header,
body.page-ready footer{
    opacity: 1;
    transform: translateY(0);
    transition: opacity .45s ease, transform .45s ease;
}
@media (prefers-reduced-motion: reduce){
  html.page-ready body main,
  html.page-ready body nav,
  html.page-ready body header,
  html.page-ready body footer,
  body.page-ready nav,
  body.page-ready main,
  body.page-ready header,
  body.page-ready footer{
    transition: none;
  }
}
.page-loader{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(245,245,245,0.92);
  backdrop-filter: blur(4px);
  z-index: 9999;
  opacity: 1;
  transition: opacity .3s ease, visibility .3s ease;
}
.page-loader.is-hidden{
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.page-loader__inner{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: #34546A;
}
.page-loader__ring{
  width: 84px;
  height: 84px;
}
.page-loader__bg{
  fill: none;
  stroke: #cbd5e1;
  stroke-width: 6;
}
.page-loader__fg{
  fill: none;
  stroke: #34546A;
  stroke-width: 6;
  stroke-linecap: round;
  transform: rotate(-90deg);
  transform-origin: 50% 50%;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
}
.page-loader__percent{
  font-weight: 700;
  font-size: 1rem;
}
.page-loader__label{
  font-size: .82rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #64748b;
}

main {
    flex: 1 0 auto; /* grow to push footer down */
}

/* ==== NAVBAR (DESKTOP) ==== */
nav {
    background-color: #34546A;
    color: white;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 21px 30px;
    min-height: 64px;
    flex-wrap: wrap;
}

nav img {
    height: 60px;
}

nav ul {
    list-style: none;
    display: flex;
    gap: 30px;
    margin: 0;
    padding: 0;
    align-items: center;
    justify-content: flex-end;
    margin-left: auto;
}

nav ul li {
    display: inline-block;
}

nav ul li a {
    color: white;
    text-decoration: none;
    font-weight: 500;
    font-size: 1rem;
    transition: color 0.2s ease;
}

nav ul li a:hover {
    color: #6C3835;
}

/* Forza altezza identica del navbar su desktop */
@media (min-width: 769px){
  nav {
    height: 64px;
    padding-top: 0;
    padding-bottom: 0;
  }
  .nav-wrapper{ height: 100%; }
}

/* ==== CONTENUTO ==== */
.contenuto {
    padding: 40px 20px;
    text-align: center;
}

/* ==== CAROSELLO ==== */
.carousel-container {
    position: relative;
    width: 100%;
    max-width: 600px;
    margin: 40px auto;
    overflow: hidden;
}

.carousel {
    display: flex;
    transition: transform 0.6s cubic-bezier(0.87, 0, 0.13, 1);
    will-change: transform;
}

.carousel-item {
    flex: 0 0 100%;
    max-width: 100%;
    transition: transform 0.5s ease;
}

.carousel-item img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: 10px;
}

.carousel-btn {
    position: absolute;
    top: 40%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 10;
    font-size: 1.5rem;
    border-radius: 50%;
}

.carousel-btn.left {
    left: 10px;
}

.carousel-btn.right {
    right: 10px;
}

.carousel-btn:disabled {
    display: none;
}

/* ==== FOOTER ==== */
footer {
    background-color: #34546A;
    color: white;
    padding: 12px;
    width: 100%;
    text-align: center;
    margin-top: auto; /* resta in fondo su contenuto corto */
    line-height: 1.35;
    font-size: .95rem;
    flex-shrink: 0;
}

.footer-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--footer-col-min, 220px), 1fr));
    justify-content: center; /* centra i blocchi all'interno del max-width */
    align-items: start;
    gap: var(--footer-row-gap, 6px) var(--footer-col-gap, 10px);
    max-width: var(--footer-max, 1100px);
    margin: 0 auto;
}

.footer-container > div {
    min-width: 0;
    max-width: none;
    text-align: center;
    display: block;
}

.footer-container p { margin: var(--footer-p-m, 3px) 0; }

footer h3 { color: #ffffff; margin-bottom: var(--footer-h3-mb, 8px); font-size: 1rem; }

/* Footer: orari più leggibili, senza riquadri */
.hours { display:flex; flex-direction:column; gap: var(--hours-row-gap, 4px); align-items:center; }
.hours-row { display:grid; grid-template-columns: auto 1fr; column-gap: var(--hours-col-gap, 10px); row-gap: 2px; align-items: start; justify-content: start; justify-items: center; }
.hours .day { font-weight:600; white-space:nowrap; }
.hours .day::after { content: ":"; margin-left: 4px; }
.hours-row .time, .hours-row .closed { grid-column: 2; display:block; padding: 0; background:none; border:0; }
.hours-row .time + .time { margin-top: 2px; }

.footer-bottom {
    margin-top: 12px;
    text-align: center;
    font-size: 0.9em;
    border-top: 1px solid #ffffff33;
    padding-top: 8px;
}

/* Footer: versione più compatta su mobile */
@media (max-width: 640px){
  footer { padding: 10px; font-size: .9rem; }
  .footer-container { grid-template-columns: 1fr; }
  .hours { align-items: center; }
}

.nav-wrapper {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
}

/* ==== HOME: IMMOBILI IN EVIDENZA ==== */
.home-listings { max-width: 1100px; margin: 40px auto; padding: 0 20px; }
.home-head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:12px; gap:12px; }
.home-head h2 { margin:0; font-weight:600; white-space:nowrap; }
.home-head .show-all { text-decoration:none; color:#34546A; border:1px solid #cbd5e1; padding:6px 10px; border-radius:10px; background:#f9fafb; white-space:nowrap; flex-shrink:0; }
.home-head .show-all:hover { background:#eef2f7; }
.home-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; justify-content:center; }
.home-grid.home-grid--single {
    grid-template-columns: minmax(260px, 420px);
    justify-items: center;
}
.home-grid.home-grid--single .home-card {
    width: min(100%, 420px);
}
.home-card { display:block; text-decoration:none; color:inherit; background:#fff; border:1px solid #e5e7eb; border-radius:14px; overflow:hidden; box-shadow:0 8px 18px rgba(0,0,0,.12); transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease; }
.home-card:hover{ transform:translateY(-2px); border-color:#cbd5e1; box-shadow:0 10px 22px rgba(0,0,0,.16); }
.home-card .thumb{ position:relative; aspect-ratio:4/3; background:#f0f3f7; overflow:hidden; }
.home-card img{ width:100%; height:100%; object-fit:cover; display:block; }
.home-card .meta{ padding:10px 12px; }
.home-card .topline{ display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:4px; }
.home-card .price{ font-weight:700; }
.home-card .topline .tipo{ color:#64748b; font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.home-card .line{ color:#64748b; font-size:.95rem; }
.home-card .stats{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; row-gap:6px; justify-content:flex-start; }
.home-card .stat{ display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.home-card .stat .icon{ width:16px; height:16px; display:inline-block; }
.home-card .stat .t{ font-size:.95rem; }
.home-card .addr{ margin-top:6px; color:#475569; font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* Allinea come in immobili_lista: stats e indirizzo a destra */
.home-card .addr{ text-align:left; }

/* Striscia rossa diagonale su thumb (venduto/affittato) */
.badge-nd{
    position:absolute; top:12px; left:-42px; transform:rotate(-20deg);
    background:#e53935; color:#fff; font-weight:700; font-size:12px;
    padding:6px 82px 6px 120px; letter-spacing:.4px; box-shadow:0 6px 12px rgba(229,57,53,.35);
    text-indent:-12px;
    z-index:3; pointer-events:none;
}

/* Etichette sotto la card (come lista) */
.labels{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}
.tag{display:inline-block;font-size:11px;padding:3px 8px;border-radius:999px;border:1px solid #e5e7eb;color:#35506a;background:#f9fafb}
.lbl-vendita{border-color:#93c5fd;color:#1d4ed8;background:#eff6ff}
.lbl-affitto{border-color:#86efac;color:#047857;background:#ecfdf5}
.lbl-vacanza{border-color:#fcd34d;color:#b45309;background:#fef3c7}
.tag.danger{border-color:#fecaca;color:#b91c1c;background:#fee2e2}

/* Responsive tweaks per la home */
@media (max-width: 640px){
  .home-head h2 { font-size: 1.4rem; }
  .home-head .show-all { padding: 5px 8px; font-size: 0.9rem; }
  .home-card .stats{ gap:10px; row-gap:4px }
  .home-card .stat .icon{ width:15px; height:15px }
  .home-card .stat .t{ font-size:.9rem }
}
@media (max-width: 420px){
  .home-head h2 { font-size: 1.2rem; }
  .home-head .show-all { padding: 4px 7px; font-size: 0.85rem; }
  .home-card .stats{ gap:8px }
  .home-card .stat .icon{ width:14px; height:14px }
  .home-card .stat .t{ font-size:.85rem }
}

/* Carosello nelle card della home (stile simile alla lista) */
.home-card .carousel{ position:relative; height:100%; }
.home-card .track,
.card .track{ display:flex; height:100%; overflow-x:auto; scroll-snap-type:x mandatory; scroll-snap-stop:always; scroll-behavior:smooth; -ms-overflow-style:none; scrollbar-width:none; position:relative; -webkit-overflow-scrolling:touch; overscroll-behavior-x:contain; }
.home-card .track::-webkit-scrollbar,
.card .track::-webkit-scrollbar{ display:none }
.home-card .track img,
.card .track img{ flex:0 0 100%; width:100%; height:100%; object-fit:cover; scroll-snap-align:center; user-select:none }
/* Frecce */
.home-card .nav,
.card .nav{
  position:absolute;
  top:0;
  bottom:0;
  width:90px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  border:none;
  color:#fff;
  cursor:pointer;
  z-index:4;
  font-size:32px;
  line-height:1;
  padding:0 14px;
  opacity:0;
  transition:opacity .18s ease;
  background:linear-gradient(to right, rgba(5,8,20,.32) 0%, rgba(5,8,20,0) 78%);
}
.home-card .nav.next,
.card .nav.next{
  right:0;
  left:auto;
  justify-content:flex-end;
  background:linear-gradient(to left, rgba(5,8,20,.32) 0%, rgba(5,8,20,0) 78%);
}
.home-card .nav.prev,
.card .nav.prev{
  left:0;
  justify-content:flex-start;
}
.home-card:hover .nav,
.home-card:focus-within .nav,
.card:hover .nav,
.card:focus-within .nav{
  opacity:1;
}
.home-card .nav:focus-visible,
.card .nav:focus-visible{
  outline:2px solid #f8fafc;
  outline-offset:4px;
}
.home-card .nav[disabled],
.card .nav[disabled]{
  display:none;
}
/* Mobile: hitbox ridotta per permettere swipe */
@media (max-width: 768px){
  .home-card .nav,
  .card .nav{
    width:50px;
    padding:0 8px;
    font-size:24px;
    opacity:0;
  }
  .home-card:active .nav,
  .card:active .nav{
    opacity:0.85;
  }
}
@media (hover:none){
  .home-card .nav,
  .card .nav{
    opacity:0;
  }
}
/* Dots */
.home-card .dots{ position:absolute; bottom:8px; left:50%; transform:translateX(-50%); max-width:min(90%, 140px); display:flex; gap:6px; padding:4px 6px; overflow-x:auto; scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none }
.home-card .dots::-webkit-scrollbar{ display:none }
.home-card .dots .dot{ flex:0 0 7px; width:7px; height:7px; border-radius:50%; background:rgba(255,255,255,.35); cursor:pointer }
.home-card .dots .dot.active{ background:#fff }
.home-card .thumb-cta{
  position:absolute;
  left:12px;
  right:12px;
  bottom:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(15,23,42,.78);
  color:#fff;
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.02em;
  z-index:4;
  pointer-events:none;
}
.home-card .thumb-cta .cta-more{
  font-weight:700;
  color:#e2e8f0;
}



/* ==== RESPONSIVE (mobile <788px) ==== */
@media (max-width: 768px) {
    footer {
        padding: 14px;
    }

    .footer-container {
        justify-items: center; /* centra le sezioni su mobile */
        gap: var(--footer-row-gap-mobile, 6px) var(--footer-col-gap-mobile, 10px);
    }

    .footer-container > div {
        align-items: center;
        text-align: center;
    }

    .carousel-item img {
        height: 250px;
    }

    .nav-wrapper {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 20px;
        width: 100%;
        justify-content: flex-end;
    }

    nav {
        padding: 18px 16px 12px;
        min-height: 64px;
        text-align: center;
        flex-direction: column;
        align-items: center;
        gap: 6px;
    }

    nav img {
        height: 70px;
    }

    nav ul {
        display: flex;
        flex-wrap: wrap;
        gap: 12px 18px;
        justify-content: center;
        align-items: center;
        width: 100%;
        max-width: none;
        margin: 10px auto 0;
        padding: 0 4px;
        overflow: visible;
        text-align: center;
    }
    nav ul li { flex: 0 1 auto; }
    nav ul li a { white-space: nowrap; }

    nav ul li {
        display: inline-flex;
        justify-content: center;
    }

    nav ul li a {
        white-space: nowrap;
        font-size: 1rem;
    }
}

/* Versione telefono (pi� stretta): riduci gap e mantieni centro */
@media (max-width: 440px) {
    nav ul {
        gap: 10px 14px;
        margin: 6px auto 0;
        text-align: center;
    }
}

/* Home logo under welcome */
.home-logo { margin: 8px auto 16px; }
.home-logo img { display:block; margin:0 auto; width: 550px; max-width: 100%; height:auto; }
/* Sottotitolo home (sotto il benvenuto) */
.home-subtitle { font-size: 1.08rem; }

/* === Logo focal alignment (responsive) ===
   Allinea il centro visivo del logo (punto medio tra 362px e 1277px
   dell'immagine originale 1278px) al centro del viewport.
   Percentuale calcolata: 819.5 / 1278 = 64.1236306729%.
   Traduzione richiesta: 50% - 64.1236306729% = -14.1236306729% dell'ampiezza del logo.
   Modifica solo il valore sotto se cambia il punto focale. */
:root {
  --logo-visual-center: 64.1236306729%;
  /* Footer spacing variables */
  --footer-col-gap: 200px;  /* distanza orizzontale tra le sezioni (desktop) */
  --footer-row-gap: 8px;    /* distanza verticale tra righe (wrap) */
  --footer-col-gap-mobile: 8px;  /* distanza orizzontale su mobile */
  --footer-row-gap-mobile: 6px;  /* distanza verticale su mobile */
  --footer-h3-mb: 8px;      /* margine sotto i titoli del footer */
  --footer-p-m: 2px;        /* margine verticale dei paragrafi nel footer */
}

/* Mantieni centrato di base con margin:auto; sposta in base al focal point in percentuale della larghezza immagine */
.home-logo img {
  transform: translateX(calc(50% - var(--logo-visual-center)));
}

/* Evita tagli su schermi piccoli: torna centrato sotto i 768px */
@media (max-width: 768px) {
  .home-logo img { transform: none; }
}

/* Footer super-compatto su schermi molto piccoli */
@media (max-width: 440px) {
  footer { padding: 10px; }
  .footer-container { gap: 2px 0; }
  .footer-container > div { text-align: center; }
  footer h3 { margin-bottom: var(--footer-h3-mb-mobile, 4px); font-size: 1rem; }
  .footer-container p { margin: var(--footer-p-m-mobile, 1px) 0; font-size: 0.95rem; }
  .footer-bottom { margin-top: 6px; }
  /* Orari: giorno a sinistra, fasce sotto una all'altra a destra */
  .hours { align-items: center; }
  .hours-row { grid-template-columns: auto 1fr; justify-items: center; row-gap: 4px; }
  .hours-row .time { display: block; }
  .hours-row .time + .time { margin-top: 4px; }
  .hours .day { margin-bottom: 0; }
}
