.menu-1 {
    list-style: none;
    padding-left: 0;
}

.menu-1 li {
    margin-right: 1rem;
}

.menu-1 li a {
    color: #6C757D;
}

.menu-1 li:last-child a {
    color: #50c878;
}

.menu-1 li:last-child {	
	font-weight: 700;
	
}

.category-list img {
    max-width: 100%;
    height: auto;
}

.category-list a {
    text-decoration: none;
}


.add_to_cart_button.btn-outline-warning:hover,
.product_type_external.btn-outline-warning:hover,
.product_type_grouped.btn-outline-warning:hover {
    color: #fff !important;
}

.added_to_cart.wc-forward {
    margin-left: 10px;
}


/* Star rating */
.woostudy-rating {
    height: 20px;
}
.woostudy-rating .woostudy-rating-count {
    position: relative;
    right: -50px;
    top: -27px;
}
@font-face {
    font-family:star;
    src:url(../fonts/star.eot);
    src:url(../fonts/star.eot?#iefix) format("embedded-opentype"),url(../fonts/star.woff) format("woff"),url(../fonts/star.ttf) format("truetype"),url(../fonts/star.svg#star) format("svg");
    font-weight:400;
    font-style:normal;
}
@font-face {
    font-family:WooCommerce;
    src:url(../fonts/WooCommerce.eot);
    src:url(../fonts/WooCommerce.eot?#iefix) format("embedded-opentype"),url(../fonts/WooCommerce.woff) format("woff"),url(../fonts/WooCommerce.ttf) format("truetype"),url(../fonts/WooCommerce.svg#WooCommerce) format("svg");
    font-weight:400;
    font-style:normal;
}
.products .product .star-rating {
    font-size: .857em;
}
.woocommerce .star-rating {
    /*float: right;*/
    overflow: hidden;
    position: relative;
    height: 1em;
    line-height: 1;
    font-size: 1em;
    width: 5.4em;
    font-family: star;
}
.woocommerce .star-rating::before {
    content: "sssss";
    color: #d3ced2;
    float: left;
    top: 0;
    left: 0;
    position: absolute;
}
.woocommerce .star-rating span {
    overflow: hidden;
    float: left;
    top: 0;
    left: 0;
    position: absolute;
    padding-top: 1.5em;
}
.woocommerce .star-rating span::before {
    content: "SSSSS";
    top: 0;
    position: absolute;
    left: 0;
    color: #FFD333;
}
.woocommerce .woocommerce-product-rating {
    line-height: 2;
    display: block;
}
.woocommerce .woocommerce-product-rating::after,
.woocommerce .woocommerce-product-rating::before {
    content: " ";
    display: table;
}
.woocommerce .woocommerce-product-rating::after {
    clear: both;
}
.woocommerce .woocommerce-product-rating .star-rating {
    margin: .5em 4px 0 0;
    float: left;
}
.woocommerce .products .star-rating {
    display: block;
    margin: 0 0 .5em;
    float: none;
}
.woocommerce .hreview-aggregate .star-rating {
    margin: 10px 0 0;
}

.products .product .star-rating,
.products .wc-block-grid__product .star-rating,
.wc-block-grid__products .product .star-rating,
.wc-block-grid__products .wc-block-grid__product .star-rating {
    margin: 0 auto .5407911001em;
}

.woocommerce p.stars a{position:relative;height:1em;width:1em;text-indent:-999em;display:inline-block;text-decoration:none}
.woocommerce p.stars a::before{display:block;position:absolute;top:0;left:0;width:1em;height:1em;line-height:1;font-family:WooCommerce;content:"\e021";text-indent:0}
.woocommerce p.stars a:hover~a::before{content:"\e021"}
.woocommerce p.stars:hover a::before{content:"\e020"}
.woocommerce p.stars.selected a.active::before{content:"\e020"}
.woocommerce p.stars.selected a.active~a::before{content:"\e021"}
.woocommerce p.stars.selected a:not(.active)::before{content:"\e020"}
/* Star rating */

.mini-cart-cnt {
    padding-bottom: 2px;
}

.aws-container .aws-search-form {
    height: 38px;
}

.aws-container .aws-search-form .aws-form-btn {
    background: #fff;
    border: 1px solid #ced4da;
}

.aws-container .aws-search-form .aws-form-btn:hover {
    background: #ededed;
}

.aws-container .aws-search-form .aws-form-btn:hover > span {
    color: #555;
}

.aws-container .aws-search-form .aws-search-btn_icon {
    color: #50c878;
}

nav.breadcrumb {
    color: #6c757d;
}
nav.breadcrumb a {
    color: #3D464D;
}

.woocommerce-products-header__title {
    font-size: 1.25rem;
}

.woocommerce-pagination ul.page-numbers {
    display: flex;
    justify-content: center;
    list-style: none;
}

.woocommerce-pagination li .page-numbers {
    position: relative;
    display: block;
    padding: 0.5rem 0.75rem;
    margin-left: -1px;
    line-height: 1.25;
    color: #50c878;
    background-color: #fff;
    border: 1px solid #50c878;
    border-radius: 5px;
}

.woocommerce-pagination span.page-numbers {
    z-index: 3;
    color: #fff;
    background-color: #50c878;
    border-color: #50c878;
}

.woocommerce-pagination a.page-numbers:hover {
    z-index: 2;
    color: #e6b400;
    text-decoration: none;
    background-color: #e9ecef;
    border-color: #50c878;
}

.woostudy-sidebar h5 {
    text-transform: uppercase;
}

.woostudy-sidebar .wc-block-price-filter .wc-block-components-price-slider__controls {
    display: block;
}



.woostudy-sidebar .wc-block-attribute-filter label {
    margin-left: 10px;
}

.wp-block-woocommerce-product-categories wc-block-product-categories bg-light p-4 mb-30 is-list has-font-size has-medium-font-size {
    list-style: none;


}

.wc-block-product-categories-list-item a {
    color: #000;
}

.woocommerce-message {
    background-color: #ffd333;
    padding: 1rem;
    margin-bottom: 1rem;
    color: #000;
}

.woocommerce-message .button,
.woocommerce-message .restore-item {
    float: right;
    color: #000;
    text-decoration: underline;
}

.woocommerce-message .button:hover {
    text-decoration: none;
}

.woocommerce-product-gallery__trigger {
    position: absolute;
    top: 10px;
    right: 10px;
    left: auto;
    z-index: 99;
    display: block;
    width: 2em;
    height: 2em;
}

.product-card.product-type-simple input::-webkit-outer-spin-button,
.product-card.product-type-simple input::-webkit-inner-spin-button,
.product-card.product-type-variable input::-webkit-outer-spin-button,
.product-card.product-type-variable input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.product-card.product-type-simple input[type=number],
.product-card.product-type-variable input[type=number] {
    -moz-appearance: textfield;
}

table.variations th,
table.variations td {
    padding: 10px;
    padding-left: 0;
}

.woocommerce-grouped-product-list td {
    min-width: 100px;
}

.woocommerce-notices-wrapper ul,
.woocommerce-error {
    list-style: none;
}

.woocommerce-notices-wrapper .woocommerce-error,
.woocommerce-error {
    color: var(--ray-ink);
    background-color: #fff;
    padding: 1rem;
}

.commentlist {
    list-style: none;
    padding-left: 0;
}

.commentlist .comment_container {
    display: flex;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.commentlist .comment_container .avatar {
    margin-right: 1rem;
    max-width: 100%;
    height: auto;
    width: 45px;
}

.commentlist .comment-text .woocommerce-review__published-date {
    font-size: 0.8rem;
    font-style: italic;
}

.form-submit .submit {
    background-color: #50c878;
    padding: 0.375rem 0.75rem;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    font-size: 1rem;
    line-height: 1.5;
    border-radius: 5px;
    border: 1px solid transparent;
}

.comment-form-cookies-consent {
    position: relative;
    display: block;
    padding-left: 1.25rem;
}

.comment-form-cookies-consent input {
    position: absolute;
    margin-top: .3rem;
    margin-left: -1.25rem;
}

.cart-product-thumb img {
    width: 50px;
    max-width: 100%;
    height: auto;
}

.product-name a {
    color: #6C757D;
}

.table-summary td {
    text-align: right;
}

ul.woocommerce-shipping-methods,
ul.wc_payment_methods {
    list-style: none;
    padding-left: 0;
}

ul.woocommerce-shipping-methods input {
    margin-right: 5px;
}

.product-cats > div {
    width: 100%;
}

/* ─── Checkout form field grid (replaces old flex hack) ─── */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
    margin: 0;
}

/* All fields full-width by default */
.woocommerce-billing-fields__field-wrapper p,
.woocommerce-additional-fields__field-wrapper p,
.woocommerce-shipping-fields__field-wrapper p {
    flex: none;
    max-width: 100%;
    padding: 0;
    margin-bottom: 14px;
    grid-column: 1 / -1;
}

/* first/last pairs (e.g. ім'я + прізвище) side by side */
.woocommerce-billing-fields__field-wrapper p.form-row-first,
.woocommerce-billing-fields__field-wrapper p.form-row-last,
.woocommerce-shipping-fields__field-wrapper p.form-row-first,
.woocommerce-shipping-fields__field-wrapper p.form-row-last {
    float: none;
    width: auto;
    grid-column: span 1;
}

/* Comments / notes always full width */
.woocommerce-additional-fields__field-wrapper p {
    grid-column: 1 / -1;
}

/* ─── Checkout inputs ─── */
.woocommerce-checkout .input-text,
.woocommerce-checkout textarea {
    display: block;
    width: 100%;
    min-height: 44px;
    padding: 10px 14px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    background: #fff;
    color: var(--ray-ink);
    font-size: .9375rem;
    line-height: 1.5;
    transition: border-color .15s, box-shadow .15s;
}

.woocommerce-checkout .input-text:focus,
.woocommerce-checkout textarea:focus {
    border-color: var(--ray-brand);
    outline: none;
    box-shadow: 0 0 0 3px rgba(22, 132, 91, .15);
}

.woocommerce-checkout textarea { min-height: 100px; resize: vertical; }

/* ─── Select2 to match 44 px inputs ─── */
.woocommerce-checkout .select2-container .select2-selection--single {
    height: 44px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 44px;
    padding-left: 14px;
    color: var(--ray-ink);
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 42px;
}
.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single,
.woocommerce-checkout .select2-container--default.select2-container--open  .select2-selection--single {
    border-color: var(--ray-brand);
    box-shadow: 0 0 0 3px rgba(22, 132, 91, .15);
}

.woocommerce-checkout p.woocommerce-invalid-required-field .input-text {
    border-color: var(--ray-danger);
}

/* ─── Mobile: single column ─── */
@media (max-width: 575px) {
    .woocommerce-billing-fields__field-wrapper,
    .woocommerce-shipping-fields__field-wrapper {
        grid-template-columns: 1fr;
    }
    .woocommerce-billing-fields__field-wrapper p.form-row-first,
    .woocommerce-billing-fields__field-wrapper p.form-row-last,
    .woocommerce-shipping-fields__field-wrapper p.form-row-first,
    .woocommerce-shipping-fields__field-wrapper p.form-row-last {
        grid-column: span 1;
    }
}

.woocommerce-NoticeGroup-checkout {
    margin-left: 48px;
    margin-right: 48px;
}

@media only screen and (max-width : 992px) {
    .woocommerce-NoticeGroup-checkout {
        margin-left: 0;
        margin-right: 0;
    }
}

.woocommerce-checkout p.woocommerce-invalid-required-field .input-text {
    border-color: #cc0000;
}

.wc-bacs-bank-details {
    list-style: none;
    padding-left: 0;
}

@media only screen and (min-width : 768px) {
    .md-h-100 {
        height: 100%;
    }
}

.woocommerce-MyAccount-navigation a {
    color: #3D464D;
}

fieldset {
    border: 1px solid #ccc;
    padding: 15px;
    margin-bottom: 30px;
}

legend {
    display: block;
    width: auto;
    padding: 0 5px;
}

.woocommerce-address-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
    margin: 0;
}

.woocommerce-address-fields__field-wrapper p {
    flex: none;
    max-width: 100%;
    padding: 0;
    margin-bottom: 14px;
    grid-column: 1 / -1;
}

.woocommerce-address-fields__field-wrapper p.form-row-first,
.woocommerce-address-fields__field-wrapper p.form-row-last {
    float: none;
    width: auto;
    grid-column: span 1;
}

.woocommerce-address-fields__field-wrapper p .input-text {
    display: block;
    width: 100%;
    min-height: 44px;
    padding: 10px 14px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    color: var(--ray-ink);
    background: #fff;
    font-size: .9375rem;
    transition: border-color .15s, box-shadow .15s;
}

.woocommerce-address-fields__field-wrapper p .input-text:focus {
    border-color: var(--ray-brand);
    outline: none;
    box-shadow: 0 0 0 3px rgba(22, 132, 91, .15);
}

.woocommerce-address-fields .button {
    color: #3D464D;
    padding: 0.375rem 1rem;
    background-color: #FFD333;
    border: 1px solid transparent;
    font-weight: 700;
}

.woocommerce-address-fields .button:hover {
    background-color: #ffcb0d;
    border-color: #ffc800;
}

.woocommerce-address-fields > p {
    margin-right: -5px;
    margin-left: -5px;
}



/*Aveopt test styles*/

.total-price-number {
    border: 10px solid #50c878;
    width: 200px;
    height: 200px;
    border-radius: 100%;
    text-align: center;
    font-weight: 700;
    font-size: 1.7em;
    line-height: 6.5;
    background: #d3d3d342;
    margin: 0 auto;
}

.dash-title {
    color: #fff;
    background-color: #50c878;
    text-transform: uppercase;
    padding: 15px 15px;
    font-weight: 500;
    margin-top: 20px;
    text-align: center;
    width: 100%;
}

.link-to-contact {
    background-color: #50c878;
    text-align: center;
    margin: 6px 0px;
    padding: 15px 0;
    width: 100%;
}


.buy_me {
    background-color: #50c878;
    width: 100%;
    text-align: center;
    padding: 15px 0px;
    margin: 6px 0;
}

.buy_me div {
    color: #fff;
    text-transform: uppercase;
    text-align: center;
    font-weight: 500;
    cursor: pointer;
}

.padd-new {
    margin: 0 10px;
}

.phone-info {
    text-align: center;
}

.account-all .row {
    margin: 0 !important;
}

.block-contact a {
    color: #fff;
}

.block-contact {
    background-color: #50c878;
    color: #fff;
    padding: 10px 20px;
}


.main-manager {
    font-size: 1.1em;
    margin-bottom: 10px;
}

.n-w {
    flex-wrap: nowrap !important;
}

#block-14 {
    border-radius: 5px;
}

#customer_login h2 {
	text-transform: uppercase;
	font-size: 1.4rem !important;
}

.woocommerce-order h2 {
	text-transform: uppercase;
	font-size: 1.4rem !important;
}

/* 2026 frontend refresh */
:root {
    --ray-ink: #182230;
    --ray-muted: #667085;
    --ray-line: #d9e2ec;
    --ray-surface: #ffffff;
    --ray-soft: #f6f8fb;
    --ray-brand: #16845b;
    --ray-brand-dark: #0f6546;
    --ray-accent: #2457c5;
    --ray-warning: #c27803;
    --ray-danger: #b42318;
    --ray-shadow: 0 14px 34px rgba(24, 34, 48, .08);
}

html { scroll-behavior: smooth; }

body {
    font-family: "Inter", "Roboto", Arial, sans-serif;
    color: var(--ray-ink);
    background: var(--ray-soft);
    letter-spacing: 0;
}

a { color: var(--ray-brand-dark); }
a:hover { color: var(--ray-accent); }

.screen-reader-text {
    position: absolute !important;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.container-fluid { max-width: 1480px; }

.bg-primary { background-color: var(--ray-brand) !important; }
.text-primary { color: var(--ray-brand) !important; }

.btn,
.button,
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    min-height: 42px;
    border-radius: 7px;
    font-weight: 700;
    letter-spacing: 0;
    box-shadow: none;
}

.btn-primary,
.woocommerce button.button.alt,
.woocommerce a.button.alt,
.woocommerce input.button.alt,
.single_add_to_cart_button {
    border-color: var(--ray-brand) !important;
    background: var(--ray-brand) !important;
    color: #fff !important;
}

.btn-primary:hover,
.woocommerce button.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce input.button.alt:hover,
.single_add_to_cart_button:hover {
    border-color: var(--ray-brand-dark) !important;
    background: var(--ray-brand-dark) !important;
}

.btn-outline-primary {
    color: var(--ray-brand);
    border-color: var(--ray-brand);
}

.btn-outline-primary:hover {
    color: #fff;
    background: var(--ray-brand);
    border-color: var(--ray-brand);
}

.form-control,
.custom-select,
.input-text,
.select2-container--default .select2-selection--single {
    min-height: 44px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    background: #fff;
    color: var(--ray-ink);
}

.form-control:focus,
.custom-select:focus,
.input-text:focus {
    border-color: rgba(36, 87, 197, .55);
    box-shadow: 0 0 0 3px rgba(36, 87, 197, .12);
}

.bg-light,
.product-item,
.woocommerce-cart-form,
.cart_totals,
.woocommerce-checkout-review-order,
.woocommerce-MyAccount-content,
.woocommerce-MyAccount-navigation,
.woocommerce-order,
.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error {
    background: #fff !important;
    color: var(--ray-ink) !important;
}

/* Product grid */
.woocommerce ul.products {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    width: 100%;
    list-style: none;
    margin: 0;
    padding: 0;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none; }

/* Card shell — flex column so button always sits at bottom */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    position: relative;
    display: flex;
    flex-direction: column;
    float: none;
    width: auto;
    margin: 0;
    padding: 14px;
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 2px 8px rgba(24, 34, 48, .06);
    transition: transform .18s, box-shadow .18s, border-color .18s;
    overflow: hidden;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
    transform: translateY(-3px);
    border-color: rgba(22, 132, 91, .3);
    box-shadow: 0 8px 28px rgba(24, 34, 48, .12);
}

/* Main product link — fills remaining height, lays out inner content vertically */
.woocommerce ul.products li.product .woocommerce-LoopProduct-link,
.woocommerce-page ul.products li.product .woocommerce-LoopProduct-link {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    text-decoration: none;
    color: inherit;
}

/* Thumbnail — square, consistent */
.woocommerce ul.products li.product .woocommerce-LoopProduct-link img {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background: #f6f8fb;
    border-radius: 8px;
    flex-shrink: 0;
    margin-bottom: 10px;
}

/* Also target older a img selector */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link img {
    margin: 0 0 10px;
}

/* Title — grows to fill space, pushing price to bottom of link */
.woocommerce-loop-product__title {
    flex: 1 1 auto;
    margin: 6px 0 8px;
    color: var(--ray-ink);
    font-size: .9rem !important;
    line-height: 1.4;
    font-weight: 700;
}

/* Star rating in loop */
.woocommerce .products .star-rating {
    display: block;
    float: none;
    margin: 0 0 6px;
    font-size: .8em;
}

/* Price in loop */
.woocommerce ul.products li.product .price {
    display: block;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--ray-ink);
    margin: 0;
    line-height: 1.3;
}

/* Price on single product and globally */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
    color: var(--ray-ink);
    font-size: 1.25rem;
    font-weight: 800;
}

/* Price del/ins */
.woocommerce ul.products li.product .price del {
    font-size: .8em;
    font-weight: 600;
    opacity: .55;
    margin-right: 4px;
}
.woocommerce ul.products li.product .price ins {
    text-decoration: none;
}

/* Sale badge */
.woocommerce span.onsale {
    position: absolute;
    top: 10px;
    left: 10px;
    min-height: auto;
    min-width: auto;
    padding: 3px 9px;
    border-radius: 999px;
    background: var(--ray-warning);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1.5;
    margin: 0;
    z-index: 3;
}

/* New Arrival badge — same pill style as onsale, green, stacks below if both present */
.woocommerce .na-badge-new {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 3px 9px;
    border-radius: 999px;
    background: var(--ray-brand);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1.5;
    margin: 0;
    z-index: 3;
}
/* If onsale is also present, push new-arrival badge below it */
.woocommerce li.product span.onsale ~ .na-badge-new,
.woocommerce li.product .onsale ~ a .na-badge-new {
    top: 36px;
}

/* Add to cart button — outside the link, sits at bottom of card */
.woocommerce ul.products li.product .button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-top: 12px;
    padding: 9px 14px;
    border-radius: 8px;
    font-size: .85rem;
    font-weight: 700;
    flex-shrink: 0;
}

.woocommerce-breadcrumb,
nav.breadcrumb {
    margin: 16px 0;
    color: var(--ray-muted);
    font-size: 13px;
}

.woocommerce-breadcrumb a,
nav.breadcrumb a {
    color: var(--ray-ink);
    font-weight: 600;
}

.woocommerce-products-header__title,
.page-title,
.product_title {
    color: var(--ray-ink);
    font-weight: 800;
}

/* Single product image */
.woocommerce div.product div.images img {
    border: 1px solid var(--ray-line);
    border-radius: 10px;
    background: #fff;
    display: block;
    width: 100%;
}

/* Summary box */
.woocommerce div.product .summary {
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 4px 16px rgba(24, 34, 48, .06);
    padding: 24px;
}

/* Non-product-page boxes */
.woocommerce-cart-form,
.cart_totals,
.woocommerce-checkout-review-order,
.woocommerce-order,
.woocommerce-MyAccount-content,
.woocommerce-MyAccount-navigation {
    border: 1px solid var(--ray-line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 8px 24px rgba(24, 34, 48, .05);
}

.woocommerce-checkout-review-order,
.woocommerce-order,
.woocommerce-MyAccount-content,
.woocommerce-MyAccount-navigation {
    padding: 18px;
}

.woocommerce table.shop_table {
    border: 1px solid var(--ray-line);
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
}

.woocommerce table.shop_table th {
    background: #f6f8fb;
    color: #475467;
    font-size: 12px;
    text-transform: uppercase;
}

.woocommerce table.shop_table td,
.woocommerce table.shop_table th { border-color: var(--ray-line); }

.woocommerce-cart-form__cart-item .product-thumbnail img {
    width: 72px;
    height: 72px;
    object-fit: contain;
    border-radius: 7px;
    background: #f8fafc;
}

.woocommerce .quantity .qty {
    width: 76px;
    min-height: 42px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    text-align: center;
}

.woocommerce-checkout-review-order-table .product-name {
    color: var(--ray-ink);
    font-weight: 600;
}

.woocommerce-checkout-payment {
    border-radius: 8px !important;
    background: #f6f8fb !important;
}

.woocommerce-checkout-payment ul.payment_methods {
    border-bottom: 1px solid var(--ray-line) !important;
}

.woocommerce-checkout-payment li.wc_payment_method { padding: 10px 0; }

.woocommerce-MyAccount-navigation ul {
    margin: 0;
    padding: 8px;
    list-style: none;
}

.woocommerce-MyAccount-navigation li a {
    display: block;
    padding: 10px 12px;
    border-radius: 7px;
    color: var(--ray-ink);
    font-weight: 700;
}

.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-MyAccount-navigation li a:hover {
    background: #e8f1ff;
    color: var(--ray-accent);
    text-decoration: none;
}

.raytd-orders-search {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
    margin: 0 0 16px;
    padding: 12px;
    border: 1px solid var(--ray-line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 4px 16px rgba(24, 34, 48, .05);
}

.raytd-orders-search input[type="search"] {
    flex: 1 1 160px;
    min-width: 120px;
    min-height: 40px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    padding: 7px 11px;
    font-size: .88rem;
}

.raytd-orders-search button[type="submit"] {
    flex-shrink: 0;
    min-height: 40px;
    padding: 7px 18px;
    font-size: .88rem;
}

.raytd-orders-search-reset {
    flex-shrink: 0;
    min-height: 40px;
    padding: 7px 14px;
    font-size: .88rem;
    background: #eef2f7 !important;
    color: var(--ray-ink) !important;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    border-top: 0;
    border-left: 4px solid var(--ray-brand);
    border-radius: 8px;
    box-shadow: 0 8px 24px rgba(24, 34, 48, .05);
}

.woocommerce-error { border-left-color: var(--ray-danger); }
.woocommerce-info { border-left-color: var(--ray-accent); }

.aws-container .aws-search-form { height: 44px; }

.aws-container .aws-search-field,
.aws-container .aws-search-form .aws-form-btn { border-color: var(--ray-line); }

.text-dark-basket { color: #fff; }

.mini-cart-cnt {
    min-width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--ray-brand);
    color: #fff !important;
    border-color: var(--ray-brand) !important;
}

.back-to-top {
    right: 22px;
    bottom: 22px;
    border-radius: 999px;
}

@media (max-width: 1199.98px) {
    .woocommerce ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
    .container-fluid {
        padding-left: 14px;
        padding-right: 14px;
    }

    .woocommerce ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }

    .woocommerce ul.products li.product,
    .woocommerce-page ul.products li.product { padding: 10px; }

    .woocommerce-loop-product__title {
        font-size: .82rem !important;
    }

    .woocommerce-checkout .raytd-checkout-fields,
    .woocommerce-checkout-review-order,
    .woocommerce-order,
    .woocommerce-MyAccount-content,
    .woocommerce-MyAccount-navigation { padding: 14px; }

    .raytd-orders-search {
        flex-direction: column;
        align-items: stretch;
    }

    .raytd-orders-search input[type="search"] {
        flex: 0 0 auto;
        width: 100%;
        min-height: 40px;
        height: 40px;
    }

    .raytd-orders-search button[type="submit"],
    .raytd-orders-search-reset {
        width: 100%;
    }
}

/* Layout corrections for WooCommerce 10.x templates */
.container-fluid {
    max-width: none;
}

.woocommerce ul.products.columns-1 { grid-template-columns: minmax(0, 1fr); }
.woocommerce ul.products.columns-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.woocommerce ul.products.columns-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.woocommerce ul.products.columns-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.woocommerce ul.products.columns-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.woocommerce ul.products.columns-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }


.woocommerce ul.products li.product .woosw-btn {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    border: 1px solid var(--ray-line);
    border-radius: 999px;
    background: rgba(255, 255, 255, .94);
    color: var(--ray-brand);
    box-shadow: 0 8px 18px rgba(24, 34, 48, .12);
    font-size: 0;
}

.woocommerce ul.products li.product .woosw-btn::before {
    content: "\f004";
    font-family: "Font Awesome 5 Free";
    font-size: 15px;
    font-weight: 900;
    line-height: 1;
}

.woocommerce ul.products li.product .woosw-btn:hover,
.woocommerce ul.products li.product .woosw-btn.woosw-added {
    border-color: rgba(22, 132, 91, .25);
    background: var(--ray-brand);
    color: #fff;
}

/* =========================================================
   SINGLE PRODUCT PAGE
   ========================================================= */

/* 2-column grid layout */
.woocommerce div.product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
        "images summary"
        "tabs   tabs";
    gap: 32px;
    align-items: start;
}
.woocommerce div.product div.images  { grid-area: images; float: none; width: auto; margin: 0; }
.woocommerce div.product div.summary { grid-area: summary; float: none; width: auto; clear: none; margin: 0; }
.woocommerce div.product .woocommerce-tabs { grid-area: tabs; clear: none; }

/* Gallery */
.woocommerce-product-gallery {
    opacity: 1 !important;
    position: relative;
}
.woocommerce-product-gallery .flex-viewport {
    border: 1px solid var(--ray-line);
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
    margin-bottom: 10px;
}
.woocommerce-product-gallery .flex-viewport img {
    border: none;
    border-radius: 0;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background: #fff;
}

/* Thumbnails */
.woocommerce-product-gallery .flex-control-thumbs {
    display: flex !important;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none !important;
    margin: 0;
    padding: 0;
}
.woocommerce-product-gallery .flex-control-thumbs li {
    float: none !important;
    width: calc(25% - 6px) !important;
    margin: 0 !important;
    cursor: pointer;
}
.woocommerce-product-gallery .flex-control-thumbs li img {
    border: 2px solid var(--ray-line);
    border-radius: 7px;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background: #f6f8fb;
    width: 100%;
    height: auto;
    transition: border-color .15s;
    display: block;
}
.woocommerce-product-gallery .flex-control-thumbs li img:hover,
.woocommerce-product-gallery .flex-control-thumbs li img.flex-active {
    border-color: var(--ray-brand);
}

/* Product title & price hierarchy */
.product_title.entry-title {
    font-size: 1.4rem;
    font-weight: 800;
    line-height: 1.3;
    margin: 0 0 12px;
    color: var(--ray-ink);
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    display: block;
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--ray-ink);
    margin: 0 0 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--ray-line);
    line-height: 1.2;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
    font-size: 1rem;
    font-weight: 600;
    opacity: .5;
    margin-right: 6px;
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: .9rem;
    color: var(--ray-muted);
    margin-bottom: 16px;
    line-height: 1.6;
}

/* Quantity + add to cart row */
.woocommerce div.product form.cart {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: 16px 0;
}
.woocommerce div.product form.cart .quantity { flex-shrink: 0; }
.woocommerce div.product form.cart .single_add_to_cart_button {
    flex: 1 1 auto;
}

/* Product meta (SKU, categories) */
.product_meta {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--ray-line);
    font-size: .82rem;
    color: var(--ray-muted);
}
.product_meta > span {
    display: block;
    margin-bottom: 4px;
}
.product_meta a {
    color: var(--ray-brand-dark);
    font-weight: 600;
}
.product_meta a:hover { color: var(--ray-brand); }

/* Sale badge on single product */
.woocommerce div.product span.onsale {
    top: 14px;
    left: 14px;
    min-height: auto;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .75rem;
    margin: 0;
}

/* ---- Tabs ---- */
.woocommerce div.product .woocommerce-tabs {
    background: #fff;
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(24, 34, 48, .06);
}

/* Tab nav */
.woocommerce div.product .woocommerce-tabs ul.wc-tabs {
    display: flex;
    list-style: none !important;
    margin: 0;
    padding: 0;
    background: var(--ray-soft);
    border-bottom: 1px solid var(--ray-line);
    gap: 0;
}
.woocommerce div.product .woocommerce-tabs ul.wc-tabs::before,
.woocommerce div.product .woocommerce-tabs ul.wc-tabs::after { content: none; }

.woocommerce div.product .woocommerce-tabs ul.wc-tabs li {
    display: block !important;
    margin: 0;
    border: none;
    background: none;
    padding: 0;
    list-style: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.wc-tabs li a {
    display: block;
    padding: 13px 20px;
    font-size: .875rem;
    font-weight: 600;
    color: var(--ray-muted);
    text-decoration: none;
    border-right: 1px solid var(--ray-line);
    transition: color .15s, background .15s;
    white-space: nowrap;
}
.woocommerce div.product .woocommerce-tabs ul.wc-tabs li a:hover {
    color: var(--ray-brand);
    background: #edf7f2;
}
.woocommerce div.product .woocommerce-tabs ul.wc-tabs li.active a {
    color: var(--ray-brand);
    background: #fff;
    font-weight: 700;
}

/* Tab panels */
.woocommerce div.product .woocommerce-Tabs-panel {
    padding: 24px;
    font-size: .9rem;
    line-height: 1.7;
    color: var(--ray-ink);
}
.woocommerce div.product .woocommerce-Tabs-panel h2 {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 12px;
    color: var(--ray-ink);
}

/* Mobile single product */
@media (max-width: 767.98px) {
    .woocommerce div.product {
        grid-template-columns: 1fr;
        grid-template-areas: "images" "summary" "tabs";
        gap: 20px;
    }
    .woocommerce div.product .summary { padding: 18px; }
    .woocommerce div.product .woocommerce-Tabs-panel { padding: 18px; }
    .product_title.entry-title { font-size: 1.15rem; }
    .woocommerce div.product p.price,
    .woocommerce div.product span.price { font-size: 1.3rem; }
}

#customer_login {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    align-items: start;
}

#customer_login .u-column1,
#customer_login .u-column2,
.woocommerce form.login,
.woocommerce form.register {
    float: none;
    width: auto;
    min-width: 0;
    margin: 0;
    border: 1px solid var(--ray-line);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 8px 24px rgba(24, 34, 48, .05);
}

.woocommerce form.login,
.woocommerce form.register {
    padding: 18px;
}

#customer_login h2 {
    margin-bottom: 12px;
    color: var(--ray-ink);
    font-size: 18px !important;
    font-weight: 800;
}

.woocommerce form .form-row {
    min-width: 0;
}

.woocommerce form .form-row label {
    color: var(--ray-ink);
    font-weight: 700;
}

.woocommerce form .show-password-input {
    top: .85em;
}

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
    float: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    width: 25%;
}

.woocommerce-account .woocommerce-MyAccount-content {
    width: calc(75% - 22px);
}

.woocommerce-account .woocommerce::after {
    content: "";
    display: table;
    clear: both;
}

.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
    display: flex;
    gap: 22px;
    align-items: flex-start;
}

.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) .woocommerce-MyAccount-navigation {
    flex: 0 0 260px;
    width: 260px;
}

.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) .woocommerce-MyAccount-content {
    flex: 1 1 auto;
    width: auto;
    min-width: 0;
}

@supports not selector(:has(*)) {
    .woocommerce-account .woocommerce-MyAccount-navigation {
        float: left;
        width: 25%;
    }

    .woocommerce-account .woocommerce-MyAccount-content {
        float: right;
        width: calc(75% - 22px);
    }
}

.woocommerce table.shop_table {
    width: 100%;
}

.woocommerce table.shop_table td,
.woocommerce table.shop_table th {
    vertical-align: middle;
}

@media (max-width: 1199.98px) {
    .woocommerce ul.products.columns-4,
    .woocommerce ul.products.columns-5,
    .woocommerce ul.products.columns-6 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    #customer_login {
        grid-template-columns: minmax(0, 1fr);
    }

    .woocommerce-account .woocommerce-MyAccount-navigation,
    .woocommerce-account .woocommerce-MyAccount-content {
        width: 100%;
    }

    .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
        display: block;
    }

    .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) .woocommerce-MyAccount-navigation,
    .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) .woocommerce-MyAccount-content {
        width: 100%;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        margin-bottom: 18px;
    }
}

@media (max-width: 767.98px) {
    .woocommerce ul.products.columns-3,
    .woocommerce ul.products.columns-4,
    .woocommerce ul.products.columns-5,
    .woocommerce ul.products.columns-6 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .woocommerce ul.products li.product .woosw-btn {
        top: 8px;
        right: 8px;
        width: 34px;
        height: 34px;
        min-height: 34px;
    }
}

@media (max-width: 420px) {
    .woocommerce ul.products,
    .woocommerce ul.products.columns-2,
    .woocommerce ul.products.columns-3,
    .woocommerce ul.products.columns-4,
    .woocommerce ul.products.columns-5,
    .woocommerce ul.products.columns-6 {
        grid-template-columns: minmax(0, 1fr);
    }
}

/* =========================================================
   HEADER — raytd-header
   ========================================================= */

:root {
    --ray-header-h:   64px;
    --ray-topbar-h:   34px;
    --ray-nav-h:      46px;
}

.raytd-header {
    position: sticky;
    top: 0;
    z-index: 1040;
    background: var(--ray-surface);
    transition: box-shadow .2s;
}
.raytd-header--scrolled {
    box-shadow: 0 2px 20px rgba(24,34,48,.12);
}
.raytd-header-spacer { display: none; }

.raytd-header-inner {
    display: flex;
    align-items: center;
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 24px;
    gap: 12px;
}

/* ── Topbar ────────────────────────────────────────── */
.raytd-topbar {
    background: var(--ray-soft);
    border-bottom: 1px solid var(--ray-line);
    height: var(--ray-topbar-h);
    font-size: .78rem;
}
.raytd-topbar .raytd-header-inner {
    height: var(--ray-topbar-h);
    justify-content: space-between;
    gap: 16px;
}
.raytd-topnav {
    display: flex;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 4px;
}
.raytd-topnav li { margin: 0; }
.raytd-topnav a {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    color: var(--ray-muted);
    text-decoration: none;
    font-size: .78rem;
    transition: color .15s, background .15s;
}
.raytd-topnav a:hover {
    color: var(--ray-brand);
    background: rgba(22,132,91,.07);
}
.raytd-topnav li:last-child a {
    color: var(--ray-brand);
    font-weight: 700;
}
.raytd-topbar-right {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.raytd-topbar-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--ray-muted);
    text-decoration: none;
    font-size: .78rem;
    transition: color .15s;
}
.raytd-topbar-link:hover { color: var(--ray-brand); }

/* ── Mainbar ───────────────────────────────────────── */
.raytd-mainbar {
    border-bottom: 1px solid var(--ray-line);
    background: var(--ray-surface);
}
.raytd-mainbar .raytd-header-inner {
    height: var(--ray-header-h);
    gap: 16px;
}

/* ── Logo ──────────────────────────────────────────── */
.raytd-logo {
    display: inline-flex;
    align-items: baseline;
    text-decoration: none;
    font-size: 1.65rem;
    font-weight: 800;
    letter-spacing: -.04em;
    line-height: 1;
    white-space: nowrap;
    flex-shrink: 0;
    transition: opacity .15s;
}
.raytd-logo:hover { opacity: .82; }
.raytd-logo-ray { color: var(--ray-ink); }
.raytd-logo-td  { color: var(--ray-brand); }

/* ── Search ────────────────────────────────────────── */
.raytd-search-wrap {
    flex: 1 1 auto;
    min-width: 0;
    max-width: 560px;
}
.raytd-search-mobile {
    width: 100%;
    padding: 7px 16px 10px;
    border-top: 1px solid var(--ray-line);
    background: var(--ray-soft);
}

/* Make the AWS search input look native */
.raytd-search-wrap .aws-search-field,
.raytd-search-mobile .aws-search-field {
    height: 40px;
    border-radius: 20px !important;
    border-color: var(--ray-line) !important;
    background: var(--ray-soft) !important;
    padding-left: 16px !important;
    font-size: .88rem !important;
    transition: border-color .15s, background .15s !important;
}
.raytd-search-wrap .aws-search-field:focus,
.raytd-search-mobile .aws-search-field:focus {
    border-color: var(--ray-brand) !important;
    background: #fff !important;
    outline: none !important;
}
.raytd-search-wrap .aws-form-btn,
.raytd-search-mobile .aws-form-btn {
    border-radius: 0 20px 20px 0 !important;
    border-color: var(--ray-line) !important;
    background: var(--ray-soft) !important;
    color: var(--ray-muted) !important;
    transition: color .15s !important;
}
.raytd-search-wrap .aws-form-btn:hover,
.raytd-search-mobile .aws-form-btn:hover {
    color: var(--ray-brand) !important;
}
.raytd-search-wrap .aws-container .aws-search-form,
.raytd-search-mobile .aws-container .aws-search-form {
    height: 40px;
    border-radius: 20px !important;
    border: 1px solid var(--ray-line) !important;
    overflow: hidden;
    background: var(--ray-soft);
    transition: border-color .15s, box-shadow .15s;
}
.raytd-search-wrap .aws-container .aws-search-form:focus-within,
.raytd-search-mobile .aws-container .aws-search-form:focus-within {
    border-color: var(--ray-brand) !important;
    box-shadow: 0 0 0 3px rgba(22,132,91,.10);
}

/* ── Actions ───────────────────────────────────────── */
.raytd-actions {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.raytd-action-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    color: var(--ray-ink);
    text-decoration: none;
    position: relative;
    transition: background .15s, color .15s;
}
.raytd-action-link:hover {
    background: rgba(22,132,91,.09);
    color: var(--ray-brand);
    text-decoration: none;
}
.raytd-cart-link {
    border: 1.5px solid var(--ray-line);
    background: var(--ray-soft);
}
.raytd-cart-link:hover {
    border-color: var(--ray-brand);
    background: rgba(22,132,91,.09);
}
.raytd-cart-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 17px;
    height: 17px;
    border-radius: 9px;
    background: var(--ray-brand);
    color: #fff;
    font-size: .63rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    line-height: 1;
    border: 1.5px solid #fff;
}

/* ── Hamburger ─────────────────────────────────────── */
.raytd-hamburger {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 42px;
    height: 42px;
    border: 1.5px solid var(--ray-line);
    background: var(--ray-soft);
    cursor: pointer;
    border-radius: 10px;
    padding: 10px;
    transition: background .15s, border-color .15s;
}
.raytd-hamburger:hover {
    background: rgba(22,132,91,.09);
    border-color: var(--ray-brand);
}
.raytd-hamburger span {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--ray-ink);
    border-radius: 2px;
    transition: transform .25s, opacity .2s;
}
.raytd-hamburger--open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.raytd-hamburger--open span:nth-child(2) { opacity: 0; }
.raytd-hamburger--open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Nav ───────────────────────────────────────────── */
.raytd-nav {
    background: var(--ray-surface);
    border-bottom: 1px solid var(--ray-line);
    overflow: visible;
}
.raytd-nav .raytd-header-inner {
    height: var(--ray-nav-h);
    overflow: visible;
    gap: 0;
}

.raytd-navlist {
    display: flex;
    align-items: stretch;
    list-style: none;
    margin: 0;
    padding: 0;
    height: 100%;
    gap: 0;
    overflow: visible;
}
.raytd-navlist > li {
    position: relative;
    display: flex;
    align-items: center;
}
.raytd-navlist > li > a {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0 13px;
    color: var(--ray-ink);
    text-decoration: none;
    font-size: .875rem;
    font-weight: 600;
    white-space: nowrap;
    border-bottom: 3px solid transparent;
    transition: color .15s, border-color .15s;
}
.raytd-navlist > li > a:hover,
.raytd-navlist > li.current-menu-item > a,
.raytd-navlist > li.current-menu-ancestor > a {
    color: var(--ray-brand);
    border-bottom-color: var(--ray-brand);
    text-decoration: none;
}
/* chevron for items with sub-menu */
.raytd-navlist > li.menu-item-has-children > a::after {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    margin-left: 5px;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid currentColor;
    vertical-align: middle;
    opacity: .55;
    flex-shrink: 0;
    transition: transform .2s;
}
.raytd-navlist > li.menu-item-has-children:hover > a::after {
    transform: rotate(180deg);
    opacity: 1;
}

/* ── "Каталог" trigger button ──────────────────────── */
.raytd-navlist > li.raytd-catalog-btn {
    margin-right: 6px;
}
.raytd-navlist > li.raytd-catalog-btn > a {
    background: var(--ray-brand);
    color: #fff !important;
    border-radius: 7px;
    border-bottom-color: transparent !important;
    padding: 0 13px 0 10px;
    margin: 7px 0;
    height: calc(var(--ray-nav-h) - 14px);
    gap: 8px;
    font-weight: 700;
}
.raytd-navlist > li.raytd-catalog-btn > a:hover {
    background: var(--ray-brand-dark);
    color: #fff !important;
    border-bottom-color: transparent !important;
}
/* 2×2 grid icon — full 13×13 layout box so flex centering works correctly */
.raytd-navlist > li.raytd-catalog-btn > a::before {
    content: '';
    display: block;
    flex-shrink: 0;
    width: 13px;
    height: 13px;
    background-image:
        radial-gradient(circle, currentColor 2.5px, transparent 2.5px),
        radial-gradient(circle, currentColor 2.5px, transparent 2.5px),
        radial-gradient(circle, currentColor 2.5px, transparent 2.5px),
        radial-gradient(circle, currentColor 2.5px, transparent 2.5px);
    background-size: 50% 50%;
    background-position: 0 0, 100% 0, 0 100%, 100% 100%;
    background-repeat: no-repeat;
    margin-right: 3px;
}
.raytd-navlist > li.raytd-catalog-btn > a::after {
    opacity: .8;
}
/* Каталог dropdown — wider panel, no overflow (would clip flyout) */
.raytd-navlist > li.raytd-catalog-btn > .sub-menu {
    min-width: 260px;
}

/* ── Flyout: nested sub-sub-menu (2nd level) ───────── */
.raytd-navlist .sub-menu > li {
    position: relative;
}
.raytd-navlist .sub-menu > li.menu-item-has-children > a {
    display: flex;
    align-items: center;
}
/* override the top-level ::after for sub-menu items */
.raytd-navlist .sub-menu > li.menu-item-has-children > a::after {
    content: '›' !important;
    font-size: 1.15rem !important;
    line-height: 1 !important;
    margin-left: auto !important;
    padding-left: 8px;
    opacity: .4;
    flex-shrink: 0;
    border: none !important;
    width: auto !important;
    height: auto !important;
    transform: none !important;
}
.raytd-navlist .sub-menu > li.menu-item-has-children:hover > a::after {
    opacity: 1;
    transform: none !important;
}
/* 2nd level flyout — appears to the right */
.raytd-navlist .sub-menu > li > .sub-menu {
    display: none;
    position: absolute;
    top: -6px;
    left: calc(100% + 1px);
    min-width: 220px;
    background: #fff !important;
    border: 1px solid var(--ray-line);
    border-radius: 10px;
    box-shadow: 0 8px 28px rgba(24,34,48,.13);
    list-style: none;
    padding: 6px 0;
    margin: 0;
    z-index: 210;
}
.raytd-navlist .sub-menu > li:hover > .sub-menu,
.raytd-navlist .sub-menu > li:focus-within > .sub-menu { display: block; }

/* ── Dropdown ──────────────────────────────────────── */
.raytd-navlist > li { position: relative; }
.raytd-navlist .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: #fff !important;
    border: 1px solid var(--ray-line);
    border-radius: 10px;
    box-shadow: 0 8px 28px rgba(24,34,48,.13);
    list-style: none;
    padding: 6px 0;
    margin: 0;
    z-index: 200;
}
.raytd-navlist > li:hover > .sub-menu,
.raytd-navlist > li:focus-within > .sub-menu { display: block; }
.raytd-navlist .sub-menu li a {
    display: block;
    padding: 9px 20px;
    color: var(--ray-ink) !important;
    text-decoration: none;
    font-size: .85rem;
    white-space: nowrap;
    transition: background .12s, color .12s;
}
.raytd-navlist .sub-menu li a:hover {
    background: rgba(22,132,91,.07);
    color: var(--ray-brand);
}

/* ── Mobile nav ────────────────────────────────────── */
@media (max-width: 991.98px) {
    .raytd-nav {
        display: none;
        border-bottom: none;
    }
    .raytd-nav--open {
        display: block;
        border-bottom: 1px solid var(--ray-line);
    }
    .raytd-nav .raytd-header-inner {
        height: auto;
        flex-direction: column;
        align-items: stretch;
        padding: 0;
        overflow-x: visible;
    }
    .raytd-navlist {
        flex-direction: column;
        height: auto;
        padding: 6px 0 10px;
    }
    /* ── Mobile nav items ── */
    .raytd-navlist > li {
        flex-direction: column;
        align-items: stretch;
        position: relative;
    }
    .raytd-navlist > li > a {
        padding: 11px 52px 11px 20px; /* right padding for toggle btn */
        height: auto;
        border-bottom: 1px solid var(--ray-line);
        border-left: 3px solid transparent;
        font-size: .9rem;
    }
    .raytd-navlist > li:last-child > a { border-bottom: none; }
    .raytd-navlist > li > a:hover,
    .raytd-navlist > li.current-menu-item > a {
        border-bottom-color: var(--ray-line);
        border-left-color: var(--ray-brand);
        background: rgba(22,132,91,.05);
    }

    /* ── Sub-menu: hidden by default on mobile ── */
    .raytd-navlist .sub-menu {
        display: none;
        position: static !important;
        left: auto !important;
        top: auto !important;
        border: none;
        box-shadow: none !important;
        border-radius: 0;
        background: var(--ray-soft);
        padding: 4px 0;
        min-width: 0;
    }
    /* Show when toggled open */
    .raytd-navlist .raytd-mob-open > .sub-menu { display: block; }

    /* 2nd level indented deeper */
    .raytd-navlist .sub-menu .sub-menu { background: rgba(0,0,0,.03); }
    .raytd-navlist .sub-menu li { position: relative; }
    .raytd-navlist .sub-menu li a { padding: 9px 48px 9px 32px; font-size: .875rem; }
    .raytd-navlist .sub-menu .sub-menu li a { padding: 8px 48px 8px 48px; font-size: .84rem; }

    /* ── Toggle button ── */
    .raytd-sub-toggle {
        display: flex !important;
        align-items: center;
        justify-content: center;
        position: absolute;
        right: 0;
        top: 0;
        width: 48px;
        height: 44px;
        background: none;
        border: none;
        border-left: 1px solid var(--ray-line);
        cursor: pointer;
        color: var(--ray-muted);
        padding: 0;
        transition: color .15s, background .15s;
        z-index: 1;
    }
    .raytd-sub-toggle:hover { color: var(--ray-brand); background: rgba(22,132,91,.06); }
    /* + / − icon via CSS */
    .raytd-sub-toggle::before,
    .raytd-sub-toggle::after {
        content: '';
        position: absolute;
        background: currentColor;
        border-radius: 2px;
        transition: transform .2s, opacity .2s;
    }
    .raytd-sub-toggle::before { width: 12px; height: 2px; }
    .raytd-sub-toggle::after  { width: 2px; height: 12px; }
    /* open state: hide vertical bar → becomes − */
    .raytd-mob-open > .raytd-sub-toggle { color: var(--ray-brand); }
    .raytd-mob-open > .raytd-sub-toggle::after { transform: rotate(90deg); opacity: 0; }

    /* Sub-menu items: toggle button sits inside li */
    .raytd-navlist .sub-menu li .raytd-sub-toggle { height: 38px; }
}

/* Toggle button hidden on desktop — only shown inside mobile media query */
.raytd-sub-toggle { display: none; }

/* Hide CSS arrows on mobile — toggle button replaces them */
@media (max-width: 991.98px) {
    .raytd-navlist > li.menu-item-has-children > a::after { display: none; }
    .raytd-navlist .sub-menu > li.menu-item-has-children > a::after { display: none; }
    .raytd-navlist > li.raytd-catalog-btn > a::before { display: none; }
    .raytd-navlist > li.raytd-catalog-btn > a {
        background: transparent;
        color: var(--ray-ink) !important;
        border-radius: 0;
        margin: 0;
        height: auto;
        padding: 11px 52px 11px 20px;
        font-weight: 700;
    }
}

@media (max-width: 767.98px) {
    .raytd-header-inner { padding: 0 14px; }
    .raytd-logo { font-size: 1.5rem; }
}

/* =========================================================
   FOOTER — raytd-footer
   ========================================================= */

.raytd-footer {
    background: #111827;
    color: #9ca3af;
    margin-top: 64px;
    font-size: .9rem;
}
.raytd-footer a {
    color: #9ca3af;
    text-decoration: none;
    transition: color .15s;
}
.raytd-footer a:hover { color: #fff; }

.raytd-footer-top {
    max-width: 1480px;
    margin: 0 auto;
    padding: 52px 24px 40px;
    display: grid;
    grid-template-columns: 280px 1fr 1fr 1fr;
    gap: 40px;
}

.raytd-footer-brand .raytd-logo {
    font-size: 1.5rem;
    margin-bottom: 14px;
    display: block;
}
.raytd-footer-brand .raytd-logo-ray { color: #fff; }
.raytd-footer-brand .raytd-logo-td  { color: var(--ray-brand); }
.raytd-footer-tagline {
    color: #6b7280;
    font-size: .85rem;
    margin-bottom: 20px;
    line-height: 1.6;
}
.raytd-footer-contacts {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: .85rem;
}
.raytd-footer-contacts a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.raytd-footer-contacts svg { flex-shrink: 0; color: var(--ray-brand); }

.raytd-footer-col h4 {
    color: #fff;
    font-size: .8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin: 0 0 18px;
}
.raytd-footer-links {
    display: flex;
    flex-direction: column;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}
.raytd-footer-links li { margin: 0; }
.raytd-footer-links a {
    font-size: .875rem;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.raytd-footer-links a::before {
    content: '';
    display: block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--ray-brand);
    flex-shrink: 0;
    opacity: .6;
}
.raytd-footer-links a:hover::before { opacity: 1; }

.raytd-footer-socials {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.raytd-footer-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: rgba(255,255,255,.07);
    color: #9ca3af;
    transition: background .15s, color .15s;
}
.raytd-footer-social-link:hover {
    background: var(--ray-brand);
    color: #fff;
}

.raytd-footer-bottom {
    border-top: 1px solid rgba(255,255,255,.08);
}
.raytd-footer-bottom-inner {
    max-width: 1480px;
    margin: 0 auto;
    padding: 18px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    font-size: .8rem;
    color: #6b7280;
}

.raytd-back-to-top {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--ray-brand);
    color: #fff;
    text-decoration: none;
    transition: background .15s, transform .15s;
    flex-shrink: 0;
}
.raytd-back-to-top:hover {
    background: var(--ray-brand-dark);
    color: #fff;
    transform: translateY(-2px);
}

@media (max-width: 991.98px) {
    .raytd-footer-top {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }
    .raytd-footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 575.98px) {
    .raytd-footer-top {
        grid-template-columns: 1fr;
        padding: 36px 16px 28px;
    }
    .raytd-footer-brand { grid-column: auto; }
    .raytd-footer-bottom-inner {
        flex-direction: column;
        text-align: center;
        padding: 16px;
        gap: 12px;
    }
}

/* =========================================================
   FRONT PAGE — benefits & section titles
   ========================================================= */

.raytd-section-title {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--ray-ink);
    letter-spacing: -.01em;
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
}
.raytd-section-title::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--ray-line);
}

/* Date group heading in arrival/sale loops */
.raytd-loop-date {
    font-size: .8rem;
    font-weight: 700;
    color: var(--ray-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin: 24px 0 12px;
}
.raytd-loop-date:first-child { margin-top: 0; }

/* WooCommerce shortcode wrapper fix (shortcode adds its own .woocommerce div) */
.px-xl-5 > .woocommerce { padding: 0; }

.raytd-benefits {
    background: var(--ray-soft);
    padding: 48px 0;
}
.raytd-benefits-grid {
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}
.raytd-benefit-card {
    background: var(--ray-surface);
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    padding: 24px 18px;
    text-align: center;
    transition: box-shadow .2s, transform .2s, border-color .2s;
}
.raytd-benefit-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--ray-shadow);
    border-color: rgba(22,132,91,.25);
}
.raytd-benefit-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: #edf7f2;
    color: var(--ray-brand);
    margin: 0 auto 16px;
}
.raytd-benefit-title {
    font-size: .88rem;
    font-weight: 700;
    color: var(--ray-ink);
    margin: 0 0 8px;
    line-height: 1.3;
}
.raytd-benefit-desc {
    font-size: .8rem;
    color: var(--ray-muted);
    margin: 0;
    line-height: 1.5;
}

@media (max-width: 1199.98px) {
    .raytd-benefits-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 767.98px) {
    .raytd-benefits-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
        padding: 0 16px;
    }
    .raytd-benefits { padding: 32px 0; }
}
@media (max-width: 479.98px) {
    .raytd-benefits-grid { grid-template-columns: 1fr; }
}

/* ── Front page layout helpers ── */

/* Hero (slider + side banners) */
.raytd-home-hero {
    background: var(--ray-soft);
    border-bottom: 1px solid var(--ray-line);
    margin-bottom: 8px;
}
.raytd-home-hero-inner {
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 20px;
    align-items: stretch;
}
.raytd-hero-carousel { min-height: 200px; }
.raytd-hero-banners {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 20px 0;
}
.raytd-hero-banners .product-offer { flex: 1; border-radius: 12px; overflow: hidden; }

/* Each product section on the home page: tighten bottom padding */
.raytd-home-section {
    padding-bottom: 32px;
}
.raytd-home-section:first-of-type {
    padding-top: 32px;
}

/* Mid-page offer banners row */
.raytd-home-offer-row {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    padding-bottom: 0;
    margin-bottom: 32px;
}
.raytd-home-offer-row .product-offer { border-radius: 12px; overflow: hidden; }

/* CTA button row */
.raytd-home-cta {
    text-align: center;
    padding: 16px 0 48px;
}
.raytd-home-cta-btn {
    display: inline-block;
    padding: 12px 40px;
    border-radius: 8px;
    background: var(--ray-brand);
    color: #fff;
    font-weight: 700;
    font-size: .95rem;
    text-decoration: none;
    transition: background .15s;
}
.raytd-home-cta-btn:hover { background: var(--ray-brand-dark); color: #fff; }

@media (max-width: 991.98px) {
    .raytd-home-hero-inner { grid-template-columns: 1fr; }
    .raytd-hero-banners { flex-direction: row; padding: 0 0 16px; }
    .raytd-hero-banners .product-offer { flex: 1; height: 160px !important; }
    .raytd-home-offer-row { grid-template-columns: 1fr; }
}
@media (max-width: 575.98px) {
    .raytd-home-hero-inner { padding: 0 14px; }
    .raytd-hero-banners { flex-direction: column; }
}

/* =========================================================
   INNER PAGES — shared container
   ========================================================= */

.raytd-page-wrap {
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 24px 48px;
}

.raytd-breadcrumb-bar {
    padding: 14px 0;
    color: var(--ray-muted);
    font-size: 13px;
    border-bottom: 1px solid var(--ray-line);
    margin-bottom: 24px;
}

.raytd-breadcrumb-bar a {
    color: var(--ray-ink);
    font-weight: 600;
    text-decoration: none;
}
.raytd-breadcrumb-bar a:hover { color: var(--ray-brand); }

.raytd-page-wrap .raytd-section-title {
    font-size: 1.4rem;
    margin-bottom: 24px;
}

.raytd-no-products {
    color: var(--ray-muted);
    font-size: .95rem;
    padding: 32px 0;
}

/* .woocommerce wrapper added by PHP — zero out its own padding */
.raytd-page-wrap .woocommerce {
    padding: 0;
    margin-bottom: 32px;
}

@media (max-width: 767.98px) {
    .raytd-page-wrap { padding: 0 14px 32px; }
}

/* Archive toolbar: result count + ordering dropdown */
.raytd-archive-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.raytd-archive-toolbar .woocommerce-result-count {
    color: var(--ray-muted);
    font-size: .875rem;
    margin: 0;
}
.raytd-archive-toolbar .woocommerce-ordering select {
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    padding: 7px 12px;
    font-size: .875rem;
    color: var(--ray-ink);
    background: #fff;
    outline: none;
    cursor: pointer;
}
.raytd-archive-toolbar .woocommerce-ordering select:focus {
    border-color: var(--ray-brand);
}
/* Shop page title — same look as raytd-section-title */
.woocommerce-products-header {
    margin-bottom: 8px;
}

/* =========================================================
   CART PAGE
   ========================================================= */

/* 2-column grid: cart table left, totals right */
.woocommerce-cart .woocommerce {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 24px 32px;
    align-items: start;
}

.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper,
.woocommerce-cart .woocommerce > .cross-sells {
    grid-column: 1 / -1;
}

.woocommerce-cart .woocommerce > form.woocommerce-cart-form {
    grid-column: 1;
    min-width: 0;
}

.woocommerce-cart .woocommerce > .cart-collaterals {
    grid-column: 2;
    float: none;
    width: 100%;
    position: sticky;
    top: calc(var(--ray-topbar-h, 36px) + var(--ray-header-h, 60px) + var(--ray-nav-h, 44px) + 16px);
}

/* Cart totals box */
.woocommerce-cart .cart_totals {
    float: none !important;
    width: 100% !important;
    padding: 24px;
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 4px 16px rgba(24, 34, 48, .06);
}

.woocommerce-cart .cart_totals h2 {
    font-size: 1rem;
    font-weight: 800;
    margin: 0 0 16px;
    color: var(--ray-ink);
}

/* Cart table column widths */
.woocommerce-cart-form__cart-item .product-remove   { width: 40px; text-align: center; }
.woocommerce-cart-form__cart-item .product-thumbnail { width: 88px; }
.woocommerce-cart-form__cart-item .product-price    { width: 110px; }
.woocommerce-cart-form__cart-item .product-quantity { width: 120px; }
.woocommerce-cart-form__cart-item .product-subtotal { width: 120px; font-weight: 700; }

/* Remove × button */
.woocommerce-cart-form a.remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #fef2f2;
    color: var(--ray-danger) !important;
    font-size: 18px;
    line-height: 1;
    text-decoration: none;
    transition: background .15s, color .15s;
}
.woocommerce-cart-form a.remove:hover {
    background: var(--ray-danger);
    color: #fff !important;
}

/* Product name link */
.woocommerce-cart-form__cart-item .product-name a {
    font-weight: 700;
    color: var(--ray-ink);
    text-decoration: none;
}
.woocommerce-cart-form__cart-item .product-name a:hover { color: var(--ray-brand); }

/* Coupon + update actions row */
.woocommerce-cart-form .actions {
    padding: 14px 0 0;
    border-top: 1px solid var(--ray-line);
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.woocommerce-cart-form .actions .coupon {
    display: flex;
    gap: 8px;
    flex: 1 1 auto;
}

.woocommerce-cart-form .actions .coupon #coupon_code {
    flex: 1 1 160px;
    min-height: 44px;
    max-width: 240px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    padding: 8px 14px;
    font-size: .9rem;
    transition: border-color .15s;
}
.woocommerce-cart-form .actions .coupon #coupon_code:focus {
    border-color: var(--ray-brand);
    outline: none;
    box-shadow: 0 0 0 3px rgba(22, 132, 91, .15);
}

/* Cart totals table */
.cart_totals table.shop_table th {
    font-size: .8rem;
    font-weight: 700;
    color: var(--ray-muted);
    text-transform: uppercase;
    white-space: nowrap;
    padding: 10px 14px;
}
.cart_totals table.shop_table td { padding: 10px 14px; }

.cart_totals .order-total th,
.cart_totals .order-total td {
    font-size: 1rem;
    font-weight: 800;
    color: var(--ray-ink);
    border-top: 2px solid var(--ray-line);
}

/* Shipping radio buttons */
ul.woocommerce-shipping-methods li {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 0;
    font-size: .88rem;
}
ul.woocommerce-shipping-methods input[type="radio"] {
    accent-color: var(--ray-brand);
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Proceed to checkout button */
.wc-proceed-to-checkout { margin-top: 16px; }
.wc-proceed-to-checkout a.checkout-button {
    display: block;
    width: 100%;
    text-align: center;
    padding: 14px 20px;
    font-size: 1rem;
    font-weight: 800;
    border-radius: 9px;
}

/* Cart mobile */
@media (max-width: 767px) {
    .woocommerce-cart .woocommerce {
        grid-template-columns: 1fr;
    }
    .woocommerce-cart .woocommerce > .cart-collaterals {
        position: static;
        grid-column: 1;
    }
    .woocommerce-cart-form .woocommerce-cart-form__contents {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
}

/* =========================================================
   CHECKOUT PAGE
   ========================================================= */

/* ─── Checkout 2-column grid ─── */
/* Left: billing + shipping fields  |  Right: order review (sticky) */
.woocommerce-checkout form.checkout {
    display: grid;
    grid-template-columns: 1fr 400px;
    gap: 32px;
    align-items: start;
}

/* Left column — billing & shipping fields (custom template removes col2-set) */
.woocommerce-checkout .raytd-checkout-fields {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 4px 16px rgba(24, 34, 48, .06);
    padding: 24px;
}

/* Right column — order review sticky */
#order_review {
    grid-column: 2;
    grid-row: 1;
    position: sticky;
    top: calc(var(--ray-topbar-h, 36px) + var(--ray-header-h, 60px) + var(--ray-nav-h, 44px) + 16px);
}

/* Any stray direct children (notices injected by plugins) */
.woocommerce-checkout form.checkout > *:not(.raytd-checkout-fields):not(#order_review) {
    grid-column: 1 / -1;
}

/* Force all Select2 containers to 100% width — overrides JS inline style */
.woocommerce-checkout .select2-container,
.woocommerce-checkout .select2,
.woocommerce-checkout span.select2-container {
    width: 100% !important;
    min-width: 0;
}

/* Nova Poshta (wc-ukr-shipping-pro) block */
.wc-ukr-shipping-np-fields {
    width: 100%;
    box-sizing: border-box;
}
.wc-ukr-shipping-np-fields p.form-row,
.wc-ukr-shipping-np-fields .woocommerce-input-wrapper {
    display: block;
    width: 100%;
    box-sizing: border-box;
    margin-bottom: 14px;
}
.wc-ukr-shipping-np-fields select,
.wc-ukr-shipping-np-fields .select2-container,
.wc-ukr-shipping-np-fields .select2 {
    width: 100% !important;
    min-width: 0;
}
.wc-ukr-shipping-np-fields .input-text {
    display: block;
    width: 100%;
    min-height: 44px;
    padding: 10px 14px;
    border: 1px solid var(--ray-line);
    border-radius: 7px;
    color: var(--ray-ink);
    background: #fff;
}
.wc-ukr-shipping-np-fields h3 {
    font-size: .95rem;
    font-weight: 800;
    color: var(--ray-ink);
    margin: 16px 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--ray-line);
}

/* Nova Poshta city text-search input */
.wc-ukr-shipping-np-fields .wcus-search-control__query {
    min-height: 44px;
    padding: 10px 14px !important;
    border: 1px solid var(--ray-line) !important;
    border-radius: 7px !important;
    color: var(--ray-ink);
    font-size: .9375rem;
    width: 100%;
}
.wc-ukr-shipping-np-fields .wcus-search-control__query:focus {
    border-color: var(--ray-brand) !important;
    box-shadow: 0 0 0 3px rgba(22, 132, 91, .15) !important;
    outline: none;
}

/* Nova Poshta zen-ui custom select (warehouse dropdown) */
.wc-ukr-shipping-np-fields .zen-ui-select__value {
    min-height: 44px !important;
    padding: 10px 36px 10px 14px !important;
    border: 1px solid var(--ray-line) !important;
    border-radius: 7px !important;
    color: var(--ray-ink);
    font-size: .9375rem;
    transition: border-color .15s !important;
}
.wc-ukr-shipping-np-fields .zen-ui-select__value:hover,
.wc-ukr-shipping-np-fields .zen-ui-select--open .zen-ui-select__value {
    border-color: var(--ray-brand) !important;
}

/* Shipping section divider */
.woocommerce-checkout .woocommerce-shipping-fields {
    margin-bottom: 16px;
}

/* Review order box override (sharper radius) */
.woocommerce-checkout-review-order {
    border: 1px solid var(--ray-line) !important;
    border-radius: 12px !important;
    padding: 24px !important;
    background: #fff !important;
    box-shadow: 0 4px 16px rgba(24, 34, 48, .06) !important;
}

.woocommerce-checkout-review-order h3 {
    font-size: 1rem;
    font-weight: 800;
    margin: 0 0 16px;
    color: var(--ray-ink);
}

/* Order total row in review */
.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
    font-weight: 800;
    font-size: 1.05rem;
    border-top: 2px solid var(--ray-line);
}

/* Payment section */
.woocommerce-checkout-payment {
    margin-top: 16px;
    border: 1px solid var(--ray-line) !important;
    border-radius: 10px !important;
    background: var(--ray-soft) !important;
    overflow: hidden;
}

.woocommerce-checkout-payment ul.payment_methods {
    padding: 12px 16px !important;
    border-bottom: 1px solid var(--ray-line) !important;
}

.woocommerce-checkout-payment ul.payment_methods li label {
    font-weight: 600;
}

.woocommerce-checkout-payment .place-order {
    padding: 16px;
    background: #fff;
}

#place_order {
    width: 100%;
    padding: 14px;
    font-size: 1.05rem;
    font-weight: 800;
    border-radius: 9px;
}

/* Section headings (Billing / Shipping) */
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3 {
    font-size: .95rem;
    font-weight: 800;
    color: var(--ray-ink);
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--ray-line);
}

/* Error notice */
.woocommerce-NoticeGroup-checkout { margin: 0 0 16px; }

/* Checkout tablet — single column */
@media (max-width: 991px) {
    .woocommerce-checkout form.checkout {
        grid-template-columns: 1fr;
    }
    .woocommerce-checkout .raytd-checkout-fields,
    #order_review {
        grid-column: 1;
        grid-row: auto;
    }
    #order_review {
        position: static;
    }
}

/* =========================================================
   LOGIN / REGISTER PAGE
   ========================================================= */

.raytd-auth-wrap {
    display: flex;
    gap: 32px;
    justify-content: center;
    align-items: flex-start;
    padding: 48px 24px 64px;
    max-width: 960px;
    margin: 0 auto;
}

.raytd-auth-card {
    flex: 1;
    max-width: 440px;
    background: #fff;
    border: 1px solid var(--ray-line);
    border-radius: 16px;
    padding: 40px 36px;
    box-shadow: 0 4px 24px rgba(24,34,48,.07);
}

.raytd-auth-logo {
    margin-bottom: 28px;
}
.raytd-auth-logo a {
    font-size: 1.5rem;
    font-weight: 800;
    text-decoration: none;
    letter-spacing: -.02em;
}

.raytd-auth-title {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--ray-ink);
    margin: 0 0 28px;
    letter-spacing: -.01em;
}

/* Fields */
.raytd-auth-field {
    margin-bottom: 18px;
}
.raytd-auth-field label {
    display: block;
    font-size: .82rem;
    font-weight: 700;
    color: var(--ray-ink);
    margin-bottom: 6px;
    letter-spacing: .01em;
}
.raytd-required {
    color: #e53935;
}
.raytd-auth-field input[type="text"],
.raytd-auth-field input[type="email"],
.raytd-auth-field input[type="password"] {
    display: block;
    width: 100%;
    height: 44px;
    padding: 0 14px;
    border: 1px solid var(--ray-line);
    border-radius: 8px;
    font-size: .9rem;
    color: var(--ray-ink);
    background: #fff;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
    box-sizing: border-box;
}
.raytd-auth-field input:focus {
    border-color: var(--ray-brand);
    box-shadow: 0 0 0 3px rgba(22,132,91,.12);
}
.raytd-auth-field input::placeholder {
    color: #b0b8c4;
}

/* Remember me + lost password row */
.raytd-auth-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 22px;
    gap: 12px;
}
.raytd-auth-check {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: .84rem;
    color: var(--ray-muted);
    cursor: pointer;
    user-select: none;
}
.raytd-auth-check input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--ray-brand);
    cursor: pointer;
    flex-shrink: 0;
}
.raytd-auth-lost {
    font-size: .82rem;
    color: var(--ray-muted);
    text-decoration: none;
    white-space: nowrap;
}
.raytd-auth-lost:hover { color: var(--ray-brand); }

/* Submit button */
.raytd-auth-btn {
    display: block;
    width: 100%;
    height: 46px;
    border: none;
    border-radius: 9px;
    background: var(--ray-brand);
    color: #fff;
    font-size: .95rem;
    font-weight: 700;
    cursor: pointer;
    transition: background .15s;
    letter-spacing: .01em;
}
.raytd-auth-btn:hover { background: var(--ray-brand-dark); }

/* Switch link */
.raytd-auth-switch {
    margin: 20px 0 0;
    text-align: center;
    font-size: .84rem;
    color: var(--ray-muted);
}
.raytd-auth-switch a {
    color: var(--ray-brand);
    font-weight: 600;
    text-decoration: none;
}
.raytd-auth-switch a:hover { text-decoration: underline; }

/* Hint text */
.raytd-auth-hint {
    font-size: .82rem;
    color: var(--ray-muted);
    margin: 0 0 18px;
    line-height: 1.5;
}

/* WooCommerce notices inside auth card */
.raytd-auth-wrap .woocommerce-error,
.raytd-auth-wrap .woocommerce-message,
.raytd-auth-wrap .woocommerce-info {
    margin-bottom: 20px;
    border-radius: 8px;
}

@media (max-width: 767.98px) {
    .raytd-auth-wrap {
        flex-direction: column;
        align-items: stretch;
        padding: 24px 16px 48px;
        gap: 20px;
    }
    .raytd-auth-card {
        max-width: 100%;
        padding: 28px 20px;
    }
}

/* ================================================================
   THANK-YOU PAGE  (.raytd-ty-*)
   ================================================================ */

.raytd-ty-wrap {
    max-width: 900px;
    margin: 48px auto;
    padding: 0 24px 64px;
}

/* ── Hero block ── */
.raytd-ty-hero {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 48px 24px 36px;
    background: var(--ray-surface);
    border: 1px solid var(--ray-line);
    border-radius: 16px;
    margin-bottom: 28px;
}
.raytd-ty-hero--fail {
    background: #fff5f5;
    border-color: #fca5a5;
}

.raytd-ty-icon {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: #d1fae5;
    color: #059669;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}
.raytd-ty-icon--fail {
    background: #fee2e2;
    color: #dc2626;
}

.raytd-ty-heading {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--ray-ink);
    margin: 0 0 10px;
    line-height: 1.2;
}
.raytd-ty-sub {
    font-size: .95rem;
    color: var(--ray-muted);
    margin: 0 0 24px;
    max-width: 480px;
}

.raytd-ty-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
}

/* ── Buttons ── */
.raytd-ty-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 24px;
    border-radius: 8px;
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s;
    cursor: pointer;
    border: 2px solid transparent;
}
.raytd-ty-btn--primary {
    background: var(--ray-brand);
    color: #fff;
    border-color: var(--ray-brand);
}
.raytd-ty-btn--primary:hover {
    background: var(--ray-brand-dark);
    border-color: var(--ray-brand-dark);
    color: #fff;
}
.raytd-ty-btn--ghost {
    background: transparent;
    color: var(--ray-ink);
    border-color: var(--ray-line);
}
.raytd-ty-btn--ghost:hover {
    border-color: var(--ray-ink);
    color: var(--ray-ink);
}

/* ── Overview chips ── */
.raytd-ty-chips {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 28px;
}
.raytd-ty-chip {
    background: var(--ray-surface);
    border: 1px solid var(--ray-line);
    border-radius: 10px;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.raytd-ty-chip-label {
    font-size: .75rem;
    font-weight: 500;
    color: var(--ray-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.raytd-ty-chip-val {
    font-size: .95rem;
    font-weight: 600;
    color: var(--ray-ink);
}

/* ── Two-column grid ── */
.raytd-ty-grid {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 20px;
    align-items: start;
}
.raytd-ty-sidebar {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* ── Cards ── */
.raytd-ty-card {
    background: var(--ray-surface);
    border: 1px solid var(--ray-line);
    border-radius: 12px;
    padding: 20px 22px;
}
.raytd-ty-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--ray-ink);
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--ray-line);
}

/* ── Items table ── */
.raytd-ty-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}
.raytd-ty-table th {
    font-size: .75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--ray-muted);
    padding: 0 0 10px;
    border-bottom: 1px solid var(--ray-line);
}
.raytd-ty-table td {
    padding: 10px 0;
    vertical-align: middle;
    border-bottom: 1px solid var(--ray-line);
    color: var(--ray-ink);
}
.raytd-ty-table tbody tr:last-child td { border-bottom: none; }
.raytd-ty-table tfoot tr th,
.raytd-ty-table tfoot tr td {
    padding: 8px 0;
    border-bottom: none;
    border-top: 1px solid var(--ray-line);
    font-size: .875rem;
    color: var(--ray-ink);
}
.raytd-ty-table tfoot tr:first-child th,
.raytd-ty-table tfoot tr:first-child td { border-top: 1px solid var(--ray-line); }
.raytd-ty-table tfoot .order-total th,
.raytd-ty-table tfoot .order-total td {
    font-weight: 700;
    font-size: 1rem;
    color: var(--ray-ink);
}
.raytd-ty-right { text-align: right; }

/* Product row inside table */
.raytd-ty-table td:first-child {
    display: flex;
    align-items: center;
    gap: 12px;
}
.raytd-ty-thumb {
    width: 44px;
    height: 44px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--ray-line);
    flex-shrink: 0;
}
.raytd-ty-item-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.raytd-ty-item-name {
    font-weight: 500;
    color: var(--ray-ink);
    line-height: 1.3;
}
.raytd-ty-item-qty {
    font-size: .8rem;
    color: var(--ray-muted);
}
.raytd-ty-item-total {
    font-weight: 600;
    white-space: nowrap;
}

/* ── Address & shipping method ── */
.raytd-ty-address {
    font-size: .875rem;
    color: var(--ray-ink);
    line-height: 1.6;
    font-style: normal;
    margin: 0 0 12px;
}
.raytd-ty-address a {
    color: var(--ray-brand);
    text-decoration: none;
}
.raytd-ty-method {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: .875rem;
    color: var(--ray-muted);
}
.raytd-ty-method svg { flex-shrink: 0; }

/* ── Card-actions (below sidebar cards) ── */
.raytd-ty-card-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.raytd-ty-card-actions .raytd-ty-btn {
    justify-content: center;
    width: 100%;
}

/* ── Mobile ── */
@media (max-width: 767.98px) {
    .raytd-ty-wrap { padding: 0 16px 48px; margin-top: 32px; }
    .raytd-ty-chips { grid-template-columns: 1fr 1fr; }
    .raytd-ty-grid { grid-template-columns: 1fr; }
    .raytd-ty-heading { font-size: 1.35rem; }
}

/* ================================================================
   STATIC CONTENT PAGES  (.raytd-content-page)
   page.php — Доставка та оплата, Обмін та повернення, тощо
   ================================================================ */

.raytd-content-page {
    padding-top: 48px;
    padding-bottom: 64px;
}

.raytd-content-header {
    margin-bottom: 36px;
    padding-bottom: 20px;
    border-bottom: 2px solid var(--ray-line);
}

.raytd-content-title {
    font-size: 2rem;
    font-weight: 700;
    color: var(--ray-ink);
    margin: 0;
    line-height: 1.2;
}

/* ── Prose content ── */
.raytd-content-body {
    max-width: 860px;
    font-size: .975rem;
    line-height: 1.75;
    color: var(--ray-ink);
}

.raytd-content-body h2 {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--ray-ink);
    margin: 40px 0 14px;
    padding-left: 14px;
    border-left: 3px solid var(--ray-brand);
}

.raytd-content-body h3 {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--ray-ink);
    margin: 28px 0 10px;
}

.raytd-content-body p {
    margin: 0 0 16px;
    color: var(--ray-ink);
}

.raytd-content-body ul,
.raytd-content-body ol {
    margin: 0 0 20px 0;
    padding-left: 24px;
}

.raytd-content-body li {
    margin-bottom: 8px;
    color: var(--ray-ink);
}

.raytd-content-body ul li::marker {
    color: var(--ray-brand);
}

.raytd-content-body strong {
    font-weight: 600;
    color: var(--ray-ink);
}

.raytd-content-body a {
    color: var(--ray-brand);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color .15s;
}
.raytd-content-body a:hover {
    border-bottom-color: var(--ray-brand);
}

/* ── Info blocks (якщо в контенті є wp-block-group або аналоги) ── */
.raytd-content-body .wp-block-group,
.raytd-content-body blockquote {
    background: var(--ray-surface);
    border: 1px solid var(--ray-line);
    border-radius: 10px;
    padding: 20px 24px;
    margin: 24px 0;
}

.raytd-content-body blockquote {
    border-left: 4px solid var(--ray-brand);
    border-radius: 0 10px 10px 0;
    font-style: normal;
}

/* ── Tables ── */
.raytd-content-body table {
    width: 100%;
    border-collapse: collapse;
    margin: 24px 0;
    font-size: .9rem;
}

.raytd-content-body table th {
    background: var(--ray-surface);
    font-weight: 600;
    text-align: left;
    padding: 11px 16px;
    border: 1px solid var(--ray-line);
    color: var(--ray-ink);
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.raytd-content-body table td {
    padding: 10px 16px;
    border: 1px solid var(--ray-line);
    color: var(--ray-ink);
    vertical-align: top;
}

.raytd-content-body table tr:nth-child(even) td {
    background: var(--ray-surface);
}

/* ── Mobile ── */
@media (max-width: 767.98px) {
    .raytd-content-page { padding-top: 28px; }
    .raytd-content-title { font-size: 1.5rem; }
    .raytd-content-body h2 { font-size: 1.1rem; }
    .raytd-content-body table { font-size: .82rem; }
    .raytd-content-body table th,
    .raytd-content-body table td { padding: 8px 10px; }
}
