
:root{
  --bg:#071522;
  --bg-soft:#0c2233;
  --card:rgba(255,255,255,.08);
  --text:#f8fbff;
  --muted:#d5e2ec;
  --line:rgba(255,255,255,.12);
  --accent:#b9e7ff;
  --accent-2:#f8ead2;
  --wave:#7ad7ff;
  --btn:#f3e2c2;
  --shadow:0 20px 60px rgba(0,0,0,.28);
  --radius:24px;
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(122,215,255,.14), transparent 30%),
    radial-gradient(circle at 80% 20%, rgba(248,234,210,.10), transparent 24%),
    linear-gradient(180deg,#071522 0%, #0a1b2b 38%, #0b2032 100%);
  line-height:1.6;
  overflow-x:hidden;
}
a{color:inherit}
img{display:block;max-width:100%}
.container{width:min(var(--container), calc(100% - 32px));margin-inline:auto}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:12px;top:12px;background:#fff;color:#000;padding:10px 14px;border-radius:8px;z-index:100}
.sea-top{
  position:fixed;top:0;left:0;right:0;height:6px;z-index:90;
  background:linear-gradient(90deg, rgba(122,215,255,.6), rgba(255,255,255,.7), rgba(122,215,255,.6));
  animation:tide 6s linear infinite;
}
@keyframes tide{0%{transform:translateX(-20%)}50%{transform:translateX(20%)}100%{transform:translateX(-20%)}}
.site-header{
  position:sticky;top:0;z-index:80;background:rgba(6,16,27,.68);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.nav{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:800;letter-spacing:.02em}
.brand-mark{
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(122,215,255,.28), rgba(248,234,210,.28));
  border:1px solid rgba(255,255,255,.16);font-size:.82rem;
}
.menu{display:flex;gap:22px;align-items:center}
.menu a{text-decoration:none;color:var(--muted)}
.menu a:hover{color:#fff}
.nav-actions{display:flex;gap:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:52px;padding:0 22px;border-radius:999px;
  text-decoration:none;font-weight:800;border:1px solid transparent;background:linear-gradient(135deg, var(--btn), #fff1d7);
  color:#132131;box-shadow:var(--shadow);transition:transform .2s ease, filter .2s ease;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.03)}
.btn-secondary,.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.16);box-shadow:none}
.btn-small{min-height:44px;padding:0 18px}
.hero{
  position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(90deg, rgba(5,14,24,.82) 0%, rgba(5,14,24,.60) 48%, rgba(5,14,24,.28) 100%), url("assets/vista-tavolo-mare.jpg") center/cover no-repeat;
}
.hero-water{
  position:absolute;inset:auto -10% 0 -10%;height:120px;
  background:radial-gradient(circle at 20% 40%, rgba(122,215,255,.20), transparent 22%), radial-gradient(circle at 60% 60%, rgba(255,255,255,.10), transparent 18%), radial-gradient(circle at 80% 35%, rgba(122,215,255,.16), transparent 22%);
  filter:blur(12px);animation:drift 10s ease-in-out infinite;
}
@keyframes drift{0%,100%{transform:translateX(0)}50%{transform:translateX(30px)}}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.72fr);gap:30px;align-items:center;padding:76px 0}
.eyebrow{margin:0 0 12px;color:var(--accent);font-weight:900;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem}
.hero h1{margin:0;font-size:clamp(2.5rem, 5vw, 5rem);line-height:1.02;max-width:11ch}
.lead{font-size:1.08rem;color:#eef7ff;max-width:62ch;margin-top:18px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.hero-points{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:10px}
.hero-points li{position:relative;padding-left:28px;color:#eef7ff}
.hero-points li::before{content:"";position:absolute;left:0;top:.56em;width:12px;height:12px;border-radius:50%;background:var(--wave);box-shadow:0 0 0 6px rgba(122,215,255,.12)}
.hero-card{justify-self:end;width:min(100%,420px)}
.hero-card-inner{background:linear-gradient(180deg, rgba(10,31,47,.86), rgba(14,38,56,.92));border:1px solid rgba(255,255,255,.14);border-radius:28px;padding:28px;box-shadow:var(--shadow)}
.rating-line{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px;font-size:1rem}
.rating-line span{color:var(--muted)}
.mini-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:18px}
.mini-actions a{text-decoration:none;color:var(--accent-2);font-weight:700}
.stats-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(9,25,39,.72)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:22px 0}
.stat{text-align:center}
.stat-number{display:block;font-size:1.28rem;font-weight:800}
.stat-label{color:var(--muted);font-size:.95rem}
.section{padding:92px 0}
.section-soft{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.04))}
.section-dark{background:linear-gradient(180deg, rgba(7,21,34,.88), rgba(9,29,45,.98))}
.split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:36px;align-items:center}
.text-block h2,.section-heading h2,.instagram-box h2,.place-intro h2,.final-cta-box h2,.marine-band h2{margin:0 0 14px;font-size:clamp(1.8rem,3vw,3rem);line-height:1.1}
.text-block p,.section-heading p,.instagram-box p,.place-intro p,.marine-band p{color:var(--muted)}
.feature-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:26px}
.feature-card,.contact-card,.review-card,.gallery-card,.instagram-box,.place-card,.final-cta-box,.marine-band{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow)}
.feature-card,.place-card{padding:18px}
.feature-card h3,.place-card h3{margin:0 0 8px}
.feature-card p,.place-card p{margin:0;color:var(--muted)}
.image-stack img{min-height:540px;object-fit:cover;border-radius:24px;border:1px solid var(--line);box-shadow:var(--shadow)}
.marine-band{padding:28px;display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;background:linear-gradient(135deg, rgba(122,215,255,.10), rgba(248,234,210,.10))}
.wave-icon{font-size:2rem;color:var(--accent);letter-spacing:.2em;animation:swell 3.8s ease-in-out infinite}
@keyframes swell{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.section-heading{max-width:760px;margin:0 auto 34px;text-align:center}
.gallery-grid{display:grid;grid-template-columns:1.25fr .9fr .9fr;gap:18px}
.gallery-card{overflow:hidden}
.gallery-card img{width:100%;height:100%;min-height:260px;object-fit:cover;transition:transform .5s ease}
.gallery-card:hover img{transform:scale(1.04)}
.gallery-card figcaption{padding:14px 16px 18px;color:var(--muted)}
.gallery-large{grid-row:span 2}
.contact-card{padding:22px;margin:22px 0 0}
.contact-card p{margin:0 0 10px}
.contact-card p:last-child{margin-bottom:0}
.contact-card a{color:var(--accent-2);text-decoration:none}
.map-card iframe{width:100%;min-height:520px;border:0;border-radius:24px;box-shadow:var(--shadow)}
.reviews-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:18px;margin-top:28px}
.review-card{padding:26px}
.review-card p{color:#eef7ff;margin:.4rem 0 .7rem}
.review-card span{color:var(--muted);font-size:.95rem}
.stars{color:var(--accent-2);letter-spacing:.16em}
.review-cta{margin-top:28px;padding:24px;border-radius:26px;background:var(--card);border:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px}
.review-cta p{margin:0;color:var(--muted)}
.review-cta h3{margin:0 0 8px}
.instagram-box{padding:28px;display:flex;justify-content:space-between;align-items:center;gap:24px}
.instagram-actions{display:flex;gap:12px}
.place-section{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start}
.place-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.final-cta{padding-top:0}
.final-cta-box{padding:32px;display:flex;justify-content:space-between;align-items:center;gap:24px;background:linear-gradient(135deg, rgba(122,215,255,.12), rgba(248,234,210,.10))}
.final-actions{display:flex;flex-wrap:wrap;gap:14px}
.site-footer{border-top:1px solid var(--line);background:rgba(5,14,24,.76);padding:28px 0 42px}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:24px}
.footer-grid p{margin:.35rem 0;color:var(--muted)}
.footer-grid a{color:var(--accent-2);text-decoration:none}
.footer-brand{font-weight:800;font-size:1.05rem}
.whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:70;display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:999px;background:#25D366;color:#fff;text-decoration:none;font-weight:800;box-shadow:0 18px 40px rgba(0,0,0,.28)}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
.reveal.visible{opacity:1;transform:none}
@media (max-width:1180px){.menu{display:none}}
@media (max-width:1080px){
  .hero-grid,.split,.place-section,.footer-grid{grid-template-columns:1fr}
  .hero-card{justify-self:start;width:100%}
  .feature-list{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-large{grid-row:auto;grid-column:1 / -1}
  .reviews-grid{grid-template-columns:1fr}
  .review-cta,.instagram-box,.final-cta-box{flex-direction:column;align-items:flex-start}
  .stats-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:700px){
  .container{width:min(var(--container), calc(100% - 20px))}
  .nav{min-height:74px}
  .hero{min-height:auto}
  .hero-grid{padding:56px 0}
  .hero h1{max-width:none}
  .hero-actions,.nav-actions,.instagram-actions{flex-direction:column;align-items:stretch}
  .btn{width:100%}
  .stats-grid,.gallery-grid,.place-grid{grid-template-columns:1fr}
  .section{padding:72px 0}
  .image-stack img,.map-card iframe{min-height:340px}
  .whatsapp-float{right:12px;bottom:12px;padding:14px 16px}
  .whatsapp-text{display:none}
}
