/**
 * TIC Design System - Status/Error Page Components
 * Styles for 404, 500, and other HTTP error pages
 */

/* ==========================================================================
   Error Page Container
   ========================================================================== */

.status-container {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - 200px);
    padding: var(--space-8) var(--space-4);
}

/* ==========================================================================
   Error Page Content
   ========================================================================== */

.status-content {
    text-align: center;
    max-width: 500px;
    font-family: var(--font-mono);
}

/* ==========================================================================
   Error Number Display
   ========================================================================== */

.status-number {
    display: flex;
    justify-content: center;
    gap: var(--space-3);
    margin-bottom: var(--space-6);
}

.status-number span {
    font-size: var(--text-6xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    line-height: 1;
    transition: var(--transition-fast);
}

@media (min-width: 576px) {
    .status-number span {
        font-size: 8rem;
    }
}

.status-number span:nth-child(2) {
    color: var(--accent-primary);
}

/* Hover animation */
.status-number span:hover {
    transform: translateY(-4px);
    color: var(--accent-primary);
}

/* ==========================================================================
   Error Title and Description
   ========================================================================== */

.status-title {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    margin: 0 0 var(--space-4);
}

@media (min-width: 768px) {
    .status-title {
        font-size: var(--text-3xl);
    }
}

.status-description {
    font-size: var(--text-lg);
    color: var(--text-secondary);
    margin: 0 0 var(--space-8);
    line-height: var(--leading-relaxed);
}

/* ==========================================================================
   Quick Links
   ========================================================================== */

.status-links {
    margin-bottom: var(--space-8);
}

.status-links-inline {
    display: flex;
    justify-content: center;
    gap: var(--space-6);
    flex-wrap: wrap;
}

.status-link-text {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--accent-primary);
    text-decoration: none;
    transition: var(--transition-fast);
}

.status-link-text:hover {
    color: var(--accent-primary-hover);
    transform: translateX(-4px);
}

.status-link-text svg {
    width: 20px;
    height: 20px;
}

/* ==========================================================================
   Support Section
   ========================================================================== */

.status-support {
    padding-top: var(--space-6);
    border-top: 1px solid var(--border-primary);
}

.status-support p {
    font-size: var(--text-sm);
    color: var(--text-tertiary);
    margin: 0;
}

.status-support-link {
    color: var(--accent-primary);
    text-decoration: none;
    font-weight: var(--font-medium);
}

.status-support-link:hover {
    text-decoration: underline;
}

/* ==========================================================================
   Animated Background (Optional)
   ========================================================================== */

.status-container--animated {
    position: relative;
    overflow: hidden;
}

.status-container--animated::before {
    content: "";
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(
        circle at center,
        var(--bg-tertiary) 0%,
        transparent 50%
    );
    animation: status-pulse 4s ease-in-out infinite;
    z-index: -1;
}

@keyframes status-pulse {
    0%, 100% {
        transform: scale(1);
        opacity: 0.5;
    }
    50% {
        transform: scale(1.1);
        opacity: 0.3;
    }
}

/* ==========================================================================
   Specific Error States
   ========================================================================== */

/* 404 - Not Found */
.status-container--404 .status-number span:nth-child(2) {
    color: var(--color-warning);
}

/* 500 - Server Error */
.status-container--500 .status-number span:nth-child(2) {
    color: var(--color-error);
}

/* 403 - Forbidden */
.status-container--403 .status-number span:nth-child(2) {
    color: var(--color-error);
}

/* Maintenance Mode */
.status-container--maintenance .status-number span {
    color: var(--accent-primary);
}

/* ==========================================================================
   Mobile Adjustments
   ========================================================================== */

@media (max-width: 576px) {
    .status-number span {
        font-size: var(--text-5xl);
    }

    .status-title {
        font-size: var(--text-xl);
    }

    .status-description {
        font-size: var(--text-base);
    }
}
