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

.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;
}

.mp-phone-row {
    display: flex !important;
    gap: 8px !important;
    align-items: center !important;
}

.mp-phone-row .mp-input {
    flex: 1 !important;
}

.mp-verify-btn {
    flex-shrink: 0 !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #fff !important;
    background: #191f28 !important;
    border: none !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}

.mp-verify-btn:disabled {
    opacity: 0.5 !important;
    cursor: default !important;
}

#mp-otp-overlay {
    display: none;
}

/* 쿠폰 섹션 */
.mp-coupon-section {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding: 20px 0 !important;
    border-top: 1px solid #f0f0f0 !important;
}

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

.mp-coupon-register {
    display: flex !important;
    gap: 8px !important;
    align-items: center !important;
}

.mp-coupon-register .mp-input {
    flex: 1 !important;
    font-family: monospace !important;
    letter-spacing: 1px !important;
}

.mp-coupon-register-btn {
    flex-shrink: 0 !important;
    padding: 12px 20px !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;
    white-space: nowrap !important;
    transition: background 0.2s !important;
}

.mp-coupon-register-btn:hover {
    background: #333d4b !important;
}

.mp-coupon-register-btn:disabled {
    opacity: 0.5 !important;
    cursor: default !important;
}

.mp-coupon-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

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

.mp-coupon-card.mp-coupon-disabled {
    opacity: 0.5 !important;
}

.mp-coupon-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    flex: 1 !important;
    min-width: 0 !important;
}

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

.mp-coupon-discount {
    font-size: 13px !important;
    color: #3b82f6 !important;
    font-weight: 500 !important;
}

.mp-coupon-meta {
    font-size: 12px !important;
    color: #a1a1aa !important;
}

.mp-coupon-status {
    flex-shrink: 0 !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    padding: 4px 10px !important;
    border-radius: 9999px !important;
    white-space: nowrap !important;
}

.mp-coupon-status-available {
    background: #dcfce7 !important;
    color: #16a34a !important;
}

.mp-coupon-status-used {
    background: #f4f4f5 !important;
    color: #71717a !important;
}

.mp-coupon-status-expired {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}

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

.mp-withdraw-section {
    padding: 20px 0 !important;
    border-top: 1px solid #f0f0f0 !important;
    margin-top: 8px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.mp-withdraw-btn {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #ef4444 !important;
    background: none !important;
    border: 1px solid #fecaca !important;
    border-radius: 8px !important;
    padding: 8px 16px !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
    white-space: nowrap !important;
}

.mp-withdraw-btn:hover {
    background: #fef2f2 !important;
}

.mp-withdraw-btn:active {
    background: #fee2e2 !important;
}

.mp-withdraw-desc {
    font-size: 15px !important;
    color: #191f28 !important;
    margin: 0 0 4px !important;
    line-height: 1.5 !important;
}

.mp-withdraw-guide {
    font-size: 13px !important;
    color: #71717a !important;
    margin: 0 0 12px !important;
    line-height: 1.5 !important;
}

.mp-withdraw-guide strong {
    color: #ef4444 !important;
    font-weight: 600 !important;
}

.mp-withdraw-actions {
    display: flex !important;
    gap: 8px !important;
    padding: 8px 20px 20px !important;
}

.mp-withdraw-confirm-btn {
    flex: 1 !important;
    padding: 14px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #fff !important;
    background: #ef4444 !important;
    border: none !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
}

.mp-withdraw-confirm-btn:hover {
    background: #dc2626 !important;
}

.mp-withdraw-confirm-btn:disabled {
    background: #fca5a5 !important;
    cursor: default !important;
}

.mp-withdraw-cancel-btn {
    flex: 1 !important;
    padding: 14px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #3f3f46 !important;
    background: #f4f4f5 !important;
    border: none !important;
    border-radius: 10px !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
}

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