/* personaltrainerinamstelveen.nl
   Info- en doorverwijssite. Eigen huisstijl: ink + energiek oranje, met kleurcodering per bedrijf.
   Type: Bricolage Grotesque (display) + Hanken Grotesk (body) */

:root{
  --paper:#FBFBF9;
  --paper-2:#F3EFE8;
  --ink:#18222D;
  --ink-2:#26333F;
  --ink-soft:#5A6470;
  --accent:#E8542B;
  --accent-deep:#C8431F;
  --accent-soft:#FBE3D8;
  --line:#E7E2D8;
  --c1:#E8542B; /* YourHealth */
  --c2:#C13E73; /* LET'S DO IT */
  --c3:#157A6E; /* Jouw Personal Trainer aan Huis */
  --maxw:1140px;
  --r:16px;
  --r-lg:26px;
  --shadow:0 20px 44px -26px rgba(24,34,45,.5);
  --shadow-sm:0 8px 20px -14px rgba(24,34,45,.45);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  font-size:18px;line-height:1.62;-webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{font-family:"Bricolage Grotesque","Hanken Grotesk",sans-serif;font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:0 0 .5em;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.6vw,3.9rem)}
h2{font-size:clamp(1.8rem,3.8vw,2.6rem)}
h3{font-size:clamp(1.2rem,2.2vw,1.5rem)}
p{margin:0 0 1.1em}
a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px}
a:hover{color:var(--ink)}
img{max-width:100%;display:block}
strong{font-weight:700}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:6px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:760px;margin-left:auto;margin-right:auto}

.eyebrow{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-deep);margin:0 0 1rem}
.eyebrow svg{width:16px;height:16px}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,251,249,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;max-width:var(--maxw);margin:0 auto;padding:13px 24px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.12rem;letter-spacing:-.02em;line-height:1.05}
.brand:hover{color:var(--ink)}
.brand img{width:38px;height:38px;border-radius:10px}
.brand span small{display:block;font-family:"Hanken Grotesk",sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.04em;color:var(--ink-soft)}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:600;font-size:.97rem;color:var(--ink);text-decoration:none;padding:9px 14px;border-radius:10px;transition:background .2s var(--ease)}
.nav-links a:hover{background:var(--paper-2)}
.nav-links a[aria-current="page"]{background:var(--ink);color:var(--paper)}
.nav-cta{background:var(--accent)!important;color:#fff!important}
.nav-cta:hover{background:var(--accent-deep)!important}
.nav-toggle{display:none;background:none;border:1.5px solid var(--line);border-radius:10px;padding:8px 10px;cursor:pointer;color:var(--ink)}
.nav-toggle svg{width:22px;height:22px;display:block}
@media (max-width:880px){
  .nav-toggle{display:inline-flex}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;background:var(--paper);border-bottom:1px solid var(--line);padding:10px 16px 18px;box-shadow:var(--shadow);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 14px}
}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:1rem;text-decoration:none;padding:14px 24px;border-radius:12px;border:2px solid transparent;cursor:pointer;transition:transform .15s var(--ease),background .2s var(--ease),color .2s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-deep);color:#fff}
.btn-dark{background:var(--ink);color:var(--paper)}
.btn-dark:hover{background:var(--ink-2);color:var(--paper)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--paper-2);color:var(--ink)}

/* hero */
.hero{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:#22303F;opacity:.6}
.hero-inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:84px 24px 90px}
.hero .eyebrow{color:#FF7A55}
.hero h1{color:#fff;max-width:16ch}
.hero h1 em{font-style:normal;color:var(--accent);}
.hero .lead{font-size:1.22rem;color:#C3CCD6;max-width:52ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero-meta{display:flex;flex-wrap:wrap;gap:8px 26px;margin-top:34px;color:#AEB7C2;font-size:.95rem}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta svg{width:18px;height:18px;color:var(--accent)}

/* sections */
.section{padding:72px 0}
.section.tight{padding:48px 0}
.section.sand{background:var(--paper-2)}
.section.ink{background:var(--ink);color:var(--paper)}
.section.ink h2,.section.ink h3{color:#fff}
.section.ink p{color:#C3CCD6}
.section-head{max-width:64ch;margin-bottom:40px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head p{color:var(--ink-soft);font-size:1.08rem}

/* criteria grid */
.criteria{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media (max-width:760px){.criteria{grid-template-columns:1fr}}
.crit{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-sm)}
.crit .ic{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);color:var(--accent-deep);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.crit .ic svg{width:24px;height:24px}
.crit h3{margin:0 0 6px}
.crit p{margin:0;color:var(--ink-soft);font-size:.98rem}

/* company cards */
.providers{display:grid;gap:26px}
.provider{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:1fr;border-top:6px solid var(--cc,var(--accent))}
.provider .pinner{display:grid;grid-template-columns:1.55fr 1fr;gap:0}
@media (max-width:820px){.provider .pinner{grid-template-columns:1fr}}
.provider .pmain{padding:32px 34px}
.provider .pside{background:var(--paper-2);padding:32px 30px;display:flex;flex-direction:column;justify-content:center;gap:14px;border-left:1px solid var(--line)}
@media (max-width:820px){.provider .pside{border-left:0;border-top:1px solid var(--line)}}
.badge{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;font-weight:700;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--cc,var(--accent));padding:6px 12px;border-radius:999px;margin-bottom:14px}
.badge svg{width:14px;height:14px}
.provider .logo-slot{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.55rem;letter-spacing:-.02em;color:var(--ink);margin:0 0 4px}
.provider .tagline{color:var(--ink-soft);font-size:.96rem;margin:0 0 16px}
.usp{list-style:none;margin:0 0 8px;padding:0;display:grid;gap:10px}
.usp li{display:flex;gap:11px;align-items:flex-start;font-size:1rem}
.usp li svg{flex:0 0 auto;width:20px;height:20px;color:var(--cc,var(--accent));margin-top:3px}
.pside .for-who{font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.pside .for-text{font-size:1.02rem;margin:0}
.pside .links{display:flex;flex-direction:column;gap:10px;margin-top:6px}

/* steps */
.steps{counter-reset:step;display:grid;gap:16px}
.step{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px}
.step::before{counter-increment:step;content:counter(step);font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.1rem;width:40px;height:40px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center}
.step h3{margin:2px 0 5px;font-size:1.18rem}
.step p{margin:0;color:var(--ink-soft);font-size:.98rem}

/* table */
.tbl{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.tbl th,.tbl td{text-align:left;padding:15px 18px;border-bottom:1px solid var(--line);font-size:1rem}
.tbl th{background:var(--paper-2);font-family:"Bricolage Grotesque",sans-serif;font-size:.95rem}
.tbl tr:last-child td{border-bottom:0}
.tbl td:first-child{font-weight:600}

/* faq */
.faq{margin-top:8px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;font-family:"Bricolage Grotesque",sans-serif;font-weight:600;font-size:1.12rem;padding:18px 0;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-weight:700;color:var(--accent);font-size:1.5rem;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq details p{margin:0 0 18px;color:var(--ink-soft)}

/* cta band */
.cta-band{background:var(--accent);color:#fff;border-radius:var(--r-lg);padding:54px 40px;text-align:center}
.cta-band h2{color:#fff;max-width:22ch;margin:0 auto .4em}
.cta-band p{color:#FFE6DC;max-width:54ch;margin:0 auto 26px}
.cta-band .btn-dark{background:var(--ink)}

/* prose */
.article{padding:54px 0 72px}
.crumbs{font-size:.85rem;color:var(--ink-soft);padding:22px 0 0}
.crumbs a{color:var(--ink-soft)}
.prose h2{margin-top:1.7em}
.prose h3{margin-top:1.3em}
.prose ul{padding-left:1.15em}
.prose li{margin-bottom:.5em}
.prose .lead{font-size:1.2rem;color:var(--ink-soft)}
.prose .updated{font-size:.85rem;color:var(--ink-soft)}
.callout{background:var(--accent-soft);border-radius:var(--r);padding:22px 26px;margin:28px 0}
.callout p:last-child{margin-bottom:0}

/* contact */
.contact-card{background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:46px 40px;text-align:center;max-width:620px;margin:0 auto}
.contact-card h1{color:#fff}
.contact-card p{color:#C3CCD6}
.contact-card .mail{font-family:"Bricolage Grotesque",sans-serif;font-size:clamp(1.4rem,4vw,2rem);color:#fff;text-decoration:none;display:inline-block;margin:6px 0 24px;border-bottom:3px solid var(--accent)}

/* footer */
.site-footer{background:var(--ink);color:#AEB7C2;padding:56px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px}
.site-footer .brand{color:#fff}
.site-footer .brand span small{color:#8A95A1}
.site-footer p{color:#9AA4B0;font-size:.95rem;max-width:38ch}
.site-footer h4{font-family:"Hanken Grotesk",sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#7E8893;margin:4px 0 14px}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.site-footer a{color:#C3CCD6;text-decoration:none;font-size:.96rem}
.site-footer a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.footer-bottom{display:flex;flex-wrap:wrap;gap:8px 24px;justify-content:space-between;border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:20px;font-size:.85rem;color:#7E8893}
.footer-bottom a{color:#7E8893}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr;gap:26px}}

/* ---- lokale toevoegingen: hero met foto, vlag, galerij, soorten, contact ---- */
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:50px;align-items:center}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:32px}}
.hero-media{position:relative}
.hero-media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px;box-shadow:var(--shadow);display:block}
@media(max-width:880px){.hero-media{max-width:420px;margin:0 auto}}
.flagchip{display:inline-block;width:24px;height:16px;border-radius:3px;overflow:hidden;vertical-align:middle;box-shadow:0 0 0 1px rgba(255,255,255,.3)}
.flagchip img{width:100%;height:100%;display:block}
.flagchip.sm{width:20px;height:13px}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:14px;display:block}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}

.types{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.types{grid-template-columns:1fr}}

.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.contact-cards{grid-template-columns:1fr}}
.ccard{background:var(--paper);border:1px solid var(--line);border-top:5px solid var(--cc,var(--accent));border-radius:var(--r);padding:26px 24px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-sm)}
.ccard h3{margin:0 0 4px;font-size:1.2rem}
.ccard .tag{font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cc,var(--accent));margin-bottom:6px}
.ccard .row{display:flex;align-items:center;gap:10px;font-size:1rem;text-decoration:none;color:var(--ink)}
.ccard .row svg{width:18px;height:18px;color:var(--cc,var(--accent));flex:0 0 auto}
.ccard a.row:hover{color:var(--cc,var(--accent))}
.ccard .ext{margin-top:8px}
.ccard .ext a{font-weight:700;font-size:.92rem;color:var(--cc,var(--accent))}

.prov-banner{margin:0 0 28px}
.prov-banner img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:18px;display:block}

.footer-flag{display:inline-flex;align-items:center;gap:8px;color:#9AA4B0;font-size:.9rem;margin-top:14px}
.footer-flag .flagchip{box-shadow:0 0 0 1px rgba(255,255,255,.18)}

/* inline pijl in tekstlinks (o.a. contactkaarten) op tekstgrootte houden */
.ccard .ext a svg, .prose p a svg, .callout a svg{width:16px;height:16px;vertical-align:middle}
