/* ===== Front + Admin mosaic grid ===== */

.kbmg-wrapper{
  --kbmg-gap: 10px;
  --kbmg-cols: 4;
  --kbmg-row: 220px;
  display: grid;
  grid-template-columns: repeat(var(--kbmg-cols), minmax(0, 1fr));
  grid-auto-rows: var(--kbmg-row);
  grid-auto-flow: dense;
  gap: var(--kbmg-gap);
  width: 100%;
}

.kbmg-item{
  margin: 0;
  min-width: 0;
}

.kbmg-link{
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 14px;
  background: rgba(255,255,255,0.04);
}

.kbmg-img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: translateZ(0);
}

.kbmg-link:hover .kbmg-img{
  transform: scale(1.02);
  transition: transform .2s ease;
}

/* ikon nede til høyre */
.kbmg-icon{
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
  background: rgba(0,0,0,.35);
  box-shadow: 0 6px 22px rgba(0,0,0,.25);
}
.kbmg-icon::before{
  content:"";
  position:absolute;
  inset: 8px;
  background: #fff;
  -webkit-mask-image: var(--kbmg-icon-url);
  mask-image: var(--kbmg-icon-url);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  opacity: .95;
}

/* ===== Lightbox ===== */
.kbmg-lock{ overflow: hidden; }

.kbmg-lightbox{
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
}
.kbmg-lightbox.is-open{ display: block; }

.kbmg-lightbox__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.7);
}
.kbmg-lightbox__dialog{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 22px;
}
.kbmg-lightbox__content{
  position: relative;
  max-width: min(1100px, 96vw);
  max-height: 86vh;
  display: grid;
  gap: 10px;
}
.kbmg-lightbox__img{
  max-width: 100%;
  max-height: 80vh;
  width: auto;
  height: auto;
  border-radius: 14px;
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
}
.kbmg-lightbox__caption{
  color: rgba(255,255,255,.9);
  font-size: 14px;
  text-align: center;
}
.kbmg-lightbox__close{
  position: absolute;
  top: 16px;
  right: 18px;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  color: #fff;
  font-size: 28px;
  line-height: 44px;
  cursor: pointer;
}
.kbmg-lightbox__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  color: #fff;
  font-size: 34px;
  line-height: 52px;
  cursor: pointer;
}
.kbmg-lightbox__prev{ left: 16px; }
.kbmg-lightbox__next{ right: 16px; }

/* ===== Admin layout ===== */
.kbmg-admin-settings{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  align-items: end;
}
.kbmg-cols{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.kbmg-cols input{ width: 70px; }

.kbmg-admin-preview{
  max-width: 1100px;
}


/* ===== Drag & drop i backend ===== */
.kbmg-admin-preview .kbmg-link{ cursor: move; }
.kbmg-drag-hint{ position:absolute; left:10px; bottom:10px; width:34px; height:34px; border-radius:999px; background: rgba(0,0,0,.35); backdrop-filter: blur(6px); display:grid; place-items:center; color:#fff; font-size:18px; line-height:1; opacity:.75; }
.kbmg-sort-placeholder{ min-height: 80px;  outline: 2px dashed rgba(255,255,255,.25); border-radius: 14px; background: rgba(255,255,255,.06); }
