.quotePage .quoteIntroBar {
    background: var(--card);
}

.quoteWrap {
    padding-top: 28px;
    padding-bottom: 36px;
}

.quoteLayout {
    display: grid;
    grid-template-columns: minmax(300px, 400px) minmax(0, 1fr) minmax(300px, 400px);
    gap: 24px;
    align-items: start;
}

.quoteRequesterCard,
.quoteMainCard,
.quoteSummaryCard {
    padding: 24px;
}

.quoteMainCard,
.quoteSummaryCard {
    min-width: 0;
}

.quoteSectionHead {
    display: grid;
    gap: 6px;
    margin-bottom: 18px;
}

.quoteSectionHead h2 {
    margin: 0;
    font-size: 20px;
    line-height: 1.2;
}

.quoteSectionHead p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.55;
}

.quoteRow1,
.quoteRow2 {
    margin-bottom: 12px;
}

.quoteRow2 {
    grid-template-columns: 1fr 1fr;
}



/* =========================================================
   좌측 섹션
========================================================= */

.quoteFileBlock {
    display: grid;
    gap: 8px;
}

.quoteFileBlock .fileName {
    display: block;
    color: var(--muted);
    font-size: 12px;
}

.quoteFileBlock .uploadRow {
    flex-wrap: wrap;
}

.quoteFileBlock .uploadRow button {
    width: auto;
    min-width: 0;
    flex: 0 0 auto;
}

.fileGuideBox {
    padding: 12px 14px;
    border: 1px dashed var(--line);
    border-radius: var(--radius-md);
    background: #fafbfc;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.55;
}

.quoteRushBox {
    margin-top: 10px;
    background: #fff8e8;
    border-color: #f2d27a;
}



/* =========================================================
   중앙 섹션
========================================================= */

.quoteAccordion {
    display: grid;
    gap: 14px;
}

.quoteAccItem {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: #fff;
    overflow: hidden;
    transition: border-color 0.16s ease, box-shadow 0.16s ease;
}

.quoteAccItem.isActive {
    border-color: #f2d27a;
    box-shadow: 0 8px 24px rgba(16, 24, 40, 0.06);
}

.quoteAccToggle {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 18px 18px;
    cursor: pointer;
}

.quoteAccToggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.quoteAccCheckWrap {
    position: relative;
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
}

.quoteAccCheck {
    position: absolute;
    inset: 0;
    border: 1px solid #cfd6e3;
    border-radius: 7px;
    background: #fff;
}

.quoteAccCheck::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 2px;
    width: 6px;
    height: 11px;
    border-right: 2px solid transparent;
    border-bottom: 2px solid transparent;
    transform: rotate(45deg);
}

.quoteAccToggle input:checked+.quoteAccCheck,
.quoteAccItem.isActive .quoteAccCheck {
    background: var(--acc);
    border-color: #efc24f;
}

.quoteAccToggle input:checked+.quoteAccCheck::after,
.quoteAccItem.isActive .quoteAccCheck::after {
    border-color: #6a4600;
}

.quoteAccTitle {
    flex: 1;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.25;
}

.quoteAccArrow {
    color: var(--muted);
    font-size: 14px;
    transition: transform 0.18s ease;
}

.quoteAccItem.isActive .quoteAccArrow {
    transform: rotate(180deg);
}

.quoteAccBody {
    display: none;
    padding: 0 18px 18px;
}

.quoteAccItem.isActive .quoteAccBody {
    display: grid;
    gap: 0;
}

.quoteGuideBox {
    margin-top: 4px;
}

.optionGuideBox {
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fbfcff;
}

.optionGuideTitle {
    margin-bottom: 10px;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.45;
}

.optionGuideDesc {
    color: var(--muted);
    font-size: 13px;
    line-height: 1.8;
}

.guideSplit {
    height: 1px;
    margin: 12px 0;
    background: var(--line);
}

.quoteHelpWrap {
    overflow: visible;
}

.quoteHelpTooltip {
    width: min(340px, calc(100vw - 40px));
}

.quoteAddAction {
    margin-top: 12px;
}

.quoteAddAction button {
    width: auto;
    min-width: 0;
    padding-left: 18px;
    padding-right: 18px;
}

.quoteGuideGrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 14px;
}

.quoteGuideCard {
    min-height: 132px;
    padding: 16px 18px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fbfcff;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.7;
}

.quoteGuideCard strong {
    display: block;
    margin-bottom: 10px;
    color: var(--txt);
    font-size: 14px;
    font-weight: 800;
}



/* =========================================================
   우측 섹션
========================================================= */

.quoteSummarySticky {
    position: sticky;
    top: 16px;
    display: grid;
    gap: 16px;
}

.quoteSummaryHead {
    margin-bottom: 0;
}

.quoteSummaryPanel {
    display: grid;
    gap: 14px;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: #fafbff;
}

.quoteSummaryGroup {
    display: grid;
    gap: 10px;
}

.quoteSummaryGroup h3 {
    margin: 0;
    font-size: 15px;
    line-height: 1.3;
}

.quoteSelectedList {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.quoteSelectedList li {
    position: relative;
    padding-left: 14px;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.55;
}

.quoteSelectedList li::before {
    content: "•";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--muted);
}

.quoteSelectedList li.quoteItemRow {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: start;
    padding: 12px 12px 12px 14px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fff;
}

.quoteSelectedList li.quoteItemRow::before {
    top: 12px;
    left: 12px;
}

.quoteItemText {
    display: block;
    padding-left: 14px;
}

.quoteItemDeleteBtn {
    width: auto !important;
    min-height: 36px;
    padding: 8px 12px;
    font-size: 12px;
    flex: 0 0 auto;
}

.quoteEmptyText {
    padding-left: 0 !important;
}

.quoteEmptyText::before {
    display: none;
}

.quotePriceRow,
.quoteTotalRow {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.quotePriceRow {
    font-size: 15px;
    line-height: 1.45;
}

.quotePriceRow strong {
    font-size: 15px;
}

.discountRow {
    color: var(--ok);
}

.rushRow {
    color: var(--bad);
}

.quoteTotalRow {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding-top: 16px;
    border-top: 1px solid var(--line);
}

.quoteTotalLeft {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.quoteTotalLeft strong {
    font-size: 16px;
    font-weight: 800;
    color: #1b2330;
}

.quoteTotalLeft .vat {
    font-size: 12px;
    color: #98a2b3;
    font-weight: 600;
}

.quoteTotalPrice {
    font-size: 26px;
    font-weight: 900;
    color: #1b2330;
    letter-spacing: -0.02em;
    white-space: nowrap;
}

.quoteSummaryButtons {
    display: grid;
    gap: 10px;
}

.telLink {
    color: #111;
    text-decoration: none;
}

.telLink:hover {
    opacity: 0.7;
}



/* =========================================================
   모바일 견적 시트
========================================================= */

.quoteMobileBar,
.quoteMobileSheet {
    display: none;
}

.quoteMobileBar {
    border-radius: 16px 16px 0 0;
}

.quoteMobileBarLabel {
    font-size: 13px;
    font-weight: 700;
}

.quoteMobileBarPrice {
    font-size: 20px;
    font-weight: 800;
}

.quoteMobileSheet {
    position: fixed;
    inset: 0;
    z-index: 1000;
}

.quoteMobileSheet[hidden] {
    display: none !important;
}

.quoteMobileSheetDim {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.46);
}

.quoteMobileSheetPanel {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    display: grid;
    gap: 16px;
    padding: 20px 16px 18px;
    border-radius: 22px 22px 0 0;
    background: #fff;
    box-shadow: 0 -20px 40px rgba(16, 24, 40, 0.18);
}

.quoteMobileSheetHead {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.quoteMobileSheetHead h3 {
    margin: 0;
    font-size: 18px;
}

.quoteMobileClose {
    all: unset;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: #f2f4f7;
    color: var(--txt);
    font-size: 22px;
    cursor: pointer;
}

.quoteMobileDetail {
    display: grid;
    gap: 12px;
}

.quoteMobileDetail .quoteSummaryPanel {
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
}



/* =========================================================
   기타
========================================================= */

.quoteNoticeWrap {
    padding-top: 18px;
    padding-bottom: 0;
}

.quoteNoticeCard {
    padding: 24px;
}

.quoteNoticeHead {
    margin-bottom: 14px;
}

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

.quoteNoticeGroup {
    padding: 16px 18px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #fbfcff;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.7;
}

.quoteNoticeGroup strong {
    display: block;
    margin-bottom: 8px;
    color: var(--txt);
    font-size: 14px;
}

.quoteNoticeContact {
    background: #fff8e8;
    border-color: #f2d27a;
}

.quotePage input[type="checkbox"] {
    accent-color: #111;
}



/* =========================================================
   반응형
========================================================= */

@media (max-width: 1280px) {
    .quoteLayout {
        grid-template-columns: minmax(280px, 320px) minmax(0, 1fr) minmax(280px, 320px);
        gap: 18px;
    }
}

@media (max-width: 1024px) {
    .quoteLayout {
        grid-template-columns: 1fr;
    }

    .quoteSummarySticky {
        position: static;
    }
}

@media (max-width: 900px) {
    .quoteNoticeBox {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .quoteWrap {
        padding-bottom: 92px;
    }

    .quoteRequesterCard,
    .quoteMainCard,
    .quoteSummaryCard {
        padding: 18px;
    }

    .quoteSummaryCard {
        display: none;
    }

    .quoteMobileBar {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: 12px;
        z-index: 900;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        min-height: 60px;
        padding: 14px 16px;
        box-shadow: 0 14px 28px rgba(16, 24, 40, 0.18);
    }

    .quoteMobileSheet:not([hidden]) {
        display: block;
    }

    .quoteHelpTooltip {
        width: min(300px, calc(100vw - 24px));
        left: 0 !important;
        transform: none !important;
    }

    .quoteMobileDetail .quoteTotalRow {
        font-size: 15px;
    }

    .quoteMobileDetail .quoteTotalRow strong {
        font-size: 20px;
    }
}

@media (max-width: 640px) {
    .quoteRow2 {
        grid-template-columns: 1fr;
    }

    .quoteGuideGrid {
        grid-template-columns: 1fr;
    }
}