/* ======================================
   Responsive Design - Modern Color Scheme
   ระบบลงทะเบียนอบรมอาชีพเสริม ปี 2568
   ====================================== */

/* Large Desktop (1200px and up) */
@media (min-width: 1200px) {
    .container {
        max-width: 1320px;
    }
    
    .welcome-header h1 {
        font-size: var(--font-size-5xl);
    }
    
    .section-header h2 {
        font-size: var(--font-size-4xl);
    }
    
    .quick-stats {
        grid-template-columns: repeat(4, 1fr);
    }
    
    .courses-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-8);
    }
}

/* Desktop (992px to 1199px) */
@media (max-width: 1199px) and (min-width: 992px) {
    .container {
        max-width: 1140px;
    }
    
    .quick-stats {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .courses-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-6);
    }
}

/* Tablet (768px to 991px) */
@media (max-width: 991px) and (min-width: 768px) {
    .container {
        max-width: 960px;
        padding: 0 var(--space-4);
    }
    
    .nav-container {
        padding: 0 var(--space-4);
    }
    
    .nav-menu {
        gap: var(--space-4);
    }
    
    .nav-link {
        padding: var(--space-2) var(--space-3);
        font-size: var(--font-size-sm);
    }
    
    .section {
        padding: var(--space-12) 0;
    }
    
    .section-header {
        margin-bottom: var(--space-12);
    }
    
    .section-header h2 {
        font-size: var(--font-size-3xl);
    }
    
    .welcome-card {
        padding: var(--space-12);
    }
    
    .welcome-header h1 {
        font-size: var(--font-size-4xl);
    }
    
    .quick-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-4);
    }
    
    .stat-card {
        padding: var(--space-4);
        flex-direction: column;
        text-align: center;
        gap: var(--space-3);
    }
    
    .stat-card i {
        font-size: var(--font-size-2xl);
        min-width: 56px;
    }
    
    .courses-grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }
    
    .course-card {
        padding: var(--space-6);
    }
    
    .profile-card {
        padding: var(--space-8);
        gap: var(--space-6);
    }
    
    .profile-avatar {
        width: 100px;
        height: 100px;
        font-size: 50px;
    }
    
    .info-row {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-1);
    }
    
    .info-row label {
        min-width: auto;
        font-size: var(--font-size-sm);
        color: var(--text-tertiary);
    }
    
    .modal-content {
        width: 95%;
        margin: var(--space-4);
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: var(--space-4);
    }
}

/* Mobile Large (576px to 767px) */
@media (max-width: 767px) and (min-width: 576px) {
    .container {
        max-width: 720px;
        padding: 0 var(--space-3);
    }
    
    .nav-toggle {
        display: flex;
    }
    
    .nav-menu {
        position: fixed;
        top: 72px;
        left: 0;
        width: 100%;
        background: var(--glass-bg);
        backdrop-filter: blur(20px) saturate(180%);
        -webkit-backdrop-filter: blur(20px) saturate(180%);
        border-top: 1px solid var(--border-light);
        flex-direction: column;
        padding: var(--space-6);
        gap: var(--space-4);
        transform: translateY(-100vh);
        transition: var(--transition-normal);
        z-index: 999;
        box-shadow: var(--shadow-lg);
    }
    
    .nav-menu.active {
        transform: translateY(0);
        animation: slideInDown 0.3s ease-out;
    }
    
    .nav-link {
        width: 100%;
        padding: var(--space-3) var(--space-4);
        border-radius: var(--radius-lg);
        text-align: center;
        background: rgba(255, 255, 255, 0.5);
        backdrop-filter: blur(10px);
        border: 1px solid rgba(255, 255, 255, 0.2);
    }
    
    .nav-link:hover,
    .nav-link.active {
        background: var(--primary-gradient);
        color: var(--text-white);
        transform: scale(1.02);
    }
    
    .section {
        padding: var(--space-10) 0;
    }
    
    .section-header h2 {
        font-size: var(--font-size-2xl);
        line-height: var(--line-height-tight);
    }
    
    .section-header p {
        font-size: var(--font-size-base);
    }
    
    .welcome-card {
        padding: var(--space-8);
    }
    
    .welcome-header h1 {
        font-size: var(--font-size-3xl);
        line-height: var(--line-height-tight);
    }
    
    .welcome-header p {
        font-size: var(--font-size-lg);
    }
    
    .org-name {
        font-size: var(--font-size-base);
    }
    
    .quick-stats {
        grid-template-columns: 1fr;
        gap: var(--space-3);
        margin-bottom: var(--space-8);
    }
    
    .stat-card {
        padding: var(--space-4);
        border-radius: var(--radius-lg);
    }
    
    .stat-number {
        font-size: var(--font-size-2xl);
    }
    
    .cta-buttons {
        flex-direction: column;
        align-items: stretch;
        gap: var(--space-3);
    }
    
    .btn {
        padding: var(--space-4) var(--space-6);
        font-size: var(--font-size-lg);
    }
    
    .course-card {
        padding: var(--space-5);
    }
    
    .course-header h3 {
        font-size: var(--font-size-lg);
    }
    
    .course-quota {
        flex-direction: column;
        gap: var(--space-2);
    }
    
    .quota-item {
        padding: var(--space-3);
    }
    
    .profile-card {
        padding: var(--space-6);
        gap: var(--space-4);
    }
    
    .profile-avatar {
        width: 80px;
        height: 80px;
        font-size: 40px;
    }
    
    .eligibility-status {
        margin-bottom: var(--space-6);
        padding: var(--space-4);
        border-radius: var(--radius-lg);
    }
    
    .modal-content {
        width: 95%;
        margin: var(--space-3);
        border-radius: var(--radius-xl);
    }
    
    .modal-header h3 {
        font-size: var(--font-size-lg);
    }
    
    .modal-footer {
        flex-direction: column;
        gap: var(--space-2);
    }
    
    .modal-footer .btn {
        width: 100%;
    }
}

/* Mobile Small (below 576px) */
@media (max-width: 575px) {
    .container {
        padding: 0 var(--space-2);
    }
    
    .nav-container {
        padding: 0 var(--space-3);
        height: 64px;
    }
    
    .nav-brand {
        font-size: var(--font-size-base);
        gap: var(--space-2);
    }
    
    .nav-brand i {
        font-size: var(--font-size-xl);
    }
    
    .nav-toggle span {
        width: 20px;
    }
    
    .main-content {
        margin-top: 64px;
        min-height: calc(100vh - 64px);
    }
    
    .nav-menu {
        top: 64px;
        padding: var(--space-4);
    }
    
    .section {
        padding: var(--space-8) 0;
    }
    
    .section-header {
        margin-bottom: var(--space-8);
    }
    
    .section-header h2 {
        font-size: var(--font-size-xl);
        flex-direction: column;
        gap: var(--space-2);
    }
    
    .section-header p {
        font-size: var(--font-size-sm);
    }
    
    .welcome-card {
        padding: var(--space-6);
        border-radius: var(--radius-xl);
    }
    
    .welcome-header h1 {
        font-size: var(--font-size-2xl);
    }
    
    .welcome-header p {
        font-size: var(--font-size-base);
    }
    
    .org-name {
        font-size: var(--font-size-sm);
        margin-bottom: var(--space-6);
    }
    
    .quick-stats {
        margin-bottom: var(--space-6);
    }
    
    .stat-card {
        padding: var(--space-3);
        gap: var(--space-2);
    }
    
    .stat-card i {
        font-size: var(--font-size-xl);
        padding: var(--space-3);
        min-width: 48px;
    }
    
    .stat-number {
        font-size: var(--font-size-xl);
    }
    
    .stat-label {
        font-size: var(--font-size-xs);
    }
    
    .course-card {
        padding: var(--space-4);
        border-radius: var(--radius-lg);
    }
    
    .course-header {
        gap: var(--space-2);
        margin-bottom: var(--space-4);
    }
    
    .course-header i {
        font-size: var(--font-size-xl);
    }
    
    .course-header h3 {
        font-size: var(--font-size-base);
    }
    
    .course-details p,
    .course-details li {
        font-size: var(--font-size-sm);
    }
    
    .course-details ul {
        margin-bottom: var(--space-4);
    }
    
    .quota-item {
        padding: var(--space-2);
        border-radius: var(--radius-md);
    }
    
    .quota-label {
        font-size: var(--font-size-xs);
    }
    
    .quota-count {
        font-size: var(--font-size-base);
    }
    
    .btn-register {
        padding: var(--space-3) var(--space-4);
        font-size: var(--font-size-base);
    }
    
    .profile-card {
        padding: var(--space-4);
    }
    
    .profile-avatar {
        width: 64px;
        height: 64px;
        font-size: 32px;
    }
    
    .info-row {
        padding: var(--space-2) 0;
    }
    
    .info-row label {
        font-weight: 500;
    }
    
    .registration-status {
        padding: var(--space-4);
        border-radius: var(--radius-lg);
    }
    
    .status-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-2);
    }
    
    .status-header h3 {
        font-size: var(--font-size-lg);
    }
    
    .modal-content {
        width: 98%;
        margin: var(--space-2);
        max-height: 95vh;
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: var(--space-3);
    }
    
    .modal-header h3 {
        font-size: var(--font-size-base);
    }
    
    .form-group {
        margin-bottom: var(--space-4);
    }
    
    .form-control {
        padding: var(--space-3);
        font-size: var(--font-size-base);
    }
    
    .input-wrapper .form-control {
        padding-left: var(--space-10);
    }
    
    .input-wrapper i {
        left: var(--space-3);
        font-size: var(--font-size-base);
    }
    
    .alert {
        padding: var(--space-3);
        font-size: var(--font-size-sm);
        border-radius: var(--radius-md);
    }
    
    .alert-container {
        top: 74px;
        right: var(--space-2);
        left: var(--space-2);
        max-width: none;
    }
    
    .status-badge {
        padding: var(--space-1) var(--space-2);
        font-size: 0.625rem;
    }
}

/* Extra Small Mobile (below 400px) */
@media (max-width: 399px) {
    .container {
        padding: 0 var(--space-1);
    }
    
    .nav-container {
        padding: 0 var(--space-2);
    }
    
    .nav-brand span {
        display: none;
    }
    
    .section {
        padding: var(--space-6) 0;
    }
    
    .welcome-card {
        padding: var(--space-4);
    }
    
    .welcome-header h1 {
        font-size: var(--font-size-xl);
    }
    
    .welcome-header p {
        font-size: var(--font-size-sm);
    }
    
    .org-name {
        font-size: var(--font-size-xs);
    }
    
    .course-card {
        padding: var(--space-3);
    }
    
    .course-header h3 {
        font-size: var(--font-size-sm);
    }
    
    .profile-card {
        padding: var(--space-3);
    }
    
    .profile-avatar {
        width: 56px;
        height: 56px;
        font-size: 28px;
    }
    
    .modal-content {
        width: 100%;
        margin: 0;
        border-radius: var(--radius-lg);
        max-height: 100vh;
    }
}

/* High DPI Displays */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .glass-card,
    .navbar,
    .modal-content {
        border-width: 0.5px;
    }
    
    .nav-toggle span {
        height: 1.5px;
    }
}

/* Reduced Motion Preference */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    
    .loading-spinner i {
        animation: none;
        transform: rotate(45deg);
    }
}

/* High Contrast Mode */
@media (prefers-contrast: high) {
    :root {
        --border-light: #000000;
        --border-main: #000000;
        --border-strong: #000000;
        --shadow-xs: none;
        --shadow-sm: none;
        --shadow-md: none;
        --shadow-lg: none;
        --shadow-xl: none;
    }
    
    .btn {
        border: 2px solid currentColor;
    }
    
    .form-control {
        border-width: 2px;
    }
    
    .card,
    .glass-card {
        border-width: 2px;
    }
}

/* Print Styles */
@media print {
    .navbar,
    .nav-toggle,
    .btn,
    .modal,
    .loading-overlay,
    .alert-container {
        display: none !important;
    }
    
    .main-content {
        margin-top: 0;
    }
    
    .section {
        display: block !important;
        page-break-inside: avoid;
    }
    
    .card,
    .welcome-card,
    .course-card,
    .profile-card {
        border: 1px solid #000;
        box-shadow: none;
        page-break-inside: avoid;
    }
    
    body {
        background: white !important;
        color: black !important;
        font-size: 12pt;
    }
    
    h1, h2, h3 {
        color: black !important;
    }
}