/* /CSS/immobile_dettaglio.css */
:root{
  --bg:#f5f5f5; --fg:#333; --muted:#666;
  --card:#ffffff; --border:#e5e7eb; --shadow:rgba(0,0,0,.12);
  --accent:#34546A; --danger:#e53935;
  /* Dimensione base delle icone dei dettagli (facile da aumentare se serve) */
  --detail-icon-size:32px;
  color-scheme: light;
}
@media (prefers-color-scheme: dark){
  :root{ color-scheme: light; }
  html, body{ background-color:#f5f5f5; color:#333; }
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--fg);font-family:'Poppins', system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,sans-serif; overflow-x:hidden}
a{color:#34546A}
img{max-width:100%; height:auto}

.page{padding:0} /* evita spazio bianco sotto al footer */
.topbar{display:flex;justify-content:flex-start;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:#ffffff;position:sticky;top:0;z-index:10;
  /* Allinea il contenuto della topbar con il container sottostante (max-width 1100px + 32px di padding complessivo) */
  padding-left: max(16px, calc((100vw - 1132px)/2 + 16px));
  padding-right: max(16px, calc((100vw - 1132px)/2 + 16px));
}
.back{text-decoration:none;color:#34546A;background:rgba(52,84,106,.08);border:1px solid var(--border);padding:8px 12px;border-radius:10px}

.container{max-width:1100px;margin:18px auto 0;padding:0 16px; overflow-x:hidden}

.head .labels{display:flex;gap:8px;margin-bottom:8px}
.tag{display:inline-block;font-size:12px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);background:#f9fafb;color:#35506a}
.tag.sale{border-color:#93c5fd;color:#1d4ed8;background:#eff6ff}
.tag.rent{border-color:#86efac;color:#047857;background:#ecfdf5}
.tag.danger{border-color:#fecaca;color:#b91c1c;background:#fee2e2}

.head .price{font-size:28px;margin:0 0 6px}
.head .sub{color:#475569;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.head .dot{opacity:.6}
.head .sub .stat{display:inline-flex;align-items:center;gap:6px}
.head .sub .icon{width:16px;height:16px;display:inline-block}
/* Nasconde la riga originale senza icone */
.head .sub:not(.sub--icons){display:none}
.address{margin-top:6px;color:#64748b}

.gallery{position:relative;margin:18px 0;background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 8px 20px var(--shadow)}
.badge-nd{
    position:absolute; top:14px; left:-44px; transform:rotate(-20deg);
    background:var(--danger); color:#fff; font-weight:700; font-size:13px;
    padding:6px 88px 6px 120px; letter-spacing:.4px; text-indent:-12px; box-shadow:0 6px 12px rgba(229,57,53,.35);
    z-index:3; pointer-events:none;
}

/* container principale: mantiene il viewport e clippa */
.gallery-main{
    position:relative;
    width:100%;
    aspect-ratio:16/10;
    overflow:hidden; /* evita bleed orizzontale */
    background:#0b0d12;
    max-width:100%;
}

/* track orizzontale che scorre */
.g-track{
    display:flex;
    height:100%;
    transform:translateX(0);           /* stato iniziale */
    transition:transform .25s ease;    /* transizione fluida */
    will-change: transform;
}

/* ogni immagine occupa il 100% del viewport */
.g-track img{
    flex:0 0 100%;
    width:100%;
    height:100%;
    object-fit:contain;
    background:#0b0d12;
    user-select:none;
    cursor: zoom-in;
}


.g-nav{
    position:absolute;top:0;bottom:0;transform:none;
    width:18vw;
    min-width:110px;
    max-width:220px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    border:none;
    background:linear-gradient(to right, rgba(5,8,20,.32), rgba(5,8,20,0));
    color:#fff;
    cursor:pointer;
    z-index:4;
    font-size:38px;
    line-height:1;
    padding:0 20px 0 16px;
    opacity:0;
    transition:opacity .18s ease;
}
.g-nav.next{
    right:0;
    left:auto;
    justify-content:flex-end;
    background:linear-gradient(to left, rgba(5,8,20,.32), rgba(5,8,20,0));
    padding:0 16px 0 20px;
}
.g-nav.prev{left:0;}
.g-nav.prev{left:0;}
.gallery-main:focus-within .g-nav,
.gallery-main:hover .g-nav{
    opacity:1;
}
.g-nav[disabled]{display:none}

.thumbs{display:flex;gap:8px;overflow-x:auto;padding:10px;background:#f9fafb;border-top:1px solid var(--border); max-width:100%}
/* Scrollbar visibile su desktop per scorrimento manuale */
.thumbs::-webkit-scrollbar{height:8px}
.thumbs::-webkit-scrollbar-track{background:#e5e7eb;border-radius:4px}
.thumbs::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:4px}
.thumbs::-webkit-scrollbar-thumb:hover{background:#64748b}
/* Firefox */
.thumbs{scrollbar-width:thin;scrollbar-color:#94a3b8 #e5e7eb}

.thumb{border:1px solid var(--border);background:transparent;padding:0;border-radius:10px;overflow:hidden;cursor:pointer;flex:0 0 auto; position:relative;}
.thumb img{display:block;width:110px;height:72px;object-fit:cover;opacity:.9;transition:opacity .12s}
.thumb:focus img,.thumb:hover img{opacity:1}

.plans{margin:24px 0}
.plans h2{margin:0 0 10px}
.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.plan{position:relative;display:block;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#f8fafc}
.plan img{display:block;width:100%;height:180px;object-fit:contain;background:#f8fafc}
.plan .zoom{position:absolute;bottom:6px;right:8px;background:rgba(0,0,0,.6);color:#fff;font-size:12px;padding:4px 8px;border-radius:8px}

.details{margin:30px 0;padding:0}
.details h2{margin:0 0 16px;font-size:24px;font-weight:600;padding:0 16px}
.details h3{margin:24px 0 10px;font-size:18px;font-weight:600;padding:0 16px}

/* Nuovo layout: lista con icone invece di grid boxes */
.details-list{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:14px 24px;
  padding:16px;
}

.detail-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border-radius:10px;
  background:transparent;
  transition:background .15s ease;
}

.detail-item:hover{
  background:#f8fafc;
}

.detail-icon{
  flex-shrink:0;
  width:var(--detail-icon-size);
  height:var(--detail-icon-size);
  color:#34546A;
  display:flex;
  align-items:center;
  justify-content:center;
}

.detail-icon svg{
  width:100%;
  height:100%;
  display:block;
}

.detail-icon--bold svg,
.detail-icon--bold svg *{
  stroke-width:3.6 !important;
}

.detail-icon--bold svg{
  transform:scale(1.16);
  transform-origin:center;
}

.detail-icon--large{
  width:calc(var(--detail-icon-size) + 8px);
  height:calc(var(--detail-icon-size) + 8px);
}

.detail-icon--large svg{
  width:100%;
  height:100%;
}

.detail-content{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:2px;
}

.detail-label{
  font-size:12px;
  color:#64748b;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.3px;
}

.detail-value{
  font-size:15px;
  color:#1e293b;
  font-weight:600;
}

/* Mobile: 1 colonna */
@media (max-width: 640px){
  .details-list{
    grid-template-columns:1fr;
    gap:10px;
    padding:12px 16px;
  }
  .detail-item{
    padding:8px 10px;
  }
}
.details .k{color:#64748b; font-size:.9rem}
.details .v{font-weight:600; word-break:break-word}
.details .desc{padding:14px 16px;border-top:1px solid var(--border)}
.details .desc h3{margin:0 0 8px}
.details .desc p{margin:0;white-space:pre-wrap;line-height:1.6}
/* Evidenza della thumb attiva */
.thumb img { opacity: .75; transition: opacity .12s, outline-color .12s, box-shadow .12s; }
.thumb:hover img, .thumb:focus img { opacity: .95; }
.thumb.active img {
    opacity: 1;
    outline: 2px solid #4da3ff;
    outline-offset: -2px;
    box-shadow: 0 0 0 2px rgba(77,163,255,.25);
}

@media (max-width: 640px){
    .g-nav{
        width:12vw;
        min-width:70px;
        max-width:110px;
        padding:0 12px;
        font-size:32px;
        opacity:0;
    }
    .gallery-main:active .g-nav{
        opacity:0.85;
    }
}

@media (hover: none) {
    .g-nav{
        opacity:0;
    }
}
