/*
Theme Name: Koksijde Appartementen
Theme URI: https://koksijde.net
Author: Eigen beheer
Description: Custom WordPress thema voor de verhuur van 5 vakantieappartementen in Koksijde. Fotogalerijen per appartement, beschikbaarheid via Booking.com iCal, aanvraagformulier per e-mail. Geen boekingsmodule, geen online betaling.
Version: 1.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: koksijde-apartments
*/

/* =========================================================
   1. VARIABLES & RESET
   ========================================================= */
:root{
  --color-ocean:        #0E5C73;
  --color-ocean-dark:   #083D4D;
  --color-ocean-light:  #4C8FA3;
  --color-sand:         #EFE3C8;
  --color-sand-dark:    #D9C49C;
  --color-sand-light:   #F8F2E3;
  --color-white:        #FFFFFF;
  --color-text:         #2B2B2B;
  --color-text-light:   #5A5A5A;
  --color-success:      #3E8E5A;
  --color-busy:         #C2554A;
  --radius:             10px;
  --shadow:             0 6px 18px rgba(8,61,77,0.12);
  --max-width:           1180px;
  --font-heading: 'Georgia', 'Times New Roman', serif;
  --font-body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-white);
  line-height: 1.65;
  font-size: 16px;
}
img{ max-width:100%; display:block; }
a{ color: var(--color-ocean); text-decoration:none; }
a:hover{ color: var(--color-ocean-dark); }
h1,h2,h3,h4{ font-family: var(--font-heading); color: var(--color-ocean-dark); line-height:1.2; margin:0 0 .5em; }
ul{ padding-left:1.2em; }
.container{ max-width: var(--max-width); margin:0 auto; padding:0 24px; }
.btn{
  display:inline-block;
  background: var(--color-ocean);
  color:#fff;
  padding: 12px 26px;
  border-radius: var(--radius);
  border:none;
  cursor:pointer;
  font-weight:600;
  letter-spacing:.02em;
  transition: background .2s ease, transform .15s ease;
}
.btn:hover{ background: var(--color-ocean-dark); color:#fff; transform: translateY(-1px); }
.btn-outline{
  background: transparent;
  border:2px solid var(--color-white);
  color:#fff;
}
.btn-outline:hover{ background: rgba(255,255,255,.15); color:#fff; }
.section{ padding: 70px 0; }
.section-sand{ background: var(--color-sand-light); }
.section-title{ text-align:center; margin-bottom: 10px; font-size: 2.1rem; }
.section-subtitle{ text-align:center; color: var(--color-text-light); margin-bottom: 40px; font-size:1.05rem; }

/* =========================================================
   2. HEADER / NAV
   ========================================================= */
.site-header{
  position: sticky; top:0; z-index: 100;
  background: var(--color-white);
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; min-height:74px; }
.site-logo{ font-family: var(--font-heading); font-size:1.4rem; font-weight:700; color: var(--color-ocean-dark); }
.site-logo a{ color: inherit; }
.main-nav ul{ list-style:none; display:flex; gap: 28px; margin:0; padding:0; }
.main-nav a{ color: var(--color-text); font-weight:600; font-size:.97rem; }
.main-nav a:hover{ color: var(--color-ocean); }
.lang-switch{ margin-left: 24px; }
.nav-toggle{ display:none; background:none; border:none; font-size:1.6rem; cursor:pointer; color: var(--color-ocean-dark); }

@media (max-width: 880px){
  .nav-toggle{ display:block; }
  .main-nav{
    position:absolute; top:74px; left:0; right:0;
    background:#fff; box-shadow: 0 8px 16px rgba(0,0,0,.08);
    display:none; flex-direction:column;
  }
  .main-nav.open{ display:flex; }
  .main-nav ul{ flex-direction:column; padding: 16px 24px; gap:14px; }
}

/* =========================================================
   3. HERO (Homepage)
   ========================================================= */
.hero{
  position:relative;
  min-height: 62vh;
  display:flex; align-items:center; justify-content:center; text-align:center;
  background-size:cover; background-position:center;
  color:#fff;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(8,61,77,.55), rgba(8,61,77,.75));
}
.hero-inner{ position:relative; z-index:2; max-width: 760px; padding: 0 24px; }
.hero-inner h1{ color:#fff; font-size: 2.6rem; margin-bottom:.4em; }
.hero-inner p{ font-size:1.2rem; margin-bottom: 1.6em; opacity:.95; }

/* =========================================================
   4. APARTMENT GRID (Homepage)
   ========================================================= */
.apartment-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 980px){ .apartment-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .apartment-grid{ grid-template-columns: 1fr; } }

.apartment-card{
  background:#fff;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
  transition: transform .2s ease, box-shadow .2s ease;
  display:flex; flex-direction:column;
}
.apartment-card:hover{ transform: translateY(-4px); box-shadow: 0 12px 26px rgba(8,61,77,.18); }
.apartment-card .thumb{ aspect-ratio: 4/3; overflow:hidden; }
.apartment-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.apartment-card .body{ padding: 18px 20px 22px; flex:1; display:flex; flex-direction:column; }
.apartment-card h3{ margin-bottom:6px; font-size:1.25rem; }
.apartment-card .meta{
  display:flex; flex-wrap:wrap; gap:12px;
  color: var(--color-text-light); font-size:.88rem; margin-bottom: 14px;
}
.apartment-card .meta span{ display:inline-flex; align-items:center; gap:5px; }
.apartment-card .btn{ margin-top:auto; align-self:flex-start; }

/* =========================================================
   5. SINGLE APARTMENT PAGE
   ========================================================= */
.apt-header{ padding: 40px 0 10px; }
.apt-header h1{ font-size: 2.2rem; margin-bottom:4px; }
.apt-header .location{ color: var(--color-text-light); font-weight:600; }

.gallery{
  display:grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr;
  gap:8px; border-radius: var(--radius); overflow:hidden; margin: 24px 0 10px;
}
.gallery a{ display:block; overflow:hidden; height:100%; }
.gallery img{ width:100%; height:100%; object-fit:cover; transition: transform .3s ease; }
.gallery a:hover img{ transform: scale(1.05); }
.gallery a:first-child{ grid-row: 1 / 3; }
@media (max-width: 760px){
  .gallery{ grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .gallery a:first-child{ grid-column: 1 / 3; grid-row: auto; aspect-ratio: 16/9; }
  .gallery a{ aspect-ratio: 1/1; }
}
.gallery-more-link{ text-align:center; margin: 6px 0 30px; font-weight:600; }

.apt-layout{ display:grid; grid-template-columns: 2fr 1fr; gap: 50px; margin-top: 20px; }
@media (max-width: 880px){ .apt-layout{ grid-template-columns: 1fr; } }

.apt-facts{
  display:grid; grid-template-columns: repeat(2,1fr); gap: 14px 24px;
  background: var(--color-sand-light); border-radius: var(--radius);
  padding: 20px 24px; margin: 24px 0;
}
.apt-facts .fact{ display:flex; flex-direction:column; }
.apt-facts .fact .label{ font-size:.8rem; text-transform:uppercase; letter-spacing:.05em; color: var(--color-text-light); }
.apt-facts .fact .value{ font-weight:700; color: var(--color-ocean-dark); font-size:1.05rem; }

.amenities-list{ list-style:none; padding:0; display:grid; grid-template-columns: repeat(2,1fr); gap: 10px 16px; }
.amenities-list li{ display:flex; align-items:center; gap:8px; }
.amenities-list li::before{ content:"✓"; color: var(--color-success); font-weight:700; }

.sidebar-box{
  background: var(--color-sand-light);
  border-radius: var(--radius);
  padding: 26px;
  margin-bottom: 28px;
}
.sidebar-box h3{ margin-bottom: 16px; font-size:1.2rem; }

/* Availability calendar */
.cal-months{ display:flex; gap: 24px; flex-wrap:wrap; }
.cal-month{ flex:1; min-width:220px; }
.cal-month h4{ text-align:center; margin-bottom:10px; font-size:1rem; }
.cal-grid{ display:grid; grid-template-columns: repeat(7,1fr); gap:3px; }
.cal-grid .dow{ font-size:.7rem; text-align:center; color: var(--color-text-light); font-weight:600; }
.cal-day{
  aspect-ratio:1/1; display:flex; align-items:center; justify-content:center;
  font-size:.78rem; border-radius:5px; background:#fff; color: var(--color-text-light);
}
.cal-day.available{ background: #E5F3E9; color: var(--color-success); }
.cal-day.busy{ background: #F6E1DE; color: var(--color-busy); text-decoration: line-through; }
.cal-day.empty{ background:transparent; }
.cal-legend{ display:flex; gap:18px; margin-top:14px; font-size:.82rem; }
.cal-legend span{ display:inline-flex; align-items:center; gap:6px; }
.cal-legend .dot{ width:12px; height:12px; border-radius:3px; display:inline-block; }
.cal-legend .dot.available{ background:#E5F3E9; border:1px solid var(--color-success); }
.cal-legend .dot.busy{ background:#F6E1DE; border:1px solid var(--color-busy); }
.cal-note{ font-size:.8rem; color: var(--color-text-light); margin-top:12px; }

/* Aanvraagformulier */
.aanvraag-form .form-row{ margin-bottom: 14px; }
.aanvraag-form label{ display:block; font-weight:600; font-size:.88rem; margin-bottom:5px; }
.aanvraag-form input,
.aanvraag-form select,
.aanvraag-form textarea{
  width:100%; padding: 11px 13px; border:1px solid var(--color-sand-dark);
  border-radius:6px; font-family: inherit; font-size:.95rem; background:#fff;
}
.aanvraag-form .two-col{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .aanvraag-form .two-col{ grid-template-columns:1fr; } }
.aanvraag-form textarea{ min-height:100px; resize:vertical; }
.aanvraag-form .btn{ width:100%; text-align:center; }
.form-success{ background:#E5F3E9; color: var(--color-success); padding:14px 18px; border-radius:8px; margin-bottom:18px; font-weight:600; }
.form-error{ background:#F6E1DE; color: var(--color-busy); padding:14px 18px; border-radius:8px; margin-bottom:18px; font-weight:600; }
.honeypot-field{ position:absolute; left:-9999px; }

/* =========================================================
   6. GENERIC PAGES
   ========================================================= */
.page-hero{
  background-size:cover; background-position:center;
  min-height: 280px; display:flex; align-items:center; justify-content:center;
  color:#fff; text-align:center; position:relative;
}
.page-hero::before{ content:""; position:absolute; inset:0; background: rgba(8,61,77,.6); }
.page-hero h1{ position:relative; z-index:2; color:#fff; }
.page-content{ padding: 50px 0; max-width: 820px; margin:0 auto; }

/* =========================================================
   7. FOOTER
   ========================================================= */
.site-footer{ background: var(--color-ocean-dark); color: #E9F1F3; padding: 50px 0 28px; margin-top:60px; }
.footer-grid{ display:grid; grid-template-columns: repeat(3,1fr); gap:30px; margin-bottom:30px; }
@media (max-width:760px){ .footer-grid{ grid-template-columns:1fr; } }
.site-footer h4{ color:#fff; font-size:1rem; margin-bottom:12px; }
.site-footer a{ color:#cfe3e8; }
.site-footer a:hover{ color:#fff; }
.footer-bottom{ text-align:center; font-size:.82rem; color:#9FC0C7; border-top:1px solid rgba(255,255,255,.12); padding-top:20px; }
