/* Front-end styles for Interactive Banner */
.interactive-banner { position: relative; width: 100%; overflow-x: visible; overflow-y: visible; border: 0; background: transparent; box-sizing: border-box; margin: 0; padding: 0; }
.interactive-banner, .interactive-banner * { box-sizing: border-box; }
.interactive-banner .ib-side { position: absolute; left: 0; top: 0; bottom: 0; width: 15%; background-size: cover; background-position: center; /* no z-index to avoid stacking context */ overflow: visible; }
/* Icon as <img> with requested styles */
.interactive-banner .ib-logo { position: absolute; left: 0; top: 0; height: 100% !important; max-height: 100%; width: auto !important; max-width: none !important; display: block; z-index: 9999; pointer-events: none; animation: float 3s ease-in-out infinite; transform-origin: left center; margin: 0; }

@keyframes float {
  0% { transform: translateY(0); }
  50% { transform: translateY(-6%); }
  100% { transform: translateY(0); }
}

.interactive-banner .banner-row { margin-left: 15%; width: 85%; position: relative; z-index: 1; display: flex; gap: 10px; align-items: stretch; }

.interactive-banner .ib-tile { position: relative; overflow: visible; flex: 0 0 auto; }
.interactive-banner .ib-tile-img { position: relative; width: 100%; height: 100%; }
.interactive-banner .ib-tile-img-el { display: block; height: 100% !important; width: auto !important; max-width: 100% !important; object-fit: contain; filter: drop-shadow(0 2px 2px rgba(0,0,0,0.2)); margin: 0; }
.interactive-banner .ib-tile-title { position: absolute; left: 0; right: 0; bottom: 15px; background: rgba(255,255,255,0.8); color: #000; padding: 6px 10px; z-index: 2; text-align: center; }
.interactive-banner .ib-tile-title h5 { margin: 0; font-size: 1em; font-weight: 600; }

/* Overlay panel covering the tiles area (85%) */
.interactive-banner .ib-overlay { position: absolute; left: 15%; right: 0; top: 0; bottom: 0; background: #fff; z-index: 4; transform: translateX(-100%); transition: transform 0.35s ease, opacity 0.2s ease; box-shadow: 0 8px 24px rgba(0,0,0,0.18); overflow: hidden; visibility: hidden; pointer-events: none; opacity: 0; }
.interactive-banner .ib-overlay.active { transform: translateX(0); visibility: visible; pointer-events: auto; opacity: 1; }
.interactive-banner .ib-overlay-inner { padding: 20px; padding-left: 15px; width: 100%; height: 100%; overflow: auto; }
.interactive-banner .ib-overlay-inner button { font: inherit; color: inherit; line-height: inherit; }

/* Mobile header area for logo/background (visible only on mobile) */
.interactive-banner .ib-mobile-header { display: none; }
.interactive-banner .ib-overlay-close { position: absolute; right: 8px; top: 6px; border: 0; background: transparent; font-size: 28px; line-height: 1; cursor: pointer; z-index: 1; }

/* Sliding panel */
.interactive-banner .ib-tile-panel { position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: #fff; z-index: 3; overflow: hidden; transition: width 0.35s ease, transform 0.35s ease; transform: translateX(-100%); box-shadow: 0 8px 24px rgba(0,0,0,0.18); }
.interactive-banner .ib-tile.active .ib-tile-panel { width: 100%; transform: translateX(0); }
.interactive-banner .ib-panel-inner { padding: 20px; height: 100%; overflow: auto; }
.interactive-banner .ib-panel-close { position: absolute; right: 8px; top: 6px; border: 0; background: transparent; font-size: 28px; line-height: 1; cursor: pointer; }

/* Mobile / vertical screens */
@media (max-width: 768px), (orientation: portrait) {
  .interactive-banner .ib-mobile-header { display: block; height: 0.4em; background-size: contain; background-position: left center; background-repeat: no-repeat; margin-bottom: 6px; }
  .interactive-banner .ib-side {opacity:0; position: absolute; width: 0; }
  .interactive-banner .ib-logo {width: 50vw !important; height: auto !important; top: auto; bottom: 0; }
  .interactive-banner .banner-row { margin-left: 0; width: 100%; display: block; }
  .interactive-banner .ib-tile { width: 100% !important; height: auto !important; }
  .interactive-banner .ib-tile + .ib-tile { margin-top: 10px; }
  .interactive-banner { max-height: 80vh; overflow-y: auto; }
  .interactive-banner[data-mobile-max-h] { max-height: var(--ib-mobile-max-h, 80vh); }
  .interactive-banner .ib-overlay { left: 0; right: 0; top: 0; bottom: 0; transform: translateY(-100%); transition: transform 0.35s ease, opacity 0.2s ease; visibility: hidden; pointer-events: none; opacity: 0; }
  .interactive-banner .ib-overlay.active { transform: translateY(0); visibility: visible; pointer-events: auto; opacity: 1; }
  .interactive-banner .ib-tile-title {opacity: 0;}
  .ct-container-full {padding-top:1px;}
}
