/* =========================================================
   Stichting 12 inch-race — terugblikwebsite
   Gedeelde stylesheet voor index.html en media.html
   ========================================================= */

:root{
  --paper:#FBF6EC;
  --paper-2:#F2E8D6;
  --ink:#16263A;
  --ink-soft:#5A6472;
  --accent:#EC5024;
  --accent-deep:#C73C16;
  --gold:#F2B43A;
  --midnight:#10243B;
  --midnight-2:#193455;
  --line:rgba(22,38,58,.12);
  --maxw:1180px;
  --display:"Bricolage Grotesque",Georgia,serif;
  --body:"Spline Sans",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--body);font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--accent);color:var(--paper)}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- HEADER ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(251,246,236,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand img{height:42px;width:auto;display:block}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{font-weight:600;font-size:15px;color:var(--ink-soft);transition:color .2s;position:relative;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--accent);transition:width .25s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.3s}
@media(max-width:900px){
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;background:var(--paper);flex-direction:column;padding:20px 28px;gap:18px;border-bottom:1px solid var(--line);align-items:flex-start}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero.compact{min-height:46vh}
.hero .bg{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;transform:scale(1.05);animation:slowzoom 18s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,36,59,.55) 0%,rgba(16,36,59,.78) 75%,var(--paper) 100%)}
.hero .inner{position:relative;z-index:2;padding:110px 0 90px;width:100%}
.hero.compact .inner{padding:70px 0 60px}
.hero .logo{height:74px;width:auto;margin-bottom:34px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.3))}
.hero .eyebrow{font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:13px;color:var(--gold);margin-bottom:20px}
.hero h1{font-family:var(--display);font-weight:800;line-height:.98;letter-spacing:-.02em;font-size:clamp(44px,8vw,104px);max-width:15ch;text-shadow:0 4px 30px rgba(0,0,0,.25)}
.hero.compact h1{font-size:clamp(38px,6vw,72px)}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero .lede{margin-top:26px;max-width:52ch;font-size:clamp(18px,2.2vw,21px);color:rgba(255,255,255,.9)}
.hero .span-years{display:inline-flex;align-items:center;gap:16px;margin-top:36px;font-family:var(--display);font-weight:700;font-size:20px}
.hero .span-years .dash{height:2px;width:54px;background:rgba(255,255,255,.7)}

/* ---------- STAT BAND ---------- */
.bignum{max-width:var(--maxw);margin:-1px auto 0;display:flex;flex-wrap:wrap;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.bignum .cell{flex:1 1 180px;padding:26px 24px;border-right:1px solid var(--line)}
.bignum .cell:last-child{border-right:none}
.bignum .n{font-family:var(--display);font-weight:800;font-size:clamp(26px,4vw,46px);line-height:1;letter-spacing:-.02em}
.bignum .n .euro{color:var(--accent)}
.bignum .l{margin-top:10px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}

/* ---------- SECTIES ---------- */
section{position:relative;z-index:2}
.pad{padding:84px 0}
.sec-head{display:flex;align-items:baseline;gap:18px;margin-bottom:40px}
.sec-head .num{font-family:var(--display);font-weight:700;color:var(--accent);font-size:20px}
.sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,4.5vw,50px);letter-spacing:-.02em;line-height:1.02}
.sec-lead{max-width:62ch;color:var(--ink-soft);font-size:19px;margin-bottom:44px}
.alt{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

.twocol{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.twocol p{margin-bottom:18px;font-size:19px}
.twocol .figure{aspect-ratio:4/3;border-radius:14px;overflow:hidden;box-shadow:0 24px 50px -24px rgba(22,38,58,.5)}
.twocol .figure.tilt-l{transform:rotate(-1.4deg)}
.twocol .figure.tilt-r{transform:rotate(1.2deg)}
.twocol .figure img{width:100%;height:100%;object-fit:cover;display:block}
.twocol .figure.video{aspect-ratio:16/9;position:relative;background:var(--midnight)}
.twocol .figure.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:820px){.twocol{grid-template-columns:1fr;gap:34px}}

.feature-list{list-style:none;margin-top:8px}
.feature-list li{padding:14px 0 14px 34px;position:relative;border-bottom:1px solid var(--line);font-size:17px}
.feature-list li::before{content:"";position:absolute;left:0;top:22px;width:16px;height:16px;border:3px solid var(--accent);border-radius:50%}
.feature-list li strong{display:block;font-family:var(--display);font-weight:700;font-size:19px}

/* ---------- GRAFIEK ---------- */
.chart{display:flex;align-items:flex-end;gap:clamp(4px,1vw,14px);height:340px;margin-top:10px;padding-bottom:2px;border-bottom:2px solid var(--ink)}
.bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;position:relative}
.bar .col{width:100%;background:linear-gradient(180deg,var(--accent),var(--accent-deep));border-radius:5px 5px 0 0;transform-origin:bottom;transition:transform .6s cubic-bezier(.22,.9,.35,1),filter .25s}
.bar.peak .col{background:linear-gradient(180deg,var(--gold),#D9912a)}
.bar.final .col{background:linear-gradient(180deg,var(--midnight-2),var(--midnight))}
.bar:hover .col{filter:brightness(1.08)}
.bar .amt{position:absolute;top:-26px;font-size:11px;font-weight:700;color:var(--ink);opacity:0;transition:opacity .2s;white-space:nowrap}
.bar:hover .amt{opacity:1}
.bar .yr{margin-top:10px;font-size:12px;font-weight:600;color:var(--ink-soft)}
.legend{display:flex;gap:24px;flex-wrap:wrap;margin-top:26px;font-size:14px;font-weight:600;color:var(--ink-soft)}
.legend span{display:inline-flex;align-items:center;gap:8px}
.legend i{width:14px;height:14px;border-radius:3px;display:inline-block}
@media(max-width:680px){.chart{height:260px}.bar .yr{font-size:10px}.bar:nth-child(even) .yr{visibility:hidden}}

/* ---------- DONKERE SECTIES ---------- */
.dark{background:var(--midnight);color:var(--paper)}
.dark .sec-head h2{color:var(--paper)}
.dark .sec-head .num{color:var(--gold)}
.dark .sec-lead{color:#C2CCD8}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:var(--midnight-2);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:28px;transition:transform .25s,border-color .25s}
.card:hover{transform:translateY(-6px);border-color:var(--gold)}
.card h3{font-family:var(--display);font-weight:700;font-size:22px;margin-bottom:10px}
.card .yrs{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.card p{font-size:15.5px;color:#BDC7D4;line-height:1.6}
@media(max-width:820px){.cards{grid-template-columns:1fr}}

/* ---------- QUOTE ---------- */
blockquote.pull{font-family:var(--display);font-weight:600;font-size:clamp(22px,3vw,30px);line-height:1.25;margin:0 0 22px;letter-spacing:-.01em}
blockquote.pull span{color:var(--accent)}
cite.src{font-style:normal;font-weight:700;font-size:15px;color:var(--ink-soft)}

/* ---------- SFEERFOTO'S / GALERIJ ---------- */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.photo-grid .ph{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;cursor:zoom-in;background:linear-gradient(135deg,var(--paper-2),#E4D6BC);transition:transform .25s,box-shadow .25s}
.photo-grid .ph:hover{transform:translateY(-4px);box-shadow:0 18px 38px -18px rgba(22,38,58,.45)}
.photo-grid .ph img{width:100%;height:100%;object-fit:cover;display:block}
.photo-grid .ph .cap{position:absolute;left:0;right:0;bottom:0;padding:26px 14px 12px;font-size:13px;font-weight:600;color:#fff;background:linear-gradient(180deg,transparent,rgba(16,36,59,.85));opacity:0;transition:opacity .25s}
.photo-grid .ph:hover .cap{opacity:1}
.photo-grid .ph.placeholder{display:flex;align-items:center;justify-content:center;cursor:default}
.photo-grid .ph.placeholder::after{content:"📷";font-size:34px;opacity:.45}

/* ---------- LIGHTBOX ---------- */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(16,36,59,.94);display:none;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:82vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox .lb-cap{position:absolute;bottom:28px;left:0;right:0;text-align:center;color:#fff;font-size:15px;font-weight:600}
.lightbox button{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;width:48px;height:48px;border-radius:50%;font-size:20px;cursor:pointer;transition:background .2s}
.lightbox button:hover{background:rgba(255,255,255,.22)}
.lightbox .lb-close{top:24px;right:24px}
.lightbox .lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lightbox .lb-next{right:24px;top:50%;transform:translateY(-50%)}

/* ---------- MEDIA-PAGINA ---------- */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:24px}
.media-item{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 14px 34px -22px rgba(22,38,58,.35)}
.media-item .frame{position:relative;aspect-ratio:16/9;background:var(--midnight);display:block}
.media-item .frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.media-item .frame.yt-fallback img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.media-item .frame.yt-fallback .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:46px;background:var(--accent);border-radius:12px;transition:background .2s}
.media-item .frame.yt-fallback .play::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-40%,-50%);border-style:solid;border-width:9px 0 9px 15px;border-color:transparent transparent transparent #fff}
.media-item .frame.yt-fallback:hover .play{background:var(--accent-deep)}
.media-item .meta{padding:16px 18px}
.media-item .meta h3{font-family:var(--display);font-weight:700;font-size:18px}
.media-item .meta p{font-size:14px;color:var(--ink-soft);margin-top:4px}
.track-list{display:grid;gap:20px;max-width:760px}
.track{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 14px 34px -22px rgba(22,38,58,.35)}
.track iframe{display:block;width:100%;border:0}
.empty-state{border:2px dashed var(--line);border-radius:14px;padding:38px;text-align:center;color:var(--ink-soft);font-size:16px;max-width:760px}
.empty-state strong{font-family:var(--display);display:block;font-size:20px;color:var(--ink);margin-bottom:6px}

/* ---------- AFSLUITING ---------- */
.einde{text-align:center}
.einde h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,5vw,56px);letter-spacing:-.02em;max-width:18ch;margin:0 auto 24px;line-height:1.04}
.einde p{max-width:58ch;margin:0 auto;color:#C2CCD8;font-size:19px}
.einde .hr{width:60px;height:3px;background:var(--gold);margin:34px auto 0;border-radius:3px}

/* ---------- KNOPPEN ---------- */
/* ---------- SPONSORS ---------- */
.sponsor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px}
.sponsor-grid .sponsor{display:flex;align-items:center;justify-content:center;min-height:112px;padding:22px 20px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 14px 34px -26px rgba(22,38,58,.35)}
.sponsor-grid .sponsor img{max-width:100%;max-height:64px;width:auto;height:auto;object-fit:contain}
.sponsor-grid a.sponsor{transition:transform .2s,box-shadow .2s}
.sponsor-grid a.sponsor:hover{transform:translateY(-3px);box-shadow:0 20px 40px -24px rgba(22,38,58,.45)}
.sponsor-names{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:0 36px;list-style:none}
.sponsor-names li{padding:11px 0;border-bottom:1px solid var(--line);font-size:16px}
.sponsor-names a{color:var(--ink);font-weight:500;transition:color .2s}
.sponsor-names a:hover{color:var(--accent)}
.sponsor-names span{color:var(--ink-soft)}

.btn{display:inline-block;font-weight:700;font-size:15px;padding:14px 26px;border-radius:999px;background:var(--accent);color:#fff;transition:transform .2s,background .2s}
.btn:hover{background:var(--accent-deep);transform:translateY(-2px)}
.btn.ghost{background:transparent;border:2px solid var(--ink);color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}

/* ---------- FOOTER ---------- */
footer.site{background:var(--ink);color:#D9DFE7;padding:64px 0 40px}
.foot-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand img{height:46px;margin-bottom:14px}
.foot-brand p{font-size:15px;color:#9AA6B4;max-width:42ch}
.foot-links{display:flex;gap:60px;flex-wrap:wrap}
.foot-links h4{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:#9AA6B4;margin-bottom:14px}
.foot-links a{display:block;font-size:15px;color:#D9DFE7;margin-bottom:9px;transition:color .2s}
.foot-links a:hover{color:var(--gold)}
.foot-bot{padding-top:26px;font-size:13px;color:#9AA6B4;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- ANIMATIE ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero .bg{animation:none;transform:none}
}
