/* ============================================
   M CREDIT - Mobile responsive (step pages)
   Tự co giãn theo từng điện thoại (device-width)
   ============================================ */

/* --- Desktop scale mode (index / marketing) --- */
html.mcredit-desktop-scale {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

html.mcredit-desktop-scale body,
html.mcredit-desktop-scale #site {
    min-width: 1200px;
}

html.mcredit-desktop-scale .mobile-nav-link {
    display: none !important;
}

html.mcredit-desktop-scale input,
html.mcredit-desktop-scale select,
html.mcredit-desktop-scale textarea,
html.mcredit-desktop-scale .form-control {
    font-size: 16px !important;
}

html.mcredit-desktop-scale a,
html.mcredit-desktop-scale button,
html.mcredit-desktop-scale .btn {
    min-height: unset;
    min-width: unset;
}

/* --- Native mobile: vừa khít từng màn hình --- */
html.mcredit-native-mobile {
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

html.mcredit-native-mobile,
html.mcredit-native-mobile body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
}

html.mcredit-native-mobile body {
    padding-left: env(safe-area-inset-left, 0);
    padding-right: env(safe-area-inset-right, 0);
    padding-bottom: env(safe-area-inset-bottom, 0);
    font-size: clamp(14px, 3.6vw, 16px);
}

html.mcredit-native-mobile #site,
html.mcredit-native-mobile #site-content,
html.mcredit-native-mobile .container,
html.mcredit-native-mobile .container-fluid {
    max-width: 100%;
    box-sizing: border-box;
}

html.mcredit-native-mobile img,
html.mcredit-native-mobile video {
    max-width: 100%;
    height: auto;
}

html.mcredit-native-mobile .step1-container,
html.mcredit-native-mobile .main-container {
    width: 100%;
    max-width: min(900px, 100%);
    margin-left: auto;
    margin-right: auto;
    padding: clamp(12px, 4vw, 28px);
    padding-left: max(clamp(12px, 4vw, 28px), env(safe-area-inset-left, 0));
    padding-right: max(clamp(12px, 4vw, 28px), env(safe-area-inset-right, 0));
    box-sizing: border-box;
}

html.mcredit-native-mobile .hero-compact,
html.mcredit-native-mobile .hero-mcredit,
html.mcredit-native-mobile .steps-wrap {
    width: 100%;
    max-width: min(900px, 100%);
    margin-left: auto;
    margin-right: auto;
    padding-left: max(clamp(8px, 3vw, 16px), env(safe-area-inset-left, 0));
    padding-right: max(clamp(8px, 3vw, 16px), env(safe-area-inset-right, 0));
    box-sizing: border-box;
}

html.mcredit-native-mobile .hero-compact-inner img {
    height: clamp(120px, 32vw, 180px);
}

html.mcredit-native-mobile .hero-compact-overlay {
    padding: clamp(14px, 4vw, 24px) clamp(16px, 4vw, 28px);
}

html.mcredit-native-mobile .hero-compact-overlay h1 {
    font-size: clamp(1.05rem, 4.5vw, 1.45rem);
}

html.mcredit-native-mobile .hero-compact-overlay p {
    font-size: clamp(0.82rem, 3.5vw, 0.92rem);
}

html.mcredit-native-mobile #site-header,
html.mcredit-native-mobile #site-header .header-inner,
html.mcredit-native-mobile #site-header .container {
    padding-left: max(12px, env(safe-area-inset-left, 0));
    padding-right: max(12px, env(safe-area-inset-right, 0));
}

html.mcredit-native-mobile .steps {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: clamp(4px, 1.5vw, 8px);
    margin: clamp(10px, 3vw, 24px) auto;
    padding: 0 clamp(8px, 3vw, 16px);
    max-width: min(900px, 100%);
}

html.mcredit-native-mobile .step {
    flex: 1 1 calc(33.333% - 8px);
    min-width: 0;
    white-space: normal;
    line-height: 1.25;
    font-size: clamp(9px, 2.6vw, 13px);
    padding: clamp(6px, 2vw, 10px) clamp(4px, 1.5vw, 8px);
    word-break: break-word;
}

html.mcredit-native-mobile .form-section {
    padding: clamp(14px, 4vw, 24px);
    margin-bottom: clamp(12px, 3vw, 20px);
}

html.mcredit-native-mobile .form-section-header {
    flex-wrap: wrap;
    gap: 12px;
}

html.mcredit-native-mobile .form-section-title {
    font-size: clamp(1rem, 4.2vw, 1.15rem);
}

html.mcredit-native-mobile .form-grid {
    grid-template-columns: 1fr !important;
    gap: clamp(12px, 3.5vw, 20px);
}

html.mcredit-native-mobile .form-label {
    font-size: clamp(13px, 3.5vw, 14px);
}

html.mcredit-native-mobile .form-control,
html.mcredit-native-mobile .form-select,
html.mcredit-native-mobile input,
html.mcredit-native-mobile select,
html.mcredit-native-mobile textarea {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    font-size: 16px !important;
    min-height: 48px;
    box-sizing: border-box;
}

html.mcredit-native-mobile .form-field-icon {
    display: none !important;
}

html.mcredit-native-mobile .form-field.has-icon .form-control,
html.mcredit-native-mobile .form-field.has-icon .form-select {
    padding-left: 12px !important;
}

html.mcredit-native-mobile .step-navigation {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
}

html.mcredit-native-mobile .step-navigation .btn-next,
html.mcredit-native-mobile .btn-next {
    width: 100%;
    padding: clamp(14px, 4vw, 16px);
    font-size: clamp(15px, 4vw, 16px);
}

html.mcredit-native-mobile .btn-next {
    min-width: 0;
}

html.mcredit-native-mobile .loan-calc-box {
    padding: clamp(14px, 4vw, 20px);
}

html.mcredit-native-mobile .calc-row {
    flex-wrap: wrap;
    gap: 4px 8px;
    font-size: clamp(13px, 3.5vw, 14px);
}

html.mcredit-native-mobile .calculation-table {
    display: block;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

html.mcredit-native-mobile .calculation-table thead {
    display: none;
}

html.mcredit-native-mobile .calculation-table tbody {
    display: block;
}

html.mcredit-native-mobile .calculation-table tbody tr {
    display: block;
    margin-bottom: 12px;
    padding: 12px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    background: #fff;
}

html.mcredit-native-mobile .calculation-table tbody td {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    padding: 6px 0;
    border: none;
    border-bottom: 1px solid #f0f0f0;
    text-align: left;
    font-size: clamp(13px, 3.5vw, 14px);
}

html.mcredit-native-mobile .calculation-table tbody td:last-child {
    border-bottom: none;
}

html.mcredit-native-mobile .calculation-table tbody td::before {
    content: attr(data-label);
    font-weight: 600;
    color: #00b4fa;
    flex-shrink: 0;
}

html.mcredit-native-mobile .auto-save-indicator {
    right: max(12px, env(safe-area-inset-right, 0));
    bottom: max(12px, env(safe-area-inset-bottom, 0));
    max-width: calc(100vw - 24px);
    font-size: clamp(12px, 3.2vw, 13px);
}

html.mcredit-native-mobile .loading-modal .loading-content,
html.mcredit-native-mobile #loadingModal > div {
    width: min(92vw, 500px);
    padding: clamp(20px, 5vw, 40px);
}

html.mcredit-native-mobile .page-footer {
    padding-left: max(16px, env(safe-area-inset-left, 0));
    padding-right: max(16px, env(safe-area-inset-right, 0));
}

html.mcredit-native-mobile .row {
    margin-left: 0;
    margin-right: 0;
}

html.mcredit-native-mobile .row > [class*='col-'] {
    padding-left: 0;
    padding-right: 0;
}

html.mcredit-native-mobile .row.g-3 {
    --bs-gutter-x: clamp(8px, 3vw, 16px);
    --bs-gutter-y: clamp(8px, 3vw, 16px);
}

/* Màn hình rộng hơn (tablet dọc / điện thoại gập) */
@media (min-width: 768px) {
    html.mcredit-native-mobile .form-grid {
        grid-template-columns: 1fr 1fr !important;
    }

    html.mcredit-native-mobile .step {
        font-size: clamp(11px, 1.8vw, 13px);
        white-space: nowrap;
    }

    html.mcredit-native-mobile .step-navigation {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }

    html.mcredit-native-mobile .step-navigation .btn-next,
    html.mcredit-native-mobile .btn-next {
        width: auto;
        min-width: 180px;
    }

    html.mcredit-native-mobile .calculation-table {
        display: table;
        overflow-x: auto;
    }

    html.mcredit-native-mobile .calculation-table thead {
        display: table-header-group;
    }

    html.mcredit-native-mobile .calculation-table tbody {
        display: table-row-group;
    }

    html.mcredit-native-mobile .calculation-table tbody tr {
        display: table-row;
        margin: 0;
        padding: 0;
        box-shadow: none;
    }

    html.mcredit-native-mobile .calculation-table tbody td {
        display: table-cell;
        text-align: center;
        padding: 12px;
        border: 1px solid #ddd;
    }

    html.mcredit-native-mobile .calculation-table tbody td::before {
        content: none;
    }
}

/* Điện thoại rất nhỏ */
@media (max-width: 360px) {
    html.mcredit-native-mobile .step {
        flex: 1 1 100%;
    }

    html.mcredit-native-mobile .form-section-icon {
        width: 40px;
        height: 40px;
        font-size: 16px;
    }
}

/* Ngang: giảm padding */
@media (orientation: landscape) and (max-height: 500px) {
    html.mcredit-native-mobile .hero-compact-inner img {
        height: 100px;
    }

    html.mcredit-native-mobile .form-section {
        padding: 12px;
    }
}
