:root {
  --primary-color: #D01257;
  --secondary-color: #0F0766;
  --accent-color: #FB90B7;
  --light-color: #FFCEE4;
  --dark-color: #000000;
  --gradient-primary: linear-gradient(135deg, #D01257 0%, #AB0E86 100%);
  --hover-color: #b00f49;
  --background-color: #FDF2F7;
  --text-color: #2D0A58;
  --border-color: #E01171;
  --divider-color: rgba(208, 18, 87, 0.2);
  --shadow-color: rgba(15, 7, 102, 0.15);
  --highlight-color: #FFEB00;
  --main-font: 'Open Sans', sans-serif;
  --alt-font: 'Montserrat', sans-serif;
}

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, h4, .font-bold {
    font-family: var(--alt-font);
}

.card-style {
    background: white;
    border-radius: 16px;
    box-shadow: 0 10px 25px var(--shadow-color);
}

.btn-vibrant {
    background: var(--gradient-primary);
    color: white;
    border-radius: 50px;
    font-weight: 700;
    text-transform: uppercase;
    transition: transform 0.2s;
}

.btn-vibrant:hover {
    transform: scale(1.02);
    box-shadow: 0 5px 15px rgba(208, 18, 87, 0.4);
}

/* Abstract Waves Pattern */
.bg-waves {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    opacity: 0.05;
    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 13.718-1.21 22.272-4.402l1.768-.661C33.64 5.347 39.647 4 50 4c10.271 0 15.362 1.222 24.629 4.928C84.112 12.722 89.438 14 100 14v-2c-10.271 0-15.362-1.222-24.629-4.928C65.888 3.278 60.562 2 50 2 39.374 2 33.145 3.397 23.34 7.063l-1.767.662C13.223 10.84 8.163 12 0 12v2z' fill='%23D01257' fill-opacity='1' fill-rule='evenodd'/%3E%3C/svg%3E");
}

.z-10 { position: relative; z-index: 10; }