/* ================================================
   321SPEED – MINIMAL LOADER
   styles/loader.css
   ================================================ */

#speed-loader {
    position: fixed;
    inset: 0;
    background: radial-gradient(ellipse 60% 70% at 50% 50%,
        #111111 0%,
        rgba(17, 17, 17, 0.98) 40%,
        rgba(17, 17, 17, 0.88) 65%,
        rgba(17, 17, 17, 0.6) 85%,
        rgba(17, 17, 17, 0.3) 100%
    );
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    z-index: 99999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: opacity 0.5s ease, visibility 0.5s ease;
}

#speed-loader.hidden {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.loader-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
}

/* ── Logo ── */
.loader-logo {
    font-family: 'Oxanium', sans-serif;
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: 6px;
    color: rgba(255, 255, 255, 0.691);
    text-transform: uppercase;
}

.loader-logo span {
    color: #FF2D2D;
}

/* ── Speedometer SVG ── */
.speedo-wrap {
    width: 240px;
    height: 140px;
}

.speedo-svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.speedo-track {
    fill: none;
    stroke: rgba(255, 255, 255, 0.06);
    stroke-width: 2.5;
    stroke-linecap: round;
}

.speedo-fill {
    fill: none;
    stroke: #FF2D2D;
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-dasharray: 345;
    stroke-dashoffset: 345;
    filter: drop-shadow(0 0 8px rgba(255, 45, 45, 0.65));
    transition: stroke-dashoffset 0.06s linear;
}

.speedo-needle {
    transform-origin: 120px 130px;
    transform: rotate(-92deg);
    transition: transform 0.08s cubic-bezier(.25, 0, .2, 1);
}

.speedo-needle line {
    stroke: #FF2D2D;
    stroke-width: 1.5;
    stroke-linecap: round;
    filter: drop-shadow(0 0 4px rgba(255, 45, 45, 0.9));
}

.speedo-cap {
    fill: #111111;
    stroke: rgba(255, 255, 255, 0.08);
    stroke-width: 1;
}

.speedo-cap-dot {
    fill: #FF2D2D;
}