/**
 * hwyc-dufoor-booking.css
 * Gedeelde CSS voor de volledige HW Yachtcharter boekingsflow:
 * zoeken-nieuw.php · accommodatiecombi.php · reserveren.php
 * Bootstrap 5 · Nautica design system
 */

/* Vereist: base.css (variabelen en gedeelde basis) */

/* ══════════════════════════════════════════════
   2. GLOBAL — body, links, reset
   ══════════════════════════════════════════════ */

.hwyc-acco {
  background: var(--bg-page);
  color: var(--text-body);
  font-family: var(--font-base);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: .01em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  max-width: 100%;
}
.hwyc-acco a { color: var(--link); text-decoration: none; }
.hwyc-acco a:hover { color: var(--link-hover); }
.hwyc-acco h1 {
  font-family: var(--font-heading);
  color: var(--text-heading);
  letter-spacing: -.015em;
  line-height: 1.2;
}
.hwyc-acco h2,
.hwyc-acco h3,
.hwyc-acco h4,
.hwyc-acco h5,
.hwyc-acco h6 {
  font-family: var(--font-base);
  color: var(--text-heading);
  letter-spacing: .01em;
  line-height: 1.3;
  font-weight: 700;
}
.hwyc-acco h1 { font-size: var(--font-size-h1); }
.hwyc-acco h2 { font-size: var(--font-size-h2); font-weight: 700; }
.hwyc-acco h3 { font-size: var(--font-size-h3); font-weight: 600; }
.hwyc-muted { color: var(--text-muted) !important; }
.hwyc-acco .h3,
.hwyc-acco .h5 { letter-spacing: 0.01em; }
.hwyc-signature {
  font-family: var(--font-accent);
  font-size: var(--font-size-accent);
  letter-spacing: var(--letter-spacing-accent);
  color: var(--brand-gold-dark);
  line-height: 1;
  opacity: .9;
}

/* sr-book body override */
body.hwyc-acco {
  min-height: 100vh;
}

/* ══════════════════════════════════════════════
   3. BOOKING-FLOW KNOPPEN
   (Header/topbar CSS is verplaatst naar base.css)
   ══════════════════════════════════════════════ */

/* Nautica overrides voor booking-knoppen */
#hwycBooking .btn.btn-primary {
  border-radius: 0 !important;
  font-family: var(--font-base) !important;
  font-weight: 700 !important;
  letter-spacing: .10em !important;
  text-transform: uppercase !important;
  font-size: .75rem !important;
}

/* ══════════════════════════════════════════════
   4. ZOEKEN-NIEUW — .zn-* classes
   ══════════════════════════════════════════════ */

/* ── Topbar zoekbalk ─────────────────────────────────────── */
.hwyc-topbar-search { flex:1; display:flex; justify-content:center; padding:0 12px; min-width:0; }
.zn-topbar-form {
  display:flex; flex-direction:column; background:var(--bg-surface);
  border:1px solid var(--border-default); box-shadow:var(--shadow-card);
  width:100%; max-width:540px;
}
.zn-form-fields {
  display:flex; flex-direction:row; flex-wrap:nowrap; align-items:stretch; height:42px;
}
.zn-form-fields .zn-tf-field.zn-tf-dates { flex:1; }
.zn-form-fields .zn-tf-field.zn-tf-guests { flex:0 0 auto; }
.zn-tf-field {
  display:flex; align-items:center; gap:7px;
  padding:0 12px; flex:1; min-width:0; cursor:pointer;
  border-right:1px solid var(--border-subtle); transition:background .12s;
}
.zn-tf-field:hover { background:var(--gray-400); }
.zn-tf-divider { width:1px; background:var(--border-subtle); flex-shrink:0; align-self:stretch; }
.zn-tf-icon { flex-shrink:0; color:var(--text-muted); }
.zn-tf-content { flex:1; min-width:0; display:flex; flex-direction:column; gap:1px; justify-content:center; }
.zn-selection-bar { display:none; }
.zn-selection-bar__row1 { font-size:.6rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--text-muted); opacity:.7; margin-bottom:2px; }
.zn-selection-bar__row2 { display:flex; flex-direction:row; flex-wrap:nowrap; align-items:center; gap:5px; font-size:.78rem; color:var(--brand-blue-dark); white-space:nowrap; }
.zn-selection-bar__row2 strong { font-weight:700; }
.zn-selection-bar__row2 svg { flex-shrink:0; color:var(--text-muted); }
.zn-selection-bar__sep { opacity:.4; margin:0 1px; }
.zn-topbar-form.has-selection .zn-selection-bar { display:none; }
.zn-tf-content .flatpickr-wrapper { display:contents; }
.zn-tf-content input[type=text],
.zn-tf-content .flatpickr-input {
  width:100%; height:1.3em !important; line-height:1.3 !important;
  padding:0 !important; margin:0 !important; border:none !important;
  background:transparent !important; box-shadow:none !important;
}
.zn-tf-label { font-size:.55rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-muted); display:block; white-space:nowrap; line-height:1; }
.zn-tf-content input[type=text] {
  border:none; padding:0; font-family:var(--font-base); font-size:.8rem; font-weight:600;
  color:var(--brand-blue-dark); background:transparent; cursor:pointer; width:100%; line-height:1.2;
}
.zn-tf-content input:focus { outline:none; }
.zn-tf-content input::placeholder { font-weight:400; color:var(--text-muted); font-size:.75rem; }
.zn-tf-val { font-size:.8rem; font-weight:600; color:var(--brand-blue-dark); white-space:nowrap; line-height:1.2; }
.zn-tf-submit {
  background:#155f38; color:#fff; border:none;
  padding:0 14px; cursor:pointer; transition:background .15s; flex-shrink:0;
  display:flex; align-items:center; gap:5px; font-family:var(--font-base); font-size:.75rem; font-weight:700;
}
.zn-tf-submit:hover { background:#0f4429; }

/* ── Mobiele zoek-pill ────────────────────────────────────── */
.zn-mob-pill {
  display:none;
  align-items:center; flex:1;
  background:#fff; border:none; border-radius:999px;
  padding:11px 18px; cursor:pointer;
  font-family:var(--font-base); text-align:left; min-width:0; overflow:hidden;
  transition:background .15s; box-shadow:0 1px 4px rgba(0,0,0,.15); margin:6px 0;
}
.zn-mob-pill:hover { background:#f0f2f5; }
.zn-mob-pill__details { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; align-items:flex-start; }
.zn-mob-pill__label { font-size:.58rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:rgba(15,27,42,.45); line-height:1.2; white-space:nowrap; }
.zn-mob-pill__primary { font-size:.82rem; font-weight:700; color:var(--brand-blue-dark); display:flex; align-items:center; gap:4px; white-space:nowrap; line-height:1.3; }
.zn-mob-pill__secondary { font-size:.72rem; color:var(--text-muted); line-height:1.2; }

/* ── Zoek-drawer ─────────────────────────────────────────── */
.zn-drawer-overlay {
  display:none; position:fixed; inset:0; background:rgba(10,20,34,.55);
  z-index:999; backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
}
.zn-drawer-overlay.open { display:block; }
.zn-drawer {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:#fff; border-bottom:3px solid var(--brand-red);
  box-shadow:0 12px 48px rgba(10,20,34,.22);
  transform:translateY(-100%); transition:transform .3s cubic-bezier(.22,.68,0,1.2); padding:0;
}
.zn-drawer.open { transform:translateY(0); }
.zn-drawer__header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px 14px; border-bottom:1px solid rgba(15,27,42,.07);
  background:var(--brand-blue-dark);
}
.zn-drawer__title { font-family:var(--font-base); font-size:.82rem; font-weight:800; color:#fff; margin:0; letter-spacing:.06em; text-transform:uppercase; }
.zn-drawer__close {
  width:34px; height:34px; border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.08); border-radius:50%;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.7); transition:all .15s;
}
.zn-drawer__close:hover { background:rgba(255,255,255,.18); color:#fff; }
.zn-drawer-form { display:flex; flex-direction:column; gap:0; padding:16px 20px; }
.zn-drawer-field {
  display:flex; align-items:center; gap:12px; padding:14px 16px;
  background:#f8f9fb; border:1px solid rgba(15,27,42,.08);
  border-bottom:none; cursor:pointer; transition:background .12s;
}
.zn-drawer-field:first-of-type { border-radius:2px 2px 0 0; }
.zn-drawer-field:last-of-type { border-bottom:1px solid rgba(15,27,42,.08); border-radius:0 0 2px 2px; margin-bottom:12px; }
.zn-drawer-field:hover { background:#f0f2f5; }
.zn-drawer-field label { font-size:.58rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:rgba(15,27,42,.45); display:block; margin-bottom:4px; line-height:1; }
.zn-drawer-field input[type=text] { border:none; background:transparent; font-family:var(--font-base); font-size:.9rem; font-weight:700; color:var(--brand-blue-dark); padding:0; width:100%; }
.zn-drawer-field input:focus { outline:none; }
.zn-drawer-field input::placeholder { font-weight:400; color:rgba(15,27,42,.35); }
.zn-drawer-submit {
  background:#155f38; color:#fff; border:none; padding:15px;
  font-family:var(--font-base); font-size:.88rem; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase; cursor:pointer; transition:background .15s;
  display:flex; align-items:center; justify-content:center; gap:9px;
}
.zn-drawer-submit:hover { background:#0f4429; }

/* ── Search subnav / period nav bar ──────────────────────── */
.zn-subnav { background:var(--bg-surface); border-bottom:1px solid var(--border-subtle); padding:0; position:sticky; top:70px; z-index:200; box-shadow:0 1px 4px rgba(0,0,0,.04); }
.zn-subnav__inner { max-width:1320px; margin:0 auto; padding:0 16px; display:flex; align-items:center; gap:6px; }
.zn-subnav__periods { display:flex; overflow-x:auto; gap:4px; padding:10px 0; scrollbar-width:none; flex:1; touch-action:pan-x; }
.zn-subnav__periods::-webkit-scrollbar { display:none; }
.zn-period-btn {
  flex-shrink:0; padding:6px 14px; border-radius:0;
  font-family:var(--font-base); font-size:.78rem; font-weight:600; letter-spacing:.01em;
  border:1px solid var(--border-default); background:var(--bg-surface); color:var(--text-muted);
  cursor:pointer; transition:all .15s; white-space:nowrap; text-decoration:none; display:inline-block;
}
.zn-period-btn:hover { border-color:var(--brand-blue-dark); color:var(--brand-blue-dark); background:var(--gray-400); }
.zn-period-btn.active { background:var(--brand-blue-dark); border-color:var(--brand-blue-dark); color:#fff; }
.zn-subnav__arrow {
  flex-shrink:0; width:30px; height:30px;
  border:1px solid var(--border-default); background:var(--bg-surface);
  cursor:pointer; font-size:.85rem; color:var(--text-muted);
  display:flex; align-items:center; justify-content:center;
  transition:all .12s; border-radius:0;
}
.zn-subnav__arrow:hover { background:var(--gray-400); color:var(--brand-blue-dark); }

/* ── Periode pills rail ───────────────────────────────────── */
.hwyc-section-nav {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-subtle);
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
}
.zn-period-rail {
  display:flex; align-items:center; justify-content:center;
  gap:12px; padding:9px 20px; width:100%;
}
.zn-period-pill {
  flex:1; text-align:center; padding:5px 8px; border-radius:100px;
  border:1.5px solid var(--border-default); background:var(--bg-surface);
  color:var(--text-muted); font-family:var(--font-base); font-size:.72rem; font-weight:600; letter-spacing:.01em;
  text-decoration:none; white-space:nowrap; transition:all .18s; cursor:pointer;
  display:flex; align-items:center; justify-content:center; min-width:0;
  touch-action:pan-x;
}
.zn-period-pill:hover { border-color:rgba(15,27,42,.4); color:var(--brand-blue-dark); background:var(--gray-400); }
.zn-period-pill--active { background:#3d4a5c; border-color:#3d4a5c; color:#fff; box-shadow:0 2px 8px rgba(15,27,42,.18); }
.zn-period-rail a.zn-period-pill,
.zn-period-rail a.zn-period-pill:link,
.zn-period-rail a.zn-period-pill:visited { color:var(--text-muted); text-decoration:none; }
.zn-period-rail a.zn-period-pill--active,
.zn-period-rail a.zn-period-pill--active:link,
.zn-period-rail a.zn-period-pill--active:visited { color:#fff; }
.zn-period-rail a.zn-period-pill--center:not(.zn-period-pill--active),
.zn-period-rail a.zn-period-pill--center:not(.zn-period-pill--active):link { color:var(--brand-blue-dark); }
.zn-period-pill--past { opacity:.45; }
.zn-period-pill--past:hover { opacity:.75; }
.zn-period-pill--center:not(.zn-period-pill--active) { border-color:rgba(15,27,42,.3); color:var(--brand-blue-dark); }
@media(max-width:767px) {
  .zn-period-rail { gap:7px; padding:7px 12px; }
  .zn-period-pill { font-size:.64rem; padding:5px 5px; }
}
@media(max-width:480px) {
  .zn-period-rail { gap:5px; padding:6px 8px; }
  .zn-period-pill { font-size:.6rem; padding:4px 4px; }
}
@media(max-width:767px) {
  .zn-period-rail .zn-period-pill { display:none; }
  .zn-period-rail .zn-period-pill--active,
  .zn-period-rail .zn-period-pill:has(+.zn-period-pill--active),
  .zn-period-rail .zn-period-pill--active+.zn-period-pill { display:flex; }
}

/* ── Search form bar ─────────────────────────────────────── */
.zn-searchbar { background:var(--gray-200); padding:12px 16px 12px; border-bottom:1px solid var(--border-subtle); position:sticky; top:114px; z-index:150; box-shadow:0 2px 6px rgba(0,0,0,.07); }
.zn-searchbar__inner { max-width:1320px; margin:0 auto; }
.zn-searchform {
  background:var(--bg-surface); border:1px solid var(--border-default);
  box-shadow:var(--shadow-card); display:flex; align-items:stretch; overflow:visible; position:relative;
}
.zn-field {
  flex:1 1 200px; display:flex; flex-direction:column;
  padding:11px 16px; border-right:1px solid var(--border-subtle);
  cursor:pointer; transition:background .12s; min-width:0; position:relative;
}
.zn-field:hover { background:var(--gray-400); }
.zn-field:last-of-type { border-right:none; }
.zn-field label { font-size:.62rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-muted); margin-bottom:3px; cursor:pointer; display:block; }
.zn-field__val { font-size:.9rem; font-weight:600; color:var(--brand-blue-dark); white-space:nowrap; }
.zn-field input[type=text] { border:none; padding:0; font-family:var(--font-base); font-size:.9rem; font-weight:600; color:var(--brand-blue-dark); background:transparent; cursor:pointer; width:100%; }
.zn-field input:focus { outline:none; }
.zn-field input::placeholder { font-weight:400; color:var(--text-muted); }
.zn-submit {
  background:#155f38; color:#fff; border:none;
  padding:0 28px; font-family:var(--font-base); font-size:.875rem; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase; cursor:pointer; transition:background .15s;
  white-space:nowrap; flex-shrink:0; display:flex; align-items:center; gap:7px;
}
.zn-submit:hover { background:#0f4429; }

/* Guests dropdown */
.zn-guests-drop {
  display:none; position:absolute; top:calc(100% + 4px); left:auto; right:0;
  background:var(--bg-surface); border:1px solid var(--border-default);
  box-shadow:0 8px 24px rgba(0,0,0,.12); padding:20px 24px; z-index:400; min-width:280px; border-radius:2px;
}
.zn-guests-drop.open { display:block; }
.zn-grow { display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--border-subtle); }
.zn-grow:last-child { border-bottom:none; padding-bottom:0; }
.zn-grow:first-child { padding-top:0; }
.zn-grow__lbl { font-size:.88rem; font-weight:700; color:var(--brand-blue-dark); }
.zn-grow__sub { font-size:.72rem; color:var(--text-muted); margin-top:2px; }
.zn-stepper { display:flex; align-items:center; gap:12px; }
.zn-stepper__btn {
  width:34px; height:34px; border:1.5px solid var(--border-default); background:transparent;
  border-radius:50%; font-size:1.1rem; font-weight:400; cursor:pointer;
  color:var(--brand-blue-dark); transition:all .15s;
  display:flex; align-items:center; justify-content:center; line-height:1;
}
.zn-stepper__btn:hover:not(:disabled) { border-color:var(--brand-blue-dark); background:var(--gray-400); }
.zn-stepper__btn:disabled { opacity:.25; cursor:default; border-color:var(--border-subtle); color:var(--text-muted); }
.zn-stepper__val { min-width:24px; text-align:center; font-weight:700; font-size:1rem; color:var(--brand-blue-dark); }

@media(max-width:699px) {
  .zn-searchform { flex-direction:column; }
  .zn-field { border-right:none; border-bottom:1px solid var(--border-subtle); }
  .zn-field:last-of-type { border-bottom:none; }
  .zn-submit { padding:14px; justify-content:center; font-size:.9rem; }
}

/* ── Fullscreen mobiele kalender overlay ─────────────────── */
.zn-cal-overlay { display:none; position:fixed; inset:0; z-index:2100; background:var(--bg-surface); flex-direction:column; }
.zn-cal-overlay.open { display:flex; }
.zn-cal-overlay__head {
  position:sticky; top:0; z-index:10; flex-shrink:0;
  display:flex; align-items:center; justify-content:space-between; padding:16px 20px;
  background:var(--brand-blue-dark); border-bottom:3px solid var(--brand-red);
}
.zn-cal-overlay__title { font-family:var(--font-base); font-size:.82rem; font-weight:800; color:#fff; letter-spacing:.06em; text-transform:uppercase; }
.zn-cal-overlay__close { width:34px; height:34px; border:1.5px solid rgba(255,255,255,.25); background:rgba(255,255,255,.08); border-radius:999px; cursor:pointer; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.75); transition:all .15s; }
.zn-cal-overlay__close:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.5); color:#fff; }
.zn-cal-body { flex:1; overflow-y:auto; padding-bottom:90px; background:#f5f6f8; }
.zn-cal-month-block { background:#fff; margin:12px 12px 0; border:1px solid rgba(15,27,42,.07); box-shadow:0 1px 4px rgba(15,27,42,.05); }
.zn-cal-month-block:last-child { margin-bottom:12px; }
.zn-cal-month-label { font-family:var(--font-base); font-size:.82rem; font-weight:800; color:var(--brand-blue-dark); padding:14px 16px 8px; text-transform:uppercase; letter-spacing:.07em; border-bottom:1px solid rgba(15,27,42,.06); }
.zn-cal-month-block .flatpickr-calendar.inline { box-shadow:none !important; border:none !important; border-radius:0 !important; background:transparent !important; width:100% !important; max-width:100% !important; padding:8px 12px 12px !important; }
.zn-cal-month-block .flatpickr-months { display:none !important; }
.zn-cal-month-block .flatpickr-rContainer,
.zn-cal-month-block .flatpickr-weekdays,
.zn-cal-month-block .flatpickr-weekdaycontainer,
.zn-cal-month-block .flatpickr-days,
.zn-cal-month-block .dayContainer { width:100% !important; min-width:0 !important; max-width:none !important; }
.zn-cal-month-block .flatpickr-weekday { font-size:.68rem !important; font-weight:800 !important; color:rgba(15,27,42,.4) !important; letter-spacing:.04em !important; }
.zn-cal-month-block .flatpickr-day { max-width:calc(100% / 7) !important; min-width:0 !important; flex-basis:calc(100% / 7) !important; height:44px !important; line-height:44px !important; font-size:.9rem !important; font-weight:600 !important; border-radius:0 !important; color:var(--brand-blue-dark) !important; }
.zn-cal-month-block .flatpickr-day.flatpickr-disabled { color:rgba(15,27,42,.2) !important; text-decoration:line-through !important; }
.zn-cal-month-block .flatpickr-day.today:not(.selected) { border-bottom:2px solid var(--brand-blue-dark) !important; font-weight:800 !important; }
.zn-cal-month-block .flatpickr-day.startRange,
.zn-cal-month-block .flatpickr-day.endRange { background:var(--brand-blue-dark) !important; border-color:var(--brand-blue-dark) !important; border-radius:0 !important; color:#fff !important; font-weight:800 !important; }
.zn-cal-month-block .flatpickr-day.inRange { background:rgba(15,27,42,.08) !important; border-color:transparent !important; box-shadow:none !important; color:var(--brand-blue-dark) !important; }
.zn-cal-overlay__foot { position:fixed; bottom:0; left:0; right:0; z-index:2101; padding:12px 16px; background:#fff; border-top:1px solid rgba(15,27,42,.08); box-shadow:0 -4px 20px rgba(15,27,42,.10); }
.zn-cal-sel-info { font-size:.75rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:rgba(15,27,42,.45); min-height:1em; margin-bottom:8px; }
.zn-cal-confirm { width:100%; background:#155f38; color:#fff; border:none; padding:15px; font-family:var(--font-base); font-size:.88rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:9px; transition:background .15s; }
.zn-cal-confirm:disabled { background:#b8c5bf; cursor:default; }
.zn-cal-confirm:not(:disabled):hover { background:#0f4429; }

/* ── Flatpickr grid fix ──────────────────────────────────── */
.flatpickr-day.hidden,
.flatpickr-day.prevMonthDay.hidden,
.flatpickr-day.nextMonthDay.hidden { visibility:hidden !important; display:block !important; pointer-events:none; }
.zn-topbar-form .flatpickr-days .dayContainer { min-width:308px; max-width:308px; }
.zn-topbar-form .flatpickr-days .dayContainer .flatpickr-day { max-width:44px; min-width:44px; }

/* ── Touch-action utilities ──────────────────────────────── */
button,.zn-cta,.zn-mob-pill,.zn-sort-pill,.zn-tf-submit,.zn-drawer-submit { touch-action:manipulation; }

/* ── Page layout ─────────────────────────────────────────── */
.zn-layout { display:flex; flex-direction:column; min-height:calc(100vh - 80px); }
.zn-page { max-width:1200px; margin:0 auto; padding:24px 24px 40px; width:100%; box-sizing:border-box; flex:1; }
.zn-main { width:100%; min-width:0; }

/* ── Cards ────────────────────────────────────────────────── */
.hwyc-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: 0;
  box-shadow: var(--shadow-card);
}
.hwyc-card .card-header {
  background: linear-gradient(to bottom, rgba(255,255,255,.96), rgba(255,255,255,.92));
  border-bottom: 1px solid var(--border-subtle);
  padding: .7rem 1rem;
}
.hwyc-card .card-header strong { position:relative; padding-left:12px; font-size:.85rem; font-weight:800; letter-spacing:.01em; color:var(--text-heading); }
.hwyc-card .card-header strong::before { content:""; position:absolute; left:0; top:50%; width:3px; height:16px; transform:translateY(-50%); background:var(--brand-red); }

/* Override WordPress theme */
article.zn-ycard { padding-bottom:0 !important; }

/* ── Yacht result card ────────────────────────────────────── */
.zn-ycard {
  background:var(--bg-surface); border:1px solid var(--border-subtle); border-radius:0;
  box-shadow:var(--shadow-card); display:flex; flex-direction:column;
  transition:box-shadow .2s,transform .2s; margin-bottom:12px; width:100%;
}
@media(hover:hover) { .zn-ycard:hover { box-shadow:var(--shadow-hover); transform:translateY(-2px); } }
@media(min-width:640px) { .zn-ycard { flex-direction:row; min-height:250px; } }
@media(min-width:640px) { .zn-ycard__gallery-wrap { height:250px; min-height:250px; } }

/* Gallery */
.zn-ycard__gallery-wrap { position:relative; flex-shrink:0; height:220px; background:var(--gray-400); }
@media(min-width:640px) { .zn-ycard__gallery-wrap { width:280px; height:auto; min-height:200px; } }
@media(min-width:1024px) { .zn-ycard__gallery-wrap { width:600px; } }
.zn-ycard__gallery { display:flex; overflow-x:auto; overflow-y:hidden; scroll-snap-type:x mandatory; scrollbar-width:none; height:100%; -webkit-overflow-scrolling:touch; touch-action:pan-x; }
.zn-ycard__gallery::-webkit-scrollbar { display:none; }
.zn-ycard__gallery-img { position:relative; flex-shrink:0; width:100%; height:100%; scroll-snap-align:start; overflow:hidden; }
.zn-ycard__gallery-img a { display:block; width:100%; height:100%; }
.zn-ycard__gallery-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s; }
@media(hover:hover) { .zn-ycard:hover .zn-ycard__gallery-img:first-child img { transform:scale(1.04); } }
.zn-ycard__gallery-img-ph { width:100%; height:100%; background:linear-gradient(135deg,var(--brand-blue-dark),#1a3550); display:flex; align-items:center; justify-content:center; font-size:3.5rem; color:rgba(255,255,255,.15); }
.zn-ycard__gallery-dots { position:absolute; bottom:7px; left:50%; transform:translateX(-50%); display:flex; gap:4px; z-index:2; pointer-events:none; }
.zn-ycard__gallery-dot { width:5px; height:5px; border-radius:50%; background:rgba(255,255,255,.5); transition:background .15s; }
.zn-ycard__gallery-dot.active { background:#fff; transform:scale(1.2); }
@media(min-width:640px) {
  .zn-ycard__gallery { overflow:hidden; display:grid; grid-template-columns:2fr 1fr; grid-template-rows:125px 125px; height:250px; }
  .zn-ycard__gallery-img { width:100%; overflow:hidden; scroll-snap-align:unset; position:relative; }
  .zn-ycard__gallery-img img { width:100%; height:100%; object-fit:cover; display:block; }
  .zn-ycard__gallery-img:first-child { grid-row:1/3; grid-column:1; height:250px; }
  .zn-ycard__gallery-img:first-child:last-child { grid-column:1/-1; grid-row:1/-1; height:250px; }
  .zn-ycard__gallery-img:nth-child(2):last-child { grid-row:1/3; grid-column:2; height:250px; border-bottom:none; }
  .zn-ycard__gallery-img:nth-child(2) { grid-row:1; grid-column:2; height:125px; border-bottom:2px solid #fff; }
  .zn-ycard__gallery-img:nth-child(3) { grid-row:2; grid-column:2; height:125px; }
  .zn-ycard__gallery-dots { display:none; }
}
/* Legacy alias */
.zn-ycard__img { flex-shrink:0; overflow:hidden; height:220px; background:var(--gray-400); }
@media(min-width:640px) { .zn-ycard__img { width:280px; height:auto; } }
@media(min-width:1024px) { .zn-ycard__img { width:330px; } }
.zn-ycard__img a { display:block; width:100%; height:100%; }
.zn-ycard__img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s; }
@media(hover:hover) { .zn-ycard:hover .zn-ycard__img img { transform:scale(1.04); } }
.zn-ycard__img-ph { width:100%; height:100%; background:linear-gradient(135deg,var(--brand-blue-dark),#1a3550); display:flex; align-items:center; justify-content:center; font-size:3.5rem; color:rgba(255,255,255,.15); }

/* Badges */
.zn-badge { position:absolute; top:0; left:0; background:var(--brand-red); color:#fff; font-size:.62rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:4px 8px; }
.zn-badge--green { background:rgba(34,139,34,.9); top:auto; bottom:0; }
.zn-badge--best-match { background:#0fc766; color:#fff; top:auto; bottom:0; left:auto; right:0; }

/* Card body */
.zn-ycard__body { flex:1; display:flex; flex-direction:column; padding:18px 20px; gap:10px; min-width:0; }
.zn-ycard__top { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.zn-ycard__name { font-family:var(--font-heading); font-size:1.05rem; font-weight:700; margin:0; line-height:1.25; color:var(--text-heading); flex:1; display:flex; flex-wrap:wrap; align-items:baseline; gap:6px; }
.zn-ycard__name a { color:inherit; text-decoration:none; }
.zn-ycard__name-specs { font-size:.72rem; font-weight:500; color:rgba(15,27,42,.45); font-family:var(--font-base); white-space:nowrap; }
.zn-ycard__name a { color:var(--text-heading); }
.zn-ycard__name a:hover { color:var(--brand-red); }
.zn-ycard__rating { text-align:right; flex-shrink:0; }
.zn-ycard__score { display:inline-block; background:var(--brand-blue-dark); color:#fff; font-weight:800; font-size:.88rem; padding:3px 7px; margin-bottom:2px; }
.zn-ycard__reviews { font-size:.65rem; color:var(--text-muted); display:block; }
.zn-ycard__specs { display:flex; flex-wrap:wrap; gap:6px 16px; font-size:.78rem; color:var(--text-muted); }
.zn-ycard__meta { display:flex; align-items:center; gap:5px; font-size:.72rem; color:rgba(15,27,42,.45); margin-bottom:10px; font-weight:500; flex-wrap:wrap; }
.zn-ycard__meta-sep { opacity:.4; }
.zn-google-rating { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.zn-google-icon { width:16px; height:16px; flex-shrink:0; }
.zn-ycard__stats { display:flex; gap:0; border:1px solid rgba(15,27,42,.07); margin-bottom:12px; }
.zn-ycard__stat { flex:1; display:flex; flex-direction:column; align-items:center; padding:8px 4px; border-right:1px solid rgba(15,27,42,.07); }
.zn-ycard__stat:last-child { border-right:none; }
.zn-ycard__stat-val { font-size:1.15rem; font-weight:800; color:var(--brand-blue-dark); line-height:1; }
.zn-ycard__stat-lbl { font-size:.58rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:rgba(15,27,42,.4); margin-top:3px; }
.zn-ycard__spec { display:flex; align-items:center; gap:5px; }
.zn-ycard__tags { display:flex; flex-wrap:wrap; gap:5px; }
.zn-ycard__tag { font-size:.68rem; font-weight:700; letter-spacing:.03em; padding:3px 8px; border:1px solid var(--border-default); color:var(--text-muted); background:var(--gray-400); }
.zn-ycard__tag--green { border-color:rgba(34,139,34,.3); color:rgba(34,139,34,1); background:rgba(34,139,34,.06); }
.zn-ycard__alt-notice { display:flex; flex-direction:column; gap:.15rem; margin-top:auto; padding:8px 0 0; border-top:1px solid rgba(15,27,42,.07); }
.zn-ycard__alt-label { font-size:.62rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--brand-red); }
.zn-ycard__alt-dates { font-size:.72rem; color:rgba(15,27,42,.5); display:flex; align-items:center; gap:4px; }

/* Footer + price */
.zn-ycard__footer { margin-top:auto; padding-top:12px; border-top:1px solid var(--border-subtle); display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.zn-ycard__price-from { font-size:.64rem; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); display:block; margin-bottom:2px; }
.zn-ycard__price { font-size:1.4rem; font-weight:800; color:var(--brand-blue-dark); display:block; line-height:1; font-family:var(--font-heading); }
.zn-ycard__price-unit { font-size:.68rem; color:var(--text-muted); display:block; margin-top:3px; }

/* CTAs */
.zn-ctas { display:flex; gap:8px; flex-wrap:wrap; min-width:0; }
.zn-cta { padding:9px 14px; font-family:var(--font-base); font-size:.75rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; transition:all .15s; border-radius:0; white-space:nowrap; text-decoration:none; display:inline-block; }
.zn-cta--view,a.zn-cta--view,a.zn-cta--view:link,a.zn-cta--view:visited { background:var(--brand-blue-dark); color:#fff !important; border:1px solid var(--brand-blue-dark); text-decoration:none !important; }
.zn-cta--view:hover,a.zn-cta--view:hover { background:#0f1b2a; color:#fff !important; }
.zn-cta--book { background:#0fc766; color:#fff; border:1px solid #0fc766; }
.zn-cta--book:hover { background:#0aaa55; color:#fff; }

/* ── Results header ──────────────────────────────────────── */
.zn-results-hdr { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; margin-bottom:16px; padding-bottom:14px; border-bottom:1px solid var(--border-subtle); }
.zn-results-hdr h1 { font-family:var(--font-heading); font-size:clamp(1.1rem,2.5vw,1.4rem); font-weight:700; margin:0; color:var(--text-heading); letter-spacing:-.01em; }
.zn-results-meta { font-size:.78rem; color:var(--text-muted); margin:3px 0 0; display:block; }
.zn-sort { display:flex; align-items:center; gap:6px; flex-wrap:wrap; justify-content:flex-end; }
.zn-sort-lbl { font-size:.65rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:var(--text-muted); white-space:nowrap; }
.zn-sort-pill { padding:5px 12px; border-radius:999px; border:1.5px solid var(--border-default); background:var(--bg-surface); font-family:var(--font-base); font-size:.72rem; font-weight:600; color:var(--text-muted); cursor:pointer; transition:all .15s; white-space:nowrap; }
.zn-sort-pill:hover { border-color:var(--brand-blue-dark); color:var(--brand-blue-dark); }
.zn-sort-pill.active { background:var(--brand-blue-dark); border-color:var(--brand-blue-dark); color:#fff; }
.zn-hdr-right { display:flex; align-items:center; gap:14px; flex-wrap:wrap; justify-content:flex-end; flex:1; }
.zn-sort-select { display:none; border:1.5px solid var(--border-default); padding:6px 10px; font-family:var(--font-base); font-size:.8rem; color:var(--brand-blue-dark); background:var(--bg-surface); cursor:pointer; border-radius:999px; }
@media(max-width:899px) {
  .zn-results-hdr { align-items:flex-start; flex-direction:column; }
  .zn-results-hdr>div:first-child { width:100%; }
  .zn-hdr-right { width:100%; justify-content:space-between; gap:8px; flex:none; }
  .zn-google-rating { flex-shrink:0; }
  .zn-sort { justify-content:flex-end; flex-shrink:0; gap:6px; }
  .zn-sort-lbl { display:none; }
  .zn-sort-pills-wrap { display:none; }
  .zn-sort-select { display:block; max-width:160px; font-size:.75rem; padding:5px 8px; }
}

/* ── Section divider ─────────────────────────────────────── */
#zn-cards,#zn-cards-alt { display:block; width:100%; }
.zn-section-hdr { display:flex; align-items:center; gap:12px; margin:36px 0 4px; font-family:var(--font-base); width:100%; clear:both; }
.zn-section-hdr__title { font-size:.72rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--brand-blue-dark); white-space:nowrap; }
.zn-section-hdr::after { content:''; flex:1; height:1px; background:var(--border-subtle); }
.zn-section-sub { font-size:.82rem; color:var(--text-muted); margin:0 0 14px; }

/* ── Filter buttons ──────────────────────────────────────── */
.zn-filter-btns { display:flex; flex-wrap:wrap; gap:5px; padding:12px 16px; }
.zn-filter-btn { padding:5px 12px; font-size:.75rem; font-weight:600; border:1px solid var(--border-default); background:var(--bg-surface); color:var(--text-muted); cursor:pointer; transition:all .12s; border-radius:0; font-family:var(--font-base); }
.zn-filter-btn:hover,.zn-filter-btn.active { border-color:var(--brand-blue-dark); background:var(--brand-blue-dark); color:#fff; }

/* ── Hero ────────────────────────────────────────────────── */
.zn-hero { background:linear-gradient(155deg,var(--brand-blue-dark) 0%,#162c44 60%,#0d2030 100%); color:#fff; text-align:center; padding:56px 20px 48px; margin-bottom:24px; position:relative; overflow:hidden; }
.zn-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 65% 40%,rgba(0,85,134,.25) 0%,transparent 70%); }
.zn-hero h1 { font-family:var(--font-heading); font-size:clamp(1.8rem,4vw,2.8rem); font-weight:700; margin:0 0 10px; position:relative; letter-spacing:-.02em; line-height:1.1; }
.zn-hero p { font-size:.95rem; opacity:.7; margin:0; position:relative; }

/* ── Empty state ─────────────────────────────────────────── */
.zn-empty { text-align:center; padding:60px 20px; }
.zn-empty__icon { font-size:3.5rem; margin-bottom:16px; display:block; }
.zn-empty p { font-size:.9rem; color:var(--text-muted); max-width:420px; margin:0 auto; }

/* ── Footer ──────────────────────────────────────────────── */
.zn-footer { background:var(--brand-blue-dark); color:rgba(255,255,255,.5); text-align:center; padding:28px 16px; font-size:.78rem; width:100%; }

/* ── Laad-overlay ────────────────────────────────────────── */
.zn-loading { display:none; position:fixed; inset:0; z-index:3000; background:rgba(10,18,30,.7); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); align-items:center; justify-content:center; }
.zn-loading.active { display:flex; }
.zn-loading__card { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; width:260px; }
.zn-loading__track { position:relative; width:100%; height:50px; overflow:hidden; }
.zn-loading__boat { position:absolute; bottom:12px; left:4px; animation:zn-boat-sail 2.8s ease-in-out infinite, zn-bob .9s ease-in-out infinite alternate; }
.zn-loading__wave-wrap { position:absolute; bottom:0; left:-100%; width:300%; height:16px; animation:zn-wave-scroll 1.8s linear infinite; }
.zn-loading__txt { font-family:var(--font-base); font-size:.65rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.45); }
@keyframes zn-boat-sail {
  0%   { transform:translateX(0)      scaleX(1); }
  44%  { transform:translateX(182px)  scaleX(1); }
  50%  { transform:translateX(182px)  scaleX(-1); }
  94%  { transform:translateX(0)      scaleX(-1); }
  100% { transform:translateX(0)      scaleX(1); }
}
@keyframes zn-bob {
  from { transform:translateY(0); }
  to   { transform:translateY(-3px); }
}
@keyframes zn-wave-scroll {
  from { transform:translateX(0); }
  to   { transform:translateX(33.33%); }
}

/* ── Mobile responsive overrides (zoeken-nieuw) ─────────── */
/* (topbar phone/logo/language responsiveness zit in base.css) */
@media(max-width:767px) {
  .hwyc-topbar-search { padding:0 4px; }
  .zn-topbar-form { max-width:100%; }
  .zn-form-fields { height:36px; }
  .zn-tf-label { display:none; }
  .zn-tf-field { padding:0 7px; gap:4px; }
  .hwyc-logo-topbar img { height:44px !important; }
  .zn-mob-pill { display:flex; }
  .hwyc-topbar-search .zn-topbar-form { display:none; }
}


/* ══════════════════════════════════════════════
   5. ACCOMMODATIECOMBI — .hwyc-* classes
   ══════════════════════════════════════════════ */

/* ── Photo header ────────────────────────────────────────── */
.hwyc-photo-header { margin-top:12px; }
.hwyc-photo-grid { min-height:420px; }
.hwyc-photo {
  position:relative; width:100%; height:100%; min-height:200px;
  background-size:cover; background-position:center; overflow:hidden;
  outline:1px solid rgba(255,255,255,.06);
  background-clip: padding-box;
}
.hwyc-photo-gap { margin:-1px; }
.hwyc-photo-gap > [class*="col"] { padding:1px; }
.hwyc-photo-main { min-height:420px; }
.hwyc-photo-small { min-height:209px; }
@media(max-width:991.98px) {
  .hwyc-photo-main { min-height:260px; }
  .hwyc-photo-small { min-height:160px; }
}
.hwyc-photo-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(15,27,42,.15),rgba(15,27,42,.35)) !important;
  opacity:0; transition:opacity .25s ease;
}
.hwyc-photo:hover .hwyc-photo-overlay { opacity:1; }
.hwyc-photo-overlay-last { opacity:1; background:rgba(0,0,0,.45); }
.hwyc-photo-more {
  position:absolute; right:12px; bottom:12px;
  background:rgba(15,27,42,.82) !important;
  color:#fff; padding:8px 14px; border-radius:0 !important;
  font-size:.75rem; font-weight:700; cursor:pointer; z-index:2;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  letter-spacing:.06em; text-transform:uppercase;
  border:none !important;
}
.hwyc-photo-more:hover { background:rgba(15,27,42,.95); }

/* ── Hero (accommodatiecombi alias) ──────────────────────── */
.hwyc-hero { margin-top:12px; }
.hwyc-hero-main { border-radius:0; overflow:hidden; background:#f7f7f7; }
.hwyc-hero-main img { width:100%; height:420px; object-fit:cover; display:block; }
@media(max-width:991.98px) { .hwyc-hero-main img { height:260px; } }
.hwyc-thumb { border-radius:0; overflow:hidden; background:#f7f7f7; }
.hwyc-thumb img { width:100%; aspect-ratio:4/3; height:auto; object-fit:cover; display:block; }

/* ── Content section & layout ────────────────────────────── */
.hwyc-content-container { max-width:1200px; margin:0 auto; }
.hwyc-content-section { background:#edf0f3; }
.hwyc-acco { background:#edf0f3; }
.hwyc-content-section main .hwyc-section { scroll-margin-top:120px; }
.hwyc-section { scroll-margin-top:120px; }
.hwyc-section.mt-4 { margin-top:1.5rem !important; }

/* ── Badges ──────────────────────────────────────────────── */
.hwyc-badges .badge {
  border-radius:0; font-weight:700;
  color:rgba(15,27,42,.78); background:rgba(15,27,42,.06) !important;
  border:1px solid rgba(15,27,42,.12);
}

/* ── Sticky booking card ─────────────────────────────────── */
.hwyc-sticky { position:sticky; top:92px; }
#hwycBooking .hwyc-card { box-shadow:0 18px 50px rgba(0,0,0,.10); border-color:rgba(15,27,42,.10); }
#hwycBooking .card-header { background:linear-gradient(to right,rgba(15,27,42,.06),rgba(255,255,255,.94)); }
#hwycBooking .form-label { font-weight:700; color:rgba(15,27,42,.80); }
#hwycBooking .form-control { border-radius:0; border-color:rgba(0,0,0,.14); padding:.55rem .75rem; }
#hwycBooking .form-control:focus { border-color:rgba(0,85,134,.45); box-shadow:0 0 0 .18rem rgba(0,85,134,.14); }
#hwycBooking .btn.btn-outline-dark { border-radius:0; font-weight:800; color:rgba(15,27,42,.90); border-color:rgba(15,27,42,.26); }
#hwycBooking .btn.btn-outline-dark:hover { background:rgba(15,27,42,.06); }
#hwycBooking .card { border:1px solid rgba(15,27,42,.09) !important; border-top:none !important; }
#hwycBooking .card-header { background:var(--brand-blue-dark) !important; border-bottom:none !important; }
#hwycBooking .card-header strong { color:rgba(255,255,255,.88) !important; font-family:var(--font-base) !important; font-weight:700 !important; font-size:.68rem !important; letter-spacing:.14em !important; text-transform:uppercase !important; padding-left:0 !important; }
#hwycBooking .card-header strong::before { display:none !important; }
#hwycBooking .card-header .hwyc-muted { color:rgba(255,255,255,.40) !important; }
#hwycBooking .card-body { padding:0 !important; }

/* ── Section subnav ──────────────────────────────────────── */
#hwycSectionNav.hwyc-section-nav {
  border-top:1px solid rgba(0,0,0,.06); border-bottom:1px solid rgba(0,0,0,.08);
  background:rgba(255,255,255,.95); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  max-height:0; overflow:hidden; opacity:0; transform:translateY(-6px);
  transition:max-height .22s ease,opacity .18s ease,transform .22s ease;
  will-change:max-height,opacity,transform;
  overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch;
  touch-action:pan-x; scrollbar-width:none;
  padding-left:12px; padding-right:12px;
}
#hwycSectionNav.hwyc-section-nav::-webkit-scrollbar { display:none; }
body.hwyc-subnav-visible #hwycSectionNav.hwyc-section-nav { max-height:64px; opacity:1; transform:translateY(0); }
@media(max-width:768px) { body.hwyc-subnav-visible #hwycSectionNav.hwyc-section-nav { max-height:120px; } }
.hwyc-section-menu-wrapper { max-width:1400px; margin:0 auto; display:flex; align-items:center; }
#hwycSectionNav.hwyc-section-nav .d-flex { display:inline-flex !important; flex-wrap:nowrap !important; width:max-content !important; gap:22px !important; }
#hwycSectionNav.hwyc-section-nav .hwyc-section-track { display:inline-flex; flex-wrap:nowrap; gap:22px; align-items:center; width:max-content; }
#hwycSectionNav .d-flex { gap:26px !important; }
#hwycSectionNav .btn {
  all:unset; cursor:pointer; font-family:var(--font-base); font-size:.92rem; font-weight:800; letter-spacing:.01em;
  color:rgba(15,27,42,.68); padding:10px 2px; position:relative; transition:color .18s ease;
  border-radius:0; font-weight:600; white-space:nowrap; font-size:.85rem;
}
#hwycSectionNav .btn:hover { color:rgba(15,27,42,1); }
#hwycSectionNav .btn::after { content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:#0D1B2A; transform:scaleX(0); transform-origin:left; transition:transform .2s ease; }
#hwycSectionNav .btn:hover::after { transform:scaleX(1); }
#hwycSectionNav .btn.is-active { color:rgba(15,27,42,1); }
#hwycSectionNav .btn.is-active::after { transform:scaleX(1); }
#hwycSectionNav .container,
#hwycSectionNav .container-fluid,
#hwycSectionNav .hwyc-section-menu-wrapper { width:auto !important; max-width:none !important; margin:0 !important; padding:0 !important; }
#hwycSectionNav.hwyc-section-nav a { flex:0 0 auto; white-space:nowrap; }
@media(max-width:768px) {
  #hwycSectionNav .d-flex { flex-wrap:nowrap !important; overflow-x:auto; -webkit-overflow-scrolling:touch; padding:8px 12px; gap:22px !important; }
  #hwycSectionNav .d-flex::-webkit-scrollbar { display:none; }
  #hwycSectionNav .btn { white-space:nowrap; font-size:.85rem; }
}

/* ── Section nav links (hwyc-section-link) ───────────────── */
.hwyc-section-nav { position:sticky; top:64px; z-index:500; background:rgba(255,255,255,.95); backdrop-filter:blur(6px); border-bottom:1px solid rgba(0,0,0,.06); }
.hwyc-section-menu { flex:1; display:flex; align-items:center; overflow-x:auto; scrollbar-width:none; }
.hwyc-section-menu::-webkit-scrollbar { display:none; }
.hwyc-section-logo img { display:block; max-height:32px; width:auto; }
.hwyc-section-link {
  display:inline-flex !important; align-items:center; min-height:44px;
  padding:6px 10px; font-size:.72rem !important; font-weight:700;
  color:rgba(15,27,42,.55) !important; text-decoration:none;
  border-radius:6px; white-space:nowrap;
  transition:background .15s ease,color .15s ease;
  font-family:var(--font-base); letter-spacing:.10em; text-transform:uppercase;
}
.hwyc-section-link:hover { background:rgba(0,0,0,.05); color:var(--brand-blue-dark) !important; }
.hwyc-section-link.is-active { background:rgba(13,27,42,.08); color:var(--brand-blue-dark) !important; font-weight:600; }
.hwyc-section-link.is-active::after { transform:scaleX(1) !important; }
.hwyc-section-link::after { background:var(--brand-red) !important; }
@media(max-width:768px) {
  .hwyc-section-nav { top:56px; }
  .hwyc-section-logo img { max-height:26px; }
  .hwyc-section-link { padding:6px 8px; font-size:.82rem; }
}

/* ── Nautica card overrides ───────────────────────────────── */
.hwyc-card { background:#fff !important; border:1px solid rgba(15,27,42,.09) !important; border-top:none !important; border-radius:0 !important; box-shadow:none !important; }
.hwyc-card .card-header { background:var(--brand-blue-dark) !important; border-bottom:none !important; padding:.9rem 1.5rem !important; }
.hwyc-card .card-header strong { color:rgba(255,255,255,.92) !important; font-family:var(--font-base) !important; font-size:.68rem !important; font-weight:700 !important; letter-spacing:.14em !important; text-transform:uppercase !important; padding-left:0 !important; }
.hwyc-card .card-header strong::before { display:none !important; }
.hwyc-card .card-body { padding:1.75rem !important; }
.hwyc-section .card-body > h2 { display:block; margin:-1.75rem -1.75rem 1.75rem -1.75rem !important; padding:.9rem 1.5rem !important; background:var(--brand-blue-dark); font-family:var(--font-base) !important; font-size:.68rem !important; font-weight:700 !important; letter-spacing:.14em !important; text-transform:uppercase !important; color:rgba(255,255,255,.92) !important; line-height:1.3; }
.hwyc-section .card-body > h2::before { display:none !important; }
.hwyc-card .card-body,
.hwyc-card .hwyc-rv-body,
.hwyc-card .hwyc-lob-grid,
.hwyc-card .hwyc-routes-outer,
.hwyc-card .hwyc-advisor { transition:opacity .2s ease; }
.hwyc-card.is-collapsed > .card-body,
.hwyc-card.is-collapsed > .hwyc-rv-body,
.hwyc-card.is-collapsed > .hwyc-lob-grid,
.hwyc-card.is-collapsed > .hwyc-routes-outer,
.hwyc-card.is-collapsed > .hwyc-advisor { display:none; }

/* ── Mobile bottom drawer ────────────────────────────────── */
.hwyc-drawer-handle { display:none; }
.hwyc-drawer-backdrop { display:none; position:fixed; inset:0; background:rgba(15,27,42,.55); z-index:1048; backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px); }
.hwyc-drawer-backdrop.is-open { display:block; }
@media(max-width:991.98px) {
  .hwyc-drawer-handle { display:flex; justify-content:center; align-items:center; padding:.85rem 1rem .6rem; background:#fff; border-radius:16px 16px 0 0; cursor:pointer; position:relative; flex-shrink:0; }
  .hwyc-drawer-handle::before { content:''; width:40px; height:4px; background:rgba(15,27,42,.15); border-radius:2px; }
  .hwyc-drawer-close { display:block; position:absolute; right:1rem; top:50%; transform:translateY(-50%); background:none; border:none; font-size:1.2rem; color:rgba(15,27,42,.38); cursor:pointer; line-height:1; padding:.25rem .5rem; }
  #hwycBooking { display:flex !important; flex-direction:column; position:fixed !important; left:0 !important; right:0 !important; bottom:-100vh; z-index:1049 !important; max-height:88vh; overflow-y:auto; -webkit-overflow-scrolling:touch; background:#fff; border-radius:16px 16px 0 0; box-shadow:0 -8px 40px rgba(15,27,42,.18); transition:bottom .32s cubic-bezier(.4,0,.2,1); }
  #hwycBooking.is-open { bottom:0 !important; }
  #hwycBooking .hwyc-sticky { position:static !important; top:auto !important; margin:0 !important; }
}
@media(min-width:900px) { .hwyc-drawer-close { display:none; } }
@media(min-width:992px) { .hwyc-sticky { position:sticky; top:128px; transition:top .22s ease; } }

/* ── Mobile sticky bottom bar ────────────────────────────── */
.hwyc-mobile-bar { display:none; position:fixed; bottom:0; left:0; right:0; z-index:1040; background:#fff; border-top:3px solid var(--brand-red); box-shadow:0 -4px 24px rgba(15,27,42,.14); align-items:center; gap:.6rem; padding:.7rem 1rem; padding-bottom:calc(.7rem + env(safe-area-inset-bottom,0px)); transition:border-color .3s; }
@media(max-width:991.98px) {
  .hwyc-mobile-bar { display:flex !important; }
  .hwyc-acco > footer { padding-bottom:calc(3.5rem + 72px) !important; }
}
.hwyc-mobile-bar__idle { flex:1; min-width:0; }
.hwyc-mobile-bar__name { font-size:.8rem; font-weight:700; color:var(--brand-blue-dark); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hwyc-mobile-bar__sub { font-size:.72rem; color:rgba(15,27,42,.42); margin-top:.1rem; }
.hwyc-mobile-bar__price-block { flex:1; min-width:0; -webkit-animation:hwyc-bar-pop .35s cubic-bezier(.34,1.56,.64,1) both; animation:hwyc-bar-pop .35s cubic-bezier(.34,1.56,.64,1) both; will-change:transform,opacity; }
@-webkit-keyframes hwyc-bar-pop {
  from { -webkit-transform:scale(.88) translateY(4px); opacity:0; }
  to   { -webkit-transform:scale(1) translateY(0); opacity:1; }
}
@keyframes hwyc-bar-pop {
  from { transform:scale(.88) translateY(4px); opacity:0; }
  to   { transform:scale(1) translateY(0); opacity:1; }
}
.hwyc-mobile-bar__period { font-size:.68rem; color:rgba(15,27,42,.45); line-height:1; margin-bottom:1px; }
.hwyc-mobile-bar__big-price { font-size:1.35rem; font-weight:800; color:var(--brand-blue-dark); line-height:1.1; }
.hwyc-mobile-bar__guarantee { font-size:.6rem; font-weight:700; color:var(--brand-red); letter-spacing:.02em; margin-top:1px; }
.hwyc-mobile-bar__cta { flex-shrink:0; display:inline-flex; align-items:center; justify-content:center; background:var(--brand-blue-dark); color:#fff !important; text-decoration:none !important; padding:.75rem 1.1rem; font-family:var(--font-base); font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; white-space:nowrap; min-height:44px; transition:background .18s,transform .12s; }
.hwyc-mobile-bar__cta:active { transform:scale(.97); }
.hwyc-mobile-bar__cta:hover { background:#1a2f45; }
.hwyc-mobile-bar__cta.is-book { background:#1a7a4a; box-shadow:0 0 0 3px rgba(26,122,74,.25); }
.hwyc-mobile-bar__cta.is-book:hover { background:#155f38; }

/* ── Lightbox (hwyc-fbox) ────────────────────────────────── */
#hwycLightbox.hwyc-fbox { z-index:100001 !important; }
.modal-backdrop { z-index:100000 !important; }
#hwycLightbox.hwyc-fbox .modal-content { background:transparent; border:0; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-bg { position:absolute; inset:0; z-index:0; background:rgba(30,30,30,.98); }
#hwycLightbox.hwyc-fbox .hwyc-fbox-inner { position:relative; width:100%; height:100%; z-index:1; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-infobar { position:absolute; top:16px; left:16px; z-index:5; color:#fff; font-size:14px; opacity:.9; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-toolbar { position:absolute; top:10px; right:10px; z-index:5; display:flex; gap:8px; align-items:center; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-btn { width:44px; height:44px; border:0; border-radius:0; background:rgba(30,30,30,.65); color:#fff; display:grid; place-items:center; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-btn svg { width:22px; height:22px; fill:#fff; opacity:.95; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-stage { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; padding:0 !important; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-content { position:absolute; top:0; left:0; display:flex; align-items:center; justify-content:center; margin:0 !important; max-width:none !important; max-height:none !important; width:auto; height:auto; transform:translate(0px,0px); }
#hwycLightbox.hwyc-fbox .hwyc-fbox-image { display:block; width:auto !important; height:auto !important; max-width:100% !important; max-height:100% !important; object-fit:contain; border-radius:0; box-shadow:0 24px 70px rgba(0,0,0,.45); transform-origin:center; transition:transform .18s ease,filter .22s ease,opacity .22s ease; filter:blur(10px); opacity:.9; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-image.is-loaded { filter:blur(0); opacity:1; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-arrow { position:absolute; top:50%; transform:translateY(-50%); width:56px; height:56px; border:0; border-radius:0; background:rgba(30,30,30,.65); color:#fff; display:grid; place-items:center; z-index:5; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-arrow svg { width:26px; height:26px; fill:#fff; opacity:.95; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-prev { left:16px; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-next { right:16px; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-caption { position:absolute; left:0; right:0; bottom:170px; padding:12px 16px; background:linear-gradient(to top,rgba(0,0,0,.55),rgba(0,0,0,0)); z-index:4; transition:bottom .18s ease,opacity .18s ease; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-caption-body { color:#fff; font-size:14px; opacity:.92; max-width:900px; margin:0 auto; text-align:center; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumbs { position:absolute; left:0; right:0; bottom:0; height:150px; padding:16px 16px 24px 16px; background:linear-gradient(to top,rgba(0,0,0,.75),rgba(0,0,0,.45),rgba(0,0,0,0)); z-index:4; display:flex; align-items:center; transition:transform .18s ease,opacity .18s ease; transform:translateY(0); opacity:1; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumbs.is-hidden { transform:translateY(110%); opacity:0; pointer-events:none; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumbs-list { display:flex; gap:12px; justify-content:center; align-items:center; width:100%; overflow-x:auto; overflow-y:hidden; padding-bottom:6px; scrollbar-width:none; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumbs-list::-webkit-scrollbar { display:none; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumb { -webkit-backface-visibility:hidden; backface-visibility:hidden; -webkit-tap-highlight-color:transparent; flex:0 0 auto; width:100px; height:75px; margin:2px; border-radius:0; background-color:rgba(0,0,0,.10); background-position:center; background-repeat:no-repeat; background-size:cover; cursor:pointer; outline:2px solid transparent; overflow:hidden; opacity:.70; transition:opacity .15s ease,outline-color .15s ease; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumb:hover { opacity:1; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-thumb.is-active { opacity:1; outline-color:rgba(255,255,255,.9); }
#hwycLightbox.hwyc-thumbs-hidden .hwyc-fbox-caption { bottom:18px; }
#hwycLightbox.hwyc-thumbs-hidden .hwyc-fbox-stage { padding-bottom:72px; }
#hwycLightbox.hwyc-zoomed .hwyc-fbox-caption { opacity:0; pointer-events:none; }
#hwycLightbox.hwyc-zoomed .hwyc-fbox-infobar { opacity:0; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-progress { position:absolute; left:0; right:0; top:0; height:1px; z-index:6; pointer-events:none; background:rgba(255,255,255,.08); opacity:.9; }
#hwycLightbox.hwyc-fbox .hwyc-fbox-progress-bar { width:0%; height:100%; background:#C1272D; transform:translateZ(0); }
@media(max-width:768px) {
  #hwycLightbox.hwyc-fbox .hwyc-fbox-infobar { top:calc(10px + env(safe-area-inset-top)) !important; left:12px !important; font-size:13px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-toolbar { top:calc(8px + env(safe-area-inset-top)) !important; right:10px !important; gap:6px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-btn { width:38px !important; height:38px !important; border-radius:10px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-btn svg { width:19px !important; height:19px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-arrow { width:44px !important; height:44px !important; border-radius:12px !important; top:calc(50% - 40px) !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-arrow svg { width:22px !important; height:22px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-prev { left:10px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-next { right:10px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-progress { top:0 !important; }
}
@media(max-width:576px) {
  #hwycLightbox.hwyc-fbox .hwyc-fbox-toolbar { right:8px !important; gap:5px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-btn { width:34px !important; height:34px !important; border-radius:9px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-btn svg { width:18px !important; height:18px !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-arrow { width:40px !important; height:40px !important; top:calc(50% - 46px) !important; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-thumbs { height:180px; padding:18px 12px 28px 12px; }
  #hwycLightbox.hwyc-fbox .hwyc-fbox-thumb { width:min(120px,calc(100% - 10px)); height:80px; }
}

/* ── Booking calendar / Flatpickr ────────────────────────── */
.sr-availability-card { background:#fff; border:1px solid rgba(15,27,42,.09); border-top:none; border-radius:0; box-shadow:none; overflow:hidden; }
.sr-availability-card__header { background:var(--brand-blue-dark); padding:.9rem 1.5rem; }
.sr-availability-card__header .h4,
.sr-availability-card__header h3 { margin-bottom:.2rem; font-family:var(--font-base); font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.92); }
.sr-availability-card__header p { margin-bottom:0; font-size:.82rem; color:var(--text-body); }
.sr-availability-card__body { padding:1.25rem; }
.sr-calendar-wrap { position:relative; display:flex; justify-content:center; width:100%; }
.sr-calendar-input { position:absolute; inset:0; opacity:0; pointer-events:none; }
.flatpickr-calendar.inline.sr-flatpickr { width:100% !important; max-width:720px; margin:0 auto; left:auto !important; right:auto !important; background:#fff; border:1px solid rgba(15,23,42,.08); border-radius:18px; box-shadow:none; overflow:hidden; }
.flatpickr-calendar.sr-flatpickr::before,
.flatpickr-calendar.sr-flatpickr::after { display:none; }
.sr-flatpickr .flatpickr-months { position:relative; background:#fff; border-bottom:1px solid rgba(15,23,42,.06); padding:.7rem 3rem; align-items:center; }
.sr-flatpickr .flatpickr-month { height:auto; }
.sr-flatpickr .flatpickr-current-month { position:static; display:flex; align-items:center; justify-content:center; gap:.35rem; width:100%; height:auto; padding:0; color:#0f172a; font-size:.98rem; font-weight:700; }
.sr-flatpickr .flatpickr-current-month .flatpickr-monthDropdown-months,
.sr-flatpickr .flatpickr-current-month input.cur-year { font-size:.98rem; font-weight:700; color:#0f172a; }
.sr-flatpickr .flatpickr-current-month .flatpickr-monthDropdown-months { appearance:none; border:0; background:transparent; padding:0; }
.sr-flatpickr .numInputWrapper:hover,
.sr-flatpickr .flatpickr-monthDropdown-months:hover { background:transparent; }
.sr-flatpickr .flatpickr-prev-month,
.sr-flatpickr .flatpickr-next-month { position:absolute; top:50%; transform:translateY(-50%); z-index:3; width:36px; height:36px; padding:0; border:1px solid rgba(15,23,42,.08); border-radius:999px; background:#fff; color:#0f172a; display:inline-flex; align-items:center; justify-content:center; transition:all .2s ease; }
.sr-flatpickr .flatpickr-prev-month { left:.75rem; }
.sr-flatpickr .flatpickr-next-month { right:.75rem; }
.sr-flatpickr .flatpickr-prev-month:hover,
.sr-flatpickr .flatpickr-next-month:hover { background:#f8fafc; border-color:rgba(15,23,42,.16); }
.sr-flatpickr .flatpickr-prev-month svg,
.sr-flatpickr .flatpickr-next-month svg { width:14px; height:14px; fill:currentColor; }
.sr-flatpickr.multiMonth .flatpickr-months,
.sr-flatpickr.multiMonth .flatpickr-innerContainer,
.sr-flatpickr.multiMonth .flatpickr-rContainer,
.sr-flatpickr.multiMonth .flatpickr-days { width:100% !important; max-width:100%; box-sizing:border-box; }
.sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month { position:relative; flex:1 1 0; }
.sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month:first-of-type { padding-right:14px; }
.sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month:last-of-type { padding-left:14px; }
.sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month:first-of-type::after { content:""; position:absolute; top:6px; right:0; bottom:6px; width:1px; }
.sr-flatpickr .flatpickr-weekdays { background:#fff; padding:.55rem .6rem 0; }
.sr-flatpickr span.flatpickr-weekday { background:transparent; color:#64748b; font-size:.74rem; font-weight:700; text-transform:lowercase; }
.sr-flatpickr.multiMonth .flatpickr-weekdays { display:flex; gap:24px; padding-left:.75rem; padding-right:.75rem; }
.sr-flatpickr.multiMonth .flatpickr-weekdaycontainer { display:flex; justify-content:space-between; flex:1 1 0; position:relative; }
.sr-flatpickr.multiMonth .flatpickr-weekdaycontainer:first-child::after { content:""; position:absolute; top:4px; right:-12px; bottom:4px; width:1px; }
.sr-flatpickr:not(.multiMonth) .flatpickr-weekdaycontainer { display:flex; justify-content:space-between; }
.sr-flatpickr:not(.multiMonth) .flatpickr-innerContainer,
.sr-flatpickr:not(.multiMonth) .flatpickr-rContainer { width:100%; display:block; }
.sr-flatpickr .flatpickr-days { width:100% !important; padding:.5rem .6rem .6rem; }
.sr-flatpickr:not(.multiMonth) .flatpickr-days { width:100% !important; }
.sr-flatpickr:not(.multiMonth) .dayContainer { min-width:0 !important; max-width:none !important; width:100% !important; }
.sr-flatpickr.multiMonth .flatpickr-days { display:flex; gap:24px; padding-left:.75rem; padding-right:.75rem; }
.sr-flatpickr .dayContainer { display:flex; flex-wrap:wrap; justify-content:flex-start; gap:0; padding:0; }
.sr-flatpickr.multiMonth .dayContainer { flex:1 1 0; min-width:0 !important; max-width:none !important; width:auto !important; position:relative; overflow:visible; background:#fff; border-radius:12px; }
.sr-flatpickr.multiMonth .dayContainer:first-child::after { content:""; position:absolute; top:0; right:-12px; bottom:0; width:1px; }
.sr-flatpickr .flatpickr-day { position:relative; display:inline-flex; align-items:flex-start; justify-content:flex-start; flex:0 0 calc(100% / 7); width:calc(100% / 7); max-width:calc(100% / 7); box-sizing:border-box; height:42px; line-height:1; margin:0; padding:6px 5px 4px; border-radius:10px; border:1px solid rgba(15,23,42,.08); color:#0f172a; font-size:.82rem; font-weight:700; transition:all .18s ease; }
.sr-flatpickr .flatpickr-day:hover { border-color:rgba(15,23,42,.14); }
.sr-flatpickr .flatpickr-day.prevMonthDay,
.sr-flatpickr .flatpickr-day.nextMonthDay { background:transparent; border-color:transparent; color:#cbd5e1; }
.sr-flatpickr .flatpickr-day.flatpickr-disabled,
.sr-flatpickr .flatpickr-day.flatpickr-disabled:hover { cursor:not-allowed; opacity:1; background:#ED1C24 !important; color:#fff !important; border-color:#ED1C24 !important; }
.sr-flatpickr .flatpickr-day.sr-day--free { background:#dff4d7; color:#0f172a; border-color:#bfe3b1; }
.sr-flatpickr .flatpickr-day.sr-day--occupied,
.sr-flatpickr .flatpickr-day.flatpickr-disabled.sr-day--occupied { background:#ED1C24; color:#ffffff; border-color:#ED1C24; pointer-events:none; cursor:default; }
.sr-flatpickr .flatpickr-day.sr-day--selectable { background:#2f8f2f !important; color:#ffffff !important; border-color:#297929 !important; }
.sr-flatpickr .flatpickr-day.sr-day--vorige-occupied { background:linear-gradient(135deg,#ED1C24 0%,#ED1C24 55%,#2f8f2f 55%,#2f8f2f 100%) !important; color:#ffffff !important; border-color:#297929 !important; }
.sr-flatpickr .flatpickr-day.sr-day--vorige-free { background:linear-gradient(135deg,#2f8f2f 0%,#2f8f2f 55%,#ED1C24 55%,#ED1C24 100%) !important; color:#ffffff !important; border-color:#297929 !important; }
.sr-flatpickr .flatpickr-day.sr-day--alt-changeover { background:#ED1C24 !important; color:#ffffff !important; border-color:#ED1C24 !important; pointer-events:auto !important; cursor:pointer !important; position:relative; }
.sr-flatpickr .flatpickr-day.sr-day--alt-changeover::after { display:none !important; }
.sr-flatpickr .flatpickr-day.sr-day--alt-changeover::before { content:'ℹ'; position:absolute; top:1px; right:2px; font-size:15px; line-height:1; color:#fff; opacity:.85; pointer-events:none; }
.sr-flatpickr .flatpickr-day.sr-day--today { box-shadow:inset 0 0 0 2px rgba(24,112,193,.2); }
.sr-flatpickr .flatpickr-day.selected,
.sr-flatpickr .flatpickr-day.startRange,
.sr-flatpickr .flatpickr-day.endRange { background:#1870C1 !important; border-color:#1870C1 !important; color:#ffffff !important; box-shadow:none; }
.sr-flatpickr .flatpickr-day.inRange,
.sr-flatpickr .flatpickr-day.sr-range-preview { background:#1870C1 !important; border-color:#1870C1 !important; color:#0f172a !important; box-shadow:none; }
.sr-flatpickr .flatpickr-day.startRange { border-top-right-radius:10px; border-bottom-right-radius:10px; }
.sr-flatpickr .flatpickr-day.endRange { border-top-left-radius:10px; border-bottom-left-radius:10px; }
.sr-flatpickr .flatpickr-day.startRange.endRange { border-radius:10px; }
.sr-flatpickr .flatpickr-day.selected.sr-day--occupied { background:#ED1C24 !important; border-color:#ED1C24 !important; }
.sr-flatpickr .sr-day-price { position:absolute; left:5px; bottom:4px; font-size:.62rem; line-height:1; font-weight:600; color:#64748b; pointer-events:none; }
.sr-flatpickr .flatpickr-day.selected .sr-day-price,
.sr-flatpickr .flatpickr-day.startRange .sr-day-price,
.sr-flatpickr .flatpickr-day.endRange .sr-day-price { color:rgba(255,255,255,.9); }
.sr-flatpickr .flatpickr-day.sr-day--valid-end { background:#1a7a4a !important; color:#fff !important; border-radius:0 !important; opacity:1 !important; }
.sr-flatpickr .flatpickr-day.sr-day--valid-end::after { display:none !important; }
.sr-flatpickr .flatpickr-day.sr-day--valid-end.selected,
.sr-flatpickr .flatpickr-day.sr-day--valid-end.startRange,
.sr-flatpickr .flatpickr-day.sr-day--valid-end.endRange,
.sr-flatpickr .flatpickr-day.sr-day--valid-end.inRange { background:#2e6da4 !important; color:#fff !important; }
.sr-flatpickr .flatpickr-day.sr-day--end-dimmed { opacity:.35 !important; }
.sr-flatpickr .flatpickr-day.sr-day--end-dimmed.inRange,
.sr-flatpickr .flatpickr-day.sr-day--end-dimmed:hover { opacity:1 !important; }
.sr-flatpickr .sr-day--alt-available::after { display:none !important; }
.sr-flatpickr .flatpickr-day:focus,
.sr-flatpickr .flatpickr-prev-month:focus,
.sr-flatpickr .flatpickr-next-month:focus { outline:2px solid rgba(24,112,193,.45); outline-offset:2px; }
@media(max-width:991.98px) {
  .sr-availability-card__header,
  .sr-availability-card__body { padding:1rem; }
  .sr-flatpickr .flatpickr-months { padding:.7rem 2.5rem; }
  .sr-flatpickr .flatpickr-current-month,
  .sr-flatpickr .flatpickr-current-month .flatpickr-monthDropdown-months,
  .sr-flatpickr .flatpickr-current-month input.cur-year { font-size:.92rem; }
  .sr-flatpickr .flatpickr-day { font-size:.8rem; padding:5px 4px 4px; }
  .sr-flatpickr.multiMonth .flatpickr-weekdays,
  .sr-flatpickr.multiMonth .flatpickr-days { gap:12px; }
  .sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month:first-of-type { padding-right:8px; }
  .sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month:last-of-type { padding-left:8px; }
  .sr-flatpickr.multiMonth .flatpickr-months .flatpickr-month:first-of-type::after,
  .sr-flatpickr.multiMonth .flatpickr-weekdaycontainer:first-child::after,
  .sr-flatpickr.multiMonth .dayContainer:first-child::after { right:-6px; }
}
@media(max-width:767.98px) {
  .sr-calendar-wrap { justify-content:stretch; }
  .flatpickr-calendar.inline.sr-flatpickr { width:100% !important; }
  .sr-flatpickr .flatpickr-months { padding:.6rem 2.25rem; }
  .sr-flatpickr .flatpickr-weekdays { padding:.45rem .45rem 0; }
  .sr-flatpickr .flatpickr-days { padding:.45rem; }
  .sr-flatpickr .dayContainer { gap:3px 0; }
  .sr-flatpickr .flatpickr-day { padding:4px 3px 3px; border-radius:8px; font-size:.75rem; }
  .sr-flatpickr span.flatpickr-weekday { font-size:.68rem; }
  .sr-legend-item { padding:7px 10px; font-size:.84rem; }
  .sr-accommodatie-prijs .card-body { padding:.9rem; }
  .sr-accommodatie-prijs .sr-boeken-prijs-voor,
  .sr-accommodatie-prijs .fs-4 { font-size:1.35rem !important; }
}
@media(max-width:575.98px) {
  .sr-availability-card { border-radius:16px; }
  .flatpickr-calendar.inline.sr-flatpickr { border-radius:14px; }
  .sr-flatpickr .flatpickr-prev-month,
  .sr-flatpickr .flatpickr-next-month { width:32px; height:32px; }
  .sr-flatpickr .flatpickr-day { font-size:.72rem; }
}

/* ── Legenda ──────────────────────────────────────────────── */
#legenda.sr-legend { display:flex; flex-wrap:wrap; gap:12px; margin-top:1rem; }
.sr-legend-item { display:flex; align-items:center; gap:8px; padding:8px 12px; background:#fff; border:1px solid rgba(15,23,42,.06); border-radius:999px; font-size:.9rem; color:#334155; white-space:nowrap; }
.sr-legend-item:hover { background:#f8fafc; }
.sr-legend-dot { width:14px; height:14px; border-radius:4px; display:inline-block; flex:0 0 14px; }
.sr-legend-dot.aankomst { background:linear-gradient(135deg,#2f8f2f 0%,#2f8f2f 55%,#ED1C24 55%,#ED1C24 100%); }
.sr-legend-dot.alt-wisseldag { background:linear-gradient(to bottom,#2f8f2f 0%,#2f8f2f 75%,#ED1C24 75%,#ED1C24 100%); }
.sr-legend-dot.beschikbaar { background:#dff4d7; border:1px solid #bfe3b1; }
.sr-legend-dot.bezet { background:#ED1C24; }
.sr-legend-dot.alternatief { background:linear-gradient(to bottom,#ED1C24 0%,#ED1C24 75%,#dff4d7 75%,#dff4d7 100%); }
.sr-legend-dot.geselecteerd { background:#1870C1; }


/* ── Price card & booking summary ────────────────────────── */
.sr-accommodatie-prijs { margin-top:1.25rem; }
.sr-accommodatie-prijs .card { border:1px solid rgba(15,23,42,.08); border-radius:18px; box-shadow:0 8px 24px rgba(15,23,42,.05); }
.sr-accommodatie-prijs .card-body { padding:1rem 1.1rem; }
.sr-accommodatie-prijs .small.text-muted { color:#64748b !important; letter-spacing:.01em; }
.sr-accommodatie-prijs .fw-bold,
.sr-accommodatie-prijs .fw-semibold { color:#0f172a; }
.sr-accommodatie-prijs .sr-boeken-prijs-voor,
.sr-accommodatie-prijs .fs-4 { font-size:1.75rem !important; font-weight:800 !important; color:var(--brand-blue-dark) !important; font-family:var(--font-base) !important; margin-bottom:1.25rem !important; padding-bottom:1.25rem; border-bottom:1px solid rgba(15,27,42,.06); }
.sr-accommodatie-prijs .btn,
.sr-accommodatie-prijs button { border-radius:12px; min-height:48px; font-weight:600; }
.sr-accommodatie-prijs:not(:has(.card)) { padding:1rem 1.1rem; border:1px solid rgba(15,23,42,.08); border-radius:16px; background:#fff; color:#475569; box-shadow:0 8px 24px rgba(15,23,42,.04); }
.sr-accommodatie-prijs .text-primary { color:var(--brand-blue-dark) !important; }
.sr-accommodatie-prijs .form-control { border-radius:0 !important; border-color:rgba(15,27,42,.14) !important; font-size:.875rem !important; }
.sr-accommodatie-prijs .small.text-muted.fw-semibold { display:block; font-size:.62rem !important; letter-spacing:.10em !important; text-transform:uppercase !important; color:rgba(15,27,42,.38) !important; margin-bottom:.3rem; }
.sr-accommodatie-prijs .fw-bold.mb-3 { margin-bottom:1.25rem !important; padding-bottom:1.25rem; border-bottom:1px solid rgba(15,27,42,.06); }
.sr-accommodatie-prijs .mb-3 { margin-bottom:1.25rem !important; }
.sr-accommodatie-prijs .d-grid { gap:.5rem !important; margin-top:.25rem; }
.sr-accommodatie-prijs .btn.btn-primary,
.sr-accommodatie-prijs a.btn-primary { background:#1a7a4a !important; border-color:#1a7a4a !important; border-radius:0 !important; font-size:.72rem !important; font-weight:700 !important; letter-spacing:.10em !important; text-transform:uppercase !important; color:#fff !important; box-shadow:0 2px 12px rgba(26,122,74,.25) !important; }
.sr-accommodatie-prijs .btn.btn-primary:hover { background:#155f38 !important; border-color:#155f38 !important; box-shadow:0 4px 16px rgba(26,122,74,.35) !important; }
.sr-accommodatie-prijs .btn.btn-outline-dark { border-radius:0 !important; border-color:rgba(15,27,42,.18) !important; color:rgba(15,27,42,.6) !important; font-size:.68rem !important; font-weight:700 !important; letter-spacing:.08em !important; text-transform:uppercase !important; }
.hwyc-booking-idle { padding:1.25rem 1.5rem; }
.hwyc-booking-idle__text { font-size:.83rem; color:rgba(15,27,42,.45); margin:0; line-height:1.65; }
.sr-accommodatie-prijs .card { border:none !important; border-radius:0 !important; box-shadow:none !important; border-top:1px solid rgba(15,27,42,.07) !important; }
#hwycBooking .sr-accommodatie-prijs .card-body { padding:1.5rem !important; }
.sr-accommodatie-prijs .sr-incl-extras { margin:-.25rem 0 .75rem; }

/* Compact price block */
.sr-price-compact { margin-bottom:.75rem; }
.sr-price-compact__row { display:flex; justify-content:space-between; align-items:baseline; padding:.3rem 0; border-bottom:1px solid rgba(15,27,42,.06); }
.sr-price-compact__row--price { border-bottom:none; padding-bottom:.1rem; }
.sr-price-compact__label { font-size:.62rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:rgba(15,27,42,.42); }
.sr-price-compact__val { font-size:.82rem; color:var(--brand-blue-dark); font-weight:600; }
.sr-price-compact__price { font-size:1.35rem; font-weight:800; color:var(--brand-blue-dark); font-family:var(--font-base); }
.sr-price-guarantee--compact { margin-top:.3rem !important; font-size:.65rem !important; }
.sr-price-guarantee { font-size:.75rem; font-weight:700; color:var(--brand-red); letter-spacing:.03em; margin-top:-.75rem; margin-bottom:1.25rem; padding-bottom:1.25rem; border-bottom:1px solid rgba(15,27,42,.06); }

/* Email lead */
.sr-lead-email-block { margin-top:.25rem; }
.sr-lead-label { display:block; font-family:var(--font-base); font-size:.88rem; font-weight:600; color:var(--brand-blue-dark); margin-bottom:.5rem; line-height:1.4; }
.sr-lead-privacy { margin-top:.35rem; font-size:.68rem; color:rgba(15,27,42,.35); letter-spacing:.01em; }
.sr-input-error { border-color:var(--brand-red) !important; box-shadow:0 0 0 2px rgba(183,12,18,.15) !important; }
.sr-email-error { margin-top:.35rem; font-size:.75rem; color:var(--brand-red); font-weight:600; }

/* Calendar summary bar */
.sr-cal-summary { margin-top:0; padding:1rem 1.25rem 1.1rem; background:#fff; border-top:1px solid rgba(15,27,42,.08); }
.sr-cal-summary__inner { display:flex; align-items:center; justify-content:space-between; gap:.75rem 1rem; flex-wrap:wrap; }
.sr-cal-summary__meta { display:flex; flex-direction:column; gap:.1rem; }
.sr-cal-summary__period { font-size:.7rem; color:rgba(15,27,42,.42); letter-spacing:.05em; text-transform:uppercase; }
.sr-cal-summary__price { font-size:1.35rem; font-weight:800; font-family:var(--font-base); color:var(--brand-blue-dark); line-height:1.1; }
.sr-cal-summary__cta { background:#1a7a4a; color:#fff !important; padding:.65rem 1.25rem; font-size:.72rem; font-weight:700; letter-spacing:.10em; text-transform:uppercase; white-space:nowrap; text-decoration:none !important; flex-shrink:0; }
.sr-cal-summary__cta:hover { background:#155f38; }
.sr-cal-summary__guarantee { margin-top:.55rem; font-size:.68rem; font-weight:700; color:#1a7a4a; letter-spacing:.03em; }
.sr-cal-summary__noprice { padding:.1rem 0; }
.sr-cal-summary__noprice p { margin:0 0 .25rem; font-size:.85rem; color:var(--brand-red); font-weight:600; }
.sr-cal-noprice__msg { font-size:.88rem; color:rgba(15,27,42,.7); margin:0 0 .75rem; }
.sr-cal-noprice__alt-btn { display:block; width:100%; padding:.7rem 1rem; background:var(--brand-navy,#1a2e4a); color:#fff; font-size:.82rem; font-weight:700; letter-spacing:.05em; text-align:center; text-decoration:none; border-radius:3px; transition:background .15s; }
.sr-cal-noprice__alt-btn:hover { background:var(--brand-red,#c0392b); color:#fff; }

/* Included extras */
.sr-incl-extras { margin:.6rem 0 .5rem; padding:.6rem .75rem; background:rgba(15,27,42,.04); border-left:3px solid var(--brand-blue-dark); }
.sr-incl-label { font-size:.62rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:rgba(15,27,42,.42); margin-bottom:.35rem; }
.sr-incl-item { display:flex; justify-content:space-between; align-items:baseline; font-size:.78rem; color:var(--brand-blue-dark); padding:.1rem 0; }
.sr-incl-title { font-weight:500; }
.sr-incl-price { font-weight:700; white-space:nowrap; margin-left:.5rem; }

/* Default CTA wrapper */
#sr-default-cta { padding:1.25rem 1.5rem; border-top:1px solid rgba(15,27,42,.07); }
.hwyc-btn-check-avail { display:block; width:100%; background:var(--brand-blue-dark); color:#fff !important; text-align:center; padding:.78rem 1rem; font-family:var(--font-base); font-size:.72rem; font-weight:700; letter-spacing:.10em; text-transform:uppercase; text-decoration:none !important; transition:background .18s; }
.hwyc-btn-check-avail:hover { background:#1a2f45; color:#fff !important; }
.hwyc-booking-advisor-link { display:block; text-align:center; font-size:.75rem; color:var(--brand-blue); text-decoration:none; font-weight:600; letter-spacing:.03em; margin-top:.6rem; }
.hwyc-booking-advisor-link:hover { color:var(--brand-blue-dark); }
.hwyc-booking-footer { padding:1rem 1.5rem; border-top:1px solid rgba(15,27,42,.06); background:#f8fafc; }
.hwyc-booking-trust-list { list-style:none; margin:0; padding:0; font-size:.75rem; color:rgba(15,27,42,.72); line-height:1.7; }
.hwyc-booking-trust-list li { padding-left:1.4rem; position:relative; }
.hwyc-booking-trust-list li::before { content:"✓"; position:absolute; left:0; color:var(--brand-red); font-weight:700; }

/* Alt popup */
.sr-alt-popup { position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; padding:1rem; }
.sr-alt-popup[hidden] { display:none; }
.sr-alt-popup__overlay { position:absolute; inset:0; background:rgba(15,27,42,.5); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px); cursor:pointer; }
.sr-alt-popup__box { position:relative; background:#fff; border-radius:10px; box-shadow:0 20px 60px rgba(15,27,42,.22); padding:2rem 1.5rem 1.5rem; max-width:360px; width:100%; text-align:center; animation:srAltPopIn .22s ease; }
@keyframes srAltPopIn { from { opacity:0; transform:translateY(10px) scale(.97); } to { opacity:1; transform:none; } }
.sr-alt-popup__close { position:absolute; top:.75rem; right:.75rem; width:32px; height:32px; border:1px solid rgba(15,27,42,.15); border-radius:50%; background:#fff; color:rgba(15,27,42,.5); display:flex; align-items:center; justify-content:center; cursor:pointer; padding:0; }
.sr-alt-popup__close:hover { background:rgba(15,27,42,.06); }
.sr-alt-popup__icon { font-size:2rem; margin-bottom:.5rem; }
.sr-alt-popup__title { font-size:1.05rem; font-weight:800; color:var(--brand-blue-dark,#1a2e4a); margin:0 0 .5rem; }
.sr-alt-popup__msg { font-size:.875rem; color:rgba(15,27,42,.65); line-height:1.6; margin:0 0 1.25rem; }
.sr-alt-popup__cta { display:block; width:100%; padding:.8rem 1rem; background:var(--brand-blue-dark,#1a2e4a); color:#fff; font-size:.85rem; font-weight:700; border:none; border-radius:4px; cursor:pointer; transition:background .15s; }
.sr-alt-popup__cta:hover { background:var(--brand-red,#c0392b); }

/* ── Section order (Nautica) ─────────────────────────────── */
.hwyc-acco main.my-4 { display:flex; flex-direction:column; }
#hwycAvailability             { order:4; }
#hwycGoogleReviews            { order:3; }
#hwycExperiences              { order:2; }
#hwycDescription              { order:9; }
#hwycInterior                 { order:7; }
#hwycExterior                 { order:8; }
#hwycVideo                    { order:1; }
#hwycOverview                 { order:6; }
#hwycDetails                  { order:12; }
#hwycAmenities                { order:13; }
#hwycBookableExtras           { order:14; }
#hwycAlternativeYachts        { order:10; }
#hwycFrequentlyAskedQuestions { order:11; }
#hwycTravelItineraries        { order:5; }
#hwycPersonalContactInfo      { order:15; }

/* ── Route panel ─────────────────────────────────────────── */
.hwyc-route-panel { position:fixed; inset:0; z-index:10000; display:flex; justify-content:flex-end; }
.hwyc-route-panel[hidden] { display:none; }
.hwyc-route-panel__overlay { position:absolute; inset:0; background:rgba(15,27,42,.45); backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); cursor:pointer; }
.hwyc-route-panel__drawer { position:relative; width:100%; max-width:480px; background:#fff; display:flex; flex-direction:column; height:100%; overflow:hidden; box-shadow:-8px 0 32px rgba(15,27,42,.18); animation:hwyc-slide-in .28s cubic-bezier(.25,.46,.45,.94); }
@keyframes hwyc-slide-in { from { transform:translateX(100%); } to { transform:translateX(0); } }
@media(max-width:520px) { .hwyc-route-panel__drawer { max-width:100%; } }
.hwyc-route-panel__head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:1.25rem 1.25rem 1rem; border-bottom:1px solid #e5e7eb; background:var(--brand-navy,#1a2e4a); }
.hwyc-route-panel__label { font-size:.65rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:.25rem; }
.hwyc-route-panel__title { font-size:1.1rem; font-weight:800; color:#fff; margin:0; line-height:1.2; }
.hwyc-route-panel__close { width:34px; height:34px; border:1.5px solid rgba(255,255,255,.35); border-radius:50%; background:transparent; color:rgba(255,255,255,.75); cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; padding:0; transition:background .15s; }
.hwyc-route-panel__close:hover { background:rgba(255,255,255,.15); color:#fff; }
.hwyc-route-panel__body { flex:1; overflow-y:auto; padding:1.25rem; }
.hwyc-route-panel__intro,
.hwyc-route-panel__day-desc { font-size:.875rem; line-height:1.7; color:rgba(15,27,42,.82); margin:0 0 1rem; }
.hwyc-route-panel__stops { display:flex; flex-wrap:wrap; align-items:center; gap:.3rem; margin-bottom:1.25rem; padding:.75rem; background:#f5f6f8; border-radius:6px; font-size:.78rem; }
.hwyc-route-panel__stop { font-weight:600; color:var(--brand-navy,#1a2e4a); }
.hwyc-route-panel__arrow { color:rgba(15,27,42,.3); font-size:.7rem; }
.hwyc-route-panel__day { border-left:3px solid var(--brand-red,#c0392b); padding:.65rem .85rem; margin-bottom:.75rem; background:#fff; border-radius:0 4px 4px 0; box-shadow:0 1px 4px rgba(15,27,42,.06); }
.hwyc-route-panel__day-head { display:flex; align-items:baseline; gap:.5rem; margin-bottom:.3rem; }
.hwyc-route-panel__day-num { font-size:.65rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--brand-red,#c0392b); }
.hwyc-route-panel__day-title { font-size:.88rem; font-weight:700; color:var(--brand-navy,#1a2e4a); }
.hwyc-route-panel__day-stats { display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:.3rem; }
.hwyc-route-panel__day-stat { font-size:.68rem; color:rgba(15,27,42,.5); background:#f0f0f1; padding:.15rem .5rem; border-radius:10px; }
.hwyc-route-panel__footer { padding:1rem 1.25rem; border-top:1px solid #e5e7eb; background:#fff; }
.hwyc-route-panel__cta { display:block; width:100%; padding:.8rem; background:var(--brand-navy,#1a2e4a); color:#fff; text-align:center; font-size:.875rem; font-weight:700; text-decoration:none; border-radius:4px; transition:background .15s; }
.hwyc-route-panel__cta:hover { background:var(--brand-red,#c0392b); color:#fff; }

/* Route strip */
.hwyc-routes-outer { display:flex; align-items:center; gap:.5rem; }
.hwyc-routes-strip { display:flex; gap:1rem; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; padding-bottom:.25rem; scroll-snap-type:x mandatory; overscroll-behavior-x:contain; }
.hwyc-routes-strip::-webkit-scrollbar { display:none; }
.hwyc-route-card { background:none; border:none; padding:0; text-align:left; cursor:pointer; flex:0 0 220px; display:flex; flex-direction:column; text-decoration:none !important; color:inherit; border:1px solid rgba(15,27,42,.09); border-radius:4px; overflow:hidden; scroll-snap-align:start; transition:box-shadow .18s,transform .18s; }
@media(max-width:639px) { .hwyc-route-card { flex:0 0 72vw; } }
.hwyc-route-card:hover { box-shadow:0 4px 16px rgba(15,27,42,.12); transform:translateY(-2px); }
.hwyc-route-card__img { width:100%; aspect-ratio:16/9; background:var(--brand-navy,#1a2e4a) center/cover no-repeat; display:flex; align-items:center; justify-content:center; }
.hwyc-route-card__body { padding:.75rem .9rem .65rem; display:flex; flex-direction:column; gap:.3rem; flex:1; }
.hwyc-route-card__chips { display:flex; align-items:center; gap:.35rem; flex-wrap:wrap; }
.hwyc-route-card__days { font-size:.65rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; background:var(--brand-navy,#1a2e4a); color:#fff; padding:.15rem .5rem; border-radius:10px; }
.hwyc-route-card__diff { font-size:.65rem; color:rgba(15,27,42,.5); border:1px solid rgba(15,27,42,.15); padding:.15rem .5rem; border-radius:10px; }
.hwyc-route-card__kids { font-size:.85rem; }
.hwyc-route-card__name { font-size:.85rem; font-weight:700; color:var(--brand-blue-dark,#1a2e4a); line-height:1.25; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hwyc-route-card__stops { font-size:.7rem; color:rgba(15,27,42,.45); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hwyc-route-card__cta { margin-top:auto; padding-top:.4rem; font-size:.65rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--brand-blue-dark,#1a2e4a); }
.hwyc-route-card:hover .hwyc-route-card__cta { color:var(--brand-red,#c0392b); }

/* Extras grid */
.hwyc-extras-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; margin-bottom:12px; }
.hwyc-extra-card { border:1px solid rgba(15,27,42,.1); border-radius:6px; padding:.85rem 1rem; background:#fff; display:flex; flex-direction:column; gap:.4rem; transition:box-shadow .15s,border-color .15s; }
.hwyc-extra-card:hover { box-shadow:0 3px 12px rgba(15,27,42,.08); border-color:rgba(15,27,42,.2); }
.hwyc-extra-card__top { display:flex; align-items:flex-start; justify-content:space-between; gap:.5rem; }
.hwyc-extra-card__title { font-size:.82rem; font-weight:700; color:var(--brand-blue-dark,#1a2e4a); line-height:1.3; }
.hwyc-extra-card__badge { font-size:.6rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; background:rgba(15,27,42,.06); color:rgba(15,27,42,.5); padding:.15rem .45rem; border-radius:10px; white-space:nowrap; flex-shrink:0; }
.hwyc-extra-card__badge--qty { background:rgba(26,46,74,.08); color:var(--brand-blue-dark,#1a2e4a); }
.hwyc-extra-card__desc { font-size:.72rem; color:rgba(15,27,42,.55); line-height:1.5; margin:0; flex:1; }
.hwyc-extra-card__price { display:flex; align-items:baseline; gap:.3rem; margin-top:auto; padding-top:.4rem; border-top:1px solid rgba(15,27,42,.06); }
.hwyc-extra-card__amount { font-size:.95rem; font-weight:800; color:var(--brand-red,#c0392b); }
.hwyc-extra-card__per { font-size:.65rem; color:rgba(15,27,42,.4); font-weight:500; }
.hwyc-extra-card__free { font-size:.78rem; font-weight:700; color:#16a34a; }
.hwyc-extra-card__note { font-size:.72rem; color:rgba(15,27,42,.4); margin:4px 0 0; font-style:italic; }

/* Life On Board grid */
.hwyc-lob-grid { column-count:3; column-gap:6px; padding:10px; background:#fff; }
@media(min-width:768px) and (max-width:1023px) { .hwyc-lob-grid { column-count:2; } }
.hwyc-lob-item { break-inside:avoid; margin-bottom:6px; border-radius:3px; overflow:hidden; display:block; }
.hwyc-lob-item img { width:100%; height:auto; display:block; transition:transform .4s ease; will-change:transform; }
.hwyc-lob-item:hover img { transform:scale(1.04); }
@media(max-width:767px) {
  .hwyc-lob-grid { column-count:unset; display:flex; gap:8px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; scroll-snap-type:x mandatory; overscroll-behavior-x:contain; padding:10px; }
  .hwyc-lob-grid::-webkit-scrollbar { display:none; }
  .hwyc-lob-item { flex:0 0 72vw; margin-bottom:0; scroll-snap-align:start; aspect-ratio:4/3; }
  .hwyc-lob-item img { width:100%; height:100%; object-fit:cover; }
}
@media(prefers-reduced-motion:reduce) { .hwyc-lob-item img { transition:none; } }

/* Advisor */
.hwyc-advisor { display:grid; grid-template-columns:260px 1fr; gap:0; background:#fff; overflow:hidden; min-height:340px; }
@media(max-width:767px) { .hwyc-advisor { grid-template-columns:1fr; } }
.hwyc-advisor__photo-wrap { position:relative; overflow:hidden; min-height:320px; }
.hwyc-advisor__photo { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
@media(max-width:767px) { .hwyc-advisor__photo-wrap { min-height:260px; max-height:300px; } }
.hwyc-advisor__badge { position:absolute; bottom:12px; left:12px; background:rgba(15,27,42,.82); color:#f4c430; font-size:.72rem; font-weight:700; padding:.3rem .65rem; border-radius:20px; display:flex; align-items:center; gap:4px; backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); }
.hwyc-advisor__content { padding:1.75rem 1.75rem 1.5rem; display:flex; flex-direction:column; justify-content:center; }
@media(max-width:767px) { .hwyc-advisor__content { padding:1.25rem 1rem 1.25rem; } }
.hwyc-advisor__label { font-size:.68rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--brand-red,#c0392b); margin-bottom:.5rem; }
.hwyc-advisor__title { font-size:clamp(1.1rem,2.5vw,1.35rem); font-weight:800; color:var(--brand-blue-dark,#1a2e4a); margin:0 0 .75rem; line-height:1.2; }
.hwyc-advisor__intro,
.hwyc-advisor__trust li { font-size:.875rem; line-height:1.7; color:rgba(15,27,42,.82); margin:0 0 1.1rem; }
.hwyc-advisor__trust { list-style:none; padding:0; margin:0 0 1.4rem; display:flex; flex-direction:column; gap:.35rem; }
.hwyc-advisor__trust li { font-size:.8rem; padding-left:1.2rem; position:relative; }
.hwyc-advisor__trust li::before { content:'✓'; position:absolute; left:0; color:var(--brand-red,#c0392b); font-weight:700; }
.hwyc-advisor__actions { display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:1.1rem; }
.hwyc-advisor__btn { display:inline-flex; align-items:center; gap:.45rem; padding:.6rem 1.1rem; font-size:.78rem; font-weight:700; letter-spacing:.04em; text-decoration:none !important; border-radius:3px; transition:background .15s,transform .1s; white-space:nowrap; min-height:40px; }
.hwyc-advisor__btn:active { transform:scale(.97); }
.hwyc-advisor__btn--primary { background:var(--brand-red,#c0392b); color:#fff !important; }
.hwyc-advisor__btn--primary:hover { background:#9a0a0f; }
.hwyc-advisor__btn--whatsapp { background:#25d366; color:#fff !important; }
.hwyc-advisor__btn--whatsapp:hover { background:#1ebe5e; }
.hwyc-advisor__btn--secondary { background:rgba(15,27,42,.06); color:var(--brand-blue-dark,#1a2e4a) !important; border:1px solid rgba(15,27,42,.15); }
.hwyc-advisor__btn--secondary:hover { background:rgba(15,27,42,.11); }
.hwyc-advisor__hours { font-size:.72rem; color:rgba(15,27,42,.4); margin:0; display:flex; align-items:center; gap:5px; }

/* Vanaf-prijs */
.hwyc-vanaf-prijs { display:flex; align-items:baseline; gap:.35rem; flex-wrap:wrap; margin:.5rem 0 .25rem; }
.hwyc-vanaf-prijs__label { font-size:.75rem; color:rgba(15,27,42,.45); text-transform:uppercase; letter-spacing:.06em; }
.hwyc-vanaf-prijs__price { font-size:1.55rem; font-weight:800; color:var(--brand-blue-dark); line-height:1; }
.hwyc-vanaf-prijs__unit { font-size:.8rem; color:rgba(15,27,42,.45); }
.hwyc-vanaf-prijs__cta { font-size:.72rem; font-weight:700; color:var(--brand-red); text-decoration:none; letter-spacing:.04em; margin-left:.5rem; white-space:nowrap; }
.hwyc-vanaf-prijs__cta:hover { text-decoration:underline; }
.hwyc-meta-rating-link { display:inline-flex; align-items:center; gap:4px; text-decoration:none; color:inherit; }
.hwyc-meta-rating-link:hover .hwyc-rating-num { color:var(--brand-red); }

/* Title block */
.hwyc-title-block { background:#fff; padding:2rem 1.75rem 1.75rem; border-bottom:1px solid rgba(15,27,42,.07); }
.hwyc-title-row { display:flex; align-items:baseline; flex-wrap:wrap; gap:.35rem .65rem; margin-bottom:.75rem; }
.hwyc-title { font-family:var(--font-heading); font-size:clamp(1.5rem,3vw,2.1rem); color:var(--brand-blue-dark); font-weight:700; letter-spacing:-.01em; margin:0; line-height:1.2; }
.hwyc-title-addon { font-size:clamp(.95rem,2vw,1.15rem); color:rgba(15,27,42,.55); font-weight:400; font-style:italic; font-family:var(--font-heading); margin:0; line-height:1.3; }
.hwyc-pers-note { font-size:.75rem; color:rgba(15,27,42,.50); margin:.25rem 0 0; letter-spacing:.02em; }
.hwyc-meta-line { display:flex; flex-wrap:wrap; align-items:center; gap:.15rem .4rem; margin-bottom:1.1rem; font-size:.85rem; }
.hwyc-stars { color:#c5a56d; font-size:.85rem; letter-spacing:.05em; }
.hwyc-rating-num { color:var(--brand-blue-dark); font-weight:800; font-size:1rem; }
.hwyc-meta-dot { color:rgba(15,27,42,.28); }

/* Specs strip */
.hwyc-specs-strip { display:flex; flex-wrap:wrap; gap:0; margin-bottom:1rem; padding:1rem 0 1.25rem; border-top:1px solid rgba(15,27,42,.07); border-bottom:1px solid rgba(15,27,42,.07); }
.hwyc-spec-chip { display:flex; flex-direction:column; align-items:center; padding:.35rem 1.25rem; min-width:72px; text-align:center; gap:2px; }
.hwyc-spec-chip + .hwyc-spec-chip { border-left:1px solid rgba(15,27,42,.10); }
.hwyc-spec-chip:first-child { padding-left:0; align-items:flex-start; }
.hwyc-spec-chip i { display:none; }
.hwyc-spec-chip strong { font-size:1.6rem; font-weight:800; color:var(--brand-blue-dark); line-height:1; font-family:var(--font-heading,'Libre Baskerville',serif); }
.hwyc-spec-chip span { font-size:.68rem; font-weight:600; color:rgba(15,27,42,.58); text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; }
@media(max-width:479px) {
  .hwyc-spec-chip { padding:.3rem .75rem; min-width:56px; }
  .hwyc-spec-chip strong { font-size:1.3rem; }
  .hwyc-spec-chip:first-child { align-items:center; padding-left:.75rem; }
}

/* Trust line */
.hwyc-trust-line { display:flex; flex-wrap:wrap; align-items:center; gap:.2rem .45rem; font-size:.72rem; color:rgba(15,27,42,.38); letter-spacing:.04em; text-transform:uppercase; }
.hwyc-trust-dot { color:rgba(15,27,42,.18); }

/* Overview grid */
.hwyc-overview-grid { gap:0; }
.hwyc-overview-cell { padding:1.4rem 1rem; text-align:center; border-right:1px solid rgba(15,27,42,.07); border-bottom:1px solid rgba(15,27,42,.07); transition:background .15s; }
.hwyc-overview-cell:hover { background:#f8fafc; }
.hwyc-ov-icon { font-size:1.1rem; color:var(--brand-red); display:block; margin-bottom:.3rem; }
.hwyc-ov-val { font-size:1.2rem; font-weight:800; color:var(--brand-blue-dark); line-height:1.15; font-family:var(--font-base); }
.hwyc-ov-label { font-size:.62rem; color:rgba(15,27,42,.42); margin-top:.2rem; letter-spacing:.08em; text-transform:uppercase; }
@media(max-width:575px) {
  .hwyc-title-block { padding:1.5rem 1rem; margin:0; }
  .hwyc-overview-cell { padding:1rem .5rem; }
  .hwyc-spec-chip + .hwyc-spec-chip { padding-left:.5rem; }
}

/* Alt strip */
.hwyc-alt-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
@media(max-width:991.98px) { .hwyc-alt-strip { display:flex; gap:.85rem; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; padding-bottom:.25rem; overscroll-behavior-x:contain; } .hwyc-alt-strip::-webkit-scrollbar { display:none; } }
.hwyc-alt-card { display:flex; flex-direction:column; text-decoration:none !important; color:inherit; border:1px solid rgba(15,27,42,.09); transition:box-shadow .18s,transform .18s; min-width:0; }
@media(max-width:991.98px) { .hwyc-alt-card { flex:0 0 64vw; max-width:64vw; } }
.hwyc-alt-card:hover { box-shadow:0 4px 18px rgba(15,27,42,.10); transform:translateY(-2px); }
.hwyc-alt-card__img { width:100%; aspect-ratio:3/2; background-size:cover; background-position:center; background-color:var(--gray-300); }
.hwyc-alt-card__body { padding:.75rem .9rem; flex:1; display:flex; flex-direction:column; gap:.2rem; }
.hwyc-alt-card__name { font-family:var(--font-base); font-size:.82rem; font-weight:700; color:var(--brand-blue-dark); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hwyc-alt-card__specs { font-size:.72rem; color:rgba(15,27,42,.45); display:flex; align-items:center; gap:.25rem; }
.hwyc-alt-sep { opacity:.4; }
.hwyc-alt-card__cta { margin-top:auto; padding-top:.5rem; font-size:.68rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--brand-blue-dark); }
.hwyc-alt-card:hover .hwyc-alt-card__cta { color:var(--brand-red); }
.hwyc-alt-card__period { display:flex; flex-direction:column; gap:.1rem; margin-top:auto; padding-top:.5rem; border-top:1px solid rgba(15,27,42,.07); }
.hwyc-alt-card__alt-label { font-size:.62rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--brand-red); }
.hwyc-alt-card__dates { font-size:.72rem; color:rgba(15,27,42,.5); }
.hwyc-alt-card__best-label { position:absolute; top:.55rem; left:.55rem; background:var(--brand-blue-dark); color:#fff; font-size:.62rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:.2rem .55rem; z-index:2; pointer-events:none; }
.hwyc-alt-card--best { position:relative; }
.hwyc-alt-card__price { font-size:.85rem; font-weight:700; color:var(--brand-blue-dark); }
.hwyc-alt-card--alt { opacity:.88; }
.hwyc-alt-card--alt:hover { opacity:1; }
.hwyc-alt-loading { font-size:.78rem; color:rgba(15,27,42,.38); padding:.5rem 0; letter-spacing:.03em; }
.hwyc-alt-link--light { color:var(--brand-blue-dark) !important; font-size:.78rem; font-weight:700; text-decoration:underline; text-underline-offset:2px; }
.hwyc-alt-link--light:hover { color:var(--brand-blue) !important; }
.hwyc-alt-link { font-size:.78rem; font-weight:700; color:var(--brand-blue-dark); text-decoration:underline; text-underline-offset:2px; }
.hwyc-alt-link:hover { color:var(--brand-blue); }

/* Google Reviews */
#hwycGoogleReviews .card-header { background:var(--brand-blue-dark,#1a2e4a) !important; border-bottom-color:rgba(255,255,255,.1); }
#hwycGoogleReviews .card-header strong { color:#fff; }
#hwycGoogleReviews .card-header strong::before { background:#f4c430; }
.hwyc-rv-score { display:flex; align-items:center; gap:5px; white-space:nowrap; }
.hwyc-rv-score__num { font-size:1rem; font-weight:800; color:#fff; line-height:1; }
.hwyc-rv-score__stars { display:inline-flex; align-items:center; gap:1px; }
.hwyc-rv-score__count { font-size:.78rem; color:rgba(255,255,255,.65); font-weight:500; }
.hwyc-rv-outer { display:flex; align-items:center; gap:.5rem; }
.hwyc-rv-nav { display:none; flex-shrink:0; }
@media(min-width:640px) { .hwyc-rv-nav { display:block; } }
.hwyc-rv-nav__btn { display:flex; align-items:center; justify-content:center; width:32px; height:32px; border:1px solid rgba(15,27,42,.18); border-radius:50%; background:#fff; color:var(--brand-blue-dark,#1a2e4a); cursor:pointer; transition:background .15s,border-color .15s,box-shadow .15s; padding:0; flex-shrink:0; }
.hwyc-rv-nav__btn:hover { background:rgba(15,27,42,.05); border-color:rgba(15,27,42,.35); box-shadow:0 1px 4px rgba(15,27,42,.08); }
.hwyc-rv-nav__btn:disabled { opacity:.3; cursor:not-allowed; }
.hwyc-rv-strip { display:flex; gap:1rem; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; padding-bottom:.5rem; scroll-snap-type:x mandatory; overscroll-behavior-x:contain; }
.hwyc-rv-strip::-webkit-scrollbar { display:none; }
.hwyc-rv-card { display:flex; flex-direction:column; gap:.55rem; border:1px solid rgba(15,27,42,.09); padding:.9rem; flex-shrink:0; scroll-snap-align:start; transition:box-shadow .18s,transform .18s; flex:0 0 calc((100% - 2rem) / 3); cursor:pointer; }
@media(max-width:991.98px) { .hwyc-rv-card { flex:0 0 calc((100% - 1rem) / 2); } }
@media(max-width:639px) { .hwyc-rv-card { flex:0 0 85vw; } }
.hwyc-rv-card:hover { box-shadow:0 4px 16px rgba(15,27,42,.10); transform:translateY(-2px); }
.hwyc-rv-card:focus-visible { outline:2px solid var(--brand-blue-dark); outline-offset:2px; }
.hwyc-rv-card__top { display:flex; align-items:center; gap:.55rem; }
.hwyc-rv-card__avatar { width:34px; height:34px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.hwyc-rv-card__avatar--ph { width:34px; height:34px; border-radius:50%; background:var(--brand-blue-dark); color:#fff; display:flex; align-items:center; justify-content:center; font-size:.82rem; font-weight:700; flex-shrink:0; text-transform:uppercase; }
.hwyc-rv-card__meta { display:flex; flex-direction:column; gap:1px; min-width:0; }
.hwyc-rv-card__name { font-size:.78rem; font-weight:700; color:var(--brand-blue-dark); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-decoration:none; }
a.hwyc-rv-card__name:hover { color:var(--brand-red); }
.hwyc-rv-card__date { font-size:.68rem; color:rgba(15,27,42,.4); }
.hwyc-rv-card__stars { display:flex; gap:1px; align-items:center; }
.hwyc-rv-card__text { font-size:.78rem; line-height:1.55; color:rgba(15,27,42,.7); margin:0; flex:1; display:-webkit-box; -webkit-line-clamp:10; -webkit-box-orient:vertical; overflow:hidden; min-height:9rem; }
.hwyc-rv-card__read-more { display:inline-block; margin-top:auto; font-size:.68rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--brand-blue-dark); opacity:.55; transition:opacity .15s; }
.hwyc-rv-card:hover .hwyc-rv-card__read-more { opacity:1; color:var(--brand-red); }

/* Review modal */
.hwyc-rv-modal { position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; padding:1rem; }
.hwyc-rv-modal[hidden] { display:none; }
.hwyc-rv-modal__overlay { position:absolute; inset:0; background:rgba(15,27,42,.55); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px); cursor:pointer; }
.hwyc-rv-modal__box { position:relative; background:#fff; border-radius:10px; box-shadow:0 20px 60px rgba(15,27,42,.25); padding:2rem 1.75rem 1.5rem; max-width:520px; width:100%; max-height:85vh; overflow-y:auto; display:flex; flex-direction:column; gap:1rem; animation:hwycRvModalIn .22s ease; }
@keyframes hwycRvModalIn { from { opacity:0; transform:translateY(12px) scale(.97); } to { opacity:1; transform:none; } }
.hwyc-rv-modal__close { position:absolute; top:.85rem; right:.85rem; width:34px; height:34px; border:1px solid rgba(15,27,42,.15); border-radius:50%; background:#fff; color:rgba(15,27,42,.5); display:flex; align-items:center; justify-content:center; cursor:pointer; padding:0; transition:background .15s,color .15s; }
.hwyc-rv-modal__close:hover { background:rgba(15,27,42,.06); color:var(--brand-blue-dark); }
.hwyc-rv-modal__top { display:flex; align-items:center; gap:.85rem; }
.hwyc-rv-modal__avatar-wrap { position:relative; flex-shrink:0; }
.hwyc-rv-modal__avatar { width:52px; height:52px; border-radius:50%; object-fit:cover; display:block; }
.hwyc-rv-modal__avatar-ph { width:52px; height:52px; border-radius:50%; background:var(--brand-blue-dark,#1a2e4a); color:#fff; display:flex; align-items:center; justify-content:center; font-size:1.25rem; font-weight:700; }
.hwyc-rv-modal__name { font-size:.95rem; font-weight:700; color:var(--brand-blue-dark); }
.hwyc-rv-modal__date { font-size:.75rem; color:rgba(15,27,42,.45); margin-top:2px; }
.hwyc-rv-modal__stars { display:flex; gap:2px; }
.hwyc-rv-modal__text { font-size:.88rem; line-height:1.7; color:rgba(15,27,42,.75); margin:0; white-space:pre-line; }
.hwyc-rv-modal__source { display:inline-flex; align-items:center; gap:5px; font-size:.75rem; font-weight:600; color:rgba(15,27,42,.4); text-decoration:none; margin-top:.25rem; transition:color .15s; }
.hwyc-rv-modal__source:hover { color:var(--brand-red); }

/* Contact popup */
.hwyc-contact-popup { position:fixed; inset:0; z-index:10000; display:flex; align-items:center; justify-content:center; padding:1rem; box-sizing:border-box; }
.hwyc-contact-popup[hidden] { display:none; }
.hwyc-contact-popup__overlay { position:absolute; inset:0; background:rgba(15,27,42,.55); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px); cursor:pointer; }
.hwyc-contact-popup__box { position:relative; background:#fff; border-radius:8px; box-shadow:0 24px 64px rgba(15,27,42,.22); width:100%; max-width:520px; min-width:0; box-sizing:border-box; max-height:90vh; overflow-y:auto; display:flex; flex-direction:column; animation:hwyc-popup-in .22s ease; }
@keyframes hwyc-popup-in { from { opacity:0; transform:translateY(12px) scale(.97); } to { opacity:1; transform:none; } }
.hwyc-contact-popup__close { position:absolute; top:.85rem; right:.85rem; width:34px; height:34px; border:1px solid rgba(15,27,42,.15); border-radius:50%; background:#fff; color:rgba(15,27,42,.5); display:flex; align-items:center; justify-content:center; cursor:pointer; padding:0; transition:background .15s; z-index:2; }
.hwyc-contact-popup__close:hover { background:rgba(15,27,42,.06); color:var(--brand-blue-dark); }
.hwyc-contact-popup__header { padding:1.1rem 1.25rem .6rem; border-bottom:1px solid rgba(15,27,42,.07); }
.hwyc-contact-popup__title { font-size:1rem; font-weight:800; color:var(--brand-blue-dark,#1a2e4a); margin:0 0 .15rem; padding-right:2rem; }
.hwyc-contact-popup__sub { font-size:.75rem; color:rgba(15,27,42,.45); margin:0; }
.hwyc-contact-popup__form { padding:.9rem 1.25rem 1.25rem; }
.hwyc-cf-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
@media(max-width:480px) { .hwyc-cf-row { grid-template-columns:1fr; } }
.hwyc-cf-field { display:flex; flex-direction:column; gap:4px; margin-bottom:12px; }
.hwyc-cf-field:last-of-type { margin-bottom:0; }
.hwyc-cf-field label { font-size:.75rem; font-weight:600; color:rgba(15,27,42,.80) !important; text-transform:uppercase; letter-spacing:.04em; }
.hwyc-cf-field input,.hwyc-cf-field textarea { border:1px solid #d0d5dd; border-radius:4px; padding:.5rem .75rem; font-size:.875rem; font-family:inherit; width:100%; box-sizing:border-box; transition:border-color .15s,box-shadow .15s; }
.hwyc-cf-field input:focus,.hwyc-cf-field textarea:focus { outline:none; border-color:var(--brand-blue-dark,#1a2e4a); box-shadow:0 0 0 3px rgba(26,46,74,.1); }
.hwyc-cf-field textarea { resize:vertical; min-height:90px; }
.hwyc-cf-error { font-size:.8rem; color:var(--brand-red,#c0392b); background:#fff1f1; border:1px solid #fecaca; border-radius:4px; padding:.5rem .75rem; margin-bottom:10px; }
.hwyc-cf-submit { width:100%; padding:.7rem 1rem; margin-top:14px; background:var(--brand-blue-dark,#1a2e4a); color:#fff; border:none; border-radius:4px; font-size:.875rem; font-weight:700; cursor:pointer; transition:background .15s; }
.hwyc-cf-submit:hover { background:var(--brand-red,#c0392b); }
.hwyc-cf-submit:disabled { opacity:.6; cursor:not-allowed; }
.hwyc-contact-popup__form .gform_wrapper { margin:0 !important; }
.hwyc-contact-popup__form .gform_body { padding:0 !important; }
.hwyc-contact-popup__form .gform_fields { list-style:none !important; margin:0 !important; padding:0 !important; display:flex; flex-direction:column; gap:.55rem !important; }
.hwyc-contact-popup__form .gfield { margin:0 !important; padding:0 !important; }
.hwyc-contact-popup__form .gfield_label { display:block !important; font-size:.78rem !important; font-weight:600 !important; color:rgba(15,27,42,.7) !important; margin-bottom:.3rem !important; letter-spacing:.01em; }
.hwyc-contact-popup__form .gfield_required { color:var(--brand-red,#c0392b) !important; }
.hwyc-contact-popup__form input[type="text"],
.hwyc-contact-popup__form input[type="email"],
.hwyc-contact-popup__form input[type="tel"],
.hwyc-contact-popup__form select,
.hwyc-contact-popup__form textarea { width:100% !important; padding:.45rem .75rem !important; border:1px solid rgba(15,27,42,.18) !important; border-radius:4px !important; font-size:.82rem !important; font-family:inherit !important; color:rgba(15,27,42,.85) !important; background:#fff !important; box-shadow:none !important; transition:border-color .15s,box-shadow .15s !important; box-sizing:border-box !important; line-height:1.4 !important; }
.hwyc-contact-popup__form input[type="text"]:focus,
.hwyc-contact-popup__form input[type="email"]:focus,
.hwyc-contact-popup__form input[type="tel"]:focus,
.hwyc-contact-popup__form select:focus,
.hwyc-contact-popup__form textarea:focus { outline:none !important; border-color:var(--brand-blue-dark,#1a2e4a) !important; box-shadow:0 0 0 3px rgba(26,46,74,.1) !important; }
.hwyc-contact-popup__form textarea { resize:vertical !important; min-height:75px !important; max-height:140px !important; }
.hwyc-contact-popup__form .gform_validation_container { display:none !important; }
.hwyc-contact-popup__form .gfield_error input,
.hwyc-contact-popup__form .gfield_error textarea,
.hwyc-contact-popup__form .gfield_error select { border-color:var(--brand-red,#c0392b) !important; }
.hwyc-contact-popup__form .validation_message { font-size:.72rem !important; color:var(--brand-red,#c0392b) !important; margin-top:.2rem !important; }
.hwyc-contact-popup__form .validation_error { font-size:.82rem !important; background:#fff1f1 !important; border:1px solid #fecaca !important; border-radius:4px !important; padding:.6rem .85rem !important; color:var(--brand-red,#c0392b) !important; margin-bottom:.75rem !important; }
.hwyc-contact-popup__form .gform_footer,
.hwyc-contact-popup__form .gform_page_footer { padding:.75rem 0 0 !important; margin:0 !important; border:none !important; }
.hwyc-contact-popup__form .gform_button,
.hwyc-contact-popup__form input[type="submit"] { width:100% !important; padding:.6rem 1rem !important; background:var(--brand-blue-dark,#1a2e4a) !important; color:#fff !important; border:none !important; border-radius:4px !important; font-size:.875rem !important; font-weight:700 !important; letter-spacing:.05em !important; cursor:pointer !important; transition:background .15s !important; font-family:inherit !important; }
.hwyc-contact-popup__form .gform_button:hover,
.hwyc-contact-popup__form input[type="submit"]:hover { background:var(--brand-red,#c0392b) !important; }
.hwyc-contact-popup__form .gform_confirmation_message { text-align:center !important; padding:1.5rem 1rem !important; font-size:.9rem !important; color:#16a34a !important; background:#f0fdf4 !important; border-radius:6px !important; border:1px solid #bbf7d0 !important; }
@media(max-width:575px) { .hwyc-contact-popup { align-items:flex-end; padding:0; } .hwyc-contact-popup__box { max-height:92vh; border-radius:16px 16px 0 0; width:100%; max-width:100%; } }

/* Collapse button */
.hwyc-collapse-btn { flex-shrink:0; margin-left:auto; width:26px; height:26px; border-radius:50%; border:1.5px solid rgba(255,255,255,.5); background:transparent; color:rgba(255,255,255,.85); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:300; line-height:1; transition:background .15s,border-color .15s; padding:0; }
.hwyc-collapse-btn:hover { background:rgba(255,255,255,.15); border-color:rgba(255,255,255,.9); color:#fff; }
.hwyc-collapse-btn--light { border-color:rgba(15,27,42,.2); color:rgba(15,27,42,.5); }
.hwyc-collapse-btn--light:hover { background:rgba(15,27,42,.06); border-color:rgba(15,27,42,.4); color:var(--brand-blue-dark,#1a2e4a); }
.hwyc-collapse-btn.is-collapsed { transform:rotate(0deg); }

/* Description toggle */
.hwyc-desc-toggle { background:none; border:none; padding:.35rem 0 0; font-size:.82rem; font-weight:700; color:var(--brand-blue-dark,#1a2e4a); cursor:pointer; letter-spacing:.02em; transition:color .15s; display:inline-flex; align-items:center; gap:4px; }
.hwyc-desc-toggle:hover { color:var(--brand-red,#c0392b); }

/* Back to top */
.hwyc-back-top { position:fixed; bottom:88px; right:16px; width:40px; height:40px; border-radius:50%; background:var(--brand-blue-dark,#1a2e4a); color:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; border:none; box-shadow:0 4px 12px rgba(15,27,42,.25); opacity:0; transform:translateY(8px); transition:opacity .2s,transform .2s; pointer-events:none; z-index:900; }
.hwyc-back-top.is-visible { opacity:1; transform:none; pointer-events:auto; }
.hwyc-back-top:hover { background:var(--brand-red,#c0392b); }
@media(min-width:992px) { .hwyc-back-top { bottom:24px; } }

/* Footer */
.hwyc-acco > footer { background:var(--brand-blue-dark) !important; color:rgba(255,255,255,.58); border-top:4px solid var(--brand-red) !important; margin-top:0 !important; padding-top:3.5rem !important; padding-bottom:3.5rem !important; }
.hwyc-acco > footer strong { color:rgba(255,255,255,.88); font-size:.7rem; letter-spacing:.10em; text-transform:uppercase; }
.hwyc-acco > footer a { color:rgba(255,255,255,.55); text-decoration:none; font-size:.9rem; }
.hwyc-acco > footer a:hover { color:rgba(255,255,255,.90); }
.hwyc-acco > footer .hwyc-muted { color:rgba(255,255,255,.40) !important; font-size:.85rem; }
.hwyc-acco > footer .border-top { border-color:rgba(255,255,255,.08) !important; }

/* iOS zoom fix */
@media(max-width:991.98px) {
  input[type="text"],input[type="email"],input[type="tel"],input[type="number"],
  input[type="search"],input[type="password"],input[type="date"],input[type="time"],
  input[type="url"],select,textarea { font-size:16px !important; }
}

/* Contrast improvements */
.hwyc-card .card-body p,
.hwyc-card .card-body li { color:var(--text-body); }
.hwyc-section-nav a { color:rgba(15,27,42,.82); }
.hwyc-section p,
.hwyc-section li { color:var(--text-body); }


/* ══════════════════════════════════════════════
   6. RESERVEREN — .sr-book-* classes + .sr-conf-*
   ══════════════════════════════════════════════ */

/* ── Bevestigingspagina (stap 5) ─────────────────────────── */
.sr-conf { background:#fff; border-radius:12px; max-width:520px; width:90%; margin:2rem auto; padding:40px 36px; box-shadow:0 4px 32px rgba(15,27,42,.10); text-align:center; }
.sr-conf__icon { font-size:3rem; margin-bottom:12px; }
.sr-conf__heading { font-size:1.5rem; font-weight:800; color:#1a2e4a; margin:0 0 12px; }
.sr-conf__intro { font-size:.95rem; color:rgba(15,27,42,.65); line-height:1.6; margin-bottom:24px; }
.sr-conf__details { background:#f5f7fa; border-radius:8px; padding:16px 20px; margin-bottom:24px; text-align:left; font-size:.875rem; }
.sr-conf__details strong { color:#1a2e4a; }
.sr-conf__row { display:flex; justify-content:space-between; padding:5px 0; border-bottom:1px solid rgba(15,27,42,.06); }
.sr-conf__row:last-child { border-bottom:none; }
.sr-conf__contact { font-size:.8rem; color:rgba(15,27,42,.45); margin-bottom:20px; }
.sr-conf__btn { display:inline-block; background:#1a2e4a; color:#fff; padding:14px 28px; border-radius:4px; font-size:.95rem; font-weight:700; text-decoration:none; transition:background .15s; }
.sr-conf__btn:hover { background:#b70c12; }

/* ── Topbar ──────────────────────────────────────────────── */
.sr-book-topbar { background:var(--brand-navy,#0f1b2a); border-top:4px solid var(--brand-red); border-bottom:1px solid rgba(255,255,255,.08); padding:14px 24px; display:flex; align-items:center; justify-content:space-between; gap:16px; position:sticky; top:0; z-index:100; box-shadow:0 2px 12px rgba(0,0,0,.18); }
.sr-book-topbar__logo img { height:44px; }
.sr-book-topbar__back { font-size:.78rem; font-weight:700; color:rgba(255,255,255,.6); text-decoration:none; letter-spacing:.04em; background:none; border:none; padding:0; cursor:pointer; font-family:inherit; }
.sr-book-topbar__back:hover { color:#fff; }
.sr-book-topbar__price { display:flex; flex-direction:column; align-items:flex-end; line-height:1.2; }
.sr-book-topbar__price-label { font-size:.65rem; color:rgba(255,255,255,.5); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:180px; }
.sr-book-topbar__price-amount { font-size:1rem; font-weight:800; color:#fff; }
@media(max-width:479px) { .sr-book-topbar__price-label { display:none; } .sr-book-topbar__price-amount { font-size:.875rem; } }

/* ── Hero ────────────────────────────────────────────────── */
.sr-book-hero { position:relative; height:180px; background-size:cover; background-position:center 30%; overflow:hidden; }
@media(max-width:767px) { .sr-book-hero { height:140px; } }
.sr-book-hero__overlay { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(10,18,30,.35) 0%,rgba(10,18,30,.55) 100%); }
.sr-book-hero__content { position:absolute; bottom:16px; left:24px; display:flex; flex-direction:column; gap:3px; }
.sr-book-hero__name { font-size:1.1rem; font-weight:800; color:#fff; line-height:1.2; text-shadow:0 1px 4px rgba(0,0,0,.3); }
.sr-book-hero__period { font-size:.75rem; color:rgba(255,255,255,.8); font-weight:600; }

/* ── Step indicator ──────────────────────────────────────── */
.sr-book-steps { display:flex; align-items:center; justify-content:center; gap:0; padding:24px 16px 0; max-width:640px; margin:0 auto; }
.sr-book-step { display:flex; align-items:center; gap:8px; flex:1; }
.sr-book-step__dot { width:28px; height:28px; border-radius:50%; border:2px solid rgba(15,27,42,.15); background:#fff; display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:800; color:rgba(15,27,42,.35); flex-shrink:0; transition:all .25s; }
.sr-book-step--active .sr-book-step__dot { background:var(--brand-navy); border-color:var(--brand-navy); color:#fff; }
.sr-book-step--done .sr-book-step__dot { background:#16a34a; border-color:#16a34a; color:#fff; }
.sr-book-step__label { font-size:.65rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:rgba(15,27,42,.35); transition:color .25s; white-space:nowrap; }
.sr-book-step--active .sr-book-step__label { color:var(--brand-navy); }
.sr-book-step--done .sr-book-step__label { color:#16a34a; }
.sr-book-step__line { flex:1; height:2px; background:rgba(15,27,42,.1); margin:0 4px; transition:background .25s; }
.sr-book-step__line--done { background:#16a34a; }
@media(max-width:480px) { .sr-book-step__label { display:none; } }

/* ── Page grid ───────────────────────────────────────────── */
.sr-book-page { max-width:960px; margin:24px auto 80px; padding:0 16px; display:grid; grid-template-columns:1fr 300px; gap:20px; align-items:start; }
@media(max-width:767px) { .sr-book-page { grid-template-columns:1fr; } }

/* ── Cards ───────────────────────────────────────────────── */
.sr-book-card { background:#fff; border:1px solid rgba(15,27,42,.08); border-radius:0; box-shadow:0 10px 30px rgba(0,0,0,.06); }
.sr-book-card__header { background:var(--brand-navy); padding:16px 20px; display:flex; align-items:center; justify-content:space-between; }
.sr-book-card__title { font-size:.82rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#fff; margin:0; }
.sr-book-card__subtitle { font-size:.72rem; color:rgba(255,255,255,.6); margin:3px 0 0; }
.sr-book-card__body { padding:24px; }

/* ── Form fields ─────────────────────────────────────────── */
.sr-book-field { display:flex; flex-direction:column; gap:5px; margin-bottom:16px; }
.sr-book-field:last-child { margin-bottom:0; }
.sr-book-field label { font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:rgba(15,27,42,.55); transition:color .15s; }
.sr-book-field input { border:1.5px solid rgba(15,27,42,.18); border-radius:4px; padding:11px 14px; font-size:16px; font-family:var(--font-base); transition:border-color .15s,box-shadow .15s; width:100%; background:#fff; color:var(--brand-blue-dark); }
.sr-book-field input:focus { outline:none; border-color:var(--brand-navy); box-shadow:0 0 0 3px rgba(26,46,74,.1); }
/* Ongeldige velden */
.sr-book-field.is-invalid label { color:var(--brand-red); }
.sr-book-field.is-invalid input,
.sr-book-field.is-invalid select,
.sr-book-field.is-invalid textarea {
  border-color:var(--brand-red) !important;
  box-shadow:0 0 0 2px rgba(183,12,18,.12) !important;
  background:#fff8f8;
}
.sr-book-field.is-invalid input:focus,
.sr-book-field.is-invalid select:focus,
.sr-book-field.is-invalid textarea:focus {
  box-shadow:0 0 0 3px rgba(183,12,18,.2) !important;
}
.sr-book-error { font-size:.78rem; color:var(--brand-red); background:#fff1f1; border:1px solid #fecaca; border-radius:4px; padding:8px 12px; margin-bottom:14px; display:none; }

/* ── Buttons ─────────────────────────────────────────────── */
.sr-book-btn { display:block; width:100%; padding:14px; border:none; border-radius:4px; font-size:.9rem; font-weight:700; font-family:var(--font-base); letter-spacing:.04em; cursor:pointer; transition:background .15s,transform .1s; text-align:center; text-decoration:none; }
.sr-book-btn:active { transform:scale(.98); }
.sr-book-btn--primary { background:var(--brand-navy); color:#fff; }
.sr-book-btn--primary:hover { background:var(--brand-red); }
.sr-book-btn--pay { background:var(--brand-red); color:#fff; margin-top:16px; font-size:1rem; padding:16px; }
.sr-book-btn--pay:hover { background:#9a0a0f; }
.sr-book-btn--ghost { background:transparent; color:rgba(15,27,42,.45); border:1px solid rgba(15,27,42,.15); margin-top:8px; }
.sr-book-btn--ghost:hover { background:rgba(15,27,42,.04); }
.sr-book-btn:disabled { opacity:.6; cursor:not-allowed; }
.sr-stepper-btn { width:32px; height:32px; border-radius:50%; border:1.5px solid rgba(15,27,42,.2); background:#fff; color:var(--brand-navy); font-size:1.1rem; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; font-family:inherit; transition:border-color .15s,background .15s; }
.sr-stepper-btn:hover { border-color:var(--brand-navy); background:rgba(26,46,74,.05); }
.sr-stepper-btn:disabled { opacity:.3; cursor:default; }

/* Hold banner */
#sr-hold-banner.sr-hold-urgent { background:#b70c12 !important; animation:sr-hold-blink 1s ease-in-out infinite; }
@keyframes sr-hold-blink { 0%,100% { opacity:1; } 50% { opacity:.6; } }

/* ── Step content ────────────────────────────────────────── */
.sr-book-step-content { display:none; }
.sr-book-step-content.is-active { display:block; }
.sr-book-step-intro { font-size:.875rem; color:rgba(15,27,42,.55); margin:0 0 20px; line-height:1.6; }

/* ── Extras ──────────────────────────────────────────────── */
.sr-book-extras { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.sr-book-extra { display:flex; align-items:center; gap:12px; border:1.5px solid rgba(15,27,42,.12); border-radius:4px; padding:12px 14px; cursor:pointer; transition:border-color .15s,background .15s; user-select:none; }
.sr-book-extra:hover { border-color:var(--brand-navy); background:rgba(26,46,74,.02); }
.sr-book-extra.is-selected { border-color:var(--brand-navy); background:rgba(26,46,74,.05); }
.sr-book-extra__chk { width:20px; height:20px; border:2px solid rgba(15,27,42,.2); border-radius:4px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:12px; color:transparent; transition:all .15s; }
.sr-book-extra--qty { cursor:default; }
.sr-book-extra--qty:hover { border-color:rgba(15,27,42,.2); background:transparent; }
.sr-book-extra--qty.is-selected { border-color:var(--brand-navy); background:rgba(26,46,74,.04); }
.sr-book-extra.is-selected .sr-book-extra__chk { background:var(--brand-navy); border-color:var(--brand-navy); color:#fff; }
.sr-book-extra__info { flex:1; }
.sr-book-extra__name { font-size:.875rem; font-weight:700; color:var(--brand-blue-dark); }
.sr-book-extra__price { font-size:.78rem; color:var(--brand-red); font-weight:700; }
.sr-book-extra__per { font-size:.65rem; color:rgba(15,27,42,.4); margin-left:3px; }

/* ── Pay options ─────────────────────────────────────────── */
.sr-pay-options { display:flex; flex-direction:column; gap:8px; }
.sr-pay-option { display:flex; align-items:center; gap:12px; border:1.5px solid rgba(15,27,42,.12); border-radius:6px; padding:12px 14px; cursor:pointer; transition:border-color .15s,background .15s; user-select:none; }
.sr-pay-option:hover { border-color:var(--brand-navy); background:rgba(26,46,74,.02); }
.sr-pay-option.is-selected { border-color:var(--brand-navy); background:rgba(26,46,74,.05); }
.sr-pay-option__icon { font-size:1.5rem; flex-shrink:0; width:36px; text-align:center; }
.sr-pay-option__info { flex:1; }
.sr-pay-option__name { font-size:.875rem; font-weight:700; color:var(--brand-navy); }
.sr-pay-option__desc { font-size:.72rem; color:rgba(15,27,42,.5); margin-top:2px; line-height:1.4; }
.sr-pay-option__chk { width:20px; height:20px; border:2px solid rgba(15,27,42,.2); border-radius:50%; flex-shrink:0; transition:all .15s; }
.sr-pay-option.is-selected .sr-pay-option__chk { background:var(--brand-navy); border-color:var(--brand-navy); box-shadow:inset 0 0 0 3px #fff; }

/* ── Summary sidebar ─────────────────────────────────────── */
.sr-book-summary { position:sticky; top:90px; }
.sr-book-summary__img { width:100%; aspect-ratio:16/9; object-fit:cover; display:block; }
.sr-book-summary__body { padding:16px; }
.sr-book-summary__acco { font-size:.9rem; font-weight:800; color:var(--brand-navy); margin:0 0 12px; }
.sr-book-summary__row { display:flex; justify-content:space-between; font-size:.8rem; padding:6px 0; border-bottom:1px solid rgba(15,27,42,.06); }
.sr-book-summary__label { color:rgba(15,27,42,.5); }
.sr-book-summary__val { font-weight:700; color:var(--brand-navy); text-align:right; }
.sr-book-summary__total { display:flex; justify-content:space-between; margin-top:12px; padding-top:12px; border-top:2px solid var(--brand-navy); font-weight:800; font-size:1rem; color:var(--brand-navy); }
.sr-book-summary__guarantee { font-size:.68rem; color:rgba(15,27,42,.4); margin-top:10px; text-align:center; line-height:1.5; }

/* ── Overview table stap 4 ───────────────────────────────── */
.sr-book-overview td { padding:6px 0; font-size:.82rem; border-bottom:1px solid rgba(15,27,42,.06); }
.sr-book-overview td:last-child { text-align:right; font-weight:700; color:var(--brand-navy); }
.sr-book-overview-total { display:flex; justify-content:space-between; margin-top:12px; padding-top:12px; border-top:2px solid var(--brand-navy); font-weight:800; font-size:1.1rem; color:var(--brand-navy); }


/* ── Reserveren header (booking-specifieke elementen) ─── */
.hwyc-topbar-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff !important;
  font-family: var(--font-base, 'Raleway', sans-serif);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .4rem .9rem;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  white-space: nowrap;
  border-radius: 0;
}
.hwyc-topbar-back-btn svg { flex-shrink: 0; opacity: .85; }
.hwyc-topbar-back-btn:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.55);
}

.hwyc-topbar-booking-summary {
  display: flex;
  align-items: center;
  gap: .6rem;
  font-size: .82rem;
  color: #fff;
}
.hwyc-topbar-booking-summary__title {
  color: rgba(255,255,255,.85);
  font-size: .78rem;
  font-weight: 500;
}
.hwyc-topbar-booking-summary__sep {
  color: rgba(255,255,255,.4);
  margin: 0 .1rem;
}
.hwyc-topbar-booking-summary__price {
  color: #fff;
  font-size: .95rem;
  font-weight: 800;
  letter-spacing: -.01em;
  white-space: nowrap;
}

@media(max-width:575px){
  .hwyc-topbar-booking-summary__title { display: none; }
  .hwyc-topbar-back-btn span { display: none; }
}
