/* =========================================================
   멀티맨 상담신청 화면 전용 보정 CSS
   파일: /assets/css/request_public_match.css

   목적:
   - 공통 site_header / site_footer는 건드리지 않음
   - request.php 본문 신청폼만 정리
   - PC 프레임 통일
   - 모바일 희망일/희망시간 밀림 방지
   - 작업선택 / 추가작업 / 상품 / 선택목록 / 신청확인 영역 정리
========================================================= */

:root {
    --req-blue: #1f5eff;
    --req-blue-dark: #123a91;
    --req-navy: #0f2b59;
    --req-yellow: #ffd43b;
    --req-yellow-dark: #eab308;
    --req-bg: #f4f7fb;
    --req-card: #ffffff;
    --req-line: #e5eaf2;
    --req-line-strong: #cbd5e1;
    --req-text: #111827;
    --req-sub: #64748b;
    --req-muted: #94a3b8;
    --req-red: #dc2626;
    --req-green: #16a34a;
    --req-radius-lg: 24px;
    --req-radius-md: 16px;
    --req-shadow: 0 16px 42px rgba(15, 23, 42, .07);
    --req-soft-shadow: 0 10px 26px rgba(15, 23, 42, .05);
    --req-frame: 980px;
}

/* =========================================================
   기본 안전값
========================================================= */

html,
body {
    max-width: 100%;
    overflow-x: hidden;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    background: var(--req-bg);
}

/*
   헤더/푸터는 공통 site_header/site_footer가 담당.
   이 파일에서는 header/footer/.mm-header/.mm-logo/.site-header 등을 절대 건드리지 않음.
*/

.request-main,
.mm-main {
    background: var(--req-bg);
    padding: 26px 0 42px;
}

.request-main > .mm-container,
.mm-main > .mm-container {
    width: 100%;
    max-width: var(--req-frame);
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
}

/* 공통 헤더 아래 첫 카드 간격 */
.request-main .mm-container > form,
.mm-main .mm-container > form,
#unifiedForm {
    width: 100%;
    max-width: var(--req-frame);
    margin-left: auto;
    margin-right: auto;
}

/* =========================================================
   카드 / 섹션
========================================================= */

#unifiedForm .mm-card,
#customer-area,
#service-area {
    width: 100%;
    max-width: var(--req-frame);
    margin: 0 auto 18px;
    border: 1px solid var(--req-line);
    border-radius: var(--req-radius-lg);
    background: var(--req-card);
    box-shadow: var(--req-shadow);
    overflow: hidden;
}

#unifiedForm .mm-card-head,
.mm-card-head {
    padding: 22px 24px 16px;
    border-bottom: 1px solid #edf2f7;
    background:
        radial-gradient(circle at top right, rgba(31, 94, 255, .06), transparent 34%),
        #ffffff;
}

#unifiedForm .mm-card-head h2,
.mm-card-head h2 {
    margin: 0;
    color: var(--req-text);
    font-size: 22px;
    line-height: 1.25;
    font-weight: 950;
    letter-spacing: -.045em;
}

#unifiedForm .mm-card-head p,
.mm-card-head p {
    margin: 8px 0 0;
    color: var(--req-sub);
    font-size: 13px;
    line-height: 1.6;
    font-weight: 760;
}

#unifiedForm .mm-card-body,
.mm-card-body {
    padding: 22px 24px 24px;
}

/* =========================================================
   고객정보 폼
========================================================= */

.mm-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    width: 100%;
}

.mm-field,
.mm-field.full {
    min-width: 0;
    max-width: 100%;
}

.mm-field.full {
    grid-column: 1 / -1;
}

.mm-field label,
.mm-cart-field label {
    display: block;
    margin-bottom: 7px;
    color: #334155;
    font-size: 13px;
    line-height: 1.35;
    font-weight: 950;
    letter-spacing: -.025em;
}

.mm-input,
.mm-select,
.mm-textarea,
.mm-field input,
.mm-field select,
.mm-field textarea,
.mm-cart-field input,
.mm-cart-field select {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    border: 1px solid var(--req-line-strong);
    border-radius: 14px;
    background: #fff;
    color: var(--req-text);
    font-size: 15px;
    font-weight: 780;
    outline: none;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.mm-input,
.mm-select,
.mm-field input,
.mm-field select,
.mm-cart-field input,
.mm-cart-field select {
    min-height: 48px;
    padding: 0 13px;
}

.mm-field textarea,
.mm-textarea {
    min-height: 110px;
    padding: 13px;
    resize: vertical;
    line-height: 1.6;
}

.mm-input:focus,
.mm-select:focus,
.mm-textarea:focus,
.mm-field input:focus,
.mm-field select:focus,
.mm-field textarea:focus,
.mm-cart-field input:focus,
.mm-cart-field select:focus {
    border-color: var(--req-blue);
    box-shadow: 0 0 0 4px rgba(31, 94, 255, .10);
}

/* 연락처/주소 버튼 줄 */
.mm-inline {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    align-items: center;
}

.mm-mini-btn {
    min-height: 48px;
    border: 1px solid #dbe3ee;
    border-radius: 14px;
    background: #fff;
    color: #334155;
    padding: 0 13px;
    font-size: 13px;
    font-weight: 950;
    cursor: pointer;
    white-space: nowrap;
}

.mm-mini-btn.yellow {
    border-color: var(--req-yellow-dark);
    background: var(--req-yellow);
    color: #111827;
}

.mm-phone-msg,
#scheduleMsg,
#phoneMsg {
    margin-top: 8px;
    color: var(--req-sub);
    font-size: 12px;
    line-height: 1.45;
    font-weight: 780;
}

/* 날짜/시간 밀림 방지 */
#preferredDate,
#preferredTime,
input[type="date"],
select {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    -webkit-appearance: none;
    appearance: none;
}

/* =========================================================
   작업 선택 영역
========================================================= */

.mm-work-lock-message {
    margin-bottom: 16px;
    padding: 14px 15px;
    border: 1px solid #bfdbfe;
    border-radius: 18px;
    background: #eff6ff;
    color: #1e40af;
}

.mm-work-lock-message strong {
    display: block;
    font-size: 14px;
    font-weight: 950;
    margin-bottom: 4px;
}

.mm-work-lock-message span {
    display: block;
    font-size: 12px;
    line-height: 1.55;
    font-weight: 760;
}

#mmRequestCart,
.mm-cart-wrap {
    width: 100%;
    max-width: 100%;
}

.mm-cart-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    width: 100%;
    align-items: stretch;
}

.mm-cart-panel {
    position: relative;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 18px;
    border: 1px solid var(--req-line);
    border-radius: 20px;
    background: #fff;
    box-shadow: var(--req-soft-shadow);
    overflow: hidden;
}

.mm-cart-panel::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--req-blue), #60a5fa);
}

#baseWorkPanel::before {
    background: linear-gradient(90deg, var(--req-blue), #60a5fa);
}

#extraWorkPanel::before {
    background: linear-gradient(90deg, #64748b, #cbd5e1);
}

#productPanel::before {
    background: linear-gradient(90deg, var(--req-yellow-dark), var(--req-yellow));
}

#baseWorkPanel {
    background:
        radial-gradient(circle at top right, rgba(31, 94, 255, .10), transparent 32%),
        #ffffff;
}

#extraWorkPanel {
    background:
        radial-gradient(circle at top right, rgba(100, 116, 139, .10), transparent 32%),
        #ffffff;
}

#productPanel {
    background:
        radial-gradient(circle at top right, rgba(255, 212, 59, .22), transparent 32%),
        #ffffff;
}

.mm-cart-panel.is-hidden {
    display: none !important;
}

.mm-cart-panel h4 {
    margin: 0 0 8px;
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--req-text);
    font-size: 18px;
    line-height: 1.3;
    font-weight: 950;
    letter-spacing: -.035em;
}

#baseWorkPanel h4::before,
#extraWorkPanel h4::before,
#productPanel h4::before {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: #fff;
    font-size: 13px;
    font-weight: 950;
    flex: 0 0 auto;
}

#baseWorkPanel h4::before {
    content: "1";
    background: var(--req-blue);
}

#extraWorkPanel h4::before {
    content: "2";
    background: #475569;
}

#productPanel h4::before {
    content: "3";
    background: var(--req-yellow);
    color: #111827;
}

.mm-cart-panel-desc {
    margin: 0 0 14px;
    color: var(--req-sub);
    font-size: 12px;
    line-height: 1.55;
    font-weight: 760;
}

/* 예전 설명 박스는 고객화면에서 숨김 */
.mm-extra-guide {
    display: none !important;
}

.mm-extra-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
}

.mm-extra-head h4 {
    margin-bottom: 6px;
}

.mm-extra-badge {
    display: inline-flex;
    min-height: 28px;
    align-items: center;
    border-radius: 999px;
    background: #f1f5f9;
    color: #475569;
    padding: 0 9px;
    font-size: 11px;
    font-weight: 950;
    white-space: nowrap;
}

.mm-cart-field {
    margin-bottom: 11px;
    min-width: 0;
}

.mm-cart-field:last-child {
    margin-bottom: 0;
}

.mm-cart-btn {
    width: 100%;
    min-height: 48px;
    border: 1px solid var(--req-blue);
    border-radius: 15px;
    background: var(--req-blue);
    color: #fff;
    font-size: 14px;
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 10px 22px rgba(31, 94, 255, .18);
}

.mm-cart-btn.gray {
    border-color: #64748b;
    background: #64748b;
    color: #fff;
    box-shadow: 0 10px 22px rgba(100, 116, 139, .16);
}

.mm-cart-btn.yellow {
    border-color: var(--req-yellow-dark);
    background: var(--req-yellow);
    color: #111827;
    box-shadow: 0 10px 22px rgba(234, 179, 8, .18);
}

.mm-cart-btn:disabled,
#extraWorkPanel .mm-cart-btn:disabled {
    opacity: .48;
    cursor: not-allowed;
    box-shadow: none;
}

.mm-cart-note,
#extraPanelNote,
#productPanelNote {
    margin-top: 9px;
    color: var(--req-sub);
    font-size: 12px;
    line-height: 1.5;
    font-weight: 760;
}

/* =========================================================
   선택한 작업/상품 리스트
========================================================= */

.mm-cart-list {
    margin-top: 16px;
    border: 1px solid var(--req-line);
    border-radius: 20px;
    background: #fff;
    box-shadow: var(--req-soft-shadow);
    overflow: hidden;
}

.mm-cart-list-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    padding: 15px 16px;
    border-bottom: 1px solid #edf2f7;
    background: #f8fafc;
}

.mm-cart-list-head strong {
    color: var(--req-text);
    font-size: 15px;
    font-weight: 950;
}

.mm-cart-total {
    color: #334155;
    font-size: 13px;
    font-weight: 900;
    white-space: nowrap;
}

.mm-cart-total span,
#mmCartTotal {
    color: var(--req-blue-dark);
    font-size: 20px;
    font-weight: 950;
    letter-spacing: -.035em;
}

.mm-cart-items {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mm-cart-empty {
    padding: 22px 16px;
    text-align: center;
    color: var(--req-muted);
    font-size: 13px;
    font-weight: 800;
}

.mm-cart-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    gap: 12px;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid #edf2f7;
}

.mm-cart-item:last-child {
    border-bottom: 0;
}

.mm-cart-item-title {
    color: var(--req-text);
    font-size: 14px;
    font-weight: 950;
    line-height: 1.4;
}

.mm-cart-item-meta {
    margin-top: 4px;
    color: var(--req-sub);
    font-size: 12px;
    line-height: 1.45;
    font-weight: 760;
}

.mm-cart-qty {
    width: 70px;
    max-width: 70px;
    height: 38px;
    border: 1px solid var(--req-line-strong);
    border-radius: 12px;
    text-align: center;
    font-weight: 900;
}

.mm-cart-line {
    min-width: 92px;
    text-align: right;
    color: var(--req-text);
    font-size: 14px;
    font-weight: 950;
    white-space: nowrap;
}

.mm-cart-remove {
    width: 34px;
    height: 34px;
    border: 1px solid #fecaca;
    border-radius: 50%;
    background: #fef2f2;
    color: #991b1b;
    font-size: 17px;
    font-weight: 950;
    cursor: pointer;
}

/* 예상금액 안내문 */
.mm-cart-guide,
.mm-cart-list + .mm-cart-guide {
    margin-top: 12px;
    padding: 13px 14px;
    border: 1px solid #bfdbfe;
    border-radius: 16px;
    background: #eff6ff;
    color: #1e40af;
    font-size: 12px;
    line-height: 1.55;
    font-weight: 760;
}

/* =========================================================
   신청내용 확인 버튼 영역
========================================================= */

.mm-final-submit,
#mmFinalSubmitArea {
    width: 100%;
    max-width: var(--req-frame);
    margin: 18px auto 0;
    padding: 18px;
    border: 1px solid var(--req-line);
    border-radius: 20px;
    background: #ffffff;
    box-shadow: var(--req-soft-shadow);
    text-align: center;
}

.mm-final-submit-btn,
#mmSubmitRequestBtn,
#openConfirmBtn,
.mm-submit-btn {
    width: 100%;
    min-height: 52px;
    border: 1px solid var(--req-yellow-dark);
    border-radius: 16px;
    background: var(--req-yellow);
    color: #111827;
    font-size: 16px;
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(234, 179, 8, .18);
}

.mm-final-submit p {
    margin: 10px 0 0;
    color: var(--req-sub);
    font-size: 13px;
    line-height: 1.6;
    font-weight: 750;
}

/* 확인 미리보기/동의 영역이 있으면 카드 폭 맞춤 */
#confirmPreview,
.mm-confirm-preview,
.mm-agree-box,
.mm-privacy-box {
    max-width: 100%;
    white-space: pre-wrap;
    word-break: keep-all;
    overflow-wrap: anywhere;
}

/* =========================================================
   PC 세부 정리
========================================================= */

@media (min-width: 901px) {
    .request-main > .mm-container,
    .mm-main > .mm-container,
    #unifiedForm,
    #unifiedForm .mm-card,
    #customer-area,
    #service-area,
    #mmRequestCart,
    .mm-cart-wrap,
    .mm-cart-list,
    .mm-final-submit,
    #mmFinalSubmitArea {
        max-width: var(--req-frame) !important;
        width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
        box-sizing: border-box !important;
    }

    .mm-cart-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

/* =========================================================
   태블릿 / 모바일
========================================================= */

@media (max-width: 900px) {
    .request-main,
    .mm-main {
        padding-top: 18px;
    }

    .request-main > .mm-container,
    .mm-main > .mm-container {
        max-width: 100%;
        padding-left: 14px;
        padding-right: 14px;
    }

    #unifiedForm .mm-card-head,
    .mm-card-head {
        padding: 18px 18px 14px;
    }

    #unifiedForm .mm-card-body,
    .mm-card-body {
        padding: 18px;
    }

    .mm-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .mm-field,
    .mm-field.full {
        grid-column: auto;
    }

    .mm-cart-tabs {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .mm-cart-panel {
        padding: 16px;
    }

    .mm-extra-head {
        display: grid;
        grid-template-columns: 1fr;
    }

    .mm-extra-badge {
        justify-self: start;
    }
}

@media (max-width: 760px) {
    .request-main,
    .mm-main,
    .mm-container,
    #unifiedForm,
    .mm-card,
    .mm-card-body,
    .mm-grid,
    .mm-field,
    #mmRequestCart,
    .mm-cart-wrap,
    .mm-cart-panel,
    .mm-cart-list {
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }

    .mm-container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .mm-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        width: 100% !important;
    }

    .mm-field,
    .mm-field.full {
        width: 100% !important;
        max-width: 100% !important;
    }

    .mm-inline {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .mm-mini-btn {
        width: 100% !important;
    }

    #preferredDate,
    #preferredTime,
    #customerName,
    #phoneInput,
    #region,
    #address,
    #addressDetail,
    #mmCartServiceType,
    #mmCartServiceOption,
    #mmCartServiceQty,
    #mmCartExtraOption,
    #mmCartExtraQty,
    #mmCartProduct,
    #mmCartProductQty {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
    }

    input[type="date"],
    input[type="text"],
    input[type="tel"],
    input[type="number"],
    select,
    textarea {
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
    }

    .mm-cart-list-head {
        display: grid;
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .mm-cart-total {
        white-space: normal;
    }

    .mm-cart-item {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .mm-cart-qty {
        width: 100%;
        max-width: 100%;
    }

    .mm-cart-line {
        min-width: 0;
        text-align: left;
    }

    .mm-cart-remove {
        width: 100%;
        border-radius: 12px;
    }

    .mm-final-submit,
    #mmFinalSubmitArea {
        padding: 15px;
    }

    .mm-final-submit-btn,
    #mmSubmitRequestBtn,
    #openConfirmBtn,
    .mm-submit-btn {
        min-height: 50px;
        font-size: 15px;
    }
}

@media (max-width: 420px) {
    .request-main > .mm-container,
    .mm-main > .mm-container,
    .mm-container {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    #unifiedForm .mm-card-head,
    .mm-card-head {
        padding: 16px 15px 12px;
    }

    #unifiedForm .mm-card-body,
    .mm-card-body {
        padding: 15px;
    }

    .mm-cart-panel {
        padding: 14px;
    }

    #unifiedForm .mm-card-head h2,
    .mm-card-head h2 {
        font-size: 19px;
    }

    .mm-cart-panel h4 {
        font-size: 16px;
    }

    .mm-input,
    .mm-select,
    .mm-field input,
    .mm-field select,
    .mm-cart-field input,
    .mm-cart-field select {
        font-size: 14px;
    }
}
/* =========================================================
   작업선택 패널 폭 보정
   기본작업 / 추가작업 / 상품패키지 패널을 상황별 동일 폭으로 정렬
========================================================= */

@media (min-width: 901px) {
    /*
       기본값: 3개 패널이 모두 보일 때 동일 3등분
    */
    #mmRequestCart .mm-cart-tabs {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 14px !important;
        align-items: stretch !important;
    }

    /*
       기본작업 + 추가작업만 보이고 상품패널이 숨겨진 경우
       → 2등분으로 넓게 표시
    */
    #mmRequestCart .mm-cart-tabs:has(#extraWorkPanel:not(.is-hidden)):has(#productPanel.is-hidden) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    /*
       기본작업만 보이는 초기 상태
       → 기본작업 패널을 전체 폭으로 표시
    */
    #mmRequestCart .mm-cart-tabs:has(#extraWorkPanel.is-hidden):has(#productPanel.is-hidden) {
        grid-template-columns: 1fr !important;
    }

    /*
       기본작업 + 상품패키지만 보이고 추가작업이 숨겨진 경우
       → 2등분
    */
    #mmRequestCart .mm-cart-tabs:has(#extraWorkPanel.is-hidden):has(#productPanel:not(.is-hidden)) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #baseWorkPanel,
    #extraWorkPanel,
    #productPanel {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    #extraWorkPanel .mm-cart-field,
    #extraWorkPanel select,
    #extraWorkPanel input,
    #extraWorkPanel button {
        width: 100% !important;
        max-width: 100% !important;
    }
}
/* =========================================================
   작업선택 패널 최종 정리
   기본작업 / 추가작업 / 상품패키지를 모두 1칸 세로 나열
========================================================= */

#mmRequestCart .mm-cart-tabs {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    width: 100% !important;
    align-items: stretch !important;
}

#baseWorkPanel,
#extraWorkPanel,
#productPanel {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

#baseWorkPanel .mm-cart-field,
#extraWorkPanel .mm-cart-field,
#productPanel .mm-cart-field {
    width: 100% !important;
    max-width: 100% !important;
}

#baseWorkPanel select,
#baseWorkPanel input,
#baseWorkPanel button,
#extraWorkPanel select,
#extraWorkPanel input,
#extraWorkPanel button,
#productPanel select,
#productPanel input,
#productPanel button {
    width: 100% !important;
    max-width: 100% !important;
}

/* 숨김 상태는 기존 기능 유지 */
#extraWorkPanel.is-hidden,
#productPanel.is-hidden {
    display: none !important;
}

/* PC에서도 1칸 유지 */
@media (min-width: 901px) {
    #mmRequestCart .mm-cart-tabs {
        grid-template-columns: 1fr !important;
    }

    #baseWorkPanel,
    #extraWorkPanel,
    #productPanel {
        grid-column: 1 / -1 !important;
    }
}

/* 모바일도 1칸 유지 */
@media (max-width: 900px) {
    #mmRequestCart .mm-cart-tabs {
        grid-template-columns: 1fr !important;
    }
}
/* =========================================================
   정보동의 / 신청내용 확인 / 상담문의 등록
========================================================= */

.mm-final-flow,
#mmConsentFinalArea {
    width: 100%;
    max-width: var(--req-frame, 980px);
    margin: 18px auto 0;
    padding: 18px;
    border: 1px solid #e5eaf2;
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .05);
}

.mm-consent-box {
    margin-bottom: 14px;
    padding: 14px;
    border: 1px solid #dbe3ee;
    border-radius: 16px;
    background: #f8fafc;
}

.mm-consent-check {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    color: #334155;
    font-size: 13px;
    line-height: 1.6;
    font-weight: 850;
    cursor: pointer;
}

.mm-consent-check input {
    margin-top: 4px;
    flex: 0 0 auto;
}

.mm-final-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.mm-submit-btn,
#mmOpenConfirmFinalBtn,
#mmFinalRealSubmitBtn {
    width: 100%;
    min-height: 52px;
    border: 1px solid #eab308;
    border-radius: 16px;
    background: #ffd43b;
    color: #111827;
    font-size: 16px;
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 12px 24px rgba(234, 179, 8, .18);
}

.mm-submit-final,
#mmFinalRealSubmitBtn {
    background: #1f5eff;
    border-color: #1f5eff;
    color: #ffffff;
    box-shadow: 0 12px 24px rgba(31, 94, 255, .18);
}

.mm-confirm-preview,
#mmFinalConfirmPreview {
    margin: 14px 0;
    padding: 14px;
    border: 1px solid #bfdbfe;
    border-radius: 16px;
    background: #eff6ff;
    color: #1e3a8a;
    white-space: pre-wrap;
    word-break: keep-all;
    overflow-wrap: anywhere;
    font-size: 13px;
    line-height: 1.65;
    font-weight: 800;
    text-align: left;
}

.mm-final-help {
    margin: 12px 0 0;
    color: #64748b;
    font-size: 13px;
    line-height: 1.6;
    font-weight: 750;
    text-align: center;
}

.is-hidden {
    display: none !important;
}

@media (max-width: 760px) {
    .mm-final-flow,
    #mmConsentFinalArea {
        padding: 15px;
    }

    .mm-submit-btn,
    #mmOpenConfirmFinalBtn,
    #mmFinalRealSubmitBtn {
        min-height: 50px;
        font-size: 15px;
    }
}
/* =========================================================
   하단 접수 영역 강제 표시 보정
========================================================= */

#mmConsentFinalArea {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    max-width: var(--req-frame, 980px) !important;
    margin: 18px auto 0 !important;
    padding: 18px !important;
    border: 1px solid #e5eaf2 !important;
    border-radius: 20px !important;
    background: #ffffff !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .05) !important;
}

#mmConsentFinalArea .mm-consent-box {
    margin-bottom: 14px !important;
    padding: 14px !important;
    border: 1px solid #dbe3ee !important;
    border-radius: 16px !important;
    background: #f8fafc !important;
}

#mmConsentFinalArea .mm-consent-check {
    display: flex !important;
    gap: 10px !important;
    align-items: flex-start !important;
    color: #334155 !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    font-weight: 850 !important;
    cursor: pointer !important;
}

#mmConsentFinalArea .mm-consent-check input {
    margin-top: 4px !important;
    width: auto !important;
    flex: 0 0 auto !important;
}

#mmConsentFinalArea .mm-final-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
}

#openConfirmBtn,
#realSubmitBtn {
    width: 100% !important;
    min-height: 52px !important;
    border-radius: 16px !important;
    font-size: 16px !important;
    font-weight: 950 !important;
    cursor: pointer !important;
}

#openConfirmBtn {
    border: 1px solid #eab308 !important;
    background: #ffd43b !important;
    color: #111827 !important;
    box-shadow: 0 12px 24px rgba(234, 179, 8, .18) !important;
}

#realSubmitBtn {
    border: 1px solid #1f5eff !important;
    background: #1f5eff !important;
    color: #ffffff !important;
    box-shadow: 0 12px 24px rgba(31, 94, 255, .18) !important;
}

#realSubmitBtn.is-hidden,
#mmFinalConfirmPreview.is-hidden {
    display: none !important;
}

#mmFinalConfirmPreview {
    display: block !important;
    margin: 14px 0 !important;
    padding: 14px !important;
    border: 1px solid #bfdbfe !important;
    border-radius: 16px !important;
    background: #eff6ff !important;
    color: #1e3a8a !important;
    white-space: pre-wrap !important;
    word-break: keep-all !important;
    overflow-wrap: anywhere !important;
    font-size: 13px !important;
    line-height: 1.65 !important;
    font-weight: 800 !important;
    text-align: left !important;
}

#mmConsentFinalArea .mm-final-help {
    margin: 12px 0 0 !important;
    color: #64748b !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    font-weight: 750 !important;
    text-align: center !important;
}

@media (max-width: 760px) {
    #mmConsentFinalArea {
        padding: 15px !important;
    }

    #openConfirmBtn,
    #realSubmitBtn {
        min-height: 50px !important;
        font-size: 15px !important;
    }
}
