/* ==========================================================================
   آنی چتر — Frontend Stylesheet (light theme, RTL, self-contained)
   Developer: SITEKA
   Design tokens are injected from PHP via :root (see Siteka_Helpers::css_vars).
   No external font/CDN/script is loaded. Spacing follows a 4/8 px scale.
   ========================================================================== */

/* ---------- 0. Base reset ---------- */
.siteka-wrap, .siteka-wrap *,
.siteka-wrap *::before, .siteka-wrap *::after {
    box-sizing: border-box;
}
.siteka-wrap {
    direction: rtl;
    font-family: var(--sk-font, "Vazirmatn", Tahoma, sans-serif);
    font-size: var(--sk-font-size, 16px);
    color: var(--sk-text, #0f172a);
    line-height: 1.7;
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--sk-s-5) var(--sk-s-4) var(--sk-s-7);
    text-align: right;
}
.siteka-wrap img { max-width: 100%; height: auto; display: block; }
.siteka-wrap h1, .siteka-wrap h2, .siteka-wrap h3, .siteka-wrap h4 {
    font-family: inherit; color: var(--sk-text); margin: 0 0 var(--sk-s-3);
    font-weight: 700; line-height: 1.4;
}
.siteka-wrap h1 { font-size: calc(var(--sk-fs-title, 22px) + 6px); }
.siteka-wrap h2 { font-size: var(--sk-fs-title, 22px); }
.siteka-wrap h3 { font-size: calc(var(--sk-fs-title, 22px) - 4px); }
.siteka-wrap h4 { font-size: calc(var(--sk-fs-title, 22px) - 6px); }
.siteka-wrap p  { margin: 0 0 var(--sk-s-3); }
.siteka-wrap a  { color: var(--sk-primary); text-decoration: none; transition: color .15s; }
.siteka-wrap a:hover { color: var(--sk-secondary); }
.siteka-wrap ul { list-style: none; padding: 0; margin: 0; }

/* ---------- 1. Utilities ---------- */
.sk-muted   { color: var(--sk-muted); font-size: .92em; }
.sk-center  { text-align: center; display: block; margin-top: var(--sk-s-4); }
.sk-link    { color: var(--sk-primary); font-weight: 600; }
.sk-link:hover { color: var(--sk-secondary); }
.sk-page-title { font-size: calc(var(--sk-fs-title, 22px) + 4px); margin-bottom: var(--sk-s-5); padding-bottom: var(--sk-s-3); border-bottom: 2px solid var(--sk-border); }
.sk-empty {
    background: var(--sk-surface); border: 1px dashed var(--sk-border);
    padding: var(--sk-s-6) var(--sk-s-5); border-radius: var(--sk-radius);
    text-align: center; color: var(--sk-muted);
}
.sk-no-scroll { overflow: hidden; }

/* ---------- 2. Buttons ---------- */
.sk-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: var(--sk-s-2);
    padding: 11px 22px;
    border: 0; border-radius: 12px;
    font-family: inherit; font-size: var(--sk-fs-text, 15px); font-weight: 600;
    color: #fff; background: var(--sk-primary);
    cursor: pointer; user-select: none;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, opacity .15s ease;
    text-decoration: none; line-height: 1;
}
.sk-btn:hover { transform: translateY(-1px); color: #fff; }
.sk-btn:active { transform: translateY(0); }
.sk-btn:disabled { opacity: .55; cursor: not-allowed; transform: none; }
.sk-btn:focus-visible { outline: 3px solid var(--sk-primary-strong); outline-offset: 2px; }
.sk-btn-glow {
    background: linear-gradient(135deg, var(--sk-primary), var(--sk-secondary));
    box-shadow: 0 6px 18px var(--sk-primary-strong);
}
.sk-btn-glow:hover  { box-shadow: 0 10px 24px var(--sk-primary-strong); color: #fff; }
.sk-btn-ghost,
.sk-btn-outline {
    background: var(--sk-surface); color: var(--sk-primary);
    border: 1.5px solid var(--sk-primary);
}
.sk-btn-ghost:hover,
.sk-btn-outline:hover { background: var(--sk-primary); color: #fff; }
.sk-btn-block { width: 100%; }
.sk-btn-sm { padding: 8px 14px; font-size: calc(var(--sk-fs-text, 15px) - 1px); }

/* ---------- 3. Surfaces ---------- */
.glass, .sk-card {
    background: var(--sk-surface);
    border: 1px solid var(--sk-border);
    border-radius: var(--sk-radius);
    box-shadow: var(--sk-shadow);
    padding: var(--sk-s-5);
}

/* ---------- 4. Section heads ---------- */
.sk-section { margin: var(--sk-s-6) 0; }
.sk-section-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: var(--sk-s-4); gap: var(--sk-s-3); flex-wrap: wrap;
}
.sk-section-head h2 {
    margin: 0; position: relative; padding-right: 14px;
    font-size: var(--sk-fs-title, 22px);
}
.sk-section-head h2::before {
    content: ''; position: absolute; right: 0; top: 6px;
    width: 5px; height: 22px; border-radius: 4px;
    background: linear-gradient(180deg, var(--sk-primary), var(--sk-secondary));
}

/* ==========================================================================
   HOME — hero
   ========================================================================== */

.sk-hero { margin-bottom: var(--sk-s-6); border-radius: var(--sk-radius-lg); overflow: hidden; box-shadow: var(--sk-shadow); }
.sk-hero-slider { position: relative; height: 380px; overflow: hidden; border-radius: var(--sk-radius-lg); }
.sk-slide { position: absolute; inset: 0; opacity: 0; transition: opacity .6s ease; pointer-events: none; }
.sk-slide.is-active { opacity: 1; pointer-events: auto; }
.sk-slide-bg { position: absolute; inset: 0; }
.sk-slide-bg::after {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse at top right, rgba(255,255,255,.18), transparent 60%);
}
.sk-slide-content {
    position: absolute; inset: 0;
    display: flex; flex-direction: column; align-items: flex-start; justify-content: center;
    padding: var(--sk-s-6) calc(var(--sk-s-7) + var(--sk-s-2));
    color: #fff; max-width: 600px;
}
.sk-slide-content .sk-eyebrow {
    display: inline-block;
    background: rgba(255,255,255,.22);
    padding: 6px 14px; border-radius: 999px; font-size: calc(var(--sk-fs-text, 15px) - 2px);
    margin-bottom: var(--sk-s-3);
}
.sk-slide-content h1 {
    color: #fff; font-size: calc(var(--sk-fs-title, 22px) + 14px); margin: 0 0 var(--sk-s-3);
    text-shadow: 0 2px 12px rgba(0,0,0,.22);
}
.sk-slide-content p { color: rgba(255,255,255,.94); font-size: var(--sk-fs-text, 15px); margin-bottom: var(--sk-s-5); }
.sk-slide-content .sk-btn { background: #fff; color: var(--sk-text); }
.sk-slide-content .sk-btn:hover { background: #f3f4f6; color: var(--sk-text); }

.sk-slide-dots {
    position: absolute; bottom: var(--sk-s-4); left: 50%; transform: translateX(-50%);
    display: flex; gap: var(--sk-s-2); z-index: 5;
}
.sk-slide-dots span {
    display: inline-block;
    width: 10px; height: 10px; border-radius: 50%;
    background: rgba(255,255,255,.55); border: 0; cursor: pointer; padding: 0;
    transition: all .25s;
}
.sk-slide-dots span.is-active { width: 28px; border-radius: 8px; background: #fff; }
.sk-slide-arrow {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 42px; height: 42px; border-radius: 50%;
    background: rgba(255,255,255,.9); color: var(--sk-text); border: 0;
    font-size: 1.6rem; cursor: pointer; z-index: 5;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
}
.sk-slide-arrow.sk-prev { right: var(--sk-s-4); }
.sk-slide-arrow.sk-next { left:  var(--sk-s-4); }

/* ==========================================================================
   HOME — infinite category marquee (replaces the old grid rail)
   The PHP renders the list twice; the track translates by exactly half its
   width then snaps back, producing a seamless infinite loop.
   ========================================================================== */

.sk-cat-marquee {
    position: relative;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to left, transparent 0, #000 8%, #000 92%, transparent 100%);
            mask-image: linear-gradient(to left, transparent 0, #000 8%, #000 92%, transparent 100%);
    padding: var(--sk-s-2) 0;
}
.sk-cat-track {
    display: flex; gap: var(--sk-s-3);
    width: max-content;
    animation: sk-cat-scroll var(--sk-marquee-duration, 40s) linear infinite;
}
.sk-cat-marquee:hover .sk-cat-track,
.sk-cat-marquee.is-paused-offscreen .sk-cat-track { animation-play-state: paused; }
@keyframes sk-cat-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(50%); } /* RTL: scrolls visually leftward */
}
@media (prefers-reduced-motion: reduce) {
    .sk-cat-track { animation: none; transform: none; }
    .sk-cat-marquee { overflow-x: auto; }
}

.sk-cat-card {
    flex: 0 0 auto;
    width: 140px;
    display: flex; flex-direction: column; align-items: center; gap: var(--sk-s-2);
    padding: var(--sk-s-4) var(--sk-s-3);
    background: var(--sk-surface); border: 1px solid var(--sk-border); border-radius: var(--sk-radius);
    color: var(--sk-text); text-decoration: none;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.sk-cat-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--sk-shadow);
    color: var(--sk-text);
    border-color: var(--sk-primary-strong);
}
.sk-cat-img {
    width: 64px; height: 64px; border-radius: 50%;
    background: linear-gradient(135deg, var(--sk-primary-soft), var(--sk-surface-2)) center/cover no-repeat;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; font-weight: 700; color: var(--sk-primary);
}
.sk-cat-name  { font-weight: 600; font-size: var(--sk-fs-text, 15px); text-align: center; }
.sk-cat-count { font-size: calc(var(--sk-fs-text, 15px) - 3px); color: var(--sk-muted); }

/* ==========================================================================
   PRODUCT RAIL & CARDS (whole card is one anchor — no inline buttons)
   ========================================================================== */

.sk-product-rail {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sk-s-4);
}

.sk-product-card {
    display: flex; flex-direction: column;
    background: var(--sk-surface);
    border: 1px solid var(--sk-border);
    border-radius: var(--sk-radius);
    overflow: hidden;
    color: var(--sk-text);
    text-decoration: none;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    position: relative;
}
.sk-product-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 14px 32px -16px var(--sk-primary-strong), 0 4px 12px -6px rgba(15, 23, 42, .08);
    border-color: var(--sk-primary-strong);
    color: var(--sk-text);
}
.sk-product-card:focus-visible {
    outline: 3px solid var(--sk-primary-strong); outline-offset: 2px;
}
.sk-card-img {
    aspect-ratio: 1 / 1;
    background: var(--sk-surface-2);
    overflow: hidden;
    position: relative;
}
.sk-card-img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .45s ease;
}
.sk-product-card:hover .sk-card-img img { transform: scale(1.06); }
.sk-card-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(15,23,42,.55) 0%, rgba(15,23,42,0) 60%);
    display: flex; align-items: flex-end; justify-content: center;
    padding: var(--sk-s-3);
    opacity: 0; transition: opacity .25s;
    pointer-events: none;
}
.sk-card-overlay span {
    color: #fff; font-size: calc(var(--sk-fs-text, 15px) - 2px); font-weight: 600;
    background: rgba(255,255,255,.18);
    padding: 8px 16px; border-radius: 999px;
    border: 1px solid rgba(255,255,255,.3);
}
.sk-product-card:hover .sk-card-overlay { opacity: 1; }

.sk-card-badge {
    position: absolute; top: 10px; right: 10px;
    background: var(--sk-danger); color: #fff;
    padding: 4px 10px; border-radius: 999px;
    font-size: calc(var(--sk-fs-text, 15px) - 4px); font-weight: 700;
    box-shadow: 0 4px 10px -2px rgba(220, 38, 38, .35);
    z-index: 2;
}
.sk-badge-discount { background: linear-gradient(135deg, #ef4444, #f97316); }
.sk-badge-out      { background: var(--sk-muted); }
.sk-product-card.is-out .sk-card-img img { filter: grayscale(.6) opacity(.7); }

.sk-card-body { padding: var(--sk-s-3) var(--sk-s-3) var(--sk-s-4); display: flex; flex-direction: column; gap: 6px; flex: 1; }
.sk-card-cat  { font-size: calc(var(--sk-fs-text, 15px) - 4px); color: var(--sk-muted); letter-spacing: .3px; }
.sk-card-title {
    font-size: var(--sk-fs-text, 15px); font-weight: 600; line-height: 1.5;
    overflow: hidden; text-overflow: ellipsis;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    min-height: 2.85em; color: var(--sk-text);
}
.sk-card-rate, .sk-card-rate-empty { display: flex; align-items: center; gap: 6px; min-height: 1.1rem; }
.sk-card-stars { display: inline-flex; gap: 1px; color: var(--sk-border); font-size: .9rem; line-height: 1; }
.sk-card-stars .is-on { color: #facc15; }
.sk-card-rate small { color: var(--sk-muted); font-size: calc(var(--sk-fs-text, 15px) - 4px); }
.sk-card-price {
    margin-top: auto;
    color: var(--sk-text); font-weight: 700; font-size: var(--sk-fs-price, 18px);
    display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
}
.sk-card-price ins { text-decoration: none; color: var(--sk-primary); }
.sk-card-price del { color: var(--sk-muted); font-weight: 400; font-size: .82em; }
.sk-card-price bdi { color: inherit; }

/* Skeleton loaders */
.sk-skeleton-card {
    background: var(--sk-surface-2); border-radius: var(--sk-radius);
    aspect-ratio: 3 / 4;
    overflow: hidden; position: relative;
    border: 1px solid var(--sk-border);
}
.sk-shimmer {
    position: absolute; inset: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.7) 50%, transparent 100%);
    animation: sk-shimmer 1.4s infinite;
}
@keyframes sk-shimmer { from { transform: translateX(100%); } to { transform: translateX(-100%); } }

/* Features strip */
.sk-features {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sk-s-4);
    margin-top: var(--sk-s-6);
}
.sk-feature {
    background: var(--sk-surface); border-radius: var(--sk-radius);
    padding: var(--sk-s-5); text-align: center;
    border: 1px solid var(--sk-border);
    transition: transform .2s, box-shadow .2s;
}
.sk-feature:hover { transform: translateY(-3px); box-shadow: var(--sk-shadow); }
.sk-feature-icon {
    width: 56px; height: 56px; border-radius: 16px; margin: 0 auto var(--sk-s-3);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem;
    background: linear-gradient(135deg, var(--sk-primary-soft), var(--sk-surface-2));
    color: var(--sk-primary);
}
.sk-feature h3 { font-size: var(--sk-fs-text, 15px); margin-bottom: 6px; }
.sk-feature p  { font-size: calc(var(--sk-fs-text, 15px) - 2px); color: var(--sk-muted); margin: 0; }

/* ==========================================================================
   SHOP PAGE
   ========================================================================== */

.sk-shop-head {
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--sk-s-3); margin-bottom: var(--sk-s-5); flex-wrap: wrap;
}
.sk-shop-head h1 { margin: 0; }
.sk-shop-tools { display: flex; gap: var(--sk-s-3); align-items: center; flex-wrap: wrap; }
.sk-search { position: relative; }
.sk-search input {
    background: var(--sk-surface); border: 1px solid var(--sk-border); color: var(--sk-text);
    border-radius: 12px; padding: 9px 38px 9px 14px;
    font-family: inherit; font-size: calc(var(--sk-fs-text, 15px) - 1px); width: 240px;
    transition: border-color .15s, box-shadow .15s;
}
.sk-search input:focus {
    outline: 0; border-color: var(--sk-primary);
    box-shadow: 0 0 0 3px var(--sk-primary-soft);
}
.sk-search span { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--sk-muted); }
.sk-select {
    background: var(--sk-surface); border: 1px solid var(--sk-border); color: var(--sk-text);
    padding: 9px 14px; border-radius: 12px; font-family: inherit; font-size: calc(var(--sk-fs-text, 15px) - 1px);
    cursor: pointer;
}
.sk-mobile-filter { display: none; }

.sk-shop-layout {
    display: grid; grid-template-columns: 260px 1fr; gap: var(--sk-s-5);
    align-items: start;
}
.sk-filters {
    background: var(--sk-surface); border: 1px solid var(--sk-border); border-radius: var(--sk-radius);
    padding: var(--sk-s-5); position: sticky; top: 80px;
    box-shadow: var(--sk-shadow);
}
.sk-filter-block { margin-bottom: var(--sk-s-5); }
.sk-filter-block h4 { font-size: var(--sk-fs-text, 15px); margin-bottom: var(--sk-s-3); padding-bottom: var(--sk-s-2); border-bottom: 1px solid var(--sk-border); }
.sk-price-range input[type="range"] {
    width: 100%; -webkit-appearance: none; appearance: none;
    height: 4px; border-radius: 4px; background: var(--sk-border);
    margin: 8px 0;
}
.sk-price-range input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--sk-primary); cursor: pointer; border: 2px solid var(--sk-surface);
    box-shadow: 0 2px 6px rgba(0,0,0,.18);
}
.sk-price-vals { display: flex; justify-content: space-between; font-size: calc(var(--sk-fs-text, 15px) - 2px); color: var(--sk-muted); }

.sk-cat-list li { margin-bottom: 6px; }
.sk-cat-list label {
    display: flex; align-items: center; gap: var(--sk-s-2); cursor: pointer;
    padding: 7px 10px; border-radius: 8px; font-size: calc(var(--sk-fs-text, 15px) - 1px);
    transition: background .15s;
}
.sk-cat-list label:hover { background: var(--sk-surface-2); }

.sk-shop-main { min-width: 0; }
.sk-result-count { color: var(--sk-muted); font-size: calc(var(--sk-fs-text, 15px) - 1px); margin-bottom: var(--sk-s-3); }
.sk-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--sk-s-4);
}
.sk-load-more { text-align: center; margin-top: var(--sk-s-6); }
.sk-end-msg   { color: var(--sk-muted); font-size: calc(var(--sk-fs-text, 15px) - 1px); padding: var(--sk-s-3); text-align: center; }

/* ==========================================================================
   PRODUCT PAGE
   ========================================================================== */

.sk-prod-grid {
    display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: var(--sk-s-6); margin-bottom: var(--sk-s-6);
    background: var(--sk-surface); border-radius: var(--sk-radius);
    border: 1px solid var(--sk-border); padding: var(--sk-s-5);
    box-shadow: var(--sk-shadow);
}
.sk-gallery { display: flex; flex-direction: column; gap: var(--sk-s-3); }
.sk-gallery-main {
    aspect-ratio: 1 / 1; background: var(--sk-surface-2);
    border-radius: var(--sk-radius); overflow: hidden; position: relative;
}
.sk-gallery-slide { position: absolute; inset: 0; opacity: 0; transition: opacity .35s; }
.sk-gallery-slide.is-active { opacity: 1; }
.sk-gallery-slide img { width: 100%; height: 100%; object-fit: cover; }
.sk-gallery-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.sk-thumb {
    aspect-ratio: 1 / 1; background: var(--sk-surface-2);
    border: 2px solid transparent; border-radius: 10px; padding: 0;
    overflow: hidden; cursor: pointer;
    transition: border-color .15s;
}
.sk-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sk-thumb.is-active { border-color: var(--sk-primary); }

.sk-prod-info  { display: flex; flex-direction: column; gap: var(--sk-s-3); }
.sk-prod-cat   { font-size: calc(var(--sk-fs-text, 15px) - 2px); color: var(--sk-muted); }
.sk-prod-title { font-size: calc(var(--sk-fs-title, 22px) + 4px); margin: 0; }
.sk-prod-meta  { display: flex; align-items: center; gap: var(--sk-s-3); flex-wrap: wrap; }
.sk-stars { color: var(--sk-accent); font-size: .95rem; display: inline-flex; align-items: center; gap: 2px; }
.sk-stars span { color: var(--sk-border); }
.sk-stars span.is-on { color: var(--sk-accent); }
.sk-stars small { color: var(--sk-muted); margin-right: 6px; }
.sk-stock { font-size: calc(var(--sk-fs-text, 15px) - 2px); padding: 4px 10px; border-radius: 999px; font-weight: 600; }
.sk-stock.in  { background: #ecfdf5; color: var(--sk-success); }
.sk-stock.out { background: #fef2f2; color: var(--sk-danger); }
.sk-prod-price {
    font-size: calc(var(--sk-fs-price, 18px) + 6px); font-weight: 700; color: var(--sk-primary);
    padding: var(--sk-s-3) 0; border-top: 1px dashed var(--sk-border); border-bottom: 1px dashed var(--sk-border);
    transition: transform .25s ease;
}
.sk-prod-price.bump { animation: sk-bump .35s ease; }
@keyframes sk-bump { 0%{transform:scale(1);} 50%{transform:scale(1.05);} 100%{transform:scale(1);} }
.sk-prod-price del { color: var(--sk-muted); font-weight: 400; font-size: 1rem; margin-left: 8px; }
.sk-prod-short { color: var(--sk-muted); font-size: var(--sk-fs-text, 15px); }

.sk-variations { display: flex; flex-direction: column; gap: var(--sk-s-3); }
.sk-variation label { display:block; font-weight:600; margin-bottom: var(--sk-s-2); font-size: var(--sk-fs-text, 15px); }
.sk-variation-options { display: flex; flex-wrap: wrap; gap: var(--sk-s-2); }
.sk-vopt {
    background: var(--sk-surface); border: 1px solid var(--sk-border); color: var(--sk-text);
    padding: 8px 16px; border-radius: 10px; font-family: inherit;
    cursor: pointer; transition: all .15s;
}
.sk-vopt:hover, .sk-vopt.is-active {
    border-color: var(--sk-primary); background: var(--sk-primary-soft); color: var(--sk-primary);
}

.sk-buybar { display: flex; align-items: center; gap: var(--sk-s-3); margin-top: var(--sk-s-2); }
.sk-qty {
    display: flex; align-items: center; background: var(--sk-surface); border: 1px solid var(--sk-border);
    border-radius: 10px; overflow: hidden;
}
.sk-qty button {
    background: transparent; border: 0; color: var(--sk-text);
    width: 38px; height: 42px; cursor: pointer; font-size: 1.2rem;
    transition: background .15s;
}
.sk-qty button:hover { background: var(--sk-surface-2); }
.sk-qty input {
    width: 50px; text-align: center;
    border: 0; border-right: 1px solid var(--sk-border); border-left: 1px solid var(--sk-border);
    background: transparent; color: var(--sk-text); font-family: inherit; height: 42px;
    -moz-appearance: textfield;
}
.sk-qty input::-webkit-outer-spin-button, .sk-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sk-add-cart { flex: 1; height: 44px; }

/* Tabs */
.sk-tabs {
    background: var(--sk-surface); border-radius: var(--sk-radius);
    border: 1px solid var(--sk-border); box-shadow: var(--sk-shadow);
    margin-bottom: var(--sk-s-6); overflow: hidden;
}
.sk-tab-bar { display: flex; border-bottom: 1px solid var(--sk-border); background: var(--sk-surface-2); }
.sk-tab {
    background: transparent; border: 0; color: var(--sk-muted);
    padding: 14px 22px; cursor: pointer; font-family: inherit;
    font-weight: 600; font-size: var(--sk-fs-text, 15px);
    border-bottom: 3px solid transparent;
    transition: all .15s;
}
.sk-tab:hover { color: var(--sk-text); }
.sk-tab.is-active { color: var(--sk-primary); border-bottom-color: var(--sk-primary); background: var(--sk-surface); }
.sk-tab-pane { display: none; padding: var(--sk-s-5); }
.sk-tab-pane.is-active { display: block; }
.sk-info-table { width: 100%; border-collapse: collapse; }
.sk-info-table th, .sk-info-table td { padding: 12px; text-align: right; border-bottom: 1px solid var(--sk-border); }
.sk-info-table th { color: var(--sk-muted); font-weight: 600; width: 30%; }

/* Reviews */
.sk-review-item {
    padding: var(--sk-s-3); border: 1px solid var(--sk-border);
    border-radius: 12px; margin-bottom: 10px;
}
.sk-review-head { display: flex; align-items: center; gap: var(--sk-s-3); margin-bottom: 6px; }
.sk-review-form { margin-top: var(--sk-s-5); padding-top: var(--sk-s-5); border-top: 1px dashed var(--sk-border); }
.sk-review-form h4 { margin-bottom: var(--sk-s-3); }
.sk-rate-pick { display: inline-flex; gap: 4px; font-size: 1.4rem; cursor: pointer; margin-bottom: var(--sk-s-3); }
.sk-rate-pick span { color: var(--sk-border); transition: color .1s; }
.sk-rate-pick span.is-on, .sk-rate-pick span:hover, .sk-rate-pick span:hover ~ span { color: var(--sk-accent); }
.sk-review-form textarea {
    width: 100%; min-height: 100px; padding: 12px;
    background: var(--sk-surface); border: 1px solid var(--sk-border); border-radius: 10px;
    color: var(--sk-text); font-family: inherit; resize: vertical;
}
.sk-review-form textarea:focus { outline: 0; border-color: var(--sk-primary); }

/* Sticky buy bar */
.sk-sticky-buy {
    position: fixed; bottom: var(--sk-s-4); right: var(--sk-s-4); left: var(--sk-s-4);
    background: rgba(255,255,255,.96);
    border: 1px solid var(--sk-border);
    box-shadow: 0 -8px 32px rgba(17,24,39,.12), 0 4px 18px rgba(17,24,39,.06);
    padding: var(--sk-s-3) var(--sk-s-4); border-radius: 18px;
    display: flex; align-items: center; justify-content: space-between; gap: var(--sk-s-3);
    z-index: 100;
    max-width: 720px; margin: 0 auto;
    animation: sk-sticky-up .35s cubic-bezier(.4,0,.2,1);
}
@keyframes sk-sticky-up { from { transform: translateY(120%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.sk-sticky-info { display: flex; align-items: center; gap: var(--sk-s-3); min-width: 0; flex: 1; }
.sk-sticky-thumb { width: 48px; height: 48px; border-radius: 12px; object-fit: cover; background: var(--sk-surface-2); flex-shrink: 0; }
.sk-sticky-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.sk-sticky-price { font-weight: 700; color: var(--sk-primary); font-size: var(--sk-fs-price, 18px); line-height: 1.2; }
.sk-sticky-price del { color: var(--sk-muted); font-weight: 400; font-size: .8em; margin-inline-start: 6px; }
.sk-sticky-stock { font-size: calc(var(--sk-fs-text, 15px) - 3px); font-weight: 600; }
.sk-sticky-stock.in  { color: var(--sk-success); }
.sk-sticky-stock.out { color: var(--sk-danger); }
.sk-sticky-cta { flex-shrink: 0; }
@media (max-width: 540px) {
    .sk-sticky-buy { padding: 10px 12px; gap: 10px; }
    .sk-sticky-thumb { width: 42px; height: 42px; }
    .sk-sticky-price { font-size: 1rem; }
    .sk-sticky-cta { padding: 10px 14px; font-size: calc(var(--sk-fs-text, 15px) - 2px); }
}

/* ==========================================================================
   CART PAGE
   ========================================================================== */

.sk-cart-layout {
    display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
    gap: var(--sk-s-5); align-items: start;
}
.sk-cart-items {
    background: var(--sk-surface); border: 1px solid var(--sk-border); border-radius: var(--sk-radius);
    padding: var(--sk-s-4); box-shadow: var(--sk-shadow);
    display: flex; flex-direction: column; gap: var(--sk-s-3);
}
.sk-cart-item {
    display: grid; grid-template-columns: 80px 1fr auto; gap: var(--sk-s-3);
    align-items: center; padding: var(--sk-s-3);
    background: var(--sk-surface); border: 1px solid var(--sk-border); border-radius: 12px;
    transition: opacity .25s ease, transform .25s ease;
}
.sk-cart-item.removing { opacity: 0; transform: translateX(20px); }
.sk-cart-item-img { width: 80px; height: 80px; border-radius: 10px; overflow: hidden; background: var(--sk-surface-2); }
.sk-cart-item-img img { width: 100%; height: 100%; object-fit: cover; }
.sk-cart-item-meta { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.sk-cart-item-title { font-weight: 600; font-size: var(--sk-fs-text, 15px); color: var(--sk-text); text-decoration: none; }
.sk-cart-item-price { color: var(--sk-primary); font-weight: 700; font-size: var(--sk-fs-text, 15px); }
.sk-cart-item-line  { font-size: calc(var(--sk-fs-text, 15px) - 2px); }
.sk-cart-item-actions { display: flex; align-items: center; gap: 10px; }
.sk-rm-item {
    width: 32px; height: 32px; border-radius: 50%;
    background: #fef2f2; color: var(--sk-danger); border: 0;
    cursor: pointer; font-size: 1.1rem;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .15s;
}
.sk-rm-item:hover { background: #fee2e2; }

.sk-cart-summary { position: sticky; top: 80px; }
.sk-cart-summary h3 { margin-top: 0; padding-bottom: var(--sk-s-3); border-bottom: 1px solid var(--sk-border); }
.sk-summary-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 0; color: var(--sk-text); font-size: var(--sk-fs-text, 15px);
}
.sk-coupon { display: flex; gap: var(--sk-s-2); margin: var(--sk-s-3) 0; }
.sk-coupon input {
    flex: 1; padding: 9px 12px; background: var(--sk-surface);
    border: 1px solid var(--sk-border); border-radius: 10px;
    color: var(--sk-text); font-family: inherit; font-size: var(--sk-fs-text, 15px);
}
.sk-coupon input:focus { outline: 0; border-color: var(--sk-primary); box-shadow: 0 0 0 3px var(--sk-primary-soft); }
.sk-summary-total {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--sk-s-3) 0; margin: var(--sk-s-3) 0;
    border-top: 2px solid var(--sk-border); border-bottom: 2px solid var(--sk-border);
    font-size: var(--sk-fs-text, 15px);
}
.sk-summary-total strong { color: var(--sk-primary); font-size: var(--sk-fs-price, 18px); }

/* ==========================================================================
   CHECKOUT PAGE
   ========================================================================== */

.sk-checkout-grid {
    display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
    gap: var(--sk-s-5); align-items: start;
}
.sk-checkout-form { display: flex; flex-direction: column; gap: var(--sk-s-4); }
.sk-step-indicator {
    display: flex; gap: var(--sk-s-3); padding: var(--sk-s-3) 0; margin-bottom: var(--sk-s-2);
    border-bottom: 1px solid var(--sk-border);
}
.sk-step {
    display: flex; align-items: center; gap: var(--sk-s-2);
    color: var(--sk-muted); font-size: calc(var(--sk-fs-text, 15px) - 1px); font-weight: 600;
}
.sk-step span {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--sk-surface-2); color: var(--sk-muted);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: calc(var(--sk-fs-text, 15px) - 2px);
}
.sk-step.is-active { color: var(--sk-text); }
.sk-step.is-active span {
    background: linear-gradient(135deg, var(--sk-primary), var(--sk-secondary));
    color: #fff;
}

.sk-fieldset { border: 0; padding: 0; margin: 0; }
.sk-fieldset legend {
    font-weight: 700; color: var(--sk-text); padding: 0 0 var(--sk-s-3);
    font-size: var(--sk-fs-text, 15px);
}
.sk-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sk-s-3); margin-bottom: var(--sk-s-3); }
.sk-row:has(.sk-input:nth-child(3)) { grid-template-columns: repeat(3, 1fr); }

.sk-input { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--sk-s-3); }
.sk-input label { font-size: calc(var(--sk-fs-text, 15px) - 2px); font-weight: 600; color: var(--sk-text); }
.sk-input small { font-size: calc(var(--sk-fs-text, 15px) - 4px); color: var(--sk-muted); }
.sk-input input, .sk-input textarea, .sk-input select {
    padding: 11px 14px;
    background: var(--sk-surface); border: 1px solid var(--sk-border);
    border-radius: 10px;
    color: var(--sk-text); font-family: inherit; font-size: var(--sk-fs-text, 15px);
    transition: border-color .15s, box-shadow .15s;
}
.sk-input input:focus, .sk-input textarea:focus, .sk-input select:focus {
    outline: 0; border-color: var(--sk-primary);
    box-shadow: 0 0 0 3px var(--sk-primary-soft);
}
.sk-input input:invalid:not(:placeholder-shown) { border-color: var(--sk-danger); }
.sk-input textarea { min-height: 84px; resize: vertical; }
.sk-check {
    display: inline-flex; align-items: center; gap: var(--sk-s-2); cursor: pointer;
    color: var(--sk-text); font-size: calc(var(--sk-fs-text, 15px) - 1px);
}

/* Payment-method picker (radio cards) */
.sk-payment-methods { display: flex; flex-direction: column; gap: var(--sk-s-2); }
.sk-payment-option {
    display: flex; align-items: flex-start; gap: var(--sk-s-3);
    padding: var(--sk-s-3) var(--sk-s-4);
    border: 1.5px solid var(--sk-border); border-radius: 12px;
    background: var(--sk-surface); cursor: pointer;
    transition: border-color .15s, box-shadow .15s, background .15s;
}
.sk-payment-option:hover { border-color: var(--sk-primary-strong); }
.sk-payment-option input[type="radio"] {
    position: absolute; opacity: 0; pointer-events: none;
}
.sk-payment-radio {
    flex-shrink: 0;
    width: 20px; height: 20px; border-radius: 50%;
    border: 2px solid var(--sk-border);
    margin-top: 3px;
    display: inline-flex; align-items: center; justify-content: center;
    transition: border-color .15s;
}
.sk-payment-radio::after {
    content: ''; width: 10px; height: 10px; border-radius: 50%;
    background: var(--sk-primary); transform: scale(0); transition: transform .15s;
}
.sk-payment-option.is-checked { border-color: var(--sk-primary); background: var(--sk-primary-soft); box-shadow: 0 0 0 3px var(--sk-primary-soft); }
.sk-payment-option.is-checked .sk-payment-radio { border-color: var(--sk-primary); }
.sk-payment-option.is-checked .sk-payment-radio::after { transform: scale(1); }
.sk-payment-meta { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.sk-payment-title { font-weight: 700; font-size: var(--sk-fs-text, 15px); color: var(--sk-text); }
.sk-payment-desc  { color: var(--sk-muted); font-size: calc(var(--sk-fs-text, 15px) - 2px); line-height: 1.6; }
.sk-payment-desc p { margin: 0; }

.sk-checkout-summary { position: sticky; top: 80px; }
.sk-checkout-summary h3 { margin-top: 0; padding-bottom: var(--sk-s-3); border-bottom: 1px solid var(--sk-border); }
.sk-mini-cart {
    max-height: 320px; overflow-y: auto; margin-bottom: var(--sk-s-3);
    padding: 4px;
    display: flex; flex-direction: column; gap: 4px;
}
.sk-mini-item {
    display: grid; grid-template-columns: 56px minmax(0, 1fr) auto;
    gap: var(--sk-s-3); align-items: center;
    padding: 10px; border-radius: 12px;
    background: var(--sk-surface-2); border: 1px solid var(--sk-border);
    transition: background .15s;
}
.sk-mini-thumb { position: relative; width: 56px; height: 56px; border-radius: 10px; overflow: hidden; background: var(--sk-surface); }
.sk-mini-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sk-mini-qty {
    position: absolute; top: -6px; right: -6px;
    background: var(--sk-primary); color: #fff;
    width: 22px; height: 22px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: calc(var(--sk-fs-text, 15px) - 4px); font-weight: 700;
    border: 2px solid var(--sk-surface);
    box-shadow: 0 2px 6px var(--sk-primary-strong);
}
.sk-mini-meta  { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.sk-mini-title {
    font-weight: 600; font-size: calc(var(--sk-fs-text, 15px) - 2px); color: var(--sk-text);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    line-height: 1.4;
}
.sk-mini-price { font-size: calc(var(--sk-fs-text, 15px) - 4px); color: var(--sk-muted); }
.sk-mini-line  { font-weight: 700; font-size: calc(var(--sk-fs-text, 15px) - 1px); color: var(--sk-primary); white-space: nowrap; }

/* ==========================================================================
   MODAL — generic + add-to-cart success card
   ========================================================================== */

.sk-modal {
    position: fixed; inset: 0;
    display: flex; align-items: center; justify-content: center;
    z-index: 1000; padding: var(--sk-s-5);
    animation: sk-fade .25s;
}
@keyframes sk-fade { from { opacity: 0; } to { opacity: 1; } }
.sk-modal[hidden] { display: none; }
.sk-modal-backdrop { position: absolute; inset: 0; background: rgba(15,23,42,.55); }
.sk-modal-card {
    position: relative; max-width: 460px; width: 100%; text-align: center;
    padding: var(--sk-s-7) var(--sk-s-5) var(--sk-s-5);
    background: var(--sk-surface); border-radius: var(--sk-radius-lg);
    animation: sk-pop .35s cubic-bezier(.18,.89,.32,1.28);
    box-shadow: 0 30px 60px rgba(15,23,42,.3);
    z-index: 1;
}
@keyframes sk-pop { from { transform: scale(.85); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.sk-modal-close {
    position: absolute; top: 12px; left: 12px;
    width: 36px; height: 36px; border-radius: 50%;
    border: 0; background: var(--sk-surface-2); color: var(--sk-text);
    font-size: 1.4rem; line-height: 1; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .15s;
}
.sk-modal-close:hover { background: var(--sk-border); }
.sk-success-anim { margin-bottom: var(--sk-s-3); display: flex; justify-content: center; }

/* Add-to-cart card (replaces the inline quick-add button) */
.sk-modal-add.is-leaving { opacity: 0; transition: opacity .2s; }
.sk-modal-add .sk-modal-card { padding-top: var(--sk-s-6); }
.sk-added-icon { display: flex; justify-content: center; margin-bottom: var(--sk-s-3); }
.sk-added-headline {
    font-size: var(--sk-fs-title, 22px); font-weight: 700;
    color: var(--sk-text); margin: 0 0 var(--sk-s-3);
}
.sk-added-product {
    display: flex; align-items: center; gap: var(--sk-s-3);
    background: var(--sk-surface-2);
    padding: var(--sk-s-3); border-radius: 12px;
    margin: 0 0 var(--sk-s-4);
    text-align: right;
}
.sk-added-thumb { width: 64px; height: 64px; border-radius: 10px; object-fit: cover; background: var(--sk-surface); flex-shrink: 0; }
.sk-added-meta  { display: flex; flex-direction: column; gap: 4px; min-width: 0; flex: 1; }
.sk-added-title {
    font-weight: 600; font-size: var(--sk-fs-text, 15px); color: var(--sk-text);
    line-height: 1.5;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
}
.sk-added-price { color: var(--sk-primary); font-weight: 700; font-size: var(--sk-fs-text, 15px); }
.sk-added-actions {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--sk-s-2);
    margin-bottom: var(--sk-s-3);
}
.sk-added-actions .sk-btn { width: 100%; }
.sk-added-continue {
    background: transparent; border: 0; padding: 6px;
    color: var(--sk-muted); font-family: inherit; font-size: calc(var(--sk-fs-text, 15px) - 1px);
    cursor: pointer;
}
.sk-added-continue:hover { color: var(--sk-primary); }
@media (max-width: 420px) {
    .sk-added-actions { grid-template-columns: 1fr; }
}

/* ==========================================================================
   PROFILE PAGE
   ========================================================================== */

.sk-profile-grid { display: grid; grid-template-columns: 280px 1fr; gap: var(--sk-s-5); align-items: start; }
.sk-profile-side { padding: var(--sk-s-5); position: sticky; top: 80px; }
.sk-profile-id {
    display: flex; align-items: center; gap: var(--sk-s-3);
    padding-bottom: var(--sk-s-4); margin-bottom: var(--sk-s-3);
    border-bottom: 1px solid var(--sk-border);
}
.sk-avatar {
    width: 56px; height: 56px; border-radius: 50%;
    background-size: cover; background-position: center;
    background-color: var(--sk-surface-2); flex-shrink: 0;
    border: 2px solid var(--sk-surface);
    box-shadow: 0 0 0 2px var(--sk-primary);
}
.sk-name { font-weight: 700; font-size: var(--sk-fs-text, 15px); }

.sk-profile-nav { display: flex; flex-direction: column; gap: 4px; }
.sk-profile-nav button {
    text-align: right;
    background: transparent; border: 0; color: var(--sk-text);
    padding: 11px 14px; border-radius: 10px;
    font-family: inherit; font-size: var(--sk-fs-text, 15px); cursor: pointer;
    transition: background .15s, color .15s;
    display: flex; align-items: center; gap: var(--sk-s-2);
}
.sk-profile-nav button:hover { background: var(--sk-surface-2); }
.sk-profile-nav button.is-active {
    background: linear-gradient(135deg, var(--sk-primary), var(--sk-secondary));
    color: #fff;
}
.sk-profile-nav .sk-danger { color: var(--sk-danger); margin-top: var(--sk-s-2); border-top: 1px solid var(--sk-border); border-radius: 0; padding-top: var(--sk-s-3); }

.sk-profile-pane { display: none; }
.sk-profile-pane.is-active { display: block; }
.sk-profile-pane h2 { padding-bottom: var(--sk-s-3); border-bottom: 1px solid var(--sk-border); margin-bottom: var(--sk-s-4); }

.sk-orders-list { display: flex; flex-direction: column; gap: var(--sk-s-3); }
.sk-order-card { background: var(--sk-surface); border: 1px solid var(--sk-border); border-radius: var(--sk-radius); padding: var(--sk-s-4); box-shadow: var(--sk-shadow); }
.sk-order-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--sk-s-2); padding-bottom: var(--sk-s-3); border-bottom: 1px dashed var(--sk-border); margin-bottom: var(--sk-s-3); }
.sk-order-status {
    padding: 4px 12px; border-radius: 999px; font-size: calc(var(--sk-fs-text, 15px) - 3px); font-weight: 600;
    background: var(--sk-surface-2); color: var(--sk-text);
}
.sk-order-status.completed  { background: #ecfdf5; color: var(--sk-success); }
.sk-order-status.processing { background: #eff6ff; color: #2563eb; }
.sk-order-status.cancelled  { background: #fef2f2; color: var(--sk-danger); }
.sk-order-status.on-hold    { background: #fef3c7; color: #b45309; }
.sk-order-progress { display: flex; gap: 4px; margin-top: var(--sk-s-3); }
.sk-order-progress .step { flex: 1; height: 6px; border-radius: 4px; background: var(--sk-surface-2); }
.sk-order-progress .step.done { background: var(--sk-primary); }

/* ==========================================================================
   AUTH PAGE
   ========================================================================== */

.siteka-auth {
    min-height: calc(100vh - 200px);
    display: flex; align-items: center; justify-content: center;
    position: relative; overflow: hidden;
}
.sk-auth-card {
    width: 100%; max-width: 440px; padding: var(--sk-s-6) var(--sk-s-5);
    background: var(--sk-surface); border-radius: 20px;
    box-shadow: 0 20px 60px rgba(17,24,39,.10);
    border: 1px solid var(--sk-border);
    z-index: 2;
}
.sk-auth-brand { text-align: center; margin-bottom: var(--sk-s-5); }
.sk-auth-logo {
    width: 64px; height: 64px; border-radius: 18px;
    background: linear-gradient(135deg, var(--sk-primary), var(--sk-secondary));
    color: #fff; font-size: 1.6rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto var(--sk-s-3);
    box-shadow: 0 8px 20px var(--sk-primary-strong);
}
.sk-auth-tabs {
    display: flex; gap: 4px; padding: 4px;
    background: var(--sk-surface-2); border-radius: 12px; margin-bottom: var(--sk-s-5);
}
.sk-auth-tabs button {
    flex: 1; background: transparent; border: 0; padding: 9px 8px;
    color: var(--sk-muted); border-radius: 9px; font-family: inherit;
    font-size: var(--sk-fs-text, 15px); font-weight: 600; cursor: pointer;
    transition: all .15s;
}
.sk-auth-tabs button.is-active { background: var(--sk-surface); color: var(--sk-text); box-shadow: 0 1px 3px rgba(0,0,0,.06); }

.sk-auth-form { display: none; }
.sk-auth-form.is-active { display: flex; flex-direction: column; gap: var(--sk-s-3); }

.sk-auth-art { position: absolute; inset: 0; pointer-events: none; z-index: 1; overflow: hidden; }
.sk-orb { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .35; }
.sk-orb-1 { width: 320px; height: 320px; background: var(--sk-primary);   top: -80px; right: -100px; }
.sk-orb-2 { width: 260px; height: 260px; background: var(--sk-secondary); bottom: -60px; left: -80px; }
.sk-orb-3 { width: 220px; height: 220px; background: var(--sk-accent);    top: 40%; left: 40%; opacity: .2; }

/* ==========================================================================
   COMMON: loading & toast
   ========================================================================== */

.sk-loading { display: flex; align-items: center; justify-content: center; gap: var(--sk-s-3); padding: var(--sk-s-6); color: var(--sk-muted); }
.sk-spinner {
    width: 20px; height: 20px; border-radius: 50%;
    border: 2px solid var(--sk-border); border-top-color: var(--sk-primary);
    animation: sk-spin .8s linear infinite;
}
@keyframes sk-spin { to { transform: rotate(360deg); } }

.sk-toast {
    position: fixed; bottom: 30px; left: 50%; transform: translate(-50%, 0);
    background: var(--sk-text); color: #fff;
    padding: 13px 24px; border-radius: 14px;
    box-shadow: 0 12px 32px rgba(0,0,0,.22);
    z-index: 1100;
    animation: sk-toast-in .35s cubic-bezier(.18,.89,.32,1.28);
    font-size: var(--sk-fs-text, 15px); font-weight: 500; max-width: 92%;
    transition: opacity .35s, transform .35s;
}
.sk-toast.is-success { background: linear-gradient(135deg, #10b981, #059669); }
.sk-toast.is-error   { background: linear-gradient(135deg, #ef4444, #dc2626); }
@keyframes sk-toast-in { from { opacity: 0; transform: translate(-50%, 30px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* ==========================================================================
   PROMO BANNERS (home)
   ========================================================================== */

.sk-promo-banners {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sk-s-4);
    margin: var(--sk-s-6) 0;
}
.sk-promo-banner {
    position: relative; overflow: hidden;
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--sk-s-5); border-radius: 22px;
    text-decoration: none; color: #fff;
    min-height: 160px;
    transition: transform .25s, box-shadow .25s;
    box-shadow: 0 12px 28px -12px rgba(15, 23, 42, .25);
}
.sk-promo-banner:hover { transform: translateY(-4px); box-shadow: 0 18px 36px -12px rgba(15, 23, 42, .3); color: #fff; }
.sk-promo-1 { background: linear-gradient(135deg, var(--sk-primary), #4c1d95); }
.sk-promo-2 { background: linear-gradient(135deg, var(--sk-secondary), #0e7490); }
.sk-promo-banner::before {
    content: ''; position: absolute; top: -40px; left: -40px;
    width: 160px; height: 160px; border-radius: 50%;
    background: rgba(255,255,255,.08);
}
.sk-promo-banner::after {
    content: ''; position: absolute; bottom: -60px; right: -60px;
    width: 200px; height: 200px; border-radius: 50%;
    background: rgba(255,255,255,.06);
}
.sk-promo-text { position: relative; z-index: 1; max-width: 70%; }
.sk-promo-eyebrow {
    display: inline-block; padding: 4px 10px; border-radius: 999px;
    background: rgba(255,255,255,.18); font-size: calc(var(--sk-fs-text, 15px) - 4px); font-weight: 600;
    margin-bottom: 10px; color: #fff;
}
.sk-promo-text h3 { color: #fff; font-size: calc(var(--sk-fs-title, 22px) - 2px); margin: 0 0 6px; line-height: 1.4; }
.sk-promo-text p  { color: rgba(255,255,255,.88); margin: 0; font-size: calc(var(--sk-fs-text, 15px) - 2px); }
.sk-promo-cta {
    position: relative; z-index: 1; flex-shrink: 0;
    background: rgba(255,255,255,.18); padding: 10px 18px; border-radius: 999px;
    font-size: calc(var(--sk-fs-text, 15px) - 1px); font-weight: 600; color: #fff;
    border: 1px solid rgba(255,255,255,.3);
    transition: background .2s;
}
.sk-promo-banner:hover .sk-promo-cta { background: rgba(255,255,255,.28); }

/* ==========================================================================
   ARCHIVE SHORTCODE
   ========================================================================== */

.siteka-archive .sk-page-title { font-size: calc(var(--sk-fs-title, 22px) + 6px); margin: 8px 0 var(--sk-s-5); padding-bottom: var(--sk-s-4); border-bottom: 1px solid var(--sk-border); }
.sk-archive-toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--sk-s-3); flex-wrap: wrap; margin-bottom: var(--sk-s-5); }
.sk-archive-count   { color: var(--sk-muted); font-size: calc(var(--sk-fs-text, 15px) - 1px); }
.sk-archive-tools   { display: flex; gap: var(--sk-s-3); flex-wrap: wrap; }
.sk-archive-grid    { display: grid; gap: var(--sk-s-4); }
.sk-cols-2 { grid-template-columns: repeat(2, 1fr); }
.sk-cols-3 { grid-template-columns: repeat(3, 1fr); }
.sk-cols-4 { grid-template-columns: repeat(4, 1fr); }
.sk-cols-5 { grid-template-columns: repeat(5, 1fr); }
.sk-cols-6 { grid-template-columns: repeat(6, 1fr); }
@media (max-width: 980px) {
    .sk-cols-4, .sk-cols-5, .sk-cols-6 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .sk-cols-3, .sk-cols-4, .sk-cols-5, .sk-cols-6 { grid-template-columns: repeat(2, 1fr); }
    .sk-promo-banners { grid-template-columns: 1fr; }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 980px) {
    .sk-product-rail { grid-template-columns: repeat(3, 1fr); }
    .sk-features     { grid-template-columns: repeat(2, 1fr); }
    .sk-shop-layout  { grid-template-columns: 1fr; }
    .sk-filters      { position: static; display: none; }
    .sk-filters.is-open { display: block; }
    .sk-mobile-filter { display: inline-flex; }

    .sk-prod-grid { grid-template-columns: 1fr; padding: var(--sk-s-4); }

    .sk-cart-layout, .sk-checkout-grid, .sk-profile-grid { grid-template-columns: 1fr; }
    .sk-cart-summary, .sk-checkout-summary, .sk-profile-side { position: static; }
}

@media (max-width: 640px) {
    .siteka-wrap { padding: var(--sk-s-4) var(--sk-s-3) var(--sk-s-7); }
    .sk-hero-slider { height: 260px; }
    .sk-slide-content { padding: var(--sk-s-5); }
    .sk-slide-content h1 { font-size: calc(var(--sk-fs-title, 22px) - 2px); }
    .sk-slide-content p  { font-size: calc(var(--sk-fs-text, 15px) - 1px); }

    .sk-product-rail { grid-template-columns: repeat(2, 1fr); }
    .sk-grid         { grid-template-columns: repeat(2, 1fr); gap: var(--sk-s-3); }
    .sk-features     { grid-template-columns: 1fr; }

    .sk-shop-head    { flex-direction: column; align-items: stretch; }
    .sk-search input { width: 100%; }
    .sk-shop-tools   { flex-direction: column; align-items: stretch; }

    .sk-prod-title { font-size: var(--sk-fs-title, 22px); }
    .sk-prod-price { font-size: calc(var(--sk-fs-price, 18px) + 2px); }
    .sk-buybar     { flex-wrap: wrap; }

    .sk-row, .sk-row:has(.sk-input:nth-child(3)) { grid-template-columns: 1fr; }
    .sk-step-indicator { flex-wrap: wrap; }

    .sk-cart-item { grid-template-columns: 64px 1fr; }
    .sk-cart-item-actions { grid-column: 1 / -1; justify-content: space-between; padding-top: var(--sk-s-2); border-top: 1px dashed var(--sk-border); }

    .sk-cat-card  { width: 120px; padding: var(--sk-s-3) var(--sk-s-2); }
    .sk-cat-img   { width: 50px; height: 50px; }
    .sk-cat-name  { font-size: calc(var(--sk-fs-text, 15px) - 2px); }

    .sk-tab       { padding: 12px 14px; font-size: calc(var(--sk-fs-text, 15px) - 2px); }
    .sk-tab-pane  { padding: var(--sk-s-4); }
}
