/* ============================================================
   SECTION #SCROLL - HIGH END AGENCY OPTIMALISATIE
   ============================================================ */

#scroll.scroll-pin-section {
  height: 300vh; /* De scroll-lengte voor de wiel-animatie */
  position: relative;
  background: transparent;
}

#scroll .sticky-container {
  position: sticky;
  top: 0;
  height: 100vh;
  display: grid;
  place-items: center;
  overflow: hidden;
  
  /* EXACTE HERO GRADIENTS VOOR CONSISTENTE BRANDING */
  background: 
    radial-gradient(900px 600px at 18% 88%, rgba(168, 120, 255, 0.35), transparent 60%),
    radial-gradient(800px 520px at 10% 92%, rgba(255, 140, 180, 0.18), transparent 62%),
    radial-gradient(900px 700px at 78% 18%, rgba(120, 200, 255, 0.18), transparent 60%),
    linear-gradient(180deg, var(--bg-1), var(--bg-0));
    
  /* Fixatie zorgt dat de kleuren niet 'mee-scrollen' maar op hun plek blijven */
  background-size: 100% 100%;
  background-position: center center;
  background-attachment: fixed;
  
  /* Voorbereiding op de zachte glow-transitie via JS */
  transition: background 0.4s ease-out;
}

#scroll .scroll-wheel {
  /* Zijdezachte rotatie zonder tekstvervorming */
  transition: transform 0.1s linear;
  will-change: transform;
}

#scroll .wheel-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  background: white;
  border-radius: 22px;
  display: grid;
  place-items: center;
  
  /* High-end diepte effecten */
  box-shadow: 0 15px 45px rgba(12, 17, 23, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.8);
  transition: all 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  z-index: 10;
}

#scroll .wheel-logo:hover {
  /* Subtiele interactie voor muisgebruikers */
  transform: translate(-50%, -50%) scale(1.05);
  box-shadow: 0 25px 60px rgba(12, 17, 23, 0.12);
}

#scroll .wheel-logo img {
  width: 42px;
  height: auto;
  object-fit: contain;
}
.hero-photo {
  position: relative;
  overflow: hidden; /* Zorgt dat de foto binnen de afgeronde hoeken blijft */
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
}

.hero-image-portrait {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Zorgt dat je gezicht niet vervormt maar de kaart vult */
  display: block;
}

/* De overlay tekst iets transparanter maken zodat je gezicht goed zichtbaar blijft */
.hero-years {
  background: rgba(255, 255, 255, 0.1); 
  backdrop-filter: blur(5px);
  pointer-events: none; /* Zorgt dat je niet per ongeluk op de tekst klikt */
}
/* Zorg dat de kaart de afbeelding niet blokkeert */
.hero-photo {
    background: none !important; /* Verwijdert de witte achtergrond */
    padding: 0 !important;       /* Verwijdert eventuele witruimte rond de foto */
    overflow: hidden;            /* Cruciaal voor de afgeronde hoeken */
    display: block;              /* Voorkomt witruimte onder de afbeelding */
}

.hero-image-portrait {
    width: 100%;
    height: 100%;
    object-fit: cover;           /* Zorgt dat de foto de kaart vult zonder vervorming */
    object-position: center;     /* Centreert je gezicht in de kaart */
    display: block;
    border-radius: 28px;         /* Matcht de radius van de kaart */
}

/* De wrapper die alles bij elkaar houdt */
.stack-wrapper {
    position: relative;
    /* Zorg dat de achtergrondkleur matcht met de volgende sectie voor een naadloze overgang */
    background-color: #0a0a0b; 
}

/* De Hero blijft 'plakken' aan de bovenkant */
.sticky-hero {
    position: sticky;
    top: 0;
    height: 100vh; /* Vult het volledige scherm */
    z-index: 1;    /* Ligt onder de actie-sectie */
    overflow: hidden;
    display: flex;
    align-items: center;
}

/* De Actie sectie schuift over de Hero heen */
.pricing-section {
    position: relative;
    z-index: 2;    /* Ligt BOVENOP de hero */
    
    /* Schaduw aan de bovenkant geeft diepte aan de 'overlap' */
    box-shadow: 0 -20px 50px rgba(0, 0, 0, 0.3); 
    
    /* Zorg dat er geen witruimte tussen de secties zit */
    margin-top: 0; 
}

/* 1. Verklein de tekst zodat deze in de afbeelding past */
#portfolio .project-title {
    font-size: clamp(2rem, 4vw, 3rem); /* Was 4rem, nu schaalbaar en kleiner */
    line-height: 1.1;
    max-width: 90%; /* Voorkomt dat tekst uit de kaart loopt */
}

/* 2. Fix de positie van de parallax container */
#portfolio .parallax-text {
    bottom: 40px; /* Iets omhoog van de rand */
    left: 40px;
    /* Belangrijk: we gaan de transform via JS verfijnen */
}

/* Subtiele extra voor de categorie tekst */
#portfolio .category {
    font-size: 0.75rem;
    letter-spacing: 2px;
}
/* De klasse die de header laat wegvliegen */
.site-header.header-hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none; /* Voorkomt dat je per ongeluk op onzichtbare links klikt */
}
/* Zorg dat verbergen ALTIJD prioriteit heeft boven de witte achtergrond */
.site-header.header-hidden {
    transform: translateY(-100%) !important;
    opacity: 0 !important;
    transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.3s ease !important;
}
/* Forceer de eerste stap naar volledige zichtbaarheid bij aanvang */
.step:first-child {
    opacity: 1 !important;
}

