:root {
--bg: #FAFAFA;
--bg-elevated: #FFFFFF;
--bg-card: #FFFFFF;
--bg-hover: #F6F6F6;
--text: #111111;
--text-2: #555555;
--text-3: #999999;
--accent: #E85D04;
--accent-hover: #D45200;
--accent-soft: rgba(232, 93, 4, 0.07);
--success: #059669;
--success-soft: rgba(5, 150, 105, 0.08);
--error: #DC2626;
--error-soft: rgba(220, 38, 38, 0.08);
--warning: #D97706;
--border: #EBEBEB;
--border-dark: #D4D4D4;
--input-bg: #FFFFFF;
--shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
--shadow-md: 0 4px 20px rgba(0,0,0,0.06);
--shadow-lg: 0 12px 40px rgba(0,0,0,0.08);
--shadow-hover: 0 16px 48px rgba(0,0,0,0.10);
--font: 'General Sans', -apple-system, 'Segoe UI', sans-serif;
--font-display: 'Cabinet Grotesk', 'General Sans', sans-serif;
--font-mono: 'GeistMono', 'SF Mono', monospace;
--space-2xs: 0.25rem;
--space-xs: 0.5rem;
--space-sm: 0.75rem;
--space-md: 1rem;
--space-lg: 1.5rem;
--space-xl: 2.5rem;
--space-2xl: 4rem;
--space-3xl: 6rem;
--max-w: 1320px;
--header-h: 64px;
--radius: 10px;
--radius-sm: 6px;
--radius-lg: 16px;
--radius-full: 100px;
--ease: cubic-bezier(0.22, 1, 0.36, 1);
--t-fast: 0.12s var(--ease);
--t-base: 0.25s var(--ease);
--t-slow: 0.5s var(--ease);
} *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);font-size:0.9375rem;line-height:1.6;color:var(--text);background:var(--bg);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{font-family:var(--font);cursor:pointer}
::selection{background:var(--accent);color:#fff} h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-0.025em;color:var(--text)}
h1{font-size:clamp(2rem,4.5vw,3.2rem)}
h2{font-size:clamp(1.5rem,3vw,2.2rem)}
h3{font-size:1.1rem;font-weight:600}
.label{font-family:var(--font-mono);font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);font-weight:500} .container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--space-lg)}
.section{padding:var(--space-3xl) 0} .announcement-bar{background:var(--text);color:#fff;text-align:center;padding:0.5rem;font-size:0.78rem;font-weight:500;letter-spacing:0.02em}
.announcement-bar strong{color:var(--accent);font-weight:700} .site-header{position:sticky;top:0;z-index:100;height:var(--header-h);background:rgba(255,255,255,0.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);display:flex;align-items:center}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--space-lg);gap:var(--space-lg)}
.site-logo{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:var(--text);letter-spacing:-0.03em;display:flex;align-items:center;gap:0.4rem;flex-shrink:0}
.site-logo span{color:var(--accent)}
.header-search{flex:1;max-width:400px;position:relative;margin:0 auto}
.header-search input{width:100%;padding:0.55rem 1rem 0.55rem 2.5rem;font-size:0.85rem;border:1.5px solid var(--border);border-radius:var(--radius-full);background:var(--bg);color:var(--text);outline:none;transition:border-color var(--t-fast)}
.header-search input:focus{border-color:var(--accent)}
.header-search input::placeholder{color:var(--text-3)}
.header-search__icon{position:absolute;left:0.85rem;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none;display:flex;align-items:center;line-height:1}
.header-nav{display:flex;align-items:center;gap:var(--space-lg)}
.header-nav a{font-size:0.85rem;font-weight:500;color:var(--text-2);transition:color var(--t-fast)}
.header-nav a:hover{color:var(--text)}
.header-actions{display:flex;align-items:center;gap:0.5rem;flex-shrink:0}
.icon-btn{width:38px;height:38px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text);transition:all var(--t-fast);position:relative;text-decoration:none}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.icon-btn__badge{position:absolute;top:-5px;right:-5px;width:18px;height:18px;background:var(--accent);color:#fff;border-radius:50%;font-size:0.58rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.icon-btn__badge:empty{display:none}
.menu-toggle{display:none;background:none;border:none;padding:6px}
.menu-toggle span{display:block;width:20px;height:2px;background:var(--text);margin:4px 0;border-radius:2px;transition:var(--t-base)} .hero-banner{position:relative;min-height:400px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);background-size:cover;background-position:center}
.hero-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320'%3E%3Cpath fill='rgba(232%2C93%2C4%2C0.08)' d='M0%2C160L48%2C170.7C96%2C181%2C192%2C203%2C288%2C186.7C384%2C171%2C480%2C117%2C576%2C112C672%2C107%2C768%2C149%2C864%2C165.3C960%2C181%2C1056%2C171%2C1152%2C149.3C1248%2C128%2C1344%2C96%2C1392%2C80L1440%2C64L1440%2C320L1392%2C320C1344%2C320%2C1248%2C320%2C1152%2C320C1056%2C320%2C960%2C320%2C864%2C320C768%2C320%2C672%2C320%2C576%2C320C480%2C320%2C384%2C320%2C288%2C320C192%2C320%2C96%2C320%2C48%2C320L0%2C320Z'/%3E%3C/svg%3E") no-repeat bottom center/cover;opacity:0.5;z-index:1}
.hero-banner__overlay{position:absolute;inset:0;background:rgba(10,10,30,0.55);z-index:1}
.hero-banner:not([style*="background-image"]) .hero-banner__overlay{background:none}
.hero-banner__content{position:relative;z-index:2;max-width:600px;padding:var(--space-2xl) var(--space-lg)}
.hero-banner__badge{display:inline-block;padding:0.4rem 1.1rem;background:rgba(232,93,4,0.15);border:1px solid rgba(232,93,4,0.3);border-radius:var(--radius-full);font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-lg)}
.hero-banner h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:var(--space-sm);letter-spacing:-0.03em;font-style:italic}
.hero-banner h1 span{color:var(--accent)}
.hero-banner p{font-size:1rem;color:rgba(255,255,255,0.7);line-height:1.6;margin-bottom:var(--space-xl);max-width:45ch;margin-left:auto;margin-right:auto}
.hero-banner__btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.85rem 2.2rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:0.9rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:all 0.2s;text-decoration:none}
.hero-banner__btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,93,4,0.3)}
@media(max-width:768px){
.hero-banner{min-height:320px}
.hero-banner__content{padding:var(--space-xl) var(--space-md)}
.hero-banner__badge{margin-bottom:var(--space-md)}
} .hero-banner--gradient{background:linear-gradient(135deg,#E85D04 0%,#ff8a3d 50%,#ffb347 100%)}
.hero-banner--gradient::before{display:none}
.hero-banner--gradient::after{content:'';position:absolute;top:-50%;right:-20%;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,0.08);z-index:0}
.hero-banner--gradient .hero-banner__overlay{display:none}
.hero-banner--gradient .hero-banner__badge{display:none}
.hero-banner--gradient .hero-banner__tag{display:inline-flex;align-items:center;gap:0.4rem;padding:0.35rem 0.9rem;background:rgba(255,255,255,0.2);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#fff;margin-bottom:var(--space-lg)}
.hero-banner--gradient .hero-banner__tag::before{content:'';width:6px;height:6px;background:#fff;border-radius:50%;animation:heroPulse 1.5s infinite}
@keyframes heroPulse{0%,100%{opacity:1}50%{opacity:0.4}}
.hero-banner--gradient h1 span{color:#fff}
.hero-banner--gradient p{color:rgba(255,255,255,0.85)}
.hero-banner--gradient .hero-banner__btn{background:#fff;color:var(--accent)}
.hero-banner--gradient .hero-banner__btn:hover{background:#fff;box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.hero-banner__stats{display:flex;justify-content:center;gap:2.5rem;margin-top:var(--space-xl)}
.hero-banner__stat{text-align:center;color:#fff}
.hero-banner__stat strong{display:block;font-size:1.5rem;font-weight:800}
.hero-banner__stat span{font-size:0.72rem;opacity:0.8;font-weight:500} .hero-banner--split{background:#fff;text-align:left;min-height:auto}
.hero-banner--split::before{display:none}
.hero-banner--split .hero-banner__overlay{display:none}
.hero-banner--split .hero-banner__inner{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1320px;margin:0 auto;width:100%;min-height:420px}
.hero-banner--split .hero-banner__text{display:flex;flex-direction:column;justify-content:center;padding:3rem 3rem 3rem 4rem}
.hero-banner--split .hero-banner__label{font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:0.5rem}
.hero-banner--split .hero-banner__label::before{content:'';width:24px;height:2px;background:var(--accent);border-radius:2px}
.hero-banner--split h1{color:var(--text-1);font-style:normal}
.hero-banner--split h1 span{color:var(--accent)}
.hero-banner--split p{color:var(--text-3);max-width:40ch;margin-left:0}
.hero-banner--split .hero-banner__badge{display:none}
.hero-banner--split .hero-banner__actions{display:flex;gap:0.7rem;align-items:center}
.hero-banner--split .hero-banner__btn--outline{background:transparent;border:1.5px solid var(--border);color:var(--text-1);padding:0.85rem 2rem;border-radius:var(--radius);font-size:0.88rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:0.5rem;transition:all 0.2s}
.hero-banner--split .hero-banner__btn--outline:hover{border-color:var(--accent);color:var(--accent)}
.hero-banner--split .hero-banner__features{display:flex;gap:1.5rem;margin-top:var(--space-lg)}
.hero-banner--split .hero-banner__feat{display:flex;align-items:center;gap:0.4rem;font-size:0.75rem;font-weight:600;color:var(--text-3)}
.hero-banner--split .hero-banner__feat svg{color:var(--accent);flex-shrink:0}
.hero-banner--split .hero-banner__visual{position:relative;background:linear-gradient(135deg,#fef3e8 0%,#fde8d3 100%);display:flex;align-items:center;justify-content:center;overflow:hidden;background-size:cover;background-position:center}
.hero-banner--split .hero-banner__visual::before{content:'';position:absolute;width:320px;height:320px;border-radius:50%;border:40px solid rgba(232,93,4,0.06)}
.hero-banner--split .hero-banner__placeholder{position:relative;z-index:1;text-align:center;color:var(--accent)}
.hero-banner--split .hero-banner__placeholder svg{width:120px;height:120px;opacity:0.3}
.hero-banner--split .hero-banner__placeholder p{font-size:0.82rem;margin-top:0.5rem;opacity:0.5;font-weight:500}
@media(max-width:768px){
.hero-banner--split .hero-banner__inner{grid-template-columns:1fr 1fr;min-height:auto}
.hero-banner--split .hero-banner__text{padding:var(--space-md);justify-content:center}
.hero-banner--split .hero-banner__label{font-size:0.6rem;margin-bottom:0.3rem}
.hero-banner--split .hero-banner__label::before{width:16px}
.hero-banner--split h1{font-size:1.3rem;margin-bottom:0.3rem}
.hero-banner--split p{font-size:0.78rem;margin-bottom:0.8rem;line-height:1.4}
.hero-banner--split .hero-banner__actions{display:none}
.hero-banner--split .hero-banner__features{gap:0.6rem;margin-top:0.6rem;flex-wrap:wrap}
.hero-banner--split .hero-banner__feat{font-size:0.65rem}
.hero-banner--split .hero-banner__visual{min-height:220px}
.hero-banner--split .hero-banner__visual::before{width:180px;height:180px;border-width:20px}
.hero-banner--split .hero-banner__placeholder svg{width:60px;height:60px}
.hero-banner--split .hero-banner__placeholder p{font-size:0.7rem}
}
.category-pills{display:flex;justify-content:center;flex-wrap:wrap;gap:0.4rem}
.category-pill{padding:0.45rem 1.1rem;font-size:0.8rem;font-weight:600;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-full);color:var(--text-2);transition:all var(--t-fast);text-decoration:none}
.category-pill:hover,.category-pill.active{background:var(--accent);border-color:var(--accent);color:#fff} .trust-bar{display:flex;justify-content:center;gap:var(--space-2xl);padding:var(--space-lg) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:var(--space-2xl);flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:var(--space-xs);font-size:0.82rem;font-weight:500;color:var(--text-2)}
.trust-item__icon{font-size:1.2rem} .products-section{padding:0 0 var(--space-3xl);scroll-margin-top:calc(var(--header-h) + var(--space-md))}
.products-section--no-trust{padding-top:var(--space-2xl)}
.products-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-sm)}
.products-toolbar__count{font-size:0.82rem;color:var(--text-3);font-weight:500}
.infinite-loader{display:flex;align-items:center;justify-content:center;gap:0.6rem;padding:var(--space-xl) 0;color:var(--text-3);font-size:0.85rem;font-weight:500;transition:opacity 0.3s}
.infinite-loader.done{display:none}
.spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}} .vm-shop-layout{display:grid;grid-template-columns:240px 1fr;gap:var(--space-lg);align-items:start}
.vm-sidebar-col{position:sticky;top:calc(var(--header-h) + var(--space-md));max-height:calc(100vh - var(--header-h) - var(--space-lg));display:flex;flex-direction:column;gap:var(--space-sm);overflow-y:auto}
.vm-sidebar-col .vm-search-bar__form--desktop{flex-shrink:0}
.vm-sidebar{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1;min-height:0}
.vm-sidebar__header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border);margin-bottom:var(--space-sm)}
.vm-sidebar__title{font-size:0.9rem;font-weight:700;display:flex;align-items:center;gap:8px;color:var(--text-1)}
.vm-sidebar__close{display:none;background:none;border:none;font-size:1.4rem;color:var(--text-3);cursor:pointer;line-height:1}
.vm-sidebar__section{padding:var(--space-sm) 0;border-bottom:1px solid var(--border)}
.vm-sidebar__section:last-of-type{border-bottom:none}
.vm-sidebar__label{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-3);margin-bottom:8px}
.vm-sidebar__cats{display:flex;flex-direction:column;gap:4px}
.vm-sidebar__actions{padding-top:var(--space-sm);display:flex;flex-direction:column;gap:8px}
.vm-sidebar-toggle{display:none}
.vm-sidebar-overlay{display:none}
.vm-shop-content{min-width:0}
.vm-filter-select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-1);font-size:0.85rem;font-family:inherit;min-width:140px;cursor:pointer;transition:border-color var(--t-base)}
.vm-filter-select:focus{outline:none;border-color:var(--accent)}
.vm-filter-select--full{width:100%;min-width:0}
.vm-filter-sizes{display:flex;gap:6px}
.vm-size-chip{display:inline-flex;align-items:center;justify-content:center;min-width:36px;padding:5px 8px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:0.75rem;font-weight:600;color:var(--text-2);cursor:pointer;transition:all var(--t-base);user-select:none}
.vm-size-chip:hover{border-color:var(--accent);color:var(--accent)}
.vm-size-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.vm-filter-price{display:flex;align-items:center;gap:8px}
.vm-filter-price--vertical{flex-wrap:wrap}
.vm-filter-price--vertical .vm-price-input{flex:1;min-width:0}
.vm-price-input{width:80px;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-1);font-size:0.85rem;font-family:inherit;transition:border-color var(--t-base)}
.vm-price-input:focus{outline:none;border-color:var(--accent)}
.vm-price-input::placeholder{color:var(--text-3)}
.vm-price-sep{color:var(--text-3);font-size:0.85rem}
.vm-filter-btn{padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:0.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--t-base)}
.vm-filter-btn:hover{background:var(--accent-hover)}
.vm-filter-btn--full{width:100%}
.vm-filter-clear{font-size:0.82rem;color:var(--text-3);text-decoration:underline;text-underline-offset:2px;transition:color var(--t-base);background:none;border:none;cursor:pointer;font-family:inherit;text-align:center}
.vm-filter-clear:hover{color:var(--text-1)}
.vm-filters__count{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:var(--accent);color:#fff;border-radius:50%;font-size:0.65rem;font-weight:700;margin-left:6px}
.vm-cat-chip{display:flex;align-items:center;width:100%;padding:6px 10px;border:1.5px solid transparent;border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500;color:var(--text-2);cursor:pointer;transition:all var(--t-base);background:none;font-family:inherit;text-align:left}
.vm-cat-chip:hover{background:var(--bg);color:var(--accent)}
.vm-cat-chip.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.vm-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.vm-toggle input{display:none}
.vm-toggle__switch{position:relative;width:38px;height:22px;background:var(--border);border-radius:11px;transition:background 0.25s;flex-shrink:0}
.vm-toggle__switch::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform 0.25s;box-shadow:0 1px 3px rgba(0,0,0,0.15)}
.vm-toggle input:checked+.vm-toggle__switch{background:var(--accent)}
.vm-toggle input:checked+.vm-toggle__switch::after{transform:translateX(16px)}
.vm-toggle__label{font-size:0.82rem;font-weight:600;color:var(--text-2)} .vm-search-filter-row{display:none;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-md)}
.vm-search-filter-row .vm-sidebar-toggle{margin-bottom:0;flex-shrink:0;width:42px;height:42px;padding:0;justify-content:center;border-radius:var(--radius)}
.vm-search-filter-row .vm-search-bar__form{flex:1;margin:0}
.vm-search-bar{margin-bottom:var(--space-md)}
.vm-search-clear{display:none;align-items:center;justify-content:center;width:28px;height:28px;margin-right:0.35rem;background:var(--border);border:none;border-radius:50%;font-size:1rem;line-height:1;color:var(--text-2);cursor:pointer;flex-shrink:0;transition:all var(--t-fast)}
.vm-search-clear:hover{background:var(--error-soft);color:var(--error)}
.vm-search-bar__form{display:flex;align-items:center;gap:0;position:relative;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--t-fast)}
.vm-search-bar__form:focus-within{border-color:var(--accent)}
.vm-search-bar__icon{position:absolute;left:0.85rem;color:var(--text-3);pointer-events:none;flex-shrink:0}
.vm-search-bar__input{flex:1;padding:0.6rem 1rem 0.6rem 2.5rem;border:none;background:transparent;font-family:var(--font);font-size:0.85rem;color:var(--text);outline:none}
.vm-search-bar__input::placeholder{color:var(--text-3)}
.vm-search-bar__btn{padding:0.55rem 1.3rem;margin:0.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:0.82rem;font-weight:600;cursor:pointer;transition:background var(--t-fast);flex-shrink:0}
.vm-search-bar__btn:hover{background:var(--accent-hover)}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)} .product-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--t-base);display:flex;flex-direction:column}
.product-card:hover{border-color:var(--accent);box-shadow:var(--shadow-hover);transform:translateY(-4px)}
.product-card__img-wrap{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--bg)}
.product-card__img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s var(--ease)}
.product-card:hover .product-card__img{transform:scale(1.04)}
.product-card__badges{position:absolute;top:0.6rem;left:0.6rem;display:flex;flex-wrap:wrap;gap:0.3rem;z-index:2;max-width:calc(100% - 1.2rem)}
.product-card__badge{padding:0.2rem 0.6rem;font-size:0.6rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:#fff;border-radius:var(--radius-full);width:fit-content}
.product-card__badge--new{background:var(--success)}
.product-card__badge--sale{background:var(--error)}
.product-card__badge--low-stock{background:var(--warning)} .product-card__overlay{position:absolute;bottom:0;left:0;right:0;padding:0.6rem;transform:translateY(100%);transition:transform var(--t-base);z-index:2}
.product-card:hover .product-card__overlay{transform:translateY(0)}
.quick-add-btn{width:100%;padding:0.6rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:0.8rem;font-weight:600;transition:background var(--t-fast)}
.quick-add-btn:hover{background:var(--accent-hover)}
.quick-add-btn.added{background:var(--success)}
.product-card__body{padding:var(--space-md);flex:1;display:flex;flex-direction:column;gap:0.25rem}
.product-card__cat{font-size:0.65rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-3);font-weight:600}
.product-card__title{font-size:0.88rem;font-weight:600;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-card__title a{color:inherit;transition:color var(--t-fast)}
.product-card__title a:hover{color:var(--accent)}
.product-card__sizes{display:flex;gap:0.25rem;margin-top:0.3rem;flex-wrap:wrap}
.product-card__size{font-size:0.6rem;padding:0.15rem 0.4rem;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-3);font-weight:500}
.product-card__size--out{text-decoration:line-through;opacity:0.4}
.product-card__bottom{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:0.5rem}
.product-price{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--text)}
.product-price--old{font-size:0.78rem;font-weight:400;color:var(--text-3);text-decoration:line-through;margin-left:0.3rem}
.product-card__stock{font-size:0.65rem;font-weight:600;padding:0.15rem 0.5rem;border-radius:var(--radius-full)}
.product-card__stock--in{background:var(--success-soft);color:var(--success)}
.product-card__stock--low{background:rgba(217,119,6,0.08);color:var(--warning)}
.product-card__stock--out{background:var(--error-soft);color:var(--error)} .cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.35);z-index:200;opacity:0;visibility:hidden;transition:all 0.25s}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-sidebar{position:fixed;top:0;right:-440px;width:420px;max-width:92vw;height:100vh;background:var(--bg-elevated);border-left:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transition:right 0.3s var(--ease);box-shadow:var(--shadow-lg)}
.cart-sidebar.open{right:0}
.cart-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border)}
.cart-header h3{font-size:1.1rem}
.cart-close{background:none;border:none;font-size:1.5rem;color:var(--text-3);transition:color var(--t-fast);line-height:1}
.cart-close:hover{color:var(--text)}
.cart-items{flex:1;overflow-y:auto;padding:var(--space-md) var(--space-lg)}
.cart-empty{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--text-3)}
.cart-empty__icon{font-size:3rem;margin-bottom:var(--space-md);opacity:0.25}
.cart-item{display:flex;gap:0.7rem;padding:0.7rem 0;border-bottom:1px solid var(--border)}
.cart-item__img{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--bg);border:1px solid var(--border)}
.cart-item__info{flex:1;min-width:0}
.cart-item__title{font-size:0.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item__meta{font-size:0.72rem;color:var(--text-3)}
.cart-item__price{font-weight:700;font-size:0.88rem;margin-top:0.15rem}
.cart-item__qty{display:flex;align-items:center;gap:0.3rem;margin-top:0.25rem}
.cart-item__qty button{width:24px;height:24px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);font-size:0.75rem;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}
.cart-item__qty button:hover{border-color:var(--accent);color:var(--accent)}
.cart-item__qty span{font-size:0.82rem;font-weight:600;min-width:1.2rem;text-align:center}
.cart-item__remove{background:none;border:none;color:var(--text-3);font-size:0.7rem;padding:0.15rem;transition:color var(--t-fast);align-self:flex-start;margin-left:auto}
.cart-item__remove:hover{color:var(--error)}
.cart-footer{padding:var(--space-lg);border-top:1px solid var(--border)}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}
.cart-total__label{font-size:0.88rem;color:var(--text-2)}
.cart-total__amount{font-family:var(--font-display);font-size:1.35rem;font-weight:700}
.cart-footer .trust-note{text-align:center;font-size:0.72rem;color:var(--text-3);margin-top:var(--space-sm)} .btn{display:inline-flex;align-items:center;justify-content:center;gap:0.4rem;font-family:var(--font);font-size:0.85rem;font-weight:600;padding:0.75rem 1.8rem;border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--t-fast);text-decoration:none}
.btn--primary{background:var(--accent);color:#fff;width:100%}
.btn--primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(232,93,4,0.25)}
.btn--secondary{background:transparent;border:1.5px solid var(--border);color:var(--text)}
.btn--secondary:hover{border-color:var(--accent);color:var(--accent)} .single-product{padding:var(--space-lg) 0 var(--space-3xl)}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2xl);align-items:start}
.product-gallery{position:sticky;top:calc(var(--header-h) + var(--space-sm))}
.product-gallery__main{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius-lg);border:1.5px solid var(--border);background:var(--bg)}
.product-gallery__thumbs{display:flex;gap:0.4rem;margin-top:var(--space-sm)}
.product-gallery__thumb{width:64px;height:64px;object-fit:cover;border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;opacity:0.5;transition:all var(--t-fast)}
.product-gallery__thumb:hover,.product-gallery__thumb.active{border-color:var(--accent);opacity:1}
.product-gallery__thumb--video{position:relative;width:64px;height:64px;border-radius:var(--radius-sm);border:2px solid var(--border);cursor:pointer;opacity:0.5;transition:all var(--t-fast);overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:#000;flex-shrink:0}
.product-gallery__thumb--video:hover,.product-gallery__thumb--video.active{border-color:var(--accent);opacity:1}
.product-gallery__thumb--video video{width:100%;height:100%;object-fit:cover;pointer-events:none}
.product-gallery__play{position:absolute;color:#fff;font-size:16px;text-shadow:0 1px 3px rgba(0,0,0,0.6);pointer-events:none}
.product-gallery__video-wrap{overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center}
.product-info .label{margin-bottom:var(--space-xs)}
.product-info h1{margin-bottom:var(--space-sm);font-size:clamp(1.6rem,2.5vw,2.2rem)}
.product-info__price{font-family:var(--font-display);font-size:1.8rem;font-weight:800;color:var(--accent);margin-bottom:var(--space-lg)}
.product-info__price .product-price--old{font-size:1.1rem;color:var(--text-3)}
.product-info__desc{color:var(--text-2);font-size:0.95rem;line-height:1.8;margin-bottom:var(--space-xl)} .size-selector{margin-bottom:var(--space-xl)}
.size-selector__label{font-size:0.82rem;font-weight:600;margin-bottom:var(--space-sm);display:flex;justify-content:space-between}
.size-selector__label span{color:var(--text-3);font-weight:400}
.size-options{display:flex;gap:0.4rem;flex-wrap:wrap}
.size-opt{min-width:48px;height:42px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:0.82rem;font-weight:600;color:var(--text);cursor:pointer;transition:all var(--t-fast);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 0.6rem;position:relative}
.size-opt:hover:not(.size-opt--out){border-color:var(--accent);color:var(--accent)}
.size-opt.selected{background:var(--accent);border-color:var(--accent);color:#fff}
.size-opt--out{opacity:0.3;cursor:not-allowed;text-decoration:line-through}
.size-opt__stock{font-size:0.55rem;font-weight:500;color:var(--text-3);margin-top:1px}
.size-opt.selected .size-opt__stock{color:rgba(255,255,255,0.7)}
.size-opt--low .size-opt__stock{color:var(--warning)}
.color-options{display:flex;gap:0.4rem;flex-wrap:wrap}
.color-opt{min-width:60px;height:42px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);font-size:0.78rem;font-weight:600;color:var(--text);cursor:pointer;transition:all var(--t-fast);display:flex;align-items:center;justify-content:center;padding:0 0.8rem;position:relative}
.color-opt:hover:not(.color-opt--out){border-color:var(--accent);background:rgba(232,93,4,0.05);color:var(--accent)}
.color-opt.selected{background:var(--accent);border-color:var(--accent);color:#fff}
.color-opt--out{opacity:0.4;cursor:pointer}
.stock-msg{font-size:0.78rem;margin-top:var(--space-xs);font-weight:500;display:flex;align-items:center;gap:0.3rem}
.stock-msg--warning{color:var(--warning)}
.stock-msg--error{color:var(--error)}
.stock-msg--ok{color:var(--success)}
.product-add{display:flex;gap:0.5rem;margin-bottom:var(--space-lg)}
.size-guide{margin-top:var(--space-md);border-top:1px solid var(--border)}
.size-guide__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-md) 0;background:none;border:none;cursor:pointer;font-size:0.9rem;font-weight:600;color:var(--text);transition:color var(--t-fast)}
.size-guide__toggle:hover{color:var(--accent)}
.size-guide__arrow{transition:transform 0.3s ease;flex-shrink:0}
.size-guide__toggle.open .size-guide__arrow{transform:rotate(180deg)}
.size-guide__content{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.size-guide__content.open{max-height:500px}
.size-guide__table{width:100%;border-collapse:collapse;font-size:0.82rem;margin-bottom:var(--space-sm)}
.size-guide__table thead{background:var(--accent)}
.size-guide__table th{padding:0.6rem 0.8rem;text-align:left;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;color:#fff}
.size-guide__table td{padding:0.55rem 0.8rem;border-bottom:1px solid var(--border);color:var(--text-2)}
.size-guide__table tbody tr:nth-child(even){background:rgba(232,93,4,0.04)}
.size-guide__table tbody tr:hover{background:rgba(232,93,4,0.08)}
.size-guide__table td:first-child{font-weight:700;color:var(--text)}
.size-guide__note{font-size:0.75rem;color:var(--accent);font-style:italic;margin-top:var(--space-xs);padding-bottom:var(--space-sm)}
.product-add .btn--primary{flex:1}
.qty-box{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg-card)}
.qty-box button{width:38px;height:44px;background:transparent;border:none;font-size:1rem;color:var(--text);transition:background var(--t-fast)}
.qty-box button:hover{background:var(--bg-hover)}
.qty-box input{width:40px;text-align:center;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);font-family:var(--font);font-size:0.88rem;font-weight:600;background:transparent;color:var(--text);outline:none}
.product-specs{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem;margin-bottom:var(--space-xl)}
.product-spec{padding:0.7rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm)}
.product-spec dt{font-size:0.62rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-3);font-weight:600;margin-bottom:0.1rem}
.product-spec dd{font-weight:600;font-size:0.88rem}
.related-products{padding:var(--space-3xl) 0}
.related-products h2{margin-bottom:var(--space-xl)} .checkout-page{padding:var(--space-2xl) 0 var(--space-3xl)}
.checkout-grid{display:grid;grid-template-columns:1.3fr 0.7fr;gap:var(--space-2xl);align-items:start}
.checkout-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-md)}
.checkout-card h3{font-size:1.05rem;margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}
.form-group{display:flex;flex-direction:column;margin-bottom:var(--space-md)}
.form-group label{font-size:0.78rem;font-weight:600;color:var(--text-2);margin-bottom:0.3rem}
.form-group input,.form-group textarea,.form-group select{font-family:var(--font);font-size:0.88rem;padding:0.7rem 0.85rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text);outline:none;transition:border-color var(--t-fast)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent)}
.form-group textarea{min-height:80px;resize:vertical}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-3)}
.form-group--full{grid-column:1/-1}
.order-summary{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);position:sticky;top:calc(var(--header-h) + var(--space-lg))}
.order-summary h3{font-size:1.05rem;margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}
.order-item{display:flex;gap:0.6rem;padding:0.55rem 0;border-bottom:1px solid var(--border)}
.order-item:last-child{border-bottom:none}
.order-item__img{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border)}
.order-item__info{flex:1}
.order-item__name{font-size:0.8rem;font-weight:600}
.order-item__detail{font-size:0.7rem;color:var(--text-3)}
.order-item__price{font-weight:700;font-size:0.82rem;white-space:nowrap}
.order-totals{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border)}
.order-totals__row{display:flex;justify-content:space-between;padding:0.3rem 0;font-size:0.85rem;color:var(--text-2)}
.order-totals__row--total{padding-top:0.7rem;margin-top:0.5rem;border-top:2px solid var(--text);font-weight:700;font-size:1.1rem;color:var(--text)} .confirmation{text-align:center;padding:var(--space-3xl) 0}
.confirmation__icon{width:80px;height:80px;border-radius:50%;background:var(--success-soft);color:var(--success);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto var(--space-xl)} .account-page{padding:var(--space-2xl) 0 var(--space-3xl)}
.auth-form{max-width:420px;margin:0 auto}
.auth-form h1{text-align:center;margin-bottom:var(--space-xl)}
.auth-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:var(--space-xl)}
.auth-tab{flex:1;padding:var(--space-md);text-align:center;font-weight:600;font-size:0.88rem;color:var(--text-3);border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all var(--t-fast)}
.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.auth-panel{display:none}
.auth-panel.active{display:block}
.orders-table{width:100%;border-collapse:collapse;font-size:0.85rem}
.orders-table th{text-align:left;padding:0.7rem;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-3);border-bottom:2px solid var(--border);background:var(--bg)}
.orders-table td{padding:0.7rem;border-bottom:1px solid var(--border)}
.orders-table tr:hover td{background:var(--accent-soft)}
.status-badge{display:inline-block;padding:0.15rem 0.55rem;font-size:0.68rem;font-weight:700;border-radius:var(--radius-full);letter-spacing:0.02em}
.status-badge--pending{background:rgba(217,119,6,0.08);color:var(--warning)}
.status-badge--processing{background:rgba(59,130,246,0.08);color:#2563EB}
.status-badge--completed{background:var(--success-soft);color:var(--success)}
.status-badge--cancelled{background:var(--error-soft);color:var(--error)} .flash{padding:0.65rem 1rem;border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500;margin-bottom:var(--space-md);display:flex;align-items:center;gap:0.4rem}
.flash--success{background:var(--success-soft);color:var(--success);border:1px solid rgba(5,150,105,0.15)}
.flash--error{background:var(--error-soft);color:var(--error);border:1px solid rgba(220,38,38,0.15)} .site-footer{padding:var(--space-2xl) 0 var(--space-lg);border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-2xl);margin-bottom:var(--space-2xl)}
.footer-brand{font-family:var(--font-display);font-size:1.1rem;font-weight:800}
.footer-brand span{color:var(--accent)}
.footer-brand p{font-family:var(--font);font-size:0.82rem;color:var(--text-2);margin-top:var(--space-xs);font-weight:400;max-width:26ch}
.footer-col h4{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:0.7rem}
.footer-col a{display:block;font-size:0.82rem;color:var(--text-2);padding:0.15rem 0;transition:color var(--t-fast)}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-lg);border-top:1px solid var(--border);font-size:0.75rem;color:var(--text-3)}
.footer-credit{font-size:0.75rem;color:var(--text-3)}
.footer-credit a{color:var(--accent);text-decoration:none;font-weight:500}
.footer-socials{display:flex;gap:var(--space-xs,8px)}
.footer-social{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:color .2s,border-color .2s}
.footer-social:hover{color:var(--accent);border-color:var(--accent)}
.footer-col--links-row{display:none} .pagination{display:flex;justify-content:center;gap:0.3rem;padding:var(--space-2xl) 0}
.pagination a,.pagination span{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;font-size:0.82rem;font-weight:500;border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-2);transition:all var(--t-fast)}
.pagination a:hover{border-color:var(--accent);color:var(--accent)}
.pagination .current{background:var(--accent);border-color:var(--accent);color:#fff} .reveal{opacity:0;transform:translateY(16px);transition:opacity 0.4s var(--ease),transform 0.4s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.stagger .reveal:nth-child(1){transition-delay:0s}
.stagger .reveal:nth-child(2){transition-delay:0.04s}
.stagger .reveal:nth-child(3){transition-delay:0.08s}
.stagger .reveal:nth-child(4){transition-delay:0.12s}
.stagger .reveal:nth-child(5){transition-delay:0.16s}
.stagger .reveal:nth-child(6){transition-delay:0.2s}
.stagger .reveal:nth-child(7){transition-delay:0.24s}
.stagger .reveal:nth-child(8){transition-delay:0.28s} @media(max-width:1024px){
.product-grid{grid-template-columns:repeat(2,1fr)}
.vm-shop-layout{grid-template-columns:220px 1fr}
.footer-grid{grid-template-columns:1fr 1fr}
.checkout-grid{grid-template-columns:1fr}
.order-summary{position:static}
.product-layout{grid-template-columns:1fr}
.product-gallery{position:static}
}
@media(max-width:768px){
.header-search,.header-nav{display:none}
.product-grid{grid-template-columns:repeat(2,1fr);gap:0.5rem}
.product-card__badges{gap:0.2rem}
.product-card__badge{font-size:0.52rem;padding:0.15rem 0.45rem}
.product-card__badge--low-stock{display:none}
.vm-shop-layout{grid-template-columns:1fr}
.vm-sidebar{position:fixed;top:0;left:-300px;width:280px;height:100vh;z-index:1000;border-radius:0;border:none;border-right:1px solid var(--border);overflow-y:auto;transition:left 0.3s ease;padding:var(--space-md)}
.vm-sidebar.open{left:0}
.vm-sidebar__close{display:block}
.vm-search-filter-row{display:flex}
.vm-search-bar__form--desktop{display:none}
.vm-sidebar-col{position:static;max-height:none;overflow:visible}
.vm-sidebar-toggle{display:flex;align-items:center;gap:8px;width:auto;padding:10px 16px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:0.88rem;font-weight:600;color:var(--text-1);font-family:inherit;cursor:pointer;margin-bottom:0}
.vm-sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:999}
.vm-sidebar-overlay.open{display:block}
.footer-grid{grid-template-columns:1fr;gap:0;margin-bottom:var(--space-lg)}
.footer-brand{text-align:center;margin-bottom:var(--space-lg)}
.footer-brand p{max-width:none;text-align:center}
.footer-col{display:none}
.footer-col--links-row{display:flex;flex-wrap:wrap;justify-content:center;gap:0.4rem;margin-bottom:var(--space-md)}
.footer-col--links-row a{display:inline-block;padding:0.4rem 0.85rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;font-size:0.78rem;font-weight:500;color:var(--text-2);transition:all 0.15s}
.footer-col--links-row a:hover{border-color:var(--accent);color:var(--accent)}
.footer-socials{justify-content:center;margin-bottom:var(--space-sm)}
.footer-bottom{flex-direction:column;gap:var(--space-sm);text-align:center;align-items:center}
.form-row{grid-template-columns:1fr}
.product-specs{grid-template-columns:1fr}
.trust-bar{gap:var(--space-lg)}
.cart-sidebar{width:100%;max-width:100%;right:-100%}
}
@media(max-width:480px){
.product-grid{grid-template-columns:1fr 1fr;gap:0.4rem}
.product-card__body{padding:0.6rem}
.product-card__title{font-size:0.8rem}
}