/* ============================================================
   Triptiq Sailing — Inner page styles (Bareboat, destinations…)
   Loaded AFTER styles.css so it reuses the same tokens.
   ============================================================ */

/* ---------- Sub-hero ---------- */
.subhero {
  position: relative; color: #fff; padding: 4.5rem 0 3.5rem; overflow: hidden;
}
.subhero__media { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.05); }
.subhero__media::after { content: ''; position: absolute; inset: 0; background: linear-gradient(100deg, rgba(6,26,40,.85), rgba(6,26,40,.5) 60%, rgba(6,26,40,.25)); }
.subhero__inner { position: relative; z-index: 2; max-width: 680px; }
.breadcrumb { display: flex; gap: .5rem; font-size: .88rem; color: rgba(255,255,255,.7); margin-bottom: 1.4rem; }
.breadcrumb a:hover { color: #fff; }
.breadcrumb span { color: var(--gold); }
.subhero__title { font-family: var(--display); font-weight: 400; font-size: clamp(2.4rem, 5vw, 3.8rem); line-height: 1.05; letter-spacing: -.015em; margin-bottom: 1.1rem; }
.subhero__lead { font-size: 1.15rem; color: rgba(255,255,255,.9); max-width: 560px; margin-bottom: 1.8rem; }
.subhero__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

/* Larger hero: on landing you see the hero + the second section, third stays below the fold */
.subhero { min-height: calc(100vh - 215px); display: flex; align-items: center; padding-top: 6rem; }
.subhero + .band { padding-top: 2rem; }
@media (max-width: 1024px) { .subhero { min-height: 64vh; } }

.livebadge {
  display: inline-flex; align-items: center; gap: .5rem; margin-bottom: 1.4rem;
  background: rgba(46,204,113,.16); border: 1px solid rgba(46,204,113,.5);
  color: #d4f7e0; font-size: .82rem; font-weight: 600; padding: .4rem .9rem; border-radius: 100px;
}
.livedot { width: 8px; height: 8px; border-radius: 50%; background: #2ecc71; box-shadow: 0 0 0 0 rgba(46,204,113,.7); animation: livePulse 1.8s infinite; }
@keyframes livePulse { 0%{box-shadow:0 0 0 0 rgba(46,204,113,.6)} 70%{box-shadow:0 0 0 8px rgba(46,204,113,0)} 100%{box-shadow:0 0 0 0 rgba(46,204,113,0)} }

/* ---------- Wizard (real-time results) ---------- */
.wizard { background: var(--cream); padding: clamp(3rem,6vw,5rem) 0; }
.wizard__bar {
  display: grid; grid-template-columns: repeat(4, 1fr) auto; gap: .6rem; align-items: end;
  background: #fff; padding: 1rem; border-radius: var(--radius); box-shadow: var(--shadow-md);
  border: 1px solid var(--line); margin-bottom: 1.6rem;
}
.wzf { display: flex; flex-direction: column; gap: .35rem; }
.wzf label { font-size: .72rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-soft); }
.wzf select, .wzf input {
  border: 1px solid var(--line); background: var(--cream); color: var(--navy); font-weight: 600;
  padding: .7rem .8rem; border-radius: 10px; outline: none; cursor: pointer; width: 100%;
}
.wzf select:focus, .wzf input:focus { border-color: var(--teal); }
.wizard__reset { align-self: end; }

.wizard__meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.2rem; flex-wrap: wrap; gap: 1rem; }
.wizard__count { font-weight: 600; color: var(--ink); }
.wizard__count b { color: var(--navy); }
.wizard__live { display: inline-flex; align-items: center; gap: .5rem; font-size: .85rem; color: var(--ink-soft); }

.yacht-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.yacht {
  background: #fff; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line);
  box-shadow: var(--shadow-sm); display: flex; flex-direction: column;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.yacht:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.yacht__media { position: relative; aspect-ratio: 16/10; background-size: cover; background-position: center; }
.yacht__tags { position: absolute; top: .75rem; left: .75rem; display: flex; gap: .4rem; }
.tag {
  font-size: .7rem; font-weight: 700; letter-spacing: .03em; padding: .3rem .6rem; border-radius: 100px;
  background: rgba(255,255,255,.92); color: var(--navy);
}
.tag--live { background: rgba(46,204,113,.95); color: #06351d; display: inline-flex; align-items: center; gap: .35rem; }
.tag--live .livedot { width: 6px; height: 6px; background: #06351d; }
.yacht__fav { position: absolute; top: .65rem; right: .65rem; width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,.9); display: grid; place-items: center; color: var(--coral); font-size: 1rem; }

.yacht__body { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; flex: 1; }
.yacht__loc { font-size: .82rem; font-weight: 600; color: var(--teal); margin-bottom: .15rem; }
.yacht__name { font-family: var(--display); font-weight: 600; font-size: 1.25rem; color: var(--navy); line-height: 1.1; }
.yacht__rating { font-size: .82rem; color: var(--ink-soft); margin: .3rem 0 .8rem; }
.yacht__rating b { color: var(--gold); }
.yacht__specs { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem; }
.spec { font-size: .78rem; font-weight: 600; color: var(--ink-soft); background: var(--cream); border: 1px solid var(--line); padding: .25rem .55rem; border-radius: 8px; }
.yacht__foot { margin-top: auto; display: flex; align-items: flex-end; justify-content: space-between; gap: .5rem; }
.yacht__price small { display: block; font-size: .72rem; color: var(--ink-soft); }
.yacht__price b { font-family: var(--display); font-size: 1.35rem; color: var(--navy); }
.yacht__price span { font-size: .8rem; color: var(--ink-soft); font-weight: 600; }
.yacht__empty { grid-column: 1/-1; text-align: center; padding: 3rem; color: var(--ink-soft); }

/* ---------- Generic content band ---------- */
.band { padding: clamp(4rem,7vw,6rem) 0; }
.band--sand { background: var(--sand); }
.band--navy { background: var(--navy); color: #fff; }
.band--navy .section__title, .band--navy h2 { color: #fff; }
.split { display: grid; grid-template-columns: 1.05fr .95fr; gap: 3.5rem; align-items: center; }
.split__media { border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/3; background-size: cover; background-position: center; box-shadow: var(--shadow-md); }
.feature-list { list-style: none; margin-top: 1.5rem; display: grid; gap: 1rem; }
.feature-list li { display: flex; gap: .8rem; align-items: flex-start; }
.feature-list .ic { flex: none; width: 28px; height: 28px; border-radius: 8px; background: rgba(30,122,140,.12); color: var(--teal); display: grid; place-items: center; font-weight: 700; }
.band--navy .feature-list .ic { background: rgba(217,162,75,.18); color: var(--gold); }
.feature-list strong { display: block; }
.feature-list p { color: var(--ink-soft); font-size: .95rem; }
.band--navy .feature-list p { color: rgba(255,255,255,.75); }

/* ---------- Steps ---------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 1rem; }
.step { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 2rem 1.6rem; box-shadow: var(--shadow-sm); }
.step__n { font-family: var(--display); font-size: 2.2rem; color: var(--gold); line-height: 1; }
.step h3 { font-size: 1.2rem; margin: .8rem 0 .4rem; color: var(--navy); }
.step p { color: var(--ink-soft); font-size: .96rem; }

/* ---------- Destination cards ---------- */
.dest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.3rem; }
.dest {
  position: relative; aspect-ratio: 3/4; border-radius: var(--radius); overflow: hidden; isolation: isolate;
  display: flex; align-items: flex-end; color: #fff; box-shadow: var(--shadow-sm);
  transition: transform .35s var(--ease);
}
.dest::before { content: ''; position: absolute; inset: 0; z-index: -2; background-size: cover; background-position: center; transition: transform .6s var(--ease); }
.dest::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(6,26,40,0) 40%, rgba(6,26,40,.85)); }
.dest:hover { transform: translateY(-4px); }
.dest:hover::before { transform: scale(1.07); }
.dest__body { padding: 1.2rem; }
.dest__body h3 { font-family: var(--display); font-weight: 600; font-size: 1.3rem; }
.dest__body span { font-size: .85rem; color: rgba(255,255,255,.8); }

/* ---------- FAQ ---------- */
.faq { max-width: 820px; margin-inline: auto; }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q { width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1.3rem 0; font-family: var(--display); font-size: 1.2rem; font-weight: 600; color: var(--navy); }
.faq__q .chev { flex: none; width: 28px; height: 28px; border-radius: 50%; border: 1.5px solid var(--line); display: grid; place-items: center; transition: transform .3s var(--ease), background .3s; color: var(--teal); }
.faq__item.open .chev { transform: rotate(45deg); background: var(--teal); color: #fff; border-color: var(--teal); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height .4s var(--ease); }
.faq__a p { padding: 0 0 1.3rem; color: var(--ink-soft); }

/* ---------- Shared form primitives (used by offerte + contact) ---------- */
.field { display: flex; flex-direction: column; gap: .4rem; margin-bottom: 1.1rem; }
.field label { font-size: .82rem; font-weight: 700; color: var(--navy); }
.field label .req { color: var(--coral); }
.field input, .field select, .field textarea {
  border: 1.5px solid var(--line); background: var(--cream); color: var(--navy); font-weight: 500;
  padding: .8rem .9rem; border-radius: 10px; outline: none; width: 100%; transition: border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--teal); background: #fff; }
.field textarea { resize: vertical; min-height: 110px; font-family: inherit; }
.field--error input, .field--error select, .field--error textarea { border-color: var(--coral); }
.field__err { font-size: .78rem; color: var(--coral-dark); display: none; }
.field--error .field__err { display: block; }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.check { display: flex; gap: .6rem; align-items: flex-start; font-size: .9rem; color: var(--ink-soft); cursor: pointer; }
.check input { width: 18px; height: 18px; margin-top: 2px; accent-color: var(--coral); flex: none; }
.check a { color: var(--teal); font-weight: 600; }
@media (max-width: 560px) { .row2 { grid-template-columns: 1fr; } }

/* ---------- Sub-hero meta chips ---------- */
.subhero__chips { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.6rem; }
.chip {
  display: inline-flex; align-items: center; gap: .4rem; font-size: .85rem; font-weight: 600;
  color: #fff; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.28);
  padding: .45rem .9rem; border-radius: 100px; backdrop-filter: blur(4px);
}
.chip::before { content: '⛵'; font-size: .8rem; }

/* ---------- Quick facts row ---------- */
.facts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.fact { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 1.4rem 1.3rem; box-shadow: var(--shadow-sm); }
.fact__label { font-size: .75rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--teal); margin-bottom: .35rem; }
.fact__value { font-family: var(--display); font-size: 1.25rem; color: var(--navy); line-height: 1.2; }

/* ---------- Destination map ---------- */
.destmap-wrap { background: #fff; border-radius: var(--radius); box-shadow: var(--shadow-md); overflow: hidden; border: 1px solid var(--line); }
.destmap { height: 480px; width: 100%; background: #aadaff; }
.destmap-hint { padding: .85rem 1.2rem; font-size: .85rem; color: var(--ink-soft); text-align: center; border-top: 1px solid var(--line); }

/* ---------- Sailing-area cards ---------- */
.area-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
/* 3-op-een-rij variant: verticale kaart (foto boven, tekst onder) zodat ze niet gedrukt worden */
.area-grid--3 { grid-template-columns: repeat(3, 1fr); }
.area-grid--3 .area { grid-template-columns: 1fr; }
.area-grid--3 .area__media { min-height: 0; aspect-ratio: 3 / 2; }
.area { display: grid; grid-template-columns: 40% 1fr; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .35s var(--ease), box-shadow .35s var(--ease); }
.area:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.area__media { background-size: cover; background-position: center; min-height: 200px; }
.area__body { padding: 1.4rem 1.5rem; }
.area__body h3 { font-family: var(--display); font-weight: 600; font-size: 1.35rem; color: var(--navy); margin-bottom: .4rem; }
.area__body p { font-size: .94rem; color: var(--ink-soft); margin-bottom: .9rem; }
.area__tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.area__tags span { font-size: .74rem; font-weight: 600; color: var(--teal); background: rgba(30,122,140,.1); padding: .25rem .6rem; border-radius: 100px; }

/* ---------- Gallery strip ---------- */
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; gap: 1rem; }
.gallery__item { border-radius: var(--radius-sm); background-size: cover; background-position: center; box-shadow: var(--shadow-sm); }
.gallery__item--tall { grid-row: span 2; }
.gallery__item--wide { grid-column: span 2; }

/* ---------- Zeegebieden: clean photo index tiles ---------- */
.searegions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; }
.searegion {
  position: relative; display: block; border-radius: var(--radius);
  overflow: hidden; aspect-ratio: 3 / 4; box-shadow: var(--shadow-sm);
  isolation: isolate;
}
.searegion__img {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  transform: scale(1.03); transition: transform .7s cubic-bezier(.2,.7,.3,1);
}
.searegion::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(11,42,63,0) 30%, rgba(11,42,63,.18) 52%, rgba(11,42,63,.82) 100%);
}
.searegion:hover .searegion__img { transform: scale(1.1); }
.searegion__body { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 1.3rem 1.3rem 1.4rem; color: #fff; }
.searegion__n { font-family: var(--display); font-size: .85rem; font-weight: 500; color: var(--gold); letter-spacing: .02em; }
.searegion__body h3 { font-family: var(--display); font-weight: 600; font-size: 1.5rem; line-height: 1.1; margin: .15rem 0 .35rem; }
.searegion__body p { font-size: .82rem; color: rgba(255,255,255,.86); margin: 0; }
.searegion__go {
  margin-top: .85rem; display: inline-flex; align-items: center; gap: .4rem;
  font-size: .82rem; font-weight: 700; letter-spacing: .02em;
  color: #fff; opacity: .9; transition: gap .3s var(--ease), opacity .3s var(--ease);
}
.searegion:hover .searegion__go { gap: .7rem; opacity: 1; }
@media (max-width: 1024px) { .searegions { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .searegions { grid-template-columns: 1fr; } .searegion { aspect-ratio: 16 / 10; } }
@media (prefers-reduced-motion: reduce) { .searegion__img { transition: none; } }

/* ---------- Product mini-cards ---------- */
.prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.3rem; }
.prodcard { display: block; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.5rem; box-shadow: var(--shadow-sm); transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.prodcard:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.prodcard__ic { font-size: 1.6rem; }
.prodcard h3 { font-family: var(--display); font-weight: 600; font-size: 1.2rem; color: var(--navy); margin: .6rem 0 .3rem; }
.prodcard p { font-size: .9rem; color: var(--ink-soft); margin-bottom: .8rem; }
.prodcard span { font-weight: 700; font-size: .9rem; color: var(--coral); }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .facts { grid-template-columns: 1fr 1fr; }
  .area-grid { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: 1fr 1fr; }
  .prod-grid { grid-template-columns: 1fr 1fr; }
  .wizard__bar { grid-template-columns: repeat(2, 1fr); }
  .wizard__reset { grid-column: 1/-1; }
  .yacht-grid { grid-template-columns: repeat(2, 1fr); }
  .split { grid-template-columns: 1fr; gap: 2rem; }
  .steps { grid-template-columns: 1fr; }
  .dest-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .subhero { padding-top: 7rem; }
  .wizard__bar { grid-template-columns: 1fr; }
  .yacht-grid { grid-template-columns: 1fr; }
  .dest-grid { grid-template-columns: 1fr 1fr; }
  .facts { grid-template-columns: 1fr 1fr; }
  .area { grid-template-columns: 1fr; }
  .area__media { min-height: 170px; }
  .gallery { grid-template-columns: 1fr 1fr; grid-auto-rows: 150px; }
  .prod-grid { grid-template-columns: 1fr; }
}

/* ---------- Country group heading + price chip (product overviews) ---------- */
.group-head { display: flex; align-items: baseline; gap: .7rem; margin: 2.4rem 0 1.2rem; padding-bottom: .5rem; border-bottom: 1px solid var(--line); }
.group-head:first-of-type { margin-top: 0; }
.group-head h3 { font-family: var(--display); font-weight: 600; font-size: 1.4rem; color: var(--navy); }
.group-head span { font-size: .85rem; color: var(--ink-soft); }
.area__tags .t-price { background: var(--coral); color: #fff; }
.area__tags .t-season { background: rgba(217,162,75,.18); color: #946a1c; }

/* ============================================================
   Geliefde zeilgebieden — faded backdrop + auto-scrolling marquee
   ============================================================ */
.destfeature { position: relative; padding: clamp(3.5rem, 7vw, 5.5rem) 0; color: #fff; overflow: hidden; }
.destfeature__bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.destfeature__bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(rgba(6,26,40,.80), rgba(6,26,40,.87)); }
.destfeature__head, .destfeature__foot, .destmarquee { position: relative; z-index: 1; }
.destfeature__head { text-align: center; max-width: 640px; margin-inline: auto; }
.destfeature .eyebrow { color: var(--gold); }
.destfeature .section__title { color: #fff; }
.destfeature__intro { color: rgba(255,255,255,.82); margin-top: .6rem; }
.destfeature__foot { text-align: center; margin-top: 2rem; }
.link-arrow--light { color: #fff; }
.link-arrow--light:hover { color: var(--gold); }

.destmarquee { margin-top: 2.2rem; overflow: hidden;
  -webkit-mask: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
          mask: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.destmarquee__track { display: flex; gap: 1.3rem; width: max-content; animation: destScroll 38s linear infinite; }
.destmarquee:hover .destmarquee__track { animation-play-state: paused; }
@keyframes destScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.dcard { position: relative; flex: 0 0 auto; width: 300px; height: 210px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); display: flex; align-items: flex-end; color: #fff; isolation: isolate; transition: transform .35s var(--ease); }
.dcard__img { position: absolute; inset: 0; z-index: -2; background-size: cover; background-position: center; transition: transform .6s var(--ease); }
.dcard::after { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(6,26,40,0) 35%, rgba(6,26,40,.85)); }
.dcard:hover { transform: translateY(-5px); }
.dcard:hover .dcard__img { transform: scale(1.08); }
.dcard__body { padding: 1.1rem 1.2rem; }
.dcard__body h3 { font-family: var(--display); font-weight: 600; font-size: 1.3rem; }
.dcard__body span { font-size: .85rem; color: rgba(255,255,255,.82); }

@media (prefers-reduced-motion: reduce) { .destmarquee__track { animation: none; } }
@media (max-width: 560px) { .dcard { width: 250px; height: 180px; } }

/* ============================================================
   Bestemmingen — multi-row moving destination marquee
   ============================================================ */
.destrows {
  margin-top: 2.4rem; display: flex; flex-direction: column; gap: 1.2rem; overflow: hidden;
  -webkit-mask: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
          mask: linear-gradient(90deg, transparent, #000 4%, #000 96%, transparent);
}
.destrow { overflow: hidden; }
.destrow__track { display: flex; gap: 1.2rem; width: max-content; will-change: transform; animation: destRow 60s linear infinite; }
.destrow:nth-child(1) .destrow__track { animation-duration: 64s; }
.destrow:nth-child(2) .destrow__track { animation-duration: 52s; animation-direction: reverse; }
.destrow:nth-child(3) .destrow__track { animation-duration: 74s; }
.destrows:hover .destrow__track { animation-play-state: paused; }
@keyframes destRow { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.destrow .dcard { width: 290px; height: 192px; box-shadow: 0 14px 30px -18px rgba(11,42,63,.55); }
.destrow .dcard__body { padding: 1rem 1.15rem; }
.destrow .dcard__body h3 { font-size: 1.25rem; }
.destrow .dcard__body span { color: var(--gold); font-weight: 600; }

@media (prefers-reduced-motion: reduce) {
  .destrow__track { animation: none; }
  .destrows { overflow-x: auto; }
}
@media (max-width: 560px) { .destrow .dcard { width: 230px; height: 158px; } }

/* ============================================================
   Bareboat — Booking Manager search bar + quick chips
   ============================================================ */
.bbsearch-sec { background: var(--sand); }
.bbsearch {
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow-md); padding: 1.1rem; margin-top: 2.2rem;
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr auto; gap: .9rem; align-items: end;
}
.bbsearch__field { display: flex; flex-direction: column; gap: .35rem; }
.bbsearch__field label { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--teal); }
.bbsearch select, .bbsearch input[type="date"] {
  font: inherit; font-size: .95rem; padding: .72rem .8rem; border: 1px solid var(--line);
  border-radius: var(--radius-sm); background: #fff; color: var(--ink); width: 100%; min-width: 0;
}
.bbsearch select:focus, .bbsearch input:focus { outline: 2px solid var(--teal-light); outline-offset: 1px; }
.bbsearch__btn { white-space: nowrap; height: fit-content; padding: .82rem 1.4rem; }
.bbsearch__note { text-align: center; font-size: .9rem; color: var(--ink-soft); margin-top: 1.1rem; }
.bbsearch__note a { color: var(--teal); font-weight: 700; }
.bbchips { display: flex; flex-wrap: wrap; align-items: center; gap: .55rem; justify-content: center; margin-top: 1.6rem; }
.bbchips__label { font-size: .85rem; font-weight: 700; color: var(--ink-soft); }
.bbchip { font-size: .88rem; font-weight: 600; color: var(--navy); background: #fff; border: 1px solid var(--line); padding: .48rem .95rem; border-radius: 100px; cursor: pointer; transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease); }
.bbchip:hover { background: var(--navy); color: #fff; border-color: var(--navy); }
@media (max-width: 900px) {
  .bbsearch { grid-template-columns: 1fr 1fr; }
  .bbsearch__field--wide { grid-column: 1 / -1; }
  .bbsearch__btn { grid-column: 1 / -1; width: 100%; }
}
@media (max-width: 520px) { .bbsearch { grid-template-columns: 1fr; } }

/* ---------- Bareboat branded date-range calendar ---------- */
.bbsearch-wrap { position: relative; }
.bbdate {
  font: inherit; font-size: .95rem; text-align: left; width: 100%; cursor: pointer;
  padding: .72rem .8rem; border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: #fff; color: var(--ink-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: border-color .2s var(--ease);
}
.bbdate:hover { border-color: var(--teal-light); }
.bbdate.is-set { color: var(--ink); font-weight: 600; }
.bbdate:focus-visible { outline: 2px solid var(--teal-light); outline-offset: 1px; }

.bbcal {
  position: absolute; z-index: 40; top: calc(100% + .5rem); left: 50%; transform: translateX(-50%);
  width: 320px; max-width: calc(100vw - 2rem); background: #fff; border: 1px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow-lg); padding: 1rem;
}
.bbcal__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .7rem; }
.bbcal__title { font-family: var(--display); font-weight: 600; color: var(--navy); font-size: 1.05rem; }
.bbcal__nav { width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--line); background: #fff; color: var(--navy); font-size: 1.2rem; line-height: 1; cursor: pointer; transition: background .18s, color .18s, border-color .18s; }
.bbcal__nav:hover { background: var(--navy); color: #fff; border-color: var(--navy); }
.bbcal__dow { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; margin-bottom: .3rem; }
.bbcal__dow span { text-align: center; font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .02em; color: var(--ink-soft); }
.bbcal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px 0; }
.bbcal__day { aspect-ratio: 1; border: none; background: transparent; border-radius: 8px; font: inherit; font-size: .88rem; font-weight: 600; color: var(--ink); cursor: pointer; transition: background .15s var(--ease), color .15s var(--ease); }
.bbcal__day:hover:not(.is-disabled):not(.is-selected) { background: var(--sand); }
.bbcal__day.is-today { box-shadow: inset 0 0 0 1.5px var(--teal-light); }
.bbcal__day.is-inrange { background: rgba(34,119,168,.15); border-radius: 0; color: var(--navy); }
.bbcal__day.is-selected { background: var(--coral); color: #fff; }
.bbcal__day.is-disabled { color: rgba(18,58,92,.28); cursor: not-allowed; }
.bbcal__foot { display: flex; align-items: center; justify-content: space-between; margin-top: .8rem; padding-top: .7rem; border-top: 1px solid var(--line); }
.bbcal__hint { font-size: .8rem; color: var(--ink-soft); }
.bbcal__clear { background: none; border: none; color: var(--teal); font-weight: 700; font-size: .82rem; cursor: pointer; }
.bbcal__clear:hover { color: var(--coral); }

/* 3-koloms area-grid: schaalt netjes terug op kleinere schermen */
@media (max-width: 1024px) { .area-grid--3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .area-grid--3 { grid-template-columns: 1fr; } }
