/* ===== TOKENS ===== */
:root{
  --verde:#2c4a2e;--verde2:#3d6640;--lino:#f4f1e8;
  --pietra:#7a6c5a;--oro:#b8862e;--bianco:#fdfcf8;
  --testo:#1c1c1a;--grigio:#4a4540;--r:4px;--t:all .28s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--lino);color:var(--testo);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ===== TOPBAR ===== */
.topbar{background:var(--verde);color:rgba(255,255,255,.7);font-size:.78rem;font-weight:300;letter-spacing:.06em;text-transform:uppercase}
.topbar-inner{max-width:1280px;margin:0 auto;padding:.5rem 2rem;display:flex;align-items:center;justify-content:space-between}
.topbar a{transition:var(--t)}.topbar a:hover{color:#fff}
.topbar-socials{display:flex;gap:1.2rem;align-items:center}
.topbar-socials svg{width:13px;height:13px;fill:currentColor;display:block}

/* ===== HEADER ===== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(253,252,248,.96);backdrop-filter:blur(8px);border-bottom:1px solid rgba(44,74,46,.1);box-shadow:0 2px 18px rgba(0,0,0,.05)}
.header-inner{max-width:1280px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.5rem;height:76px}
.nav-left{display:flex;gap:.1rem;justify-content:flex-end}
.nav-right{display:flex;gap:.1rem;justify-content:flex-start}
.nav-left a,.nav-right a{font-size:.76rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--grigio);padding:.45rem .7rem;border-radius:var(--r);transition:var(--t);white-space:nowrap}
.nav-left a:hover,.nav-right a:hover,.nav-left a.active,.nav-right a.active{color:var(--verde);background:rgba(44,74,46,.07)}
.header-logo{text-align:center}
.header-logo img{height:58px;width:auto;margin:0 auto;transition:var(--t)}
.header-logo img:hover{opacity:.82}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none}
.burger span{display:block;width:22px;height:2px;background:var(--verde);border-radius:2px;transition:var(--t)}

/* ===== PAGE HERO ===== */
.page-hero{position:relative;height:340px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;text-align:center}
.page-hero::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.48)}
.page-hero-content{position:relative;z-index:1;color:#fff;padding:0 1.5rem}
.page-hero-content .eyebrow{color:rgba(255,255,255,.75)}
.page-hero-content h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;letter-spacing:-.01em;margin-top:.6rem}

/* ===== MAIN CONTENT ===== */
.page-main{max-width:900px;margin:0 auto;padding:5rem 2rem}
.page-main h2{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--verde);margin-bottom:1rem}
.page-main h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--verde);margin:2rem 0 .7rem}
.page-main p{color:var(--grigio);font-size:.96rem;line-height:1.9;margin-bottom:1.2rem}
.page-main p:last-child{margin-bottom:0}
.wide-main{max-width:1280px}

/* ===== HELPERS ===== */
.eyebrow{display:block;font-size:.7rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--oro);margin-bottom:.9rem}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,3rem);font-weight:300;color:var(--verde);letter-spacing:-.01em;line-height:1.2}
.divider{width:44px;height:2px;background:var(--oro);margin:1.4rem 0}
.divider.center{margin:1.4rem auto}

/* ===== ROOM CARDS ===== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card{background:var(--bianco);border-radius:6px;overflow:hidden;box-shadow:0 2px 14px rgba(0,0,0,.055);transition:var(--t)}
.card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.11)}
.card-img{aspect-ratio:3/2;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card-img img{transform:scale(1.04)}
.card-body{padding:1.6rem 1.6rem 1.9rem}
.card-body h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--verde);margin-bottom:.5rem}
.card-body p{font-size:.87rem;color:var(--pietra);line-height:1.8;margin-bottom:1.1rem}
.btn-outline{display:inline-block;font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--verde);border:1.5px solid var(--verde);padding:.55rem 1.4rem;border-radius:var(--r);transition:var(--t)}
.btn-outline:hover{background:var(--verde);color:var(--bianco)}

/* ===== GALLERY GRID ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.gallery-item{aspect-ratio:3/2;overflow:hidden;border-radius:6px;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-item:hover img{transform:scale(1.05)}

/* ===== SINGLE ROOM ===== */
.room-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;margin-bottom:3rem}
.room-layout .room-text{}
.room-layout .room-photos{display:grid;gap:.75rem}
.room-photos img{border-radius:6px;width:100%;object-fit:cover}

/* ===== SERVICES PAGE ===== */
.services-page{padding:5rem 2rem;background:var(--bianco)}
.services-page-inner{max-width:1100px;margin:0 auto}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;margin-top:2.5rem}
.svc-card{display:flex;gap:1.5rem;align-items:flex-start;padding:2rem;background:var(--lino);border-radius:8px}
.svc-card svg{width:36px;height:36px;flex-shrink:0;color:var(--verde);stroke:var(--verde)}
.svc-card h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--verde);margin-bottom:.4rem}
.svc-card p{font-size:.87rem;color:var(--grigio);line-height:1.8}

/* ===== TARIFFE TABLE ===== */
.tariffe-table{width:100%;border-collapse:collapse;margin:2rem 0;font-size:.92rem}
.tariffe-table th{background:var(--verde);color:#fff;padding:.9rem 1.2rem;text-align:left;font-weight:500;letter-spacing:.04em;font-size:.8rem;text-transform:uppercase}
.tariffe-table td{padding:.85rem 1.2rem;border-bottom:1px solid rgba(0,0,0,.07);color:var(--grigio)}
.tariffe-table tr:last-child td{border-bottom:none}
.tariffe-table tr:hover td{background:rgba(44,74,46,.04)}
.tariffe-note{font-size:.84rem;color:var(--pietra);font-style:italic;margin-top:.5rem}

/* ===== CONTATTI ===== */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;color:var(--verde);margin-bottom:1.2rem}
.contact-info p{font-size:.92rem;color:var(--grigio);line-height:1.9;margin-bottom:.9rem;display:flex;gap:.7rem;align-items:flex-start}
.contact-form input,.contact-form textarea{width:100%;padding:.8rem 1rem;border:1.5px solid rgba(44,74,46,.2);border-radius:var(--r);background:var(--bianco);font-family:'Jost',sans-serif;font-size:.92rem;color:var(--testo);transition:var(--t);outline:none;margin-bottom:1rem}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--verde)}
.contact-form textarea{min-height:130px;resize:vertical}
.contact-form label{font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--pietra);display:block;margin-bottom:.3rem}
.btn-solid{display:inline-block;background:var(--verde);color:#fff;font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 2rem;border-radius:var(--r);border:none;cursor:pointer;transition:var(--t)}
.btn-solid:hover{background:var(--verde2);transform:translateY(-1px)}
.map-wrap{border-radius:8px;overflow:hidden;margin-top:2rem}
.map-wrap iframe{width:100%;height:340px;border:none;display:block}

/* ===== DOVE SIAMO ===== */
.dove-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}

/* ===== HIGHLIGHT BOX ===== */
.highlight-box{background:var(--verde);color:rgba(255,255,255,.9);border-radius:8px;padding:2rem 2.2rem;margin:2.5rem 0}
.highlight-box h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:#fff;margin-bottom:.7rem}
.highlight-box p{font-size:.9rem;line-height:1.85}
.highlight-box a{color:rgba(255,255,255,.85);text-decoration:underline;text-underline-offset:3px}
.highlight-box a:hover{color:#fff}

/* ===== OFFERTE CARDS ===== */
.offerta-card{background:var(--bianco);border-radius:8px;padding:2rem;border-left:4px solid var(--oro);margin-bottom:1.5rem;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.offerta-card h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--verde);margin-bottom:.5rem}
.offerta-card p{font-size:.9rem;color:var(--grigio);line-height:1.85}

/* ===== MOBILE NAV ===== */
.mobile-nav{display:none;position:fixed;inset:0;z-index:200;background:var(--verde);flex-direction:column;align-items:center;justify-content:center;gap:1.4rem}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:300;color:rgba(255,255,255,.88);letter-spacing:.04em;transition:var(--t)}
.mobile-nav a:hover{color:#fff}
.mobile-close{position:absolute;top:1.5rem;right:1.8rem;font-size:1.8rem;color:rgba(255,255,255,.7);cursor:pointer;background:none;border:none;transition:var(--t)}
.mobile-close:hover{color:#fff}

/* ===== FOOTER ===== */
.site-footer{background:var(--verde);color:rgba(255,255,255,.72);padding:4rem 2rem 2rem}
.footer-inner{max-width:1280px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-logo img{height:66px;margin-bottom:1.1rem;filter:brightness(0) invert(1);opacity:.85}
.footer-logo p{font-size:.83rem;line-height:1.85}
.footer-col h4{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:400;color:#fff;letter-spacing:.04em;margin-bottom:1.1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.5rem}
.footer-col ul a{font-size:.82rem;transition:var(--t)}
.footer-col ul a:hover{color:#fff}
.footer-contact p{font-size:.84rem;margin-bottom:.65rem;display:flex;align-items:flex-start;gap:.5rem}
.f-socials{display:flex;gap:.9rem;margin-top:1.1rem}
.f-socials a{opacity:.55;transition:var(--t)}
.f-socials a:hover{opacity:1}
.f-socials svg{width:15px;height:15px;fill:#fff;display:block}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;font-size:.73rem;opacity:.45}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){.cards-grid{grid-template-columns:1fr 1fr}.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:768px){
  .header-inner{grid-template-columns:1fr auto;gap:1rem}
  .nav-left,.nav-right{display:none}
  .burger{display:flex}
  .page-hero{height:240px}
  .page-hero-content h1{font-size:2rem}
  .cards-grid{grid-template-columns:1fr}
  .room-layout,.contact-layout,.dove-layout{grid-template-columns:1fr}
  .svc-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:.7rem;text-align:center}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
