/* WEDDING SEASON 2025 THEME - COMPLETELY ISOLATED */
.ws25-active {
  /* Wedding Color Variables */
  --ws25-primary: #8b0000;
  --ws25-gold: #d4af37;
  --ws25-ivory: #fffff0;
  --ws25-maroon: #800020;
  --ws25-saffron: #ff9933;

  /* Background Patterns */
  --ws25-bg-pattern: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M50,0 C77.614,0 100,22.386 100,50 C100,77.614 77.614,100 50,100 C22.386,100 0,77.614 0,50 C0,22.386 22.386,0 50,0 Z' fill='none' stroke='%23D4AF37' stroke-width='0.5' opacity='0.1'/%3E%3C/svg%3E");
}

/* Floating Petals Animation */
@keyframes ws25-float-petals {
  0% {
    transform: translateY(-100px) rotate(0deg);
    opacity: 0;
  }
  10% {
    opacity: 0.7;
  }
  90% {
    opacity: 0.7;
  }
  100% {
    transform: translateY(100vh) rotate(360deg);
    opacity: 0;
  }
}

.ws25-petal {
  position: fixed;
  pointer-events: none;
  z-index: 9998;
  animation: ws25-float-petals 15s linear infinite;
  font-size: 24px;
}

/* Background Doodles */
.ws25-bg-doodles {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: -1;
  opacity: 0.1;
  background-image:
    radial-gradient(
      circle at 20% 80%,
      var(--ws25-gold) 0.5px,
      transparent 0.5px
    ),
    radial-gradient(
      circle at 80% 20%,
      var(--ws25-primary) 0.5px,
      transparent 0.5px
    );
  background-size:
    50px 50px,
    30px 30px;
}

/* Wedding-themed buttons */
.ws25-btn-primary {
  background: linear-gradient(135deg, var(--ws25-primary), var(--ws25-maroon));
  border: 1px solid var(--ws25-gold);
  color: var(--ws25-ivory);
  position: relative;
  overflow: hidden;
}

.ws25-btn-primary::before {
  content: "";
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(
    45deg,
    var(--ws25-gold),
    transparent,
    var(--ws25-gold)
  );
  z-index: -1;
  border-radius: inherit;
}

/* Header decorations */
.ws25-header-decoration {
  background: linear-gradient(
    90deg,
    transparent,
    var(--ws25-gold),
    transparent
  );
  height: 3px;
  margin: 5px 0;
  opacity: 0.6;
}

/* Profile frame */
.ws25-profile-frame {
  border: 2px solid var(--ws25-gold);
  padding: 3px;
  border-radius: 50%;
  background: linear-gradient(45deg, var(--ws25-primary), var(--ws25-maroon));
}

/* Card decorations */
.ws25-card {
  border: 1px solid rgba(212, 175, 55, 0.3);
  background: rgba(255, 255, 240, 0.02);
  position: relative;
}

.ws25-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    var(--ws25-primary),
    var(--ws25-gold),
    var(--ws25-primary)
  );
}

/* Golden text for important elements */
.ws25-gold-text {
  background: linear-gradient(135deg, var(--ws25-gold), #ffd700);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: bold;
}

/* Mehndi pattern borders */
.ws25-mehndi-border {
  border: 1px solid transparent;
  background:
    linear-gradient(white, white) padding-box,
    repeating-linear-gradient(
        45deg,
        var(--ws25-primary) 0,
        var(--ws25-primary) 2px,
        transparent 2px,
        transparent 8px
      )
      border-box;
}

/* Floating elements container */
#ws25-floating-elements {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 9999;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .ws25-petal {
    font-size: 18px;
  }

  .ws25-bg-doodles {
    opacity: 0.05;
  }
}
