/* =====================================================================
   SHOPMALL.BG — Mall Design System
   Identity: Black / Gold (#FFD700) / White  |  Bold, editorial, high-energy
   NO shared rules with shopmode.cz
   ===================================================================== */

/* ─── Root tokens ─── */
:root {
  --sm-black:       #000;
  --sm-dark:        #0f0f0f;
  --sm-dark2:       #1a1a1a;
  --sm-gold:        #FFD700;
  --sm-gold-dark:   #E6C200;
  --sm-gold-text:   #B8940A;
  --sm-white:       #fff;
  --sm-off:         #f5f5f5;
  --sm-border:      #e0e0e0;
  --sm-text:        #111;
  --sm-muted:       #666;
  --sm-font:        'Poppins','Open Sans',system-ui,sans-serif;
  --sm-radius:      4px;
  --sm-radius-lg:   12px;
}

/* ─── Override CZ warm-beige with white ─── */
.ni-fullscreen { background: var(--sm-white) !important; font-family: var(--sm-font) !important; }

/* ─── MALL TICKER ─── */
.sm-ticker { background: var(--sm-black); overflow: hidden; border-top: 3px solid var(--sm-gold); }
.sm-ticker__track { display: flex; animation: smTicker 40s linear infinite; white-space: nowrap; }
.sm-ticker__track:hover { animation-play-state: paused; }
.sm-ticker__item { display: inline-flex; align-items: center; gap: 10px; padding: 10px 28px; color: var(--sm-white); font-size: 13px; font-weight: 600; letter-spacing: .5px; text-decoration: none; border-right: 1px solid #222; flex-shrink: 0; }
.sm-ticker__item:hover { color: var(--sm-gold); }
.sm-ticker__item i { color: var(--sm-gold); font-size: 11px; }
@keyframes smTicker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ─── MALL WINDOW — bold category showcase ─── */
.sm-mall-window { background: var(--sm-black); }
.sm-mw-header { padding: 40px 40px 20px; display: flex; align-items: flex-end; justify-content: space-between; }
.sm-mw-header__title { font-size: clamp(28px,4vw,52px); font-weight: 900; letter-spacing: -1px; color: var(--sm-white); text-transform: uppercase; line-height: 1; }
.sm-mw-header__title em { color: var(--sm-gold); font-style: normal; }
.sm-mw-header__sub { font-size: 14px; color: #aaa; max-width: 280px; text-align: right; }
.sm-mw-feature { display: grid; grid-template-columns: 2fr 1fr; gap: 3px; padding: 0 3px; }
.sm-mw-stack { display: grid; grid-template-rows: 1fr 1fr; gap: 3px; }
.sm-mw-tile { position: relative; display: block; overflow: hidden; text-decoration: none; background: #111 center/cover no-repeat; }
.sm-mw-tile--big { min-height: 500px; }
.sm-mw-tile--half { min-height: 248px; }
.sm-mw-tile::before { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.2) 50%, transparent 100%); z-index: 1; transition: opacity .3s; }
.sm-mw-tile:hover::before { opacity: .7; }
.sm-mw-tile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.sm-mw-tile:hover img { transform: scale(1.04); }
.sm-mw-tile__inner { position: relative; z-index: 2; padding: 24px; display: flex; flex-direction: column; justify-content: flex-end; height: 100%; }
.sm-mw-tile--big .sm-mw-tile__inner { padding: 32px; }
.sm-mw-tile__tag { display: inline-block; background: var(--sm-gold); color: var(--sm-black); font-size: 10px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; padding: 4px 10px; border-radius: 2px; margin-bottom: 12px; width: fit-content; }
.sm-mw-tile__title { font-size: clamp(32px,5vw,64px); font-weight: 900; color: var(--sm-white); text-transform: uppercase; letter-spacing: -1px; line-height: 1; margin: 0 0 6px; }
.sm-mw-tile--half .sm-mw-tile__title { font-size: clamp(24px,3vw,40px); }
.sm-mw-tile__count { font-size: 13px; color: rgba(255,255,255,.7); margin: 0 0 14px; }
.sm-mw-tile__cta { display: inline-flex; align-items: center; gap: 8px; background: var(--sm-gold); color: var(--sm-black); padding: 10px 20px; font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; border-radius: var(--sm-radius); width: fit-content; transition: background .2s, transform .2s; }
.sm-mw-tile:hover .sm-mw-tile__cta { background: var(--sm-gold-dark); transform: translateX(4px); }
.sm-mw-strip { display: grid; grid-template-columns: repeat(5, 1fr); gap: 3px; padding: 3px; }
.sm-mw-mini { position: relative; overflow: hidden; display: block; text-decoration: none; aspect-ratio: 3/4; background: #111 center/cover no-repeat; }
.sm-mw-mini::before { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.8) 0%, transparent 60%); z-index: 1; }
.sm-mw-mini:hover::before { background: linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 60%); }
.sm-mw-mini img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.sm-mw-mini:hover img { transform: scale(1.06); }
.sm-mw-mini__label { position: absolute; bottom: 0; left: 0; right: 0; z-index: 2; padding: 14px; }
.sm-mw-mini__name { display: block; font-size: 14px; font-weight: 800; color: var(--sm-white); text-transform: uppercase; letter-spacing: .5px; }
.sm-mw-mini__bar { display: block; height: 3px; background: var(--sm-gold); width: 0; transition: width .3s; margin-top: 6px; }
.sm-mw-mini:hover .sm-mw-mini__bar { width: 100%; }

/* ─── SECTION BASE ─── */
.sm-section { padding: 56px 40px; background: var(--sm-white); }
.sm-section--dark { background: var(--sm-dark); }
.sm-section--black { background: var(--sm-black); }
.sm-section__head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 32px; gap: 24px; }
.sm-section__kicker { display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--sm-gold-text); background: rgba(255,215,0,.1); border: 1px solid rgba(255,215,0,.3); padding: 4px 12px; border-radius: 2px; margin-bottom: 10px; }
.sm-section--dark .sm-section__kicker,
.sm-section--black .sm-section__kicker { color: var(--sm-gold); background: rgba(255,215,0,.12); }
.sm-section__title { font-size: clamp(22px,3vw,36px); font-weight: 900; letter-spacing: -.5px; color: var(--sm-text); text-transform: uppercase; margin: 0 0 6px; line-height: 1.1; }
.sm-section--dark .sm-section__title,
.sm-section--black .sm-section__title { color: var(--sm-white); }
.sm-section__sub { font-size: 14px; color: var(--sm-muted); margin: 0; }
.sm-section--dark .sm-section__sub,
.sm-section--black .sm-section__sub { color: #aaa; }
.sm-section__more { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 700; color: var(--sm-text); text-decoration: none; border-bottom: 2px solid var(--sm-gold); padding-bottom: 2px; white-space: nowrap; flex-shrink: 0; transition: color .2s; }
.sm-section__more:hover { color: var(--sm-gold-text); }
.sm-section--dark .sm-section__more,
.sm-section--black .sm-section__more { color: var(--sm-gold); border-color: rgba(255,215,0,.4); }

/* ─── PRODUCT CARDS (BG bold style) ─── */
.sm-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.sm-card { display: block; text-decoration: none; color: inherit; background: var(--sm-white); border: 1.5px solid var(--sm-border); border-radius: var(--sm-radius); overflow: hidden; transition: transform .2s, box-shadow .2s, border-color .2s; }
.sm-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,.1); border-color: var(--sm-gold); }
.sm-card__img { position: relative; aspect-ratio: 3/4; overflow: hidden; background: var(--sm-off); }
.sm-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.sm-card:hover .sm-card__img img { transform: scale(1.04); }
.sm-card__badge { position: absolute; top: 8px; left: 8px; background: var(--sm-black); color: var(--sm-gold); font-size: 11px; font-weight: 800; padding: 3px 8px; border-radius: 2px; letter-spacing: .5px; }
.sm-card__badge--new { background: var(--sm-gold); color: var(--sm-black); }
.sm-card__meta { padding: 12px; }
.sm-card__brand { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sm-muted); margin: 0 0 4px; }
.sm-card__title { font-size: 13px; font-weight: 600; color: var(--sm-text); margin: 0 0 8px; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sm-card__prices { display: flex; align-items: center; gap: 8px; }
.sm-card__price { font-size: 16px; font-weight: 900; color: var(--sm-black); }
.sm-card__old { font-size: 12px; color: var(--sm-muted); text-decoration: line-through; }

/* ─── STYLE ROULETTE (unique BG widget) ─── */
.sm-roulette { background: var(--sm-black); padding: 56px 40px; text-align: center; }
.sm-roulette__eyebrow { font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--sm-gold); display: block; margin-bottom: 12px; }
.sm-roulette__title { font-size: clamp(28px,4vw,48px); font-weight: 900; color: var(--sm-white); text-transform: uppercase; letter-spacing: -1px; margin: 0 0 10px; }
.sm-roulette__title em { color: var(--sm-gold); font-style: normal; }
.sm-roulette__sub { font-size: 15px; color: #aaa; margin: 0 0 40px; }
.sm-roulette__display { width: 260px; height: 260px; border-radius: 50%; border: 5px solid var(--sm-gold); background: #111; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 8px; margin: 0 auto 32px; cursor: pointer; user-select: none; position: relative; transition: transform .1s; }
.sm-roulette__display:hover { transform: scale(1.02); }
.sm-roulette__display.is-spinning { animation: smSpin 1.8s cubic-bezier(.17,.67,.12,.99) forwards; }
@keyframes smSpin { 0%{transform:rotate(0)} 100%{transform:rotate(900deg)} }
.sm-roulette__icon { font-size: 48px; transition: opacity .3s; }
.sm-roulette__cat-name { font-size: 18px; font-weight: 900; color: var(--sm-gold); text-transform: uppercase; letter-spacing: 1px; transition: opacity .3s; }
.sm-roulette__hint { font-size: 12px; color: #555; margin-top: 4px; }
.sm-roulette__btn { display: inline-flex; align-items: center; gap: 10px; background: var(--sm-gold); color: var(--sm-black); font-size: 15px; font-weight: 900; text-transform: uppercase; letter-spacing: 1.5px; padding: 16px 36px; border: none; border-radius: var(--sm-radius); cursor: pointer; transition: background .2s, transform .1s; }
.sm-roulette__btn:active { transform: scale(.97); }
.sm-roulette__btn:hover { background: var(--sm-gold-dark); }
.sm-roulette__result-text { margin-top: 20px; font-size: 14px; color: #bbb; min-height: 22px; }
.sm-roulette__result-text a { color: var(--sm-gold); font-weight: 700; text-decoration: none; }
.sm-roulette__result-text a:hover { text-decoration: underline; }

/* ─── STYLE QUIZ (3-step) ─── */
.sm-quiz { background: var(--sm-gold); padding: 56px 40px; }
.sm-quiz__inner { max-width: 760px; margin: 0 auto; }
.sm-quiz__tag { font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: #555; display: block; margin-bottom: 12px; }
.sm-quiz__title { font-size: clamp(24px,3.5vw,44px); font-weight: 900; color: var(--sm-black); text-transform: uppercase; letter-spacing: -.5px; margin: 0 0 6px; }
.sm-quiz__sub { font-size: 15px; color: #333; margin: 0 0 36px; }
.sm-quiz__panel { display: none; }
.sm-quiz__panel.is-active { display: block; }
.sm-quiz__step-label { font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #555; margin-bottom: 14px; }
.sm-quiz__row { display: flex; flex-wrap: wrap; gap: 10px; }
.sm-quiz__btn { padding: 12px 22px; border: 2.5px solid var(--sm-black); background: transparent; font-size: 14px; font-weight: 700; color: var(--sm-black); border-radius: var(--sm-radius); cursor: pointer; transition: all .15s; font-family: var(--sm-font); }
.sm-quiz__btn:hover { background: var(--sm-black); color: var(--sm-gold); }
.sm-quiz__start { display: inline-flex; align-items: center; gap: 10px; background: var(--sm-black); color: var(--sm-gold); font-size: 16px; font-weight: 900; text-transform: uppercase; letter-spacing: 1px; padding: 16px 32px; border: none; border-radius: var(--sm-radius); cursor: pointer; font-family: var(--sm-font); transition: opacity .2s; }
.sm-quiz__start:hover { opacity: .85; }

/* ─── BRAND WALL ─── */
.sm-brand-wall { background: var(--sm-dark); padding: 48px 40px; }
.sm-brand-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 2px; }
.sm-brand-cell { display: flex; align-items: center; justify-content: center; background: #111; padding: 20px 12px; text-decoration: none; transition: background .2s; min-height: 72px; }
.sm-brand-cell:hover { background: var(--sm-gold); }
.sm-brand-cell span { font-size: 12px; font-weight: 700; color: #ccc; letter-spacing: .5px; text-align: center; text-transform: uppercase; }
.sm-brand-cell:hover span { color: var(--sm-black); }
.sm-brand-cell img { max-width: 100%; max-height: 38px; filter: grayscale(1) brightness(1.5); transition: filter .2s; object-fit: contain; }
.sm-brand-cell:hover img { filter: grayscale(1) brightness(0); }

/* ─── USP STRIP override ─── */
.ni-usps { background: var(--sm-black) !important; border-top: 1px solid #1a1a1a !important; }
.ni-usp i { color: var(--sm-gold) !important; }
.ni-usp strong { color: var(--sm-white) !important; }
.ni-usp span { color: #888 !important; }

/* ─── QUICK PILLS override ─── */
.ni-quick { background: var(--sm-black) !important; }
.ni-quick__label { color: var(--sm-gold) !important; font-weight: 800 !important; }
.ni-quick__pill { background: #111 !important; border: 1px solid #2a2a2a !important; color: #ccc !important; font-weight: 600 !important; }
.ni-quick__pill:hover { background: var(--sm-gold) !important; border-color: var(--sm-gold) !important; color: var(--sm-black) !important; }
.ni-quick__pill i { color: var(--sm-gold); }
.ni-quick__pill:hover i { color: var(--sm-black); }

/* ─── SOCIAL PROOF BAND override ─── */
.ni-social-proof-band { background: var(--sm-gold) !important; padding: 0 !important; }
.ni-social-proof { background: transparent !important; border: none !important; box-shadow: none !important; }
.ni-social-proof__text { color: var(--sm-black) !important; font-weight: 700 !important; }
#niLiveCount { color: var(--sm-black) !important; }
.ni-social-proof__dot { background: var(--sm-black) !important; }

/* ─── DEAL override (dark) ─── */
.ni-deals { background: var(--sm-dark) !important; padding: 48px 40px !important; }
.ni-deals .ni-section__head { /* inherit section head dark styles */ }
.ni-deal { background: #111 !important; border: 1.5px solid #2a2a2a !important; border-radius: var(--sm-radius) !important; }
.ni-deal:hover { border-color: var(--sm-gold) !important; transform: translateY(-4px) !important; }
.ni-deal__badge { background: var(--sm-gold) !important; color: var(--sm-black) !important; font-weight: 900 !important; border-radius: 2px !important; }
.ni-deal__title { color: var(--sm-white) !important; }
.ni-deal__now { color: var(--sm-gold) !important; font-weight: 900 !important; font-size: 18px !important; }
.ni-deal__was { color: #666 !important; }
.ni-deals .ni-section__kicker { color: var(--sm-gold) !important; background: rgba(255,215,0,.12) !important; border-color: rgba(255,215,0,.3) !important; }
.ni-deals .ni-section__title { color: var(--sm-white) !important; }
.ni-deals .ni-section__sub { color: #aaa !important; }
.ni-deals .ni-section__more { color: var(--sm-gold) !important; }

/* ─── PRICE DROP override (off-white) ─── */
.ni-drops { background: var(--sm-off) !important; }
.ni-drops__kicker { color: var(--sm-gold-text) !important; background: rgba(255,215,0,.1) !important; border: 1px solid rgba(255,215,0,.3) !important; }
.ni-drop { background: var(--sm-white) !important; border: 1.5px solid var(--sm-border) !important; border-radius: var(--sm-radius) !important; }
.ni-drop:hover { border-color: var(--sm-gold) !important; transform: translateY(-3px) !important; }
.ni-drop__pct { background: var(--sm-gold) !important; color: var(--sm-black) !important; font-weight: 900 !important; border-radius: 2px !important; }
.ni-drop__now { color: var(--sm-black) !important; font-weight: 900 !important; }

/* ─── AI GUIDE override (dark) ─── */
.ni-wizard-cta.ni-ai-guide { background: var(--sm-dark) !important; border-top: 3px solid var(--sm-gold) !important; border-bottom: 3px solid var(--sm-gold) !important; }
.ni-ai-guide__kicker { color: var(--sm-gold) !important; background: rgba(255,215,0,.1) !important; border-color: rgba(255,215,0,.3) !important; }
.ni-ai-guide__title { color: var(--sm-white) !important; }
.ni-ai-guide__text { color: #aaa !important; }
.ni-ai-guide__step { background: #111 !important; border-color: #2a2a2a !important; }
.ni-ai-guide__step-label { color: #ccc !important; }
.ni-ai-guide__icon { background: var(--sm-gold) !important; color: var(--sm-black) !important; }

/* ─── SPORT override (dark) ─── */
.ni-sport { background: var(--sm-dark) !important; }
.ni-sport__title { color: var(--sm-white) !important; }
.ni-sport__kicker { color: var(--sm-gold) !important; }
.ni-sport__sub { color: #aaa !important; }
.ni-sport__col-title { color: var(--sm-gold) !important; }
.ni-sport__disc { background: #111 !important; border-color: #2a2a2a !important; color: var(--sm-white) !important; }
.ni-sport__disc:hover { background: var(--sm-gold) !important; border-color: var(--sm-gold) !important; color: var(--sm-black) !important; }
.ni-sport__disc i { color: var(--sm-gold); }
.ni-sport__disc:hover i { color: var(--sm-black); }

/* ─── OCCASION TILES override (dark overlay, bold) ─── */
.ni-occasion { border-radius: 0 !important; }
.ni-occasion__kicker { color: var(--sm-gold) !important; font-weight: 800 !important; letter-spacing: 2px !important; }
.ni-occasion__title { font-weight: 900 !important; text-transform: uppercase !important; }
.ni-occasion__cta { background: var(--sm-gold) !important; color: var(--sm-black) !important; font-weight: 800 !important; }

/* ─── EDITORIAL TILES override ─── */
.ni-edit-tile { border-radius: 0 !important; }
.ni-edit-tile__kicker { color: var(--sm-gold) !important; font-weight: 800 !important; letter-spacing: 2px !important; background: transparent !important; border: none !important; padding: 0 !important; }

/* ─── PROD CARDS override (BG flat style) ─── */
.ni-prod { background: var(--sm-white) !important; border: 1.5px solid var(--sm-border) !important; border-radius: var(--sm-radius) !important; }
.ni-prod:hover { border-color: var(--sm-gold) !important; transform: translateY(-3px) !important; }
.ni-prod__price { color: var(--sm-black) !important; font-weight: 900 !important; }
.ni-prod__old { color: var(--sm-muted) !important; }

/* ─── LOOK CARDS override ─── */
.ni-look__shop { background: var(--sm-gold) !important; color: var(--sm-black) !important; font-weight: 800 !important; }
.ni-look__slot { background: var(--sm-gold) !important; color: var(--sm-black) !important; font-weight: 800 !important; }

/* ─── BRAND section override ─── */
.ni-botw { background: var(--sm-dark) !important; }
.ni-botw__kicker { color: var(--sm-gold) !important; background: rgba(255,215,0,.1) !important; }
.ni-botw__name { color: var(--sm-white) !important; }
.ni-botw__desc { color: #aaa !important; }

/* ─── NEWSLETTER override ─── */
.ni-newsletter { background: var(--sm-dark) !important; border-top: 3px solid var(--sm-gold) !important; }
.ni-newsletter h2 { color: var(--sm-white) !important; }
.ni-newsletter p { color: #aaa !important; }
.ni-newsletter__form input[type="email"] { background: #111 !important; border: 1.5px solid #333 !important; color: var(--sm-white) !important; border-radius: var(--sm-radius) !important; }
.ni-newsletter__form input[type="email"]::placeholder { color: #555 !important; }
.ni-newsletter__consent, .ni-newsletter__legal { color: #777 !important; }
.ni-newsletter__consent a { color: var(--sm-gold) !important; }
.ni-newsletter__status.is-success { color: var(--sm-gold) !important; }
.ni-btn--accent { background: var(--sm-gold) !important; color: var(--sm-black) !important; font-weight: 800 !important; border-radius: var(--sm-radius) !important; }
.ni-btn--accent:hover { background: var(--sm-gold-dark) !important; }

/* ─── SEO SECTION override ─── */
.ni-seo { background: var(--sm-black) !important; }
.ni-seo h2 { color: var(--sm-white) !important; }
.ni-seo p { color: #888 !important; }
.ni-seo a { color: var(--sm-gold) !important; }
.ni-seo a:hover { color: var(--sm-gold-dark) !important; }

/* ─── HERO stats override ─── */
.ni-hero__stat b { color: var(--sm-gold) !important; }

/* ─── SECTION kicker green → gold ─── */
.ni-section__kicker--green { background: rgba(255,215,0,.1) !important; color: var(--sm-gold-text) !important; border: 1px solid rgba(255,215,0,.3) !important; border-radius: 2px !important; }

/* ─── OUTFIT SECTION override ─── */
.ni-outfit { background: var(--sm-black) !important; }
.ni-outfit__kicker { color: var(--sm-gold) !important; }
.ni-outfit__title { color: var(--sm-white) !important; }
.ni-outfit__desc { color: #aaa !important; }
.ni-outfit__refresh { border-color: var(--sm-gold) !important; color: var(--sm-gold) !important; }
.ni-outfit__refresh:hover { background: var(--sm-gold) !important; color: var(--sm-black) !important; }
.ni-outfit__item { background: #111 !important; border-color: #2a2a2a !important; }
.ni-outfit__item:hover { border-color: var(--sm-gold) !important; }
.ni-outfit__slot { color: var(--sm-gold) !important; }
.ni-outfit__name { color: #ccc !important; }
.ni-outfit__price { color: var(--sm-gold) !important; font-weight: 900 !important; }
.ni-outfit__total { background: #111 !important; border-color: #2a2a2a !important; }
.ni-outfit__total strong { color: var(--sm-gold) !important; }

/* ─── CATEGORY INDEX PAGE ─── */
.sm-cat-page { background: var(--sm-white); }

/* Category banner (top of category page) */
.sm-cat-banner { position: relative; min-height: 200px; background: var(--sm-black); overflow: hidden; display: flex; align-items: flex-end; }
.sm-cat-banner__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .35; }
.sm-cat-banner__content { position: relative; z-index: 2; padding: 32px 40px; width: 100%; }
.sm-cat-banner__kicker { font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--sm-gold); display: block; margin-bottom: 8px; }
.sm-cat-banner__title { font-size: clamp(28px,5vw,60px); font-weight: 900; color: var(--sm-white); text-transform: uppercase; letter-spacing: -1px; margin: 0; line-height: 1; }
.sm-cat-banner__meta { margin-top: 10px; display: flex; gap: 20px; align-items: center; }
.sm-cat-banner__count { font-size: 14px; color: rgba(255,255,255,.6); }
.sm-cat-banner__breadcrumb { display: flex; gap: 6px; align-items: center; font-size: 13px; color: rgba(255,255,255,.5); }
.sm-cat-banner__breadcrumb a { color: rgba(255,255,255,.7); text-decoration: none; }
.sm-cat-banner__breadcrumb a:hover { color: var(--sm-gold); }
.sm-cat-banner__breadcrumb span { color: var(--sm-gold); }

/* Subcategory chips */
.sm-subcat-chips { background: var(--sm-dark); padding: 14px 40px; display: flex; gap: 8px; flex-wrap: wrap; border-bottom: 1px solid #222; }
.sm-subcat-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; background: #111; border: 1px solid #2a2a2a; color: #ccc; font-size: 12px; font-weight: 600; text-decoration: none; border-radius: 2px; transition: all .15s; white-space: nowrap; }
.sm-subcat-chip:hover, .sm-subcat-chip.is-active { background: var(--sm-gold); border-color: var(--sm-gold); color: var(--sm-black); }

/* ─── PRODUCERS (BRAND) PAGE ─── */
.sm-producers-hero { background: var(--sm-black); padding: 60px 40px 40px; text-align: center; border-bottom: 3px solid var(--sm-gold); }
.sm-producers-hero__tag { font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--sm-gold); display: block; margin-bottom: 14px; }
.sm-producers-hero__title { font-size: clamp(40px,6vw,80px); font-weight: 900; color: var(--sm-white); text-transform: uppercase; letter-spacing: -2px; line-height: 1; margin: 0 0 12px; }
.sm-producers-hero__sub { font-size: 15px; color: #aaa; }
.sm-producers-wrap { max-width: 1400px; margin: 0 auto; padding: 40px; }
.sm-producers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.sm-producer-card { display: block; text-decoration: none; background: var(--sm-white); border: 1.5px solid var(--sm-border); border-radius: var(--sm-radius); overflow: hidden; transition: transform .2s, border-color .2s, box-shadow .2s; }
.sm-producer-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,.08); border-color: var(--sm-gold); }
.sm-producer-card__img { aspect-ratio: 3/2; background: var(--sm-off); overflow: hidden; display: flex; align-items: center; justify-content: center; position: relative; }
.sm-producer-card__img img { max-width: 80%; max-height: 80%; object-fit: contain; transition: transform .3s; }
.sm-producer-card:hover .sm-producer-card__img img { transform: scale(1.08); }
.sm-producer-card__img-fallback { font-size: clamp(16px,3vw,28px); font-weight: 900; color: var(--sm-text); text-transform: uppercase; letter-spacing: -1px; }
.sm-producer-card__meta { padding: 14px; display: flex; align-items: center; justify-content: space-between; }
.sm-producer-card__name { font-size: 14px; font-weight: 800; color: var(--sm-text); text-transform: uppercase; letter-spacing: .5px; }
.sm-producer-card__count { font-size: 12px; color: var(--sm-muted); }
.sm-producer-card:hover .sm-producer-card__name { color: var(--sm-gold-text); }

/* ─── PRODUCT DETAIL PAGE ─── */
.sm-pv-wrapper { background: var(--sm-white); }
.sm-pv-crumbs { padding: 14px 40px; display: flex; gap: 6px; align-items: center; font-size: 13px; color: var(--sm-muted); border-bottom: 1px solid var(--sm-border); flex-wrap: wrap; }
.sm-pv-crumbs a { color: var(--sm-muted); text-decoration: none; }
.sm-pv-crumbs a:hover { color: var(--sm-gold-text); }
.sm-pv-crumbs span { color: var(--sm-gold-text); }
.sm-pv-body { max-width: 1200px; margin: 0 auto; padding: 36px 40px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.sm-pv-gallery { position: relative; }
.sm-pv-main-img { aspect-ratio: 3/4; overflow: hidden; border-radius: var(--sm-radius); background: var(--sm-off); }
.sm-pv-main-img img { width: 100%; height: 100%; object-fit: cover; }
.sm-pv-badges { position: absolute; top: 12px; left: 12px; display: flex; flex-direction: column; gap: 6px; }
.sm-pv-badge { display: inline-block; padding: 4px 10px; font-size: 11px; font-weight: 800; letter-spacing: .5px; border-radius: 2px; }
.sm-pv-badge--sale { background: var(--sm-gold); color: var(--sm-black); }
.sm-pv-badge--new { background: var(--sm-black); color: var(--sm-white); }
.sm-pv-info { }
.sm-pv-brand { font-size: 11px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase; color: var(--sm-muted); margin-bottom: 8px; display: block; }
.sm-pv-title { font-size: clamp(20px,2.5vw,30px); font-weight: 800; color: var(--sm-text); line-height: 1.25; margin: 0 0 20px; }
.sm-pv-price-row { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; flex-wrap: wrap; }
.sm-pv-price-now { font-size: 38px; font-weight: 900; color: var(--sm-black); }
.sm-pv-price-old { font-size: 20px; color: var(--sm-muted); text-decoration: line-through; }
.sm-pv-discount { background: var(--sm-gold); color: var(--sm-black); font-size: 13px; font-weight: 900; padding: 5px 10px; border-radius: 2px; }
.sm-pv-buy-btn { display: flex; align-items: center; justify-content: center; gap: 12px; background: var(--sm-black); color: var(--sm-gold); font-size: 16px; font-weight: 900; text-transform: uppercase; letter-spacing: 2px; padding: 18px 32px; border-radius: var(--sm-radius); text-decoration: none; transition: background .2s, color .2s; width: 100%; box-sizing: border-box; border: 2.5px solid var(--sm-black); }
.sm-pv-buy-btn:hover { background: var(--sm-gold); color: var(--sm-black); }
.sm-pv-buy-btn i { font-size: 18px; }
.sm-pv-divider { border: none; border-top: 1px solid var(--sm-border); margin: 28px 0; }
.sm-pv-desc { font-size: 15px; line-height: 1.75; color: #444; }
.sm-pv-desc h2, .sm-pv-desc h3 { font-size: 16px; font-weight: 700; color: var(--sm-text); text-transform: uppercase; letter-spacing: .5px; margin: 20px 0 8px; }
.sm-pv-similar { padding: 48px 40px; background: var(--sm-off); border-top: 1px solid var(--sm-border); }
.sm-pv-similar__title { font-size: 22px; font-weight: 900; color: var(--sm-text); text-transform: uppercase; letter-spacing: -.5px; margin: 0 0 24px; }
.sm-pv-sim-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 14px; }
.sm-pv-sim-card { display: block; text-decoration: none; background: var(--sm-white); border: 1.5px solid var(--sm-border); border-radius: var(--sm-radius); overflow: hidden; transition: border-color .2s, transform .2s; }
.sm-pv-sim-card:hover { border-color: var(--sm-gold); transform: translateY(-3px); }
.sm-pv-sim-card__img { aspect-ratio: 3/4; overflow: hidden; }
.sm-pv-sim-card__img img { width: 100%; height: 100%; object-fit: cover; }
.sm-pv-sim-card__meta { padding: 10px; }
.sm-pv-sim-card__title { font-size: 12px; color: var(--sm-text); margin-bottom: 4px; line-height: 1.3; }
.sm-pv-sim-card__price { font-size: 14px; font-weight: 900; color: var(--sm-black); }

/* ─── MALL WINDOW responsive (visible on ALL screen sizes) ─── */
@media (max-width: 767px) {
  .sm-mw-feature { grid-template-columns: 1fr; }
  .sm-mw-tile--big { min-height: 280px; }
  .sm-mw-tile--half { min-height: 160px; }
  .sm-mw-stack { grid-template-columns: 1fr 1fr; grid-template-rows: auto; gap: 3px; }
  .sm-mw-strip { grid-template-columns: repeat(3,1fr); }
  .sm-mw-header { padding: 24px 16px 14px; flex-direction: column; gap: 8px; }
  .sm-mw-header__sub { text-align: left; }
}
@media (max-width: 767px) {
  .sm-ticker__item { padding: 8px 16px; font-size: 12px; }
}

/* ─── RESPONSIVE ─── */
@media (max-width: 991px) {
  .sm-quiz { padding: 36px 20px; }
  .sm-roulette { padding: 36px 20px; }
  .sm-brand-wall { padding: 36px 20px; }
  .sm-section { padding: 36px 20px; }
  .sm-pv-body { grid-template-columns: 1fr; padding: 20px; }
  .sm-pv-crumbs { padding: 12px 20px; }
  .sm-pv-similar { padding: 32px 20px; }
  .sm-producers-wrap { padding: 24px 20px; }
}

/* ─── SCROLL REVEAL ANIMATIONS ─── */
.sm-reveal { opacity: 0; transform: translateY(28px); transition: opacity .55s ease, transform .55s ease; }
.sm-reveal.is-visible { opacity: 1; transform: translateY(0); }
.sm-reveal-left { opacity: 0; transform: translateX(-28px); transition: opacity .55s ease, transform .55s ease; }
.sm-reveal-left.is-visible { opacity: 1; transform: translateX(0); }
.sm-reveal-scale { opacity: 0; transform: scale(.95); transition: opacity .5s ease, transform .5s ease; }
.sm-reveal-scale.is-visible { opacity: 1; transform: scale(1); }

/* ─── HERO PARALLAX TINT ─── */
.ni-hero { position: relative; }
.ni-hero::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 120px; background: linear-gradient(to top, var(--sm-black), transparent); pointer-events: none; z-index: 3; }

/* ─── GOLD PULSE animation for social proof ─── */
@keyframes smGoldPulse { 0%,100%{box-shadow:0 0 0 0 rgba(255,215,0,.4)} 50%{box-shadow:0 0 0 8px rgba(255,215,0,0)} }
.ni-social-proof__dot { animation: smGoldPulse 2s infinite !important; }

/* ─── FLOATING CHIP animation (AI guide) ─── */
.ni-ai-guide__chip { animation: smFloat 4s ease-in-out infinite; }
.ni-ai-guide__chip--1 { animation-delay: 0s; }
.ni-ai-guide__chip--2 { animation-delay: .7s; }
.ni-ai-guide__chip--3 { animation-delay: 1.4s; }
.ni-ai-guide__chip--4 { animation-delay: 2.1s; }
.ni-ai-guide__chip--5 { animation-delay: 2.8s; }
@keyframes smFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }

/* ─── TYPING CURSOR for hero kicker ─── */
.ni-hero__kicker { border-right: 2px solid var(--sm-gold); padding-right: 2px; animation: smCursor 1s step-end infinite; }
.ni-hero__slide:not(.is-active) .ni-hero__kicker { animation: none; border-right: none; }
@keyframes smCursor { 0%,100%{border-color:var(--sm-gold)} 50%{border-color:transparent} }

/* ─── MAGNETIC BUTTON effect (JS-powered, CSS side) ─── */
.sm-magnetic { transition: transform .2s cubic-bezier(.23,1,.32,1); }

/* ─── ROULETTE wheel glow ─── */
.sm-roulette__display { box-shadow: 0 0 40px rgba(255,215,0,.15); transition: box-shadow .3s; }
.sm-roulette__display:hover { box-shadow: 0 0 60px rgba(255,215,0,.3); }

/* ─── MALL WINDOW tile shimmer on load ─── */
@keyframes smShimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
.sm-mw-tile.is-loading { background: linear-gradient(90deg,#111 25%,#1a1a1a 50%,#111 75%); background-size:200% 100%; animation:smShimmer 1.5s infinite; }

/* ─── TICKER smooth glow on scroll into view ─── */
.sm-ticker { transition: opacity .4s; }

/* ─── PRODUCT CARD shimmer skeleton ─── */
.sm-card--skeleton .sm-card__img { background: linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%); background-size:200% 100%; animation:smShimmer 1.5s infinite; }

/* ─── SECTION SEPARATOR — diagonal gold line ─── */
.sm-sep { width: 48px; height: 3px; background: var(--sm-gold); margin: 14px 0; display: block; }

/* ─── PRICE PULSE (for live price updates) ─── */
@keyframes smPricePulse { 0%{color:var(--sm-gold);transform:scale(1.1)} 100%{color:inherit;transform:scale(1)} }
.sm-price-updated { animation: smPricePulse .6s ease-out forwards; }

/* ═══════════════════════════════════════════════════════════════════════
   HIGH-SPECIFICITY OVERRIDES — prefix .ni-fullscreen to win vs index.css
   index.css loads inside the view (after layout head CSS) so same-spec
   !important in index.css beats shopmall-theme.css at equal specificity.
   Adding .ni-fullscreen parent bumps specificity to guarantee gold wins.
   ═══════════════════════════════════════════════════════════════════════ */

/* ── LOOK CARDS dark context ── */
.ni-fullscreen .ni-look { background: #111 !important; border-radius: 0 !important; }
.ni-fullscreen .ni-look__products { background: #1a1a1a !important; }
.ni-fullscreen .ni-look__product { background: #222 !important; border-color: #333 !important; }
.ni-fullscreen .ni-look__footer { background: #0f0f0f !important; border-top: 1px solid #2a2a2a !important; }
.ni-fullscreen .ni-look__count { color: #666 !important; }
.ni-fullscreen .ni-look__title { color: #fff !important; font-weight: 800 !important; }
.ni-fullscreen .ni-look__cover-link:hover .ni-look__title { color: #FFD700 !important; }
.ni-fullscreen .ni-look__slot { background: #FFD700 !important; color: #000 !important; font-weight: 800 !important; border-radius: 0 !important; box-shadow: none !important; }
.ni-fullscreen .ni-look__shop { background: transparent !important; color: #FFD700 !important; font-weight: 800 !important; border-bottom: 2px solid #FFD700 !important; padding: 2px 0 !important; border-radius: 0 !important; }
.ni-fullscreen .ni-look__shop:hover { color: #E6C200 !important; background: transparent !important; }
.ni-fullscreen .ni-look__sub { color: #ccc !important; }

/* ── BOTW dark context — product prices in gold ── */
.ni-fullscreen .ni-botw__prod .ni-prod__price { color: #FFD700 !important; }
.ni-fullscreen .ni-botw__prod .ni-prod__old { color: #555 !important; }
.ni-fullscreen .ni-botw__prod .ni-prod__title { color: #ddd !important; }
.ni-fullscreen .ni-botw .ni-btn--accent { background: #FFD700 !important; color: #000 !important; font-weight: 800 !important; border-color: #FFD700 !important; }

/* ── WIZARD-CTA step numbers (CZ orange → gold) ── */
.ni-fullscreen .ni-wizard-cta__step-num { color: #FFD700 !important; }
.ni-fullscreen .ni-wizard-cta__step-label { color: #ccc !important; }
.ni-fullscreen .ni-wizard-cta__step:not(:last-child)::after { background: rgba(255,215,0,.35) !important; }
.ni-fullscreen .ni-wizard-cta__icon { background: #FFD700 !important; color: #000 !important; box-shadow: 0 8px 24px rgba(255,215,0,.25) !important; }
.ni-fullscreen .ni-wizard-cta__step:hover .ni-wizard-cta__icon { box-shadow: 0 12px 32px rgba(255,215,0,.4) !important; }
.ni-fullscreen .ni-wizard-cta__title { color: #fff !important; }
.ni-fullscreen .ni-wizard-cta__text { color: #aaa !important; }
.ni-fullscreen .ni-wizard-cta__text strong,
.ni-fullscreen .ni-wizard-cta__text em { color: #FFD700 !important; }
.ni-fullscreen .ni-wizard-cta { background: #0f0f0f !important; }

/* ── GENDER RAILS ── */
.ni-fullscreen .ni-rail__title { color: #fff !important; }
.ni-fullscreen .ni-rail__sub { color: #aaa !important; }
.ni-fullscreen .ni-rail__head .ni-section__more { color: #FFD700 !important; }

/* ── HOMEPAGE BRAND LOGOS section ── */
.ni-fullscreen .ni-brand { border: 1.5px solid #e5e5e5 !important; border-radius: 6px !important; background: #fff !important; }
.ni-fullscreen .ni-brand:hover { border-color: #FFD700 !important; box-shadow: 0 6px 20px rgba(255,215,0,.18) !important; transform: translateY(-2px) !important; }
.ni-fullscreen .ni-brand span { color: #111 !important; font-weight: 700 !important; }
.ni-fullscreen .ni-brand:hover span { color: #B8940A !important; }

/* ── NEWS CARDS ── */
.ni-fullscreen .ni-news-card { border: 1.5px solid #e5e5e5 !important; border-radius: 0 !important; background: #fff !important; }
.ni-fullscreen .ni-news-card:hover { border-color: #FFD700 !important; transform: translateY(-2px) !important; }
.ni-fullscreen .ni-news-card__title { color: #111 !important; font-weight: 800 !important; }
.ni-fullscreen .ni-news-card time { color: #B8940A !important; font-weight: 600 !important; }

/* ── DEALS section-more link border (lime → gold) ── */
.ni-fullscreen .ni-deals .ni-section__more { color: #FFD700 !important; border-color: rgba(255,215,0,.4) !important; }
.ni-fullscreen .ni-deals .ni-section__more:hover { background: #FFD700 !important; color: #000 !important; }
.ni-fullscreen .ni-deals__kicker { background: #FFD700 !important; color: #000 !important; border-radius: 2px !important; }

/* ── DROPS section detail ── */
.ni-fullscreen .ni-drops .ni-section__title { color: #111 !important; }
.ni-fullscreen .ni-drops .ni-section__sub { color: #555 !important; }
.ni-fullscreen .ni-drops .ni-section__more { color: #B8940A !important; }
.ni-fullscreen .ni-drop__when { color: #FFD700 !important; font-weight: 700 !important; }
.ni-fullscreen .ni-drop__title { color: #111 !important; }
.ni-fullscreen .ni-drop__now { color: #111 !important; font-weight: 900 !important; }

/* ── SPORT override (all orange → gold) ── */
.ni-fullscreen .ni-sport { background: #0f0f0f !important; border-radius: 0 !important; }
.ni-fullscreen .ni-sport__kicker { color: #FFD700 !important; background: rgba(255,215,0,.1) !important; }
.ni-fullscreen .ni-sport__title { color: #FFD700 !important; }
.ni-fullscreen .ni-sport__sub { color: #aaa !important; }
.ni-fullscreen .ni-sport .ni-btn--outline { border-color: #FFD700 !important; color: #FFD700 !important; background: transparent !important; }
.ni-fullscreen .ni-sport .ni-btn--outline:hover { background: #FFD700 !important; color: #000 !important; }
.ni-fullscreen .ni-sport__col-title { color: #FFD700 !important; }
.ni-fullscreen .ni-sport__disc { background: #111 !important; border-color: #2a2a2a !important; color: #fff !important; }
.ni-fullscreen .ni-sport__disc:hover { background: #FFD700 !important; border-color: #FFD700 !important; color: #000 !important; }
.ni-fullscreen .ni-sport__disc i { color: #FFD700 !important; }
.ni-fullscreen .ni-sport__disc:hover i { color: #000 !important; }

/* ── SECTION KICKER green variants → gold ── */
.ni-fullscreen .ni-section__kicker--green { background: rgba(255,215,0,.1) !important; color: #B8940A !important; border: 1px solid rgba(255,215,0,.3) !important; border-radius: 2px !important; }

/* ── PRODUCT CARDS general ── */
.ni-fullscreen .ni-prod { background: #fff !important; border: 1.5px solid #e8e8e8 !important; border-radius: 4px !important; }
.ni-fullscreen .ni-prod:hover { border-color: #FFD700 !important; transform: translateY(-3px) !important; box-shadow: 0 8px 24px rgba(0,0,0,.08) !important; }
.ni-fullscreen .ni-prod__title { color: #111 !important; font-size: 13px !important; font-weight: 600 !important; }
.ni-fullscreen .ni-prod__price { color: #111 !important; font-weight: 900 !important; }
.ni-fullscreen .ni-prod__old { color: #999 !important; }

/* ── OUTFIT section bg gradient → pure black ── */
.ni-fullscreen .ni-outfit { background: #000 !important; }
.ni-fullscreen .ni-outfit__kicker { background: #FFD700 !important; color: #000 !important; border-radius: 2px !important; }
.ni-fullscreen .ni-outfit__desc strong { color: #FFD700 !important; }

/* ── CATEGORY TILES ── */
.ni-fullscreen .ni-cat { border-radius: 0 !important; overflow: hidden !important; }
.ni-fullscreen .ni-cat:hover .ni-cat__lbl { color: #FFD700 !important; }
.ni-fullscreen .ni-cat__meta { background: rgba(0,0,0,.72) !important; }
.ni-fullscreen .ni-cat__lbl { color: #fff !important; font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: .5px !important; }

/* ── OCCASION overlay CTA ── */
.ni-fullscreen .ni-occasion__cta { background: #FFD700 !important; color: #000 !important; border-radius: 0 !important; }

/* ── SECTION general background ── */
.ni-fullscreen .ni-section { background: transparent !important; }
.ni-fullscreen .ni-section--latest { background: #f8f8f8 !important; padding: 32px 0 !important; }
.ni-fullscreen .ni-section--rails { background: transparent !important; }
.ni-fullscreen .ni-section--news { background: #f8f8f8 !important; padding: 32px 0 !important; }

/* ── USP STRIP double-override ── */
.ni-fullscreen .ni-usps { background: #000 !important; border-top: 1px solid #1a1a1a !important; border-bottom: 1px solid #1a1a1a !important; padding: 28px 0 !important; }
.ni-fullscreen .ni-usp i { color: #FFD700 !important; font-size: 24px !important; }
.ni-fullscreen .ni-usp strong { color: #fff !important; font-size: 14px !important; }
.ni-fullscreen .ni-usp span { color: #777 !important; font-size: 12px !important; }
