:root{
  --bg:#f7f8fb;
  --ink:#0b1220;
  --muted:#66708a;
  --line:rgba(12,18,32,.10);
  --card:#ffffff;
  --shadow:0 14px 40px rgba(2,6,23,.10);
  --r:18px;
  --brand:#5D59A3;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  background:var(--bg);
  color:var(--ink);
}
a{color:inherit;text-decoration:none}
.wrap{width:min(1120px,calc(100% - 40px));margin:0 auto}
.page{min-height:70vh}
.muted{color:var(--muted);font-weight:700}

/* Header */
.hdr{
  position:sticky;top:0;z-index:50;
  background:rgba(247,248,251,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.hdr__in{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:14px}

.brand{display:flex;align-items:center;gap:12px}
.brand__logo{
  width:42px;height:42px;border-radius:14px;
  display:grid;place-items:center;
  font-weight:900;
  background:rgba(93,89,163,.12);
  border:1px solid rgba(93,89,163,.22);
}
.brand__txt{display:flex;flex-direction:column;line-height:1.1}
.brand__name{font-weight:900}
.brand__sub{font-size:.82rem;color:var(--muted);font-weight:800}

.nav{display:flex;gap:18px;align-items:center}
.nav a{
  padding:10px 12px;border-radius:999px;
  font-weight:900;color:#2a3246;
}
.nav a:hover{background:rgba(12,18,32,.05)}
.is-active{background:rgba(93,89,163,.10);border:1px solid rgba(93,89,163,.18)}
.hdr__cta{display:flex;align-items:center;gap:10px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 14px;border-radius:999px;
  font-weight:900;border:1px solid transparent;
  transition:.15s;
}
.btn--primary{
  background:linear-gradient(90deg,var(--brand),#6a66c2);
  color:#fff;
  box-shadow:0 10px 24px rgba(93,89,163,.22);
}
.btn--primary:hover{box-shadow:0 14px 34px rgba(93,89,163,.28)}
.btn--ghost{background:#fff;border-color:var(--line);color:#2a3246}
.btn--ghost:hover{border-color:rgba(12,18,32,.20)}
.btn--block{width:100%}
/* Burger + mobile nav */
.burger{
  width:44px;height:44px;border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  display:none;
  flex-direction:column;align-items:center;justify-content:center;gap:5px
}
.burger span{width:18px;height:2px;background:#1a2236;border-radius:2px}

.mnav{border-top:1px solid var(--line);background:rgba(247,248,251,.96)}
.mnav__in{padding:12px 0 16px;display:flex;flex-direction:column;gap:10px}
.mnav a{padding:12px 12px;border-radius:14px;font-weight:900;background:#fff;border:1px solid var(--line)}

/* Hero */
.hero{
  padding:34px 0 18px;
  background:
    radial-gradient(900px 380px at 20% 0%, rgba(93,89,163,.18), transparent 60%),
    radial-gradient(860px 420px at 90% 10%, rgba(45,212,191,.10), transparent 60%);
}
.hero__in{display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:start}
.pill{
  display:inline-flex;
  padding:8px 12px;border-radius:999px;
  background:rgba(93,89,163,.10);
  border:1px solid rgba(93,89,163,.18);
  font-weight:900;color:#2a2f47;font-size:.85rem;
}
h1{margin:12px 0 10px;font-size:clamp(2.1rem,3.7vw,3.2rem);letter-spacing:-.02em}
.lead{margin:0;color:#2a3246;line-height:1.6;font-weight:600}
.cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

/* Search bar */
.search{
  margin-top:16px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow);
  padding:12px;
}
.search__row{display:grid;grid-template-columns:1.25fr 1fr .8fr auto;gap:10px}
.field{padding:10px 12px;border-radius:16px;border:1px solid var(--line);background:#fff}
.field__label{font-size:.78rem;color:var(--muted);font-weight:900}
.field__value{margin-top:4px;font-weight:900;color:#1a2236}

/* Chips/tags */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.chip{padding:8px 10px;border-radius:999px;background:rgba(93,89,163,.10);border:1px solid rgba(93,89,163,.18);font-weight:900}
.chip--btn{cursor:pointer}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.tag{font-size:.85rem;padding:6px 10px;border-radius:999px;background:rgba(12,18,32,.06);border:1px solid var(--line);font-weight:900;color:#2a3246}
.link{display:inline-flex;font-weight:900;color:var(--brand)}
.link:hover{text-decoration:underline}
/* Cards/layout */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:16px}
.card--soft{background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(255,255,255,.75))}
.card__t{font-weight:900;margin-bottom:10px}
.list{margin:0;padding-left:18px}
.list li{margin:8px 0;color:#3a435a;line-height:1.45;font-weight:600}
.miniGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mini{padding:12px;border-radius:16px;background:rgba(12,18,32,.04);border:1px solid var(--line);font-weight:900;color:#2a3246}

/* Sections + grid */
.sec{padding:22px 0 46px}
.sec--tight{padding-top:10px}
.sec__head{margin-bottom:12px}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.hcard{overflow:hidden;border-radius:var(--r);border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.hcard__img{
  height:140px;
  background:
    radial-gradient(420px 160px at 20% 0%, rgba(93,89,163,.35), transparent 60%),
    radial-gradient(520px 200px at 90% 10%, rgba(45,212,191,.20), transparent 60%),
    #0b1020
}
.hcard__b{padding:14px}
.hcard__top{display:flex;justify-content:space-between;gap:10px}
.hcard__top h3{margin:0;font-size:1.05rem}
.stars{font-weight:900}
.two{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}
.h2{margin:0 0 8px;font-weight:900}

/* FAQ */
.faq{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff;margin-top:10px}
.faq summary{cursor:pointer;font-weight:900;color:#2a3246}
.faq__a{padding-top:8px;line-height:1.5}

/* Footer */
.ftr{border-top:1px solid var(--line);padding:22px 0 26px;background:rgba(255,255,255,.65)}
.ftr__in{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center}
.ftr__brand{font-weight:900}
.ftr__links{display:flex;gap:14px;flex-wrap:wrap}
.ftr__links a{font-weight:900;color:#2a3246}
.ftr__links a:hover{text-decoration:underline}

/* Responsive */
@media (max-width:980px){
  .hero__in{grid-template-columns:1fr}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .two{grid-template-columns:1fr}
}
@media (max-width:720px){
  .nav{display:none}
  .burger{display:flex}
  .search__row{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}

/* ---- UI polish v2 (forms + head) ---- */
.head{padding:26px 0 10px}

.formWrap{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;align-items:start}
.formAside{position:sticky;top:92px}

.form{max-width:980px}
.form .row{margin-bottom:14px}
.form label{
  display:block;
  font-weight:900;
  margin:10px 0 6px;
  color:#2a3246;
  font-size:.92rem;
}
.form input,.form select,.form textarea{
  display:block;
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  outline:none;
  font-weight:700;
  color:#1a2236;
}
.form input:focus,.form select:focus,.form textarea:focus{
  border-color:rgba(93,89,163,.45);
  box-shadow:0 0 0 4px rgba(93,89,163,.12);
}
.formGrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}

@media (max-width:980px){
  .formWrap{grid-template-columns:1fr}
  .formGrid{grid-template-columns:1fr}
  .formAside{position:relative;top:auto}
}

/* --- Images hooks (JPG ready) --- */
/* Hero: pakt /assets/img/hero/noordwijk-hero.jpg als die bestaat, anders blijft gradient zichtbaar */
.hero{
  background:
    url('/assets/img/hero/noordwijk-hero.jpg') center/cover no-repeat,
    radial-gradient(900px 380px at 20% 0%, rgba(93,89,163,.18), transparent 60%),
    radial-gradient(860px 420px at 90% 10%, rgba(45,212,191,.10), transparent 60%);
}

/* Hotel cards: pakt placeholder JPG als die bestaat, anders blijft gradient zichtbaar */
.hcard__img{
  background:
    url('/assets/img/ui/hotel-placeholder.jpg') center/cover no-repeat,
    radial-gradient(420px 160px at 20% 0%, rgba(93,89,163,.35), transparent 60%),
    radial-gradient(520px 200px at 90% 10%, rgba(45,212,191,.20), transparent 60%),
    #0b1020;
}

/* --- Exo 2 default --- */
@import url('https://fonts.googleapis.com/css2?family=Exo+2:wght@400;600;700;800&display=swap');
body{font-family:"Exo 2", Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial;}

/* --- Hero image (header) + overlay --- */
.hero{
  background:
    linear-gradient(180deg, rgba(11,18,32,.62), rgba(11,18,32,.22)),
    url('/assets/img/hero/noordwijk-hotels.jpg') center/cover no-repeat,
    radial-gradient(900px 380px at 20% 0%, rgba(93,89,163,.18), transparent 60%),
    radial-gradient(860px 420px at 90% 10%, rgba(45,212,191,.10), transparent 60%);
}

.hero__copy h1,
.hero__copy .lead{color:#fff}

.hero__copy .pill{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.22);
  color:#fff;
}

/* --- Banner header for inner pages (Noordzee vibe) --- */
.head.head--banner{
  padding:44px 0 18px;
  background:
    linear-gradient(180deg, rgba(11,18,32,.62), rgba(11,18,32,.18)),
    url('/assets/img/hero/noordwijk-hotels.jpg') center/cover no-repeat;
}
.head.head--banner h1{color:#fff}
.head.head--banner .muted{color:rgba(255,255,255,.85)}
.head__tagline{
  margin:6px 0 12px;
  font-weight:900;
  color:rgba(255,255,255,.92);
}

/* chips in banner: glass */
.head.head--banner .chip{
  background:rgba(255,255,255,.14);
  border-color:rgba(255,255,255,.22);
  color:#fff;
}
