/* ================================================================
   B&B Carpe Diemen — stylesheet
   Palet: diep petrol + gouden "carpe diem"-zon op warm papier
   ================================================================ */
:root{
  --ink:#16323C;        /* diep petrol */
  --ink-2:#24505C;
  --sun:#E5A02C;        /* gouden zon — pluk de dag */
  --sun-deep:#C77E1A;
  --paper:#FCF9F3;      /* warm papier */
  --sand:#F3ECDF;       /* zachte sectie-achtergrond */
  --sage:#6E8B6C;
  --text:#1B2A2E;
  --muted:#5C6B6E;
  --line:#E3DBCB;
  --ok:#2E7D5B; --wait:#B7791F; --fail:#B23A48;
  --radius:14px; --radius-sm:9px;
  --shadow:0 10px 40px rgba(22,50,60,.10);
  --wrap:1120px;
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);color:var(--text);
  background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--ink);text-decoration:none}
a:hover{color:var(--sun-deep)}
h1,h2,h3{font-family:var(--font-display);line-height:1.1;font-weight:600;color:var(--ink);margin:.2em 0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.narrow{max-width:720px}
.center{text-align:center}
.muted{color:var(--muted)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:100}
.skip-link:focus{left:8px;top:8px}
:focus-visible{outline:3px solid var(--sun);outline-offset:2px}

/* ---- Knoppen ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  padding:12px 22px;border-radius:100px;font-weight:600;font-size:.98rem;
  border:2px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-sun{background:var(--sun);color:var(--ink);border-color:var(--sun)}
.btn-sun:hover{background:var(--sun-deep);border-color:var(--sun-deep);color:#fff}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--ink-2);color:#fff}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-lg{padding:15px 30px;font-size:1.05rem}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ---- Eyebrow / titels ---- */
.eyebrow{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;font-weight:600;color:var(--sun-deep);margin:0 0 .6em}
.eyebrow.center{text-align:center}
.section-title{font-size:clamp(1.8rem,4vw,2.9rem)}
.section{padding:76px 0}
.section-sand{background:var(--sand)}

/* ---- Header ---- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(252,249,243,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:11px}
.brand-mark{display:grid;place-items:center}
.brand-name{font-family:var(--font-display);font-weight:900;font-size:1.28rem;letter-spacing:-.01em;line-height:1}
.brand-sub{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.site-nav{display:flex;align-items:center;gap:26px}
.site-nav a{font-weight:500;font-size:.96rem}
.nav-cta{background:var(--ink);color:#fff!important;padding:9px 18px;border-radius:100px}
.nav-cta:hover{background:var(--sun);color:var(--ink)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px}

/* ---- Taalswitcher ---- */
.lang-switch{position:relative}
.lang-current{display:flex;align-items:center;background:none;border:1px solid var(--line);border-radius:8px;
  padding:6px 8px;cursor:pointer;line-height:0}
.lang-current:hover{border-color:var(--sun)}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:6px;margin:0;list-style:none;
  min-width:160px;display:none;z-index:20}
.lang-switch.open .lang-menu{display:block}
.lang-menu li a{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;font-size:.9rem;white-space:nowrap}
.lang-menu li a:hover{background:var(--sand)}
.lang-menu li a[aria-current]{font-weight:700}
.lang-menu svg{border-radius:2px;flex-shrink:0}

/* ---- Hero ---- */
.hero{position:relative;overflow:hidden;background:var(--ink);color:var(--paper);padding:96px 0 120px}
.hero-glow{position:absolute;inset:auto 0 -40% 0;height:120%;
  background:radial-gradient(60% 60% at 78% 12%,rgba(229,160,44,.55),transparent 60%),
             radial-gradient(50% 50% at 20% 90%,rgba(110,139,108,.35),transparent 60%);
  pointer-events:none}
.hero-inner{position:relative}
.hero .eyebrow{color:var(--sun)}
.hero-title{font-size:clamp(2.4rem,6.4vw,4.6rem);font-weight:900;color:#fff;letter-spacing:-.02em}
.hero-lede{font-size:1.12rem;max-width:52ch;color:rgba(252,249,243,.86)}

/* ---- Zoek/boek-widget ---- */
.search-card{margin-top:34px;background:var(--paper);color:var(--text);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;scroll-margin-top:84px;
  display:grid;grid-template-columns:1.4fr 1fr 1fr .7fr auto;gap:14px;align-items:end}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:.78rem;font-weight:600;color:var(--muted)}
.field input,.field select,.field textarea{
  font:inherit;padding:11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:#fff;color:var(--text)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--sun);outline:none}
.search-card .btn{height:46px}

/* ---- Studio-cards ---- */
.room-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:38px}
.room-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:.2s}
.room-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.room-card-media{position:relative;aspect-ratio:16/10;display:block;background:var(--sand)}
.room-card-media img{width:100%;height:100%;object-fit:cover}
.media-placeholder{position:absolute;inset:0;
  background:linear-gradient(135deg,var(--sand),#e7dcc6);
  background-image:radial-gradient(circle at 78% 26%,rgba(229,160,44,.5),transparent 42%)}
.room-badge{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;
  font-size:.74rem;font-weight:600;padding:5px 11px;border-radius:100px}
.room-card-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:6px;flex:1}
.room-card-body h3{font-size:1.5rem}
.room-price{margin:6px 0 4px;font-size:1.05rem}
.room-card-actions{margin-top:auto;display:flex;gap:10px;padding-top:12px}
.room-card-actions .btn{flex:1}

/* ---- Events / locatie ---- */
.events-band{max-width:760px}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
.checklist{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:10px}
.checklist li{padding-left:30px;position:relative}
.checklist li::before{content:"";position:absolute;left:0;top:7px;width:16px;height:16px;border-radius:50%;
  background:var(--sun);box-shadow:0 0 0 4px rgba(229,160,44,.2)}
.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.map-embed iframe{width:100%;height:100%;border:0}

/* ---- Prose (WYSIWYG-content) ---- */
.prose{max-width:68ch}
.prose p{margin:0 0 1em}
.prose h2{font-size:1.7rem;margin:1.2em 0 .4em}
.prose h3{font-size:1.3rem;margin:1.1em 0 .3em}
.prose a{color:var(--sun-deep);text-decoration:underline}
.prose img{border-radius:var(--radius);margin:1em 0}
.prose ul,.prose ol{padding-left:1.3em}

/* ---- Blog ---- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:34px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;padding-bottom:18px}
.post-card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.post-card h2,.post-card h3{font-size:1.25rem;padding:16px 18px 0;margin:0}
.post-card p{padding:6px 18px 0;margin:0}
.post-meta{font-size:.82rem}
.read-more{display:inline-block;padding:10px 18px 0;font-weight:600;color:var(--sun-deep)}
.post-single .post-cover{border-radius:var(--radius);margin:18px 0 26px;width:100%;max-height:420px;object-fit:cover}

/* ---- Detail ---- */
.back-link{display:inline-block;margin-bottom:14px;font-weight:600;color:var(--muted)}
.room-detail-head{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:flex-end}
.room-detail-price{text-align:right;display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.price-big{font-family:var(--font-display);font-size:2.2rem;font-weight:900;color:var(--ink)}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px;margin:28px 0}
.gallery-hero{grid-column:1/2;grid-row:1/3}
.gallery img{border-radius:var(--radius-sm);width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.room-detail-body{display:grid;grid-template-columns:1.6fr 1fr;gap:40px;margin-top:20px}
.amenities{background:var(--sand);border-radius:var(--radius);padding:24px}
.amenity-list{list-style:none;padding:0;margin:14px 0 20px;display:grid;gap:9px}
.amenity-list li{padding-left:24px;position:relative}
.amenity-list li::before{content:"✓";position:absolute;left:0;color:var(--sage);font-weight:700}

/* ---- Boekingspagina ---- */
.booking-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:40px;align-items:start}
.booking-summary{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;position:sticky;top:92px}
.summary-lines{margin:16px 0 0}
.summary-lines .line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line)}
.summary-lines .line.total{border:0;border-top:2px solid var(--ink);margin-top:6px;padding-top:12px;
  font-family:var(--font-display);font-weight:900;font-size:1.25rem}
.summary-empty{color:var(--muted)}
.guest-form{margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-sm{max-width:120px}
.fineprint{font-size:.82rem;color:var(--muted);margin-top:12px}
.alert{padding:14px 16px;border-radius:var(--radius-sm);margin:16px 0}
.alert-error{background:#fbe9eb;color:var(--fail);border:1px solid #f0c4c9}

/* ---- Kalender ---- */
.calendar{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-top:20px}
.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.cal-month{font-family:var(--font-display);font-weight:600;font-size:1.15rem;text-transform:capitalize}
.cal-nav{background:var(--sand);border:0;width:38px;height:38px;border-radius:50%;cursor:pointer;font-size:1rem}
.cal-nav:hover{background:var(--sun);color:var(--ink)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal-dow{text-align:center;font-size:.72rem;font-weight:600;color:var(--muted);padding:4px 0}
.cal-day{aspect-ratio:1;border:0;background:#f4f7f6;border-radius:9px;cursor:pointer;
  font:inherit;font-size:.9rem;color:var(--text);position:relative;transition:.12s}
.cal-day:hover:not(:disabled){background:var(--sun);color:var(--ink)}
.cal-day.empty{background:transparent;cursor:default}
.cal-day.busy,.cal-day:disabled{background:#f0ece3;color:#c3bcaf;cursor:not-allowed;text-decoration:line-through}
.cal-day.past{background:transparent;color:#cbc7bd;cursor:not-allowed}
.cal-day.sel{background:var(--ink);color:#fff}
.cal-day.in-range{background:rgba(229,160,44,.28)}
.cal-day.range-end{background:var(--ink);color:#fff}
.cal-legend{display:flex;gap:18px;align-items:center;font-size:.8rem;color:var(--muted);margin-top:14px}
.dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:-1px}
.dot-free{background:#f4f7f6;border:1px solid var(--line)}
.dot-sel{background:var(--ink)}
.dot-busy{background:#f0ece3}

/* ---- Cookie-consent ---- */
.cookie-banner{display:none;position:fixed;left:16px;right:16px;bottom:16px;z-index:50;max-width:640px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:18px 20px;gap:16px;align-items:center;flex-wrap:wrap}
.cookie-banner.is-visible{display:flex}
.cookie-banner p{margin:0;flex:1 1 260px;font-size:.9rem;color:var(--text)}
.cookie-banner a{text-decoration:underline}
.cookie-actions{display:flex;gap:8px;flex-shrink:0}

/* ---- Google-reviews ---- */
.google-badge{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
  margin:0 auto 34px;width:fit-content;padding:12px 22px;background:#fff;border:1px solid var(--line);
  border-radius:100px;box-shadow:var(--shadow)}
.google-score{font-family:var(--font-display);font-weight:900;font-size:1.3rem;color:var(--ink)}
.google-stars{color:#FBBC05;letter-spacing:1px}
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.review-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.review-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}
.review-stars{display:block;color:#FBBC05;font-size:.85rem;letter-spacing:1px}
.review-text{font-size:.95rem;margin:0 0 6px}

/* ---- Evenementenlijst (iamsterdam.com) ---- */
.event-list{display:grid;gap:16px;margin-top:26px}
.event-item{display:grid;grid-template-columns:76px 1fr;gap:18px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:18px 20px;align-items:start}
.event-date{background:var(--ink);color:#fff;border-radius:var(--radius-sm);text-align:center;padding:10px 6px;line-height:1}
.event-day{display:block;font-family:var(--font-display);font-weight:900;font-size:1.6rem}
.event-mon{display:block;text-transform:uppercase;font-size:.72rem;letter-spacing:.08em;color:var(--sun);margin-top:3px}
.event-body h3{font-size:1.2rem;margin:0 0 3px}
.event-when{margin:0 0 6px}
.event-body p{margin:0 0 8px}

/* ---- Status / receipt ---- */
.status-icon{width:78px;height:78px;border-radius:50%;display:grid;place-items:center;
  font-size:2.2rem;margin:0 auto 18px;color:#fff}
.status-ok{background:var(--ok)} .status-wait{background:var(--wait)} .status-fail{background:var(--fail)}
.receipt{max-width:440px;margin:26px auto 0;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:22px 26px;text-align:left}
.receipt-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--line)}
.receipt-row.total{border:0;border-top:2px solid var(--ink);margin-top:6px;font-size:1.15rem}

/* ---- CTA-band ---- */
.cta-band{background:var(--ink);color:var(--paper)}
.cta-band .section-title{color:#fff}
.cta-band .hero-lede{color:rgba(252,249,243,.85);margin-bottom:22px}

/* ---- Footer ---- */
.site-footer{background:var(--ink);color:rgba(252,249,243,.82);padding:60px 0 26px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px}
.footer-brand{color:#fff;font-size:1.5rem}
.site-footer h3{color:#fff;font-size:1rem;margin-bottom:10px}
.site-footer a{color:var(--sun)}
.site-footer a:hover{color:#fff}
.social,.footer-links{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.site-footer address{font-style:normal;line-height:1.9}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:36px;padding-top:20px;font-size:.85rem}

/* ---- Responsive ---- */
@media (max-width:900px){
  .search-card{grid-template-columns:1fr 1fr}
  .search-card .btn{grid-column:1/-1;height:48px}
  .room-grid,.post-grid,.loc-grid,.room-detail-body,.booking-grid,.footer-grid{grid-template-columns:1fr}
  .booking-summary{position:static}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery-hero{grid-column:1/-1;grid-row:auto}
  .nav-toggle{display:flex}
  .site-nav{position:fixed;inset:64px 0 auto 0;background:var(--paper);flex-direction:column;
    padding:20px;border-bottom:1px solid var(--line);display:none;gap:16px}
  .site-nav.open{display:flex}
}
@media (max-width:560px){
  .search-card{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .section{padding:52px 0}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important;animation:none!important}
}
