﻿body {
    margin: 0;
    font-family: 'Segoe UI', Arial, sans-serif;
    background: #f4f4f4;
}

/* Spazio per header fisso */
.maintenance {
    min-height: calc(100vh - 80px);
    padding-top: 120px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.maintenance-box {
    background: white;
    padding: 50px 60px;
    border-radius: 16px;
    box-shadow: 0 12px 35px rgba(0,0,0,0.08);
    text-align: center;
    max-width: 650px;
    width: 90%;
}

/* Fade-in */
.fade-in {
    opacity: 0;
    animation: fadeIn 0.8s ease forwards;
}

@keyframes fadeIn {
    to {
        opacity: 1;
    }
}

/* --- INGRANAGGI VERI --- */
.gears-wrapper {
    position: relative;
    width: 180px;
    height: 180px;
    margin: 0 auto 25px;
}

.gear {
    position: absolute;
    top: 0;
    left: 0;
}

    .gear.big {
        width: 180px;
        height: 180px;
        animation: rotateBig 6s linear infinite;
    }

    .gear.small {
        width: 90px;
        height: 90px;
        bottom: -10px;
        right: -10px;
        animation: rotateSmall 4s linear infinite reverse;
    }

@keyframes rotateBig {
    to {
        transform: rotate(360deg);
    }
}

@keyframes rotateSmall {
    to {
        transform: rotate(360deg);
    }
}

/* Titolo */
.title-anim {
    font-size: 34px;
    color: #0B7A3E;
    margin-bottom: 15px;
    opacity: 0;
    animation: slideDown 0.8s ease forwards 0.2s;
}

@keyframes slideDown {
    from {
        transform: translateY(-20px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Testo */
.slide-up {
    opacity: 0;
    animation: slideUp 0.8s ease forwards 0.4s;
}

@keyframes slideUp {
    from {
        transform: translateY(20px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Loader */
.loader {
    width: 50px;
    height: 50px;
    border: 4px solid #0B7A3E;
    border-top-color: transparent;
    border-radius: 50%;
    margin: 25px auto;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Subtext */
.fade-delay {
    opacity: 0;
    animation: fadeIn 1s ease forwards 0.8s;
}

.maintenance-sub {
    font-size: 15px;
    color: #666;
    margin-top: 10px;
}
