/* =============================================
   La Puritate – style.css
   Design: Coastal Chic · Glassmorphism · Forme Fluide
   Palette: #FDFBF7 sabbia · #0A2035 oceano · #2E8B8B acquamarina
   Fonts: Cormorant Garamond (titoli) + Montserrat (body)
   ============================================= */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --sand:#FDFBF7;--sand2:#F5F0E8;--sand3:#EDE5D8;
  --ocean:#0A2035;--ocean2:#0D2D4A;--ocean3:#1A3F5C;
  --teal:#2E8B8B;--teal2:#226969;--teal3:#C8E8E8;
  --gold:#B8860B;--gold2:#D4A017;
  --mist:rgba(255,255,255,.12);
}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--sand);color:var(--ocean);overflow-x:hidden}
a{text-decoration:none;color:inherit}
::selection{background:var(--teal);color:#fff}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--sand)}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:2px}

/* ── NAVBAR ── */
nav#navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(253,251,247,.75);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(46,139,139,.15);transition:all .4s}
nav#navbar.scrolled{background:rgba(253,251,247,.94);box-shadow:0 2px 32px rgba(10,32,53,.06)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 40px;height:72px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
.nav-links{display:flex;gap:36px}
.nav-links a{font-size:11px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--ocean3);transition:color .2s}
.nav-links a:hover{color:var(--teal)}
.nav-logo{text-align:center}
.nav-logo-text{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;letter-spacing:.15em;color:var(--ocean);font-style:italic}
.nav-logo-sub{font-size:9px;font-weight:300;letter-spacing:.35em;text-transform:uppercase;color:var(--teal);margin-top:2px}
.nav-right{display:flex;justify-content:flex-end}
.nav-cta{font-size:11px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--ocean);border:1px solid var(--teal);padding:9px 20px;border-radius:100px;transition:all .25s}
.nav-cta:hover{background:var(--teal);color:#fff;border-color:var(--teal)}
.ham{display:none;background:none;border:none;cursor:pointer;color:var(--ocean);flex-direction:column;gap:5px;padding:4px}
.ham span{display:block;width:22px;height:1px;background:currentColor;transition:all .3s}

/* ── MOBILE OVERLAY ── */
#mob{display:none;position:fixed;inset:0;background:var(--ocean);z-index:200;flex-direction:column;align-items:center;justify-content:center;gap:32px}
#mob.open{display:flex}
.mob-logo{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;font-style:italic;color:#fff;letter-spacing:.15em;margin-bottom:8px}
.mob-links{display:flex;flex-direction:column;align-items:center;gap:20px}
.mob-links a{font-size:14px;font-weight:300;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.6);transition:color .2s}
.mob-links a:hover{color:#fff}
.mob-close{position:absolute;top:28px;right:40px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.5);font-size:24px;line-height:1;font-family:'Montserrat',sans-serif;transition:color .2s}
.mob-close:hover{color:#fff}

/* ── HERO ── */
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--ocean)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,#0A1525 0%,#0D3050 40%,#0A4060 70%,#062030 100%)}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-texture{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(46,139,139,.25) 0%,transparent 60%),radial-gradient(ellipse at 70% 30%,rgba(184,134,11,.1) 0%,transparent 50%)}
.hero-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:rgba(255,255,255,.1)}
.hero-img-ph svg{width:56px;height:56px;stroke:currentColor;fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
.hero-img-ph span{font-size:11px;font-weight:300;letter-spacing:.2em;text-transform:uppercase}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,32,53,.3) 0%,rgba(10,32,53,.5) 50%,rgba(10,32,53,.8) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 40px;max-width:800px;margin:0 auto;width:100%}
.hero-pre{font-size:11px;font-weight:300;letter-spacing:.45em;text-transform:uppercase;color:rgba(200,232,232,.8);margin-bottom:28px;display:flex;align-items:center;justify-content:center;gap:14px}
.hero-pre::before,.hero-pre::after{content:'';width:32px;height:1px;background:var(--teal);opacity:.6}
.hero-h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,6vw,5.5rem);font-weight:300;font-style:italic;color:#fff;line-height:1.15;letter-spacing:.04em;margin-bottom:20px}
.hero-h1 em{font-style:normal;font-weight:400;color:var(--teal3)}
.hero-sub{font-size:14px;font-weight:200;letter-spacing:.18em;color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:40px}
.hero-btn{display:inline-block;font-size:11px;font-weight:400;letter-spacing:.25em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.4);padding:14px 36px;border-radius:100px;background:rgba(255,255,255,.08);backdrop-filter:blur(8px);transition:all .3s}
.hero-btn:hover{background:rgba(46,139,139,.4);border-color:var(--teal3)}
.scroll-ind{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.4);animation:bounce 2s ease-in-out infinite}
.scroll-ind svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.scroll-ind span{font-size:9px;font-weight:300;letter-spacing:.25em;text-transform:uppercase}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ── WAVE DIVIDERS ── */
.wave-divider{display:block;width:100%;margin-bottom:-2px}
.wave-ocean{margin-bottom:-2px;margin-top:0}
.wave-back{margin-top:-2px;margin-bottom:0}

/* ── PESCATO ── */
.pescato{background:var(--sand);padding:100px 40px}
.pescato-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.pescato-img{position:relative}
.pescato-img-frame{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,var(--ocean2),var(--ocean3));border-radius:60% 40% 55% 45% / 45% 55% 45% 55%;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:rgba(255,255,255,.2);border:1px solid rgba(46,139,139,.2);transition:border-radius .6s ease}
.pescato-img-frame:hover{border-radius:45% 55% 40% 60% / 55% 45% 55% 45%}
.pescato-img-frame img{width:100%;height:100%;object-fit:cover;display:block}
.pescato-img-frame svg{width:40px;height:40px;stroke:rgba(255,255,255,.3);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
.pescato-img-frame span{font-size:10px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;opacity:.4}
.pescato-img-badge{position:absolute;bottom:-20px;right:-20px;background:var(--ocean);color:#fff;border-radius:50%;width:100px;height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:3px solid var(--teal);font-size:10px;font-weight:300;letter-spacing:.15em;text-align:center;text-transform:uppercase;line-height:1.4}
.sect-pre{font-size:10px;font-weight:400;letter-spacing:.4em;text-transform:uppercase;color:var(--teal);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.sect-pre::before{content:'';width:20px;height:1px;background:var(--teal)}
.sect-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;font-style:italic;color:var(--ocean);line-height:1.15;letter-spacing:.03em;margin-bottom:24px}
.sect-title em{font-style:normal;font-weight:500;color:var(--teal2)}
.sect-body{font-size:14px;font-weight:300;color:var(--ocean3);line-height:1.9;margin-bottom:16px;letter-spacing:.02em}
.pescato-detail{display:flex;flex-direction:column;gap:16px;margin-top:32px;padding-top:32px;border-top:1px solid var(--sand3)}
.pd-item{display:flex;align-items:flex-start;gap:14px}
.pd-icon{width:36px;height:36px;border-radius:50%;border:1px solid var(--teal);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.pd-label{font-size:10px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--teal2);margin-bottom:3px}
.pd-val{font-size:13px;font-weight:300;color:var(--ocean3);line-height:1.5}

/* ── VERANDA ── */
.veranda{background:var(--ocean);padding:100px 40px;position:relative;overflow:hidden}
.veranda-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(46,139,139,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(184,134,11,.08) 0%,transparent 50%)}
.veranda-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.veranda-header{text-align:center;margin-bottom:64px}
.veranda-pre{justify-content:center;color:rgba(200,232,232,.7)}
.veranda-pre::before{background:rgba(200,232,232,.4)}
.veranda-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.5rem);font-weight:300;font-style:italic;color:#fff;line-height:1.15;margin-bottom:12px}
.veranda-title em{font-style:normal;color:var(--teal3)}
.veranda-sub{font-size:13px;font-weight:200;letter-spacing:.15em;color:rgba(255,255,255,.5);line-height:1.8}
.glass-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.glass-card{background:rgba(255,255,255,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:40px 32px;transition:all .3s;position:relative;overflow:hidden}
.glass-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}
.glass-card:hover{background:rgba(255,255,255,.12);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.gc-num{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:300;color:rgba(46,139,139,.3);line-height:1;margin-bottom:20px}
.gc-title{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;font-style:italic;color:#fff;margin-bottom:12px}
.gc-desc{font-size:13px;font-weight:200;letter-spacing:.05em;color:rgba(255,255,255,.55);line-height:1.85}
.gc-items{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}
.gc-item{font-size:12px;font-weight:300;letter-spacing:.08em;color:rgba(200,232,232,.7);display:flex;align-items:center;gap:8px}
.gc-item::before{content:'';width:4px;height:4px;background:var(--teal);border-radius:50%;flex-shrink:0}

/* ── PRENOTAZIONE ── */
.prenota{background:var(--sand);padding:100px 40px}
.prenota-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.pf-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;font-style:italic;color:var(--ocean);margin-bottom:8px}
.pf-sub{font-size:13px;font-weight:200;letter-spacing:.1em;color:var(--ocean3);line-height:1.7;margin-bottom:36px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:0 32px}
.fgroup{display:flex;flex-direction:column;margin-bottom:28px}
.fgroup.full{grid-column:1/-1}
.fgroup label{font-size:10px;font-weight:400;letter-spacing:.25em;text-transform:uppercase;color:var(--teal2);margin-bottom:8px}
.fgroup input,.fgroup select,.fgroup textarea{background:transparent;border:none;border-bottom:1px solid var(--sand3);color:var(--ocean);font-family:'Montserrat',sans-serif;font-size:14px;font-weight:300;padding:8px 0;outline:none;transition:border-color .2s;appearance:none;border-radius:0}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus{border-bottom-color:var(--teal)}
.fgroup input::placeholder,.fgroup textarea::placeholder{color:var(--sand3);font-style:italic}
.fgroup textarea{resize:none;height:80px}
.fgroup select option{background:var(--sand)}
.form-btn{background:var(--ocean);color:#fff;border:none;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:400;letter-spacing:.25em;text-transform:uppercase;padding:16px 40px;border-radius:100px;cursor:pointer;transition:all .25s;margin-top:8px}
.form-btn:hover{background:var(--teal);transform:translateY(-1px)}
.form-btn:disabled{opacity:.6;cursor:not-allowed}
.f-ok{display:none;background:rgba(46,139,139,.1);border:1px solid rgba(46,139,139,.3);color:var(--teal2);font-size:13px;padding:12px;text-align:center;border-radius:8px;margin-top:12px;letter-spacing:.05em}
.contact-info{display:flex;flex-direction:column;gap:28px;padding-top:72px}
.ci-pre{font-size:10px;font-weight:400;letter-spacing:.35em;text-transform:uppercase;color:var(--teal);margin-bottom:8px}
.ci-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:300;font-style:italic;color:var(--ocean);margin-bottom:28px}
.ci-item{display:flex;align-items:flex-start;gap:16px}
.ci-icon{width:40px;height:40px;border-radius:50%;border:1px solid var(--sand3);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--teal)}
.ci-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.ci-label{font-size:10px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--teal2);margin-bottom:3px}
.ci-val{font-size:14px;font-weight:300;color:var(--ocean);line-height:1.6}
.ci-val a{color:inherit;transition:color .2s}
.ci-val a:hover{color:var(--teal)}
.orari-note{font-size:12px;color:var(--teal2)}
.map-wrap{margin-top:32px;border-radius:20px;overflow:hidden;border:1px solid var(--sand3);height:200px}
.map-wrap iframe{width:100%;height:100%;display:block;border:none;filter:grayscale(60%) sepia(20%) hue-rotate(180deg) brightness(.9)}

/* ── FOOTER ── */
footer{background:var(--ocean);padding:80px 40px 40px;position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(46,139,139,.4),transparent)}
.foot-inner{max-width:1200px;margin:0 auto}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;margin-bottom:60px}
.foot-logo-text{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:300;font-style:italic;color:#fff;letter-spacing:.15em;margin-bottom:6px}
.foot-logo-sub{font-size:9px;font-weight:300;letter-spacing:.4em;text-transform:uppercase;color:var(--teal);margin-bottom:20px}
.foot-desc{font-size:13px;font-weight:200;color:rgba(255,255,255,.4);line-height:1.8;max-width:280px}
.foot-col-title{font-size:10px;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px}
.foot-links{display:flex;flex-direction:column;gap:10px}
.foot-links a{font-size:13px;font-weight:200;letter-spacing:.05em;color:rgba(255,255,255,.5);transition:color .2s}
.foot-links a:hover{color:#fff}
.foot-closing{text-align:center;padding:40px 0 20px;border-top:1px solid rgba(255,255,255,.06)}
.foot-closing-text{font-family:'Cormorant Garamond',serif;font-size:clamp(1.2rem,3vw,2rem);font-weight:300;font-style:italic;color:rgba(255,255,255,.5);letter-spacing:.08em}
.foot-closing-text em{font-style:normal;color:rgba(200,232,232,.6)}
.foot-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;padding-top:20px}
.foot-copy{font-size:11px;font-weight:200;color:rgba(255,255,255,.2);letter-spacing:.05em}
.foot-legal{display:flex;gap:16px}
.foot-legal a{font-size:11px;font-weight:200;color:rgba(255,255,255,.2);transition:color .2s}
.foot-legal a:hover{color:rgba(255,255,255,.6)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .nav-links,.nav-right{display:none}
  .ham{display:flex}
  .nav-inner{grid-template-columns:auto 1fr;padding:0 24px}
  .nav-logo{text-align:left}
  .pescato{padding:64px 24px}
  .pescato-inner{grid-template-columns:1fr;gap:48px}
  .pescato-img-badge{right:-8px;bottom:-8px;width:80px;height:80px;font-size:9px}
  .veranda{padding:64px 24px}
  .glass-grid{grid-template-columns:1fr}
  .prenota{padding:64px 24px}
  .prenota-inner{grid-template-columns:1fr;gap:48px}
  .frow{grid-template-columns:1fr}
  .contact-info{padding-top:0}
  .foot-top{grid-template-columns:1fr;gap:32px}
  footer{padding:56px 24px 32px}
  .mob-close{right:24px}
}
@media(max-width:480px){
  .hero-content{padding:0 24px}
  .hero-h1{font-size:2.4rem}
  .glass-card{padding:28px 22px}
}
