:root {
  --msc-navy: #071827;
  --msc-blue: #0b4f7a;
  --msc-sky: #13a8d8;
  --msc-gold: #f3b33d;
  --msc-cream: #fff7ea;
  --msc-ink: #102033;
  --msc-muted: #5f6f82;
  --msc-line: #dbe7ef;
  --msc-soft: #f4f8fb;
  --msc-white: #ffffff;
  --msc-shadow: 0 24px 70px rgba(7, 24, 39, 0.16);
  --msc-radius: 26px;
}

body { color: var(--msc-ink); }
body p { color: var(--msc-muted); font-size: 16px; line-height: 1.75; }
.wrapper { overflow: hidden; }
.msc-page .container { position: relative; z-index: 2; }
.msc-kicker { display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:999px; background:rgba(19,168,216,.12); color:var(--msc-blue); font-weight:700; letter-spacing:.08em; text-transform:uppercase; font-size:12px; margin-bottom:14px; }
.msc-kicker.light { background:rgba(255,255,255,.18); color:#fff; border:1px solid rgba(255,255,255,.28); }
.msc-section-title { max-width:820px; margin:0 auto 42px; text-align:center; }
.msc-section-title h2, .msc-split-copy h2 { color:var(--msc-navy); font-weight:800; letter-spacing:-.04em; line-height:1.08; font-size:clamp(34px,4vw,56px); margin-bottom:16px; }
.msc-section-title p { max-width:760px; margin-left:auto; margin-right:auto; }

.msc-btn, a.msc-btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:15px 24px; border-radius:999px; background:var(--msc-gold); color:#111 !important; font-weight:800; letter-spacing:.02em; box-shadow:0 12px 28px rgba(243,179,61,.32); border:2px solid var(--msc-gold); text-transform:none; }
.msc-btn:hover { transform:translateY(-2px); background:#ffd06d; border-color:#ffd06d; color:#111 !important; }
.msc-btn.secondary { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.55); color:#fff !important; box-shadow:none; }
.msc-btn.secondary:hover { background:#fff; color:var(--msc-navy) !important; }
.msc-btn.dark { background:var(--msc-navy); border-color:var(--msc-navy); color:#fff !important; box-shadow:0 14px 28px rgba(7,24,39,.24); }

.msc-hero { min-height:720px; padding:170px 0 80px; position:relative; background-image:linear-gradient(110deg,rgba(7,24,39,.88) 0%,rgba(7,24,39,.64) 43%,rgba(7,24,39,.18) 100%), url('../images/manhattan-scenic.jpg'); background-size:cover; background-position:center; }
.msc-hero:after { content:""; position:absolute; inset:auto 0 0; height:180px; background:linear-gradient(to top,#fff,rgba(255,255,255,0)); }
.msc-hero-grid { display:grid; grid-template-columns:minmax(0,1.05fr) minmax(320px,.72fr); gap:48px; align-items:center; }
.msc-hero h1 { color:#fff; font-size:clamp(48px,7vw,88px); line-height:.95; font-weight:900; letter-spacing:-.07em; margin:0 0 22px; text-shadow:0 8px 30px rgba(0,0,0,.28); }
.msc-hero p { color:rgba(255,255,255,.9); font-size:20px; max-width:680px; line-height:1.65; }
.msc-hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:28px; }
.msc-hero-points { display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.msc-hero-points span { color:#fff; background:rgba(255,255,255,.13); border:1px solid rgba(255,255,255,.2); padding:9px 13px; border-radius:999px; font-weight:600; }
.msc-booking-card { background:rgba(255,255,255,.94); border:1px solid rgba(255,255,255,.72); border-radius:var(--msc-radius); padding:28px; box-shadow:var(--msc-shadow); backdrop-filter:blur(10px); }
.msc-booking-card h3 { color:var(--msc-navy); font-size:28px; font-weight:800; margin-bottom:10px; }
.msc-booking-card ul { list-style:none; margin:20px 0 24px; padding:0; }
.msc-booking-card li { color:var(--msc-ink); padding:10px 0; border-bottom:1px solid var(--msc-line); font-weight:600; }
.msc-booking-card li i { color:var(--msc-sky); width:23px; }

.msc-trust { margin-top:-55px; position:relative; z-index:4; }
.msc-trust-inner { background:#fff; border-radius:22px; padding:18px 20px; box-shadow:var(--msc-shadow); display:grid; grid-template-columns:repeat(4,1fr); gap:10px; border:1px solid var(--msc-line); }
.msc-trust-item { display:flex; align-items:center; gap:10px; justify-content:center; color:var(--msc-ink); font-weight:700; padding:10px; }
.msc-trust-item i { color:var(--msc-sky); font-size:20px; }

.msc-intro { padding:90px 0 70px; }
.msc-intro-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:20px; }
.msc-info-card { background:#fff; border:1px solid var(--msc-line); border-radius:22px; padding:28px; box-shadow:0 14px 40px rgba(7,24,39,.07); }
.msc-info-card h3 { color:var(--msc-navy); font-weight:800; font-size:23px; }
.msc-info-card i { width:48px; height:48px; display:inline-flex; align-items:center; justify-content:center; border-radius:16px; background:rgba(19,168,216,.12); color:var(--msc-blue); font-size:22px; margin-bottom:18px; }

.msc-tours { padding:90px 0; background:linear-gradient(180deg,var(--msc-soft),#fff); }
.msc-tour-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:26px; max-width:980px; margin:0 auto; }
.msc-tour-card { background:#fff; border-radius:var(--msc-radius); overflow:hidden; box-shadow:var(--msc-shadow); border:1px solid var(--msc-line); }
.msc-tour-card img { width:100%; height:310px; object-fit:cover; display:block; }
.msc-tour-body { padding:28px; }
.msc-pill { display:inline-flex; padding:7px 12px; border-radius:999px; background:var(--msc-cream); color:#9a6100; font-weight:800; font-size:12px; text-transform:uppercase; letter-spacing:.08em; margin-bottom:12px; }
.msc-tour-body h3 { font-size:28px; line-height:1.15; font-weight:850; color:var(--msc-navy); margin-bottom:12px; }
.msc-meta { display:flex; flex-wrap:wrap; gap:9px; margin:20px 0 22px; }
.msc-meta span { background:var(--msc-soft); border:1px solid var(--msc-line); border-radius:999px; padding:8px 12px; color:var(--msc-ink); font-weight:700; }

.msc-split { padding:90px 0; }
.msc-split-grid { display:grid; grid-template-columns: .92fr 1.08fr; gap:46px; align-items:center; }
.msc-photo-stack { position:relative; min-height:520px; }
.msc-photo-stack img { position:absolute; object-fit:cover; border-radius:30px; box-shadow:var(--msc-shadow); }
.msc-photo-stack .photo-main { width:78%; height:420px; right:0; top:0; }
.msc-photo-stack .photo-small { width:48%; height:260px; left:0; bottom:0; border:8px solid #fff; }
.msc-check-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-top:26px; }
.msc-check { background:var(--msc-soft); border:1px solid var(--msc-line); border-radius:18px; padding:14px 16px; font-weight:800; color:var(--msc-ink); }
.msc-check i { color:var(--msc-sky); margin-right:8px; }

.msc-landmarks { padding:90px 0; background:var(--msc-navy); position:relative; }
.msc-landmarks:before { content:""; position:absolute; inset:0; background:radial-gradient(circle at top right,rgba(19,168,216,.28),transparent 34%); }
.msc-landmarks .msc-section-title h2, .msc-landmarks .msc-section-title p { color:#fff; }
.msc-landmark-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.msc-landmark { min-height:170px; border-radius:22px; padding:20px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); color:#fff; display:flex; flex-direction:column; justify-content:flex-end; }
.msc-landmark i { color:var(--msc-gold); font-size:26px; margin-bottom:20px; }
.msc-landmark h3 { color:#fff; font-size:20px; font-weight:800; margin:0 0 5px; }
.msc-landmark p { color:rgba(255,255,255,.78); font-size:14px; margin:0; }

.msc-route { padding:90px 0; background:#fff; }
.msc-route-grid { display:grid; grid-template-columns:.82fr 1.18fr; gap:40px; align-items:start; }
.msc-route-list { display:grid; gap:14px; }
.msc-route-step { display:grid; grid-template-columns:54px 1fr; gap:16px; background:#fff; border:1px solid var(--msc-line); border-radius:20px; padding:18px; box-shadow:0 12px 34px rgba(7,24,39,.06); }
.msc-route-num { width:54px; height:54px; border-radius:17px; background:var(--msc-navy); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:900; }
.msc-route-step h3 { margin:0 0 6px; color:var(--msc-navy); font-weight:800; font-size:20px; }
.msc-route-step p { margin:0; font-size:15px; }
.msc-route-image { border-radius:30px; overflow:hidden; box-shadow:var(--msc-shadow); position:sticky; top:110px; }
.msc-route-image img { display:block; width:100%; height:680px; object-fit:cover; }

.msc-policy { padding:90px 0; background-image:linear-gradient(90deg,rgba(7,24,39,.92),rgba(7,24,39,.72)), url('../demo-one-page/law/images/bg/02.jpg'); background-size:cover; background-position:center; }
.msc-policy h2 { color:#fff; font-weight:850; font-size:clamp(34px,4vw,56px); letter-spacing:-.04em; }
.msc-policy p { color:rgba(255,255,255,.84); }
.msc-stat-grid { display:grid; gap:16px; }
.msc-stat { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); border-radius:22px; padding:20px; color:#fff; }
.msc-stat strong { display:block; font-size:36px; line-height:1; color:var(--msc-gold); }
.msc-stat span { font-weight:700; color:#fff; }

.msc-reviews { padding:90px 0; background:var(--msc-soft); }
.msc-review-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.msc-review { background:#fff; border-radius:22px; padding:26px; border:1px solid var(--msc-line); box-shadow:0 12px 30px rgba(7,24,39,.07); }
.msc-stars { color:var(--msc-gold); margin-bottom:16px; }
.msc-review p { color:var(--msc-ink); font-size:16px; }
.msc-review strong { color:var(--msc-navy); }

.msc-services { padding:90px 0; }
.msc-service-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.msc-service { border:1px solid var(--msc-line); border-radius:22px; padding:24px; background:#fff; transition:.25s ease; }
.msc-service:hover { transform:translateY(-4px); box-shadow:var(--msc-shadow); }
.msc-service i, .msc-service span { width:48px; height:48px; border-radius:16px; display:inline-flex; align-items:center; justify-content:center; background:rgba(19,168,216,.12); color:var(--msc-blue); font-size:22px; margin-bottom:18px; }
.msc-service h3 { color:var(--msc-navy); font-weight:800; font-size:21px; margin-bottom:10px; }

.msc-gallery { padding:90px 0; background:linear-gradient(180deg,#fff,var(--msc-soft)); }
.msc-gallery-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:22px; align-items:stretch; }
.msc-gallery-grid img { width:100%; height:100%; min-height:360px; object-fit:cover; border-radius:26px; box-shadow:var(--msc-shadow); }

.msc-map { padding:90px 0; }
.msc-map-card { border-radius:30px; overflow:hidden; box-shadow:var(--msc-shadow); border:1px solid var(--msc-line); position:relative; }
.msc-map-card img { width:100%; display:block; }
.msc-map-card .popup { position:absolute; right:20px; top:20px; width:52px; height:52px; border-radius:50%; background:#fff; color:var(--msc-navy); display:flex; align-items:center; justify-content:center; box-shadow:0 12px 24px rgba(7,24,39,.2); }

.msc-final-cta { padding:85px 0; background:linear-gradient(135deg,var(--msc-blue),var(--msc-navy)); text-align:center; }
.msc-final-cta h2 { color:#fff; font-weight:900; font-size:clamp(34px,5vw,62px); letter-spacing:-.05em; margin-bottom:14px; }
.msc-final-cta p { color:rgba(255,255,255,.82); max-width:720px; margin:0 auto 25px; }

#back-to-top .top { background:var(--msc-blue); border-radius:999px; }

@media (max-width: 991px) {
  .msc-hero { min-height:auto; padding:135px 0 80px; }
  .msc-hero-grid, .msc-split-grid, .msc-route-grid, .msc-gallery-grid { grid-template-columns:1fr; }
  .msc-trust-inner, .msc-intro-grid, .msc-landmark-grid, .msc-review-grid, .msc-service-grid { grid-template-columns:repeat(2,1fr); }
  .msc-booking-card { max-width:560px; }
  .msc-route-image { position:relative; top:auto; }
  .msc-route-image img { height:420px; }
}
@media (max-width: 767px) {
  .msc-hero { padding:115px 0 65px; }
  .msc-hero p { font-size:17px; }
  .msc-hero-actions { flex-direction:column; align-items:stretch; }
  .msc-btn { width:100%; }
  .msc-trust { margin-top:0; padding-top:20px; background:#fff; }
  .msc-trust-inner, .msc-intro-grid, .msc-tour-grid, .msc-landmark-grid, .msc-review-grid, .msc-service-grid, .msc-check-grid { grid-template-columns:1fr; }
  .msc-photo-stack { min-height:420px; }
  .msc-photo-stack .photo-main { width:88%; height:320px; }
  .msc-photo-stack .photo-small { width:58%; height:210px; }
  .msc-landmark { min-height:140px; }
  .msc-tour-card img { height:240px; }
}

/* =========================================================
   Inner landing pages: NYC Boat Cruises
   Added because the page uses these classes directly.
   ========================================================= */
.msc-inner-page .msc-subhero {
  position: relative;
  padding: 155px 0 80px;
  min-height: 620px;
  background:
    radial-gradient(circle at 82% 18%, rgba(19,168,216,.34), transparent 32%),
    linear-gradient(115deg, rgba(7,24,39,.94) 0%, rgba(7,24,39,.82) 46%, rgba(11,79,122,.74) 100%),
    url('../images/manhattan-scenic.jpg');
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.msc-inner-page .msc-subhero:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 120px;
  background: linear-gradient(to top, #fff, rgba(255,255,255,0));
  pointer-events: none;
}

.msc-subhero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, .72fr);
  gap: 48px;
  align-items: center;
}

.msc-subhero-copy h1 {
  color: #fff;
  font-size: clamp(46px, 6vw, 82px);
  line-height: .98;
  font-weight: 900;
  letter-spacing: -.06em;
  margin: 0 0 18px;
  text-shadow: 0 10px 34px rgba(0,0,0,.32);
}

.msc-subhero-copy p {
  color: rgba(255,255,255,.9);
  font-size: 19px;
  line-height: 1.65;
  max-width: 720px;
}

.msc-subhero-card {
  position: relative;
  border-radius: 30px;
  overflow: hidden;
  background: #fff;
  box-shadow: var(--msc-shadow);
  border: 1px solid rgba(255,255,255,.45);
}

.msc-subhero-card img {
  width: 100%;
  height: 380px;
  display: block;
  object-fit: cover;
}

.msc-card-panel {
  padding: 22px 24px 24px;
  background: #fff;
}

.msc-card-panel strong {
  display: block;
  color: var(--msc-navy);
  font-size: 18px;
  margin-bottom: 12px;
}

.msc-card-panel ul,
.msc-affiliate-box ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.msc-card-panel li {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  color: var(--msc-ink);
  font-weight: 700;
  border-bottom: 1px solid var(--msc-line);
}

.msc-card-panel li:last-child { border-bottom: 0; }
.msc-card-panel li i { color: var(--msc-sky); }

.msc-trust-flat {
  margin-top: -34px;
  margin-bottom: 0;
}

.msc-content-section {
  padding: 88px 0;
  background: #fff;
}

.msc-soft-section {
  background: linear-gradient(180deg, var(--msc-soft), #fff);
}

.msc-editorial-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 42px;
  align-items: start;
}

.msc-editorial-grid.reverse {
  grid-template-columns: .9fr 1.1fr;
  align-items: center;
}

.msc-editorial-main h2,
.msc-affiliate-card h2 {
  color: var(--msc-navy);
  font-weight: 900;
  letter-spacing: -.045em;
  line-height: 1.08;
  font-size: clamp(34px, 4vw, 54px);
  margin-bottom: 18px;
}

.msc-editorial-main h3,
.msc-affiliate-box h3 {
  color: var(--msc-navy);
  font-weight: 850;
}

.msc-sidebar-card {
  position: sticky;
  top: 110px;
  background: #fff;
  border: 1px solid var(--msc-line);
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 18px 44px rgba(7,24,39,.08);
}

.msc-sidebar-card h3 {
  color: var(--msc-navy);
  font-weight: 900;
  margin-bottom: 14px;
}

.msc-sidebar-card a {
  display: flex;
  gap: 9px;
  align-items: center;
  padding: 12px 0;
  border-top: 1px solid var(--msc-line);
  color: var(--msc-ink);
  font-weight: 800;
}

.msc-sidebar-card a i { color: var(--msc-sky); }

.msc-feature-band {
  padding: 92px 0;
  background: #fff;
}

.msc-two-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  max-width: 1040px;
  margin: 0 auto;
}

.msc-modern-card {
  background: #fff;
  border: 1px solid var(--msc-line);
  border-radius: var(--msc-radius);
  overflow: hidden;
  box-shadow: var(--msc-shadow);
}

.msc-modern-card img {
  width: 100%;
  height: 330px;
  object-fit: cover;
  display: block;
}

.msc-modern-card-body { padding: 28px; }
.msc-modern-card-body h3 {
  color: var(--msc-navy);
  font-size: 28px;
  line-height: 1.12;
  font-weight: 900;
  margin-bottom: 12px;
}

.simple-image img {
  height: auto !important;
  min-height: 0;
  max-height: 560px;
}

.msc-benefit-list {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.msc-benefit-list div {
  background: var(--msc-soft);
  border: 1px solid var(--msc-line);
  border-radius: 18px;
  padding: 16px 18px;
}

.msc-benefit-list strong {
  display: block;
  color: var(--msc-navy);
  font-size: 17px;
  margin-bottom: 4px;
}

.msc-benefit-list span {
  display: block;
  color: var(--msc-muted);
  line-height: 1.55;
}

.msc-affiliate-section {
  padding: 86px 0;
  background: var(--msc-soft);
}

.msc-affiliate-card {
  display: grid;
  grid-template-columns: 1fr .78fr;
  gap: 34px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--msc-line);
  border-radius: 30px;
  padding: 36px;
  box-shadow: 0 18px 48px rgba(7,24,39,.08);
}

.msc-affiliate-box {
  background: linear-gradient(135deg, var(--msc-navy), var(--msc-blue));
  color: #fff;
  border-radius: 24px;
  padding: 26px;
}

.msc-affiliate-box h3 { color: #fff; }
.msc-affiliate-box p { color: rgba(255,255,255,.82); }
.msc-affiliate-box li {
  padding: 9px 0;
  color: #fff;
  border-top: 1px solid rgba(255,255,255,.16);
  font-weight: 700;
}

@media (max-width: 991px) {
  .msc-inner-page .msc-subhero { padding: 128px 0 70px; }
  .msc-subhero-grid,
  .msc-editorial-grid,
  .msc-editorial-grid.reverse,
  .msc-affiliate-card { grid-template-columns: 1fr; }
  .msc-sidebar-card { position: relative; top: auto; }
  .msc-subhero-card img { height: 320px; }
}

@media (max-width: 767px) {
  .msc-inner-page .msc-subhero { padding: 112px 0 54px; }
  .msc-subhero-copy p { font-size: 17px; }
  .msc-subhero-card img,
  .msc-modern-card img { height: 240px; }
  .msc-two-card-grid { grid-template-columns: 1fr; }
  .msc-content-section,
  .msc-feature-band,
  .msc-affiliate-section { padding: 58px 0; }
  .msc-affiliate-card { padding: 24px; border-radius: 24px; }
}
.msc-guide-cta {
  margin-top: 45px;
  padding: 34px 38px;
  border-radius: 28px;
  background: #ffffff;
  border: 1px solid rgba(15, 45, 70, 0.12);
  box-shadow: 0 18px 45px rgba(10, 32, 50, 0.10);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
}

.msc-guide-cta h3 {
  margin: 12px 0 10px;
  font-size: 34px;
  line-height: 1.15;
}

.msc-guide-cta p {
  margin: 0;
  max-width: 760px;
}

.msc-guide-cta .msc-btn {
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .msc-guide-cta {
    padding: 28px 24px;
    flex-direction: column;
    align-items: flex-start;
  }

  .msc-guide-cta h3 {
    font-size: 28px;
  }
}

.msc-booking-card,
.msc-booking-card h3,
.msc-booking-card p,
.msc-booking-card li {
  color: #071827;
}

.msc-booking-card p {
  color: #526171;
}

.msc-booking-card ul li {
  color: #102033;
}