/**
 * Customer Payment (receipt) — mobile-first responsive layout.
 */

.cp-root {
    --cp-blue: #31b0d5;
    --cp-border: #c0c0c0;
    --cp-bg: #f4f5f7;
    --cp-card: #fff;
    --cp-tap: 44px;
    --cp-gap: 12px;
    --cp-radius: 8px;
    --cp-sidebar-w: 100%;
}

.cp-root .panel-body {
    padding: 8px 10px 16px !important;
    background: var(--cp-bg);
}

.cp-root .purchaseHeading {
    font-size: 17px;
    padding: 12px 14px !important;
}

/* Page grid — toolbar above sidebar column, main spans right */
.cp-page {
    display: flex;
    flex-direction: column;
    gap: var(--cp-gap);
    max-width: 1536px;
    margin: 0 auto;
}

/* Toolbar menu — outside sidebar, left-aligned with sidebar below */
.cp-toolbar {
    margin: 0;
    padding: 0;
    width: 100%;
}

.cp-toolbar .purchaseMenu {
    margin: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    min-height: 0 !important;
}

.cp-toolbar .purchaseMenu .container-fluid {
    padding: 0 !important;
}

.cp-toolbar .navbar-nav {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    margin: 0;
    float: none;
}

.cp-toolbar .navbar-nav > li {
    float: none;
    flex: 0 0 auto;
    text-align: left;
}

.cp-toolbar .navbar-nav > li > a {
    padding: 8px 16px 8px 0 !important;
    min-height: var(--cp-tap);
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    font-size: 14px;
    white-space: nowrap;
}

.cp-sidebar,
.cp-main {
    background: var(--cp-card);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    padding: 12px;
    min-width: 0;
}

.cp-sidebar-restart {
    width: 100%;
    min-height: var(--cp-tap);
    margin: 0 0 10px;
}

.cp-debtors-title {
    display: block;
    color: var(--cp-blue);
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 8px;
}

.cp-sidebar {
    display: flex;
    flex-direction: column;
}

.cp-debtors-list {
    list-style: square;
    margin: 0;
    padding: 0 0 0 4px;
    flex: 1 1 auto;
    min-height: 120px;
    max-height: 240px;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

.cp-debtors-list li {
    padding: 10px 8px;
    border-bottom: 1px solid #eee;
    cursor: pointer;
    font-size: 14px;
    line-height: 1.35;
    white-space: normal;
    word-break: break-word;
}

.cp-debtors-list li:last-child {
    border-bottom: none;
}

.cp-debtors-list li:active {
    background: #e8f4f8;
}

/* Form sections */
.cp-section {
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    padding: 12px;
    margin-bottom: var(--cp-gap);
    background: var(--cp-card);
}

.cp-section legend,
.cp-section-title {
    font-size: 14px;
    font-weight: 600;
    color: #333;
    margin: 0 0 10px;
    padding: 0;
    border: none;
    width: auto;
}

.cp-field {
    margin-bottom: 10px;
}

.cp-field:last-child {
    margin-bottom: 0;
}

.cp-field label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 4px;
    color: #444;
}

.cp-field .tpControl1,
.cp-field .tpControl2,
.cp-field input[type="text"],
.cp-field select {
    width: 100% !important;
    max-width: 100%;
    box-sizing: border-box;
    min-height: var(--cp-tap);
    font-size: 16px;
    margin: 0 !important;
}

.cp-field-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.cp-field-row-2 {
    grid-template-columns: 1fr 1fr;
}

.cp-field-with-btn {
    display: flex;
    gap: 8px;
    align-items: stretch;
}

.cp-field-with-btn .tpControl1 {
    flex: 1;
    min-width: 0;
}

.cp-field-with-btn .btn {
    flex-shrink: 0;
    min-width: var(--cp-tap);
    min-height: var(--cp-tap);
    padding: 0 12px;
}

.cp-date-wrap {
    display: flex;
    align-items: stretch;
    gap: 0;
    max-width: 100%;
}

.cp-date-wrap .input-group {
    display: flex;
    flex: 1;
    min-width: 0;
    width: 100% !important;
}

.cp-date-wrap .tpControl2 {
    flex: 1;
    min-width: 0;
    height: var(--cp-tap) !important;
    border-radius: 4px 0 0 4px !important;
}

.cp-date-wrap .input-group-addon {
    position: static !important;
    left: auto !important;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: var(--cp-tap);
    height: var(--cp-tap);
    border-radius: 0 4px 4px 0;
}

.cp-memo-row {
    background: #ddd;
    padding: 10px 12px;
    border-radius: var(--cp-radius);
    margin-bottom: var(--cp-gap);
}

.cp-memo-row label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 4px;
}

.cp-memo-row .tpControl1 {
    width: 100% !important;
    min-height: var(--cp-tap);
    font-size: 16px;
}

/* Grids */
.cp-grid-wrap {
    width: 100%;
    min-width: 0;
    margin-bottom: var(--cp-gap);
}

.cp-grid-invoices {
    width: 100% !important;
    min-height: 154px;
}

.cp-root .cp-grid-invoices.div_Grid {
    min-height: 154px;
}

.cp-grid-payment {
    height: 220px !important;
    width: 100% !important;
}

.cp-root .ui-grid-viewport {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
}

/* Totals */
.cp-totals {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    background: #ddd;
    padding: 10px 12px;
    border-radius: var(--cp-radius);
    margin-bottom: var(--cp-gap);
}

.cp-totals label {
    font-weight: 600;
    margin: 0;
    font-size: 14px;
}

.cp-totals .tpControl1 {
    width: 120px !important;
    max-width: 42vw;
    text-align: right;
    min-height: var(--cp-tap);
    font-size: 16px;
}

/* Payment + actions */
.cp-payment-row {
    display: flex;
    flex-direction: column;
    gap: var(--cp-gap);
}

.cp-payment-method-inner {
    display: flex;
    flex-direction: column;
    gap: var(--cp-gap);
}

.cp-payment-summary label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin: 0 0 4px;
}

.cp-payment-summary .tpControl1 {
    width: 100% !important;
    text-align: right;
    min-height: var(--cp-tap);
    font-size: 16px;
    margin-bottom: 10px !important;
}

.cp-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.cp-actions .btn {
    width: 100%;
    min-height: var(--cp-tap);
    font-size: 14px;
    margin: 0 !important;
}

.cp-actions-save {
    grid-column: 1 / -1;
    display: flex;
    gap: 10px;
}

.cp-actions-save .btn {
    flex: 1;
}

/* Tablet — menu aligns with left edge of sidebar column */
@media (min-width: 768px) {
    .cp-root {
        --cp-sidebar-w: 220px;
    }

    .cp-root .panel-body {
        padding: 10px 16px 20px !important;
    }

    .cp-page {
        display: grid;
        grid-template-columns: var(--cp-sidebar-w) 1fr;
        column-gap: var(--cp-gap);
        row-gap: var(--cp-gap);
        align-items: start;
    }

    .cp-toolbar {
        grid-column: 1 / -1;
        grid-row: 1;
        width: 100%;
        max-width: 100%;
    }

    .cp-sidebar {
        grid-column: 1;
        grid-row: 2;
        width: var(--cp-sidebar-w);
        max-width: var(--cp-sidebar-w);
        align-self: stretch;
    }

    .cp-main {
        grid-column: 2;
        grid-row: 2;
        align-self: stretch;
    }

    .cp-debtors-list {
        max-height: none;
    }

    .cp-field-row-2 {
        grid-template-columns: 1fr 1fr;
    }

    .cp-field-row-3 {
        grid-template-columns: 1.2fr 1fr 1fr;
    }

    .cp-payment-row {
        flex-direction: row;
        align-items: flex-start;
    }

    .cp-payment-method {
        flex: 1 1 55%;
        min-width: 0;
    }

    .cp-payment-method-inner {
        flex-direction: row;
    }

    .cp-payment-method-inner .cp-grid-wrap {
        flex: 1 1 60%;
        margin-bottom: 0;
    }

    .cp-payment-summary {
        flex: 0 0 160px;
    }

    .cp-actions-col {
        flex: 0 0 180px;
    }

    .cp-actions {
        grid-template-columns: 1fr;
    }

    .cp-actions-save {
        grid-column: auto;
        flex-direction: column;
    }
}

/* Desktop */
@media (min-width: 992px) {
    .cp-root {
        --cp-sidebar-w: 240px;
    }

    .cp-sidebar {
        display: flex;
        flex-direction: column;
    }

    .cp-field-row-desktop {
        display: grid;
        grid-template-columns: minmax(100px, 1fr) minmax(140px, 1.2fr) auto minmax(80px, 0.8fr) minmax(120px, 1fr);
        gap: 10px;
        align-items: end;
    }

    .cp-field-row-desktop-2 {
        grid-template-columns: minmax(100px, 1fr) minmax(140px, 1.2fr) auto 1fr minmax(100px, 0.8fr) minmax(120px, 1fr);
    }
}