/* ============================================================
   VMFK – design.css (opryddet)
   - Dubletter fjernet
   - Regler samlet i logiske afsnit
   - Mobil-overrides samlet (max-width:700px)
   ============================================================ */

/* =========================
   CSS Variables / Base
   ========================= */
:root{
  --bg:#6E8CB5;
  --text:#333;
  --box-bg:#fff;
  --accent:#6E8CB5;
  --nav-bg:#fff;
  --border:#ddd;
}

/* =========================
   Page / Background
   ========================= */
body{
  margin:0;
  font-family:Arial, sans-serif;
  color:var(--text);

  /* Desktop baggrund */
  background-color:var(--bg);
  background-image:url("/media/background.jpg");
  background-position:center center;
  background-size:cover;
  background-repeat:no-repeat;
  background-attachment:fixed;
}

/* =========================
   Header / Nav
   ========================= */
.vmfk-header{
  width:100%;
  box-sizing:border-box;
  margin:0;
  padding:15px 20px;
  display:flex;
  justify-content:center;
  align-items:center;
  position:relative;
  background-color:var(--nav-bg);
  border-radius:0;
}

.vmfk-header h1{
  margin:0;
  font-size:24px;
  color:var(--accent);
  display:flex;
  align-items:center;
  gap:10px;
}

.vmfk-header img.logo,
.vmfk-header .header-logo{
  height:64px;
  width:auto;
  border-radius:50%;
  display:block;
}

.vmfk-header .header-left{
  position:absolute;
  left:20px;
  display:flex;
  align-items:center;
  gap:15px;
}

.vmfk-header .header-left a.header-link,
.vmfk-header .header-link{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:inherit;
}

.vmfk-header nav{
  display:flex;
  gap:20px;
  justify-content:center;
  align-items:center;
}

.vmfk-header nav a{
  text-decoration:none;
  color:var(--accent);
  font-weight:bold;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:42px;
  box-sizing:border-box;
}

.nav-disabled{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:42px;
  padding:10px 20px;
  box-sizing:border-box;
  font-weight:bold;
  color:var(--accent);
  opacity:.6;
  cursor:not-allowed;
}

.vmfk-mobile-nav{
  display:flex;
  flex-direction:column;
  background:#fff;
  padding:15px;
  position:absolute;
  top:70px;
  right:20px;
  border-radius:10px;
  box-shadow:0 0 10px rgba(0,0,0,.2);
  z-index:10000;
}

.vmfk-mobile-nav[hidden]{ display:none !important; }

.vmfk-mobile-nav a{
  padding:10px 0;
  color:var(--accent);
  font-weight:bold;
  text-decoration:none;
}

.vmfk-header .hamburger{
  display:none;
  flex-direction:column;
  cursor:pointer;
  gap:5px;
  position:absolute;
  right:20px;
  background:transparent;
  border:none;
  padding:0;
}

.vmfk-header .hamburger div{
  width:28px;
  height:3px;
  background-color:var(--accent);
  border-radius:3px;
}

.vmfk-header .hamburger:focus{ outline:none; }
.vmfk-header .hamburger:focus-visible{
  outline:2px solid rgba(110,140,181,.8);
  outline-offset:3px;
  border-radius:6px;
}

html.vmfk-embedded .vmfk-header,
body.vmfk-embedded .vmfk-header{
  width:min(calc(100% - 32px), 960px);
  margin:16px auto 0;
  border-radius:12px;
}

html.vmfk-embedded .vmfk-header .header-logo,
html.vmfk-embedded .vmfk-header .header-title,
html.vmfk-embedded .vmfk-header .header-logout,
body.vmfk-embedded .vmfk-header .header-logo,
body.vmfk-embedded .vmfk-header .header-title,
body.vmfk-embedded .vmfk-header .header-logout{
  display:none !important;
}

html.vmfk-embedded .vmfk-header nav,
body.vmfk-embedded .vmfk-header nav,
html.vmfk-embedded .vmfk-mobile-nav,
body.vmfk-embedded .vmfk-mobile-nav{
  width:100%;
  justify-content:center;
}

html.vmfk-embedded .vmfk-mobile-nav a,
body.vmfk-embedded .vmfk-mobile-nav a{
  text-align:center;
}
/* =========================
   Containers
   ========================= */
.upload-container,
.admin-container{
  max-width:900px;
  margin:40px auto;
  background:var(--box-bg);
  padding:30px;
  border-radius:10px;
  box-shadow:0 0 10px rgba(0,0,0,.15);
}
.admin-container h1{
  margin-top:0;
  margin-bottom:15px;
}

/* =========================
   Upload Area
   ========================= */
.upload-area{
  border:2px dashed var(--accent);
  border-radius:10px;
  padding:40px;
  cursor:pointer;
  text-align:center;
  transition:.25s ease;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  will-change:transform;
}
.upload-area p{
  font-size:18px;
  font-weight:bold;
  color:var(--accent);
}
.upload-area svg{
  width:60px;
  height:60px;
  fill:var(--accent);
  margin-bottom:10px;
  pointer-events:none;
}
.upload-area.locked{
  pointer-events:none;
  opacity:.65;
  cursor:not-allowed;
}

@media (hover:hover) and (pointer:fine){
  .upload-area.hover{
    transform:scale(1.03);
    background-color:rgba(255,255,255,.25);
    border-color:var(--accent);
    box-shadow:0 0 12px rgba(0,0,0,.25);
  }
}

/* =========================
   Upload Inputs
   ========================= */
.uploader-box{
  margin-top:20px;
  margin-bottom:10px;
  text-align:center;
}
.uploader-box label{
  font-weight:bold;
  color:var(--accent);
  font-size:18px;
  display:block;
  margin-bottom:6px;
}
.uploader-box input,
.uploader-box select{
  width:260px;
  max-width:80%;
  border:2px solid var(--accent);
  border-radius:6px;
  font-size:18px;
  text-align:center;
  color:var(--text);
  background:var(--box-bg);
  height:42px;
  padding:0 12px;
  box-sizing:border-box;
}
#eventSelect.locked{
  opacity:.7;
  cursor:not-allowed;
}

/* =========================
   Buttons (global)
   ========================= */
button,
.start-btn,
.clear-btn,
.green-btn,
.blue-btn,
.red-btn,
.mode-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:42px;
  padding:10px 20px;
  box-sizing:border-box;
  font-weight:bold;
  font-size:15px;
  text-decoration:none;
  cursor:pointer;
  border-radius:6px;
  vertical-align:middle;
}

/* Specific button colors */
.start-btn{ background-color:var(--accent); color:#fff; }
.clear-btn{ background-color:transparent; color:var(--text); }

.green-btn{ background:#0BBD16; color:#fff; border:none; }
.blue-btn{ background:var(--accent); color:#fff; border:none; }
.red-btn{ background:#d9534f; color:#fff; border:none; }

.start-btn.disabled,
.start-btn:disabled{
  background:#b5b5b5 !important;
  color:#fff !important;
  cursor:not-allowed;
  opacity:.9;
}

/* Upload buttons row */
.buttons-upload{
  display:flex;
  justify-content:center;
  gap:15px;
  margin-top:25px;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.buttons-upload.has-files{ margin-bottom:50px; }

/* =========================
   Progress
   ========================= */
.progress-container{ margin-top:20px; }
.progress-bar-bg{
  width:100%;
  background-color:#eee;
  border-radius:5px;
  overflow:hidden;
  height:20px;
}
.progress-bar{
  height:20px;
  background-color:var(--accent);
  width:0%;
  transition:width .3s;
}

/* =========================
   Grid / Thumbs
   ========================= */
.grid{
  display:flex;
  flex-wrap:wrap;
  gap:15px;
  margin-top:15px;
}
.grid.no-files{ margin-top:0 !important; }
.grid > .grid-info{ flex:0 0 100%; }

.thumb{
  position:relative;
  display:inline-block;
  z-index:0;
}
.thumb img{
  position:relative;
  z-index:1;
  max-width:200px;
  max-height:112px;
  border-radius:6px;
  cursor:pointer;
  box-shadow:0 0 5px rgba(0,0,0,.2);
}

/* Placeholder previews */
.thumb-placeholder{
  position:relative;
  z-index:1;
  width:200px;
  height:112px;
  border-radius:6px;
  background:rgba(0,0,0,.06);
  box-shadow:0 0 5px rgba(0,0,0,.2);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:10px;
  box-sizing:border-box;
  text-align:center;
  gap:6px;
}
.thumb-placeholder-type{ font-weight:700; letter-spacing:.5px; }
.thumb-placeholder-name{ font-size:12px; opacity:.85; word-break:break-word; }
.thumb-placeholder-note{ font-size:12px; opacity:.75; }

/* Overlay icons */
.icon-overlay{
  position:absolute;
  inset:0;
  z-index:10;
  pointer-events:none;
}
.icon-overlay .delete-file,
.icon-overlay .download-icon{
  position:absolute;
  z-index:20;
  pointer-events:auto;
  opacity:0;
  transition:opacity .15s ease;

  /* reset (så global button-style ikke laver rammer) */
  background:transparent;
  border:none;
  padding:0;
  margin:0;
  height:auto;
  width:auto;
  border-radius:0;
  box-shadow:none;
  line-height:0;
}
.icon-overlay .delete-file{ top:8px; left:8px; }
.icon-overlay .download-icon{
  top:8px;
  right:8px;
  transform:rotate(180deg);
}
.thumb:hover .icon-overlay .delete-file,
.thumb:hover .icon-overlay .download-icon{ opacity:1; }

/* Focus (a11y) */
.icon-overlay .delete-file:focus,
.icon-overlay .download-icon:focus{ outline:none; }
.icon-overlay .delete-file:focus-visible,
.icon-overlay .download-icon:focus-visible{
  outline:2px solid rgba(110,140,181,.8);
  outline-offset:2px;
  border-radius:6px;
}
a:focus-visible,
button:focus-visible{
  outline:2px solid rgba(110,140,181,.8);
  outline-offset:2px;
}

/* =========================
   Login (match Admin login.php 1:1)
   ========================= */
/* NOTE:
   Upload/Admin login pages use inline <style>. This block intentionally wins over global styles
   (especially global button styles) so the login layout is identical everywhere.
*/
.login-box{
  max-width:420px !important;
  margin:40px auto 0 !important;
  background:#fff !important;
  border:1px solid #e2e8f0 !important;
  border-radius:12px !important;
  padding:22px !important;
  box-shadow:0 6px 18px rgba(0,0,0,.06) !important;
  text-align:center !important;
  box-sizing:border-box !important;
}

.login-box h2{
  margin:0 0 14px 0 !important;
  font-size:22px !important;
  line-height:1.2 !important;
}

/* Inputs match Admin app.css login inputs */
.login-box input[type=email],
.login-box input[type=password]{
  width:100% !important;
  max-width:350px !important;
  padding:10px 12px !important;
  border-radius:8px !important;
  border:1px solid var(--border) !important;
  font-size:16px !important;
  box-sizing:border-box !important;
  margin-top:20px; /* allow inline style on password field to override */
}
/* Admin login.php sets password margin-top inline to 10px */
.login-box input[type=password]{ margin-top:10px; }

.forgot-row{
  margin-top:10px !important;
  text-align:center !important;
}

/* Reset global button styling for the "Glemt password" link */
.forgot-link{
  padding:0 !important;
  margin:0 !important;
  border:0 !important;
  background:transparent !important;
  color:#1d4ed8 !important;
  text-decoration:underline !important;
  cursor:pointer !important;
  font-size:14px !important;
  font-weight:400 !important;
  height:auto !important;
  min-height:0 !important;
  display:inline !important;
  box-shadow:none !important;
}

.login-btn{
  width:100% !important;
  max-width:350px !important;
  margin-top:12px !important;
  padding:10px 12px !important;
  border:0 !important;
  border-radius:10px !important;
  background:#6E8CB5 !important;
  color:#fff !important;
  font-size:16px !important;
  font-weight:700 !important;
  cursor:pointer !important;
  height:auto !important;
  box-shadow:none !important;
}
.login-btn:hover{filter:brightness(.97) !important;}

.login-error{margin:10px 0 0 0 !important;color:#b91c1c !important;font-weight:700;}
.login-success{margin:10px 0 0 0 !important;color:#15803d !important;font-weight:700;}


/* =========================
   Admin inputs + buttons
   ========================= */
.admin-container .vmfk-input,
.admin-container .vmfk-select{
  padding:12px;
  border:2px solid var(--accent);
  border-radius:6px;
  font-size:18px;
  background:var(--box-bg);
  color:var(--text);
  margin-top:8px;
  margin-bottom:10px;
  max-width:300px;
}
.admin-container .start-btn,
.admin-container a.start-btn{
  background-color:var(--accent);
  color:#fff;
  padding:10px 20px;
  border-radius:6px;
  font-weight:bold;
  font-size:16px;
  text-decoration:none;
  display:inline-block;
  margin-top:0;
}
.admin-container .clear-btn{
  background:transparent;
  color:var(--text);
  padding:8px 16px;
  border-radius:6px;
  font-weight:bold;
  font-size:14px;
  border:1px solid var(--border);
}

.admin-container .delete-folder-btn{
  padding:8px 16px;
  border-radius:6px;
  font-weight:bold;
  font-size:16px;
  border:none;
}

/* Ensartet mappe-action */
.admin-container .folder-action-btn{
  background:transparent;
  color:var(--text);
  padding:8px 16px;
  border-radius:6px;
  font-weight:bold;
  font-size:14px;
  border:1px solid var(--border);
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box;
  cursor:pointer;
  text-decoration:none;
}

/* =========================
   Events collapsible (Uploads)
   ========================= */
.events-collapsible{
  border:1px solid var(--border);
  border-radius:10px;
  background:rgba(0,0,0,.02);
  padding:10px 12px;
  margin-bottom:18px;
}
.events-collapsible:not([open]){
  background:rgba(110,140,181,.25);
}

/* Summary (centreret tekst + pil) */
.events-summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;  /* centrer tekst */
  text-align:center;
  gap:12px;
  font-weight:800;
  color:var(--accent);
  user-select:none;
  position:relative;       /* for pil */
}
.events-summary::-webkit-details-marker{ display:none; }
.events-summary::after{
  content:"▸";
  font-size:18px;
  line-height:1;
  transform:translateY(-1px);
}
.events-collapsible[open] .events-summary::after{ content:"▾"; }

.events-summary-hint{
  font-weight:700;
  color:rgba(0,0,0,.55);
  font-size:13px;
}
.events-inner{ margin-top:12px; }

/* =========================
   Event list rows
   ========================= */
.event-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:8px 0;
}
.event-row:not(:last-child){ border-bottom:1px solid var(--border); }

.event-name{ flex:1 1 auto; }
.event-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}
.event-actions .start-btn,
.event-actions .clear-btn{
  padding:10px 20px;
  font-size:15px;
  margin-top:0;
}

/* =========================
   Create event form
   ========================= */
#createEventForm{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  margin-bottom:25px;
}
#createEventForm .vmfk-input{
  flex:1 1 220px;
  height:42px;
  padding:10px 16px;
  font-size:16px;
  line-height:1;
  border:1px solid var(--border);
  box-sizing:border-box;
  display:inline-flex;
  align-items:center;
}
#createEventForm .start-btn{
  flex:0 0 auto;
  height:42px;
  padding:10px 16px;
  font-size:16px;
  line-height:1;
  border:1px solid var(--border);
  box-sizing:border-box;
}

/* =========================
   Lightbox + Modal
   ========================= */
.lightbox{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.50);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display:none;
  justify-content:center;
  align-items:center;
  z-index:9999;
}

.lightbox img{
  max-width:90%;
  max-height:90%;
  border-radius:8px;
}

.vmfk-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.65);
  display:none;
  justify-content:center;
  align-items:center;
  z-index:99999;
}
.vmfk-modal-box{
  background:var(--box-bg);
  padding:25px 30px;
  border-radius:12px;
  width:90%;
  max-width:380px;
  text-align:center;
}
.vmfk-modal-buttons{
  display:flex;
  justify-content:center;
  gap:15px;
}
.modal-copy-btn{
  background:var(--accent);
  color:#fff;
}

/* =========================
   Mode switch
   ========================= */
.mode-switch{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:0;
  margin-bottom:18px;
}
.mode-btn{
  border:1px solid var(--border);
  background:#e6e6e6;
  color:#222;
  text-decoration:none;
  border-radius:0;
}
.mode-btn:first-child{
  border-top-left-radius:8px;
  border-bottom-left-radius:8px;
}
.mode-btn:last-child{
  border-top-right-radius:8px;
  border-bottom-right-radius:8px;
  border-left:none;
}
.mode-btn.active{ background:#bdbdbd; }

/* =========================
   Gallery (bulk / icons / danger)
   ========================= */
.gallery-thumb{ position:relative; }

.gallery-check{
  position:absolute;
  top:8px;
  left:8px;
  z-index:30;
  width:18px;
  height:18px;
  cursor:pointer;
  accent-color:var(--accent);
}

.gallery-danger{
  background:#d9534f !important;
  color:#fff !important;
  border:none !important;
}

/* Ikon-knapper i galleri */
.gallery-icon-btn{
  padding:0 10px !important;
  width:42px;
}
.gallery-icon-btn svg{
  width:18px;
  height:18px;
  stroke:currentColor;
  fill:none;
}

/* "Slet mappe" danger outline */
.gallery-danger-outline{
  border:2px solid #d9534f !important;
  color:#d9534f !important;
  background:transparent !important;
}

/* Desktop+mobil: dropdown i wrapper skal kunne fylde */
.gallery-folder .gallery-move-wrap .gallery-move-select{
  width:100% !important;
  max-width:none !important;
  box-sizing:border-box;
}


/* Kun upload.php: "Ryd alle" */
.clear-files-btn{
  background:transparent;
  color:var(--text);
  border:2px solid #000;         /* sort ramme altid */
}

/* Bevar samme look på hover/active */
.clear-files-btn:hover,
.clear-files-btn:active{
  background:transparent;
  color:var(--text);
  border-color:#000;
}

/* Undgå “browser-sort ramme” ved klik */
.clear-files-btn:focus{ outline:none; }

/* Fokus til tastaturbrug */
.clear-files-btn:focus-visible{
  outline:2px solid rgba(0,0,0,.6);
  outline-offset:2px;
  border-radius:6px;
}



/* =========================
   Uploads – bulk/actions/checkbox layout
   ========================= */
.uploads-thumb{ position:relative; }

/* Uploads: delete-ikon nederst højre */
.uploads-thumb .icon-overlay .delete-file{
  top:auto !important;
  left:auto !important;
  right:8px !important;
  bottom:8px !important;
}

/* Uploads: download-ikon øverst højre */
.uploads-thumb .icon-overlay .download-icon{
  top:8px !important;
  right:8px !important;
  bottom:auto !important;
}

/* Uploads: checkmark */
.uploads-check{
  position:absolute;
  top:8px;
  left:8px;
  z-index:30;
  width:18px;
  height:18px;
  cursor:pointer;
  accent-color:var(--accent);
}

/* Uploads: actions row */
.uploads-actions-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.uploads-actions-row .clear-btn,
.uploads-actions-row .start-btn{
  height:42px;
}

/* =========================
   Rotate icon buttons (Uploads + Galleri)
   ========================= */
.icon-btn{
  width:44px;
  height:42px;
  padding:0 !important;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0;
  line-height:1;
}
.rotate-char{
  font-size:22px;
  line-height:1;
  display:inline-block;
}
@media (max-width:520px){
  .icon-btn{ width:42px; height:42px; }
  .rotate-char{ font-size:21px; }
}

/* =========================
   Mobile upload logo
   ========================= */
.mobile-upload-logo{ display:none; }

/* ============================================================
   MOBILE OVERRIDES (max-width:700px)
   ============================================================ */
@media (max-width:700px){

  /* Body: ingen billede, kun blå baggrund */
  body{
    background-image:none;
    background-color:var(--bg);
    background-attachment:scroll;
  }

  /* Nav/hamburger */
  .vmfk-header nav{ display:none; }
  .vmfk-header .hamburger{ display:flex; }

  .vmfk-header{ justify-content:flex-start; }

  .vmfk-header .header-left{
    position:static;
    left:auto;
    width:100%;
    justify-content:space-between;
    gap:12px;
  }
  .vmfk-header .header-left .hamburger{ order:2; position:static; right:auto; }
  .vmfk-header .header-left h1{ order:1; }

  html.vmfk-embedded .vmfk-header,
  body.vmfk-embedded .vmfk-header{
    width:min(calc(100% - 20px), 960px);
    margin:10px auto 0;
  }

  html.vmfk-embedded .vmfk-mobile-nav,
  body.vmfk-embedded .vmfk-mobile-nav{
    left:10px;
    right:10px;
    width:auto;
  }

  /* Overlay icons: altid synlige på mobil */
  .icon-overlay .delete-file,
  .icon-overlay .download-icon{
    opacity:1 !important;
    pointer-events:auto !important;
  }

  /* Event row layout */
  .event-row{
    flex-direction:column;
    align-items:flex-start;
    margin-bottom:10px;
  }

  /* Upload container padding */

  .upload-container{
    width:90%;
    max-width:90%;
    margin:40px auto;     /* centrer */
    padding:22px 16px;    /* behold din nuværende padding */
    box-sizing:border-box;
  }


  /* Preview grid: 1 kolonne + 16:9 crop */
  #previewArea.grid{
    display:grid;
    grid-template-columns:repeat(1, minmax(0, 1fr));
    gap:10px;
    width:100%;
    margin-top:15px;
  }
  #previewArea .thumb{
    width:100%;
    display:block;
    position:relative;
    aspect-ratio:16 / 9;
    overflow:hidden;
  }
  #previewArea .thumb img,
  #previewArea .thumb-placeholder{
    width:100%;
    max-width:none;
    max-height:none;
    border-radius:6px;
    display:block;
    object-fit:cover;
  }
  #previewArea .thumb img{
    position:absolute;
    inset:0;
    height:100%;
  }
  #previewArea .thumb-placeholder{
    position:absolute;
    inset:0;
    height:100%;
    padding:10px;
    box-sizing:border-box;
  }

  /* Admin container */
  .admin-container{
    margin:18px 10px;
    padding:16px;
    border-radius:10px;
  }

  .admin-container > div[style*="justify-content:space-between"][style*="align-items:center"]{
    flex-direction:column;
    align-items:stretch !important;
    gap:10px;
  }
  .admin-container > div[style*="justify-content:space-between"][style*="align-items:center"] h1{
    font-size:22px;
    line-height:1.15;
  }

  /* Create event */
  #createEventForm{
    width:100%;
    gap:10px;
  }
  #createEventForm .vmfk-input{
    flex:1 1 100%;
    max-width:none;
    width:100%;
    margin:0;
  }
  #createEventForm .start-btn{ width:100%; }

  /* Filter forms (uploads + galleri) */
  #eventFilterForm,
  #galleryEventFilterForm{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:stretch !important;
    gap:6px;
    margin:0;
  }
  #eventFilterForm label,
  #galleryEventFilterForm label{
    margin:0 !important;
    text-align:left;
  }
  #eventFilterForm .vmfk-select,
  #galleryEventFilterForm .vmfk-select{
    width:100%;
    max-width:none;
    margin:0;
  }

  /* Transfer form */
  #transferMediaForm{ justify-content:stretch !important; }
  #transferMediaForm .start-btn{ width:100%; }

  /* Folder header rows */
  .folder-wrap > div > div[style*="justify-content:space-between"][style*="align-items:center"]{
    flex-direction:column;
    align-items:stretch !important;
    gap:10px;
  }

  .assign-event-form{
    width:100%;
    flex-direction:column;
    align-items:stretch !important;
    gap:6px;
  }
  .assign-event-form label{ margin:0 !important; }
  .assign-event-form .vmfk-select{
    width:100%;
    max-width:none;
    margin:0;
  }

  /* Admin thumbs grid 2 kolonner */
  .admin-container .grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:10px;
  }
  .admin-container .thumb{ width:100%; }
  .admin-container .thumb img,
  .admin-container .thumb-placeholder{
    width:100%;
    max-width:none;
    max-height:none;
    aspect-ratio:16 / 9;
    object-fit:cover;
    display:block;
  }

  /* Event actions: hold samlet */
  .event-actions{
    width:100%;
    flex-wrap:nowrap;
    gap:8px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .event-actions > *{
    flex:1 1 calc(50% - 10px);
    min-width:0;
  }
  .event-actions > a.start-btn{ text-align:center; }
  .event-actions .start-btn,
  .event-actions .clear-btn,
  .event-actions .green-btn,
  .event-actions .red-btn{
    padding:8px 10px;
    font-size:14px;
    height:40px;
  }

  /* Folder action forms full width */
  .folder-wrap > div[style*="display:flex"][style*="flex-wrap:wrap"]{
    flex-direction:column;
    gap:10px;
  }
  .folder-wrap > div[style*="display:flex"][style*="flex-wrap:wrap"] form,
  .folder-wrap > div[style*="display:flex"][style*="flex-wrap:wrap"] form button,
  .folder-wrap > div[style*="display:flex"][style*="flex-wrap:wrap"] form a{
    width:100%;
  }

  /* Mode switch */
  .mode-switch{ margin-bottom:12px; }
  .mode-btn{ flex:1 1 50%; }

  /* Mobile upload logo */
  .mobile-upload-logo{
    display:flex;
    justify-content:center;
    margin:16px auto 26px;
    max-width:900px;
    padding:0 16px;
    box-sizing:border-box;
  }
  .mobile-upload-logo img{
    width:70%;
    height:auto;
    display:block;
  }

  /* =========
     Uploads mobile actions layout (2+2+1)
     ========= */
  .uploads-download-form,
  .uploads-download-btn{ display:none !important; }

  .uploads-actions-row{
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px;
    align-items:stretch;
  }
  .uploads-actions-row > form,
  .uploads-actions-row > button{
    width:100%;
    margin:0;
  }
  .uploads-actions-row button,
  .uploads-actions-row .clear-btn,
  .uploads-actions-row .start-btn{
    width:100%;
  }

  .uploads-actions-row .uploads-delete-selected-form{ grid-column:1; }
  .uploads-actions-row .uploads-delete-folder-form{ grid-column:2; }
  .uploads-actions-row .uploads-mark-all{ grid-column:1; }
  .uploads-actions-row .uploads-mark-none{ grid-column:2; }
  .uploads-actions-row .uploads-transfer-selected-form{ grid-column:1 / -1; }
  .uploads-actions-row .uploads-transfer-selected-btn{ width:100%; }

  /* Rotate-form på egen linje og fuld bredde */
  .uploads-actions-row .uploads-rotate-form{
    grid-column:1 / -1;
    width:100%;
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px;
    margin:0;
  }
  .uploads-actions-row .uploads-rotate-form .uploads-rotateL-btn,
  .uploads-actions-row .uploads-rotate-form .uploads-rotateR-btn{
    width:100% !important;
  }
  .uploads-actions-row .uploads-rotate-form .icon-btn{
    width:auto !important;
    padding:0 20px !important;
  }

  /* =========
     Galleri actions: 2 kolonner + rotér på egen række
     ========= */
  .gallery-folder .gallery-actions-row{
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px;
    width:100%;
  }
  .gallery-folder .gallery-actions-row .gallery-btn[data-action="delete"]{ grid-column:1; }
  .gallery-folder .gallery-actions-row .gallery-btn[data-action="deleteFolder"]{ grid-column:2; }
  .gallery-folder .gallery-actions-row .uploads-rotateL-btn{ grid-column:1; }
  .gallery-folder .gallery-actions-row .uploads-rotateR-btn{ grid-column:2; }
  .gallery-folder .gallery-actions-row button{ width:100% !important; }
  .gallery-folder .gallery-actions-row .icon-btn{
    width:auto !important;
    padding:0 20px !important;
  }

  /* =========
     Galleri: “Flyt valgte til …” dropdown stacked
     ========= */
  .gallery-bulk-form{ width:100%; }

  .gallery-folder .gallery-head-move{
    width:100%;
    flex-direction:column;
    align-items:stretch !important;
    gap:6px;
    margin-left:0;
  }
  .gallery-folder .gallery-head-move .gallery-move-select{
    width:100%;
    max-width:none;
    margin:0;
  }
  .gallery-folder .gallery-head-move .gallery-move-btn{ width:100%; }

  /* Wrapper hvis den bruges i markup */
  .gallery-move-wrap{
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:stretch !important;
    gap:6px;
  }
  .gallery-move-wrap .gallery-move-select{
    width:100%;
    max-width:none;
    margin:0;
  }
  .gallery-move-wrap .gallery-move-btn{ width:100%; }

  /* =========
     Uploads – header + filter stacked
     ========= */
  .admin-head-row{
    flex-direction:column;
    align-items:stretch !important;
    gap:8px;
  }

  /* =========
     Lightbox:
     ========= */
  #lightbox.lightbox{
	position:fixed;
	inset:0;
	background:rgba(0,0,0,.50);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	display:none;
	justify-content:center;
	align-items:center;
	z-index:9999;
  }
  
  #lightbox #lightboxImg{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    max-width:92vw;
    max-height:92vh;
    width:auto;
    height:auto;
    margin:0;
    display:block;
  }

/* Embedded gallery/frame consistency */
html.vmfk-embedded .gallery-frame,
body.vmfk-embedded .gallery-frame{
  width:min(calc(100% - 32px), 960px);
  margin:16px auto;
  border-radius:12px;
  overflow:hidden;
}

.settings-status-success{ color:#0BBD16; font-weight:bold; }
.settings-status-error{ color:#d9534f; font-weight:bold; }
