/* ═══════════════════════════════════════════════════════════════════
 * [cr_cart] + [cr_checkout] — Enfold-compatible WC layout (v0.66.186)
 *
 * Default WC checkout uses float-based 50/50 columns that collapse
 * inside Enfold ALB Code-Blocks because the parent flex/column reset
 * overrides float. CSS Grid with explicit areas is theme-agnostic.
 * ═══════════════════════════════════════════════════════════════════ */

.dnlc-woo-checkout-wrap,
.dnlc-woo-cart-wrap {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
    box-sizing: border-box;
}

/* ── Checkout: 2-column grid ──────────────────────────────────── */
.dnlc-woo-checkout-wrap .checkout.woocommerce-checkout {
    display: grid !important;
    grid-template-columns: minmax(0, 1.7fr) minmax(320px, 1fr) !important;
    grid-template-areas:
        "ibc      ibc"
        "billing  review"
        "billing  review" !important;
    gap: 8px 40px !important;
    align-items: start !important;
}
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields { grid-area: ibc !important; }
.dnlc-woo-checkout-wrap #customer_details       { grid-area: billing !important; min-width: 0; }
.dnlc-woo-checkout-wrap #order_review_heading,
.dnlc-woo-checkout-wrap #order_review           { grid-area: review !important; min-width: 0; }
.dnlc-woo-checkout-wrap #order_review_heading { margin: 0 0 10px !important; }

/* ── Fluid layout (layout="fluid") ────────────────────────────────
 * Keeps all the field / button / order-review styling but drops the
 * fixed 2-column grid, so checkout add-ons that inject their own
 * markup (e.g. an appointment/booking plugin's tour description) get
 * full width and aren't squeezed into a rigid grid cell. Billing and
 * order review simply stack full-width in normal document flow. */
.dnlc-woo-checkout-wrap.dnlc-checkout-fluid .checkout.woocommerce-checkout {
    display: block !important;
    grid-template-columns: none !important;
    grid-template-areas: none !important;
    gap: 0 !important;
}
.dnlc-woo-checkout-wrap.dnlc-checkout-fluid #dnlc-ibc-checkout-fields,
.dnlc-woo-checkout-wrap.dnlc-checkout-fluid #customer_details,
.dnlc-woo-checkout-wrap.dnlc-checkout-fluid #order_review_heading,
.dnlc-woo-checkout-wrap.dnlc-checkout-fluid #order_review {
    grid-area: auto !important;
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
.dnlc-woo-checkout-wrap.dnlc-checkout-fluid #customer_details { margin-bottom: 24px !important; }

/* Reset WC's internal col-1/col-2 floats — single column inside billing block */
.dnlc-woo-checkout-wrap .col2-set,
.dnlc-woo-checkout-wrap .col2-set .col-1,
.dnlc-woo-checkout-wrap .col2-set .col-2 {
    width: 100% !important;
    float: none !important;
    margin: 0 0 16px !important;
    padding: 0 !important;
}

/* Form inputs polish */
.dnlc-woo-checkout-wrap .form-row input.input-text,
.dnlc-woo-checkout-wrap .form-row textarea,
.dnlc-woo-checkout-wrap .select2-container--default .select2-selection--single {
    height: 44px !important;
    padding: 10px 14px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 6px !important;
    background: #fff !important;
    font-size: 15px !important;
    box-sizing: border-box !important;
}
.dnlc-woo-checkout-wrap .form-row textarea {
    height: auto !important;
    min-height: 96px !important;
}
.dnlc-woo-checkout-wrap .form-row label {
    display: block !important;
    margin: 0 0 4px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #374151 !important;
}
.dnlc-woo-checkout-wrap .form-row {
    margin: 0 0 14px !important;
    padding: 0 !important;
}

/* Order-review box visually distinct */
.dnlc-woo-checkout-wrap #order_review {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 20px !important;
    position: sticky;
    top: 24px;
}
.dnlc-woo-checkout-wrap #order_review .shop_table {
    border: 0 !important;
    margin: 0 0 14px !important;
    background: transparent !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table th,
.dnlc-woo-checkout-wrap #order_review .shop_table td {
    border-bottom: 1px solid #e2e8f0 !important;
    padding: 10px 0 !important;
    background: transparent !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table .order-total {
    font-size: 17px;
}

/* Place Order button */
.dnlc-woo-checkout-wrap #place_order {
    width: 100% !important;
    padding: 14px 20px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
    background: var(--dnlc-accent,#2c3e50) !important;
    color: #fff !important;
    border: 0 !important;
    margin-top: 16px !important;
    cursor: pointer !important;
}
.dnlc-woo-checkout-wrap #place_order:hover {
    background: var(--dnlc-accent-hover,#1e3a4d) !important;
}

/* Section headings */
.dnlc-woo-checkout-wrap h3 {
    font-size: 20px !important;
    margin: 0 0 16px !important;
    color: var(--dnlc-accent,#2c3e50);
    font-weight: 500;
}

/* Mobile — stack to single column */
@media (max-width: 900px) {
    .dnlc-woo-checkout-wrap .checkout.woocommerce-checkout {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "ibc"
            "billing"
            "review" !important;
    }
    .dnlc-woo-checkout-wrap #order_review { position: static; }
}

/* ── Cart: clean two-row layout ───────────────────────────────── */
.dnlc-woo-cart-wrap .woocommerce-cart-form {
    margin: 0 0 28px;
}
.dnlc-woo-cart-wrap .shop_table.cart {
    width: 100% !important;
    border-collapse: collapse !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    overflow: hidden;
}
.dnlc-woo-cart-wrap .shop_table.cart th,
.dnlc-woo-cart-wrap .shop_table.cart td {
    padding: 14px 16px !important;
    border-bottom: 1px solid #e2e8f0 !important;
    text-align: left !important;
    vertical-align: middle !important;
}
.dnlc-woo-cart-wrap .shop_table.cart thead th {
    background: #f8fafc !important;
    font-weight: 500 !important;
    color: #374151;
}
.dnlc-woo-cart-wrap .shop_table.cart .product-thumbnail img {
    max-width: 70px !important;
    height: auto !important;
    border-radius: 4px;
}
.dnlc-woo-cart-wrap .shop_table.cart .actions {
    background: #f8fafc !important;
    padding: 16px !important;
}
.dnlc-woo-cart-wrap .shop_table.cart .actions .coupon {
    display: inline-flex !important;
    gap: 8px;
    align-items: center;
}
.dnlc-woo-cart-wrap .shop_table.cart .actions .coupon input[type="text"] {
    height: 38px !important;
    padding: 8px 12px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 4px !important;
}

/* Cart totals block — full width below cart, not floated */
.dnlc-woo-cart-wrap .cart-collaterals {
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    gap: 32px !important;
    align-items: start;
}
.dnlc-woo-cart-wrap .cart-collaterals .cross-sells {
    width: 100% !important;
    float: none !important;
}
.dnlc-woo-cart-wrap .cart-collaterals .cart_totals {
    width: 100% !important;
    float: none !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 20px !important;
}
.dnlc-woo-cart-wrap .cart_totals h2 {
    font-size: 20px !important;
    margin: 0 0 16px !important;
}
.dnlc-woo-cart-wrap .cart_totals .shop_table {
    border: 0 !important;
    background: transparent !important;
}
.dnlc-woo-cart-wrap .cart_totals .shop_table th,
.dnlc-woo-cart-wrap .cart_totals .shop_table td {
    border-bottom: 1px solid #e2e8f0 !important;
    padding: 10px 0 !important;
    background: transparent !important;
}
.dnlc-woo-cart-wrap .checkout-button {
    display: block !important;
    width: 100% !important;
    padding: 14px 20px !important;
    margin-top: 16px !important;
    text-align: center !important;
    background: var(--dnlc-accent,#2c3e50) !important;
    color: #fff !important;
    border-radius: 6px !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    text-decoration: none !important;
}
.dnlc-woo-cart-wrap .checkout-button:hover {
    background: var(--dnlc-accent-hover,#1e3a4d) !important;
}

@media (max-width: 900px) {
    .dnlc-woo-cart-wrap .cart-collaterals {
        grid-template-columns: 1fr !important;
    }
}

/* Hide WC's empty-cart heading icon shenanigans */
.dnlc-woo-cart-wrap .cart-empty,
.dnlc-woo-checkout-wrap .cart-empty {
    text-align: center;
    font-size: 18px;
    padding: 60px 20px;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.187: per-section boxes with CR brand accents
 *
 * Each major section becomes a clear card with:
 *   - white background, subtle border + shadow
 *   - left-border accent (gold #d4b98c for customer-data sections,
 *     dark var(--dnlc-accent,#2c3e50) for order/payment sections)
 *   - heading divider line
 * ═══════════════════════════════════════════════════════════════════ */

/* Back-to-cart link at top of checkout */
.dnlc-back-to-cart {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    margin-bottom: 24px;
    background: #f1f5f9;
    color: #475569;
    border-radius: 6px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
}
.dnlc-back-to-cart:hover {
    background: #e2e8f0;
    color: var(--dnlc-accent,#2c3e50);
}

/* ── Checkout: each customer-data section as a card ───────────── */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields,
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields {
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-left: 3px solid #d4b98c !important;
    border-radius: 8px !important;
    padding: 22px 24px !important;
    margin: 0 0 16px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.dnlc-woo-checkout-wrap .woocommerce-billing-fields h3,
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields h3,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields h3 {
    margin: 0 0 18px !important;
    padding: 0 0 12px !important;
    border-bottom: 1px solid #f1f5f9 !important;
    font-size: 18px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 500 !important;
}

/* IBC box keeps its blue accent — already styled inline in the block */
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields {
    margin: 0 0 16px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* Order review heading + body as one connected card */
.dnlc-woo-checkout-wrap #order_review_heading {
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-bottom: 0 !important;
    border-left: 3px solid var(--dnlc-accent,#2c3e50) !important;
    border-radius: 8px 8px 0 0 !important;
    padding: 16px 22px !important;
    margin: 0 !important;
    font-size: 18px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 500 !important;
}
.dnlc-woo-checkout-wrap #order_review {
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-top: 0 !important;
    border-left: 3px solid var(--dnlc-accent,#2c3e50) !important;
    border-radius: 0 0 8px 8px !important;
    padding: 0 22px 22px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.dnlc-woo-checkout-wrap #order_review .shop_table {
    margin: 16px 0 !important;
}

/* Payment block — separate sub-card inside order review */
.dnlc-woo-checkout-wrap #payment {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 6px !important;
    margin: 16px 0 !important;
    padding: 16px !important;
}
.dnlc-woo-checkout-wrap #payment ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
}
.dnlc-woo-checkout-wrap #payment ul.payment_methods li {
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 6px !important;
    padding: 12px 14px !important;
    margin: 0 0 8px !important;
}
.dnlc-woo-checkout-wrap #payment ul.payment_methods li:last-child {
    margin-bottom: 0 !important;
}
.dnlc-woo-checkout-wrap #payment .payment_box {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 4px !important;
    margin-top: 10px !important;
    padding: 12px !important;
    font-size: 13px;
}

/* Terms checkbox */
.dnlc-woo-checkout-wrap .woocommerce-terms-and-conditions-wrapper {
    margin: 16px 0 !important;
    padding: 12px 14px !important;
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 6px !important;
}

/* ── Cart: section-card treatment ─────────────────────────────── */
.dnlc-woo-cart-wrap .woocommerce-cart-form {
    background: #fff !important;
    border: 1px solid #e2e8f0 !important;
    border-left: 3px solid #d4b98c !important;
    border-radius: 8px !important;
    padding: 16px !important;
    margin: 0 0 24px !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.dnlc-woo-cart-wrap .woocommerce-cart-form .shop_table.cart {
    border: 0 !important;
    background: transparent !important;
}
.dnlc-woo-cart-wrap .cart_totals {
    border-left: 3px solid var(--dnlc-accent,#2c3e50) !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.dnlc-woo-cart-wrap .cart_totals h2 {
    color: var(--dnlc-accent,#2c3e50) !important;
    border-bottom: 1px solid #f1f5f9 !important;
    padding-bottom: 12px !important;
}
.dnlc-woo-cart-wrap .cross-sells {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 16px !important;
}
.dnlc-woo-cart-wrap .cross-sells h2 {
    color: var(--dnlc-accent,#2c3e50) !important;
    font-size: 18px;
    margin: 0 0 14px;
}

/* WC notices (e.g. "applied coupon") get the same card treatment */
.dnlc-woo-cart-wrap .woocommerce-notices-wrapper .woocommerce-message,
.dnlc-woo-cart-wrap .woocommerce-notices-wrapper .woocommerce-info,
.dnlc-woo-checkout-wrap .woocommerce-notices-wrapper .woocommerce-message,
.dnlc-woo-checkout-wrap .woocommerce-notices-wrapper .woocommerce-info {
    background: #f0fdf4 !important;
    border: 1px solid #86efac !important;
    border-left: 3px solid #16a34a !important;
    border-radius: 6px !important;
    padding: 12px 16px !important;
    margin: 0 0 16px !important;
    color: #14532d !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.188: real .dnlc-card boxes for cart/checkout (matches single-
 * listing template's "Reviews & Ratings" / "Know something about
 * this entry?" boxes — multi-layer shadow, proper depth, real card
 * feel). Overrides v0.66.187's flat boxes.
 * ═══════════════════════════════════════════════════════════════════ */

/* Each major section becomes a real .dnlc-card with depth */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields,
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields,
.dnlc-woo-checkout-wrap #order_review,
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields,
.dnlc-woo-cart-wrap .woocommerce-cart-form,
.dnlc-woo-cart-wrap .cart_totals,
.dnlc-woo-cart-wrap .cross-sells {
    background: #ffffff !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    margin-bottom: 14px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
    transition: box-shadow 0.25s ease, transform 0.25s ease;
    /* Strip the v0.66.187 left-accent — let the shadow do the heavy lifting */
    border-left: 1px solid #cbd5e1 !important;
}

/* Hover lift */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields:hover,
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields:hover,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields:hover,
.dnlc-woo-checkout-wrap #order_review:hover,
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields:hover,
.dnlc-woo-cart-wrap .woocommerce-cart-form:hover,
.dnlc-woo-cart-wrap .cart_totals:hover {
    box-shadow:
        0 0 0 1px rgba(37, 99, 235, 0.15),
        0 2px 4px rgba(0, 0, 0, 0.08),
        0 8px 16px rgba(0, 0, 0, 0.10),
        0 16px 32px rgba(0, 0, 0, 0.14) !important;
}

/* Reset the heading-card-combo from v0.66.187 — heading goes back
   to being just a heading, the order_review card holds it inside */
.dnlc-woo-checkout-wrap #order_review_heading {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 0 12px !important;
    font-size: 18px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 700 !important;
    border-bottom: 1px solid #cbd5e1 !important;
    padding-bottom: 10px !important;
}
/* And merge it visually with the review card below */
.dnlc-woo-checkout-wrap #order_review_heading + #order_review {
    margin-top: -2px;
}

/* Section H3s consistent with .dnlc-card h2 from frontend.css */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields > h3,
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields > h3,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields > h3 {
    margin: 0 0 14px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    padding-bottom: 10px !important;
    border-bottom: 1px solid #cbd5e1 !important;
}

/* IBC block — already has its own blue brand, keep it but match
   the card depth */
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields {
    background: #f0f9ff !important;
    border: 1px solid #bae6fd !important;
    border-left: 1px solid #bae6fd !important;
}
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields h3 {
    margin: 0 0 6px !important;
    padding: 0 !important;
    border: 0 !important;
}

/* Payment block inside the order review card — flat sub-section */
.dnlc-woo-checkout-wrap #payment {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 16px 0 0 !important;
    margin-top: 16px !important;
    border-top: 1px solid #e2e8f0 !important;
}
.dnlc-woo-checkout-wrap #payment ul.payment_methods li {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: none !important;
}

/* Terms — flat row, no card */
.dnlc-woo-checkout-wrap .woocommerce-terms-and-conditions-wrapper {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 14px 0 !important;
    box-shadow: none !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.189: hellblau accent rhythm + hide empty col-2 wrapper
 * ═══════════════════════════════════════════════════════════════════ */

/* Order Review keeps the hellblau tint like the IBC box for visual
   rhythm — they're related concepts (what you're buying + where to
   send it / how much to pay). Cart Totals gets the same. */
.dnlc-woo-checkout-wrap #order_review,
.dnlc-woo-cart-wrap .cart_totals {
    background: #f0f9ff !important;
    border: 1px solid #bae6fd !important;
    border-left: 1px solid #bae6fd !important;
}
.dnlc-woo-checkout-wrap #order_review:hover,
.dnlc-woo-cart-wrap .cart_totals:hover {
    box-shadow:
        0 0 0 1px rgba(14, 165, 233, 0.20),
        0 2px 4px rgba(0, 0, 0, 0.08),
        0 8px 16px rgba(0, 0, 0, 0.10),
        0 16px 32px rgba(0, 0, 0, 0.14) !important;
}

/* Hide the empty col-2 wrapper — modern WC puts everything in col-1,
   but #customer_details still renders the empty col-2 div which our
   v0.66.188 CSS styled as a card → the "empty narrow box" Karl saw. */
.dnlc-woo-checkout-wrap .col2-set .col-2:empty,
.dnlc-woo-checkout-wrap #customer_details .col-2:empty {
    display: none !important;
}
/* Also hide if col-2 only has whitespace/comments and no visible elements */
.dnlc-woo-checkout-wrap .col2-set .col-2:not(:has(*)),
.dnlc-woo-checkout-wrap #customer_details .col-2:not(:has(*)) {
    display: none !important;
}

/* Hide shipping-fields wrapper when the actual ship-to-different
   form is collapsed — keeps "Ship to a different address" toggle
   visible but doesn't render an empty card */
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 0 14px !important;
}
/* Only re-apply card styling when ship-to-different is actually checked
   (shipping_address visible) */
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields:has(.shipping_address:not([style*="display: none"])) {
    background: #fff !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
}

/* "Ship to a different address" toggle h3 — clean inline look */
.dnlc-woo-checkout-wrap #ship-to-different-address {
    background: #fff !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 10px !important;
    padding: 14px 20px !important;
    margin: 0 0 14px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08) !important;
    font-size: 15px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    cursor: pointer;
}
.dnlc-woo-checkout-wrap #ship-to-different-address-checkbox {
    margin-right: 8px;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.190: shipping prominence + privacy text hidden + ship-to-
 * different toggle as proper card
 * ═══════════════════════════════════════════════════════════════════ */

/* (1) Hide privacy policy text as a CSS fallback (PHP filters
   already empty it but the wrapper paragraph could remain) */
.dnlc-woo-checkout-wrap .woocommerce-privacy-policy-text,
.dnlc-woo-checkout-wrap .privacy-policy-link,
.dnlc-woo-checkout-wrap p:has(> .woocommerce-privacy-policy-link),
.dnlc-woo-checkout-wrap .woocommerce-checkout p:empty {
    display: none !important;
}

/* (2) Shipping method row in order_review = its own prominent block */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping {
    background: #fffbeb !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping td {
    padding: 16px 14px !important;
    background: #fffbeb !important;
    border-top: 2px solid #fde68a !important;
    border-bottom: 2px solid #fde68a !important;
    font-size: 15px !important;
    vertical-align: middle !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th {
    color: #92400e !important;
    font-weight: 700 !important;
    width: 35%;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th::before {
    content: "🚚 ";
    margin-right: 4px;
}
.dnlc-woo-checkout-wrap #order_review ul#shipping_method {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.dnlc-woo-checkout-wrap #order_review ul#shipping_method li {
    padding: 6px 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
}
.dnlc-woo-checkout-wrap #order_review ul#shipping_method li label {
    font-size: 15px !important;
    font-weight: 500 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
}
.dnlc-woo-checkout-wrap #order_review ul#shipping_method input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    accent-color: #c79a52 !important;
    cursor: pointer !important;
}

/* (3) Ship-to-different-address — bigger, friendlier */
.dnlc-woo-checkout-wrap #ship-to-different-address {
    background: #fff !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 10px !important;
    padding: 18px 22px !important;
    margin: 0 0 14px !important;
    font-size: 16px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08) !important;
    transition: box-shadow 0.2s ease;
}
.dnlc-woo-checkout-wrap #ship-to-different-address:hover {
    box-shadow:
        0 0 0 1px rgba(37, 99, 235, 0.15),
        0 2px 4px rgba(0, 0, 0, 0.08),
        0 8px 16px rgba(0, 0, 0, 0.10) !important;
}
.dnlc-woo-checkout-wrap #ship-to-different-address label {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 0 !important;
    cursor: pointer !important;
}
.dnlc-woo-checkout-wrap #ship-to-different-address-checkbox {
    width: 20px !important;
    height: 20px !important;
    margin: 0 !important;
    accent-color: #c79a52 !important;
    cursor: pointer !important;
}
.dnlc-woo-checkout-wrap #ship-to-different-address span {
    flex: 1;
}
/* Add a hint after the label via pseudo content */
.dnlc-woo-checkout-wrap #ship-to-different-address::after {
    content: "Tick the box above to enter a separate shipping address";
    display: block !important;
    margin-top: 6px !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: #64748b !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.191: Match the "Know something about this entry?" box
 * recipe — #bfdbfe blue tint, #60a5fa border. Karl wants ALL cart
 * + checkout sections to look like that one specific box.
 * Overrides v0.66.188–.190 white-card styling.
 * ═══════════════════════════════════════════════════════════════════ */

/* Each major section: blue-tinted card (Know-Something recipe) */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields,
.dnlc-woo-checkout-wrap #order_review,
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields,
.dnlc-woo-cart-wrap .woocommerce-cart-form,
.dnlc-woo-cart-wrap .cart_totals,
.dnlc-woo-cart-wrap .cross-sells {
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
    border-left: 1px solid #60a5fa !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    margin-bottom: 14px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
}

/* Shipping fields wrapper — same blue when actively shown */
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields:has(.shipping_address:not([style*="display: none"])) {
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
}

/* Hover lift — slightly stronger blue ring */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields:hover,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields:hover,
.dnlc-woo-checkout-wrap #order_review:hover,
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields:hover,
.dnlc-woo-cart-wrap .woocommerce-cart-form:hover,
.dnlc-woo-cart-wrap .cart_totals:hover {
    box-shadow:
        0 0 0 1px rgba(96, 165, 250, 0.40),
        0 2px 4px rgba(0, 0, 0, 0.08),
        0 8px 16px rgba(0, 0, 0, 0.10),
        0 16px 32px rgba(0, 0, 0, 0.14) !important;
}

/* Form inputs: white background contrasts with blue card */
.dnlc-woo-checkout-wrap .form-row input.input-text,
.dnlc-woo-checkout-wrap .form-row textarea,
.dnlc-woo-checkout-wrap .form-row .select2-container--default .select2-selection--single {
    background: #ffffff !important;
    border: 1px solid #93c5fd !important;
}
.dnlc-woo-checkout-wrap .form-row input.input-text:focus,
.dnlc-woo-checkout-wrap .form-row textarea:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15) !important;
    outline: 0 !important;
}

/* Section H3 — match Know-Something heading (15px, no bottom border now) */
.dnlc-woo-checkout-wrap .woocommerce-billing-fields > h3,
.dnlc-woo-checkout-wrap .woocommerce-additional-fields > h3,
.dnlc-woo-checkout-wrap .woocommerce-shipping-fields > h3,
.dnlc-woo-checkout-wrap #order_review_heading {
    margin: 0 0 12px !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    background: transparent !important;
}

/* Order Review needs distinct accent — keep blue but darker headline color */
.dnlc-woo-checkout-wrap #order_review_heading {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
}

/* IBC stays slightly lighter (lighter blue) for hierarchy distinction */
.dnlc-woo-checkout-wrap #dnlc-ibc-checkout-fields {
    background: #dbeafe !important; /* slightly lighter than #bfdbfe */
    border: 1px solid #60a5fa !important;
}

/* "Place Order" button — dark-blue solid like the "Submit" button
   in the Know-Something form */
.dnlc-woo-checkout-wrap #place_order,
.dnlc-woo-cart-wrap .checkout-button {
    background: var(--dnlc-accent,#2c3e50) !important; /* deep blue (matches dnlc-btn-primary) */
    color: #fff !important;
    border: 0 !important;
    border-radius: 6px !important;
    padding: 14px 22px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: background 0.15s ease, transform 0.15s ease !important;
}
.dnlc-woo-checkout-wrap #place_order:hover,
.dnlc-woo-cart-wrap .checkout-button:hover {
    background: #1d4ed8 !important;
    transform: translateY(-1px) !important;
}

/* Cart table inside the blue card — transparent so it inherits blue */
.dnlc-woo-cart-wrap .shop_table.cart {
    background: transparent !important;
    border: 0 !important;
}
.dnlc-woo-cart-wrap .shop_table.cart thead th {
    background: rgba(255, 255, 255, 0.5) !important;
    border-bottom: 1px solid #60a5fa !important;
}
.dnlc-woo-cart-wrap .shop_table.cart tbody td {
    background: transparent !important;
    border-bottom: 1px solid rgba(96, 165, 250, 0.30) !important;
}

/* Order Review table inside blue card */
.dnlc-woo-checkout-wrap #order_review .shop_table {
    background: transparent !important;
    border: 0 !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table th,
.dnlc-woo-checkout-wrap #order_review .shop_table td {
    background: transparent !important;
    border-bottom: 1px solid rgba(96, 165, 250, 0.30) !important;
}

/* Payment block — white box inside the blue review card */
.dnlc-woo-checkout-wrap #payment {
    background: #ffffff !important;
    border: 1px solid #93c5fd !important;
    border-radius: 6px !important;
    padding: 16px !important;
    margin: 16px 0 !important;
}
.dnlc-woo-checkout-wrap #payment ul.payment_methods li {
    background: #f8fafc !important;
    border: 1px solid #93c5fd !important;
}

/* Ship-to-different toggle: blue card too */
.dnlc-woo-checkout-wrap #ship-to-different-address {
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.192: shipping row — drop the v0.66.190 truck emoji + amber
 * frame. The whole row sits inside the blue order_review card now,
 * so the amber border looked wrong + the emoji was kitschy.
 * ═══════════════════════════════════════════════════════════════════ */

/* Override v0.66.190's amber styling — transparent + blue accents */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping {
    background: transparent !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping td {
    background: transparent !important;
    border-top: 1px solid rgba(96, 165, 250, 0.40) !important;
    border-bottom: 1px solid rgba(96, 165, 250, 0.40) !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    padding: 14px 8px !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th {
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 700 !important;
}
/* Kill the truck emoji from v0.66.190 */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th::before {
    content: none !important;
}

/* Shipping method radio buttons stay in CR-Gold? No — switch to blue
   to match the new colour palette */
.dnlc-woo-checkout-wrap #order_review ul#shipping_method input[type="radio"] {
    accent-color: #2563eb !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.193: shipping row styled like the IBC box (lighter blue
 * card-like cell) + container breathing room from page edges
 * ═══════════════════════════════════════════════════════════════════ */

/* Container: less wide, more side padding — kein Rand-Klemmen mehr */
.dnlc-woo-checkout-wrap,
.dnlc-woo-cart-wrap {
    max-width: 1040px !important;
    margin: 0 auto !important;
    padding: 0 32px !important;
}
@media (max-width: 768px) {
    .dnlc-woo-checkout-wrap,
    .dnlc-woo-cart-wrap {
        padding: 0 16px !important;
    }
}

/* Shipping row: same lighter-blue treatment as IBC box (#dbeafe +
   #60a5fa border), distinct from the order-review table flow. */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping {
    background: transparent !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping td {
    background: #dbeafe !important;
    border-top: 1px solid #60a5fa !important;
    border-bottom: 1px solid #60a5fa !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    padding: 18px 16px !important;
    font-weight: 600 !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th {
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 700 !important;
    text-transform: none !important;
    font-size: 15px !important;
    letter-spacing: 0 !important;
}
/* Round the corners on the outer cells via first/last */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th {
    border-left: 1px solid #60a5fa !important;
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping td {
    border-right: 1px solid #60a5fa !important;
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px;
}

/* Truck emoji: stays killed */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th::before {
    content: none !important;
}

/* Shipping method label inside the row */
.dnlc-woo-checkout-wrap #order_review ul#shipping_method li label {
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 500 !important;
}

/* Subtotal + Total rows in order_review — neutral, transparent,
   no special background so the blue shipping row stands out */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.cart-subtotal,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total {
    background: transparent !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.cart-subtotal th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.cart-subtotal td,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total td {
    background: transparent !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.195: container tighter + TOTAL row prominent
 * ═══════════════════════════════════════════════════════════════════ */

/* Even more breathing room from the page edge — Enfold's full-width
   container was giving us more horizontal real-estate than needed */
.dnlc-woo-checkout-wrap,
.dnlc-woo-cart-wrap {
    max-width: 920px !important;
    margin: 0 auto !important;
    padding: 0 24px !important;
}
@media (min-width: 1200px) {
    .dnlc-woo-checkout-wrap,
    .dnlc-woo-cart-wrap {
        max-width: 960px !important;
        padding: 0 0 !important;
    }
}
@media (max-width: 768px) {
    .dnlc-woo-checkout-wrap,
    .dnlc-woo-cart-wrap {
        max-width: 100% !important;
        padding: 0 12px !important;
    }
}

/* Order Total row — prominent: bigger font, bold, distinct treatment */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total {
    background: transparent !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total td {
    background: rgba(255, 255, 255, 0.55) !important;
    border-top: 2px solid #60a5fa !important;
    border-bottom: 2px solid #60a5fa !important;
    padding: 18px 16px !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    letter-spacing: 0.3px !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total th {
    color: var(--dnlc-accent,#2c3e50) !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-size: 18px !important;
}
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total td .amount,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total td strong {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}

/* Same treatment for cart totals page */
.dnlc-woo-cart-wrap .cart_totals .shop_table tr.order-total th,
.dnlc-woo-cart-wrap .cart_totals .shop_table tr.order-total td {
    padding: 18px 12px !important;
    border-top: 2px solid #60a5fa !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}
.dnlc-woo-cart-wrap .cart_totals .shop_table tr.order-total td .amount,
.dnlc-woo-cart-wrap .cart_totals .shop_table tr.order-total td strong {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.196: padding inside the order_review + cart tables —
 * text was sitting right against the cell edges
 * ═══════════════════════════════════════════════════════════════════ */

/* Order Review table — all cells get proper padding */
.dnlc-woo-checkout-wrap #order_review .shop_table th,
.dnlc-woo-checkout-wrap #order_review .shop_table td {
    padding: 14px 18px !important;
}

/* Cart table — all cells get proper padding */
.dnlc-woo-cart-wrap .shop_table.cart th,
.dnlc-woo-cart-wrap .shop_table.cart td {
    padding: 16px 20px !important;
}

/* Cart totals table */
.dnlc-woo-cart-wrap .cart_totals .shop_table th,
.dnlc-woo-cart-wrap .cart_totals .shop_table td {
    padding: 12px 16px !important;
}

/* But preserve our v0.66.193 IBC-style shipping row padding */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.shipping td {
    padding: 18px 18px !important;
}

/* And v0.66.195 prominent TOTAL row padding */
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total th,
.dnlc-woo-checkout-wrap #order_review .shop_table tr.order-total td,
.dnlc-woo-cart-wrap .cart_totals .shop_table tr.order-total th,
.dnlc-woo-cart-wrap .cart_totals .shop_table tr.order-total td {
    padding: 18px 18px !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.197: Cart 2-Spalten-Layout — Items LINKS, Totals RECHTS
 * + cart_totals als echte Card sicherstellen
 * ═══════════════════════════════════════════════════════════════════ */

/* The cart wrap is a CSS Grid: heading on top (full-width), then
   cart-items left + cart-totals right side-by-side, cross-sells
   below both. */
.dnlc-woo-cart-wrap {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 340px !important;
    grid-template-areas:
        "heading heading"
        "items   totals"
        "sells   sells" !important;
    gap: 24px 32px !important;
    align-items: start !important;
}

.dnlc-woo-cart-wrap > .dnlc-woo-heading {
    grid-area: heading !important;
}
.dnlc-woo-cart-wrap > .woocommerce,
.dnlc-woo-cart-wrap > .woocommerce-notices-wrapper {
    /* WC sometimes wraps its output in a .woocommerce div — let it
       flow normally inside the grid */
    grid-area: items !important;
    display: contents !important;
}

.dnlc-woo-cart-wrap .woocommerce-cart-form {
    grid-area: items !important;
}
.dnlc-woo-cart-wrap .cart-collaterals {
    /* Break cart-collaterals open so its children (cross-sells +
       cart_totals) can take their own grid positions */
    display: contents !important;
}
.dnlc-woo-cart-wrap .cart-collaterals .cart_totals {
    grid-area: totals !important;
    align-self: start !important;
    position: sticky;
    top: 24px;
    /* Re-affirm card styling with extra specificity */
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
    margin: 0 !important;
    width: auto !important;
    float: none !important;
}
.dnlc-woo-cart-wrap .cart-collaterals .cart_totals h2 {
    margin: 0 0 14px !important;
    padding: 0 !important;
    border: 0 !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}
.dnlc-woo-cart-wrap .cart-collaterals .cross-sells {
    grid-area: sells !important;
    margin: 0 !important;
}

/* Mobile: stack to single column */
@media (max-width: 900px) {
    .dnlc-woo-cart-wrap {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "heading"
            "items"
            "totals"
            "sells" !important;
    }
    .dnlc-woo-cart-wrap .cart-collaterals .cart_totals {
        position: static !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.198: Cart layout revert — die 2-Spalten-Variante aus v0.66.197
 * hat den Cart-Items-Table zu eng gemacht. Zurück zum klassischen WC:
 * Cart items FULL-WIDTH oben, dann cart-collaterals darunter mit
 * cart_totals als 360px Card RECHTS, cross-sells links daneben.
 * ═══════════════════════════════════════════════════════════════════ */

/* Cancel the v0.66.197 grid */
.dnlc-woo-cart-wrap {
    display: block !important;
    grid-template-columns: none !important;
    grid-template-areas: none !important;
}

.dnlc-woo-cart-wrap > .dnlc-woo-heading,
.dnlc-woo-cart-wrap .woocommerce-cart-form {
    grid-area: auto !important;
}

/* Cart items: full width on top */
.dnlc-woo-cart-wrap .woocommerce-cart-form {
    width: 100% !important;
    margin: 0 0 24px !important;
    clear: both;
}

/* Cart collaterals row: flex with cart_totals on the right */
.dnlc-woo-cart-wrap .cart-collaterals {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: row-reverse !important;
    gap: 24px !important;
    align-items: flex-start !important;
    margin: 0 !important;
    grid-area: auto !important;
}

/* Cart totals: 360px on the right (or alone right-aligned) */
.dnlc-woo-cart-wrap .cart-collaterals .cart_totals {
    flex: 0 0 360px !important;
    max-width: 360px !important;
    width: 360px !important;
    margin: 0 !important;
    position: static !important; /* kill the sticky from v0.66.197 */
    grid-area: auto !important;
    /* Re-affirm card styling */
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
}

/* Cross-sells: left, fills remaining space */
.dnlc-woo-cart-wrap .cart-collaterals .cross-sells {
    flex: 1 1 320px !important;
    min-width: 320px !important;
    width: auto !important;
    margin: 0 !important;
    grid-area: auto !important;
}

/* Mobile: stack column */
@media (max-width: 768px) {
    .dnlc-woo-cart-wrap .cart-collaterals {
        flex-direction: column !important;
    }
    .dnlc-woo-cart-wrap .cart-collaterals .cart_totals,
    .dnlc-woo-cart-wrap .cart-collaterals .cross-sells {
        flex: 1 1 100% !important;
        width: 100% !important;
        max-width: 100% !important;
    }
}

/* Wider container for cart so the items table fits comfortably */
.dnlc-woo-cart-wrap {
    max-width: 1100px !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.199: Cart IBC card — for Express Checkout (Apple/Google Pay)
 * flows that skip the regular checkout form
 * ═══════════════════════════════════════════════════════════════════ */
.dnlc-cart-ibc-card {
    background: #dbeafe !important;
    border: 1px solid #60a5fa !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    margin: 0 0 24px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
}
.dnlc-cart-ibc-card h3 {
    margin: 0 0 10px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}
.dnlc-cart-ibc-card > p {
    margin: 0 0 18px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}
.dnlc-cart-ibc-card > p strong {
    color: var(--dnlc-accent,#2c3e50) !important;
}
.dnlc-cart-ibc-row {
    margin: 0 0 14px !important;
}
.dnlc-cart-ibc-row label {
    display: block !important;
    margin: 0 0 5px !important;
    font-weight: 500 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-size: 13px !important;
}
.dnlc-cart-ibc-input {
    width: 100% !important;
    padding: 11px 14px !important;
    border: 1px solid #93c5fd !important;
    border-radius: 6px !important;
    background: #ffffff !important;
    font-size: 15px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    box-sizing: border-box !important;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.dnlc-cart-ibc-input::placeholder {
    color: #94a3b8 !important;
}
.dnlc-cart-ibc-input:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15) !important;
    outline: 0 !important;
}
.dnlc-cart-ibc-status {
    margin: 6px 0 0 !important;
    min-height: 18px !important;
    font-size: 13px !important;
    color: #16a34a !important;
    font-weight: 500 !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.200: Cart IBC card compact — max-width + 2-column inputs
 * ═══════════════════════════════════════════════════════════════════ */
.dnlc-cart-ibc-card {
    max-width: 720px !important;
    margin: 0 auto 24px !important;
}
.dnlc-cart-ibc-form-row {
    display: flex !important;
    gap: 16px !important;
    flex-wrap: wrap !important;
}
.dnlc-cart-ibc-form-row .dnlc-cart-ibc-row {
    flex: 1 1 240px !important;
    min-width: 0 !important;
    margin: 0 !important;
}
@media (max-width: 600px) {
    .dnlc-cart-ibc-form-row .dnlc-cart-ibc-row {
        flex: 1 1 100% !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.201: IBC card sits BELOW the cart items table, RIGHT-aligned,
 * inside the cart-form box — looks like a "closing" section of the cart.
 * Update Cart row gets extra spacing so the two together feel like a
 * deliberate end-of-cart group.
 * ═══════════════════════════════════════════════════════════════════ */

/* Override v0.66.200's centered 720px layout — now LEFT-aligned 460px */
.dnlc-cart-ibc-card {
    max-width: 460px !important;
    margin: 24px auto 0 0 !important;  /* push left within parent */
    /* Lighter inner card so it nests visually inside the blue cart-form */
    background: #ffffff !important;
    border: 1px solid #93c5fd !important;
    padding: 18px 20px !important;
}
.dnlc-cart-ibc-card h3 {
    font-size: 16px !important;
    margin: 0 0 6px !important;
}
.dnlc-cart-ibc-card > p {
    font-size: 13px !important;
    margin: 0 0 14px !important;
    line-height: 1.45 !important;
}
.dnlc-cart-ibc-form-row {
    flex-direction: column !important; /* stack within the narrower card */
    gap: 10px !important;
}
.dnlc-cart-ibc-form-row .dnlc-cart-ibc-row {
    flex: 1 1 100% !important;
}
.dnlc-cart-ibc-card .dnlc-cart-ibc-input {
    padding: 9px 12px !important;
    font-size: 14px !important;
}
.dnlc-cart-ibc-card .dnlc-cart-ibc-row label {
    font-size: 12px !important;
}

/* Cart actions row (coupon + Update cart) — extra top/bottom space so
   together with the IBC card below it forms a clear "closing" group */
.dnlc-woo-cart-wrap .shop_table.cart .actions {
    padding: 20px !important;
    background: rgba(255, 255, 255, 0.45) !important;
}

/* Cart-form box bottom gets a touch more padding so the IBC card has
   breathing room before the box ends */
.dnlc-woo-cart-wrap .woocommerce-cart-form {
    padding-bottom: 24px !important;
}

@media (max-width: 768px) {
    .dnlc-cart-ibc-card {
        max-width: 100% !important;
        margin-right: 0 !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.202: Cart bottom group — IBC card (left) + cart_totals (right)
 * sit side-by-side inside the cart-form, as a closing summary section.
 * JS in CR_Woo_Shortcodes pulls .cart_totals out of .cart-collaterals
 * and places it inside .dnlc-cart-bottom-group beside the IBC card.
 * ═══════════════════════════════════════════════════════════════════ */

.dnlc-cart-bottom-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
    margin: 24px 0 0 !important;
    align-items: stretch !important;
}

.dnlc-cart-bottom-group .dnlc-cart-ibc-card {
    flex: 1 1 360px !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
}

.dnlc-cart-bottom-group .cart_totals {
    flex: 1 1 320px !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    width: auto !important;
    /* Override v0.66.198's standalone cart_totals styling — when
       inside the bottom-group it nests in the blue cart-form, so
       white inner card with light-blue border */
    background: #ffffff !important;
    border: 1px solid #93c5fd !important;
    border-radius: 10px !important;
    padding: 18px 20px !important;
    box-shadow: none !important;
    position: static !important;
    float: none !important;
}

.dnlc-cart-bottom-group .cart_totals h2 {
    margin: 0 0 12px !important;
    padding: 0 0 10px !important;
    font-size: 16px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    border-bottom: 1px solid #cbd5e1 !important;
}

.dnlc-cart-bottom-group .cart_totals .shop_table th,
.dnlc-cart-bottom-group .cart_totals .shop_table td {
    padding: 8px 10px !important;
    font-size: 13px !important;
}
.dnlc-cart-bottom-group .cart_totals .shop_table tr.order-total th,
.dnlc-cart-bottom-group .cart_totals .shop_table tr.order-total td {
    padding: 14px 10px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    border-top: 2px solid #93c5fd !important;
}
.dnlc-cart-bottom-group .cart_totals .shop_table tr.order-total td .amount {
    font-size: 18px !important;
}

.dnlc-cart-bottom-group .wc-proceed-to-checkout {
    margin-top: 12px !important;
    padding: 0 !important;
}
.dnlc-cart-bottom-group .checkout-button {
    padding: 12px 16px !important;
    font-size: 14px !important;
}

/* When cart-collaterals has lost its cart_totals child it may render
   as an empty box — hide it cleanly */
.dnlc-woo-cart-wrap .cart-collaterals:not(:has(.cart_totals)):not(:has(.cross-sells .cross-sells)) {
    display: none !important;
}

/* Mobile: stack the bottom group */
@media (max-width: 768px) {
    .dnlc-cart-bottom-group {
        flex-direction: column !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.207: Order-received (thank-you) page styling — die Page rendert
 * im selben [woocommerce_checkout] Shortcode, also auch innerhalb
 * .dnlc-woo-checkout-wrap, aber mit komplett anderen HTML-Klassen als
 * das Checkout-Form.
 * ═══════════════════════════════════════════════════════════════════ */

/* Hide back-to-cart on order-received — kein sinnvoller Link mehr */
body.woocommerce-order-received .dnlc-back-to-cart,
.dnlc-woo-checkout-wrap:has(.woocommerce-order) .dnlc-back-to-cart {
    display: none !important;
}

/* Thank-you message — grüne Success-Card oben */
.dnlc-woo-checkout-wrap .woocommerce-thankyou-order-received,
.dnlc-woo-checkout-wrap p.woocommerce-thankyou-order-received {
    background: #f0fdf4 !important;
    border: 1px solid #86efac !important;
    border-left: 3px solid #16a34a !important;
    border-radius: 10px !important;
    padding: 16px 22px !important;
    margin: 0 0 20px !important;
    color: #14532d !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08) !important;
}

/* Order overview — die ul mit ORDER NUMBER, DATE, EMAIL, TOTAL, PAYMENT METHOD */
.dnlc-woo-checkout-wrap ul.woocommerce-order-overview,
.dnlc-woo-checkout-wrap .woocommerce-order-overview {
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
    border-radius: 10px !important;
    padding: 22px 28px !important;
    margin: 0 0 24px !important;
    list-style: none !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px 32px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
}
.dnlc-woo-checkout-wrap .woocommerce-order-overview li {
    flex: 1 1 180px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    list-style: none !important;
    text-transform: uppercase !important;
    font-size: 11px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    letter-spacing: 0.5px !important;
    font-weight: 500 !important;
}
.dnlc-woo-checkout-wrap .woocommerce-order-overview li strong {
    display: block !important;
    margin-top: 4px !important;
    font-size: 17px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 700 !important;
}

/* Section headings "Order details" / "Billing address" / "Shipping address" */
.dnlc-woo-checkout-wrap .woocommerce-order-details > h2,
.dnlc-woo-checkout-wrap .woocommerce-customer-details > h2,
.dnlc-woo-checkout-wrap section.woocommerce-order-details > h2,
.dnlc-woo-checkout-wrap section.woocommerce-customer-details > h2 {
    margin: 0 0 16px !important;
    padding: 0 0 12px !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    border-bottom: 1px solid #93c5fd !important;
    text-transform: none !important;
}

/* Order details + customer details sections als blaue Cards */
.dnlc-woo-checkout-wrap .woocommerce-order-details,
.dnlc-woo-checkout-wrap .woocommerce-customer-details,
.dnlc-woo-checkout-wrap section.woocommerce-order-details,
.dnlc-woo-checkout-wrap section.woocommerce-customer-details {
    background: #bfdbfe !important;
    border: 1px solid #60a5fa !important;
    border-radius: 10px !important;
    padding: 22px 24px !important;
    margin: 0 0 24px !important;
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, 0.04),
        0 1px 2px rgba(0, 0, 0, 0.06),
        0 4px 8px rgba(0, 0, 0, 0.08),
        0 10px 24px rgba(0, 0, 0, 0.10) !important;
}

/* Order details table inside the blue card */
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details {
    background: transparent !important;
    border: 0 !important;
    width: 100% !important;
    margin: 0 !important;
}
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table thead th,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details thead th {
    background: rgba(255, 255, 255, 0.55) !important;
    border-bottom: 1px solid #60a5fa !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    font-weight: 700 !important;
    padding: 12px 16px !important;
    text-transform: uppercase !important;
    font-size: 12px !important;
    letter-spacing: 0.5px !important;
}
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table tbody td,
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table tfoot td,
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table tfoot th,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details tbody td,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details tfoot td,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details tfoot th {
    background: transparent !important;
    border-bottom: 1px solid rgba(96, 165, 250, 0.40) !important;
    padding: 12px 16px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}

/* TOTAL row in order-details prominent (matches checkout) */
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table tfoot tr:last-child th,
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table tfoot tr:last-child td,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details tfoot tr:last-child th,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details tfoot tr:last-child td {
    background: rgba(255, 255, 255, 0.55) !important;
    border-top: 2px solid #60a5fa !important;
    padding: 16px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--dnlc-accent,#2c3e50) !important;
}
.dnlc-woo-checkout-wrap .woocommerce-order-details .shop_table tfoot tr:last-child td .amount,
.dnlc-woo-checkout-wrap .woocommerce-table--order-details tfoot tr:last-child td .amount {
    color: var(--dnlc-accent,#2c3e50) !important;
    font-size: 18px !important;
    font-weight: 800 !important;
}

/* Customer details address blocks — weiße Sub-Cards in der blauen */
.dnlc-woo-checkout-wrap .woocommerce-customer-details .woocommerce-columns,
.dnlc-woo-checkout-wrap .woocommerce-customer-details .woocommerce-column {
    margin: 0 !important;
}
.dnlc-woo-checkout-wrap .woocommerce-customer-details address,
.dnlc-woo-checkout-wrap .woocommerce-customer-details .woocommerce-column address {
    background: #ffffff !important;
    border: 1px solid #93c5fd !important;
    border-radius: 6px !important;
    padding: 14px 18px !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    line-height: 1.5 !important;
    font-style: normal !important;
}
.dnlc-woo-checkout-wrap .woocommerce-customer-details h3 {
    font-size: 14px !important;
    text-transform: uppercase !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    letter-spacing: 0.5px !important;
    margin: 0 0 8px !important;
    border: 0 !important;
    padding: 0 !important;
}

/* WC-order wrapper resets — sometimes adds padding */
.dnlc-woo-checkout-wrap .woocommerce-order {
    margin: 0 !important;
    padding: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.209: PDF Download Button on order-received page
 * ═══════════════════════════════════════════════════════════════════ */
.dnlc-pdf-download {
    text-align: center;
    margin: 24px 0 !important;
}
.dnlc-pdf-download-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 14px 28px !important;
    background: var(--dnlc-accent,#2c3e50) !important;
    color: #ffffff !important;
    border: 0 !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    letter-spacing: 0.3px !important;
    transition: background 0.2s ease, transform 0.15s ease !important;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.08),
        0 4px 8px rgba(0, 0, 0, 0.10) !important;
}
.dnlc-pdf-download-btn:hover {
    background: var(--dnlc-accent-hover,#1e3a4d) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
    text-decoration: none !important;
}

/* ═══════════════════════════════════════════════════════════════════
 * v0.66.210: Order-received Actions Bar (PDF Download + Print)
 * ═══════════════════════════════════════════════════════════════════ */
.dnlc-order-actions {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 14px;
    margin: 28px 0 !important;
    flex-wrap: wrap;
}

.dnlc-print-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 14px 28px !important;
    background: #ffffff !important;
    color: var(--dnlc-accent,#2c3e50) !important;
    border: 2px solid var(--dnlc-accent,#2c3e50) !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    letter-spacing: 0.3px !important;
    cursor: pointer !important;
    transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease !important;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.08),
        0 4px 8px rgba(0, 0, 0, 0.10) !important;
    font-family: inherit !important;
}
.dnlc-print-btn:hover {
    background: var(--dnlc-accent,#2c3e50) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
}

/* Hide actions when printing */
@media print {
    .dnlc-order-actions { display: none !important; }
    .dnlc-back-to-cart  { display: none !important; }
    .site-header,
    .header_bg,
    #top .header_bg,
    .av_header_transparency,
    #main_menu,
    .av_my_account_link,
    .av_phone_active_left,
    footer { display: none !important; }
}
