/**
 * STARFLEET Elementor Frontend Styles
 * Styles applied to all STARFLEET widgets on the frontend
 * Version: 1.1.0
 */

/* ========================================
   Base Widget Styles
   ======================================== */
.starfleet-widget {
    position: relative;
    z-index: 1;
}

/* Ensure widgets don't overflow their containers */
.elementor-widget-starfleet-carousel,
.elementor-widget-starfleet-lcars-button,
.elementor-widget-starfleet-academy-stats,
.elementor-widget-starfleet-red-alert,
.elementor-widget-starfleet-holographic-display,
.elementor-widget-starfleet-warp-core-loader,
.elementor-widget-starfleet-mission-briefing,
.elementor-widget-starfleet-lcars-navigation,
.elementor-widget-starfleet-stardate-clock,
.elementor-widget-starfleet-campus-showcase,
.elementor-widget-starfleet-roster,
.elementor-widget-starfleet-lcars-data-table {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

/* ========================================
   Widget Spacing
   ======================================== */
.elementor-widget-container .starfleet-widget {
    margin: 0;
    padding: 0;
}

/* ========================================
   Z-Index Management
   ======================================== */
.starfleet-widget.has-overlay {
    z-index: 10;
}

.starfleet-widget .widget-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    z-index: 5;
}

/* ========================================
   Animation Base Classes
   ======================================== */
.starfleet-animate {
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.starfleet-animate-slow {
    transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.starfleet-animate-fast {
    transition: all 0.15s ease-out;
}

/* Fade In Animation */
@keyframes starfleet-fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.starfleet-fade-in {
    animation: starfleet-fadeIn 0.6s ease-out forwards;
}

/* Pulse Animation */
@keyframes starfleet-pulse {
    0%, 100% {
        opacity: 1;
        transform: scale(1);
    }
    50% {
        opacity: 0.8;
        transform: scale(0.98);
    }
}

.starfleet-pulse {
    animation: starfleet-pulse 2s ease-in-out infinite;
}

/* ========================================
   Loading States
   ======================================== */
.starfleet-widget.is-loading {
    position: relative;
    min-height: 200px;
}

.starfleet-widget.is-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 40px;
    height: 40px;
    border: 3px solid rgba(81, 71, 155, 0.2);
    border-top-color: var(--lcars-gold, #D2B887);
    border-radius: 50%;
    animation: starfleet-spin 1s linear infinite;
}

@keyframes starfleet-spin {
    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}

/* ========================================
   Responsive Helpers
   ======================================== */
@media (max-width: 1024px) {
    .starfleet-hide-tablet {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .starfleet-hide-mobile {
        display: none !important;
    }
    
    /* Ensure proper spacing on mobile */
    .elementor-widget-container .starfleet-widget {
        margin-left: -10px;
        margin-right: -10px;
        padding-left: 10px;
        padding-right: 10px;
    }
}

/* ========================================
   Accessibility
   ======================================== */
.starfleet-widget:focus-visible,
.starfleet-widget *:focus-visible {
    outline: 2px solid var(--lcars-gold, #D2B887);
    outline-offset: 2px;
}

.starfleet-widget [aria-hidden="true"] {
    display: none !important;
}

/* Screen reader only text */
.starfleet-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ========================================
   Performance Optimizations
   ======================================== */
.starfleet-widget {
    will-change: auto;
}

.starfleet-widget.animating {
    will-change: transform, opacity;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    .starfleet-widget,
    .starfleet-widget * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    .starfleet-animate,
    .starfleet-animate-slow,
    .starfleet-animate-fast {
        transition: none !important;
    }
}

/* ========================================
   Print Styles
   ======================================== */
@media print {
    .starfleet-widget-no-print {
        display: none !important;
    }
    
    .starfleet-widget {
        animation: none !important;
        transition: none !important;
    }
}

/* ========================================
   Dark Mode Support
   ======================================== */
@media (prefers-color-scheme: dark) {
    .starfleet-widget {
        color-scheme: dark;
    }
}

/* Manual dark mode class */
.starfleet-dark-mode .starfleet-widget {
    color-scheme: dark;
}

/* ========================================
   RTL Support
   ======================================== */
.rtl .starfleet-widget {
    direction: rtl;
}

.rtl .starfleet-widget .text-left {
    text-align: right;
}

.rtl .starfleet-widget .text-right {
    text-align: left;
}

/* ========================================
   Browser Compatibility
   ======================================== */
/* Firefox specific fixes */
@-moz-document url-prefix() {
    .starfleet-widget {
        -moz-osx-font-smoothing: grayscale;
    }
}

/* Safari specific fixes */
@supports (-webkit-appearance: none) {
    .starfleet-widget {
        -webkit-font-smoothing: antialiased;
    }
}

/* ========================================
   Utility Classes
   ======================================== */
.starfleet-clearfix::after {
    content: "";
    display: table;
    clear: both;
}

.starfleet-text-center {
    text-align: center;
}

.starfleet-text-left {
    text-align: left;
}

.starfleet-text-right {
    text-align: right;
}

.starfleet-mt-1 { margin-top: 0.5rem; }
.starfleet-mt-2 { margin-top: 1rem; }
.starfleet-mt-3 { margin-top: 1.5rem; }
.starfleet-mt-4 { margin-top: 2rem; }

.starfleet-mb-1 { margin-bottom: 0.5rem; }
.starfleet-mb-2 { margin-bottom: 1rem; }
.starfleet-mb-3 { margin-bottom: 1.5rem; }
.starfleet-mb-4 { margin-bottom: 2rem; }

.starfleet-p-1 { padding: 0.5rem; }
.starfleet-p-2 { padding: 1rem; }
.starfleet-p-3 { padding: 1.5rem; }
.starfleet-p-4 { padding: 2rem; }

/* ========================================
   Widget Error States
   ======================================== */
.starfleet-widget.has-error {
    border: 2px solid var(--lcars-red, #FF5252);
    padding: 1rem;
    background: rgba(255, 82, 82, 0.1);
}

.starfleet-widget-error-message {
    color: var(--lcars-red, #FF5252);
    font-size: 0.875rem;
    margin-top: 0.5rem;
}

/* ========================================
   Widget Success States
   ======================================== */
.starfleet-widget.has-success {
    border: 2px solid var(--lcars-green, #117733);
    padding: 1rem;
    background: rgba(17, 119, 51, 0.1);
}

.starfleet-widget-success-message {
    color: var(--lcars-green, #117733);
    font-size: 0.875rem;
    margin-top: 0.5rem;
}

/* ========================================
   End of Frontend Styles
   ======================================== */