/* PuntoCrociere.it — design system condiviso (MSC) */
:root{
  --blue:#0a4d8c;--blue-d:#003b7a;--blue-dd:#012a59;--gold:#ffca28;--gold-d:#e0a800;
  --ink:#13233b;--muted:#5b6b82;--line:#e6ecf3;--bg:#f4f7fb;--wa:#25D366;
  --radius:16px;--shadow:0 10px 30px rgba(10,40,90,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:1240px;margin:0 auto;padding:0 22px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;border-radius:12px;cursor:pointer;font-family:inherit;border:none;transition:filter .15s,transform .15s}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#3a2a00}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff}
.btn-gold:hover,.btn-blue:hover{filter:brightness(1.06)}

/* ===== HEADER ===== */
.site-hd{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:60}
.site-hd .in{display:flex;align-items:center;gap:26px;height:66px;max-width:1240px;margin:0 auto;padding:0 22px}
.site-hd .logo{font-weight:800;font-size:1.32rem;color:var(--blue);letter-spacing:-.5px;white-space:nowrap}
.site-hd .logo b{color:var(--gold-d)}
.site-hd nav{display:flex;gap:24px;margin-left:6px}
.site-hd nav a{font-weight:600;font-size:.93rem;color:var(--muted)}
.site-hd nav a:hover,.site-hd nav a.active{color:var(--blue)}
.site-hd .cta{margin-left:auto;display:flex;align-items:center;gap:14px}
.site-hd .phone{font-weight:700;color:var(--blue);font-size:.95rem;text-align:right;white-space:nowrap}
.site-hd .phone span{display:block;font-weight:500;font-size:.72rem;color:var(--muted)}
.site-hd .wa{background:var(--wa);color:#fff;font-weight:700;font-size:.9rem;padding:10px 16px;border-radius:30px;display:inline-flex;gap:8px;align-items:center}
.site-hd .burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;margin-left:auto}
.site-hd .burger span{width:24px;height:2px;background:var(--blue);border-radius:2px}
/* mobile drawer */
.site-drawer{position:fixed;inset:0;z-index:70;background:rgba(1,20,45,.5);display:none}
.site-drawer.open{display:block}
.site-drawer .pan{position:absolute;top:0;right:0;bottom:0;width:78%;max-width:320px;background:#fff;padding:64px 22px 22px;display:flex;flex-direction:column;gap:6px}
.site-drawer .pan a{padding:13px 8px;font-weight:700;color:var(--ink);border-bottom:1px solid var(--line)}
.site-drawer .x{position:absolute;top:16px;right:18px;font-size:1.6rem;color:var(--muted);background:none;border:none;cursor:pointer}

/* ===== FOOTER ===== */
.site-ft{background:var(--blue-dd);color:#aecbe8;margin-top:30px}
.site-ft .in{max-width:1240px;margin:0 auto;padding:40px 22px 26px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:26px}
.site-ft h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;font-weight:700}
.site-ft a,.site-ft p{color:#aecbe8;font-size:.9rem;line-height:1.9;font-weight:500}
.site-ft a:hover{color:#fff}
.site-ft .brand{font-weight:800;font-size:1.2rem;color:#fff}.site-ft .brand b{color:var(--gold)}
.site-ft .bottom{border-top:1px solid rgba(255,255,255,.12);text-align:center;padding:16px;font-size:.8rem;color:#7fa3c8}
@media(max-width:900px){
  .site-hd nav,.site-hd .phone span{display:none}
  .site-hd .wa{display:none}
  .site-hd .burger{display:flex}
  .site-hd .cta{display:none}
  .site-ft .in{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){.site-ft .in{grid-template-columns:1fr}}

/* ===== PAGINE STATICHE ===== */
.page-hero{background:linear-gradient(150deg,var(--blue),var(--blue-d) 60%,var(--blue-dd));color:#fff;padding:46px 0 54px;position:relative;overflow:hidden}
.page-hero:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:46px;background:var(--bg);clip-path:ellipse(82% 100% at 50% 100%)}
.page-hero .crumb{font-size:.82rem;color:#bcd6f2;font-weight:600;margin-bottom:8px}.page-hero .crumb a{color:#fff}
.page-hero h1{font-size:2.1rem;font-weight:800;letter-spacing:-.6px}.page-hero p{color:#cfe0f4;margin-top:8px;font-weight:500;max-width:640px}
.page{max-width:880px;margin:0 auto;padding:34px 22px 10px}
.page.wide{max-width:1240px}
.prose h2{font-size:1.35rem;font-weight:800;margin:26px 0 10px;letter-spacing:-.3px}
.prose h3{font-size:1.08rem;font-weight:800;margin:18px 0 6px}
.prose p{margin:0 0 12px;color:#2c3c54}.prose ul{margin:0 0 14px 20px;color:#2c3c54}.prose li{margin:5px 0}
.prose a{color:var(--blue);font-weight:600}
.cardbox{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-bottom:18px}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin:6px 0 20px}
.tile{position:relative;border-radius:14px;overflow:hidden;height:150px;display:flex;align-items:flex-end;color:#fff;background:linear-gradient(135deg,var(--blue),var(--blue-dd))}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile .ov{position:relative;width:100%;padding:14px 16px;background:linear-gradient(to top,rgba(1,20,45,.82),transparent);font-weight:800}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:6px 0}
.contact-grid .c{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:20px}
.contact-grid .c .l{font-size:.76rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}
.contact-grid .c .v{font-size:1.15rem;font-weight:800;color:var(--blue);margin-top:4px}
.contact-grid .c a{color:var(--blue)}
@media(max-width:600px){.contact-grid{grid-template-columns:1fr}.page-hero h1{font-size:1.6rem}}
