/* ===== Over WattIQ — unified canvas (matches home/situaties/oplossingen) ============ */

/* Single page-level canvas. All sections share it — only border-tops separate them. */
[data-page="over"]{
  background:var(--deep-black);
  color:var(--off-white);
  --display:'Archivo','IBM Plex Sans',Arial,sans-serif;
}
body.light [data-page="over"]{
  background:var(--paper);
  color:var(--paper-ink);
}

/* Subtle ambient glow once across the whole page (like situaties-final) */
[data-page="over"]::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(900px 700px at 82% 18%, rgba(255,107,43,.12), transparent 60%),
    radial-gradient(700px 600px at 12% 70%, rgba(255,107,43,.06), transparent 65%);
}

/* All over sections share the same shell rules */
[data-page="over"] section.over-sec{
  position:relative; z-index:1;
  padding:clamp(72px,9vw,128px) 0;
  border-top:1px solid var(--line);
  background:transparent;
}
[data-page="over"] section.over-sec:first-of-type{
  border-top:none;
  padding-top:clamp(96px,12vw,160px);
}

/* Unified wrapper — same as global .wrap (1320px / 32px) */
[data-page="over"] .over-sec > .wrap{
  position:relative; z-index:1;
  max-width:1320px;
  margin:0 auto;
  padding:0 32px;
}

/* ===== HERO ===== */
.over-hero{ text-align:center; }
.over-hero .badge{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 18px;
  border:1px solid rgba(255,107,43,.4);
  border-radius:999px;
  font-family:var(--mono);
  font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--power-orange);
  background:rgba(255,107,43,.06);
  margin-bottom:36px;
}
.over-hero .badge .pulse{
  width:6px; height:6px; border-radius:99px;
  background:var(--power-orange);
  box-shadow:0 0 0 4px rgba(255,107,43,.18);
}
.over-hero h1{
  font-family:var(--display); font-weight:900;
  letter-spacing:-.035em; line-height:.92;
  font-size:clamp(40px, 5.4vw, 88px);
  margin:0 auto;
  color:var(--off-white);
  max-width:18ch;
}
body.light .over-hero h1{ color:var(--paper-ink); }
.over-hero h1 .o{ color:var(--power-orange); font-style:italic; }
.over-hero .lead{
  margin:32px auto 0;
  font-size:clamp(17px, 1.4vw, 20px);
  line-height:1.55;
  color:var(--muted);
  max-width:58ch;
}
.over-hero .pillars{
  margin:56px auto 0;
  display:grid; grid-template-columns:repeat(3,1fr);
  border:1px solid var(--line);
  border-radius:18px; overflow:hidden;
  background:rgba(26,20,9,.55);
  backdrop-filter:blur(8px);
  text-align:left;
  max-width:1080px;
}
body.light .over-hero .pillars{ background:rgba(255,255,255,.7); }
.over-hero .pillars .it{ padding:26px 28px; border-right:1px solid var(--line); }
.over-hero .pillars .it:last-child{ border-right:none; }
.over-hero .pillars .ix{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--power-orange); margin-bottom:14px;
}
.over-hero .pillars b{
  font-family:var(--display); font-weight:700;
  font-size:22px; letter-spacing:-.01em;
  display:block; margin-bottom:8px;
  color:var(--off-white);
}
body.light .over-hero .pillars b{ color:var(--paper-ink); }
.over-hero .pillars span{
  font-family:var(--mono); font-size:11.5px;
  color:var(--muted); line-height:1.5; display:block;
}
@media (max-width:900px){
  .over-hero .pillars{ grid-template-columns:1fr; }
  .over-hero .pillars .it{ border-right:none; border-bottom:1px solid var(--line); }
  .over-hero .pillars .it:last-child{ border-bottom:none; }
}

/* ===== MANIFESTO ===== */
.over-manifesto .eye,
.over-pijlers .head .eye,
.over-tijdlijn .head .eye,
.over-cijfers .head .eye,
.over-cta .cta-head .eye{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--power-orange);
  margin-bottom:18px;
  display:inline-flex; align-items:center; gap:12px;
}
.over-manifesto .eye .bar,
.over-pijlers .head .eye .bar,
.over-tijdlijn .head .eye .bar,
.over-cijfers .head .eye .bar,
.over-cta .cta-head .eye .bar{
  width:32px; height:1px; background:var(--power-orange);
}

.over-manifesto h2{
  font-family:var(--display); font-weight:800;
  letter-spacing:-.025em; line-height:.95;
  font-size:clamp(40px, 5.2vw, 84px);
  margin:0 0 32px;
  color:var(--off-white);
  max-width:22ch;
}
body.light .over-manifesto h2{ color:var(--paper-ink); }
.over-manifesto h2 .o{ color:var(--power-orange); }
.over-manifesto p{
  font-size:19px; line-height:1.55;
  color:var(--muted); max-width:56ch; margin:0 0 14px;
}
.over-manifesto .sig{
  margin-top:32px;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
  padding-top:18px;
  border-top:1px solid var(--line);
  max-width:56ch;
  display:flex; justify-content:space-between;
}
.over-manifesto .sig b{ color:var(--power-orange); font-weight:600; }

/* ===== PIJLERS ===== */
.over-pijlers .head{ margin-bottom:48px; }
.over-pijlers .head h2{
  font-family:var(--display); font-weight:800;
  letter-spacing:-.02em; line-height:1;
  font-size:clamp(36px,4.2vw,60px);
  margin:0; color:var(--off-white); max-width:24ch;
}
body.light .over-pijlers .head h2{ color:var(--paper-ink); }
.over-pijlers .pillar{
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px; align-items:center;
  padding:64px 0; border-top:1px solid var(--line);
}
.over-pijlers .pillar:nth-child(even){ direction:rtl; }
.over-pijlers .pillar:nth-child(even) > *{ direction:ltr; }
.over-pijlers .pillar .meta{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--power-orange); margin-bottom:16px;
}
.over-pijlers .pillar h3{
  font-family:var(--display); font-weight:900;
  letter-spacing:-.04em; line-height:.85;
  font-size:clamp(56px,7vw,120px);
  margin:0 0 24px; color:var(--off-white);
}
body.light .over-pijlers .pillar h3{ color:var(--paper-ink); }
.over-pijlers .pillar p{
  font-size:17px; line-height:1.55;
  color:var(--muted); margin:0 0 24px; max-width:48ch;
}
.over-pijlers .pillar .data{
  font-family:var(--mono); font-size:13.5px;
  color:var(--muted); line-height:1.95;
  margin-top:24px; padding-top:18px;
  border-top:1px solid var(--line);
}
.over-pijlers .pillar .data div span{
  color:var(--power-orange); font-weight:600; margin-right:4px;
}
.over-pijlers .ph{
  aspect-ratio:4/3;
  background:linear-gradient(135deg, var(--steel-dark), var(--deep-black));
  border:1px solid var(--line); border-radius:18px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); position:relative; overflow:hidden;
}
.over-pijlers .ph::before{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,107,43,.06) 0 2px, transparent 2px 18px),
    radial-gradient(600px 300px at 70% 80%, rgba(255,107,43,.12), transparent 70%);
}
body.light .over-pijlers .ph{
  background:linear-gradient(135deg, #efeadf, #e3dccc);
  border-color:rgba(0,0,0,.08);
}
body.light .over-pijlers .ph::before{
  background-image:
    repeating-linear-gradient(45deg, rgba(0,0,0,.05) 0 2px, transparent 2px 18px),
    radial-gradient(600px 300px at 70% 80%, rgba(255,107,43,.18), transparent 70%);
}
.over-pijlers .ph .meta{
  position:relative; z-index:1;
  padding:10px 18px;
  background:rgba(20,16,10,.55); backdrop-filter:blur(6px);
  border-radius:99px;
}
body.light .over-pijlers .ph .meta{
  background:rgba(253,248,242,.7); color:var(--paper-mute);
}
@media (max-width:900px){
  .over-pijlers .pillar{ grid-template-columns:1fr; gap:32px; padding:48px 0; }
  .over-pijlers .pillar:nth-child(even){ direction:ltr; }
}

/* ===== TIJDLIJN ===== */
.over-tijdlijn .head{ margin-bottom:48px; }
.over-tijdlijn .head h2{
  font-family:var(--display); font-weight:800;
  letter-spacing:-.02em; line-height:1;
  font-size:clamp(32px,3.8vw,52px);
  margin:0; color:var(--off-white);
}
body.light .over-tijdlijn .head h2{ color:var(--paper-ink); }
.over-tijdlijn .timeline{
  position:relative; max-width:820px;
  margin:0 auto; padding-left:48px;
}
.over-tijdlijn .timeline::before{
  content:""; position:absolute;
  left:14px; top:14px; bottom:14px;
  width:1px; background:var(--line);
}
.over-tijdlijn .timeline{
  max-width:1100px;
}
.over-tijdlijn .row{
  position:relative; padding:32px 0 40px;
  border-bottom:1px solid var(--line);
  display:grid;
  grid-template-columns:160px 1fr 140px;
  gap:32px; align-items:start;
}
.over-tijdlijn .row:last-child{ border-bottom:none; }
.over-tijdlijn .row::before{
  content:""; position:absolute;
  left:-41px; top:42px; width:14px; height:14px;
  border-radius:99px;
  background:var(--deep-black);
  border:2px solid var(--power-orange);
}
body.light .over-tijdlijn .row::before{ background:var(--paper); }
.over-tijdlijn .row.future::before{ border-color:var(--muted); }
.over-tijdlijn .row.now::before{
  background:var(--power-orange);
  box-shadow:0 0 0 4px rgba(255,107,43,.18);
}
.over-tijdlijn .row .yr{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; color:var(--power-orange);
  font-weight:600; text-transform:uppercase;
  display:flex; flex-direction:column; gap:8px;
  padding-top:6px;
}
.over-tijdlijn .row .yr b{
  font-family:var(--display); font-size:32px;
  letter-spacing:-.015em; font-weight:800;
  color:var(--off-white); margin:0;
  line-height:1;
}
body.light .over-tijdlijn .row .yr b{ color:var(--paper-ink); }
.over-tijdlijn .row .body h3{
  font-family:var(--display); font-weight:700;
  letter-spacing:-.015em; line-height:1.15;
  font-size:22px; margin:0 0 8px;
  color:var(--off-white);
}
body.light .over-tijdlijn .row .body h3{ color:var(--paper-ink); }
.over-tijdlijn .row .body p{
  font-size:15px; line-height:1.55;
  color:var(--muted); margin:0; max-width:48ch;
}
.over-tijdlijn .row .tag{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
  padding:6px 12px; border:1px solid var(--line); border-radius:99px;
  justify-self:end; white-space:nowrap;
  margin-top:8px;
}
.over-tijdlijn .row.now .tag{ color:var(--power-orange); border-color:var(--power-orange); }
@media (max-width:900px){
  .over-tijdlijn .row{
    grid-template-columns:1fr;
    gap:8px;
  }
  .over-tijdlijn .row .tag{ justify-self:start; }
}

/* ===== CIJFERS ===== */
.over-cijfers .head{ margin-bottom:56px; text-align:center; }
.over-cijfers .head .eye{ display:inline-flex; }
.over-cijfers .head h2{
  font-family:var(--display); font-weight:800;
  letter-spacing:-.02em; line-height:1.05;
  font-size:clamp(32px,3.8vw,52px);
  margin:0 auto; color:var(--off-white); max-width:24ch;
}
body.light .over-cijfers .head h2{ color:var(--paper-ink); }
.over-cijfers .grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
}
.over-cijfers .badge{
  position:relative;
  background:
    radial-gradient(circle at 50% 30%, rgba(255,107,43,.10), transparent 60%),
    var(--industrial-black);
  border:1px solid var(--line); border-radius:20px;
  padding:40px 28px; text-align:center;
  display:flex; flex-direction:column; gap:14px;
  min-height:260px; justify-content:center; overflow:hidden;
  transition:border-color .25s ease, transform .25s ease;
}
body.light .over-cijfers .badge{
  background:
    radial-gradient(circle at 50% 30%, rgba(255,107,43,.10), transparent 60%),
    #fff;
}
.over-cijfers .badge:hover{
  border-color:var(--power-orange); transform:translateY(-3px);
}
.over-cijfers .badge::before{
  content:""; position:absolute;
  top:0; left:50%; transform:translateX(-50%);
  width:60px; height:1px; background:var(--power-orange);
}
.over-cijfers .badge .ix{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--power-orange); font-weight:600;
}
.over-cijfers .badge .big{
  font-family:var(--display); font-weight:900;
  letter-spacing:-.04em; line-height:.85;
  font-size:clamp(56px,7vw,108px);
  color:var(--off-white); margin:0;
}
body.light .over-cijfers .badge .big{ color:var(--paper-ink); }
.over-cijfers .badge .big em{
  font-family:var(--mono); font-style:normal;
  font-size:.32em; font-weight:600; letter-spacing:0;
  margin-left:4px; color:var(--power-orange);
}
.over-cijfers .badge .lab{
  font-family:var(--display); font-weight:600;
  font-size:14.5px; letter-spacing:-.005em;
  color:var(--muted); max-width:18ch; margin:0 auto; line-height:1.4;
}
.over-cijfers .badge .stamp{
  margin-top:8px; font-family:var(--mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
  padding:6px 12px; border:1px solid var(--line);
  border-radius:99px; display:inline-block; align-self:center;
}
@media (max-width:1100px){ .over-cijfers .grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .over-cijfers .grid{ grid-template-columns:1fr; } }

/* ===== CTA — same canvas, contained in unified .wrap ===== */
.over-cta .cta-inner{
  max-width:1080px;
  margin:0 auto;
}
.over-cta .cta-head{
  display:grid; grid-template-columns:1fr auto;
  align-items:end; gap:32px;
  padding-bottom:56px;
  border-bottom:1px solid var(--line);
  margin-bottom:56px;
}
.over-cta .cta-head h2{
  font-family:var(--display); font-weight:900;
  letter-spacing:-.03em; line-height:.92;
  font-size:clamp(44px,5.6vw,88px);
  margin:0; color:var(--off-white); max-width:18ch;
}
body.light .over-cta .cta-head h2{ color:var(--paper-ink); }
.over-cta .cta-head h2 em{
  font-style:italic; font-weight:400;
  color:var(--power-orange);
  font-family:var(--serif, "Times New Roman"), serif;
}
.over-cta .cta-head .stamp{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
  padding:10px 16px; border:1px solid var(--line);
  border-radius:99px; white-space:nowrap;
  display:inline-flex; align-items:center; gap:10px;
}
.over-cta .cta-head .stamp .dot{
  width:6px; height:6px; border-radius:99px;
  background:var(--power-orange);
  box-shadow:0 0 0 4px rgba(255,107,43,.18);
}

.over-cta .cta-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
.over-cta .col{
  position:relative; overflow:hidden;
  border-radius:24px;
  padding:56px 48px 48px;
  display:flex; flex-direction:column;
  min-height:520px; cursor:pointer; text-decoration:none;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
}
.over-cta .col:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.6);
}
body.light .over-cta .col:hover{
  box-shadow:0 24px 60px -20px rgba(0,0,0,.18);
}
.over-cta .col.partner{
  background:var(--power-orange); color:var(--deep-black);
}
.over-cta .col.partner::before{
  content:""; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(20,16,10,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(20,16,10,.06) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 80% 20%, #000 30%, transparent 75%);
  pointer-events:none;
}
.over-cta .col.partner::after{
  content:""; position:absolute;
  right:-120px; top:-120px;
  width:380px; height:380px;
  border-radius:99px;
  border:1px solid rgba(20,16,10,.18); pointer-events:none;
}
.over-cta .col.contact{
  background:var(--industrial-black); color:var(--off-white);
  border:1px solid var(--line);
}
body.light .over-cta .col.contact{
  background:#fff; color:var(--paper-ink);
  border-color:rgba(0,0,0,.08);
}
.over-cta .col.contact::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(600px 300px at 90% 110%, rgba(255,107,43,.16), transparent 70%);
  pointer-events:none;
}
body.no-accent .over-cta .col.partner{
  background:var(--off-white); color:var(--deep-black);
}
body.light.no-accent .over-cta .col.partner{
  background:var(--deep-black); color:var(--off-white);
}
body.no-accent .over-cta .col.partner::after{ border-color:rgba(20,16,10,.12); }

.over-cta .col .top{
  position:relative; z-index:1;
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:20px; padding-bottom:36px;
  border-bottom:1px solid currentColor;
  margin-bottom:36px;
}
.over-cta .col.partner .top{ border-bottom-color:rgba(20,16,10,.2); }
.over-cta .col.contact .top{ border-bottom-color:var(--line); }
.over-cta .col .ix{
  font-family:var(--display); font-weight:900;
  letter-spacing:-.04em; line-height:.85;
  font-size:clamp(64px,7vw,108px);
}
.over-cta .col.partner .ix{ color:rgba(20,16,10,.85); }
.over-cta .col.contact .ix{ color:var(--off-white); }
body.light .over-cta .col.contact .ix{ color:var(--paper-ink); }
.over-cta .col .ix em{
  font-family:var(--mono); font-style:normal;
  font-size:.18em; font-weight:600; letter-spacing:.18em;
  vertical-align:top; display:inline-block;
  margin-left:8px; margin-top:14px; text-transform:uppercase;
}
.over-cta .col.partner .ix em{ color:rgba(20,16,10,.6); }
.over-cta .col.contact .ix em{ color:var(--power-orange); }
.over-cta .col .tag{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.22em; text-transform:uppercase;
  font-weight:600; padding:8px 14px;
  border-radius:99px; border:1px solid currentColor; white-space:nowrap;
}
.over-cta .col.partner .tag{
  border-color:rgba(20,16,10,.25); color:rgba(20,16,10,.7);
  background:rgba(20,16,10,.04);
}
.over-cta .col.contact .tag{ border-color:var(--line); color:var(--muted); }
.over-cta .col h3{
  position:relative; z-index:1;
  font-family:var(--display); font-weight:800;
  letter-spacing:-.025em; line-height:.95;
  font-size:clamp(32px,3.4vw,48px);
  margin:0 0 20px; max-width:16ch;
}
.over-cta .col p{
  position:relative; z-index:1;
  font-size:16px; line-height:1.55;
  margin:0; max-width:42ch;
}
.over-cta .col.partner p{ color:rgba(20,16,10,.78); }
.over-cta .col.contact p{ color:var(--muted); }
body.light .over-cta .col.contact p{ color:var(--paper-mute); }
.over-cta .col ul{
  position:relative; z-index:1;
  list-style:none; margin:24px 0 0; padding:0;
  font-family:var(--mono); font-size:12px;
  letter-spacing:.04em; line-height:1.95;
  display:grid; gap:4px;
}
.over-cta .col.partner ul{ color:rgba(20,16,10,.7); }
.over-cta .col.contact ul{ color:var(--muted); }
.over-cta .col ul li{ display:flex; align-items:center; gap:10px; }
.over-cta .col ul li::before{
  content:""; width:14px; height:1px;
  background:currentColor; opacity:.5; flex-shrink:0;
}
.over-cta .col .foot{
  position:relative; z-index:1;
  margin-top:auto; padding-top:36px;
  display:flex; align-items:center; justify-content:space-between;
  gap:20px;
}
.over-cta .col .arrow{
  font-family:var(--display); font-weight:700;
  font-size:clamp(20px,1.8vw,26px);
  letter-spacing:-.015em;
  display:inline-flex; align-items:center; gap:14px;
}
.over-cta .col .arrow .arr{
  width:48px; height:48px; border-radius:99px;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:18px; line-height:1;
  transition:transform .25s cubic-bezier(.2,.7,.2,1), background .2s ease;
}
.over-cta .col.partner .arrow .arr{ background:var(--deep-black); color:var(--power-orange); }
.over-cta .col.contact .arrow .arr{ background:var(--power-orange); color:var(--deep-black); }
body.no-accent .over-cta .col.contact .arrow .arr{ background:var(--off-white); color:var(--deep-black); }
body.light.no-accent .over-cta .col.contact .arrow .arr{ background:var(--deep-black); color:var(--off-white); }
.over-cta .col:hover .arrow .arr{ transform:translateX(8px) rotate(-8deg); }
.over-cta .col .sub{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase; text-align:right;
}
.over-cta .col.partner .sub{ color:rgba(20,16,10,.6); }
.over-cta .col.contact .sub{ color:var(--muted); }

.over-cta .cta-tail{
  margin-top:48px;
  padding-top:24px;
  border-top:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted);
}
.over-cta .cta-tail .left,
.over-cta .cta-tail .right{ display:flex; align-items:center; gap:10px; }
.over-cta .cta-tail .bar{ width:24px; height:1px; background:var(--line); }

@media (max-width:900px){
  .over-cta .cta-head{ grid-template-columns:1fr; }
  .over-cta .cta-grid{ grid-template-columns:1fr; }
  .over-cta .col{ min-height:auto; padding:48px 32px 36px; }
  .over-cta .col .ix{ font-size:72px; }
  .over-cta .cta-tail{ flex-direction:column; align-items:flex-start; gap:8px; }
}
