/* ================================================
   모바일 최적화 CSS
   ================================================ */

/* 터치 반응성 향상 */
* {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
    -webkit-touch-callout: none;
    touch-action: manipulation;
}

/* 모바일 기본 스타일 */
@media screen and (max-width: 768px) {
    body {
        padding: 10px;
        font-size: 14px;
    }

    .container {
        padding: 0;
    }

    /* 사용자 정보 바 모바일 */
    .user-info-bar {
        padding: 12px 15px;
        flex-direction: column;
        gap: 10px;
        align-items: flex-start;
    }

    #userGreeting {
        font-size: 16px;
        width: 100%;
    }

    .user-actions {
        width: 100%;
        justify-content: flex-end;
        gap: 8px;
    }

    .user-btn {
        padding: 10px 16px;
        font-size: 14px;
        min-height: 44px; /* iOS 최소 터치 영역 */
        min-width: 80px;
    }

    /* 메인 버튼 그리드 모바일 */
    .main-buttons-table {
        padding: 15px;
        margin-bottom: 15px;
    }

    .main-buttons-table h2 {
        font-size: 20px;
        margin-bottom: 15px;
    }

    .button-grid {
        grid-template-columns: repeat(2, 1fr); /* 2열로 변경 */
        gap: 12px;
    }

    .menu-btn {
        padding: 18px 12px;
        font-size: 15px;
        min-height: 80px; /* 터치하기 쉬운 크기 */
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
    }

    /* 버튼 활성화 애니메이션 (터치 피드백) */
    .menu-btn:active {
        transform: scale(0.95);
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    }

    .user-btn:active {
        transform: scale(0.95);
    }

    /* 샘플 테이블 모바일 */
    .sample-tables {
        padding: 15px;
    }

    .sample-table {
        margin-bottom: 15px;
    }

    .sample-table h3 {
        font-size: 18px;
        margin-bottom: 10px;
    }

    table {
        font-size: 13px;
    }

    table th,
    table td {
        padding: 10px 8px;
    }

    /* 테이블 가로 스크롤 */
    .table-wrapper {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* 로그인/회원가입 폼 모바일 */
    .auth-container {
        padding: 20px 15px;
    }

    .auth-box {
        padding: 25px 20px;
    }

    .form-group input {
        min-height: 44px; /* 터치 영역 */
        font-size: 16px; /* iOS 자동 줌 방지 */
    }

    .auth-btn {
        min-height: 48px;
        font-size: 16px;
    }

    /* 모달 모바일 */
    .modal-content {
        width: 95%;
        margin: 5% auto;
        padding: 20px 15px;
        max-height: 90vh;
        overflow-y: auto;
    }

    .modal-content h2 {
        font-size: 20px;
    }

    /* 검색창 모바일 */
    .search-bar input {
        min-height: 44px;
        font-size: 16px;
    }

    .search-bar button {
        min-height: 44px;
        min-width: 80px;
    }

    /* 관리자 컨트롤 모바일 */
    .admin-controls {
        padding: 12px;
    }

    .admin-controls button {
        min-height: 44px;
        font-size: 14px;
        padding: 10px 16px;
    }
}

/* 작은 모바일 (iPhone SE 등) */
@media screen and (max-width: 375px) {
    .button-grid {
        grid-template-columns: 1fr; /* 1열로 */
        gap: 10px;
    }

    .menu-btn {
        font-size: 14px;
        padding: 16px 10px;
        min-height: 70px;
    }

    .user-info-bar {
        padding: 10px;
    }

    #userGreeting {
        font-size: 14px;
    }

    .user-btn {
        font-size: 13px;
        padding: 8px 12px;
        min-width: 70px;
    }
}

/* 태블릿 */
@media screen and (min-width: 769px) and (max-width: 1024px) {
    .button-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* 가로모드 모바일 */
@media screen and (max-width: 768px) and (orientation: landscape) {
    .button-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .menu-btn {
        min-height: 60px;
        padding: 12px;
    }
}

/* 터치 디바이스 전용 스타일 */
@media (hover: none) and (pointer: coarse) {
    /* 호버 효과 제거, 터치 효과로 대체 */
    .menu-btn:hover {
        transform: none;
    }

    .menu-btn:active {
        transform: scale(0.95);
        opacity: 0.9;
    }

    .user-btn:hover {
        background-color: inherit;
    }

    .user-btn:active {
        opacity: 0.8;
    }

    /* 더 큰 터치 영역 */
    button, a, input[type="submit"] {
        min-height: 44px;
        min-width: 44px;
    }
}

/* 접근성 향상 */
@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
    }
}

/* 다크모드 대응 (선택사항) */
@media (prefers-color-scheme: dark) {
    body {
        background-color: #1a1a1a;
        color: #e0e0e0;
    }

    .user-info-bar,
    .main-buttons-table,
    .sample-tables {
        background-color: #2d2d2d;
        color: #e0e0e0;
    }

    table {
        background-color: #2d2d2d;
        color: #e0e0e0;
    }

    table th {
        background-color: #3d3d3d;
    }

    table tr:nth-child(even) {
        background-color: #353535;
    }
}
