@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css');

:root {
  /* Purple/Vibrant Palette: #8E44AD, #9B59B6, #F3EBFF, #2D0A58 */
  --primary-color: #8E44AD;
  --secondary-color: #9B59B6;
  --accent-color: #D2B4DE;
  --light-color: #F3EBFF;
  --dark-color: #2D0A58;
  --gradient-primary: linear-gradient(45deg, #8E44AD, #3498DB);
  --hover-color: #71368A;
  --background-color: #F4F6F7;
  --text-color: #2c3e50;
  --border-color: rgba(142, 68, 173, 0.2);
  --divider-color: rgba(155, 89, 182, 0.1);
  --shadow-color: rgba(45, 10, 88, 0.1);
  --highlight-color: #E74C3C;
  --main-font: 'Oswald', sans-serif;
  --alt-font: 'Inter', sans-serif;
}

body {
    font-family: var(--alt-font);
    color: var(--text-color);
    background-color: var(--background-color);
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--main-font);
    text-transform: uppercase;
}

/* Soft Colorful Neumorphism */
.neu-card {
    background: white;
    border-radius: 20px;
    box-shadow: 0 10px 30px -5px rgba(142, 68, 173, 0.15);
    border-bottom: 4px solid var(--primary-color);
    transition: transform 0.3s ease;
}

.neu-card:hover {
    transform: translateY(-5px);
}

.btn-gradient {
    background: var(--gradient-primary);
    color: white;
    box-shadow: 0 4px 15px rgba(142, 68, 173, 0.4);
    border-radius: 50px;
    transition: all 0.3s ease;
}

.btn-gradient:hover {
    box-shadow: 0 6px 20px rgba(142, 68, 173, 0.6);
    transform: scale(1.05);
}

section:not(.hero-section) {
    padding-top: 10dvh;
    padding-bottom: 10dvh;
}

.section-title {
    position: relative;
    display: inline-block;
    margin-bottom: 3rem;
    color: var(--dark-color);
}

.section-title::after {
    content: '';
    display: block;
    width: 60%;
    height: 4px;
    background: var(--gradient-primary);
    margin: 10px auto 0;
    border-radius: 2px;
}