/* =======================================================================
   PROJECT: Fysiotherapie Kampherbeek
   FILE   : assets/css/style.css
   VERSION: v1.1.7 (2025-10-20)
   NOTE   : Desktop-duo-scroll ongewijzigd; mobiele native scrollbar verborgen
            zodat alléén de custom mobiele edge-scrollbar zichtbaar is.
   CHANGE : [2025-10-20] (19) Hide native page scrollbar on mobile (≤800px).
   PREV   : v1.1.6 — mobiele edge-scrollbar toegevoegd.
   ======================================================================== */

/* >>> Basisset/Global START */
:root {
  --gap: 24px;
  --gap-sm: 12px;
  --tile-bg: rgba(0,0,0,0.10);
  --tile-bg-hover: rgba(0,0,0,0.18);
  --tile-bg-active: rgba(0,0,0,0.30);
  --tile-bg-dark: rgba(0,0,0,0.15);
  --tile-bg-darker: rgba(0,0,0,0.225);
  --left-col: 275px;
  --btn-h: 36px;

  /* Edge scrollbar kleuren */
  --edge-thumb: #52486C;
  --edge-thumb-hover: #40385A;
  --edge-thumb-active: #322C48;
  --edge-track-bg: transparent;
  --edge-track-shadow: 0 0 0 1px rgba(255,255,255,0.12), 0 4px 16px rgba(0,0,0,0.18);
}
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
html { min-width: 360px; }

body{
  margin: 0;
  padding: var(--gap);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Arial, sans-serif;
  line-height: 1.5;
}

.menu-wrap { display: none; }
/* <<< Basisset/Global END */


/* >>> Component: Mainpage container */
.main-page { border-radius: 28px; overflow: hidden; }

/* >>> Font instellingen */
h2 { font-weight:700; font-size: clamp(22px, 3vw, 46px); line-height:1.2; margin:0 0 40px; }
h3 { font-weight:700; font-size: clamp(20px, calc(3vw - 2px), 24px); line-height:1.2; margin:0 0 10px; }
p  { font-weight:500; font-size: clamp(18px, calc(3vw - 4px), 20px); line-height:1.55; margin:0 0 1em; }
h2.h2-light { font-size: clamp(22px, 3vw, 40px); line-height:1.2; font-weight:600; margin:0 0 12px; }
.brand-title {
  font-weight:800; font-size: clamp(27px, 4.8vw, 54px); line-height:1.1; letter-spacing:.2px;
  color:#fff; text-shadow: 0 2px 6px rgba(0,0,0,0.35); margin:0; cursor:pointer;
}

/* >>> Lists (… ongewijzigd) */
.page-wrap ul { list-style:none; padding:0; margin:0; display:grid; row-gap:16px; font-size:clamp(16px,2.4vw,20px); font-weight:700; }
.hang{ position:relative; display:block; padding-left:1.6em; line-height:1.5; }
.hang::before{ content:"•"; position:absolute; left:0; width:1.6em; text-align:left; }
.hang--dash::before{ content:"–"; } .hang--none::before{ content:""; }
ul[data-bullets="none"]{ list-style:none; padding-left:0; }

.page-wrap ul.list-small{ list-style:disc; padding-left:1.2em; margin:0 0 1em; display:block; font-size:clamp(14px,2vw,16px); font-weight:500; line-height:1.45; text-align:left; }
.page-wrap ul[data-align="left"]{ text-align:left; } .page-wrap ul[data-align="center"]{ text-align:center; } .page-wrap ul[data-align="right"]{ text-align:right; }
.page-wrap ul.list-default{ list-style:disc; padding-left:1.2em; margin:0 0 1em; display:block; font-size:clamp(18px,calc(3vw - 4px),20px); font-weight:500; line-height:1.45; }
.page-wrap ul.list-medium{ list-style:disc; padding-left:1.2em; margin:0 0 1em; display:block; font-size:clamp(20px,2.4vw,22px); font-weight:500; line-height:1.45; }
.page-wrap ul.list-large{ list-style:disc; padding-left:1.2em; margin:0 0 1em; display:block; font-size:clamp(22px,calc(3.4vw - 2px),24px); font-weight:500; line-height:1.45; }
.page-wrap ul.list-xl{ list-style:disc; padding-left:1.2em; margin:0 0 1em; display:block; font-size:clamp(24px,3.8vw,26px); font-weight:500; line-height:1.45; }
.page-wrap ul.list-xxl{ list-style:disc; padding-left:1.2em; margin:0 0 1em; display:block; font-size:clamp(26px,4.2vw,30px); font-weight:500; line-height:1.45; }
.page-wrap ul[data-bullets="disc"]{ list-style:disc; padding-left:1.2em; }
.page-wrap ul[data-bullets="circle"]{ list-style:circle; padding-left:1.2em; }
.page-wrap ul[data-bullets="square"]{ list-style:square; padding-left:1.2em; }
.page-wrap ul[data-bullets="dash"], .page-wrap ul[data-bullets="check"]{ list-style:none; padding-left:1.2em; }
.page-wrap ul[data-bullets="dash"] li::before{ content:"–"; position:absolute; left:-1.2em; }
.page-wrap ul[data-bullets="check"] li::before{ content:"✔"; position:absolute; left:-1.2em; }

@media (min-width: 701px){
  .page-wrap p:not([data-align]), .page-wrap p[data-align="justify"]{
    text-align:justify; text-align-last:left; hyphens:auto; -webkit-hyphens:auto; overflow-wrap:anywhere;
  }
}
@media (max-width: 800px){
  .page-wrap p:not([data-align]), .page-wrap p[data-align="justify"]{ text-align:left; }
}
.page-wrap ul.centered-bullets { list-style-position: inside; }

/* >>> Content links */
.page-wrap a.ext-link{ text-decoration:underline; font-weight:600; color:#fff; font-family:inherit; display:inline; }
.page-wrap a.ext-link[data-align]{ display:block; }
.page-wrap a.ext-link[data-align="left"]{ text-align:left; }
.page-wrap a.ext-link[data-align="center"]{ text-align:center; margin-inline:auto; }
.page-wrap a.ext-link[data-align="right"]{ text-align:right; }
.page-wrap a.ext-link[data-italic="true"]{ font-style:italic; }
.page-wrap a.ext-link[data-color="brand"]{ color:#DCD6F7; }
.page-wrap a.ext-link[data-color="white"]{ color:#FFFFFF; }
.page-wrap a.ext-link[data-color="black"]{ color:#000000; }
.page-wrap a.ext-link[data-color="muted"]{ color:#E0E0E0; }
.page-wrap a.ext-link[data-color="accent"]{ color:#FFD166; }
.page-wrap a.ext-link[data-font="system"]{ font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Arial, sans-serif; }
.page-wrap a.ext-link[data-font="segoe"]{ font-family:"Segoe UI", Arial, sans-serif; }
.page-wrap a.ext-link[data-font="roboto"]{ font-family: Roboto, "Helvetica Neue", Arial, sans-serif; }
.page-wrap a.ext-link[data-font="arial"]{ font-family: Arial, Helvetica, sans-serif; }
.page-wrap a.ext-link[data-font="verdana"]{ font-family: Verdana, Geneva, sans-serif; }
.page-wrap a.ext-link[data-font="trebuchet"]{ font-family: "Trebuchet MS", Arial, sans-serif; }
.page-wrap a.ext-link[data-font="georgia"]{ font-family: Georgia, "Times New Roman", serif; }
.page-wrap a.ext-link[data-font="times"]{ font-family: "Times New Roman", Times, serif; }

/* >>> Content host (.page-wrap) */
.page-wrap{
  width:100%; color:#fff; text-shadow:0 2px 6px rgba(0,0,0,0.35);
  max-width:900px; margin:0 auto; text-align:center;
  padding:40px 30px 30px 30px;
}
.page-wrap .table-wrap{ width:100%; max-width:900px; margin:0 auto var(--gap-sm); overflow-x:auto; }
.page-wrap .table-card{
  position:relative; z-index:1; background:rgba(0,0,0,0.18);
  border:1px solid rgba(255,255,255,0.18); border-radius:10px; box-shadow:0 6px 18px rgba(0,0,0,0.12); overflow:hidden;
}
.page-wrap .table-card .table-caption{
  text-align:center; font-weight:700; letter-spacing:.4px; padding:10px 12px;
  background:rgba(255,255,255,0.10); border-bottom:1px solid rgba(255,255,255,0.18);
}

/* >>> PRIJSLIJST: typografie als <p>, indeling ongewijzigd */
.page-wrap table.pricing-table{
  width:100%;
  border-collapse:collapse;
  table-layout:auto; /* laat kolom 2 vrij schalen */
  font-family: inherit;
  font-size: clamp(18px, calc(3vw - 4px), 20px);
  line-height: 1.55;  /* context (thead/algemeen) */
  font-weight: 500;
}

/* Kolombreedtes — NIET wijzigen */
.page-wrap table.pricing-table th:nth-child(1),
.page-wrap table.pricing-table td:nth-child(1){ width:50px; }
.page-wrap table.pricing-table th:nth-child(3),
.page-wrap table.pricing-table td:nth-child(3){ width:100px; }

/* Titels/kolomkoppen — vet en ongewijzigde achtergrond/padding */
.page-wrap table.pricing-table thead th{
  background:rgba(255,255,255,0.08);
  white-space:nowrap;
  padding:10px 10px;
  border-bottom:none;
  font-weight:700;
}
.page-wrap table.pricing-table thead th.th-canbreak{ white-space:normal; }

/* Uitlijning per kolom (ongewijzigd) */
.page-wrap table.pricing-table thead th:nth-child(1),
.page-wrap table.pricing-table tbody td:nth-child(1){ text-align:center; }
.page-wrap table.pricing-table thead th:nth-child(2),
.page-wrap table.pricing-table tbody td:nth-child(2){ text-align:left; }
.page-wrap table.pricing-table thead th:nth-child(3),
.page-wrap table.pricing-table tbody td:nth-child(3){ text-align:center; }

/* Body-cellen — compacter (zichtbaar verschil) */
.page-wrap table.pricing-table tbody td{
  padding:3px 10px;
  border-bottom:none;
  font-weight:500;
  line-height: 1.15;   /* duidelijk compacter */
}

/* Extra ruimte boven eerste dataregel blijft bestaan */
.page-wrap table.pricing-table tbody tr:first-child td{ padding-top:12px; }

/* Spacer-rij (zorgt voor lucht na blokken) */
.page-wrap table.pricing-table tr.spacer td{ padding:4px 0; }

/* >>> Main button */
.main-button { height:150px; padding:16px; text-align:center; flex:0 0 150px; }

/* >>> Badges */
.versie-info{ position:fixed; left:10px; bottom:10px; font-size:12px; color:#000; background:rgba(255,255,255,0.8); padding:4px 8px; border-radius:6px; box-shadow:0 2px 6px rgba(0,0,0,0.1) }
.dbg{ position:fixed; right:10px; bottom:10px; max-width:90vw; padding:8px 10px; font-size:12px; border:1px solid #e5e5e5; border-radius:10px; background:#fafafa; box-shadow:0 6px 22px rgba(0,0,0,0.08) }
.dbg .ok{ color:#207227 } .dbg .err{ color:#b02a37 }

/* >>> Layout */
.wrap { max-width:1200px; margin:0 auto; width:100%; }
.board{ display:grid; grid-auto-rows:max-content; row-gap:var(--gap); }
.row-first{
  display:grid; grid-template-columns: var(--left-col) 1fr; column-gap:var(--gap);
  align-items:stretch; width:100%; position:relative; z-index:0;
}
.col-left{ display:grid; grid-auto-rows:max-content; row-gap:var(--gap); }
.col-right{ display:flex; flex-direction:column; gap:var(--gap); min-height:0; }

/* >>> Tegels */
.tile{
  background:var(--tile-bg); border-radius:12px; box-shadow:0 6px 20px rgba(0,0,0,0.15);
  overflow:hidden; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700;
  width:100%; transition: background-color 160ms ease;
}
.h150{ height:150px; }
.tile img{ width:100%; height:100%; object-fit:contain; object-position:center; display:block; }

/* >>> Knoppen */
.btn-tile{ height: var(--btn-h); }
.buttons-list{ display:grid; row-gap:var(--gap); }
.nav-link{ display:flex; align-items:center; justify-content:center; width:100%; height:100%; color:#fff; text-decoration:none; }
.tile.link:hover{ background:var(--tile-bg-hover); }
.tile.link.active{ background:var(--tile-bg-active); }
.siteinfo{ height: var(--btn-h); font-weight:600; }
.buttons-list .nav-link{ font-family:"Segoe UI", Arial, sans-serif; font-size:16px; font-weight:700; letter-spacing:.2px; line-height:1.2; }
.menu-dropdown .nav-link{ font-family:"Segoe UI", Arial, sans-serif; font-size:16px; font-weight:600; letter-spacing:.2px; line-height:1.2; }

/* >>> Main-page (inhoudstegel) */
.main-page{
  flex: 0 0 auto; min-height:auto; padding:16px;
  display:flex; align-items:flex-start; justify-content:center;
  position:relative; z-index:0; overflow:visible !important;
}

/* >>> Uitlijning helpers */
h2[data-align="left"],h3[data-align="left"],p[data-align="left"],.h2-light[data-align="left"]{ text-align:left; }
h2[data-align="center"],h3[data-align="center"],p[data-align="center"],.h2-light[data-align="center"]{ text-align:center; }
h2[data-align="right"],h3[data-align="right"],p[data-align="right"],.h2-light[data-align="right"]{ text-align:right; }

/* >>> Utilities */
.full-bleed-sep{ display:block; height:1px; background:rgba(255,255,255,0.18); margin:8px -24px 14px; width:auto; }
.page-wrap .links-ctx .card p{ text-align:center; }

/* === Wallpaper fixed === */
html, body { margin:0; min-height:100svh; background:transparent !important; }
body::before{
  content:""; position:fixed; top:0; left:0; width:100vw; height:100vh;
  background:url("../img/wallpaper.jpg") center / cover no-repeat; pointer-events:none; z-index:0; will-change:transform;
}
body > *{ position:relative; z-index:1; background:transparent; background-image:none; }
.wallpaper, .page-bg, .body-bg, main, .container, #app, #root{
  background:transparent !important; background-image:none !important; background-attachment:scroll !important;
}
html, body { transform:none !important; }

/* === Desktop kolom-scrollers (≥801px) === */
@media (min-width: 801px){
  body { overflow:hidden; }
  .row-first { height: calc(100svh - 2 * var(--gap)); }

  .col-left,
  .col-right{
    height: calc(100svh - 2 * var(--gap));
    overflow-x:hidden; overflow-y:auto;
  }

  /* Linker kolom: scrollbar verbergen, wel scrollbaar */
  .col-left{ scrollbar-width:none; -ms-overflow-style:none; }
  .col-left::-webkit-scrollbar{ width:0; height:0; }

  /* Rechter kolom: native scrollbar verbergen (we gebruiken edge-scrollbar) */
  .col-right{ scrollbar-width:none; -ms-overflow-style:none; }
  .col-right::-webkit-scrollbar{ width:0; height:0; }

  .col-left{ position:relative; top:0; align-self:stretch; }
  .col-right{ display:flex; flex-direction:column; gap:var(--gap); min-height:0; }
}

/* === Mobiel (≤800px): OUDE pull-down menu (ongewijzigd) === */
@media (max-width: 800px) {

  .row-first { grid-template-columns: 1fr; row-gap: var(--gap); }

  .col-left, .col-right { display: contents; }

  .main-button { grid-row: 1; }
  .oefening-sm { grid-row: 2; }
  .menu-wrap   { grid-row: 3; }
  .main-page   { grid-row: 4; }

  :root { --menu-w: 275px; --menu-btn-h: var(--btn-h); }

  .buttons-list { display: none !important; }

  .menu-wrap { display: block; position: relative; width: 100%; }

  .menu-btn {
    width: calc(var(--menu-w) + 16px);
    height: var(--menu-btn-h);
    margin: 0 auto;
    cursor: pointer;
    user-select: none;
    display: flex; align-items: center; justify-content: center;
    position: relative; z-index: 11;
  }

  .menu-wrap::before{
    content: "";
    position: absolute; left: 50%; transform: translateX(-50%); top: 0;
    width: calc(var(--menu-w) + 16px);
    height: var(--menu-btn-h);
    background: #52486C;
    border: 1px solid #52486C;
    border-radius: 12px;
    z-index: 9;
  }
  .menu-wrap.open::before{
    height: calc(
      (1 * var(--menu-btn-h)) + (1 * var(--gap-sm)) +
      (10 * var(--menu-btn-h)) + (9 * var(--gap-sm)) + 16px
    );
  }

  .menu-hitbox{
    position: absolute; left: 50%; transform: translateX(-50%); top: 0;
    width: calc(var(--menu-w) + 16px);
    height: var(--menu-btn-h);
    z-index: 12; pointer-events: none;
  }
  .menu-wrap.open .menu-hitbox{
    height: calc(
      (1 * var(--menu-btn-h)) + (1 * var(--gap-sm)) +
      (10 * var(--menu-btn-h)) + (9 * var(--gap-sm)) + 16px
    );
  }

  .menu-dropdown{
    position: absolute; left: 50%; transform: translateX(-50%);
    top: calc(var(--menu-btn-h) + var(--gap-sm));
    width: var(--menu-w);
    display: grid; row-gap: var(--gap-sm);
    pointer-events: none; opacity: 0; transition: opacity 160ms ease;
    z-index: 10;
  }
  .menu-wrap.open .menu-dropdown{ opacity: 1; pointer-events: auto; }

  .menu-dropdown .btn-tile{
    height: var(--menu-btn-h);
    width: var(--menu-w);
    position: relative; z-index: 11;
  }

  .menu-wrap.open .menu-dropdown .tile{ background: var(--tile-bg-darker); }
  .menu-wrap.open .menu-dropdown .tile.link:hover{  background: var(--tile-bg-active); }
  .menu-wrap.open .menu-dropdown .tile.link.active{ background: rgba(0,0,0,0.34); }

  .main-button { height: 80px; padding: 8px; }
  .brand-title { font-size: clamp(34px, 6vw, 68px); }
  .oefening-sm { height: 100px !important; width: 100% !important; }

  /* Verberg native vertical page scrollbar — toon alléén custom mobile edge bar */
  html, body { scrollbar-width: none; -ms-overflow-style: none; }
  html::-webkit-scrollbar, body::-webkit-scrollbar { width:0; height:0; }
}

/* === Edge Scrollbar (basis) — stijl geldt voor beide varianten === */
.edge-scrollbar{
  position: fixed;
  right: 0;
  top: var(--gap);
  height: calc(100svh - 2 * var(--gap));
  width: 16px;
  z-index: 5;
  pointer-events: none;
}
.edge-scrollbar__track{
  position: absolute; inset: 0;
  background: var(--edge-track-bg); backdrop-filter: none;
  box-shadow: none; border-radius: 8px; pointer-events: auto;
}
.edge-scrollbar__thumb{
  position: absolute; left: 3px; width: 10px; height: 60px;
  border-radius: 8px; background: var(--edge-thumb);
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  cursor: grab; transition: background-color 120ms ease;
  touch-action: none;
}
.edge-scrollbar__thumb:hover{ background: var(--edge-thumb-hover); }
.edge-scrollbar__thumb.is-active{ background: var(--edge-thumb-active); cursor: grabbing; }
.edge-scrollbar__thumb.is-disabled{ opacity: .35; cursor: not-allowed; }

/* === Variants: desktop vs mobile (zichtbaarheid + maten) === */
.edge-scrollbar--desktop { display:block; }
.edge-scrollbar--mobile  { display:none; }

/* Mobile override — toon mobiele variant en eigen afmetingen */
@media (max-width: 800px){
  .edge-scrollbar--desktop { display:none !important; }
  .edge-scrollbar--mobile  {
    display:block !important;
    right: 0;
    top: 8px;
    height: calc(100svh - 16px);
    width: 18px;
    z-index: 999;
    pointer-events: none;
  }
  .edge-scrollbar--mobile .edge-scrollbar__track{
    border-radius: 10px;
    pointer-events: auto;
  }
  .edge-scrollbar--mobile .edge-scrollbar__thumb{
    left: 3px; width: 12px; border-radius: 10px;
  }
}
