.wpu-wrap{max-width:640px;margin:0 auto;padding:18px 14px 24px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#2b2b2b}
@media (min-width:960px){
  /* On desktop give the gallery more breathing room so the grid doesn't look cramped */
  .wpu-wrap{max-width:1040px}
  .wpu-card{padding:26px 22px}
}
.wpu-card{background:linear-gradient(180deg,rgba(176,139,87,.10),rgba(176,139,87,0)),#fff;border:1px solid rgba(176,139,87,.18);border-radius:18px;padding:22px 18px;box-shadow:0 10px 30px rgba(0,0,0,.08);text-align:center}
.wpu-logo img{max-width:220px;height:auto;margin:0 auto 10px;display:block}
.wpu-title{font-size:23px;margin:8px 0 6px;letter-spacing:-.2px}
.wpu-sub{margin:0 0 14px;color:#7a7a7a;font-size:14px;line-height:1.4}
.wpu-file{display:none !important}
.wpu-btn{width:100%;max-width:520px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;border-radius:12px;border:0;background:linear-gradient(180deg,#d6b47b,#b08b57);color:#fff;font-size:18px;font-weight:700;box-shadow:0 10px 22px rgba(0,0,0,.12);cursor:pointer}
.wpu-btn[disabled]{opacity:.72;cursor:not-allowed}
.wpu-help{margin-top:10px;font-size:12px;color:#6f6f6f}
.wpu-toast{margin-top:12px;font-size:13px;min-height:18px;color:#245b2a}
.wpu-toast.is-error{color:#9a1d1d}
.wpu-section{margin-top:18px}
.wpu-section-title{background:#f0e6d8;border:1px solid rgba(176,139,87,.22);border-radius:14px;padding:12px 14px;font-weight:700;color:#5b4630}
.wpu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:14px 6px}
@media (min-width:640px){.wpu-grid{grid-template-columns:repeat(4,1fr)}}
.wpu-item{position:relative;border-radius:14px;overflow:hidden;border:2px solid rgba(176,139,87,.25);box-shadow:0 8px 18px rgba(0,0,0,.08);background:#fff}
.wpu-item img{width:100%;height:160px;object-fit:cover;display:block}
.wpu-badge{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.55);color:#fff;font-size:12px;padding:6px 8px;border-radius:999px}
.wpu-progress{position:absolute;left:0;right:0;bottom:0;height:6px;background:rgba(0,0,0,.12)}
.wpu-progress>span{display:block;height:100%;width:0%;background:rgba(176,139,87,.95)}
.wpu-download-bar{padding:4px 6px 0;text-align:center}
.wpu-download{display:inline-flex;gap:8px;align-items:center;justify-content:center;padding:10px 14px;border-radius:12px;border:1px solid rgba(176,139,87,.25);background:#fff;color:#5b4630;text-decoration:none;font-weight:700}
.wpu-download:active{transform:translateY(1px)}
.wpu-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;padding:16px;z-index:99999}
.wpu-lightbox.is-open{display:flex}
.wpu-lightbox-inner{width:min(920px,100%);background:#fff;border-radius:18px;overflow:hidden;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:center;padding:14px}
.wpu-lightbox img{max-width:100%;height:auto;border-radius:12px}
.wpu-lightbox-close{position:absolute;right:10px;top:10px;border:0;background:rgba(0,0,0,.12);border-radius:999px;width:38px;height:38px;cursor:pointer;font-size:18px}
.wpu-lightbox-dl{display:inline-block;margin:10px 0 2px;padding:10px 12px;border-radius:12px;background:linear-gradient(180deg,#d6b47b,#b08b57);color:#fff;text-decoration:none;font-weight:800}
.wpu-toast.is-error{color:#8a1f1f}
.wpu-section{margin-top:16px}
.wpu-section-title{background:#efe3d6;border:1px solid rgba(176,139,87,.22);color:#4a3a27;border-radius:12px;padding:10px 12px;font-weight:700}
.wpu-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media (min-width:680px){.wpu-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (min-width:960px){.wpu-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}}
.wpu-item{position:relative;border-radius:14px;overflow:hidden;background:#f6f6f6;border:2px solid rgba(176,139,87,.25)}
.wpu-item img{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.wpu-item video.wpu-video-thumb{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#000}
.wpu-badge{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.55);color:#fff;font-size:12px;padding:6px 8px;border-radius:999px}
.wpu-progress{position:absolute;left:0;right:0;bottom:0;height:6px;background:rgba(255,255,255,.45)}
.wpu-progress > div{height:100%;width:0;background:rgba(176,139,87,.95)}
.wpu-x{position:absolute;right:8px;top:8px;width:30px;height:30px;border-radius:999px;border:0;background:rgba(0,0,0,.45);color:#fff;font-size:18px;line-height:30px;cursor:pointer}
.wpu-download-bar{margin:18px 0 0;text-align:center}
.wpu-download{display:inline-block;padding:12px 14px;border-radius:12px;border:1px solid rgba(176,139,87,.25);background:#fff;text-decoration:none;color:#4a3a27;font-weight:700}
.wpu-download:hover{box-shadow:0 10px 22px rgba(0,0,0,.08)}
/* lightbox */
.wpu-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.72);display:none;align-items:center;justify-content:center;padding:18px;z-index:999999}
.wpu-lightbox.is-open{display:flex}
.wpu-lightbox-inner{max-width:860px;width:100%;background:#111;border-radius:16px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.wpu-lightbox-inner img{max-width:100%;max-height:80vh;width:auto;height:auto;display:block;margin:0 auto}
.wpu-lightbox-close{position:absolute;right:10px;top:10px;width:36px;height:36px;border-radius:999px;border:0;background:rgba(255,255,255,.18);color:#fff;font-size:20px;cursor:pointer}
.wpu-lightbox-dl{position:absolute;left:10px;top:10px;background:rgba(255,255,255,.85);color:#111;padding:10px 12px;border-radius:12px;text-decoration:none;font-weight:700}
@media (min-width:768px){
  /* Avoid overlapping the player's controls on desktop */
  .wpu-lightbox-dl{top:10px;bottom:auto}
}

/* Video support */
.wpu-item-video .wpu-badge{background:rgba(0,0,0,.55)}
.wpu-item-video:after{content:'▶';position:absolute;inset:auto 10px 10px auto;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(0,0,0,.45);color:#fff;font-weight:800;font-size:16px}
.wpu-lightbox-video{max-width:100%;max-height:80vh;width:auto;height:auto;display:none;background:#000;margin:0 auto;object-fit:contain}
.wpu-lightbox-inner.is-video img{display:none}
.wpu-lightbox-inner.is-video .wpu-lightbox-video{display:block}

/* Video loading hint (better perceived speed on slow internet) */
.wpu-lightbox-inner.is-video.is-loading::after{
  content:"Načítavam video…";
  position:absolute;
  left:50%;top:50%;transform:translate(-50%,-50%);
  color:#fff;
  background:rgba(0,0,0,.55);
  padding:10px 12px;
  border-radius:12px;
  font-weight:700;
}

/* Secondary CTA */
.wpu-btn-secondary{
  margin-top:10px;
  background:#fff;
  color:#4a3a27;
  border:1px solid rgba(176,139,87,.35);
  box-shadow:0 10px 22px rgba(0,0,0,.06);
}

/* Recorder modal (video wish) */
.wpu-recorder{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:16px;background:rgba(0,0,0,.72);z-index:2147483647}
.wpu-recorder.is-open{display:flex}
.wpu-recorder-inner{width:min(480px,92vw);background:#fff;border-radius:18px;overflow:hidden;position:relative;padding:12px 10px calc(12px + env(safe-area-inset-bottom));box-shadow:0 20px 60px rgba(0,0,0,.35);max-height:calc(100vh - 20px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.wpu-recorder-close{position:absolute;right:10px;top:10px;width:36px;height:36px;border-radius:999px;border:0;background:rgba(0,0,0,.10);font-size:20px;cursor:pointer}
/* Title/subtitle removed in v1.2.3 to keep recorder compact on mobile */
.wpu-recorder-preview{width:100%;aspect-ratio:9/16;max-height:58vh;background:#000;border-radius:14px;object-fit:cover;display:block}
.wpu-recorder-preview.is-mirrored{transform:scaleX(-1)}
.wpu-recorder-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:12px 2px}
.wpu-small-btn{border:1px solid rgba(176,139,87,.35);background:#fff;border-radius:12px;padding:8px 10px;font-weight:800;color:#4a3a27;cursor:pointer}
.wpu-small-btn[disabled]{opacity:.6;cursor:not-allowed}
#wpu-recorder-flash[aria-pressed="true"]{background:#f0e6d8}
.wpu-recorder-timer{font-weight:900;color:#4a3a27;background:#f0e6d8;border:1px solid rgba(176,139,87,.22);border-radius:12px;padding:8px 10px;min-width:82px;text-align:center}
.wpu-recorder-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.wpu-recorder-actions .wpu-btn{max-width:none;flex:1;padding:10px 12px;font-size:15px;border-radius:12px}

/* When recorder/lightbox is open, hide the theme header/menu so users don't see the site navigation behind/over it */
body.wpu-modal-open header,
body.wpu-modal-open nav,
body.wpu-modal-open .site-header,
body.wpu-modal-open #masthead,
body.wpu-modal-open .wp-site-blocks > header,
body.wpu-modal-open .menu-toggle,
body.wpu-modal-open .nav-toggle,
body.wpu-modal-open .mobile-nav-toggle,
body.wpu-modal-open .hamburger,
body.wpu-modal-open .header-toggle,
body.wpu-modal-open .wp-block-navigation__responsive-container-open,
body.wpu-modal-open .wp-block-navigation__responsive-container-close{
  display:none !important;
}
/* iOS Safari scroll lock helper (JS sets body to fixed) */
html.wpu-scroll-lock,
body.wpu-scroll-lock{overflow:hidden !important;}
.wpu-recorder-foot{margin-top:10px;font-size:12px;color:#6f6f6f;text-align:center}

.wpu-recorder-zoom{display:flex;align-items:center;gap:10px;margin:6px 2px 12px;padding:8px 10px;border:1px solid rgba(176,139,87,.22);border-radius:12px;background:#faf5ee}
.wpu-recorder-zoom input[type=range]{flex:1}
.wpu-zoom-txt{font-weight:800;color:#4a3a27;font-size:13px}
.wpu-zoom-label{font-weight:900;color:#4a3a27;font-size:13px;min-width:52px;text-align:right}

/* --- v1.2.8 hotfixes --- */
/* Force intended typography even if the theme overrides h2/p styles */
.wpu-wrap .wpu-title{font-size:23px !important;}

/* Ensure the download button in lightbox is always readable */
.wpu-lightbox-dl{color:#111 !important;}

/* Prevent any theme grid auto-flow overrides that could create strange gaps */
.wpu-grid{grid-auto-flow:row;}

/* Fix: prevent theme clearfix pseudo-elements from creating empty first grid cell */
#wpu-grid::before,
#wpu-grid::after,
.wpu-grid::before,
.wpu-grid::after{content:none !important; display:none !important; height:0 !important; width:0 !important;}

/* In-app browser hint (Instagram/Facebook webview) */
.wpu-inapp{display:none;flex-direction:column;align-items:stretch;gap:10px;margin:0 0 12px;padding:12px 14px;border-radius:16px;border:1px solid rgba(176,139,87,.25);background:#fff;box-shadow:0 8px 22px rgba(0,0,0,.05)}
.wpu-inapp.is-show{display:flex}
.wpu-inapp-text{font-size:13px;line-height:1.35;color:#4a3a27;font-weight:700}
.wpu-inapp-open{width:100%;display:block;text-align:center;font-weight:900;color:#4a3a27;background:#f0e6d8;border:1px solid rgba(176,139,87,.25);padding:10px 12px;border-radius:12px;text-decoration:none}
.wpu-inapp-open:active{transform:translateY(1px)}

/* Load more (pagination) */
.wpu-load-more-wrap{display:flex;justify-content:center;margin-top:14px}
.wpu-load-more{border:1px solid rgba(176,139,87,.35);background:#fff;border-radius:14px;padding:10px 14px;font-weight:900;color:#4a3a27;cursor:pointer;min-width:180px}
.wpu-load-more[disabled]{opacity:.65;cursor:not-allowed}
.wpu-load-more:active{transform:translateY(1px)}


/* Delete icon (only for items uploaded by this device) */
.wpu-delete-btn{
  position:absolute;
  right:8px;
  top:8px;
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(0,0,0,.55);
  color:#fff;
  font-size:16px;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 22px rgba(0,0,0,.28);
}
.wpu-delete-btn svg{display:block}
.wpu-delete-btn:hover{background:rgba(0,0,0,.65)}
.wpu-delete-btn:active{transform:translateY(1px)}

/* Confirm delete modal */
.wpu-confirm{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:16px;background:rgba(0,0,0,.72);z-index:2147483647}
.wpu-confirm.is-open{display:flex}
.wpu-confirm-inner{width:min(380px,92vw);max-height:84vh;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35);padding:12px;display:flex;flex-direction:column}
.wpu-confirm-title{font-weight:900;color:#2b2b2b;margin:2px 2px 12px}
.wpu-confirm-preview{border-radius:14px;overflow:hidden;background:#111;display:flex;align-items:center;justify-content:center;min-height:0;flex:1;max-height:52vh}
.wpu-confirm-preview img{width:100%;height:100%;display:block;object-fit:contain}
.wpu-confirm-preview video{width:100%;height:100%;display:block;background:#000;object-fit:contain}
.wpu-confirm-actions{display:flex;gap:10px;margin-top:12px}
.wpu-confirm-actions .wpu-btn{flex:1;font-size:15px;padding:10px 12px}
