/**
 * Stago Webinars - Responsive Styles
 *
 * @package StagoWebinars
 */

/* Tablet and below */
@media (max-width: 1200px) {
    .slide {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .slide-content {
        order: 2;
    }

    .slide-thumbnail {
        order: 1;
    }

    .slide-title {
        font-size: 26px;
    }

    .welcome-container {
        grid-template-columns: 1fr;
        gap: 40px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    /* Remove sticky header on mobile */
    .header {
        position: relative;
    }

    /* Show burger menu */
    .burger-menu {
        display: flex;
        order: 2;
    }

    /* Hide desktop nav, show burger */
    .nav-bar {
        display: none;
    }

    .nav-bar.mobile-open {
        display: block;
        position: relative;
        border-bottom: 6px solid var(--stago-red);
        z-index: 1002;
    }

    .nav-bar.mobile-open .container {
        flex-direction: column;
        padding: 8px 0;
        gap: 0;
    }

    .nav-bar.mobile-open .nav-link {
        width: 100%;
        padding: 12px 24px;
        border-bottom: none;
    }

    .header .container {
        flex-wrap: wrap;
        gap: 20px 5px;
    }

    .logo {
        flex: 1;
    }

    .logo-text-suffix {
        font-size: 18px;
    }

    .search-container {
        order: 3;
        width: 100%;
        flex: 1 1 100%;
        margin: 0;
        max-width: none;
    }

    .header-actions {
        flex: 0 0 auto;
        gap: 4px;
    }

    /* Hide desktop lang switcher on mobile */
    .lang-switcher {
        display: none;
    }

    /* Language Switcher in Mobile Menu */
    .nav-bar.mobile-open .nav-lang-selector {
        display: flex;
        border-top: 1px solid var(--border-color);
        margin-top: 8px;
        padding: 12px 0 4px;
        min-width: 300px;
    }

    .lang-switcher-mobile {
        flex: 1;
        display: flex;
        gap: 8px;
    }

    .lang-link-mobile {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 5px;
        padding: 10px 8px;
        background: var(--bg-tertiary);
        border: 1px solid var(--border-color);
        color: var(--text-secondary);
        text-decoration: none;
        font-size: 12px;
        font-weight: 500;
        transition: all 0.2s;
        text-align: center;
        line-height: 1.3;
    }

    .lang-link-mobile.active {
        background: var(--stago-red);
        color: white;
        border-color: var(--stago-red);
    }

    .lang-link-mobile img {
        width: 24px;
        height: 16px;
    }

    .btn-signin,
    .btn-register {
        padding: 8px 10px;
        font-size: 12px;
    }

    .btn-signin i,
    .btn-register i {
        display: none;
    }

    /* Promo banner mobile */
    .promo-banner {
        padding: 10px 24px;
    }

    .promo-banner-inner {
        flex-wrap: wrap;
        gap: 10px;
        padding-right: 30px;
    }

    .promo-badge {
        font-size: 10px;
        padding: 3px 8px;
    }

    .promo-text {
        font-size: 12px;
        flex: 1;
        min-width: 0;
    }

    .promo-cta {
        padding: 5px 12px;
        font-size: 11px;
        white-space: nowrap;
    }

    .promo-close {
        right: 10px;
        font-size: 16px;
    }

    /* Live now banner mobile */
    .live-now-banner {
        padding: 12px 0;
    }

    .live-now-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .live-now-left {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
        width: 100%;
    }

    .live-badge {
        padding: 6px 12px;
        font-size: 11px;
    }

    .live-now-title {
        font-size: 14px;
    }

    .live-now-meta {
        font-size: 12px;
        gap: 12px;
    }

    .btn-watch-live {
        width: 100%;
        justify-content: center;
        padding: 10px 20px;
        font-size: 13px;
    }

    /* Hero slider mobile */
    .hero-slider {
        padding: 24px 24px;
    }

    .slider-container {
        padding: 0;
    }

    .slider-nav {
        display: none;
    }

    .slide-title {
        font-size: 20px;
    }

    .slide-title a {
        font-size: 20px;
    }

    .slide-actions-row {
        flex-direction: column;
        gap: 16px;
    }

    .slide-actions {
        width: 100%;
    }

    .btn-watch {
        width: 100%;
        justify-content: center;
    }

    .countdown-container {
        width: 100%;
        justify-content: center;
    }

    /* Webinars section mobile */
    .webinars-section {
        padding: 48px 0;
    }

    .section-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .filters {
        width: 100%;
        flex-direction: column;
    }

    .filter-group {
        width: 100%;
    }

    .filter-btn {
        flex: 1;
        text-align: center;
        padding: 10px 12px;
        font-size: 13px;
    }

    .filter-dropdown {
        width: 100%;
    }

    .webinar-grid {
        grid-template-columns: 1fr;
    }

    /* Welcome section mobile */
    .welcome-section {
        padding: 48px 24px;
    }

    .welcome-container {
        padding: 0;
    }

    .welcome-content h2 {
        font-size: 26px;
    }

    .welcome-features {
        grid-template-columns: 1fr;
    }

    .stats-grid {
        grid-template-columns: 1fr 1fr;
    }

    /* Footer mobile */
    .footer {
        padding: 24px 24px;
    }

    .footer-inner {
        flex-direction: column;
        text-align: center;
        padding: 0;
    }

    .footer-links {
        flex-wrap: wrap;
        justify-content: center;
        gap: 12px;
    }

    .footer-links a {
        font-size: 12px;
    }

    .footer-copyright {
        font-size: 11px;
    }

    /* Back to top hidden on mobile */
    .back-to-top {
        display: none;
    }

    /* Account page mobile */
    .account-section {
        padding: 60px 0;
    }

    .account-wrapper {
        flex-direction: column;
        gap: 20px;
    }

    .account-divider {
        width: 100%;
        height: 1px;
        margin: 30px 0;
    }

    .account-divider span {
        padding: 0 20px;
    }

    .form-row {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .form-row .form-group {
        width: 100%;
    }
}

/* Small mobile */
@media (max-width: 480px) {
    .stats-grid {
        grid-template-columns: 1fr 1fr; /* Keep 2 columns on small mobile */
    }

    .stat-card {
        padding: 24px;
    }

    .stat-number {
        font-size: 36px;
    }

    .logo-text-suffix {
        font-size: 16px;
    }
}

/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-in {
    animation: fadeInUp 0.6s ease forwards;
}

/* Single Post Responsive */
@media (max-width: 992px) {
    .single-wrapper {
        grid-template-columns: 1fr;
    }

    .single-sidebar {
        order: 2;
    }
}

@media (max-width: 768px) {
    /* User dropdown mobile */
    .btn-user-menu span {
        display: none;
    }

    .btn-user-menu {
        padding: 8px 10px;
    }

    .user-dropdown {
        right: -50px;
        min-width: 260px;
    }

    /* Page section mobile */
    .page-section {
        padding: 40px 0;
    }

    .page-title {
        font-size: 28px;
    }

    /* Single mobile */
    .single-section {
        padding: 40px 0;
    }

    .single-title {
        font-size: 24px;
    }

    .single-meta {
        flex-wrap: wrap;
        gap: 12px;
    }

    /* Video container mobile */
    .video-container {
        min-height: 250px;
    }

    /* Archive mobile */
    .archive-section {
        padding: 40px 0;
    }

    .archive-title {
        font-size: 26px;
    }

    .posts-grid {
        grid-template-columns: 1fr;
    }

    /* 404 Page Mobile */
    .error-404 {
        padding: 100px 0;
    }

    .error-actions {
        flex-direction: column;
        align-items: center;
    }

    .error-actions .btn-watch,
    .error-actions .btn-secondary-action {
        width: 100%;
        max-width: 300px;
        justify-content: center;
    }

    /* On-demand mobile */
    .ondemand-section {
        padding: 32px 0;
    }

    .ondemand-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .ajax-pagination {
        flex-wrap: wrap;
    }

    .ajax-pagination .page-link {
        min-width: 36px;
        height: 36px;
        font-size: 13px;
    }

    /* Single webinar mobile */
    .webinar-details-wrapper {
        grid-template-columns: 1fr;
    }

    .webinar-title {
        font-size: 26px;
    }

    .webinar-meta-info {
        gap: 16px;
    }

    .locked-message {
        padding: 20px;
    }

    .locked-message i {
        font-size: 48px;
    }

    .locked-message h3 {
        font-size: 20px;
    }

    .locked-actions {
        flex-direction: column;
        gap: 12px;
    }

    .locked-actions .btn-signin,
    .locked-actions .btn-register {
        width: 100%;
        justify-content: center;
        padding: 12px 20px;
    }

    .locked-actions .btn-signin i,
    .locked-actions .btn-register i {
        display: inline-block !important;
        font-size: 16px;
    }

    /* Profile mobile */
    .profile-section,
    .favorites-section,
    .history-section,
    .certificates-section {
        padding: 40px 0;
    }

    .profile-header {
        flex-direction: column;
        text-align: center;
    }

    .profile-name {
        font-size: 24px;
    }

    /* History mobile */
    .history-link {
        grid-template-columns: 1fr;
    }

    .history-thumbnail {
        width: 100%;
    }

    .history-content {
        padding: 20px;
    }

    /* Live mobile */
    .live-header {
        padding: 24px 0 16px;
    }

    .live-title {
        font-size: 24px;
    }

    .live-meta {
        flex-direction: column;
        gap: 12px;
    }

    .upcoming-grid {
        grid-template-columns: 1fr;
    }

    /* Section header inline mobile */
    .section-header-inline {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .webinar-grid-compact {
        grid-template-columns: 1fr;
    }

    /* Single Webinar Mobile */
    .webinar-simple-hero {
        padding: 20px 0 24px;
    }

    .video-container:has(.video-locked) {
        min-height: auto;
    }

    .video-locked {
        position: relative;
        min-height: auto;
        padding: 40px 20px;
    }

    .video-locked-content {
        padding: 20px;
    }

    .hero-top {
        margin-bottom: 16px;
    }

    .hero-title-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .hero-title {
        font-size: 24px;
    }

    .btn-save-simple {
        align-self: flex-start;
    }

    .webinar-info-section {
        padding: 32px 0;
    }

    .info-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .speakers-label-row {
        font-size: 18px;
    }

    .speaker-name-col {
        font-size: 16px;
    }

    .speaker-details-col {
        padding-left: 0;
        gap: 12px;
    }

    .info-share {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .share-buttons {
        width: 100%;
        justify-content: space-between;
    }

    .related-webinars-section {
        padding: 40px 0;
    }
}


/* ==========================================
   LIVE PAGE MOBILE
   ========================================== */

@media (max-width: 768px) {
    .live-status-inner {
        flex-direction: column;
        gap: 12px;
        align-items: flex-start;
    }
    
    .live-indicator {
        width: 100%;
        justify-content: center;
    }
    
    .live-viewers {
        width: 100%;
        justify-content: center;
    }
    
    .live-video-container {
        max-height: none;
    }
    
    .live-info-section {
        padding: 32px 0;
    }
    
    .live-info-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    
    .live-title {
        font-size: 26px;
    }
    
    .live-meta-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .speakers-grid {
        grid-template-columns: 1fr;
    }
    
    .live-sidebar {
        position: relative;
        top: 0;
    }
    
    .no-live-section {
        padding: 80px 0;
    }
    
    .no-live-content i {
        font-size: 60px;
    }
    
    .no-live-content h2 {
        font-size: 28px;
    }
    
    .no-live-actions {
        flex-direction: column;
        width: 100%;
    }
    
    .no-live-actions .btn-watch,
    .no-live-actions .btn-outline {
        width: 100%;
        justify-content: center;
    }

    .no-live-actions .btn-outline i {
        font-size: 14px;
    }
    
    .upcoming-next-section {
        padding: 40px 0;
    }
    
    .upcoming-grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================
   UPCOMING PAGE MOBILE
   ========================================== */

@media (max-width: 768px) {
    .upcoming-hero-slideshow {
        height: 100vh;
        min-height: auto;
    }

    .upcoming-hero-slideshow .slide-title {
        font-size: 32px;
    }
    
    .slide-overlay {
        background: linear-gradient(
            to top,
            rgba(0,0,0,0.95) 0%,
            rgba(0,0,0,0.8) 50%,
            rgba(0,0,0,0.4) 100%
        );
    }
    
    .slide-content-wrapper {
        align-items: flex-end;
    }
    
    .slide-content {
        max-width: 100%;
        padding: 40px 20px;
    }
    
    .slide-title {
        font-size: 28px;
    }
    
    .slide-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .slide-description {
        font-size: 15px;
    }
    
    .slide-actions {
        flex-direction: column;
        width: 100%;
    }
    
    .slide-actions .btn-primary,
    .slide-actions .btn-secondary {
        width: 100%;
        justify-content: center;
        padding: 14px 24px;
        font-size: 15px;
    }
    
    .slideshow-nav {
        width: 48px;
        height: 48px;
        font-size: 20px;
    }
    
    .slideshow-nav.prev {
        left: 16px;
    }
    
    .slideshow-nav.next {
        right: 16px;
    }
    
    .slideshow-indicators {
        bottom: 20px;
    }
    
    .all-upcoming-section {
        padding: 40px 0;
    }
    
    .all-upcoming-section .section-title {
        font-size: 24px;
    }
    
    .no-upcoming-section {
        padding: 80px 0;
    }
    
    .no-upcoming-content > i {
        font-size: 60px;
    }
    
    .no-upcoming-content h2 {
        font-size: 28px;
    }
    
    .no-upcoming-actions {
        flex-direction: column;
        width: 100%;
        max-width: 300px;
        margin: 0 auto;
    }
    
    .no-upcoming-actions .btn-watch,
    .no-upcoming-actions .btn-outline {
        width: 100%;
        justify-content: center;
    }
}


/* ==========================================
   UPCOMING PAGE LIST - MOBILE
   ========================================== */

@media (max-width: 768px) {
    
    .all-upcoming-section {
        padding: 40px 0;
    }
    
    .upcoming-list {
        gap: 16px;
    }
    
    .upcoming-list-item {
        grid-template-columns: 1fr;
        gap: 0;
    }
    
    .upcoming-item-thumbnail {
        min-height: 200px;
    }
    
    .upcoming-item-content {
        padding: 24px;
    }
    
    .upcoming-item-date-wrapper {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        margin-bottom: 16px;
    }
    
    .upcoming-item-title {
        font-size: 18px;
    }
    
    .upcoming-item-speaker {
        font-size: 14px;
        flex-wrap: wrap;
    }
}



/* Single Webinar Upcoming Countdown - Mobile */
@media (max-width: 768px) {
    .upcoming-countdown-container {
        padding: 60px 24px;
    }

    .video-container:has(.upcoming-countdown-container) {
        min-height: auto;
    }
    
    .upcoming-title {
        font-size: 28px;
    }
    
    .upcoming-date-text {
        font-size: 16px;
    }
    
    .countdown-container-single .countdown {
        gap: 4px;
    }
    
    .btn-register-single {
        width: 100%;
        justify-content: center;
        padding: 14px 24px;
        font-size: 14px;
    }
    
    /* Sidebar Mobile */
    .info-wrapper.has-sidebar {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .info-sidebar {
        position: relative;
        top: 0;
        order: -1;
    }

    .sidebar-cta-box {
        padding: 24px;
    }
    
    /* Language Version Banner Mobile */
    .lang-version-banner {
        padding: 12px 0;
    }
    
    .lang-version-inner {
        gap: 10px;
    }
    
    .lang-version-left {
        display: flex;
        flex-direction: row;
        gap: 8px;
        align-items: center;
    }
    
    .lang-version-flag {
        width: 20px;
    }
    
    .lang-version-text {
        flex-direction: column;
        align-items: flex-start;
        gap: 2px;
    }
    
    .btn-lang-version {
        padding: 8px 14px;
        font-size: 12px;
    }
    
    /* Hide Slideshow Navigation Arrows on Mobile */
    .slideshow-nav {
        display: none !important;
    }
    
    /* Mobile Menu Overlay */
    .nav-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 999;
    }
    
    .nav-overlay.active {
        display: block;
    }
    
    /* Certificates Mobile */
    .certificates-stats {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .certificates-filters {
        flex-direction: column;
        align-items: stretch;
    }
    
    .filter-select {
        width: 100%;
    }
    
    .certificates-grid {
        grid-template-columns: 1fr;
    }
    
    .certificate-content-wrapper {
        flex-direction: column;
        gap: 12px;
    }
    
    .certificate-thumbnail {
        width: 100%;
        height: 140px;
    }
    
    .btn-download-certificate,
    .btn-view-certificate {
        padding-left: 10px;
        padding-right: 10px;
    }
    
    .certificates-pagination {
        flex-direction: column;
        gap: 16px;
    }
    
    .pagination-btn {
        width: 100%;
        justify-content: center;
    }
    
    .pagination-info {
        flex-direction: column;
        text-align: center;
        gap: 4px;
    }
    
    .pagination-info .separator {
        display: none;
    }
    
    /* Live Chat Mobile */
    .live-video-chat-wrapper {
        display: block;
    }
    
    .live-video-chat-wrapper .video-container {
        max-width: 100%;
        margin: 0 0 24px;
    }
    
    .live-video-container {
        margin-bottom: 24px;
    }
    
    .live-chat-box {
        padding: 20px;
    }
    
    .btn-send-message {
        padding: 12px 20px;
        font-size: 14px;
    }
    
    /* Add to Calendar Mobile */
    .upcoming-register-action {
        flex-direction: column;
        align-items: stretch;
    }
    
    .btn-add-calendar,
    .btn-register-single {
        width: 100%;
        justify-content: center;
    }
    
    .calendar-dropdown {
        left: 0;
        right: 0;
        width: 100%;
    }
    
    /* Login Required Section Mobile */
    .login-required-section {
        padding: 48px 16px;
    }
    
    .login-required-box {
        padding: 40px 24px;
        border-radius: 8px;
    }
    
    .login-required-icon {
        width: 64px;
        height: 64px;
        margin-bottom: 20px;
    }
    
    .login-required-icon i {
        font-size: 28px;
    }
    
    .login-required-title {
        font-size: 22px;
        margin-bottom: 10px;
    }
    
    .login-required-text {
        font-size: 14px;
        margin-bottom: 24px;
    }
    
    .login-required-actions {
        flex-direction: column;
        gap: 10px;
    }
    
    .btn-signin-required,
    .btn-register-required {
        width: 100%;
        justify-content: center;
        padding: 12px 24px;
        font-size: 14px;
    }
}

/* Small Screens - Logo Adjustment */
@media (max-width: 415px) {
    .logo-img {
        height: 30px;
        width: auto;
    }
}



/* ============================================================
   Nav lang switcher + Auth — responsive
   ============================================================ */

/* Tablet: hide text labels, keep flags in pill */
@media (max-width: 1100px) {
    .nav-lang-link span { display: none; }
    .nav-lang-link { padding: 6px 10px; }
}

@media (max-width: 768px) {
    /* Hide desktop pill on mobile */
    .nav-lang-switcher { display: none; }

    /* Auth forms */
    .auth-box {
        padding: 24px 20px;
        max-width: 100% !important;
    }

    .auth-form .form-row {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .form-group--inline {
        flex-direction: column;
        align-items: flex-start;
    }

    .auth-success-icon { font-size: 44px; }
    .auth-success-title { font-size: 18px; }
}
