/* ===========================================================
   Hoeseltse Treinclub — sitebrede stijl (richting C: stationssfeer)
   Slate + salie + amber · Oswald / Public Sans / JetBrains Mono
   Toegankelijk: grote tekst, hoog contrast, duidelijke focus
   =========================================================== */

:root{
  --ink:#202a30;        /* donker leisteen */
  --ink-2:#11171b;      /* nog donkerder paneel */
  --ink-3:#161d22;
  --paper:#eceae4;      /* zacht wit */
  --paper-2:#dedbd1;    /* warmer zandwit */
  --sage:#5b8a72;
  --sage-2:#7fae93;
  --amber:#c6a24a;
  --line:#d4d0c6;
  --line-dark:#33424b;
  --card:#ffffff;
  --text:#222a2f;
  --muted:#5a666e;
  --muted-2:#9aa6ab;
  --radius:6px;
  --maxw:1120px;
  --pad:48px;
  --fs:18px;            /* basis lettergrootte (toggle past dit aan) */
}
html[data-textsize="large"]{ --fs:21px; }

*{ box-sizing:border-box; }
html{ font-size:var(--fs); scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--text);
  font-family:'Public Sans',system-ui,sans-serif;
  font-size:1rem; line-height:1.65; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ font-family:'Oswald',sans-serif; margin:0; line-height:1.06;
  text-transform:uppercase; letter-spacing:0.01em; color:var(--ink); font-weight:600; }
p{ margin:0 0 1rem; }
a{ color:var(--sage); }
img{ max-width:100%; display:block; }
.mono{ font-family:'JetBrains Mono',monospace; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }

/* focus visibility for keyboard users */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible{
  outline:3px solid var(--amber); outline-offset:2px; border-radius:3px;
}

/* skip link */
.skip{ position:absolute; left:-9999px; top:0; background:var(--amber); color:var(--ink);
  padding:12px 18px; font-weight:700; z-index:200; border-radius:0 0 6px 0; }
.skip:focus{ left:0; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; font-family:'Oswald',sans-serif;
  text-transform:uppercase; letter-spacing:0.04em; font-weight:500; font-size:1.05rem;
  padding:15px 28px; text-decoration:none; cursor:pointer; border:0; border-radius:4px;
  line-height:1; transition:transform .12s, background .15s, box-shadow .15s; }
.btn:hover{ transform:translateY(-2px); }
.btn-pri{ background:var(--amber); color:var(--ink); }
.btn-pri:hover{ box-shadow:0 8px 20px rgba(198,162,74,.35); }
.btn-sage{ background:var(--sage); color:#fff; }
.btn-sage:hover{ box-shadow:0 8px 20px rgba(91,138,114,.35); }
.btn-sec{ background:transparent; color:var(--ink); box-shadow:inset 0 0 0 2px var(--line); }
.btn-sec:hover{ box-shadow:inset 0 0 0 2px var(--sage); }
.btn-ghost{ background:transparent; color:#fff; box-shadow:inset 0 0 0 2px #4a565d; }
.btn-ghost:hover{ box-shadow:inset 0 0 0 2px var(--amber); }

/* ---------- top strip ---------- */
.strip{ background:var(--ink-2); color:#e9e6df; }
.strip .wrap{ display:flex; align-items:center; justify-content:space-between;
  min-height:42px; font-family:'JetBrains Mono',monospace; font-size:.78rem;
  letter-spacing:0.05em; color:var(--amber); padding-top:8px; padding-bottom:8px; }
.strip a{ color:var(--amber); text-decoration:none; }

/* ---------- header / nav ---------- */
.siteheader{ background:#fff; border-bottom:3px solid var(--ink); position:sticky; top:0; z-index:50; }
.siteheader .wrap{ display:flex; align-items:center; justify-content:space-between; min-height:80px; gap:20px; }
.brand{ display:flex; align-items:center; gap:14px; text-decoration:none; }
.roundel{ width:50px; height:50px; border-radius:50%; background:var(--ink);
  position:relative; display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.roundel::after{ content:""; position:absolute; left:-6px; right:-6px; top:50%; height:9px;
  transform:translateY(-50%); background:var(--amber); }
.roundel span{ position:relative; z-index:1; color:#fff; font-family:'Oswald',sans-serif; font-weight:700; font-size:.95rem; }
.brand b{ font-family:'Oswald',sans-serif; font-size:1.45rem; text-transform:uppercase;
  letter-spacing:0.02em; display:block; line-height:1; color:var(--ink); font-weight:600; }
.brand small{ font-family:'JetBrains Mono',monospace; font-size:.62rem; letter-spacing:0.18em; color:var(--sage); }

.nav{ display:flex; align-items:center; gap:26px; }
.nav a{ font-family:'Oswald',sans-serif; text-transform:uppercase; letter-spacing:0.04em;
  font-size:1.02rem; color:var(--ink); text-decoration:none; font-weight:500; padding:6px 2px;
  border-bottom:3px solid transparent; }
.nav a:hover{ color:var(--amber); }
.nav a[aria-current="page"]{ color:var(--sage); border-color:var(--sage); }

.headtools{ display:flex; align-items:center; gap:10px; }
.textsize{ display:flex; align-items:center; gap:7px; background:var(--paper-2); border-radius:999px; padding:5px 12px;
  font-family:'JetBrains Mono',monospace; font-size:.7rem; letter-spacing:0.06em; color:var(--muted); border:1px solid var(--line); }
.textsize button{ border:0; background:transparent; cursor:pointer; font-family:'Oswald',sans-serif;
  font-weight:600; color:var(--ink); line-height:1; padding:2px 4px; }
.textsize button.s{ font-size:.8rem; }
.textsize button.l{ font-size:1.05rem; }
.textsize button[aria-pressed="true"]{ color:var(--sage); }

.hamburger{ display:none; width:48px; height:48px; border:2px solid var(--line); border-radius:8px;
  background:#fff; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.hamburger span{ width:24px; height:3px; background:var(--ink); border-radius:2px; }

/* ---------- page header band ---------- */
.pagehead{ background:var(--ink); color:#fff; padding:56px 0 50px; position:relative; overflow:hidden; }
.pagehead::before{ content:""; position:absolute; left:0; right:0; bottom:0; height:9px;
  background:repeating-linear-gradient(90deg,var(--amber) 0 40px,transparent 40px 80px); opacity:.5; }
.pagehead .platform{ font-family:'JetBrains Mono',monospace; color:var(--amber); font-size:.82rem;
  letter-spacing:0.16em; text-transform:uppercase; margin-bottom:12px; }
.pagehead h1{ color:#fff; font-size:clamp(2.4rem,5vw,3.6rem); }
.pagehead p{ color:var(--muted-2); font-size:1.15rem; max-width:60ch; margin-top:14px; }

/* ---------- generic sections ---------- */
.section{ padding:72px 0; }
.section.tight{ padding:52px 0; }
.section.paper2{ background:var(--paper-2); }
.section.ink{ background:var(--ink-2); color:var(--paper); }
.eyebrow{ font-family:'JetBrains Mono',monospace; color:var(--sage); font-size:.8rem;
  letter-spacing:0.14em; text-transform:uppercase; margin-bottom:10px; }
.section.ink .eyebrow{ color:var(--amber); }
.section h2{ font-size:clamp(2rem,4vw,2.7rem); }
.section.ink h2{ color:#fff; }
.lead{ font-size:1.18rem; color:var(--muted); max-width:62ch; }
.section.ink .lead{ color:var(--muted-2); }

/* ---------- hero ---------- */
.hero{ background:var(--ink); color:var(--paper); overflow:hidden; }
.hero .wrap{ display:grid; grid-template-columns:1.05fr .95fr; gap:44px; align-items:center;
  padding-top:64px; padding-bottom:64px; }
.hero .platform{ font-family:'JetBrains Mono',monospace; color:var(--amber); font-size:.85rem;
  letter-spacing:0.16em; text-transform:uppercase; }
.hero h1{ color:#fff; font-size:clamp(2.6rem,5.4vw,4.4rem); margin:14px 0 18px; }
.hero h1 em{ color:var(--sage-2); font-style:normal; }
.hero p{ color:#b9c4c9; font-size:1.22rem; max-width:42ch; }
.hero .cta{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
.ticket{ background:#fff; border-radius:8px; padding:8px; box-shadow:0 20px 50px rgba(0,0,0,.4); }

/* ---------- placeholder ---------- */
.ph{ position:relative; width:100%; overflow:hidden; background:#dcdfda; border-radius:3px; }
.ph svg{ position:absolute; inset:0; width:100%; height:100%; }
.ph .lbl{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; padding:16px; }
.ph .lbl span{ font-family:'JetBrains Mono',monospace; font-size:.72rem; letter-spacing:0.04em;
  color:#5a6660; background:rgba(255,255,255,.8); padding:6px 12px; border-radius:4px;
  text-align:center; text-transform:uppercase; }

/* ---------- departure board (events) ---------- */
.board{ background:var(--ink-2); color:var(--paper); }
.board h2{ color:#fff; display:flex; align-items:center; gap:14px; }
.board h2::before{ content:"●"; color:var(--sage); font-size:.7em; }
.board .sub{ font-family:'JetBrains Mono',monospace; color:#7d8a8f; font-size:.82rem;
  margin:8px 0 28px; letter-spacing:0.04em; }
.depwrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
.deptable{ width:100%; border-collapse:collapse; background:var(--ink-3); border-radius:8px; overflow:hidden; min-width:620px; }
.deptable th{ font-family:'JetBrains Mono',monospace; text-transform:uppercase; font-size:.7rem;
  letter-spacing:0.14em; color:var(--amber); text-align:left; padding:14px 22px;
  background:#0c1115; border-bottom:1px solid #232c32; }
.deptable td{ padding:20px 22px; border-bottom:1px solid #232c32; color:#e9e6df; vertical-align:middle; }
.deptable tr:last-child td{ border-bottom:0; }
.flap{ font-family:'JetBrains Mono',monospace; font-weight:700; font-size:1.35rem; color:#fff;
  background:#0c1115; padding:8px 13px; border-radius:4px; display:inline-block; letter-spacing:0.06em; white-space:nowrap; }
.deptable .nm{ font-family:'Oswald',sans-serif; text-transform:uppercase; font-size:1.18rem; letter-spacing:0.02em; color:#fff; }
.deptable .loc{ color:var(--muted-2); font-size:.85rem; }
.status{ font-family:'JetBrains Mono',monospace; font-size:.72rem; letter-spacing:0.08em;
  padding:6px 12px; border-radius:4px; white-space:nowrap; display:inline-block; }
.st-on{ background:var(--sage); color:#fff; }
.st-soon{ background:#2a343a; color:var(--amber); }

/* ---------- ledger stats ---------- */
.ledger{ display:grid; grid-template-columns:repeat(3,1fr); border:1px solid var(--line);
  border-radius:var(--radius); overflow:hidden; }
.ledger > div{ padding:20px 22px; border-right:1px solid var(--line); }
.ledger > div:last-child{ border-right:0; }
.ledger b{ font-family:'Oswald',sans-serif; font-size:2.1rem; color:var(--ink); display:block; line-height:1; }
.ledger span{ font-family:'JetBrains Mono',monospace; font-size:.72rem; letter-spacing:0.06em;
  color:var(--muted); text-transform:uppercase; }

/* ---------- cards / grids ---------- */
.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.grid3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.split.narrow{ grid-template-columns:.9fr 1.1fr; }

.lc{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.lc .tabh{ display:flex; justify-content:space-between; align-items:center; padding:16px 22px; background:var(--ink); }
.lc .tabh h3{ color:#fff; font-size:1.25rem; }
.lc .tabh span{ font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--amber); letter-spacing:0.1em; }
.lc .body{ padding:20px 22px 24px; }
.lc .body p{ color:var(--muted); margin:0; }

/* gallery */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.gallery .ph{ border:1px solid var(--line); }

/* info cards */
.infocard{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px 28px; }
.infocard h3{ font-size:1.2rem; margin-bottom:10px; display:flex; align-items:center; gap:10px; }
.infocard .tag{ font-family:'JetBrains Mono',monospace; font-size:.66rem; color:var(--sage);
  letter-spacing:0.12em; text-transform:uppercase; }
.infocard p{ margin:0; color:var(--muted); }
.infocard a{ color:var(--sage); font-weight:600; }

/* timeline */
.timeline{ border-left:3px solid var(--line); margin-left:8px; padding-left:28px; display:flex; flex-direction:column; gap:30px; }
.tl-item{ position:relative; }
.tl-item::before{ content:""; position:absolute; left:-37px; top:4px; width:15px; height:15px;
  border-radius:50%; background:var(--sage); box-shadow:0 0 0 4px var(--paper); }
.tl-item .yr{ font-family:'JetBrains Mono',monospace; color:var(--amber); font-size:.9rem;
  letter-spacing:0.08em; font-weight:700; }
.tl-item h3{ font-size:1.3rem; margin:4px 0 6px; }
.tl-item p{ margin:0; color:var(--muted); }

/* sponsors */
.sponsors{ display:flex; flex-wrap:wrap; gap:18px; justify-content:center; align-items:center; }
.sponsor{ background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  width:200px; height:96px; display:flex; align-items:center; justify-content:center;
  font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--muted); letter-spacing:0.04em; text-align:center; padding:10px; }

/* ---------- forms ---------- */
.formcard{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:32px; }
.formtabs{ display:flex; gap:8px; margin-bottom:24px; flex-wrap:wrap; }
.formtab{ font-family:'Oswald',sans-serif; text-transform:uppercase; letter-spacing:0.03em;
  font-size:1rem; font-weight:500; padding:11px 20px; border-radius:6px; cursor:pointer;
  border:2px solid var(--line); background:#fff; color:var(--ink); }
.formtab[aria-selected="true"]{ background:var(--ink); color:#fff; border-color:var(--ink); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-family:'Oswald',sans-serif; text-transform:uppercase;
  letter-spacing:0.04em; font-size:.95rem; font-weight:500; color:var(--ink); margin-bottom:7px; }
.field .req{ color:var(--sage); }
.field input, .field select, .field textarea{ width:100%; font-family:'Public Sans',sans-serif;
  font-size:1.05rem; padding:14px 16px; border:2px solid var(--line); border-radius:6px;
  background:var(--paper); color:var(--text); }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--sage); background:#fff; }
.field textarea{ min-height:140px; resize:vertical; }
.field.err input, .field.err select, .field.err textarea{ border-color:#b3402f; background:#fbecea; }
.field .msg{ display:none; color:#b3402f; font-size:.9rem; margin-top:6px; font-weight:600; }
.field.err .msg{ display:block; }
.formrow{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.formnote{ font-size:.92rem; color:var(--muted); }
.formsuccess{ display:none; background:#eaf3ee; border:2px solid var(--sage); border-radius:var(--radius);
  padding:26px 28px; }
.formsuccess.show{ display:block; }
.formsuccess h3{ color:var(--sage); display:flex; align-items:center; gap:10px; }

/* map */
.map{ width:100%; height:380px; border:0; border-radius:var(--radius); filter:grayscale(.2) contrast(1.05); }
.mapframe{ border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }

/* ---------- footer ---------- */
.sitefooter{ background:var(--ink); color:#b9c4c9; padding:58px 0 30px; font-size:1rem; }
.sitefooter .cols{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; }
.sitefooter h4{ font-family:'JetBrains Mono',monospace; color:var(--amber); font-size:.72rem;
  letter-spacing:0.16em; text-transform:uppercase; margin:0 0 16px; }
.sitefooter a{ color:#b9c4c9; text-decoration:none; display:block; margin-bottom:9px; }
.sitefooter a:hover{ color:#fff; }
.sitefooter .big{ font-family:'Oswald',sans-serif; font-size:1.45rem; color:#fff;
  text-transform:uppercase; margin-bottom:10px; }
.sitefooter .copyr{ font-family:'JetBrains Mono',monospace; border-top:1px solid var(--line-dark);
  margin-top:38px; padding-top:20px; text-align:center; font-size:.72rem; color:#71828a; letter-spacing:0.06em; }

/* utility */
.center{ text-align:center; }
.mt0{ margin-top:0; }
.mt8{ margin-top:8px; } .mt16{ margin-top:16px; } .mt24{ margin-top:24px; } .mt32{ margin-top:32px; }
.maxc{ max-width:760px; margin-left:auto; margin-right:auto; }

/* ============== responsive ============== */
@media (max-width:900px){
  :root{ --pad:28px; }
  .hero .wrap{ grid-template-columns:1fr; gap:32px; padding-top:44px; padding-bottom:44px; }
  .split, .split.narrow{ grid-template-columns:1fr; gap:28px; }
  .grid3{ grid-template-columns:1fr 1fr; }
  .sitefooter .cols{ grid-template-columns:1fr 1fr; }
  .nav{ position:fixed; inset:0 0 0 auto; width:min(80vw,320px); background:#fff; flex-direction:column;
    align-items:flex-start; gap:4px; padding:90px 28px 28px; transform:translateX(105%);
    transition:transform .25s ease; box-shadow:-10px 0 40px rgba(0,0,0,.2); z-index:60; }
  .nav.open{ transform:translateX(0); }
  .nav a{ font-size:1.3rem; padding:12px 0; width:100%; border-bottom:1px solid var(--line); }
  .nav a[aria-current="page"]{ border-color:var(--sage); }
  .hamburger{ display:flex; }
  .navscrim{ position:fixed; inset:0; background:rgba(17,23,27,.45); z-index:55; opacity:0; pointer-events:none; transition:opacity .25s; }
  .navscrim.open{ opacity:1; pointer-events:auto; }
}
@media (max-width:560px){
  :root{ --pad:20px; }
  .grid2, .grid3, .gallery, .formrow{ grid-template-columns:1fr; }
  .ledger{ grid-template-columns:1fr 1fr; }
  .ledger > div:nth-child(2){ border-right:0; }
  .strip .wrap{ font-size:.68rem; }
  .strip .wrap span:last-child{ display:none; }
  .textsize{ display:none; }
  .hero .cta .btn{ width:100%; justify-content:center; }
}
