.shop-page {
padding: var(--sp-7) 0 var(--sp-9);
background: var(--c-bg);
min-height: 60vh;
} .shop-page__head {
text-align: center;
margin-bottom: var(--sp-7);
}
.shop-page__breadcrumb {
font-size: var(--fs-xs);
letter-spacing: 0.08em;
color: var(--c-text-mute);
margin-bottom: var(--sp-3);
}
.shop-page__breadcrumb a { color: inherit; text-decoration: underline; text-underline-offset: 3px; }
.shop-page__breadcrumb a:hover { color: var(--c-text); }
.shop-page__title {
font-family: var(--ff-display);
font-size: clamp(36px, 5vw, 56px);
font-weight: 500;
letter-spacing: -0.01em;
margin-bottom: var(--sp-3);
}
.shop-page__intro {
color: var(--c-text-soft);
max-width: 620px;
margin: 0 auto;
}
.shop-page__rating {
display: inline-flex;
align-items: center;
gap: 8px;
margin: var(--sp-3) auto 0;
font-size: var(--fs-sm);
color: var(--c-text);
}
.shop-page__rating-stars {
display: inline-flex;
gap: 2px;
color: var(--c-accent);
}
.shop-page__rating-stars svg {
width: 16px;
height: 16px;
fill: var(--c-accent);
stroke: var(--c-accent);
}
.shop-page__rating-sep { color: var(--c-text-soft); }
.shop-page__rating a {
color: var(--c-text-soft);
text-decoration: underline;
text-decoration-thickness: 1px;
text-underline-offset: 3px;
}
.shop-page__rating a:hover { color: var(--c-accent-dark); } .shop-page__layout {
display: grid;
grid-template-columns: 1fr;
gap: var(--sp-7);
align-items: start;
} @media (min-width: 901px) {
.shop-page__layout:has(.shop-filters) {
grid-template-columns: 240px 1fr;
}
} .shop-filters {
position: sticky;
top: 110px;
background: #fff;
}
.shop-filters__backdrop {
display: none;
}
.shop-filters__head {
display: none;
align-items: center;
justify-content: space-between;
padding: var(--sp-4);
border-bottom: 1px solid var(--c-border-soft);
}
.shop-filters__head h2 {
font-family: var(--ff-display);
font-size: var(--fs-xl);
font-weight: 500;
margin: 0;
}
.shop-filter {
padding: var(--sp-3) 0;
border-bottom: 1px solid var(--c-border-soft);
}
.shop-filter:last-of-type { border-bottom: none; margin-bottom: var(--sp-4); }
.shop-filter h3 {
font-size: var(--fs-xs);
letter-spacing: 0.14em;
text-transform: uppercase;
font-weight: 600;
color: var(--c-text-soft);
margin-bottom: var(--sp-3);
font-family: var(--ff-body);
}
.shop-filter ul {
display: flex;
flex-direction: column;
gap: var(--sp-2);
}
.shop-filter label {
display: flex;
align-items: center;
gap: 10px;
font-size: var(--fs-sm);
color: var(--c-text);
cursor: pointer;
transition: color var(--t-base) var(--ease);
}
.shop-filter label:hover { color: var(--c-accent-dark); }
.shop-filter input { accent-color: var(--c-text); cursor: pointer; } .shop-filter__swatches {
display: flex;
gap: var(--sp-3);
flex-wrap: wrap;
}
.swatch {
display: flex;
flex-direction: column;
align-items: center;
gap: 6px;
cursor: pointer;
font-size: var(--fs-xs);
color: var(--c-text-soft);
transition: color var(--t-base) var(--ease);
}
.swatch input {
position: absolute;
opacity: 0;
pointer-events: none;
}
.swatch__circle {
width: 32px;
height: 32px;
border-radius: 50%;
border: 2px solid transparent;
box-shadow: inset 0 0 0 1px rgba(0,0,0,0.1);
transition: border-color var(--t-base) var(--ease), transform var(--t-base) var(--ease);
}
.swatch__circle--silver {
background: linear-gradient(135deg, #d8d6d2 0%, #b3b0aa 50%, #d8d6d2 100%);
}
.swatch__circle--gold {
background: linear-gradient(135deg, #e8c987 0%, #c4994a 50%, #e8c987 100%);
}
.swatch:hover .swatch__circle { transform: scale(1.05); }
.swatch input:checked ~ .swatch__circle {
border-color: var(--c-text);
}
.swatch input:checked ~ .swatch__name {
color: var(--c-text);
font-weight: 600;
} .shop-toolbar {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--sp-5);
padding-bottom: var(--sp-4);
border-bottom: 1px solid var(--c-border-soft);
gap: var(--sp-3);
flex-wrap: wrap;
}
.shop-toolbar__filter-btn {
display: none;
padding: 10px 18px;
font-size: var(--fs-xs);
}
.shop-toolbar__filter-btn svg { width: 14px; height: 14px; }
.shop-toolbar__count {
font-size: var(--fs-sm);
color: var(--c-text-soft);
}
.shop-toolbar__sort {
margin: 0 !important;
float: none !important;
}
.shop-toolbar__sort select,
.shop-sort {
padding: 10px 36px 10px 14px !important;
border: 1px solid var(--c-border) !important;
border-radius: var(--radius) !important;
font-size: var(--fs-sm) !important;
font-family: inherit !important;
background-color: #fff !important;
color: var(--c-text) !important;
cursor: pointer;
appearance: none !important;
-webkit-appearance: none !important;
-moz-appearance: none !important;
background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%231a1a1a' stroke-width='1.5'/%3E%3C/svg%3E") !important;
background-repeat: no-repeat !important;
background-position: right 14px center !important;
background-size: 10px 6px !important;
box-shadow: none !important;
outline: none !important;
transition: none !important;
height: auto !important;
line-height: 1.4 !important;
margin: 0 !important;
}
.shop-sort:focus,
.shop-sort:hover,
.shop-sort:active {
border-color: var(--c-text) !important;
outline: none !important;
box-shadow: none !important;
background-color: #fff !important;
transition: none !important;
} .shop-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--sp-6) var(--sp-5);
}
.shop-card {
display: flex;
flex-direction: column;
position: relative;
} .shop-card__link {
position: absolute;
inset: 0;
z-index: 1; }
.shop-card__media {
position: relative;
aspect-ratio: 1 / 1;
background: var(--c-bg-soft);
border-radius: var(--radius-lg);
overflow: hidden;
margin-bottom: var(--sp-3);
}
.shop-card__media img {
width: 100%; height: 100%; object-fit: cover;
transition: transform var(--t-slow) var(--ease);
}
.shop-card:hover .shop-card__media img { transform: scale(1.05); }
.shop-card__quick {
position: absolute;
left: 8px; right: 8px; bottom: 8px;
background: rgba(255,255,255,0.95);
color: var(--c-text);
text-align: center;
padding: 10px;
font-size: var(--fs-xs);
letter-spacing: 0.1em;
text-transform: uppercase;
font-weight: 600;
border-radius: var(--radius);
opacity: 0;
transform: translateY(8px);
transition: all var(--t-base) var(--ease);
cursor: pointer;
border: none;
width: calc(100% - 16px);
}
.shop-card:hover .shop-card__quick {
opacity: 1;
transform: translateY(0);
} .shop-card__colors {
position: absolute;
bottom: 8px;
right: 8px;
display: flex;
gap: 4px;
z-index: 5;
} .shop-card:hover .shop-card__quick {
padding-right: 70px;
}
.card-swatch {
width: 20px;
height: 20px;
border-radius: 50%;
border: 2px solid #fff;
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2), inset 0 0 0 1px rgba(0, 0, 0, 0.1);
cursor: pointer;
padding: 0;
transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.card-swatch:hover { transform: scale(1.15); }
.card-swatch.is-active {
border-color: var(--c-text);
transform: scale(1.1);
} .shop-card__cat {
font-size: var(--fs-xs);
color: var(--c-text-mute);
letter-spacing: 0.08em;
text-transform: uppercase;
margin-bottom: 2px;
}
.shop-card__name {
font-family: var(--ff-display);
font-size: var(--fs-lg);
font-weight: 500;
margin-bottom: 2px;
color: var(--c-text);
}
.shop-card__name a { color: inherit; }
.shop-card__price {
font-size: var(--fs-base);
font-weight: 500;
color: var(--c-text);
} .shop-empty {
grid-column: 1 / -1;
text-align: center;
padding: var(--sp-8) var(--sp-5);
color: var(--c-text-soft);
}
.shop-empty p { margin-bottom: var(--sp-4); } .visually-hidden {
position: absolute;
width: 1px; height: 1px;
padding: 0; margin: -1px;
overflow: hidden;
clip: rect(0,0,0,0);
white-space: nowrap;
border: 0;
} @media (max-width: 1100px) {
.shop-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) { .shop-page__layout { grid-template-columns: 1fr; gap: var(--sp-5); }
.shop-filters {
position: fixed;
inset: 0 0 0 auto;
width: min(85vw, 360px);
background: #fff;
z-index: 220;
transform: translateX(100%);
transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease);
padding: 0 var(--sp-5) var(--sp-5);
overflow-y: auto;
top: 0; bottom: 0;
}
.shop-filters.is-open {
transform: translateX(0);
box-shadow: 0 0 32px rgba(0,0,0,0.2);
} .shop-filters__backdrop {
display: block;
position: fixed;
inset: 0;
background: rgba(0,0,0,0.5);
z-index: 170;
opacity: 0;
transition: opacity var(--t-base) var(--ease);
pointer-events: none;
}
.shop-filters__backdrop.is-open {
opacity: 1;
pointer-events: auto;
}
.shop-filters__head { display: flex; padding: 12px var(--sp-4); margin: 0 calc(var(--sp-5) * -1) var(--sp-3); }
.shop-toolbar__filter-btn { display: inline-flex; align-items: center; gap: 8px; }
.shop-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5) var(--sp-3); }
}
@media (max-width: 480px) {
.shop-page { padding: var(--sp-5) 0 var(--sp-7); }
.shop-toolbar { flex-wrap: nowrap; }
.shop-toolbar__count { display: none; } }