@import url('https://fonts.googleapis.com/css2?family=Lato&display=swap');
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css');

/* Base */
html, body { height:100%; overflow-x:hidden; }
body { position:relative; /* background-color:#FFa660; */ margin:0; font-family:'Lato', sans-serif; line-height:1.6; display:flex; flex-direction:column; background-image:url('../leatherbackground.webp'); background-repeat:repeat; }
/* body::before { content:''; position:absolute; inset:0; z-index:-1; } */
main { padding:5px 20px 20px 20px; flex:1 0 auto; }

/* Header */
header { background-color:#FFD700; color:#000; padding:20px 0; text-align:center; position:sticky; top:0; z-index:1200; box-shadow:0 2px 10px rgba(0,0,0,0.18); }
header h1 { margin:0; font-weight:bold; font-size:2rem; }
.social-links { display:flex; justify-content:center; align-items:center; gap:12px; flex-wrap:wrap; margin:10px auto 0; }
.social-link { display:inline-flex; align-items:center; gap:7px; background:rgba(255,255,255,0.22); color:#fdfdfd; padding:7px 12px; border-radius:20px; text-decoration:none; font-weight:700; border:1px solid rgba(255,215,0,0.35); box-shadow:0 2px 6px rgba(0,0,0,0.10); transition:background 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease, border-color 0.18s ease, color 0.18s ease; backdrop-filter:blur(3px); }
.social-link:hover { background:rgba(255,255,255,0.34); box-shadow:0 0 10px rgba(255,215,0,0.65), 0 4px 12px rgba(0,0,0,0.18); border-color:rgba(255,215,0,0.55); color:#ffffff; }
.social-link:active { transform:translateY(1px) scale(0.985); box-shadow:inset 0 2px 6px rgba(0,0,0,0.22), 0 2px 4px rgba(0,0,0,0.12); background:rgba(255,255,255,0.28); }
.social-link .fab { font-size:1.2rem; }
.social-link .fa-facebook-square { color:#1877f2; }
.social-link .fa-instagram { color:#c13584; }
header .social-link { color:#111; }
header .social-link:hover { color:#000; }
header .social-link-raffle { background:#25D366; border-color:rgba(0,0,0,0.22); color:#fff; }
header .social-link-raffle:hover { background:#1fb556; border-color:rgba(0,0,0,0.28); color:#fff; }
header .social-link-raffle .fa-whatsapp { color:#fff; }

/* Headings */
h2 { background:#000; color:#fff; padding:10px 14px; border-radius:6px; width:fit-content; margin:10px auto; }

/* Carousel */
.image-carousel { display:flex; overflow:hidden; width:100%; padding:0 4px; box-sizing:border-box; }
.image-carousel img { max-height:300px; object-fit:contain; margin:auto; }
body .slick-prev { left:20px; z-index:930; transform:scale(2.6); transform-origin:top left; }
body .slick-next { right:-20px; z-index:930; transform:scale(2.6); transform-origin:top right; }
.slick-slide { margin: 0; padding:0 4px; box-sizing:border-box; }
.slick-list { margin: 0; overflow:hidden; }
.slick-dotted.slick-slider { margin-bottom:5px; }

/* Lightbox */
.lightbox{position:fixed; inset:0; background:rgba(0,0,0,0.9); display:flex; align-items:center; justify-content:center; z-index:1050; cursor:pointer}
.lightbox img{max-width:98vw; max-height:98vh}
.lightbox-close{position:absolute; top:10px; right:10px; padding:8px 10px; background:rgba(255,255,255,.85); border-radius:14px; font-weight:700;}

/* Category cards */
.category-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:16px; margin:10px auto; max-width:1200px; }
#categories h2 { margin:12px auto; }
.card { position:relative; display:block; text-decoration:none; color:inherit; background:#fff; border-radius:10px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,0.15); }
.card img { width:100%; height:160px; object-fit:cover; display:block; }
.card-title { position:absolute; top:0; left:0; right:0; background:#000; color:#fff; text-align:center; padding:8px 10px; font-weight:700; }
.card-easter .card-title { background:linear-gradient(90deg, #000, #8a3d00); }


/* Sections */
#about { color:#fff; background:rgba(0,0,0,0.9); padding:30px; border-radius:8px; max-width:1200px; margin:20px auto; }
#testimonials, #contact { background:rgba(15,15,15,0.50); color:#fff; padding:20px; border-radius:12px; max-width:1200px; margin:20px auto; }
.phonespin { font-weight:700; }

/* Page wrappers (menu pages) */
.page { max-width:1000px; margin:20px auto; padding:0 16px; display:flex; flex-direction:column; flex:1 0 auto; min-width:50%; }
.page-glass { background:rgba(255,255,255,0.5); border-radius:12px; padding:16px; max-width:1000px; margin:12px auto; flex:1 0 auto; min-width:100%; }
.maze-wrap { display:flex; flex-direction:column; align-items:center; gap:10px; }
.maze-intro { max-width:820px; margin:6px auto 12px; text-align:center; color:#222; }
.maze-wrap canvas { border:2px solid rgba(0,0,0,0.25); border-radius:10px; background:rgba(255,255,255,0.7); box-shadow:0 4px 12px rgba(0,0,0,0.14); cursor:pointer; }
.food-legend { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; font-weight:700; }
.food-item { background:rgba(0,0,0,0.08); padding:6px 10px; border-radius:14px; border:1px solid rgba(0,0,0,0.12); color:#111; }
.food-item i { margin-right:6px; }
.food-item.eaten { opacity:0.35; text-decoration:line-through; }
.maze-status { text-align:center; margin:10px auto 0; font-weight:700; color:#8a3d00; padding:6px 10px; border-radius:7px; min-height:24px; }
.maze-status.status-flash { background:rgba(255,215,0,0.8); color:#000; }
.back { margin:10px auto; display:block; width:fit-content; text-align:center; color:#8a3d00; border:2px solid #8a3d00; padding:8px 14px; border-radius:8px; background:transparent; text-decoration:none; }
.back:hover { background:#fff; color:#8a3d00; }
.back:active { transform:translateY(1px); box-shadow:inset 0 2px 4px rgba(0,0,0,0.2); }
.page ul { max-width:800px; margin:0 auto 16px; }
.page article h3, .page article p { max-width:800px; margin:4px auto; }

/* Breadcrumbs */
.breadcrumbs { max-width:1000px; margin:10px auto 0; padding:8px 16px; color:#fff; background:rgba(0,0,0,0.5); border-radius:8px; }
.breadcrumbs a { color:#fff; text-decoration:underline; }

/* Contact form layout */
.tobookpieter { background:#ffffffaa; border-radius:7px; padding:8px; color:#000; }
#contact .inner, .contact-fields { background:rgba(0,0,0,0.22); padding:10px 12px; border-radius:10px; max-width:820px; margin:0 auto; }
.contact-form{ display:flex; flex-wrap:wrap; gap:12px 16px; justify-content:left; max-width:820px; margin:0 auto; }
.contactformlabelandinput{ display:flex; flex-direction:column; flex:1 1 260px; max-width:400px; min-width:220px; }
.contactformlabelandinput label{ margin-bottom:6px; font-weight:600; }
.contactformlabelandinput input{ padding:10px; border:1px solid #ccc; border-radius:4px; max-width:234px; width:100%; box-sizing:border-box; }
.contactformnotes{ flex:1 1 100%; }
.contactformnotes label{ display:block; margin-bottom:6px; font-weight:600; }
.contactformnotes textarea{ width:100%; max-width:min(100%, 99vw); padding:10px; border:1px solid #ccc; border-radius:4px; box-sizing:border-box; margin:4px 0; }
.contactformsubmit{ flex:1 1 100%; text-align:center; }
.contactformsubmit input[type=submit]{ max-width:200px; width:100%; padding:10px 16px; border:none; background:#4CAF50; color:#fff; border-radius:4px; cursor:pointer; }

/* Footer */
footer { background:#333; color:#fff; text-align:center; padding:20px 0; margin-top:20px; }
footer { flex-shrink:0; }

/* Responsive */
@media (max-width:768px) {
  header h1 { font-size:1.6rem; }
  .card img { height:140px; }
}
@media (max-width:420px){
  .social-links { flex-wrap:nowrap; gap:8px; }
  .social-link { padding:6px 10px; font-size:0.95rem; }
  .social-link .fab { font-size:1rem; }
}
@media (max-width:540px){
  main { padding:5px 10px 16px 10px; }
  .page { padding:0 8px; }
  .page-glass { padding:10px; }
  .maze-wrap canvas { width:min(320px, 94vw); height:auto; }
}
@media (min-width:760px){
  .contactformlabelandinput { flex-direction:row; align-items:center; }
  .contactformlabelandinput label{ width:30%; min-width:140px; margin:0 8px 0 0; text-align:right; }
  .contactformlabelandinput input{ flex:1 1 0; }
}

/* Scrollbar theming */
html { scrollbar-color: #8a3d00 #f0d1b4; scrollbar-width: thin; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: #f0d1b4; }
::-webkit-scrollbar-thumb { background-color: #8a3d00; border-radius: 8px; border: 2px solid #f0d1b4; }
::-webkit-scrollbar-thumb:hover { background-color: #6f3100; }
