/* ─────────────────────────────────────────
   style.css — Reis Concierge
   Gedeelde stijlen voor alle pagina's
───────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300;0,400;1,300;1,400&family=Jost:wght@200;300;400&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --s0:  #faf7f3;
  --s1:  #f5efe6;
  --s2:  #ede4d8;
  --s3:  #e0d4c4;
  --s4:  #cfc0ac;
  --s5:  #b8a48e;
  --w1:  #9e8b75;
  --w2:  #7d6a54;
  --tx:  #3c3028;
  --tx2: #6b5e50;
  --tx3: #9e9083;
}

html { scroll-behavior: smooth; }
body { background: var(--s0); color: var(--tx); font-family: 'Jost', sans-serif; font-weight: 200; overflow-x: hidden; }

/* CURSOR */
* { cursor: none !important; }
#cur { position:fixed;width:7px;height:7px;background:var(--w1);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .15s; }
#cur-ring { position:fixed;width:30px;height:30px;border:1px solid var(--s4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s; }
@media(max-width:768px){#cur,#cur-ring{display:none!important}*{cursor:auto!important}}

/* NAV */
nav {
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:28px 64px;
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .4s,background .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
nav.scrolled { padding:16px 64px;background:rgba(250,247,243,0.97);border-bottom-color:var(--s2);backdrop-filter:blur(12px); }
nav.solid { padding:16px 64px;background:rgba(250,247,243,0.97);border-bottom-color:var(--s2); }

.logo { text-decoration:none;display:flex;align-items:center;gap:14px; }
.logo-ring { width:42px;height:42px;border:1px solid rgba(255,255,255,0.35);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color .4s; }
nav.scrolled .logo-ring, nav.solid .logo-ring { border-color:var(--s4); }
.logo-ring span { font-family:'Cormorant',serif;font-size:14px;font-weight:400;color:var(--w2);letter-spacing:.06em; }
.logo-words { display:flex;flex-direction:column;line-height:1; }
.logo-words strong { font-family:'Cormorant',serif;font-size:17px;font-weight:400;color:#faf5ee;letter-spacing:.08em;transition:color .4s; }
nav.scrolled .logo-words strong, nav.solid .logo-words strong { color:var(--tx); }
.logo-words small { font-size:7.5px;letter-spacing:.5em;text-transform:uppercase;color:rgba(250,247,243,0.5);margin-top:4px;transition:color .4s; }
nav.scrolled .logo-words small, nav.solid .logo-words small { color:var(--tx3); }

.nav-links { display:flex;gap:36px;list-style:none;align-items:center; }
.nav-links a { text-decoration:none;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(250,247,243,0.8);transition:color .3s; }
nav.scrolled .nav-links a, nav.solid .nav-links a { color:var(--tx2); }
.nav-links a:hover, nav.scrolled .nav-links a:hover { color:var(--tx)!important; }
.nav-links a.active { color:var(--w1)!important; }
.nav-cta { padding:9px 22px;border:1px solid rgba(250,247,243,0.3)!important;color:rgba(250,247,243,0.9)!important;transition:border-color .3s,background .3s!important; }
nav.scrolled .nav-cta, nav.solid .nav-cta { border-color:var(--s3)!important;color:var(--tx)!important; }
.nav-cta:hover { background:rgba(255,255,255,0.1)!important; }
nav.scrolled .nav-cta:hover { background:var(--s1)!important; }

/* HAMBURGER */
.hamburger { display:none;flex-direction:column;gap:6px;width:36px;padding:4px 0;background:none;border:none; }
.hamburger span { display:block;height:1px;background:#faf5ee;transition:background .4s,transform .3s,opacity .3s; }
nav.scrolled .hamburger span, nav.solid .hamburger span { background:var(--tx); }
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* MOBILE MENU */
.mobile-menu { display:none;position:fixed;inset:0;z-index:190;background:var(--s0);flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .4s; }
.mobile-menu.open { opacity:1;pointer-events:all; }
.mobile-menu a { font-family:'Cormorant',serif;font-size:36px;font-weight:300;text-decoration:none;color:var(--tx);letter-spacing:.04em;opacity:0;transform:translateY(16px);transition:opacity .4s,transform .4s,color .3s; }
.mobile-menu.open a { opacity:1;transform:translateY(0); }
.mobile-menu.open a:nth-child(1){transition-delay:.08s}
.mobile-menu.open a:nth-child(2){transition-delay:.15s}
.mobile-menu.open a:nth-child(3){transition-delay:.22s}
.mobile-menu.open a:nth-child(4){transition-delay:.29s}
.mobile-menu.open a:nth-child(5){transition-delay:.36s}
.mobile-menu.open a:nth-child(6){transition-delay:.43s}
.mobile-menu a:hover { color:var(--w1); }
.mob-cta { font-size:13px!important;letter-spacing:.35em!important;border:1px solid var(--s3);padding:12px 32px!important;color:var(--tx)!important; }

/* FOOTER */
footer { background:var(--s0);border-top:1px solid var(--s2);padding:68px 0 34px; }
.footer-grid { display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;margin-bottom:52px; }
.footer-brand p { font-size:12px;line-height:1.9;color:var(--tx3);margin-top:18px;max-width:250px; }
.footer-contact { display:flex;flex-direction:column;gap:8px;margin-top:16px; }
.footer-contact a { font-size:12px;color:var(--tx3);text-decoration:none;transition:color .3s; }
.footer-contact a:hover { color:var(--tx); }
.footer-logo .logo-ring { border-color:var(--s3)!important; }
.footer-logo .logo-words strong { color:var(--tx)!important; }
.footer-logo .logo-words small { color:var(--tx3)!important; }
.footer-col h5 { font-size:8px;letter-spacing:.45em;text-transform:uppercase;color:var(--w1);margin-bottom:20px; }
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:11px; }
.footer-col a { text-decoration:none;font-size:12px;color:var(--tx3);transition:color .3s; }
.footer-col a:hover { color:var(--tx); }
.footer-bottom { display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--s2);font-size:10px;color:var(--tx3);letter-spacing:.06em; }

/* WHATSAPP FAB */
.whatsapp-fab { position:fixed;bottom:28px;right:28px;z-index:300;width:52px;height:52px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 20px rgba(37,211,102,0.35);transition:transform .3s,box-shadow .3s; }
.whatsapp-fab:hover { transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,0.45); }
.whatsapp-fab svg { width:26px;height:26px; }

/* LAYOUT */
.container { max-width:1260px;margin:0 auto;padding:0 64px; }
section { padding:110px 0; }

/* TYPOGRAPHY HELPERS */
.lbl { font-size:8px;letter-spacing:.55em;text-transform:uppercase;color:var(--w1);display:flex;align-items:center;gap:12px;margin-bottom:20px; }
.lbl::before { content:'';width:22px;height:1px;background:var(--s4); }
h2.t { font-family:'Cormorant',serif;font-size:clamp(34px,4.5vw,62px);font-weight:300;color:var(--tx);line-height:1.05;margin-bottom:18px; }
h2.t em { font-style:italic;color:var(--w1); }
.body-text { font-size:14px;line-height:2;color:var(--tx2); }
.body-text strong { color:var(--tx);font-weight:300; }

/* BUTTONS */
.btn { display:inline-block;text-decoration:none;font-family:'Jost',sans-serif;font-size:9px;letter-spacing:.4em;text-transform:uppercase;font-weight:300;transition:all .3s; }
.btn-dark { padding:14px 40px;background:var(--tx);color:var(--s0); }
.btn-dark:hover { background:var(--w2); }
.btn-fill { padding:14px 40px;background:var(--s0);color:var(--tx); }
.btn-fill:hover { background:var(--s1); }
.btn-outline { padding:13px 40px;border:1px solid var(--s3);color:var(--tx); }
.btn-outline:hover { border-color:var(--w1);background:var(--s1); }
.btn-ghost-white { padding:13px 40px;border:1px solid rgba(250,240,225,0.35);color:rgba(250,240,225,0.9); }
.btn-ghost-white:hover { border-color:rgba(250,240,225,0.7); }
.btn-gold { padding:14px 40px;background:var(--w1);color:var(--s0); }
.btn-gold:hover { background:var(--w2); }

/* TICKER */
.ticker { background:var(--s1);border-top:1px solid var(--s2);border-bottom:1px solid var(--s2);padding:14px 0;overflow:hidden; }
.ticker-track { display:flex;white-space:nowrap;animation:tick 38s linear infinite; }
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item { display:inline-flex;align-items:center;gap:18px;padding:0 24px;font-size:9px;letter-spacing:.4em;text-transform:uppercase;color:var(--tx3); }
.ticker-item::after { content:'·';color:var(--s3); }

/* PAGE HERO (inner pages) */
.page-hero { padding:160px 0 80px;background:var(--s1);border-bottom:1px solid var(--s2); }
.page-hero .lbl::before { background:var(--s4); }

/* PHOTO BANDS */
.photo-hero { position:relative;height:55vh;min-height:400px;overflow:hidden; }
.photo-hero img { width:100%;height:100%;object-fit:cover;filter:saturate(.8); }
.photo-hero-overlay { position:absolute;inset:0;background:linear-gradient(180deg,rgba(60,48,40,0.25) 0%,rgba(60,48,40,0.55) 100%); }
.photo-hero-text { position:absolute;bottom:0;left:0;right:0;padding:0 64px 52px; }

/* SECTION BANDS */
.band { background:var(--tx);padding:72px 0; }
.band-inner { display:flex;align-items:center;justify-content:space-between;gap:60px; }
.band-title { font-family:'Cormorant',serif;font-size:clamp(26px,3.5vw,48px);font-weight:300;color:var(--s0);line-height:1.15;max-width:500px; }
.band-title em { font-style:italic;color:var(--s4); }

/* SCROLL REVEAL */
.reveal { opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease; }
.reveal.in { opacity:1;transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s}
.d4{transition-delay:.4s} .d5{transition-delay:.5s} .d6{transition-delay:.6s}

/* FORMS */
label { display:block;font-size:8px;letter-spacing:.45em;text-transform:uppercase;color:var(--tx3);margin-bottom:8px; }
input,select,textarea { width:100%;background:transparent;border:none;border-bottom:1px solid var(--s3);color:var(--tx);padding:10px 0;font-family:'Jost',sans-serif;font-size:13px;font-weight:200;outline:none;transition:border-color .3s;-webkit-appearance:none;border-radius:0; }
input:focus,select:focus,textarea:focus { border-bottom-color:var(--w1); }
select option { background:var(--s0); }
textarea { resize:none; }
.f-row { margin-bottom:24px; }
.f-row-2 { display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px; }
.f-note { font-size:11px;line-height:1.7;color:var(--tx3);padding:14px 0;border-top:1px solid var(--s2);border-bottom:1px solid var(--s2);margin-bottom:26px; }
.f-note strong { color:var(--tx);font-weight:300; }
.btn-submit { width:100%;padding:15px;background:var(--tx);color:var(--s0);border:none;font-family:'Jost',sans-serif;font-size:9px;letter-spacing:.45em;text-transform:uppercase;font-weight:300;transition:background .3s; }
.btn-submit:hover { background:var(--w2); }

/* CARDS */
.card-grid-3 { display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--s2);border:1px solid var(--s2); }
.card-grid-4 { display:grid;grid-template-columns:repeat(4,1fr);gap:32px; }
.card { background:var(--s0);padding:44px 38px;position:relative;overflow:hidden;transition:background .3s; }
.card:hover { background:var(--s1); }
.card-bar { position:absolute;bottom:0;left:38px;right:38px;height:1px;background:var(--w1);transform:scaleX(0);transform-origin:left;transition:transform .5s; }
.card:hover .card-bar { transform:scaleX(1); }
.card-num { font-family:'Cormorant',serif;font-size:12px;font-weight:400;color:var(--s3);letter-spacing:.12em;margin-bottom:28px; }
.card-icon { margin-bottom:16px; }
.card-icon svg { width:26px;stroke:var(--w1);fill:none;stroke-width:1.1; }
.card-title { font-family:'Cormorant',serif;font-size:21px;font-weight:300;color:var(--tx);margin-bottom:12px;line-height:1.2; }
.card-text { font-size:12px;line-height:1.85;color:var(--tx3); }
.card-tags { display:flex;flex-wrap:wrap;gap:8px;margin-top:16px; }
.tag { font-size:8px;letter-spacing:.3em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--s3);color:var(--tx3); }

/* QUOTE SECTION */
.quote-sec { background:var(--s2);padding:96px 0;text-align:center; }
.quote-mark { font-family:'Cormorant',serif;font-size:72px;font-weight:300;line-height:.5;color:var(--s4);margin-bottom:28px;display:block; }
.quote-text { font-family:'Cormorant',serif;font-size:clamp(19px,2.8vw,32px);font-weight:300;font-style:italic;color:var(--tx);line-height:1.6;max-width:720px;margin:0 auto 28px; }
.quote-by { font-size:9px;letter-spacing:.45em;text-transform:uppercase;color:var(--w1); }

/* RESPONSIVE */
@media(max-width:1100px){
  nav,nav.scrolled,nav.solid{padding:22px 32px!important;}
  .container{padding:0 32px;}
  .photo-hero-text{padding:0 32px 44px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .card-grid-3{grid-template-columns:1fr 1fr;}
  .card-grid-4{grid-template-columns:1fr 1fr;}
  .band-inner{flex-direction:column;align-items:flex-start;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .mobile-menu{display:flex;}
}
@media(max-width:768px){
  nav,nav.scrolled,nav.solid{padding:16px 20px!important;}
  .container{padding:0 20px;}
  .photo-hero-text{padding:0 20px 36px;}
  section{padding:72px 0;}
  .card-grid-3,.card-grid-4{grid-template-columns:1fr;}
  .f-row-2{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
  .page-hero{padding:130px 0 60px;}
}
