/* Base */
@font-face {
    font-family: "Borna";
    src: url("../fonts/Borna-Bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: "League Spartan";
    src: url("../fonts/LeagueSpartan-Bold.ttf") format("truetype");
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: "Swiza";
    src: url("../fonts/Swiza-Medium.otf") format("opentype");
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: "CircularStd";
    src: url("../fonts/circular-std-medium-500.ttf") format("truetype");
    font-weight: 500;
    font-style: normal;
}

:root {
    --white: #ffffff;
    --dark-gray: #565656;
    --black: #000000;
    --cream: #f0e6da;
    --rose: #d79f90;
    --green: #6c8d1f;
    --navy: #13273f;
    --category-academic: var(--green);
    --category-talks: #3f7fbf;
    --category-social: var(--rose);
    --category-sports: #d06f45;
    --category-culture: #7a4f7d;
    --category-recreational: #d783a8;
    --category-workshop: #2f9b8f;
    --category-default: var(--dark-gray);
    --cream-light: rgba(240, 230, 218, 0.55);
    --navy-soft: rgba(19, 39, 63, 0.08);
    --green-soft: rgba(108, 141, 31, 0.16);
    --rose-soft: rgba(215, 159, 144, 0.22);
    --category-academic-soft: rgba(108, 141, 31, 0.16);
    --category-talks-soft: rgba(63, 127, 191, 0.16);
    --category-social-soft: rgba(215, 159, 144, 0.22);
    --category-sports-soft: rgba(208, 111, 69, 0.18);
    --category-culture-soft: rgba(122, 79, 125, 0.18);
    --category-recreational-soft: rgba(215, 131, 168, 0.2);
    --category-workshop-soft: rgba(47, 155, 143, 0.18);
    --category-default-soft: rgba(86, 86, 86, 0.14);
    --border: rgba(19, 39, 63, 0.16);
    --shadow: 0 18px 44px rgba(19, 39, 63, 0.12);
    --soft-shadow: 0 10px 26px rgba(19, 39, 63, 0.08);
    --transition-fast: 160ms ease;
    --transition-normal: 260ms ease;
    --transition-slow: 720ms cubic-bezier(0.22, 1, 0.36, 1);
    --font-title: "Borna", Arial, sans-serif;
    --font-subtitle: "League Spartan", Arial, sans-serif;
    --font-body: "Swiza", Arial, sans-serif;
    --font-secondary: "CircularStd", Arial, sans-serif;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    min-width: 320px;
    font-family: var(--font-body);
    background: var(--cream);
    color: var(--black);
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: -1;
    background:
        radial-gradient(circle at 8% 12%, rgba(215, 159, 144, 0.22), transparent 23%),
        radial-gradient(circle at 92% 18%, rgba(108, 141, 31, 0.16), transparent 22%),
        linear-gradient(180deg, var(--cream), var(--cream-light));
}

main {
    min-height: 70vh;
    animation: pageFadeIn var(--transition-slow) both;
}

img {
    max-width: 100%;
    display: block;
}

a {
    color: inherit;
}

button,
input,
select,
textarea {
    font: inherit;
}

h1,
h2,
h3,
.footer-signature,
.stat-card strong {
    font-family: var(--font-title);
    color: var(--navy);
}

h1,
h2,
h3 {
    line-height: 1;
}

p {
    line-height: 1.65;
}

.small-title,
.section-title p,
.about-label,
.event-category,
.detail-box h3,
.card-label,
label,
th,
.state-badge,
.nav-links a,
.footer-column h3 {
    font-family: var(--font-subtitle);
}

.subtle-text,
.external-note,
.event-card-meta,
.form-help,
.form-note,
.auth-intro,
.profile-list span,
.stat-card span,
.footer-column p,
.flash-message {
    font-family: var(--font-secondary);
}

.small-title,
.section-title p,
.about-label,
.event-category,
.detail-box h3,
.card-label {
    color: var(--green);
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.category-academic {
    --category-color: var(--category-academic);
    --category-soft: var(--category-academic-soft);
}

.category-talks {
    --category-color: var(--category-talks);
    --category-soft: var(--category-talks-soft);
}

.category-social {
    --category-color: var(--category-social);
    --category-soft: var(--category-social-soft);
}

.category-sports {
    --category-color: var(--category-sports);
    --category-soft: var(--category-sports-soft);
}

.category-culture {
    --category-color: var(--category-culture);
    --category-soft: var(--category-culture-soft);
}

.category-recreational {
    --category-color: var(--category-recreational);
    --category-soft: var(--category-recreational-soft);
}

.category-workshop {
    --category-color: var(--category-workshop);
    --category-soft: var(--category-workshop-soft);
}

.event-category {
    color: var(--category-color, var(--category-default));
}

.page-shell,
.section-inner {
    width: min(1120px, calc(100% - 48px));
    margin: 0 auto;
}

.section-title {
    max-width: 760px;
    margin: 0 auto 42px;
    text-align: center;
}

.section-title h2 {
    margin-top: 10px;
    font-size: clamp(36px, 5vw, 58px);
}

.muted {
    color: var(--dark-gray);
}

/* Animation Utilities */
@keyframes pageFadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(18px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes scaleIn {
    from {
        opacity: 0;
        transform: scale(0.96);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.fade-in {
    animation: fadeIn var(--transition-slow) both;
}

.slide-up {
    animation: slideUp var(--transition-slow) both;
}

.scale-in {
    animation: scaleIn var(--transition-slow) both;
}

.reveal-on-scroll {
    opacity: 0.98;
    transform: translateY(6px);
    transition:
        opacity var(--transition-slow),
        transform var(--transition-slow);
}

.reveal-on-scroll.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.reveal-card {
    opacity: 1;
    transform: scale(1);
}

.js-enabled .reveal-card {
    opacity: 0;
    transform: scale(0.8);
    transition:
        opacity 460ms ease-out,
        transform 460ms cubic-bezier(0.22, 1, 0.36, 1) !important;
    backface-visibility: hidden;
    transform-origin: center center;
}

.js-enabled .reveal-card.is-visible {
    opacity: 1;
    transform: scale(1);
}

.section-text-reveal {
    opacity: 1;
    transform: translateY(0);
}

.js-enabled .section-text-reveal {
    opacity: 0.1;
    transform: translate3d(0, 8px, 0);
    transition:
        opacity 450ms ease-out,
        transform 450ms cubic-bezier(0.22, 1, 0.36, 1);
}

.js-enabled .section-text-reveal.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.performance-mode *,
.performance-mode *::before,
.performance-mode *::after {
    animation: none !important;
    transition-duration: 0ms !important;
    scroll-behavior: auto !important;
}

.performance-mode .reveal-on-scroll,
.performance-mode .reveal-card,
.performance-mode .section-text-reveal,
.performance-mode .feature-banner-reveal,
.performance-mode .feature-banner-reveal::after,
.performance-mode .hero-image-item,
.performance-mode .hero-image-hover,
.performance-mode .feature-kicker,
.performance-mode .feature-title,
.performance-mode .feature-copy,
.performance-mode .event-detail-poster-entrance,
.performance-mode .event-detail-content-entrance,
.performance-mode .event-detail-card-entrance,
.performance-mode .event-detail-action-entrance,
.performance-mode .user-area-entrance .small-title,
.performance-mode .user-area-entrance h1,
.performance-mode .user-area-entrance > p:not(.small-title),
.performance-mode .dashboard-card-entrance {
    opacity: 1 !important;
    transform: none !important;
}

.performance-mode .hero-scroll-indicator {
    opacity: 0.85 !important;
    transform: none !important;
}

.performance-mode .hero-title-accent {
    transition-duration: 0ms !important;
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto !important;
    }

    .reveal-on-scroll {
        opacity: 1 !important;
        transform: none !important;
    }

    .reveal-card {
        opacity: 1 !important;
        transform: none !important;
    }

    .section-text-reveal {
        opacity: 1 !important;
        transform: none !important;
    }

    .feature-banner-reveal,
    .feature-banner-reveal::after,
    .hero-image-item,
    .hero-image-hover,
    .feature-kicker,
    .feature-title,
    .feature-copy,
    .event-detail-poster-entrance,
    .event-detail-content-entrance,
    .event-detail-card-entrance,
    .event-detail-action-entrance {
        opacity: 1 !important;
        transform: none !important;
    }
}
