.rtv-kdrive{margin:16px 0;padding:10px;border:1px solid #e5e5e5;border-radius:8px;background:#fff}
.rtv-kdrive-head{display:flex;gap:10px;align-items:baseline;justify-content:space-between;margin-bottom:8px}
.rtv-kdrive-path{font-size:12px;opacity:.7;word-break:break-word}
.rtv-kdrive-breadcrumb{font-size:13px;margin:6px 0 10px 0;opacity:.85;word-break:break-word}
.rtv-kdrive-breadcrumb a{text-decoration:none}
.rtv-kdrive-table{width:100%;border-collapse:collapse}
.rtv-kdrive-table th,.rtv-kdrive-table td{padding:8px 6px;border-bottom:1px solid #eee;font-size:14px;vertical-align:top}
.rtv-kdrive-table th{text-align:left;font-weight:600}
.rtv-kdrive-size,.rtv-kdrive-mod{white-space:nowrap}
.rtv-kdrive-error{border-color:#f3c2c2;background:#fff7f7}
.rtv-kdrive-foot{margin-top:8px;font-size:13px;opacity:.8}
.rtv-kdrive-debug{margin-top:10px}
.rtv-kdrive-debug pre{max-height:260px;overflow:auto;background:#f7f7f7;padding:10px;border-radius:8px;border:1px solid #eee;font-size:12px;white-space:pre-wrap;word-break:break-word}
.rtv-kdrive-cover{display:inline-block;width:28px;height:20px;border-radius:4px;overflow:hidden;margin-right:6px;vertical-align:middle;background:#f0f0f0}
.rtv-kdrive-cover img{width:100%;height:100%;object-fit:cover;display:block}

/* Gallery/grid view */
.rtv-kdrive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:12px}
.rtv-kdrive-card{border-radius:14px;overflow:hidden;box-shadow:0 1px 8px rgba(0,0,0,.08);background:#fff}
.rtv-kdrive-card-media{height:170px;background:#f0f0f0;position:relative}
.rtv-kdrive-card-media img{width:100%;height:100%;object-fit:cover;display:block}

/* Smooth thumb loading (grid + folder covers) */
.rtv-kdrive-card-media img,
.rtv-kdrive-cover img{
  opacity: .20;
  transition: opacity .25s ease;
}
.rtv-kdrive-card-media img.rtv-kdrive-thumb--loaded,
.rtv-kdrive-cover img.rtv-kdrive-thumb--loaded{
  opacity: 1;
}
.rtv-kdrive-card-media img.rtv-kdrive-thumb--loading,
.rtv-kdrive-cover img.rtv-kdrive-thumb--loading{
  opacity: .20;
}


/* Portrait photos: avoid aggressive cropping in the grid (desktop) */
.rtv-kdrive-card-media img.rtv-kdrive-orient-portrait,
.rtv-kdrive-cover img.rtv-kdrive-orient-portrait,
.rtv-kdrive-cover--big img.rtv-kdrive-orient-portrait{
  object-fit: contain;
  background: #000;
}

/* Respect EXIF rotation where supported */
.rtv-kdrive-card-media img,
.rtv-kdrive-cover img,
.rtv-kdrive-lightbox__stage img{
  image-orientation: from-image !important;
}
.rtv-kdrive-card-media--video{position:relative;}
.rtv-kdrive-card-media--video::after{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:58px;
  height:58px;
  border-radius:999px;
  background:
    rgba(0,0,0,0.45)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M8 5v14l11-7z'/%3E%3C/svg%3E")
    center/26px 26px
    no-repeat;
  pointer-events:none;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.rtv-kdrive-video-thumb--ready{opacity:1;}
.rtv-kdrive-cover--big{display:block;width:100%;height:100%}
.rtv-kdrive-cover--big img{width:100%;height:100%;object-fit:cover;display:block}
.rtv-kdrive-fileicon{height:100%;display:flex;align-items:center;justify-content:center;font-size:42px}
.rtv-kdrive-card-label{background:#5b1a6f;color:#fff;padding:10px 12px;font-weight:600}
.rtv-kdrive-card-link{color:#fff;text-decoration:none}
.rtv-kdrive-card-link:hover{text-decoration:underline}

/* Search highlighting */
.rtv-kdrive mark.rtv-kdrive-hl{padding:0 2px;border-radius:3px}
.rtv-kdrive-table mark.rtv-kdrive-hl{background:rgba(91,26,111,.18)}
.rtv-kdrive-card-label mark.rtv-kdrive-hl{background:rgba(255,255,255,.35);color:#fff}
.rtv-kdrive-more{margin-top:14px;text-align:center}
.rtv-kdrive-more-btn{padding:10px 14px;border:0;border-radius:10px;cursor:pointer}

/* When grid view is enabled, hide the table */

/* Hide table only after grid is rendered */
.rtv-kdrive[data-view="grid"][data-grid-ready="1"] table{display:none}


.rtv-kdrive-toolbar{display:flex; flex-direction:column; gap:10px; margin:8px 0 12px;}

/* === Compact topbar (kruimelpad links + icon knoppen rechts) === */
.rtv-kdrive-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  background:rgba(0,0,0,.06);
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
}
.rtv-kdrive-topbar-left{min-width:0; display:flex; align-items:center;}
.rtv-kdrive-topbar-actions{display:flex; align-items:center; gap:10px; flex:0 0 auto;}
.rtv-kdrive-topbar-actions .rtv-kdrive-icbtn{width:44px;height:44px; box-shadow: 0 8px 18px rgba(0,0,0,.24);} 
.rtv-kdrive-topbar-actions .rtv-kdrive-icbtn:hover{box-shadow: 0 10px 22px rgba(0,0,0,.28);} 
.rtv-kdrive-icbtn--small{width:44px;height:44px;}

.rtv-kdrive-breadcrumb{display:flex; align-items:center; gap:6px; min-width:0; overflow:auto; white-space:nowrap; -webkit-overflow-scrolling:touch;}
.rtv-kdrive-breadcrumb a,
.rtv-kdrive-breadcrumb span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  text-decoration:none;
  color:inherit;
}
.rtv-kdrive-breadcrumb a:hover{background:rgba(0,0,0,.08);}
.rtv-kdrive-breadcrumb .rtv-kdrive-bc-sep{opacity:.45; padding:0 2px;}
.rtv-kdrive-homeic{font-size:16px; opacity:.8; transform: translateY(-1px);}

/* Tools panel: search + sort (default dicht) */
.rtv-kdrive-tools-panel{display:none; align-items:center; gap:10px; flex-wrap:wrap; width:100%;}
.rtv-kdrive-tools-panel.is-open{display:flex;}
.rtv-kdrive-search{max-width:260px; width:100%; padding:8px 10px; border:1px solid #d7d7d7; border-radius:10px; font-size:14px; flex:1 1 240px; min-width: 180px;}
.rtv-kdrive-sortwrap{display:flex; align-items:center; gap:6px; flex: 1 1 260px; min-width: 220px;}
.rtv-kdrive-sortlabel{font-size:13px; opacity:.8; white-space:nowrap;}
.rtv-kdrive-sort{padding:8px 10px; border:1px solid #d7d7d7; border-radius:10px; font-size:14px; background:#fff;}
@media (max-width: 720px){
  .rtv-kdrive-topbar{border-radius:18px;}
  .rtv-kdrive-topbar-actions{gap:8px;}
  .rtv-kdrive-topbar-actions .rtv-kdrive-icbtn{width:42px;height:42px;}
  .rtv-kdrive-tools-panel{flex-direction:column; align-items:stretch;}
  .rtv-kdrive-search{max-width:none; width:100%; min-width:0; box-sizing:border-box;}
  .rtv-kdrive-sortwrap{width:100%; min-width:0;}
  .rtv-kdrive-sort{width:100%; box-sizing:border-box;}
}

/* Lightbox */
.rtv-kdrive-noscroll{overflow:hidden;}
.rtv-kdrive-lightbox{position:fixed; inset:0; z-index:99999; display:none;}
.rtv-kdrive-lightbox.is-open{display:block;}
.rtv-kdrive-lightbox__backdrop{position:absolute; inset:0; background:rgba(0,0,0,.72);}
.rtv-kdrive-lightbox__panel{position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); width:95vw; height:95vh; max-width:95vw; max-height:95vh; background:#111; border-radius:14px; overflow:hidden; display:flex; flex-direction:column;}

/* Fullscreen mode (photos): make the panel truly fill the screen */
.rtv-kdrive-lightbox__panel:fullscreen{
  left:0; top:0; transform:none;
  width:100vw; height:100vh;
  max-width:none; max-height:none;
  border-radius:0;
}
.rtv-kdrive-lightbox__panel:-webkit-full-screen{
  left:0; top:0; transform:none;
  width:100vw; height:100vh;
  max-width:none; max-height:none;
  border-radius:0;
}
@media (max-width: 600px){ .rtv-kdrive-lightbox__panel{position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); width:95vw; height:95vh; max-width:95vw; max-height:95vh; background:#111; border-radius:14px; overflow:hidden; display:flex; flex-direction:column;} }
.rtv-kdrive-lightbox__stage{flex:1; display:flex; align-items:center; justify-content:center; padding:10px;}
.rtv-kdrive-lightbox__stage{position:relative; z-index:1;}
.rtv-kdrive-lightbox__stage img{width:auto; height:auto; max-width:100%; max-height:100%; object-fit:contain; background:#000; border-radius:10px;}
.rtv-kdrive-lightbox__stage video{max-width:100%; max-height:100%; width:100%; height:100%; object-fit:contain; background:#000; border-radius:10px;}
.rtv-kdrive-lightbox__meta{display:flex; justify-content:space-between; align-items:center; gap:10px; padding:10px 12px; color:#fff; font-size:14px; background:rgba(0,0,0,.35);}
.rtv-kdrive-lightbox__dl{color:#fff; text-decoration:none; border:1px solid rgba(255,255,255,.25); padding:6px 10px; border-radius:10px;}
.rtv-kdrive-lightbox__close{position:absolute; top:8px; right:8px; width:36px; height:36px; border-radius:10px; border:none; background:rgba(255,255,255,.12); color:#fff; font-size:22px; cursor:pointer;}
.rtv-kdrive-lightbox__close,
.rtv-kdrive-lightbox__nav,
.rtv-kdrive-lightbox__meta{z-index:10;}
.rtv-kdrive-lightbox__nav{position:absolute; top:50%; transform:translateY(-50%); width:44px; height:54px; border-radius:12px; border:none; background:rgba(255,255,255,.12); color:#fff; font-size:28px; cursor:pointer;}
.rtv-kdrive-lightbox__prev{left:8px;}
.rtv-kdrive-lightbox__next{right:8px;}

/* Light placeholder while lazy images load */
.rtv-kdrive-grid img[src^="data:image/gif;base64"]{
  opacity: 0.35;
}

/* Lightbox: place download button bottom-left */
.rtv-kdrive-lightbox__meta{
  position: absolute;
  left: 14px;
  right: auto;
  bottom: 14px;
  top: auto;
  display: flex;
  gap: 10px;
  align-items: center;
}
.rtv-kdrive-lightbox__download{
  display: inline-block;
  padding: 8px 10px;
  border-radius: 10px;
  text-decoration: none;
  font-weight: 600;
  background: rgba(0,0,0,0.55);
  color: #fff;
}
.rtv-kdrive-lightbox__download:hover{ text-decoration: underline; }

.rtv-kdrive-lightbox__panel{position:fixed; left:50%; top:50%; transform:translate(-50%,-50%); width:95vw; height:95vh; max-width:95vw; max-height:95vh; background:#111; border-radius:14px; overflow:hidden; display:flex; flex-direction:column;}

/* Lightbox slideshow control */
.rtv-kdrive-lightbox__play{
  border: 0;
  background: rgba(0,0,0,0.55);
  color: #fff;
  padding: 8px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
}
.rtv-kdrive-lightbox__play:hover{ background: rgba(0,0,0,0.7); }

/* Lightbox actions (play + download) */
.rtv-kdrive-lightbox__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.rtv-kdrive-lightbox__play{
  border: 0;
  background: rgba(0,0,0,0.55);
  color: #fff;
  padding: 8px 10px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
}
.rtv-kdrive-lightbox__play:hover{ background: rgba(0,0,0,0.7); }

/* Icon buttons like play/pause/stop (round) */
.rtv-kdrive-lightbox__meta{
  display:flex;
  gap:10px;
  align-items:center;
}
.rtv-kdrive-lightbox__play,
.rtv-kdrive-lightbox__stop{
  width:44px;
  height:44px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,0.75);
  background: rgba(0,0,0,0.35);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
}
.rtv-kdrive-lightbox__fs{
  width:44px;
  height:44px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,0.75);
  background: rgba(0,0,0,0.35);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0;
  color:#fff;
  user-select:none;
}
.rtv-kdrive-lightbox__fs:hover{ background: rgba(0,0,0,0.55); }
.rtv-kdrive-lightbox__fs.is-active{ background: rgba(255,255,255,0.12); }
.rtv-kdrive-fs-ic{ font-size: 20px; line-height: 1; }
.rtv-kdrive-lightbox__play:hover,
.rtv-kdrive-lightbox__stop:hover{
  background: rgba(0,0,0,0.55);
}
.rtv-kdrive-ic{
  display:block;
  width:0;
  height:0;
}
.rtv-kdrive-ic--play{
  border-top:10px solid transparent;
  border-bottom:10px solid transparent;
  border-left:16px solid rgba(255,255,255,0.92);
  margin-left:3px;
}
.rtv-kdrive-ic--pause{
  width:16px;
  height:18px;
  background: transparent;
  position: relative;
}
.rtv-kdrive-ic--pause:before,
.rtv-kdrive-ic--pause:after{
  content:'';
  position:absolute;
  top:0;
  width:5px;
  height:18px;
  background: rgba(255,255,255,0.92);
  border-radius:2px;
}
.rtv-kdrive-ic--pause:before{ left:0; }
.rtv-kdrive-ic--pause:after{ right:0; }

.rtv-kdrive-ic--stop{
  width:16px;
  height:16px;
  background: rgba(255,255,255,0.92);
  border-radius:3px;
}

/* Fullscreen: make the panel use the whole screen */
.rtv-kdrive-lightbox__panel:fullscreen,
.rtv-kdrive-lightbox__panel:-webkit-full-screen{
  left: 0 !important;
  top: 0 !important;
  transform: none !important;
  width: 100vw !important;
  height: 100vh !important;
  max-width: none !important;
  max-height: none !important;
  border-radius: 0 !important;
}

/* Fullscreen: keep a bit of breathing room so images don't feel overly "in your face" */
.rtv-kdrive-lightbox__panel:fullscreen .rtv-kdrive-lightbox__stage,
.rtv-kdrive-lightbox__panel:-webkit-full-screen .rtv-kdrive-lightbox__stage{
  padding: 28px !important;
}

/* Hide the loading label text ("Laden...") */
.rtv-kdrive-status,
.rtv-kdrive-loading {
  display: none !important;
}

/* Grid caption: keep same purple block height (even with 1 line) */
.rtv-kdrive-grid .rtv-kdrive-card__label,
.rtv-kdrive-grid .rtv-kdrive-grid__label,
.rtv-kdrive-grid .rtv-kdrive-item__label,
.rtv-kdrive-grid .rtv-kdrive-card__footer,
.rtv-kdrive-grid .rtv-kdrive-grid-item__label {
  min-height: 64px; /* roughly 2 lines */
  display: flex;
  align-items: center;
}
.rtv-kdrive-grid .rtv-kdrive-grid-item__label,
.rtv-kdrive-grid .rtv-kdrive-card__label,
.rtv-kdrive-grid .rtv-kdrive-item__label{
  width: 100%;
  box-sizing: border-box;
}


/* Lightbox controls: nicer PREV/NEXT pills + round close button */
.rtv-kdrive-lightbox__close{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.55);
  display: grid;
  place-items: center;
  font-size: 28px;
  line-height: 1;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.rtv-kdrive-lightbox__close:hover{ background: rgba(0,0,0,.75); }

.rtv-kdrive-lightbox__nav{
  height: 46px;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 800;
  font-size: 12px;
}

.rtv-kdrive-lightbox__prev{ background: rgba(220,53,69,.85); left: 14px; }
.rtv-kdrive-lightbox__next{ background: rgba(13,110,253,.85); right: 14px; }
.rtv-kdrive-lightbox__prev:hover{ background: rgba(220,53,69,.95); }
.rtv-kdrive-lightbox__next:hover{ background: rgba(13,110,253,.95); }

.rtv-kdrive-lb-icon{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
}

@media (max-width: 640px){
  .rtv-kdrive-lb-label{ display:none; }
  .rtv-kdrive-lightbox__nav{ padding: 6px 10px; }
}


/* Accent color variables (override in Extra CSS if you want)
   Example:
   .rtv-kdrive, .rtv-kdrive-container{--rtv-kdrive-accent:#5b1a6f;}
*/
.rtv-kdrive-container{
  --rtv-kdrive-accent:#5b1a6f;
  --rtv-kdrive-accent-hover:#4a155a;
  --rtv-kdrive-accent-contrast:#ffffff;
}

/* Lightbox: make sure controls are always clickable above media */
.rtv-kdrive-lightbox__close,
.rtv-kdrive-lightbox__nav,
.rtv-kdrive-lightbox__meta{
  z-index: 10;
}

/* Apply accent color to cards/labels */
.rtv-kdrive-card{
  background: var(--rtv-kdrive-accent);
}
.rtv-kdrive-grid .rtv-kdrive-grid-item__label,
.rtv-kdrive-grid .rtv-kdrive-card__label,
.rtv-kdrive-grid .rtv-kdrive-item__label,
.rtv-kdrive-grid .rtv-kdrive-card__footer{
  background: var(--rtv-kdrive-accent);
  color: var(--rtv-kdrive-accent-contrast);
}
.rtv-kdrive-grid .rtv-kdrive-grid-item__label *,
.rtv-kdrive-grid .rtv-kdrive-card__label *,
.rtv-kdrive-grid .rtv-kdrive-item__label *,
.rtv-kdrive-grid .rtv-kdrive-card__footer *{
  color: inherit;
}

/* Lightbox navigation buttons */
.rtv-kdrive-lightbox .rtv-kdrive-lb-prev,
.rtv-kdrive-lightbox .rtv-kdrive-lb-next{
  background: var(--rtv-kdrive-accent);
  color: var(--rtv-kdrive-accent-contrast);
}
.rtv-kdrive-lightbox .rtv-kdrive-lb-prev:hover,
.rtv-kdrive-lightbox .rtv-kdrive-lb-next:hover{
  background: var(--rtv-kdrive-accent-hover);
}

/* "Meer laden" button */
.rtv-kdrive-more-btn{
  background: var(--rtv-kdrive-accent);
  color: var(--rtv-kdrive-accent-contrast);
}
.rtv-kdrive-more-btn:hover{
  background: var(--rtv-kdrive-accent-hover);
}


/* Smooth lightbox transitions */
.rtv-kdrive-lightbox .rtv-kdrive-lb-media img{
  will-change: opacity, transform;
  transition: opacity 180ms ease, transform 220ms ease;
  transform: translate3d(0,0,0);
}
.rtv-kdrive-lightbox .rtv-kdrive-lb-media img.is-fading{
  opacity: 0;
  transform: translate3d(0,10px,0);
}
@media (prefers-reduced-motion: reduce){
  .rtv-kdrive-lightbox .rtv-kdrive-lb-media img{
    transition: none !important;
  }
}

/* Video badge on grid items */
.rtv-kdrive-grid .rtv-kdrive-thumb-wrap{ position: relative; }
.rtv-kdrive-grid .rtv-kdrive-grid-item.is-video .rtv-kdrive-thumb-wrap:after{
  content:'▶';
  position:absolute;
  left: 10px;
  bottom: 10px;
  width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background: rgba(0,0,0,0.45);
  color: #fff;
  font-weight: 700;
  line-height: 1;
}

/* --- Lightbox: better alignment + keep metadata clear of video controls --- */
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta{
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,0.45);
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta [data-lb-title]{
  flex: 1;
  min-width: 0;
  font-weight: 600;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__dl{
  display:inline-flex;
  align-items:center;
}
/* In video mode, move the overlay up so it doesn't sit on top of the native controls */
.rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__meta{ bottom: 64px; }
@media (max-width: 600px){
  .rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__meta{ bottom: 84px; }
}

/* === Icon buttons (zoals voorbeeld: zwart rond, wit icoon) === */
.rtv-kdrive-icbtn{
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 0;
  /* Force white icon color (some themes override button{color:...} with !important) */
  background: #000 !important;
  color: #fff !important;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease;
}
.rtv-kdrive-icbtn:hover{
  background: #111;
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0,0,0,.34);
}
.rtv-kdrive-icbtn:active{ transform: translateY(0); }
.rtv-kdrive-icbtn svg{ width: 24px; height: 24px; display:block; }

/* Text-glyph fallback for icons (used for close/refresh when themes break SVG rendering) */
.rtv-kdrive-icbtn .rtv-kdrive-glyph{
  color: #fff !important;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 800;
  line-height: 1;
  font-size: 28px;
  display: inline-block;
  transform: translateY(-1px);
}
.rtv-kdrive-lightbox__close .rtv-kdrive-glyph{ font-size: 34px; }

/* Extra-safe overrides (higher specificity) for themes that load after plugin CSS */
.rtv-kdrive .rtv-kdrive-icbtn,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn{
  background: #000 !important;
  color: #fff !important;
}
.rtv-kdrive .rtv-kdrive-icbtn svg,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn svg{
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Ensure icons stay visible even if the theme applies global SVG rules */
.rtv-kdrive .rtv-kdrive-icbtn svg,
.rtv-kdrive .rtv-kdrive-icbtn svg *,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn svg,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn svg *{
  fill: #fff !important;
  stroke: #fff !important;
}

/* Some themes set svg/path fill to 'none' globally; re-assert for our icon buttons */
.rtv-kdrive .rtv-kdrive-icbtn svg path,
.rtv-kdrive .rtv-kdrive-icbtn svg circle,
.rtv-kdrive .rtv-kdrive-icbtn svg rect,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn svg path,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn svg circle,
.rtv-kdrive-lightbox .rtv-kdrive-icbtn svg rect{
  fill: #fff !important;
  stroke: #fff !important;
}

/* Toolbar refresh button (iets kleiner) */
.rtv-kdrive-refresh{ width: 44px; height: 44px; }
.rtv-kdrive-refresh svg{ width: 22px; height: 22px; }
.rtv-kdrive-ic--refresh{
  width: 22px;
  height: 22px;
  display:block;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M17.65 6.35A7.95 7.95 0 0 0 12 4V1L7 6l5 5V7a5 5 0 1 1-5 5H5a7 7 0 1 0 12.65-5.65z'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* Lightbox controls positions with icon buttons */
.rtv-kdrive-lightbox__close{ top: 14px; right: 14px; }

/* Keep the close button always on top */
.rtv-kdrive-lightbox__close{ z-index: 1001 !important; }
.rtv-kdrive-lightbox__nav{
  width: 62px;
  height: 62px;
  padding: 0;
  border-radius: 999px;
  border: 0;
  background: #000;
}
.rtv-kdrive-lightbox__prev{ left: 16px; }
.rtv-kdrive-lightbox__next{ right: 16px; }

/* Hide old label/icon spans if any exist from earlier versions */
.rtv-kdrive-lb-label, .rtv-kdrive-lb-icon{ display:none !important; }

/* Play button: swap play/pause icons */
.rtv-kdrive-lightbox__play .rtv-kdrive-icwrap--pause{ display:none; }
.rtv-kdrive-lightbox__play.is-playing .rtv-kdrive-icwrap--play{ display:none; }
.rtv-kdrive-lightbox__play.is-playing .rtv-kdrive-icwrap--pause{ display:inline-flex; }

/* Download icon button: keep link looking like a button */
.rtv-kdrive-lightbox__dl{ text-decoration:none; }

/* Grid video overlay: use solid black circle + white play */
.rtv-kdrive-card-media--video::after{
  width:64px;
  height:64px;
  background:
    #000
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M8 5v14l11-7z'/%3E%3C/svg%3E")
    center/28px 28px
    no-repeat;
  box-shadow: 0 14px 34px rgba(0,0,0,.35);
}

/* Remove the extra bottom-left play badge (veroorzaakte dubbele play-icoontjes) */
.rtv-kdrive-grid .rtv-kdrive-grid-item.is-video .rtv-kdrive-thumb-wrap:after{
  content: '' !important;
  display: none !important;
}


.rtv-kdrive-lightbox__close{ width:62px; height:62px; }


/* v1.0.0: duidelijke video-aanduiding in de tegelweergave */
.rtv-kdrive-card-media--video{position:relative;}
.rtv-kdrive-play-badge{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:999px;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.62);color:#fff;font-size:22px;line-height:1;z-index:2;
  box-shadow:0 6px 18px rgba(0,0,0,.25);pointer-events:none;
}

/* =========================================================
   v1.1.0 - De Werven styling
   Rustiger, lichter en minder technisch. Deze overrides staan bewust onderaan
   zodat ze oude 1.0.x lightbox-regels overschrijven.
   ========================================================= */
:root{
  --dw-bg:#f4f1ea;
  --dw-panel:#ffffff;
  --dw-ink:#16212b;
  --dw-muted:#6b7280;
  --dw-line:rgba(22,33,43,.12);
  --dw-slate:#63717f;
  --dw-slate-dark:#465460;
  --dw-green:#708c5c;
  --dw-red:#c83b36;
  --dw-yellow:#f0b23b;
}

.rtv-kdrive,
.rtv-kdrive-container{
  --rtv-kdrive-accent:var(--dw-slate) !important;
  --rtv-kdrive-accent-hover:var(--dw-slate-dark) !important;
  --rtv-kdrive-accent-contrast:#fff !important;
  color:var(--dw-ink);
}

.rtv-kdrive{
  border:1px solid var(--dw-line);
  border-radius:18px;
  background:#fff;
  box-shadow:0 12px 34px rgba(22,33,43,.06);
}

.rtv-kdrive-head h2,
.rtv-kdrive-head h3{
  color:var(--dw-ink);
  letter-spacing:-.02em;
}

.rtv-kdrive-topbar{
  background:linear-gradient(135deg, #f8f6f1 0%, #ebe7de 100%) !important;
  border:1px solid rgba(22,33,43,.08) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75), 0 10px 26px rgba(22,33,43,.08) !important;
}

.rtv-kdrive-breadcrumb a,
.rtv-kdrive-breadcrumb span{
  color:var(--dw-ink) !important;
}
.rtv-kdrive-breadcrumb a:hover{
  background:rgba(99,113,127,.12) !important;
}

.rtv-kdrive-card{
  border-radius:18px !important;
  background:#fff !important;
  border:1px solid rgba(22,33,43,.08) !important;
  box-shadow:0 14px 30px rgba(22,33,43,.10) !important;
  transition:transform .16s ease, box-shadow .16s ease;
}
.rtv-kdrive-card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 38px rgba(22,33,43,.16) !important;
}
.rtv-kdrive-card-media{
  background:#e8e4dc !important;
}
.rtv-kdrive-card-label,
.rtv-kdrive-grid .rtv-kdrive-grid-item__label,
.rtv-kdrive-grid .rtv-kdrive-card__label,
.rtv-kdrive-grid .rtv-kdrive-item__label,
.rtv-kdrive-grid .rtv-kdrive-card__footer{
  background:linear-gradient(135deg, var(--dw-slate) 0%, var(--dw-slate-dark) 100%) !important;
  color:#fff !important;
}
.rtv-kdrive-card-link{
  color:#fff !important;
}

/* Fotografie/video-tegel: De Werven play-accent */
.rtv-kdrive-card-media--video::after,
.rtv-kdrive-play-badge{
  background:
    linear-gradient(135deg, var(--dw-red), var(--dw-yellow)) !important;
  box-shadow:0 14px 30px rgba(22,33,43,.30) !important;
}

/* Popup basis */
.rtv-kdrive-lightbox__backdrop{
  background:
    radial-gradient(circle at 18% 12%, rgba(112,140,92,.30), transparent 34%),
    radial-gradient(circle at 82% 88%, rgba(240,178,59,.22), transparent 34%),
    rgba(20,27,34,.84) !important;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.rtv-kdrive-lightbox__panel{
  width:min(94vw, 1480px) !important;
  height:min(92vh, 920px) !important;
  max-width:94vw !important;
  max-height:92vh !important;
  background:linear-gradient(180deg, #ffffff 0%, #f4f1ea 100%) !important;
  border:1px solid rgba(255,255,255,.50) !important;
  border-radius:24px !important;
  box-shadow:0 30px 90px rgba(0,0,0,.45) !important;
  padding:16px !important;
  overflow:hidden !important;
}
.rtv-kdrive-lightbox__panel::before{
  content:'';
  position:absolute;
  left:18px;
  right:18px;
  top:0;
  height:5px;
  border-radius:0 0 999px 999px;
  background:linear-gradient(90deg, var(--dw-red), var(--dw-yellow), var(--dw-green), var(--dw-slate));
  z-index:2;
}

.rtv-kdrive-lightbox__stage{
  flex:1 1 auto !important;
  min-height:0;
  padding:54px 18px 88px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(244,241,234,.92)) !important;
  border-radius:18px !important;
  border:1px solid rgba(22,33,43,.08) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75) !important;
}
.rtv-kdrive-lightbox__stage img,
.rtv-kdrive-lightbox__stage video{
  border-radius:16px !important;
  background:#121820 !important;
  box-shadow:0 16px 44px rgba(22,33,43,.26) !important;
}

/* Informatie-balk: van somber zwart naar De Werven kaart */
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta{
  left:28px !important;
  right:28px !important;
  bottom:24px !important;
  padding:12px 14px !important;
  border-radius:16px !important;
  background:rgba(255,255,255,.92) !important;
  color:var(--dw-ink) !important;
  border:1px solid rgba(22,33,43,.10) !important;
  box-shadow:0 12px 32px rgba(22,33,43,.18) !important;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta [data-lb-title]{
  color:var(--dw-ink) !important;
  font-weight:800 !important;
  letter-spacing:-.01em;
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta [data-lb-title]::before{
  content:'De Werven media';
  display:block;
  color:var(--dw-slate);
  font-size:12px;
  line-height:1.2;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:2px;
}

/* Video: extra ruimte, zodat de native videoknoppen vrij blijven */
.rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__stage{
  padding-bottom:120px !important;
}
.rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__meta{
  bottom:24px !important;
}
.rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__meta [data-lb-title]::before{
  content:'De Werven video';
}

/* Knoppen in De Werven stijl */
.rtv-kdrive-lightbox .rtv-kdrive-icbtn,
.rtv-kdrive .rtv-kdrive-icbtn{
  background:var(--dw-slate) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.22) !important;
  box-shadow:0 12px 28px rgba(22,33,43,.22) !important;
}
.rtv-kdrive-lightbox .rtv-kdrive-icbtn:hover,
.rtv-kdrive .rtv-kdrive-icbtn:hover{
  background:var(--dw-slate-dark) !important;
  transform:translateY(-1px);
}
.rtv-kdrive-lightbox__close{
  top:26px !important;
  right:26px !important;
  width:54px !important;
  height:54px !important;
  background:var(--dw-red) !important;
}
.rtv-kdrive-lightbox__close:hover{
  background:#a8322e !important;
}
.rtv-kdrive-lightbox__nav{
  width:58px !important;
  height:58px !important;
  background:rgba(99,113,127,.92) !important;
}
.rtv-kdrive-lightbox__prev{ left:24px !important; }
.rtv-kdrive-lightbox__next{ right:24px !important; }

.rtv-kdrive-lightbox__play,
.rtv-kdrive-lightbox__stop,
.rtv-kdrive-lightbox__fs,
.rtv-kdrive-lightbox__dl{
  width:46px !important;
  height:46px !important;
  background:var(--dw-slate) !important;
  border:0 !important;
}
.rtv-kdrive-lightbox__dl{
  position:relative;
}
.rtv-kdrive-lightbox__dl::after{
  content:'Download';
  position:absolute;
  right:54px;
  top:50%;
  transform:translateY(-50%);
  color:var(--dw-ink);
  font-weight:700;
  font-size:13px;
  white-space:nowrap;
  opacity:.86;
}

.rtv-kdrive-more-btn{
  border-radius:999px !important;
  background:linear-gradient(135deg, var(--dw-slate), var(--dw-slate-dark)) !important;
  box-shadow:0 12px 26px rgba(22,33,43,.16);
}

/* Fullscreen moet de hele ruimte blijven gebruiken */
.rtv-kdrive-lightbox__panel:fullscreen,
.rtv-kdrive-lightbox__panel:-webkit-full-screen{
  width:100vw !important;
  height:100vh !important;
  max-width:none !important;
  max-height:none !important;
  border-radius:0 !important;
  padding:18px !important;
}
.rtv-kdrive-lightbox__panel:fullscreen .rtv-kdrive-lightbox__stage,
.rtv-kdrive-lightbox__panel:-webkit-full-screen .rtv-kdrive-lightbox__stage{
  padding:60px 24px 96px !important;
}

@media (max-width: 720px){
  .rtv-kdrive-lightbox__panel{
    width:96vw !important;
    height:94vh !important;
    border-radius:18px !important;
    padding:10px !important;
  }
  .rtv-kdrive-lightbox__stage{
    padding:58px 8px 104px !important;
  }
  .rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta{
    left:16px !important;
    right:16px !important;
    bottom:14px !important;
    align-items:flex-start !important;
  }
  .rtv-kdrive-lightbox__actions{
    gap:7px !important;
  }
  .rtv-kdrive-lightbox__play,
  .rtv-kdrive-lightbox__stop,
  .rtv-kdrive-lightbox__fs,
  .rtv-kdrive-lightbox__dl{
    width:42px !important;
    height:42px !important;
  }
  .rtv-kdrive-lightbox__dl::after{ display:none; }
  .rtv-kdrive-lightbox__close{
    top:18px !important;
    right:18px !important;
    width:48px !important;
    height:48px !important;
  }
  .rtv-kdrive-lightbox__nav{
    width:48px !important;
    height:48px !important;
  }
  .rtv-kdrive-lightbox__prev{ left:12px !important; }
  .rtv-kdrive-lightbox__next{ right:12px !important; }
}


/* =========================================================
   v1.1.1 - afwerking De Werven popup
   Alleen polijstwerk: knoppen, actiebalk en download-uitlijning.
   ========================================================= */
.rtv-kdrive-lightbox__panel{
  padding:18px !important;
}
.rtv-kdrive-lightbox__stage{
  padding:54px 18px 100px !important;
}
.rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__stage{
  padding:54px 18px 126px !important;
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta{
  left:30px !important;
  right:30px !important;
  bottom:24px !important;
  min-height:54px;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:18px !important;
  padding:12px 14px !important;
  box-sizing:border-box !important;
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta [data-lb-title]{
  min-width:0 !important;
  padding-right:10px !important;
}
.rtv-kdrive-lightbox .rtv-kdrive-lightbox__actions{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:12px !important;
  flex:0 0 auto !important;
  white-space:nowrap !important;
}
.rtv-kdrive-lightbox__play,
.rtv-kdrive-lightbox__stop,
.rtv-kdrive-lightbox__fs{
  width:44px !important;
  height:44px !important;
  min-width:44px !important;
  padding:0 !important;
}
.rtv-kdrive-lightbox__dl{
  width:auto !important;
  min-width:118px !important;
  height:44px !important;
  padding:0 14px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  border-radius:999px !important;
  font-size:13px !important;
  line-height:1 !important;
  font-weight:800 !important;
  text-decoration:none !important;
  white-space:nowrap !important;
  box-sizing:border-box !important;
}
.rtv-kdrive-lightbox__dl::after{
  content:none !important;
  display:none !important;
}
.rtv-kdrive-lightbox__dl .rtv-kdrive-download-text{
  display:inline-block !important;
  color:#fff !important;
  font-size:13px !important;
  line-height:1 !important;
}
.rtv-kdrive-lightbox__dl .rtv-kdrive-dl-icon,
.rtv-kdrive-lightbox__dl .rtv-kdrive-dl-icon svg{
  display:block !important;
  width:18px !important;
  height:18px !important;
  flex:0 0 auto !important;
}
.rtv-kdrive-lightbox__close{
  width:48px !important;
  height:48px !important;
  top:24px !important;
  right:24px !important;
  box-shadow:0 10px 24px rgba(22,33,43,.24) !important;
}
.rtv-kdrive-lightbox__close .rtv-kdrive-glyph{
  font-size:30px !important;
  transform:translateY(-2px) !important;
}
.rtv-kdrive-lightbox__nav{
  width:52px !important;
  height:52px !important;
  min-width:52px !important;
  opacity:.96;
  box-shadow:0 10px 24px rgba(22,33,43,.22) !important;
}
.rtv-kdrive-lightbox__prev{ left:20px !important; }
.rtv-kdrive-lightbox__next{ right:20px !important; }
.rtv-kdrive-lightbox__stage img,
.rtv-kdrive-lightbox__stage video{
  max-width:100% !important;
  max-height:100% !important;
}
@media (max-width: 900px){
  .rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta{
    left:20px !important;
    right:20px !important;
    gap:12px !important;
  }
  .rtv-kdrive-lightbox__dl{
    min-width:44px !important;
    width:44px !important;
    padding:0 !important;
  }
  .rtv-kdrive-lightbox__dl .rtv-kdrive-download-text{
    display:none !important;
  }
}
@media (max-width: 640px){
  .rtv-kdrive-lightbox__panel{
    padding:10px !important;
  }
  .rtv-kdrive-lightbox__stage{
    padding:58px 8px 112px !important;
  }
  .rtv-kdrive-lightbox.is-video .rtv-kdrive-lightbox__stage{
    padding:58px 8px 128px !important;
  }
  .rtv-kdrive-lightbox .rtv-kdrive-lightbox__meta{
    left:14px !important;
    right:14px !important;
    bottom:12px !important;
    padding:10px !important;
  }
  .rtv-kdrive-lightbox .rtv-kdrive-lightbox__actions{
    gap:7px !important;
  }
  .rtv-kdrive-lightbox__play,
  .rtv-kdrive-lightbox__stop,
  .rtv-kdrive-lightbox__fs,
  .rtv-kdrive-lightbox__dl{
    width:40px !important;
    height:40px !important;
    min-width:40px !important;
  }
  .rtv-kdrive-lightbox__close{
    width:44px !important;
    height:44px !important;
    top:16px !important;
    right:16px !important;
  }
  .rtv-kdrive-lightbox__nav{
    width:44px !important;
    height:44px !important;
    min-width:44px !important;
  }
  .rtv-kdrive-lightbox__prev{ left:10px !important; }
  .rtv-kdrive-lightbox__next{ right:10px !important; }
}
