* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  background: #000;
  color: #fff;
}

a {
  color: inherit;
  text-decoration: none;
}

.black-section {
  background: #000;
  color: #fff;
}

.white-section {
  background: #f7f7f7;
  color: #000;
}

/* Header */

.site-header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 20;
  min-height: 58px;
}

.navbar {
  display: flex;
  justify-content: center;
  gap: 26px;
  padding-top: 16px;
  font-size: 11px;
  font-weight: 800;
}

.eyes {
  position: absolute;
  right: 58px;
  top: 16px;
  display: flex;
  gap: 5px;
}

.eyes span {
  width: 12px;
  height: 21px;
  background: #fff;
  border-radius: 50%;
  display: block;
  position: relative;
}

.eyes span::after {
  content: "";
  position: absolute;
  width: 5px;
  height: 7px;
  right: 1px;
  top: 7px;
  background: #000;
  border-radius: 50%;
}

/* Buttons */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-width: 118px;
  height: 31px;
  padding: 0 18px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
}

.light-btn,
.hero-btn {
  border: 1.5px solid #fff;
  color: #fff;
  background: transparent;
}

.dark-btn {
  border: 1.5px solid #000;
  color: #000;
  background: transparent;
}

/* Hero */

.hero {
  min-height: 656px;
  position: relative;
  padding: 155px 70px 0;
}

.hero-content {
  position: relative;
  min-height: 365px;
}

.hero h1 {
  margin: 0;
  font-size: clamp(58px, 12vw, 118px);
  line-height: 0.87;
  font-weight: 900;
  letter-spacing: -5px;
}

.hero-subtitle {
  margin: 8px 0 0;
  font-size: 30px;
  line-height: 1;
}

.small-text {
  margin: 6px 0 0;
  font-size: 12px;
}

.hero-btn {
  position: absolute;
  right: 12px;
  bottom: 65px;
}

.services-line {
  position: absolute;
  left: 70px;
  right: 70px;
  bottom: 18px;
  margin: 0;
  font-size: 24px;
  font-style: italic;
  white-space: nowrap;
}

/* Mijn werk */

.work {
  min-height: 514px;
  padding: 86px 84px 70px;
}

.section-inner {
  position: relative;
  max-width: 1060px;
  margin: 0 auto;
}

.work-heading h2 {
  margin: 0;
  font-size: 82px;
  line-height: 0.82;
  letter-spacing: -2px;
  font-weight: 400;
}

.work-heading h2 span,
.work-heading h2 strong {
  display: block;
}

.work-heading h2 strong {
  font-weight: 900;
}

.work-heading p {
  margin: 9px 0 0;
  font-size: 20px;
}

.work-btn {
  position: absolute;
  right: 10px;
  top: 155px;
}

.project-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 56px;
  margin-top: 148px;
}

.project-card {
  text-align: center;
}

.placeholder {
  width: 100%;
  aspect-ratio: 1 / 1;
  background:
    linear-gradient(to bottom right, transparent 49.5%, #999 50%, transparent 50.5%),
    linear-gradient(to top right, transparent 49.5%, #999 50%, transparent 50.5%),
    #b7b7b7;
  border: 1px solid #8d8d8d;
}

.project-card h3 {
  margin: 24px 0 0;
  font-size: 24px;
  line-height: 1.02;
  font-weight: 900;
}

/* Split sections */

.split-section {
  min-height: 340px;
  padding: 0 84px;
  position: relative;
}

.split-content {
  max-width: 1060px;
  height: 340px;
  margin: 0 auto;
  position: relative;
}

.split-title h2 {
  margin: 0;
  font-size: clamp(55px, 9vw, 82px);
  line-height: 0.95;
  font-weight: 400;
  letter-spacing: -2px;
}

.split-title h2 strong {
  font-weight: 900;
}

.split-title p {
  margin: 5px 0 0;
  font-size: 20px;
}

.right-title .split-title {
  position: absolute;
  right: 0;
  top: 92px;
  text-align: left;
}

.left-title .split-title {
  position: absolute;
  left: 0;
  top: 90px;
}


.left-btn {
  position: absolute;
  left: 28px;
  bottom: 94px;
}

.right-btn {
  position: absolute;
  right: 12px;
  bottom: 90px;
}

/* ===== Layout fixes voor grote schermen ===== */

.hero-content,
.section-inner,
.split-content {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.hero {
  overflow: hidden;
}

.services-line {
  left: 50%;
  right: auto;
  width: min(1200px, calc(100% - 140px));
  transform: translateX(-50%);
}

.hero-btn {
  right: 12px;
}
/* ===== Footer polish ===== */

.footer {
  background: #f7f7f7;
  color: #000;
  padding: 72px 70px 60px;
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 80px;
}

.footer-left h2 {
  margin: 0;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 0.9;
  font-weight: 900;
  letter-spacing: -1.5px;
}

.footer-tagline {
  margin: 8px 0 30px;
  font-size: 16px;
  font-weight: 800;
}

.contact-info {
  display: grid;
  gap: 4px;
}

.contact-info p,
.contact-info a {
  margin: 0;
  display: block;
  color: #000;
  font-size: 18px;
  line-height: 1.1;
  font-weight: 900;
}

.contact-info p:first-child {
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 800;
}

.footer-right {
  padding-top: 26px;
  min-width: 150px;
}

.footer-right p {
  margin: 0 0 22px;
  font-size: 14px;
  font-weight: 900;
}

.socials {
  display: flex;
  align-items: center;
  gap: 14px;
}

.social-icon {
  width: 42px;
  height: 42px;
  border-radius: 9px;
  background: #000;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 23px;
  font-weight: 900;
  line-height: 1;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.social-icon:hover {
  transform: translateY(-2px);
  opacity: 0.8;
}

/* Footer mobiel */
@media (max-width: 650px) {
  .footer {
    padding: 52px 22px;
  }

  .footer-inner {
    flex-direction: column;
    gap: 36px;
  }

  .footer-right {
    padding-top: 0;
  }

  .footer-left h2 {
    font-size: 38px;
  }

  .contact-info p,
  .contact-info a {
    font-size: 16px;
  }
}
/* ===== Sterke mobiele fix ===== */

html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

@media (max-width: 650px) {
  body {
    background: #000;
  }

  .site-header {
    position: relative;
    background: #000;
    width: 100%;
  }

  .navbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 18px;
    padding: 18px 20px 0;
    font-size: 11px;
  }

  .eyes {
    display: none;
  }

  .hero,
  .work,
  .split-section,
  .footer {
    width: 100%;
    max-width: 100%;
    padding-left: 36px;
    padding-right: 36px;
  }

  .hero {
    min-height: 610px;
    padding-top: 85px;
  }

  .hero-content {
    min-height: 390px;
    max-width: 100%;
  }

  .hero h1 {
    font-size: 64px;
    line-height: 0.9;
    letter-spacing: -2px;
    max-width: 310px;
  }

  .hero-subtitle {
    font-size: 30px;
    line-height: 0.95;
    max-width: 270px;
  }

  .small-text {
    font-size: 12px;
  }

  .hero-btn {
    position: absolute;
    left: 50%;
    right: auto;
    bottom: 95px;
    transform: translateX(-50%);
  }

  .services-line {
    left: 36px;
    right: 36px;
    bottom: 28px;
    width: auto;
    transform: none;
    white-space: normal;
    font-size: 23px;
    line-height: 1.25;
  }

  .work {
    padding-top: 72px;
    padding-bottom: 80px;
  }

  .section-inner {
    max-width: 100%;
    width: 100%;
  }

  .work-heading h2 {
    font-size: 66px;
    line-height: 0.82;
  }

  .work-heading p {
    font-size: 18px;
    margin-top: 10px;
  }

  .work-btn {
    position: static;
    margin-top: 16px;
  }

  .project-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 48px;
    margin-top: 70px;
    width: 100%;
  }

  .project-card {
    width: 100%;
    text-align: left;
  }

  .placeholder {
    width: 100%;
    max-width: 260px;
    aspect-ratio: 1 / 1;
    margin: 0;
  }

  .project-card h3 {
    font-size: 26px;
    margin-top: 18px;
  }

  .split-section {
    min-height: 360px;
  }

  .split-content {
    height: 360px;
    max-width: 100%;
    width: 100%;
  }

  .right-title .split-title,
  .left-title .split-title {
    position: absolute;
    left: 0;
    right: auto;
    top: 78px;
    text-align: left;
  }

  .split-title h2 {
    font-size: 54px;
    line-height: 0.9;
    letter-spacing: -1.5px;
    max-width: 300px;
  }

  .split-title p {
    font-size: 16px;
    line-height: 1.15;
    max-width: 260px;
  }

  .left-btn,
  .right-btn {
    left: 0;
    right: auto;
    bottom: 78px;
  }

  .footer {
    padding: 52px 36px;
  }

  .footer-inner {
    flex-direction: column;
    gap: 36px;
    max-width: 100%;
  }

  .footer-left h2 {
    font-size: 34px;
  }

  .footer-tagline {
    font-size: 15px;
  }

  .contact-info p,
  .contact-info a {
    font-size: 16px;
  }

  .footer-right {
    padding-top: 0;
  }
}

/* ===== Creaties pagina ===== */

.page-hero {
  min-height: 420px;
  padding: 150px 70px 80px;
}

.page-hero-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.page-hero h1 {
  margin: 0;
  font-size: clamp(70px, 12vw, 140px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -5px;
}

.page-hero p {
  margin: 18px 0 0;
  font-size: 24px;
  font-weight: 700;
}

.creations-page {
  padding: 90px 70px;
}

.creations-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: 90px;
}

.creation-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
}

.creation-item.reversed .creation-image {
  order: 2;
}

.creation-image {
  width: 100%;
  aspect-ratio: 1 / 0.75;
  background:
    linear-gradient(to bottom right, transparent 49.5%, #999 50%, transparent 50.5%),
    linear-gradient(to top right, transparent 49.5%, #999 50%, transparent 50.5%),
    #b7b7b7;
  border: 1px solid #8d8d8d;
}

.creation-text h2 {
  margin: 0;
  font-size: clamp(46px, 6vw, 78px);
  line-height: 0.9;
  font-weight: 900;
  letter-spacing: -2px;
}

.creation-text p {
  max-width: 430px;
  margin: 18px 0 22px;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 700;
}

/* Mobiel creaties pagina */
@media (max-width: 650px) {
  .page-hero {
    min-height: 360px;
    padding: 95px 36px 70px;
  }

  .page-hero h1 {
    font-size: 64px;
    letter-spacing: -2px;
  }

  .page-hero p {
    font-size: 19px;
  }

  .creations-page {
    padding: 70px 36px;
  }

  .creations-inner {
    gap: 70px;
  }

  .creation-item {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .creation-item.reversed .creation-image {
    order: 0;
  }

  .creation-text h2 {
    font-size: 46px;
  }

  .creation-text p {
    font-size: 16px;
  }
}

/* ===== Creaties hero kleiner maken ===== */

.page-hero {
  min-height: 340px;
  padding: 115px 70px 65px;
}

.page-hero h1 {
  font-size: clamp(58px, 9vw, 118px);
  line-height: 0.87;
  letter-spacing: -4px;
}

.page-hero p {
  margin-top: 12px;
  font-size: 22px;
}

@media (max-width: 650px) {
  .page-hero {
    min-height: 300px;
    padding: 85px 36px 55px;
  }

  .page-hero h1 {
    font-size: 58px;
    line-height: 0.9;
    letter-spacing: -2px;
  }

  .page-hero p {
    font-size: 18px;
  }
}
/* ===== Wie ben ik pagina ===== */

.about-page-hero h1 {
  max-width: 980px;
}

.about-intro {
  padding: 95px 70px;
}

.about-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.about-intro .about-inner {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 80px;
  align-items: start;
}

.about-big-text h2 {
  margin: 0;
  font-size: clamp(58px, 8vw, 105px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.about-copy p {
  margin: 0 0 22px;
  font-size: 23px;
  line-height: 1.2;
  font-weight: 800;
  max-width: 560px;
}

.about-block {
  padding: 95px 70px;
}

.about-split {
  display: grid;
  grid-template-columns: 1fr 0.8fr;
  gap: 80px;
  align-items: center;
}

.about-split h2 {
  margin: 0 0 22px;
  font-size: clamp(54px, 7vw, 92px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -3px;
}

.about-split p {
  margin: 0;
  max-width: 560px;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 700;
}

.about-card {
  border: 2px solid #fff;
  border-radius: 22px;
  padding: 32px;
}

.about-card h3 {
  margin: 0 0 22px;
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
}

.about-card ul {
  margin: 0;
  padding-left: 20px;
}

.about-card li {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: 800;
}

.about-quote {
  padding: 95px 70px;
}

.about-quote .about-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 60px;
}

.about-quote p {
  margin: 0;
  max-width: 780px;
  font-size: clamp(34px, 5vw, 66px);
  line-height: 0.95;
  font-weight: 900;
  letter-spacing: -2px;
}

/* Mobiel wie ben ik pagina */
@media (max-width: 650px) {
  .about-intro,
  .about-block,
  .about-quote {
    padding: 70px 36px;
  }

  .about-intro .about-inner,
  .about-split {
    grid-template-columns: 1fr;
    gap: 38px;
  }

  .about-big-text h2 {
    font-size: 58px;
    letter-spacing: -2px;
  }

  .about-copy p {
    font-size: 18px;
    line-height: 1.25;
  }

  .about-split h2 {
    font-size: 52px;
    letter-spacing: -2px;
  }

  .about-split p {
    font-size: 17px;
  }

  .about-card {
    padding: 24px;
    border-radius: 18px;
  }

  .about-card h3 {
    font-size: 24px;
  }

  .about-card li {
    font-size: 16px;
  }

  .about-quote .about-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 28px;
  }

  .about-quote p {
    font-size: 38px;
    letter-spacing: -1px;
  }
}

/* ===== Skills pagina ===== */

.skills-page-hero h1 {
  max-width: 980px;
}

.skills-intro {
  padding: 95px 70px;
}

.skills-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.skills-intro .skills-inner {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 85px;
  align-items: start;
}

.skills-heading h2 {
  margin: 0;
  font-size: clamp(58px, 8vw, 105px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.skills-heading p {
  margin: 16px 0 0;
  max-width: 360px;
  font-size: 22px;
  line-height: 1.15;
  font-weight: 800;
}

.skills-list {
  display: grid;
  gap: 22px;
}

.skill-item {
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 22px;
  padding-bottom: 22px;
  border-bottom: 2px solid #000;
}

.skill-item span {
  font-size: 18px;
  font-weight: 900;
}

.skill-item h3 {
  margin: 0;
  font-size: 34px;
  line-height: 0.95;
  font-weight: 900;
  letter-spacing: -1px;
}

.skill-item p {
  margin: 8px 0 0;
  max-width: 560px;
  font-size: 17px;
  line-height: 1.25;
  font-weight: 700;
}

.skills-banner {
  padding: 95px 70px;
}

.skills-banner h2 {
  margin: 0;
  max-width: 880px;
  font-size: clamp(56px, 8vw, 105px);
  line-height: 0.86;
  font-weight: 900;
  letter-spacing: -4px;
}

.skills-banner p {
  margin: 22px 0 0;
  max-width: 620px;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 700;
}

.tools-section {
  padding: 90px 70px;
}

.tools-grid {
  display: grid;
  grid-template-columns: 0.75fr 1.25fr;
  gap: 80px;
  align-items: start;
}

.tools-grid h2 {
  margin: 0;
  font-size: clamp(58px, 8vw, 100px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.tools-grid p {
  margin: 16px 0 0;
  max-width: 370px;
  font-size: 21px;
  line-height: 1.15;
  font-weight: 800;
}

.tool-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.tool-tags span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border: 2px solid #000;
  border-radius: 999px;
  font-size: 18px;
  font-weight: 900;
}

.skills-cta {
  padding: 85px 70px;
}

.skills-cta .skills-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 50px;
}

.skills-cta h2 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(48px, 7vw, 86px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -3px;
}

/* Mobiel skills pagina */
@media (max-width: 650px) {
  .skills-intro,
  .skills-banner,
  .tools-section,
  .skills-cta {
    padding: 70px 36px;
  }

  .skills-intro .skills-inner,
  .tools-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .skills-heading h2,
  .tools-grid h2 {
    font-size: 58px;
    letter-spacing: -2px;
  }

  .skills-heading p,
  .tools-grid p {
    font-size: 18px;
  }

  .skill-item {
    grid-template-columns: 42px 1fr;
    gap: 16px;
  }

  .skill-item h3 {
    font-size: 30px;
  }

  .skill-item p {
    font-size: 16px;
  }

  .skills-banner h2 {
    font-size: 52px;
    letter-spacing: -2px;
  }

  .skills-banner p {
    font-size: 17px;
  }

  .tool-tags {
    gap: 12px;
  }

  .tool-tags span {
    min-height: 42px;
    padding: 0 18px;
    font-size: 15px;
  }

  .skills-cta .skills-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 28px;
  }

  .skills-cta h2 {
    font-size: 44px;
    letter-spacing: -2px;
  }
}

/* ===== Contact pagina ===== */

.contact-page-hero h1 {
  max-width: 980px;
}

.contact-page {
  padding: 95px 70px;
}

.contact-page-inner {
  max-width: 1200px;
  margin: 0 auto;
}

.contact-page .contact-page-inner {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 85px;
  align-items: start;
}

.contact-text h2 {
  margin: 0;
  font-size: clamp(58px, 8vw, 105px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.contact-text > p {
  margin: 20px 0 32px;
  max-width: 470px;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 800;
}

.contact-details {
  display: grid;
  gap: 5px;
}

.contact-details p,
.contact-details a {
  margin: 0;
  color: #000;
  font-size: 18px;
  line-height: 1.15;
  font-weight: 900;
}

.contact-details p:first-child {
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 800;
}

.contact-page-form {
  display: grid;
  gap: 12px;
}

.contact-page-form label {
  font-size: 14px;
  font-weight: 900;
}

.contact-page-form input,
.contact-page-form textarea {
  width: 100%;
  border: 2px solid #000;
  border-radius: 0;
  background: transparent;
  color: #000;
  padding: 15px 16px;
  font: inherit;
  font-size: 16px;
  font-weight: 700;
  outline: none;
}

.contact-page-form textarea {
  min-height: 155px;
  resize: vertical;
}

.contact-page-form input::placeholder,
.contact-page-form textarea::placeholder {
  color: #555;
}

.contact-page-form input:focus,
.contact-page-form textarea:focus {
  background: #000;
  color: #fff;
}

.contact-page-form input:focus::placeholder,
.contact-page-form textarea:focus::placeholder {
  color: #bbb;
}

.contact-page-form .btn {
  justify-self: start;
  margin-top: 10px;
}

.contact-social {
  padding: 85px 70px;
}

.contact-social-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 60px;
}

.contact-social h2 {
  margin: 0;
  font-size: clamp(48px, 7vw, 86px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -3px;
}

.contact-social-links {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.social-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 24px;
  border: 2px solid #fff;
  border-radius: 999px;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
}

/* Mobiel contact pagina */
@media (max-width: 650px) {
  .contact-page,
  .contact-social {
    padding: 70px 36px;
  }

  .contact-page .contact-page-inner {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .contact-text h2 {
    font-size: 58px;
    letter-spacing: -2px;
  }

  .contact-text > p {
    font-size: 18px;
  }

  .contact-details p,
  .contact-details a {
    font-size: 16px;
  }

  .contact-social-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 30px;
  }

  .contact-social h2 {
    font-size: 44px;
    letter-spacing: -2px;
  }

  .contact-social-links {
    flex-direction: column;
    align-items: flex-start;
  }
}

.social-icon {
  width: 42px;
  height: 42px;
  background: #000;
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.social-icon img {
  width: 22px;
  height: 22px;
  display: block;
  filter: brightness(0) invert(1);
}

.social-icon svg,
.social-icon img {
  width: 28px;
  height: 28px;
}

/* ===== Alle subpagina's gelijke afmetingen geven ===== */

.page-hero {
  min-height: 340px;
  padding: 115px 70px 65px;
}

.page-hero-inner,
.creations-inner,
.about-inner,
.skills-inner,
.contact-page-inner {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.page-hero h1 {
  font-size: clamp(58px, 9vw, 118px);
  line-height: 0.87;
  letter-spacing: -4px;
}

.page-hero p {
  margin-top: 12px;
  font-size: 22px;
}

/* Zelfde sectie-padding voor subpagina's */
.creations-page,
.about-intro,
.about-block,
.about-quote,
.skills-intro,
.skills-banner,
.tools-section,
.skills-cta,
.contact-page,
.contact-social {
  padding-left: 70px;
  padding-right: 70px;
}

/* Contact specifiek iets gelijker trekken */
.contact-page {
  padding-top: 90px;
  padding-bottom: 90px;
}

.contact-social {
  padding-top: 85px;
  padding-bottom: 85px;
}

@media (max-width: 650px) {
  .page-hero {
    min-height: 300px;
    padding: 85px 36px 55px;
  }

  .page-hero h1 {
    font-size: 58px;
    line-height: 0.9;
    letter-spacing: -2px;
  }

  .page-hero p {
    font-size: 18px;
  }

  .creations-page,
  .about-intro,
  .about-block,
  .about-quote,
  .skills-intro,
  .skills-banner,
  .tools-section,
  .skills-cta,
  .contact-page,
  .contact-social {
    padding-left: 36px;
    padding-right: 36px;
  }
}
/* ===== Animaties / polish ===== */

/* Algemene soepele interacties */
.btn,
.social-icon,
.project-card,
.creation-item,
.skill-item,
.tool-tags span,
.social-pill {
  transition:
    transform 0.22s ease,
    opacity 0.22s ease,
    background-color 0.22s ease,
    color 0.22s ease,
    border-color 0.22s ease;
}

/* Buttons hover */
.btn:hover {
  transform: translateY(-3px);
}

/* Lichte buttons op zwarte achtergrond */
.light-btn:hover,
.hero-btn:hover {
  background: #fff;
  color: #000;
}

/* Donkere buttons op witte achtergrond */
.dark-btn:hover {
  background: #000;
  color: #fff;
}

/* Project cards op Home */
.project-card:hover {
  transform: translateY(-8px);
}

.project-card:hover .placeholder {
  filter: contrast(1.08);
}

/* Creaties pagina projectblokken */
.creation-item:hover {
  transform: translateY(-6px);
}

/* Skills items */
.skill-item:hover {
  transform: translateX(8px);
}

/* Tool tags */
.tool-tags span:hover {
  background: #000;
  color: #fff;
}

/* Social icons */
.social-icon:hover {
  transform: translateY(-3px) scale(1.04);
  opacity: 0.85;
}

/* Social pills op contactpagina */
.social-pill:hover {
  background: #fff;
  color: #000;
}

/* Afbeeldingen/placeholders subtiel laten reageren */
.placeholder,
.creation-image {
  transition:
    transform 0.25s ease,
    filter 0.25s ease;
}

.project-card:hover .placeholder,
.creation-item:hover .creation-image {
  transform: scale(1.02);
}

/* ===== Scroll reveal ===== */

.reveal {
  opacity: 0;
  transform: translateY(34px);
  transition:
    opacity 0.65s ease,
    transform 0.65s ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Kleine stagger als elementen na elkaar moeten verschijnen */
.reveal-delay-1 {
  transition-delay: 0.1s;
}

.reveal-delay-2 {
  transition-delay: 0.2s;
}

/* ===== DEFINITIEVE VEILIGE REVEAL ANIMATIE ===== */

.reveal {
  opacity: 1;
  transform: none;
}

.js-enabled .reveal {
  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity 0.7s ease,
    transform 0.7s ease;
}

.js-enabled .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.js-enabled .reveal-delay-1 {
  transition-delay: 0.1s;
}

.js-enabled .reveal-delay-2 {
  transition-delay: 0.2s;
}

.js-enabled .reveal-delay-3 {
  transition-delay: 0.3s;
}

/* ===== DEFINITIEVE SCROLL ANIMATIE ===== */

.reveal {
  opacity: 1;
  transform: none;
}

.js-enabled .reveal:not(.is-visible) {
  opacity: 0;
  transform: translateY(45px);
}

.js-enabled .reveal {
  transition:
    opacity 0.8s ease,
    transform 0.8s ease;
}

.js-enabled .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.js-enabled .reveal-delay-1 {
  transition-delay: 0.12s;
}

.js-enabled .reveal-delay-2 {
  transition-delay: 0.24s;
}

.js-enabled .reveal-delay-3 {
  transition-delay: 0.36s;
}



.reveal {
  opacity: 1;
  transform: none;
}

.reveal-delay-1 {
  animation-delay: 0.1s;
}

.reveal-delay-2 {
  animation-delay: 0.2s;
}

.reveal-delay-3 {
  animation-delay: 0.3s;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(45px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===== Hover polish ===== */

.btn,
.project-card,
.creation-item,
.skill-item,
.tool-tags span,
.social-icon,
.social-pill {
  transition:
    transform 0.25s ease,
    opacity 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease,
    border-color 0.25s ease,
    filter 0.25s ease;
}

.btn:hover {
  transform: translateY(-3px);
}

.light-btn:hover,
.hero-btn:hover {
  background: #fff;
  color: #000;
}

.dark-btn:hover {
  background: #000;
  color: #fff;
}

.project-card:hover {
  transform: translateY(-10px);
}

.placeholder,
.creation-image {
  transition:
    transform 0.3s ease,
    filter 0.3s ease;
}

.project-card:hover .placeholder,
.creation-item:hover .creation-image {
  transform: scale(1.03);
  filter: contrast(1.08);
}

.creation-item:hover {
  transform: translateY(-6px);
}

.skill-item:hover {
  transform: translateX(8px);
}

.tool-tags span:hover {
  background: #000;
  color: #fff;
}

.social-icon:hover {
  transform: translateY(-3px) scale(1.05);
  opacity: 0.85;
}

.social-pill:hover {
  background: #fff;
  color: #000;
}

/* ===== Intro / inlaadanimatie ===== */

body.intro-lock {
  overflow: hidden;
}

.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #000;
  color: #fff;
  display: grid;
  place-items: center;
  padding: 32px;
  pointer-events: all;
}

.intro-loader-inner {
  text-align: left;
  width: min(1200px, 100%);
  overflow: hidden;
}

.intro-loader h1 {
  margin: 0;
  font-size: clamp(58px, 12vw, 135px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -5px;
  transform: translateY(100%);
  animation: introTitleIn 0.9s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.intro-small,
.intro-subtitle {
  margin: 0;
  font-weight: 800;
  opacity: 0;
  transform: translateY(20px);
  animation: introTextIn 0.7s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.intro-small {
  font-size: 13px;
  margin-bottom: 10px;
  animation-delay: 0.15s;
}

.intro-subtitle {
  font-size: clamp(22px, 3vw, 34px);
  margin-top: 10px;
  animation-delay: 0.45s;
}

.intro-loader.is-done {
  animation: introExit 0.85s cubic-bezier(0.76, 0, 0.24, 1) forwards;
}

@keyframes introTitleIn {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes introTextIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes introExit {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-100%);
  }
}

/* Mobiel */
@media (max-width: 650px) {
  .intro-loader {
    padding: 36px;
  }

  .intro-loader h1 {
    font-size: 64px;
    letter-spacing: -2px;
  }

  .intro-subtitle {
    font-size: 24px;
  }
}

/* ===== CSS-only intro animatie ===== */

.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: #000;
  color: #fff;
  display: grid;
  place-items: center;
  padding: 32px;

  animation: introScreenOut 0.9s cubic-bezier(0.76, 0, 0.24, 1) 2.2s forwards;
}

.intro-loader-inner {
  width: min(1200px, 100%);
  overflow: hidden;
}

.intro-small {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 800;
  opacity: 0;
  transform: translateY(20px);
  animation: introTextIn 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.15s forwards;
}

.intro-loader h1 {
  margin: 0;
  font-size: clamp(58px, 12vw, 135px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -5px;
  transform: translateY(110%);
  animation: introTitleIn 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.35s forwards;
}

.intro-subtitle {
  margin: 12px 0 0;
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 800;
  opacity: 0;
  transform: translateY(20px);
  animation: introTextIn 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.8s forwards;
}

@keyframes introTitleIn {
  from {
    transform: translateY(110%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes introTextIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes introScreenOut {
  0% {
    transform: translateY(0);
    visibility: visible;
  }

  99% {
    transform: translateY(-100%);
    visibility: visible;
  }

  100% {
    transform: translateY(-100%);
    visibility: hidden;
    pointer-events: none;
  }
}

/* Mobiel intro */
@media (max-width: 650px) {
  .intro-loader {
    padding: 36px;
  }

  .intro-loader h1 {
    font-size: 64px;
    letter-spacing: -2px;
  }

  .intro-subtitle {
    font-size: 24px;
  }
}

/* ===== CSS-only intro animatie ===== */

.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: #000;
  color: #fff;
  display: grid;
  place-items: center;
  padding: 32px;

  animation: introScreenOut 0.9s cubic-bezier(0.76, 0, 0.24, 1) 2.2s forwards;
}

.intro-loader-inner {
  width: min(1200px, 100%);
  overflow: hidden;
}

.intro-small {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 800;
  opacity: 0;
  transform: translateY(20px);
  animation: introTextIn 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.15s forwards;
}

.intro-loader h1 {
  margin: 0;
  font-size: clamp(58px, 12vw, 135px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -5px;
  transform: translateY(110%);
  animation: introTitleIn 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.35s forwards;
}

.intro-subtitle {
  margin: 12px 0 0;
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 800;
  opacity: 0;
  transform: translateY(20px);
  animation: introTextIn 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.8s forwards;
}

@keyframes introTitleIn {
  from {
    transform: translateY(110%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes introTextIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes introScreenOut {
  0% {
    transform: translateY(0);
    visibility: visible;
  }

  99% {
    transform: translateY(-100%);
    visibility: visible;
  }

  100% {
    transform: translateY(-100%);
    visibility: hidden;
    pointer-events: none;
  }
}

/* Mobiel intro */
@media (max-width: 650px) {
  .intro-loader {
    padding: 36px;
  }

  .intro-loader h1 {
    font-size: 64px;
    letter-spacing: -2px;
  }

  .intro-subtitle {
    font-size: 24px;
  }
}

/* ===== Premium CSS-only intro animatie ===== */

.intro-loader {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: #000;
  color: #fff;
  display: grid;
  place-items: center;
  padding: 32px;
  overflow: hidden;
  animation: introScreenExit 1s cubic-bezier(0.76, 0, 0.24, 1) 3.05s forwards;
}

/* Witte wipe/streep voor premium overgang */
.intro-loader::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -12%;
  width: 100%;
  height: 18%;
  background: #f7f7f7;
  transform: translateY(100%);
  animation: introWipe 1s cubic-bezier(0.76, 0, 0.24, 1) 2.72s forwards;
}

.intro-loader-inner {
  position: relative;
  z-index: 2;
  width: min(1200px, 100%);
  overflow: hidden;
}

/* Kleine bovenregel */
.intro-small {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.04em;
  opacity: 0;
  transform: translateY(24px);
  animation: introTextUp 0.75s cubic-bezier(0.16, 1, 0.3, 1) 0.18s forwards;
}

/* Grote titel */
.intro-loader h1 {
  margin: 0;
  font-size: clamp(58px, 12vw, 140px);
  line-height: 0.83;
  font-weight: 900;
  letter-spacing: -6px;
  transform: translateY(115%) scale(0.98);
  animation:
    introTitleUp 1s cubic-bezier(0.16, 1, 0.3, 1) 0.38s forwards,
    introTitleSettle 0.8s cubic-bezier(0.16, 1, 0.3, 1) 1.25s forwards;
}

/* Subtitel */
.intro-subtitle {
  margin: 14px 0 0;
  font-size: clamp(22px, 3vw, 36px);
  line-height: 1;
  font-weight: 800;
  opacity: 0;
  transform: translateY(28px);
  animation: introTextUp 0.75s cubic-bezier(0.16, 1, 0.3, 1) 0.95s forwards;
}

/* Kleine subtiele lijn onder de intro */
.intro-loader-inner::after {
  content: "";
  display: block;
  width: 0;
  height: 2px;
  margin-top: 34px;
  background: #fff;
  animation: introLine 0.9s cubic-bezier(0.16, 1, 0.3, 1) 1.35s forwards;
}

/* Animaties */
@keyframes introTextUp {
  from {
    opacity: 0;
    transform: translateY(24px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes introTitleUp {
  from {
    opacity: 1;
    transform: translateY(115%) scale(0.98);
    letter-spacing: -10px;
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    letter-spacing: -6px;
  }
}

@keyframes introTitleSettle {
  from {
    transform: translateY(0) scale(1);
  }

  to {
    transform: translateY(0) scale(1);
  }
}

@keyframes introLine {
  from {
    width: 0;
    opacity: 0;
  }

  to {
    width: min(360px, 70vw);
    opacity: 1;
  }
}

@keyframes introWipe {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(-620%);
  }
}

@keyframes introScreenExit {
  0% {
    transform: translateY(0);
    visibility: visible;
  }

  99% {
    transform: translateY(-100%);
    visibility: visible;
  }

  100% {
    transform: translateY(-100%);
    visibility: hidden;
    pointer-events: none;
  }
}

/* Hero komt subtiel binnen nadat intro weggaat */
.hero h1,
.hero-subtitle,
.small-text,
.hero-btn,
.services-line {
  animation-fill-mode: both;
}

.hero h1 {
  animation: homeHeroIn 0.9s cubic-bezier(0.16, 1, 0.3, 1) 3.25s both;
}

.hero-subtitle {

}

/* ===== Scroll reveal animaties ===== */

/* Veilig: zonder JS blijft alles zichtbaar */
.reveal {
  opacity: 1;
  transform: none;
}

/* Alleen wanneer JS werkt, starten reveal-elementen verborgen */
.js-enabled .reveal {
  opacity: 0;
  transform: translateY(55px);
  transition:
    opacity 0.85s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.85s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

/* Zodra element in beeld komt */
.js-enabled .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Variaties */
.js-enabled .reveal-left {
  transform: translateX(-55px);
}

.js-enabled .reveal-right {
  transform: translateX(55px);
}

.js-enabled .reveal-scale {
  transform: scale(0.94);
}

.js-enabled .reveal-left.is-visible,
.js-enabled .reveal-right.is-visible,
.js-enabled .reveal-scale.is-visible {
  transform: translateX(0) scale(1);
}

/* Delays */
.js-enabled .reveal-delay-1 {
  transition-delay: 0.12s;
}

.js-enabled .reveal-delay-2 {
  transition-delay: 0.24s;
}

.js-enabled .reveal-delay-3 {
  transition-delay: 0.36s;
}

/* Mobiel iets subtieler */
@media (max-width: 650px) {
  .js-enabled .reveal {
    transform: translateY(35px);
  }

  .js-enabled .reveal-left,
  .js-enabled .reveal-right {
    transform: translateY(35px);
  }
}

/* ===== Scroll reveal animaties ===== */

/* Veilig: zonder JS blijft alles zichtbaar */
.reveal {
  opacity: 1;
  transform: none;
}

/* Alleen wanneer JS werkt, starten reveal-elementen verborgen */
.js-enabled .reveal {
  opacity: 0;
  transform: translateY(55px);
  transition:
    opacity 0.85s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.85s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

/* Zodra element in beeld komt */
.js-enabled .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Variaties */
.js-enabled .reveal-left {
  transform: translateX(-55px);
}

.js-enabled .reveal-right {
  transform: translateX(55px);
}

.js-enabled .reveal-scale {
  transform: scale(0.94);
}

.js-enabled .reveal-left.is-visible,
.js-enabled .reveal-right.is-visible,
.js-enabled .reveal-scale.is-visible {
  transform: translateX(0) scale(1);
}

/* Delays */
.js-enabled .reveal-delay-1 {
  transition-delay: 0.12s;
}

.js-enabled .reveal-delay-2 {
  transition-delay: 0.24s;
}

.js-enabled .reveal-delay-3 {
  transition-delay: 0.36s;
}

/* Mobiel iets subtieler */
@media (max-width: 650px) {
  .js-enabled .reveal {
    transform: translateY(35px);
  }

  .js-enabled .reveal-left,
  .js-enabled .reveal-right {
    transform: translateY(35px);
  }
}

/* ===== Nieuwe scroll animatie - schoon systeem ===== */

.scroll-animate {
  opacity: 1;
  transform: none;
}

/* Alleen als JavaScript werkt */
.js-enabled .scroll-animate {
  opacity: 0;
  transform: translateY(70px);
  transition:
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .scroll-animate.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Variaties */
.js-enabled .scroll-left {
  transform: translateX(-70px);
}

.js-enabled .scroll-right {
  transform: translateX(70px);
}

.js-enabled .scroll-scale {
  transform: scale(0.9);
}

.js-enabled .scroll-left.is-visible,
.js-enabled .scroll-right.is-visible,
.js-enabled .scroll-scale.is-visible {
  opacity: 1;
  transform: translateX(0) scale(1);
}

/* Vertraging */
.scroll-delay-1 {
  transition-delay: 0.12s;
}

.scroll-delay-2 {
  transition-delay: 0.24s;
}

.scroll-delay-3 {
  transition-delay: 0.36s;
}

@media (max-width: 650px) {
  .js-enabled .scroll-animate {
    transform: translateY(45px);
  }

  .js-enabled .scroll-left,
  .js-enabled .scroll-right {
    transform: translateY(45px);
  }
}

/* ===== Simpele fade-in scroll animatie ===== */

.fade-scroll {
  opacity: 1;
  transform: none;
}

.js-enabled .fade-scroll {
  opacity: 0;
  transform: translateY(48px);
  transition:
    opacity 0.8s ease,
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .fade-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.fade-delay-1 {
  transition-delay: 0.12s;
}

.fade-delay-2 {
  transition-delay: 0.24s;
}

.fade-delay-3 {
  transition-delay: 0.36s;
}

@media (max-width: 650px) {
  .js-enabled .fade-scroll {
    transform: translateY(32px);
  }
}

/* ===== Simpele fade-in scroll animatie ===== */

.fade-scroll {
  opacity: 1;
  transform: none;
}

.js-enabled .fade-scroll {
  opacity: 0;
  transform: translateY(48px);
  transition:
    opacity 0.8s ease,
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.js-enabled .fade-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.fade-delay-1 {
  transition-delay: 0.12s;
}

.fade-delay-2 {
  transition-delay: 0.24s;
}

.fade-delay-3 {
  transition-delay: 0.36s;
}

/* ===== Page fade transition ===== */

body {
  opacity: 1;
  transition: opacity 0.35s ease;
}

body.page-is-loading {
  opacity: 0;
}

body.page-is-leaving {
  opacity: 0;
}

/* ===== Page transition fade ===== */

body {
  animation: pageFadeIn 0.45s ease both;
}

body.page-leave {
  opacity: 0;
  transition: opacity 0.45s ease;
}

@keyframes pageFadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* ===== Mobile fix: hero subtitle op één regel ===== */

@media (max-width: 650px) {
  .hero-subtitle {
    white-space: nowrap;
    max-width: none;
    font-size: 24px;
  }
}

/* ===== Contact pagina blauwe stijl ===== */

.contact-blue-hero {
  position: relative;
  min-height: 520px;
  overflow: hidden;
  background: #06457c;
  color: #fff;
  padding: 145px 70px 90px;
  display: flex;
  align-items: center;
}

/* Abstract patroon zoals in je screenshot */
.contact-pattern {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, transparent 0 18%, rgba(255,255,255,0.08) 18% 28%, transparent 28% 100%),
    linear-gradient(25deg, transparent 0 38%, rgba(255,255,255,0.11) 38% 47%, transparent 47% 100%),
    linear-gradient(160deg, transparent 0 58%, rgba(0,0,0,0.12) 58% 65%, transparent 65% 100%),
    linear-gradient(90deg, #06457c, #0c4f89);
  opacity: 1;
}

.contact-pattern::before,
.contact-pattern::after {
  content: "";
  position: absolute;
  width: 70vw;
  height: 70vw;
  background: rgba(255, 255, 255, 0.08);
  transform: rotate(38deg);
}

.contact-pattern::before {
  right: -22vw;
  top: -28vw;
}

.contact-pattern::after {
  left: -34vw;
  bottom: -46vw;
  background: rgba(0, 0, 0, 0.13);
}

.contact-blue-inner {
  position: relative;
  z-index: 2;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}

.contact-kicker {
  margin: 0 0 20px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contact-blue-title {
  position: relative;
  margin: 0;
  max-width: 780px;
  font-size: clamp(72px, 13vw, 170px);
  line-height: 0.78;
  font-weight: 900;
  letter-spacing: -7px;
  color: #fff;
}

/* Oranje verticale lijn/accent in de titel */
.contact-blue-title::before {
  content: "";
  position: absolute;
  left: 0.5em;
  top: -0.08em;
  width: 10px;
  height: 1.45em;
  background: #ff8a13;
}

.contact-blue-title span {
  display: block;
  padding-left: 0.62em;
}

.contact-blue-subtitle {
  margin: 28px 0 0;
  font-size: clamp(22px, 3vw, 36px);
  font-weight: 800;
}

/* Content */
.contact-blue-content {
  background: #000;
  color: #fff;
  padding: 95px 70px;
}

.contact-blue-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 85px;
  align-items: start;
}

.contact-blue-text h2 {
  margin: 0;
  font-size: clamp(58px, 8vw, 105px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.contact-blue-text > p {
  margin: 22px 0 34px;
  max-width: 500px;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 800;
}

.contact-blue-details {
  display: grid;
  gap: 5px;
}

.contact-blue-details p,
.contact-blue-details a {
  margin: 0;
  color: #fff;
  font-size: 18px;
  line-height: 1.15;
  font-weight: 900;
}

.contact-blue-details p:first-child {
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 800;
}

/* Formulier in blauwe stijl */
.contact-blue-form {
  display: grid;
  gap: 12px;
}

.contact-blue-form label {
  color: #fff;
  font-size: 14px;
  font-weight: 900;
}

.contact-blue-form input,
.contact-blue-form textarea {
  width: 100%;
  border: 2px solid #fff;
  border-radius: 0;
  background: transparent;
  color: #fff;
  padding: 15px 16px;
  font: inherit;
  font-size: 16px;
  font-weight: 700;
  outline: none;
}

.contact-blue-form textarea {
  min-height: 155px;
  resize: vertical;
}

.contact-blue-form input::placeholder,
.contact-blue-form textarea::placeholder {
  color: rgba(255, 255, 255, 0.58);
}

.contact-blue-form input:focus,
.contact-blue-form textarea:focus {
  background: #fff;
  color: #000;
}

.contact-blue-form input:focus::placeholder,
.contact-blue-form textarea:focus::placeholder {
  color: #666;
}

.blue-form-btn {
  justify-self: start;
  margin-top: 10px;
  border: 2px solid #fff;
  background: #fff;
  color: #000;
}

.blue-form-btn:hover {
  background: #ff8a13;
  border-color: #ff8a13;
  color: #000;
}

/* Social stuk */
.contact-blue-social {
  background: #06457c;
  color: #fff;
  padding: 85px 70px;
  position: relative;
  overflow: hidden;
}

.contact-blue-social::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(145deg, transparent 0 45%, rgba(255,255,255,0.08) 45% 54%, transparent 54% 100%);
}

.contact-blue-social-inner {
  position: relative;
  z-index: 2;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 60px;
  align-items: center;
}

.contact-blue-social h2 {
  margin: 0;
  font-size: clamp(48px, 7vw, 86px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -3px;
}

.blue-social-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 24px;
  border: 2px solid #fff;
  border-radius: 999px;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease,
    border-color 0.25s ease;
}

.blue-social-pill:hover {
  background: #fff;
  color: #06457c;
  transform: translateY(-4px);
}

/* Mobiel */
@media (max-width: 650px) {
  .contact-blue-hero {
    min-height: 430px;
    padding: 110px 36px 70px;
  }

  .contact-blue-title {
    font-size: 74px;
    line-height: 0.82;
    letter-spacing: -3px;
  }

  .contact-blue-title::before {
    width: 7px;
    height: 1.5em;
  }

  .contact-blue-subtitle {
    font-size: 24px;
  }

  .contact-blue-content,
  .contact-blue-social {
    padding: 70px 36px;
  }

  .contact-blue-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .contact-blue-text h2 {
    font-size: 58px;
    letter-spacing: -2px;
  }

  .contact-blue-text > p {
    font-size: 18px;
  }

  .contact-blue-details p,
  .contact-blue-details a {
    font-size: 16px;
  }

  .contact-blue-social-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 30px;
  }

  .contact-blue-social h2 {
    font-size: 44px;
    letter-spacing: -2px;
  }

  .contact-social-links {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ===== Contact pagina 1-op-1 zwart/wit ontwerp ===== */

.contact-design-inner {
  width: min(1220px, calc(100% - 96px));
  margin: 0 auto;
}

/* Hero */
.contact-design-hero {
  min-height: 650px;
  padding: 125px 0 92px;
  display: flex;
  align-items: center;
}

.contact-hero-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 90px;
  align-items: center;
}

.contact-hero-text h1 {
  margin: 0 0 18px;
  font-size: clamp(72px, 9vw, 118px);
  line-height: 0.82;
  font-weight: 900;
  letter-spacing: -4px;
}

.contact-hero-text h2 {
  margin: 0 0 12px;
  font-size: 28px;
  line-height: 1;
  font-weight: 800;
}

.contact-hero-text p {
  margin: 0;
  max-width: 440px;
  font-size: 18px;
  line-height: 1.15;
  font-weight: 700;
}

.contact-hero-image {
  width: 100%;
}

.contact-hero-image img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  display: block;
}

/* Formulier sectie */
.contact-form-section {
  padding: 95px 0 92px;
}

.contact-form-grid {
  display: grid;
  grid-template-columns: 0.78fr 1.22fr;
  gap: 110px;
  align-items: start;
}

.contact-form-info h2 {
  margin: 0;
  font-size: clamp(58px, 6vw, 78px);
  line-height: 0.88;
  font-weight: 400;
  letter-spacing: -2px;
}

.contact-form-info h2 strong {
  display: block;
  font-weight: 900;
}

.contact-form-info > p {
  margin: 32px 0 52px;
  font-size: 17px;
  line-height: 1.22;
  font-weight: 700;
}

.contact-info-list {
  display: grid;
  gap: 28px;
  padding-left: 48px;
}

.contact-info-list h3 {
  margin: 0 0 5px;
  font-size: 14px;
  line-height: 1;
  font-weight: 900;
}

.contact-info-list p,
.contact-info-list a {
  display: block;
  margin: 0;
  color: #000;
  font-size: 13px;
  line-height: 1.2;
  font-weight: 500;
}

/* Clean form */
.contact-clean-form {
  display: grid;
  gap: 34px;
  padding-top: 34px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 58px;
}

.form-field {
  display: grid;
  gap: 9px;
}

.contact-clean-form label {
  font-size: 14px;
  line-height: 1;
  color: #000;
  font-weight: 600;
}

.contact-clean-form input,
.contact-clean-form textarea {
  width: 100%;
  border: 0;
  border-bottom: 1.5px solid #000;
  border-radius: 0;
  background: transparent;
  color: #000;
  padding: 0 0 10px;
  font: inherit;
  font-size: 15px;
  font-weight: 600;
  outline: none;
}

.contact-clean-form textarea {
  min-height: 145px;
  resize: vertical;
}

.contact-submit-btn {
  justify-self: start;
  min-height: 38px;
  padding: 0 24px;
  border: 1.5px solid #000;
  border-radius: 999px;
  background: transparent;
  color: #000;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 18px;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease;
}

.contact-submit-btn:hover {
  background: #000;
  color: #fff;
  transform: translateY(-3px);
}

/* CTA zwart blok */
.contact-cta-section {
  padding: 68px 0 76px;
  text-align: center;
}

.contact-cta-inner h2 {
  margin: 0;
  font-size: clamp(34px, 4.5vw, 54px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -1.5px;
}

.contact-cta-inner p {
  margin: 14px 0 42px;
  font-size: 22px;
  line-height: 1;
  font-style: italic;
  font-weight: 500;
}

.contact-cta-btn {
  min-height: 37px;
  padding: 0 20px;
  border: 1.5px solid #fff;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 900;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease;
}

.contact-cta-btn:hover {
  background: #fff;
  color: #000;
  transform: translateY(-3px);
}

/* Footer exact voor contact */
.contact-design-footer {
  padding: 65px 0 64px;
}

.contact-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 80px;
  align-items: center;
}

.contact-footer-left h2 {
  margin: 0;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -2px;
}

.contact-footer-tagline {
  margin: 6px 0 40px;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.contact-footer-info p,
.contact-footer-info a {
  display: block;
  margin: 0;
  color: #000;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 900;
}

.contact-footer-info p:first-child {
  margin-bottom: 8px;
  font-size: 16px;
}

.contact-footer-right {
  padding-top: 48px;
}

.contact-footer-right > p {
  margin: 0 0 36px;
  font-size: 17px;
  font-weight: 900;
}

/* Social icons iets groter zoals screenshot */
.contact-design-footer .social-icon {
  width: 58px;
  height: 58px;
  border-radius: 12px;
}

.contact-design-footer .social-icon img,
.contact-design-footer .social-icon svg {
  width: 34px;
  height: 34px;
}

/* Mobiel */
@media (max-width: 650px) {
  .contact-design-inner {
    width: calc(100% - 44px);
  }

  .contact-design-hero {
    min-height: auto;
    padding: 82px 0 58px;
  }

  .contact-hero-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .contact-hero-text h1 {
    font-size: 64px;
    letter-spacing: -2px;
  }

  .contact-hero-text h2 {
    font-size: 22px;
  }

  .contact-hero-text p {
    font-size: 15px;
  }

  .contact-hero-image img {
    max-height: 310px;
  }

  .contact-form-section {
    padding: 62px 0 66px;
  }

  .contact-form-grid {
    grid-template-columns: 1fr;
    gap: 46px;
  }

  .contact-form-info h2 {
    font-size: 50px;
  }

  .contact-form-info > p {
    margin: 24px 0 34px;
    font-size: 15px;
  }

  .contact-info-list {
    padding-left: 0;
    gap: 24px;
  }

  .contact-clean-form {
    padding-top: 0;
    gap: 30px;
  }

  .form-row {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .contact-cta-section {
    padding: 58px 0 62px;
  }

  .contact-cta-inner h2 {
    font-size: 32px;
  }

  .contact-cta-inner p {
    font-size: 18px;
    margin-bottom: 32px;
  }

  .contact-design-footer {
    padding: 52px 0;
  }

  .contact-footer-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .contact-footer-left h2 {
    font-size: 42px;
  }

  .contact-footer-tagline {
    margin-bottom: 28px;
    font-size: 15px;
  }

  .contact-footer-info p,
  .contact-footer-info a {
    font-size: 16px;
  }

  .contact-footer-right {
    padding-top: 0;
  }

  .contact-footer-right > p {
    margin-bottom: 20px;
  }

  .contact-design-footer .social-icon {
    width: 48px;
    height: 48px;
  }

  .contact-design-footer .social-icon img,
  .contact-design-footer .social-icon svg {
    width: 28px;
    height: 28px;
  }
}

/* ===== Contact formulier mooier / cleaner ===== *//* ===== Contact formulier mooier /20px;
}

/* Naam + Email naast elkaar */
.contact-clean-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
}

/* Elk veld */
.contact-clean-form .form-field {
  display: grid;
  gap: 14px;
}

/* Labels */
.contact-clean-form label {
  font-size: 14px;
  line-height: 1;
  color: #000;
  font-weight: 800;
}

/* Inputs en textarea */
.contact-clean-form input,
.contact-clean-form textarea {
  width: 100%;
  border: none;
  border-bottom: 1.5px solid #000;
  border-radius: 0;
  background: transparent !important;
  color: #000 !important;
  padding: 0 0 12px;
  font: inherit;
  font-size: 15px;
  font-weight: 600;
  outline: none;
}

/* Focus niet zwart maken */
.contact-clean-form input:focus,
.contact-clean-form textarea:focus {
  background: transparent !important;
  color: #000 !important;
  border-bottom-color: #000;
}

/* Berichtveld mooier */
.contact-clean-form textarea {
  min-height: 140px;
  resize: vertical;
  padding-top: 6px;
}

/* Extra lijn onder berichtveld zoals ontwerp */
.contact-clean-form textarea {
  border: none;
  border-bottom: 1.5px solid #000;
}

/* Submit knop */
.contact-submit-btn {
  justify-self: start;
  min-height: 40px;
  padding: 0 24px;
  border: 1.5px solid #000;
  border-radius: 999px;
  background: transparent;
  color: #000;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 18px;
  margin-top: 4px;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease;
}

.contact-submit-btn:hover {
  background: #000;
  color: #fff;
  transform: translateY(-3px);
}

/* Mobiel */
@media (max-width: 650px) {
  .contact-clean-form {
    gap: 30px;
  }

  .contact-clean-form .form-row {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .contact-clean-form textarea {
    min-height: 120px;
  }
}

.contact-clean-form {
  display: grid;
  gap: 34px;
}

/* ===== DIT DOE IK pagina 1-op-1 stijl ===== *//* ===== DIT width: min(1220px, calc(100% - 96px));
  margin: 0 auto;
}

/* Hero */
.do-hero {
  min-height: 705px;
  padding: 135px 0 110px;
  display: flex;
  align-items: center;
}

.do-hero-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 90px;
  align-items: center;
}

.do-hero-text h1 {
  margin: 0 0 34px;
  font-size: clamp(72px, 8vw, 112px);
  line-height: 0.86;
  font-weight: 400;
  letter-spacing: -4px;
}

.do-hero-text h1 strong {
  font-weight: 900;
}

.do-hero-text p {
  max-width: 470px;
  margin: 0 0 26px;
  font-size: 20px;
  line-height: 1.15;
  font-weight: 700;
}

.do-hero-btn {
  margin-top: 70px;
  min-height: 42px;
  padding: 0 22px;
  border: 1.5px solid #fff;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  font-weight: 900;
  transition: transform 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.do-hero-btn:hover {
  background: #fff;
  color: #000;
  transform: translateY(-3px);
}

.do-hero-image img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  display: block;
}

/* 01 herkenbaar */
.do-recognizable {
  padding: 62px 0 68px;
  text-align: center;
}

.do-section-number {
  margin: 0 0 52px;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.do-section-number.light {
  color: #fff;
}

.do-three-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 70px;
  align-items: start;
}

.do-three-grid h2 {
  margin: 0 0 18px;
  font-size: clamp(86px, 9vw, 128px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.do-three-grid p {
  margin: 0;
  font-size: 20px;
  line-height: 1.08;
  font-weight: 900;
}

.do-three-grid em {
  font-style: italic;
  font-weight: 500;
}

/* 02 kern */
.do-core {
  padding: 52px 0 62px;
  text-align: center;
}

.do-core .do-section-number {
  margin-bottom: 34px;
}

.do-core h2 {
  margin: 0;
  font-size: clamp(38px, 5vw, 62px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -1.5px;
}

.do-core-italic {
  margin: 16px 0 36px;
  font-size: clamp(34px, 4.7vw, 58px);
  line-height: 1;
  font-style: italic;
  font-weight: 400;
}

.do-core-small {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
}

/* 03 samenbrengen */
.do-bring {
  padding: 58px 0 72px;
  text-align: center;
}

.do-bring .do-section-number {
  margin-bottom: 28px;
}

.do-bring h2 {
  margin: 0 0 34px;
  font-size: clamp(42px, 5vw, 64px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -1.5px;
}

.do-arrow-grid {
  max-width: 640px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 58px;
}

.do-arrow-grid span {
  display: block;
  margin-bottom: 18px;
  font-size: 48px;
  line-height: 1;
}

.do-arrow-grid p {
  margin: 0;
  font-size: 17px;
  line-height: 1.05;
}

.do-arrow-grid strong {
  font-weight: 900;
}

/* 04 aanbod */
.do-offer {
  padding: 62px 0 70px;
  text-align: center;
}

.do-offer .do-section-number {
  margin-bottom: 46px;
}

.do-card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.do-card {
  min-height: 310px;
  padding: 34px 24px 30px;
  border: 2px solid #fff;
  border-radius: 22px;
  text-align: left;
  color: #fff;
  display: flex;
  flex-direction: column;
  transition: transform 0.28s ease, background-color 0.28s ease, color 0.28s ease;
}

.do-card:hover {
  transform: translateY(-8px);
  background: #fff;
  color: #000;
}

.do-icon {
  margin-bottom: 50px;
  font-size: 44px;
  line-height: 1;
}

.do-card h3 {
  margin: 0 0 34px;
  font-size: 22px;
  line-height: 1;
  font-weight: 900;
}

.do-card p {
  margin: auto 0 0;
  font-size: 14px;
  line-height: 1.12;
  font-weight: 800;
}

.do-offer-bottom {
  margin-top: 54px;
}

.do-offer-bottom p {
  margin: 0;
  font-size: 28px;
  line-height: 1.05;
  font-weight: 400;
}

/* Mobiel */
@media (max-width: 650px) {
  .do-inner {
    width: calc(100% - 44px);
  }

  .do-hero {
    min-height: auto;
    padding: 86px 0 62px;
  }

  .do-hero-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .do-hero-text h1 {
    font-size: 58px;
    letter-spacing: -2px;
    margin-bottom: 24px;
  }

  .do-hero-text p {
    font-size: 16px;
    margin-bottom: 20px;
  }

  .do-hero-btn {
    margin-top: 30px;
  }

  .do-hero-image img {
    max-height: 310px;
  }

  .do-recognizable {
    padding: 52px 0 56px;
  }

  .do-section-number {
    margin-bottom: 36px;
    font-size: 15px;
  }

  .do-three-grid {
    grid-template-columns: 1fr;
    gap: 44px;
  }

  .do-three-grid h2 {
    font-size: 86px;
  }

  .do-three-grid p {
    font-size: 18px;
  }

  .do-core {
    padding: 52px 0;
  }

  .do-core h2 {
    font-size: 34px;
  }

  .do-core-italic {
    font-size: 32px;
    margin-bottom: 28px;
  }

  .do-core-small {
    font-size: 15px;
  }

  .do-bring {
    padding: 52px 0 58px;
  }

  .do-bring h2 {
    font-size: 36px;
  }

  .do-arrow-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .do-card-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .do-card {
    min-height: 240px;
  }

  .do-icon {
    margin-bottom: 34px;
  }

  .do-offer-bottom p {
    font-size: 22px;
  }
}

.do-inner {
}

/* ===== Fix DIT DOE IK pagina: centreren en overflow stoppen ===== */

.skills-page,
.do-hero,
.do-recognizable,
.do-core,
.do-bring,
.do-offer {
  overflow-x: hidden;
}

.do-inner {
  width: min(1120px, calc(100% - 120px));
  max-width: 1120px;
  margin-left: auto;
  margin-right: auto;
}

.do-hero-grid {
  display: grid;
  grid-template-columns: 0.9fr 1fr;
  gap: 70px;
  align-items: center;
}

.do-hero-text {
  max-width: 500px;
}

.do-hero-image {
  width: 100%;
  max-width: 520px;
  justify-self: end;
  overflow: hidden;
}

.do-hero-image img {
  width: 100%;
  height: auto;
  max-height: 430px;
  object-fit: cover;
  display: block;
}

/* Zorgt dat grote afbeeldingen nooit uit de pagina breken */
img {
  max-width: 100%;
}

.navbar a.active::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -8px;
  width: 20px;
  height: 2px;
  background: currentColor;
  border-radius: 999px;
  transform: translateX(-50%);
}

/* ===== DIT DOE IK pagina 1-op-1 stijl ===== */

.do-inner {
  width: min(1220px, calc(100% - 96px));
  margin: 0 auto;
}

/* Hero */
.do-hero {
  min-height: 705px;
  padding: 135px 0 110px;
  display: flex;
  align-items: center;
}

.do-hero-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 90px;
  align-items: center;
}

.do-hero-text h1 {
  margin: 0 0 34px;
  font-size: clamp(72px, 8vw, 112px);
  line-height: 0.86;
  font-weight: 400;
  letter-spacing: -4px;
}

.do-hero-text h1 strong {
  font-weight: 900;
}

.do-hero-text p {
  max-width: 470px;
  margin: 0 0 26px;
  font-size: 20px;
  line-height: 1.15;
  font-weight: 700;
}

.do-hero-btn {
  margin-top: 70px;
  min-height: 42px;
  padding: 0 22px;
  border: 1.5px solid #fff;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  font-weight: 900;
  transition: transform 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.do-hero-btn:hover {
  background: #fff;
  color: #000;
  transform: translateY(-3px);
}

.do-hero-image img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  display: block;
}

/* 01 herkenbaar */
.do-recognizable {
  padding: 62px 0 68px;
  text-align: center;
}

.do-section-number {
  margin: 0 0 52px;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.do-section-number.light {
  color: #fff;
}

.do-three-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 70px;
  align-items: start;
}

.do-three-grid h2 {
  margin: 0 0 18px;
  font-size: clamp(86px, 9vw, 128px);
  line-height: 0.85;
  font-weight: 900;
  letter-spacing: -4px;
}

.do-three-grid p {
  margin: 0;
  font-size: 20px;
  line-height: 1.08;
  font-weight: 900;
}

.do-three-grid em {
  font-style: italic;
  font-weight: 500;
}

/* 02 kern */
.do-core {
  padding: 52px 0 62px;
  text-align: center;
}

.do-core .do-section-number {
  margin-bottom: 34px;
}

.do-core h2 {
  margin: 0;
  font-size: clamp(38px, 5vw, 62px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -1.5px;
}

.do-core-italic {
  margin: 16px 0 36px;
  font-size: clamp(34px, 4.7vw, 58px);
  line-height: 1;
  font-style: italic;
  font-weight: 400;
}

.do-core-small {
  margin: 0;
  font-size: 18px;
  font-weight: 500;
}

/* 03 samenbrengen */
.do-bring {
  padding: 58px 0 72px;
  text-align: center;
}

.do-bring .do-section-number {
  margin-bottom: 28px;
}

.do-bring h2 {
  margin: 0 0 34px;
  font-size: clamp(42px, 5vw, 64px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -1.5px;
}

.do-arrow-grid {
  max-width: 640px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 58px;
}

.do-arrow-grid span {
  display: block;
  margin-bottom: 18px;
  font-size: 48px;
  line-height: 1;
}

.do-arrow-grid p {
  margin: 0;
  font-size: 17px;
  line-height: 1.05;
}

.do-arrow-grid strong {
  font-weight: 900;
}

/* 04 aanbod */
.do-offer {
  padding: 62px 0 70px;
  text-align: center;
}

.do-offer .do-section-number {
  margin-bottom: 46px;
}

.do-card-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.do-card {
  min-height: 310px;
  padding: 34px 24px 30px;
  border: 2px solid #fff;
  border-radius: 22px;
  text-align: left;
  color: #fff;
  display: flex;
  flex-direction: column;
  transition: transform 0.28s ease, background-color 0.28s ease, color 0.28s ease;
}

.do-card:hover {
  transform: translateY(-8px);
  background: #fff;
  color: #000;
}

.do-icon {
  margin-bottom: 50px;
  font-size: 44px;
  line-height: 1;
}

.do-card h3 {
  margin: 0 0 34px;
  font-size: 22px;
  line-height: 1;
  font-weight: 900;
}

.do-card p {
  margin: auto 0 0;
  font-size: 14px;
  line-height: 1.12;
  font-weight: 800;
}

.do-offer-bottom {
  margin-top: 54px;
}

.do-offer-bottom p {
  margin: 0;
  font-size: 28px;
  line-height: 1.05;
  font-weight: 400;
}

/* Mobiel */
@media (max-width: 650px) {
  .do-inner {
    width: calc(100% - 44px);
  }

  .do-hero {
    min-height: auto;
    padding: 86px 0 62px;
  }

  .do-hero-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .do-hero-text h1 {
    font-size: 58px;
    letter-spacing: -2px;
    margin-bottom: 24px;
  }

  .do-hero-text p {
    font-size: 16px;
    margin-bottom: 20px;
  }

  .do-hero-btn {
    margin-top: 30px;
  }

  .do-hero-image img {
    max-height: 310px;
  }

  .do-recognizable {
    padding: 52px 0 56px;
  }

  .do-section-number {
    margin-bottom: 36px;
    font-size: 15px;
  }

  .do-three-grid {
    grid-template-columns: 1fr;
    gap: 44px;
  }

  .do-three-grid h2 {
    font-size: 86px;
  }

  .do-three-grid p {
    font-size: 18px;
  }

  .do-core {
    padding: 52px 0;
  }

  .do-core h2 {
    font-size: 34px;
  }

  .do-core-italic {
    font-size: 32px;
    margin-bottom: 28px;
  }

  .do-core-small {
    font-size: 15px;
  }

  .do-bring {
    padding: 52px 0 58px;
  }

  .do-bring h2 {
    font-size: 36px;
  }

  .do-arrow-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .do-card-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .do-card {
    min-height: 240px;
  }

  .do-icon {
    margin-bottom: 34px;
  }

  .do-offer-bottom p {
    font-size: 22px;
  }
}

/* ===== Wie bijt niet / DIT BEN IK 1-op-1 pagina ===== */

.about-design-inner {
  width: min(1220px, calc(100% - 96px));
  margin: 0 auto;
}

/* Hero */
.about-design-hero {
  min-height: 760px;
  padding: 145px 0 105px;
  display: flex;
  align-items: center;
}

.about-hero-grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 80px;
  align-items: center;
}

.about-hero-text h1 {
  margin: 0 0 14px;
  font-size: clamp(72px, 8vw, 112px);
  line-height: 0.86;
  font-weight: 400;
  letter-spacing: -4px;
}

.about-hero-text h1 strong {
  font-weight: 900;
}

.about-hero-subtitle {
  margin: 0 0 44px;
  font-size: 20px;
  line-height: 1;
  font-weight: 500;
}

.about-hero-copy {
  max-width: 540px;
}

.about-hero-copy p {
  margin: 0 0 28px;
  font-size: 18px;
  line-height: 1.12;
  font-weight: 500;
}

.about-hero-copy strong {
  font-weight: 900;
}

.about-hero-btn {
  margin-top: 18px;
  min-height: 48px;
  padding: 0 22px;
  border: 1.5px solid #fff;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 20px;
  font-size: 17px;
  font-weight: 900;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease;
}

.about-hero-btn:hover {
  background: #fff;
  color: #000;
  transform: translateY(-3px);
}

.about-hero-image {
  width: 100%;
  justify-self: end;
}

.about-hero-image img {
  width: 100%;
  max-height: 455px;
  object-fit: cover;
  display: block;
}

/* Witte facts sectie */
.about-facts {
  padding: 72px 0 70px;
}

.about-facts h2 {
  margin: 0 0 48px;
  font-size: clamp(56px, 6vw, 78px);
  line-height: 0.9;
  font-weight: 400;
  letter-spacing: -2px;
}

.about-facts h2 strong {
  font-weight: 900;
}

.about-facts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 120px;
}

.about-fact-block {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 20px;
  align-items: start;
}

.about-fact-icon {
  font-size: 36px;
  line-height: 1;
  color: #000;
}

.about-fact-block ul {
  margin: 0 0 28px;
  padding-left: 22px;
}

.about-fact-block li {
  font-size: 17px;
  line-height: 1.15;
  font-weight: 500;
}

.about-fact-block p {
  margin: 0;
  font-size: 18px;
  line-height: 1.1;
  font-weight: 900;
}

/* Zwarte quote sectie */
.about-question {
  padding: 76px 0 82px;
  text-align: center;
}

.about-question h2 {
  margin: 0 0 8px;
  font-size: clamp(38px, 5vw, 58px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -1px;
}

.about-question p {
  margin: 0;
  font-size: clamp(46px, 6vw, 72px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -2px;
}

/* Wat ik nu leer */
.about-learning {
  padding: 76px 0 74px;
}

.about-learning h2 {
  margin: 0 0 6px;
  font-size: clamp(58px, 7vw, 84px);
  line-height: 0.9;
  font-weight: 400;
  letter-spacing: -3px;
}

.about-learning h2 strong {
  font-weight: 900;
}

.about-learning p {
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.1;
  font-weight: 900;
}

.about-learning ul {
  margin: 0;
  padding-left: 22px;
}

.about-learning li {
  font-size: 18px;
  line-height: 1.18;
  font-weight: 500;
}

/* Footer zwart */
.about-design-footer {
  padding: 68px 0 76px;
}

.about-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 90px;
  align-items: center;
}

.about-footer-left h2 {
  margin: 0;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -2px;
}

.about-footer-tagline {
  margin: 6px 0 42px;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.about-footer-info p,
.about-footer-info a {
  display: block;
  margin: 0;
  color: #fff;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 900;
}

.about-footer-info p:first-child {
  margin-bottom: 8px;
  font-size: 16px;
}

.about-footer-right {
  padding-top: 56px;
}

.about-footer-right > p {
  margin: 0 0 36px;
  font-size: 17px;
  font-weight: 900;
}

.about-social-icon {
  background: #fff;
  color: #000;
}

.about-social-icon img {
  filter: none;
}

.about-design-footer .social-icon {
  width: 58px;
  height: 58px;
  border-radius: 12px;
}

.about-design-footer .social-icon img,
.about-design-footer .social-icon svg {
  width: 34px;
  height: 34px;
}

/* Mobiel */
@media (max-width: 650px) {
  .about-design-inner {
    width: calc(100% - 44px);
  }

  .about-design-hero {
    min-height: auto;
    padding: 88px 0 64px;
  }

  .about-hero-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .about-hero-text h1 {
    font-size: 58px;
    letter-spacing: -2px;
  }

  .about-hero-subtitle {
    font-size: 17px;
    margin-bottom: 32px;
  }

  .about-hero-copy p {
    font-size: 16px;
    margin-bottom: 22px;
  }

  .about-hero-btn {
    font-size: 14px;
    min-height: 42px;
  }

  .about-hero-image img {
    max-height: 310px;
  }

  .about-facts {
    padding: 58px 0 60px;
  }

  .about-facts h2 {
    font-size: 50px;
    margin-bottom: 38px;
  }

  .about-facts-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .about-fact-block {
    grid-template-columns: 36px 1fr;
    gap: 16px;
  }

  .about-fact-icon {
    font-size: 30px;
  }

  .about-fact-block li {
    font-size: 15px;
  }

  .about-fact-block p {
    font-size: 16px;
  }

  .about-question {
    padding: 58px 0 62px;
  }

  .about-question h2 {
    font-size: 30px;
  }

  .about-question p {
    font-size: 38px;
  }

  .about-learning {
    padding: 58px 0 60px;
  }

  .about-learning h2 {
    font-size: 48px;
  }

  .about-learning p,
  .about-learning li {
    font-size: 15px;
  }

  .about-design-footer {
    padding: 54px 0 62px;
  }

  .about-footer-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .about-footer-left h2 {
    font-size: 42px;
  }

  .about-footer-tagline {
    font-size: 15px;
    margin-bottom: 30px;
  }

  .about-footer-info p,
  .about-footer-info a {
    font-size: 16px;
  }

  .about-footer-right {
    padding-top: 0;
  }

  .about-footer-right > p {
    margin-bottom: 22px;
  }

  .about-design-footer .social-icon {
    width: 48px;
    height: 48px;
  }

  .about-design-footer .social-icon img,
  .about-design-footer .social-icon svg {
    width: 28px;
    height: 28px;
  }
}

/* ===== HOE IK WERK sectie op Wie bijt niet pagina ===== */

.work-method-page {
  background: #f7f7f7;
  color: #000;
  padding: 95px 0 0;
}

.work-method-inner {
  width: min(1220px, calc(100% - 56px));
  margin: 0 auto;
}

/* Bovenstuk */
.work-method-hero {
  min-height: 525px;
  display: grid;
  grid-template-columns: 1fr 0.55fr;
  gap: 80px;
  align-items: start;
  position: relative;
}

.work-method-hero h2 {
  margin: 0;
  font-size: clamp(78px, 10vw, 140px);
  line-height: 0.82;
  font-weight: 400;
  letter-spacing: -6px;
}

.work-method-hero h2 strong {
  display: block;
  font-weight: 900;
}

.work-method-hero > div:first-child > p {
  margin: 14px 0 56px;
  font-size: 28px;
  line-height: 1;
  font-weight: 400;
}

.work-method-btn {
  min-height: 38px;
  padding: 0 20px;
  border: 1.5px solid #000;
  border-radius: 999px;
  color: #000;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  font-weight: 900;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease;
}

.work-method-btn:hover {
  background: #000;
  color: #fff;
  transform: translateY(-3px);
}

.work-method-side-text {
  align-self: end;
  padding-bottom: 98px;
}

.work-method-side-text p {
  margin: 0;
  font-size: 32px;
  line-height: 1.05;
  font-weight: 400;
}

/* Lijst */
.work-method-list {
  border-top: 2px solid #000;
}

.work-method-step {
  display: grid;
  grid-template-columns: 370px 1fr;
  min-height: 220px;
  border-bottom: 2px solid #000;
}

.work-method-number {
  border-right: 1.5px solid #000;
  display: flex;
  align-items: center;
  padding-left: 48px;
  font-size: clamp(112px, 12vw, 158px);
  line-height: 0.8;
  font-weight: 900;
  letter-spacing: -6px;
}

.work-method-content {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
  padding: 42px 48px 42px 54px;
}

.work-method-content h3 {
  margin: 0 0 8px;
  font-size: 42px;
  line-height: 0.95;
  font-weight: 900;
  letter-spacing: -1px;
}

.work-method-content h4 {
  margin: 0 0 4px;
  font-size: 17px;
  line-height: 1.05;
  font-weight: 900;
}

.work-method-content p {
  margin: 0;
  font-size: 12px;
  line-height: 1.15;
  font-weight: 500;
  max-width: 440px;
}

.work-method-plus {
  width: 28px;
  height: 28px;
  border: 1.5px solid #000;
  border-radius: 50%;
  background: transparent;
  color: #000;
  font-size: 22px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    color 0.25s ease;
}

.work-method-plus:hover {
  background: #000;
  color: #fff;
  transform: rotate(90deg);
}

/* Mobiel */
@media (max-width: 650px) {
  .work-method-page {
    padding: 62px 0 0;
  }

  .work-method-inner {
    width: calc(100% - 44px);
  }

  .work-method-hero {
    min-height: auto;
    grid-template-columns: 1fr;
    gap: 70px;
    padding-bottom: 60px;
  }

  .work-method-hero h2 {
    font-size: 66px;
    letter-spacing: -3px;
  }

  .work-method-hero > div:first-child > p {
    font-size: 22px;
    margin-bottom: 34px;
  }

  .work-method-side-text {
    padding-bottom: 0;
  }

  .work-method-side-text p {
    font-size: 25px;
  }

  .work-method-step {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .work-method-number {
    border-right: 0;
    border-bottom: 1.5px solid #000;
    padding: 34px 0 24px;
    font-size: 92px;
  }

  .work-method-content {
    padding: 32px 0 36px;
    grid-template-columns: 1fr auto;
    gap: 18px;
  }

  .work-method-content h3 {
    font-size: 30px;
  }

  .work-method-content h4 {
    font-size: 15px;
  }

  .work-method-content p {
    font-size: 12px;
  }

  .work-method-plus {
    width: 26px;
    height: 26px;
    font-size: 20px;
  }
}

/* ===== Fix overgang WAT IK NU LEER naar HOE IK WERK ===== */

.about-learning {
  padding-bottom: 55px;
}

.work-method-page {
  padding-top: 70px;
  border-top: 2px solid #000;
}

.work-method-hero {
  min-height: auto;
  padding-bottom: 80px;
}

.work-method-side-text {
  padding-bottom: 0;
  align-self: end;
}

/* ===== Creaties footer zwart maken ===== */

.creaties-footer {
  background: #000;
  color: #fff;
}

.creaties-footer .footer-left h2,
.creaties-footer .footer-tagline,
.creaties-footer .contact-info p,
.creaties-footer .contact-info a,
.creaties-footer .footer-right p {
  color: #fff;
}

.creaties-footer .social-icon {
  background: #fff;
  color: #000;
}

.creaties-footer .social-icon img {
  filter: none;
}
/* ===== Anchor positie voor Hoe ik werk ===== */

#hoe-ik-werk {
  scroll-margin-top: 0px;
}

/* ===== Zwarte footer uitlijning fix ===== */

.about-design-footer,
.creaties-footer,
.footer.black-section {
  background: #000;
  color: #fff;
  padding: 70px 0 72px;
}

.about-design-footer .about-design-inner,
.creaties-footer .footer-inner,
.footer.black-section .footer-inner {
  width: min(1220px, calc(100% - 96px));
  max-width: 1220px;
  margin: 0 auto;
}

.about-footer-grid,
.creaties-footer .footer-inner,
.footer.black-section .footer-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 80px;
}

/* Linkerkant footer */
.about-footer-left,
.creaties-footer .footer-left,
.footer.black-section .footer-left {
  justify-self: start;
}

.about-footer-left h2,
.creaties-footer .footer-left h2,
.footer.black-section .footer-left h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 0.88;
  font-weight: 900;
  letter-spacing: -2px;
}

.about-footer-tagline,
.creaties-footer .footer-tagline,
.footer.black-section .footer-tagline {
  margin: 6px 0 42px;
  color: #fff;
  font-size: 18px;
  line-height: 1;
  font-weight: 900;
}

.about-footer-info p,
.about-footer-info a,
.creaties-footer .contact-info p,
.creaties-footer .contact-info a,
.footer.black-section .contact-info p,
.footer.black-section .contact-info a {
  display: block;
  margin: 0;
  color: #fff;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 900;
}

.about-footer-info p:first-child,
.creaties-footer .contact-info p:first-child,
.footer.black-section .contact-info p:first-child {
  margin-bottom: 8px;
  font-size: 16px;
}

/* Rechterkant footer */
.about-footer-right,
.creaties-footer .footer-right,
.footer.black-section .footer-right {
  justify-self: end;
  align-self: center;
  padding-top: 0;
  min-width: 160px;
}

.about-footer-right > p,
.creaties-footer .footer-right > p,
.footer.black-section .footer-right > p {
  margin: 0 0 28px;
  color: #fff;
  font-size: 17px;
  line-height: 1;
  font-weight: 900;
}

.about-design-footer .socials,
.creaties-footer .socials,
.footer.black-section .socials {
  display: flex;
  align-items: center;
  gap: 16px;
}

/* Witte icon-knoppen op zwarte footer */
.about-design-footer .social-icon,
.creaties-footer .social-icon,
.footer.black-section .social-icon {
  width: 58px;
  height: 58px;
  border-radius: 12px;
  background: #fff;
  color: #000;
}

.about-design-footer .social-icon img,
.creaties-footer .social-icon img,
.footer.black-section .social-icon img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter: none;
}

/* Mobiel */
@media (max-width: 650px) {
  .about-design-footer,
  .creaties-footer,
  .footer.black-section {
    padding: 54px 0 62px;
  }

  .about-design-footer .about-design-inner,
  .creaties-footer .footer-inner,
  .footer.black-section .footer-inner {
    width: calc(100% - 44px);
  }

  .about-footer-grid,
  .creaties-footer .footer-inner,
  .footer.black-section .footer-inner {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .about-footer-right,
  .creaties-footer .footer-right,
  .footer.black-section .footer-right {
    justify-self: start;
    min-width: 0;
  }

  .about-footer-left h2,
  .creaties-footer .footer-left h2,
  .footer.black-section .footer-left h2 {
    font-size: 42px;
  }

  .about-footer-tagline,
  .creaties-footer .footer-tagline,
  .footer.black-section .footer-tagline {
    margin-bottom: 30px;
    font-size: 15px;
  }

  .about-footer-info p,
  .about-footer-info a,
  .creaties-footer .contact-info p,
  .creaties-footer .contact-info a,
  .footer.black-section .contact-info p,
  .footer.black-section .contact-info a {
    font-size: 16px;
  }

  .about-design-footer .social-icon,
  .creaties-footer .social-icon,
  .footer.black-section .social-icon {
    width: 48px;
    height: 48px;
  }

  .about-design-footer .social-icon img,
  .creaties-footer .social-icon img,
  .footer.black-section .social-icon img {
    width: 28px;
    height: 28px;
  }
}

.about-design-footer .about-design-inner,
.creaties-footer .footer-inner,
.footer.black-section .footer-inner {
  width: min(1120px, calc(100% - 96px));
}

/* ===== Fix Wie bijt niet pagina structuur + anchor ===== */

#hoe-ik-werk {
  scroll-margin-top: 0;
}

.about-learning {
  padding-bottom: 60px;
}

.work-method-page {
  margin-top: 0;
  padding-top: 70px;
  border-top: 2px solid #000;
}

.work-method-hero {
  min-height: auto;
  padding-bottom: 80px;
}

.work-method-side-text {
  padding-bottom: 0;
  align-self: end;
}

/* Footer beter uitgelijnd op deze pagina */
.about-design-footer {
  padding: 70px 0 74px;
}

.about-design-footer .about-design-inner {
  width: min(1220px, calc(100% - 96px));
  margin: 0 auto;
}

.about-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 90px;
  align-items: center;
}

.about-footer-right {
  justify-self: end;
  align-self: center;
  padding-top: 0;
}

@media (max-width: 650px) {
  .about-learning {
    padding-bottom: 48px;
  }

  .work-method-page {
    padding-top: 56px;
  }

  .work-method-hero {
    padding-bottom: 56px;
  }

  .about-design-footer .about-design-inner {
    width: calc(100% - 44px);
  }

  .about-footer-grid {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .about-footer-right {
    justify-self: start;
  }
}

/* ===== Navbar zwart balkje op Hoe ik werk pagina ===== */

.hoe-ik-werk-page .site-header {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: min(1320px, calc(100% - 48px));
  min-height: 72px;
  background: #000;
  color: #fff;
  border-radius: 0;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hoe-ik-werk-page .navbar {
  padding: 0;
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 34px;
  font-size: 16px;
  font-weight: 900;
}

.hoe-ik-werk-page .navbar a {
  color: #fff;
  opacity: 1;
}

.hoe-ik-werk-page .navbar a:hover {
  opacity: 0.75;
}

/* Oogjes rechts in de zwarte balk */
.hoe-ik-werk-page .eyes {
  position: absolute;
  right: 42px;
  top: 50%;
  transform: translateY(-50%);
}

.hoe-ik-werk-page .eyes span {
  background: #fff;
}

.hoe-ik-werk-page .eyes span::after {
  background: #000;
}

/* Ruimte boven de pagina, omdat navbar fixed is */
.hoe-ik-werk-page .work-method-page {
  padding-top: 150px;
}

/* ===== Hoe ik werk pagina: navbar exact zoals de rest, maar met zwarte balk ===== */

.hoe-ik-werk-page .site-header {
  position: relative;
  top: auto;
  left: auto;
  transform: none;
  width: 100%;
  min-height: 58px;
  background: #000;
  color: #fff;
  z-index: 50;
  display: block;
}

.hoe-ik-werk-page .navbar {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 26px;
  padding-top: 16px;
  min-height: 58px;
  font-size: 11px;
  font-weight: 800;
}

.hoe-ik-werk-page .navbar a {
  color: #fff;
  opacity: 1;
}

.hoe-ik-werk-page .navbar a:hover {
  opacity: 0.75;
}

/* Oogjes exact zoals op de andere pagina's */
.hoe-ik-werk-page .eyes {
  position: absolute;
  right: 58px;
  top: 16px;
  display: flex;
  gap: 5px;
  transform: none;
}

.hoe-ik-werk-page .eyes span {
  width: 12px;
  height: 21px;
  background: #fff;
  border-radius: 50%;
  display: block;
  position: relative;
}

.hoe-ik-werk-page .eyes span::after {
  content: "";
  position: absolute;
  width: 5px;
  height: 7px;
  right: 1px;
  top: 7px;
  background: #000;
  border-radius: 50%;
}

/* Content begint netjes onder de zwarte balk */
.hoe-ik-werk-page .work-method-page {
  padding-top: 80px;
}

@media (max-width: 650px) {
  .hoe-ik-werk-page .site-header {
    position: relative;
    background: #000;
    padding-bottom: 18px;
  }

  .hoe-ik-werk-page .navbar {
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 16px;
    padding: 18px 22px 0;
    min-height: auto;
    font-size: 11px;
  }

  .hoe-ik-werk-page .eyes {
    display: none;
  }

  .hoe-ik-werk-page .work-method-page {
    padding-top: 62px;
  }
}

/* ===== Dit ben ik footer zwart ===== */

.about-design-footer {
  background: #000 !important;
  color: #fff !important;
  padding: 70px 0 74px;
}

.about-design-footer .about-footer-left h2,
.about-design-footer .about-footer-tagline,
.about-design-footer .about-footer-info p,
.about-design-footer .about-footer-info a,
.about-design-footer .about-footer-right p {
  color: #fff !important;
}

.about-design-footer .about-design-inner {
  width: min(1220px, calc(100% - 96px));
  margin: 0 auto;
}

.about-design-footer .about-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 90px;
  align-items: center;
}

.about-design-footer .about-footer-right {
  justify-self: end;
  align-self: center;
  padding-top: 0;
}

/* Witte icon-knoppen op zwarte footer */
.about-design-footer .social-icon {
  background: #fff !important;
  color: #000 !important;
}

.about-design-footer .social-icon img {
  filter: none;
}

/* ===== Project afbeeldingen op Home ===== */

.project-image {
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #b7b7b7;
  border: 1px solid #8d8d8d;
}

.project-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform 0.3s ease, filter 0.3s ease;
}

.project-card:hover .project-image img {
  transform: scale(1.06);
  filter: contrast(1.08);
}