/* Google fonts import */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Macondo&display=swap');

/* CSS Variables */
:root {
    --primary-font: "Inter", sans-serif;
    --secondary-font: "Macondo", cursive;
    --primary-color: #3f0441;
    --secondary-color: #f97316;
    --highlight-color: #33053f;
    --highlight-color-light: #c8f2f9;
    --surface-color: #ffffff;
    --surface-muted: #f8fafc;
}

/* Global styles */

body {
    font-family: var(--primary-font);
    padding-top: 78px; /* pushes the top of the header down under fixed navbar */
    color: #1f2937;
    background:
        radial-gradient(circle at 10% 10%, #dff7fb 0%, transparent 35%),
        radial-gradient(circle at 90% 15%, #ffe8d6 0%, transparent 30%),
        var(--surface-muted);
}

h1,
h2,
h3 {
    font-family: var(--secondary-font);
    color: var(--primary-color);
}

h1,
h2 {
    text-transform: uppercase;
}

h2 {
    margin-bottom: 2rem;
}

.sub-heading-color {
    color: var(--highlight-color);
}

.section {
    padding-top: 4rem; /* prevent navbar overlap */
}

/* Buttons */

.custom-button-filled {
    border: 2px solid var(--highlight-color);
    background-color: var(--highlight-color);
    color: white;
    border-radius: 999px;
    padding: 0.5rem 1rem;
}

.custom-button-filled:hover {
    border: 2px solid var(--secondary-color);
    background-color: var(--secondary-color);
    color: white;
}

.custom-button-outline {
    border: 3px solid var(--highlight-color);
    padding: 7px 25px;
    color: var(--highlight-color);
    border-radius: 999px;
    background-color: rgba(255, 255, 255, 0.7);
}

.custom-button-outline:hover {
    background-color: var(--highlight-color);
    color: white;
}

/* Navbar */

#navbar {
    background-color: rgba(61, 2, 73, 0.973);
    backdrop-filter: blur(8px);
    box-shadow: 0 8px 24px rgba(2, 6, 23, 0.25);
    height: 78px;
}

#navbar .container {
    height: 100%;
}

#navbar .navbar-brand {
    height: 100%;
    display: flex;
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
}

#navbar .logo {
    height: 160px;
    width: auto;
    max-width: none;
    transform: translateY(6px);
}

#navbar .nav-link {
    color: #e2e8f0;
}

#navbar .nav-link:hover,
#navbar .nav-link.active {
    color: #ffffff;
}

@media (max-width: 991.98px) {
    #navbar .logo {
        height: 96px;
        transform: translateY(3px);
    }
}

/* Header */

#header .lead {
    font-family: var(--secondary-font);
}

#header .row {
    background-color: var(--surface-color);
    border-radius: 20px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.12);
    padding: 1.25rem;
}

#homeCarousel .carousel-inner,
#homeCarousel .carousel-item img {
    border-radius: 16px;
}

#homeCarousel .carousel-item img {
    height: 380px;
    object-fit: cover;
}

.card {
    border: 0;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(163, 3, 226, 0.904);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.card:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 35px rgb(55, 1, 73);
}

.card-img-top {
    height: 210px;
    object-fit: cover;
}

#schedule .table {
    background-color: var(--surface-color);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(15, 23, 42, 0.08);
}

#schedule .table thead {
    background-color: #a006c7;
    color: #ffffff;
}

#schedule {
    padding-bottom: 2rem;
}

#contact {
    margin-top: 1rem;
    background-color: var(--primary-color);
    color: white;
    padding-bottom: 1rem;
}

#contact .section {
    padding-top: 1rem;
}

#contact h2,
#contact strong {
    color: white;
}

#contact .sub-heading-color {
    color: var(--highlight-color-light);
}

#contact i {
    color: var(--secondary-color);
    font-size: 1.2rem;
    margin-right: 15px;
}

#contact .social-links i {
    color: var(--highlight-color-light);
    font-size: 1.9rem;
    transition: color 0.3s ease-in-out;
}

#contact .social-links i:hover {
    color: var(--secondary-color);
}

#contact .table-dark,
#contact .table-dark * {
    background-color: transparent;
    color: white;
}
