/* =====================================================================
   James Martin & Associates — Aruba
   Stijl: ruige vintage Americana (jaren '20-'30 NYC) + warme
   Caribische / Latijns-Amerikaanse kleuren. Gritty maar warm.
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;500;600;700&family=Lora:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Playfair+Display:ital,wght@0,500;0,700;1,500;1,700&display=swap');

:root{
  --ink:        #1c1814;   /* near-black, gritty ink            */
  --ink-soft:   #2a2420;
  --paper:      #f4ead7;   /* warm old paper                    */
  --paper-2:    #ece0c8;
  --paper-3:    #e2d3b4;
  --rust:       #b5532a;   /* terracotta / brick                */
  --rust-dark:  #8c3c1d;
  --oxblood:    #6f2a20;   /* deep oxblood                      */
  --ochre:      #c79233;   /* mustard / brass                   */
  --teal:       #2f7d76;   /* muted Caribbean accent (sparing)  */
  --cream:      #fbf5e9;
  --shadow:     rgba(28,24,20,.28);

  --serif:  'Lora', Georgia, serif;
  --display:'Oswald', 'Arial Narrow', sans-serif;
  --fancy:  'Playfair Display', Georgia, serif;

  --maxw: 1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--serif);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:18px;
  /* subtiele papier/grain textuur */
  background-image:
    radial-gradient(rgba(28,24,20,.035) 1px, transparent 1px),
    radial-gradient(rgba(28,24,20,.025) 1px, transparent 1px);
  background-size:7px 7px, 11px 11px;
  background-position:0 0, 3px 4px;
}

/* ---- taalwissel: standaard NL, EN verborgen tot JS swap ----
   In het Engels (body[data-lang="en"]) draaien we het om. */
.lang-en,.lang-es{display:none}
body[data-lang="en"] .lang-en{display:inline}
body[data-lang="en"] .lang-nl{display:none}
body[data-lang="es"] .lang-es{display:inline}
body[data-lang="es"] .lang-nl{display:none}

img{max-width:100%;display:block}
a{color:var(--rust-dark);text-decoration:none}
a:hover{color:var(--rust)}

h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.08;
  letter-spacing:.5px;text-transform:uppercase;margin:0 0 .4em}
h1{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:700;letter-spacing:1px}
h2{font-size:clamp(1.7rem,3.4vw,2.7rem)}
h3{font-size:1.25rem;letter-spacing:1px}
p{margin:0 0 1.1em}

.container{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.section{padding:84px 0}
.section--tight{padding:54px 0}
.center{text-align:center}

.kicker{font-family:var(--display);text-transform:uppercase;letter-spacing:3px;
  font-size:.82rem;font-weight:600;color:var(--rust);display:inline-block;
  margin-bottom:14px}
.kicker::before{content:"";display:inline-block;width:34px;height:2px;
  background:var(--ochre);vertical-align:middle;margin-right:12px}

.lead{font-size:1.22rem;font-style:italic;color:var(--ink-soft);max-width:60ch}

/* =========================  TOP BAR  ========================= */
.topbar{background:var(--ink);color:var(--paper-3);font-family:var(--display);
  letter-spacing:1.5px;text-transform:uppercase;font-size:.72rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;
  min-height:38px;gap:14px;flex-wrap:wrap}
.topbar a{color:var(--paper-3)}
.topbar a:hover{color:var(--ochre)}
.lang-toggle button{background:none;border:1px solid rgba(244,234,215,.35);
  color:var(--paper-3);font-family:var(--display);letter-spacing:1.5px;
  font-size:.72rem;padding:3px 10px;cursor:pointer;text-transform:uppercase}
.lang-toggle button.active{background:var(--rust);border-color:var(--rust);
  color:var(--cream)}

/* =========================  HEADER / NAV  ========================= */
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,234,215,.96);
  border-bottom:3px solid var(--ink);backdrop-filter:blur(4px)}
.nav{display:flex;align-items:center;justify-content:space-between;
  padding:14px 26px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--display);font-weight:700;font-size:1.5rem;
  letter-spacing:2px;text-transform:uppercase;color:var(--ink)}
.brand .sub{font-family:var(--serif);font-style:italic;font-size:.78rem;
  letter-spacing:.5px;color:var(--rust-dark);margin-top:3px}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--display);text-transform:uppercase;letter-spacing:1.5px;
  font-size:.86rem;font-weight:500;color:var(--ink);padding:4px 0;
  border-bottom:2px solid transparent}
.nav-links a:hover,.nav-links a.active{color:var(--rust);border-bottom-color:var(--ochre)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:26px;height:3px;background:var(--ink);margin:5px 0}

/* =========================  HERO  ========================= */
.hero{position:relative;color:var(--cream);
  background:linear-gradient(rgba(20,17,14,.62),rgba(20,17,14,.74)),
    url('gettyimages-117880312-612x612.jpg') center 28%/cover no-repeat;
  border-bottom:5px solid var(--rust)}
.hero .container{padding-top:110px;padding-bottom:110px;max-width:920px}
.hero .kicker{color:var(--ochre)}
.hero .kicker::before{background:var(--ochre)}
.hero h1{color:var(--cream);text-shadow:0 2px 18px rgba(0,0,0,.5)}
.hero .lead{color:#f1e4cd;font-size:1.32rem;max-width:54ch}
.hero .tag{font-family:var(--fancy);font-style:italic;font-size:1.5rem;
  color:var(--ochre);margin-bottom:8px}

/* =========================  BUTTONS  ========================= */
.btn{display:inline-block;font-family:var(--display);text-transform:uppercase;
  letter-spacing:2px;font-weight:600;font-size:.88rem;padding:14px 30px;
  border:2px solid var(--rust);background:var(--rust);color:var(--cream);
  cursor:pointer;transition:.18s;box-shadow:4px 4px 0 var(--ink)}
.btn:hover{background:var(--rust-dark);color:var(--cream);transform:translate(-2px,-2px);
  box-shadow:6px 6px 0 var(--ink)}
.btn--ghost{background:transparent;color:var(--cream);border-color:var(--cream);
  box-shadow:4px 4px 0 rgba(0,0,0,.4)}
.btn--ghost:hover{background:var(--cream);color:var(--ink)}
.btn--dark{background:var(--ink);border-color:var(--ink);box-shadow:4px 4px 0 var(--rust)}
.btn-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:26px}

/* =========================  STAT STRIP  ========================= */
.stats{background:var(--ink);color:var(--paper);border-bottom:5px solid var(--ochre)}
.stats .container{display:flex;flex-wrap:wrap;justify-content:space-around;
  text-align:center;padding:46px 26px;gap:26px}
.stat .num{font-family:var(--display);font-weight:700;font-size:3rem;color:var(--ochre);
  line-height:1}
.stat .lbl{font-family:var(--display);text-transform:uppercase;letter-spacing:2px;
  font-size:.8rem;color:var(--paper-3);margin-top:6px}

/* =========================  CARDS / GRID  ========================= */
.grid{display:grid;gap:26px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-auto{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}

.card{background:var(--cream);border:2px solid var(--ink);padding:30px 28px;
  box-shadow:6px 6px 0 var(--shadow);transition:.18s}
.card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--shadow)}
.card .ic{font-family:var(--display);font-weight:700;color:var(--rust);
  font-size:.8rem;letter-spacing:2px;text-transform:uppercase}
.card h3{margin-top:8px;color:var(--ink)}
.card p{font-size:.98rem;margin-bottom:0;color:var(--ink-soft)}

/* split image + text */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.split .media{min-height:420px;background-size:cover;background-position:center;
  filter:sepia(.32) contrast(1.03)}
.split .body{padding:64px 56px}
.split--paper .body{background:var(--paper-2)}
.split--ink{background:var(--ink);color:var(--paper)}
.split--ink h2,.split--ink .kicker{color:var(--ochre)}
.split--ink .kicker::before{background:var(--ochre)}

.band{background:var(--oxblood);color:var(--cream);border-top:4px solid var(--ochre);
  border-bottom:4px solid var(--ochre)}
.band h2{color:var(--cream)}
.band .lead{color:#f0dcc9}

/* quote */
.quote{font-family:var(--fancy);font-style:italic;font-size:clamp(1.5rem,3vw,2.3rem);
  line-height:1.4;max-width:24ch;text-transform:none}
.quote--big{max-width:30ch}

/* =========================  TEAM  ========================= */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px}
.member{background:var(--cream);border:2px solid var(--ink);
  box-shadow:6px 6px 0 var(--shadow);transition:.18s;overflow:hidden}
.member:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--shadow)}
.member .ph{height:300px;background:var(--paper-3);display:flex;align-items:center;
  justify-content:center;border-bottom:2px solid var(--ink);overflow:hidden;
  background-image:linear-gradient(135deg,var(--paper-3),var(--paper-2))}
.member .ph span{font-family:var(--display);font-weight:700;font-size:3.4rem;
  color:var(--rust);letter-spacing:2px}
.member .ph.has-photo{background:var(--ink)}
.member .ph img{width:100%;height:100%;object-fit:cover;
  filter:sepia(.14) contrast(1.03);transition:.3s}
.member:hover .ph img{filter:sepia(0) contrast(1.03)}
.member .info{padding:22px 22px 26px}
.member h3{margin-bottom:2px;color:var(--ink);font-size:1.15rem}
.member .role{font-family:var(--display);text-transform:uppercase;letter-spacing:1.5px;
  font-size:.74rem;color:var(--rust);font-weight:600}
.member .spec{font-size:.94rem;color:var(--ink-soft);margin-top:10px;margin-bottom:0;
  font-style:italic}

/* =========================  VIDEO  ========================= */
.video-wrap{max-width:900px;margin:0 auto}
.video-frame{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;
  border:3px solid var(--ink);box-shadow:8px 8px 0 var(--shadow);background:#000}
.video-frame iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.video-cap{font-family:var(--display);text-transform:uppercase;letter-spacing:2px;
  font-size:.82rem;color:var(--rust);margin-top:16px}

/* =========================  CONTACT  ========================= */
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:start}
.info-block{font-size:1.05rem}
.info-block .row{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--paper-3)}
.info-block .row .k{font-family:var(--display);text-transform:uppercase;
  letter-spacing:1.5px;font-size:.74rem;color:var(--rust);min-width:90px;padding-top:3px}
form label{display:block;font-family:var(--display);text-transform:uppercase;
  letter-spacing:1.5px;font-size:.74rem;color:var(--ink);margin:16px 0 6px}
form input,form textarea{width:100%;padding:12px 14px;border:2px solid var(--ink);
  background:var(--cream);font-family:var(--serif);font-size:1rem;color:var(--ink)}
form textarea{min-height:130px;resize:vertical}

.map-embed{width:100%;height:300px;border:3px solid var(--ink);
  box-shadow:8px 8px 0 var(--shadow);filter:sepia(.18) contrast(1.02)}

/* =========================  TERMS / VOORWAARDEN  ========================= */
.legal-note{background:var(--paper-2);border-left:5px solid var(--rust);
  padding:18px 22px;margin:0 auto 34px;max-width:820px;font-size:.98rem;
  font-style:italic;color:var(--ink-soft)}
.terms{max-width:820px;margin:0 auto;padding-left:26px;counter-reset:none}
.terms li{margin-bottom:18px;padding-left:8px;font-size:1.02rem;line-height:1.65}
.terms li::marker{font-family:var(--display);font-weight:700;color:var(--rust)}
.terms-meta{max-width:820px;margin:30px auto 0;font-size:.92rem;color:var(--ink-soft)}
.dl-row{display:flex;gap:16px;flex-wrap:wrap;max-width:820px;margin:6px auto 0}

/* =========================  FOOTER  ========================= */
.site-footer{background:var(--ink);color:var(--paper-3);padding:56px 0 26px;
  border-top:5px solid var(--rust)}
.site-footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
.site-footer h4{color:var(--ochre);font-size:.95rem;letter-spacing:2px}
.site-footer a{color:var(--paper-3)}
.site-footer a:hover{color:var(--ochre)}
.site-footer .brand .name{color:var(--cream)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:8px 0;font-size:.95rem}
.footer-bottom{border-top:1px solid rgba(244,234,215,.18);margin-top:40px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  font-family:var(--display);text-transform:uppercase;letter-spacing:1.5px;
  font-size:.72rem;color:#9b8f7c}

/* =========================  RESPONSIVE  ========================= */
@media(max-width:900px){
  /* backdrop-filter op een ouder maakt position:fixed kinderen relatief aan die
     ouder i.p.v. het scherm — daarom hier uitschakelen zodat het menu klopt */
  .site-header{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-links{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;
    height:100vh;height:100dvh;background:var(--ink);
    flex-direction:column;justify-content:flex-start;align-items:center;
    gap:22px;margin:0;
    padding:calc(env(safe-area-inset-top) + 84px) 24px calc(env(safe-area-inset-bottom) + 40px);
    transform:translateX(100%);transition:transform .25s;z-index:60;
    overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{color:var(--cream);font-size:1.25rem}
  .nav-toggle{display:block;z-index:70}
  body.nav-open .nav-toggle span{background:var(--cream)}
  body.nav-open{overflow:hidden}
  .split{grid-template-columns:1fr}
  .split .media{min-height:280px}
  .split .body{padding:48px 32px}
  .contact-grid{grid-template-columns:1fr}
  .site-footer .cols{grid-template-columns:1fr;gap:28px}
  .grid-2,.grid-3{grid-template-columns:1fr}
}
