/* Hotel Petit Royal — Ospedaletti (IM)
   Restyle leggero sulla scia di Alexander vecchio + Bel Soggiorno.
   Palette: blu marino profondo + oro caldo + sabbia chiara (liberty + mare).
   Tipografia: Cormorant Garamond (titoli, liberty) + Inter (corpo). */

:root{
  --brand-blue:#1c4763;
  --brand-blue-dark:#123249;
  --brand-gold:#c89b56;
  --brand-gold-dark:#a07a36;
  --txt:#2b2b2b;
  --txt-soft:#5e5e5e;
  --line:#e6e1d6;
  --bg:#fff;
  --bg-soft:#f7f2e8;
  --bg-cream:#faf6ec;
  --footer-bg:#123249;
  --footer-txt:#cfd7df;
  --footer-link:#fff;
  --maxw:1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter','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-blue);text-decoration:none;transition:color .2s}
a:hover{color:var(--brand-gold-dark);text-decoration:underline}
img{max-width:100%;height:auto;display:block}

h1,h2,h3,h4{
  font-family:'Cormorant Garamond','Playfair Display','Georgia',serif;
  font-weight:500;
  color:#1a1a1a;
  letter-spacing:.4px;
  line-height:1.2;
}
h1{font-size:2.6rem;margin:0 0 .8rem}
h2{font-size:2rem;margin:0 0 1rem;text-align:center}
h2::after{
  content:"";display:block;width:64px;height:2px;background:var(--brand-gold);
  margin:.7rem auto 0;
}
h3{font-size:1.35rem;margin:.4rem 0 .6rem}
h4{font-size:1.1rem;letter-spacing:1px;text-transform:uppercase;margin:0 0 14px}

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

/* ===== TOP BAR ===== */
.topbar{
  background:var(--brand-blue-dark);
  color:#dfe6ed;
  font-size:13px;
}
.topbar a{color:#dfe6ed}
.topbar a:hover{color:var(--brand-gold);text-decoration:none}
.topbar .container{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:8px;padding-bottom:8px;flex-wrap:wrap;gap:10px;
}
.topbar .lang{display:flex;gap:14px}
.topbar .lang a{text-transform:uppercase;font-size:12px;letter-spacing:2px}
.topbar .lang a.active{color:var(--brand-gold);font-weight:600}
.topbar .phone strong{color:#fff;font-weight:600}
.topbar .social a{margin-left:10px;font-size:14px}

/* ===== HEADER / LOGO + NAV ===== */
.site-header{
  background:#fff;border-bottom:1px solid var(--line);
  padding:18px 0;position:relative;
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
}
.brand{
  display:flex;align-items:center;gap:14px;
}
.brand .brand-mark{
  width:54px;height:54px;border-radius:50%;
  border:2px solid var(--brand-gold);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:#fff;flex-shrink:0;
}
.brand .brand-mark img{width:46px;height:46px;object-fit:cover;border-radius:50%}
.brand .brand-text{
  font-family:'Cormorant Garamond','Georgia',serif;
  font-size:1.7rem;color:#1a1a1a;letter-spacing:1.5px;line-height:1;
}
.brand .brand-text small{
  display:block;font-family:'Inter',sans-serif;font-size:10.5px;
  letter-spacing:3px;text-transform:uppercase;color:var(--brand-gold-dark);
  margin-top:4px;font-weight:500;
}
.main-nav ul{
  list-style:none;padding:0;margin:0;display:flex;gap:4px;flex-wrap:wrap;
}
.main-nav a{
  display:block;padding:10px 14px;color:#3a3a3a;font-size:13.5px;
  text-transform:uppercase;letter-spacing:1.4px;border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;font-weight:500;
}
.main-nav a:hover,.main-nav a.active{
  color:var(--brand-blue);border-bottom-color:var(--brand-gold);text-decoration:none;
}
.nav-toggle{
  display:none;background:none;border:1px solid #ccc;padding:8px 12px;
  font-size:20px;cursor:pointer;color:var(--brand-blue);
}

/* ===== HERO ===== */
.hero{
  position:relative;
  height:78vh;
  min-height:560px;
  max-height:780px;
  background:#1c2c3a center/cover no-repeat;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(18,50,73,.25) 0%,rgba(18,50,73,.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:5px;text-transform:uppercase;
  color:var(--brand-gold);margin-bottom:18px;
  text-shadow:0 1px 4px rgba(0,0,0,.4);font-weight:600;
}
.hero-inner h1{
  color:#fff;font-size:3.4rem;text-shadow:0 2px 14px rgba(0,0,0,.45);
  margin-bottom:.6rem;font-weight:500;
}
.hero-inner p{
  font-size:1.15rem;letter-spacing:3px;text-transform:uppercase;
  text-shadow:0 1px 6px rgba(0,0,0,.5);margin:0;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  letter-spacing:1px;font-size:1.4rem;text-transform:none;
}
.hero-inner .scroll-cue{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  color:#fff;opacity:.7;font-size:22px;animation:bounce 2s infinite;
}
@keyframes bounce{
  0%,20%,50%,80%,100%{transform:translateX(-50%) translateY(0)}
  40%{transform:translateX(-50%) translateY(-8px)}
  60%{transform:translateX(-50%) translateY(-4px)}
}

/* Hero compatto per pagine interne */
.hero.compact{height:42vh;min-height:300px;max-height:420px}
.hero.compact .hero-inner h1{font-size:2.4rem}
.hero.compact .hero-inner p{font-size:1.1rem}

/* ===== BOOKING BAR ===== */
.booking-bar{
  background:#fff;
  border:1px solid #e7e2d6;
  box-shadow:0 30px 80px -30px rgba(18,50,73,.5);
  margin:-64px auto 0;
  position:relative;z-index:5;
  max-width:1140px;
  padding:0;
}
form.booking-bar{
  display:grid !important;
  grid-template-columns:1.2fr 1.2fr 1.2fr auto !important;
  gap:0 !important;
  align-items:stretch !important;
  width:100% !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:#faf6ec}
.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(26,26,26,.55);margin-bottom:6px;
  font-weight:600;
}
.booking-bar input,
.booking-bar select{
  width:100%;border:none;background:transparent;outline:none;
  padding:0;margin:0;font-family:inherit;
  font-size:14.5px;font-weight:500;color:#1a1a1a;
  appearance:none;-webkit-appearance:none;cursor:pointer;
}
.booking-bar input[type="date"]::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer}
.booking-bar select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23c89b56'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right center;padding-right:18px;
}

.btn{
  display:inline-block;padding:14px 28px;background:var(--brand-gold);
  color:#fff;border:none;border-radius:2px;font-size:13px;
  text-transform:uppercase;letter-spacing:2px;cursor:pointer;
  font-family:inherit;text-decoration:none;text-align:center;
  transition:background .3s,transform .2s;font-weight:600;
}
.btn:hover{background:var(--brand-gold-dark);color:#fff;text-decoration:none;transform:translateY(-1px)}
.btn-outline{
  background:transparent;border:2px solid var(--brand-gold);color:var(--brand-gold-dark);padding:12px 26px;
}
.btn-outline:hover{background:var(--brand-gold);color:#fff}
.btn-blue{background:var(--brand-blue)}
.btn-blue:hover{background:var(--brand-blue-dark)}

.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:170px;
}
.booking-bar .btn svg{width:16px;height:16px;flex-shrink:0}

/* ===== SECTIONS ===== */
section.page{padding:80px 0}
section.page.tight{padding:50px 0}
section.page.alt{background:var(--bg-cream)}
section.page.dark{background:var(--brand-blue-dark);color:#dfe6ed}
section.page.dark h2,section.page.dark h3{color:#fff}
section.page.dark h2::after{background:var(--brand-gold)}

.eyebrow-text{
  text-align:center;font-size:11px;letter-spacing:4px;text-transform:uppercase;
  color:var(--brand-gold-dark);margin-bottom:10px;font-weight:600;
}
.intro,.lead{
  font-size:1.08rem;text-align:center;color:var(--txt);max-width:780px;
  margin:0 auto 30px;line-height:1.75;
}
.lead-soft{color:var(--txt-soft)}

/* ===== FEATURE GRID ===== */
.feature-grid{
  display:grid;gap:24px;grid-template-columns:repeat(3,1fr);
  margin-top:40px;
}
.feature{
  background:#fff;border:1px solid var(--line);padding:32px 26px;text-align:center;
  transition:transform .25s,box-shadow .25s;
}
.feature:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(18,50,73,.2)}
.feature .ico{
  width:48px;height:48px;margin:0 auto 14px;color:var(--brand-gold);
}
.feature h3{margin:.2rem 0 .6rem;color:#1a1a1a}
.feature p{color:var(--txt-soft);font-size:.96rem;margin:0;line-height:1.6}

/* ===== LIST CLEAN ===== */
.list-clean{list-style:none;padding:0;margin:18px 0}
.list-clean li{
  padding:11px 0 11px 30px;border-bottom:1px dotted #d6c89e;
  position:relative;color:var(--txt);
}
.list-clean li::before{
  content:"";position:absolute;left:0;top:18px;
  width:14px;height:8px;border-left:2px solid var(--brand-gold);
  border-bottom:2px solid var(--brand-gold);
  transform:rotate(-45deg);
}

.services-grid{
  display:grid;gap:36px;grid-template-columns:repeat(3,1fr);margin-top:36px;
}
.services-grid .svc-block h3{
  color:var(--brand-blue);font-size:1.3rem;
  border-bottom:1px solid var(--line);padding-bottom:8px;margin-bottom:6px;
}

/* ===== TWO-COL ===== */
.two-col{display:grid;gap:50px;grid-template-columns:1fr 1fr;align-items:center;margin-top:40px}
.two-col + .two-col{margin-top:80px}
.two-col img{box-shadow:0 18px 40px -18px rgba(18,50,73,.4);width:100%;height:auto;object-fit:cover;aspect-ratio:4/3}
.two-col.reverse > :first-child{order:2}

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

.gallery-grid{
  display:grid;gap:12px;
  grid-template-columns:repeat(3,1fr);
  margin-top:36px;
}
.gallery-grid img{
  width:100%;aspect-ratio:4/3;object-fit:cover;
  transition:transform .4s,opacity .3s;
}
.gallery-grid a{display:block;overflow:hidden;background:#000}
.gallery-grid a:hover img{transform:scale(1.05);opacity:.92}

/* ===== ROOM CARDS ===== */
.rooms-grid{
  display:grid;gap:32px;grid-template-columns:repeat(3,1fr);margin-top:40px;
}
.room-card{
  background:#fff;border:1px solid var(--line);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .25s,box-shadow .25s;
}
.room-card:hover{transform:translateY(-4px);box-shadow:0 25px 45px -25px rgba(18,50,73,.3)}
.room-card .room-img{aspect-ratio:4/3;background:#ddd center/cover no-repeat;overflow:hidden}
.room-card .room-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.room-card:hover .room-img img{transform:scale(1.05)}
.room-card .room-body{padding:24px 22px;flex:1;display:flex;flex-direction:column}
.room-card h3{color:var(--brand-blue);margin-top:0}
.room-card p{color:var(--txt-soft);font-size:.95rem;flex:1}
.room-card .room-meta{
  margin:14px 0;padding:10px 0;border-top:1px solid var(--line);
  font-size:.85rem;color:var(--brand-gold-dark);
  text-transform:uppercase;letter-spacing:1.5px;font-weight:600;
}

/* ===== CONTATTI ===== */
.contact-grid{
  display:grid;grid-template-columns:minmax(0,640px);gap:50px;margin-top:40px;align-items:start;justify-content:center;
}
.contact-card{
  background:#fff;border:1px solid var(--line);padding:36px;
}
.contact-card h3{color:var(--brand-blue);margin-top:0}
.contact-card p{margin:.4rem 0;color:var(--txt)}
.contact-card .row{
  display:flex;gap:14px;align-items:flex-start;padding:10px 0;
  border-bottom:1px dotted var(--line);
}
.contact-card .row:last-child{border-bottom:none}
.contact-card .row .ico{
  width:22px;height:22px;color:var(--brand-gold);flex-shrink:0;margin-top:2px;
}
.contact-card .row strong{display:block;color:#1a1a1a;font-size:.85rem;
  text-transform:uppercase;letter-spacing:1.5px;margin-bottom:2px}
.map-wrap{
  width:100%;aspect-ratio:4/3;background:#e3ddd0;
  border:1px solid var(--line);overflow:hidden;
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* ===== BOOKING CTA BIG ===== */
.book-cta{
  background:var(--brand-blue) url('../img/hero/petit-mare.jpg') center/cover no-repeat fixed;
  position:relative;padding:90px 0;color:#fff;text-align:center;
  background-blend-mode:multiply;
}
.book-cta::before{content:"";position:absolute;inset:0;background:rgba(18,50,73,.7)}
.book-cta .container{position:relative;z-index:1}
.book-cta h2{color:#fff}
.book-cta h2::after{background:var(--brand-gold)}
.book-cta p{max-width:680px;margin:0 auto 26px;font-size:1.05rem;color:#dfe6ed}

/* ===== FOOTER ===== */
.site-footer{
  background:var(--footer-bg);color:var(--footer-txt);
  padding:60px 0 24px;font-size:14px;
}
.site-footer a{color:var(--footer-link)}
.site-footer a:hover{color:var(--brand-gold);text-decoration:none}
.site-footer .cols{
  display:grid;gap:40px;grid-template-columns:1.2fr 1fr 1fr 1fr;
}
.site-footer h4{
  color:#fff;font-family:'Cormorant Garamond',serif;font-weight:500;
  font-size:1.25rem;margin:0 0 16px;letter-spacing:.6px;
  text-transform:none;
}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{padding:5px 0}
.site-footer .promo{
  display:block;padding:6px 0;color:var(--brand-gold);font-weight:500;font-size:.92rem;
}
.site-footer .social a{
  display:inline-block;width:34px;height:34px;line-height:32px;
  border:1px solid rgba(255,255,255,.25);border-radius:50%;
  text-align:center;margin-right:8px;color:#fff;
  transition:background .2s,border-color .2s;
}
.site-footer .social a:hover{background:var(--brand-gold);border-color:var(--brand-gold)}
.legal{
  border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:18px;
  font-size:12px;color:rgba(255,255,255,.55);line-height:1.7;text-align:center;
}
.legal a{color:rgba(255,255,255,.7)}

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

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  h1{font-size:2.2rem}
  h2{font-size:1.7rem}
  .hero-inner h1{font-size:2.4rem}
  .hero-inner p{font-size:1.1rem}
  .feature-grid,.services-grid,.rooms-grid{grid-template-columns:1fr 1fr;gap:20px}
  .thumb-grid,.gallery-grid{grid-template-columns:1fr 1fr}
  .two-col,.contact-grid{grid-template-columns:1fr;gap:32px}
  .two-col.reverse > :first-child{order:0}
  .site-footer .cols{grid-template-columns:1fr 1fr}
  .hero{height:60vh;min-height:420px}
  .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:14px}
  .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)}
  .main-nav a{padding:14px 6px}
  .booking-bar{margin-top:-30px}
  form.booking-bar{grid-template-columns:1fr 1fr !important}
  .booking-bar .fld{padding:12px 12px;border-right:1px solid #e7e2d6}
  .booking-bar .fld:nth-child(2){border-right:none}
  .booking-bar .fld:nth-child(3){border-top:1px solid #e7e2d6}
  .booking-bar .fld.btn-wrap{grid-column:1/-1;border-top:1px solid #e7e2d6}
  .booking-bar .btn{padding:16px;font-size:12px;letter-spacing:2px;width:100%}
  .feature-grid,.services-grid,.rooms-grid{grid-template-columns:1fr}
  .thumb-grid,.gallery-grid{grid-template-columns:1fr}
  .site-footer .cols{grid-template-columns:1fr}
  .hero{height:55vh;min-height:360px}
  .hero-inner h1{font-size:1.9rem}
  .hero.compact{height:32vh;min-height:240px}
  .hero.compact .hero-inner h1{font-size:1.7rem}
  h1{font-size:1.7rem}
  h2{font-size:1.45rem}
  section.page{padding:50px 0}
  .topbar .container{flex-direction:column;text-align:center}
}
