/* AB Swagger - Custom CSS for Token Persistence and Enhanced UI */
/* Felles styling for alle Arkitektbedriftene API-er */

:root {
    --ab-primary-color: #007bff;
    --ab-success-color: #49cc90;
    --ab-danger-color: #dc3545;
    --ab-info-color: #61affe;
    --ab-warning-color: #fca130;
    --ab-dark-color: #343a40;
    --ab-light-color: #f8f9fa;
}

/* Status message styling */
.ab-token-status {
    position: fixed;
    top: 10px;
    right: 10px;
    padding: 8px 16px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    z-index: 9999;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    backdrop-filter: blur(10px);
    animation: slideInRight 0.3s ease-out;
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.ab-token-status-success {
    background-color: var(--ab-success-color);
    color: white;
    border-left: 4px solid #28a745;
}

.ab-token-status-info {
    background-color: var(--ab-info-color);
    color: white;
    border-left: 4px solid #17a2b8;
}

.ab-token-status-warning {
    background-color: var(--ab-warning-color);
    color: white;
    border-left: 4px solid #fd7e14;
}

.ab-token-status-error {
    background-color: var(--ab-danger-color);
    color: white;
    border-left: 4px solid #dc3545;
}

/* Clear token button styling - improved visibility */
.ab-clear-token-btn {
    background-color: var(--ab-danger-color) !important;
    color: white !important;
    border: 2px solid var(--ab-danger-color) !important;
    padding: 8px 16px !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    margin-left: 15px !important;
    transition: all 0.2s ease !important;
    text-shadow: none !important;
    box-shadow: 0 2px 4px rgba(220, 53, 69, 0.2) !important;
    min-height: 36px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
}

.ab-clear-token-btn:hover {
    background-color: #c82333 !important;
    border-color: #bd2130 !important;
    box-shadow: 0 4px 8px rgba(220, 53, 69, 0.3) !important;
    transform: translateY(-1px) !important;
    color: white !important;
}

.ab-clear-token-btn:active {
    background-color: #bd2130 !important;
    border-color: #b21f2d !important;
    transform: translateY(0) !important;
    box-shadow: 0 2px 4px rgba(220, 53, 69, 0.2) !important;
}

.ab-clear-token-btn:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.25) !important;
}

/* AB Branding */
.ab-branding {
    margin-left: auto;
    margin-right: 15px;
    color: #6c757d;
    font-size: 11px;
}

.ab-branding a {
    color: var(--ab-primary-color) !important;
    text-decoration: none !important;
    font-weight: 500;
}

.ab-branding a:hover {
    text-decoration: underline !important;
}

/* Enhanced auth section styling */
.swagger-ui .auth-wrapper .auth-container::after {
    content: "?? Tokens lagres automatisk i localStorage og cookies for bekvemmelighet på tvers av alle AB API-er.";
    display: block;
    margin-top: 15px;
    padding: 12px;
    background: linear-gradient(135deg, var(--ab-light-color) 0%, #e9ecef 100%);
    border: 1px solid #dee2e6;
    border-radius: 6px;
    font-size: 12px;
    color: #495057;
    font-style: italic;
    border-left: 4px solid var(--ab-primary-color);
}

/* Visual indicator when token is loaded */
.swagger-ui .topbar::after {
    content: "";
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-left: 10px;
    background-color: var(--ab-success-color);
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(73, 204, 144, 0.7);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(73, 204, 144, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(73, 204, 144, 0);
    }
}

/* Improved authorize button styling - much better visibility */
.swagger-ui .auth-wrapper .authorize,
.swagger-ui .btn.authorize {
    background: linear-gradient(135deg, var(--ab-primary-color) 0%, #0056b3 100%) !important;
    border: 2px solid var(--ab-primary-color) !important;
    color: white !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding: 10px 24px !important;
    border-radius: 8px !important;
    text-shadow: none !important;
    box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3) !important;
    transition: all 0.3s ease !important;
    min-height: 40px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
}

.swagger-ui .auth-wrapper .authorize:hover,
.swagger-ui .btn.authorize:hover {
    background: linear-gradient(135deg, #0056b3 0%, #004085 100%) !important;
    border-color: #004085 !important;
    box-shadow: 0 6px 16px rgba(0, 123, 255, 0.4) !important;
    transform: translateY(-2px) !important;
}

.swagger-ui .auth-wrapper .authorize:active,
.swagger-ui .btn.authorize:active {
    background: linear-gradient(135deg, #004085 0%, #003d82 100%) !important;
    border-color: #003d82 !important;
    transform: translateY(0) !important;
    box-shadow: 0 2px 8px rgba(0, 123, 255, 0.3) !important;
}

.swagger-ui .auth-wrapper .authorize:focus,
.swagger-ui .btn.authorize:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25) !important;
}

/* Style for the topbar to accommodate our elements */
.swagger-ui .topbar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 12px 24px !important;
    background: linear-gradient(135deg, var(--ab-light-color) 0%, #ffffff 100%) !important;
    border-bottom: 2px solid #e9ecef !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1) !important;
}

.swagger-ui .topbar .download-url-wrapper {
    display: flex;
    align-items: center;
}

/* Additional styling for better contrast and readability */
.swagger-ui .topbar a {
    color: var(--ab-dark-color) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

.swagger-ui .topbar a:hover {
    color: var(--ab-primary-color) !important;
}

/* Make sure our buttons are visible on all backgrounds */
.ab-clear-token-btn,
.swagger-ui .auth-wrapper .authorize,
.swagger-ui .btn.authorize {
    position: relative !important;
    z-index: 1000 !important;
}

/* Additional authorize button improvements */
.swagger-ui .authorization__btn {
    background: linear-gradient(135deg, var(--ab-primary-color) 0%, #0056b3 100%) !important;
    border: 2px solid var(--ab-primary-color) !important;
    color: white !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    padding: 8px 20px !important;
    border-radius: 6px !important;
    text-shadow: none !important;
    box-shadow: 0 2px 4px rgba(0, 123, 255, 0.2) !important;
    transition: all 0.2s ease !important;
}

.swagger-ui .authorization__btn:hover {
    background: linear-gradient(135deg, #0056b3 0%, #004085 100%) !important;
    border-color: #004085 !important;
    box-shadow: 0 4px 8px rgba(0, 123, 255, 0.3) !important;
    transform: translateY(-1px) !important;
}

/* Ensure auth modal buttons are visible too */
.swagger-ui .auth-container .auth-btn-wrapper .btn-done,
.swagger-ui .auth-container .auth-btn-wrapper .btn-cancel {
    background: linear-gradient(135deg, var(--ab-success-color) 0%, #218838 100%) !important;
    border: 2px solid var(--ab-success-color) !important;
    color: white !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    border-radius: 6px !important;
    margin-right: 10px !important;
    transition: all 0.2s ease !important;
    text-transform: uppercase !important;
    font-size: 12px !important;
    letter-spacing: 0.5px !important;
}

.swagger-ui .auth-container .auth-btn-wrapper .btn-cancel {
    background: linear-gradient(135deg, #6c757d 0%, #495057 100%) !important;
    border-color: #6c757d !important;
}

.swagger-ui .auth-container .auth-btn-wrapper .btn-done:hover {
    background: linear-gradient(135deg, #218838 0%, #1e7e34 100%) !important;
    border-color: #1e7e34 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3) !important;
}

.swagger-ui .auth-container .auth-btn-wrapper .btn-cancel:hover {
    background: linear-gradient(135deg, #5a6268 0%, #343a40 100%) !important;
    border-color: #495057 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 8px rgba(108, 117, 125, 0.3) !important;
}

/* Enhanced API title styling */
.swagger-ui .info .title {
    color: var(--ab-dark-color) !important;
    font-weight: 700 !important;
}

/* Better operation method badges */
.swagger-ui .opblock.opblock-get .opblock-summary-method {
    background: linear-gradient(135deg, var(--ab-success-color) 0%, #218838 100%) !important;
}

.swagger-ui .opblock.opblock-post .opblock-summary-method {
    background: linear-gradient(135deg, var(--ab-primary-color) 0%, #0056b3 100%) !important;
}

.swagger-ui .opblock.opblock-put .opblock-summary-method {
    background: linear-gradient(135deg, var(--ab-warning-color) 0%, #e0a800 100%) !important;
}

.swagger-ui .opblock.opblock-delete .opblock-summary-method {
    background: linear-gradient(135deg, var(--ab-danger-color) 0%, #c82333 100%) !important;
}

/* Responsive design */
@media (max-width: 768px) {
    .swagger-ui .topbar {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .ab-clear-token-btn {
        margin-left: 0 !important;
        margin-top: 10px !important;
    }
    
    .ab-branding {
        margin: 0 !important;
        text-align: center;
    }
}