/*
Theme Name: Hello Elementor Child
Template: hello-elementor
Version: 1.0
*/



/* =========================================================
   PROARGUMENT – WEBSITE CSS
   Bereich: Checkout + Thank You + Seminarticket
   Für: Hello Elementor Child Theme
   ========================================================= */


/* =========================================================
   1) CHECKOUT – GRUNDLAYOUT
   ========================================================= */

body.woocommerce-checkout .woocommerce {
    max-width: 1200px;
    margin: 0 auto;
}

body.woocommerce-checkout form.checkout {
    display: grid;
    grid-template-columns: minmax(0, 0.84fr) minmax(470px, 1fr);
    grid-template-areas:
        "customer ordertitle"
        "customer orderbox";
    gap: 36px;
    align-items: start;
}

body.woocommerce-checkout #customer_details {
    grid-area: customer;
    width: 100%;
    float: none !important;
}

body.woocommerce-checkout #order_review_heading {
    grid-area: ordertitle;
    width: 100%;
    margin: 0 0 8px 0;
    float: none !important;
    clear: none !important;
}

body.woocommerce-checkout #order_review {
    grid-area: orderbox;
    width: 100%;
    float: none !important;
    clear: none !important;
    box-sizing: border-box;
    background: #ffffff;
    border: 1px solid #e8e8ee;
    border-radius: 18px;
    padding: 22px;
    box-shadow: 0 12px 30px rgba(20, 20, 43, 0.05);
}

/* WooCommerce-Floats neutralisieren */
body.woocommerce-checkout .col2-set,
body.woocommerce-checkout .col-1,
body.woocommerce-checkout .col-2 {
    width: 100% !important;
    float: none !important;
}

body.woocommerce-checkout input,
body.woocommerce-checkout select,
body.woocommerce-checkout textarea {
    box-sizing: border-box;
}


/* =========================================================
   2) CHECKOUT – BESTELLÜBERSICHT / PRODUKTBOX
   ========================================================= */

body.woocommerce-checkout .woocommerce-checkout-review-order-table {
    width: 100% !important;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    margin-bottom: 18px;
    font-size: 15px;
    border-radius: 10px;
    overflow: hidden;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table thead {
    display: none;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tbody {
    display: block;
    width: 100%;
    background: transparent !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table td {
    padding: 14px 18px;
    vertical-align: middle;
    box-sizing: border-box;
    border: 1px solid #d9dfe8 !important;
    background: #ffffff !important;
}

/* Produktkasten */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item {
    display: block !important;
    width: 100% !important;
    margin-bottom: 12px !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item td.product-name {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 20px !important;
    box-sizing: border-box !important;

    background: #EFF5FF !important;
    border: 1px solid #EFF5FF !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    outline: none !important;

    font-size: 17px !important;
    line-height: 1.5 !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item td.product-name * {
    color: #1a1a1a !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item td.product-total {
    display: none !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table .product-quantity,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .product-quantity * {
    display: block !important;
    margin-top: 6px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #5f6b7a !important;
    opacity: 1 !important;
}

/* Zwischensumme / Steuer */
body.woocommerce-checkout .woocommerce-checkout-review-order-table .cart-subtotal th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .cart-subtotal td,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .tax-total th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .tax-total td,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.tax-rate th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.tax-rate td {
    font-size: 14px !important;
    font-weight: 400 !important;
    color: #555 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    background: #ffffff !important;
}

/* Steuerlabel umbenennen */
body.woocommerce-checkout .woocommerce-checkout-review-order-table .tax-total th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.tax-rate th {
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
    text-shadow: none !important;
    position: relative;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table .tax-total th::after,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.tax-rate th::after {
    content: "19 % MwSt.";
    color: #555 !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    font-weight: 400 !important;
    display: inline-block !important;
}

/* Gesamtsumme */
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total td,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total strong,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .amount {
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #111827 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    background: #ffffff !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total small,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .includes_tax,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .woocommerce-Price-currencyCode,
body.woocommerce-checkout .woocommerce-checkout-review-order-table .order-total .currency-code {
    display: none !important;
}


/* =========================================================
   3) CHECKOUT – ZAHLUNGSBEREICH
   ========================================================= */

body.woocommerce-checkout #payment {
    width: 100% !important;
    float: none !important;
    clear: none !important;
    box-sizing: border-box;
    margin-top: 18px;
    padding: 16px;
    background: #EFF5FF !important;
    border: 1px solid #dbe7ff !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 20px rgba(60, 100, 200, 0.08) !important;
}

body.woocommerce-checkout .wc_payment_methods {
    margin: 0 0 14px 0;
    padding: 0;
    list-style: none;
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method {
    position: relative;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > input[type="radio"] {
    position: absolute !important;
    top: 4px !important;
    left: 0 !important;
    margin: 0 !important;

    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border: 2px solid #9fb6e9;
    border-radius: 50%;
    background: #ffffff;
    cursor: pointer;
    box-shadow: 0 1px 2px rgba(20, 20, 43, 0.06);
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > input[type="radio"]:checked {
    border-color: #EB5C2B;
    background: #ffffff;
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > input[type="radio"]:checked::after {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #EB5C2B;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 0 0 28px !important;
    width: calc(100% - 28px) !important;
    min-width: 0 !important;
    line-height: 1.35 !important;
    font-weight: 500 !important;
    cursor: pointer;
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label .payment-method__label,
body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label .wcpay-payment-method-label,
body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label span:first-child {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label img,
body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label .payment-method__icon,
body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label .wcpay-payment-method__icon {
    margin-left: auto !important;
    flex: 0 0 auto !important;
    max-height: 18px !important;
    width: auto !important;
}

body.woocommerce-checkout .wc_payment_methods li.wc_payment_method .payment_box {
    margin: 10px 0 0 28px !important;
    padding: 14px 16px !important;
    background: #ffffff !important;
    border: 1px solid #dfe6f2 !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #6b7685 !important;
}

body.woocommerce-checkout .payment_box,
body.woocommerce-checkout .payment_box p,
body.woocommerce-checkout .payment_box label,
body.woocommerce-checkout .payment_box span,
body.woocommerce-checkout .payment_box div,
body.woocommerce-checkout .payment_box .wc-stripe-elements-field,
body.woocommerce-checkout .payment_box .wcpay-payment-method-label {
    font-family: inherit !important;
    color: #6b7685 !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
}

body.woocommerce-checkout .payment_box input,
body.woocommerce-checkout .payment_box select,
body.woocommerce-checkout .payment_box textarea {
    border: 1px solid #d7deea !important;
    border-radius: 10px !important;
    background: #ffffff !important;
    color: #3f4b5a !important;
    box-shadow: none !important;
    font-family: inherit !important;
}

body.woocommerce-checkout .payment_box input::placeholder,
body.woocommerce-checkout .payment_box textarea::placeholder {
    color: #8b96a5 !important;
    opacity: 1 !important;
}

body.woocommerce-checkout .payment_box input:focus,
body.woocommerce-checkout .payment_box select:focus,
body.woocommerce-checkout .payment_box textarea:focus {
    border-color: #B0CCFF !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(176, 204, 255, 0.18) !important;
}

body.woocommerce-checkout .payment_box::before,
body.woocommerce-checkout .payment_box::after {
    display: none !important;
}

body.woocommerce-checkout .woocommerce-privacy-policy-text {
    margin-top: 16px !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #555;
}

body.woocommerce-checkout .woocommerce-privacy-policy-text a {
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
    color: #5B7FFF !important;
    text-decoration: none !important;
}

body.woocommerce-checkout .woocommerce-privacy-policy-text a:hover {
    text-decoration: underline !important;
}

body.woocommerce-checkout #payment #place_order {
    width: 100%;
    padding: 16px 20px;
    border-radius: 12px !important;
    font-size: 16px;
    font-weight: 700;
    background: #EB5C2B !important;
    border: 1px solid #D94E1D !important;
    color: #ffffff !important;
    box-shadow: 0 8px 18px rgba(235, 92, 43, 0.22) !important;
    transition: all 0.2s ease !important;
}

body.woocommerce-checkout #payment #place_order:hover,
body.woocommerce-checkout #payment #place_order:focus {
    background: #D94E1D !important;
    border-color: #C84618 !important;
    box-shadow: 0 10px 22px rgba(235, 92, 43, 0.28) !important;
    transform: translateY(-1px);
}

body.woocommerce-checkout #payment #place_order:active {
    transform: translateY(0);
    box-shadow: 0 6px 14px rgba(235, 92, 43, 0.20) !important;
}


/* =========================================================
   4) CHECKOUT – TRUST BOX / LINKS
   ========================================================= */

.trust-box {
    background: #ffffff;
    border: 1px solid #ececf2;
    border-radius: 12px;
    padding: 12px 14px;
    margin: 14px 0 16px 0;
    font-size: 14px;
    line-height: 1.7;
}

.trust-box .trust-line {
    color: #1a1a1a !important;
    font-size: 14px;
    line-height: 1.7;
}

.trust-box .trust-icon {
    display: inline-block;
    width: 18px;
    margin-right: 6px;
    text-align: center;
    color: #1a1a1a;
    font-weight: 700;
}

.trust-box .trust-icon-green {
    color: #2e9b57 !important;
    -webkit-text-fill-color: #2e9b57 !important;
}

body.woocommerce-checkout a,
body.woocommerce-checkout .showcoupon {
    color: #4A6FA5 !important;
    text-decoration: none !important;
    font-weight: 500;
    text-transform: none !important;
}

body.woocommerce-checkout a:hover,
body.woocommerce-checkout .showcoupon:hover {
    color: #EB5C2B !important;
    text-decoration: underline !important;
}

body.woocommerce-checkout .showcoupon {
    border-bottom: 1px dashed rgba(74,111,165,0.4);
    padding-bottom: 2px;
}


/* =========================================================
   5) MOBILE – CHECKOUT
   ========================================================= */

@media (max-width: 767px) {
    body.woocommerce-checkout form.checkout {
        display: block;
    }

    body.woocommerce-checkout #customer_details,
    body.woocommerce-checkout #order_review_heading,
    body.woocommerce-checkout #order_review {
        width: 100%;
    }

    body.woocommerce-checkout #order_review_heading {
        margin-top: 32px !important;
    }

    body.woocommerce-checkout #order_review {
        padding: 18px !important;
        border-radius: 12px !important;
    }

    body.woocommerce-checkout #payment {
        padding: 18px 16px !important;
    }

    body.woocommerce-checkout .wc_payment_methods li.wc_payment_method {
        margin-bottom: 14px !important;
    }

    body.woocommerce-checkout .wc_payment_methods li.wc_payment_method > label {
        flex-wrap: wrap;
        align-items: flex-start !important;
    }

    body.woocommerce-checkout .payment_box {
        margin-top: 10px !important;
        margin-left: 0 !important;
        padding: 14px !important;
        border-radius: 12px !important;
    }

    body.woocommerce-checkout .payment_box p,
    body.woocommerce-checkout .payment_box label,
    body.woocommerce-checkout .payment_box span,
    body.woocommerce-checkout .payment_box div {
        font-size: 13px !important;
        line-height: 1.5 !important;
    }

    body.woocommerce-checkout .payment_box iframe,
    body.woocommerce-checkout .payment_box input,
    body.woocommerce-checkout .payment_box select,
    body.woocommerce-checkout .payment_box textarea {
        max-width: 100% !important;
    }

    body.woocommerce-checkout #payment #place_order {
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        padding: 16px 20px !important;
        line-height: 1.2 !important;
        min-height: 56px !important;
        white-space: normal !important;
        font-size: 15px !important;
        font-weight: 700 !important;
        letter-spacing: 0 !important;
    }

    .trust-box {
        margin-top: 14px !important;
        padding: 14px 16px !important;
    }
}


/* =========================================================
   6) THANK YOU PAGE
   ========================================================= */

/* Google Font */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap');

body.woocommerce-order-received {
    font-family: 'Montserrat', sans-serif !important;
}

body.woocommerce-order-received .woocommerce-order {
    max-width: 800px;
    margin: 0 auto;
}

body.woocommerce-order-received .thankyou-hero {
    text-align: center;
    max-width: 820px;
    margin: 50px auto 30px;
}

body.woocommerce-order-received .thankyou-hero,
body.woocommerce-order-received .thankyou-hero * {
    font-family: 'Montserrat', sans-serif !important;
}

body.woocommerce-order-received .thankyou-hero h1 {
    color: #72A3FF;
    font-size: 34px;
    line-height: 1.2;
    margin-bottom: 12px;
}

body.woocommerce-order-received .thankyou-hero p {
    font-size: 16px;
    line-height: 1.6;
    color: #4b5563;
    margin: 0 0 8px 0;
}

body.woocommerce-order-received .woocommerce-thankyou-order-received {
    display: none !important;
}

body.woocommerce-order-received .woocommerce-order p {
    font-size: 16px;
}

body.woocommerce-order-received .woocommerce-order-details,
body.woocommerce-order-received .woocommerce-customer-details {
    background: #ffffff;
    border-radius: 14px;
    padding: 25px;
    margin-bottom: 25px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

body.woocommerce-order-received .woocommerce-order-details {
    background: #EFF5FF !important;
    padding: 28px !important;
}

body.woocommerce-order-received .woocommerce-customer-details address {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    line-height: 1.6;
}

body.woocommerce-order-received .woocommerce-table {
    border: none !important;
}

body.woocommerce-order-received .woocommerce-table th,
body.woocommerce-order-received .woocommerce-table td {
    border: none !important;
    padding: 12px 0;
}

body.woocommerce-order-received .woocommerce-table tfoot tr:last-child {
    font-weight: bold;
}

body.woocommerce-order-received .woocommerce-table__product-name {
    font-weight: 500;
}

body.woocommerce-order-received .woocommerce-table__product-name a {
    pointer-events: none;
    text-decoration: none;
    color: inherit;
}

body.woocommerce-order-received .woocommerce-table thead th:last-child,
body.woocommerce-order-received .woocommerce-table__product-total {
    display: none !important;
}

/* Bestellübersicht oben als Grid */
body.woocommerce-order-received .woocommerce-order-overview {
    display: grid !important;
    grid-template-columns: max-content max-content max-content !important;
    grid-template-areas:
        "order date email"
        "total payment empty";
    column-gap: 42px !important;
    row-gap: 14px !important;
    justify-content: center !important;
    margin: 24px 0 36px !important;
    padding: 0 !important;
    list-style: none !important;
}

body.woocommerce-order-received .woocommerce-order-overview li {
    float: none !important;
    width: auto !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}

body.woocommerce-order-received .woocommerce-order-overview li::before,
body.woocommerce-order-received .woocommerce-order-overview li::after {
    display: none !important;
    content: none !important;
    border: 0 !important;
}

body.woocommerce-order-received .woocommerce-order-overview li:nth-child(1) { grid-area: order !important; }
body.woocommerce-order-received .woocommerce-order-overview li:nth-child(2) { grid-area: date !important; }
body.woocommerce-order-received .woocommerce-order-overview li:nth-child(3) { grid-area: email !important; }
body.woocommerce-order-received .woocommerce-order-overview li:nth-child(4) { grid-area: total !important; }
body.woocommerce-order-received .woocommerce-order-overview li:nth-child(5) { grid-area: payment !important; }


/* =========================================================
   7) HEADER / FOOTER AUF CHECKOUT + THANK YOU
   ========================================================= */

body.woocommerce-checkout .elementor-location-header a,
body.woocommerce-checkout .elementor-location-footer a,
body.woocommerce-order-received .elementor-location-header a,
body.woocommerce-order-received .elementor-location-footer a,
body.woocommerce-checkout .site-header a,
body.woocommerce-checkout .site-footer a,
body.woocommerce-order-received .site-header a,
body.woocommerce-order-received .site-footer a {
    color: #ffffff !important;
}

body.woocommerce-checkout .elementor-location-header .elementor-button,
body.woocommerce-checkout .elementor-location-footer .elementor-button,
body.woocommerce-order-received .elementor-location-header .elementor-button,
body.woocommerce-order-received .elementor-location-footer .elementor-button,
body.woocommerce-checkout .site-header .elementor-button,
body.woocommerce-checkout .site-footer .elementor-button,
body.woocommerce-order-received .site-header .elementor-button,
body.woocommerce-order-received .site-footer .elementor-button {
    color: #ffffff !important;
}

/* Inhaltslinks auf Checkout / Thank You */
body.woocommerce-checkout .thankyou-hero a,
body.woocommerce-order-received .thankyou-hero a,
body.woocommerce-checkout .woocommerce-order a,
body.woocommerce-order-received .woocommerce-order a {
    color: #72A3FF !important;
}


/* =========================================================
   8) SEMINARTICKET BOX
   ========================================================= */

.seminar-ticket-section {
    margin-top: 28px;
}

.seminar-ticket-heading {
    margin: 0 0 14px 0;
    font-size: 20px;
    font-weight: 600;
    line-height: 1.3;
    color: #1a1a1a;
}

.seminar-ticket-box {
    background: #ffffff;
    border-radius: 10px;
    padding: 18px 20px;
    box-shadow: 0 8px 22px rgba(0,0,0,0.05);
}

.seminar-ticket-box p {
    margin: 0 0 10px 0;
    color: #1a1a1a;
}

.seminar-ticket-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.seminar-ticket-list li {
    position: relative;
    margin: 0 0 8px 0;
    padding-left: 22px;
    line-height: 1.5;
    color: #1a1a1a;
}

.seminar-ticket-list li::before {
    content: "✔";
    position: absolute;
    left: 0;
    top: 0;
    color: #2e9b57;
    font-weight: 700;
}

/* =========================================================
   9) WEITERE OPTIMIERUNGEN
   ========================================================= */
   
body.woocommerce-checkout .seminar-ticket-box {
    background: #ffffff !important;
    border: 1px solid #ececf2 !important;
    border-radius: 10px !important;
    padding: 18px 20px !important;
    box-shadow: 0 8px 22px rgba(0,0,0,0.05) !important;
}

/* Haupttitel im Checkout */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item td.product-name .product-title-main {
    display: block !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    color: #1a1a1a !important;
    margin: 0 0 8px 0 !important;
}

/* Untertitel im Checkout */
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item td.product-name .proargument-checkout-subtitle,
body.woocommerce-checkout .woocommerce-checkout-review-order-table tr.cart_item td.product-name .proargument-checkout-subtitle * {
    display: block !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
    color: #5f6b7a !important;
    margin: 0 !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table .product-quantity {
    display: block !important;
    margin-top: 12px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #5f6b7a !important;
}