.elementor-1546 .elementor-element.elementor-element-ff4e864{--display:flex;}:root{--page-title-display:none;}/* Start custom CSS */:root {
  --cw-navy: #062b3d;
  --cw-deep: #07384d;
  --cw-ink: #143847;
  --cw-muted: #607d87;
  --cw-teal: #00a9b7;
  --cw-aqua: #56e7ef;
  --cw-mint: #e7ffff;
  --cw-sea: #eaffff;
  --cw-sand: #fff4de;
  --cw-coral: #ff7a59;
  --cw-gold: #fac85f;
  --cw-white: #ffffff;
  --cw-red: #d94c3d;
  --cw-shadow: 0 24px 70px rgba(2,37,55,.16);
  --cw-shadow-soft: 0 18px 45px rgba(4,47,65,.10);
  --cw-radius: 28px;
  --cw-max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--cw-ink);
  background: linear-gradient(180deg, #f6ffff 0%, #ffffff 40%, #f7ffff 100%);
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.cw-page { overflow: hidden; }
.cw-container { width: min(var(--cw-max), calc(100% - 40px)); margin: 0 auto; }
.cw-pill {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 9px 15px; border-radius: 999px;
  background: rgba(255,255,255,.78); color: var(--cw-deep);
  font-weight: 800; font-size: 13px; letter-spacing: .02em;
  box-shadow: 0 12px 30px rgba(4,47,65,.10);
  border: 1px solid rgba(0,169,183,.16);
  backdrop-filter: blur(8px);
}
.cw-pill.dark { background: rgba(6,43,61,.78); color: white; border-color: rgba(255,255,255,.18); }
.cw-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 52px; padding: 15px 22px; border-radius: 999px;
  font-weight: 900; transition: .22s ease; border: 0; cursor: pointer;
  box-shadow: 0 16px 38px rgba(0,169,183,.26);
}
.cw-btn.primary { background: linear-gradient(135deg, var(--cw-teal), var(--cw-aqua)); color: var(--cw-navy); }
.cw-btn.secondary { background: rgba(255,255,255,.18); color: white; border: 1px solid rgba(255,255,255,.42); box-shadow: none; }
.cw-btn.light { background: white; color: var(--cw-deep); box-shadow: var(--cw-shadow-soft); }
.cw-btn:hover { transform: translateY(-2px); filter: saturate(1.06); }
.cw-section { padding: 86px 0; position: relative; }
.cw-kicker { color: var(--cw-teal); font-weight: 950; text-transform: uppercase; letter-spacing: .12em; font-size: 13px; margin: 0 0 12px; }
h1, h2, h3 { color: var(--cw-navy); line-height: 1.07; margin: 0; }
h1 { font-size: clamp(44px, 7vw, 88px); letter-spacing: -0.055em; }
h2 { font-size: clamp(32px, 4vw, 54px); letter-spacing: -0.04em; }
h3 { font-size: 22px; letter-spacing: -0.02em; }
.cw-lead { font-size: clamp(18px, 2vw, 22px); color: #315a66; margin: 20px 0 0; max-width: 800px; }
.cw-small { color: var(--cw-muted); font-size: 14px; }
.cw-grid { display: grid; gap: 24px; }
.cw-grid.two { grid-template-columns: 1.04fr .96fr; align-items: center; }
.cw-grid.three { grid-template-columns: repeat(3, 1fr); }
.cw-grid.four { grid-template-columns: repeat(4, 1fr); }
.cw-card {
  background: rgba(255,255,255,.88); border: 1px solid rgba(0,169,183,.14);
  border-radius: var(--cw-radius); padding: 28px; box-shadow: var(--cw-shadow-soft);
}
.cw-card strong { color: var(--cw-navy); }

.cw-hero {
  min-height: 92vh; position: relative; display: flex; align-items: center; color: white;
  background:
    linear-gradient(90deg, rgba(3,31,45,.86), rgba(3,31,45,.56) 45%, rgba(3,31,45,.22)),
    radial-gradient(circle at top right, #7affff, #00a9b7 35%, #05384e 75%);
}
.cw-hero::after {
  content: ""; position: absolute; inset: auto 0 -1px; height: 170px;
  background: linear-gradient(180deg, rgba(246,255,255,0), #f6ffff);
  pointer-events: none;
}
.cw-hero-inner { position: relative; z-index: 1; padding: 100px 0 160px; }
.cw-hero h1, .cw-hero h2 { color: white; text-shadow: 0 18px 55px rgba(0,0,0,.25); }
.cw-hero h2 { margin-top: 12px; font-size: clamp(27px, 3.6vw, 49px); }
.cw-hero .cw-lead { color: rgba(255,255,255,.92); max-width: 780px; }
.cw-hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.cw-trust { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.cw-floating-card {
  position: absolute; right: max(24px, calc((100vw - var(--cw-max)) / 2)); bottom: 78px;
  z-index: 2; width: min(390px, calc(100% - 40px));
  background: rgba(255,255,255,.94); color: var(--cw-ink); border-radius: 26px;
  padding: 24px; box-shadow: var(--cw-shadow); border: 1px solid rgba(255,255,255,.4);
}
.cw-floating-card h3 { margin-bottom: 12px; }
.cw-tour-meta { display: grid; gap: 10px; margin-top: 16px; }
.cw-meta-row { display: flex; justify-content: space-between; gap: 18px; padding: 11px 0; border-bottom: 1px solid rgba(0,169,183,.15); }
.cw-meta-row:last-child { border-bottom: 0; }
.cw-meta-row span:first-child { color: var(--cw-muted); font-weight: 700; }
.cw-meta-row span:last-child { color: var(--cw-navy); font-weight: 950; text-align: right; }

.cw-overlap { margin-top: -78px; position: relative; z-index: 4; }
.cw-fact-strip {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 0;
  background: white; border-radius: 30px; overflow: hidden;
  box-shadow: var(--cw-shadow); border: 1px solid rgba(0,169,183,.13);
}
.cw-fact { padding: 26px 22px; border-right: 1px solid rgba(0,169,183,.12); }
.cw-fact:last-child { border-right: 0; }
.cw-fact .label { color: var(--cw-muted); font-size: 13px; text-transform: uppercase; letter-spacing: .08em; font-weight: 900; }
.cw-fact .value { margin-top: 7px; color: var(--cw-navy); font-weight: 950; font-size: 19px; line-height: 1.22; }

.cw-photo-card {
  min-height: 560px; border-radius: 38px; overflow: hidden; position: relative;
  background:
    linear-gradient(180deg, rgba(6,43,61,.08), rgba(6,43,61,.52)),
    linear-gradient(135deg, #91f8ff, #eaffff);
  box-shadow: var(--cw-shadow);
}
.cw-photo-badge {
  position: absolute; left: 24px; right: 24px; bottom: 24px; padding: 22px;
  border-radius: 24px; background: rgba(255,255,255,.9); backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.6);
}
.cw-icon-list { display: grid; gap: 16px; margin-top: 28px; }
.cw-icon-item { display: grid; grid-template-columns: 42px 1fr; gap: 14px; align-items: start; }
.cw-icon {
  width: 42px; height: 42px; border-radius: 14px;
  background: linear-gradient(135deg, var(--cw-mint), white); display: grid; place-items: center;
  color: var(--cw-teal); font-weight: 950; border: 1px solid rgba(0,169,183,.16);
}
.cw-icon-item p { margin: 4px 0 0; color: var(--cw-muted); }

.cw-blue {
  background:
    radial-gradient(circle at top left, rgba(86,231,239,.34), transparent 34%),
    linear-gradient(135deg, #062b3d, #07516a 55%, #00a9b7);
  color: white;
}
.cw-blue h2, .cw-blue h3 { color: white; }
.cw-blue .cw-lead, .cw-blue p, .cw-blue .cw-small { color: rgba(255,255,255,.82); }
.cw-blue .cw-card { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.18); box-shadow: none; backdrop-filter: blur(10px); }
.cw-blue .cw-card strong { color: white; }

.cw-highlight-card { min-height: 100%; position: relative; overflow: hidden; }
.cw-highlight-card::before {
  content: ""; position: absolute; inset: 0 0 auto; height: 5px;
  background: linear-gradient(90deg, var(--cw-teal), var(--cw-aqua), var(--cw-gold));
}
.cw-highlight-card p { color: var(--cw-muted); margin-bottom: 0; }

.cw-route { position: relative; margin-top: 40px; }
.cw-route::before {
  content: ""; position: absolute; left: 24px; top: 10px; bottom: 10px; width: 3px;
  background: linear-gradient(180deg, var(--cw-teal), var(--cw-aqua), var(--cw-gold)); border-radius: 999px;
}
.cw-stop { display: grid; grid-template-columns: 70px 1fr; gap: 18px; position: relative; margin-bottom: 18px; }
.cw-stop:last-child { margin-bottom: 0; }
.cw-stop-num {
  width: 52px; height: 52px; border-radius: 50%; background: white; color: var(--cw-teal);
  border: 2px solid rgba(0,169,183,.25); display: grid; place-items: center; font-weight: 950;
  box-shadow: 0 12px 26px rgba(0,169,183,.18); z-index: 1;
}
.cw-stop-body {
  background: white; border: 1px solid rgba(0,169,183,.13); border-radius: 24px; padding: 24px;
  box-shadow: var(--cw-shadow-soft);
}
.cw-stop-body .time { display: inline-flex; margin-bottom: 10px; color: var(--cw-teal); font-weight: 950; font-size: 13px; text-transform: uppercase; letter-spacing: .08em; }
.cw-stop-body p { margin: 10px 0 0; color: var(--cw-muted); }

.cw-pricing {
  background: linear-gradient(180deg, #ffffff, #efffff);
}
.cw-price-card { text-align: center; padding: 32px 22px; }
.cw-price { font-size: 46px; line-height: 1; color: var(--cw-navy); font-weight: 950; letter-spacing: -0.04em; margin: 12px 0 8px; }
.cw-price small { font-size: 18px; color: var(--cw-muted); letter-spacing: 0; }

.cw-split-list { display: grid; gap: 12px; margin-top: 22px; }
.cw-check, .cw-x {
  display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: start;
  padding: 12px 0; border-bottom: 1px solid rgba(0,169,183,.10);
}
.cw-check::before { content: "âœ“"; color: var(--cw-teal); font-weight: 950; }
.cw-x::before { content: "â€”"; color: var(--cw-coral); font-weight: 950; }
.cw-check:last-child, .cw-x:last-child { border-bottom: 0; }

.cw-notice {
  background: #fffaf0; border: 1px solid rgba(250,200,95,.35); border-radius: 24px; padding: 24px;
  box-shadow: 0 14px 34px rgba(250,200,95,.12);
}
.cw-danger {
  background: #fff7f5; border: 1px solid rgba(217,76,61,.18); border-radius: 24px; padding: 24px;
}

.cw-comfort-block h2 {
  font-size: clamp(28px, 3.4vw, 46px);
  max-width: 820px;
  letter-spacing: -0.035em;
}
.cw-comfort-block .cw-lead { max-width: 900px; }
.cw-comfort-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}
.cw-comfort-item {
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(0,169,183,.12);
  border-radius: 20px;
  padding: 20px;
  box-shadow: 0 12px 28px rgba(4,47,65,.05);
}
.cw-comfort-item h3 {
  font-size: 18px;
  margin: 0 0 8px;
  line-height: 1.18;
  letter-spacing: -0.015em;
}
.cw-comfort-item p { margin: 0; color: #315a66; font-size: 15.5px; }
.cw-comfort-note {
  margin-top: 24px;
  padding: 20px;
  border-radius: 20px;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(250,200,95,.35);
}
.cw-comfort-note p { margin: 0 0 12px; }
.cw-comfort-note p:last-child { margin-bottom: 0; }


.cw-section-heading { max-width: 960px; }
.cw-section-heading h2 { max-width: 920px; overflow-wrap: normal; word-break: normal; hyphens: none; }
.cw-section-heading .cw-lead { max-width: 900px; }
.cw-comfort-block { width: 100%; }
.cw-comfort-block .cw-kicker { display: block; width: 100%; white-space: normal; }
.cw-comfort-block h2 { display: block; width: 100%; overflow-wrap: normal; word-break: normal; hyphens: none; }
.cw-family-note {
  margin-top: 18px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(231,255,255,.92), rgba(255,244,222,.8));
  border: 1px solid rgba(0,169,183,.15);
  padding: 18px 20px;
  color: #315a66;
}
.cw-family-note strong { color: var(--cw-navy); }


.cw-faq { display: grid; gap: 14px; margin-top: 30px; }
details {
  background: white; border: 1px solid rgba(0,169,183,.14); border-radius: 20px; padding: 20px 22px;
  box-shadow: 0 14px 32px rgba(4,47,65,.06);
}
summary { cursor: pointer; font-weight: 950; color: var(--cw-navy); font-size: 18px; list-style: none; }
summary::-webkit-details-marker { display: none; }
details p { color: var(--cw-muted); margin: 14px 0 0; }

.cw-cta-band {
  border-radius: 38px; padding: 46px; overflow: hidden; position: relative; color: white;
  background:
    linear-gradient(90deg, rgba(6,43,61,.94), rgba(0,169,183,.72)),
    linear-gradient(135deg, #062b3d, #00a9b7);
  box-shadow: var(--cw-shadow);
}
.cw-cta-band h2 { color: white; }
.cw-cta-band p { color: rgba(255,255,255,.86); max-width: 760px; }
.cw-contact-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.cw-contact-pill { display: inline-flex; align-items: center; gap: 8px; border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.08); color: white; text-decoration: none; border-radius: 999px; padding: 10px 14px; font-weight: 800; font-size: 14px; }
.cw-contact-pill:hover { background: rgba(255,255,255,.16); transform: translateY(-1px); }
.cw-footer { background: #041e2b; color: rgba(255,255,255,.78); padding: 38px 0 110px; }
.cw-footer a { color: white; text-decoration: none; font-weight: 800; }
.cw-footer-grid { display: grid; grid-template-columns: 1.25fr .75fr; gap: 24px; align-items: start; }
.cw-footer h2, .cw-footer h3 { color: white; margin: 0 0 10px; }
.cw-footer p { margin: 0 0 10px; }

.cw-sticky {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 20;
  background: rgba(255,255,255,.92); backdrop-filter: blur(14px); border-top: 1px solid rgba(0,169,183,.16);
  padding: 12px 0; box-shadow: 0 -12px 36px rgba(2,37,55,.10);
}
.cw-sticky-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.cw-sticky strong { display: block; color: var(--cw-navy); line-height: 1.2; }
.cw-sticky span { color: var(--cw-muted); font-size: 13px; }

@media (max-width: 980px) {
  .cw-floating-card { position: relative; right: auto; bottom: auto; margin: -120px auto 0; }
  .cw-hero-inner { padding-bottom: 180px; }
  .cw-grid.two, .cw-grid.three, .cw-grid.four { grid-template-columns: 1fr; }
  .cw-fact-strip { grid-template-columns: repeat(2, 1fr); }
  .cw-fact { border-right: 0; border-bottom: 1px solid rgba(0,169,183,.12); }
  .cw-comfort-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .cw-container { width: min(100% - 28px, var(--cw-max)); }
  .cw-section { padding: 64px 0; }
  .cw-hero { min-height: 86vh; }
  .cw-hero-inner { padding: 76px 0 170px; }
  .cw-hero-cta .cw-btn { width: 100%; }
  .cw-floating-card { width: min(100% - 28px, 390px); }
  .cw-fact-strip { grid-template-columns: 1fr; }
  .cw-stop { grid-template-columns: 52px 1fr; gap: 12px; }
  .cw-route::before { left: 25px; }
  .cw-cta-band { padding: 30px 22px; border-radius: 28px; }
  .cw-sticky-inner { align-items: stretch; }
  .cw-sticky .cw-btn { min-height: 46px; padding: 12px 16px; white-space: nowrap; }
  .cw-footer-grid { grid-template-columns: 1fr; }
  h2 { font-size: clamp(28px, 9vw, 38px); }
  .cw-kicker { letter-spacing: .07em; font-size: 12px; }
  .cw-comfort-grid { grid-template-columns: 1fr; }
  .cw-comfort-block h2 { font-size: clamp(28px, 8vw, 36px); }
}/* End custom CSS */