*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 1rem;
    line-height: 1.6;
    color: var(--text);
    background-color: var(--bg);
    background-image:
        radial-gradient(ellipse 80% 50% at 50% -20%, var(--glow-green), transparent 55%),
        radial-gradient(ellipse 60% 40% at 100% 0%, var(--glow-clay), transparent 50%);
    background-attachment: fixed;
}

h1, h2, h3, h4 {
    font-family: var(--font-heading);
    font-weight: 600;
    line-height: 1.25;
    margin: 0 0 var(--space-md);
    color: var(--text);
}

p {
    margin: 0 0 var(--space-md);
}

a {
    color: var(--accent-bright);
    text-decoration: none;
}

a:hover {
    color: var(--accent-hover);
    text-decoration: underline;
}

img {
    max-width: 100%;
    height: auto;
}

:focus-visible {
    outline: 2px solid var(--accent-bright);
    outline-offset: 2px;
}

.alya-icon {
    display: inline-block;
    vertical-align: middle;
    flex-shrink: 0;
}

/* Motion — content stays visible if animation does not run */
.motion-fade-up {
    animation: fadeUp var(--duration-med, 0.35s) var(--ease-out, ease-out) both;
}

.motion-hover-lift {
    transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);
}

.motion-hover-lift:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lift);
}

@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .motion-fade-up {
        animation: none;
    }

    .motion-hover-lift:hover {
        transform: none;
    }
}
