/* ==========================================================================
   Marjoleins Boshuis - Main Stylesheet
   Performance optimized with critical CSS considerations
   ========================================================================== */

:root {
  --forest:#0B3D2E;
  --leaf:#2E7D32;
  --moss:#A5D6A7;
  --mist:#F5F8F5;
  --radius:10px;
  --transition:150ms ease;
  --max:1180px;
  font-size:16px;
  /* Reduce layout shift */
  --nav-height:84px;
}

/* Base reset - critical */
* { box-sizing:border-box; }
[hidden] { display:none !important; }
html { 
  scroll-behavior:smooth;
  /* Prevent layout shift on scrollbar appearance */
  scrollbar-gutter: stable;
}
body {
  margin:0;
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--mist);
  color:var(--forest);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

/* Image optimization */
img { 
  display:block; 
  max-width:100%; 
  height:auto;
  /* Prevent layout shift */
  content-visibility:auto;
}
hr {
  border:none;
  height:1px;
  background:rgba(11,61,46,0.15);
  margin:1.5rem 0;
}
a { color:var(--leaf); text-decoration:none; }
a:hover { text-decoration:underline; }
a:focus-visible, button:focus-visible { outline:3px solid var(--leaf); outline-offset:3px; border-radius:6px; }
button { font:inherit; cursor:pointer; }

.skip-link {
  position:absolute; left:-999px; top:0;
  background:#fff; padding:.5rem 1rem; border-radius:4px;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.skip-link:focus { left:1rem; z-index:1000; }

.container { width:100%; max-width:var(--max); margin:0 auto; padding:0 1.25rem; }
.flex { display:flex; }
.center { align-items:center; }
.between { justify-content:space-between; }

/* HEADER / NAV */
.site-header {
  position:sticky; top:0; z-index:500;
  --nav-height:84px;
  background:linear-gradient(rgba(245,248,245,.85),rgba(245,248,245,.85));
  backdrop-filter:blur(12px);
  border-bottom:1px solid #d9e5d9;
  transition:background .3s ease, box-shadow .3s ease;
}
.site-header.scrolled {
  --nav-height:68px;
  background:rgba(255,255,255,0.94);
  box-shadow:0 4px 18px -6px rgba(0,0,0,0.15);
  border-color:#cfdccf;
}
.nav-inner { height:var(--nav-height); display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.brand { display:flex; align-items:center; gap:.75rem; font-weight:600; font-size:1.1rem; color:var(--forest); text-decoration:none; white-space:nowrap; }
.logo-img { height:54px; width:auto; transition:height .3s; }
.site-header.scrolled .logo-img { height:46px; }

.main-nav { position:relative; }
.nav-panel { display:flex; align-items:center; }
.nav-list { list-style:none; margin:0; padding:0; display:flex; gap:1.75rem; align-items:center; }
.nav-list a {
  position:relative; font-weight:500; padding:.55rem .2rem; line-height:1.2; display:inline-flex; align-items:center;
}
.nav-note {
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.35rem .65rem;
  font-size:.75rem;
  font-weight:600;
  color:#0b3d2e;
  background:rgba(255,255,255,0.6);
  border:1px solid rgba(11,61,46,0.15);
  border-radius:999px;
}
.nav-list a:after {
  content:""; position:absolute; left:0; bottom:0; width:100%; height:2px;
  background:var(--leaf); transform:scaleX(0); transform-origin:right;
  transition:transform .25s ease; border-radius:2px;
}
.nav-list a:hover:after,
.nav-list a:focus-visible:after,
.nav-list a.active:after { transform:scaleX(1); transform-origin:left; }
.nav-cta { margin-left:.5rem; }

/* Disable underline bar for only the nav CTA ('Aanvraag') */
.nav-list .nav-cta a::after { content:none !important; display:none !important; }



@media (max-width:1024px){
  /* Always visible nav on mobile */
  .nav-panel { position:static; inset:auto; width:auto; background:transparent; padding:0; box-shadow:none; transform:none; overflow:visible; }
  /* Hide nav links on mobile */
  .nav-panel { display:none; }
}

@media (min-width:1025px){
  .nav-panel { display:flex; }
  .nav-list { display:flex; gap:1.75rem; align-items:center; }
}

/* HERO */
.hero { position:relative; min-height:72vh; display:flex; align-items:center; color:#fff; text-shadow:0 2px 8px rgba(0,0,0,0.4); }
.hero-bg { position:absolute; inset:0; background:linear-gradient(rgba(0,0,0,.45),rgba(0,0,0,.55)), url('images/hero.webp') center/cover no-repeat; z-index:-1; }
.hero-content { max-width:700px; }
#hero-title { margin:0; }
.hero-subtext { margin:.3rem 0 1.1rem; font-size:1.05rem; color:rgba(255,255,255,0.9); }
.lead { font-size:1.15rem; margin-bottom:1.5rem; }
.hero .cta-group { display:flex; gap:.85rem; flex-wrap:wrap; }
/* Make the secondary hero button (outline) more visible on the dark image */
.hero .btn.outline {
  color:#fff; border-color:#fff;
  background:rgba(255,255,255,0.08);
  box-shadow:0 10px 28px -14px rgba(0,0,0,0.75);
}
.hero .btn.outline:hover { background:#fff; color:#053024; border-color:#fff; }
.hero .btn:focus-visible { outline:3px solid #fff; outline-offset:2px; }

/* BUTTONS (refined, cleaner aesthetic) */
.btn {
  /* Reverted filled style */
  --btn-bg: var(--leaf);
  --btn-bg-hover: var(--forest);
  --btn-bg-active: #072d22;
  --btn-color: #fff;
  --btn-radius: 40px;
  --btn-border: var(--leaf);
  --btn-shadow: 0 2px 4px rgba(0,0,0,.18), 0 1px 2px rgba(0,0,0,.12);
  background:var(--btn-bg);
  color:var(--btn-color);
  border:2px solid var(--btn-border);
  border-radius:var(--btn-radius);
  padding:.9rem 1.4rem;
  font-weight:600;
  font-size:.95rem;
  line-height:1.2;
  display:inline-flex; align-items:center; gap:.5rem;
  text-decoration:none;
  cursor:pointer;
  position:relative;
  transition:background .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease, transform .15s ease;
  box-shadow:var(--btn-shadow);
  -webkit-tap-highlight-color:transparent;
}
.btn:hover { background:var(--btn-bg-hover); border-color:var(--btn-bg-hover); text-decoration:none; }
.btn:active { background:var(--btn-bg-active); border-color:var(--btn-bg-active); transform:translateY(1px); box-shadow:0 1px 3px rgba(0,0,0,.35); }
.btn:focus-visible { outline:0; box-shadow:0 0 0 2px #fff, 0 0 0 5px var(--leaf); }

/* Outline variant restored */
.btn.outline { background:transparent; color:var(--leaf); border-color:var(--leaf); }
.btn.outline:hover { background:var(--leaf); color:#fff; }
.btn.outline:active { background:var(--forest); border-color:var(--forest); }

/* Small variant */
.btn.small { padding:.5rem .85rem .55rem; font-size:.75rem; border-radius:22px; }

/* SECTIONS */
.section { padding:4.5rem 0 4rem; }
.section.alt { background:#fff; box-shadow:0 1px 0 #e7ede7 inset, 0 -1px 0 #e7ede7 inset; }
.section-title { font-size:2.2rem; margin:0 0 1rem; line-height:1.2; }
.section-subtext { margin:.2rem 0 1.5rem; font-style:italic; color:#2d4b3c; font-size:1rem; }
.intro { max-width:620px; margin-bottom:2rem; }

/* FEATURES */
.grid.features { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.25rem; }
.feature-card {
  background:#fff; padding:1.1rem 1rem 1.3rem; border-radius:var(--radius);
  border:1px solid #dde5de; box-shadow:0 2px 6px -2px rgba(0,0,0,0.06);
}
.feature-card h3 { margin:.25rem 0 .6rem; font-size:1.05rem; }

/* RUIMTES */
.space-grid { display:grid; gap:2rem; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); }
.space-card {
  background:#fff; border:1px solid #dbe3db; border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column; box-shadow:0 4px 14px -6px rgba(0,0,0,0.08);
}
.space-media img { width:100%; height:220px; object-fit:cover; }
.space-body { padding:1.1rem 1.15rem 1.4rem; flex:1; display:flex; flex-direction:column; }
.space-body h3 { margin:.2rem 0 .5rem; }
.capacity { list-style:none; padding:0; margin:0 0 .75rem; display:flex; flex-wrap:wrap; gap:.9rem; font-size:.8rem; }
.amenities { display:flex; gap:.5rem; flex-wrap:wrap; margin-top:auto; }
.amenities span {
  background:var(--moss); color:#053024; font-size:.65rem; letter-spacing:.5px;
  padding:.35rem .55rem; border-radius:20px; font-weight:600;
}

/* FACILITEITEN LIST */
.facility-list { list-style:none; margin:0; padding:0; display:grid; gap:1.25rem 2.5rem; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.facility { display:flex; align-items:center; gap:.9rem; font-size:1rem; }
.facility-icon { width:54px; height:54px; border-radius:50%; background:var(--forest); display:grid; place-items:center; flex:0 0 54px; }
.facility-icon img { width:30px; height:30px; display:block; }
.facility-label { line-height:1.25; }
@media (max-width:600px){
  .facility-list { gap:1rem 1.25rem; grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); }
  .facility-icon { width:48px; height:48px; flex-basis:48px; }
  .facility-icon img { width:26px; height:26px; }
}

/* Facility checklist (no icons version) */
.facility-check-grid { list-style:none; margin:0; padding:0; display:grid; gap:.6rem 2.2rem; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.facility-check-grid li { position:relative; padding-left:1.35rem; }
.facility-check-grid li:before { content:""; position:absolute; left:0; top:.45rem; width:.75rem; height:.75rem; background:var(--leaf); border-radius:2px; }
@media (max-width:640px){ .facility-check-grid { grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:.55rem 1.25rem; } }

/* Enhanced facilities section */
.facility-section { display:flex; flex-direction:column; gap:2.75rem; }
.facility-section .section-header { display:flex; flex-direction:column; gap:.65rem; }
.facility-card-grid {
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.facility-card-grid.summary { gap:1.25rem; }
.facility-card-grid.primary { margin-top:1rem; }
.facility-card-grid.secondary {
  margin-top:1.5rem;
  gap:1.35rem;
}
.facility-card {
  background:#fff; border:1px solid #dbe3db; border-radius:var(--radius);
  padding:1.35rem 1.5rem 1.6rem;
  box-shadow:0 18px 42px -30px rgba(11,61,46,0.5);
  display:flex; flex-direction:column; gap:.85rem;
}
.facility-card h3 { margin:0; font-size:1.15rem; color:var(--forest); }
.card-subtext {
  margin:.35rem 0 .5rem;
  font-style:italic;
  color:#2d4b3c;
  font-size:.92rem;
  line-height:1.4;
}
.secure-placeholder {
  padding:1.25rem 1.5rem;
  background:rgba(255,255,255,0.82);
  border:1px dashed rgba(11,61,46,0.25);
  border-radius:var(--radius);
  color:#204031;
  max-width:720px;
  transition:opacity var(--transition);
}
.private-main #secureContent {
  margin-top:2rem;
}
.card-lead { margin:0; color:#2d4a3b; font-size:.95rem; }
.card-bullet-list {
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:.55rem;
}
.card-bullet-list li {
  position:relative; padding-left:1.4rem; font-size:.95rem; color:#1f362a;
}
.card-bullet-list li::before {
  content:""; position:absolute; left:0; top:.45rem; width:.75rem; height:.75rem;
  background:var(--leaf); border-radius:2px;
}
.facility-card-grid.summary .facility-card {
  background:linear-gradient(160deg,#f8fcf8 0%,#ffffff 90%);
}
.facility-card-grid.secondary .facility-card {
  background:linear-gradient(160deg,#ffffff 0%,#f4fbf5 95%);
  border-color:#d5e5d7;
}
.facility-note-card {
  margin-top:2rem;
  background:linear-gradient(140deg,#f4fbf6 0%,#ffffff 100%);
  border:1px solid #cfe3d2; border-radius:20px;
  padding:1.6rem 1.8rem 1.9rem;
  box-shadow:0 22px 48px -32px rgba(5,48,36,0.5);
  display:flex; flex-direction:column; gap:1rem;
}
.facility-note-card h3 { margin:0; font-size:1.15rem; }
.facility-note-card .btn { align-self:flex-start; box-shadow:0 10px 24px -18px rgba(11,61,46,0.7); }

@media (max-width:1024px){
  .facility-card-grid { grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
}

@media (max-width:640px){
  .facility-card-grid,
  .facility-card-grid.primary,
  .facility-card-grid.secondary { grid-template-columns:1fr; }
  .facility-card { padding:1.2rem 1.25rem 1.4rem; }
  .facility-note-card { padding:1.35rem 1.3rem 1.6rem; }
}

/* COLS */
.cols-2 { --gap:2.5rem; display:grid; gap:var(--gap); grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); }
.mt { margin-top:1.75rem; }
.check-list { list-style:none; padding:0; margin:0 0 1rem; }
.check-list li { position:relative; padding-left:1.4rem; margin:.45rem 0; }
.check-list li:before {
  content:""; position:absolute; left:0; top:.45rem; width:.75rem; height:.75rem;
  background:var(--leaf); border-radius:2px;
}
.note { background:#eef6ef; border-left:4px solid var(--leaf); padding:.75rem .9rem; font-size:.85rem; border-radius:4px; }
.small { font-size:.8rem; }
.text-muted { color:#52655c; }

/* CATERING */
.catering-section { position:relative; }
.pricing-wrapper { overflow-x:auto; }
.pricing-table {
  width:100%; border-collapse:collapse; background:#fff; font-size:.9rem; border:1px solid #cfd8cf;
}
.pricing-table th, .pricing-table td {
  border:1px solid #cfd8cf; padding:.85rem .9rem; vertical-align:top; text-align:left;
}
.pricing-table thead th {
  background:#f2f7f2; font-size:.75rem; letter-spacing:.08em; text-transform:uppercase;
}
.pricing-table tbody th { font-weight:600; position:relative; }
.pricing-table .sub { font-weight:400; font-size:.72rem; line-height:1.3; color:#335344; margin-top:.25rem; }
.pricing-table td[data-label] { white-space:nowrap; }
.price-note { font-size:.75rem; text-align:center; margin:1rem 0 0; font-style:italic; color:#274136; }
.catering-cta { margin-top:2.2rem; text-align:center; }

@media (max-width:680px){
  .pricing-table thead { display:none; }
  .pricing-table tbody, .pricing-table tr, .pricing-table td, .pricing-table th {
    display:block; width:100%;
  }
  .pricing-table tr {
    margin:0 0 1.1rem; border:1px solid #cfd8cf; border-radius:8px; overflow:hidden;
  }
  .pricing-table th { background:#f5f9f5; }
  .pricing-table td {
    border:none; border-top:1px solid #e2e9e2; position:relative;
    padding:.6rem .9rem .6rem 7.5rem; min-height:44px;
  }
  .pricing-table td:before {
    content:attr(data-label);
    position:absolute; left:.9rem; top:.6rem;
    font-weight:600; font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; color:#2d4b3c;
  }
}

/* GALLERY (uniform grid) */
.gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.gallery .g-item { position:relative; aspect-ratio:4/3; overflow:hidden; border-radius:10px; box-shadow:0 2px 8px -2px rgba(0,0,0,0.15); background:#e3ece5; display:block; }
.gallery .g-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gallery .g-item:focus-visible { outline:3px solid var(--leaf); outline-offset:3px; }
.gallery .g-item:hover img { transform:scale(1.06); }

/* MAP */
.map-frame { margin-top:1rem; background:#d3e3d5; border:1px solid #c1d5c3; border-radius:8px; overflow:hidden; aspect-ratio:4/3; }
.map-frame iframe { width:100%; height:100%; border:0; }

/* FAQ */
.faq details {
  background:#fff; border:1px solid #dfe5df; border-radius:8px;
  padding:1rem 1.1rem; transition:var(--transition);
}
.faq details + details { margin-top:.75rem; }
.faq summary { cursor:pointer; list-style:none; font-weight:600; }
.faq summary::-webkit-details-marker { display:none; }
.faq details[open] { background:#f0f7f1; border-color:#cfe3d1; }

/* FAQ accordion animation */
.faq .faq-panel { overflow:hidden; max-height:0; transition:max-height 260ms ease; }

/* FAQ chevron icon */
.faq summary { position:relative; padding-right:1.5rem; }
.faq summary::after {
  content:""; position:absolute; right:.4rem; top:50%; width:.6rem; height:.6rem;
  border-right:2px solid var(--leaf); border-bottom:2px solid var(--leaf);
  transform:translateY(-50%) rotate(-45deg); transition:transform var(--transition);
}
.faq details[open] summary::after { transform:translateY(-50%) rotate(45deg); }
.faq details.closing summary::after { transform:rotate(-45deg); }

/* CONTACT FORM */
.contact-section { background:linear-gradient(160deg,#ffffff 0%,#f1f7f2 90%); position:relative; }
.contact-section .section-title,
#contact .section-title { text-align:center; }
#contact .intro { text-align:center; margin-left:auto; margin-right:auto; }
.contact-form {
  max-width:760px; background:#fff; padding:2rem 2rem 2.2rem;
  border-radius:var(--radius); border:1px solid #d9e5d9;
  margin:0 auto 2rem; box-shadow:0 10px 30px -12px rgba(0,0,0,0.18);
}
.form-row { display:flex; flex-direction:column; margin-bottom:1rem; }
.form-row.full { grid-column:1 / -1; }
.contact-form input, .contact-form textarea {
  padding:.75rem .85rem; font:inherit; border:1px solid #c6d6c7; border-radius:6px;
  background:#fdfefd; transition:var(--transition);
}
.contact-form input:focus, .contact-form textarea:focus {
  outline:2px solid var(--leaf); outline-offset:1px; background:#fff;
}
.form-row label { font-size:.85rem; font-weight:600; margin-bottom:.35rem; }
.contact-form .hp { position:absolute; left:-9999px; opacity:0; }
.error { color:#c62828; font-size:.7rem; min-height:1em; margin-top:.25rem; }
.form-status { margin-top:.75rem; font-size:.75rem; color:#274136; }
.form-status.is-success {
  background:#dff5e8; color:#0f2a21; border-left:5px solid var(--leaf);
  padding:.75rem 1rem; border-radius:8px; display:flex; align-items:center; gap:.6rem;
  font-weight:600; box-shadow:0 6px 18px -8px rgba(0,0,0,0.18);
  animation:fadeIn .25s ease;
}
.form-status.is-success::before { content:"✓"; color:#1e7a42; font-weight:900; }
.contact-direct { text-align:center; font-size:.9rem; }
.contact-direct a { font-weight:600; }

@media (min-width:640px){
  .contact-form {
    display:grid; grid-template-columns:repeat(2,1fr); gap:1.25rem 1.5rem;
  }
}

/* ADMIN */
.admin-main { padding-top:3.5rem; }
.admin-card {
  background:#fff;
  border:1px solid #dbe3db;
  border-radius:16px;
  padding:1.8rem 2rem 2rem;
  box-shadow:0 14px 36px -26px rgba(5,48,36,0.7);
  margin-bottom:2rem;
  display:flex;
  flex-direction:column;
  gap:1.2rem;
}
.admin-card-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.admin-form {
  display:flex;
  flex-direction:column;
  gap:.9rem;
}
.admin-form.row {
  flex-direction:row;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:1rem;
}
.admin-form.row > div { flex:1; min-width:220px; }
.admin-form label { font-size:.85rem; font-weight:600; color:#1c3729; }
.admin-form input {
  padding:.75rem .9rem;
  border:1px solid #c6d6c7;
  border-radius:10px;
  font:inherit;
  background:#f7faf8;
}
.admin-form input:focus {
  outline:3px solid rgba(46,125,50,0.32);
  border-color:#2e7d32;
  background:#fff;
}
.form-message {
  min-height:1.25rem;
  font-size:.8rem;
  color:#1f362a;
}
.form-message.is-error { color:#c62828; }

.admin-table {
  width:100%;
  border-collapse:collapse;
  border:1px solid #dbe3db;
  border-radius:12px;
  overflow:hidden;
  font-size:.92rem;
}
.admin-table th,
.admin-table td {
  padding:.85rem 1rem;
  border-bottom:1px solid #edf4ee;
  text-align:left;
}
.admin-table thead th {
  background:#f2f7f2;
  font-size:.75rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:#274136;
}
.admin-table tbody tr:last-child td { border-bottom:none; }
.admin-table tbody tr.empty td {
  text-align:center;
  color:#567060;
  font-style:italic;
}
.text-right { text-align:right; }

.btn.danger {
  --btn-bg:#c62828;
  --btn-bg-hover:#b71c1c;
  --btn-bg-active:#8e1515;
  --btn-color:#fff;
  background:var(--btn-bg);
  border-color:var(--btn-bg);
  color:var(--btn-color);
}
.btn.danger:hover { background:var(--btn-bg-hover); border-color:var(--btn-bg-hover); }
.btn.danger:active { background:var(--btn-bg-active); border-color:var(--btn-bg-active); }

@media (max-width:640px){
  .admin-form.row { flex-direction:column; align-items:stretch; }
  .admin-card { padding:1.5rem 1.4rem 1.6rem; }
}

/* FOOTER */
.site-footer { background:var(--forest); color:#fff; margin-top:3rem; font-size:.9rem; }
.site-footer h3,.site-footer h4 { margin:0 0 .75rem; }
.footer-grid {
  display:grid; gap:2rem; grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  padding:3rem 0 2rem;
}
.footer-intro { display:flex; align-items:flex-start; gap:.75rem; }
.footer-logo { display:block; padding:.25rem; }
.footer-grid ul { list-style:none; margin:0; padding:0; line-height:1.8; }
.footer-grid a { color:#fff; }
.footer-grid a:hover { text-decoration:underline; }
.subfooter { background:#092b21; padding:.85rem 0; }
.subfooter .container { gap:.75rem; }
@media (max-width:700px){
  .footer-grid { grid-template-columns:1fr; text-align:center; }
  .footer-grid > div { display:flex; flex-direction:column; align-items:center; }
  .footer-intro { justify-content:center; }
  .subfooter .container { flex-direction:column; justify-content:center; }
}

/* Footer brand/logo */
.footer-brand img { filter:drop-shadow(0 0 0 transparent); }

/* LIGHTBOX */
.lightbox { animation:fadeIn .35s ease; }
/* Enhanced gallery lightbox */
.lightbox.enhanced { position:fixed; inset:0; display:none; z-index:600; }
.lightbox.enhanced.open { display:block; }
.lightbox.enhanced .lb-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.85); backdrop-filter:blur(2px); }
.lightbox.enhanced .lb-shell { position:relative; width:100%; height:100%; display:flex; align-items:center; justify-content:center; padding:2rem 3.5rem; }
.lightbox.enhanced .lb-figure { margin:0; max-width:1280px; width:100%; position:relative; }
.lightbox.enhanced .lb-image { width:100%; height:auto; display:block; border-radius:10px; box-shadow:0 12px 50px -12px rgba(0,0,0,.6); transition:transform .25s ease; will-change:transform; touch-action:none; }
.lightbox.enhanced .lb-counter { position:absolute; bottom:1rem; right:1.2rem; font-size:.7rem; letter-spacing:.12em; font-weight:600; color:#cfe7d4; background:rgba(0,0,0,.4); padding:.4rem .6rem; border-radius:30px; }
.lightbox.enhanced .lb-btn {
  position:absolute;
  width:50px; height:50px; border-radius:32px;
  display:grid; place-items:center;
  font-size:1.45rem; font-weight:600;
  cursor:pointer;
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,.55);
  backdrop-filter:none; -webkit-backdrop-filter:none;
  box-shadow:0 2px 10px -4px rgba(0,0,0,.55);
  transition:background .25s ease, color .25s ease, border-color .25s ease, transform .18s ease, box-shadow .3s ease;
}
.lightbox.enhanced .lb-btn:hover {
  background:rgba(255,255,255,.12);
  transform:translateY(-2px);
}
.lightbox.enhanced .lb-btn:active {
  background:rgba(255,255,255,.22);
  transform:translateY(0) scale(.94);
  box-shadow:0 1px 6px -2px rgba(0,0,0,.6);
}
.lightbox.enhanced .lb-btn:focus-visible { outline:0; box-shadow:0 0 0 2px #fff, 0 0 0 5px var(--leaf); }
.lightbox.enhanced .lb-prev { left:1rem; }
.lightbox.enhanced .lb-next { right:1rem; }
.lightbox.enhanced .lb-close { top:1rem; right:1rem; font-size:2rem; line-height:1; }
.lightbox.enhanced .lb-btn:disabled { opacity:.4; cursor:not-allowed; }
@media (max-width:900px){
  .lightbox.enhanced .lb-shell { padding:1.5rem 2.5rem; }
  .lightbox.enhanced .lb-btn { width:42px; height:42px; font-size:1.4rem; }
  .lightbox.enhanced .lb-prev { left:.5rem; }
  .lightbox.enhanced .lb-next { right:.5rem; }
}
@media (max-width:640px){
  .lightbox.enhanced .lb-shell { padding:1rem 1.5rem 2.5rem; }
  .lightbox.enhanced .lb-btn { width:40px; height:40px; font-size:1.35rem; }
  .lightbox.enhanced .lb-caption { font-size:.75rem; }
  .lightbox.enhanced .lb-counter { font-size:.6rem; }
}
@keyframes fadeIn { from {opacity:0;} to {opacity:1;} }

/* DIALOG */
dialog {
  width:min(640px,92vw); border:1px solid #c7dcc9; border-radius:12px;
  padding:1.75rem 1.5rem 2rem; box-shadow:0 12px 40px -10px rgba(0,0,0,0.35); background:#fff;
}
dialog::backdrop { background:rgba(0,0,0,0.55); backdrop-filter:blur(3px); }
/* Review modal specific */
.review-modal-header { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:.5rem; }
.review-modal .stars { margin-top:.1rem; }

/* Success modal */
.success-modal-header .success-icon {
  width:28px; height:28px; border-radius:50%; display:grid; place-items:center;
  background:#dff5e8; color:#1e7a42; font-weight:800;
}
.success-modal p { color:#274136; }

/* UTIL */
.sr-only {
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap; border:0;
}

@media (prefers-reduced-motion:reduce){
  * { animation:none !important; transition:none !important; }
}

/* AUTH OVERLAY */
.auth-overlay {
  position:fixed;
  inset:0;
  z-index:1000;
  display:grid;
  place-items:center;
  padding:2rem 1.5rem;
  background:rgba(5,29,23,0.68);
  backdrop-filter:blur(4px);
}

.auth-overlay[hidden] { display:none !important; }

.auth-card {
  background:#ffffff;
  border-radius:16px;
  padding:2rem 2.25rem;
  box-shadow:0 28px 60px -32px rgba(0,0,0,0.55);
  max-width:420px;
  width:100%;
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  text-align:left;
}

.auth-card h1 {
  margin:0;
  font-size:1.6rem;
  color:#0b3d2e;
}

.auth-form {
  display:flex;
  flex-direction:column;
  gap:.85rem;
}

.auth-form label {
  font-weight:600;
  font-size:.85rem;
  color:#173125;
}

.auth-form input {
  padding:.75rem .9rem;
  border-radius:10px;
  border:1px solid #c6d6c7;
  font:inherit;
  background:#f7faf8;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.auth-form input:focus {
  outline:3px solid rgba(46,125,50,0.35);
  border-color:#2e7d32;
  background:#ffffff;
}

.auth-error {
  min-height:1.2rem;
  font-size:.78rem;
  color:#c62828;
}

.auth-locked .site-header,
.auth-locked .private-main,
.auth-locked .site-footer {
  display:none;
}

@media (max-width:520px){
  .auth-card { padding:1.6rem 1.5rem; }
}

/* REVIEWS */
.reviews-mount { min-height:140px; }
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.1rem; }
.reviews-carousel { position:relative; }
.reviews-track {
  display:flex; gap:1rem; overflow-x:auto; scroll-snap-type:x mandatory; padding:0 .25rem .25rem; /* bottom pad for shadow */
  -webkit-overflow-scrolling: touch;
  /* Hide scrollbar across browsers */
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE/Edge legacy */
}
.reviews-track:focus { outline:none; }
.reviews-track::-webkit-scrollbar { display:none; width:0; height:0; }
.review-card { scroll-snap-align:start; flex:0 0 calc((100% - 2rem) / 3); /* 3 per view with gaps */ }
@media (max-width:980px){ .review-card { flex-basis: calc((100% - 1rem) / 2); } } /* 2 per view */
@media (max-width:600px){ .review-card { flex-basis: 100%; } } /* 1 per view */
.reviews-nav {
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  background:#fff; color:var(--forest); border:1px solid #cfe0d2; box-shadow:0 6px 18px -8px rgba(0,0,0,.25);
  width:40px; height:40px; border-radius:50%; display:grid; place-items:center; font-size:1.25rem;
}
.reviews-nav.prev { left:-6px; }
.reviews-nav.next { right:-6px; }
.reviews-nav:disabled { opacity:.5; cursor:not-allowed; }
.reviews-nav[hidden] { display:none !important; }
.reviews-carousel:not(.is-scrollable) .reviews-nav { display:none; }
.review-card {
  background:#fff; border:1px solid #dbe3db; border-radius:12px; padding:1rem 1rem 1.1rem;
  box-shadow:0 4px 14px -6px rgba(0,0,0,.08);
}
.review-head { display:flex; align-items:center; justify-content:space-between; gap:.75rem; margin-bottom:.35rem; }
.review-author { font-weight:700; }
.review-date { font-size:.75rem; color:#3a5246; margin-bottom:.4rem; }
.review-text { margin:.2rem 0 .8rem; }

.stars { display:inline-flex; gap:.1rem; color:#f5a524; font-size:1.0rem; line-height:1; flex-wrap:wrap; }
.stars .star.half { position:relative; }
.stars .star.half::before { content:"★"; position:absolute; left:0; width:50%; overflow:hidden; color:#f5a524; }
.stars .star { color:#c5d0c7; }
.stars .star.full { color:#f5a524; }

.btn-more { font-size:.78rem; padding:.45rem .7rem; }
.reviews-source { margin-top:1rem; color:#274136; }

/* Skeleton */
.skeleton .review-card { position:relative; overflow:hidden; }
.skeleton-line { height:10px; background:linear-gradient(90deg,#e9f0ea,#f6faf7,#e9f0ea); background-size:200% 100%; animation:sheen 1.2s infinite; border-radius:6px; margin:.5rem 0; }
.skeleton-line.lg { height:16px; width:60%; }
.skeleton-stars { height:14px; width:100px; background:linear-gradient(90deg,#e9f0ea,#f6faf7,#e9f0ea); background-size:200% 100%; animation:sheen 1.2s infinite; border-radius:6px; margin:.35rem 0; }
@keyframes sheen { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* COOKIE CONSENT BANNER */
.cookie-banner {
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  background:rgba(11, 61, 46, 0.98);
  backdrop-filter:blur(10px);
  color:#fff;
  padding:1.5rem 1rem;
  box-shadow:0 -4px 20px rgba(0,0,0,0.2);
  z-index:9999;
  transform:translateY(100%);
  transition:transform 0.3s ease-in-out;
}

.cookie-banner-visible {
  transform:translateY(0);
}

.cookie-banner-content {
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
}

.cookie-banner-text {
  flex:1;
}

.cookie-banner-text h3 {
  margin:0 0 0.5rem;
  font-size:1.25rem;
  color:#fff;
}

.cookie-banner-text p {
  margin:0.5rem 0;
  line-height:1.5;
  opacity:0.95;
  font-size:0.95rem;
}

.cookie-banner-link {
  margin-top:0.75rem !important;
}

.cookie-banner-link a {
  color:var(--moss);
  text-decoration:underline;
  font-weight:500;
}

.cookie-banner-link a:hover {
  color:#fff;
}

.cookie-banner-actions {
  display:flex;
  gap:0.75rem;
  flex-shrink:0;
  flex-wrap:wrap;
}

.cookie-btn-accept {
  background:var(--leaf);
  color:#fff;
  border:none;
  padding:0.75rem 1.5rem;
  border-radius:8px;
  font-weight:600;
  cursor:pointer;
  transition:all 0.2s ease;
  white-space:nowrap;
}

.cookie-btn-accept:hover {
  background:#1e5f24;
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(46, 125, 50, 0.3);
}

.cookie-btn-functional,
.cookie-btn-decline {
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,0.4);
  padding:0.75rem 1.25rem;
  border-radius:8px;
  font-weight:500;
  cursor:pointer;
  transition:all 0.2s ease;
  white-space:nowrap;
}

.cookie-btn-functional:hover,
.cookie-btn-decline:hover {
  background:rgba(255,255,255,0.1);
  border-color:rgba(255,255,255,0.6);
}

/* Responsive cookie banner */
@media (max-width:900px) {
  .cookie-banner-content {
    flex-direction:column;
    align-items:stretch;
    gap:1.25rem;
  }
  
  .cookie-banner-actions {
    justify-content:stretch;
  }
  
  .cookie-banner-actions button {
    flex:1;
    min-width:0;
  }
}

@media (max-width:640px) {
  .cookie-banner {
    padding:1.25rem 1rem;
  }
  
  .cookie-banner-text h3 {
    font-size:1.1rem;
  }
  
  .cookie-banner-text p {
    font-size:0.9rem;
  }
  
  .cookie-banner-actions {
    flex-direction:column;
    gap:0.5rem;
  }
  
  .cookie-banner-actions button {
    width:100%;
    padding:0.7rem 1rem;
  }
}

/* ACTIVITIES PAGE */
.hero-small { min-height:55vh; }
.hero-small .hero-content { max-width:800px; }

/* Reduced spacing for activities page sections */
.activities-page {
  background-image:url('/images/logo.png');
  background-repeat:no-repeat;
  background-position:center center;
  background-attachment:fixed;
  background-size:400px auto;
  position:relative;
}
.activities-page::before {
  content:'';
  position:fixed;
  inset:0;
  background:rgba(245,248,245,0.92);
  pointer-events:none;
  z-index:-1;
}
.activities-page .section { padding:2rem 0; }
.activities-page .section.alt { padding:2.5rem 0; }
.activities-page .section-title { margin-bottom:0.5rem; }
.activities-page .intro { margin-bottom:1.25rem; }
.activities-page .site-footer { margin-top:0; }

.activity-card {
  background:#fff;
  border:1px solid #dbe3db;
  border-radius:var(--radius);
  padding:2rem 2.5rem;
  box-shadow:0 18px 42px -30px rgba(11,61,46,0.5);
}

.activity-card.partner {
  background:linear-gradient(160deg,#f8fcf8 0%,#ffffff 90%);
  border-color:#cfe3d2;
}

.activity-content h2 {
  margin:0 0 0.5rem;
  font-size:1.5rem;
  color:var(--forest);
}

.activity-subtitle {
  margin:0 0 1rem;
  color:#2d4b3c;
  font-size:1rem;
}

.activity-content p {
  margin:0 0 1rem;
  color:#1f362a;
  line-height:1.7;
}

.activity-content .check-list {
  margin:0 0 1.25rem;
}

.activity-meta {
  display:flex;
  flex-wrap:wrap;
  gap:0.75rem 1.5rem;
  margin-top:1.25rem;
  padding-top:1rem;
  border-top:1px solid #e7ede7;
}

.meta-item {
  font-size:0.9rem;
  color:#274136;
}

.meta-item strong {
  color:var(--forest);
}

.meta-item a {
  color:var(--leaf);
  font-weight:600;
}

.cta-section .section-title {
  text-align:center;
}

.cta-section .intro {
  text-align:center;
  max-width:650px;
}

@media (max-width:768px) {
  .activity-card {
    padding:1.5rem 1.25rem;
  }

  .activity-content h2 {
    font-size:1.3rem;
  }

  .activity-meta {
    flex-direction:column;
    gap:0.5rem;
  }
}