﻿/* ============================================================
   ATTAI — Shop & Category Archive
   Covers: /shop/ and /product-category/*
   Self-contained: no dependency on category-pages.css
   Brand tokens: Navy #393968 / Indigo #444794 / Gold #a8812d
   ============================================================ */

/* -- DESIGN TOKENS ------------------------------------------ */
.attai-shop-page {
--shop-primary:       var(--color-indigo);
--shop-primary-dark:  var(--color-navy);
--shop-primary-rgb:   68, 71, 148;
--shop-accent:        var(--color-gold);
--shop-bg:            var(--color-pale);
--shop-surface:       var(--color-white);
--shop-border:        var(--color-pale);
--shop-border-dark:   var(--color-purple);
--shop-text:          var(--color-navy);
--shop-text-muted:    var(--text-muted);
--shop-radius-xs:     4px;
--shop-radius-sm:     8px;
--shop-radius-md:     14px;
--shop-radius-lg:     20px;
--shop-shadow-xs:     0 1px 4px rgba(57,57,104,.06);
--shop-shadow-sm:     0 2px 10px rgba(57,57,104,.09);
--shop-shadow-md:     0 6px 24px rgba(57,57,104,.13);
--shop-shadow-lg:     0 16px 48px rgba(57,57,104,.18);
--shop-transition:    0.22s ease;
--shop-transition-slow: 0.4s ease;
--shop-sidebar-w:     260px;
--shop-hero-height:   240px;
--shop-hero-image:    none;
--shop-hero-overlay:  rgba(57,57,104,.5);
--shop-cols:          3;
--image-ratio-product: 3 / 4;
}

/* -- PAGE SHELL --------------------------------------------- */
.attai-shop-page {
background: var(--shop-bg);
min-height: 60vh;
}

/* -- HERO BANNER -------------------------------------------- */
.attai-shop-hero {
position: relative;
min-height: var(--shop-hero-height);
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
background: var(--shop-primary-dark);
}
.attai-shop-hero__bg {
position: absolute;
inset: 0;
background-image: var(--shop-hero-image, none);
background-size: cover;
background-position: center;
z-index: 0;
}
.attai-shop-hero__overlay {
position: absolute;
inset: 0;
background: var(--shop-hero-overlay);
z-index: 1;
}
.attai-shop-hero__content {
position: relative;
z-index: 2;
text-align: center;
padding: 3rem 1.5rem;
max-width: min(40rem, 100%);
}
.attai-shop-hero__title {
font-size: clamp(2rem, 5vw, 3.2rem);
font-weight: 800;
color: #fff;
margin: 0 0 .75rem;
letter-spacing: -.025em;
line-height: 1.1;
}
.attai-shop-hero__subtitle {
font-size: clamp(.95rem, 2vw, 1.1rem);
color: rgba(255,255,255,.85);
margin: 0;
line-height: 1.6;
}
.attai-shop-title {
font-size: clamp(1.6rem, 3.5vw, 2.2rem);
font-weight: 800;
color: var(--shop-text);
letter-spacing: -.02em;
margin: 2rem 0 0;
padding-inline: clamp(1rem, 4vw, 2.5rem);
}

/* -- WRAPPER & LAYOUT --------------------------------------- */
.attai-shop-wrapper {
width: min(var(--container-max), calc(100% - var(--container-pad)));
margin-inline: auto;
padding-block: clamp(1.5rem, 3vw, 2.5rem) clamp(2.5rem, 5vw, 4rem);
}
.attai-shop-layout {
display: flex;
gap: 1.75rem;
align-items: flex-start;
}
.attai-shop-layout--no-sidebar .attai-shop-content { flex: 1 1 100%; }
.attai-shop-layout--sidebar-left  { flex-direction: row; }
.attai-shop-layout--sidebar-right { flex-direction: row; }
.attai-shop-layout--sidebar-left  .attai-shop-sidebar { order: 0; }
.attai-shop-layout--sidebar-left  .attai-shop-content { order: 1; }
.attai-shop-layout--sidebar-right .attai-shop-sidebar { order: 1; }
.attai-shop-layout--sidebar-right .attai-shop-content { order: 0; }
.attai-shop-content { flex: 1 1 0; min-width: 0; }

/* -- SIDEBAR SHELL ------------------------------------------ */
.attai-shop-sidebar {
flex: 0 0 var(--shop-sidebar-w);
width: var(--shop-sidebar-w);
background: var(--shop-surface);
border-radius: var(--shop-radius-lg);
border: 1px solid var(--shop-border);
box-shadow: var(--shop-shadow-xs);
padding: 1.25rem;
position: sticky;
top: 2rem;
max-height: calc(100vh - 4rem);
overflow-y: auto;
scrollbar-width: thin;
scrollbar-color: var(--shop-border) transparent;
}
.attai-shop-sidebar__inner {
display: flex;
flex-direction: column;
gap: 1rem;
}
.attai-shop-sidebar__header {
display: flex;
align-items: center;
justify-content: space-between;
gap: .5rem;
padding-bottom: .875rem;
border-bottom: 1.5px solid var(--shop-border);
}
.attai-shop-sidebar__heading {
font-size: .78rem;
font-weight: 800;
letter-spacing: .1em;
text-transform: uppercase;
color: var(--shop-primary-dark);
}
.attai-shop-sidebar__clear {
font-size: .75rem;
font-weight: 600;
color: var(--shop-text-muted);
background: none;
border: none;
cursor: pointer;
padding: 0;
transition: color var(--shop-transition);
margin-inline-start: auto;
}
.attai-shop-sidebar__clear:hover { color: var(--shop-primary); }
.attai-shop-sidebar__close {
display: none;
background: none;
border: none;
cursor: pointer;
color: var(--shop-text-muted);
padding: .25rem;
border-radius: var(--shop-radius-sm);
transition: color var(--shop-transition), background var(--shop-transition);
flex-shrink: 0;
}
.attai-shop-sidebar__close:hover { color: var(--shop-text); background: var(--shop-border); }

/* -- FILTER SECTION ----------------------------------------- */
.attai-shop-filter {
border-bottom: 1px solid var(--shop-border);
padding-bottom: .875rem;
}
.attai-shop-filter:last-child { border-bottom: none; padding-bottom: 0; }
.attai-shop-filter__toggle {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
background: none;
border: none;
cursor: pointer;
padding: 0;
font-size: .8rem;
font-weight: 700;
color: var(--shop-text);
letter-spacing: .04em;
text-transform: uppercase;
margin-bottom: .75rem;
transition: color var(--shop-transition);
}
.attai-shop-filter__toggle:hover { color: var(--shop-primary); }
.attai-shop-filter__chevron {
transition: transform var(--shop-transition);
flex-shrink: 0;
color: var(--shop-text-muted);
}
.attai-shop-filter__toggle.is-open .attai-shop-filter__chevron { transform: rotate(180deg); }
.attai-shop-filter__list,
.attai-shop-filter__sublist { list-style: none; margin: 0; padding: 0; }
.attai-shop-filter__list {
display: flex;
flex-direction: column;
gap: .1rem;
}
.attai-shop-filter__sublist {
padding-inline-start: .75rem;
margin-top: .15rem;
display: flex;
flex-direction: column;
gap: .1rem;
}
.attai-shop-filter__link {
display: flex;
align-items: center;
justify-content: space-between;
gap: .4rem;
padding: .4rem .6rem;
border-radius: var(--shop-radius-sm);
font-size: .84rem;
color: var(--shop-text);
text-decoration: none;
transition: background var(--shop-transition), color var(--shop-transition);
}
.attai-shop-filter__link:hover {
background: rgba(68,71,148,.08);
color: var(--shop-primary);
text-decoration: none;
}
.attai-shop-filter__item.is-active > .attai-shop-filter__link,
.attai-shop-filter__subitem.is-active > .attai-shop-filter__link {
background: rgba(68,71,148,.1);
color: var(--shop-primary);
font-weight: 600;
}
.attai-shop-filter__label { flex: 1 1 auto; }
.attai-shop-filter__count { font-size: .73rem; color: var(--shop-text-muted); flex-shrink: 0; }
.attai-shop-filter__link--sub { font-size: .8rem; }
.attai-shop-filter__body { overflow: hidden; }

/* -- PRICE FILTER ------------------------------------------- */
.attai-price-filter { display: flex; flex-direction: column; gap: .65rem; }
.attai-price-filter__inputs { display: flex; align-items: center; gap: .5rem; }
.attai-price-filter__input {
flex: 1 1 0;
padding: .45rem .6rem;
border: 1.5px solid var(--shop-border);
border-radius: var(--shop-radius-sm);
font-size: .83rem;
color: var(--shop-text);
background: var(--shop-bg);
min-width: 0;
transition: border-color var(--shop-transition);
-moz-appearance: textfield;
}
.attai-price-filter__input::-webkit-outer-spin-button,
.attai-price-filter__input::-webkit-inner-spin-button { -webkit-appearance: none; }
.attai-price-filter__input:focus { outline: none; border-color: var(--shop-primary); }
.attai-price-filter__sep { font-size: .8rem; color: var(--shop-text-muted); flex-shrink: 0; }
.attai-price-filter__btn {
width: 100%;
padding: .55rem;
background: var(--shop-primary);
color: #fff;
border: none;
border-radius: var(--shop-radius-sm);
font-size: .82rem;
font-weight: 600;
cursor: pointer;
transition: background var(--shop-transition), box-shadow var(--shop-transition);
}
.attai-price-filter__btn:hover {
background: var(--shop-primary-dark);
box-shadow: 0 4px 12px rgba(68,71,148,.35);
}

/* -- SIDEBAR SECTION / HEADING ------------------------------ */
.attai-shop-sidebar__title {
display: flex;
align-items: center;
gap: .5rem;
font-size: .78rem;
font-weight: 800;
letter-spacing: .1em;
text-transform: uppercase;
color: var(--shop-primary-dark);
}
.attai-shop-sidebar__title svg { flex-shrink: 0; color: var(--shop-primary); }
.attai-shop-sidebar__section {
padding-bottom: 1rem;
border-bottom: 1px solid var(--shop-border);
}
.attai-shop-sidebar__section:last-child { border-bottom: none; padding-bottom: 0; }
.attai-shop-sidebar__section-title {
font-size: .75rem;
font-weight: 800;
letter-spacing: .1em;
text-transform: uppercase;
color: var(--shop-primary-dark);
margin: 0 0 .65rem;
}

/* -- SIDEBAR CATEGORY TREE ----------------------------------- */
.attai-sidebar-cats {
list-style: none;
margin: 0;
padding: 0;
display: flex;
flex-direction: column;
gap: .05rem;
}
.attai-sidebar-cats__row {
display: flex;
align-items: center;
gap: .2rem;
}
.attai-sidebar-cats__link {
flex: 1 1 auto;
display: flex;
align-items: center;
justify-content: space-between;
gap: .4rem;
padding: .42rem .6rem;
border-radius: var(--shop-radius-sm);
font-size: .84rem;
color: var(--shop-text);
text-decoration: none;
transition: background var(--shop-transition), color var(--shop-transition);
}
.attai-sidebar-cats__link:hover {
background: rgba(68,71,148,.08);
color: var(--shop-primary);
text-decoration: none;
}
.attai-sidebar-cats__link.is-active {
background: rgba(68,71,148,.12);
color: var(--shop-primary);
font-weight: 600;
}
.attai-sidebar-cats__name { flex: 1 1 auto; }
.attai-sidebar-cats__count {
font-size: .72rem;
color: var(--shop-text-muted);
flex-shrink: 0;
min-width: 1.4em;
text-align: end;
}
.attai-sidebar-cats__toggle {
flex-shrink: 0;
width: 26px;
height: 26px;
display: flex;
align-items: center;
justify-content: center;
background: none;
border: none;
cursor: pointer;
color: var(--shop-text-muted);
border-radius: var(--shop-radius-sm);
padding: 0;
transition: color var(--shop-transition), background var(--shop-transition), transform var(--shop-transition);
}
.attai-sidebar-cats__toggle:hover { color: var(--shop-primary); background: rgba(68,71,148,.07); }
.attai-sidebar-cats__item.is-open > .attai-sidebar-cats__row > .attai-sidebar-cats__toggle {
transform: rotate(180deg);
color: var(--shop-primary);
}
.attai-sidebar-subcats {
list-style: none;
margin: .15rem 0 .15rem .85rem;
padding: 0;
display: flex;
flex-direction: column;
gap: .05rem;
}
.attai-sidebar-subcats[hidden] { display: none; }

/* -- SIDEBAR SORT -------------------------------------------- */
.attai-sidebar-sort { display: flex; flex-direction: column; gap: .1rem; }
.attai-sidebar-sort__option {
display: block;
padding: .42rem .6rem;
border-radius: var(--shop-radius-sm);
font-size: .84rem;
color: var(--shop-text);
text-decoration: none;
transition: background var(--shop-transition), color var(--shop-transition);
}
.attai-sidebar-sort__option:hover {
background: rgba(68,71,148,.08);
color: var(--shop-primary);
text-decoration: none;
}
.attai-sidebar-sort__option.is-active {
background: rgba(68,71,148,.12);
color: var(--shop-primary);
font-weight: 600;
}

/* -- TOOLBAR ------------------------------------------------- */
.attai-shop-toolbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: .75rem;
flex-wrap: wrap;
margin-bottom: 1.25rem;
padding: .7rem 1rem;
background: var(--shop-surface);
border-radius: var(--shop-radius-md);
border: 1px solid var(--shop-border);
box-shadow: var(--shop-shadow-xs);
}
.attai-shop-toolbar__count { font-size: .83rem; color: var(--shop-text-muted); margin: 0; }
.attai-sort-wrap { display: flex; align-items: center; gap: .5rem; }
.attai-sort-wrap .woocommerce-ordering,
.attai-sort-wrap form.woocommerce-ordering { margin: 0; }
.attai-sort-wrap select.orderby,
.attai-sort-wrap .woocommerce-ordering select {
appearance: none;
-webkit-appearance: none;
background-color: transparent;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6b8a' stroke-width='2.5' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right .6rem center;
border: 1.5px solid var(--shop-border);
border-radius: var(--shop-radius-sm);
padding: .4rem 2rem .4rem .75rem;
font-size: .82rem;
font-weight: 500;
color: var(--shop-text);
cursor: pointer;
transition: border-color var(--shop-transition);
}
.attai-sort-wrap select.orderby:focus,
.attai-sort-wrap .woocommerce-ordering select:focus { outline: none; border-color: var(--shop-primary); }
.attai-shop-filter-btn {
display: none;
align-items: center;
gap: .45rem;
padding: .5rem 1rem;
margin-bottom: .875rem;
border: 1.5px solid var(--shop-border);
border-radius: var(--shop-radius-sm);
background: var(--shop-surface);
font-size: .83rem;
font-weight: 600;
color: var(--shop-text);
cursor: pointer;
transition: border-color var(--shop-transition), background var(--shop-transition);
white-space: nowrap;
}
.attai-shop-filter-btn:hover {
border-color: var(--shop-primary);
background: rgba(68,71,148,.05);
color: var(--shop-primary);
}

/* -- PRODUCT GRID ------------------------------------------- */
.attai-shop-grid {
display: grid;
grid-template-columns: repeat(var(--shop-cols, 3), 1fr);
gap: 1.25rem;
}

/* -- PRODUCT CARD ------------------------------------------- */
.attai-product-card {
background: var(--shop-surface);
border-radius: var(--shop-radius-md);
border: 1px solid var(--shop-border);
box-shadow: var(--shop-shadow-xs);
overflow: hidden;
display: flex;
flex-direction: column;
height: 100%;
transition: transform var(--shop-transition), box-shadow var(--shop-transition), border-color var(--shop-transition);
}
.attai-product-card:hover {
transform: translateY(-4px);
box-shadow: var(--shop-shadow-md);
border-color: var(--shop-border-dark);
}
.attai-product-card__image-wrap {
position: relative;
aspect-ratio: var(--image-ratio-product, 3 / 4);
overflow: hidden;
background: var(--shop-bg);
flex-shrink: 0;
}
.attai-product-card__img-link { display: block; width: 100%; height: 100%; }
.attai-product-card__img {
width: 100%;
height: 100%;
object-position: center top;
display: block;
transition: transform var(--shop-transition-slow);
}
.attai-product-card:hover .attai-product-card__img { transform: scale(1.05); }
.attai-product-card__badge {
position: absolute;
top: 10px;
inset-inline-start: 10px;
padding: .22rem .55rem;
border-radius: var(--shop-radius-xs);
font-size: .7rem;
font-weight: 700;
letter-spacing: .05em;
z-index: 2;
line-height: 1.4;
}
.attai-product-card__badge--sale { background: var(--shop-primary); color: #fff; }
.attai-product-card__badge--oos  { background: var(--shop-text-muted); color: #fff; }
.attai-product-card__actions {
position: absolute;
top: 10px;
inset-inline-end: 10px;
display: flex;
flex-direction: column;
gap: .4rem;
z-index: 3;
}
.attai-product-card__qv,
.attai-product-card__fav {
width: 36px;
height: 36px;
border-radius: 50%;
border: none;
background: rgba(255,255,255,.92);
backdrop-filter: blur(8px);
color: var(--shop-text) !important;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
box-shadow: var(--shop-shadow-sm);
text-decoration: none;
opacity: 0;
transform: translateX(8px);
transition: opacity var(--shop-transition), transform var(--shop-transition),
            background var(--shop-transition), color var(--shop-transition);
}
.attai-product-card__qv svg,
.attai-product-card__fav svg {
display: block;
flex-shrink: 0;
stroke: var(--shop-text);
pointer-events: none;
}
[dir="rtl"] .attai-product-card__qv,
[dir="rtl"] .attai-product-card__fav { transform: translateX(-8px); }
.attai-product-card:hover .attai-product-card__qv,
.attai-product-card:hover .attai-product-card__fav { opacity: 1; transform: translateX(0); }
.attai-product-card__fav { transition-delay: .04s; }
.attai-product-card__qv:hover,
.attai-product-card__fav:hover { background: var(--shop-primary); color: #fff !important; }
.attai-product-card__qv:hover svg,
.attai-product-card__fav:hover svg { stroke: #fff; }
.attai-product-card__fav.is-wishlisted { background: var(--shop-primary); color: #fff !important; opacity: 1; transform: translateX(0); }
.attai-product-card__fav.is-wishlisted svg { stroke: #fff; fill: #fff; }
@media (hover: none) and (pointer: coarse) {
.attai-product-card__qv,
.attai-product-card__fav { opacity: 1; transform: translateX(0); }
}
.attai-product-card__content {
padding: .85rem 1rem .75rem;
flex: 1;
display: flex;
flex-direction: column;
gap: .3rem;
}
.attai-product-card__name {
font-size: .875rem;
font-weight: 600;
color: var(--shop-text);
margin: 0;
line-height: 1.4;
min-height: 2.5em;
text-align: start !important;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
.attai-product-card__name a { color: inherit; text-decoration: none; transition: color var(--shop-transition); }
.attai-product-card__name a:hover { color: var(--shop-primary); }
.attai-product-card__pricing { margin-top: .1rem; }
.attai-product-card__pricing .price {
display: flex;
flex-wrap: wrap;
align-items: baseline;
gap: .35rem;
margin: 0;
justify-content: start !important;
text-align: start !important;
}
.attai-product-card__pricing .amount { font-weight: 700; font-size: .95rem; color: var(--shop-text); }
.attai-product-card__pricing ins { text-decoration: none; }
.attai-product-card__pricing ins .amount { color: var(--shop-primary); }
.attai-product-card__pricing del .amount { color: var(--shop-text-muted); font-size: .78rem; font-weight: 400; }
.attai-product-card__atc-bar { margin-top: auto; padding-top: .75rem; }
.attai-product-card__atc {
display: flex;
align-items: center;
justify-content: center;
gap: .4rem;
width: 100%;
padding: .62rem .8rem;
background: var(--shop-primary);
color: #fff;
border: none;
border-radius: var(--shop-radius-sm);
font-size: .82rem;
font-weight: 600;
cursor: pointer;
text-decoration: none;
font-family: inherit;
transition: background var(--shop-transition), box-shadow var(--shop-transition);
}
.attai-product-card__atc:hover {
background: var(--shop-primary-dark);
color: #fff;
text-decoration: none;
box-shadow: 0 4px 14px rgba(68,71,148,.4);
}

/* -- UNIFIED CARD BEHAVIOR (match home page) ----------------  */

/* Wishlist: always visible */
.attai-product-card__fav {
opacity: 1 !important;
transform: translateX(0) !important;
}

/* ATC overlay: desktop hover only */
@media (hover: hover) and (pointer: fine) {
.attai-product-card__atc-overlay {
	display: block !important;
	position: absolute;
	inset-inline: 0.75rem;
	bottom: 0.75rem;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity var(--shop-transition), transform var(--shop-transition);
	z-index: 4;
}
.attai-product-card:hover .attai-product-card__atc-overlay {
	opacity: 1;
	transform: translateY(0);
}
}

.attai-product-card__atc--overlay {
display: flex;
align-items: center;
justify-content: center;
gap: .4rem;
width: 100%;
padding: .65rem 1rem;
background: var(--color-navy, #393968);
color: #fff;
border: none;
font-size: .75rem;
font-weight: 500;
letter-spacing: .12em;
text-transform: uppercase;
cursor: pointer;
font-family: inherit;
transition: background var(--shop-transition);
border-radius: var(--shop-radius-sm);
}
.attai-product-card__atc--overlay:hover { background: var(--shop-primary); }

/* Content layout: name + price side by side */
.attai-product-card__content {
display: grid;
grid-template-columns: 1fr auto;
grid-template-areas:
	"name  price"
	"stars stars"
	"mktg  mktg"
	"atcbar atcbar";
column-gap: .5rem;
padding: .85rem .95rem 1rem;
flex: 1;
align-content: start;
gap: .2rem;
}
.attai-product-card__name    { grid-area: name; font-weight: 400; }
.attai-product-card__pricing { grid-area: price; align-self: start; }
.attai-product-card__stars   { grid-area: stars; }
.attai-product-card__atc-bar { grid-area: atcbar; margin-top: .4rem; }

.attai-product-card__pricing .price {
justify-content: flex-end !important;
text-align: end;
}

/* -- EMPTY STATE --------------------------------------------- */
.attai-shop-empty {
grid-column: 1 / -1;
text-align: center;
padding: 4rem 1rem;
color: var(--shop-text-muted);
display: flex;
flex-direction: column;
align-items: center;
gap: .75rem;
}
.attai-shop-empty svg { opacity: .35; }
.attai-shop-empty__title { font-size: 1.2rem; font-weight: 700; color: var(--shop-text); margin: 0; }
.attai-shop-empty__btn {
display: inline-flex;
align-items: center;
gap: .4rem;
margin-top: .5rem;
padding: .65rem 1.5rem;
background: var(--shop-primary);
color: #fff;
border-radius: var(--shop-radius-sm);
font-size: .85rem;
font-weight: 600;
text-decoration: none;
transition: background var(--shop-transition);
}
.attai-shop-empty__btn:hover { background: var(--shop-primary-dark); color: #fff; text-decoration: none; }

/* -- PAGINATION ---------------------------------------------- */
.attai-shop-pagination { margin-top: 2.5rem; display: flex; justify-content: center; }
.attai-shop-pagination .woocommerce-pagination {
display: flex;
gap: .4rem;
list-style: none;
padding: 0;
margin: 0;
flex-wrap: wrap;
justify-content: center;
}
.attai-shop-pagination .woocommerce-pagination .page-numbers {
min-width: 38px;
height: 38px;
display: flex;
align-items: center;
justify-content: center;
border-radius: var(--shop-radius-sm);
font-size: .875rem;
font-weight: 500;
text-decoration: none;
color: var(--shop-text);
border: 1px solid var(--shop-border);
background: var(--shop-surface);
transition: all var(--shop-transition);
}
.attai-shop-pagination .woocommerce-pagination .page-numbers:hover,
.attai-shop-pagination .woocommerce-pagination .page-numbers.current {
background: var(--shop-primary);
color: #fff;
border-color: var(--shop-primary);
}

/* -- MOBILE OVERLAY ------------------------------------------ */
.attai-shop-overlay {
position: fixed;
inset: 0;
background: rgba(0,0,0,.45);
z-index: 190;
opacity: 0;
pointer-events: none;
transition: opacity .28s ease;
}
.attai-shop-overlay.is-visible { opacity: 1; pointer-events: auto; }

/* -- RESPONSIVE ---------------------------------------------- */
@media (max-width: 1080px) {
.attai-shop-page { --shop-cols: 3; }
.attai-shop-layout--sidebar-left,
.attai-shop-layout--sidebar-right { flex-direction: column; }
.attai-shop-sidebar {
position: fixed;
top: 0;
left: -100%;
width: min(320px, 85vw);
height: 100dvh;
max-height: 100dvh;
z-index: 200;
border-radius: 0;
border: none;
box-shadow: var(--shop-shadow-lg);
transition: left .3s cubic-bezier(.4,0,.2,1);
}
.attai-shop-sidebar.is-open { left: 0; }
.attai-shop-layout--sidebar-right .attai-shop-sidebar { left: auto; right: -100%; }
.attai-shop-layout--sidebar-right .attai-shop-sidebar.is-open { right: 0; }
.attai-shop-sidebar__close { display: flex; }
.attai-shop-filter-btn { display: inline-flex; }
}
@media (max-width: 767px) {
.attai-shop-page { --shop-cols: 2; }
.attai-shop-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .65rem; }
.attai-shop-toolbar { flex-direction: row; align-items: center; gap: .5rem; flex-wrap: wrap; }
.attai-shop-hero__title { font-size: clamp(1.6rem, 7vw, 2.4rem); }

/* Wishlist: always visible on mobile */
.attai-product-card__fav { opacity: 1 !important; transform: translateX(0) !important; }

/* ATC overlay hidden on touch, ATC bar handles it */
.attai-product-card__atc-overlay { display: none !important; }
.attai-product-card__atc-bar { display: flex !important; }

.attai-shop-wrapper {
   width: min(var(--container-max), calc(100% - 1.25rem));
   padding-block: 1rem 1.5rem;
}
}

/* -- WC GLOBAL RESETS --------------------------------------- */
.attai-shop-page .products { display: contents !important; margin: 0 !important; padding: 0 !important; }
.attai-shop-page ul.products li.product { margin: 0 !important; padding: 0 !important; float: none !important; width: auto !important; }
.attai-shop-page .woocommerce-loop-product__title { text-align: start !important; }
.attai-shop-page .price { text-align: start !important; justify-content: start !important; }