* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

body {
    font-family: 'Inter', sans-serif;
    background: #fff;
    color: #1e293b;
    overflow-x: hidden
}

.page {
    display: none
}

.page.active {
    display: block
}

.hero-gradient {
    background: linear-gradient(135deg, #0f3460 0%, #1a5276 40%, #0c2a4e 100%)
}

.flame-gradient {
    background: linear-gradient(135deg, #e65100, #fb923c)
}

.light-gradient {
    background: linear-gradient(180deg, #f8fafc 0%, #fff 100%)
}

.overlay-grid {
    background-image: radial-gradient(circle, rgba(15, 52, 96, .06) 1px, transparent 1px);
    background-size: 32px 32px
}

.card-hover {
    transition: all .3s cubic-bezier(.4, 0, .2, 1)
}

.card-hover:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px -12px rgba(15, 52, 96, .15)
}

.stat-card {
    background: rgba(255, 255, 255, .95);
    backdrop-filter: blur(10px)
}

.nav-link {
    position: relative
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: #e65100;
    transition: width .3s
}

.nav-link:hover::after {
    width: 100%
}

/* Animations start VISIBLE - JS adds hidden state only after confirming it works */
.fade-up,
.fade-left,
.fade-right {
    opacity: 1;
    transform: none;
    transition: all .7s cubic-bezier(.4, 0, .2, 1)
}

.fade-up.anim-init {
    opacity: 0;
    transform: translateY(30px)
}

.fade-left.anim-init {
    opacity: 0;
    transform: translateX(-30px)
}

.fade-right.anim-init {
    opacity: 0;
    transform: translateX(30px)
}

.fade-up.visible,
.fade-left.visible,
.fade-right.visible {
    opacity: 1;
    transform: none
}

@keyframes float {

    0%,
    100% {
        transform: translateY(0)
    }

    50% {
        transform: translateY(-12px)
    }
}

.float-anim {
    animation: float 5s ease-in-out infinite
}

.dropdown-menu {
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: all .2s
}

.dropdown:hover .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}

.input-field {
    transition: border-color .2s, box-shadow .2s
}

.input-field:focus {
    border-color: #1a5276;
    box-shadow: 0 0 0 3px rgba(26, 82, 118, .1);
    outline: none
}

.btn-primary {
    background: linear-gradient(135deg, #0f3460, #1a5276);
    transition: all .3s
}

.btn-primary:hover {
    background: linear-gradient(135deg, #1a5276, #2471a3);
    transform: translateY(-1px);
    box-shadow: 0 8px 25px -5px rgba(15, 52, 96, .3)
}

.btn-accent {
    background: linear-gradient(135deg, #e65100, #fb923c);
    transition: all .3s
}

.btn-accent:hover {
    background: linear-gradient(135deg, #d84315, #e65100);
    transform: translateY(-1px);
    box-shadow: 0 8px 25px -5px rgba(230, 81, 0, .3)
}

.toast {
    transform: translateX(120%);
    transition: transform .4s cubic-bezier(.4, 0, .2, 1)
}

.toast.show {
    transform: translateX(0)
}

::-webkit-scrollbar {
    width: 8px
}

::-webkit-scrollbar-track {
    background: #f1f5f9
}

::-webkit-scrollbar-thumb {
    background: #94a3b8;
    border-radius: 4px
}

.border-accent-l {
    border-left: 4px solid
}

/* Loading screen */
#loader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .4s
}

#loader.hide {
    opacity: 0;
    pointer-events: none
}

@keyframes spin {
    to {
        transform: rotate(360deg)
    }
}

.spinner {
    width: 40px;
    height: 40px;
    border: 3px solid #e2e8f0;
    border-top-color: #e65100;
    border-radius: 50%;
    animation: spin .8s linear infinite
}