/* === DESIGN TOKENS === */
:root {
  /* Spacing scale */
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 2rem;
  --space-lg: 3.2rem;
  --space-xl: 6.4rem;
  /* Brand colors */
  --color-red: rgb(204, 0, 0);
  --color-bright-red: rgb(241, 0, 0);
  --color-black: #121212;
  --color-text: rgb(51, 51, 51);
  --color-text-light: rgb(102, 102, 102);
  --color-border: #e6e6e6;
  --color-bg-light: #f4f4f4;
  /* Header */
  --header-top-height: 6.7rem;
  /* Z-index layers */
  --z-header: 1500;
  --z-mobile-menu: 1600;
  --z-modal: 9999;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
a { color: inherit; text-decoration: none; text-underline-offset: 0.35rem; }
html { max-width: 100%; font-size: clamp(8px, 0.52vw, 10px); }
body { overflow-x: hidden; position: relative; max-width: 100%; margin: 0; font-family: "Prompt", sans-serif; }
.header { position: sticky; top: 0; z-index: var(--z-header); width: 100%; border-bottom: 1px solid var(--color-border); background: #fff; transform: translateZ(0); transition: box-shadow 160ms ease; will-change: box-shadow; backface-visibility: hidden; }
.header.fixed { box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08); }
.headerTop { display: flex; overflow: hidden; justify-content: space-between; align-items: center; width: 100%; height: 6.7rem; padding: 0 6.4rem; background: var(--color-black); color: #fff; transition: height 220ms ease, opacity 180ms ease; will-change: height, opacity; }
.header.fixed .headerTop { opacity: 0; pointer-events: none; height: 0; }
.headerTop a, .headerTop p { padding-top: 1rem; padding-right: 1.5rem; padding-bottom: 1rem; font-size: 1.8rem; font-weight: 300; line-height: 2.4rem; }
.headerTop a:hover { color: var(--color-red); }
.headerNavbar { display: flex; position: relative; flex-direction: column; gap: 2.6rem; width: 100%; padding: 2.6rem 6.4rem 2rem 6.4rem; background: #fff; }
.navbarSearch { display: flex; justify-content: space-between; align-items: center; gap: 2rem; width: 100%; }
.navbarSearch a { flex-shrink: 0; }
.navbarSearch a img { width: 28rem; height: auto; }
.navbarSearchWrapper { display: flex; flex: 1; justify-content: space-between; align-items: center; gap: 1rem; max-width: 101rem; padding: .55rem 2.4rem; border-radius: 2.4rem; background: var(--color-border); }
.navbarSearchWrapper input { width: 100%; border: none; outline: none; background: var(--color-border); color: rgb(77, 77, 77); font-family: "Helvetica", sans-serif; font-size: 2rem; font-weight: 300; line-height: 100%; }
.navbarSearchWrapper:focus-within { border-radius: 2.4rem; outline: .1rem solid rgb(7, 7, 7); }
/* Voice Search Button */
.voice-search-btn { display: flex; cursor: pointer; flex-shrink: 0; justify-content: center; align-items: center; width: 3.2rem; height: 3.2rem; padding: 0; border: none; border-radius: 50%; background: none; color: #000000; transition: all 0.25s ease; }
.voice-search-btn:hover { background-color: rgba(204, 0, 0, 0.1); color: var(--color-red); transform: scale(1.05); }
.voice-search-btn:active { transform: scale(0.95); }
.voice-search-btn svg { width: 2.2rem; height: 2.2rem; fill: none; stroke: currentColor; stroke-width: 2; }
/* Navigation Dropdown Styles */
.nav-item-wrapper { position: relative; }
.nav-item-with-dropdown { display: flex; cursor: pointer; position: relative; align-items: flex-end; gap: 0.5rem; padding-bottom: 0.8rem; color: rgb(7, 7, 7); font-family: "DM Sans", sans-serif; font-size: 1.9rem; font-weight: 600; line-height: 1.9rem; letter-spacing: .05rem; }
.nav-item-with-dropdown::after { content: ""; position: absolute; bottom: 0px; left: 0; width: 0; height: 2px; background-color: rgb(7, 7, 7); transition: width 0.3s ease; }
.nav-item-with-dropdown:hover::after { width: 100%; }
.nav-item-with-dropdown svg { width: 2rem; color: rgb(7, 7, 7); transition: transform 0.3s ease; }
.nav-item-wrapper:hover .nav-item-with-dropdown svg { transform: rotate(180deg); }
.nav-dropdown { visibility: hidden; opacity: 0; position: absolute; top: 100%; left: 150%; z-index: 9999; min-width: 320px; margin-top: .5rem; padding: 1.6rem; border-radius: 0 0 1.2rem 1.2rem; background: #fff; box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15); transform: translateX(-50%); transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease; }
.nav-item-wrapper:hover .nav-dropdown { visibility: visible; opacity: 1; }
.nav-dropdown-content { display: flex; flex-direction: column; gap: 0.4rem; }
.nav-dropdown-item { display: flex; align-items: center; gap: 1.2rem; padding: 0.8rem; border-radius: 0.8rem; text-decoration: none; transition: background-color 0.2s ease; }
.nav-dropdown-item img { flex-shrink: 0; width: 8.5rem; height: auto; margin-right: 1rem; border-radius: 0.6rem; object-fit: cover; }
.nav-dropdown-item span { color: #333; font-family: "DM Sans", sans-serif; font-size: 1.9rem; font-weight: 700; line-height: 1.3; letter-spacing: .03rem; }
.nav-dropdown-item span:hover { color: var(--color-red); }
.hideDesk { display: none !important; }
/* Для мобильных устройств */
.marquee-wrapper { overflow-x: hidden; width: 100%; }
.navbarBacketWrapper { display: flex; align-items: center; gap: 1rem; }
.navbarBacketWrapper button { display: flex; cursor: pointer; justify-content: center; align-items: center; padding: 0.8rem; border: none; border-radius: 50%; background: transparent; }
.navbarBacketWrapper button:hover { background: #f0f0f0; }
.navbarBacketWrapper button:focus-visible { outline: 2px solid var(--color-red); outline-offset: 2px; }
.navbarBacketWrapper button svg { width: 3.6rem; height: 3.6rem; }
.navbarBacketWrapper button:nth-child(2) svg { width: 3.5rem; height: 3.5rem; color: #000; }
.navbarBacketWrapper button:nth-child(2) svg:hover { color: rgba(0, 0, 0, .7); }
.navbarBacketWrapper button:nth-child(1) svg { --color-bright-red; }
.navbarBacketWrapper button:hover svg { color: var(--color-black); }
.headerNavbarLinks { display: flex; opacity: 1; overflow: visible; align-items: center; gap: 2.4rem; width: 100%; max-height: 6rem; transform: translate3d(0, 0, 0); transform-origin: top; transition: max-height 300ms cubic-bezier(0.4, 0, 0.2, 1), opacity 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 300ms cubic-bezier(0.4, 0, 0.2, 1); will-change: transform, max-height, opacity; overflow-anchor: none; }
.headerNavbarLinks.linksHidden { opacity: 0; pointer-events: none; max-height: 0; transform: translate3d(0, -100%, 0); }
.headerNavbarLinks a { display: flex; position: relative; align-items: center; gap: 0.5rem; padding-bottom: 0.8rem; font-family: "DM Sans", sans-serif; font-size: 1.9rem; font-weight: 600; line-height: 1.9rem; letter-spacing: .05rem; }
.mobileMenuToggle { display: none; cursor: pointer; position: relative; flex-shrink: 0; width: 2.4rem; height: 2.4rem; padding-right: 2.8rem; border: none; background: transparent; color: var(--color-black); }
.mobileMenuToggle::before, .mobileMenuToggle::after, .mobileMenuToggle .burger-line { content: ''; position: absolute; left: 0; width: 100%; height: 2px; background-color: currentColor; transition: transform 0.3s ease, top 0.3s ease, bottom 0.3s ease, opacity 0.2s ease; }
.mobileMenuToggle::before { top: 2px; }
.mobileMenuToggle .burger-line { top: 50%; transform: translateY(-50%); }
.mobileMenuToggle::after { bottom: 2px; }
.mobileMenuToggle svg { display: none; }
.mobileMenuToggle.active::before { top: 50%; transform: translateY(-50%) rotate(45deg); }
.mobileMenuToggle.active .burger-line { opacity: 0; }
.mobileMenuToggle.active::after { bottom: 50%; transform: translateY(50%) rotate(-45deg); }
.mobileMenuToggle:focus-visible { outline: 2px solid var(--color-red); outline-offset: 2px; }
/* Main */
main { display: flex; flex-direction: column; }
/* Hero Section */
.hero { display: flex; overflow: hidden; position: relative; align-items: center; width: 100%; height: clamp(40rem, 45vw, 55rem); min-height: 43rem; }
.heroImageDesktop, .heroImageMobile { position: absolute; top: 0; left: 0; z-index: -1; width: 100%; height: 100%; object-fit: cover; }
.heroImageDesktop { display: block; }
.heroImageMobile { display: none; }
.heroContent { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 100%; max-width: 105.6rem; margin-right: 3rem; margin-left: auto; padding: 3.5rem 4rem; border-radius: 8.2rem 0; background: rgba(255, 255, 255, 0.65); text-align: center; }
.heroContent h1 { width: 100%; margin: 0; color: rgb(42, 43, 42); font-family: "Prompt", sans-serif; font-size: 4.1rem; font-weight: 400; line-height: 4.5rem; text-align: center; }
.heroContent p { width: 100%; margin: 1rem 0 2rem 0; margin-right: auto; margin-left: auto; color: rgb(42, 43, 42); font-family: "Prompt", sans-serif; font-size: 2.8rem; font-weight: 300; line-height: 3.5rem; }
.heroContentButtons { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 2rem; }
.heroContentButtons button { cursor: pointer; width: 26.5rem; height: 5.7rem; border: none; border-radius: 3rem; color: #fff; font-family: "Helvetica", sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: .075rem; text-transform: uppercase; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.btnPrimary { background: var(--color-red); }
.btnPrimary:hover { background: #000; }
.btnSecondary { background: #000; }
.btnSecondary:hover { background: var(--color-red); }
.btnBlack { display: inline-block; padding: 1.5rem 2rem; border-radius: 1rem; background: var(--color-black); color: white; font-size: 2rem; font-weight: 600; }
.btnRed { display: inline-block; padding: 1.5rem 2rem; border-radius: 1rem; background: var(--color-red); color: white; font-size: 2rem; font-weight: 600; }
.btnBlack:hover { background: var(--color-red); }
.btnRed:hover { background: rgb(0, 0, 0); }
/* Bottom Button Styles - Universal */
.bottom-button-wrapper { display: flex; position: absolute; bottom: 20px; left: 20px; z-index: 10; flex-direction: column; align-items: stretch; gap: .3rem; }
.bottom-button-label { display: flex; justify-content: center; align-items: center; gap: 8px; color: #ffffff; font-size: 1.35rem; font-weight: 500; letter-spacing: 0.15em; text-transform: uppercase; }
.bottom-button-label::before, .bottom-button-label::after { content: ''; display: block; flex: none; width: 37px; height: 1px; background-color: #ffffff; }
.bottom-button { display: flex; cursor: pointer; position: static; justify-content: center; align-items: center; margin: 0; padding: 7px 20px 7px 25px; border: 1px solid #1a0a00; border-radius: 100px; background-color: #1a0a00; color: #ffffff; font-size: 1.7rem; font-weight: 500; letter-spacing: .075rem; white-space: nowrap; text-decoration: none; text-transform: none; transition: background-color 0.25s ease, border-color 0.25s ease; }
.bottom-button:hover { border-color: #cc0000; background-color: #cc0000; color: #ffffff; }
.bottom-button-arrow { position: relative; top: 1px; margin-left: 8px; font-size: 18px; line-height: 1; }
/* Адаптация для мобильных устройств */
/* Features Bar */
.featuresBar { display: flex; justify-content: center; align-items: center; gap: 14rem; margin-bottom: 3rem; padding: 1.7rem; background: var(--color-bg-light); }
.featuresCarouselWrapper .featureItem { width: 100%; }
.featureItem { display: flex; align-items: center; gap: .75rem; }
.featureItem img { width: 3.7rem; height: auto; aspect-ratio: 1 / 1; object-fit: contain; }
.featureItem.large img { width: 7rem; }
.featureText { text-align: left; }
.featureTitle { margin-bottom: 0.2rem; color: rgb(42, 43, 42); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 2.4rem; }
.featureSubtitle { color: rgb(42, 43, 42); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 400; }
.description { max-width: 110rem; margin: 0 auto; color: #666; font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 1.6; text-align: center; }
.description p { margin-bottom: .75rem; color: #374151; font-family: "Helvetica", sans-serif; font-size: 2.8rem; font-weight: 400; line-height: 1.7; }
.description a { cursor: pointer; color:var(--color-bright-red); text-decoration: underline; }
.description a:hover { opacity:.7; color:var(--color-bright-red) }
/* Trusted By */
.trustedBy { display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 1rem; width: 100%; margin-top: 4rem; margin-bottom: 2rem; padding: 0 2rem; }
.trustedBy h1 { color: rgb(42, 43, 42); font-family: "Prompt", sans-serif; font-size: 3rem; font-weight: 400; line-height: 4.5rem; text-align: center; }
/* Marquee animation for trustedBy section */
@keyframes marquee {
0% { transform: translateX(0); }
100% { transform: translateX(-50%); }
}
.marquee-content { display: flex; gap: 4rem; animation: marquee 40s linear infinite; }
.marquee-wrapper:hover .marquee-content { animation-play-state: paused; }
.logo-item { display: inline-flex; justify-content: center; align-items: center; height: 60px; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.logo-item img { width: auto; max-width: 160px; height: 100%; object-fit: contain; }
/* Brands */
.brands { display: flex; cursor: pointer; justify-content: center; align-items: flex-start; gap: 4.5rem; width: 100%; }
.brandItem { display: flex; overflow: visible; flex-direction: column; justify-content: center; align-items: center; gap: 10px; margin-top: 2rem; }
.brandItem p { width: 128px; color: rgb(0, 0, 0); font-family: "Prompt", sans-serif; font-size: 2.1rem; font-weight: 400; line-height: 2.7rem; text-align: center; }
.brandItem:hover p { color: rgb(107, 102, 102); }
.brandItem div { width: 14.8rem; height: 14.8rem; border: 1px solid rgb(197 197 197 / 39%); border-radius: 50%; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.brandItem:hover div { transform: scale(1.1); }
.brandItem .brandItemLogo1 { background: url('../images/brands_button.webp') center/cover no-repeat; }
.brandItem .brandItemLogo2 { background: url('../images/eyeglasses_button.webp') center/cover no-repeat; }
.brandItem .brandItemLogo3 { background: url('../images/sunglasses_button.webp') center/cover no-repeat; }
.brandItem .brandItemLogo6 { background: url('../images/prescription_lenses.webp') center/cover no-repeat; }
.brandItem .brandItemLogo4 { background: url('../images/snow_goggles.webp') center/cover no-repeat; }
.brandItem .brandItemLogo4:hover { background: url('../images/swimming_goggles.webp') center/cover no-repeat; }
.brandItem .brandItemLogo5 { background: url('../images/activities_button.webp') center/cover no-repeat; }
.brandItem .brandItemLogo7 { border-color: var(--color-red); background: url('../images/sale_button.webp') center/cover no-repeat; }
.brandItem .brandItemLogo8 { background: url('../images/accessories_button.avif') center/cover no-repeat; }
.brandItem .brandItemLogo7 p { color: var(--color-red); }
/* Best Selling */
.bestSellingContainer { width: 100%; margin: 4rem auto 0 auto; padding: 0 6.4rem; }
.bestSellingContainer:nth-of-type(2) { margin: 0 auto; }
.bestSellingHeader { display: flex; justify-content: space-between; align-items: center; margin-bottom: 3.2rem; }
.bestSellingTitle { color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 2.8rem; font-weight: 400; line-height: 3.6rem; }
.bestSellingLink { color: var(--color-red); font-family: "Prompt", sans-serif; font-size: 2.3rem; font-weight: 400; line-height: 3rem; text-decoration: none; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingLink:hover { color: #000; text-decoration: none; }
.bestSellingGrid { display: flex; overflow-x: auto; cursor: grab; user-select: none; align-items: stretch; order: 10; gap: 2.5rem; padding-top: 1rem; padding-bottom: 4rem; padding-left: .5rem; scroll-behavior: smooth; }
.bestSellingGrid.active { cursor: grabbing; scroll-behavior: auto; }
.bestSellingGrid::-webkit-scrollbar { height: 2px; }
.bestSellingGrid::-webkit-scrollbar-track { border-radius: 10px; background: #f1f1f1; }
.bestSellingGrid::-webkit-scrollbar-thumb { border-radius: 10px; background: #888; }
.bestSellingGrid::-webkit-scrollbar-thumb:hover { background: #555; }
.bestSellingCard { display: flex; overflow: hidden; cursor: pointer; user-select: none; flex-direction: column; padding: 1rem; border-radius: 2.5rem; box-shadow: 0 0 10px rgba(0, 0, 0, 0.09); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingGrid .bestSellingCard { flex: 0 0 calc((100% - 8rem) / 5); width: calc((100% - 8rem) / 5); }
.bestSellingSectionCards .bestSellingCard { flex: 0 0 calc((100% - 6rem) / 3); width: calc((100% - 6rem) / 3); }
.bestSellingSectionCards.cards-4 .bestSellingCard { flex: 0 0 calc((100% - 6rem) / 4); width: calc((100% - 6rem) / 4); }
.bestSellingCard:focus-visible { outline: 2px solid var(--color-red); outline-offset: 4px; }
.bestSellingCard:hover { box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); }
.bestSellingCard:hover .bestSellingBtn { border-color: var(--color-red); color: var(--color-red); }
.bestSellingCard:hover .bestSellingName { color: var(--color-red); }
.bestSellingImageBox { display: flex; overflow: hidden; user-select: none; position: relative; justify-content: center; align-items: center; width: 100%; height: 32.5rem; }
.bestSellingIconsWrapper { display: flex; pointer-events: none; position: absolute; top: 1rem; right: 1rem; left: 1rem; z-index: 10; justify-content: space-between; align-items: flex-start; }
.bestSellingLikeIcon { display: flex; pointer-events: auto; cursor: pointer; justify-content: center; align-items: center; width: 2.9rem; height: 2.9rem; border: none; background: none; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingLikeIcon svg { width: 100%; height: 100%; color: #333; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingLikeIcon:hover svg { color: #f01911; fill: #f01911; }
.bestSellingLikeIcon.liked svg { color: #f01911; fill: #f01911; }
.bestSellingBrandIcon { display: flex; pointer-events: auto; justify-content: center; align-items: center; width: 2.9rem; height: 2.9rem; }
.bestSellingBrandIcon img { width: 100%; height: 100%; object-fit: contain; }
.bestSellingImage { user-select: none; position: absolute; top: 50%; left: 50%; width: 100%; height: auto; max-height: 100%; transform: translate(-50%, -50%); transition: opacity 0.3s ease; object-fit: contain; }
.bestSellingImageDefault { opacity: 1; z-index: 1; }
.bestSellingImageHover { opacity: 0; z-index: 2; }
.bestSellingCard:hover .bestSellingImageDefault { opacity: 0; }
.bestSellingCard:hover .bestSellingImageHover { opacity: 1; }
.bestSellingInfo { display: flex; flex: 1; flex-direction: column; justify-content: space-between; padding: 0; }
.bestSellingInfoTop { display: flex; flex-direction: column; }
.bestSellingName { display: -webkit-box; overflow: hidden; min-height: 4.8rem; margin-bottom: 0.6rem; color: #333; font-family: "Helvetica", sans-serif; font-size: 2.0rem; font-weight: 400; line-height: 3.1rem; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; }
.bestSellingPrice { margin-bottom: 1.6rem; color: #333; font-family: "Helvetica", sans-serif; font-size: 1.8rem; line-height: 2.4rem; }
.bestSellingPrice strong { margin-left: 0.5rem; font-size: 1.9rem; font-weight: 700; line-height: 2.4rem; }
.bestSellingColors { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.bestSellingColorCircle { display: flex; cursor: pointer; position: relative; justify-content: center; align-items: center; width: 6rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingColorCircle img { display: block; width: 100%; height: auto; margin-bottom: 3px; object-fit: contain; }
.bestSellingColorCircle::after { content: ""; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background-color: var(--color-red); transition: width 0.3s ease; }
.bestSellingColorCircle:hover::after { width: 100%; }
.moreColors { display: flex; cursor: pointer; justify-content: center; align-items: center; min-width: 3rem; padding: 0.5rem; border-radius: 0.5rem; background: #000; color: #fff; font-family: "Helvetica", sans-serif; font-size: 1.4rem; font-weight: 600; vertical-align: middle; transition: color 0.3s ease; }
.moreColors:hover { color: var(--color-red); }
.bestSellingBtn { cursor: pointer; width: 100%; padding: 1rem; border: 0.2rem solid rgb(42, 43, 42); border-radius: 3rem; background-color: transparent; color: rgb(42, 43, 42); font-family: "Prompt", sans-serif; font-size: 1.9rem; font-weight: 500; line-height: 2.4rem; letter-spacing: 0.035em; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingBtn:focus-visible { outline: 2px solid var(--color-red); outline-offset: 2px; }
/* Refresh Section */
.refreshContainer { width: 100%; padding: 3rem 6.4rem 2rem 6.4rem; }
.refreshContent { display: flex; justify-content: center; align-items: center; gap: 4rem; }
.refreshText { max-width: 56rem; }
.refreshTitle { margin-bottom: 2rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 2.9rem; font-weight: 400; line-height: 3.7rem; }
.refreshDescription { margin-bottom: 3.2rem; color: var(--color-text); font-size: 2.1rem; font-weight: 300; line-height: 2.9rem; }
.refreshBtn { cursor: pointer; padding: 1.6rem 3.2rem; border: none; border-radius: 3rem; background-color: #c7100a; color: #fff; font-family: "Prompt", sans-serif; font-size: 1.9rem; font-weight: 500; line-height: 1.9rem; letter-spacing: 0.05em; text-transform: uppercase; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.refreshBtn:hover { background-color: #000; }
.refreshImage { overflow: hidden; width: 100%; max-width: 93.6rem; padding: 3rem 6rem; background: var(--color-bg-light); }
.refreshImage img { width: 100%; height: auto; object-fit: contain; }
/* Info Cards */
.infoCardsSection { width: 100%; padding: 2rem 6.4rem; background-color: #fff; }
.infoCardsGrid { display: grid; gap: 3.5rem; grid-template-columns: repeat(2, 1fr); }
.infoCard { display: flex; flex-direction: column; gap: .75rem; padding: 3.2rem; border-radius: 1rem; background-color: var(--color-bg-light); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.infoCardTitle { margin: 0; color: #2a2b2a; font-family: "Prompt", sans-serif; font-size: 2.7rem; font-weight: 400; line-height: 1.4; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.infoCardTitle:hover { cursor: pointer; color: var(--color-red); }
.infoCardText, .infoCard p { flex-grow: 1; margin: 0; padding-bottom: 1rem; color: #2a2b2a; font-family: "Prompt", sans-serif; font-size: 2.1rem; font-weight: 300; line-height: 2.9rem; letter-spacing: 0.05rem; }
.infoCardBtn { display: inline-block; align-self: flex-start; padding: 1.2rem 3.2rem; border: none; border-radius: 3rem; background-color: var(--color-red); color: #fff; font-size: 1.75rem; font-weight: 500; letter-spacing: 0.075em; text-align: center; text-decoration: none; text-transform: uppercase; vertical-align: middle; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.infoCardBtn:hover { background-color: #000; }
/* Features Section */
.featuresSection { overflow-x: hidden; width: 100%; padding: 2.2rem 15rem; background-color: var(--color-bg-light); }
.featuresSection .featuresContainer { display: flex; position: relative; justify-content: space-between; align-items: center; gap: 2rem; }
.featuresSection .featuresCarouselWrapper { display: none; width: 100%; max-width: 140rem; margin: 0 auto; }
.featuresSection .featuresCarousel { width: 100%; }
.featuresSection .featuresCarouselItem { padding: 0 1.5rem; }
.featuresSection .featureItem { display: flex; position: relative; flex-direction: column; align-items: center; text-align: center; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.featuresSection .featureItem:hover { color: var(--color-red); transform: scale(1.05); }
.featuresSection .featureIconWrapper { margin-bottom: 0.5rem; }
.featuresSection .featureIconWrapper svg { width: 4.2rem; height: 4.2rem; }
.featuresSection .featureTitle { color: rgb(42, 43, 42); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 1.8rem; }
.featuresSection .featureDescription { color: rgb(42, 43, 42); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 400; line-height: 2.5rem; }
.featuresSection .featureDivider { position: absolute; top: 50%; right: -3rem; width: 1px; height: 8rem; background-color: rgba(107, 102, 102, 0.2); transform: translateY(-50%); }
/* Newsletter Section */
.newsletterSection { width: 100%; padding: 3.5rem 6.4rem; background-color: #bb1608; }
.newsletterContainer { text-align: center; }
.newsletterTitle { margin-bottom: 0.6rem; color: #fff; font-family: "Prompt", sans-serif; font-size: 3.6rem; font-weight: 300; line-height: 1.4; }
.newsletterDescription { opacity: 0.95; margin-bottom: 2rem; color: #fff; font-family: "Helvetica", sans-serif; font-size: 1.9rem; font-weight: 300; line-height: 2.4rem; }
.newsletterForm { display: flex; justify-content: center; align-items: stretch; gap: 0; max-width: 50rem; margin: 0 auto; }
.newsletterInputWrapper { display: flex; position: relative; flex: 1; }
.newsletterInput { box-sizing: border-box; width: 100%; padding: 0 2rem; border: none; border-radius: 0.5rem 0 0 0.5rem; outline: none; background-color: #fff; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.3rem; letter-spacing: .075rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.newsletterInput::placeholder { color: rgb(107, 102, 102); }
.newsletterError { position: absolute; bottom: -2.5rem; left: 0; padding: 0.6rem 1.2rem; border-radius: 0.4rem; background-color: var(--color-text); color: #fff; font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 300; letter-spacing: .12rem; white-space: nowrap; }
.newsletterError::before { content: ""; position: absolute; top: -0.4rem; left: 2rem; width: 0; height: 0; border-right: 0.4rem solid transparent; border-bottom: 0.4rem solid var(--color-text); border-left: 0.4rem solid transparent; }
.newsletterBtn { display: flex; cursor: pointer; flex-shrink: 0; justify-content: center; align-items: center; padding: 1rem 1rem; border: none; border-radius: 0 0.5rem 0.5rem 0; background-color: #000; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.newsletterBtn svg { width: 3.9rem; height: 3.4rem; }
.newsletterBtn:hover { background-color: var(--color-text); }
.newsletterArrow { width: 2rem; height: 2rem; color: #fff; }
/* Footer */
.footer { width: 100%; padding: 6rem 6.4rem 7rem 6.4rem; background-color: #222529; color: #fff; }
.footerTop { display: grid; gap: 4rem; grid-template-columns: 1.5fr 1fr 1.2fr 1.3fr; margin-bottom: 0rem; padding-bottom: 4rem; }
.footerColumn { display: flex; flex-direction: column; }
.footerLogo { width: 30rem; height: auto; margin-bottom: 1.5rem; }
.footerAbout { max-width: 40rem; color: rgba(255, 255, 255, 0.85); font-family: "Helvetica", sans-serif; font-size: 1.9rem; font-weight: 300; line-height: 3.1rem; letter-spacing: 0.1rem; }
.footerTitle { display: flex; cursor: pointer; justify-content: space-between; align-items: center; margin-bottom: 1rem; color: #fff; font-family: "Prompt", sans-serif; font-size: 2.1rem; font-weight: 500; letter-spacing: 0.07rem; }
.footerTitle svg { display: none; }
.footerList { display: flex; flex-direction: column; list-style: none; }
.footerLink { color: rgba(255, 255, 255, 0.85); font-family: "Helvetica", sans-serif; font-size: 1.8rem; line-height: 3.5rem; letter-spacing: 0.1rem; text-decoration: none; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.footerLink:hover { color: var(--color-red); transform: translateX(0.5rem); }
.footerContact { display: flex; flex-direction: column; gap: 2rem; }
.footerContact a { font-size: 1.7rem; line-height: 2.4rem; letter-spacing: 0.1rem; }
.footerAddress { color: rgba(255, 255, 255, 0.7); font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 2.4rem; text-decoration: none; }
.footerPhone strong, .footerHours strong { display: block; margin-bottom: 0.5rem; color: #fff; font-family: "Helvetica", sans-serif; font-weight: 600; }
.footerPhone, .footerHours { color: rgba(255, 255, 255, 0.85); font-family: "Helvetica", sans-serif; font-size: 1.75rem; line-height: 2rem; letter-spacing: 0.1rem; }
.footerSocial { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.footerSocialLink { width: 2.4rem; height: 2.4rem; color: rgba(255, 255, 255, 0.85); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.footerSocialLink:hover { color: var(--color-red); transform: translateY(-0.3rem); }
.footerSocialLink svg { width: 100%; height: 100%; }
.footerMiddle { display: flex; justify-content: space-between; align-items: center; padding: 2rem 0; border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
.footerLinks { display: flex; gap: 2.5rem; }
.footerBottomLink { color: rgba(255, 255, 255, 0.7); font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 2.4rem; text-decoration: none; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.footerBottomLink:hover { color: var(--color-red); }
.footerTopLink { color: rgba(255, 255, 255, 0.7); font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 600; line-height: 2.4rem; letter-spacing: 0.05em; text-decoration: none; text-transform: uppercase; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.footerTopLink:hover { color: var(--color-red); }
.footerBottom { display: flex; justify-content: space-between; align-items: center; padding-top: 3rem; }
.footerPayments { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; }
.footerPaymentIcon { width: 3.6rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.footerPaymentIcon:hover { opacity: 1; transform: scale(1.05); }
.footerCopyright { color: rgba(255, 255, 255, 0.5); font-family: "Helvetica", sans-serif; font-size: 1.3rem; text-align: center; }
/* ==================== RESPONSIVE ==================== */
/* Product Detail Page */
.productDetail { width: 100%; padding: 1rem 6.4rem; }
.backButton { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.9rem; font-weight: 400; }
.backButton svg { width: 1.5rem; height: 1.5rem; }
.backBtn { transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.backBtn:last-child { overflow: visible; white-space: normal; text-overflow: clip; overflow-wrap: anywhere; }
.backBtn:hover { text-decoration: underline; }
.productGrid { display: flex; position: relative; align-items: flex-start; gap: 3rem; width: 100%; max-width: 180rem; margin: 0 auto; }
.imageSection { display: flex; position: sticky; top: 14rem; flex: 1; flex-direction: column; align-self: flex-start; max-width: 105.7rem; height: fit-content; }
.imageZoomContainer { display: flex; overflow: hidden; cursor: zoom-in; position: relative; justify-content: center; align-items: center; width: 100%; max-width: 105.7rem; height: 58.1rem; border: 1px solid #f7f7f7; }
.productImage { width: 100%; transition: all 0.1s ease-out; object-fit: contain; }
.navButton { display: flex; cursor: pointer; position: absolute; top: 50%; z-index: 10; justify-content: center; align-items: center; width: 4rem; height: 4rem; border: 1px solid #ddd; border-radius: 50%; background-color: rgba(255, 255, 255, 0.9); transform: translateY(-50%); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.navButton:hover { background-color: rgba(255, 255, 255, 1); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15); }
.navButtonLeft { left: 2rem; }
.navButtonRight { right: 2rem; }
.colorVariants { display: flex; flex-wrap: nowrap; gap: 1rem; margin-top: 1.5rem; }
.colorVariant { display: block; overflow: hidden; cursor: pointer; position: relative; width: 8rem; height: 8rem; border: 1px solid #ddd; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.colorVariantImage { display: block; width: 100%; height: 100%; object-fit: contain; }
.colorVariant::after { content: ""; position: absolute; bottom: 0; left: 0; width: 0; height: 1px; background-color: rgb(7, 7, 7); transition: width 0.3s ease; }
.colorVariant:hover::after { width: 100%; }
.colorVariantActive::after { width: 100%; background-color: rgb(7, 7, 7); }
.productInfo { display: flex; flex-direction: column; flex-shrink: 0; width: 46.9rem; max-width: 100%; }
.productInfoLogo img { width: 12rem; }
.details h1 { color: var(--color-text); font-family: "Prompt", sans-serif; font-size: clamp(23px, 2.4rem, 2.4rem); font-weight: 400; line-height: 31px; }
.stars { display: flex; align-items: center; gap: 2rem; margin: 2rem 0; }
.rating { display: flex; align-items: center; gap: 0.2rem; }
.star { width: 2rem; height: 2rem; }
.reviews { color: rgb(0, 204, 0); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 400; line-height: 2.7rem; }
.sku { color: rgb(1, 51, 51); font-family: "Helvetica", sans-serif; font-size: 1.5rem; font-weight: 400; line-height: 2.1rem; }
.payment { display: flex; align-items: center; gap: 2rem; }
.productSize { display: flex; align-items: center; gap: 0.5rem; }
.price { color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 2.4rem; }
.rulerIcon { width: 2rem; height: 2rem; }
.productSize p { border-bottom: 1px solid #c7100a; color: rgb(24, 24, 24); font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 400; line-height: 2rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.productSize p:hover { cursor: pointer; border-color: #000; }
.wishlist { display: flex; cursor: pointer; align-items: center; gap: 1rem; border: none; background: none; color: #b90909; font-size: 1.8rem; font-weight: 700; line-height: normal; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.wishlisted .heartIcon { color: #b90909; }
.heartIcon { width: 2rem; height: 2rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.buttons { display: flex; flex-direction: column; gap: 1rem; margin-top: 3rem; }
.buttons button { cursor: pointer; padding: 1.2rem 2.6rem; border: 2px solid #000; border-radius: 3rem; background-color: #000; color: #fff; font-size: 1.6rem; font-weight: 700; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.buttons button:nth-child(1) { background: #fff; color: #000; }
.buttons button:nth-child(1):hover { background: #000; color: #fff; }
.buttons button:nth-child(2):hover { background: #fff; color: #000; }
.check { display: flex; align-items: flex-start; gap: 1.5rem; margin-top: 2rem; padding: 1rem; border-radius: 1rem; background: #f5f5f5; }
.checkIcon { font-size: 4.2rem; }
.check p { color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.4rem; line-height: 2.1rem; }
.accordionContainer { margin-top: 2rem; }
.accordionItem { overflow: hidden; margin-bottom: 1rem; border: 1px solid #424940; border-radius: 2rem; }
.accordionHeader { display: flex; cursor: pointer; user-select: none; justify-content: space-between; align-items: center; padding: 1rem 1rem; background: #ffffff; transition: background 0.3s ease; }
.accordionHeader:hover { background: #f9f9f9; }
.accordionTitle { display: flex; align-items: center; gap: 0.5rem; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 2.4rem; }
.accordionTitleIcon { width: 2rem; height: 2rem; color: #333333; }
.accordionArrow { flex-shrink: 0; width: 2rem; height: 2rem; color: #4d4d4d; transition: transform 0.3s ease; }
.accordionOpen .accordionArrow { transform: rotate(180deg); }
.accordionTitle svg { font-size: 2.5rem; }
.accordionContent { overflow: hidden; max-height: 0; padding: 0 2rem; background: #ffffff; color: #666666; font-family: "Helvetica", sans-serif; font-size: 1.4rem; line-height: 2.1rem; transition: max-height 0.3s ease, padding 0.3s ease; }
.accordionOpen .accordionContent { max-height: 1000px; padding: 0 2rem 2rem 2rem; }
.accordionContent p { margin-bottom: 0.5rem; color: #333; font-size: 1.8rem; line-height: 2.4rem; }
.modalOverlay { display: flex; position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 9999; justify-content: center; align-items: center; background-color: rgba(0, 0, 0, 0.7); }
.modalContent { overflow-x: auto; position: relative; width: 90%; max-width: 75rem; max-height: 90vh; padding: 3.5rem 2rem 1rem; border-radius: 0.5rem; background-color: #fff; }
.closeButton { cursor: pointer; position: absolute; top: 1.5rem; right: 2rem; border: none; background: none; color: #000; font-size: 2rem; transition: color 0.3s ease; }
.sizeGuideModal { display: none; z-index: 9999; }
.imageModalOverlay { display: none; overflow: hidden; cursor: pointer; position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: 2000; justify-content: center; align-items: center; background-color: rgba(0, 0, 0, 0.95); }
.imageModalContent { display: flex; position: relative; justify-content: center; align-items: center; width: 100%; height: 100%; background: #fff; }
.imageModalImg { user-select: none; max-width: 90%; max-height: 90%; object-fit: contain; }
.relatedProducts { padding: 4rem 6.4rem; }
.relatedProducts h2 { margin-bottom: 3rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 2.8rem; font-weight: 400; }
.relatedProductsGrid { display: flex; overflow-x: auto; cursor: grab; user-select: none; align-items: stretch; gap: 2.5rem; padding-top: 1rem; padding-bottom: 2rem; scroll-behavior: smooth; }
.relatedProductsGrid::-webkit-scrollbar { height: 2px; }
.relatedProductsGrid::-webkit-scrollbar-track { border-radius: 10px; background: #f1f1f1; }
.relatedProductsGrid::-webkit-scrollbar-thumb { border-radius: 10px; background: #888; }
.relatedProductsGrid .bestSellingCard { flex: 0 0 calc((100% - 7.5rem) / 4); width: calc((100% - 7.5rem) / 4); }
/* === ARTICLES PAGE STYLES === */
.articlesPage { width: 100%; padding: 1rem 6.4rem 0rem; }
.articlesHeader { display: flex; justify-content: space-between; align-items: center; margin: 2rem 0 1.4rem 0; }
.articlesTitle { color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 3.2rem; font-weight: 400; line-height: 4rem; }
.shareSection { display: flex; align-items: center; gap: 1rem; }
.shareSection span { color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 700; line-height: 2.4rem; }
.shareIcon { display: flex; justify-content: center; align-items: center; width: 2.4rem; height: 2.4rem; color: var(--color-text); transition: color 0.3s ease; }
.shareIcon:hover { color: var(--color-red); }
.shareIcon svg { width: 100%; height: 100%; }
.categoriesWrapper { position: relative; margin-bottom: 3.2rem; padding: 1.2rem 0; padding-right: 8rem;  }
.categoriesWrapper.expanded { padding-right: 0; }
.categoriesInner { display: flex; overflow: hidden; flex-wrap: wrap; align-items: center; gap: 0.6rem 3.2rem; max-height: calc((2.7rem + 1rem) * 2 + 0.6rem); transition: max-height 0.3s ease; }
.categoriesWrapper.expanded .categoriesInner { max-height: none; }
.categoryBtn { display: inline-grid; cursor: pointer; position: relative; padding: 0.5rem 0; border: none; background: none; color: var(--color-text); font-size: 1.8rem; font-weight: 400; line-height: 2.7rem; white-space: nowrap; transition: color 0.2s ease; }
.categoryBtn::before { content: attr(data-label); visibility: hidden; grid-area: 1 / 1; font-weight: 600; }
.categoryBtnLabel { grid-area: 1 / 1; }
.categoryBtn::after { content: ""; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background: currentColor; transition: width 0.2s ease; }
.categoryBtn:hover { color: #000; }
.categoryBtn:hover::after { width: 100%; }
.categoryBtn:focus-visible { border-radius: 4px; outline: 2px solid rgba(0, 0, 0, 0.35); outline-offset: 3px; }
.categoryBtn.active { color: #000; font-weight: 600; }
.categoryBtn.active::after { width: 100%; }
.moreBtn { display: flex; cursor: pointer; position: absolute; right: 0; bottom: 1.2rem; align-items: center; gap: 0.5rem; padding: 0.5rem 0; padding-left: 1rem; border: none; background: #fff; color: var(--color-red); font-size: 1.8rem; font-weight: 600; line-height: 2.7rem; white-space: nowrap; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.categoriesWrapper.expanded .moreBtn { position: absolute; right: 0; bottom: auto; padding-left: 0; background: transparent; }
.moreBtn:hover { color: var(--color-bright-red); text-decoration: underline; }
.moreBtn svg { width: 1.6rem; height: 1.6rem; }
.featuredArticle { display: flex; overflow: hidden; cursor: pointer; gap: 8rem; margin-bottom: 6.4rem; padding: 4rem; background: var(--color-bg-light); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.featuredArticle:hover .featuredTitle { color: var(--color-red); }
.featuredImage { flex-shrink: 0; width: 100%; max-width: 75rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.featuredImage img { width: 100%; height: 100%; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; object-fit: cover; }
.featuredImage:hover img { transform: scale(1.05); }
.featuredContent { display: flex; flex: 1; flex-direction: column; justify-content: center; }
.featuredTitle { margin-bottom: 1.5rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 2.9rem; font-weight: 400; line-height: 3.7rem; }
.featuredExcerpt { margin-bottom: 1.5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.4rem; line-height: 3.2rem; }
.featuredMeta { margin-bottom: 2rem; color: var(--color-text-light); font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 400; line-height: 2.7rem; }
.featuredArrow { display: flex; justify-content: center; align-items: center; width: 5.6rem; height: 5.6rem; border: 2px solid var(--color-bright-red); border-radius: 50%; color: var(--color-red); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.featuredArrow:hover { background: #f4e5e4; }
.featuredArrow svg { width: 2.4rem; height: 2.4rem; }
.articlesGrid { display: grid; gap: 4rem 3rem; grid-template-columns: repeat(3, 1fr); margin-bottom: 4rem; }
.articleCard { display: flex; flex-direction: column; text-decoration: none; }
.articleCard:hover .articleTitle { color: var(--color-red); }
.articleImage { overflow: hidden; width: 100%; height: 20rem; margin-bottom: 1.5rem; }
.articleImage img { display: block; width: 100%; height: 100%; transition: transform 0.3s ease; object-fit: cover; object-position: top; }
.articleCard:hover .articleImage img { transform: scale(1.05); }
.articleCategory { display: block; margin-bottom: 0.8rem; color: rgba(51, 51, 51, 0.6); font-family: "Helvetica", sans-serif; font-size: 1.9rem; line-height: 2.1rem; }
.articleTitle { display: -webkit-box; overflow: hidden; margin-bottom: .7rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 2.5rem; font-weight: 400; line-height: 3.4rem; transition: color 0.3s ease; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; }
.articleExcerpt { display: -webkit-box; overflow: hidden; margin-bottom: 1rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.0rem; -webkit-line-clamp: 3; line-clamp: 3; -webkit-box-orient: vertical; }
.articleMeta { margin-top: auto; color: rgba(51, 51, 51, 0.6); font-family: "Helvetica", sans-serif; font-size: 1.9rem; line-height: 2.4rem; }
.pagination { display: flex; justify-content: center; align-items: center; gap: 5rem; padding: 3rem 0; border-top: 1px solid #e5e5e5; }
.paginationBtn { display: flex; cursor: pointer; align-items: flex-end; gap: 0.5rem; border: none; background: none; color: var(--color-text); font-size: 1.9rem; line-height: 2.2rem; transition: color 0.3s ease; }
.paginationBtn:hover:not(:disabled) { color: var(--color-text); }
.paginationBtn:disabled { cursor: not-allowed; color: rgba(51, 51, 51, 0.6); }
.paginationBtn svg { position: relative; top: 1px; width: 1.8rem; height: 2.4rem; vertical-align: middle; }
.paginationNumbers { display: flex; align-items: center; gap: 0.5rem; }
.pageNumber { display: flex; cursor: pointer; justify-content: center; align-items: center; width: 3rem; height: 3rem; border: none; border-radius: 0.3rem; background: none; color: var(--color-text); font-size: 2.1rem; line-height: 1.6rem; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.pageNumber:hover { background: #f5f5f5; }
.activePage { border-bottom: 0.2rem solid var(--color-text); border-radius: 0; font-weight: 600; }
.paginationDots { padding: 0 0.5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.8rem; }
/* === ABOUT US PAGE STYLES === */
.aboutPage { width: 100%; padding: 2rem 6.4rem 4rem; }
.pageTitle { margin-bottom: 2rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 3.2rem; font-weight: 400; line-height: 4rem; text-align: center; }
.aboutContent { max-width: 80rem; margin: 0 auto; padding: 0 2rem; }
.mainTitle { margin-bottom: 2rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 3.7rem; font-weight: 600; line-height: 4.4rem; }
.sectionTitle { margin-top: 2.5rem; margin-bottom: .5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.4rem; font-weight: 700; line-height: 2.4rem; }
.aboutContent p { margin-bottom: 1.5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.7rem; }
.italicText { font-style: italic; }
.contactInfo { padding-top: 2rem; }
.contactTitle { margin-bottom: 0.5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.9rem; font-weight: 400; line-height: 3.2rem; }
.contactLink { display: block; margin-bottom: 0.5rem; color: var(--color-red); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 2.4rem; text-decoration: none; transition: color 0.3s ease; }
.contactLink:hover { text-decoration: underline; }
.phoneInfo { margin-top: 1.5rem; }
.phoneInfo p { margin-bottom: 0.3rem; }
.hoursInfo { margin-top: 1.5rem; }
.hoursInfo p { margin-bottom: 0.3rem; }
.calendarLink { color: var(--color-red); font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 2.4rem; text-decoration: none; transition: color 0.3s ease; }
.calendarLink:hover { text-decoration: underline; }
/* === BRANDS PAGE STYLES === */
.brandsPage { width: 100%; padding: 1rem 6.4rem 4rem; }
.heroBanner { width: 100%; margin-bottom: 2rem; }
.heroBanner img { width: 100%; height: auto; object-fit: cover; }
.filterSection { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; gap: 0.5rem; margin-bottom: 2rem; padding: 2rem; border-bottom: 1px solid #e5e5e5; background: #f3f3f3; }
.filterBtn { display: flex; cursor: pointer; justify-content: center; align-items: center; min-width: 4.5rem; height: 4.5rem; padding: 0 0.8rem; border: 1px solid #000; border-radius: 0.7rem; background: none; color: var(--color-text); font-size: 2.7rem; font-weight: 500; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.filterBtn.active, .filterBtn:hover { border-color: var(--color-text); background: var(--color-text); color: #fff; }
.filterBtn:focus-visible { outline: 2px solid var(--color-red); outline-offset: 2px; }
.filterTitle { flex-basis: 100%; width: 100%; margin-bottom: 0.5rem; color: var(--color-text); font-size: 2.1rem; font-weight: 500; }
.brandsGrid { display: grid; gap: 3rem 2rem; grid-template-columns: repeat(5, 1fr); }
.brandCard { display: flex; flex-direction: column; align-items: center; text-decoration: none; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.brandCard:hover .brandLogo { opacity: 0.7; }
.brandCard:hover .brandName { opacity: 0.7; }
.brandLogo { display: flex; justify-content: center; align-items: center; width: 100%; height: 10rem; margin-bottom: 1rem; transition: transform 0.3s ease; }
.brandLogo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.brandName { color: rgb(0, 0, 0); font-family: "Helvetica", sans-serif; font-size: 1.9rem; font-weight: 400; line-height: 2.4rem; letter-spacing: 0.05em; text-align: center; text-transform: uppercase; transition: color 0.3s ease; }
.noResults { padding: 4rem 0; text-align: center; }
.noResults p { color: var(--color-text-light); font-family: "Helvetica", sans-serif; font-size: 1.6rem; }
/* === EYEGLASSES/SUNGLASSES PAGE STYLES === */
.eyeglassesPage { width: 100%; padding: 1rem 6.4rem; }
.heroSection { display: flex; justify-content: space-between; align-items: flex-start; gap: 4rem; padding: 1rem 8rem 3rem 0; }
.heroTitle { margin-bottom: 1rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 3.2rem; font-weight: 400; line-height: 4rem; }
.heroSubtitle { margin-bottom: 0.5rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 2.5rem; font-weight: 400; line-height: 3.3rem; }
.heroSectionSale { margin-bottom: 0; }
.featureList { display: flex; flex-direction: column; gap: 0.8rem; margin: 0; padding-left: 2rem; list-style: none; }
.featureList li { display: flex; align-items: center; gap: 1rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; font-weight: 300; line-height: 3.1rem; }
.featureList li .checkIcon { flex-shrink: 0; width: 1.9rem; height: 1.9rem;stroke-width: 7rem !important; color:#197bfe }
.heroSection .heroContent { flex: 1; align-items: flex-start; width: auto; max-width: none; margin: 0; padding: 0 0 1rem 0; border: none; border-radius: 0; background: none; box-shadow: none; text-align: left; }
.heroSection .heroContent h1 { text-align: left; }
.heroSection .heroContent p { margin-right: 0; margin-left: 0; text-align: left; }
.heroImage { display: flex; flex: 1; justify-content: flex-end; max-width: 58rem; height: auto; }
.heroImage img { width: 100%; height: auto; max-height: 100%; object-fit: contain; }
.categoriesSection { display: flex; position: relative; align-items: center; gap: 1rem; padding: 0rem 0 3rem; }
.sliderBtn { display: flex; cursor: pointer; z-index: 10; flex-shrink: 0; justify-content: center; align-items: center; width: 4rem; height: 4rem; border: 1px solid #ddd; border-radius: 50%; background: #fff; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.sliderBtn:hover:not(:disabled) { border-color: #333; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); }
.sliderBtn:disabled { opacity: 0.4; cursor: not-allowed; }
.sliderBtn svg { width: 3rem; height: 3rem; color: #333; }
.categoriesSlider { display: flex; overflow-x: auto; flex: 1; align-items: stretch; gap: 1.5rem; padding: 1rem 0 1rem .5rem; scroll-behavior: smooth; scrollbar-width: none; -ms-overflow-style: none; }
.categoriesSlider::-webkit-scrollbar { display: none; }
.categoryCard { display: flex; flex-shrink: 0; align-items: center; gap: 1.2rem; max-width: 220px; padding: 1rem 2rem; border: 1px solid #E9E9E9; border-radius: 0.7rem; background: #fff; text-decoration: none; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.categoryCard:hover { box-shadow: 1px 1px 6px 2px rgba(34, 60, 80, 0.2); }
.categoryImage { display: flex; flex-shrink: 0; justify-content: center; align-items: center; width: 8rem; height: 4rem; }
.categoryImage img { width: 100%; height: 100%; object-fit: contain; }
.categoryName { color: var(--color-text); font-family: "Helvetica", arial, sans-serif; font-size: 2rem; font-weight: 500; line-height: 2.9rem; text-align: left; }
.bestSellingSection { display: flex; flex-direction: column; align-items: center; gap: 2rem; width: 100%; }
.bestSellingSectionCards { display: flex; flex-wrap: wrap; justify-content: center; align-items: stretch; gap: 2rem 2rem; width: 100%; padding: .9rem; }
.bestSellingSectionCards.cards-3 { gap: 3rem 3rem; }
.bestSellingLoadMore { cursor: pointer; width: 25rem; height: 4.6rem; margin-bottom: 2rem; border: 1px solid #000; outline: none; background: none; color: #000; font-family: "Helvetica", sans-serif; font-size: 1.9rem; font-weight: 400; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bestSellingLoadMore:hover:not(:disabled) { background: #000; color: #fff; }
.bestSellingLoadMore:disabled { cursor: not-allowed; }
.descriptionSection { width: 100%; max-width: 125rem; margin: 0 auto; padding: 2rem 0 0rem 0rem; }
.sunglassesDescription { max-width: max-content; }
.descriptionSection p { margin-bottom: .7rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.2rem; }
.descriptionSection p a { color: #f01911; text-decoration: underline; }
.descriptionSection h3 { margin-top: 2rem; margin-bottom: 0.5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; font-weight: 700; line-height: 2.4rem; }
.descriptionSection ul { margin: 1.5rem 0 2rem; padding-left: 0rem; list-style: none; }
.descriptionSection ul li { margin-bottom: 0.5rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.2rem; position: relative;  padding-left: 5rem;}
.descriptionSection ul li::before { content: "•"; position: absolute; left: 0; font-size: 3rem; color: black; line-height: 1;}
.descriptionSection ul li strong { font-weight: 700; }
.brandFeatureSection { width: max-content; margin: 2rem auto 3rem auto; padding: 2rem 4rem 2rem 2rem; background-color: #f5f5f5; }
.brandFeatureContainer { display: flex; align-items: center; gap: 5rem; }
.brandFeatureImage { flex-shrink: 0; width: 55rem; }
.brandFeatureImage img { width: 100%; height: 100%; object-fit: cover; }
.brandFeatureContent { flex: 1; }
.brandFeatureContent h2 { margin-bottom: 1.5rem; color: var(--color-text); font-family: "Prompt", sans-serif; font-size: 3.2rem; font-weight: 400; font-style: normal; line-height: 4rem; }
.brandFeatureContent p { max-width: 55rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.2rem; }
.kidsSizeIcon { pointer-events: none; position: absolute; right: 1rem; bottom: 1rem; z-index: 10; }
.kidsSizeDesktop { display: block; width: 7rem; height: auto; object-fit: contain; }
.kidsSizeMobile { display: none; width: 4rem; height: auto; object-fit: contain; }
/* === SALE PAGE STYLES === */
.salePriceWrapper { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: 1.6rem; }
.salePrices { display: flex; align-items: center; gap: 1rem; font-size: 1.8rem; font-family: "Helvetica", sans-serif}
.salePrice { color: #e22d2d; font-family: "Helvetica", sans-serif; font-size: 2rem; font-weight: 700; line-height: 2.4rem; }
.originalPrice { color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.7rem; font-weight: 400; line-height: 2.4rem; text-decoration: line-through; }
.saleBadge { padding: 0.5rem 1rem; border-radius: 2rem; background-color: var(--color-red); color: #fff; font-size: 1.2rem; font-weight: 500; line-height: 1; white-space: nowrap; }
/* === RISK FREE GUARANTEE PAGE STYLES === */
.guaranteePage { width: 100%; padding: 2rem 6.4rem 4rem; }
.badgeWrapper { display: flex; justify-content: center; margin-bottom: 3rem; }
.badge { width: 29.6rem; height: auto; object-fit: contain; }
.guaranteeContent { max-width: 80rem; margin: 0 auto; padding: 0 2rem; }
.guaranteeContent p { margin-bottom: .75rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.7rem; }
.guaranteeContent p strong { font-weight: 700; }
.link { color: var(--color-red); text-decoration: underline; transition: color 0.3s ease; }
.link:hover { text-decoration: underline; }
.bulletList { margin-bottom: 1.5rem; padding-left: 0rem; list-style: none; }
.bulletList li { margin-bottom: 0.8rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 2.1rem; line-height: 3.2rem; position: relative;  padding-left: 2.5rem;}
.bulletList li::before { content: "•"; position: absolute; left: 0; font-size: 3.1rem; line-height: 2.5rem;}

/* === NOT FOUND / 404 PAGE STYLES === */
/* NOTE: .errorPage .container overrides the global .container padding. Add class="errorPage" to the 404-page wrapper element in HTML. */
.icon { width: 100%; }
.icon img { width: 15rem; height: auto; }
/* === SHIPPING & MEASUREMENTS STYLES === */
.shippingSection { width: 100%; }
.shippingTitle { margin-bottom: 2rem; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 700; line-height: 2.4rem; }
.shippingTable { margin-bottom: 2rem; }
.shippingRow { display: flex; justify-content: flex-start; align-items: center; gap: 2rem; padding: 0.3rem 0; font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 2.4rem; }
.shippingLabel { min-width: 150px; color: #333; font-size: 1.8rem; font-weight: bold; }
.shippingValue { color: #333; font-size: 1.8rem; font-weight: 400; }
.shippingText { margin-bottom: 1.5rem; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 2.4rem; }
.shippingLink { margin-bottom: 2rem; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.6rem; line-height: 2.4rem; }
.shippingSubtitle { margin-top: 2rem; margin-bottom: 1rem; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 700; }
.measurementsSection { overflow-x: auto; width: 100%; -webkit-overflow-scrolling: touch; }
.measurementsTable { width: 100%; font-family: "Helvetica", sans-serif; border-collapse: collapse; }
.measurementsTable thead th { padding: 0.5rem 1rem; text-align: center; vertical-align: bottom; }
.measurementsTable thead th:first-child { width: 40%; }
.measurementsTable .sizeLabel { display: block; color: #333333; font-size: 1.6rem; font-weight: 400; }
.measurementsTable .sizeAsterisk { display: block; color: #333333; font-size: 1.4rem; font-weight: 400; }
.measurementsTable .sizeNumber { display: block; margin-top: 0.2rem; color: #333333; font-size: 1.8rem; font-weight: 700; }
.measurementsTable tbody td { padding: 0.3rem 1rem; color: #333333; font-size: 1.6rem; line-height: 2.2rem; text-align: center; }
.measurementsTable tbody td.measurementLabel { color: #333; font-weight: 400; white-space: nowrap; text-align: left; }
.measurementNote { margin: 1.5rem 0 0 0; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.4rem; font-style: normal; text-align: left; }
.redText { color: #c62828; font-weight: 600; }
.specificationTable { width: 100%; }
.specRow { display: flex; gap: 5rem; padding: 0.5rem 0; }
.specRow:last-child { border-bottom: none; }
.specLabel { width: 20rem; color: #333; font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: bold; }
.specValue { color: #333; font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 400; text-align: right; }
/* === MODAL STYLES === */
.modalTitle { margin-bottom: 1rem; color: #333; font-family: "Prompt", sans-serif; font-size: 1.5rem; font-weight: 500; }
.modalDescription { margin-bottom: 2rem; color: #333; font-family: "Prompt", sans-serif; font-size: 1.5rem; font-weight: 400; }
.modalNote { margin-bottom: 1.5rem; color: #333; font-family: "Helvetica", sans-serif; font-size: 1.4rem; line-height: 1.8rem; }
.modalNote span { color: #c7100a; }
.modalFootnote { margin: 1rem 0 2rem 0; padding-left: 10%; color: #333; font-family: "Helvetica", sans-serif; font-size: 1.4rem; line-height: 2rem; }
.sizeTable { width: 80%; margin: 0 auto; margin-bottom: 1rem; border: 1px solid #ccc; border-collapse: collapse; }
.sizeTable th, .sizeTable td { padding: 1rem; border: 1px solid #ccc; font-family: "Helvetica", sans-serif; font-size: 1.4rem; line-height: 1.8rem; text-align: left; }
.sizeTable thead { background-color: #d9d7d7; }
.sizeTable th { color: var(--color-text); font-weight: 700; }
.sizeTable tbody tr { background-color: #d9d7d7; }
.sizeTable tbody tr:nth-child(even) { background-color: #f5f5f5; }
.sizeTable td { color: var(--color-text); }
.diagramSection { display: flex; align-items: center; gap: 1rem; width: 100%; margin-top: 3rem; }
.diagramSection img { width: 48.5rem; height: auto; }
.diagramLabels { display: flex; flex-direction: column; gap: 0; }
.diagramLabels p { color: #333; font-family: "Helvetica", sans-serif; font-size: 1.3rem; font-weight: 400; line-height: 2rem; }
.imageModalClose { display: flex; cursor: pointer; position: absolute; top: 2rem; right: 2rem; z-index: 2001; justify-content: center; align-items: center; width: 5rem; height: 5rem; padding: 0; border: none; border-radius: 50%; background-color: rgba(255, 255, 255, 0.9); color: #333; font-size: 3rem; line-height: 100%; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.imageModalClose:hover { background-color: rgba(255, 255, 255, 1); transform: scale(1.1); }
.imageModalNav { display: flex; cursor: pointer; position: absolute; top: 50%; z-index: 2001; justify-content: center; align-items: center; width: 6rem; height: 6rem; border: none; border-radius: 50%; background-color: rgba(255, 255, 255, 0.9); transform: translateY(-50%); transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.imageModalNav:hover { background-color: rgba(255, 255, 255, 1); transform: translateY(-50%) scale(1.1); }
.imageModalNavLeft { left: 3rem; background: none; }
/* === BOTTOM BAR (MOBILE CART) === */
.bottomBar { position: fixed; right: 0; bottom: 0; left: 0; z-index: 100; border-top: 1px solid #e5e5e5; background: #fff; box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1); transform: translateY(100%); transition: transform 0.3s ease; }
.bottomBarContent { display: flex; justify-content: space-between; align-items: center; gap: 2rem; padding: 1rem 6.4rem; }
.bottomBarLeft { display: flex; flex: 1; align-items: center; gap: 1.5rem; }
.bottomBarImage { flex-shrink: 0; width: 6rem; height: 6rem; }
.bottomBarImage img { width: 100%; height: 100%; object-fit: contain; }
.bottomBarInfo { flex: 1; }
.bottomBarInfo h4 { margin-bottom: 0.3rem; color: #333; font-family: "Helvetica", sans-serif; font-size: 1.4rem; font-weight: 700; }
.bottomBarVariant { margin-bottom: 0.2rem; color: var(--color-text); font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 400; line-height: 2.1rem; }
.bottomBarChoose { cursor: pointer; color: #c7100a; font-weight: 600; }
.bottomBarPrice { color: #333; font-family: "Helvetica", sans-serif; font-size: 1.6rem; font-weight: 700; }
.bottomBarButtons { display: flex; flex-shrink: 0; gap: 1rem; }
.bottomBarButtons button { cursor: pointer; padding: 0.8rem 2rem; border-radius: 3rem; font-size: 1.4rem; font-weight: 700; white-space: nowrap; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.bottomBarButtons button:first-child { border: 2px solid #000; background: #fff; color: #000; }
.bottomBarButtons button:first-child:hover { background: #000; color: #fff; }
.bottomBarButtons button:last-child { border: 2px solid #000; background: #000; color: #fff; }
.bottomBarButtons button:last-child:hover { background: #fff; color: #000; }
/* === READ MORE & ADDITIONAL === */
.readMore { cursor: pointer; margin-top: 1rem; padding: 0; border: none; background: transparent; color: #fc3131; font-size: 1.8rem; font-weight: 500; text-decoration: none; transition: text-decoration 0.3s ease; }
.readMore:hover { text-decoration: underline; }
.sizeLabel { display: block; color: #333333; font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: 700; }
.sizeAsterisk { font-weight: 700; }
.sizeNumber { display: block; margin-top: 0.2rem; color: #333333; font-size: 1.8rem; font-weight: 700; }
.measurementLabel { color: #333; font-family: "Helvetica", sans-serif; font-size: 1.8rem; font-weight: bold; }
/* --- Core Web Vitals Ultra Optimizations --- */
section { content-visibility: auto; contain-intrinsic-size: 1000px; }
.card, .bestSellingCard, .productCard { transform: translateZ(0); will-change: transform; }
.headerNavbarLinks > a:last-child { color: var(--color-red) !important; }
@media (max-width: 1440px) and (min-width: 769px) {
.kidsSizeIcon { right: 0.8rem; bottom: 0.8rem; }
.kidsSizeDesktop { width: 6rem; }
.heroSectionSale { margin-bottom: 2rem; }
.salePriceWrapper { gap: 0.8rem; }
.salePrice { font-size: 1.9rem; }
.originalPrice { font-size: 1.7rem; }
.saleBadge { padding: 0.4rem 0.8rem; font-size: 1.4rem; }
.bestSellingSectionCards { justify-content: flex-start; }
.bestSellingSectionCards .bestSellingCard { width: calc((100% - 6rem) / 3); }
.bestSellingSectionCards.cards-4 .bestSellingCard { width: calc((100% - 6rem) / 4); }
.bestSellingImageBox { height: clamp(24rem, 20vw, 34rem); }
}
@media (max-width: 1440px) {
.navbarSearchWrapper { gap: 2.4rem; max-width: 80rem; height: 5rem; }
.navbarBacketWrapper button svg { width: 3.3rem; height: 3.3rem; }
.heroContent { width: 100%; max-width: 89.2rem; }
.bestSellingImageBox { height: auto; aspect-ratio: 1/1; }
.refreshContent { gap: 11.4rem; }
.refreshText { max-width: 45rem; }
.refreshImage { max-width: 76.6rem; padding: 0; background: none; }
.refreshImage img { object-fit: contain; }
.imageSection { max-width: 77rem; }
.productDetail { padding: 1rem 6.4rem; }
.productGrid { justify-content: space-between; gap: 3rem; }
.imageZoomContainer { width: 100%; height: 50rem; }
.productInfo { width: 53.9rem; }
}
@media (max-width: 1280px) and (min-width: 1024px) {
.bestSellingGrid .bestSellingCard { flex: 0 0 calc((100% - 8rem) / 5); width: calc((100% - 8rem) / 5); }
.bestSellingImageBox { height: clamp(20rem, 20vw, 30rem); }
}
@media only screen and (max-width: 1200px) {
html { font-size: calc(100vw / (1200 / 10)); }
}
@media (max-width: 1200px) {
.articlesPage { padding: 1rem 3.2rem 0rem; }
.articlesGrid { gap: 3rem 2rem; }
.featuredArticle { padding: 2rem 2rem 2rem 0; }
.featuredImage { width: 100%; max-width: 70rem; }
.brandsGrid { grid-template-columns: repeat(4, 1fr); }
}
@media only screen and (max-width: 1024px) {
html { font-size: calc(100vw / (1024 / 10)); }
}
@media (max-width: 1024px) {
.heroContent { max-width: 79.2rem; }
.refreshText { padding: 0 2rem; }
.refreshBtn, .infoCardBtn { padding: 1.1rem 3.2rem; font-size: 2.1rem; }
.infoCardText, .infoCard p { font-size: 2.1rem; line-height: 3.4rem; letter-spacing: 0rem; }
.brandItem div { width: 9.0rem; height: 9.0rem; border: 1px solid rgb(197 197 197 / 39%); border-radius: 50%; transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease, color 0.3s ease; }
.brandItem { width: 10.5rem; }
.brands { overflow-x: auto; cursor: grab; user-select: none; justify-content: flex-start; gap: 0; padding: 2rem; scroll-behavior: smooth; }
.brands.active { cursor: grabbing; scroll-behavior: auto; }
.brands::-webkit-scrollbar { display: none; }
.brandItem { flex-shrink: 0; }
.bestSellingContainer { padding: 0 3rem; }
.refreshContainer { padding: 1rem 3rem; }
.refreshContent { gap: 6rem; }
.refreshTitle { margin-bottom: .5rem; font-size: 2.7rem; line-height: 3.7rem; }
.refreshDescription { margin-bottom: 2rem; font-size: 2.2rem; line-height: 3.4rem; }
.infoCardsSection { padding: 2rem 3rem 3rem 3rem; }
.infoCardsGrid { gap: 3rem; }
.infoCard { gap: .5rem; padding: 2.8rem; }
.infoCardTitle { font-size: 2.9rem; }
.infoCardText { font-size: 1.5rem; line-height: 2.2rem; }
.newsletterSection { padding: 3rem 2rem; }
.newsletterTitle { font-size: 3.2rem; }
.newsletterDescription { font-size: 2.1rem; line-height: 2.7rem; letter-spacing: .05rem; }
.footer { padding: 5rem 4rem 2rem; }
.footerTop { gap: 3rem; grid-template-columns: repeat(2, 1fr); }
.featuresSection { padding: 2rem 0rem; }
.featuresSection .featuresContainer { display: flex; overflow-x: auto; flex-wrap: nowrap; gap: 1rem; padding: 0.5rem 1rem 1.5rem 1rem; scroll-behavior: smooth; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.featuresSection .featuresContainer::-webkit-scrollbar { height: 3px; }
.featuresSection .featuresContainer::-webkit-scrollbar-track { border-radius: 10px; background: #e0e0e0; }
.featuresSection .featuresContainer::-webkit-scrollbar-thumb { border-radius: 10px; background: #aaa; }
.featuresSection .featureItem { flex: 0 0 calc(50% - 0.5rem); padding: 1.2rem 0.8rem; border-radius: 1.2rem; scroll-snap-align: start; }
.featuresSection .featureItem:hover { box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); transform: scale(1.02); }
.featuresSection { background-color: #fff; }
.featuresSection .featureIconWrapper svg { width: 4.6rem; height: 4.6rem; }
.featuresSection .featureTitle { margin-top: 0.4rem; font-size: 1.5rem; }
.featuresSection .featureDescription { padding: 0 0.4rem; font-size: 1.2rem; line-height: 1.4; }
.featuresSection .featureDivider { display: none; }
.productDetail { padding: 1rem 2rem; }
.productGrid { flex-direction: column; gap: 3rem; }
.imageSection { position: static; top: auto; width: 100%; }
.productInfo { width: 100%; }
.articlesPage { padding: 1rem 3.2rem 0rem; }
.featuredArticle { gap: 3rem; }
.articlesGrid { grid-template-columns: repeat(2, 1fr); }
.featuredImage { max-width: 50rem; }
.brandsPage { padding: 1rem 3.2rem 4rem; }
.brandsGrid { gap: 2.5rem 1.5rem; grid-template-columns: repeat(4, 1fr); }
.brandLogo { height: 8rem; }
.eyeglassesPage { padding: 1rem 3.2rem; }
.brandFeatureContainer { gap: 3rem; }
.brandFeatureImage { width: 35rem; height: 25rem; }
.brandFeatureContent h2 { font-size: 2.8rem; }
.brandFeatureContent p { font-size: 1.5rem; line-height: 2.4rem; }
.guaranteePage { padding: 2rem 3.2rem 4rem; }
.aboutPage { padding: 2rem 3.2rem 4rem; }
}
@media (max-width: 1023px) and (min-width: 768px) {
.bestSellingGrid .bestSellingCard { flex: 0 0 calc((100% - 5rem) / 3); width: calc((100% - 5rem) / 3); }
.bestSellingSectionCards .bestSellingCard { flex: 0 0 calc((100% - 5rem) / 3); width: calc((100% - 5rem) / 3); }
.bestSellingImageBox { height: clamp(20rem, 28vw, 32.5rem); }
}
@media (max-width: 900px) {
.infoCardsGrid { gap: 2.4rem; grid-template-columns: 1fr; }
.infoCard { padding: 2.4rem; }
.infoCardTitle { font-size: 2rem; }
}
@media only screen and (max-width: 768px) {
html { font-size: calc(100vw / (768 / 10)); }
}
@media (max-width: 768px) and (min-width: 481px) {
.kidsSizeIcon { right: 0.6rem; bottom: 2rem; }
.kidsSizeDesktop { width: 4rem; }
.heroSectionSale { margin-bottom: 2rem; }
.salePriceWrapper { gap: 0.5rem; }
.salePrice { font-size: 1.8rem; }
.originalPrice { font-size: 1.4rem; }
.saleBadge { padding: 0.4rem 0.8rem; font-size: 1rem; }
}
@media (max-width: 768px) {
.mobileMenuToggle.active::before, .mobileMenuToggle.active::after { width: 3.2rem; }
.mobileMenuToggle::before, .mobileMenuToggle::after { width: 2.4rem; height: 2px; }
.voice-search-btn { width: 3rem; height: auto; }
.voice-search-btn svg { width: 26px; height: 26px; }
.headerNavbar { padding-right: 3rem; padding-left: 3rem; }
.hideDesk { display: flex !important; }
.hideMob { display: none !important; }
.headerTop { display: none; }
.headerNavbar { display: flex; flex-direction: column; gap: 1.92rem; padding-top: 1.92rem; padding-bottom: 3.2rem; }
.navbarSearch { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: .0rem; }
.navbarSearch a img { width: 30rem; }
.mobileMenuToggle { display: flex; flex-shrink: 0; }
.mobileMenuToggle svg { width: 4rem; height: 4rem; }
.navbarBacketWrapper { gap: 0.48rem; margin-left: auto; }
.navbarBacketWrapper button { padding: 0.96rem; }
.navbarBacketWrapper button svg { width: 3.88rem; height: 3.88rem; }
.navbarSearchWrapper { flex: 1 1 100%; order: 2; gap: 1.2rem; width: 100%; max-width: 100%; margin-top: 1rem; padding: 1.4rem 2.88rem; border-radius: 3.88rem; }
.navbarSearchWrapper svg { width: 3.3rem; height: 3.3rem; }
.navbarSearchWrapper input { font-family: "Helvetica", sans-serif; font-size: 2.4rem; font-weight: 300; }
.headerNavbarLinks { display: none; opacity: 1; overflow-x: hidden; overflow-y: auto; position: absolute; top: 100%; right: 0; left: 0; z-index: 1600; flex-direction: column; align-items: flex-start; gap: 0; width: 100%; max-height: 70vh; padding: 1.2rem; background: #fff; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); transform: none; transition: none; will-change: auto; -webkit-overflow-scrolling: touch; overscroll-behavior: contain; }
.headerNavbarLinks.mobileOpen { display: flex !important; }
.headerNavbarLinks a, .headerNavbarLinks .nav-item-wrapper { gap: 0.36rem; width: 100%; padding: .45rem 0; font-size: 1.92rem; }
.headerNavbarLinks .nav-item-wrapper { display: flex; position: relative; flex-wrap: wrap; align-items: center; }
.headerNavbarLinks a:last-child { border-bottom: none; }
.headerNavbarLinks a::after { display: none; }
.headerNavbarLinks .nav-item-with-dropdown::after { display: none; }
.headerNavbarLinks .nav-item-with-dropdown svg { width: 1.68rem; height: 1.68rem; transform: rotate(-90deg); }
.headerNavbarLinks .nav-item-wrapper:hover .nav-item-with-dropdown svg { transform: rotate(-90deg); }
/* Mobile dropdown styles */
.nav-dropdown { display: none; visibility: visible; opacity: 1; position: static; width: 100%; min-width: 100%; margin-top: 0; padding: 0; border-radius: 0; box-shadow: none; transform: none; }
.nav-dropdown::before { display: none; }
.nav-item-wrapper.mobile-open .nav-dropdown { display: block; }
.nav-item-wrapper.mobile-open .nav-item-with-dropdown svg { transform: rotate(0deg) !important; }
.nav-dropdown-item { padding: 1.2rem 0.8rem; }
.nav-dropdown-item img { width: 7rem; height: auto; }
.nav-dropdown-item span { font-size: 1.9rem; }
.bottom-button-wrapper { right: 1.3rem !important; bottom: 49rem !important; left: auto !important; gap: 0.3rem !important; }
.featureTitle { font-size: 1.9rem !important; }
.featureItem:nth-child(2) { margin-right: 1rem; }
.bottom-button { font-size: 1.8rem; }
.bottom-button-label { color: #000; font-size: 1.7rem; }
.bottom-button-label::before, .bottom-button-label::after { background-color: #000; }
.bestSellingGrid .bestSellingCard, .bestSellingSectionCards .bestSellingCard { flex: 0 0 calc((100% - 2.5rem) / 2); width: calc((100% - 2.5rem) / 2); }
.bestSellingImageBox { height: clamp(18rem, 35vw, 24rem); }
.bestSellingPrice, .bestSellingPrice strong { font-size: 2.1rem; }
.moreColors { font-size: 1.7rem; }
.bestSellingBtn { font-size: 1.9rem; }
.bestSellingLikeIcon, .bestSellingBrandIcon { width: 3rem; height: 3rem; }
.heroImageDesktop { display: none; }
.heroImageMobile { display: block; object-fit: contain; object-position: center top; }
.featuresBar { display: flex; gap: 2.5rem; margin: 2rem 0; padding: 1.6rem 2.5rem; }
.featureItem { gap: 1.2rem; }
.hero { height: auto; }
.heroContent { max-width: 72rem; margin-top: 39rem; background: #e9e9e9; }
.heroContent h1 { max-width: 77%; font-size: 3.7rem; line-height: 4.3rem; }
.heroContent p { margin: 1rem 0 2.7rem 0; font-size: 2.7rem; font-weight: 300; line-height: 3.7rem; }
.description { max-width: 60rem; }
.description p { font-size: 2.9rem; }
.trustedBy { gap: .75rem; margin-top: 1.7rem; margin-bottom: 1rem; }
.trustedBy h1 { font-size: 2.4rem; line-height: 3.6rem; }
.marquee-content { gap: 2rem; }
.logo-item { margin: 0 2.4rem; }
.logo-item img { width: 16rem; }
main .brands { order: -1; }
.brands { margin: 0; padding: 1.6rem; }
.brandItem p { width: 12.8rem; font-size: 1.8rem; line-height: 2.7rem; }
.bestSellingContainer { margin: 3rem auto; padding: 0 2rem; }
.bestSellingHeader { margin-bottom: 3rem; }
.bestSellingTitle { font-size: 2.9rem; line-height: 3.6rem; }
.bestSellingLink { font-size: 2.3rem; text-align: right; }
.refreshContainer { padding: 1rem 3rem; }
.refreshContent { flex-direction: column-reverse; gap: 1rem; }
.refreshText { max-width: 100%; text-align: start; }
.refreshImage { width: 100%; height: auto; }
.infoCardsSection { padding: 2rem 3rem 3rem 3rem; }
.infoCardsGrid { gap: 2.2rem; }
.infoCard { padding: 2.2rem; }
.infoCardTitle { font-size: 1.98rem; }
.infoCardText { font-size: 1.54rem; line-height: 2.2rem; }
.infoCardBtn { padding: 1.5rem 2rem; font-size: 1.4rem; }
.featuresSection { padding: 4rem 2rem; }
.featuresSection .featuresCarouselItem { padding: 0 1rem; }
.footer { padding: 4.79rem 2.39rem 2.39rem; }
.footerTop { gap: 1.8rem; grid-template-columns: 1fr; margin-bottom: 0rem; padding-bottom: 2rem; }
.footerLogo { width: 35rem; margin-bottom: 2.39rem; }
.footerAbout { font-size: 2.1rem; font-weight: 300; line-height: 3.1rem; }
.footerTitle { margin-bottom: 0rem; font-size: 2.16rem; }
.footerTitle svg { display: block; width: 2rem; height: 2rem; transition: transform 0.3s ease; }
.footerTitle.active svg { transform: rotate(180deg); }
.footerList { overflow: hidden; gap: 0.3rem; max-height: 0; padding-top: 0.9rem; transition: max-height 0.3s ease; }
.footerList.open { max-height: 500px; }
.footerLink { font-size: 2rem; }
.footerContact { gap: 2.1rem; }
.footerAddress { margin-top: 2rem; }
.footerAddress, .footerPhone, .footerHours { font-size: 2rem; line-height: 3.1rem; }
.footerSocial { gap: 1.8rem; }
.footerSocialLink { width: 2.87rem; height: 2.87rem; }
.footerMiddle { flex-direction: column-reverse; align-items: flex-start; gap: 2.39rem; padding: 2.39rem 0; }
.footerLinks { gap: 3rem; }
.footerBottomLink, .footerTopLink { align-self: flex-end; font-size: 1.7rem; letter-spacing: .07rem; }
.footerBottom { flex-direction: column; align-items: flex-start; gap: 0rem; padding-top: 2rem; }
.footerPayments { justify-content: flex-start; gap: 1.44rem; }
.footerCopyright { width: 100%; font-size: 1.8rem; font-weight: 300; letter-spacing: .07rem; text-align: center; }
.productDetail { padding: 1rem 3.2rem; }
.backButton { gap: 0.3rem; }
.navButton { width: 3rem; height: 3rem; }
.navButtonLeft { left: 1rem; }
.navButtonRight { right: 1rem; }
.colorVariant { width: 8.4rem; height: 8.4rem; }
.details h1 { font-size: 2.2rem; line-height: 2.4rem; }
.stars { flex-wrap: wrap; gap: 1rem; }
.star { font-size: 1.6rem; }
.navButton { display: none; }
.relatedProducts { padding: 2rem; }
.articlesPage { padding: 1rem 2rem 0rem; }
.articlesHeader { margin-bottom: 3.2rem; }
.categoriesWrapper { margin-bottom: 4.2rem; padding-right: 6rem; }
.categoriesInner { gap: 0rem 2rem; max-height: calc((2.4rem + 0.8rem) * 2 + 0rem); }
.categoryBtn { padding: 0.4rem 0; font-size: 1.6rem; line-height: 2.4rem; }
.moreBtn { bottom: 1rem; font-size: 1.6rem; line-height: 2.4rem; }
.featuredArticle { flex-direction: column; gap: 2rem; width: 100%; padding: 0; }
.featuredImage { max-width: 100%; height: auto; }
.featuredImage img { width: 100%; height: auto; }
.featuredContent { padding: 0 2rem 2rem; }
.brandsPage { padding: 1rem 2rem 3rem; }
.pageTitle { font-size: 2.6rem; line-height: 3.2rem; }
.filterSection { gap: 0.75rem; }
.filterBtn { min-width: 2.5rem; height: 2.5rem; font-size: 1.1rem; }
.brandsGrid { gap: 2rem 1.5rem; grid-template-columns: repeat(3, 1fr); }
.brandLogo { height: 7rem; }
.heroSection { flex-direction: column; padding: 1rem 0 0 0; }
.heroTitle { margin: 0; }
.categoriesSection { padding: 1.5rem 0; }
.descriptionSection p, .descriptionSection ul li { font-size: 2.2rem; line-height: 3.7rem; }
.descriptionSection h3 { font-size: 2.3rem; line-height: 2.2rem; }
.brandFeatureSection { width: 100%; padding: 2rem 0; }
.brandFeatureContainer { flex-direction: column; }
.brandFeatureImage { width: 100%; height: 39.6rem; }
.brandFeatureContent p { max-width: 100%; }
.badgeWrapper { margin-bottom: 2rem; }
.guaranteeContent { padding: 0; }
.bulletList { padding-left: 2.5rem; }
.guaranteePage { padding: 1.5rem 2rem 3rem; }
.aboutPage { padding: 1.5rem 2rem 3rem; }
.aboutContent { padding: 0; }
.description { font-size: 1.4rem; }
.buttons { flex-direction: column; align-items: center; }
.btnPrimary, .btnSecondary { width: 100%; width: 30rem !important; max-width: 32rem !important; font-size: 2.3rem !important; text-align: center; }
.shippingLabel { min-width: 120px; }
.modalContent { width: 95%; max-height: 85vh; padding: 2.5rem 1.5rem; }
.diagramSection { flex-direction: column; gap: 2rem; }
.diagramSection img { width: 100%; max-width: 40rem; }
.diagramLabels { width: 100%; padding: 0 1rem; }
.diagramLabels p { font-size: 1.3rem; line-height: 2.2rem; }
.imageModalClose { top: 1.5rem; right: 1.5rem; width: 4rem; height: 4rem; border: 1px solid rgba(0, 0, 0, 0.1); font-size: 4rem; }
.imageModalNav { width: 5rem; height: 5rem; }
.imageModalNavLeft { left: 2rem; }
.imageModalNavRight { right: 2rem; }
.bottomBarContent { flex-wrap: wrap; padding: 1rem 2rem; }
.bottomBarButtons button { padding: 0.6rem 1.5rem; font-size: 1.2rem; }
.navbarSearchWrapper { opacity: 1; transform: translateY(0); transition: transform 0.3s ease, opacity 0.3s ease; will-change: transform; }
.header.scrolled .navbarSearchWrapper { display: none; opacity: 0; pointer-events: none; transform: translateY(-100%); }
.header { transition: none; will-change: transform; }
.header.fixed { transform: translateY(0); }
.header.scrolled .headerTop, .header.fixed .headerTop, .headerNavbarLinks.linksHidden, .headerNavbarLinks { transition: none !important; }
.header:not(.scrolled):not(.fixed) .headerTop, .headerNavbarLinks:not(.linksHidden) { transition: height 220ms ease, opacity 180ms ease, transform 220ms ease; }
.featuresBar > .featureItem, .featuresCarouselWrapper .featureItem { display: flex !important; flex-direction: row !important; justify-content: flex-start !important; align-items: center !important; width: 100% !important; text-align: left !important; }
.featuresBar .featureItem .featureText, .featuresBar .featureItem > div { margin-left: 0 !important; text-align: left !important; }
}
@media only screen and (max-width: 480px) {
html { font-size: calc(100vw / (480 / 10)); }
}
@media (max-width: 480px) {
.articleExcerpt { font-size: 2.4rem; line-height: 3.2rem;}
.articleTitle { font-size: 2.7rem; line-height: 3.2rem;}
.guaranteeContent p {font-size: 2.4rem; line-height: 3.7rem}
.bulletList li {font-size: 2.4rem; line-height: 3.2rem}
.bulletList li::before { font-size: 3.7rem; line-height: 3.2rem;}
.aboutContent p {font-size: 2.4rem; line-height: 4.2rem}
.sectionTitle {font-size: 2.6rem; line-height: 3.2rem}
.contactTitle,.contactLink,.calendarLink {font-size: 2.4rem; line-height: 3.2rem}
.featureSubtitle { display: none !important }
.categoryImage { width: 9rem; height: 5rem; }
.categoryName {text-align: center; font-size: 1.9rem}
.mobileMenuToggle.active::before, .mobileMenuToggle.active::after { width: 3.2rem; }
.mobileMenuToggle::before, .mobileMenuToggle::after { width: 2.8rem; }
.navbarBacketWrapper button:nth-child(2) svg { width: 3.1rem; height: 3.1rem; }
.voice-search-btn { width: 42px; height: 42px; }
.voice-search-btn svg { width: 28px; height: 28px; }
.featuresSection .featureItem { flex: 0 0 calc(50% - 0.5rem); padding: 1rem 0.5rem; }
.headerNavbar { gap: 1.6rem; padding: 0rem 2rem 1.2rem 2rem; }
.header.scrolled .headerNavbar { padding-bottom: 0rem !important; }
.headerNavbarLinks { padding: 1.2rem; }
.navbarSearch { row-gap: 0rem; column-gap: 0.5rem; }
.navbarSearch a img { width: 26rem; height: auto; padding-top: 1rem; padding-left: 2rem; }
.mobileMenuToggle { padding-right: 2.8rem; }
.mobileMenuToggle svg { width: 3rem; height: 3rem; }
.navbarBacketWrapper { gap: 0.4rem; }
.navbarBacketWrapper button { padding: 0.8rem; }
.navbarBacketWrapper button svg { width: 3rem; height: 3rem; }
.navbarSearchWrapper { gap: 1.3rem; margin-top: 0; padding: 0rem 2rem; border-radius: 3.12rem; }
.navbarSearchWrapper svg { width: 3.12rem; height: 3.12rem; }
.navbarSearchWrapper input { font-size: 2.08rem; }
.headerNavbarLinks a { gap: 0.39rem; padding: 1.6rem 1rem; font-size: 2.08rem; }
.headerNavbarLinks a svg { width: 1.82rem; height: 1.82rem; }
.featuresCarouselWrapper .featureItem { transform: scale(1.1); transform-origin: center; }
.hero { height: auto; }
.heroContent { max-width: 45rem; margin: 0 auto; margin-top: 26rem; }
.heroContent h1 { max-width: 100%; font-size: 3.1rem; font-weight: 400; line-height: 3.8rem; }
.heroContent p { margin: 1.2rem 0 2rem 0; font-size: 2.5rem; line-height: 3.1rem; }
.heroContentButtons button { width: 26rem; height: 5.3rem; font-size: 2.1rem; line-height: 2.1rem; }
.description p { padding: 0 1.2rem; font-size: 2.4rem; font-weight: 400; }
.trustedBy { gap: 1.6rem; margin-top: 2rem; margin-bottom: 2rem; }
.trustedBy h1 { font-size: 2.3rem; line-height: 3rem; }
.logo-item { margin: 0 2rem; }
.logo-item img { width: 13.6rem; }
.brands { gap: 0rem; padding: 1.2rem; }
.brandItem p { width: 10rem; font-size: 1.6rem; line-height: 2rem; }
.brandItem .brandItemLogo1 { background-size: 80% 50%; }
.bestSellingContainer { margin: 1rem auto; }
.bestSellingHeader { margin-bottom: 2rem; }
.bestSellingTitle { font-size: 2.3rem; }
.bestSellingCard { flex: 0 0 calc((100% - 2.5rem) / 2); width: calc((100% - 2.5rem) / 2); border-radius: 2rem; }
.bestSellingImageBox { height: 24rem; }
.bestSellingName { min-height: 3rem; margin-bottom: 1rem; font-size: 1.9rem; line-height: 2.3rem; }
.bestSellingPrice { font-size: 1.9rem; line-height: 2rem; }
.bestSellingPrice strong { font-size: 1.95rem; line-height: 2rem; }
.bestSellingColors { gap: 0.5rem; }
.bestSellingColorCircle { width: 5rem; }
.bestSellingBtn { padding: .7rem; border: 0.2rem solid rgb(42, 43, 42); border-radius: 2.5rem; font-size: 1.6rem; font-weight: 500; letter-spacing: 0.03rem; }
.moreColors { min-width: 2.5rem; padding: 0.4rem; font-size: 1.7rem; }
.refreshContainer { padding: 0 2rem; }
.refreshContent { gap: 2rem; }
.refreshDescription { font-size: 2.1rem; }
.refreshBtn { padding: 1.6rem 3.2rem; border-radius: 3rem; font-size: 1.9rem; line-height: 1.9rem; letter-spacing: .075rem; }
.infoCardsSection { padding: 2rem 1.6rem 1rem 1.6rem; }
.infoCardsGrid { gap: 1.6rem; }
.infoCard { padding: 1.8rem; }
.infoCardTitle { font-size: 2.5rem; }
.infoCardText { font-size: 1.7rem; line-height: 2.4rem; }
.infoCardBtn { padding: 1.2rem 2.4rem; border-radius: 3rem; font-size: 1.9rem; vertical-align: bottom; }
.featuresSection { padding: 1rem 1rem 2rem 1rem; }
.featuresSection .featuresCarouselItem { padding: 0 0.5rem; }
.featuresSection .featureIconWrapper { margin-bottom: .3rem; }
.featuresSection .featureTitle { margin-bottom: 0rem; font-size: 1.98rem; }
.featuresSection .featureDescription { font-size: 1.8rem; line-height: 2.5rem; }
.footerContact a { font-size: 2.1rem; font-weight: 300; line-height: 3.1rem; }
.footer { padding: 3.59rem 1.92rem 10rem 1.92rem; }
.footerTop { gap: 2rem; }
.footerLogo { margin-bottom: 1.2rem; }
.footerTitle { font-size: 2.1rem; }
.footerBottom { gap: 2.64rem; }
.footerPayments { gap: 1rem; }
.footerAddress { margin-top: 0.4rem; }
.footerCopyright { font-size: 1.8rem; }
.productDetail { padding: 1rem; }
.backButton { flex-wrap: wrap; align-items: center; }
.relatedProducts { padding: 1rem; }
.articlesPage { padding: 1rem 1.5rem 0rem; }
.articlesGrid { gap: 3rem 0; grid-template-columns: 1fr; }
.featuredArticle { margin-bottom: 3rem; }
.categoriesWrapper { padding-right: 5.5rem; }
.categoriesInner { gap: 0.3rem 1rem; max-height: calc((2.2rem + 0.6rem) * 2 + 0.3rem); }
.categoryBtn { padding: 0.3rem 0; font-size: 2.1rem; line-height: 2.2rem; }
.moreBtn { bottom: 1rem; font-size: 2.1rem; line-height: 2.2rem;  gap: 0.15rem; }
.moreBtn svg { width: 2.4rem; height: 2.4rem; }
.brandsPage { padding: 1rem 1.5rem 2rem; }
.pageTitle { font-size: 2.5rem; line-height: 1; }
.filterSection { gap: 0.75rem; }
.brandName { font-size: 2.1rem; }
.filterBtn { width: 5rem; height: 5rem; padding: 0 0.5rem; font-size: 3.1rem; }
.filterBtn:first-child { padding: 0 1rem; font-size: 2.6rem; }
.brandsGrid { gap: 2rem 1rem; grid-template-columns: repeat(2, 1fr); }
.brandLogo { height: 6rem; }
.eyeglassesPage { padding: 1rem 2rem; }
.backButton { flex-wrap: wrap; align-items: center; row-gap: 0.2rem; }
.heroImage { display: none; }
.categoryCard { flex-direction: column; justify-content: center; align-items: center; width: 12rem; padding: 0.3rem 1.2rem; }
.heroSubtitle { font-size: 2.2rem; }
.brandFeatureSection { padding: 0; background: none; }
.brandFeatureImage { display: none; }
.brandFeatureContent h2 { font-size: 3.3rem; line-height: 4rem; }
.brandFeatureContent p { font-size: 2.3rem; line-height: 3.4rem; }
.guaranteePage { padding: 1rem 1.5rem 2rem; }
.bulletList { padding-left: 2rem; }
.aboutPage { padding: 1rem 1.5rem 2rem; }
.mainTitle { font-size: 3.3rem; line-height: 4rem; }
.kidsSizeIcon { right: 0.5rem; bottom: 1.5rem; }
.kidsSizeDesktop { display: none; }
.kidsSizeMobile { display: block; width: 6rem; }
.heroSectionSale { margin-bottom: 2rem; }
.salePriceWrapper { gap: 0.8rem; margin-bottom: 0.8rem; }
.salePrices { gap: 0.6rem; font-size:1.6rem }
.salePrice { font-size: 1.9rem; line-height: 2rem; }
.originalPrice { font-size: 1.8rem; line-height: 2rem; }
.saleBadge { font-size: 1.4rem; }
.bestSellingLoadMore { margin-top: 1rem; margin-bottom: 0; }
}
@media (max-width: 390px) {
.headerNavbar { gap: 2rem; padding: 0rem 2.5rem; padding-bottom: 3rem; }
.navbarSearch a img { width: 25rem; height: auto; }
.navbarSearch { column-gap: 1.3rem; }
.mobileMenuToggle svg { width: 3.5rem; height: 3.5rem; }
.navbarBacketWrapper button svg { width: 3.5rem; height: 3.5rem; }
}
@media (min-width: 1281px) {
.bestSellingGrid .bestSellingCard { flex: 0 0 calc((100% - 8rem) / 5); width: calc((100% - 8rem) / 5); }
.bestSellingImageBox { height: clamp(18rem, 16vw, 26rem); }
}
@media (prefers-reduced-motion: reduce) {
.header { transition: none; }
.headerTop { transition: none; }
.headerNavbar, .navbarSearch a img, .navbarSearchWrapper { transition: none; }
.headerNavbarLinks { transition: none; }
.accordionContent { transition: none; }
* { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
.header, .headerNavbarLinks, .headerNavbarLinks.linksHidden { transition: none !important; }
}
