/* Boatfolio — stile condiviso landing + pagine legali. Minimale, professionale. */
:root {
  --ink: #14202b;
  --muted: #5b6b78;
  --line: #e2e6ea;
  --brand: #11507a;
  --brand-dark: #0c3b5a;
  --bg: #ffffff;
  --bg-soft: #f4f7f9;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink);
  background: var(--bg);
}

a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: 1040px; margin: 0 auto; padding: 0 20px; }

/* Header */
header.site {
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; background: rgba(255,255,255,0.92);
  backdrop-filter: blur(6px); z-index: 10;
}
header.site .inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.logo { font-weight: 800; font-size: 1.25rem; color: var(--ink); letter-spacing: -0.02em; }
.logo span { color: var(--brand); }
nav.site a { color: var(--ink); margin-left: 22px; font-size: 0.95rem; }

/* Buttons */
.btn {
  display: inline-block; padding: 12px 20px; border-radius: 10px;
  font-weight: 600; font-size: 1rem; cursor: pointer; border: 1px solid transparent;
}
.btn-primary { background: var(--brand); color: #fff; }
.btn-primary:hover { background: var(--brand-dark); text-decoration: none; }
.btn-ghost { background: #fff; color: var(--brand); border-color: var(--line); }
.btn-ghost:hover { background: var(--bg-soft); text-decoration: none; }

/* Hero */
.hero { padding: 72px 0 56px; }
.hero h1 { font-size: 2.6rem; line-height: 1.1; margin: 0 0 14px; letter-spacing: -0.02em; }
.hero p.lead { font-size: 1.2rem; color: var(--muted); max-width: 640px; margin: 0 0 28px; }
.hero .cta { display: flex; gap: 12px; flex-wrap: wrap; }

/* Sections */
section { padding: 48px 0; }
section.alt { background: var(--bg-soft); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
h2 { font-size: 1.6rem; margin: 0 0 8px; letter-spacing: -0.01em; }
.section-sub { color: var(--muted); margin: 0 0 28px; }

/* Cards grid */
.grid { display: grid; gap: 16px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.card {
  background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 20px;
}
.card h3 { margin: 0 0 6px; font-size: 1.15rem; }
.card p { margin: 0; color: var(--muted); font-size: 0.97rem; }
.eyebrow { color: var(--brand); font-weight: 700; font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase; }

ul.features { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2,1fr); gap: 12px 28px; }
ul.features li { padding-left: 22px; position: relative; }
ul.features li::before { content: "›"; color: var(--brand); position: absolute; left: 4px; font-weight: 800; }

/* Footer */
footer.site { border-top: 1px solid var(--line); padding: 32px 0; color: var(--muted); font-size: 0.9rem; }
footer.site .row { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
footer.site a { color: var(--muted); margin-right: 16px; }

/* Legal pages */
.legal { max-width: 820px; margin: 0 auto; padding: 32px 20px 64px; }
.legal h1 { font-size: 1.9rem; margin: 0 0 4px; }
.legal h2 { font-size: 1.25rem; margin: 28px 0 8px; }
.legal h3 { font-size: 1.1rem; margin: 18px 0 6px; }
.legal .updated { color: var(--muted); font-size: 0.9rem; margin-bottom: 24px; }
.legal table { border-collapse: collapse; width: 100%; margin: 8px 0; font-size: 0.95rem; }
.legal th, .legal td { border: 1px solid var(--line); padding: 8px 12px; text-align: left; vertical-align: top; }
.legal th { background: var(--bg-soft); }
.note { border: 1px solid var(--line); background: var(--bg-soft); border-radius: 8px; padding: 12px 14px; font-size: 0.92rem; color: var(--muted); margin: 16px 0 24px; }
.ph { background: #fff3cd; padding: 0 3px; border-radius: 3px; }

@media (max-width: 760px) {
  .grid-3, .grid-2, ul.features { grid-template-columns: 1fr; }
  .hero h1 { font-size: 2rem; }
  nav.site { display: none; }
}
