/**
 * 공통 기본 스타일 (reset, body, 레이아웃)
 * 휴대폰 자동 반응형 지원
 */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
}

body {
    font-family: 'Noto Sans KR', sans-serif;
    background-color: #f4f6f9;
    color: #333;
    line-height: 1.5;
    overflow-x: hidden;
    /* iOS 노치·홈바 영역 대응 */
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
}

.wrap {
    max-width: 500px;
    width: 100%;
    margin: 0 auto;
    background-color: #fff;
    min-height: 100vh;
    min-height: 100dvh; /* 동적 뷰포트 높이 (모바일 주소창 고려) */
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
}

header {
    padding: 20px 16px;
    padding-top: max(20px, env(safe-area-inset-top));
    text-align: center;
    border-bottom: 1px solid #eee;
    background: #fff;
}

header h1,
header h2 {
    font-size: 1.2rem;
    font-weight: 700;
}

header h1 {
    color: #0068ff;
}

header h2 {
    color: #333;
}

/* 모바일 반응형 (480px 이하) */
@media (max-width: 480px) {
    body {
        font-size: 15px;
    }

    .wrap {
        box-shadow: none;
    }

    header {
        padding: 16px;
        padding-top: max(16px, env(safe-area-inset-top));
    }

    header h1,
    header h2 {
        font-size: 1.15rem;
    }
}
