/* Hotel Bel Soggiorno — Genova
   Look: blu notte + oro caldo, font serif per i titoli, sans per il resto.
   Palette ispirata al sito originale (#2e4375 blu, #ffca00 giallo) ma più
   elegante: oro caldo invece di giallo acceso. */

:root{
  --brand-navy:#1f3454;
  --brand-navy-dark:#142441;
  --brand-navy-soft:#2c4970;
  --brand-gold:#b48c4d;
  --brand-gold-dark:#8a6a37;
  --txt:#2a2a2a;
  --txt-soft:#666;
  --line:#e5e5e5;
  --bg:#fff;
  --bg-soft:#f7f5f1;
  --footer-bg:#152238;
  --footer-txt:#cfd6e2;
  --footer-link:#fff;
  --maxw:1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Open Sans','Helvetica Neue',Arial,sans-serif;
  color:var(--txt);
  background:var(--bg);
  line-height:1.6;
  font-size:15.5px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--brand-navy);text-decoration:none}
a:hover{color:var(--brand-gold-dark);text-decoration:underline}
img{max-width:100%;height:auto;display:block}

h1,h2,h3,h4{
  font-family:'Playfair Display','Georgia',serif;
  font-weight:500;
  color:#1a2538;
  letter-spacing:.3px;
}
h1{font-size:2.6rem;margin:0 0 .8rem;line-height:1.15}
h2{font-size:2rem;margin:0 0 1rem;text-align:center;line-height:1.2}
h2::after{
  content:"";display:block;width:64px;height:2px;background:var(--brand-gold);
  margin:.8rem auto 0;
}
h2.left{text-align:left}
h2.left::after{margin-left:0}
h3{font-size:1.3rem;margin:.4rem 0 .6rem}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== TOP BAR ===== */
.topbar{
  background:#fff;border-bottom:1px solid var(--line);
  font-size:13px;color:var(--txt-soft);
}
.topbar .container{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:8px;padding-bottom:8px;flex-wrap:wrap;gap:8px;
}
.topbar .lang{display:flex;gap:14px}
.topbar .lang a{color:var(--txt-soft);text-transform:uppercase;font-size:12px;letter-spacing:1.4px}
.topbar .lang a.active{color:var(--brand-navy);font-weight:700}
.topbar .phone{font-size:13px}
.topbar .phone strong{color:#1a2538}

/* ===== HEADER / LOGO + NAV ===== */
.site-header{
  background:#fff;border-bottom:1px solid var(--line);
  padding:18px 0;
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.brand{
  font-family:'Playfair Display','Georgia',serif;
  font-size:1.85rem;color:#1a2538;letter-spacing:1.2px;line-height:1.05;
}
.brand small{
  display:block;font-family:'Open Sans',sans-serif;font-size:10.5px;
  letter-spacing:3px;text-transform:uppercase;color:var(--brand-gold);
  margin-top:4px;font-weight:600;
}
.main-nav ul{
  list-style:none;padding:0;margin:0;display:flex;gap:4px;flex-wrap:wrap;
}
.main-nav a{
  display:block;padding:10px 12px;color:#333;font-size:13px;
  text-transform:uppercase;letter-spacing:1.2px;border-bottom:2px solid transparent;
  font-weight:600;
}
.main-nav a:hover,.main-nav a.active{
  color:var(--brand-navy);border-bottom-color:var(--brand-gold);text-decoration:none;
}
.nav-toggle{display:none;background:none;border:1px solid #ccc;padding:6px 10px;font-size:18px;cursor:pointer;border-radius:3px}

/* ===== HERO ===== */
.hero{
  position:relative;
  height:78vh;
  min-height:560px;
  max-height:820px;
  background:#1a2538 url('../img/hero/hero-home.jpg') center/cover no-repeat;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(20,30,55,.55) 0%, rgba(20,30,55,.35) 60%, rgba(20,30,55,.55) 100%);
}
.hero-inner{
  position:relative;z-index:1;height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:#fff;text-align:center;padding:0 16px;
}
.hero-inner .eyebrow{
  font-size:11px;letter-spacing:4px;text-transform:uppercase;
  color:var(--brand-gold);font-weight:700;margin-bottom:14px;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
}
.hero-inner h1{
  color:#fff;font-size:3.4rem;text-shadow:0 2px 14px rgba(0,0,0,.55);
  margin-bottom:.4rem;
}
.hero-inner p{
  font-size:1.05rem;letter-spacing:2.4px;text-transform:uppercase;
  text-shadow:0 1px 8px rgba(0,0,0,.55);margin-top:6px;
}

/* Hero più basso per le pagine interne */
.hero.subhero{height:42vh;min-height:300px;max-height:380px}
.hero.subhero .hero-inner h1{font-size:2.6rem;margin-bottom:0}
.hero.subhero .hero-inner p{margin-top:10px;font-size:.95rem;letter-spacing:3px}

/* ===== BOOKING WIDGET ===== */
.booking-bar{
  background:#fff;
  border:1px solid #e7e2d6;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.4);
  margin:-64px auto 0;
  position:relative;z-index:5;
  max-width:1140px;
  padding:0;
  border-radius:0;
}
form.booking-bar,
.booking-bar.booking-bar-form,
.booking-bar form,
form.booking-bar-form{
  display:grid !important;
  grid-template-columns:1.2fr 1.2fr 1.2fr auto !important;
  grid-template-rows:auto !important;
  gap:0 !important;
  align-items:stretch !important;
  width:100% !important;
}
form.booking-bar > .fld,
.booking-bar form > .fld,
.booking-bar.booking-bar-form > .fld{
  grid-row:1 !important;
}
.booking-bar .fld{
  position:relative;
  padding:22px 26px;
  border-right:1px solid #e7e2d6;
  display:flex;flex-direction:column;justify-content:center;
  min-width:0;cursor:pointer;
  transition:background-color .2s;
  margin:0;
}
.booking-bar .fld:hover{background:#faf7f0}
.booking-bar .fld.btn-wrap{
  padding:0;border-right:none;
}
.booking-bar .fld > label,
.booking-bar .fld .eyebrow{
  display:block;
  font-size:10px;letter-spacing:2.2px;text-transform:uppercase;
  color:rgba(31,52,84,.7);margin-bottom:4px;
  font-weight:700;
  font-family:'Open Sans',sans-serif;
}
.booking-bar input,
.booking-bar select{
  width:100%;border:none;background:transparent;outline:none;
  padding:0;margin:0;font-family:inherit;
  font-size:14px;font-weight:500;color:#1a2538;
  appearance:none;-webkit-appearance:none;
  cursor:pointer;
}
.booking-bar input[type="date"]::-webkit-calendar-picker-indicator{
  opacity:.4;cursor:pointer;
}
.btn{
  display:inline-block;padding:14px 28px;background:var(--brand-navy);
  color:#fff;border:none;border-radius:2px;font-size:13px;
  text-transform:uppercase;letter-spacing:1.5px;cursor:pointer;
  font-family:inherit;text-decoration:none;text-align:center;
  font-weight:600;
  transition:background .3s,color .3s;
}
.btn:hover{background:var(--brand-navy-dark);color:#fff;text-decoration:none}
.btn.btn-gold{background:var(--brand-gold)}
.btn.btn-gold:hover{background:var(--brand-gold-dark)}
.btn-block{display:inline-block}
.booking-bar .btn{
  height:100%;
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:24px 38px;border-radius:0;
  font-size:11px;letter-spacing:3px;font-weight:600;
  min-width:160px;background:var(--brand-navy);
}
.booking-bar .btn:hover{background:var(--brand-gold)}
.booking-bar .btn svg{width:16px;height:16px;flex-shrink:0}

/* ===== SECTIONS ===== */
section.page{padding:64px 0}
section.page.alt{background:var(--bg-soft)}
section.page.dark{background:var(--brand-navy);color:#e9ecf2}
section.page.dark h2{color:#fff}
section.page.dark h2::after{background:var(--brand-gold)}
.intro{max-width:780px;margin:0 auto 30px;text-align:center;color:var(--txt-soft);font-size:1.05rem}
.lead{
  font-size:1.06rem;text-align:center;color:var(--txt);max-width:780px;
  margin:0 auto 26px;line-height:1.75;
}
.lead.left{text-align:left;margin-left:0}

.feature-grid{
  display:grid;gap:24px;grid-template-columns:repeat(3,1fr);
  margin-top:30px;
}
.feature{
  background:#fff;border:1px solid var(--line);padding:28px 22px;text-align:center;
  transition:transform .3s,box-shadow .3s;
}
.feature:hover{transform:translateY(-4px);box-shadow:0 18px 40px -20px rgba(0,0,0,.18)}
.feature .ico{
  width:46px;height:46px;margin:0 auto 14px;color:var(--brand-gold);
}
.feature h3{margin:.2rem 0 .4rem;color:#1a2538}
.feature p{color:var(--txt-soft);font-size:.95rem;margin:0}

.list-clean{list-style:none;padding:0;margin:18px 0;max-width:680px}
.list-clean li{
  padding:11px 0 11px 30px;border-bottom:1px dotted #d6d6d6;
  position:relative;color:var(--txt);
}
.list-clean li::before{
  content:"\2713";position:absolute;left:0;top:11px;color:var(--brand-gold);font-weight:700;font-size:1.05rem;
}

.two-col{display:grid;gap:48px;grid-template-columns:1fr 1fr;align-items:center}
.two-col img{box-shadow:0 12px 30px -10px rgba(0,0,0,.25)}
.two-col.flip{direction:rtl}
.two-col.flip > *{direction:ltr}

/* Card camere */
.rooms-grid{
  display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin-top:30px;
}
.room-card{
  background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .3s,box-shadow .3s;
}
.room-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -20px rgba(0,0,0,.2)}
.room-card .ph{aspect-ratio:4/3;overflow:hidden;background:#ddd}
.room-card .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.room-card:hover .ph img{transform:scale(1.05)}
.room-card .body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.room-card h3{margin:0 0 .35rem;color:#1a2538}
.room-card .room-desc{color:var(--txt-soft);font-size:.93rem;margin:0 0 .4rem}

.thumb-grid{
  display:grid;gap:18px;grid-template-columns:repeat(4,1fr);margin-top:24px;
}
.thumb-grid figure{margin:0;text-align:center;font-size:.88rem;color:var(--txt-soft)}
.thumb-grid figcaption{padding-top:10px}
.thumb-grid .thumb-ph,
.thumb-ph{
  width:100%;aspect-ratio:4/3;background:#ddd center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;color:#888;font-size:.85rem;
  border:1px solid var(--line);overflow:hidden;
}
.thumb-ph.has-img{color:transparent}
.thumb-ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.thumb-grid figure:hover .thumb-ph img{transform:scale(1.05)}

/* Gallery 3 colonne (servizi) */
.gallery-3{
  display:grid;gap:18px;grid-template-columns:repeat(3,1fr);margin-top:24px;
}
.gallery-3 .thumb-ph{aspect-ratio:4/3}

/* contatti box */
.contact-card{
  background:#fff;border:1px solid var(--line);padding:36px;max-width:600px;
  margin:0 auto;text-align:center;
  box-shadow:0 18px 40px -20px rgba(0,0,0,.12);
}
.contact-card p{margin:.4rem 0}
.contact-card .big{font-size:1.4rem;color:#1a2538;font-family:'Playfair Display',serif;margin-bottom:.8rem}

.map-wrap{margin-top:36px;border:1px solid var(--line);box-shadow:0 18px 40px -20px rgba(0,0,0,.12)}
.map-wrap iframe{display:block;width:100%;height:420px;border:0}

/* Note/avvisi */
.note{
  background:#fff;border-left:4px solid var(--brand-gold);
  padding:16px 22px;margin:18px 0;color:var(--txt-soft);font-size:.95rem;
}

/* ===== FOOTER ===== */
.site-footer{
  background:var(--footer-bg);color:var(--footer-txt);
  padding:50px 0 22px;margin-top:0;font-size:14px;
}
.site-footer a{color:var(--footer-link)}
.site-footer .cols{
  display:grid;gap:36px;grid-template-columns:1fr 1fr 1fr;
}
.site-footer h4{
  color:#fff;font-family:'Playfair Display',serif;font-weight:500;
  font-size:1.15rem;margin:0 0 16px;letter-spacing:.6px;
}
.site-footer h4::after{
  content:"";display:block;width:40px;height:2px;background:var(--brand-gold);margin-top:8px;
}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{padding:5px 0}
.site-footer .promo{
  display:block;padding:8px 0;color:var(--brand-gold);font-weight:600;
}
.legal{
  border-top:1px solid #2a3954;margin-top:34px;padding-top:18px;
  font-size:12px;color:#8a96ad;line-height:1.6;
}

/* ===== UTIL ===== */
.center{text-align:center}
.mt-0{margin-top:0}
.mt-2{margin-top:1rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.6rem}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  .feature-grid{grid-template-columns:1fr 1fr}
  .rooms-grid{grid-template-columns:1fr 1fr}
  .gallery-3{grid-template-columns:1fr 1fr}
  .thumb-grid{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
  .two-col.flip{direction:ltr}
  .site-footer .cols{grid-template-columns:1fr 1fr}
  .hero{height:60vh;min-height:420px}
  .hero-inner h1{font-size:2.4rem}
}
@media (max-width:980px){
  .booking-bar .fld{padding:14px 14px}
  .booking-bar .fld > label,
  .booking-bar .fld .eyebrow{font-size:9px;letter-spacing:1.4px}
  .booking-bar input,.booking-bar select{font-size:13px}
  .booking-bar .btn{padding:14px 18px;min-width:0;font-size:10px;letter-spacing:1.5px}
}
@media (max-width:640px){
  .nav-toggle{display:inline-block}
  .main-nav{display:none;width:100%;margin-top:10px}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:0;border-top:1px solid var(--line)}
  .main-nav li{border-bottom:1px solid var(--line)}
  .booking-bar{margin-top:-30px}
  .booking-bar .fld{padding:10px 8px}
  .booking-bar .fld > label,
  .booking-bar .fld .eyebrow{font-size:8px;letter-spacing:1px;margin-bottom:2px}
  .booking-bar input,.booking-bar select{font-size:11px}
  .booking-bar .btn{padding:10px 8px;font-size:9px;letter-spacing:.5px;min-width:0}
  .booking-bar .btn svg{display:none}
  .feature-grid,
  .rooms-grid,
  .gallery-3{grid-template-columns:1fr}
  .thumb-grid{grid-template-columns:1fr 1fr}
  .site-footer .cols{grid-template-columns:1fr}
  .hero{height:54vh;min-height:340px}
  .hero-inner h1{font-size:1.9rem}
  h1{font-size:1.9rem}
  h2{font-size:1.55rem}
}

/* ============================================================
   FLATPICKR — calendario elegante in tema con il brand
   ============================================================ */
.flatpickr-calendar{
  background:#fdfbf6;
  border:1px solid rgba(0,0,0,.08);
  border-radius:2px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.25);
  font-family:'Open Sans','Helvetica Neue',Arial,sans-serif;
  width:320px;max-width:calc(100vw - 32px);
  padding:10px 8px 12px;
  margin-top:0 !important;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after,
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after{display:none}

.flatpickr-months{padding:10px 6px 8px;align-items:center}
.flatpickr-month{
  color:#1a2538;
  font-family:'Playfair Display','Georgia',serif;
  height:44px;
}
.flatpickr-current-month{
  font-size:1.35rem;font-weight:400;padding:4px 0 0;letter-spacing:.5px;
}
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year{
  font-family:'Playfair Display',serif;font-weight:400;color:#1a2538;
}
.flatpickr-current-month .numInputWrapper span.arrowUp:after{
  border-bottom-color:var(--brand-gold)
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after{
  border-top-color:var(--brand-gold)
}
.flatpickr-prev-month,.flatpickr-next-month{
  color:#1a2538 !important;fill:#1a2538 !important;
  padding:12px !important;transition:color .25s;
}
.flatpickr-prev-month:hover,.flatpickr-next-month:hover{
  color:var(--brand-gold) !important;fill:var(--brand-gold) !important;
}
.flatpickr-prev-month svg,.flatpickr-next-month svg{width:12px;height:12px}

.flatpickr-weekdays{background:transparent;margin-top:6px}
span.flatpickr-weekday{
  color:rgba(31,52,84,.6);font-size:10px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;background:transparent;
}

.flatpickr-days{width:100%}
.dayContainer{width:100%;min-width:0;max-width:none;padding:4px 2px}
.flatpickr-day{
  color:#1a2538;font-size:13px;font-weight:400;
  height:38px;line-height:38px;
  border-radius:0;border:1px solid transparent;
  margin:1px 0;max-width:14.2857%;
  transition:background .2s,color .2s,border-color .2s;
}
.flatpickr-day:hover{
  background:rgba(180,140,77,.14);
  border-color:transparent;color:#1a2538;
}
.flatpickr-day.today{
  border:1px solid var(--brand-gold);
  background:transparent;color:#1a2538;font-weight:600;
}
.flatpickr-day.today:hover{background:rgba(180,140,77,.14)}
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange{
  background:var(--brand-navy) !important;
  border-color:var(--brand-navy) !important;
  color:#fff !important;font-weight:600;
}
.flatpickr-day.inRange{
  background:rgba(31,52,84,.13) !important;
  border-color:transparent !important;
  box-shadow:none !important;color:#1a2538;
}
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay{
  color:rgba(26,37,56,.25);background:transparent;
}
.flatpickr-day.flatpickr-disabled{cursor:not-allowed}

.booking-bar input.flatpickr-input{
  background:transparent;cursor:pointer;
}

/* ============================================================
   POPOVER OSPITI
   ============================================================ */
.guests-cell{position:relative}
.guests-toggle{
  width:100%;height:100%;
  background:transparent;border:none;outline:none;
  padding:0;margin:0;
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  cursor:pointer;font-family:inherit;text-align:left;
}
.guests-toggle .eyebrow{
  display:block;font-size:10px;letter-spacing:2.2px;text-transform:uppercase;
  color:rgba(31,52,84,.7);margin-bottom:4px;
  font-weight:700;
}
.guests-toggle .guests-summary{
  font-size:14px;font-weight:500;color:#1a2538;line-height:1.3;
}
.guests-popover{
  position:absolute;top:100%;left:0;right:0;
  background:#fff;border:1px solid #e7e2d6;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.25);
  padding:20px 22px;z-index:50;
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:opacity .2s,transform .2s;
  min-width:280px;
}
@media (min-width:768px){
  .guests-popover{left:auto;right:0;width:320px}
}
.guests-popover.open{opacity:1;pointer-events:auto;transform:translateY(0)}
.guests-popover.open-up{top:auto;bottom:100%;transform:translateY(6px)}
.guests-popover.open-up.open{transform:translateY(0)}
.guests-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.guests-row + .guests-row{border-top:1px solid #ece7da}
.guests-row .label{font-size:14px;color:#1a2538;font-weight:600;line-height:1.2}
.guests-row .hint{
  display:block;font-size:11px;color:rgba(31,52,84,.6);
  margin-top:2px;font-weight:400;letter-spacing:.3px;
}
.stepper{display:flex;align-items:center;gap:14px}
.stepper-btn{
  width:32px;height:32px;border-radius:50%;
  border:1px solid rgba(31,52,84,.25);
  background:transparent;color:#1a2538;
  font-size:18px;font-weight:400;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;font-family:inherit;
  transition:border-color .2s,color .2s,background .2s;
}
.stepper-btn:hover:not(:disabled){
  border-color:var(--brand-gold);color:var(--brand-gold);
}
.stepper-btn:disabled{opacity:.3;cursor:not-allowed}
.stepper-value{
  min-width:18px;text-align:center;font-weight:600;font-size:15px;color:#1a2538;
}
.guests-done{
  margin-top:14px;width:100%;
  background:var(--brand-navy);color:#fff;border:none;
  padding:11px;font-family:inherit;
  font-size:11px;text-transform:uppercase;letter-spacing:2px;font-weight:600;
  cursor:pointer;transition:background .2s;
}
.guests-done:hover{background:var(--brand-gold)}
