/**
 * 마이페이지 스타일
 */

.mp-container {
    margin: 0 auto !important;
}

.mp-title {
    font-size: 15px !important;
    color: #a1a1aa !important;
    font-weight: 400 !important;
    margin-bottom: 16px !important;
}

.mp-login-msg {
    text-align: center !important;
    padding: 60px 16px !important;
    color: #71717a !important;
    font-size: 15px !important;
}

/* Row 스타일 */
.mp-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    padding: 20px 0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
    cursor: pointer !important;
}

.mp-row-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.mp-row-label {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #191f28 !important;
}

.mp-row-value {
    font-size: 15px !important;
    color: #71717a !important;
}

.mp-row-arrow {
    width: 20px !important;
    height: 20px !important;
    color: #d4d4d8 !important;
    flex-shrink: 0 !important;
}

.mp-saju-section {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding: 20px 0 !important;
}

.mp-saju-section > .mp-row-label {
    display: block !important;
    margin-bottom: 12px !important;
}

.mp-saju-label-tag {
    font-size: 11px !important;
    color: #a1a1aa !important;
    display: block !important;
    margin-bottom: 2px !important;
}

.mp-saju-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin-bottom: 12px !important;
}

.mp-saju-card {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 14px 16px !important;
    background: #f9fafb !important;
    border-radius: 10px !important;
}

.mp-saju-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.mp-saju-name {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #191f28 !important;
}

.mp-saju-birth {
    font-size: 13px !important;
    color: #71717a !important;
}

.mp-saju-delete {
    font-size: 13px !important;
    color: #ef4444 !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 4px 8px !important;
}

.mp-add-btn {
    width: 100% !important;
    padding: 14px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #191f28 !important;
    background: #f4f4f5 !important;
    border: none !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
}

.mp-add-btn:hover {
    background: #e4e4e7 !important;
}

.mp-empty {
    text-align: center !important;
    padding: 24px !important;
    color: #a1a1aa !important;
    font-size: 14px !important;
}

/* 모달 */
.mp-modal-backdrop {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0,0,0,0) !important;
    z-index: 99999 !important;
    display: none;
    align-items: flex-end !important;
    justify-content: center !important;
    transition: background 0.3s ease !important;
}

.mp-modal-backdrop.mp-modal-open {
    display: flex !important;
}

.mp-modal-backdrop.mp-modal-visible {
    background: rgba(0,0,0,0.4) !important;
}

.mp-modal-backdrop .mp-modal {
    transform: translateY(100%) !important;
    transition: transform 0.3s ease !important;
}

.mp-modal-backdrop.mp-modal-visible .mp-modal {
    transform: translateY(0) !important;
}

.mp-modal {
    background: #fff !important;
    width: 100% !important;
    max-width: 500px !important;
    border-radius: 16px 16px 0 0 !important;
    padding: 0 !important;
    max-height: 85vh !important;
    overflow-y: auto !important;
}

.mp-modal-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 20px 20px 12px !important;
}

.mp-modal-header h3 {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #191f28 !important;
    margin: 0 !important;
}

.mp-modal-close {
    font-size: 24px !important;
    color: #a1a1aa !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    line-height: 1 !important;
    padding: 0 !important;
}

.mp-modal-body {
    padding: 0 20px 8px !important;
}

.mp-modal-save {
    width: calc(100% - 40px) !important;
    margin: 8px 20px 20px !important;
    padding: 14px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #fff !important;
    background: #191f28 !important;
    border: none !important;
    border-radius: 10px !important;
    cursor: pointer !important;
}

.mp-modal-save:disabled {
    opacity: 0.5 !important;
}

/* 필드 */
.mp-field {
    margin-bottom: 16px !important;
}

.mp-label {
    display: block !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #3f3f46 !important;
    margin-bottom: 6px !important;
}

.mp-input {
    width: 100% !important;
    padding: 12px 14px !important;
    font-size: 16px !important;
    border: 1px solid #e4e4e7 !important;
    border-radius: 10px !important;
    background: #fff !important;
    color: #191f28 !important;
    outline: none !important;
    box-sizing: border-box !important;
}

.mp-input:focus {
    border-color: #a1a1aa !important;
}

.mp-select {
    appearance: none !important;
    -webkit-appearance: none !important;
}

/* 생년월일 row */
.mp-birth-row {
    display: flex !important;
    gap: 8px !important;
}

.mp-birth-item {
    flex: 1 !important;
    position: relative !important;
}

.mp-birth-item .mp-input {
    padding-right: 28px !important;
}

.mp-suffix {
    position: absolute !important;
    right: 10px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 13px !important;
    color: #a1a1aa !important;
    pointer-events: none !important;
}

.mp-calendar-row {
    display: flex !important;
    gap: 12px !important;
    margin-top: 8px !important;
}

.mp-radio, .mp-checkbox {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    font-size: 14px !important;
    color: #3f3f46 !important;
    cursor: pointer !important;
}

.mp-label-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 6px !important;
}

.mp-gender-row {
    display: flex !important;
    gap: 8px !important;
}

.mp-gender {
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px !important;
    border: 1px solid #e4e4e7 !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    font-size: 15px !important;
    transition: all 0.2s !important;
}

.mp-gender input { display: none !important; }
.mp-gender:has(input:checked) {
    border-color: #191f28 !important;
    background: #191f28 !important;
    color: #fff !important;
}
