/* ===================================================
   ALFA TECH GROUP — Responsive Styles
   =================================================== */

/* --- Large desktop (1280px+) handled in main.css --- */

/* --- Medium desktop (1024px - 1279px) --- */
@media (max-width: 1279px) {
    .container { padding: 0 1.25rem; }
    .footer-grid { grid-template-columns: 1.2fr repeat(3, 1fr); gap: 2rem; }
}

/* --- Tablet landscape (768px - 1023px) --- */
@media (max-width: 1023px) {
    .navbar-menu { display: none; }
    .hamburger { display: flex; }

    /* Mobile menu */
    .mobile-nav {
        display: none;
        position: fixed;
        top: 68px; left: 0; right: 0; bottom: 0;
        background: var(--bg-primary);
        z-index: 999;
        overflow-y: auto;
        padding: 1.5rem;
        flex-direction: column;
        gap: 0.25rem;
        border-top: 1px solid var(--border);
    }
    .mobile-nav.open { display: flex; }
    .mobile-nav a {
        display: flex;
        align-items: center;
        padding: 0.85rem 1rem;
        border-radius: var(--radius-md);
        font-size: 1rem;
        font-weight: 500;
        color: var(--text-secondary);
        border-bottom: 1px solid var(--border);
        gap: 0.5rem;
    }
    .mobile-nav a:hover, .mobile-nav a.active {
        color: var(--accent);
        background: var(--accent-glow);
    }
    .mobile-nav-section {
        font-size: 0.72rem;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--text-muted);
        padding: 1rem 1rem 0.25rem;
        font-weight: 700;
    }

    /* Grid adjustments */
    .grid-4 { grid-template-columns: repeat(2, 1fr); }
    .grid-3 { grid-template-columns: repeat(2, 1fr); }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }

    /* Hero */
    .hero { min-height: 80vh; padding: 4rem 0; }
    .hero-title { font-size: clamp(2rem, 5vw, 3.5rem); }

    /* Admin */
    .admin-sidebar {
        transform: translateX(-100%);
        transition: transform 0.3s ease;
    }
    .admin-sidebar.open { transform: translateX(0); }
    .admin-main { margin-left: 0; }
}

/* --- Tablet portrait (640px - 767px) --- */
@media (max-width: 767px) {
    .section { padding: 3.5rem 0; }
    .section-lg { padding: 5rem 0; }

    .grid-2 { grid-template-columns: 1fr; }
    .grid-3 { grid-template-columns: 1fr; }
    .grid-4 { grid-template-columns: repeat(2, 1fr); }
    .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .footer-brand { grid-column: 1 / -1; }

    .hero { min-height: unset; padding: 3rem 0; }
    .hero-badge { font-size: 0.75rem; }
    .hero-actions { flex-direction: column; }
    .hero-actions .btn { width: 100%; }

    .plan-card { padding: 1.5rem; }
    .theme-grid { grid-template-columns: repeat(2, 1fr); }

    .auth-card { padding: 2rem 1.5rem; }
    .maintenance-content { padding: 0 0.5rem; }

    /* Admin */
    .admin-main { padding: 1rem; }
    .stat-cards { grid-template-columns: repeat(2, 1fr); }
    .admin-header { flex-direction: column; align-items: flex-start; gap: 0.75rem; }

    /* Tables */
    .data-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* --- Mobile (< 640px) --- */
@media (max-width: 639px) {
    html { font-size: 15px; }
    .container { padding: 0 1rem; }

    .navbar-logo-text { font-size: 1.05rem; }
    .navbar-actions .lang-picker-btn span:not(.flag) { display: none; }

    .grid-4 { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
    .footer-grid { grid-template-columns: 1fr; }
    .footer-bottom { flex-direction: column; text-align: center; }

    .hero-title { font-size: clamp(1.8rem, 8vw, 2.5rem); }

    .section-header { margin-bottom: 2rem; }

    .countdown { gap: 1rem; }
    .countdown-val { font-size: clamp(1.8rem, 8vw, 2.5rem); }

    .stat-cards { grid-template-columns: 1fr; }
    .theme-grid { grid-template-columns: repeat(2, 1fr); }

    .btn-lg { padding: 0.85rem 1.75rem; font-size: 0.95rem; }

    /* Fix contact form */
    .contact-grid { grid-template-columns: 1fr; }
}

/* --- Very small screens (< 375px) --- */
@media (max-width: 374px) {
    .countdown { gap: 0.5rem; }
    .countdown-sep { display: none; }
    .auth-card { padding: 1.5rem 1rem; }
}

/* --- Print --- */
@media print {
    .navbar, .footer, .hamburger, .theme-picker-btn, .lang-picker, .hero-bg, .hero-grid-overlay { display: none !important; }
    body { background: white; color: black; }
    main { padding-top: 0; }
    a { color: black; text-decoration: underline; }
}

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    [data-reveal] { opacity: 1; transform: none; }
}

/* --- High contrast --- */
@media (forced-colors: active) {
    .btn-primary { forced-color-adjust: none; }
    .card, .plan-card { border: 2px solid ButtonText; }
}

/* --- Landscape mobile fix --- */
@media (max-width: 767px) and (orientation: landscape) {
    .hero { min-height: unset; }
    .maintenance-wrap { padding: 1rem; }
    .auth-wrap { align-items: flex-start; padding-top: 1rem; }
}
