/* 추가 스타일링 */
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    transition: all 0.3s ease;
}

/* 컨테이너 크기 제한 - 더 넓은 화면에서도 자연스럽게 확장 */
.container {
    min-width: 280px;
    max-width: clamp(400px, 95vw, 1200px); /* 더 넓은 최대 크기로 확장 */
    margin: 0 auto;
    padding: clamp(0.5rem, 2vw, 2rem);
}

.card {
    border-radius: clamp(10px, 2vw, 15px);
    transition: all 0.3s ease;
    min-width: 250px;
    width: 100%; /* 컨테이너 전체 너비 사용 */
}

.card-header {
    border-radius: clamp(10px, 2vw, 15px) clamp(10px, 2vw, 15px) 0 0 !important;
    padding: clamp(0.75rem, 2vw, 1.25rem);
}

.card-body {
    padding: clamp(1rem, 3vw, 2.5rem); /* 더 넓은 패딩 */
}

/* 버튼 스타일 */
.btn {
    border-radius: clamp(5px, 1vw, 8px);
    transition: all 0.3s ease;
    font-size: clamp(0.9rem, 2vw, 1.1rem); /* 글자 크기 약간 증가 */
    padding: clamp(0.5rem, 1.5vw, 0.875rem); /* 패딩 증가 */
    min-height: 48px; /* 터치 친화적 크기 증가 */
}

.btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

/* 폼 요소 */
.form-control {
    transition: all 0.3s ease;
    font-size: clamp(0.9rem, 2vw, 1.1rem); /* 글자 크기 증가 */
    padding: clamp(0.5rem, 1.5vw, 0.875rem); /* 패딩 증가 */
    min-height: 48px; /* 높이 증가 */
}

.form-control:focus {
    border-color: #007bff;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
    transform: scale(1.02);
}

.form-label {
    font-size: clamp(0.95rem, 2vw, 1.1rem); /* 글자 크기 증가 */
    font-weight: 500;
}

.form-text {
    font-size: clamp(0.8rem, 1.5vw, 0.9rem); /* 글자 크기 증가 */
}

/* 결과 영역 */
#result {
    font-size: clamp(1.1rem, 2.5vw, 1.3rem); /* 글자 크기 증가 */
    font-weight: 500;
    min-height: clamp(50px, 8vw, 70px); /* 높이 증가 */
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    transition: all 0.3s ease;
    padding: clamp(0.75rem, 2vw, 1.25rem); /* 패딩 증가 */
}

.alert {
    border-radius: clamp(5px, 1vw, 8px);
    transition: all 0.3s ease;
}

/* 제목 크기 */
#main-title {
    font-size: clamp(1rem, 3vw, 1.4rem) !important; /* 크기 증가 */
}

#calculator-title {
    font-size: clamp(1.2rem, 4vw, 1.75rem) !important; /* 크기 증가 */
}

#calculator-subtitle {
    font-size: clamp(0.8rem, 2vw, 1rem) !important; /* 크기 증가 */
}

.card-title {
    font-size: clamp(1.1rem, 2.5vw, 1.4rem) !important; /* 크기 증가 */
}

/* 언어 선택기 스타일 */
.language-selector {
    position: relative;
}

.language-selector .dropdown-toggle {
    border-radius: 20px;
    padding: clamp(0.375rem, 1vw, 0.625rem) clamp(0.75rem, 1.5vw, 1rem); /* 패딩 증가 */
    font-size: clamp(0.8rem, 1.5vw, 0.95rem); /* 글자 크기 증가 */
    transition: all 0.3s ease;
    min-height: 36px; /* 높이 증가 */
}

.language-selector .dropdown-toggle:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.language-selector .dropdown-menu {
    border-radius: 10px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    border: none;
    min-width: clamp(160px, 30vw, 200px); /* 크기 증가 */
}

.language-selector .dropdown-item {
    padding: clamp(0.5rem, 1vw, 0.75rem) clamp(1rem, 2vw, 1.25rem); /* 패딩 증가 */
    transition: all 0.2s ease;
    font-size: clamp(0.8rem, 1.5vw, 0.95rem); /* 글자 크기 증가 */
}

.language-selector .dropdown-item:hover {
    background-color: #f8f9fa;
    color: #007bff;
    transform: translateX(5px);
}

.language-selector .dropdown-item:active {
    background-color: #007bff;
    color: white;
}

/* 리스트 스타일 */
.card-body ol, .card-body ul {
    padding-left: clamp(1.25rem, 3vw, 1.75rem); /* 패딩 증가 */
    font-size: clamp(0.9rem, 2vw, 1.1rem); /* 글자 크기 증가 */
}

/* 접근성 개선 */
.visually-hidden-focusable {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

.visually-hidden-focusable:focus {
    position: static !important;
    width: auto !important;
    height: auto !important;
    padding: 0.5rem !important;
    margin: 0 !important;
    overflow: visible !important;
    clip: auto !important;
    white-space: normal !important;
    background-color: #007bff !important;
    color: white !important;
    text-decoration: none !important;
}

/* 성능 최적화 */
* {
    box-sizing: border-box;
}

img {
    max-width: 100%;
    height: auto;
}

/* 검색 엔진 최적화를 위한 콘텐츠 강조 */
h1, h2, h3 {
    font-weight: 600;
}

/* 더 자연스러운 반응형 디자인 */

/* 태블릿과 데스크톱 */
@media (min-width: 768px) {
    .container {
        margin-top: clamp(2rem, 5vh, 4rem);
        max-width: clamp(600px, 85vw, 1100px); /* 더 넓은 화면에서 더 많이 활용 */
    }
    
    .card-body {
        padding: clamp(1.5rem, 4vw, 3rem); /* 더 넓은 패딩 */
    }
    
    /* 버튼 크기 증가 */
    .btn {
        font-size: clamp(1rem, 2vw, 1.2rem);
        padding: clamp(0.625rem, 2vw, 1rem);
        min-height: 52px;
    }
    
    /* 입력 필드 크기 증가 */
    .form-control {
        font-size: clamp(1rem, 2vw, 1.2rem);
        padding: clamp(0.625rem, 2vw, 1rem);
        min-height: 52px;
    }
    
    header .row {
        align-items: center;
        gap: 1rem;
    }
}

/* 큰 데스크톱 화면 */
@media (min-width: 1200px) {
    .container {
        max-width: clamp(800px, 80vw, 1400px); /* 큰 화면에서 훨씬 더 많이 활용 */
    }
    
    .card-body {
        padding: clamp(2rem, 5vw, 4rem); /* 동적 패딩으로 변경 */
    }
    
    /* 더 큰 폰트와 요소들 */
    .btn {
        font-size: clamp(1.1rem, 2.2vw, 1.4rem); /* 더 큰 글자 */
        padding: clamp(0.75rem, 2vw, 1.5rem); /* 더 큰 패딩 */
        min-height: clamp(54px, 8vw, 70px); /* 동적 높이 */
    }
    
    .form-control {
        font-size: clamp(1.1rem, 2.2vw, 1.4rem); /* 더 큰 글자 */
        padding: clamp(0.75rem, 2vw, 1.25rem); /* 더 큰 패딩 */
        min-height: clamp(54px, 8vw, 70px); /* 동적 높이 */
    }
    
    #result {
        font-size: clamp(1.4rem, 3vw, 1.8rem); /* 더 큰 결과 텍스트 */
        min-height: clamp(80px, 10vw, 100px); /* 더 큰 결과 영역 */
        padding: clamp(1.5rem, 3vw, 2rem); /* 더 큰 패딩 */
    }
    
    /* 제목들도 큰 화면에서 더 크게 */
    #calculator-title {
        font-size: clamp(1.5rem, 4vw, 2.2rem) !important;
    }
    
    #calculator-subtitle {
        font-size: clamp(1rem, 2.5vw, 1.3rem) !important;
    }
    
    .form-label {
        font-size: clamp(1.1rem, 2.2vw, 1.3rem);
    }
}

/* 초대형 화면 (1400px 이상) */
@media (min-width: 1400px) {
    .container {
        max-width: clamp(900px, 75vw, 1600px); /* 초대형 화면에서 최대 활용 */
    }
    
    .card-body {
        padding: clamp(3rem, 6vw, 5rem); /* 매우 큰 패딩 */
    }
    
    .btn {
        font-size: clamp(1.3rem, 2.5vw, 1.6rem); /* 매우 큰 글자 */
        padding: clamp(1rem, 2.5vw, 1.75rem); /* 매우 큰 패딩 */
        min-height: clamp(60px, 10vw, 80px); /* 매우 큰 높이 */
    }
    
    .form-control {
        font-size: clamp(1.3rem, 2.5vw, 1.6rem);
        padding: clamp(1rem, 2.5vw, 1.5rem);
        min-height: clamp(60px, 10vw, 80px);
    }
    
    #result {
        font-size: clamp(1.6rem, 3.5vw, 2.2rem);
        min-height: clamp(90px, 12vw, 120px);
        padding: clamp(2rem, 4vw, 2.5rem);
    }
    
    #calculator-title {
        font-size: clamp(1.8rem, 5vw, 2.5rem) !important;
    }
    
    #calculator-subtitle {
        font-size: clamp(1.2rem, 3vw, 1.5rem) !important;
    }
}

/* 모바일 */
@media (max-width: 767px) {
    .container {
        padding: clamp(0.5rem, 3vw, 1rem);
        margin-top: 1rem;
    }
    
    header .row {
        flex-direction: column;
        gap: 0.5rem;
    }
    
    header .col {
        order: 2;
    }
    
    header .col-auto {
        order: 1;
        align-self: flex-end;
    }
    
    .mb-3 {
        margin-bottom: 1rem !important;
    }
}

/* 매우 작은 화면 */
@media (max-width: 320px) {
    .container {
        padding: 0.5rem;
        min-width: 300px;
    }
    
    .card-body {
        padding: 0.75rem;
    }
}

/* 가로 모드 최적화 */
@media (max-height: 600px) and (orientation: landscape) {
    .container {
        margin-top: 0.5rem;
    }
    
    .mb-3 {
        margin-bottom: 0.75rem !important;
    }
    
    #result {
        min-height: 40px;
    }
}

/* 고해상도 디스플레이 */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .btn, .form-control, .card {
        border-width: 0.5px;
    }
}

/* 인쇄 스타일 */
@media print {
    .btn, footer, .language-selector {
        display: none !important;
    }
    
    .card {
        box-shadow: none !important;
    }
    
    body {
        font-size: 12pt;
    }
    
    .container {
        max-width: 100% !important;
    }
}
