:root {
  /* Random Colors: #59057B, #FFD23F, #FB90B7, #FEFAE0 */
  --primary-color: #59057B; /* Deep Purple */
  --secondary-color: #FFD23F; /* Yellow */
  --accent-color: #FB90B7; /* Pink */
  --light-color: #FEFAE0; /* Cream */
  --dark-color: #1A0126;
  --background-color: #FEFAE0;
  --text-color: #2D3748;
  --highlight-color: #C0392B; /* Contrast Red */
  
  --main-font: 'Roboto', sans-serif;
  --heading-font: 'Oswald', sans-serif;
  
  --border-radius: 12px;
}

body {
    font-family: var(--main-font);
    background-color: var(--background-color);
    color: var(--text-color);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

h1, h2, h3, .heading-font {
    font-family: var(--heading-font);
    text-transform: uppercase;
}

/* Wavy Pattern */
.bg-wave {
    background-image: url("data:image/svg+xml,%3Csvg width='100' height='20' viewBox='0 0 100 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M21.184 20c.357-.13.72-.264 1.088-.402l1.768-.661C33.64 15.347 39.647 14 50 14c10.271 0 15.362 1.222 24.629 4.928.955.383 1.869.74 2.75 1.072h6.225c-2.51-.73-5.139-1.691-8.233-2.928C65.888 13.278 60.562 12 50 12c-10.626 0-16.855 1.397-26.66 5.063l-1.767.662c-2.475.923-4.66 1.674-6.724 2.275h6.335zm0-20C13.258 2.892 8.077 4 0 4V2c5.744 0 9.951-.574 14.85-2h6.334zM77.38 0C85.239 2.966 90.502 4 100 4V2c-6.842 0-11.386-.542-16.396-2h-6.225zM0 14c8.44 0 14.018 1.237 22.424 4.594l1.768.661C24.116 19.66 24.046 20 23.951 20H0v-6z' fill='%2359057B' fill-opacity='0.05' fill-rule='evenodd'/%3E%3C/g%3E%3C/svg%3E");
    z-index: 0;
}

.content-box {
    background: white;
    border: 2px solid var(--primary-color);
    border-radius: var(--border-radius);
    box-shadow: 6px 6px 0px var(--accent-color);
}

.price-tag {
    background-color: var(--primary-color);
    color: var(--secondary-color);
    padding: 10px 20px;
    border-radius: var(--border-radius);
    display: inline-block;
}

.cta-btn {
    background-color: var(--secondary-color);
    color: var(--dark-color);
    font-weight: 700;
    border: 2px solid var(--dark-color);
    box-shadow: 4px 4px 0px var(--dark-color);
    transition: all 0.2s;
}
.cta-btn:hover {
    transform: translate(2px, 2px);
    box-shadow: 2px 2px 0px var(--dark-color);
}

.testimonial-box {
    background-color: var(--primary-color);
    color: var(--light-color);
    border-radius: var(--border-radius);
    position: relative;
}