:root {
  --navy: #0b1f33;
  --ink: #162331;
  --harbor: #0f6b7a;
  --tide: #dff3f6;
  --sand: #f3dfc1;
  --coral: #cf6f55;
  --line: #dbe4ea;
  --soft: #f5f8fa;
  --shadow: 0 18px 55px rgba(11, 31, 51, 0.14);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: #fff;
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
input, select, textarea, button { font: inherit; }
.container { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }
.skip-link { position:absolute; left:16px; top:-60px; background:var(--navy); color:white; padding:10px 14px; border-radius:999px; z-index:99; }
.skip-link:focus { top:16px; }

.site-header {
  position: sticky; top: 0; z-index: 40;
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(12px);
}
.header-inner { min-height: 68px; display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand { font-weight: 800; color: var(--navy); line-height:1.1; }
.brand small { display:block; color:#6b7b88; font-weight:600; font-size:12px; margin-top:3px; }
.nav { display:flex; gap:18px; align-items:center; font-size:14px; font-weight:700; color:#4b5c68; }
.nav a:hover { color: var(--harbor); }
.top-cta, .btn {
  display:inline-flex; align-items:center; justify-content:center;
  border:0; border-radius:999px; padding:12px 18px;
  background:var(--coral); color:white; font-weight:800; cursor:pointer;
}
.top-cta:hover, .btn:hover { background:#b95c46; }
.btn.secondary { background:white; color:var(--navy); border:1px solid var(--line); }

.hero {
  background: var(--navy);
  color: white;
  overflow:hidden;
}
.hero-grid { display:grid; grid-template-columns: 1.06fr .94fr; gap:34px; align-items:center; padding:48px 0; }
.eyebrow {
  display:inline-flex; border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.1); color:var(--tide);
  border-radius:999px; padding:9px 14px; font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.05em;
}
h1 { margin:18px 0 0; font-size: clamp(38px, 5vw, 66px); line-height:1.02; color: inherit; letter-spacing:0; }
.hero p.lead { max-width:680px; color:#d6e2e7; font-size:18px; line-height:1.7; margin:20px 0 0; }
.proof-grid { margin-top:26px; display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:12px; max-width:700px; }
.proof-grid div { border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.09); border-radius:8px; padding:13px 14px; font-weight:700; font-size:14px; }
.route-chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.route-chips a, .pill { border-radius:999px; background:white; color:var(--navy); padding:9px 14px; font-size:14px; font-weight:800; }
.hero-side { display:grid; gap:16px; }
.visual-card { border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.1); border-radius:10px; padding:12px; box-shadow:var(--shadow); }
.visual-card img { width:100%; height:230px; object-fit:cover; border-radius:8px; }
.route-overlay { display:flex; flex-wrap:wrap; gap:8px; margin-top:-218px; padding:12px; position:relative; min-height:206px; align-items:flex-start; }
.route-overlay span { background:rgba(255,255,255,.94); color:var(--navy); border-radius:999px; padding:7px 11px; font-size:12px; font-weight:800; }
.option-metrics { display:grid; grid-template-columns:repeat(3, 1fr); gap:8px; margin-top:12px; }
.option-metrics div { background:white; color:var(--navy); border-radius:8px; padding:12px; }
.option-metrics small { color:var(--harbor); font-size:11px; text-transform:uppercase; font-weight:800; }
.option-metrics strong { display:block; margin-top:4px; font-size:14px; }

.lead-form {
  background:white; color:var(--ink); border:1px solid var(--line);
  border-radius:10px; padding:18px; box-shadow:var(--shadow);
}
.lead-form h2 { margin:4px 0 0; color:var(--navy); font-size:22px; line-height:1.2; }
.lead-form .form-intro { margin:8px 0 16px; color:#61717d; font-size:14px; line-height:1.55; }
.lead-form .form-kicker { color:var(--coral); text-transform:uppercase; font-size:12px; letter-spacing:.05em; font-weight:900; }
.form-grid { display:grid; gap:12px; }
.two-col { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:12px; }
label { display:block; font-size:13px; font-weight:750; color:#263746; margin-bottom:5px; }
input, select, textarea {
  width:100%; border:1px solid #cbd5dc; border-radius:7px;
  padding:10px 11px; background:white; color:var(--ink); outline:none;
}
input:focus, select:focus, textarea:focus { border-color:var(--harbor); box-shadow:0 0 0 3px rgba(15,107,122,.16); }
details.form-details { background:#f7fafb; border:1px solid var(--line); border-radius:8px; padding:12px; }
details.form-details summary { cursor:pointer; color:var(--harbor); font-weight:850; font-size:14px; }
.consent { display:flex; gap:10px; align-items:flex-start; margin-top:12px; color:#60707d; font-size:13px; line-height:1.5; }
.consent input { width:16px; margin-top:3px; accent-color:var(--harbor); }
.form-note { text-align:center; color:#70808c; font-size:12px; line-height:1.45; margin:9px 0 0; }
.form-status { display:none; margin-top:12px; padding:12px; border-radius:8px; font-size:14px; font-weight:750; }
.form-status.success { display:block; background:var(--tide); color:var(--navy); }
.form-status.error { display:block; background:#fff1f1; color:#9d2424; }

.section { padding:56px 0; }
.section.soft { background:var(--soft); }
.breadcrumbs { border-bottom:1px solid var(--line); background:#fbfdfe; }
.breadcrumbs ol { list-style:none; margin:0; padding:13px 0; display:flex; flex-wrap:wrap; gap:8px; align-items:center; color:#6a7b87; font-size:13px; }
.breadcrumbs li { display:flex; gap:8px; align-items:center; }
.breadcrumbs a:hover { color:var(--harbor); }
.breadcrumbs strong { color:var(--navy); font-weight:800; }
.section-head { max-width:720px; margin-bottom:26px; }
.section-kicker { color:var(--harbor); text-transform:uppercase; font-size:13px; letter-spacing:.04em; font-weight:900; }
h2 { margin:7px 0 0; color:var(--navy); font-size: clamp(28px, 3vw, 38px); line-height:1.14; }
.section-head p { color:#60707d; line-height:1.7; }
.quick-use { border-bottom:1px solid var(--line); background:white; }
.quick-use-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:12px; padding:20px 0; }
.mini-card { background:#f7fafb; border-radius:8px; padding:16px; }
.mini-card h3 { color:var(--navy); margin:0; font-size:16px; }
.mini-card p { color:#60707d; margin:8px 0 0; font-size:14px; line-height:1.55; }

.cards { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:18px; }
.cards.boats { grid-template-columns:repeat(4, minmax(0, 1fr)); }
.card {
  display:block; overflow:hidden; border:1px solid var(--line);
  background:white; border-radius:10px; box-shadow:0 3px 14px rgba(11,31,51,.06);
  transition: transform .16s ease, box-shadow .16s ease;
}
.card:hover { transform:translateY(-3px); box-shadow:var(--shadow); }
.card.featured { grid-column:span 2; }
.card img { width:100%; height:180px; object-fit:cover; background:var(--tide); }
.card.featured img { height:235px; }
.card-body { padding:18px; }
.card .meta { color:var(--coral); text-transform:uppercase; font-size:12px; font-weight:900; }
.card h3 { color:var(--navy); margin:5px 0 0; font-size:20px; line-height:1.25; }
.card p { color:#5d6d79; font-size:14px; line-height:1.65; }
.facts { display:grid; grid-template-columns:repeat(2, 1fr); gap:8px; margin-top:14px; padding-top:14px; border-top:1px solid #edf1f4; }
.fact { background:#f7fafb; border-radius:7px; padding:10px; }
.fact dt { color:#8a98a3; text-transform:uppercase; font-size:10px; font-weight:900; }
.fact dd { margin:3px 0 0; color:#30414f; font-size:13px; font-weight:800; }
.link-action { display:inline-flex; margin-top:14px; color:var(--harbor); font-weight:900; font-size:14px; }

.table-card { overflow:hidden; border:1px solid var(--line); border-radius:10px; background:white; box-shadow:0 3px 14px rgba(11,31,51,.06); }
.option-row { display:grid; grid-template-columns:160px 150px 1fr; gap:12px; align-items:center; padding:16px; border-bottom:1px solid var(--line); }
.option-row:last-child { border-bottom:0; }
.option-row strong { color:var(--navy); }
.option-row .route { color:var(--coral); font-weight:900; }
.option-row p { margin:0; color:#5d6d79; line-height:1.55; font-size:14px; }

.info-grid { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:16px; }
.info-box { border:1px solid var(--line); border-radius:10px; background:white; padding:18px; }
.info-box h3 { margin:0; color:var(--navy); }
.info-box ul { margin:12px 0 0; padding-left:18px; color:#5e6f7c; line-height:1.7; font-size:14px; }
.prose { max-width:760px; line-height:1.78; color:#4b5c68; }
.prose h2 { margin-top:34px; }
.related-panel { background:#f7fafb; border:1px solid var(--line); border-radius:10px; padding:22px; }
.related-panel h2 { font-size:24px; margin:0; }
.related-links { display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; }
.related-links a { border:1px solid #cbd5dc; background:white; color:var(--harbor); border-radius:999px; padding:10px 14px; font-size:14px; font-weight:900; }
.related-links a:hover { border-color:var(--harbor); }
.faq-list details { background:white; border:1px solid var(--line); border-radius:8px; padding:16px; margin-bottom:10px; }
.faq-list summary { cursor:pointer; color:var(--navy); font-weight:900; }
.faq-list p { color:#5d6d79; line-height:1.65; }

.footer { background:var(--navy); color:white; padding:46px 0 24px; margin-top:60px; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:28px; }
.footer p, .footer a { color:#c7d2d9; line-height:1.65; font-size:14px; }
.footer h3 { color:white; margin:0 0 12px; }
.footer ul { list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:34px; padding-top:18px; color:#aebcc5; font-size:12px; }

.mobile-bar {
  position:fixed; z-index:60; left:12px; right:12px; bottom:12px;
  display:none; background:rgba(11,31,51,.96); border:1px solid rgba(255,255,255,.25);
  border-radius:999px; padding:8px; box-shadow:var(--shadow);
}
.mobile-bar-inner { display:grid; grid-template-columns:1fr auto; gap:8px; align-items:center; }
.mobile-bar a { border-radius:999px; padding:12px 15px; font-size:14px; font-weight:900; text-align:center; }
.mobile-bar .primary { background:var(--coral); color:white; }
.mobile-bar .secondary { background:white; color:var(--navy); }

@media (max-width: 900px) {
  .nav { display:none; }
  .hero-grid, .cards, .cards.boats, .quick-use-grid, .info-grid, .footer-grid { grid-template-columns:1fr; }
  .card.featured { grid-column:auto; }
  .option-metrics, .two-col, .facts { grid-template-columns:1fr; }
  .option-row { grid-template-columns:1fr; }
  .hero-grid { padding:34px 0 46px; }
  .hero p.lead { font-size:16px; }
  .proof-grid { grid-template-columns:1fr; }
  .mobile-bar { display:block; }
  body { padding-bottom:82px; }
}
