/* =========================================================
   CLASSIC THEME — style.css  v2.0
   Prefix: cl-*  |  Namespace: window.CL
   Mobile-first · RTL-native · Full dark/light mode
   Dark mode: html[data-cl-mode="dark"]
   ========================================================= */

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
img { max-width: 100%; height: auto; display: block; }
a  { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
input, textarea, select { font: inherit; }

/* =========================================================
   DESIGN TOKENS
   ========================================================= */
:root {
    /* Brand — overridden by PHP inline style block */
    --cl-primary:   #111827;
    --cl-secondary: #d97706;
    --cl-font:      'Cairo', system-ui, sans-serif;

    /* Light mode semantic tokens */
    --cl-bg:        #ffffff;
    --cl-bg-2:      #f9fafb;
    --cl-bg-3:      #f3f4f6;
    --cl-surface:   #ffffff;
    --cl-border:    #e5e7eb;
    --cl-border-2:  rgba(0,0,0,.06);
    --cl-text:      #111827;
    --cl-text-2:    #374151;
    --cl-text-3:    #6b7280;
    --cl-text-4:    #9ca3af;

    /* Shadows */
    --cl-shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
    --cl-shadow:    0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
    --cl-shadow-lg: 0 12px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);

    /* Layout */
    --cl-max-w:     1280px;
    --cl-gutter:    clamp(16px, 4vw, 32px);
    --cl-header-h:  68px;

    /* Shape */
    --cl-radius:    12px;
    --cl-radius-sm: 8px;
    --cl-radius-lg: 20px;
    --cl-radius-xl: 28px;

    /* Animation */
    --cl-ease:      cubic-bezier(.4, 0, .2, 1);
    --cl-ease-out:  cubic-bezier(0, 0, .2, 1);
    --cl-dur:       200ms;
    --cl-dur-md:    300ms;
}

/* =========================================================
   DARK MODE
   ========================================================= */
html[data-cl-mode="dark"] {
    --cl-bg:        #0d0d0f;
    --cl-bg-2:      #141416;
    --cl-bg-3:      #1c1c1e;
    --cl-surface:   #1c1c1e;
    --cl-border:    rgba(255,255,255,.08);
    --cl-border-2:  rgba(255,255,255,.04);
    --cl-text:      #f3f4f6;
    --cl-text-2:    #d1d5db;
    --cl-text-3:    #9ca3af;
    --cl-text-4:    #6b7280;
    --cl-shadow-sm: 0 1px 3px rgba(0,0,0,.3);
    --cl-shadow:    0 4px 16px rgba(0,0,0,.4);
    --cl-shadow-lg: 0 12px 40px rgba(0,0,0,.6);
}

/* =========================================================
   BASE BODY
   ========================================================= */
body.cl-body {
    font-family:            var(--cl-font);
    font-size:              15px;
    line-height:            1.65;
    color:                  var(--cl-text);
    background:             var(--cl-bg);
    -webkit-font-smoothing: antialiased;
    transition:             background var(--cl-dur-md) var(--cl-ease),
                            color      var(--cl-dur-md) var(--cl-ease);
}

/* =========================================================
   LAYOUT
   ========================================================= */
.cl-container {
    width:          100%;
    max-width:      var(--cl-max-w);
    margin-inline:  auto;
    padding-inline: var(--cl-gutter);
}

/* =========================================================
   BUTTONS
   ========================================================= */
.cl-btn {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             8px;
    padding:         11px 28px;
    border-radius:   var(--cl-radius);
    font-weight:     600;
    font-size:       14px;
    letter-spacing:  .01em;
    transition:      all var(--cl-dur) var(--cl-ease);
    white-space:     nowrap;
    cursor:          pointer;
    border:          2px solid transparent;
}

.cl-btn-primary {
    background:   var(--cl-secondary);
    color:        #fff;
    border-color: var(--cl-secondary);
}
.cl-btn-primary:hover {
    filter:     brightness(1.08);
    transform:  translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,.2);
}

.cl-btn-dark {
    background:   var(--cl-primary);
    color:        #fff;
    border-color: var(--cl-primary);
}
.cl-btn-dark:hover { opacity: .88; }

.cl-btn-outline {
    background:   transparent;
    color:        var(--cl-text);
    border-color: var(--cl-border);
}
.cl-btn-outline:hover {
    background:   var(--cl-primary);
    color:        #fff;
    border-color: var(--cl-primary);
}

.cl-btn-outline-white {
    background:   transparent;
    color:        #fff;
    border-color: rgba(255,255,255,.65);
}
.cl-btn-outline-white:hover {
    background:   rgba(255,255,255,.18);
    border-color: #fff;
}

.cl-btn-link {
    display:     inline-flex;
    align-items: center;
    gap:         6px;
    font-size:   14px;
    font-weight: 600;
    color:       var(--cl-secondary);
    transition:  gap var(--cl-dur) var(--cl-ease), opacity var(--cl-dur);
}
.cl-btn-link:hover { gap: 10px; opacity: .8; }
.cl-btn-link--light { color: rgba(255,255,255,.9); }
.cl-btn-link--light:hover { color: #fff; }

/* =========================================================
   SECTION UTILITY
   ========================================================= */
.cl-section         { padding-block: 72px; }
.cl-section--gray   {
    background: var(--cl-bg-2);
}
.cl-section--offers {
    background: linear-gradient(135deg, var(--cl-primary) 0%, #1f2937 100%);
    color: #fff;
}

/* Dark mode: gray section gets a slightly lighter bg */
html[data-cl-mode="dark"] .cl-section--gray { background: var(--cl-bg-2); }

.cl-section-head {
    display:         flex;
    align-items:     flex-end;
    justify-content: space-between;
    gap:             16px;
    margin-bottom:   44px;
    flex-wrap:       wrap;
}
.cl-section-head--center {
    flex-direction: column;
    align-items:    center;
    text-align:     center;
}
.cl-section-title {
    font-size:   clamp(20px, 3vw, 28px);
    font-weight: 800;
    color:       var(--cl-text);
    line-height: 1.25;
    letter-spacing: -.02em;
}
.cl-section-title--light { color: #fff; }
.cl-section-sub {
    font-size:  14px;
    color:      var(--cl-text-3);
    margin-top: 6px;
}
.cl-section-sub--light { color: rgba(255,255,255,.65); }

/* Decorative section title accent line */
.cl-section-head-text { position: relative; }

/* =========================================================
   HEADER — glass morphism in dark, clean white in light
   ========================================================= */
.cl-header {
    position:     fixed;
    top:          0;
    inset-inline: 0;
    z-index:      200;
    background:   var(--cl-bg);
    border-bottom: 1px solid var(--cl-border);
    transition:   background var(--cl-dur-md) var(--cl-ease),
                  box-shadow var(--cl-dur-md) var(--cl-ease),
                  border-color var(--cl-dur-md) var(--cl-ease);
}
/* Leave room so the page content doesn't slide under the fixed header. */
#cl-main { padding-top: var(--cl-header-h, 68px); }
/* In the demo / customizer preview, the top preview banner takes the
   first 56px of the viewport — shift the fixed header down so it sits
   right under the banner instead of overlapping it. */
body.tm-preview-active .cl-header,
body.tm-device-mobile .cl-header,
body.tm-device-tablet .cl-header {
    top: 56px;
}

/* Glass effect on scroll in dark mode */
html[data-cl-mode="dark"] .cl-header {
    background:    rgba(13,13,15,.80);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}
html[data-cl-mode="dark"] .cl-header.is-scrolled {
    background:    rgba(13,13,15,.92);
    box-shadow:    var(--cl-shadow);
}
.cl-header.is-scrolled { box-shadow: var(--cl-shadow); }

/* Customizer "Sticky header" toggle OFF — header scrolls away with the page.
   Drops the fixed positioning and the content offset the fixed header needs. */
.cl-header--static { position: static; top: auto; }
.cl-header--static ~ #cl-main,
body:has(.cl-header--static) #cl-main { padding-top: 0; }

.cl-header-row {
    display:     flex;
    align-items: center;
    gap:         16px;
    height:      var(--cl-header-h);
}

/* Burger */
.cl-burger {
    display:         none;
    flex-direction:  column;
    justify-content: center;
    gap:             5px;
    width:           36px;
    height:          36px;
    flex-shrink:     0;
    padding:         0;
}
.cl-burger span {
    display:          block;
    height:           2px;
    background:       var(--cl-text);
    border-radius:    2px;
    transition:       all var(--cl-dur) var(--cl-ease);
    transform-origin: center;
}
.cl-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.cl-burger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.cl-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Logo */
.cl-logo {
    display:     flex;
    align-items: center;
    flex-shrink: 0;
}
.cl-logo img { max-height: 44px; width: auto; object-fit: contain; }
.cl-logo-text {
    font-size:      20px;
    font-weight:    800;
    color:          var(--cl-text);
    letter-spacing: -.03em;
}

/* Desktop Nav */
.cl-nav { margin-inline-start: 8px; }
.cl-nav-list {
    display:     flex;
    align-items: center;
    gap:         2px;
}
.cl-nav-list li a {
    display:       block;
    padding:       6px 13px;
    font-size:     14px;
    font-weight:   500;
    color:         var(--cl-text-2);
    border-radius: var(--cl-radius-sm);
    transition:    color var(--cl-dur), background var(--cl-dur);
    white-space:   nowrap;
}
.cl-nav-list li a:hover,
.cl-nav-list li a.is-active {
    color:      var(--cl-text);
    background: var(--cl-bg-3);
}
.cl-nav-list li a.is-active { font-weight: 700; }

/* Header Tools */
.cl-header-tools {
    display:           flex;
    align-items:       center;
    gap:               4px;
    margin-inline-start: auto;
}
.cl-icon-btn {
    position:        relative;
    display:         flex;
    align-items:     center;
    justify-content: center;
    width:           40px;
    height:          40px;
    border-radius:   var(--cl-radius-sm);
    color:           var(--cl-text-2);
    font-size:       16px;
    transition:      color var(--cl-dur), background var(--cl-dur);
}
.cl-icon-btn:hover {
    color:      var(--cl-text);
    background: var(--cl-bg-3);
}
.cl-icon-badge {
    position:          absolute;
    top:               4px;
    inset-inline-end:  4px;
    min-width:         17px;
    height:            17px;
    padding-inline:    4px;
    border-radius:     999px;
    background:        var(--cl-secondary);
    color:             #fff;
    font-size:         10px;
    font-weight:       700;
    display:           flex;
    align-items:       center;
    justify-content:   center;
    line-height:       1;
    pointer-events:    none;
}

/* Search Bar */
.cl-search-bar {
    border-top:  1px solid var(--cl-border);
    padding-block: 12px;
    background:  var(--cl-bg);
    animation:   cl-slide-down var(--cl-dur) var(--cl-ease) both;
    transition:  background var(--cl-dur-md);
}
@keyframes cl-slide-down {
    from { opacity: 0; transform: translateY(-10px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cl-search-bar[hidden] { display: none; }

.cl-search-form {
    display:     flex;
    align-items: center;
    gap:         10px;
    background:  var(--cl-bg-3);
    border-radius: var(--cl-radius);
    padding:     10px 16px;
    border:      1.5px solid var(--cl-border);
    transition:  border-color var(--cl-dur), background var(--cl-dur);
}
.cl-search-form:focus-within {
    border-color: var(--cl-secondary);
    background:   var(--cl-surface);
    box-shadow:   0 0 0 3px rgba(217,119,6,.12);
}
.cl-search-form > i { color: var(--cl-text-3); font-size: 14px; }
.cl-search-form input {
    flex:        1;
    border:      none;
    background:  transparent;
    outline:     none;
    font-size:   14px;
    color:       var(--cl-text);
}
.cl-search-form input::placeholder { color: var(--cl-text-4); }
.cl-search-submit {
    padding:       7px 18px;
    background:    var(--cl-secondary);
    color:         #fff;
    border-radius: var(--cl-radius-sm);
    font-size:     13px;
    font-weight:   600;
    transition:    opacity var(--cl-dur);
    flex-shrink:   0;
}
.cl-search-submit:hover { opacity: .88; }
.cl-search-close {
    color:      var(--cl-text-3);
    font-size:  16px;
    transition: color var(--cl-dur);
    flex-shrink: 0;
}
.cl-search-close:hover { color: var(--cl-text); }

/* =========================================================
   MOBILE NAV DRAWER
   ========================================================= */
.cl-nav-drawer {
    position:           fixed;
    inset-block:        0;
    inset-inline-start: 0;
    width:              min(300px, 85vw);
    background:         var(--cl-bg);
    z-index:            500;
    display:            flex;
    flex-direction:     column;
    transform:          translateX(-100%);
    transition:         transform .28s var(--cl-ease),
                        background var(--cl-dur-md);
    box-shadow:         var(--cl-shadow-lg);
    overflow-y:         auto;
}
[dir="rtl"] .cl-nav-drawer { transform: translateX(100%); }
.cl-nav-drawer.is-open { transform: translateX(0) !important; }

.cl-overlay {
    position:       fixed;
    inset:          0;
    background:     rgba(0,0,0,.5);
    z-index:        499;
    opacity:        0;
    pointer-events: none;
    transition:     opacity .28s var(--cl-ease);
    backdrop-filter: blur(2px);
}
.cl-overlay.is-visible { opacity: 1; pointer-events: all; }

.cl-drawer-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding:         16px 20px;
    border-bottom:   1px solid var(--cl-border);
    flex-shrink:     0;
}
.cl-drawer-close {
    width:         34px;
    height:        34px;
    display:       flex;
    align-items:   center;
    justify-content: center;
    border-radius: var(--cl-radius-sm);
    color:         var(--cl-text-3);
    font-size:     16px;
    transition:    background var(--cl-dur), color var(--cl-dur);
}
.cl-drawer-close:hover { background: var(--cl-bg-3); color: var(--cl-text); }

.cl-drawer-nav { flex: 1; }
.cl-drawer-nav ul { padding: 8px 0; }
.cl-drawer-nav li a,
.cl-drawer-nav li .cl-drawer-auth-btn {
    display:     flex;
    align-items: center;
    gap:         12px;
    padding:     13px 20px;
    font-size:   14px;
    font-weight: 500;
    color:       var(--cl-text-2);
    transition:  background var(--cl-dur), color var(--cl-dur);
    width:       100%;
    text-align:  start;
}
.cl-drawer-nav li a:hover,
.cl-drawer-nav li .cl-drawer-auth-btn:hover {
    background: var(--cl-bg-2);
    color:      var(--cl-text);
}
.cl-drawer-nav li a i,
.cl-drawer-nav li .cl-drawer-auth-btn i {
    width:    20px;
    color:    var(--cl-text-4);
    font-size: 15px;
}

.cl-drawer-contact {
    padding:        16px 20px;
    border-top:     1px solid var(--cl-border);
    display:        flex;
    flex-direction: column;
    gap:            10px;
    flex-shrink:    0;
}
.cl-drawer-contact a {
    display:     flex;
    align-items: center;
    gap:         10px;
    font-size:   13px;
    color:       var(--cl-text-3);
}
.cl-drawer-contact a:hover { color: var(--cl-text); }

/* =========================================================
   BOTTOM NAVIGATION (mobile)
   ========================================================= */
.cl-bottom-nav {
    display:            none;
    position:           fixed;
    bottom:             0;
    inset-inline:       0;
    z-index:            300;
    background:         var(--cl-surface);
    border-top:         1px solid var(--cl-border);
    padding-bottom:     env(safe-area-inset-bottom, 0);
    grid-template-columns: repeat(5, 1fr);
    transition:         background var(--cl-dur-md);
}
html[data-cl-mode="dark"] .cl-bottom-nav {
    background: rgba(20,20,22,.95);
    backdrop-filter: blur(16px);
}
.cl-bn-item {
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    gap:             3px;
    padding:         9px 4px;
    font-size:       11px;
    font-weight:     500;
    color:           var(--cl-text-3);
    transition:      color var(--cl-dur);
    background:      none;
    border:          none;
    cursor:          pointer;
    font-family:     inherit;
}
.cl-bn-item.is-active,
.cl-bn-item:hover { color: var(--cl-secondary); }
.cl-bn-item i { font-size: 18px; }
.cl-bn-ico-wrap { position: relative; display: inline-flex; }
.cl-bn-badge {
    position:          absolute;
    top:               -4px;
    inset-inline-end: -6px;
    min-width:         16px;
    height:            16px;
    padding-inline:    3px;
    background:        var(--cl-secondary);
    color:             #fff;
    font-size:         10px;
    font-weight:       700;
    border-radius:     999px;
    display:           flex;
    align-items:       center;
    justify-content:   center;
}

/* =========================================================
   HERO SLIDER — Cinematic
   ========================================================= */
.cl-hero {
    position:   relative;
    overflow:   hidden;
    background: var(--cl-bg-3);
}
.cl-hero-track { position: relative; }
.cl-hero-slide {
    display:  none;
    position: relative;
    height:   clamp(420px, 56vw, 640px);
    overflow: hidden;
}
.cl-hero-slide.is-active { display: block; }

.cl-hero-bg {
    position:           absolute;
    inset:              0;
    background-size:    cover;
    background-position: center;
    transition:         transform 8s linear;
    will-change:        transform;
}
.cl-hero-slide.is-active .cl-hero-bg { transform: scale(1.05); }

/* Demo slide: use actual picsum image, no tint needed */
.cl-hero-slide--demo .cl-hero-bg {
    background-size:     cover;
    background-position: center;
}

/* Default no-image gradient */
.cl-hero-bg--default {
    background: linear-gradient(135deg, var(--cl-primary) 0%, #1f2937 55%, var(--cl-secondary) 100%);
}

/* Gradient overlay for text legibility */
.cl-hero-overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(
        to right,
        rgba(0,0,0,.72) 0%,
        rgba(0,0,0,.35) 50%,
        rgba(0,0,0,.08) 100%
    );
}
[dir="rtl"] .cl-hero-overlay {
    background: linear-gradient(
        to left,
        rgba(0,0,0,.72) 0%,
        rgba(0,0,0,.35) 50%,
        rgba(0,0,0,.08) 100%
    );
}

/* Hero content */
.cl-hero-content {
    position:       absolute;
    inset:          0;
    display:        flex;
    flex-direction: column;
    justify-content: center;
    padding-block:  56px;
    max-width:      600px;
}

.cl-hero-badge {
    display:        inline-block;
    padding:        5px 16px;
    background:     var(--cl-secondary);
    color:          #fff;
    font-size:      12px;
    font-weight:    700;
    border-radius:  999px;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom:  18px;
    width:          fit-content;
    animation:      cl-fade-up .6s var(--cl-ease) .1s both;
}
.cl-hero-title {
    font-size:     clamp(28px, 5.5vw, 56px);
    font-weight:   900;
    color:         #fff;
    line-height:   1.15;
    margin-bottom: 16px;
    letter-spacing: -.03em;
    animation:     cl-fade-up .6s var(--cl-ease) .2s both;
    text-shadow:   0 2px 16px rgba(0,0,0,.2);
}
.cl-hero-sub {
    font-size:     clamp(14px, 2vw, 18px);
    color:         rgba(255,255,255,.88);
    margin-bottom: 32px;
    max-width:     440px;
    animation:     cl-fade-up .6s var(--cl-ease) .3s both;
    line-height:   1.6;
}
.cl-hero-actions {
    display:     flex;
    align-items: center;
    gap:         14px;
    flex-wrap:   wrap;
    animation:   cl-fade-up .6s var(--cl-ease) .4s both;
}

@keyframes cl-fade-up {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Arrow controls */
.cl-hero-arrow {
    position:          absolute;
    top:               50%;
    transform:         translateY(-50%);
    z-index:           10;
    width:             48px;
    height:            48px;
    background:        rgba(255,255,255,.12);
    backdrop-filter:   blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border:            1.5px solid rgba(255,255,255,.2);
    border-radius:     50%;
    color:             #fff;
    font-size:         14px;
    display:           flex;
    align-items:       center;
    justify-content:   center;
    transition:        background var(--cl-dur), transform var(--cl-dur);
}
.cl-hero-arrow:hover { background: rgba(255,255,255,.28); transform: translateY(-50%) scale(1.05); }
.cl-hero-prev { inset-inline-start: 20px; }
.cl-hero-next { inset-inline-end:   20px; }

/* Dots */
.cl-hero-dots {
    position:  absolute;
    bottom:    24px;
    left:      50%;
    transform: translateX(-50%);
    display:   flex;
    gap:       8px;
    z-index:   10;
}
[dir="rtl"] .cl-hero-dots { left: auto; right: 50%; transform: translateX(50%); }
.cl-hero-dot {
    width:         8px;
    height:        8px;
    border-radius: 50%;
    background:    rgba(255,255,255,.38);
    transition:    all .3s var(--cl-ease);
    border:        none;
    cursor:        pointer;
    padding:       0;
}
.cl-hero-dot.is-active {
    width:         28px;
    border-radius: 4px;
    background:    #fff;
}

/* =========================================================
   HIGHLIGHTS / FEATURES BAR
   ========================================================= */
.cl-highlights {
    background: var(--cl-primary);
    padding-block: 32px;
    position: relative;
    overflow: hidden;
}
.cl-highlights::before {
    content:    '';
    position:   absolute;
    inset-inline-end: 0;
    top:        0;
    bottom:     0;
    width:      30%;
    background: rgba(255,255,255,.02);
    clip-path:  polygon(20% 0%, 100% 0%, 100% 100%, 0% 100%);
    pointer-events: none;
}
.cl-highlights-grid {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   24px;
}
.cl-highlight {
    display:     flex;
    align-items: center;
    gap:         16px;
    color:       rgba(255,255,255,.9);
}
.cl-highlight-icon {
    width:           52px;
    height:          52px;
    flex-shrink:     0;
    background:      rgba(255,255,255,.08);
    border-radius:   var(--cl-radius);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       22px;
    color:           var(--cl-secondary);
    border:          1px solid rgba(255,255,255,.08);
}
.cl-highlight > i {
    font-size:   26px;
    color:       var(--cl-secondary);
    flex-shrink: 0;
    width:       30px;
    text-align:  center;
}
.cl-highlight strong {
    display:     block;
    font-size:   14px;
    font-weight: 700;
    color:       #fff;
}
.cl-highlight span {
    font-size: 12px;
    color:     rgba(255,255,255,.55);
}

/* =========================================================
   CATEGORIES — Tall card (3:4 ratio)
   ========================================================= */
.cl-cats-grid {
    display:               grid;
    grid-template-columns: repeat(6, 1fr);
    gap:                   16px;
}
.cl-cat-card {
    display:    block;
    border-radius: var(--cl-radius);
    overflow:   hidden;
    box-shadow: var(--cl-shadow-sm);
    transition: transform var(--cl-dur) var(--cl-ease),
                box-shadow var(--cl-dur) var(--cl-ease);
    border:     1px solid var(--cl-border);
    background: var(--cl-surface);
    position:   relative;
}
.cl-cat-card:hover {
    transform:  translateY(-5px);
    box-shadow: var(--cl-shadow);
}
.cl-cat-img {
    aspect-ratio:       3 / 4;
    background-size:    cover;
    background-position: center;
    background-color:   var(--cl-bg-3);
    transition:         transform .5s var(--cl-ease);
    overflow:           hidden;
}
.cl-cat-card:hover .cl-cat-img { transform: scale(1.06); }
.cl-cat-meta {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding:         10px 14px;
    background:      var(--cl-surface);
    border-top:      1px solid var(--cl-border);
    transition:      background var(--cl-dur-md);
}
.cl-cat-name {
    font-size:   13px;
    font-weight: 600;
    color:       var(--cl-text);
}
.cl-cat-arrow {
    color:      var(--cl-secondary);
    font-size:  12px;
    transition: transform var(--cl-dur);
}
.cl-cat-card:hover .cl-cat-arrow { transform: translateX(3px); }
[dir="rtl"] .cl-cat-card:hover .cl-cat-arrow { transform: translateX(-3px); }

/* =========================================================
   PRODUCT CARDS — Modern with hover quick-add
   ========================================================= */
.cl-products-grid {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   20px;
}
.cl-prod-card {
    position:       relative;
    background:     var(--cl-surface);
    border-radius:  var(--cl-radius);
    box-shadow:     var(--cl-shadow-sm);
    border:         1px solid var(--cl-border);
    overflow:       hidden;
    transition:     box-shadow var(--cl-dur) var(--cl-ease),
                    transform   var(--cl-dur) var(--cl-ease),
                    border-color var(--cl-dur) var(--cl-ease),
                    background  var(--cl-dur-md) var(--cl-ease);
    display:        flex;
    flex-direction: column;
}
.cl-prod-card:hover {
    box-shadow:   var(--cl-shadow);
    transform:    translateY(-4px);
    border-color: var(--cl-border-2);
}

/* Image area */
.cl-prod-img-link {
    display:    block;
    position:   relative;
    overflow:   hidden;
    background: var(--cl-bg-2);
    aspect-ratio: 1 / 1;
    transition: background var(--cl-dur-md);
}
.cl-prod-img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    transition: transform .45s var(--cl-ease);
    will-change: transform;
}
.cl-prod-card:hover .cl-prod-img { transform: scale(1.07); }

/* Badges */
.cl-prod-badges {
    position:           absolute;
    top:                10px;
    inset-inline-start: 10px;
    display:            flex;
    flex-direction:     column;
    gap:                5px;
    z-index:            2;
}
.cl-badge {
    display:       inline-block;
    padding:       3px 10px;
    border-radius: 999px;
    font-size:     11px;
    font-weight:   700;
    line-height:   1.4;
}
.cl-badge--new  { background: #2563eb; color: #fff; }
.cl-badge--sale { background: #ef4444; color: #fff; }
.cl-badge--hot  { background: #f97316; color: #fff; }

/* Wishlist button */
.cl-prod-fav {
    position:          absolute;
    top:               10px;
    inset-inline-end:  10px;
    z-index:           2;
    width:             36px;
    height:            36px;
    background:        var(--cl-surface);
    border-radius:     50%;
    display:           flex;
    align-items:       center;
    justify-content:   center;
    box-shadow:        var(--cl-shadow-sm);
    font-size:         14px;
    color:             var(--cl-text-3);
    transition:        color var(--cl-dur), transform var(--cl-dur),
                       background var(--cl-dur-md);
    opacity:           0;
    transform:         scale(.85);
}
.cl-prod-card:hover .cl-prod-fav,
.cl-prod-fav.is-on {
    opacity:   1;
    transform: scale(1);
}
.cl-prod-fav:hover,
.cl-prod-fav.is-on { color: #ef4444; }

/* Slide-up quick-add button */
.cl-prod-quick-add {
    position:        absolute;
    bottom:          0;
    inset-inline:    0;
    background:      var(--cl-primary);
    color:           #fff;
    font-size:       13px;
    font-weight:     600;
    padding:         11px;
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             7px;
    transform:       translateY(100%);
    transition:      transform .25s var(--cl-ease);
    cursor:          pointer;
    border:          none;
    font-family:     inherit;
    z-index:         3;
}
.cl-prod-card:hover .cl-prod-quick-add { transform: translateY(0); }
.cl-prod-quick-add:hover { filter: brightness(1.12); }

/* Card body */
.cl-prod-body {
    padding:        14px 16px 16px;
    display:        flex;
    flex-direction: column;
    gap:            6px;
    flex:           1;
}
.cl-prod-name {
    font-size:               14px;
    font-weight:             600;
    color:                   var(--cl-text);
    line-height:             1.45;
    display:                 -webkit-box;
    -webkit-line-clamp:      2;
    -webkit-box-orient:      vertical;
    overflow:                hidden;
    transition:              color var(--cl-dur);
}
.cl-prod-name a:hover { color: var(--cl-secondary); }

.cl-prod-stars {
    display:     flex;
    align-items: center;
    gap:         3px;
    font-size:   11px;
    color:       #f59e0b;
}
.cl-prod-stars span { color: var(--cl-text-4); font-size: 11px; }

.cl-prod-price-row {
    display:     flex;
    align-items: center;
    gap:         8px;
    margin-top:  2px;
    flex-wrap:   wrap;
}
.cl-prod-price {
    font-size:   16px;
    font-weight: 800;
    color:       var(--cl-text);
}
.cl-prod-price-old {
    font-size:       13px;
    color:           var(--cl-text-4);
    text-decoration: line-through;
}

.cl-prod-add-btn {
    margin-top:      auto;
    width:           100%;
    padding:         9px;
    background:      var(--cl-bg-3);
    color:           var(--cl-text-2);
    border-radius:   var(--cl-radius-sm);
    font-size:       13px;
    font-weight:     600;
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             7px;
    transition:      background var(--cl-dur), color var(--cl-dur),
                     border-color var(--cl-dur);
    border:          1.5px solid var(--cl-border);
}
.cl-prod-add-btn:hover {
    background:   var(--cl-primary);
    color:        #fff;
    border-color: var(--cl-primary);
}
/* Feedback state */
.cl-prod-add-btn.cl-added {
    background: #16a34a;
    color:      #fff;
    border-color: #16a34a;
}

/* =========================================================
   OFFERS / FLASH SALE GRID
   ========================================================= */
.cl-offers-grid {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   16px;
}
.cl-offer-card {
    display:        flex;
    flex-direction: column;
    background:     rgba(255,255,255,.06);
    border:         1px solid rgba(255,255,255,.1);
    border-radius:  var(--cl-radius);
    overflow:       hidden;
    transition:     transform var(--cl-dur) var(--cl-ease),
                    box-shadow var(--cl-dur) var(--cl-ease);
    color:          inherit;
}
.cl-offer-card:hover { transform: translateY(-4px); box-shadow: 0 10px 30px rgba(0,0,0,.3); }
.cl-offer-img {
    aspect-ratio:       1;
    background-size:    cover;
    background-position: center;
    background-color:   rgba(255,255,255,.08);
    transition:         transform .45s var(--cl-ease);
    overflow:           hidden;
}
.cl-offer-card:hover .cl-offer-img { transform: scale(1.05); }
.cl-offer-body { padding: 14px 16px 16px; }
.cl-offer-discount {
    display:      inline-block;
    background:   #ef4444;
    color:        #fff;
    font-size:    11px;
    font-weight:  700;
    padding:      3px 10px;
    border-radius: 999px;
    margin-bottom: 8px;
}
.cl-offer-name {
    font-size:               14px;
    font-weight:             600;
    color:                   #fff;
    margin-bottom:           10px;
    display:                 -webkit-box;
    -webkit-line-clamp:      2;
    -webkit-box-orient:      vertical;
    overflow:                hidden;
    line-height:             1.45;
}
.cl-offer-prices { display: flex; align-items: center; gap: 8px; }
.cl-offer-price { font-size: 15px; font-weight: 800; color: var(--cl-secondary); }
.cl-offer-price-old {
    font-size:       12px;
    color:           rgba(255,255,255,.42);
    text-decoration: line-through;
}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.cl-testimonials {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   20px;
}
.cl-testimonial {
    background:     var(--cl-surface);
    border:         1px solid var(--cl-border);
    border-radius:  var(--cl-radius-lg);
    padding:        28px;
    display:        flex;
    flex-direction: column;
    gap:            14px;
    box-shadow:     var(--cl-shadow-sm);
    transition:     box-shadow var(--cl-dur), transform var(--cl-dur),
                    background var(--cl-dur-md), border-color var(--cl-dur-md);
    position:       relative;
}
.cl-testimonial::before {
    content:     '\201C';
    position:    absolute;
    top:         20px;
    inset-inline-end: 24px;
    font-size:   56px;
    line-height: 1;
    color:       var(--cl-secondary);
    opacity:     .18;
    font-family: Georgia, serif;
    font-weight: 900;
}
.cl-testimonial:hover { box-shadow: var(--cl-shadow); transform: translateY(-3px); }
.cl-testimonial-stars { color: #f59e0b; font-size: 14px; display: flex; gap: 3px; }
.cl-testimonial-text {
    font-size:   14px;
    color:       var(--cl-text-2);
    line-height: 1.75;
    flex:        1;
}
.cl-testimonial-author { display: flex; align-items: center; gap: 12px; margin-top: 4px; }
.cl-testimonial-avatar {
    width:           42px;
    height:          42px;
    border-radius:   50%;
    background:      linear-gradient(135deg, var(--cl-primary) 0%, var(--cl-secondary) 100%);
    color:           #fff;
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-weight:     800;
    font-size:       16px;
    flex-shrink:     0;
}
.cl-testimonial-author strong { font-size: 14px; display: block; color: var(--cl-text); }
.cl-testimonial-author span   { font-size: 12px; color: var(--cl-text-4); }

/* =========================================================
   NEWSLETTER — gradient section
   ========================================================= */
.cl-newsletter {
    background:  linear-gradient(135deg, var(--cl-secondary) 0%, #b45309 100%);
    padding-block: 64px;
    color:       #fff;
    position:    relative;
    overflow:    hidden;
}
.cl-newsletter::before {
    content:    '';
    position:   absolute;
    inset:      0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cl-newsletter-inner {
    position:              relative;
    display:               grid;
    grid-template-columns: auto 1fr 1fr;
    gap:                   36px;
    align-items:           center;
}
.cl-newsletter-icon {
    width:           80px;
    height:          80px;
    background:      rgba(255,255,255,.15);
    border-radius:   50%;
    border:          2px solid rgba(255,255,255,.2);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       30px;
    flex-shrink:     0;
}
.cl-newsletter-text h2 {
    font-size:     clamp(18px, 3vw, 24px);
    font-weight:   800;
    margin-bottom: 6px;
    letter-spacing: -.01em;
}
.cl-newsletter-text p { font-size: 14px; opacity: .88; }
.cl-newsletter-form { display: flex; flex-direction: column; gap: 8px; }
.cl-newsletter-input-wrap {
    display:       flex;
    border-radius: var(--cl-radius);
    overflow:      hidden;
    box-shadow:    0 6px 24px rgba(0,0,0,.2);
}
.cl-newsletter-input-wrap input {
    flex:       1;
    padding:    14px 18px;
    border:     none;
    outline:    none;
    font-size:  14px;
    background: rgba(255,255,255,.96);
    color:      var(--cl-primary);
    min-width:  0;
}
.cl-newsletter-input-wrap input::placeholder { color: #9ca3af; }
.cl-newsletter-input-wrap .cl-btn {
    border-radius: 0;
    background:    var(--cl-primary);
    border-color:  var(--cl-primary);
    padding-inline: 24px;
    white-space:   nowrap;
    flex-shrink:   0;
}
.cl-newsletter-note { font-size: 12px; opacity: .7; }

/* =========================================================
   FOOTER — Dark, elegant
   ========================================================= */
.cl-footer {
    background:  var(--cl-primary);
    color:       rgba(255,255,255,.72);
    padding-top: 60px;
    position:    relative;
}
.cl-footer-grid {
    display:               grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap:                   44px;
    padding-bottom:        52px;
    border-bottom:         1px solid rgba(255,255,255,.08);
}
.cl-footer-col h4 {
    font-size:     14px;
    font-weight:   700;
    color:         #fff;
    margin-bottom: 20px;
    letter-spacing: .02em;
    text-transform: uppercase;
    position:      relative;
    padding-bottom: 12px;
}
.cl-footer-col h4::after {
    content:            '';
    position:           absolute;
    bottom:             0;
    inset-inline-start: 0;
    width:              28px;
    height:             2px;
    background:         var(--cl-secondary);
    border-radius:      2px;
}
.cl-footer-about p {
    font-size:     13.5px;
    line-height:   1.75;
    color:         rgba(255,255,255,.6);
    margin-bottom: 22px;
}
.cl-footer-social {
    display:  flex;
    gap:      10px;
    flex-wrap: wrap;
}
.cl-footer-social a {
    width:           38px;
    height:          38px;
    border-radius:   var(--cl-radius-sm);
    background:      rgba(255,255,255,.07);
    border:          1px solid rgba(255,255,255,.1);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       14px;
    color:           rgba(255,255,255,.65);
    transition:      all var(--cl-dur);
}
.cl-footer-social a:hover {
    background:   var(--cl-secondary);
    border-color: var(--cl-secondary);
    color:        #fff;
    transform:    translateY(-2px);
}

.cl-footer-col ul { display: flex; flex-direction: column; gap: 10px; }
.cl-footer-col ul li a {
    font-size:      13.5px;
    color:          rgba(255,255,255,.62);
    transition:     color var(--cl-dur), padding-inline-start var(--cl-dur);
    display:        inline-flex;
    align-items:    center;
    gap:            6px;
}
.cl-footer-col ul li a::before {
    content:    '›';
    opacity:    0;
    transition: opacity var(--cl-dur), transform var(--cl-dur);
    font-size:  16px;
    transform:  translateX(-4px);
    line-height: 1;
}
[dir="rtl"] .cl-footer-col ul li a::before { transform: translateX(4px); }
.cl-footer-col ul li a:hover {
    color:                rgba(255,255,255,.95);
    padding-inline-start: 6px;
}
.cl-footer-col ul li a:hover::before { opacity: 1; transform: translateX(0); }

/* Contact rows (phone / email / address): icon chip + text, tight & aligned.
   Scoped under .cl-footer-col to outrank the generic demo-polish icon rule
   (.cl-footer-col ul li i) that would otherwise force width:16px / opacity:.6. */
ul.cl-footer-contact-list { gap: 10px; }
.cl-footer-col ul.cl-footer-contact-list li {
    display:       flex;
    align-items:   center;
    gap:           10px;
    font-size:     13.5px;
    line-height:   1.5;
    color:         rgba(255,255,255,.62);
    margin-bottom: 0;
}
.cl-footer-col ul.cl-footer-contact-list li i {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    width:           32px;
    height:          32px;
    margin:          0;
    border-radius:   8px;
    background:      rgba(255,255,255,.06);
    color:           var(--cl-secondary);
    font-size:       13px;
    opacity:         1;
    flex-shrink:     0;
}
/* The address can wrap to two lines — keep its icon aligned to the first line. */
.cl-footer-col ul.cl-footer-contact-list li:has(span) { align-items: flex-start; }
.cl-footer-col ul.cl-footer-contact-list li a,
.cl-footer-col ul.cl-footer-contact-list li span { color: inherit; }
.cl-footer-col ul.cl-footer-contact-list li a:hover { color: #fff; }

.cl-footer-bottom {
    display:         flex;
    align-items:     center;
    justify-content: center;
    text-align:      center;
    gap:             16px;
    padding-block:   22px;
    border-top:      1px solid rgba(255,255,255,.06);
}
.cl-footer-copy { font-size: 13px; color: rgba(255,255,255,.7); }
.cl-footer-year { color: rgba(255,255,255,.7); }
.cl-footer-sep  { margin-inline: 6px; color: rgba(255,255,255,.3); }
.cl-footer-brand { color: var(--cl-secondary); font-weight: 600; text-decoration: none; }
.cl-footer-brand:hover { text-decoration: none; opacity: .8; }
.cl-footer-payments {
    display:    flex;
    gap:        10px;
    color:      rgba(255,255,255,.38);
    font-size:  22px;
    flex-wrap:  wrap;
    align-items: center;
}

/* =========================================================
   DARK MODE — component overrides
   ========================================================= */
/* Header nav active state in dark */
html[data-cl-mode="dark"] .cl-nav-list li a:hover,
html[data-cl-mode="dark"] .cl-nav-list li a.is-active {
    background: rgba(255,255,255,.06);
    color:      #fff;
}

/* Search form dark */
html[data-cl-mode="dark"] .cl-search-form {
    background: var(--cl-bg-3);
    border-color: var(--cl-border);
}
html[data-cl-mode="dark"] .cl-search-form:focus-within {
    background:  var(--cl-surface);
    border-color: var(--cl-secondary);
}

/* Product card dark quick-add */
html[data-cl-mode="dark"] .cl-prod-quick-add {
    background: var(--cl-secondary);
}

/* Category card dark */
html[data-cl-mode="dark"] .cl-cat-card { background: var(--cl-surface); }
html[data-cl-mode="dark"] .cl-cat-meta { background: var(--cl-surface); }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.cl-reveal {
    opacity:     0;
    transform:   translateY(28px);
    transition:  opacity .55s var(--cl-ease),
                 transform .55s var(--cl-ease);
}
.cl-reveal.is-visible { opacity: 1; transform: none; }

/* =========================================================
   SHARED PAGES INTEGRATION
   ========================================================= */
#cl-main > [class^="ms-"],
#cl-main > [class*=" ms-"],
#cl-main > .container,
#cl-main > section { padding-block: 40px; }

/* Hero / highlights must bleed edge-to-edge — remove the generic section gap */
#cl-main > .cl-hero,
#cl-main > .cl-highlights { padding-block: 0; }

/* =========================================================
   MAIN BOTTOM PADDING (mobile bottom nav)
   ========================================================= */
@media (max-width: 767px) {
    #cl-main { padding-bottom: 64px; }
}

/* =========================================================
   UTILITIES
   ========================================================= */
.cl-sr-only {
    position:    absolute;
    width:       1px;
    height:      1px;
    padding:     0;
    margin:      -1px;
    overflow:    hidden;
    clip:        rect(0,0,0,0);
    white-space: nowrap;
    border-width: 0;
}

/* =========================================================
   RESPONSIVE — 1100px
   ========================================================= */
@media (max-width: 1100px) {
    .cl-cats-grid     { grid-template-columns: repeat(4, 1fr); }
    .cl-products-grid { grid-template-columns: repeat(3, 1fr); }
    .cl-footer-grid   { grid-template-columns: repeat(2, 1fr); gap: 32px; }
}

/* =========================================================
   RESPONSIVE — 900px
   ========================================================= */
@media (max-width: 900px) {
    .cl-highlights-grid  { grid-template-columns: repeat(2, 1fr); }
    .cl-testimonials     { grid-template-columns: repeat(2, 1fr); }
    .cl-offers-grid      { grid-template-columns: repeat(2, 1fr); }
    .cl-newsletter-inner { grid-template-columns: 1fr 1fr; }
    .cl-newsletter-icon  { display: none; }
}

/* =========================================================
   RESPONSIVE — 768px (mobile)
   ========================================================= */
@media (max-width: 768px) {
    /* Header */
    .cl-burger { display: flex; }
    .cl-nav    { display: none; }
    /* Grids */
    .cl-cats-grid     { grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .cl-products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .cl-footer-grid   { grid-template-columns: 1fr 1fr; gap: 24px; }
    .cl-testimonials  { grid-template-columns: 1fr; }

    /* Hero */
    .cl-hero-slide  { height: clamp(340px, 66vw, 480px); }
    .cl-hero-content { max-width: 86%; }

    /* Newsletter */
    .cl-newsletter-inner { grid-template-columns: 1fr; gap: 24px; }
    .cl-newsletter-text  { text-align: center; }

    /* Section */
    .cl-section { padding-block: 48px; }

    /* Footer */
    .cl-footer-bottom { flex-direction: column; text-align: center; gap: 12px; }

    /* Bottom nav */
    .cl-bottom-nav { display: grid; }

    /* Product cards — always show fav button on touch */
    .cl-prod-fav { opacity: 1; transform: scale(1); }
    .cl-prod-quick-add { transform: translateY(0); position: static; }
}

/* =========================================================
   RESPONSIVE — 520px (small mobile)
   ========================================================= */
@media (max-width: 520px) {
    .cl-cats-grid        { grid-template-columns: repeat(2, 1fr); }
    .cl-highlights-grid  { grid-template-columns: 1fr; gap: 14px; }
    .cl-offers-grid      { grid-template-columns: 1fr; }
    .cl-footer-grid      { grid-template-columns: 1fr; }
    .cl-products-grid    { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .cl-prod-body        { padding: 10px 12px 12px; }
    .cl-hero-content     { max-width: 95%; }
    .cl-hero-actions     { gap: 8px; }
    .cl-hero-actions .cl-btn { padding: 9px 16px; font-size: 13px; }
    .cl-newsletter-input-wrap { flex-direction: column; }
    .cl-newsletter-input-wrap .cl-btn {
        border-radius: 0 0 var(--cl-radius) var(--cl-radius);
        width: 100%;
    }
    .cl-newsletter-input-wrap input {
        border-radius: var(--cl-radius) var(--cl-radius) 0 0;
    }
    .cl-testimonial { padding: 20px; }
    .cl-section     { padding-block: 40px; }
}


/* ════════════════════════════════════════════════════════════════
   CLASSIC PRODUCTION POLISH LAYER
   Ported verbatim from the demo (storefront/demo/template-classic).
   Loaded after base tokens so it reproduces the demo cascade exactly.
   Demo-only .cl-demo-root scope stripped so rules apply to the store.
   Vendor brand --cl-primary/--cl-secondary are re-injected by
   index.blade.php AFTER this file, so they always win.
   ════════════════════════════════════════════════════════════════ */
    /* ════════════════════════════════════════════════════
       DEMO POLISH LAYER — premium visual refinements
       Scoped to the demo only. Production theme untouched.
       ════════════════════════════════════════════════════ */

    :root {
        --cl-font:       'Cairo','Inter',system-ui,-apple-system,sans-serif;
        --cl-font-display:'Playfair Display','Cairo',serif;
        --cl-primary:    #0f172a;
        --cl-secondary:  #d97706;
        --cl-gold:       #c5a572;
        --cl-shadow-xl:  0 24px 48px -12px rgba(15,23,42,.18), 0 8px 16px -8px rgba(15,23,42,.10);
    }
    html[data-cl-mode="dark"] {
        --cl-gold: #d4b87f;
    }

    /* ── Refined logo wordmark ── */
    .cl-demo-logo {
        font-family: var(--cl-font-display);
        font-weight: 800;
        font-size:   24px;
        letter-spacing: -.02em;
        color: var(--cl-text);
        display: inline-flex;
        align-items: baseline;
        gap: 2px;
        line-height: 1;
    }
    .cl-demo-logo .dot { color: var(--cl-secondary); font-size: 26px; }
    .cl-demo-logo .tag { font-family: var(--cl-font); font-size: 10px; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: var(--cl-text-3); margin-inline-start: 6px; }

    /* ── Hero: premium typography + bottom trust row ── */
    .cl-hero {
        min-height: min(86vh, 780px);
        position: relative;
        display: block;
        margin: 0 !important;
        padding: 0;
        width: 100% !important;
        max-width: 100% !important;
    }
    .cl-hero-track {
        min-height: min(86vh, 780px);
        position: relative;
        width: 100% !important;
    }
    .cl-hero-slide {
        min-height: min(86vh, 780px);
        display: none;
        position: relative;
        width: 100% !important;
    }
    .cl-hero-bg {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background-size: cover !important;
        background-position: center !important;
        z-index: 0 !important;
    }
    .cl-hero-overlay {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        z-index: 1 !important;
    }
    .cl-hero-slide.is-active { display: block; }
    .cl-hero-bg {
        position: absolute;
        inset: 0;
        background-size: cover;
        background-position: center;
        z-index: 0;
    }
    .cl-hero-slide .cl-container {
        position: relative;
        z-index: 2;
        min-height: inherit;
        display: flex;
        align-items: center;
    }
    /* Remove the generic section padding-block that #cl-main > section adds */
    #cl-main > .cl-hero,
    #cl-main > .cl-highlights { padding-block: 0; }

    .cl-hero-content {
        position: relative !important;
        inset: auto !important;
        max-width: 640px;
        width: 100%;
        padding: 28px 0 52px;
    }

    /* ── Hero nav arrows — HIDDEN by default, shown only on large screens (≥1281px) ── */
    .cl-hero-arrow,
    button.cl-hero-arrow,
    .cl-hero-prev,
    .cl-hero-next {
        display: none !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }
    @media (min-width: 1281px) {
        .cl-hero-arrow,
        button.cl-hero-arrow,
        .cl-hero-prev,
        .cl-hero-next {
            position: absolute !important;
            top: 50%;
            transform: translateY(-50%);
            z-index: 5;
            width: 52px; height: 52px;
            background: rgba(255,255,255,.14);
            backdrop-filter: blur(12px);
            -webkit-backdrop-filter: blur(12px);
            border: 1px solid rgba(255,255,255,.22);
            border-radius: 50%;
            color: #fff;
            font-size: 16px;
            display: inline-flex !important;
            visibility: visible !important;
            pointer-events: auto !important;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: background .2s var(--cl-ease), transform .2s var(--cl-ease), border-color .2s;
        }
    }
    .cl-hero-arrow:hover {
        background: rgba(255,255,255,.28);
        border-color: rgba(255,255,255,.40);
        transform: translateY(-50%) scale(1.08);
    }
    .cl-hero-prev { inset-inline-start: 24px; }
    .cl-hero-next { inset-inline-end:   24px; }

    /* ── Hero dots: keep inside the section bottom edge ── */
    .cl-hero-dots,
    [dir="rtl"] .cl-hero-dots {
        position: absolute !important;
        bottom: 28px !important;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        display: flex !important;
        justify-content: center !important;
        gap: 8px !important;
        z-index: 5;
        padding: 0;
    }
    .cl-hero-dot {
        width: 28px; height: 4px;
        border-radius: 999px;
        background: rgba(255,255,255,.35);
        border: 0;
        cursor: pointer;
        transition: width .25s var(--cl-ease), background .2s;
    }
    .cl-hero-dot.is-active { background: #fff; width: 44px; }

    .cl-hero-overlay {
        background: linear-gradient(90deg,
            rgba(10,15,30,.78) 0%,
            rgba(10,15,30,.62) 40%,
            rgba(10,15,30,.35) 70%,
            rgba(10,15,30,.20) 100%
        ),
        linear-gradient(180deg,
            rgba(10,15,30,.20) 0%,
            rgba(10,15,30,.40) 60%,
            rgba(10,15,30,.70) 100%
        ) !important;
    }
    [dir="rtl"] .cl-hero-overlay {
        background: linear-gradient(270deg,
            rgba(10,15,30,.78) 0%,
            rgba(10,15,30,.62) 40%,
            rgba(10,15,30,.35) 70%,
            rgba(10,15,30,.20) 100%
        ),
        linear-gradient(180deg,
            rgba(10,15,30,.20) 0%,
            rgba(10,15,30,.40) 60%,
            rgba(10,15,30,.70) 100%
        ) !important;
    }
    .cl-hero-badge {
        background: rgba(255,255,255,.14) !important;
        backdrop-filter: blur(14px);
        -webkit-backdrop-filter: blur(14px);
        border: 1px solid rgba(255,255,255,.22);
        color: #fff !important;
        padding: 8px 18px !important;
        font-size: 11.5px !important;
        font-weight: 700 !important;
        letter-spacing: .14em !important;
        text-transform: uppercase;
        box-shadow: 0 4px 16px rgba(0,0,0,.20);
    }
    .cl-hero-title {
        font-family: var(--cl-font-display) !important;
        font-size: clamp(34px, 5.4vw, 64px) !important;
        font-weight: 800 !important;
        line-height: 1.08 !important;
        letter-spacing: -.02em !important;
        color: #fff !important;
        text-shadow: 0 2px 16px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.50);
        margin-bottom: 18px !important;
    }
    .cl-hero-title-2 {
        display: block;
        color: var(--cl-gold) !important;
        font-style: italic;
        font-weight: 700;
        text-shadow: 0 2px 16px rgba(0,0,0,.50), 0 1px 4px rgba(0,0,0,.55);
    }
    .cl-hero-sub {
        font-size: clamp(15px, 1.4vw, 18px) !important;
        color: rgba(255,255,255,.92) !important;
        max-width: 580px;
        line-height: 1.7 !important;
        text-shadow: 0 1px 8px rgba(0,0,0,.45);
        margin-bottom: 28px !important;
    }
    .cl-hero-trust {
        display: flex;
        gap: 22px;
        flex-wrap: wrap;
        margin-top: 28px;
    }
    .cl-hero-trust-item {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        color: rgba(255,255,255,.85);
        font-size: 13px;
        font-weight: 500;
    }
    .cl-hero-trust-item i {
        width: 28px; height: 28px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: rgba(255,255,255,.12);
        border-radius: 50%;
        font-size: 11px;
        color: var(--cl-gold);
        border: 1px solid rgba(255,255,255,.18);
    }

    /* ── Refined buttons ── */
    .cl-btn { font-weight: 700 !important; letter-spacing: .01em; }
    .cl-btn-primary {
        background: #fff !important;
        color: #0f172a !important;
        padding: 14px 28px !important;
        box-shadow: 0 8px 28px rgba(0,0,0,.18) !important;
        transition: transform .2s var(--cl-ease), box-shadow .2s var(--cl-ease), background .2s !important;
    }
    .cl-btn-primary:hover {
        transform: translateY(-2px);
        box-shadow: 0 14px 38px rgba(0,0,0,.28) !important;
        background: var(--cl-gold) !important;
        color: #fff !important;
    }
    .cl-btn-outline-white {
        padding: 14px 26px !important;
        backdrop-filter: blur(10px);
        background: rgba(255,255,255,.08) !important;
    }
    .cl-btn-outline-white:hover {
        background: rgba(255,255,255,.18) !important;
        transform: translateY(-2px);
    }

    /* ══════════ HEADER POLISH ══════════ */
    .cl-header {
        backdrop-filter: blur(14px);
        background: rgba(255,255,255,.92) !important;
    }
    html[data-cl-mode="dark"] .cl-header {
        background: rgba(13,13,15,.85) !important;
    }
    .cl-header.is-scrolled { box-shadow: 0 4px 20px rgba(15,23,42,.06); }
    .cl-nav-list a {
        position: relative;
        font-weight: 600;
    }
    .cl-nav-list a::after {
        content: '';
        position: absolute;
        bottom: -4px;
        inset-inline: 50% 50%;
        height: 2px;
        background: var(--cl-secondary);
        border-radius: 2px;
        transition: inset .25s var(--cl-ease);
    }
    .cl-nav-list a:hover::after,
    .cl-nav-list a.is-active::after { inset-inline: 0 0; }
    .cl-icon-btn {
        transition: background .18s, color .18s, transform .18s;
    }
    .cl-icon-btn:hover {
        background: var(--cl-bg-2);
        transform: translateY(-1px);
    }

    /* ══════════ SECTION HEADINGS POLISH ══════════ */
    .cl-section-title {
        font-family: var(--cl-font-display) !important;
        font-size: clamp(26px, 3vw, 38px) !important;
        font-weight: 700 !important;
        letter-spacing: -.015em !important;
        line-height: 1.15 !important;
    }
    .cl-section-sub { font-size: 15px !important; color: var(--cl-text-3) !important; }
    .cl-section-eyebrow {
        display: inline-block;
        font-size: 11px;
        font-weight: 700;
        letter-spacing: .18em;
        text-transform: uppercase;
        color: var(--cl-secondary);
        margin-bottom: 12px;
    }

    /* ══════════ CATEGORY CARDS POLISH ══════════ */
    .cl-cats-grid { gap: 16px; }
    .cl-cat-card {
        aspect-ratio: 3 / 4;
        border-radius: 20px !important;
        overflow: hidden;
        position: relative;
        background: #111827;
        box-shadow: 0 4px 20px rgba(0,0,0,.18), 0 1px 4px rgba(0,0,0,.10);
        transition: transform .35s var(--cl-ease), box-shadow .35s var(--cl-ease) !important;
    }
    .cl-cat-card:hover {
        transform: translateY(-8px) !important;
        box-shadow: 0 16px 40px rgba(0,0,0,.28), 0 4px 10px rgba(0,0,0,.14) !important;
    }
    .cl-cat-card .cl-cat-img {
        position: absolute !important;
        inset: 0 !important;
        aspect-ratio: unset !important;
        width: 100% !important;
        height: 100% !important;
        background-size: cover !important;
        background-position: center top !important;
        background-color: transparent !important;
        transition: transform .6s var(--cl-ease) !important;
        opacity: .9;
    }
    .cl-cat-card:hover .cl-cat-img { transform: scale(1.07) !important; opacity: 1; }
    .cl-cat-card::after {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg,
            rgba(10,10,20,.05) 0%,
            rgba(10,10,20,.30) 40%,
            rgba(10,10,20,.90) 100%);
        z-index: 1;
    }
    .cl-cat-meta {
        position: absolute !important;
        inset-inline: 0 !important;
        bottom: 0 !important;
        top: auto !important;
        padding: 20px 20px !important;
        color: #fff !important;
        background: transparent !important;
        border-top: none !important;
        z-index: 2;
        display: flex !important;
        align-items: flex-end !important;
        justify-content: space-between !important;
    }
    .cl-cat-name { color:#fff !important; font-size: 17px !important; font-weight: 700 !important; line-height: 1.3 !important; }
    .cl-cat-meta small { color: rgba(255,255,255,.70); font-size: 12px; display: block; margin-top: 4px; font-weight: 500; }
    .cl-cat-card .cl-cat-arrow {
        flex-shrink: 0;
        background: rgba(255,255,255,.15);
        backdrop-filter: blur(8px);
        -webkit-backdrop-filter: blur(8px);
        width: 36px; height: 36px;
        border-radius: 50%;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: #fff !important;
        transition: background .25s, transform .25s !important;
    }
    .cl-cat-card:hover .cl-cat-arrow { background: var(--cl-secondary); transform: scale(1.12) !important; }

    /* ══════════ PROMO BANNERS ══════════ */
    .cl-promo {
        position: relative;
        border-radius: 24px;
        overflow: hidden;
        min-height: 360px;
        display: flex;
        align-items: center;
        background: #1c1917;
        color: #fff;
    }
    .cl-promo-img {
        position: absolute;
        inset: 0;
        background-size: cover;
        background-position: center;
        transition: transform .8s var(--cl-ease);
    }
    .cl-promo:hover .cl-promo-img { transform: scale(1.04); }
    .cl-promo::after {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(90deg, rgba(15,23,42,.85) 0%, rgba(15,23,42,.55) 50%, rgba(15,23,42,.20) 100%);
    }
    [dir="rtl"] .cl-promo::after {
        background: linear-gradient(270deg, rgba(15,23,42,.85) 0%, rgba(15,23,42,.55) 50%, rgba(15,23,42,.20) 100%);
    }
    .cl-promo-content {
        position: relative;
        z-index: 2;
        max-width: 540px;
        padding: 48px 56px;
    }
    .cl-promo-eyebrow {
        display: inline-block;
        background: var(--cl-gold);
        color: #1c1917;
        font-size: 11px;
        font-weight: 800;
        letter-spacing: .14em;
        text-transform: uppercase;
        padding: 6px 14px;
        border-radius: 999px;
        margin-bottom: 18px;
    }
    .cl-promo-title {
        font-family: var(--cl-font-display);
        font-size: clamp(28px, 3.4vw, 44px);
        font-weight: 800;
        line-height: 1.1;
        margin-bottom: 14px;
        letter-spacing: -.015em;
    }
    .cl-promo-sub {
        font-size: 16px;
        line-height: 1.65;
        color: rgba(255,255,255,.78);
        margin-bottom: 26px;
        max-width: 440px;
    }
    .cl-promo-cta {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        background: #fff;
        color: #1c1917;
        padding: 13px 24px;
        border-radius: 999px;
        font-weight: 700;
        font-size: 14px;
        text-decoration: none;
        transition: transform .2s, box-shadow .2s, background .2s, color .2s;
        box-shadow: 0 6px 22px rgba(0,0,0,.18);
    }
    .cl-promo-cta:hover {
        transform: translateY(-2px);
        background: var(--cl-gold);
        color: #fff;
        box-shadow: 0 12px 30px rgba(0,0,0,.28);
    }

    /* ══════════ PRODUCT CARD POLISH ══════════ */
    /* ══════════ PRODUCT CARDS — Premium redesign ══════════ */
    .cl-prod-card {
        border-radius: 18px !important;
        border: 1px solid rgba(15,23,42,.07) !important;
        box-shadow: 0 2px 10px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04) !important;
        background: #fff !important;
        transition: transform .32s var(--cl-ease), box-shadow .32s var(--cl-ease), border-color .32s !important;
        overflow: hidden;
    }
    /* ── Product cards — Dark mode polish ── */
    html[data-cl-mode="dark"] .cl-prod-card {
        background: #1a1d28 !important;
        border: 1px solid rgba(255,255,255,.08) !important;
        box-shadow: 0 2px 12px rgba(0,0,0,.30), 0 1px 3px rgba(0,0,0,.20) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-card:hover {
        background: #1f2230 !important;
        border-color: rgba(255,255,255,.14) !important;
        box-shadow: 0 18px 40px rgba(0,0,0,.45), 0 6px 14px rgba(0,0,0,.25) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-img-link {
        background: #14161e !important;
    }
    html[data-cl-mode="dark"] .cl-prod-name,
    html[data-cl-mode="dark"] .cl-prod-name a {
        color: #f1f3f7 !important;
    }
    html[data-cl-mode="dark"] .cl-prod-name a:hover {
        color: var(--cl-gold) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-stars-text {
        color: #d6d9e0 !important;
    }
    html[data-cl-mode="dark"] .cl-prod-stars-count {
        color: rgba(255,255,255,.50) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-price {
        color: #ffffff !important;
    }
    html[data-cl-mode="dark"] .cl-prod-price-old {
        color: rgba(255,255,255,.40) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-add-btn {
        background: var(--cl-gold) !important;
        color: #14161e !important;
        border-color: var(--cl-gold) !important;
        font-weight: 800 !important;
    }
    html[data-cl-mode="dark"] .cl-prod-add-btn:hover {
        background: var(--cl-secondary) !important;
        color: #fff !important;
        border-color: var(--cl-secondary) !important;
        box-shadow: 0 8px 22px rgba(217,119,6,.40) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-fav {
        background: rgba(30,33,42,.95) !important;
        border: 1px solid rgba(255,255,255,.12) !important;
        color: rgba(255,255,255,.70) !important;
        box-shadow: 0 4px 12px rgba(0,0,0,.30) !important;
    }
    html[data-cl-mode="dark"] .cl-prod-fav:hover {
        color: #ff5757 !important;
        background: #2a2d38 !important;
    }
    html[data-cl-mode="dark"] .cl-badge--new {
        background: var(--cl-gold, #d4b87f) !important;
        color: #0d0d0f !important;
    }
    .cl-prod-card:hover {
        transform: translateY(-8px) !important;
        box-shadow: 0 20px 48px rgba(15,23,42,.13), 0 4px 12px rgba(15,23,42,.07) !important;
        border-color: rgba(15,23,42,.12) !important;
    }

    /* Image area */
    .cl-prod-img-link {
        aspect-ratio: 1 / 1 !important;
        overflow: hidden !important;
        display: block !important;
        position: relative !important;
    }
    .cl-prod-img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        transition: transform .5s var(--cl-ease) !important;
    }
    .cl-prod-card:hover .cl-prod-img { transform: scale(1.06) !important; }

    /* Badges */
    .cl-badge {
        padding: 4px 11px !important;
        font-size: 10.5px !important;
        font-weight: 800 !important;
        letter-spacing: .05em !important;
        border-radius: 999px !important;
        box-shadow: 0 2px 6px rgba(0,0,0,.18) !important;
    }
    .cl-badge--sale { background: #e53e3e !important; color: #fff !important; }
    .cl-badge--new  { background: var(--cl-gold, #c5a572) !important; color: #1a1a2e !important; text-shadow: 0 1px 0 rgba(255,255,255,.18); }

    /* Fav button */
    .cl-prod-fav {
        width: 36px !important; height: 36px !important;
        background: rgba(255,255,255,.96) !important;
        backdrop-filter: blur(10px) !important;
        -webkit-backdrop-filter: blur(10px) !important;
        border: 1px solid rgba(15,23,42,.08) !important;
        box-shadow: 0 2px 10px rgba(15,23,42,.12) !important;
        border-radius: 50% !important;
        font-size: 13px !important;
        color: var(--cl-text-3) !important;
        opacity: 0 !important;
        transform: scale(.8) translateY(-4px) !important;
        transition: opacity .2s, transform .2s, color .15s !important;
    }
    .cl-prod-card:hover .cl-prod-fav { opacity: 1 !important; transform: scale(1) translateY(0) !important; }
    .cl-prod-fav:hover { color: #e53e3e !important; }

    /* Card body */
    .cl-prod-body {
        padding: 14px 16px 16px !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        flex: 1 !important;
    }

    /* Product name */
    .cl-prod-name {
        font-size: 14.5px !important;
        font-weight: 600 !important;
        line-height: 1.45 !important;
        color: var(--cl-text) !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
        min-height: 42px !important;
        margin: 0 !important;
    }
    .cl-prod-name a { color: inherit !important; text-decoration: none !important; }
    .cl-prod-name a:hover { color: var(--cl-secondary) !important; }

    /* Stars */
    .cl-prod-stars {
        display: flex !important;
        align-items: center !important;
        gap: 6px !important;
    }
    .cl-prod-stars-icons { display: flex; gap: 2px; font-size: 11px; color: #f59e0b; }
    .cl-prod-stars-text  { font-size: 12px; font-weight: 700; color: var(--cl-text-2); }
    .cl-prod-stars-count { font-size: 11px; font-weight: 400; color: var(--cl-text-4); }

    /* Price row */
    .cl-prod-price-row {
        display: flex !important;
        align-items: baseline !important;
        gap: 8px !important;
        flex-wrap: wrap !important;
    }
    .cl-prod-price {
        font-size: 18px !important;
        font-weight: 800 !important;
        color: var(--cl-primary) !important;
        letter-spacing: -.02em !important;
        font-family: var(--cl-font) !important;
    }
    .cl-prod-price-old {
        font-size: 12.5px !important;
        font-weight: 500 !important;
        color: var(--cl-text-4) !important;
        text-decoration: line-through !important;
    }

    /* Add to cart button */
    .cl-prod-add-btn {
        margin-top: auto !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        padding: 11px 16px !important;
        background: var(--cl-primary) !important;
        color: #fff !important;
        border: 2px solid var(--cl-primary) !important;
        border-radius: 12px !important;
        font-size: 13.5px !important;
        font-weight: 700 !important;
        font-family: inherit !important;
        cursor: pointer !important;
        transition: background .2s, border-color .2s, transform .18s, box-shadow .2s !important;
        letter-spacing: .01em !important;
    }
    .cl-prod-add-btn:hover {
        background: var(--cl-secondary) !important;
        border-color: var(--cl-secondary) !important;
        transform: translateY(-1px) !important;
        box-shadow: 0 6px 18px rgba(217,119,6,.30) !important;
    }

    /* ══════════ TESTIMONIALS POLISH ══════════ */
    .cl-testimonials { gap: 22px !important; }
    .cl-testimonial {
        background: var(--cl-surface) !important;
        border: 1px solid var(--cl-border) !important;
        border-radius: 20px !important;
        padding: 30px !important;
        position: relative;
        transition: transform .25s, box-shadow .25s;
    }
    .cl-testimonial:hover { transform: translateY(-4px); box-shadow: var(--cl-shadow); }
    .cl-testimonial::before {
        content: '"';
        position: absolute;
        top: 8px;
        inset-inline-end: 20px;
        font-family: var(--cl-font-display);
        font-size: 80px;
        color: var(--cl-secondary);
        opacity: .14;
        line-height: 1;
    }
    .cl-testimonial-stars { color: #f59e0b; font-size: 13px; margin-bottom: 14px !important; }
    .cl-testimonial-text {
        font-size: 15px !important;
        line-height: 1.8 !important;
        color: var(--cl-text-2) !important;
        margin-bottom: 20px !important;
        position: relative;
        z-index: 1;
    }
    .cl-testimonial-author { gap: 12px !important; }
    .cl-testimonial-avatar {
        width: 48px !important;
        height: 48px !important;
        border-radius: 50% !important;
        background-size: cover !important;
        background-position: center !important;
        border: 2px solid var(--cl-bg) !important;
        box-shadow: 0 4px 12px rgba(15,23,42,.10);
        font-size: 0 !important;
    }
    .cl-testimonial-author strong { font-size: 14px !important; color: var(--cl-text) !important; }
    .cl-testimonial-author span { color: var(--cl-text-3) !important; font-size: 12.5px !important; }

    /* ══════════ FOOTER POLISH ══════════ */
    .cl-footer { background: #0a0f1a !important; }
    .cl-footer-col h4 {
        font-family: var(--cl-font-display);
        font-weight: 700;
        font-size: 16px;
        margin-bottom: 16px;
        color: #fff;
        letter-spacing: -.01em;
    }
    .cl-footer-col ul li a,
    .cl-footer-col ul li {
        color: rgba(255,255,255,.55);
        font-size: 13.5px;
        line-height: 2.2;
        transition: color .15s;
    }
    .cl-footer-col ul li a:hover { color: var(--cl-gold); }
    .cl-footer-col ul li i { width: 16px; margin-inline-end: 8px; opacity: .6; }
    .cl-footer-social a {
        width: 36px; height: 36px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: rgba(255,255,255,.06);
        border: 1px solid rgba(255,255,255,.10);
        border-radius: 50%;
        color: rgba(255,255,255,.75);
        margin-inline-end: 8px;
        transition: all .2s;
    }
    .cl-footer-social a:hover {
        background: var(--cl-gold);
        color: #fff;
        border-color: var(--cl-gold);
        transform: translateY(-2px);
    }
    .cl-footer-bottom {
        color: rgba(255,255,255,.7) !important;
        padding-top: 22px !important;
        text-align: center !important;
        font-size: 13px !important;
    }
    .cl-footer-bottom .cl-footer-copy,
    .cl-footer-bottom .cl-footer-year { color: rgba(255,255,255,.7) !important; }
    .cl-footer-bottom .cl-footer-sep   { color: rgba(255,255,255,.3) !important; }
    .cl-footer-bottom .cl-footer-brand { color: var(--cl-secondary) !important; }

    /* ══════════ SCROLL REVEAL ══════════ */
    .cl-reveal {
        opacity: 0;
        transform: translateY(20px);
        transition: opacity .6s var(--cl-ease), transform .6s var(--cl-ease);
    }
    .cl-reveal.is-visible {
        opacity: 1;
        transform: translateY(0);
    }
    @media (prefers-reduced-motion: reduce) {
        .cl-reveal { opacity: 1; transform: none; transition: none; }
        .cl-hero-slide.is-active .cl-hero-bg { transform: none; }
    }

    /* ══════════ RESPONSIVE ══════════ */

    /* ─── Tablet landscape (≤1200px) ─── */
    @media (max-width: 1200px) {
        .cl-hero, .cl-hero-slide, .cl-hero-track { min-height: min(70vh, 600px) !important; }
        .cl-hero-title { font-size: clamp(30px, 5vw, 50px) !important; }
        .cl-hero-content { padding: 24px 0 48px; max-width: 560px; }
    }

    /* ─── On tablet/mobile: hide nav + tools, show only logo + burger ─── */
    @media (max-width: 1024px) {
        .cl-nav,
        .cl-nav-list,
        .cl-header-tools { display: none !important; }
        .cl-burger {
            display: flex !important;
            order: 1 !important;
            width: 28px !important;
            height: 28px !important;
            padding: 0 !important;
            gap: 3px !important;
        }
        .cl-burger span { height: 1.5px !important; }
        .cl-logo { order: 2 !important; }
        .cl-header-row { justify-content: space-between !important; }
    }


    /* ─── Tablet portrait/landscape (≤1100px) ─── */
    @media (max-width: 1100px) {
        .cl-hero, .cl-hero-slide, .cl-hero-track { min-height: min(65vh, 560px) !important; }
        .cl-cat-card { aspect-ratio: 4 / 5; }
        .cl-promo { min-height: 320px; }
    }

    /* ─── Tablet portrait (≤900px) ─── */
    @media (max-width: 900px) {
        .cl-hero, .cl-hero-slide, .cl-hero-track { min-height: min(62vh, 520px) !important; }
        .cl-hero-title { font-size: clamp(28px, 5.4vw, 42px) !important; }
        .cl-promo { min-height: 280px; }
        .cl-promo-content { padding: 36px 36px; }
        .cl-section-head { flex-direction: column !important; align-items: flex-start !important; gap: 14px !important; }
    }

    /* ─── Mobile (≤768px) ─── */
    @media (max-width: 768px) {
        .cl-hero, .cl-hero-slide, .cl-hero-track { min-height: 480px !important; }
        .cl-hero-content { padding: 22px 0 38px; max-width: 90%; }
        .cl-hero-arrow { width: 40px; height: 40px; font-size: 13px; }
        .cl-hero-prev { inset-inline-start: 10px; }
        .cl-hero-next { inset-inline-end: 10px; }
        .cl-hero-trust { gap: 12px; margin-top: 20px; flex-wrap: wrap; }
        .cl-hero-trust-item { font-size: 11.5px; }
        .cl-cat-card { aspect-ratio: 1 / 1; }
        .cl-cat-name { font-size: 15px !important; }
        .cl-promo { min-height: 240px; }
        .cl-promo-content { padding: 28px 28px; }
        .cl-promo-title { font-size: clamp(20px, 4.5vw, 30px); }
        .cl-promo-sub { font-size: 14px; margin-bottom: 20px; max-width: 100%; }
        .cl-prod-name { min-height: 36px; }
        .cl-prod-price { font-size: 16px !important; }
        .cl-prod-add-btn { font-size: 12.5px !important; padding: 10px 12px !important; gap: 6px !important; }
        .cl-footer-bottom { flex-direction: column !important; gap: 6px !important; text-align: center !important; justify-content: center !important; }
    }

    /* ─── Small mobile (≤520px) ─── */
    @media (max-width: 520px) {
        .cl-hero, .cl-hero-slide, .cl-hero-track { min-height: 420px !important; }
        .cl-hero-content { padding: 18px 0 32px; max-width: 100%; }
        .cl-hero-trust { display: none; }
        .cl-hero-arrow { width: 36px; height: 36px; font-size: 12px; }
        .cl-cat-card { aspect-ratio: 4 / 5; }
        .cl-cat-name { font-size: 14px !important; }
        .cl-cat-meta { padding: 14px 14px !important; }
        .cl-cat-card .cl-cat-arrow { width: 30px; height: 30px; font-size: 11px; }
        .cl-promo { min-height: 200px; }
        .cl-promo-content { padding: 22px 20px; }
        .cl-promo-title { font-size: clamp(18px, 5vw, 24px); }
        .cl-promo-sub { display: none; }
        .cl-promo-cta { padding: 10px 18px; font-size: 13px; }
        .cl-prod-body { padding: 10px 12px 12px !important; gap: 5px !important; }
        .cl-prod-name { font-size: 13px !important; min-height: auto; }
        .cl-prod-price { font-size: 15px !important; }
        .cl-prod-add-btn { padding: 9px 10px !important; font-size: 12px !important; }
        .cl-prod-stars-text { font-size: 11px; }
        .cl-testimonial { padding: 22px !important; }
        .cl-section-title { font-size: clamp(20px, 5.5vw, 26px) !important; }
        .cl-section-sub { font-size: 13.5px !important; }
    }

    /* ─── Extra small (≤380px) ─── */
    @media (max-width: 380px) {
        .cl-hero, .cl-hero-slide, .cl-hero-track { min-height: 380px !important; }
        .cl-hero-actions .cl-btn { padding: 10px 16px; font-size: 13px; }
        .cl-cat-name { font-size: 13px !important; }
        .cl-prod-add-btn { font-size: 11.5px !important; }
        .cl-promo-title { font-size: 18px; }
    }

    /* ── Mobile side drawer (slides in from start side / RTL: right, LTR: left) ── */
    .cl-mobile-menu {
        position: fixed;
        top: 0;
        bottom: 0;
        inset-inline-start: 0;
        width: 280px;
        max-width: 80vw;
        background: var(--cl-surface);
        box-shadow: 4px 0 24px rgba(0,0,0,.18);
        z-index: 9999;
        padding: 24px 18px;
        transform: translateX(-105%);
        transition: transform .32s var(--cl-ease);
        overflow-y: auto;
    }
    [dir="rtl"] .cl-mobile-menu {
        transform: translateX(105%);
        box-shadow: -4px 0 24px rgba(0,0,0,.18);
    }
    .cl-mobile-menu.is-open,
    [dir="rtl"] .cl-mobile-menu.is-open {
        transform: translateX(0);
    }

    /* ══════ PREVIEW DEVICE CONTAINMENT ══════
       In preview mode, wraps all demo content.
       Adding transform: translateZ(0) makes it the containing block
       for ALL position:fixed descendants — menu, backdrop, and header
       are all clipped and positioned within the 420/820px device frame.
       overflow: hidden clips the off-screen closed menu from the gutter.
    ══════════════════════════════════════════ */
    /* ⚠ Do NOT apply `overflow:hidden` or `z-index:0` to body here.
       Both bugs broke device-mode preview:
         • overflow:hidden disabled vertical page scroll
         • z-index:0 stacked body above #tm-preview-banner, hiding it.
       The platform's _preview_banner.blade.php already handles device
       framing via `body.tm-device-* > *:not(#tm-preview-banner)`. */
    body.tm-device-mobile,
    body.tm-device-tablet {
        overflow-x: hidden;
    }
    .cl-mobile-menu-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding-bottom: 18px;
        margin-bottom: 14px;
        border-bottom: 1px solid var(--cl-border);
    }
    .cl-mobile-menu-close {
        width: 34px; height: 34px;
        border-radius: 50%;
        border: 1px solid var(--cl-border);
        background: transparent;
        color: var(--cl-text);
        font-size: 15px;
        cursor: pointer;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        transition: background .15s;
    }
    .cl-mobile-menu-close:hover { background: var(--cl-bg-2); }
    .cl-mobile-menu-nav { display: flex; flex-direction: column; gap: 2px; }
    .cl-mobile-menu a {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 13px 16px;
        margin: 0;
        border-radius: 10px;
        color: var(--cl-text);
        text-decoration: none;
        font-weight: 600;
        font-size: 14.5px;
        transition: background .15s, color .15s;
    }
    .cl-mobile-menu a i {
        width: 20px;
        font-size: 15px;
        color: var(--cl-text-3);
        text-align: center;
    }
    .cl-mobile-menu a:hover,
    .cl-mobile-menu a.is-active {
        background: var(--cl-bg-2);
        color: var(--cl-secondary);
    }
    .cl-mobile-menu a:hover i,
    .cl-mobile-menu a.is-active i {
        color: var(--cl-secondary);
    }
    .cl-mobile-menu-badge {
        margin-inline-start: auto;
        background: var(--cl-secondary);
        color: #fff;
        font-size: 11px;
        font-weight: 700;
        padding: 2px 8px;
        border-radius: 999px;
        min-width: 22px;
        text-align: center;
    }
    .cl-mobile-menu-divider {
        height: 1px;
        background: var(--cl-border);
        margin: 12px 0;
    }
    /* Backdrop */
    .cl-mobile-backdrop {
        position: fixed;
        inset: 0;
        background: rgba(15,23,42,.45);
        backdrop-filter: blur(2px);
        z-index: 9998;
        opacity: 0;
        pointer-events: none;
        transition: opacity .25s;
    }
    .cl-mobile-backdrop.is-active {
        opacity: 1;
        pointer-events: auto;
    }

    /* ─── Touch devices ─── */
    @media (hover: none) {
        .cl-prod-fav { opacity: 1 !important; transform: scale(1) translateY(0) !important; }
        .cl-cat-card:hover { transform: none !important; }
        .cl-prod-card:hover { transform: none !important; }
    }

    /* ════════════════════════════════════════════════════
       PREVIEW BANNER DEVICE SIMULATION
       The preview banner sets max-width on body via classes
       (tm-device-mobile/tablet), not actual viewport.
       So media queries don't trigger. We mirror them here.
       ════════════════════════════════════════════════════ */

    /* ──── TABLET preview (820px max-width) ──── */
    /* On tablet: show full nav (burger only on mobile) */
    body.tm-device-tablet .cl-nav,
    body.tm-device-tablet .cl-nav-list,
    body.tm-device-tablet .cl-header-tools { display: flex !important; }
    body.tm-device-tablet .cl-burger { display: none !important; }
    body.tm-device-tablet .cl-logo { order: unset !important; margin-inline-end: 0 !important; }
    body.tm-device-tablet .cl-header-row { justify-content: flex-start !important; gap: 0 !important; }
    body.tm-device-tablet .cl-nav { margin-inline-start: 20px !important; margin-inline-end: 0 !important; }
    body.tm-device-tablet .cl-header-tools { margin-inline-start: auto !important; gap: 4px !important; }
    body.tm-device-tablet .cl-hero,
    body.tm-device-tablet .cl-hero-slide,
    body.tm-device-tablet .cl-hero-track { min-height: 520px !important; }
    body.tm-device-tablet .cl-hero-content { max-width: 480px !important; padding: 24px 0 44px !important; }
    body.tm-device-tablet .cl-hero-title { font-size: 36px !important; line-height: 1.1 !important; }
    body.tm-device-tablet .cl-hero-sub { font-size: 14px !important; max-width: 400px !important; }
    body.tm-device-tablet .cl-hero-trust { gap: 14px; }
    body.tm-device-tablet .cl-hero-trust-item { font-size: 12px; }
    body.tm-device-tablet .cl-hero-actions .cl-btn { padding: 12px 22px !important; font-size: 13.5px !important; }
    body.tm-device-tablet .cl-section-title { font-size: 26px !important; }
    body.tm-device-tablet .cl-section-sub { font-size: 13.5px !important; }
    body.tm-device-tablet .cl-cats-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 12px !important; }
    body.tm-device-tablet .cl-cat-card { aspect-ratio: 3/4 !important; }
    body.tm-device-tablet .cl-products-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 14px !important; }
    body.tm-device-tablet .cl-prod-name { font-size: 13.5px !important; }
    body.tm-device-tablet .cl-prod-price { font-size: 16px !important; }
    body.tm-device-tablet .cl-prod-fav { opacity: 1 !important; transform: scale(1) translateY(0) !important; }
    body.tm-device-tablet .cl-testimonials { grid-template-columns: 1fr !important; }
    body.tm-device-tablet .cl-testimonial { padding: 24px !important; }
    body.tm-device-tablet .cl-footer-grid { grid-template-columns: 1fr 1fr !important; gap: 24px !important; }
    body.tm-device-tablet .cl-footer-bottom { flex-direction: column !important; gap: 6px !important; text-align: center !important; justify-content: center !important; }
    body.tm-device-tablet .cl-promo { min-height: 260px !important; border-radius: 18px !important; }
    body.tm-device-tablet .cl-promo-content { padding: 32px 36px !important; }
    body.tm-device-tablet .cl-promo-title { font-size: 26px !important; }
    body.tm-device-tablet .cl-section-head { flex-direction: column !important; align-items: flex-start !important; gap: 12px !important; }

    /* MOBILE preview (420px max-width) */
    body.tm-device-mobile .cl-nav,
    body.tm-device-mobile .cl-nav-list,
    body.tm-device-mobile .cl-header-tools { display: none !important; }
    body.tm-device-mobile .cl-burger {
        display: flex !important;
        order: 1 !important;
        width: 26px !important;
        height: 26px !important;
        padding: 0 !important;
        gap: 3px !important;
    }
    body.tm-device-mobile .cl-burger span { height: 1.5px !important; }
    body.tm-device-mobile .cl-logo { order: 2 !important; }
    body.tm-device-mobile .cl-header-row { justify-content: space-between !important; }
    body.tm-device-mobile .cl-demo-logo { font-size: 20px !important; }
    body.tm-device-mobile .cl-demo-logo .dot { font-size: 22px !important; }
    body.tm-device-mobile .cl-hero,
    body.tm-device-mobile .cl-hero-slide,
    body.tm-device-mobile .cl-hero-track { min-height: 460px !important; }
    body.tm-device-mobile .cl-hero-content { padding: 18px 0 32px !important; max-width: 100% !important; }
    body.tm-device-mobile .cl-hero-badge { padding: 5px 12px !important; font-size: 10px !important; }
    body.tm-device-mobile .cl-hero-title { font-size: 28px !important; line-height: 1.1 !important; }
    body.tm-device-mobile .cl-hero-sub { font-size: 13px !important; margin-bottom: 18px !important; }
    body.tm-device-mobile .cl-hero-trust { display: none !important; }
    body.tm-device-mobile .cl-hero-actions { gap: 8px; flex-wrap: wrap; }
    body.tm-device-mobile .cl-hero-actions .cl-btn { padding: 10px 16px !important; font-size: 12.5px !important; }
    body.tm-device-mobile .cl-cats-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    body.tm-device-mobile .cl-cat-card { aspect-ratio: 4/5 !important; border-radius: 14px !important; }
    body.tm-device-mobile .cl-cat-name { font-size: 13.5px !important; }
    body.tm-device-mobile .cl-products-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    body.tm-device-mobile .cl-prod-name { font-size: 12.5px !important; min-height: 32px; }
    body.tm-device-mobile .cl-prod-price { font-size: 14px !important; }
    body.tm-device-mobile .cl-prod-add-btn { padding: 8px !important; font-size: 11px !important; }
    body.tm-device-mobile .cl-prod-fav { opacity: 1 !important; transform: scale(1) translateY(0) !important; }
    body.tm-device-mobile .cl-testimonials { grid-template-columns: 1fr !important; }
    body.tm-device-mobile .cl-testimonial { padding: 18px !important; }
    body.tm-device-mobile .cl-footer-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
    body.tm-device-mobile .cl-footer-bottom { flex-direction: column !important; gap: 6px !important; text-align: center !important; justify-content: center !important; }
    body.tm-device-mobile .cl-promo { min-height: 200px !important; border-radius: 14px !important; }
    body.tm-device-mobile .cl-promo-content { padding: 20px 18px !important; }
    body.tm-device-mobile .cl-promo-title { font-size: 22px !important; }
    body.tm-device-mobile .cl-promo-sub { display: none !important; }
    body.tm-device-mobile .cl-section-head { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important; }
    body.tm-device-mobile .cl-section-title { font-size: 22px !important; }
    body.tm-device-mobile .cl-section-sub { font-size: 13px !important; }

/* ════════════════════════════════════════════════════════════════
   LANGUAGE SWITCHER + MOBILE DRAWER TOOLS
   Added for multi-lang support — only renders when the merchant
   has storefront_language in {multi, both} (header.blade.php gate).
   ════════════════════════════════════════════════════════════════ */

/* Desktop trigger pill — globe icon + current locale code */
.cl-lang-dd { position: relative; display: inline-block; }
.cl-lang-trigger {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    width: auto !important;
    min-width: 56px;
    padding: 0 10px !important;
    border-radius: 999px !important;
    background: transparent;
    color: var(--cl-text);
    font: 600 12.5px/1 var(--cl-font);
    letter-spacing: .02em;
    cursor: pointer;
    transition: background .18s var(--cl-ease), color .18s var(--cl-ease);
}
.cl-lang-trigger i { font-size: 13px; opacity: .8; }
.cl-lang-current { font-weight: 700; }
.cl-lang-trigger:hover { background: var(--cl-bg-2); color: var(--cl-secondary); }

/* Dropdown menu */
.cl-lang-menu {
    position: absolute;
    top: calc(100% + 8px);
    inset-inline-end: 0;
    min-width: 160px;
    background: var(--cl-surface);
    border: 1px solid var(--cl-border);
    border-radius: 12px;
    box-shadow: 0 12px 32px -8px rgba(15,23,42,.15), 0 4px 8px -4px rgba(15,23,42,.08);
    padding: 6px;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: opacity .18s var(--cl-ease), transform .18s var(--cl-ease), visibility .18s linear;
}
.cl-lang-dd.is-open .cl-lang-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    transition: opacity .18s var(--cl-ease), transform .18s var(--cl-ease), visibility 0s linear;
}
.cl-lang-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    padding: 9px 12px;
    background: transparent;
    border: 0;
    border-radius: 8px;
    color: var(--cl-text);
    font: 500 13.5px/1 var(--cl-font);
    text-align: start;
    cursor: pointer;
    transition: background .15s var(--cl-ease), color .15s var(--cl-ease);
}
.cl-lang-item:hover { background: var(--cl-bg-2); }
.cl-lang-item.is-active { color: var(--cl-secondary); background: var(--cl-bg-2); }
.cl-lang-check { font-size: 11px; color: var(--cl-secondary); }

/* Dark mode tweaks */
html[data-cl-mode="dark"] .cl-lang-menu {
    box-shadow: 0 12px 32px -8px rgba(0,0,0,.5), 0 4px 8px -4px rgba(0,0,0,.3);
}

/* ── Mobile drawer tools row (lang + mode) ── */
.cl-drawer-tools {
    padding: 16px 20px;
    border-top: 1px solid var(--cl-border);
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.cl-drawer-tools-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.cl-drawer-tools-label {
    font: 600 13px/1 var(--cl-font);
    color: var(--cl-text-2);
}
.cl-drawer-lang {
    display: inline-flex;
    border: 1px solid var(--cl-border);
    border-radius: 999px;
    overflow: hidden;
    background: var(--cl-bg-2);
}
.cl-drawer-lang-btn {
    padding: 7px 16px;
    background: transparent;
    border: 0;
    color: var(--cl-text-2);
    font: 600 12.5px/1 var(--cl-font);
    cursor: pointer;
    transition: background .15s var(--cl-ease), color .15s var(--cl-ease);
}
.cl-drawer-lang-btn:hover { color: var(--cl-text); }
.cl-drawer-lang-btn.is-active {
    background: var(--cl-secondary);
    color: #fff;
}
.cl-drawer-mode-toggle {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid var(--cl-border);
    background: var(--cl-bg-2);
    color: var(--cl-text);
    font-size: 14px;
    cursor: pointer;
    transition: background .18s var(--cl-ease), border-color .18s var(--cl-ease);
}
.cl-drawer-mode-toggle:hover { background: var(--cl-surface); border-color: var(--cl-secondary); }
