:root {color-scheme: dark;}

  html,
  body {
      height: 100%;
      overflow: hidden;
  }

.hkk-viewer {
      position: fixed;
      inset: 0;
      height: 100vh;
      height: 100dvh;
      display: grid;
      grid-template-rows: minmax(0, 1fr) auto auto auto;
      overflow: hidden;
      background: rgba(0, 0, 0, 0.0);
      color: #fff;
  }

.hkk-viewer.is-thumbs-hidden {grid-template-rows: minmax(0, 1fr) auto 0;}
.hkk-stage {
    display: flex;
    flex-direction: column;
    align-items: center; /* Centreert de foto en de tekst horizontaal */
    justify-content: center; /* Centreert het geheel verticaal in de beschikbare ruimte */
    position: relative;
	width: 100%;
	padding: 0 10px;
	box-sizing: border-box;
}
.hkk-photo {
	max-width: 100%;
    max-height: 80vh; /* Of de hoogte die je nu gebruikt, zodat er ruimte blijft voor tekst */
    display: block;   /* Voorkomt een ongewenste witruimte aan de onderkant van een img */
	border-radius: 11px;
	border: 3px solid transparent;
	transition: border-color 0.25s ease;
}
.hkk-photo[hidden] {
      display: none !important;
      width: 0 !important;
      height: 0 !important;
      opacity: 0 !important;
      visibility: hidden !important;
  }
.hkk-empty {
      padding: 18px 22px;
      border-radius: 8px;
      background: rgba(0, 0, 0, 0.5);
      font-size: 15px;
      line-height: 1.45;
	  border: none;
}
.hkk-button {
      appearance: none;
      border: 0;
      border-radius: 8px;
      background: transparent;
      color: #fff;
      cursor: pointer;
      transition: background 0.2s ease, opacity 0.2s ease;
  }

.hkk-button:hover,
.hkk-button:focus-visible {
      color: #c4a808;
      outline: none;
  }

.hkk-nav {
      position: absolute;
      top: 0;
      bottom: 0;
      width: 50%; /* Elke knop beslaat nu exact de helft van het scherm */
      height: 100%;
      transform: none; /* Niet meer nodig aangezien de knop de volle hoogte heeft */
      z-index: 5; /* Ligt nu als beschermplaat over de foto */
      cursor: pointer;
      pointer-events: auto; /* Altijd klikbaar voor de bescherming */
  }

  /* De navigatie-vlakken zijn links en rechts gepositioneerd */
.hkk-prev { left: 0; }
.hkk-next { right: 0; }

  /* NIEUW: Dit stylt de zichtbare pijltjes binnenin de grote knoppen */
.hkk-nav span {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      font-size: 40px;
      font-weight: 900;
      line-height: 1;
      color: #fff;      
      /* Begin onzichtbaar voor de mooie overgang */
      opacity: 0;
      transition: opacity 0.3s ease;
  }

  /* Positioneer de pijltjes op hun originele plek aan de zijkanten */
.hkk-prev span { left: 14px; }
.hkk-next span { right: 14px; }

 /* Wanneer de knop de klasse 'is-active' krijgt, lichten we de SPAN (het pijltje) op */
.hkk-nav.is-active {opacity: 1;}
.hkk-nav.is-active span {opacity: 1;}

.hkk-caption-row {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    margin-top: 9px; /* Dit is de exacte, vaste afstand onder ELK type foto (panorama of landscape) */
    width: 100%;
    max-width: 1280px; /* Of de breedte die jij mooi vindt aansluiten */
    padding: 0 10px;
    box-sizing: border-box;
	z-index: 11;
}
.hkk-caption {
      min-height: 38px;
      max-height: 96px;
      overflow: auto;
      padding: 0px 10%;
      color: #fff;
      font-size: 14px;
      line-height: 1.4;
      text-align: center;
	  letter-spacing: 1px;
  }
.hkk-caption a {
    color: #c4a808;
    text-decoration: none;
}
.hkk-caption a:hover {
    color: #fff;
}
.hkk-strip {
      display: flex;
      gap: 8px;
      min-height: 101px;
      max-height: 101px;
      padding: 8px 10px 8px 10px;
      overflow-x: auto;
      overflow-y: hidden;
      /* background: rgba(16, 16, 16, 0.76); */
      -webkit-overflow-scrolling: touch;
  }

.hkk-viewer.is-thumbs-hidden .hkk-strip {
      min-height: 0;
      height: 0;
      max-height: 0;
      padding-top: 0;
      padding-bottom: 0;
      overflow: hidden;
  }

.hkk-thumb {
      flex: 0 0 85px;
      width: 85px;
      height: 85px;
      padding: 0;
      border: 3px solid transparent;
      border-radius: 7px;
      background: #111;
      cursor: pointer;
      overflow: hidden;
      opacity: 0.72;
  }

.hkk-thumb[aria-current="true"] {
      border-color: #fff; /* #c4a808 HeikkiPut.com Geel */
      opacity: 1;
  }

.hkk-thumb img {
      width: 100%;
      height: 100%;
      display: block;
      object-fit: cover;
  }

/* ===== Setting Menu Sidebar ===== */
.hkk-menu-sidebar {
    position: fixed;
    top: 39px;         /* Startpositie van de bovenste knop */
    left: 0px;
    transform: translateX(1px);
    z-index: 999;    
    display: flex;
    flex-direction: column;
    gap: 0px; /* Vaste afstand tussen de knoppen */
    pointer-events: auto; /* Zorgt ervoor dat muisklikken gegarandeerd doorkomen */
	
	/* STANDAARD STATUS: Ingeklapt en semi-transparant */
    opacity: 0.3;
    transform: translateX(-40px); /* Schuift de knoppen grotendeels van het scherm af */
    transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.4s ease;
}
/* DICHTBIJ STATUS: Zodra de muis binnen bv. 100px komt (via JS) */
.hkk-menu-sidebar.is-visible {
    opacity: 1;
    transform: translateX(1px); /* Originele positie */
}

.hkk-menu-sidebar svg {
    width: 100%;
    height: 100%;
    display: block;
}
.hkk-thumb-toggle,
.hkk-font-toggle,
.hkk-border-toggle {
    width: 52px;
    height: auto;
    display: block;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    margin: 0;
    opacity: 1;
    transition: opacity 0.4s ease, transform 0.4s ease;
}
.hkk-thumb-toggle {
	opacity: 0.2;
}
.hkk-thumb-toggle:hover {
	opacity: 1;
}
.hkk-thumb-svg {
    fill: #fff; /* Begin-kleur */
    transition: fill 0.4s ease; /* Zorgt voor het langzaam verkleuren */
}
.hkk-thumb-toggle[aria-pressed="true"] {
    opacity: 1; /* Maakt de hele knop vager */
}
.hkk-thumb-toggle[aria-pressed="true"] .hkk-thumb-svg {
    fill: #555; /* Verandert vloeiend de kleur van de 3 kleine vierkantjes */
	opacity: 0.5;
}
/* ===== Font Toggle - Start ================ */
.hkk-font-toggle {
    border: 2px solid rgba(255, 255, 255, 0.1);
    color: #555; /* Standaard gedimde kleur (inactief) */
    width: 36px;
    font-size: 12px;
    font-weight: bold;
    border-radius: 4px;
    -webkit-user-select: none;
    margin: 5px 8px;
    display: inline-block;
    transition: border-color 0.3s ease, background 0.3s ease, color 0.3s ease; 
}

.hkk-font-toggle span { font-size: 16px; }

/* 1. HOVER STATUS: Licht smooth op naar wit */
.hkk-font-toggle:hover {
    border-color: #fff;
    background: rgba(255, 255, 255, 1);
    color: #000;
}

/* 2. ACTIEVE STATUS: Geselecteerd / Groot lettertype (aria-pressed="true") */
/* Blijft volledig opgelicht (wit met zwarte letters), net als bij de hover! */
.hkk-font-toggle[aria-pressed="true"] {
    border-color: #fff;
    background: rgba(255, 255, 255, 1);
    color: #000;
}
/* Font Toggle END */
/* ===== Border Toggle Start ================= */
.hkk-viewer.has-border .hkk-photo {
    border-color: #fff !important;
}
.hkk-border-toggle svg {
    width: 100%;
    height: 100%;
    display: block;
	stroke-width: 5px;
}
.hkk-border-toggle:hover svg {
	stroke: #fff;
	border-color: #fff;
}
/* Zet alle transities netjes klaar */
.hkk-border-toggle .hkk-frame-svg {
    transition: stroke 0.25s ease;
}
.hkk-border-toggle svg circle,
.hkk-border-toggle svg path {
    transition: fill 0.25s ease, opacity 0.25s ease;
}
.hkk-border-toggle:hover .hkk-frame-svg {
    stroke: #fff !important;
    opacity: 1 !important;
}

.hkk-border-toggle:hover svg circle,
.hkk-border-toggle:hover svg path {
    fill: #fff !important;
    opacity: 1 !important;
}
/* ==========================================
   STATUS: KADER STAAT AAN (aria-pressed="true")
   ========================================== */
.hkk-border-toggle[aria-pressed="true"] .hkk-frame-svg {
    stroke: #fff; /* Wit kader in de knop (of #c4a808 voor je accentgeel) */
}

.hkk-border-toggle[aria-pressed="true"] svg circle,
.hkk-border-toggle[aria-pressed="true"] svg path {
    fill: #fff;
    opacity: 0.9;
}

/* ==========================================
   STATUS: KADER STAAT UIT (aria-pressed="false")
   ========================================== */
.hkk-border-toggle[aria-pressed="false"] .hkk-frame-svg {
    stroke: #555; /* Donkergrijs/gedimd kader in de knop */
	opacity: 0.5;
}

.hkk-border-toggle[aria-pressed="false"] svg circle,
.hkk-border-toggle[aria-pressed="false"] svg path {
    fill: #555;
    opacity: 0.5;
}
/* ===== Border Toggle END ===== */

.hkk-caption-row.has-large-font .hkk-caption {
    font-size: 18px !important;
    line-height: 1.5; /* Iets meer regelafstand voor betere leesbaarheid */
}
.hkk-counter {
      position: absolute;
      right: 15px;  /* Matcht de padding-right van de .hkk-caption-row */
      bottom: 7px;  /* Plakt hem strak tegen de onderkant van de rij */      
      color: #666;
      font-size: 13px;
      font-family: sans-serif;
      user-select: none;
  }
.hkk-scale-indicator {
	  display: none; /* Uitgeschakeld > Geeft formaat van de foto weer zoals getoont op het scherm */
      position: absolute;
      top: 5px;
      right: 5px;
      z-index: 10;
      padding: 4px 8px;
      border-radius: 4px;
      background: rgba(0, 0, 0, 0.3);
      font-family: sans-serif;
      font-size: 10px;
      font-weight: bold;
      user-select: none;
      cursor: pointer; 
      transition: background 0.2s ease, transform 0.1s ease;
	  opacity: 0.3;
  }

  /* Subtiel effect als je er met de muis boven zweeft */
  .hkk-scale-indicator:hover {
	  background: rgba(0, 0, 0, 0.95);
	  opacity: 1;
	  transition: opacity 0.4s ease;	
}
  .hkk-scale-indicator:active {transform: scale(0.95);}

/* Groen voor 1% t/m 100% (binnen originele kwaliteit) */
  .hkk-scale-indicator.is-safe {color: #2ecc71 !important;}

  /* Rood voor 101% en hoger (kwaliteitsverlies door upscaling) */
  .hkk-scale-indicator.is-stretched {color: #e74c3c !important;}

  /* NIEUW: Deze CSS-klasse dwingt de foto naar exact 100% van zijn eigen pixels */
  .hkk-photo.is-forced-pixel-perfect {
      width: auto !important;
      height: auto !important;
      max-width: none !important;
      max-height: none !important;
  }
/* ===== Hoofdmenu aanpassen voor viewer ===== */
.container {
	opacity: 0.3;
}
.container:hover {
	opacity: 1;
	transition: opacity 0.25s ease;
}
#menu {
	display: none;
	visibility: hidden;
}
/* ================================= 
	END Regular CSS - Start Small Screen CSS
   ================================= */
@media (max-width: 720px) {
.container {
	opacity: 0.3;
	}
.hkk-viewer {
    /* Schakelt het standaard swipen van de browser uit (zoals geschiedenis navigeren of pull-to-refresh) */
    touch-action: pan-y; 
    }
.hkk-stage {
	padding: 0px 10px;
    }
.hkk-nav {
	top: auto;
    bottom: 18px;
    width: 42px;
    height: 42px;
    transform: none;
    font-size: 30px;
    pointer-events: auto; 
    }
.hkk-thumb {
	flex: 0 0 65px;
	width: 65px;
	height: 65px;
	}
.hkk-thumb-toggle {
	display: none; visibility: hidden;
	}
.hkk-font-toggle {
	display: none;
	visibility: hidden;
	}
.hkk-border-toggle {
	display: none;
	visibility: hidden;
	}
.hkk-scale-indicator {
	display: none;
	visibility: hidden;
	}
.hkk-counter {
	display: none;
	visibility: hidden;
    }
.hkk-prev {left: 12px;}
.hkk-next {right: 12px;}
.hkk-caption-row {

    }
.hkk-caption {
    min-height: 38px;
	padding: 0px 3px;
	max-height: 120px;
    font-size: 13px;
	overflow: scroll;
    }
.hkk-strip {
    min-height: 67px;
    max-height: 67px;
    padding: 3px 5px;
    }
#title {display: none;}
}