/** General styles */

h3 {
    color: #000000;
    text-align: center;
    /* margin-top: 0px; */
    font-size: x-large;
    margin-bottom: 10px;
    margin-top: 10px;
}

h4 {
    font-size: larger;
    margin-bottom: 12px;

}

input[type="checkbox"] {
    margin-left: 5px;
    margin-right: 5px;
}


.next-button {
    margin-top: 20px !important;
}

/** Cart styles */
#emptyCart {
    margin-top: 32px;
    text-align: center;
    
}


#cart-form {
    margin-top: 32px;
    overflow-x: auto;
    display: grid;
    grid-template-columns: 110px 2fr 1fr 1fr 1fr;
    row-gap: 24px;
    column-gap: 12px;
    align-items: center;
    font-size: 1.08rem;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.07);
    padding: 32px 24px 24px 24px;
    border: 1px solid #eaeaea;
}


.cartHeader div {
    font-weight: 600;
    padding: 8px 6px;
    color: #2b2b2b;
    letter-spacing: 0.01em;
    font-size: 1.05em;
}


.cartItem,
.cartHeader {
    display: contents;
    /* This makes children line up with grid like a table row */
}


.cartItem .img img {
    width: 90px;
    border-radius: 8px;
    background-color: #f5f7fa;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    border: 1px solid #eaeaea;
}


.cartItem .unitPrice,
.cartItem .price,
.cartItem .amount {
    text-align: right;
    color: #222;
}

.cartItem .ref {
    display: inline-block;
    max-width: 10ch;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: bottom;
}


.amountAndDelete {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: flex-end;
    height: 100%;
}


.deleteBtn {
    cursor: pointer;
    text-align: center;
    font-size: 1.3rem;
    vertical-align: middle;
    color: #d9534f;
    transition: color 0.2s;
}

.deleteBtn:hover {
    color: #ff3b3b;
}


.cartItem input[type="number"] {
    width: 70px;
    padding: 8px 12px;
    border-radius: 8px;
    border: 1px solid #d1d5db;
    font-size: 1.05rem;
    background: #f8f9fa;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.cartItem input[type="number"]:focus {
    border-color: #007bff;
    box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.13);
    outline: none;
}



/* Totals section */


.total {
    font-weight: bold;
    color: #007bff;
}

.totalPrice {
    font-weight: bold;
    font-size: 1.25rem;
    color: #007bff;
}

/* Input fields (amount) */
.cartItem input[type="number"] {
    width: 60px;
    padding: 6px 10px;
    border: 1px solid #ccc;
    border-radius: 6px;
    font-size: 1rem;
    background-color: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.cartItem input[type="number"]:focus {
    border-color: #0037ff;
    box-shadow: 0 0 0 2px rgba(0, 55, 255, 0.2);
    outline: none;
}


@media (min-width: 769px) {
    .cartItem .label {
        display: none;
    }

    #cart-form {
        padding: 32px 32px 24px 32px;
    }
}


.totalButton {
    grid-column: span 5;
    text-align: right;
    margin-top: 18px;
}


@media (max-width: 768px) {
    .cartItem .label {
        font-weight: bold;
        margin-right: 4px;
    }

    #cart-form {
        display: block;
        padding: 16px 6px;
        border-radius: 10px;
        box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
        border: 1px solid #eaeaea;
    }

    .cartItem {
        display: grid;
        grid-template-columns: 90px 1fr;
        grid-template-areas:
            "img desc"
            ". unitPrice"
            ". amount"
            ". price";
        gap: 8px 14px;
        padding: 16px 0;
        border-bottom: 1px solid #eee;
        background: #fff;
        border-radius: 8px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.03);
    }

    .cartHeader {
        display: none;
    }

    .cartItem .img {
        grid-area: img;
    }

    .cartItem .desc {
        grid-area: desc;
    }

    .cartItem .unitPrice {
        grid-area: unitPrice;
        text-align: left;
    }

    .cartItem .amount {
        grid-area: amount;
        text-align: left;
    }

    .amountAndDelete input[type="number"] {
        flex: 0 1 auto;
        padding: 8px 12px;
        font-size: 1.05rem;
        border-radius: 8px;
    }

    .cartItem .price {
        grid-area: price;
        text-align: left;
    }

    .cartItem .delete {
        grid-area: delete;
        text-align: left;
    }

    .cartItem input[type="number"] {
        width: 100%;
    }
}

/* cart information section */
[hide=hide] {
    display: none;
}



#informationForm .formContainer {
    margin-top: 20px;
    padding: 12px;
    border: 1px solid #ccc;
    border-radius: 6px;
    background-color: #f9f9f9;
}

#informationForm h4 {
    margin-top: 4px;
    padding: 0;

}

.formLayout input[readonly] {
    background-color: #f0f0f0;
    color: #6c757d;
    border-color: #ced4da;
    cursor: not-allowed;
    pointer-events: none;
    /* optional, disables focus */
}

#informationForm .formLayout {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 4px;
    align-items: center;
}

#informationForm .formLayout .formrow {
    display: contents;
}

input[type="radio"] {
    margin-left: 7px;
    display: inline-block;
}



/*Cart summary*/


.cartSummary h3 {
    text-align: center;
    font-size: 2rem;
    
    margin-bottom: 18px;
    margin-top: 14px;
}
.cartSummary h4 {
    text-align: left;
    font-size: 1.15rem;
    margin: 22px 0 10px 0;
    color: #222;
}

.cartSummary .block {
    margin-bottom: 18px;
    padding-bottom: 12px;
    border-bottom: 1px solid #eee;
}
.cartSummary .entityOverview {
    margin-bottom: 18px;
}
.cartSummary em {
    color: #007bff;
    font-style: normal;
    font-weight: 500;
}
.cartSummary .totalPrice {
    font-size: 1.4rem;
    color: #007bff;
    font-weight: bold;
    margin-bottom: 12px;
}
.cartSummary input[type="submit"],
.cartSummary input[type="button"] {
    display: inline-block;
    padding: 12px 28px;
    font-size: 1.08rem;
    border-radius: 8px;
    background: #2826a1;
    color: #fff;
    border: none;
    margin: 18px 8px 0 0;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0,123,255,0.08);
    transition: background 0.2s;
}
.cartSummary input[type="submit"]:hover,
.cartSummary input[type="button"]:hover {
    background: #0056b3;
}

.aans {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;

}

/* Order confirmed card */

.order-confirmed-card h3 {
    color: #222;
    font-size: 2rem;
    margin-bottom: 18px;
    margin-top: 0;
}
.order-confirmed-card .order-id {
    font-size: 1.1rem;
    color: #444;
    margin-bottom: 10px;
}
.order-confirmed-card .confirmed-msg {
    font-size: 1.12rem;
    color: #444;
    margin-bottom: 18px;
}
.order-confirmed-card .mail-sent {
    color: #009726;
    margin-bottom: 10px;
}
.order-confirmed-card .mail-error {
    color: #b30000;
    margin-bottom: 10px;
}
.order-confirmed-card h4 {
    color: #222;
    margin-top: 24px;
    margin-bottom: 10px;
}
.order-confirmed-card .details {
    background: #f8f9fa;
    border-radius: 8px;
    padding: 18px 16px;
    margin-bottom: 18px;
    font-size: 1.08rem;
    color: #222;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    border: 1px solid #eaeaea;
    text-align: left;
    display: grid;
    grid-template-columns: 1fr 2fr;
    row-gap: 10px;
    column-gap: 18px;
    justify-items: start;
}
.order-confirmed-card .details .label {
    font-weight: 500;
    color: #555;
    text-align: right;
}
.order-confirmed-card .details .value {
    font-weight: 400;
    color: #222;
    word-break: break-all;
}
.order-confirmed-card .details .value.important {
    font-weight: bold;
    color: #222;
}
.order-confirmed-card .payconiq-link {
    margin-bottom: 10px;
}
.order-confirmed-card .payconiq-link a {
    color: #0056b3;
    text-decoration: underline;
    font-weight: 500;
    margin: 0 4px;
}
.order-confirmed-card .unknown-payment {
    color: #b30000;
    margin-top: 18px;
}


/** empty cart **/
#emptyCart{
    margin-top: 40px;
    text-align: center;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
    padding: 32px 24px 28px 24px;
    border: 1px solid #eaeaea;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}
.custom-empty-cart div {
    font-size: 1.15rem;
    color: #444;
    margin-bottom: 18px;
}
.custom-empty-cart .tips {
    display: inline-block;
    margin: 10px 8px 0 8px;
    padding: 12px 24px;
    font-size: 1.08rem;
    border-radius: 8px;
    background: #000000;
    color: #fff;
    text-decoration: none;
    box-shadow: 0 2px 8px rgba(0,123,255,0.08);
    transition: background 0.2s;
}
.custom-empty-cart .tips:hover {
    background: #0056b3;
}