/* ============ AmberDock — porto notturno & ambra ============ */
:root{
  --night:#0D1622;        /* notte di porto */
  --night-2:#13202F;      /* acqua profonda */
  --line:#283A50;         /* cime d'ormeggio */
  --amber:#E9A23B;        /* faro */
  --amber-2:#F6C66D;      /* riflesso */
  --sand:#FBF6EC;         /* banchina */
  --ink:#16202E;          /* inchiostro */
  --steel:#5F6E80;        /* acciaio */
  --steel-light:#9FB0C3;
  --radius:14px;
  --display:'Bricolage Grotesque', sans-serif;
  --body:'Albert Sans', sans-serif;
  --mono:'IBM Plex Mono', monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:var(--body);
  background:var(--night);
  color:var(--sand);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--amber-2)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--amber);outline-offset:2px;border-radius:4px;
}

/* ---------- bottoni ---------- */
.btn{
  display:inline-block;padding:.8rem 1.5rem;border-radius:999px;
  font-weight:700;text-decoration:none;border:2px solid transparent;
  font-size:.95rem;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-amber{background:var(--amber);color:var(--night);box-shadow:0 6px 24px rgba(233,162,59,.35)}
.btn-amber:hover{background:var(--amber-2)}
.btn-ghost{border-color:var(--line);color:var(--sand)}
.btn-ghost-light{border-color:var(--steel-light);color:var(--sand);background:transparent}
.btn-dark{background:var(--ink);color:var(--sand)}
.btn-wide{width:100%;text-align:center}

/* ---------- topbar ---------- */
.topbar{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:1.5rem;
  padding:.9rem clamp(1rem,4vw,3rem);
  background:rgba(13,22,34,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--sand);
  font-family:var(--display);font-size:1.25rem;letter-spacing:.01em}
.brand strong{color:var(--amber)}
.brand-mark{width:30px;height:30px}
.nav{display:flex;gap:1.4rem;margin-left:auto}
.nav a{color:var(--steel-light);text-decoration:none;font-size:.95rem}
.nav a:hover{color:var(--amber-2)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{width:24px;height:2px;background:var(--sand);display:block}

/* ---------- hero ---------- */
.hero{
  display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;
  padding:clamp(3rem,8vw,6rem) clamp(1rem,4vw,3rem);
  max-width:1240px;margin:0 auto;
}
.kicker{font-family:var(--mono);font-size:.8rem;letter-spacing:.12em;color:var(--steel-light);
  display:flex;align-items:center;gap:.55rem;margin-bottom:1.2rem}
.beacon{width:10px;height:10px;border-radius:50%;background:var(--amber);
  box-shadow:0 0 0 0 rgba(233,162,59,.7);animation:pulse 2.2s infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(233,162,59,.6)}
  70%{box-shadow:0 0 0 12px rgba(233,162,59,0)}
  100%{box-shadow:0 0 0 0 rgba(233,162,59,0)}
}
h1{font-family:var(--display);font-weight:800;font-size:clamp(2.1rem,5vw,3.4rem);
  line-height:1.08;letter-spacing:-.015em;margin-bottom:1.2rem}
.lede{color:var(--steel-light);font-size:1.1rem;max-width:34rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin:1.8rem 0 2.4rem}
.hero-stats{display:flex;gap:2.4rem;flex-wrap:wrap}
.hero-stats dt{font-family:var(--display);font-weight:800;font-size:1.7rem;color:var(--amber)}
.hero-stats dd{color:var(--steel);font-size:.85rem;max-width:9.5rem}

.hero-panel{
  background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:0 30px 60px rgba(0,0,0,.45);
}
.panel-head{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-bottom:1px solid var(--line)}
.panel-head .dot{width:9px;height:9px;border-radius:50%;background:var(--line)}
.panel-head .dot:first-child{background:var(--amber)}
.panel-title{margin-left:auto;font-family:var(--mono);font-size:.7rem;color:var(--steel)}
.harbor-svg{width:100%;display:block}
.berth circle{animation:glow 3s ease-in-out infinite}
.berth.b2 circle{animation-delay:.8s}
.berth.b3 circle{animation-delay:1.6s}
@keyframes glow{0%,100%{opacity:1}50%{opacity:.45}}

/* ---------- strip ---------- */
.strip{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.1rem clamp(1rem,4vw,3rem);display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;
  background:var(--night-2);
}
.strip p{font-family:var(--mono);font-size:.75rem;color:var(--steel);letter-spacing:.1em;text-transform:uppercase}
.strip ul{display:flex;gap:1.6rem;flex-wrap:wrap;list-style:none}
.strip li{color:var(--steel-light);font-weight:500;font-size:.95rem}

/* ---------- sezioni ---------- */
.section{padding:clamp(3.5rem,8vw,6rem) clamp(1rem,4vw,3rem)}
.section-light{background:var(--sand);color:var(--ink)}
.section-light a{color:#A2691B}
.section-dark{background:var(--night);color:var(--sand)}
.section-head{max-width:760px;margin:0 auto 3rem;text-align:center}
.section-head p:not(.eyebrow){color:inherit;opacity:.78}
.eyebrow{font-family:var(--mono);font-size:.78rem;letter-spacing:.18em;color:var(--amber);margin-bottom:.8rem}
.section-light .eyebrow{color:#B47318}
h2{font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,3.6vw,2.5rem);line-height:1.15;margin-bottom:1rem;letter-spacing:-.01em}
h3{font-family:var(--display);font-weight:600;font-size:1.25rem;margin:.6rem 0 .4rem}

/* ---------- banchine (servizi) ---------- */
.berths{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.6rem;
  max-width:1240px;margin:0 auto;
}
.berth-card{
  background:#fff;border:1px solid #E7DCC6;border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 8px 24px rgba(22,32,46,.07);
  border-top:4px solid var(--amber);
  transition:transform .18s ease, box-shadow .18s ease;
}
.berth-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(22,32,46,.13)}
.berth-card img{aspect-ratio:3/2;object-fit:cover}
.berth-card h3, .berth-card > p, .berth-card .card-link{padding-inline:1.2rem}
.berth-card > p:not(.berth-code){color:var(--steel);font-size:.95rem;flex:1}
.berth-code{font-family:var(--mono);font-size:.75rem;letter-spacing:.15em;color:#B47318;
  padding:.7rem 1.2rem .5rem}
.card-link{display:block;padding-block:1rem 1.2rem;font-weight:700;text-decoration:none}
.card-link:hover{text-decoration:underline}

/* ---------- rotta ---------- */
.route{
  list-style:none;max-width:980px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1.4rem;
  counter-reset:rotta;
}
.route li{
  background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.5rem;position:relative;
}
.route li::after{
  content:"→";position:absolute;right:-1.15rem;top:50%;transform:translateY(-50%);
  color:var(--amber);font-size:1.2rem;
}
.route li:last-child::after{content:none}
.route-code{font-family:var(--mono);font-size:.75rem;color:var(--amber);letter-spacing:.15em}
.route p{color:var(--steel-light);font-size:.92rem}

/* ---------- split (plancia / contatti) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1240px;margin:0 auto;align-items:start}
.split-copy > p{margin-bottom:1rem}
.checks{list-style:none;margin:1.2rem 0 1.8rem;display:grid;gap:.7rem}
.checks li{padding-left:1.8rem;position:relative}
.checks li::before{content:"✓";position:absolute;left:0;color:#B47318;font-weight:700}
.split-media img{border-radius:var(--radius);box-shadow:0 20px 50px rgba(22,32,46,.2)}
.split-media figcaption{font-family:var(--mono);font-size:.75rem;color:var(--steel);margin-top:.7rem}

/* ---------- tariffe ---------- */
.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.6rem;max-width:1180px;margin:0 auto}
.plan{
  background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.7rem;display:flex;flex-direction:column;position:relative;
}
.plan-featured{border-color:var(--amber);box-shadow:0 0 0 1px var(--amber),0 24px 50px rgba(233,162,59,.12)}
.plan-badge{
  position:absolute;top:-0.8rem;left:50%;transform:translateX(-50%);
  background:var(--amber);color:var(--night);font-family:var(--mono);font-size:.68rem;
  letter-spacing:.14em;padding:.25rem .8rem;border-radius:999px;font-weight:600;
}
.plan-code{font-family:var(--mono);font-size:.78rem;letter-spacing:.16em;color:var(--steel-light)}
.plan-price{font-family:var(--display);font-weight:800;font-size:2.1rem;color:var(--amber-2);margin:.6rem 0 1.2rem}
.plan-price span{font-family:var(--body);font-weight:400;font-size:.85rem;color:var(--steel-light)}
.plan ul{list-style:none;display:grid;gap:.65rem;margin-bottom:1.8rem;flex:1}
.plan li{padding-left:1.5rem;position:relative;color:var(--steel-light);font-size:.93rem}
.plan li::before{content:"⚓";position:absolute;left:0;font-size:.75rem;color:var(--amber)}
.plans-note{max-width:760px;margin:2.4rem auto 0;text-align:center;color:var(--steel-light);font-size:.95rem}

/* ---------- faq ---------- */
.faq{max-width:760px;margin:0 auto;display:grid;gap:.9rem}
.faq details{background:#fff;border:1px solid #E7DCC6;border-radius:var(--radius);padding:1.1rem 1.4rem}
.faq summary{font-weight:700;cursor:pointer;font-family:var(--display);font-size:1.02rem}
.faq details[open] summary{color:#B47318}
.faq details p{margin-top:.7rem;color:var(--steel)}

/* ---------- contatti ---------- */
.contact-card{font-style:normal;background:var(--night-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.5rem;display:grid;gap:.8rem;margin-top:1.6rem}
.contact-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;color:var(--steel);
  display:block;margin-bottom:.1rem}
.contact-form{background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;display:grid;gap:1.1rem}
.field{display:grid;gap:.4rem}
.field label{font-size:.88rem;font-weight:500;color:var(--steel-light)}
input,select,textarea{
  width:100%;padding:.75rem .9rem;border-radius:9px;border:1px solid var(--line);
  background:var(--night);color:var(--sand);font-family:var(--body);font-size:.95rem;
}
input::placeholder,textarea::placeholder{color:#46566B}
input.invalid,textarea.invalid{border-color:#D86B5A}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.85rem;color:var(--steel-light)}
.consent input{width:auto;margin-top:.25rem}
.form-status{font-family:var(--mono);font-size:.85rem;min-height:1.3em}
.form-status.ok{color:var(--amber-2)}
.form-status.err{color:#E58E80}

/* ---------- footer ---------- */
.footer{background:#0A111B;border-top:1px solid var(--line);padding:3.5rem clamp(1rem,4vw,3rem) 2rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2.2rem;max-width:1240px;margin:0 auto 2.4rem}
.footer-brand{font-family:var(--display);font-size:1.35rem}
.footer-brand strong{color:var(--amber)}
.footer p{color:var(--steel);font-size:.92rem}
.footer-title{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--steel-light);margin-bottom:.8rem}
.footer nav{display:grid;gap:.5rem}
.footer nav a{color:var(--steel);text-decoration:none;font-size:.92rem}
.footer nav a:hover{color:var(--amber-2)}
.footer-legal{text-align:center;color:#3D4C5F;font-size:.8rem;border-top:1px solid var(--line);
  padding-top:1.6rem;max-width:1240px;margin:0 auto}

/* ---------- cookie banner ---------- */
.cookie-banner{
  position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);
  width:min(680px,calc(100% - 2rem));z-index:90;
  background:var(--night-2);border:1px solid var(--amber);border-radius:var(--radius);
  padding:1.3rem 1.5rem;box-shadow:0 24px 60px rgba(0,0,0,.55);
  display:grid;gap:1rem;
}
.cookie-banner p{font-size:.9rem;color:var(--steel-light)}
.cookie-actions{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:flex-end}

/* ---------- pagine legali ---------- */
.legal-page{max-width:820px;margin:0 auto;padding:clamp(2.5rem,6vw,4.5rem) clamp(1rem,4vw,2rem)}
.legal-page h1{font-size:clamp(1.8rem,4vw,2.6rem)}
.legal-page h2{font-size:1.3rem;margin-top:2.2rem}
.legal-page p,.legal-page li{color:var(--steel-light);margin-bottom:.8rem;font-size:.97rem}
.legal-page ul{padding-left:1.4rem;margin-bottom:1rem}
.legal-meta{font-family:var(--mono);font-size:.78rem;color:var(--steel);margin:.6rem 0 2rem}
.legal-back{display:inline-block;margin-bottom:2rem;font-family:var(--mono);font-size:.85rem}

/* ---------- responsive ---------- */
@media (max-width: 960px){
  .hero{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .route li::after{content:none}
}
@media (max-width: 760px){
  .nav{
    display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--night-2);border-bottom:1px solid var(--line);padding:1.2rem clamp(1rem,4vw,3rem);gap:1rem;
  }
  .nav.open{display:flex}
  .nav-toggle{display:flex}
  .topbar .btn{display:none}
  .hero-stats{gap:1.4rem}
}
