
:root{
  --green:#203f2c;--green2:#2e5c42;--cream:#f3eee4;--white:#fff;
  --dark:#111827;--muted:#5f6b7a;--blue:#071b3a;--blue2:#0c3c72;
  --shadow:0 22px 55px rgba(5,19,41,.14);--radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--cream);color:var(--dark);line-height:1.6}
a{color:inherit}
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid rgba(15,23,42,.08)}
.nav{max-width:1240px;margin:auto;padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;text-decoration:none}
.logo-mark{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,var(--green),#6fb987);display:grid;place-items:center;color:white;font-weight:950}
.menu{display:flex;gap:18px;font-size:14px;font-weight:800;color:#334155;align-items:center}
.menu a{text-decoration:none}.menu a:hover{color:var(--green)}
.lang{display:flex;gap:6px}.lang button{border:1px solid #dbe3ed;background:white;border-radius:999px;padding:8px 10px;font-weight:900;cursor:pointer}.lang button.active{background:var(--green);color:white}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;border:none;background:#62ce70;color:white;padding:13px 22px;border-radius:999px;font-weight:900;box-shadow:0 12px 25px rgba(35,121,69,.22);transition:.2s;cursor:pointer}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn-dark{background:#1f3c2b;color:white}
.btn-outline{background:transparent;color:var(--green);border:2px solid var(--green);box-shadow:none}
.btn-light{background:white;color:var(--green);box-shadow:none}
.hero{
  min-height:92vh;
  padding:96px 32px 70px;
  display:flex;
  align-items:center;
  color:white;
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center;
}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,13,31,.78),rgba(3,13,31,.42),rgba(3,13,31,.12))}
.hero-inner{position:relative;z-index:2;max-width:1240px;margin:auto;width:100%}
.hero-logo-img{width:min(470px,46vw);max-width:92%;display:block;margin-bottom:28px;border-radius:0}
.badge{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.34);padding:10px 18px;border-radius:999px;font-size:17px;font-weight:900;margin-bottom:20px}
.hero h1{font-size:clamp(46px,7vw,90px);line-height:.98;margin:0 0 18px;letter-spacing:-2px;font-weight:950}
.hero h2{font-size:clamp(24px,3.2vw,42px);margin:0 0 18px;font-weight:900;color:#f8fafc}
.hero p{max-width:830px;font-size:22px;margin:0 0 28px;color:#f8fafc}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
section{padding:82px 22px}.container{max-width:1240px;margin:auto}
.eyebrow{color:var(--green);text-transform:uppercase;letter-spacing:2px;font-weight:900;font-size:13px}
h3{font-size:clamp(31px,4vw,48px);line-height:1.08;margin:8px 0 14px}.lead{font-size:18px;color:var(--muted);max-width:860px}
.intro-professional{background:var(--cream)}
.intro-grid{max-width:1240px;margin:auto;display:grid;grid-template-columns:1fr .82fr;gap:44px;align-items:center}
.intro-grid img{width:100%;height:auto;max-height:620px;border-radius:28px;object-fit:contain;background:#eee;box-shadow:var(--shadow)}
.intro-panel{background:white;border-radius:30px;padding:46px;box-shadow:var(--shadow)}
.intro-panel h3{margin-top:0}
.solution-horizontal{background:#f3eee4}
.solution-list{display:grid;gap:22px;margin-top:30px}
.solution-row{display:grid;grid-template-columns:260px 1fr 1fr;gap:0;background:white;border-radius:28px;overflow:hidden;box-shadow:0 16px 40px rgba(15,23,42,.08);border:1px solid #e7ddcf}
.solution-title{background:var(--green);color:white;padding:28px;font-size:25px;font-weight:950;display:flex;align-items:center}
.solution-cell{padding:28px;border-left:1px solid #e7ddcf}.solution-cell strong{display:block;color:#111827;margin-bottom:8px}
.emotional-green{background:var(--green);color:white}.emotional-green .eyebrow{color:#b8e0c6}.emotional-green .lead{color:#e8f3eb}
.emotional-layout{display:grid;grid-template-columns:1.35fr .75fr;gap:24px;align-items:stretch;margin-top:30px}
.emotional-main,.emotional-side{display:grid;gap:24px}
.emotional-layout img{width:100%;height:100%;min-height:250px;object-fit:cover;border-radius:24px;box-shadow:0 18px 42px rgba(0,0,0,.20)}
.emotional-main img{min-height:610px}
.formula{background:white}.formula-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.formula-card{position:relative;overflow:hidden;border-radius:32px;min-height:370px;color:white;box-shadow:var(--shadow);display:flex;align-items:flex-end}.formula-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.formula-card:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(2,8,23,.82),rgba(2,8,23,.15))}.formula-card div{position:relative;z-index:2;padding:28px}.formula-card h4{font-size:28px;margin:0 0 8px}
.services{background:linear-gradient(135deg,#edf8ff,#fff7e8)}.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.service{background:rgba(255,255,255,.9);border:1px solid #e8ddca;border-radius:20px;padding:18px;display:flex;gap:12px;align-items:center;font-weight:850}.icon{font-size:25px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#e6f4ff;border-radius:15px}
.gallery-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 28px}.tab-label{background:white;border:1px solid #e6dccd;border-radius:999px;padding:10px 15px;font-weight:900;color:#334155;cursor:pointer}.tab-label.active{background:var(--green);color:white}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.gitem{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 12px 30px rgba(15,23,42,.13);background:#fff;min-height:260px;cursor:zoom-in;display:flex;align-items:center;justify-content:center;padding:8px}
.gitem img{width:100%;height:100%;object-fit:contain;display:block;border-radius:18px;background:#f4f0e8;transition:.25s}.gitem:hover img{transform:scale(1.02)}.caption{position:absolute;left:8px;right:8px;bottom:8px;padding:26px 14px 12px;color:white;font-weight:900;background:linear-gradient(0deg,rgba(0,0,0,.70),rgba(0,0,0,0));border-radius:0 0 18px 18px;pointer-events:none}
.all-gallery-note{color:#64748b;font-weight:800;margin-top:8px}
.sea{background:linear-gradient(90deg,rgba(7,27,58,.92),rgba(7,27,58,.55)),url('../images/06-spiaggia/01-spiaggia.webp') center/cover no-repeat;color:white}.sea .lead{color:#eaf7ff}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px}.contact-list{display:grid;gap:14px}.contact-item{background:white;padding:18px;border-radius:18px;border:1px solid #eee1cf;font-weight:800}
.map-wrap{margin-top:24px}.map-wrap iframe{width:100%;height:430px;border:0;border-radius:28px;box-shadow:var(--shadow)}
.coast-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.coast-card{background:white;border-radius:30px;overflow:hidden;box-shadow:var(--shadow)}.coast-card img{width:100%;height:300px;object-fit:cover}.coast-card div{padding:24px}.distance{display:inline-block;margin-bottom:8px;background:#eaf7ff;color:#0c3c72;padding:7px 12px;border-radius:999px;font-weight:900;font-size:13px}
.lightbox{position:fixed;inset:0;z-index:999;background:rgba(2,8,23,.94);display:none;align-items:center;justify-content:center;padding:28px}.lightbox.open{display:flex}.lightbox img{max-width:94vw;max-height:88vh;object-fit:contain;border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.55);background:white}.lightbox .close{position:absolute;right:22px;top:18px;background:white;color:#071b3a;border:none;border-radius:999px;padding:12px 18px;font-weight:900;cursor:pointer}
.fixed-whatsapp{position:fixed;right:18px;bottom:18px;z-index:60;background:#62ce70;color:white;width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;text-decoration:none;box-shadow:0 15px 30px rgba(0,0,0,.25)}
footer{background:#06152e;color:#dbeafe;padding:30px 22px;font-size:14px}footer .container{display:flex;justify-content:space-between;gap:22px;flex-wrap:wrap;align-items:center}
@media(max-width:950px){.menu{display:none}.intro-grid,.emotional-layout,.contact-grid,.solution-row{grid-template-columns:1fr}.formula-grid,.coast-grid{grid-template-columns:1fr}.cards,.service-grid,.gallery{grid-template-columns:1fr 1fr}.hero-logo-img{width:360px}.hero{min-height:86vh}.solution-cell{border-left:0;border-top:1px solid #e7ddcf}.emotional-main img{min-height:420px}}
@media(max-width:620px){.service-grid,.gallery{grid-template-columns:1fr}.gitem{min-height:280px}.hero{padding:82px 18px 56px}.hero-logo-img{width:280px}.badge{font-size:14px}.hero p{font-size:18px}.intro-panel{padding:28px}}

/* ULTIMI AGGIUSTAMENTI */
.hero{
  background-position:center !important;
}
.hero-logo-img{
  width:min(470px,46vw);
  max-width:92%;
  margin-bottom:28px;
}
.hero h1.removed-title{
  display:none !important;
}
.hero h2{
  font-size:clamp(42px,6vw,82px) !important;
  line-height:1.02;
  max-width:1200px;
  margin-top:18px;
}
.hero p{
  font-size:22px;
  max-width:850px;
}
.gitem{
  min-height:260px;
  padding:8px;
  background:#fff;
}
.gitem img{
  object-fit:contain !important;
  background:#f4f0e8;
}
.caption{
  display:none !important;
}
.contact-list{
  gap:10px !important;
}
.contact-item{
  padding:12px 15px !important;
  border-radius:14px !important;
  font-size:15px !important;
  line-height:1.35 !important;
}
.contact-grid{
  align-items:start;
}
.intro-panel .btn{
  min-width:210px;
}
@media(max-width:620px){
  .hero h2{font-size:clamp(34px,11vw,50px) !important}
  .hero-logo-img{width:260px}
}

.formula-card{text-decoration:none;color:white}
.formula-card:hover{transform:translateY(-3px)}


/* Aggiornamenti richiesti: contatore a fondo pagina e servizio non fumatori */
.visit-counter {
    position: static !important;
    display: block;
    text-align: right;
    margin-top: 8px;
    font-size: 13px;
    opacity: 0.9;
}
.no-smoking-service {
    text-align: center;
}
.no-smoking-service .service-icon,
.no-smoking-service i {
    font-size: 30px;
    margin-bottom: 10px;
}
