/* REHABCYBER Mobile Responsive Design */
/* This file contains mobile optimizations for all pages */

/* Mobile Responsive Design */
@media (max-width: 768px) {
    /* Header Mobile Optimization */
    .header__container {
        padding: 0 20px !important;
        flex-direction: column;
        gap: 15px;
    }
    
    .header__logo img {
        height: 60px !important;
    }
    
    #homeSearchInput {
        width: 100% !important;
        max-width: 300px !important;
        font-size: 16px !important; /* Prevents zoom on iOS */
    }
    
    .menu-toggle {
        position: absolute;
        top: 20px;
        right: 20px;
    }
    
    .collapsible-menu {
        width: 100% !important;
        right: 0 !important;
        margin-right: 0 !important;
        border-radius: 0 !important;
        position: fixed;
        top: 80px;
        left: 0;
        right: 0;
    }
    
    /* Main Content Mobile */
    .main__container {
        padding: 0 20px !important;
        margin-top: 0 !important; /* Remove negative margin on mobile */
        text-align: center !important;
    }
    
    .main__title {
        font-size: 48px !important;
        line-height: 1.1 !important;
        max-width: 100% !important;
        word-wrap: break-word !important;
    }
    
    .main__caption {
        font-size: 18px !important;
        line-height: 1.4 !important;
        padding: 0 15px !important;
    }
    
    .main__text {
        font-size: 16px !important;
        margin-bottom: 25px !important;
        text-align: center !important;
        padding: 0 15px !important;
    }
    
    .main__button {
        padding: 12px 30px !important;
        font-size: 14px !important;
    }
    
    /* About Section Mobile */
    .about__title {
        font-size: 24px !important;
        white-space: normal !important;
    }
    
    .about__container {
        flex-direction: column !important;
    }
    
    .about__content {
        padding: 30px 20px !important;
    }
    
    /* Search Section Mobile */
    .search-section {
        padding: 30px 20px !important;
    }
    
    .search-section h2 {
        font-size: 24px !important;
    }
    
    .search-section p {
        font-size: 16px !important;
    }
    
    .search-container {
        flex-direction: column !important;
        gap: 15px;
        padding: 0 20px !important;
    }
    
    .search-container input,
    .search-input {
        width: 100% !important;
        font-size: 16px !important;
        padding: 15px !important;
    }
    
    .search-container button,
    .search-button {
        width: 100% !important;
        padding: 15px !important;
        margin-top: 15px !important;
    }
    
    /* Results Mobile */
    .results-container {
        padding: 0 20px !important;
    }
    
    .result-card {
        padding: 15px !important;
        margin-bottom: 15px !important;
    }
    
    .result-card h3 {
        font-size: 16px !important;
        line-height: 1.3 !important;
    }
    
    .result-card .journal {
        font-size: 14px !important;
    }
    
    .result-card .abstract {
        font-size: 14px !important;
        line-height: 1.4 !important;
    }
    
    /* Services Mobile */
    .services-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    
    .service-card {
        padding: 20px !important;
    }
    
    .service-card h3 {
        font-size: 20px !important;
    }
    
    /* Video Section Mobile */
    .video-section {
        padding: 30px 20px !important;
    }
    
    .video-container {
        height: 200px !important;
    }
    
    /* Blog Content Mobile */
    .blog__grid {
        display: block !important;
    }
    
    .blog__main {
        width: 100% !important;
        padding: 0 20px;
    }
    
    .blog__sidebar {
        padding-left: 20px !important;
        padding-right: 20px;
        margin-top: 30px;
    }
    
    /* Social Media Banner Mobile */
    .social-media-banner {
        margin: 0 20px 30px 20px;
        padding: 15px !important;
    }
    
    .social-media-banner h3 {
        font-size: 18px !important;
    }
    
    .social-btn {
        padding: 10px 15px !important;
        font-size: 14px !important;
    }
    
    /* Blog Posts Mobile */
    .blog__post {
        padding: 20px !important;
        margin-bottom: 20px !important;
    }
    
    .blog__post h2 {
        font-size: 20px !important;
        line-height: 1.2 !important;
    }
    
    .blog__post-image {
        height: 150px !important;
    }
    
    /* Newsletter Signup Mobile */
    .newsletter-signup {
        padding: 20px !important;
        margin: 0 20px 30px 20px;
    }
    
    .newsletter-signup input {
        width: 100% !important;
        margin-bottom: 10px;
    }
    
    .newsletter-signup button {
        width: 100% !important;
    }
    
    /* Sidebar Mobile */
    .sidebar-ad,
    .sidebar-widget,
    .social-widget,
    .newsletter-widget {
        margin-bottom: 20px !important;
        padding: 15px !important;
    }
    
    /* Dashboard Content Mobile */
    .dashboard-container {
        padding: 20px !important;
    }
    
    .dashboard-container h1 {
        font-size: 28px !important;
    }
    
    .dashboard-container h2 {
        font-size: 22px !important;
    }
    
    .dashboard-container p {
        font-size: 16px !important;
    }
    
    .dashboard-button {
        width: 100% !important;
        padding: 15px !important;
        font-size: 16px !important;
        margin-bottom: 15px !important;
    }
    
    .dashboard-grid {
        display: block !important;
    }
    
    .dashboard-card {
        margin-bottom: 20px !important;
        padding: 20px !important;
    }
    
    .dashboard-card h3 {
        font-size: 18px !important;
    }
    
    .dashboard-card p {
        font-size: 14px !important;
    }
    
    /* Form Mobile */
    .form-container {
        padding: 20px !important;
    }
    
    .form-group {
        margin-bottom: 20px !important;
    }
    
    .form-group input,
    .form-group select,
    .form-group textarea {
        width: 100% !important;
        padding: 15px !important;
        font-size: 16px !important;
        box-sizing: border-box;
    }
    
    .form-group label {
        font-size: 16px !important;
        margin-bottom: 8px !important;
    }
    
    .form-button {
        width: 100% !important;
        padding: 15px !important;
        font-size: 16px !important;
        margin-top: 20px !important;
    }
    
    /* Filters Mobile */
    .filters {
        flex-direction: column !important;
        gap: 15px !important;
    }
    
    .filter-group {
        width: 100% !important;
    }
    
    .filter-group select {
        width: 100% !important;
        font-size: 16px !important;
    }
    
    /* Pagination Mobile */
    .pagination {
        flex-wrap: wrap !important;
        gap: 10px !important;
    }
    
    .pagination button {
        padding: 10px 15px !important;
        font-size: 14px !important;
    }
    
    /* Loading Mobile */
    .loading {
        padding: 0 20px !important;
    }
    
    .loading h3 {
        font-size: 18px !important;
    }
    
    /* Outro Section Mobile */
    .outro__container {
        padding: 0 20px !important;
    }
    
    .outro__title {
        font-size: 28px !important;
    }
    
    .outro__text {
        font-size: 16px !important;
    }
    
    .outro__button {
        padding: 15px 30px !important;
        font-size: 16px !important;
    }
    
    /* Social Media CTA Mobile */
    .social-media-banner .social-btn {
        flex-direction: column;
        gap: 5px;
        text-align: center;
    }
    
    /* Footer Mobile */
    .footer__container {
        padding: 0 20px !important;
        flex-direction: column;
        gap: 20px;
        text-align: center;
    }
}

@media (max-width: 480px) {
    /* Extra Small Mobile */
    .header__container {
        padding: 0 15px !important;
    }
    
    .header__logo img {
        height: 50px !important;
    }
    
    #homeSearchInput {
        padding: 10px 12px !important;
        font-size: 14px !important;
    }
    
    .main__container {
        margin-top: 50px !important; /* Positive margin for very small screens */
    }
    
    .main__title {
        font-size: 36px !important;
        padding: 0 10px !important;
    }
    
    .main__caption {
        font-size: 16px !important;
        padding: 0 10px !important;
    }
    
    .about__title {
        font-size: 20px !important;
    }
    
    .search-section h2 {
        font-size: 20px !important;
    }
    
    .service-card h3 {
        font-size: 18px !important;
    }
    
    .video-container {
        height: 150px !important;
    }
    
    .blog__post h2 {
        font-size: 18px !important;
    }
    
    .social-btn {
        padding: 8px 12px !important;
        font-size: 12px !important;
    }
    
    .outro__title {
        font-size: 24px !important;
    }
    
    .blog__post-image {
        height: 120px !important;
    }
    
    .dashboard-container h1 {
        font-size: 24px !important;
    }
    
    .dashboard-container h2 {
        font-size: 20px !important;
    }
    
    .dashboard-card h3 {
        font-size: 16px !important;
    }
    
    .result-card h3 {
        font-size: 15px !important;
    }
    
    .result-card .journal {
        font-size: 13px !important;
    }
    
    .result-card .abstract {
        font-size: 13px !important;
    }
    
    .pagination button {
        padding: 8px 12px !important;
        font-size: 12px !important;
    }
    
    /* Stack social buttons vertically on very small screens */
    .social-media-banner > div {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .social-media-banner .social-btn {
        width: 100%;
        justify-content: center;
    }
}

/* iOS-specific fixes */
@supports (-webkit-touch-callout: none) {
    /* iOS Safari specific styles */
    input[type="email"],
    input[type="text"],
    input[type="password"],
    select,
    textarea {
        font-size: 16px !important; /* Prevents zoom on iOS */
    }
}

/* Android-specific fixes */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
    /* Android Chrome specific styles */
    .header__container {
        -webkit-transform: translateZ(0);
        transform: translateZ(0);
    }
}

/* Touch device optimizations */
@media (hover: none) and (pointer: coarse) {
    /* Touch device specific styles */
    .nav-link,
    .social-btn,
    .outro__button,
    .main__button,
    .search-button,
    .form-button,
    .dashboard-button {
        min-height: 44px; /* Apple's recommended touch target size */
        padding: 12px 20px !important;
    }
    
    .menu-toggle {
        min-height: 44px;
        min-width: 44px;
        padding: 10px !important;
    }
}

/* High DPI display optimizations */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    /* High DPI display specific styles */
    .header__logo img {
        image-rendering: -webkit-optimize-contrast;
        image-rendering: crisp-edges;
    }
}

/* Landscape orientation optimizations */
@media (max-width: 768px) and (orientation: landscape) {
    .main__title {
        font-size: 32px !important;
    }
    
    .header__container {
        flex-direction: row !important;
        padding: 10px 20px !important;
    }
    
    .header__logo img {
        height: 40px !important;
    }
    
    .collapsible-menu {
        top: 60px !important;
    }
}

/* Print styles */
@media print {
    .header,
    .menu-toggle,
    .collapsible-menu,
    .social-media-banner,
    .newsletter-signup,
    .sidebar-ad,
    .footer {
        display: none !important;
    }
    
    .main__container,
    .blog__main,
    .dashboard-container {
        padding: 0 !important;
    }
    
    body {
        background: white !important;
        color: black !important;
    }
}

