/* Splash N Go upgrade layer - v9 compatibility and content edition
   Load after css/style.css and css/responsi.css. This file is intentionally conservative
   so the existing template keeps its working layout. */
:root {
  --sng-blue: #053f5f;
  --sng-green: #83c669;
  --sng-yellow: #fdbc44;
  --sng-sky: #5bcbf3;
  --sng-dark: #183548;
  --sng-light: #f7fbfd;
  --sng-white: #ffffff;
  --sng-shadow: 0 12px 30px rgba(5, 63, 95, 0.14);
  --sng-radius: 16px;
}

html { scroll-behavior: smooth; }

/* Restore visible keyboard focus. The older CSS removes outlines globally. */
:focus, button:focus, select:focus, a:focus, input:focus, textarea:focus {
  outline: 3px solid rgba(253, 188, 68, 0.85) !important;
  outline-offset: 3px !important;
}

.skip-link {
  position: absolute; left: 12px; top: -60px; z-index: 99999;
  background: var(--sng-yellow); color: var(--sng-blue);
  padding: 10px 16px; border-radius: 0 0 10px 10px; font-weight: 700;
}
.skip-link:focus { top: 0; }

.sng-section, .sng-page-section { float: left; width: 100%; padding: 70px 0; }
.sng-page-section-alt { background: #f8fcff; }
.sng-kicker { display: inline-block; margin-bottom: 10px; color: var(--sng-green); font-size: 14px; font-weight: 700; letter-spacing: .08em; line-height: 1.35; text-transform: uppercase; }
.sng-section-title { max-width: 820px; margin: 0 auto 34px; text-align: center; }
.sng-section-title h2, .sng-plan h2, .sng-subscribe h2 { color: var(--sng-blue); font-size: 42px; font-weight: 800; line-height: 1.1; margin-bottom: 14px; }
.sng-section-title p, .sng-plan p, .sng-lead { color: #315b73; font-size: 18px; line-height: 1.65; }

.sng-btn, .sng-park-card .all-button, .sng-content-card .all-button {
  display: inline-block !important; min-height: 46px; padding: 12px 22px !important;
  border: 0; border-radius: 999px !important; font-size: 17px !important; font-weight: 700 !important;
  line-height: 1.2 !important; text-align: center; transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.sng-btn:hover, .sng-park-card .all-button:hover { transform: translateY(-2px); text-decoration: none !important; }
.sng-btn-primary, .sng-park-card .all-button { background: var(--sng-yellow) !important; color: var(--sng-blue) !important; box-shadow: 0 10px 22px rgba(253, 188, 68, .24); }
.sng-btn-secondary { background: rgba(255,255,255,.14); color: var(--sng-white); border: 2px solid rgba(255,255,255,.75); }
.sng-btn-light { color: var(--sng-blue) !important; background: var(--sng-white) !important; border: 1px solid rgba(5,63,95,.12); }

.sng-hero { float: left; width: 100%; min-height: 620px; display: flex; align-items: center; background-position: center; background-size: cover; color: #fff; position: relative; overflow: hidden; }
.sng-hero-content { position: relative; z-index: 2; max-width: 760px; padding: 90px 0; }
.sng-hero .sng-kicker { color: var(--sng-yellow); }
.sng-hero h1 { color: #fff; font-size: 72px; font-weight: 900; line-height: .98; margin-bottom: 22px; text-shadow: 0 8px 28px rgba(0,0,0,.28); }
.sng-hero-text { max-width: 640px; color: rgba(255,255,255,.96); font-size: 22px; line-height: 1.55; margin-bottom: 28px; }
.sng-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 28px; }
.sng-hero-points { display: flex; flex-wrap: wrap; gap: 12px; margin: 0; padding: 0; list-style: none; }
.sng-hero-points li { display: inline-flex; align-items: center; gap: 9px; background: rgba(255,255,255,.13); border: 1px solid rgba(255,255,255,.24); border-radius: 999px; color: #fff; font-size: 15px; font-weight: 700; padding: 9px 14px; }

.sng-booking-strip { float: left; width: 100%; margin-top: -55px; position: relative; z-index: 5; }
.sng-booking-card { display: flex; align-items: center; justify-content: space-between; gap: 24px; background: #fff; border-radius: 20px; box-shadow: var(--sng-shadow); padding: 28px; }
.sng-booking-card h2 { color: var(--sng-blue); font-size: 30px; font-weight: 800; margin-bottom: 8px; }
.sng-booking-card p { color: #315b73; font-size: 16px; line-height: 1.55; margin-bottom: 0; }
.sng-booking-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 10px; min-width: 360px; }

.sng-info-card, .sng-content-card, .sng-price-card, .sng-location-tile { height: 100%; background: #fff; border: 1px solid rgba(5,63,95,.08); border-radius: var(--sng-radius); box-shadow: var(--sng-shadow); padding: 28px; }
.sng-info-card { text-align: center; }
.sng-info-card i { display:inline-flex; align-items:center; justify-content:center; width:58px; height:58px; margin-bottom:18px; background:rgba(131,198,105,.15); border-radius:50%; color:var(--sng-green); font-size:25px; }
.sng-info-card h2, .sng-content-card h2, .sng-price-card h2 { color: var(--sng-blue); font-size: 22px; font-weight: 800; margin-bottom: 12px; }
.sng-info-card p, .sng-content-card p, .sng-price-card p, .sng-content-card li { color:#315b73; font-size:16px; line-height:1.6; }
.sng-content-card ul { padding-left: 20px; list-style: disc; }
.sng-content-card li { margin-bottom: 8px; }

.sng-parks { background-color: #f8fcff; background-size: 100%; padding-top: 88px !important; }
.sng-parks .sng-section-title h2 { color: var(--sng-blue) !important; }
.sng-park-card { height: 100%; position: relative; overflow: hidden; }
.sng-park-card .popular-choice-bg { min-height: 190px; border-radius: 8px 8px 0 0; background-size: cover; background-position: center; }
.sng-park-card p { max-width: none !important; min-height: 82px; padding: 0 16px; }
.sng-featured-park { border: 2px solid rgba(131,198,105,.8); }
.sng-card-ribbon { position: absolute; top: 14px; left: 14px; z-index: 2; background: var(--sng-green); color: #fff; font-weight: 800; font-size: 13px; padding: 7px 12px; border-radius: 999px; }

.sng-plan { background: linear-gradient(135deg, #053f5f, #0d6f92); color: #fff; }
.sng-plan h2, .sng-plan p, .sng-plan .sng-kicker { color: #fff; }
.sng-checklist-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px; }
.sng-check-item { display:flex; gap:12px; align-items:flex-start; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); border-radius:14px; padding:18px; color:#fff; font-size:16px; line-height:1.45; }
.sng-check-item i { color: var(--sng-yellow); margin-top: 4px; }

.sng-page-hero { float:left; width:100%; min-height:420px; display:flex; align-items:center; background-position:center; background-size:cover; position:relative; color:#fff; padding:90px 0; }
.sng-page-hero:before { content:""; position:absolute; inset:0; background:rgba(5,63,95,.62); }
.sng-page-hero .container { position:relative; z-index:2; }
.sng-page-hero h1 { color:#fff; font-size:56px; font-weight:900; line-height:1.05; max-width:850px; margin-bottom:18px; }
.sng-page-hero p { color:rgba(255,255,255,.95); font-size:20px; line-height:1.55; max-width:760px; }
.sng-page-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }
.sng-meta-list { display:flex; flex-wrap:wrap; gap:12px; margin:22px 0 0; padding:0; list-style:none; }
.sng-meta-list li { display:inline-flex; gap:8px; align-items:center; background:rgba(255,255,255,.14); border-radius:999px; padding:9px 13px; color:#fff; font-weight:700; }

.sng-card-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:22px; }
.sng-locations-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:18px; }
.sng-location-tile h3 { color: var(--sng-blue); font-size: 21px; font-weight: 800; }
.sng-location-tile a { color: var(--sng-green); font-weight: 800; }
.sng-alert { background:#fff8e8; border-left:6px solid var(--sng-yellow); border-radius:12px; color:var(--sng-blue); font-size:17px; line-height:1.55; padding:20px 22px; }
.sng-price { color: var(--sng-green); font-size: 42px; font-weight: 900; margin-bottom: 10px; }
.sng-rule-list { list-style: disc; padding-left: 46px; }

.sng-mini-faq .card, .sng-accordion .card { border: 0; margin-bottom: 10px; background: transparent; }
.sng-mini-faq .card-header, .sng-accordion .card-header { padding:0; border:0; background:transparent; }
.sng-mini-faq .btn-link, .sng-accordion .btn-link { width:100%; background:#d0e2b8; color:#000; text-align:left; border-radius:10px; padding:15px 22px; font-weight:700; white-space:normal; }
.sng-mini-faq .card-body, .sng-accordion .card-body { background:#fff; border-radius:0 0 10px 10px; color:#315b73; font-size:16px; line-height:1.55; }

.sng-gallery img { border-radius: 12px; }
.sng-gallery-grid > div { margin-bottom: 15px; }
.sng-subscribe .subcribe-content h2 { color: #fff; }
.sng-footer-list a, .footer a { color: #fff; }
.footer a:hover { color: var(--sng-yellow); }
#myIframe { width: 100%; min-height: 800px; border: 0; }

/* Fix mobile nav contrast from the legacy responsive stylesheet. */
@media screen and (max-width: 767px) {
  .menubar ul li a { color: #fff !important; }
  .menubar ul li .contact-btn { color: var(--sng-blue) !important; background: var(--sng-yellow) !important; }
  .overlay-content { top: 18%; }
}

@media screen and (max-width: 991px) {
  .sng-hero h1 { font-size: 54px; }
  .sng-booking-card { align-items:flex-start; flex-direction:column; margin-top:20px; }
  .sng-booking-actions { justify-content:flex-start; min-width:0; }
  .sng-card-grid, .sng-locations-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .sng-checklist-grid { grid-template-columns: 1fr; }
}

@media screen and (max-width: 767px) {
  .sng-section, .sng-page-section { padding: 48px 0; }
  .sng-hero { min-height: 560px; }
  .sng-hero-content { padding: 70px 0; }
  .sng-hero h1, .sng-page-hero h1 { font-size: 38px; }
  .sng-hero-text, .sng-page-hero p { font-size: 17px; }
  .sng-section-title h2, .sng-plan h2, .sng-subscribe h2 { font-size: 32px; }
  .sng-booking-strip { margin-top: 0; padding: 20px 0; }
  .sng-booking-card { padding: 22px; }
  .sng-booking-actions { width: 100%; }
  .sng-booking-actions .sng-btn { width: 100%; }
  .sng-card-grid, .sng-locations-grid { grid-template-columns: 1fr; }
}

/* --- v8 subpage/native-template fixes ---
   These rules intentionally use the existing template sections where possible.
   This prevents subpages from looking unstyled if the old template CSS is still controlling the page. */
.sng-location-banner { max-height: 310px; overflow: hidden; background: #053F5F; }
.sng-location-banner img { width: 100% !important; min-height: 260px; object-fit: cover; object-position: center; }
.sng-native-intro { margin: 55px 0 25px !important; }
.sng-wide-title { max-width: 980px !important; }
.sng-wide-title h1 { font-size: 42px !important; line-height: 1.15 !important; color: #053F5F !important; font-weight: 800 !important; margin-bottom: 18px !important; }
.sng-wide-title p { max-width: 860px !important; margin-left: auto !important; margin-right: auto !important; line-height: 1.7 !important; }
.sng-native-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 24px; }
.sng-native-actions .all-button { width: auto !important; max-width: none !important; min-width: 180px !important; padding: 0 22px !important; margin: 0 !important; }
.sng-green-button { background: #83C669 !important; color: #fff !important; }
.sng-native-details { margin: 35px 0 45px !important; }
.sng-native-card { height: 100%; min-height: 210px; background: #fff; border-radius: 14px; box-shadow: 0 10px 24px rgba(5,63,95,.14); border: 1px solid rgba(5,63,95,.08); padding: 30px 24px; text-align: center; }
.sng-native-card i { display: inline-flex; align-items: center; justify-content: center; width: 58px; height: 58px; border-radius: 50%; background: rgba(131,198,105,.16); color: #83C669; font-size: 25px; margin-bottom: 18px; }
.sng-native-card h2 { color: #053F5F !important; font-size: 24px !important; font-weight: 800 !important; margin-bottom: 12px !important; }
.sng-native-card p, .sng-native-card li { color: #315b73 !important; font-size: 16px !important; line-height: 1.65 !important; }
.sng-left-card { text-align: left; }
.sng-left-card ul { list-style: disc; padding-left: 22px; margin-top: 12px; }
.sng-left-card li { margin-bottom: 8px; }
.sng-visit-grid { margin-top: 20px; }
.sng-alert { margin: 0 0 30px !important; background: #fff8e8 !important; border-left: 6px solid #FDBC44 !important; border-radius: 12px !important; color: #053F5F !important; font-size: 17px !important; line-height: 1.55 !important; padding: 20px 22px !important; box-shadow: 0 8px 20px rgba(5,63,95,.08); }

/* Strong fallback for any pages still using the v7 custom hero. */
.sng-page-hero { float:left !important; width:100% !important; min-height:420px !important; display:flex !important; align-items:center !important; background-position:center !important; background-size:cover !important; position:relative !important; color:#fff !important; padding:90px 0 !important; overflow:hidden !important; }
.sng-page-hero:before { content:"" !important; position:absolute !important; top:0 !important; right:0 !important; bottom:0 !important; left:0 !important; background:rgba(5,63,95,.66) !important; z-index:1 !important; }
.sng-page-hero .container { position:relative !important; z-index:2 !important; }
.sng-page-hero h1, .sng-page-hero p, .sng-page-hero li, .sng-page-hero .sng-kicker { color:#fff !important; }
.sng-page-hero h1 { font-size:56px !important; font-weight:900 !important; line-height:1.05 !important; max-width:850px !important; margin-bottom:18px !important; }
.sng-content-card, .sng-price-card, .sng-info-card { background:#fff !important; border:1px solid rgba(5,63,95,.08) !important; border-radius:16px !important; box-shadow:0 12px 30px rgba(5,63,95,.14) !important; padding:28px !important; }
.sng-card-grid { display:grid !important; grid-template-columns:repeat(3,minmax(0,1fr)) !important; gap:22px !important; }

@media screen and (max-width: 767px) {
  .sng-location-banner { max-height: 220px; }
  .sng-location-banner img { min-height: 190px; }
  .sng-native-intro { margin: 38px 0 20px !important; }
  .sng-wide-title h1 { font-size: 30px !important; }
  .sng-native-actions { display: block; }
  .sng-native-actions .all-button { width: 100% !important; margin-bottom: 12px !important; }
  .sng-card-grid { grid-template-columns:1fr !important; }
}


/* --- v9 layout/content improvements --- */
.sng-booking-card-v9 { align-items: stretch !important; gap: 28px !important; }
.sng-booking-copy { flex: 1 1 280px; }
.sng-booking-groups { display: grid; grid-template-columns: 1.15fr .85fr; gap: 18px; align-items: stretch; flex: 1.4 1 520px; }
.sng-booking-groups h3 { color:#053F5F; font-weight:800; font-size:18px; margin-bottom:10px; }
.sng-private-booking { background:#fff8e8; border:1px solid rgba(253,188,68,.35); border-radius:16px; padding:18px; }
.sng-private-booking p { color:#315b73; font-size:14px; line-height:1.5; margin-bottom:12px; }
.sng-parks-v9 .sng-section-title { max-width: 960px; margin: 0 auto 34px; text-align:center; }
.sng-public-parks { display:grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap:22px; margin-bottom:24px; }
.sng-location-card { position:relative; background:#fff; border:1px solid rgba(5,63,95,.09); border-radius:16px; box-shadow:0 12px 30px rgba(5,63,95,.12); padding:28px; height:100%; }
.sng-location-card h3 { color:#053F5F; font-weight:900; font-size:26px; margin-bottom:12px; }
.sng-location-card p, .sng-location-card li { color:#315b73; font-size:16px; line-height:1.65; }
.sng-location-card ul { list-style: disc; padding-left:20px; margin:16px 0 22px; }
.sng-resort-card { display:flex; align-items:center; justify-content:space-between; gap:24px; background:#f8fcff; border-left:7px solid #FDBC44; }
.sng-private-badge, .sng-hero-badge { display:inline-block; margin-left:10px; padding:7px 12px; border-radius:999px; background:#fff8e8; color:#053F5F; font-weight:800; font-size:13px; vertical-align:middle; }
.sng-timeline { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px; }
.sng-timeline div { background:#fff; border-radius:16px; padding:22px; box-shadow:0 10px 24px rgba(5,63,95,.10); border:1px solid rgba(5,63,95,.08); }
.sng-timeline strong { display:block; color:#83C669; font-size:24px; margin-bottom:10px; }
.sng-timeline p { color:#315b73; line-height:1.6; }
.sng-faq-clean { margin: 45px 0 70px !important; }
.sng-faq-clean .card { margin-bottom:12px !important; border-radius:12px !important; overflow:hidden; box-shadow:0 6px 16px rgba(5,63,95,.08); }
.sng-faq-clean .btn-link { font-size:18px !important; line-height:1.35 !important; padding:18px 24px !important; }
.sng-faq-clean .card-body { padding:20px 24px !important; font-size:16px !important; line-height:1.65 !important; color:#315b73 !important; }
.sng-faq-chooser { margin-top:-50px; position:relative; z-index:3; }
.sng-jobs-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:22px; }
.sng-job-listing { background:#fff; border:1px solid rgba(5,63,95,.09); border-radius:16px; box-shadow:0 12px 30px rgba(5,63,95,.12); padding:28px; }
.sng-job-listing h3 { color:#053F5F; font-size:25px; font-weight:900; margin-bottom:8px; }
.sng-job-meta-text { color:#83C669 !important; font-weight:800; margin-bottom:14px !important; }
.sng-job-listing ul { list-style:disc; padding-left:22px; margin-top:14px; }
.sng-job-listing li { color:#315b73; line-height:1.6; margin-bottom:6px; }
.sng-application-wrap { max-width:900px; margin:0 auto; background:#fff; border:1px solid rgba(5,63,95,.08); border-radius:18px; box-shadow:0 12px 30px rgba(5,63,95,.14); padding:34px; }
.sng-application-intro { text-align:center; margin-bottom:28px; }
.sng-application-intro h2 { color:#053F5F; font-weight:900; font-size:34px; }
.sng-application-form label, .sng-application-form legend { display:block; color:#053F5F; font-weight:800; margin-bottom:10px; }
.sng-application-form input[type="text"], .sng-application-form input[type="email"], .sng-application-form input[type="tel"], .sng-application-form input[type="file"], .sng-application-form textarea { width:100%; border:1px solid rgba(5,63,95,.18); border-radius:10px; padding:12px 14px; margin-top:7px; margin-bottom:18px; color:#183548; }
.sng-application-form fieldset { border:1px solid rgba(5,63,95,.12); border-radius:14px; padding:18px; margin-bottom:20px; }
.sng-checkbox-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px 18px; }
.sng-checkbox-grid label { font-weight:600; margin:0; color:#315b73; }
.sng-checkbox-grid input { margin-right:8px; }
.sng-form-note { display:block; color:#587386; font-size:13px; margin-top:-8px; margin-bottom:18px; }
.sng-honeypot { position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.sng-success-box, .sng-error-box { border-radius:14px; padding:22px; margin-bottom:22px; }
.sng-success-box { background:#effbea; border-left:6px solid #83C669; color:#053F5F; }
.sng-error-box { background:#fff3f1; border-left:6px solid #d9534f; color:#053F5F; }
.sng-error-box ul { padding-left:20px; }
@media screen and (max-width: 991px) { .sng-booking-groups, .sng-public-parks, .sng-timeline, .sng-jobs-grid { grid-template-columns:1fr; } .sng-resort-card { display:block; } .sng-resort-card .sng-btn { margin-top:16px; } }
@media screen and (max-width: 767px) { .sng-checkbox-grid { grid-template-columns:1fr; } .sng-application-wrap { padding:22px; } }


/* --- v10 waiver, homepage, FAQ, safety, and hiring refinements --- */
.sng-waiver-alert { float:left; width:100%; background:#053F5F; color:#fff; padding:10px 0; font-size:15px; line-height:1.45; text-align:center; }
.sng-waiver-alert a { color:#FDBC44; font-weight:900; text-decoration:underline; }
.sng-waiver-alert strong { color:#fff; font-weight:900; }
.sng-info-card a, .sng-alert a, .sng-content-card a, .sng-native-card a { color:#0d6f92; font-weight:800; text-decoration:underline; }
.sng-faq-booking-card { margin-top:0 !important; }
.sng-steps-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:18px; }
.sng-step { background:#fff; border:1px solid rgba(5,63,95,.09); border-radius:16px; box-shadow:0 10px 24px rgba(5,63,95,.10); padding:24px; }
.sng-step strong { display:inline-block; background:#FDBC44; color:#053F5F; border-radius:999px; padding:7px 13px; margin-bottom:14px; font-weight:900; }
.sng-step p { color:#315b73; line-height:1.65; margin:0; }
.sng-numbered-rules { counter-reset:item; padding-left:48px !important; }
.sng-numbered-rules li { margin-bottom:11px; }
.sng-apply-panel { display:none; }
.sng-apply-panel.is-open, .sng-show-application .sng-apply-panel, .sng-apply-panel:target { display:block; }
.sng-job-listing .sng-btn { margin-top:18px; }
.sng-turnstile-wrap { margin:18px 0 22px; }
.sng-application-form button[type="submit"] { border:0; cursor:pointer; }
.sng-error-box strong, .sng-success-box strong { font-weight:900; }
.sng-form-note { display:block !important; }
.sng-hero-actions .sng-btn-secondary { color:#fff !important; }
@media screen and (max-width: 991px) { .sng-steps-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media screen and (max-width: 767px) { .sng-waiver-alert { font-size:13px; padding:9px 12px; } .sng-steps-grid { grid-template-columns:1fr; } .sng-numbered-rules { padding-left:24px !important; } }

/* v11 Checkfront embedded booking widget */
.sng-checkfront-section {
  float: left;
  width: 100%;
  padding: 45px 0 25px;
  background: #ffffff;
}
.sng-checkfront-card {
  background: #ffffff;
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(5, 63, 95, 0.12);
  border: 1px solid rgba(5, 63, 95, 0.08);
  padding: 28px;
}
.sng-checkfront-heading {
  max-width: 900px;
  margin-bottom: 22px;
}
.sng-checkfront-heading h2 {
  color: #053F5F;
  font-weight: 800;
  margin: 5px 0 10px;
}
.sng-checkfront-heading p {
  color: #053F5F;
  font-size: 16px;
  line-height: 1.55;
}
.sng-waiver-inline {
  background: #fff6dd;
  border-left: 5px solid #FDBC44;
  padding: 12px 14px;
  border-radius: 10px;
}
.sng-checkfront-widget-wrap {
  width: 100%;
  min-height: 520px;
  overflow-x: auto;
}
#CHECKFRONT_WIDGET_01 {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .sng-checkfront-card {
    padding: 18px;
    border-radius: 14px;
  }
  .sng-checkfront-widget-wrap {
    min-height: 650px;
  }
}


/* --- v12 pricing and hiring modal refinements --- */
.sng-pricing-strip { float:left; width:100%; padding:24px 0 10px; background:#fff; }
.sng-pricing-card { display:flex; align-items:center; justify-content:space-between; gap:24px; background:#053F5F; color:#fff; border-radius:18px; padding:28px 34px; box-shadow:0 16px 34px rgba(5,63,95,.20); }
.sng-pricing-card .sng-kicker, .sng-pricing-card h2, .sng-pricing-card p { color:#fff !important; }
.sng-pricing-card h2 { font-size:32px; font-weight:900; margin:4px 0 8px; }
.sng-pricing-card p { font-size:16px; line-height:1.55; margin:0; max-width:680px; }
.sng-price-pills { display:flex; gap:14px; flex-shrink:0; }
.sng-price-pills div { min-width:130px; border-radius:16px; background:#fff; color:#053F5F; text-align:center; padding:16px 18px; box-shadow:0 8px 20px rgba(0,0,0,.12); }
.sng-price-pills strong { display:block; font-size:34px; line-height:1; font-weight:900; color:#053F5F; }
.sng-price-pills span { display:block; margin-top:7px; font-size:13px; font-weight:800; color:#315b73; }
.sng-application-modal .modal-dialog { max-width:980px; }
.sng-application-modal .modal-content { border:0; border-radius:20px; overflow:hidden; box-shadow:0 24px 60px rgba(5,63,95,.35); }
.sng-application-modal .modal-header { background:#053F5F; color:#fff; border-bottom:0; padding:18px 24px; }
.sng-application-modal .modal-title { color:#fff; font-size:26px; font-weight:900; margin:0; }
.sng-application-modal .close { color:#fff; opacity:1; text-shadow:none; font-size:32px; }
.sng-application-modal .modal-body { max-height:calc(100vh - 120px); overflow-y:auto; padding:0; background:#f8fcff; }
.sng-application-wrap-modal { max-width:none; margin:0; border:0 !important; border-radius:0 !important; box-shadow:none !important; }
.sng-application-wrap-modal .sng-application-intro h2 { font-size:28px; }
button.all-button { border:0; cursor:pointer; }
@media screen and (max-width: 767px) {
  .sng-pricing-card { display:block; padding:24px; }
  .sng-price-pills { margin-top:18px; display:grid; grid-template-columns:1fr 1fr; }
  .sng-price-pills div { min-width:0; }
  .sng-application-modal .modal-dialog { margin:10px; }
  .sng-application-modal .modal-body { max-height:calc(100vh - 86px); }
}

/* === v17 targeted fixes: desktop waiver bar, popular badge, static reviews, directions blocks === */
.sng-v17-marker { display: none; }
.waiver-reminder-bar { clear: both; }

@media screen and (min-width: 768px) {
  .waiver-reminder-bar {
    margin-top: 58px;
    position: relative;
    z-index: 1;
  }
  .menubar.navbarbox {
    position: relative;
    z-index: 3;
  }
}

@media screen and (max-width: 767px) {
  .waiver-reminder-bar { margin-top: 0; }
}

.sng-card-ribbon {
  position: static !important;
  display: inline-flex !important;
  align-items: center;
  width: auto !important;
  margin: 0 0 16px 0 !important;
  padding: 7px 14px !important;
  line-height: 1.1 !important;
}

.sng-park-card h2,
.sng-park-card h3 {
  clear: both;
}

.sng-reviews-static.review-section {
  display: block !important;
  padding-top: 80px;
}

.sng-review-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 42px;
}

.sng-review-card {
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 12px 30px rgba(5, 63, 95, 0.12);
  border: 1px solid rgba(5, 63, 95, 0.08);
  padding: 42px 26px 28px;
  text-align: center;
  position: relative;
  min-height: 250px;
}

.sng-review-quote {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 4px 16px rgba(5, 63, 95, 0.18);
  color: #5BCBF3;
  font-size: 54px;
  font-weight: 900;
  line-height: 70px;
  position: absolute;
  top: -29px;
  left: 50%;
  transform: translateX(-50%);
}

.sng-review-card h3 {
  color: #000;
  font-weight: 800;
  font-size: 19px;
  line-height: 1.25;
  margin-bottom: 12px;
}

.sng-review-card p {
  color: #315b73;
  font-size: 15px;
  line-height: 1.55;
}

.sng-review-name {
  color: #1EB6E7 !important;
  font-weight: 800;
  margin-top: 18px !important;
  margin-bottom: 0 !important;
}

.sng-directions-card {
  background: #fff;
  border: 1px solid rgba(5,63,95,.08);
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(5,63,95,.14);
  padding: 28px;
  height: 100%;
}

.sng-directions-card h2,
.sng-directions-card h3 {
  color: #053F5F;
  font-weight: 900;
  margin-bottom: 12px;
}

.sng-directions-card p {
  color: #315b73;
  font-size: 16px;
  line-height: 1.6;
}

.sng-map-embed {
  border: 0;
  width: 100%;
  min-height: 320px;
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(5,63,95,.12);
}

@media screen and (max-width: 991px) {
  .sng-review-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media screen and (max-width: 767px) {
  .sng-review-grid { grid-template-columns: 1fr; }
  .sng-reviews-static.review-section { padding-top: 60px; }
}

/* === v18 polish: single waiver topbar, aligned location cards, clean reviews === */
.sng-v18-marker { display:none; }
.topbar.waiver-reminder-bar {
  float:left;
  width:100%;
  background:#053F5F !important;
  color:#fff !important;
  padding:8px 0 !important;
  min-height:0 !important;
  line-height:1.4 !important;
  text-align:center;
}
.topbar.waiver-reminder-bar .container,
.sng-top-waiver-inner {
  display:flex;
  align-items:center;
  justify-content:center;
}
.topbar.waiver-reminder-bar p {
  float:none !important;
  width:auto !important;
  margin:0 !important;
  padding:0 !important;
  color:#fff !important;
  font-size:14px !important;
  line-height:1.4 !important;
  font-weight:500 !important;
}
.topbar.waiver-reminder-bar a {
  color:#FDBC44 !important;
  font-weight:900 !important;
  text-decoration:underline !important;
}
.topbar.waiver-reminder-bar strong { color:#fff !important; font-weight:900 !important; }
.sng-waiver-alert:not(.waiver-reminder-bar) { display:none !important; }
@media screen and (min-width:768px) {
  .waiver-reminder-bar { margin-top:0 !important; }
}
@media screen and (max-width:767px) {
  .topbar.waiver-reminder-bar { padding:9px 12px !important; }
  .topbar.waiver-reminder-bar p { font-size:13px !important; }
}

/* Location card alignment */
.sng-location-card,
.sng-park-card {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.sng-location-card .sng-card-ribbon,
.sng-park-card .sng-card-ribbon {
  position:absolute !important;
  top:20px !important;
  right:22px !important;
  margin:0 !important;
  padding:7px 14px !important;
  z-index:2;
}
.sng-location-card h2,
.sng-location-card h3,
.sng-park-card h2,
.sng-park-card h3 {
  margin-top:0 !important;
  padding-right:95px;
  min-height:40px;
}
.sng-location-card .sng-button,
.sng-park-card .sng-button,
.sng-location-card .all-button,
.sng-park-card .all-button { margin-top:auto; }
@media screen and (max-width:767px) {
  .sng-location-card .sng-card-ribbon,
  .sng-park-card .sng-card-ribbon { position:static !important; margin-bottom:14px !important; }
  .sng-location-card h2,
  .sng-location-card h3,
  .sng-park-card h2,
  .sng-park-card h3 { padding-right:0; min-height:0; }
}

/* Reviews: remove old carousel/sidebar behaviour and force a clean card layout */
.sng-review-section {
  float:left;
  width:100%;
  background:#fff;
  padding:80px 0 70px;
  overflow:hidden;
}
.sng-review-section * { box-sizing:border-box; }
.sng-review-section .container { max-width:1140px; }
.sng-review-heading { text-align:center; max-width:760px; margin:0 auto 44px; }
.sng-review-heading span { display:block; color:#5BCBF3; font-weight:900; letter-spacing:.12em; text-transform:uppercase; margin-bottom:8px; }
.sng-review-heading h2 { color:#053F5F; font-weight:900; font-size:42px; line-height:1.1; margin:0 0 12px; }
.sng-review-heading p { color:#315b73; font-size:18px; line-height:1.6; margin:0; }
.sng-review-grid-clean {
  display:grid !important;
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  gap:26px !important;
  width:100% !important;
  float:none !important;
  clear:both !important;
  margin:0 auto !important;
}
.sng-review-card-clean {
  position:relative;
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
  float:none !important;
  background:#fff;
  border:1px solid rgba(5,63,95,.08);
  border-radius:18px;
  box-shadow:0 14px 34px rgba(5,63,95,.12);
  padding:50px 28px 30px;
  text-align:center;
  min-height:280px;
}
.sng-review-mark {
  position:absolute;
  top:-28px;
  left:50%;
  transform:translateX(-50%);
  width:58px;
  height:58px;
  border-radius:50%;
  background:#fff;
  color:#5BCBF3;
  box-shadow:0 6px 18px rgba(5,63,95,.18);
  font-size:58px;
  font-weight:900;
  line-height:76px;
  font-family:Georgia, serif;
}
.sng-review-card-clean h3 { color:#053F5F; font-weight:900; font-size:20px; line-height:1.25; margin:0 0 12px; }
.sng-review-card-clean p { color:#315b73; font-size:16px; line-height:1.6; margin:0 0 18px; }
.sng-review-card-clean strong { display:block; color:#1EB6E7; font-weight:900; margin-top:auto; }
@media screen and (max-width:991px) { .sng-review-grid-clean { grid-template-columns:1fr !important; max-width:620px; } }
@media screen and (max-width:767px) {
  .sng-review-section { padding:60px 0 50px; }
  .sng-review-heading h2 { font-size:34px; }
}

/* === sng-v26-marker: location alignment, clean reviews, hiring modal polish === */
.sng-v26-marker { display:none; }
.sng-location-card.featured, .sng-location-card { padding-top:32px !important; }
.sng-location-card .sng-card-ribbon, .sng-location-card.featured .sng-card-ribbon { display:none !important; }
.sng-location-card h3 { margin-top:0 !important; }
.sng-review-section, .sng-review-section * { box-sizing:border-box !important; }
.sng-review-section { float:none !important; width:100% !important; clear:both !important; padding:84px 0 76px !important; background:#fff !important; overflow:visible !important; }
.sng-review-section .container { max-width:1140px !important; margin:0 auto !important; }
.sng-review-heading { text-align:center !important; max-width:760px !important; margin:0 auto 42px !important; }
.sng-review-heading span { display:inline-block !important; color:#83C669 !important; font-weight:900 !important; letter-spacing:.12em !important; text-transform:uppercase !important; margin-bottom:10px !important; }
.sng-review-heading h2 { color:#5BCBF3 !important; font-weight:900 !important; font-size:44px !important; line-height:1.08 !important; margin:0 0 12px !important; }
.sng-review-heading p { color:#315b73 !important; font-size:18px !important; line-height:1.65 !important; margin:0 !important; }
.sng-review-grid-clean { display:grid !important; grid-template-columns:repeat(3,minmax(0,1fr)) !important; gap:28px !important; width:100% !important; max-width:1100px !important; margin:0 auto !important; float:none !important; transform:none !important; }
.sng-review-card-clean { position:relative !important; display:flex !important; flex-direction:column !important; width:auto !important; min-width:0 !important; max-width:none !important; min-height:285px !important; padding:58px 28px 28px !important; background:#fff !important; border:1px solid rgba(5,63,95,.08) !important; border-radius:18px !important; box-shadow:0 18px 40px rgba(5,63,95,.13) !important; text-align:center !important; overflow:visible !important; }
.sng-review-mark { position:absolute !important; top:-24px !important; left:50% !important; transform:translateX(-50%) !important; width:58px !important; height:58px !important; border-radius:50% !important; background:#fff !important; color:#5BCBF3 !important; box-shadow:0 6px 18px rgba(5,63,95,.14) !important; font-size:58px !important; line-height:74px !important; font-weight:900 !important; text-align:center !important; }
.sng-review-card-clean h3 { color:#053F5F !important; font-weight:900 !important; font-size:22px !important; line-height:1.25 !important; margin:0 0 14px !important; }
.sng-review-card-clean p { color:#315b73 !important; font-size:16px !important; line-height:1.65 !important; margin:0 0 18px !important; }
.sng-review-card-clean strong { display:block !important; color:#1EB6E7 !important; font-weight:900 !important; margin-top:auto !important; }
.sng-application-modal .modal-dialog { max-width:980px !important; }
.sng-application-modal .modal-content { border:0 !important; border-radius:22px !important; overflow:hidden !important; box-shadow:0 28px 80px rgba(5,63,95,.38) !important; }
.sng-application-modal .modal-header { background:#053F5F !important; color:#fff !important; border:0 !important; padding:18px 24px !important; align-items:center !important; }
.sng-application-modal .modal-title { color:#fff !important; font-size:24px !important; font-weight:900 !important; }
.sng-application-modal .sng-modal-close, .sng-application-modal .close { color:#fff !important; opacity:1 !important; text-shadow:none !important; font-size:34px !important; line-height:1 !important; padding:0 !important; margin:0 !important; cursor:pointer !important; }
.sng-application-modal .modal-body { background:#f7fbfd !important; padding:0 !important; max-height:calc(100vh - 110px) !important; overflow-y:auto !important; }
.sng-application-wrap-modal { background:transparent !important; border:0 !important; box-shadow:none !important; padding:34px !important; }
.sng-form-grid { display:grid !important; grid-template-columns:repeat(2,minmax(0,1fr)) !important; gap:18px 22px !important; }
.sng-application-modal label { font-weight:800 !important; color:#053F5F !important; }
.sng-application-modal input[type="text"], .sng-application-modal input[type="email"], .sng-application-modal input[type="tel"], .sng-application-modal input[type="number"], .sng-application-modal input[type="file"], .sng-application-modal textarea { border:1px solid rgba(5,63,95,.16) !important; border-radius:12px !important; padding:12px 14px !important; background:#fff !important; box-shadow:none !important; }
.sng-application-modal fieldset { background:#fff !important; border:1px solid rgba(5,63,95,.09) !important; border-radius:16px !important; padding:18px !important; margin:24px 0 !important; }
.sng-application-modal fieldset legend { width:auto !important; padding:0 10px !important; margin:0 0 8px !important; font-size:22px !important; color:#053F5F !important; font-weight:900 !important; }
.sng-checkbox-grid { display:grid !important; grid-template-columns:repeat(2,minmax(0,1fr)) !important; gap:12px !important; }
.sng-checkbox-grid label { display:flex !important; align-items:flex-start !important; gap:10px !important; min-height:54px !important; padding:14px !important; background:#f8fcff !important; border:1px solid rgba(5,63,95,.12) !important; border-radius:14px !important; cursor:pointer !important; line-height:1.3 !important; }
.sng-checkbox-grid label:hover { border-color:#83C669 !important; box-shadow:0 8px 18px rgba(5,63,95,.08) !important; }
.sng-checkbox-grid input[type="checkbox"] { width:18px !important; height:18px !important; margin:1px 0 0 !important; accent-color:#83C669 !important; flex:0 0 auto !important; }
.sng-form-note { margin-top:8px !important; color:#587386 !important; font-size:13px !important; }
@media screen and (max-width:991px){ .sng-review-grid-clean{ grid-template-columns:1fr !important; max-width:620px !important; } .sng-form-grid, .sng-checkbox-grid{ grid-template-columns:1fr !important; } }
@media screen and (max-width:575px){ .sng-review-heading h2{font-size:34px !important;} .sng-application-wrap-modal{padding:22px 16px !important;} .sng-application-modal .modal-dialog{margin:8px !important;} }

/* === sng-v26-marker: FAQ reliability, gift cards, weather policy, donation requests, banner crop fixes === */
.sng-gift-weather-strip{float:left;width:100%;clear:both;padding:52px 0;background:#f3f9fc;}
.sng-gift-weather-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:stretch;}
.sng-gift-card-cta,.sng-weather-policy-cta{background:#fff;border:1px solid rgba(5,63,95,.08);border-radius:22px;padding:34px;box-shadow:0 18px 42px rgba(5,63,95,.10);}
.sng-gift-card-cta{background:linear-gradient(135deg,#fff 0%,#fff8e6 100%);border-left:6px solid #FDBC44;}
.sng-weather-policy-cta{background:linear-gradient(135deg,#fff 0%,#eef8ff 100%);border-left:6px solid #5BCBF3;}
.sng-gift-card-cta h2,.sng-weather-policy-cta h2{color:#053F5F;font-weight:900;font-size:30px;line-height:1.15;margin:0 0 12px;}
.sng-gift-card-cta p,.sng-weather-policy-cta p{color:#315b73;font-size:17px;line-height:1.6;margin-bottom:20px;}
.sng-card-icon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;background:#e9f8e5;color:#83C669;border-radius:50%;font-size:22px;margin-bottom:16px;}
.sng-alert-success,.sng-alert-error{border-radius:14px;padding:16px 18px;margin-bottom:22px;}
.sng-alert-success{background:#e8f8e4;color:#195c22;border:1px solid #bfe8b7;}
.sng-alert-error{background:#fff0f0;color:#8b1e1e;border:1px solid #f4b8b8;}
.sng-donation-form label{display:block;color:#053F5F;font-weight:800;margin-bottom:16px;}
.sng-donation-form input,.sng-donation-form textarea{display:block;width:100%;margin-top:7px;padding:12px 14px;border:1px solid #d9e5eb;border-radius:10px;color:#053F5F;background:#fff;font-weight:500;}
.sng-donation-form input:focus,.sng-donation-form textarea:focus{outline:3px solid rgba(91,203,243,.28);border-color:#5BCBF3;}
.sng-donation-form .cf-turnstile{margin:18px 0;}
.sng-hp-field{position:absolute!important;left:-99999px!important;opacity:0!important;height:0!important;width:0!important;}
.sng-about-banner img{object-position:center 42%!important;}
.sng-faq-banner img{object-position:center 42%!important;}
.sng-hiring-banner img{object-position:center 35%!important;}
.sng-gift-banner img,.sng-donation-banner img{object-position:center 42%!important;}
.sng-faq-clean .collapse:not(.show){display:none;}
.sng-faq-clean .collapse.show{display:block;}
.sng-faq-clean .card[id="weather-policy"]{border-left:6px solid #5BCBF3!important;}
.sng-faq-clean .card[id="weather-policy"] .btn-link:after{content:'Important';float:right;background:#FDBC44;color:#053F5F;border-radius:999px;padding:2px 10px;font-size:12px;line-height:22px;margin-top:12px;margin-right:12px;}
@media screen and (max-width:991px){.sng-gift-weather-grid{grid-template-columns:1fr;}.sng-gift-card-cta,.sng-weather-policy-cta{padding:28px;}}
@media screen and (max-width:575px){.sng-gift-weather-strip{padding:36px 0;}.sng-gift-card-cta h2,.sng-weather-policy-cta h2{font-size:26px;}}


/* === sng-v26-marker: gallery modal, gift card embed, and cookie banner === */
.sng-v26-marker { display:none; }

.sng-checkfront-embed-card {
  max-width: 1040px;
}
.sng-checkfront-embed-card #CHECKFRONT_WIDGET_01 {
  margin-top: 22px;
  min-height: 360px;
  padding: 18px;
  background: #fff;
  border: 1px solid rgba(5,63,95,.10);
  border-radius: 18px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.65);
}

.sng-gallery a {
  display:block;
  position:relative;
  cursor:zoom-in;
}
.sng-gallery a:after {
  content:'View';
  position:absolute;
  right:12px;
  bottom:12px;
  background:rgba(5,63,95,.88);
  color:#fff;
  border-radius:999px;
  padding:6px 12px;
  font-size:13px;
  font-weight:800;
  opacity:0;
  transform:translateY(6px);
  transition:all .2s ease;
}
.sng-gallery a:hover:after,
.sng-gallery a:focus:after {
  opacity:1;
  transform:translateY(0);
}

.sng-gallery-lightbox {
  position:fixed;
  inset:0;
  z-index:999999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:72px 86px;
  background:rgba(4,31,47,.88);
}
.sng-gallery-lightbox[hidden] { display:none !important; }
.sng-gallery-lightbox img {
  display:block;
  max-width:100%;
  max-height:100%;
  border-radius:18px;
  box-shadow:0 24px 80px rgba(0,0,0,.42);
}
.sng-gallery-close,
.sng-gallery-prev,
.sng-gallery-next {
  position:absolute;
  border:0;
  background:#fff;
  color:#053F5F;
  box-shadow:0 10px 30px rgba(0,0,0,.20);
  cursor:pointer;
  font-weight:900;
}
.sng-gallery-close {
  top:22px;
  right:24px;
  width:48px;
  height:48px;
  border-radius:50%;
  font-size:34px;
  line-height:44px;
}
.sng-gallery-prev,
.sng-gallery-next {
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:70px;
  border-radius:18px;
  font-size:50px;
  line-height:58px;
}
.sng-gallery-prev { left:22px; }
.sng-gallery-next { right:22px; }
.sng-lightbox-open { overflow:hidden; }

.sng-cookie-banner {
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:999999998;
  padding:18px;
  background:linear-gradient(180deg, rgba(5,63,95,0), rgba(5,63,95,.18));
}
.sng-cookie-banner[hidden] { display:none !important; }
.sng-cookie-card {
  max-width:1120px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:20px;
  align-items:center;
  background:#fff;
  border:1px solid rgba(5,63,95,.12);
  border-left:6px solid #5BCBF3;
  border-radius:20px;
  padding:20px 22px;
  box-shadow:0 20px 60px rgba(5,63,95,.22);
}
.sng-cookie-card h2 {
  margin:0 0 6px;
  color:#053F5F;
  font-size:22px;
  font-weight:900;
}
.sng-cookie-card p {
  margin:0;
  color:#315b73;
  line-height:1.55;
}
.sng-cookie-actions {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
@media screen and (max-width:767px) {
  .sng-gallery-lightbox { padding:68px 16px; }
  .sng-gallery-prev,.sng-gallery-next { width:42px;height:58px;font-size:40px;border-radius:14px; }
  .sng-gallery-prev { left:8px; }
  .sng-gallery-next { right:8px; }
  .sng-cookie-card { grid-template-columns:1fr; }
  .sng-cookie-actions { justify-content:flex-start; }
}


/* === sng-v26-marker: Sherkston dual-pass booking widgets === */
.sng-v26-marker { display: none; }
.sng-booking-embed-section { padding: 70px 0; background: #f7fbfe; }
.sng-sherkston-pass-row { align-items: stretch; }
.sng-pass-choice-card { min-height: 100%; border-top: 6px solid #83C669; }
.sng-pass-choice-card h2 { color: #053F5F; font-weight: 700; margin-bottom: 8px; }
.sng-price-line { font-size: 34px !important; line-height: 1.1 !important; font-weight: 800 !important; color: #053F5F !important; margin: 10px 0 15px !important; }
.sng-checkfront-loader { color: #053F5F; font-weight: 600; margin-top: 18px; }
#CHECKFRONT_WIDGET_SHERKSTON_HOMEOWNER,
#CHECKFRONT_WIDGET_SHERKSTON_GUEST { margin-top: 20px; }
@media screen and (max-width: 767px) {
  .sng-booking-embed-section { padding: 45px 0; }
  .sng-price-line { font-size: 28px !important; }
}

/* === sng-v26-marker: selected Sherkston booking widget and policy updates === */
.sng-v26-marker { display:none; }
.sng-pass-selector-row { align-items: stretch; }
.sng-pass-select-card {
  width:100%;
  min-height:100%;
  display:flex;
  flex-direction:column;
  gap:10px;
  text-align:left;
  background:#fff;
  border:2px solid rgba(5,63,95,.12);
  border-top:6px solid #83C669;
  border-radius:18px;
  padding:26px;
  box-shadow:0 12px 30px rgba(5,63,95,.10);
  color:#053F5F;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.sng-pass-select-card:hover,
.sng-pass-select-card:focus {
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(5,63,95,.17);
  border-color:#5BCBF3;
  outline:3px solid rgba(91,203,243,.25);
}
.sng-pass-select-card.is-selected {
  border-color:#FDBC44;
  border-top-color:#FDBC44;
  box-shadow:0 18px 42px rgba(253,188,68,.25);
}
.sng-pass-select-card strong {
  font-size:28px;
  font-weight:900;
  line-height:1.1;
}
.sng-pass-select-card .sng-price-line {
  display:block;
  margin:0 !important;
}
.sng-pass-select-card em {
  display:inline-flex;
  width:max-content;
  margin-top:auto;
  padding:10px 18px;
  border-radius:999px;
  background:#053F5F;
  color:#fff;
  font-style:normal;
  font-weight:800;
}
.sng-selected-widget-panel {
  margin-top:10px;
  border-top:6px solid #5BCBF3;
}
.sng-selected-widget-panel[hidden] { display:none !important; }
.sng-selected-widget-heading h2 {
  color:#053F5F;
  font-weight:900;
  margin-bottom:8px;
}
.sng-policy-warning {
  border-left:6px solid #FDBC44;
}
.sng-rule-section-heading {
  margin-top:34px;
}
.sng-rule-note-box {
  background:#fff8e7;
  border:1px solid rgba(253,188,68,.45);
  border-radius:18px;
  padding:24px;
  color:#053F5F;
}
@media screen and (max-width:767px) {
  .sng-pass-select-card { padding:22px; }
  .sng-pass-select-card strong { font-size:24px; }
}

/* === sng-v26-marker: pricing corrections and Timmins removal === */
.sng-v26-marker{display:none;}
.sng-price-line + small, .sng-pricing-card small, .sng-location-card small{display:block;font-size:12px;line-height:1.25;margin-top:2px;opacity:.78;font-weight:600;}

/* === sng-v26-marker: pricing update and Sherkston pass selector visibility === */
.sng-v26-marker{display:none;}
.sng-pass-select-card em,
.sng-sherkston-pass-row .sng-pass-select-card em{
  display:flex !important;
  align-items:center;
  justify-content:center;
  width:100% !important;
  margin-top:auto !important;
  padding:14px 18px !important;
  border-radius:14px !important;
  background:#FDBC44 !important;
  color:#053F5F !important;
  font-style:normal !important;
  font-weight:900 !important;
  box-shadow:0 8px 18px rgba(253,188,68,.28) !important;
}
.sng-pass-select-card[data-sherkston-pass="guest"] em{
  background:#5BCBF3 !important;
  color:#053F5F !important;
  box-shadow:0 8px 18px rgba(91,203,243,.28) !important;
}
.sng-pass-select-card:hover em,
.sng-pass-select-card:focus em{
  transform:translateY(-1px);
  filter:brightness(1.02);
}
.sng-pass-select-card.is-selected em{
  background:#053F5F !important;
  color:#fff !important;
  box-shadow:0 10px 24px rgba(5,63,95,.28) !important;
}
.sng-pass-select-card .sng-kicker{
  color:#3a7ab8;
  font-weight:900;
}

/* sng-v31-marker: Turnstile visibility fixes for hiring modal */
.sng-v31-marker{display:none;}
.sng-turnstile-wrap {
  margin: 18px 0 8px;
  padding: 16px;
  border: 1px solid rgba(5, 63, 95, 0.14);
  border-radius: 14px;
  background: #f8fbfd;
}
.sng-turnstile-box {
  min-height: 70px;
  display: flex;
  align-items: center;
}
.sng-turnstile-help {
  margin: 8px 0 0;
  font-size: 13px;
  line-height: 1.4;
  color: #45586a;
}
.sng-turnstile-warning { color: #9b1c1c !important; font-weight: 700; }

/* sng-v31-marker: stronger booking button visibility */
.sng-v31-marker{display:none;}

/* Make primary booking buttons feel clickable and stand out from white/light cards */
.sng-btn,
.sng-location-card .sng-btn,
.sng-booking-actions .sng-btn,
.sng-private-booking .sng-btn,
.sng-resort-card .sng-btn,
.sng-gift-weather-strip .sng-btn,
.sng-content-card .sng-btn,
.sng-job-listing .sng-btn,
a.all-button {
  border-radius: 999px !important;
  font-weight: 800 !important;
  letter-spacing: .01em !important;
  text-decoration: none !important;
  border: 2px solid transparent !important;
  box-shadow: 0 12px 24px rgba(5,63,95,.16) !important;
}

.sng-btn-primary,
.sng-location-card .sng-btn-primary,
.sng-booking-actions .sng-btn-primary,
.sng-content-card .sng-btn-primary,
.sng-job-listing .sng-btn-primary,
a.all-button {
  background: linear-gradient(135deg, #FDBC44 0%, #f5a900 100%) !important;
  color: #053F5F !important;
  border-color: #d88d00 !important;
}

.sng-btn-primary:hover,
.sng-location-card .sng-btn-primary:hover,
.sng-booking-actions .sng-btn-primary:hover,
.sng-content-card .sng-btn-primary:hover,
.sng-job-listing .sng-btn-primary:hover,
a.all-button:hover {
  background: linear-gradient(135deg, #83C669 0%, #5fab47 100%) !important;
  color: #053F5F !important;
  border-color: #4f963b !important;
  transform: translateY(-2px);
}

.sng-btn-light,
.sng-private-booking .sng-btn-light,
.sng-resort-card .sng-btn-light {
  background: #FDBC44 !important;
  color: #053F5F !important;
  border-color: #d88d00 !important;
}

.sng-btn-light:hover,
.sng-private-booking .sng-btn-light:hover,
.sng-resort-card .sng-btn-light:hover {
  background: #83C669 !important;
  color: #053F5F !important;
  border-color: #4f963b !important;
}

/* Sherkston pass chooser: make both options impossible to miss */
.sng-pass-select-card .sng-pass-select-btn,
.sng-pass-select-card button,
.sng-sherkston-pass-card .sng-btn,
.sng-sherkston-pass-card button {
  background: linear-gradient(135deg, #FDBC44 0%, #f5a900 100%) !important;
  color: #053F5F !important;
  border: 2px solid #d88d00 !important;
  border-radius: 999px !important;
  font-weight: 900 !important;
  box-shadow: 0 12px 24px rgba(253,188,68,.32) !important;
}

.sng-pass-select-card:nth-child(2) .sng-pass-select-btn,
.sng-pass-select-card:nth-child(2) button,
.sng-sherkston-pass-card:nth-child(2) .sng-btn,
.sng-sherkston-pass-card:nth-child(2) button {
  background: linear-gradient(135deg, #5BCBF3 0%, #1EB6E7 100%) !important;
  color: #053F5F !important;
  border-color: #1598c1 !important;
}

.sng-pass-select-card .sng-pass-select-btn:hover,
.sng-pass-select-card button:hover,
.sng-sherkston-pass-card .sng-btn:hover,
.sng-sherkston-pass-card button:hover,
.sng-pass-select-card.is-active .sng-pass-select-btn,
.sng-pass-select-card.is-active button,
.sng-sherkston-pass-card.is-active .sng-btn,
.sng-sherkston-pass-card.is-active button {
  background: #053F5F !important;
  color: #fff !important;
  border-color: #053F5F !important;
}

/* Improve booking buttons in stacked mobile layouts */
@media screen and (max-width: 767px) {
  .sng-location-card .sng-btn,
  .sng-booking-actions .sng-btn,
  .sng-resort-card .sng-btn,
  .sng-private-booking .sng-btn,
  .sng-pass-select-card button,
  .sng-pass-select-card .sng-pass-select-btn {
    width: 100% !important;
    display: block !important;
    text-align: center !important;
    padding: 14px 18px !important;
  }
}

/* sng-v31-marker: affordable access + Sherkston homeowner pricing update */
.sng-v31-marker{display:none;}
.sng-affordable-access{float:left;width:100%;padding:0 0 42px;background:#fff;}
.sng-affordable-card{background:linear-gradient(135deg,#053F5F 0%,#0b6f9c 100%);color:#fff;border-radius:24px;padding:34px;box-shadow:0 18px 42px rgba(5,63,95,.20);display:flex;gap:22px;align-items:center;justify-content:space-between;flex-wrap:wrap;}
.sng-affordable-card .sng-kicker{color:#FDBC44;margin-bottom:6px;}
.sng-affordable-card h2{color:#fff;font-weight:900;font-size:30px;line-height:1.15;margin:0 0 8px;}
.sng-affordable-card p{color:rgba(255,255,255,.92);font-size:17px;line-height:1.55;margin:0;max-width:760px;}
.sng-affordable-card .sng-btn{background:#FDBC44!important;color:#053F5F!important;border:2px solid #FDBC44!important;box-shadow:0 10px 22px rgba(0,0,0,.18);}
.sng-affordable-card .sng-btn:hover{background:#83C669!important;border-color:#83C669!important;color:#053F5F!important;}
@media screen and (max-width:767px){.sng-affordable-access{padding:0 0 30px;}.sng-affordable-card{padding:26px;}.sng-affordable-card h2{font-size:25px;}.sng-affordable-card .sng-btn{width:100%;}}

/* sng-v31-marker: subtle affordable access; homepage/location promo blocks removed */
.sng-v31-marker{display:none;}

/* sng-v31-marker: Sherkston taxes-included pricing update */
.sng-v31-marker{display:none;}
