/* Core layout additions */
.mbsh-steps-header h3{margin:4px 0 8px}
.mbsh-dashboard{max-width:1100px;margin:0 auto;padding:16px}
.mbsh-header h2{margin:0 0 4px}
.mbsh-progress{margin:16px 0 24px}
.mbsh-progress-bar{width:100%;height:16px;background:#e8e8e8;border-radius:10px;overflow:hidden}
.mbsh-progress-fill{height:100%;background:#4caf50;border-radius:10px}
.mbsh-progress-label{margin-top:6px;font-weight:600}

/* Dashboard module cards */
.mbsh-modules{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.mbsh-module{
  border-radius:14px;
  padding:14px;
  background:#fafafa;
  border:1px solid #eee;
  display:flex;
  flex-direction:column;
  gap:10px;
  height:100%;
}
.mbsh-module[data-url]{cursor:pointer}
.mbsh-module[data-url]:focus{outline:2px solid #111;outline-offset:3px}
.mbsh-module.green{border-color:#cde8d1}
.mbsh-module.orange{border-color:#ffe3b3}
.mbsh-module.red{border-color:#ffc6c6}

/* Modul-spezifische Fortschrittsleiste oben in der Karte */
.mbsh-module-progress{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.mbsh-module-progress-bar{
  width:100%;
  height:8px;
  background:#eeeeee;
  border-radius:999px;
  overflow:hidden;
}
.mbsh-module-progress-fill{
  height:100%;
  background:#4caf50;
  border-radius:999px;
}
.mbsh-module-progress-label{
  font-size:12px;
  font-weight:600;
  color:#555;
  text-align:right;
}

.mbsh-module-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:4px;
}
.mbsh-module-head h3{
  margin:0;
  font-size:clamp(var(--mbsh-card-title-min,12px), calc(var(--mbsh-card-title-min,12px) + 0.8vw), var(--mbsh-card-title-max,18px)) !important;
  line-height:1.12;
}

/* Body so dass der Button immer unten sitzt */
.mbsh-module-body{
  margin-top:auto;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.mbsh-hint{margin:4px 0 0;color:#555}
.mbsh-module-body .mbsh-btn{
  margin-top:auto;
  align-self:flex-start;
}

.mbsh-btn{
  display:inline-block;
  padding:10px 14px;
  border-radius:10px;
  background:#111;
  color:#fff;
  text-decoration:none;
  cursor:pointer;
  border:none;
  font-weight:600;
  font-size:14px;
}
.mbsh-btn:hover{opacity:.9}
.mbsh-box.mbsh-warning{background:#fff7e6;border:1px solid #ffd28a;padding:12px;border-radius:10px}

/* Spezielle Buttons im Modul */
.mbsh-btn.mbsh-mark-done{
  background:#2e7d32;
}
.mbsh-btn.mbsh-mark-done:hover{
  background:#256628;
}
.mbsh-btn.mbsh-undo{
  background:#ffffff;
  color:#333;
  border:1px solid #cfcfcf;
}
.mbsh-btn.mbsh-undo:hover{
  background:#f5f5f5;
}

/* Back-Buttons oben/unten im Modul */
.mbsh-back-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:20px;
  padding:10px 14px;
  background:#fff;
  color:#111;
  border-radius:10px;
  font-weight:700;
  cursor:pointer;
  border:1px solid #e5e7eb;
  text-decoration:none;
  box-shadow:0 1px 2px rgba(0,0,0,.06);
}
.mbsh-back-btn:hover{
  background:#f9fafb;
  border-color:#d1d5db;
}
.mbsh-back-top{
  margin-bottom:28px;
}

.mbsh-steps{max-width:1000px;margin:0 auto;padding:8px}

/* ===============================
   Sidebar layout (course-like)
   =============================== */
.mbsh-layout-sidebar{max-width:1200px}
.mbsh-layout-sidebar .mbsh-steps-layout{display:grid;grid-template-columns:280px 1fr;gap:22px;align-items:start}
.mbsh-layout-sidebar .mbsh-steps-nav{position:sticky;top:20px}
.mbsh-steps-nav-title{font-weight:800;margin:2px 0 10px;font-size:14px;color:#111}
.mbsh-steps-nav-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.mbsh-steps-nav-item{width:100%;text-align:left;border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:10px 10px;cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.mbsh-steps-nav-item:hover{border-color:#d1d5db;background:#f9fafb}
.mbsh-steps-nav-item:focus{outline:2px solid #111;outline-offset:2px}
.mbsh-steps-nav-num{display:block;font-size:11px;font-weight:800;color:#6b7280;margin-bottom:4px}
.mbsh-steps-nav-text{display:block;font-size:13px;font-weight:800;color:#111;line-height:1.2}
.mbsh-steps-nav-item.is-done{border-color:#2e7d32;background:#e8f5e9}
.mbsh-steps-nav-item.is-active{border-color:#111}

/* Only show the active step to keep the page short (like a course player) */
.mbsh-layout-sidebar .mbsh-step-list > li{display:none}
.mbsh-layout-sidebar .mbsh-step-list > li.is-active{display:block}

@media (max-width: 860px){
  .mbsh-layout-sidebar .mbsh-steps-layout{grid-template-columns:1fr}
  .mbsh-layout-sidebar .mbsh-steps-nav{position:relative;top:auto}
}
.mbsh-steps-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.mbsh-acc-toggleall{white-space:nowrap}
.mbsh-step-list{margin:0;padding-left:0;list-style:none}
.mbsh-step-list li{position:relative;margin:16px 0;padding:0;border:1px solid #eee;border-radius:12px;background:#fff;transition:background-color .2s,border-color .2s}
.mbsh-step-list li.done{border-color:#2e7d32;background:#e8f5e9}
.mbsh-step-num{position:absolute;top:-12px;left:16px;padding:4px 10px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;font-size:12px;font-weight:700;color:#111;box-shadow:0 1px 2px rgba(0,0,0,.06)}
.mbsh-step-list li.done .mbsh-step-num{border-color:#2e7d32;background:#ffffff}

/* Accordion (optional) */
.mbsh-step-list.mbsh-accordion li{padding:0}
.mbsh-step-list.mbsh-accordion .mbsh-acc-header{
  display:block;
  width:100%;
  background:transparent;
  border:0;
  text-align:left;
  cursor:pointer;
  padding:18px 16px 10px;
  font-weight:800;
  font-size:18px;
  color:#111;
}
.mbsh-acc-header-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.mbsh-acc-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#6b7280;white-space:nowrap}
.mbsh-acc-chevron{display:inline-block;transition:transform .15s ease}
.mbsh-step-list.mbsh-accordion li.is-open .mbsh-acc-chevron{transform:rotate(180deg)}
.mbsh-step-list.mbsh-accordion li.done .mbsh-acc-header{color:#111;}
.mbsh-step-list.mbsh-accordion .mbsh-acc-header:focus{outline:2px solid #111;outline-offset:2px;border-radius:10px}
.mbsh-acc-panel[hidden]{display:none !important;}

.mbsh-step-row{display:flex;gap:18px;align-items:flex-start;padding:16px}
.mbsh-step-media{flex:0 0 40%;max-width:40%}
.mbsh-step-media img{max-width:100%;height:auto;border-radius:10px;display:block;cursor:pointer}
.mbsh-main-media{margin-bottom:8px}
.mbsh-responsive-iframe{position:relative;width:100%;padding-top:56%}
.mbsh-responsive-iframe iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;border-radius:10px}

/* Mobile inline video helper: always-visible stop button overlay */
.mbsh-responsive-iframe{position:relative}
.mbsh-mobile-video-stop{
  position:absolute; top:8px; right:8px;
  z-index:50;
  border:0; border-radius:999px;
  padding:8px 10px;
  font-size:14px; line-height:1;
  background:rgba(0,0,0,.75);
  color:#fff;
  cursor:pointer;
}
.mbsh-mobile-video-stop:active{transform:scale(.98)}
@media (min-width:768px){
  .mbsh-mobile-video-stop{display:none}
}
@media (max-width:767px){
  .mbsh-mobile-video-stop{display:inline-flex;align-items:center;gap:6px}

  /* Mobile: Nutzer regeln Lautstärke am Handy. Volume/Mute-Controls im Video ausblenden,
     damit wichtige Controls (Play/Pause/Timeline) mehr Platz haben. */
  .mbsh-step-media video::-webkit-media-controls-volume-slider,
  .mbsh-step-media video::-webkit-media-controls-mute-button,
  .mbsh-step-media video::-webkit-media-controls-volume-control-container,
  .mbsh-step-media video::-webkit-media-controls-volume-control-container *{
    display:none !important;
  }
}



/* In der Schrittansicht soll ein Klick auf Video/Embed immer den schwebenden Viewer oeffnen.
   Viele Embeds (z.B. Bunny/YouTube) fangen Klicks direkt im iframe ab (Play/Controls).
   Durch pointer-events:none auf dem iframe geht der Klick an den Wrapper (.mbsh-lightbox-trigger).
   Im Viewer selbst sind die Embeds nicht in .mbsh-responsive-iframe, daher bleiben sie bedienbar. */
.mbsh-step-media .mbsh-responsive-iframe iframe{pointer-events:none}
.mbsh-step-media .mbsh-responsive-iframe{cursor:pointer}
.mbsh-step-content{flex:1}
.mbsh-step-title{font-weight:700;margin-bottom:6px;display:flex;gap:8px;align-items:center}
.mbsh-badge{background:#c8e6c9;border-radius:999px;padding:2px 8px;font-size:12px}
.mbsh-step-media .mbsh-badge{display:inline-block;margin-bottom:10px}

.mbsh-step-desc{color:#333;margin:6px 0 10px}
.mbsh-step-gallery{display:flex;flex-wrap:wrap;gap:8px;margin:2px 0 4px}
.mbsh-step-gallery img{max-height:70px;border-radius:8px;cursor:pointer}
.mbsh-thumb-video{
  display:flex;
  align-items:center;
  justify-content:center;
  width:70px;
  height:45px;
  border-radius:8px;
  background:#111;
  color:#fff;
  font-size:18px;
  font-weight:700;
  cursor:pointer;
}

.mbsh-steps-footer{
  margin-top:24px;
}

/* Responsive */
@media (max-width: 768px){
  .mbsh-step-row{flex-direction:column}
  .mbsh-step-media{flex:0 0 auto;max-width:100%}

  /* Mobile UX: Videos/Embeds direkt im Schritt abspielen (kein schwebender Viewer).
     Daher darf das iframe Klicks wieder annehmen. Bilder bleiben weiterhin im Viewer. */
  .mbsh-step-media .mbsh-responsive-iframe iframe{pointer-events:auto}

  /* Mobile UX: Lautstaerke wird am Handy meist ueber Hardware-Tasten geregelt.
     Deshalb blenden wir den Volume-Regler von nativen <video controls> aus,
     um Platz zu schaffen (z.B. fuer unseren Stop-Button-Overlay). */
  video::-webkit-media-controls-volume-slider,
  video::-webkit-media-controls-mute-button,
  video::-webkit-media-controls-volume-control-container{
    display:none !important;
  }
}

/* Floating PiP viewer */
.mbsh-viewer[hidden]{display:none}
.mbsh-viewer{position:fixed;z-index:9999;top:80px;left:40px;right:auto;width:520px;max-width:92vw;background:#111;color:#fff;border-radius:12px;box-shadow:0 10px 28px rgba(0,0,0,.45);overflow:hidden;user-select:none}
.mbsh-viewer.mbsh-pinned{box-shadow:0 10px 30px rgba(0,0,0,.6)}
.mbsh-viewer-head{display:flex;align-items:center;justify-content:space-between;background:#1f1f1f;padding:6px 8px;cursor:move}
.mbsh-viewer-actions{display:flex;align-items:center;gap:6px}
.mbsh-viewer-actions input.mbsh-opacity{width:90px}
.mbsh-viewer-actions button{background:#2a2a2a;color:#fff;border:none;border-radius:8px;padding:6px 8px;cursor:pointer}
.mbsh-viewer-actions .mbsh-viewer-close{background:#e53935}
.mbsh-viewer-body{background:#000;height:360px;max-height:75vh;position:relative;overflow:hidden;opacity:1}
.mbsh-viewer-canvas{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.mbsh-viewer-canvas img,.mbsh-viewer-canvas video{max-width:none;max-height:none;display:block;transform-origin:0 0}
.mbsh-viewer-canvas .mbsh-iframe-wrap{position:relative;width:100%;height:100%}
.mbsh-viewer-canvas .mbsh-iframe-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:0}
/* Floating resize grips */
.mbsh-viewer-resize-e{position:absolute;top:0;right:0;width:10px;height:100%;cursor:ew-resize;user-select:none;touch-action:none;background:linear-gradient(180deg,transparent,rgba(255,255,255,.12),transparent)}
.mbsh-viewer-resize-s{position:absolute;left:0;bottom:0;height:10px;width:100%;cursor:ns-resize;user-select:none;touch-action:none;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}
.mbsh-viewer-resize-se{position:absolute;right:0;bottom:0;width:18px;height:18px;cursor:nwse-resize;user-select:none;touch-action:none;background:rgba(255,255,255,.10);border-top-left-radius:10px}

/* Prevent iframes from swallowing mouse events during drag/resize */
.mbsh-viewer.is-dragging iframe,
.mbsh-viewer.is-resizing iframe{pointer-events:none!important}

/* Docking modes */
.mbsh-viewer-actions .mbsh-viewer-dock{display:flex;align-items:center;gap:4px}
.mbsh-viewer.mbsh-dock-top{left:12px;right:12px;top:40px;width:auto;max-width:none}
/* Dock-Top: Height is user-resizable (stored per browser) */
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-body{height:var(--mbsh-dock-top-h, 320px);max-height:70vh}
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-head{cursor:default}
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-resize-e,
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-resize-s,
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-resize-se{display:none}

/* Resize bar for docked top viewer */
.mbsh-viewer .mbsh-viewer-dock-resize{display:none;height:10px;cursor:row-resize;user-select:none;touch-action:none}
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-dock-resize{display:block}
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-dock-resize{height:18px;cursor:ns-resize;position:relative}
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-dock-resize:before{content:"";display:block;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:96px;height:10px;border-radius:999px;background:rgba(255,255,255,.10)}
.mbsh-viewer.mbsh-dock-top .mbsh-viewer-dock-resize:after{content:"";display:block;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:72px;height:4px;border-radius:999px;background:repeating-linear-gradient(90deg, rgba(255,255,255,.75) 0 6px, rgba(255,255,255,0) 6px 10px)}

.mbsh-viewer.mbsh-dock-left{left:0;right:auto;top:40px;width:var(--mbsh-dock-side-w, min(460px,45vw));max-width:none;border-radius:0 12px 12px 0}
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-body{height:calc(100vh - 100px);max-height:none}
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-head{cursor:default}
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-resize-e,
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-resize-s,
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-resize-se{display:none}
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-dock-resize-side{display:block;position:absolute;top:44px;bottom:12px;right:-6px;width:12px;cursor:ew-resize;z-index:10001}
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-dock-resize-side:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:44px;border-radius:6px;background:rgba(255,255,255,.14)}
.mbsh-viewer.mbsh-dock-left .mbsh-viewer-dock-resize-side:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:28px;border-radius:2px;background:repeating-linear-gradient(180deg, rgba(255,255,255,.85) 0 5px, rgba(255,255,255,0) 5px 9px)}

.mbsh-viewer.mbsh-dock-right{right:0;left:auto;top:40px;width:var(--mbsh-dock-side-w, min(460px,45vw));max-width:none;border-radius:12px 0 0 12px}
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-body{height:calc(100vh - 100px);max-height:none}
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-head{cursor:default}
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-resize-e,
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-resize-s,
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-resize-se{display:none}
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-dock-resize-side{display:block;position:absolute;top:44px;bottom:12px;left:-6px;width:12px;cursor:ew-resize;z-index:10001}
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-dock-resize-side:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:44px;border-radius:6px;background:rgba(255,255,255,.14)}
.mbsh-viewer.mbsh-dock-right .mbsh-viewer-dock-resize-side:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:28px;border-radius:2px;background:repeating-linear-gradient(180deg, rgba(255,255,255,.85) 0 5px, rgba(255,255,255,0) 5px 9px)}

/* hide dock resize handles by default */
.mbsh-viewer .mbsh-viewer-dock-resize-side{display:none}

.mbsh-progress-motivation{margin-top:4px;margin-bottom:18px;color:#444;font-size:14px;}

/* === Editor-Inhalte in Kurs-Schritten: NICHT automatisch umstylen === */
/* Wir lassen Kurzbeschreibung + Beschreibung so, wie sie im Editor formatiert wurden. */
.mbsh-step-short p,
.mbsh-step-short li,
.mbsh-step-short blockquote,
.mbsh-step-short pre,
.mbsh-step-short code,
.mbsh-step-desc p,
.mbsh-step-desc li,
.mbsh-step-desc blockquote,
.mbsh-step-desc pre,
.mbsh-step-desc code{
  border:0;
  background:transparent;
  box-shadow:none;
  border-radius:0;
}

/* Listen bleiben lesbar (nur Einzug/Abstand), ohne Box-Rahmen. */
.mbsh-step-short ol, .mbsh-step-short ul,
.mbsh-step-desc ol, .mbsh-step-desc ul{
  padding-left:1.2em;
  margin:0.8em 0;
}
.mbsh-step-short li, .mbsh-step-desc li{
  padding:0;
  margin:0.3em 0;
}
/* === Step hint box (hide after 'Fertig') === */
.mbsh-step-hint{background:#f5f7fa;border-left:4px solid #4f46e5;padding:12px 14px;margin-top:16px;font-size:14px;}
.mbsh-step-list li.done .mbsh-step-hint{display:none !important;}


/* === Mobile: viewer becomes a clean, usable fullscreen panel === */
@media (max-width: 640px){
  .mbsh-viewer{
    /* Keep it readable: full panel with safe margins */
    display:flex;
    flex-direction:column;
    top: 60px !important;
    left: 10px !important;
    right:10px !important;
    bottom:10px !important;
    width:auto !important;
    max-width:none !important;
    border-radius:12px;
  }
  .mbsh-viewer-head{
    cursor:default;
    position:sticky;
    top:0;
    z-index:2;
  }
  .mbsh-viewer-actions{
    flex-wrap:wrap;
    gap:4px;
  }
  .mbsh-viewer-actions input.mbsh-opacity{width:70px;}
  .mbsh-viewer-actions button{padding:8px 10px;}

  /* On mobile we hide docking controls; it tends to clutter the header */
  .mbsh-viewer-actions .mbsh-viewer-dock{display:none !important;}

  /* Mobile: keep header minimal (PC is primary use-case) */
  .mbsh-viewer-actions .mbsh-prev,
  .mbsh-viewer-actions .mbsh-next,
  .mbsh-viewer-actions input.mbsh-opacity,
  .mbsh-viewer-actions .mbsh-pin,
  .mbsh-viewer-actions .mbsh-zoom-out,
  .mbsh-viewer-actions .mbsh-zoom-reset,
  .mbsh-viewer-actions .mbsh-zoom-in{display:none !important;}

  /* Make close button easier to hit */
  .mbsh-viewer-actions .mbsh-viewer-close{padding:10px 12px;}
  .mbsh-viewer-head > span{font-weight:600;}


  .mbsh-viewer-body{
    flex:1;
    min-height:0;
    height:auto !important;
    max-height:none !important;
  }

  /* Disable resize handles (touch UX) */
  .mbsh-viewer-resize-e,
  .mbsh-viewer-resize-s,
  .mbsh-viewer-resize-se{display:none !important;}
}


/* Steps layout v0.3.37: top (media + overview) and body (full width) */
.mbsh-step-top{display:flex;gap:18px;align-items:flex-start;padding:16px}
.mbsh-step-media{flex:0 0 320px;max-width:320px}
.mbsh-step-head{flex:1;min-width:0}
.mbsh-step-body{padding:0 16px 16px}
.mbsh-step-title{font-weight:800;margin-bottom:8px;display:flex;gap:10px;align-items:center;font-size:22px;line-height:1.25}
.mbsh-step-short{color:#333;margin:0 0 10px}
.mbsh-step-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.mbsh-step-actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.mbsh-tts-text.mbsh-sr-only{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
@media (max-width: 860px){
  .mbsh-step-top{flex-direction:column}
  .mbsh-step-media{flex:0 0 auto;max-width:100%;width:100%}
}

/* === Kategorien im Dashboard === */
.mbsh-cat-block{
  grid-column: 1 / -1 !important;
  width: 100%;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 18px 18px 16px;
  margin: 0 0 18px;
  background: #fff;
}
.mbsh-cat-title{
  margin: 0 0 6px !important;
  font-size: var(--mbsh-cat-title-size, 28px) !important;
  line-height: 1.2 !important;
}
.mbsh-cat-desc{
  margin: 0 0 12px;
  opacity: .85;
  font-size: 14px;
}
.mbsh-cat-grid{
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 1100px){
  .mbsh-cat-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .mbsh-cat-grid{ grid-template-columns: 1fr; }
}


/* Video/Embed preview cards (load in modal on click) */
.mbsh-media-card{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;box-shadow:0 1px 2px rgba(0,0,0,.08);} 
.mbsh-media-card-inner{position:relative;}
.mbsh-media-card-img{display:block;width:100%;height:auto;}
.mbsh-media-card-play{position:absolute;left:12px;top:12px;background:rgba(0,0,0,.6);color:#fff;border-radius:999px;padding:8px 10px;font-size:14px;line-height:1;}
.mbsh-thumb-video{position:relative;overflow:hidden;border-radius:10px;}
.mbsh-thumb-video img{display:block;width:100%;height:100%;object-fit:cover;}
.mbsh-thumb-play{position:absolute;left:6px;top:6px;background:rgba(0,0,0,.65);color:#fff;border-radius:999px;padding:4px 6px;font-size:12px;line-height:1;}
.mbsh-inline-media-meta{font-size:12px;color:#6b7280;margin-top:6px;}

/* Hard-hide any leftover ratio/aspect labels under media previews */
.mbsh-inline-media-meta,
.mbsh-media-meta,
.mbsh-media-format,
.mbsh-media-ratio,
.mbsh-media-aspect,
.mbsh-video-ratio,
.mbsh-video-format,
.mbsh-preview-ratio {
  display:none !important;
}

/* Force viewer default position (theme-safe) */
#mbsh-viewer{top:40px; left:40px; right:auto;}
#mbsh-viewer .mbsh-viewer-head{cursor:move; user-select:none;}


/* Viewer: desktop-only counter (e.g., 2 / 5) */
.mbsh-viewer-count{ display:none; margin-left:10px; font-size:12px; opacity:0.85; }
@media (min-width: 768px){
  .mbsh-viewer-count{ display:inline-block; }
}
