/*
 Theme Name: Child
 Template: xstore
 Version:      1.0
*/

:root {
    --black: #000;
    --blue: #165DD1;
	--blue-patriot: #0039A5;
    --dark: #111;
    --red: #D52B1E;
    --white: #FFF;
    --button-hover: #444;
    --border-radius-button: 4px;
    --col-md-7-width: 70%;
    --font-open: 'Open Sans';
    --font-robo: 'Roboto';
	--font-nasa: 'Nasalization';
    --p-font-size: .5rem;
	--header: 70px;
	--footer: 335px;
	--page-100vh: calc(100vh - 90px - 365px);
}

@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  src: url('/media/fonts/open-sans-v40-cyrillic_latin-regular.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 500;
  src: url('/media/fonts/open-sans-v40-cyrillic_latin-500.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 600;
  src: url('/media/fonts/open-sans-v40-cyrillic_latin-600.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  src: url('/media/fonts/open-sans-v40-cyrillic_latin-700.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('/media/fonts/roboto-v30-cyrillic_latin-regular.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: url('/media/fonts/roboto-v30-cyrillic_latin-500.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: url('/media/fonts/roboto-v30-cyrillic_latin-700.woff2') format('woff2');
}

@font-face {
  font-display: swap;
  font-family: 'Nasalization';
  font-style: normal;
  font-weight: normal;
  src: url('/media/fonts/nasalization.woff2') format('woff2');
}

body ::selection {
    background-color: var(--blue);
    color: black;
}

p, a, div, li, input, h1, h2, h3, h4, h5, h6, label, th, td, bdi, .products-title{
	font-family: var(--font-open), var(--font-robo), Calibri, Verdana, sans-serif;
    color: black;
}

p, a, div, li, input {
    font-size: 14px;
}

p {
    margin-bottom: .8rem;
}

p.point{
	margin: 0;	
}

a:hover {
    color: var(--blue); 
}

h1 {
    font-size: 23px;
    font-weight: 600;
    margin-bottom: 2rem;
}

h2, h3 {
    font-weight: 700;
    margin-top: .5rem;
    margin-bottom: .2rem;
}

h2 {
    font-size: 19px;
    padding-bottom: 0.2rem;
    margin-top: 1rem;
}

h3 {
    font-size: 1.2rem;
}

.site{
	line-height: 1.5;	
}
.site p{
	margin-bottom: 0;	
}
.site h2 {
    border-bottom: 1px solid #ccc;
}

strong {
    color: black;
}

mb-hide{
	display: none;	
}

button, .button {
    margin-top: 1.5rem;
    padding: 0 20px !important;
    border: none !important;
    border-radius: var(----border-radius-button, 4px) !important;
    height: 2.85rem !important;
    line-height: 2.85rem !important;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--dark);
	color: white;
    cursor: pointer;
	letter-spacing: 0.06rem;
	font-size: 1rem;
	font-weight: 500;
}

.tx-bold{
	font-weight: bold;
	margin: 0;	
}

.at-404-container {
	min-height: var(--page-100vh);
	height: 500px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 10px;
}

.at-404-container a.button {
    display: inline-block;
    padding: 12px 24px;
    font-size: 16px;
    text-decoration: none;
}

.at-404-container h1{
	font-size: clamp(24px, 5vw, 35px);
}
.at-404-container p {
    font-size: clamp(16px, 2.5vw, 18px);
	margin-bottom: 5px;
}

#impressum .tx-bold {
    margin-top: 5px;
}

button:hover, .button:hover, 
button:focus, .button:focus{
	background-color: var(--blue-patriot) !important;
}

.elementor-widget-container li{
	font-size: 14px;	
}

p.legal-note,
.legal-note a{
    color: #666;
    margin-top: 2em;
    font-size: 0.9em;
}
.legal-note a{
	text-decoration: underline;
}

.payment-shipping h3{
	margin-top: 0.8rem;
    margin-bottom: 0.4rem;	
}

/* Scrollbalken */
::-webkit-scrollbar {
	width: 10px;
}
::-webkit-scrollbar-track {
	background: var(--dark); 
}
::-webkit-scrollbar-thumb {
	background: white; 
	border-left: 2px solid var(--dark);
}
::-webkit-scrollbar-thumb:hover {
	background: var(--blue); 
}

/* Header und Menü */
#yahead {
    min-height: 70px;
    background-color: var(--dark);
    margin-bottom: 20px;
}

#headmenu {
    min-height: 33px;
}

#headmenu img.trp-flag-image {
    height: 18px;
    width: auto;
    margin: 0;
}

#headmenu .etheme-elementor-nav-menu.horizontal>li {
    margin: 0 12px 4px 0;
}

#headmenu .elementor-icon-wrapper {
    max-height: 21px;
}

#YaPatriot-Logo img {
    width: 200px;
    height: auto;
    margin-left: 5px;
}

@media (max-width: 400px) {
    svg.YaLogo {
        max-width: 150px;
    }
}

/* Home */
#home-slide-dt .elementor-slide-heading {
    color: white;
    text-shadow: 0 0 15px black;
}

#home-slide-mob {
    position: relative;
    height: 100vh;
    overflow: hidden;
}

#home-slide-mob .elementor-shortcode {
    position: relative;
    height: 100vh;
}

.home-slide-mob-text {
    position: absolute;
    top: 70vh;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'Nasalization', 'Open Sans', 'Segoe UI', 'Helvetica Neue', Arial, sans-serif;
    color: white;
    font-size: 1.6rem;
    text-align: center;
    width: 100%;
    padding: 0 15px;
    box-sizing: border-box;
	text-shadow: 0 0 10px #FFF;
}


/* Footer */
#footer {
    background-color: var(--dark);
    margin-top: 60px;
    padding-top: 30px;
    padding-bottom: 30px;
	min-height: 304px;
}

.at-footer-menu {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    gap: 1rem;
	justify-content: center;
}

#footer a {
    color: white;
}

#footer a:hover {
    color: #165DD1;
}

#footer-logo {
    margin-top: 15px;
}

#footer-info{
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

#footer-social {
    margin: 20px 0;
    display: flex;
    gap: 15px;
	justify-content: center;
}

#footer-social a:hover svg path,
#footer-payment svg:hover path{
    fill: var(--blue);
}

p.copyright {
	color: white;
	font-size: 13px;    
	font-family: var(--font-nasa);
	letter-spacing: 0.5px;
}

/* Page */
.content-page, .page-content {
	padding-bottom: 0;
	min-height: var(--page-100vh);
}

#at-verification{
	margin: 0 auto;
	padding-top: 50px;
	text-align: center;
	max-width: 1200px;
	min-height: var(--page-100vh);
}

/* Login und Registrierung */
.at-login-wrapper {
    max-width: 500px;
    margin: auto;
}

.login-form, .register-form {
    border: 1px solid var(--dark);
    border-radius: 4px;
    margin-bottom: 20px !important;
    padding: 20px;
}

.login-form p, .register-form p {
    padding-top: 5px;
}

.form-row {
    width: 100%;
}

label.woocommerce-form__label.woocommerce-form__label-for-checkbox.woocommerce-form-login__rememberme {
    padding-bottom: 10px;
}

.at-login-text a {
    font-weight: 600;
    text-decoration: underline;
}

.woocommerce-password-strength {
    font-weight: bold;
    margin-top: 5px;
}

#password_strength.short,
#password_strength.bad {
    color: red;
}

#password_strength.good {
    color: darkorange;
}

#password_strength.strong{
	color: green;	
}

.at-login-wrapper button {
    width: 100%;
    border: none;
	margin-top: 5px;
}

.at-login-wrapper button:hover,
.at-login-wrapper button:focus {
    background-color: var(--blue) !important;
}

form.login .lost_password:last-child,
form.register .lost_password:last-child {
    margin-top: 10px;
}

p.woocommerce-form-row.woocommerce-form-row--wide.form-row.form-row-wide {
    margin-bottom: 0;
}

.at-error-message {
    font-size: 12px;
    color: red;
    font-weight: 600;
}


.elementor-element-2be8315 .woocommerce-info::before{
	display: none;	
}

.elementor-element-2be8315 .woocommerce-info{
	font-size: 14px;
	text-align: center;
	padding: 0;
	margin: 3px 0;
}

.elementor-element-2be8315 .woocommerce-info a {
	color: var(--blue) !important;
    opacity: 1;
	text-decoration: none;
}

.elementor-element-2be8315 .woocommerce-info a:hover {
	color: black;
    opacity: 1;
	text-decoration: underline;
}

/* E-Mail Verifikation */
#at-verification-form {
    display: flex;
    justify-content: center;
    gap: 15px;
	margin-bottom: 15px;
}

#at-verification-form input[name="code[]"] {
    width: 60px !important;
    height: 60px;
    font-size: 24px;
    text-align: center;
    border: 2px solid #ccc;
    border-radius: 5px;
    outline: none;
}

#at-verification-form input[name="code[]"]:focus {
    border-color: #0039A5;
    box-shadow: 0 0 8px rgba(0, 57, 165, 0.5);
}

@media (max-width: 480px) {
    #at-verification-form{
		gap: 5px;
	}
}

/* Account */
.MyAccount-user-info {
    margin-bottom: 15px;
}

.MyAccount-user-name {
    font-family: var(--font-nasa), var(--font-open), Calibri, Verdana;
    font-weight: 600;
}

.MyAccount-user-info div {
    font-size: 11px;
}

.woocommerce-MyAccount-content button {
    width: 100%;
}

.woocommerce-MyAccount-content mark {
    text-decoration: none;
    font-weight: bold;
	color: var(--blue);
}

.myaccount-title {
    margin-bottom: 20px;
    font-variant: all-petite-caps;
    font-size: 22px;
}

.myaccount_col {
    box-sizing: border-box;
}

span#account_display_name_description {
    font-size: 12px;
}

@media screen and (max-width: 480px) {
    .woocommerce-MyAccount-navigation ul {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: .5rem 1rem;
        text-align: center;
		margin-bottom: 10px;
    }
	.woocommerce-MyAccount-navigation-link a {
		background-color: var(--dark);
		border-radius: var(----border-radius-button, 4px);
		color: white;
	}
	a.woocommerce-button.button.pay {
		background: var(--dark);
		color: white;
		text-decoration: none;
	}
}

@media screen and (min-width: 481px) and (max-width: 992px) {
    .woocommerce-MyAccount-navigation ul {
        display: flex;
        justify-content: center;
        gap: 1.5rem;
        text-align: center;
    }
	
}

@media screen and (max-width: 992px) {
	.woocommerce-MyAccount-navigation-wrapper .MyAccount-user-name{
		font-size: 22px;	
	}
	
	.woocommerce-MyAccount-navigation {
		border-bottom: 1px solid var(--dark);
	}
	.MyAccount-user-info div {
		font-size: 13px;
	}
}

@media screen and (min-width: 993px) {
	.woocommerce-MyAccount-navigation{
		border-bottom: none;	
	}
    .woocommerce-MyAccount-navigation-wrapper {
        width: 20%;
        border-right: none;
    }
    .MyAccount-user-info {
        margin-bottom: 30px;
    }
}

form.woocommerce-EditAccountForm.edit-account .section-title {
    padding: 0;
}

form.woocommerce-EditAccountForm.edit-account fieldset {
    border: none;
    margin: 20px 0 5px;
    padding: 0;
}

.woocommerce-Address address,
th.woocommerce-orders-table__header,
th.woocommerce-table__product-name.product-name,
th.woocommerce-table__product-table.product-total {
    font-size: 13px;
    font-weight: 600;
}

th.woocommerce-table__product-name.product-name,
th.woocommerce-table__product-table.product-total {
    padding: 5px 0 !important;
}

th.woocommerce-orders-table__cell.woocommerce-orders-table__cell-order-number {
    font-weight: bold;
}

table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table th,
table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table td {
    text-align: center;
    padding: 5px 0;
}

.woocommerce-orders-table thead,
.woocommerce-table.woocommerce-table--order-details.shop_table.order_details thead,
.woocommerce-table__line-item.order_item {
    border-bottom: 1px solid var(--dark);
}

.woocommerce-table__line-item.order_item ul {
    margin-bottom: 5px;
}

.my_account_orders td .button {
    display: inline;
    padding: 5px 15px !important;
}

.woocommerce-table.order_details th,
.woocommerce-table.order_details td {
    padding: 0;
}

table.woocommerce-table.woocommerce-table--order-details.shop_table.order_details {
    margin-bottom: 10px;
}

.wc-item-meta strong {
    font-weight: 400;
}

.wc-item-meta p {
    color: black;
}

.wc-item-meta li,
table.woocommerce-table.woocommerce-table--order-details.shop_table.order_details th,
table.woocommerce-table.woocommerce-table--order-details.shop_table.order_details td {
    font-size: 13px;
}

.woocommerce-table__product-name.product-name a {
    font-weight: bold;
}

.woocommerce-customer-details h2 {
    font-size: 15px;
    margin-bottom: 5px;
}

.woocommerce-customer-details address {
    padding: 0;
    font-size: 13px;
}

address p {
    margin: 0;
}

legend.section-title {
    font-size: 15px;
    font-weight: 800;
    margin-top: 20px;
    margin-bottom: 5px;
}

input#billing_address_1::placeholder {
    color: white;
}

input#shipping_address_1::placeholder {
    color: white;
}

small.shipped_via {
    display: none;
}

@media only screen and (max-width: 500px) {
    a.woocommerce-button.button.view {
        display: none;
    }
}

@media only screen and (max-width: 660px) {
    .woocommerce-orders-table__header.woocommerce-orders-table__header-order-total,
    .woocommerce-orders-table__cell.woocommerce-orders-table__cell-order-total {
        display: none;
    }
}

@media (min-width: 700px) {
    .myaccount_row {
        display: flex;
        gap: 20px;
        flex-wrap: wrap;
    }
    .myaccount_col {
        flex: 1;
    }
    .woocommerce-address-fields__field-wrapper {
        display: flex;
        flex-wrap: wrap;
        gap: 0 10px;
    }
    #billing_first_name_field,
    #billing_last_name_field,
    #billing_postcode_field,
    #billing_city_field,
    #billing_phone_field,
    #billing_email_field {
        flex: 1 1 calc(50% - 10px);
        box-sizing: border-box;
    }
}

.woocommerce-order-details .order-actions-button.view {
    display: none;
}

.woocommerce-MyAccount-content .woocommerce-customer-details {
    margin-bottom: 30px;
}


/* Warenkorb */
.woocommerce-form-coupon-cart {
    margin-bottom: 30px !important;
}

.cart-coupon-wrapper h3 {
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 600;
}

.woocommerce-form-coupon-cart .form-row {
    margin: 0 0 5px 0;
}

.woocommerce-form-coupon-cart input.input-text {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin-bottom: 0;
}

button.button-coupon {
    line-height: 30px !important;
    height: 30px !important;
    font-size: 12px;
    font-weight: 400;
}

.woocommerce-form-coupon-cart .button-coupon {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin-top: 0;
    padding-top: 12px;
    padding-bottom: 12px;
}

.cart-collaterals,
a.clear-cart.btn.bordered {
    border-radius: 4px;
}

.cart_totals>h2 {
    border-bottom: 1px solid var(--dark);
}

.cart-collaterals bdi {
    font-weight: 600;
}

ul.active>li {
    padding-left: 0;
    padding-top: 10px;
}

a.clear-cart.btn.bordered:hover {
    background-color: var(--red);
}

p.wc-gzd-cart-info.delivery-time-info {
    display: none;
}

.quantity .quantity-wrapper.type-square input,
span.minus.et-icon.et_b-icon,
span.plus.et-icon.et_b-icon {
    border: none;
}

.shop_table .amount {
    color: black;
    font-weight: 600;
}

.shop_table .variation {
    gap: 0;
}

.actions {
    border-top: none;
}

.col-md-7 .shop_table {
    border-collapse: separate;
    border-spacing: 0 5px;
}

.table-responsive .et_b-icon svg {
    fill: black;
    font-size: 9px;
    stroke: black;
    stroke-width: 2;
}

.table-responsive .et_b-icon svg:hover {
    stroke: var(--blue);
}

.table-responsive p,
.cart-order-details:not(:has(#payment)) .order-total td,
.cart-order-details:not(:has(#payment)) .order-total th,
.cart_totals .order-total td,
.cart_totals .order-total th,
table.cart .product-details .product-title,
table.cart tbody .product-name {
    font-weight: 600;
    color: black;
}

table.cart .product-details .product-title,
table.cart tbody .product-name {
    font-size: 13px;
}

.woocommerce-cart-form table thead th {
    padding: 5px;
    border-bottom: 1px solid var(--dark);
    font-size: 13px;
    font-weight: 600;
}

.woocommerce-shipping-totals.shipping td {
    padding-top: 0 !important;
}


li.free-shipping,
#shipping_method label {
    font-size: 12px;
    margin: 0;
    font-weight: 600;
    color: black;
}

table.shop_table.shop_table_responsive.cart.woocommerce-cart-form__contents {
    margin-bottom: 5px;
}

table.shop_table.shop_table_responsive tbody th,
table.shop_table.shop_table_responsive tbody td,
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
    padding: 2px;
    font-size: 14px;
}

.wc-stripe-payment-method.or {
    display: none !important;
}

p.wc-ppcp-cart-or {
    font-size: 14px;
    text-transform: uppercase;
}

.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment-method.or {
    color: var(--et_dark-2-white);
    opacity: .7;
    margin: 15px 0;
    width: 100%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment-method.or p {
    display: flex;
    align-items: center;
    width: 100%;
    margin: 0;
}

.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment-method.or p:before,
.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment-method.or p:after {
    content: '';
    height: 1px;
    background: currentColor;
    flex: 1;
    opacity: .1;
}

.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment-method.or p:before{
	margin: 0 10px 0 0;	
}

.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment-method.or p:after{
	margin: 0 0 0 10px;
}


.wc-proceed-to-checkout .button:not(:last-child),
.wc-stripe-cart-checkout-container ul.wc_stripe_cart_payment_methods.active,
.wc-ppcp-cart-payments__container.below .wc-ppcp-cart-payment__methods,
.wc-stripe-cart-checkout-container ul.wc_stripe_cart_payment_methods li[class*=payment_method_stripe_], .wc-stripe-product-checkout-container ul.wc_stripe_product_payment_methods li[class*=payment_method_stripe_] {
	margin: 0 !important;	
}


.wc-ppcp-cart-payments__container .wc-ppcp-cart-payment__methods .wc-ppcp-cart-payment-method.or{
	margin: .7rem 0 !important;
}

/* Media Queries */
@media (max-width: 992px) {
    .elementor-widget-shortcode:has(table.cart) .product-details .cart-item-details>div~.variation,
    .elementor-widget-shortcode:has(table.cart) .product-details .cart-item-details>div~div,
    body:not(.elementor-page) table.cart .product-details .cart-item-details>div~.variation,
    body:not(.elementor-page) table.cart .product-details .cart-item-details>div~div {
        border-top: none;
        padding-top: 0;
    }

    table.cart tr:not(:last-child) td.product-details {
        padding-bottom: 30px;
    }

    table.shop_table.shop_table_responsive td.product-details {
        padding-left: 15px;
    }

    .table-responsive .et_b-icon svg {
        font-size: 12px;
    }

    .cart-order-details>div {
        padding: 15px;
    }

    .actions {
        border-top: none;
        display: flex;
        justify-content: flex-end;
    }
}

@media (max-width: 768px) {
    table.cart thead {
        display: table-header-group;
    }

    table.cart .product-name img {
        max-height: 120px;
    }
}

@media (min-width: 720px) {
    .container.content-page.sidebar-mobile-bottom {
        width: 98%;
    }

    .content.col-md-12 {
        width: 98%;
    }
}

@media (min-width: 720px) and (max-width: 992px) {
    .actions {
        border-top: none;
        display: flex;
        justify-content: flex-end;
    }
}

@media (max-width: 770px) {
    .actions {
        display: none;
    }

    .cart-order-details>div {
        border: none;
        padding: 0;
        margin-top: 20px;
    }

    .cart-order-details .cart_totals>h2,
    .cart-order-details .order-review .step-title {
        padding-bottom: 5px;
    }
}

@media (min-width: 993px) {
    .col-md-7 {
        width: 60%;
    }

    .col-md-5 {
        width: 40%;
    }

    .col-md-1,
    .col-md-10,
    .col-md-11,
    .col-md-12,
    .col-md-2,
    .col-md-3,
    .col-md-4,
    .col-md-5,
    .col-md-6,
    .col-md-7,
    .col-md-8,
    .col-md-9 {
        float: left;
    }
}

/* Checkout */
.woocommerce-checkout .shop_table th{
    line-height: 1.2;
}
.elementor-77 .elementor-element.elementor-element-ac193e5 {
    padding: 0;
}

.elementor-element.elementor-element-88d4402.elementor-widget.elementor-widget-shortcode .step-title {
    border-bottom: none;
}

.woocommerce-NoticeGroup,
.woocommerce-form-coupon button {
	margin: 0;	
}

ul.step-nav.nav-wizard .step-title {
	font-size: 13px;
    padding-bottom: 0;
    text-transform: none;
	text-align: center;
}

form.checkout.woocommerce-checkout h3 {
    border-bottom: 1px solid var(--dark) !important;
	font-size: 14px;
	margin-top: var(--widget-title-space-bottom,1em) !important;
    padding-bottom: 5px;
    text-transform: uppercase;
}

form.checkout_coupon.woocommerce-form-coupon button {
	max-height: var(--et_inputs-height,2.642rem);
	margin-left: 15px;
}

@media (max-width: 440px) {
    .woocommerce-form-coupon {
        flex-direction: column;
        align-items: stretch;
    }

    .woocommerce-form-coupon .form-row-first,
    .woocommerce-form-coupon .form-row-last {
        flex: 1;
        width: 100%;
        max-width: none;
        margin-bottom: 10px;
    }

    .woocommerce-form-coupon .form-row-last {
        margin-bottom: 0;
    }
	form.checkout_coupon.woocommerce-form-coupon button{
		margin: 0;
		width: 100%;
		margin-bottom: 1.43em;
	}
}

@media (min-width: 993px) {
    #customer_details {
        padding-top: 0;
    }
}

@media (min-width: 700px) {
    .woocommerce-billing-fields__field-wrapper {
        display: flex;
        flex-wrap: wrap;
        gap: 0 10px;
    }
    #billing_first_name_field,
    #billing_last_name_field,
    #billing_postcode_field,
    #billing_city_field,
    #billing_phone_field,
    #billing_email_field {
        flex: 1 1 calc(50% - 10px);
        box-sizing: border-box;
    }
    #billing_phone_field {
        margin-bottom: 0;
    }
}
.form-row-first, .form-row-last {
    padding: 0;
}

.wc-stripe_klarna-container,
.wc-ppcp-payment-method__container,
#order-payment li.payment_method_stripe_applepay,
#order-payment li.payment_method_stripe_googlepay{
	display: none !important;	
}

.content li, .type-product li {
	margin: 0;
}

.woocommerce-multistep-checkout ul.nav-wizard{
	margin: 0;	
}

.woocommerce-multistep-checkout ul.nav-wizard li a,
.woocommerce-multistep-checkout ul.nav-wizard li.active a{
    color: black;	
	font-size: 12px;
	margin-top: 10px;
	font-weight: 500;
}

.woocommerce-multistep-checkout ul.nav-wizard li.active ~ li::before,
.woocommerce-multistep-checkout ul.nav-wizard li:not(:first-child):before {
    margin-top: 2px;
}

.woocommerce-multistep-checkout ul.nav-wizard li a::before{
    height: 15px;
    width: 15px;
}

.woocommerce-multistep-checkout ul.nav-wizard li.active a::before,
.woocommerce-multistep-checkout ul.nav-wizard li:not(:first-child)::before, .woocommerce-multistep-checkout ul.nav-wizard li a::before{
    border: none;
    background-color: var(--dark);
}

.woocommerce-multistep-checkout .step-buttons{
	margin: 0;	
}

a#prev-step-payment,
a#prev-step-order {
    display: inline-block;
    padding: 0 20px !important;
    border-radius: var(----border-radius-button, 4px) !important;
    height: 2.85rem !important;
    line-height: 2.85rem !important;
    background-color: var(--dark);
    color: white;
    cursor: pointer;
    letter-spacing: 0.06rem;
    font-size: 1rem;
    font-weight: 500;
}

.step-buttons a#prev-step-payment,
.step-buttons .next-step-button,
a#prev-step-order {
	width: 200px;
	max-width: 48%;	
    text-align: center;
	text-transform: uppercase;
}

a#prev-step-payment {
    margin-top: 1.5rem;
}

a#prev-step-order{
	margin-top: 1rem;
}

a#prev-step-payment:hover, a#prev-step-order:hover, 
a#prev-step-payment:focus, a#prev-step-order:focus {
	background-color: var(--blue-patriot) !important;
}

abbr.required,
.woocommerce-gzd-legal-checkbox-text,
.woocommerce-gzd-legal-checkbox-text a{
	font-size: 13px;
}

abbr.required,
.woocommerce-gzd-legal-checkbox-text {
	font-weight: 400;
}

.woocommerce-gzd-legal-checkbox-text a {
	font-weight: 600;
    text-decoration: underline;
}

#payment{
	border-top: 0;
	padding-top: 0;
}

.payment_box {
    padding-left: 31px;
}

.wc-stripe-gateway-desc {
	margin: 0 !important;	
}

/* Step 3 */
.col-1 address,
p.wc-gzdp-payment-gateway,
.col-2 address,
a.edit.step-trigger {
    font-size: 13px;
	margin-bottom: 10px;
}

a.edit.step-trigger {
    text-decoration: underline;
}

.woocommerce-gzdp-checkout-verify-data h4 {
    margin-bottom: 5px;
    font-size: 15px;
    font-weight: 600;
}

tr.order-total th {
	font-weight: 600;
	text-transform: uppercase;
}

.woocommerce-info {
	margin-bottom: 5px;
    font-weight: 600;
}

.cart_item .product-info,
.woocommerce-info a.showcoupon {
	color: black !important;
	font-size: 13px;
    font-weight: 500;
	opacity: 1;
	text-decoration: none;
}

.woocommerce-info a.showcoupon {
	font-weight: bold;	
}

.woocommerce-info a.showcoupon:hover {
	color: var(--blue) !important;
	opacity: 1;
}

dl.variation {
    font-weight: 400;
}

dl.variation dd {
    color: black;
    font-weight: 600;
}

#shipping_method .amount {
	text-decoration: none;	
}

table tfoot{
	border-top: 1px solid var(--dark);	
}

.multi-checkout-overview {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

@media (min-width: 600px) {
	.woocommerce-gzdp-checkout-verify-data .multi-checkout-overview {
	flex-direction: row;
		justify-content: space-between;
	}

	.multi-checkout-adresses,
	.multi-checkout-payment {
		width: 48%;
	}
}

/* Kategorie */
.category-wrapper {
	padding: 0 10px;
}

.custom-category-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
    margin: 0 auto;
    max-width: 1200px;
    box-sizing: border-box;
}

.product-card {
    position: relative;
    overflow: hidden;
    text-align: center;
    border-radius: 4px;
}

.product-image {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.3s ease;
}

.product-card:hover .product-image {
    transform: scale(1.4);
}

.product-overlay {
    position: absolute;
    bottom: 0;
    width: 100%;
    background: rgba(0, 0, 0, 0.8);
    padding: 5px 10px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    transition: transform 0.3s ease;
}

.product-card .product-title {
    color: white;
    font-size: 13px;
    font-weight: 500;
    margin: 2px 0 0;
}

p.product-price {
    margin-bottom: 0;
}

p.product-price bdi {
    color: white;
    font-size: 13px;
}

.available-colors,
.available-sizes {
    display: none;
    color: white;
    font-size: 0.9rem;
}

.available-colors {
    margin: 5px 0 0;
}

.color-circle {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 5px;
    border: 1px solid #fff;
}

.product-card:hover .available-sizes,
.product-card:hover .available-colors {
    display: block;
	font-size: 11px;
}

/* Responsive Design */
@media (max-width: 1024px) {
    .custom-category-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .custom-category-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 300px) {
    .custom-category-grid {
        grid-template-columns: 1fr;
    }
}

/* Thanks */
.woocommerce-thankyou-message {
    text-align: center;
}

p.woocommerce-notice.woocommerce-notice--success.woocommerce-thankyou-order-received {
    font-size: 18px;
    font-weight: bold;
    margin: 0;
}

p.thanks-text {
    font-size: 15px;
    font-weight: 500;
}

.received-grid-container,
.received-order-view,
section.at-bacs-bank-details{
    max-width: 600px;
    margin: 20px auto;
    border: 2px solid black;
    border-radius: 4px;
    padding: 15px;
    text-align: center;
}

.received-grid-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-bottom: 40px;
}

.received-order-view p {
    font-size: 13px;
    font-weight: 600;
    margin: 0 auto 15px;
}

a.button.button-order-view {
    display: block;
    max-width: 250px;
    margin: 0 auto;
    font-size: 12px;
    height: 28px;
    text-align: center;
    line-height: 28px;
}

.received-grid-container > div {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.woocommerce-bacs-bank-details.woocommerce-order-details strong {
    font-weight: bold;
}

/* Akkordeon - Shortcode */
.at-accordion-button {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    text-align: left;
	margin: 0;
}

.at-accordion:last-child {
    border-bottom: 1px solid;
}

.at-accordion .at-accordion-button {
    background: none;
    color: black;
    font-size: 16px;
    font-weight: bold;
	letter-spacing: 0.02rem;
    border-top: 1px solid black !important;
    border-radius: 0 !important;
    padding: 10px !important;
}

.at-accordion .at-accordion-button:hover{
    color: var(--blue);
}

.at-accordion .at-accordion-button:hover, 
.at-accordion .at-accordion-button:active, 
.at-accordion .at-accordion-button:focus {
    background-color: transparent !important;
}

.at-accordion-button::after {
    content: "+";
    font-size: 22px;
    font-weight: bold;
}

.at-accordion-button.active::after {
    content: "−";
}

.at-accordion-content {
    display: none;
    padding: 5px 10px;
}


