/* ==========================================================================
   Akadverse Pro — Cover Widget
   Fully isolated, responsive, no overflow/collision.
   ========================================================================== */

/* ── Wrapper ─────────────────────────────────────────────────────────── */
.akadverse-cover-wrapper {
  position: relative;
  background-size: cover;
  background-position: center;
  min-height: 100vh;
  width: 100%;
  max-width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  box-sizing: border-box;
}

.akadverse-cover-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}
.akadverse-gradient-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

/* ── Content ─────────────────────────────────────────────────────────── */
.akadverse-cover-content {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(8px, 2vw, 14px);
  padding: clamp(16px, 4vw, 32px);
  max-width: 90%;
  width: 90%;
  box-sizing: border-box;
  min-width: 0;
}
.akadverse-foto-pemelai img {
  max-width: clamp(120px, 30vw, 200px);
  width: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}
.akadverse-button-group {
  display: flex;
  gap: clamp(8px, 2vw, 12px);
  flex-wrap: wrap;
  justify-content: center;
  max-width: 100%;
}

/* ── Ornaments ───────────────────────────────────────────────────────── */
.akadverse-ornament {
  position: absolute;
  pointer-events: none;
  z-index: 5;
  --akv-rotate: 0deg;
  max-width: 40vw;  /* prevent huge ornaments colliding content */
}
.akadverse-ornament img { width: 100%; display: block; }

.akadverse-ornament-preset-top-left     { top: 0; left: 0; }
.akadverse-ornament-preset-top-right    { top: 0; right: 0; }
.akadverse-ornament-preset-bottom-left  { bottom: 0; left: 0; }
.akadverse-ornament-preset-bottom-right { bottom: 0; right: 0; }
.akadverse-ornament-preset-top-center    { top: 0; left: 50%; transform: translateX(-50%) rotate(var(--akv-rotate)); }
.akadverse-ornament-preset-bottom-center { bottom: 0; left: 50%; transform: translateX(-50%) rotate(var(--akv-rotate)); }
.akadverse-ornament-preset-left-center  { top: 50%; left: 0; transform: translateY(-50%) rotate(var(--akv-rotate)); }
.akadverse-ornament-preset-right-center { top: 50%; right: 0; transform: translateY(-50%) rotate(var(--akv-rotate)); }
.akadverse-ornament-preset-center       { top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(var(--akv-rotate)); }
.akadverse-ornament:not(.akadverse-ornament-preset-top-center):not(.akadverse-ornament-preset-bottom-center):not(.akadverse-ornament-preset-left-center):not(.akadverse-ornament-preset-right-center):not(.akadverse-ornament-preset-center) {
  transform: rotate(var(--akv-rotate));
}

/* ── Ornament Animations ─────────────────────────────────────────────── */
@keyframes akvSway      { 0%,100%{transform:rotate(calc(var(--akv-rotate) - 6deg))}  50%{transform:rotate(calc(var(--akv-rotate) + 6deg))} }
@keyframes akvFloat     { 0%,100%{transform:translateY(0) rotate(var(--akv-rotate))} 50%{transform:translateY(-14px) rotate(var(--akv-rotate))} }
@keyframes akvPendulum  { 0%,100%{transform:rotate(calc(var(--akv-rotate) - 12deg))} 50%{transform:rotate(calc(var(--akv-rotate) + 12deg))} }
@keyframes akvPulseOrn  { 0%,100%{transform:scale(1) rotate(var(--akv-rotate))}      50%{transform:scale(1.06) rotate(var(--akv-rotate))} }
@keyframes akvSpinSlow  { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }

.akadverse-ornament-anim-sway      { animation: akvSway      var(--akv-speed, 4s)   ease-in-out infinite; }
.akadverse-ornament-anim-float     { animation: akvFloat     var(--akv-speed, 3s)   ease-in-out infinite; }
.akadverse-ornament-anim-pendulum  { animation: akvPendulum  var(--akv-speed, 5s)   ease-in-out infinite; }
.akadverse-ornament-anim-pulse     { animation: akvPulseOrn  var(--akv-speed, 3.5s) ease-in-out infinite; }
.akadverse-ornament-anim-spin-slow { animation: akvSpinSlow  var(--akv-speed, 10s)  linear infinite; }
.akadverse-ornament-anim-none      { animation: none; }

/* ── Cover Entrance Animations ───────────────────────────────────────── */
@keyframes coverFadeIn       { from{opacity:0}                            to{opacity:1} }
@keyframes coverFadeInUp     { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes coverFadeInDown   { from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)} }
@keyframes coverZoomIn       { from{opacity:0;transform:scale(0.8)}       to{opacity:1;transform:scale(1)} }
@keyframes coverSlideInLeft  { from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)} }
@keyframes coverSlideInRight { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }

.akadverse-cover-anim-fadeIn       { animation: coverFadeIn       var(--akv-dur,1s) ease var(--akv-delay,0.3s) both; }
.akadverse-cover-anim-fadeInUp     { animation: coverFadeInUp     var(--akv-dur,1s) ease var(--akv-delay,0.3s) both; }
.akadverse-cover-anim-fadeInDown   { animation: coverFadeInDown   var(--akv-dur,1s) ease var(--akv-delay,0.3s) both; }
.akadverse-cover-anim-zoomIn       { animation: coverZoomIn       var(--akv-dur,1s) ease var(--akv-delay,0.3s) both; }
.akadverse-cover-anim-slideInLeft  { animation: coverSlideInLeft  var(--akv-dur,1s) ease var(--akv-delay,0.3s) both; }
.akadverse-cover-anim-slideInRight { animation: coverSlideInRight var(--akv-dur,1s) ease var(--akv-delay,0.3s) both; }

/* fade-out */
.akadverse-cover-wrapper.fade-out { animation: coverFadeOut 0.8s ease forwards; }
@keyframes coverFadeOut { to { opacity: 0; } }

/* ── QR Modal ────────────────────────────────────────────────────────── */
.qr-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 99999;
  align-items: center;
  justify-content: center;
}
.qr-modal-overlay.active { display: flex; }
.qr-modal-box {
  background: #fff;
  border-radius: 16px;
  padding: clamp(20px, 5vw, 32px);
  text-align: center;
  max-width: min(90vw, 360px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
  box-sizing: border-box;
}
.qr-modal-close {
  margin-top: 16px;
  padding: 8px 24px;
  border: none;
  border-radius: 8px;
  background: #c0608a;
  color: #fff;
  cursor: pointer;
  font-size: 0.9rem;
}

/* ── Responsive: mobile cover ────────────────────────────────────────── */
@media (max-width: 480px) {
  .akadverse-cover-content {
    max-width: 96%;
    width: 96%;
    gap: 8px;
    padding: 16px 12px;
  }
  .akadverse-ornament { max-width: 35vw; }
}

/* ==========================================================================
   akv-khitan-cover-layout (Custom premium khitan cover style)
   ========================================================================== */
.akv-khitan-cover-layout.akadverse-cover-wrapper {
  background: radial-gradient(circle at center, #2fa4a8 0%, #208b90 100%);
  position: relative;
}

/* Wavy background layer pattern */
.akv-khitan-cover-layout.akadverse-cover-wrapper::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: 
    radial-gradient(circle at 20% 30%, rgba(227, 177, 90, 0.08) 0%, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(255, 255, 255, 0.05) 0%, transparent 50%);
  pointer-events: none;
  z-index: 1;
}

/* Circular gold ornament pattern behind text */
.akv-khitan-cover-layout .akadverse-cover-content::before {
  content: '';
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(80vw, 480px);
  height: min(80vw, 480px);
  border: 1px dashed rgba(227, 177, 90, 0.2);
  border-radius: 50%;
  pointer-events: none;
  z-index: -1;
  animation: akvSpinSlow 40s linear infinite;
}

.akv-khitan-cover-layout .akadverse-cover-content::after {
  content: '';
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.9);
  width: min(80vw, 480px);
  height: min(80vw, 480px);
  border: 2px solid rgba(227, 177, 90, 0.1);
  border-radius: 50%;
  pointer-events: none;
  z-index: -1;
}

/* Cover primary text adjustments */
.akv-khitan-cover-layout .akadverse-cover-content {
  gap: 16px;
}

/* Button style for khitan cover */
.akv-khitan-cover-layout .akadverse-button-group button {
  background: #e3b15a;
  color: #165a5d;
  font-weight: 700;
  border-radius: 50px;
  padding: 14px 36px;
  font-size: 1rem;
  letter-spacing: 0.5px;
  box-shadow: 0 8px 24px rgba(227, 177, 90, 0.35);
  border: none;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.akv-khitan-cover-layout .akadverse-button-group button:hover {
  background: #f1c46f;
  color: #165a5d;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(227, 177, 90, 0.5);
}

/* Smooth fade out cover */
.akv-khitan-cover-layout.akadverse-cover-wrapper.fade-out {
  animation: coverFadeOut 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}