/* XPLAY LOOP — TikTok-style full screen app */

:root { --xloop-safe-top: env(safe-area-inset-top); --xloop-safe-bot: env(safe-area-inset-bottom); }

/* Allows JS to reserve space for floating widgets like cookie revisit buttons */
.xplay-loop {
  --xloop-cookie-safe-bot: 0px;           /* legacy (max of left/right) */
  --xloop-cookie-safe-bot-left: 0px;
  --xloop-cookie-safe-bot-right: 0px;
  --xloop-vh: 1vh;
}

body.xplay-loop-page {
  margin: 0 !important;
  background: #000 !important;
}

html.xplay-loop-scrolllock,
html.xplay-loop-scrolllock body {
  height: 100% !important;
  overflow: hidden !important;
  overscroll-behavior: none;
  /* Prevent iOS rubber-band revealing the document background (white line at bottom) */
  background: #000 !important;
}

.xplay-loop, .xplay-loop * { box-sizing: border-box; }

.xplay-loop {
  position: fixed;
  inset: 0;
  z-index: 999999;
  background: #000;
  color: #fff;
  padding: 0;
  font-family: inherit;
}

/* Loading overlay (tab switch / fetchPack) */
.xplay-loop-loading{
  position:absolute;
  inset:0;
  z-index: 60;
  display:none;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}
.xplay-loop-loading.is-on{ display:flex; }
.xplay-loop-loading__inner{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.36);
  border-radius: 999px;
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
}
.xplay-loop-loading__spinner{
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.25);
  border-top-color: rgba(255,255,255,.92);
  animation: xloopSpin .75s linear infinite;
}
.xplay-loop-loading__text{
  font-weight: 850;
  font-size: 12px;
  letter-spacing: .15px;
  opacity: .95;
}
@keyframes xloopSpin{ to { transform: rotate(360deg); } }

/* Network error overlay */
.xplay-loop-neterr{
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: none;
  padding: 20px;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.55);
}
.xplay-loop-neterr.is-on{ display:flex; }
.xplay-loop-neterr__inner{
  max-width: 420px;
  width: 100%;
  padding: 16px 16px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(15,15,15,.65);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 50px rgba(0,0,0,.5);
  text-align: center;
}
.xplay-loop-neterr__title{
  font-weight: 900;
  font-size: 14px;
  margin-bottom: 6px;
}
.xplay-loop-neterr__text{
  font-size: 13px;
  opacity: .92;
  line-height: 1.35;
}
.xplay-loop-neterr__actions{
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 12px;
  flex-wrap: wrap;
}
.xplay-loop-neterr__btn{
  cursor: pointer;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 850;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
}
.xplay-loop-neterr__btn--secondary{
  background: rgba(0,0,0,.18);
}


/* Hide theme chrome behind */
body.xplay-loop-page header,
body.xplay-loop-page footer,
body.xplay-loop-page .site-header,
body.xplay-loop-page .site-footer {
  display: none !important;
}

/* Normalize buttons/links inside loop (prevent theme overrides) */
.xplay-loop button,
.xplay-loop a {
  font: inherit;
  color: inherit;
}
.xplay-loop button {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  background: none;
}

/* iOS Safari: avoid the purple tap highlight “sticking” on the next card */
.xplay-loop, .xplay-loop *{
  -webkit-tap-highlight-color: rgba(0,0,0,0);
}

/* Top bar */
.xplay-loop-top {
  position: absolute;
  top: 0;
  left: 0; right: 0;
  z-index: 30;
  padding: calc(10px + var(--xloop-safe-top)) 14px 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(to bottom, rgba(0,0,0,.72), rgba(0,0,0,0));
}

.xplay-loop-top__brand {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.xplay-loop-top__logo {
  height: var(--xloop-logo-h, 72px);
  width: auto;
  display: block;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.55));
}

/* Optional: separate square logo for mobile/PWA header */
.xplay-loop-top__logo--small{ display:none; }

.xplay-loop-top__brandText {
  font-weight: 900;
  letter-spacing: .2px;
  font-size: 14px;
  opacity: .95;
}

/* Feed tabs (Για Σένα / Ανακάλυψε) */
.xplay-loop-top__tabs{
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  min-width: 0;
}

.xplay-loop-top__tab{
  position: relative;
  padding: 6px 14px;
  font-size: clamp(12px, 3.4vw, 14px);
  font-weight: 800;
  letter-spacing: .15px;
  cursor: pointer;
  color: rgba(255,255,255,.55);
  border-radius: 24px;
  white-space: nowrap;
  transition: background .2s ease, color .2s ease, transform .08s ease;
  text-shadow: 0 8px 22px rgba(0,0,0,.55);
}

/* PWA mobile header: keep compact header even in landscape (stable alignment) */
.xplay-loop--pwa-mobile .xplay-loop-top{
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-areas: "brand tabs actions";
  align-items: center;
  gap: 10px;
  padding: calc(10px + var(--xloop-safe-top)) 12px 10px;
}
.xplay-loop--pwa-mobile.xplay-loop--has-small-logo .xplay-loop-top__logo--main{ display:none; }
.xplay-loop--pwa-mobile.xplay-loop--has-small-logo .xplay-loop-top__logo--small{ display:block; }
.xplay-loop--pwa-mobile .xplay-loop-top__brand{
  grid-area: brand;
  justify-self: start;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(255,255,255,.10);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  min-width: 0;
}
.xplay-loop--pwa-mobile .xplay-loop-top__brandText{ display:none; }
.xplay-loop--pwa-mobile .xplay-loop-top__logo{
  width: 100%;
  height: 100%;
  padding: 4px;
  object-fit: contain;
  filter: none;
}
.xplay-loop--pwa-mobile .xplay-loop-top__tabs{
  grid-area: tabs;
  justify-self: center;
  /* Keep readable tabs without colliding with actions */
  width: min(66vw, 280px);
  max-width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 3px;
  border-radius: 30px;
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(8px);
  min-width: 0;
  overflow: hidden;
}
.xplay-loop--pwa-mobile .xplay-loop-top__tab{
  /* Keep readable like normal mobile */
  font-size: 14px;
  padding: 6px 15px;
  border-radius: 24px;
  letter-spacing: .1px;
  line-height: 1.1;
}

@media (max-width: 360px){
  .xplay-loop--pwa-mobile .xplay-loop-top__tab{
    font-size: 13px;
    padding: 6px 13px;
  }
}
.xplay-loop--pwa-mobile .xplay-loop-top__actions{
  grid-area: actions;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-direction: column; /* saved on top, bell underneath */
}
.xplay-loop--pwa-mobile .xplay-loop-top__iconBtn{ width: 36px; height: 36px; font-size: 15px; }

/* When height is small (landscape), let header breathe in 2 rows */
@media (orientation: landscape) and (max-height: 520px){
  .xplay-loop--pwa-mobile .xplay-loop-top{
    grid-template-areas:
      "brand actions actions"
      "tabs  tabs    tabs";
    row-gap: 8px;
    padding-bottom: 12px;
  }
  .xplay-loop--pwa-mobile .xplay-loop-top__actions{ flex-direction: row; gap: 8px; }
  .xplay-loop--pwa-mobile .xplay-loop-top__tabs{ justify-self: start; width: min(76vw, 360px); }
}

/* Mobile top bar: keep tabs + logo on the SAME row (C logo left + D tabs center) */
@media (max-width: 520px){
  .xplay-loop-top{
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-areas: "brand tabs actions";
    align-items: center;
    gap: 10px;
    padding: calc(10px + var(--xloop-safe-top)) 12px 10px;
  }

  /* Small logo (Option C) */
  /* Small logo (Option C) */
  .xplay-loop--has-small-logo .xplay-loop-top__logo--main{ display:none; }
  .xplay-loop--has-small-logo .xplay-loop-top__logo--small{ display:block; }

  /* Small logo (Option C) */
  .xplay-loop-top__brand{
    grid-area: brand;
    justify-self: start;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: rgba(255,255,255,.10);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    min-width: 0;
  }
  .xplay-loop-top__brandText{ display:none; }

  .xplay-loop-top__logo{
    width: 100%;
    height: 100%;
    padding: 4px;
    object-fit: contain;
    filter: none;
  }

  /* Floating pill tabs (Option D) */
  .xplay-loop-top__tabs{
    grid-area: tabs;
    justify-self: center;
    /* Keep tabs from colliding with action icons on small screens */
    width: min(66vw, 280px);
    max-width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 2px;
    border-radius: 30px;
    background: rgba(255,255,255,.10);
    backdrop-filter: blur(8px);
    min-width: 0;
    overflow: hidden;
  }

  .xplay-loop-top__tab{
    font-size: clamp(13px, 4vw, 15px);
    padding: 6px 14px;
    border-radius: 24px;
    letter-spacing: .1px;
    white-space: nowrap;
    min-width: 0;
    line-height: 1.1;
  }


  .xplay-loop-top__actions{
    grid-area: actions;
    justify-self: end;
    gap: 8px;
  }

  /* In installed mobile PWA only: stack Saved + Push (bell under Saved) */
  .xplay-loop--pwa-mobile .xplay-loop-top__actions{
    flex-direction: column;
    gap: 6px;
  }
  .xplay-loop--pwa-mobile .xplay-loop-top__iconBtn--saved{ order: 1; }
  .xplay-loop--pwa-mobile .xplay-loop-top__iconBtn--push{ order: 2; }

  .xplay-loop-top__iconBtn{
    width: 36px;
    height: 36px;
    font-size: 15px;
  }

  /* Larger article text on mobile */
  .xplay-loop-article__content{ font-size: 18px; line-height: 1.78; }
  .xplay-loop-article__content h2{ font-size: 21px; }
  .xplay-loop-article__content h3{ font-size: 19px; }
}

@media (max-width: 390px){
  .xplay-loop-top{ gap: 8px; }
  .xplay-loop-top__tabs{ width: min(70vw, 280px); }
  .xplay-loop-top__tab{ padding: 6px 12px; }
}

.xplay-loop-top__tab::after{
  display: none !important;
  content: none;
}

.xplay-loop-top__tab.is-active{
  background: #fff;
  color: #000;
  font-weight: 900;
  text-shadow: none;
}

.xplay-loop-top__tab.is-active::after{
  display: none !important;
  content: none;
}

.xplay-loop-top__btn {
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.28);
  color: #fff !important;
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  backdrop-filter: blur(10px);
  text-shadow: 0 8px 22px rgba(0,0,0,.55);
}

.xplay-loop-top__actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.xplay-loop-top__btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.xplay-loop-top__btnIcon{ font-size: 14px; line-height: 1; }
.xplay-loop-top__btnText{ line-height: 1; }
.xplay-loop-top__count{
  margin-left: 2px;
  font-weight: 950;
  font-size: 12px;
  opacity: .92;
}

.xplay-loop-top__iconBtn{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.28);
  color: #fff !important;
  cursor: pointer;
  backdrop-filter: blur(10px);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 16px;
  font-weight: 900;
  text-shadow: 0 8px 22px rgba(0,0,0,.55);
}
.xplay-loop-top__iconBtn:active{ transform: translateY(1px); }

/* Push bell is ONLY for installed mobile PWA */
.xplay-loop-top__iconBtn--push{ display:none; }
.xplay-loop--pwa-mobile .xplay-loop-top__iconBtn--push{ display:flex; }

/* Active fill state so it's obvious when enabled */
.xplay-loop-top__iconBtn--push svg{ fill: none; }
.xplay-loop-top__iconBtn--push.is-active{
  color: rgb(168,85,247);
  background: rgba(168,85,247,.08);
}
.xplay-loop-top__iconBtn--push.is-active svg path{ stroke: currentColor; }
.xplay-loop-top__iconBtn--push.is-active svg path:first-child{ fill: currentColor; }

/* Push bell (active = opted-in) */
.xplay-loop-top__iconBtn--push.is-active{
  border-color: rgba(168,85,247,.9);
  box-shadow: 0 0 0 2px rgba(168,85,247,.25);
}
.xplay-loop-top__iconBtn--push.is-disabled{
  opacity: .55;
  pointer-events: none;
}

/* Refresh button feedback */
#xplay-loop-newpack{ display:none !important; }
#xplay-loop-newpack.is-loading svg{
  animation: xloopSpin 0.8s linear infinite;
  transform-origin: 50% 50%;
}
@keyframes xloopSpin { to { transform: rotate(360deg); } }

/* Icon wrapper (used across UI) */
.xplay-loop-ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.xplay-loop-ico svg{ display:block; }

/* Keep SVG icons consistent inside action buttons */
.xplay-loop-action .xplay-loop-ico svg{
  width: 22px;
  height: 22px;
}

/* PWA install prompt */
#xplay-loop-install{
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 99999;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.62);
  color: #fff;
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
  padding: 12px 12px 10px;
}
#xplay-loop-install[hidden]{ display:none !important; }
#xplay-loop-install .xloopi__row{ display:flex; gap:12px; align-items:flex-start; }
#xplay-loop-install .xloopi__icon{
  width: 42px; height: 42px; border-radius: 12px;
  background: rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  flex: 0 0 auto;
}
#xplay-loop-install .xloopi__icon img{ width: 28px; height: 28px; border-radius: 8px; }
#xplay-loop-install .xloopi__title{ font-weight: 950; font-size: 14px; line-height: 1.15; margin: 0 0 2px; }
#xplay-loop-install .xloopi__body{ font-size: 12px; opacity: .92; line-height: 1.25; margin: 0; }
#xplay-loop-install .xloopi__actions{ display:flex; gap:10px; justify-content:flex-end; margin-top: 10px; }
#xplay-loop-install .xloopi__btn{
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 850;
  font-size: 12px;
  cursor: pointer;
}
#xplay-loop-install .xloopi__btn--primary{ background: rgba(168,85,247,.78); border-color: rgba(168,85,247,.9); }
#xplay-loop-install .xloopi__btn:active{ transform: translateY(1px); }

@media (min-width: 980px){
  #xplay-loop-install{ left: auto; right: 18px; bottom: 18px; max-width: 420px; }
}

/* Slight spacing for special badge icons */
.xplay-loop-special .xplay-loop-ico{
  margin-right: 6px;
  transform: translateY(1px);
}

/* Feed: use svh/dvh for iOS so 1 swipe = 1 card */
.xplay-loop-feed {
  /* Fallback first, then modern viewport units */
  height: 100vh;
  height: 100svh;
  height: 100dvh;
  height: calc(var(--xloop-vh, 1vh) * 100);
  overflow-y: auto;
  scroll-snap-type: y mandatory;
  -webkit-overflow-scrolling: touch;
  /* Safari rounding fix: ensure the last card can always snap into view */
  padding-bottom: 12px;
  scroll-padding-bottom: 12px;

}

.xplay-loop-item {
  /* Fallback first, then modern viewport units */
  height: 100vh;
  height: 100svh;
  height: 100dvh;
  height: calc(var(--xloop-vh, 1vh) * 100);
  position: relative;
  scroll-snap-align: start;
  overflow: hidden;
}

@media (hover: hover) and (pointer: fine) {
  .xplay-loop-item { scroll-snap-stop: always; }
}

/* Layout wrapper (mobile: full screen; desktop: stage + side rail like TikTok) */
.xplay-loop-layout {
  position: absolute;
  inset: 0;
}

.xplay-loop-stage {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.xplay-loop-side {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.xplay-loop-side .xplay-loop-actions { pointer-events: auto; }

/* Background media */
.xplay-loop-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  filter: saturate(1.07) contrast(1.02);
  background: #111;
}

/* Desktop-only blurred backdrop (prevents “low-res full-page” feel) */
.xplay-loop-backdrop { display: none; }

.xplay-loop-bg--fallback {
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,.10), rgba(0,0,0,0) 40%),
              radial-gradient(circle at 70% 70%, rgba(255,255,255,.10), rgba(0,0,0,0) 45%),
              linear-gradient(180deg, #0a0a0a, #000);
}

/* Overlays */
.xplay-loop-grad-top {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 22vh;
  background: linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,0));
  pointer-events: none;
}
.xplay-loop-grad-bot {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 48vh;
  background: linear-gradient(to top, rgba(0,0,0,.80), rgba(0,0,0,0));
  pointer-events: none;
}

/* Ad card (clear, centered, predictable sizing for AdSense) */
.xplay-loop-item--ad .xplay-loop-stage{
  display:flex;
  align-items:center;
  justify-content:center;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* Floating like burst (dopamine feedback) */
.xplay-loop-likeBurst{
  position:absolute;
  z-index: 40;
  width: 96px;
  height: 96px;
  transform: translate(-50%, -50%) scale(.25);
  opacity: 0;
  pointer-events: none;
  filter: drop-shadow(0 14px 30px rgba(0,0,0,.55));
}
.xplay-loop-likeBurst svg{
  width:100%;
  height:100%;
  display:block;
  fill: currentColor;
}
.xplay-loop-likeBurst{
  color: rgba(255, 120, 0, .95);
}
.xplay-loop-likeBurst.is-on{
  animation: xplayLikeBurst .62s ease-out forwards;
}
@keyframes xplayLikeBurst{
  0%   { transform: translate(-50%, -50%) scale(.20); opacity: 0; }
  12%  { opacity: 1; }
  55%  { transform: translate(-50%, -62%) scale(1.05); opacity: 1; }
  100% { transform: translate(-50%, -96%) scale(.92); opacity: 0; }
}



.xplay-loop-ad{
  position: relative;
  z-index: 22;
  width: min(420px, 92vw);
  min-height: 260px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.30);
  border-radius: 22px;
  padding: 16px 14px;
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 44px rgba(0,0,0,.55);
}

.xplay-loop-ad__label{
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .25px;
  opacity: .75;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.xplay-loop-ad__slot{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 220px;
}

.xplay-loop-ad__slot ins{ display:block; width:100%; }

.xplay-loop-ad__fallback{
  font-size: 13px;
  opacity: .85;
  text-align:center;
}

/* Special badge (strong comms) */
.xplay-loop-special {
  position: absolute;
  left: 14px;
  top: calc(92px + var(--xloop-safe-top));
  z-index: 25;
  padding: 8px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .2px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.38);
  backdrop-filter: blur(10px);
  text-shadow: 0 10px 22px rgba(0,0,0,.60);
}

@media (max-width: 520px){
  .xplay-loop-special{ top: calc(118px + var(--xloop-safe-top)); }
}
.xplay-loop-special--vault { animation: xloopPulse 1.9s ease-in-out infinite; }
.xplay-loop-special--mystery { animation: xloopPulse 2.4s ease-in-out infinite; }

.xplay-loop-special--banger{
  border-color: rgba(0,255,255,.36);
  background: linear-gradient(135deg, rgba(0,0,0,.46), rgba(12,12,18,.46));
  box-shadow:
    0 0 0 1px rgba(0,255,255,.08) inset,
    0 10px 34px rgba(0,0,0,.55),
    0 0 26px rgba(0,255,255,.18),
    0 0 44px rgba(168,85,247,.16);
  text-transform: uppercase;
  overflow:hidden;
  position:absolute;
}
.xplay-loop-special--banger .xplay-loop-jackpotText{ position: relative; display:inline-block; }
.xplay-loop-special--banger .xplay-loop-jackpotText::before,
.xplay-loop-special--banger .xplay-loop-jackpotText::after{
  content: attr(data-text);
  position:absolute;
  left:0;
  top:0;
  opacity: .72;
  pointer-events:none;
}
.xplay-loop-special--banger .xplay-loop-jackpotText::before{
  transform: translate(1px, -1px);
  filter: blur(.2px);
  text-shadow: -1px 0 rgba(0,255,255,.55);
  clip-path: inset(0 0 52% 0);
}
.xplay-loop-special--banger .xplay-loop-jackpotText::after{
  transform: translate(-1px, 1px);
  filter: blur(.25px);
  text-shadow: 1px 0 rgba(255,0,160,.35);
  clip-path: inset(48% 0 0 0);
}
.xplay-loop-special--banger::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    linear-gradient(110deg, transparent 0%, rgba(0,255,255,.16) 25%, rgba(168,85,247,.12) 48%, rgba(0,255,255,.16) 72%, transparent 100%);
  transform: translateX(-40%);
  opacity:.65;
  mix-blend-mode: screen;
  animation: xloopJackpotShimmer 1.15s ease-in-out infinite;
}
.xplay-loop-special--banger::after{
  content:"";
  position:absolute;
  inset:0;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,.12) 0 1px,
    rgba(255,255,255,0) 1px 3px
  );
  opacity:.12;
  mix-blend-mode: overlay;
  animation: xloopScanShift 2.1s linear infinite;
}

@keyframes xloopJackpotShimmer{
  0%{ transform: translateX(-48%); opacity:.20; }
  35%{ opacity:.72; }
  100%{ transform: translateX(42%); opacity:.22; }
}

@keyframes xloopScanShift{
  0%{ transform: translateY(0); }
  100%{ transform: translateY(10px); }
}


@keyframes xloopPulse {
  0%,100% { transform: translateY(0); box-shadow: 0 0 0 rgba(255,255,255,0); }
  50% { transform: translateY(-1px); box-shadow: 0 0 18px rgba(255,255,255,.10); }
}

/* Make special picks pop (whole card, not just the badge) */
.xplay-loop-item[data-special="mystery"] .xplay-loop-stage::before,
.xplay-loop-item[data-special="vault"] .xplay-loop-stage::before{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  z-index: 6;
  opacity: .18;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.18), rgba(0,0,0,0) 52%),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.14), rgba(0,0,0,0) 58%);
  mix-blend-mode: screen;
}

.xplay-loop-item[data-special="vault"] .xplay-loop-stage::before{
  opacity: .22;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.22), rgba(0,0,0,0) 54%),
    radial-gradient(circle at 70% 80%, rgba(255,255,255,.16), rgba(0,0,0,0) 60%);
}

.xplay-loop-item[data-special="vault"] .xplay-loop-stage,
.xplay-loop-item[data-special="mystery"] .xplay-loop-stage{
  box-shadow:
    0 36px 86px rgba(0,0,0,.52),
    0 18px 44px rgba(168,85,247,.16);
}

/* Banger (Jackpot) – neon + glitch treatment */
.xplay-loop-item[data-special="banger"] .xplay-loop-stage::before{
  content:"";
  position:absolute;
  inset:-3px;
  pointer-events:none;
  z-index: 6;
  opacity: .28;
  background:
    radial-gradient(circle at 18% 25%, rgba(0,255,255,.26), rgba(0,0,0,0) 54%),
    radial-gradient(circle at 82% 75%, rgba(168,85,247,.18), rgba(0,0,0,0) 58%),
    repeating-linear-gradient(to bottom, rgba(255,255,255,.14) 0 1px, rgba(255,255,255,0) 1px 4px);
  mix-blend-mode: screen;
}

.xplay-loop-item[data-special="banger"] .xplay-loop-stage{
  box-shadow:
    0 40px 96px rgba(0,0,0,.58),
    0 22px 54px rgba(0,255,255,.16),
    0 18px 44px rgba(168,85,247,.14);
}

/* Active jackpot hit */
.xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-stage{
  animation: xloopJackpotPop 1.55s cubic-bezier(.2,.9,.2,1) 1;
}
.xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-stage::after{
  content:"";
  position:absolute;
  inset:-26px;
  border-radius: 30px;
  pointer-events:none;
  z-index: 7;
  background:
    radial-gradient(circle at 22% 18%, rgba(0,255,255,.34) 0 2px, transparent 3px),
    radial-gradient(circle at 78% 26%, rgba(168,85,247,.26) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 82%, rgba(0,255,255,.22) 0 2px, transparent 3px),
    radial-gradient(circle at 30% 78%, rgba(255,255,255,.18) 0 2px, transparent 3px),
    radial-gradient(circle at 52% 52%, rgba(0,255,255,.12) 0 1px, transparent 2px);
  opacity: 0;
  animation: xloopJackpotSpark 1.35s ease-out 1;
}

.xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-special--banger{
  animation: xloopJackpotBadge 1.45s ease-out 1;
}


.xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-jackpotText::before{
  animation: xloopTextGlitchA .65s steps(2,end) 1;
}
.xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-jackpotText::after{
  animation: xloopTextGlitchB .72s steps(2,end) 1;
}

@keyframes xloopTextGlitchA{
  0%{ transform: translate(1px,-1px); clip-path: inset(0 0 52% 0); opacity:.8; }
  18%{ transform: translate(3px,-2px); clip-path: inset(0 0 34% 0); }
  34%{ transform: translate(-2px,-1px); clip-path: inset(0 0 66% 0); }
  52%{ transform: translate(2px,-3px); clip-path: inset(0 0 46% 0); }
  100%{ transform: translate(1px,-1px); clip-path: inset(0 0 52% 0); opacity:.72; }
}

@keyframes xloopTextGlitchB{
  0%{ transform: translate(-1px,1px); clip-path: inset(48% 0 0 0); opacity:.75; }
  16%{ transform: translate(-3px,2px); clip-path: inset(62% 0 0 0); }
  36%{ transform: translate(2px,1px); clip-path: inset(40% 0 0 0); }
  58%{ transform: translate(-2px,3px); clip-path: inset(54% 0 0 0); }
  100%{ transform: translate(-1px,1px); clip-path: inset(48% 0 0 0); opacity:.72; }
}

@keyframes xloopJackpotPop{
  0%{ transform: translateZ(0) scale(1); filter: saturate(1); }
  18%{ transform: translateZ(0) scale(1.018); filter: saturate(1.35) contrast(1.06); }
  42%{ transform: translateZ(0) scale(1.01); }
  100%{ transform: translateZ(0) scale(1); filter: saturate(1) contrast(1); }
}

@keyframes xloopJackpotSpark{
  0%{ opacity:0; transform: scale(.96); }
  18%{ opacity:.85; }
  100%{ opacity:0; transform: scale(1.05); }
}

@keyframes xloopJackpotBadge{
  0%{ transform: translateY(0) skewX(0deg); filter: brightness(1); }
  12%{ transform: translateY(-2px) skewX(-6deg); filter: brightness(1.25); }
  22%{ transform: translateY(1px) skewX(5deg); }
  32%{ transform: translateY(-1px) skewX(-3deg); }
  100%{ transform: translateY(0) skewX(0deg); filter: brightness(1); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .xplay-loop-special--banger::before,
  .xplay-loop-special--banger::after,
  .xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-stage,
  .xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-stage::after,
  .xplay-loop-item.xplay-loop-jackpot-anim .xplay-loop-special--banger{
    animation: none !important;
  }
}


.xplay-loop-item.xplay-loop-reward-anim .xplay-loop-stage::before{
  opacity: .40;
  animation: xloopRewardFlash 1.55s ease-out 1;
}

@keyframes xloopRewardFlash{
  0%{ opacity:.14; }
  30%{ opacity:.46; }
  100%{ opacity:.22; }
}

/* Extra sparkle hit for special items (whole card) */
.xplay-loop-item.xplay-loop-reward-anim[data-special="vault"] .xplay-loop-stage::after,
.xplay-loop-item.xplay-loop-reward-anim[data-special="mystery"] .xplay-loop-stage::after{
  content:"";
  position:absolute;
  inset:-22px;
  border-radius: 28px;
  pointer-events:none;
  z-index: 7;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,.26) 0 2px, transparent 3px),
    radial-gradient(circle at 82% 24%, rgba(216,180,254,.24) 0 2px, transparent 3px),
    radial-gradient(circle at 66% 78%, rgba(167,139,250,.20) 0 2px, transparent 3px),
    radial-gradient(circle at 28% 82%, rgba(255,255,255,.18) 0 2px, transparent 3px),
    radial-gradient(circle at 46% 46%, rgba(216,180,254,.14) 0 1px, transparent 2px);
  opacity: 0;
  animation: xloopSparkle 1.35s ease-out 1;
}

@keyframes xloopSparkle{
  0%{ opacity: 0; transform: scale(.985); }
  18%{ opacity: 1; }
  100%{ opacity: 0; transform: scale(1.02); }
}


/* Right action rail */
.xplay-loop-actions {
  position: absolute;
  right: 10px;
  /* Keep icons lower on modern iPhones (prevents huge empty gap under the rail) */
  bottom: calc(clamp(42px, 6vh, 70px) + var(--xloop-safe-bot) + var(--xloop-cookie-safe-bot-right));
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: center;
}

.xplay-loop-actions__item { display:flex; flex-direction:column; align-items:center; gap:7px; }

.xplay-loop-action {
  width: 60px;
  height: 60px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.30);
  color: #fff !important;
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 30px rgba(0,0,0,.42);
}
.xplay-loop-action:active { transform: translateY(1px); }

.xplay-loop-action__label {
  font-size: 11px;
  opacity: .92;
  text-align: center;
  color: rgba(255,255,255,.95);
  text-shadow: 0 10px 22px rgba(0,0,0,.60);
}

/* TikTok-style counters under icons */
.xplay-loop-action__count{
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  opacity: .95;
  text-align: center;
  color: rgba(255,255,255,.96);
  text-shadow: 0 10px 22px rgba(0,0,0,.60);
  font-variant-numeric: tabular-nums;
  min-width: 44px;
}

.xplay-loop-action__count--empty{
  opacity: 0;
}

/* Hide legacy labels if any cached HTML still contains them */
.xplay-loop-action__label{
  display:none;
}

/* Bottom info */
.xplay-loop-info {
  position: absolute;
  left: 14px;
  right: 92px;
  bottom: calc(18px + var(--xloop-safe-bot) + var(--xloop-cookie-safe-bot-left));
  z-index: 20;
  display: flex;
  flex-direction: column;
}

.xplay-loop-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.xplay-loop-badge {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(12px);
  text-shadow: 0 10px 22px rgba(0,0,0,.55);
}

/* Clickable title */
.xplay-loop-titleBtn {
  display: block;
  width: 100%;
  text-align: left;
  color: #fff !important;
  font-size: clamp(26px, 3.2vw, 38px);
  line-height: 1.15;
  font-weight: 950;
  letter-spacing: -.2px;
  text-shadow: 0 10px 30px rgba(0,0,0,.70);
  cursor: pointer;
  background: transparent !important;
  border: 0 !important;
  padding: 0;
  margin: 0;
  /* prevent pushing the button out of view on mobile */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Avoid theme hover backgrounds; modern hover */
.xplay-loop-titleBtn:hover { background: transparent !important; }
.xplay-loop-titleBtn__text { display: inline; }

/* Stronger, modern title pop when a card becomes active (mobile included) */
.xplay-loop-item.is-active .xplay-loop-titleBtn__text{
  text-shadow: 0 14px 34px rgba(0,0,0,.78), 0 0 22px rgba(168,85,247,.20);
}

.xplay-loop-item.xplay-loop-title-glint .xplay-loop-titleBtn__text{
  background-image: linear-gradient(90deg,
    rgba(255,255,255,1) 0%,
    rgba(216,180,254,.92) 22%,
    rgba(255,255,255,1) 44%,
    rgba(167,139,250,.92) 62%,
    rgba(255,255,255,1) 100%
  );
  background-size: 240% 100%;
  background-position: 120% 50%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent !important;
  animation: xloopTitleShine .95s ease-out 1;
}

@keyframes xloopTitleShine { to { background-position: -10% 50%; } }

@media (hover:hover) and (pointer:fine) {
  .xplay-loop-titleBtn:hover { transform: translateY(-1px); }
  .xplay-loop-titleBtn:hover .xplay-loop-titleBtn__text {
    text-shadow: 0 12px 34px rgba(0,0,0,.75);
  }
}

@supports (-webkit-background-clip:text) {
  @media (hover:hover) and (pointer:fine) {
    .xplay-loop-titleBtn:hover .xplay-loop-titleBtn__text{
      background-image: linear-gradient(90deg, rgba(255,255,255,1), rgba(255,255,255,.65), rgba(255,255,255,1));
      background-size: 220% 100%;
      background-position: 0% 50%;
      -webkit-background-clip: text;
      color: transparent !important;
      animation: xloopShine 1.05s ease-out 1;
    }
  }
}

@keyframes xloopShine { to { background-position: 100% 50%; } }

.xplay-loop-openMeta {
  margin-top: 10px;
  display: inline-flex;
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(0,0,0,.28);
  color: #fff !important;
  padding: 9px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  backdrop-filter: blur(12px);
  text-shadow: 0 10px 22px rgba(0,0,0,.65);
  width: max-content;
}

.xplay-loop-openMeta__count{
  font-variant-numeric: tabular-nums;
}

.xplay-loop-openMeta__label{
  opacity: .92;
  font-weight: 800;
}

.xplay-loop-openMeta .xplay-loop-ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.xplay-loop-openMeta .xplay-loop-ico svg{
  display:block;
}


/* Action states */
.xplay-loop-action.is-active {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.42);
  box-shadow: 0 18px 40px rgba(0,0,0,.52);
}

/* Fill the heart when "Μου άρεσε" is active */
.xplay-loop-action--like.is-active svg path{ fill: currentColor; }

/* End card */
.xplay-loop-item--end { background: #000; }
.xplay-loop-end {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  padding: 24px;
}
.xplay-loop-end__box{
  width: min(520px, 100%);
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  border-radius: 22px;
  padding: 18px;
  backdrop-filter: blur(14px);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
}
.xplay-loop-end__title{ font-size: 22px; font-weight: 950; margin-bottom: 8px; }
.xplay-loop-end__summary{ font-size: 15px; font-weight: 950; margin-bottom: 12px; opacity: .96; }
.xplay-loop-end__sub{ opacity:.9; margin-bottom: 14px; }
.xplay-loop-end__sub--hint{ margin-top: -6px; }
.xplay-loop-end__btn{
  width: 100%;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.22);
  color:#fff !important;
  padding: 12px 14px;
  border-radius: 999px;
  font-weight: 950;
  cursor:pointer;
}

.xplay-loop-end__actions{ display:flex; flex-direction:column; gap:10px; }

.xplay-loop-end__btn--secondary{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.20);
}

/* Overlay reader — polished */
.xplay-loop-overlay {
  display: none !important;
  position: fixed;
  inset: 0;
  z-index: 1000000;
  background: rgba(0,0,0,.68);
  align-items: flex-end;
}
.xplay-loop-overlay.is-open { display: flex !important; }

/* When reader is open, fully disable feed chrome behind (prevents “buttons overlaying article” feel) */
.xplay-loop.is-reading .xplay-loop-top,
.xplay-loop.is-reading .xplay-loop-feed,
.xplay-loop.is-modal .xplay-loop-top,
.xplay-loop.is-modal .xplay-loop-feed {
  opacity: 0;
  pointer-events: none;
}

.xplay-loop-sheet {
  width: 100%;
  max-height: 92dvh;
  background: #0f0f10;
  color: #fff;
  border-top-left-radius: 22px;
  border-top-right-radius: 22px;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  position: relative;
  display: flex;
  flex-direction: column;
}

.xplay-loop-sheet__header{
  position: sticky;
  top: 0;
  z-index: 8;
  padding: calc(10px + var(--xloop-safe-top)) 14px 10px;
  background: rgba(15,15,16,.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.xplay-loop-sheet__body{
  flex: 1;
  overflow: auto;
  padding: 14px 14px 26px;
  -webkit-overflow-scrolling: touch;
}

.xplay-loop-sheet__title{
  font-size: 16px;
  font-weight: 950;
  letter-spacing: .1px;
  padding: 4px 0 12px;
}

.xplay-loop-sheet__handle {
  width: 52px;
  height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,.20);
  margin: 0 auto 10px;
}

.xplay-loop-sheet__close {
  position: absolute;
  right: 10px;
  top: calc(10px + var(--xloop-safe-top));
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: #fff !important;
  cursor: pointer;
  font-size: 18px;
}

.xplay-loop-sheet__open{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: #fff;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 13px;
  max-width: calc(100% - 64px);
}

/* Article typography */
.xplay-loop-article {
  max-width: 720px;
  margin: 0 auto;
  padding: 4px 4px 22px;
}

.xplay-loop-article__top {
  display:flex;
  justify-content:flex-start;
  margin: 6px 0 10px;
}

.xplay-loop-article__open {
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: #fff;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 13px;
}

.xplay-loop-article__title { margin: 6px 0 10px; font-size: clamp(22px, 2.2vw, 30px); line-height: 1.18; font-weight: 950; color: #fff !important; }
.xplay-loop-article__meta { display:flex; gap:8px; flex-wrap:wrap; margin: 10px 0 14px; opacity: .92; }
.xplay-loop-article__pill { font-size:12px; padding: 4px 10px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.10); }

/* Make WP content look intentional */
.xplay-loop-article__content { font-size: 16px; line-height: 1.72; color: rgba(255,255,255,.92) !important; }
.xplay-loop-article__content * { color: inherit !important; }
.xplay-loop-article__content p { margin: 0 0 14px; }
.xplay-loop-article__content h2 { margin: 22px 0 10px; font-size: 20px; line-height: 1.25; color: #fff !important; }
.xplay-loop-article__content h3 { margin: 18px 0 10px; font-size: 18px; line-height: 1.25; opacity: .98; color: #fff !important; }
.xplay-loop-article__content a { color: #fff; text-decoration: underline; text-underline-offset: 3px; }
.xplay-loop-article__content img,
.xplay-loop-article__content video,
.xplay-loop-article__content iframe { max-width: 100%; height: auto; border-radius: 14px; }
.xplay-loop-article__content figure { margin: 0 0 14px; }
.xplay-loop-article__content blockquote {
  margin: 14px 0;
  padding: 12px 14px;
  border-left: 3px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.06);
  border-radius: 12px;
}

/* Mobile tuning: guarantee title+button visible */
@media (max-width: 420px), (max-height: 740px) {
  .xplay-loop-actions { bottom: calc(clamp(36px, 5vh, 60px) + var(--xloop-safe-bot) + var(--xloop-cookie-safe-bot-right)); gap: 12px; }
  .xplay-loop-action { width: 64px; height: 64px; font-size: 24px; }
  .xplay-loop-titleBtn { font-size: 28px; -webkit-line-clamp: 3; }
  .xplay-loop-badges { margin-bottom: 8px; }
  /* keep it clean: show first 3 badges only (avoid pushing button down) */
  .xplay-loop-badge:nth-child(n+4) { display: none; }
  .xplay-loop-openMeta { margin-top: 10px; padding: 10px 12px; }
}

/* Desktop: TikTok-like stage + side rail (no full-page low-res cover) */
@media (max-width: 979px) {
  .xplay-loop-bg { transform: none; }
}

@media (min-width: 980px) {
  /* Desktop has more vertical room; allow longer titles before clamping */
  .xplay-loop-titleBtn { -webkit-line-clamp: 5; }

  .xplay-loop-layout {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 26px;
    padding: 34px 28px;
  }

  .xplay-loop-stage {
    position: relative;
    inset: auto;
    width: min(560px, 42vw);
    height: min(92vh, 920px);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 24px 70px rgba(0,0,0,.55);
    border: 1px solid rgba(255,255,255,.10);
  }

  .xplay-loop-bg {
    transform: none;
  }

  .xplay-loop-item.is-active .xplay-loop-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: blur(26px) saturate(1.1);
    transform: scale(1.08);
    opacity: .26;
    pointer-events: none;
    z-index: 0;
  }

  .xplay-loop-layout { z-index: 2; }

  .xplay-loop-side {
    position: relative;
    inset: auto;
    width: 110px;
    height: min(92vh, 920px);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    pointer-events: auto;
  }

  .xplay-loop-actions {
    position: relative;
    right: auto;
    bottom: auto;
    z-index: 20;
  }

  .xplay-loop-info {
    right: 14px;
    bottom: 16px;
  }

  /* Reader modal feels better on desktop */
  .xplay-loop-overlay { align-items: center; justify-content: center; }
  .xplay-loop-sheet {
    width: min(860px, 92vw);
    max-height: 88vh;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.10);
  }
}

/* Reward pop (mystery) — subtle, non-cringe */
.xplay-loop-item.xplay-loop-reward-anim .xplay-loop-special--mystery {
  animation: xloopRewardPop 900ms ease-out 1;
}
.xplay-loop-item.xplay-loop-reward-anim .xplay-loop-special--mystery::after {
  content: "επιλογή βάσει όσων σου αρέσουν";
  display: block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .1px;
  opacity: .92;
  margin-top: 4px;
}

@keyframes xloopRewardPop {
  0% { transform: translateY(0) scale(.92); box-shadow: 0 0 0 rgba(255,255,255,0); }
  55% { transform: translateY(-2px) scale(1.03); box-shadow: 0 0 28px rgba(255,255,255,.12); }
  100% { transform: translateY(0) scale(1); box-shadow: 0 0 0 rgba(255,255,255,0); }
}

/* Tiny confirmation toasts (action feedback) */
.xplay-loop-toast {
  position: fixed;
  left: 50%;
  bottom: calc(18px + var(--xloop-safe-bot) + max(var(--xloop-cookie-safe-bot-left), var(--xloop-cookie-safe-bot-right)));
  transform: translate(-50%, 12px);
  opacity: 0;
  z-index: 1000001;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(0,0,0,.72);
  color: #fff;
  font-weight: 850;
  font-size: 13px;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  transition: transform .22s ease, opacity .22s ease;
}
.xplay-loop-toast.is-in {
  opacity: 1;
  transform: translate(-50%, 0);
}


/* Desktop arrow nav (TikTok-like) */
.xplay-loop-desktopNav{
  display:none;
  position: fixed;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1000002;
  pointer-events: auto;
  flex-direction: column;
  gap: 14px;
}
.xplay-loop-navBtn{
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.30);
  color: #fff !important;
  cursor: pointer;
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 30px rgba(0,0,0,.42);
  font-size: 14px;
  font-weight: 900;
  display:flex;
  align-items:center;
  justify-content:center;
}
.xplay-loop-navBtn:active{ transform: translateY(1px); }
@media (hover: hover) and (pointer: fine){
  .xplay-loop-desktopNav{ display:flex !important; }
}

.xplay-loop.is-reading .xplay-loop-desktopNav,
.xplay-loop.is-modal .xplay-loop-desktopNav{ display:none !important; }

/* Saved modal */
.xplay-loop-sheet--saved .xplay-loop-sheet__header{
  padding: 14px 14px 0;
  display:flex;
  align-items:center;
  justify-content: space-between;
}
.xplay-loop-sheet--saved .xplay-loop-sheet__close{
  position: static;
  width: 40px;
  height: 40px;
}
.xplay-loop-overlay--saved{ background: rgba(0,0,0,.74); }
.xplay-loop-sheet--saved{ max-height: 80vh; }

@media (min-width: 980px){
  .xplay-loop-sheet--saved{
    width: min(560px, 94vw);
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: 0 24px 70px rgba(0,0,0,.55);
  }
  .xplay-loop-overlay--saved{ align-items: center; }
}

.xplay-loop-saved{ display:flex; flex-direction:column; gap:10px; }
.xplay-loop-savedEmpty{ padding: 14px; opacity: .9; }

.xplay-loop-savedItem{
  display:flex;
  gap:12px;
  align-items:center;
  padding: 10px 10px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  cursor: pointer;
}
.xplay-loop-savedItem:active{ transform: translateY(1px); }

.xplay-loop-savedThumb{
  width: 58px;
  height: 58px;
  border-radius: 14px;
  object-fit: cover;
  background: #111;
  flex: 0 0 58px;
}

.xplay-loop-savedText{ flex: 1; min-width: 0; }
.xplay-loop-savedTitle{ font-weight: 950; font-size: 14px; line-height: 1.25; margin-bottom: 4px; }
.xplay-loop-savedMeta{ font-size: 12px; opacity: .86; }

.xplay-loop-savedRemove{
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color:#fff !important;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  cursor:pointer;
}
