/*
Theme Name: Toolcenter
Theme URI: https://toolcenter.ma
Author: Toolcenter
Description: FORGE — Premium industrial tools ecommerce for Morocco
Version: 3.0.0
Requires at least: 6.0
WC requires at least: 7.0
WC tested up to: 10.0
Text Domain: toolcenter
*/

/* ═══════════════════════════════════════════════════════
   DESIGN SYSTEM — FORGE
   ═══════════════════════════════════════════════════════ */
:root {
  /* Colors */
  --c-orange:   #FF4500;
  --c-orange-d: #CC3700;
  --c-orange-l: #FF6A35;
  --c-orange-bg:#FFF3EE;
  --c-orange-10:rgba(255,69,0,.10);
  --c-black:    #111111;
  --c-dark:     #1A1A1A;
  --c-dark-2:   #242424;
  --c-dark-3:   #2F2F2F;
  --c-gold:     #F5A623;
  --c-white:    #FFFFFF;
  --c-off:      #F7F5F1;
  --c-surface:  #FAFAF8;
  --c-gray:     #888888;
  --c-gray-l:   #CCCCCC;
  --c-border:   #E5E5E0;
  --c-border-d: #2E2E2E;
  --c-red:      #E53E3E;
  --c-green:    #2D9B51;

  /* Typography */
  --f-head: 'Barlow Condensed', sans-serif;
  --f-body: 'Plus Jakarta Sans', system-ui, sans-serif;

  /* Spacing & Shape */
  --max:  1400px;
  --r:    6px;
  --r-lg: 12px;
  --r-xl: 20px;

  /* Shadows */
  --sh-sm: 0 2px 8px rgba(0,0,0,.06);
  --sh:    0 4px 20px rgba(0,0,0,.10);
  --sh-lg: 0 12px 40px rgba(0,0,0,.16);
  --sh-xl: 0 24px 60px rgba(0,0,0,.22);

  /* Motion */
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,.55,.45,1);
  --t: .24s var(--ease);
  --t-slow: .6s var(--ease);
}

/* ═══════════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);color:var(--c-black);background:var(--c-white);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:color var(--t)}
img{display:block;max-width:100%;height:auto}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit;line-height:inherit}
input,select,textarea{font:inherit;outline:none}
svg{flex-shrink:0}

/* ═══════════════════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════════════════ */
.tc-wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ═══════════════════════════════════════════════════════
   TYPOGRAPHY UTILITIES
   ═══════════════════════════════════════════════════════ */
.tc-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-head);font-size:12px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--c-orange);
}
.tc-eyebrow::before{
  content:'';display:block;width:24px;height:2px;background:var(--c-orange);
}
.tc-title{
  font-family:var(--f-head);font-size:clamp(36px,4vw,56px);
  font-weight:800;line-height:1.05;letter-spacing:-1px;
  text-transform:uppercase;color:var(--c-black);
}
.tc-title--white{color:var(--c-white)}
.tc-title--sm{font-size:clamp(26px,3vw,38px)}
.tc-section-label{
  display:inline-block;font-family:var(--f-head);font-size:11px;
  font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--c-orange);padding:5px 14px;border:1.5px solid var(--c-orange);
  border-radius:2px;
}

/* Section head layout */
.tc-sh{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.tc-sh-left{display:flex;flex-direction:column;gap:10px}
.tc-see-all{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-head);font-size:13px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--c-black);
  border-bottom:2px solid var(--c-black);padding-bottom:2px;
  transition:var(--t);white-space:nowrap;
}
.tc-see-all svg{transition:transform var(--t)}
.tc-see-all:hover{color:var(--c-orange);border-color:var(--c-orange)}
.tc-see-all:hover svg{transform:translateX(4px)}

/* ═══════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════ */
.tc-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--f-head);font-size:14px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 32px;transition:var(--t);cursor:pointer;
  white-space:nowrap;border:2px solid transparent;
}
.tc-btn-primary{background:var(--c-orange);color:#fff;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}
.tc-btn-primary:hover{background:var(--c-orange-d);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,69,0,.4)}
.tc-btn-dark{background:var(--c-black);color:#fff}
.tc-btn-dark:hover{background:var(--c-dark-2);color:#fff;transform:translateY(-2px)}
.tc-btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.tc-btn-outline:hover{background:#fff;color:var(--c-black);border-color:#fff}
.tc-btn-outline-dark{background:transparent;color:var(--c-black);border-color:var(--c-black)}
.tc-btn-outline-dark:hover{background:var(--c-black);color:#fff}
.tc-btn-sm{padding:10px 22px;font-size:12px}
.tc-btn-full{width:100%;justify-content:center}

/* ═══════════════════════════════════════════════════════
   TOP BAR
   ═══════════════════════════════════════════════════════ */
.tc-topbar{
  background:var(--c-black);color:rgba(255,255,255,.75);
  padding:9px 0;font-size:12.5px;border-bottom:1px solid var(--c-dark-3);
}
.tc-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.tc-topbar-msg{display:flex;align-items:center;gap:10px;font-weight:500}
.tc-topbar-msg svg{color:var(--c-orange)}
.tc-topbar-msg strong{color:var(--c-orange-l)}
.tc-topbar-right{display:flex;align-items:center;gap:20px}
.tc-topbar-right a{display:flex;align-items:center;gap:5px;color:rgba(255,255,255,.6);font-size:12px;transition:var(--t)}
.tc-topbar-right a:hover{color:#fff}
.tc-topbar-wa{
  background:linear-gradient(135deg,#25D366,#1db954);
  color:#fff!important;padding:4px 14px;font-weight:700;font-size:12px;border-radius:2px;
}
.tc-topbar-wa:hover{opacity:.9;color:#fff!important}
.tc-topbar-devis{
  background:var(--c-orange);
  color:#fff!important;padding:4px 14px;font-weight:700;font-size:12px;border-radius:2px;
  display:flex;align-items:center;gap:5px;
}
.tc-topbar-devis:hover{background:var(--c-orange-d);color:#fff!important}

/* ═══════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════ */
.tc-header{
  background:var(--c-white);border-bottom:1px solid var(--c-border);
  position:sticky;top:0;z-index:800;transition:box-shadow var(--t);
}
.tc-header.scrolled{box-shadow:var(--sh-lg)}
.tc-header-grid{
  display:grid;grid-template-columns:200px 1fr auto;
  align-items:center;gap:28px;padding:14px 0;min-height:68px;
}

/* Logo */
.tc-logo-wrap{display:flex;align-items:center}
.tc-logo-wrap .custom-logo-link{display:flex!important;align-items:center}
.tc-logo-wrap .custom-logo-link img.custom-logo,
.tc-logo-wrap img.custom-logo{height:48px!important;width:auto!important;max-width:200px!important;object-fit:contain!important;display:block!important}
.tc-logo-text{display:flex;flex-direction:column;text-decoration:none}
.tc-logo-name{font-family:var(--f-head);font-size:30px;font-weight:900;color:var(--c-black);letter-spacing:-1.5px;line-height:1;text-transform:uppercase}
.tc-logo-name em{color:var(--c-orange);font-style:normal}
.tc-logo-sub{font-family:var(--f-head);font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--c-gray);margin-top:2px}

/* Search */
.tc-search-wrap{width:100%}
.tc-search-form{
  display:flex;height:46px;
  border:1.5px solid var(--c-border);background:var(--c-surface);
  transition:border-color var(--t),box-shadow var(--t);
}
.tc-search-form:focus-within{border-color:var(--c-orange);box-shadow:0 0 0 3px rgba(255,69,0,.12);background:var(--c-white)}
.tc-search-input{flex:1;border:none;padding:0 18px;font-size:14px;color:var(--c-black);background:transparent;min-width:0}
.tc-search-input::placeholder{color:var(--c-gray)}
.tc-search-btn{background:var(--c-orange);color:#fff;border:none;padding:0 20px;display:flex;align-items:center;cursor:pointer;transition:background var(--t)}
.tc-search-btn:hover{background:var(--c-orange-d)}

/* Header actions */
.tc-header-actions{display:flex;align-items:center;gap:2px}
.tc-action-btn{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:8px 12px;color:var(--c-black);font-size:10px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;transition:var(--t);
  cursor:pointer;background:none;border:none;text-decoration:none;
  min-width:54px;
}
.tc-action-btn:hover{color:var(--c-orange);background:var(--c-orange-bg)}
.tc-cart-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}
.tc-cart-badge{
  position:absolute;top:-7px;right:-9px;min-width:18px;height:18px;
  background:var(--c-orange);color:#fff;font-size:10px;font-weight:800;
  border-radius:2px;display:flex;align-items:center;justify-content:center;
  padding:0 4px;opacity:0;transition:var(--t);font-family:var(--f-head);
}
.tc-cart-badge.active{opacity:1}

/* ═══════════════════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════════════════ */
.tc-nav{background:var(--c-black)}
.tc-nav-inner{display:flex;align-items:stretch;min-height:48px}
.tc-menu{display:flex;align-items:stretch;margin:0;padding:0}
.tc-menu>li{position:relative}
.tc-menu-link{
  display:flex;align-items:center;gap:6px;padding:0 18px;height:48px;
  font-family:var(--f-head);font-size:13px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,.8);transition:var(--t);white-space:nowrap;
}
.tc-menu-link svg{opacity:.5;transition:var(--t)}
.tc-menu-link:hover,.tc-menu-link.active{color:#fff;background:rgba(255,255,255,.06)}
.tc-menu-link:hover svg{opacity:1;transform:rotate(180deg)}
.tc-menu-promo{color:var(--c-orange-l)!important}
.tc-menu-promo .tc-promo-tag{background:var(--c-orange);color:#fff;font-size:10px;font-weight:800;padding:2px 7px;letter-spacing:1px}
.tc-menu-promo:hover{color:var(--c-orange-l)!important;background:rgba(255,69,0,.12)!important}

/* Mega menu */
.tc-has-mega{position:static!important}
.tc-mega-panel{
  position:fixed;top:auto;left:0;right:0;background:var(--c-white);
  box-shadow:var(--sh-xl);border-top:3px solid var(--c-orange);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:var(--t);z-index:900;
  max-height:80vh;overflow-y:auto;
}
.tc-has-mega:hover .tc-mega-panel{opacity:1;visibility:visible;transform:translateY(0)}
.tc-mega-inner{padding:28px 24px}
.tc-mega-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--c-border)}
.tc-mega-header strong{font-family:var(--f-head);font-size:15px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--c-black)}
.tc-mega-header a{font-family:var(--f-head);font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--c-orange)}
/* Mega menu — hierarchical columns layout */
.tc-mega-cols{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:0}
.tc-mega-col-group{padding:0 14px 16px 0;border-right:1px solid var(--c-border)}
.tc-mega-col-group:last-child{border-right:none;padding-right:0}
.tc-mega-col-title{
  display:flex;align-items:center;gap:7px;
  font-family:var(--f-head);font-size:11.5px;font-weight:800;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--c-black);
  text-decoration:none;padding:10px 0 8px;
  border-bottom:2px solid var(--c-orange);margin-bottom:8px;transition:var(--t);
}
.tc-mega-col-title:hover{color:var(--c-orange)}
.tc-mega-col-title svg{color:var(--c-orange);flex-shrink:0}
.tc-mega-col-title img{width:16px;height:16px;object-fit:contain}
.tc-mega-count{margin-left:auto;font-size:10px;font-weight:800;background:var(--c-orange);color:#fff;padding:1px 6px;border-radius:10px;font-family:var(--f-body);letter-spacing:0}
.tc-mega-sub-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px}
.tc-mega-sub-list li a{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--c-gray);padding:5px 0;text-decoration:none;transition:var(--t);border-bottom:1px solid transparent}
.tc-mega-sub-list li a:hover{color:var(--c-orange);padding-left:4px}
.tc-mega-sub-list li a span{font-size:10px;color:var(--c-gray-l)}
/* Fallback flat grid */
.tc-mega-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.tc-mega-cat{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:16px 8px;text-align:center;transition:var(--t);
  text-decoration:none;color:var(--c-black);border:1.5px solid transparent;
}
.tc-mega-cat:hover{border-color:var(--c-orange);background:var(--c-orange-bg);color:var(--c-orange)}
.tc-mega-cat img{width:40px;height:40px;object-fit:contain}
.tc-mega-cat-icon{width:44px;height:44px;background:var(--c-off);display:flex;align-items:center;justify-content:center;transition:var(--t)}
.tc-mega-cat:hover .tc-mega-cat-icon{background:var(--c-orange);color:#fff}
.tc-mega-cat span{font-family:var(--f-head);font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;line-height:1.3}
.tc-mega-cat small{font-size:10px;color:var(--c-gray)}

/* Desktop/Mobile icon visibility */
.tc-mobile-icon{display:none!important}
.tc-desktop-icon{display:flex}

/* Hamburger — used in both nav (desktop unused) and header (mobile) */
.tc-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;padding:10px;cursor:pointer;background:none;border:none;
  border-radius:var(--r-sm);transition:var(--t);flex-shrink:0}
.tc-hamburger:hover{background:var(--c-orange-bg)}
.tc-hamburger span{display:block;width:20px;height:2px;background:var(--c-black);transition:var(--t);border-radius:1px}
.tc-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.tc-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.tc-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile search bar */
.tc-mobile-search-bar{
  display:none;background:var(--c-off);border-bottom:1px solid var(--c-border);
  padding:0;max-height:0;overflow:hidden;
  transition:max-height .3s var(--ease),padding .3s var(--ease);
}
.tc-mobile-search-bar.open{max-height:72px;padding:10px 0;display:block}
.tc-mobile-search-form{display:flex;height:44px;border:1.5px solid var(--c-border);background:var(--c-white);transition:border-color var(--t)}
.tc-mobile-search-form:focus-within{border-color:var(--c-orange)}
.tc-mobile-search-input{flex:1;border:none;padding:0 14px;font-size:14px;color:var(--c-black);background:transparent}
.tc-mobile-search-input::placeholder{color:var(--c-gray);font-size:13px}
.tc-mobile-search-submit{background:var(--c-orange);color:#fff;border:none;padding:0 16px;cursor:pointer;display:flex;align-items:center}

/* ═══════════════════════════════════════════════════════
   MOBILE DRAWER
   ═══════════════════════════════════════════════════════ */
.tc-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:899;opacity:0;visibility:hidden;transition:var(--t);backdrop-filter:blur(4px)}
.tc-drawer-overlay.open{opacity:1;visibility:visible}
.tc-drawer{position:fixed;top:0;left:-100%;width:320px;max-width:90vw;height:100vh;background:var(--c-black);z-index:900;overflow-y:auto;transition:left .32s var(--ease);display:flex;flex-direction:column}
.tc-drawer.open{left:0}
.tc-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--c-border-d)}
.tc-drawer-logo .tc-logo-name{font-size:24px;color:#fff}
.tc-drawer-close{color:rgba(255,255,255,.6);cursor:pointer;padding:6px;line-height:1;background:none;border:none;transition:var(--t)}
.tc-drawer-close:hover{color:#fff;transform:rotate(90deg)}
.tc-drawer-search{padding:14px 20px;border-bottom:1px solid var(--c-border-d)}
.tc-drawer-search input{width:100%;padding:10px 14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:13px}
.tc-drawer-search input::placeholder{color:rgba(255,255,255,.4)}
.tc-drawer-nav{display:flex;flex-direction:column;padding:8px 0}
.tc-drawer-nav a{display:block;padding:13px 20px;color:rgba(255,255,255,.8);font-family:var(--f-head);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.05);transition:var(--t)}
.tc-drawer-nav a:hover{color:#fff;background:rgba(255,255,255,.05);padding-left:28px}
.tc-drawer-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 20px;color:rgba(255,255,255,.8);font-family:var(--f-head);font-size:14px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border:none;border-bottom:1px solid rgba(255,255,255,.05);background:none;cursor:pointer;font:inherit;transition:var(--t)}
.tc-drawer-toggle:hover{background:rgba(255,255,255,.05)}
.tc-drawer-toggle svg{transition:var(--t)}
.tc-drawer-toggle.open svg{transform:rotate(180deg)}
.tc-drawer-sub{display:none;background:rgba(0,0,0,.25)}
.tc-drawer-sub.open{display:block}
.tc-drawer-sub a{padding-left:32px!important;font-size:13px!important}

/* ═══════════════════════════════════════════════════════
   CART PANEL
   ═══════════════════════════════════════════════════════ */
/* Cart panel: use transform instead of right to avoid scrollWidth pollution */
.tc-cart-panel{
  position:fixed;top:0;right:0;width:420px;height:100vh;
  background:var(--c-white);z-index:901;display:flex;flex-direction:column;
  transform:translateX(calc(100% + 4px));
  transition:transform .32s var(--ease);
  box-shadow:-4px 0 40px rgba(0,0,0,.15);
}
.tc-cart-panel.open{transform:translateX(0)}
.tc-cart-panel-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:2px solid var(--c-black)}
.tc-cart-panel-head h3{font-family:var(--f-head);font-size:20px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--c-black);display:flex;align-items:center;gap:10px}
.tc-cart-panel-head h3 svg{color:var(--c-orange)}
.tc-cart-close{color:var(--c-gray);cursor:pointer;padding:6px;background:none;border:none;line-height:1;transition:var(--t)}
.tc-cart-close:hover{color:var(--c-orange);transform:rotate(90deg)}
.tc-cart-panel-body{flex:1;overflow-y:auto;padding:16px 24px}
.tc-cart-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--c-border)}
.tc-cart-item:last-child{border-bottom:none}
.tc-cart-item img{width:72px;height:72px;object-fit:cover;border:1px solid var(--c-border);flex-shrink:0}
.tc-cart-item-name{font-size:13px;font-weight:600;color:var(--c-black);margin-bottom:4px;line-height:1.35}
.tc-cart-item-price{font-family:var(--f-head);font-size:16px;font-weight:800;color:var(--c-orange)}
.tc-cart-item-qty{font-size:12px;color:var(--c-gray);margin-top:3px}
.tc-cart-empty{text-align:center;padding:48px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}
.tc-cart-empty svg{color:var(--c-border)}
.tc-cart-empty p{font-size:14px;color:var(--c-gray)}
.tc-cart-panel-foot{padding:20px 24px;border-top:2px solid var(--c-black);background:var(--c-off)}
.tc-cart-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}
.tc-cart-total span{font-family:var(--f-head);font-size:14px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--c-gray)}
.tc-cart-total strong{font-family:var(--f-head);font-size:26px;font-weight:900;color:var(--c-orange)}
.tc-cart-panel-foot .tc-btn{margin-bottom:8px}
.tc-cart-panel-foot .tc-btn:last-child{margin-bottom:0}

/* ═══════════════════════════════════════════════════════
   HERO — FORGE
   ═══════════════════════════════════════════════════════ */
.tc-hero{
  position:relative;min-height:min(90vh,640px);background:var(--c-black);
  display:flex;align-items:center;overflow:hidden;
}

/* Diagonal pattern background */
.tc-hero::before{
  content:'';position:absolute;inset:0;
  background-image:repeating-linear-gradient(
    -55deg,
    transparent,transparent 40px,
    rgba(255,255,255,.015) 40px,rgba(255,255,255,.015) 41px
  );
}

/* Orange vertical accent */
.tc-hero::after{
  content:'';position:absolute;right:38%;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,transparent,var(--c-orange),transparent);
  opacity:.6;
}

/* Swiper setup */
.tc-hero .swiper{position:absolute;inset:0;height:100%!important}
.tc-hero-slide{position:relative;width:100%;height:100%;display:flex;align-items:center}
.tc-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 8s ease;mix-blend-mode:soft-light;opacity:.3}
.tc-hero .swiper-slide-active .tc-hero-bg{transform:scale(1.05)}

/* Content */
.tc-hero-content-wrap{position:relative;z-index:2;width:100%;padding:80px 0}
.tc-hero-grid{display:grid;grid-template-columns:1fr auto;align-items:center;gap:60px}
.tc-hero-left{max-width:620px}
.tc-hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-head);font-size:11px;font-weight:700;
  letter-spacing:3px;text-transform:uppercase;color:var(--c-orange);
  margin-bottom:20px;
}
.tc-hero-badge::before{content:'';display:block;width:20px;height:2px;background:var(--c-orange)}
.tc-hero-title{
  font-family:var(--f-head);font-size:clamp(48px,7vw,92px);font-weight:900;
  color:#fff;line-height:.95;letter-spacing:-3px;text-transform:uppercase;
  margin-bottom:20px;
}
.tc-hero-title em{color:var(--c-orange);font-style:normal;display:block}
.tc-hero-sub{font-size:16px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:36px;max-width:480px}
.tc-hero-ctas{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* Right side stats */
.tc-hero-stats{display:flex;flex-direction:column;gap:2px;flex-shrink:0}
.tc-hero-stat{
  padding:20px 28px;border-left:3px solid var(--c-orange-10);
  transition:var(--t);
}
.tc-hero-stat:hover{border-left-color:var(--c-orange);background:rgba(255,255,255,.03)}
.tc-hero-stat-num{
  font-family:var(--f-head);font-size:clamp(36px,4vw,52px);font-weight:900;
  color:#fff;line-height:1;letter-spacing:-2px;margin-bottom:4px;
}
.tc-hero-stat-num span{color:var(--c-orange)}
.tc-hero-stat-lbl{font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* Swiper pagination */
.tc-hero .swiper-pagination{position:absolute;bottom:32px;left:24px;right:auto;width:auto;display:flex;gap:8px;align-items:center}
.tc-hero .swiper-pagination-bullet{width:6px;height:6px;background:rgba(255,255,255,.35);opacity:1;transition:var(--t);border-radius:0}
.tc-hero .swiper-pagination-bullet-active{background:var(--c-orange);width:28px}

/* ═══════════════════════════════════════════════════════
   TRUST BAR
   ═══════════════════════════════════════════════════════ */
.tc-trust{background:var(--c-off);border-bottom:1px solid var(--c-border)}
.tc-trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.tc-trust-item{display:flex;align-items:center;gap:16px;padding:20px 24px;border-right:1px solid var(--c-border);transition:var(--t);position:relative}
.tc-trust-item:last-child{border-right:none}
.tc-trust-item::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--c-orange);transform:scaleX(0);transition:var(--t)}
.tc-trust-item:hover::before{transform:scaleX(1)}
.tc-trust-item:hover{background:var(--c-white)}
.tc-trust-icon{width:44px;height:44px;background:var(--c-black);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--t)}
.tc-trust-item:hover .tc-trust-icon{background:var(--c-orange)}
.tc-trust-icon svg{color:#fff}
.tc-trust-label{font-family:var(--f-head);font-size:15px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--c-black);display:block;line-height:1.2}
.tc-trust-sub{font-size:12px;color:var(--c-gray);display:block;margin-top:2px}

/* ═══════════════════════════════════════════════════════
   CATEGORY GRID — image tiles
   ═══════════════════════════════════════════════════════ */
.tc-section{padding:80px 0}
.tc-section-sm{padding:56px 0}
.tc-section-dark{background:var(--c-black)}
.tc-section-off{background:var(--c-off)}

.tc-cats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto auto;
  gap:3px;
}
/* First 2 cats span double height — more visual impact */
.tc-cat-tile:nth-child(1),.tc-cat-tile:nth-child(2){grid-row:span 1}

.tc-cat-tile{
  position:relative;overflow:hidden;background:var(--c-off);
  aspect-ratio:1/1;cursor:pointer;text-decoration:none;display:flex;
}
.tc-cat-tile:nth-child(-n+2){aspect-ratio:4/3}
.tc-cat-img-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transition:transform .6s var(--ease-out);
}
.tc-cat-tile:hover .tc-cat-img-bg{transform:scale(1.08)}
.tc-cat-icon-wrap{
  position:absolute;inset:0;background:linear-gradient(135deg,var(--c-off),var(--c-border));
  display:flex;align-items:center;justify-content:center;
}
.tc-cat-icon-wrap svg{color:var(--c-gray);transition:var(--t)}
.tc-cat-tile:hover .tc-cat-icon-wrap svg{color:var(--c-orange)}
.tc-cat-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 50%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:20px;transition:var(--t);
}
.tc-cat-tile:hover .tc-cat-overlay{background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.5) 50%,rgba(0,0,0,.1) 100%)}
.tc-cat-name{
  font-family:var(--f-head);font-size:18px;font-weight:800;
  letter-spacing:.5px;text-transform:uppercase;color:#fff;
  line-height:1.2;display:block;
}
.tc-cat-count{font-size:11px;color:rgba(255,255,255,.55);margin-top:3px;font-weight:500}
.tc-cat-arrow{
  position:absolute;top:16px;right:16px;width:32px;height:32px;
  background:var(--c-orange);display:flex;align-items:center;justify-content:center;
  color:#fff;opacity:0;transform:translate(8px,-8px);transition:var(--t);
}
.tc-cat-tile:hover .tc-cat-arrow{opacity:1;transform:translate(0,0)}
/* Fallback for cats without images */
.tc-cat-tile.no-img .tc-cat-overlay{background:linear-gradient(135deg,var(--c-black),var(--c-dark-2))}
.tc-cat-tile.no-img .tc-cat-name{color:#fff}

/* ═══════════════════════════════════════════════════════
   PRODUCT CARDS — PREMIUM v2
   ═══════════════════════════════════════════════════════ */
.tc-products-slider{position:relative;padding:0 32px}
.tc-products-slider .swiper{overflow:visible!important}
.tc-swiper-prev,.tc-swiper-next{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;background:var(--c-black);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--t);z-index:10;border:none;
}
.tc-swiper-prev{left:0}
.tc-swiper-next{right:0}
.tc-swiper-prev:hover,.tc-swiper-next:hover{background:var(--c-orange)}
.swiper-slide{height:auto;display:flex}

/* ─── CARD CONTAINER ──────────────────────────────── */
.tc-card{
  background:var(--c-white);
  border:1.5px solid var(--c-border-light);
  display:flex;flex-direction:column;
  width:100%;height:100%;
  position:relative;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease), transform .2s var(--ease);
  border-radius:0;
  overflow:hidden;
}
.tc-card:hover{
  border-color:var(--c-orange);
  box-shadow:0 8px 32px rgba(255,69,0,.15), 0 2px 8px rgba(0,0,0,.08);
  transform:translateY(-3px);
}

/* ─── BADGES ──────────────────────────────────────── */
.tc-card-badges{
  position:absolute;top:10px;left:10px;z-index:6;
  display:flex;flex-direction:column;gap:4px;
}
.tc-badge-sale{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--c-orange);color:#fff;
  font-family:var(--f-head);font-size:11px;font-weight:900;
  letter-spacing:1px;padding:4px 10px;
  clip-path:polygon(0 0,calc(100% - 5px) 0,100% 5px,100% 100%,0 100%);
  box-shadow:0 2px 8px rgba(255,69,0,.4);
}
.tc-badge-new{
  display:inline-block;background:var(--c-green);color:#fff;
  font-family:var(--f-head);font-size:11px;font-weight:900;
  letter-spacing:1px;padding:4px 10px;
}
.tc-badge-oos{
  display:inline-block;background:var(--c-gray);color:#fff;
  font-family:var(--f-head);font-size:10px;font-weight:700;
  letter-spacing:1px;padding:3px 8px;
}

/* ─── WISHLIST ────────────────────────────────────── */
.tc-card-wish{
  position:absolute;top:10px;right:10px;z-index:6;
  width:32px;height:32px;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(4px);
  border:1px solid var(--c-border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-gray);
  cursor:pointer;
  transition:var(--t);
  /* Always visible on mobile */
  opacity:1;transform:scale(1);
}
@media(min-width:681px){
  .tc-card-wish{opacity:0;transform:scale(.8)}
  .tc-card:hover .tc-card-wish{opacity:1;transform:scale(1)}
}
.tc-card-wish:hover,.tc-card-wish.wished{
  background:var(--c-red);border-color:var(--c-red);color:#fff;
}

/* ─── IMAGE WRAP ──────────────────────────────────── */
.tc-card-img-wrap{
  display:block;overflow:hidden;
  aspect-ratio:4/3;
  background:var(--c-off);
  position:relative;text-decoration:none;
  border-bottom:1px solid var(--c-border-light);
}
.tc-card-img-wrap img{
  width:100%;height:100%;
  object-fit:contain;
  object-position:center;
  padding:12px;
  transition:transform .5s var(--ease-out);
  display:block;
}
.tc-card:hover .tc-card-img-wrap img{transform:scale(1.07)}

/* Hover overlay — view product CTA appears on image hover */
.tc-card-overlay-hover{
  position:absolute;inset:0;
  background:rgba(22,33,62,.55);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .25s var(--ease);
  backdrop-filter:blur(1px);
}
.tc-card:hover .tc-card-overlay-hover{opacity:1}
.tc-card-overlay-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--c-white);color:var(--c-black);
  font-family:var(--f-head);font-size:12px;font-weight:800;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:10px 20px;
  transform:translateY(8px);transition:transform .25s var(--ease);
  box-shadow:var(--sh);
}
.tc-card:hover .tc-card-overlay-cta{transform:translateY(0)}
/* Mobile: hide complex overlay, keep simple */
@media(max-width:680px){
  .tc-card-overlay-hover{display:none}
}

/* ─── BODY ────────────────────────────────────────── */
.tc-card-body{
  padding:14px 14px 8px;
  flex:1;
  display:flex;flex-direction:column;
  gap:4px;
}
/* Category link — clickable breadcrumb */
.tc-card-cat{
  font-family:var(--f-head);
  font-size:10px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  color:var(--c-orange);
  text-decoration:none;
  transition:opacity var(--t);
  display:block;
}
.tc-card-cat:hover{opacity:.75;color:var(--c-orange)}
span.tc-card-cat{cursor:default}
/* Product name */
.tc-card-name{
  font-family:var(--f-body);
  font-size:14px;font-weight:700;
  color:var(--c-black);line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;flex:1;
  transition:color var(--t);
  text-decoration:none;
  margin-top:2px;
}
.tc-card-name:hover{color:var(--c-orange)}
/* SKU */
.tc-card-sku{
  font-size:10px;color:var(--c-gray-l);
  font-family:monospace;letter-spacing:.3px;
}
/* Price block */
.tc-card-price{
  display:flex;align-items:baseline;gap:8px;
  flex-wrap:wrap;margin-top:6px;
  padding-top:8px;
  border-top:1px solid var(--c-border-light);
}
.tc-price-now{
  font-family:var(--f-head);
  font-size:22px;font-weight:900;
  color:var(--c-orange);line-height:1;
  letter-spacing:-.5px;
}
.tc-price-now small{font-size:12px;font-weight:700;letter-spacing:0;opacity:.85}
.tc-price-was{
  font-size:12px;color:var(--c-gray-l);
  text-decoration:line-through;font-weight:400;
}
.tc-price-quote{font-size:13px;color:var(--c-gray);font-style:italic}

/* ─── FOOT / CTA ─────────────────────────────────── */
.tc-card-foot{padding:8px 14px 14px}
.tc-atc{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;height:42px;
  background:var(--c-black);color:#fff;
  font-family:var(--f-head);font-size:12px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;
  border:none;cursor:pointer;
  transition:background var(--t), transform .15s var(--ease), box-shadow .15s var(--ease);
  position:relative;overflow:hidden;
}
.tc-atc::before{
  content:'';position:absolute;inset:0;
  background:var(--c-orange);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s var(--ease);
}
.tc-atc:hover::before{transform:scaleX(1)}
.tc-atc:hover{color:#fff;box-shadow:0 4px 16px rgba(255,69,0,.35)}
.tc-atc svg,.tc-atc span{position:relative;z-index:1}
.tc-atc.success{background:var(--c-green)!important}
.tc-atc.success::before{display:none}
.tc-atc.loading{opacity:.5;pointer-events:none}
.tc-atc-view{
  background:var(--c-off)!important;color:var(--c-gray)!important;
  border:1.5px solid var(--c-border)!important;
  font-size:11px!important;
}
.tc-atc-view::before{display:none}
.tc-atc-view:hover{background:var(--c-dark)!important;color:#fff!important;border-color:transparent!important}

/* ═══════════════════════════════════════════════════════
   PROMO STRIP — diagonal design
   ═══════════════════════════════════════════════════════ */
.tc-promo-strip{
  background:var(--c-orange);padding:60px 0;position:relative;overflow:hidden;
}
.tc-promo-strip::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(-55deg,transparent,transparent 20px,rgba(0,0,0,.05) 20px,rgba(0,0,0,.05) 21px);
}
.tc-promo-strip::after{
  content:'';position:absolute;right:-60px;top:-60px;
  width:320px;height:320px;border-radius:50%;
  background:rgba(255,255,255,.08);
}
.tc-promo-strip-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:40px}
.tc-promo-strip-content{color:#fff}
.tc-promo-strip-eyebrow{font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;opacity:.75;margin-bottom:10px;display:block}
.tc-promo-strip-title{font-family:var(--f-head);font-size:clamp(32px,4vw,52px);font-weight:900;color:#fff;line-height:1;text-transform:uppercase;letter-spacing:-2px;margin-bottom:8px}
.tc-promo-strip-sub{font-size:15px;opacity:.85;max-width:480px}
.tc-promo-strip-ctas{display:flex;flex-direction:column;gap:10px;flex-shrink:0}
.tc-promo-strip .tc-btn-outline{border-color:rgba(255,255,255,.5);padding:14px 32px}
.tc-promo-strip .tc-btn-dark{background:#fff;color:var(--c-orange);padding:14px 32px}
.tc-promo-strip .tc-btn-dark:hover{background:var(--c-black);color:#fff}

/* ═══════════════════════════════════════════════════════
   BRANDS — marquee
   ═══════════════════════════════════════════════════════ */
.tc-brands-section{background:var(--c-black);padding:48px 0;overflow:hidden;position:relative}
.tc-brands-section::before,.tc-brands-section::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;
}
.tc-brands-section::before{left:0;background:linear-gradient(90deg,var(--c-black),transparent)}
.tc-brands-section::after{right:0;background:linear-gradient(-90deg,var(--c-black),transparent)}
.tc-brands-label{text-align:center;margin-bottom:32px}
.tc-brands-label span{font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3)}
.tc-brands-track{display:flex;gap:0}
.tc-brands-swiper .swiper-slide{display:flex;align-items:center;justify-content:center}
.tc-brand-item{
  display:flex;align-items:center;justify-content:center;
  padding:12px 32px;height:64px;opacity:.3;
  filter:grayscale(1) brightness(2);
  transition:var(--t);cursor:default;border-right:1px solid rgba(255,255,255,.06);
}
.tc-brand-item:hover{opacity:.9;filter:none}
.tc-brand-item img{max-height:36px;max-width:100px;object-fit:contain}
.tc-brand-item-text{font-family:var(--f-head);font-size:15px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:#fff;white-space:nowrap}

/* ═══════════════════════════════════════════════════════
   NEWSLETTER
   ═══════════════════════════════════════════════════════ */
.tc-newsletter{background:var(--c-black);padding:80px 0;position:relative;overflow:hidden}
.tc-newsletter::before{
  content:'';position:absolute;left:-100px;top:-100px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(255,69,0,.08),transparent 70%);pointer-events:none;
}
.tc-newsletter-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.tc-newsletter-left{}
.tc-newsletter-eyebrow{display:flex;align-items:center;gap:8px;font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--c-orange);margin-bottom:14px}
.tc-newsletter-eyebrow::before{content:'';display:block;width:20px;height:2px;background:var(--c-orange)}
.tc-newsletter-title{font-family:var(--f-head);font-size:clamp(30px,3.5vw,46px);font-weight:900;color:#fff;line-height:1;text-transform:uppercase;letter-spacing:-2px;margin-bottom:12px}
.tc-newsletter-sub{font-size:15px;color:rgba(255,255,255,.5);line-height:1.7}
.tc-newsletter-form{display:flex;height:52px;border:1.5px solid rgba(255,255,255,.15);transition:border-color var(--t)}
.tc-newsletter-form:focus-within{border-color:var(--c-orange)}
.tc-newsletter-input{flex:1;padding:0 20px;background:rgba(255,255,255,.06);border:none;color:#fff;font-size:14px;min-width:0}
.tc-newsletter-input::placeholder{color:rgba(255,255,255,.3)}
.tc-newsletter-submit{background:var(--c-orange);color:#fff;border:none;padding:0 28px;font-family:var(--f-head);font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:var(--t);white-space:nowrap}
.tc-newsletter-submit:hover{background:var(--c-orange-d)}
.tc-newsletter-note{font-size:11.5px;color:rgba(255,255,255,.25);margin-top:10px}

/* ═══════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════ */
.tc-footer{background:#0A0A0A;color:rgba(255,255,255,.7);padding:72px 0 0;position:relative}
.tc-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--c-orange),transparent);
}
.tc-footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07)}
.tc-footer-logo .tc-logo-name{font-size:28px;color:#fff;display:block;margin-bottom:16px}
.tc-footer-logo .tc-logo-name em{color:var(--c-orange);font-style:normal}
.tc-footer-desc{font-size:13.5px;line-height:1.8;color:rgba(255,255,255,.45);margin-bottom:20px}
.tc-footer-contact{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.tc-footer-contact-row{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(255,255,255,.5)}
.tc-footer-contact-row svg{color:var(--c-orange);flex-shrink:0;margin-top:1px}
.tc-footer-contact-row a:hover{color:#fff}
.tc-footer-social{display:flex;gap:6px}
.tc-footer-social a{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:14px;transition:var(--t)}
.tc-footer-social a:hover{border-color:var(--c-orange);background:var(--c-orange);color:#fff}
.tc-footer-col-title{
  font-family:var(--f-head);font-size:13px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;color:#fff;
  margin-bottom:20px;padding-bottom:10px;
  border-bottom:2px solid var(--c-orange);display:inline-block;
}
.tc-footer-links{display:flex;flex-direction:column;gap:8px}
.tc-footer-links a{font-size:13px;color:rgba(255,255,255,.5);transition:var(--t);display:flex;align-items:center;gap:8px}
.tc-footer-links a::before{content:'—';color:var(--c-orange);opacity:0;transform:translateX(-6px);transition:var(--t);font-size:10px}
.tc-footer-links a:hover{color:#fff;padding-left:8px}
.tc-footer-links a:hover::before{opacity:1;transform:translateX(0)}
.tc-footer-bottom{padding:20px 0;border-top:1px solid rgba(255,255,255,.05)}
.tc-footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.tc-footer-copy{font-size:12.5px;color:rgba(255,255,255,.25)}
.tc-footer-copy a{color:rgba(255,255,255,.3)}
.tc-footer-copy a:hover{color:var(--c-orange)}
.tc-footer-pay{display:flex;align-items:center;gap:8px;font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.2)}
.tc-footer-pay svg{color:var(--c-orange)}

/* ═══════════════════════════════════════════════════════
   FLOATING ELEMENTS
   ═══════════════════════════════════════════════════════ */
.tc-wa-float{
  position:fixed;bottom:28px;right:28px;z-index:9998;
  width:54px;height:54px;background:#25D366;
  display:flex;align-items:center;justify-content:center;
  color:#fff;box-shadow:0 4px 24px rgba(37,211,102,.45);
  transition:var(--t);text-decoration:none;
}
.tc-wa-float:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(37,211,102,.6);color:#fff}
.tc-wa-float::before{content:'';position:absolute;inset:-6px;border:2px solid rgba(37,211,102,.3);animation:tc-pulse 2.5s infinite}
@keyframes tc-pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.3);opacity:0}100%{transform:scale(1);opacity:0}}

.tc-back-top{
  position:fixed;bottom:96px;right:28px;z-index:9997;
  width:44px;height:44px;background:var(--c-black);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--t);opacity:0;transform:translateY(10px);
  pointer-events:none;border:none;
}
.tc-back-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.tc-back-top:hover{background:var(--c-orange);transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════ */
.tc-toast{
  position:fixed;bottom:30px;left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--c-black);color:#fff;
  padding:13px 24px;font-size:13.5px;font-weight:500;
  z-index:9999;box-shadow:var(--sh-xl);
  transition:transform .35s var(--ease);
  border-left:3px solid var(--c-orange);
  max-width:380px;text-align:center;pointer-events:none;
}
.tc-toast.show{transform:translateX(-50%) translateY(0)}
.tc-toast a{color:var(--c-orange-l);text-decoration:underline;pointer-events:auto}

/* ═══════════════════════════════════════════════════════
   PAGE HERO
   ═══════════════════════════════════════════════════════ */
.tc-page-hero{background:var(--c-black);padding:40px 0;color:#fff;border-bottom:3px solid var(--c-orange)}
.tc-page-hero h1{font-family:var(--f-head);font-size:clamp(24px,4vw,40px);font-weight:900;color:#fff;text-transform:uppercase;letter-spacing:-1.5px;line-height:1}
.tc-page-hero .woocommerce-breadcrumb{margin-top:8px;font-size:12.5px;color:rgba(255,255,255,.4)}
.tc-page-hero .woocommerce-breadcrumb a{color:rgba(255,255,255,.4)}
.tc-page-hero .woocommerce-breadcrumb a:hover{color:var(--c-orange)}

/* ═══════════════════════════════════════════════════════
   WOOCOMMERCE SHOP LAYOUT
   ═══════════════════════════════════════════════════════ */
.tc-wc-wrap{padding:48px 0}
.tc-shop-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:28px;padding-bottom:20px;border-bottom:2px solid var(--c-black);flex-wrap:wrap}
.woocommerce-result-count{font-family:var(--f-head);font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--c-gray);margin:0}
.woocommerce-ordering select{padding:9px 14px;border:1.5px solid var(--c-border);font-size:13px;background:var(--c-white);color:var(--c-black);cursor:pointer;font-family:var(--f-body)}
.woocommerce-ordering select:focus{border-color:var(--c-orange);outline:none}
.tc-cat-filter{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:28px}
.tc-cat-filter-btn{padding:7px 18px;font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:1.5px solid var(--c-border);background:var(--c-white);color:var(--c-gray);cursor:pointer;transition:var(--t)}
.tc-cat-filter-btn:hover,.tc-cat-filter-btn.active{background:var(--c-black);border-color:var(--c-black);color:#fff}
.woocommerce ul.products{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:2px!important;margin:0!important;padding:0!important;list-style:none!important}
.woocommerce ul.products li.product{margin:0!important;padding:0!important;display:flex;flex-direction:column}
.woocommerce span.onsale{display:none!important}

/* ═══════════════════════════════════════════════════════
   WOOCOMMERCE SINGLE PRODUCT
   ═══════════════════════════════════════════════════════ */
.woocommerce div.product{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.woocommerce div.product .woocommerce-product-gallery{border:1px solid var(--c-border)}
.woocommerce div.product .product_title{font-family:var(--f-head);font-size:clamp(28px,4vw,44px);font-weight:900;text-transform:uppercase;letter-spacing:-2px;color:var(--c-black);line-height:1;margin-bottom:14px}
.woocommerce div.product p.price,.woocommerce div.product span.price{font-family:var(--f-head);font-size:34px;font-weight:900;color:var(--c-orange);margin-bottom:18px}
.woocommerce div.product p.price ins,.woocommerce div.product span.price ins{text-decoration:none}
.woocommerce div.product p.price del,.woocommerce div.product span.price del{font-size:18px;color:var(--c-gray-l)}
.woocommerce div.product form.cart .button,.single_add_to_cart_button{
  background:var(--c-orange)!important;color:#fff!important;border:none!important;
  padding:16px 40px!important;font-family:var(--f-head)!important;font-size:14px!important;
  font-weight:800!important;letter-spacing:2px!important;text-transform:uppercase!important;
  cursor:pointer!important;transition:var(--t)!important;
}
.woocommerce div.product form.cart .button:hover,.single_add_to_cart_button:hover{background:var(--c-orange-d)!important;transform:translateY(-2px)!important;box-shadow:0 8px 24px rgba(255,69,0,.4)!important}
.woocommerce div.product .woocommerce-tabs .tabs{border-bottom:2px solid var(--c-black)}
.woocommerce div.product .woocommerce-tabs .tabs li{border:none!important;background:transparent!important;margin:0!important;border-radius:0!important}
.woocommerce div.product .woocommerce-tabs .tabs li a{font-family:var(--f-head)!important;font-size:13px!important;font-weight:700!important;letter-spacing:1.5px!important;text-transform:uppercase!important;color:var(--c-gray)!important;padding:12px 20px!important}
.woocommerce div.product .woocommerce-tabs .tabs li.active a{color:var(--c-black)!important;border-bottom:2px solid var(--c-orange)!important}
.woocommerce div.product .woocommerce-tabs .tabs li::after,.woocommerce div.product .woocommerce-tabs .tabs::before{display:none!important}

/* WC Global button reset */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{background:var(--c-black)!important;color:#fff!important;border:none!important;padding:10px 24px!important;font-family:var(--f-head)!important;font-size:12px!important;font-weight:700!important;letter-spacing:1.5px!important;text-transform:uppercase!important;cursor:pointer!important;transition:var(--t)!important;border-radius:0!important}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover{background:var(--c-orange)!important;color:#fff!important}
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt{background:var(--c-orange)!important}
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{background:var(--c-orange-d)!important}

/* WC notices */
.woocommerce-message,.woocommerce-error,.woocommerce-info{border-radius:0!important;padding:14px 18px!important;font-size:13.5px!important;margin-bottom:20px!important;border-left-width:3px!important}
.woocommerce-message{background:rgba(45,155,81,.08)!important;border-left:3px solid var(--c-green)!important;color:#1a6b38!important}
.woocommerce-error{background:rgba(229,62,62,.08)!important;border-left:3px solid var(--c-red)!important;color:#c53030!important}

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb{font-size:12.5px;color:var(--c-gray);margin-bottom:20px}
.woocommerce .woocommerce-breadcrumb a{color:var(--c-gray)}
.woocommerce .woocommerce-breadcrumb a:hover{color:var(--c-orange)}

/* Price */
.woocommerce .price{color:var(--c-orange)!important;font-family:var(--f-head)!important;font-weight:900!important}
.woocommerce .price del{color:var(--c-gray-l)!important;font-weight:400!important}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span{border:1.5px solid var(--c-border)!important;color:var(--c-black)!important;padding:8px 14px!important;border-radius:0!important;font-family:var(--f-head)!important;font-weight:700!important;font-size:12px!important;letter-spacing:1px!important}
.woocommerce nav.woocommerce-pagination ul li a:hover,.woocommerce nav.woocommerce-pagination ul li span.current{background:var(--c-orange)!important;border-color:var(--c-orange)!important;color:#fff!important}

/* Cart & Checkout */
.woocommerce-cart .woocommerce-cart-form table.cart td,.woocommerce-cart .woocommerce-cart-form table.cart th{padding:14px 12px;border-bottom:1px solid var(--c-border);vertical-align:middle;font-size:14px}
.woocommerce-cart .woocommerce-cart-form table.cart th{font-family:var(--f-head);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--c-gray);border-bottom:2px solid var(--c-black);padding:12px 12px}
.woocommerce-checkout #customer_details{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row select{padding:11px 14px!important;border:1.5px solid var(--c-border)!important;border-radius:0!important;font-size:14px!important;transition:border-color var(--t)!important}
.woocommerce form .form-row input.input-text:focus,.woocommerce form .form-row select:focus{border-color:var(--c-orange)!important;box-shadow:none!important;outline:none!important}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a{display:block;padding:10px 16px;font-family:var(--f-head);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--c-gray);border:1.5px solid var(--c-border);transition:var(--t)}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover{background:var(--c-black);border-color:var(--c-black);color:#fff}
.woocommerce-cart .return-to-shop{text-align:center;margin-top:20px}
.woocommerce-cart .cart-empty{font-family:var(--f-head);font-size:18px;letter-spacing:1px;text-transform:uppercase;color:var(--c-gray);text-align:center;padding:40px 0}

/* WC loading */
.woocommerce .blockUI.blockOverlay::before{content:'';width:28px;height:28px;border:2px solid var(--c-border);border-top-color:var(--c-orange);border-radius:50%;animation:tc-spin .8s linear infinite;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
@keyframes tc-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* Variation swatches */
.wvs-pro-variation-items-wrapper{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px!important}
.variable-items-wrapper .variable-item{border-radius:0!important;transition:var(--t)!important}
.variable-items-wrapper .variable-item.selected{border-color:var(--c-orange)!important}
.variable-items-wrapper .variable-item:not(.disabled):hover{border-color:var(--c-orange)!important}
.woocommerce ul.products .wvs-pro-variation-items-wrapper,.woocommerce ul.products .variations_form,.woocommerce ul.products form.cart{display:none!important}

/* Elementor kit reset */
.e-con{all:unset}
.e-global__color{--e-global-color-primary:var(--c-orange)!important}

/* WVS loop hiding */
.woocommerce ul.products .wvs-pro-variation-items-wrapper,.woocommerce ul.products .variations_form{display:none!important}

/* WC toolbar */
.woocommerce-ordering{margin:0}

/* Misc fixes */
.woostify-mobile-menu,.woostify-sticky-header,#masthead.sticky-header{display:none!important}
.woocommerce-store-notice,.demo_store{display:none!important}
.tc-logo-wrap a img,.tc-logo-wrap .custom-logo{max-height:48px!important;width:auto!important;object-fit:contain!important;display:block!important}
.woocommerce-cart .product-thumbnail img{width:70px!important;height:70px!important;object-fit:cover!important}
.woocommerce div.product .woocommerce-product-gallery__image img{width:100%!important;height:auto!important;object-fit:contain!important}
[data-litespeed-placeholder]{min-height:0!important}

/* ═══════════════════════════════════════════════════════
   REVEAL ANIMATIONS
   ═══════════════════════════════════════════════════════ */
.tc-reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.tc-reveal.visible{opacity:1;transform:none}

/* ═══════════════════════════════════════════════════════
   GLOBAL OVERFLOW PREVENTION — must be first
   ═══════════════════════════════════════════════════════ */
html{overflow-x:clip}
body{overflow-x:clip}

/* Prevent Swiper overflow:visible from causing body scroll blowout.
   overflow:hidden clips slides to the slider container.
   Nav buttons are inside the padded wrapper so they stay visible. */
.tc-products-slider{overflow:hidden}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — 1200px
   ═══════════════════════════════════════════════════════ */
@media(max-width:1200px){
  .tc-cats-grid{grid-template-columns:repeat(3,1fr)}
  .tc-mega-grid{grid-template-columns:repeat(4,1fr)}
  .tc-footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .tc-hero-stats{display:none}
  .tc-hero-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — 960px (tablet)
   ═══════════════════════════════════════════════════════ */
@media(max-width:960px){
  /* Hamburger moves to header — hide desktop nav links */
  .tc-menu{display:none}
  /* Show hamburger in header (it's a .tc-mobile-icon + .tc-hamburger) */
  .tc-mobile-icon{display:flex!important}
  .tc-mobile-search-bar{display:block}
  /* Hide old hamburger position (none in nav now) */
  .tc-nav-inner .tc-hamburger{display:none}
  /* On tablet, nav bar still shows for branding — but compact */
  .tc-hero{min-height:min(65vh,480px)}
  .tc-hero-content-wrap{padding:48px 0}
  .tc-trust-grid{grid-template-columns:repeat(2,1fr)}
  .tc-cats-grid{grid-template-columns:repeat(2,1fr)}
  .tc-newsletter-grid{grid-template-columns:1fr}
  .tc-newsletter{padding:52px 0}
  .woocommerce div.product{grid-template-columns:1fr;gap:28px}
  .woocommerce-checkout #customer_details{grid-template-columns:1fr}
  .tc-promo-strip{padding:40px 0}
  .tc-promo-strip-inner{flex-direction:column;text-align:center;gap:28px}
  .tc-promo-strip-ctas{flex-direction:row;justify-content:center;flex-wrap:wrap}
  .woocommerce ul.products{grid-template-columns:repeat(3,1fr)!important}
  .tc-swiper-prev,.tc-swiper-next{width:36px;height:36px}
  .tc-products-slider{padding:0 20px}
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — 680px (mobile)
   ═══════════════════════════════════════════════════════ */
@media(max-width:680px){

  /* ── Topbar: single line, centered message ── */
  .tc-topbar{padding:7px 0;font-size:11px}
  .tc-topbar-inner{justify-content:center;text-align:center}
  .tc-topbar-msg{justify-content:center}
  .tc-topbar-msg span:not(strong){display:none}
  .tc-topbar-right{display:none}

  /* ── Header: full-width flex, logo left / icons right ── */
  .tc-header-grid{
    display:flex;
    width:100%;
    box-sizing:border-box;
    align-items:center;
    justify-content:space-between;
    gap:0;
    padding:12px 0;
    min-height:62px;
  }
  .tc-search-wrap{display:none}
  /* Desktop icons hidden */
  .tc-desktop-icon{display:none!important}
  /* Logo */
  .tc-logo-wrap{flex-shrink:0}
  .tc-logo-wrap .custom-logo-link img.custom-logo,
  .tc-logo-wrap img.custom-logo{height:36px!important;max-width:155px!important}
  .tc-logo-text .tc-logo-name{font-size:22px;letter-spacing:-1px}
  .tc-logo-sub{display:none}
  /* Icon group — pushed to right by space-between */
  .tc-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}
  .tc-action-btn > span:last-child{display:none}
  .tc-action-btn{
    width:40px;height:40px;padding:0;gap:0;
    border-radius:var(--r-sm);
    display:flex;align-items:center;justify-content:center;
    background:transparent;
    border:none;cursor:pointer;
    color:var(--c-black);
    transition:var(--t);
  }
  .tc-action-btn:hover{background:var(--c-orange-bg);color:var(--c-orange)}
  .tc-action-btn svg{width:20px;height:20px}
  /* Search icon button */
  #tc-mobile-search-btn{color:var(--c-black)}
  /* Cart: pill style with count */
  #tc-cart-toggle{
    background:var(--c-off);
    border:1.5px solid var(--c-border);
    border-radius:var(--r-sm);
    position:relative;
  }
  #tc-cart-toggle:hover{border-color:var(--c-orange);background:var(--c-orange-bg)}
  .tc-cart-badge{top:-7px;right:-7px;min-width:17px;height:17px;font-size:9px}
  /* Hamburger: solid black pill */
  .tc-header-actions .tc-hamburger{
    display:flex;
    background:var(--c-black);
    border-radius:var(--r-sm);
    width:40px;height:40px;
    padding:11px;
    gap:4px;
    flex-direction:column;
    justify-content:center;
    align-items:center;
  }
  .tc-header-actions .tc-hamburger span{background:#fff;width:18px;height:2px}
  .tc-header-actions .tc-hamburger:hover{background:var(--c-orange)}
  .tc-header-actions .tc-hamburger.open{background:var(--c-orange)}

  /* ── Nav bar: hidden on mobile (hamburger is in header) ── */
  .tc-nav{display:none}

  /* ── Mobile search bar ── */
  .tc-mobile-search-bar{display:block}

  /* ── Hero ── */
  .tc-hero{min-height:280px}
  .tc-hero-content-wrap{padding:32px 0}
  .tc-hero-badge{font-size:9px;letter-spacing:2px;margin-bottom:10px}
  .tc-hero-title{font-size:clamp(32px,9vw,48px);letter-spacing:-2px;margin-bottom:12px;line-height:.98}
  .tc-hero-sub{display:none}
  .tc-hero-ctas{gap:8px;flex-wrap:wrap}
  .tc-hero-pill{display:none}
  .tc-btn{padding:11px 18px;font-size:12px;letter-spacing:1px}
  .tc-btn svg{width:14px;height:14px}
  .tc-hero .swiper-pagination{bottom:14px;left:16px}

  /* ── Sections ── */
  .tc-section{padding:36px 0}
  .tc-section-sm{padding:28px 0}
  /* Section heading */
  .tc-sh{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:20px}
  .tc-sh-left{gap:6px}
  .tc-title{font-size:clamp(24px,7vw,34px);letter-spacing:-1px}
  .tc-eyebrow{font-size:10px;letter-spacing:2.5px}
  .tc-section-label{font-size:10px;letter-spacing:2px}
  .tc-see-all{font-size:11px;letter-spacing:1px;padding-bottom:2px}

  /* ── Trust bar ── */
  .tc-trust{border-bottom:2px solid var(--c-border)}
  .tc-trust-grid{grid-template-columns:1fr 1fr}
  .tc-trust-item{padding:16px 14px;gap:10px;flex-direction:column;align-items:flex-start}
  .tc-trust-icon{width:40px;height:40px;flex-shrink:0}
  .tc-trust-icon svg{width:18px;height:18px}
  .tc-trust-label{font-size:12px;line-height:1.2}
  .tc-trust-sub{font-size:10.5px}
  .tc-trust-item::before{height:3px}

  /* ── Category tiles ── */
  .tc-cats-grid{grid-template-columns:repeat(2,1fr);gap:2px}
  .tc-cat-name{font-size:13px;letter-spacing:.3px}
  .tc-cat-overlay{padding:12px}
  .tc-cat-arrow{width:26px;height:26px}
  .tc-cat-arrow svg{width:12px;height:12px}

  /* ── Product sliders ── */
  .tc-products-slider{padding:0 4px}
  .tc-swiper-prev,.tc-swiper-next{display:none}
  /* Swiper pagination on mobile */
  .swiper-pagination{margin-top:12px}
  .swiper-pagination-bullet{width:6px;height:6px}
  .swiper-pagination-bullet-active{width:20px;border-radius:3px}

  /* ── Product cards ── */
  .tc-card-body{padding:10px 12px 4px}
  .tc-card-foot{padding:6px 12px 12px}
  .tc-price-now{font-size:16px;letter-spacing:-.5px}
  .tc-price-was{font-size:11px}
  .tc-atc{padding:9px 12px;font-size:11px;letter-spacing:1px;height:38px}
  .tc-badge-sale{font-size:10px;padding:2px 8px}
  /* Always show wishlist + view link on touch devices */
  .tc-card-wish{opacity:1;transform:scale(1)}
  .tc-card-view-link{opacity:1;transform:translateY(0);font-size:10px;padding:7px;letter-spacing:1.5px}

  /* ── Promo strip ── */
  .tc-promo-strip{padding:32px 0}
  .tc-promo-strip-title{font-size:clamp(24px,7vw,36px);letter-spacing:-1.5px}
  .tc-promo-strip-sub{font-size:13px;line-height:1.6}
  .tc-promo-strip-ctas{gap:8px}

  /* ── Brands ── */
  .tc-brands-section{padding:28px 0}
  .tc-brands-label{margin-bottom:16px}
  .tc-brand-item{padding:8px 14px;height:48px}
  .tc-brand-item-text{font-size:11px;letter-spacing:2px}

  /* ── Newsletter ── */
  .tc-newsletter{padding:40px 0}
  .tc-newsletter-eyebrow{font-size:10px;letter-spacing:2px}
  .tc-newsletter-title{font-size:clamp(22px,6vw,30px);letter-spacing:-1.5px;margin-bottom:8px}
  .tc-newsletter-sub{font-size:13px}
  .tc-newsletter-form{flex-direction:column;height:auto}
  .tc-newsletter-input{padding:13px 14px;font-size:13px}
  .tc-newsletter-submit{padding:13px 18px;font-size:12px;letter-spacing:1.5px}
  .tc-newsletter-note{font-size:11px}

  /* ── Footer ── */
  .tc-footer{padding:40px 0 0}
  .tc-footer-grid{grid-template-columns:1fr}
  .tc-footer-col-title{font-size:11px;letter-spacing:2px}
  .tc-footer-links a{font-size:13px}
  .tc-footer-bottom-inner{flex-direction:column;gap:6px;text-align:center}
  .tc-footer-copy{font-size:11.5px}
  /* Floating elements */
  .tc-wa-float{width:48px;height:48px;bottom:20px;right:16px}
  .tc-back-top{width:38px;height:38px;bottom:80px;right:16px}

  /* ── Cart panel: full-width ── */
  .tc-cart-panel{width:100%;max-width:100vw}
  .tc-cart-panel-head h3{font-size:16px}

  /* ── WooCommerce ── */
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)!important;gap:2px!important}
  .woocommerce-checkout #customer_details{grid-template-columns:1fr}
  .tc-wc-wrap{padding:24px 0}
  .tc-shop-toolbar{padding-bottom:12px;margin-bottom:14px;gap:8px}
  .woocommerce div.product form.cart .button,.single_add_to_cart_button{
    padding:13px 24px!important;font-size:13px!important;width:100%!important;
  }
  .tc-wc-wrap .tc-page-hero{padding:20px 0}
  .tc-cat-filter{gap:6px;margin-bottom:16px}
  .tc-cat-filter-btn{padding:6px 14px;font-size:10px}

  /* ── Page hero ── */
  .tc-page-hero{padding:22px 0;border-width:2px}
  .tc-page-hero h1{font-size:clamp(18px,5.5vw,26px);letter-spacing:-1px}
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — 420px (small phone)
   ═══════════════════════════════════════════════════════ */
@media(max-width:420px){
  .tc-trust-grid{grid-template-columns:1fr 1fr}
  .tc-trust-item{flex-direction:column;align-items:flex-start;gap:6px;padding:12px 10px}
  .woocommerce ul.products{grid-template-columns:repeat(2,1fr)!important;gap:2px!important}
  /* Extra small logo */
  .tc-logo-wrap .custom-logo-link img.custom-logo,
  .tc-logo-wrap img.custom-logo{max-width:120px!important;height:36px!important}
  .tc-logo-text .tc-logo-name{font-size:20px}
  /* Hero tighter */
  .tc-hero{min-height:260px}
  .tc-hero-content-wrap{padding:28px 0}
  .tc-hero-title{font-size:clamp(28px,9vw,40px)}
}

/* ═══════════════════════════════════════════════════════
   PROMO BUTTON (hero slider)
   ═══════════════════════════════════════════════════════ */
.tc-btn-promo{
  background:transparent;
  color:#fff;
  border:2px solid var(--c-gold);
  position:relative;
  overflow:hidden;
}
.tc-btn-promo::before{
  content:'';position:absolute;inset:0;
  background:var(--c-gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s var(--ease);
}
.tc-btn-promo:hover::before{transform:scaleX(1)}
.tc-btn-promo svg,.tc-btn-promo span{position:relative;z-index:1}
.tc-btn-promo:hover{color:var(--c-black)}
.tc-btn-promo svg{color:var(--c-gold);transition:color var(--t)}
.tc-btn-promo:hover svg{color:var(--c-black)}

/* ═══════════════════════════════════════════════════════
   TRUST BAR — 5 columns
   ═══════════════════════════════════════════════════════ */
.tc-trust-5{grid-template-columns:repeat(5,1fr)}
@media(max-width:1100px){.tc-trust-5{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px) {.tc-trust-5{grid-template-columns:repeat(2,1fr)}}

/* ═══════════════════════════════════════════════════════
   SEARCH AUTOCOMPLETE
   ═══════════════════════════════════════════════════════ */
.tc-search-wrap{position:relative}
.tc-search-suggest{
  position:absolute;top:calc(100% + 4px);left:0;right:0;
  background:var(--c-white);border:1.5px solid var(--c-orange);
  box-shadow:var(--sh-xl);z-index:1000;
  max-height:380px;overflow-y:auto;
  display:none;
}
.tc-search-suggest.open{display:block}
.tc-suggest-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;text-decoration:none;color:var(--c-black);
  border-bottom:1px solid var(--c-border);transition:background var(--t);
  cursor:pointer;
}
.tc-suggest-item:last-child{border-bottom:none}
.tc-suggest-item:hover,.tc-suggest-item.focused{background:var(--c-orange-bg)}
.tc-suggest-img{width:44px;height:44px;object-fit:contain;border:1px solid var(--c-border);flex-shrink:0;background:var(--c-off)}
.tc-suggest-info{flex:1;min-width:0}
.tc-suggest-name{font-size:13px;font-weight:600;color:var(--c-black);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-suggest-sku{font-size:11px;color:var(--c-gray);font-family:monospace}
.tc-suggest-price{font-family:var(--f-head);font-size:14px;font-weight:800;color:var(--c-orange);white-space:nowrap;flex-shrink:0}
.tc-suggest-loader,.tc-suggest-empty{padding:12px 14px;font-size:13px;color:var(--c-gray);text-align:center}
.tc-suggest-all{
  display:block;padding:10px 14px;text-align:center;
  font-family:var(--f-head);font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--c-orange);
  background:var(--c-off);border-top:2px solid var(--c-border);
  text-decoration:none;transition:var(--t);
}
.tc-suggest-all:hover{background:var(--c-orange);color:#fff}

/* ═══════════════════════════════════════════════════════
   CATEGORY TILES — Découvrir CTA
   ═══════════════════════════════════════════════════════ */
.tc-cat-cta{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-head);font-size:11px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  color:var(--c-orange);margin-top:8px;
  border-top:1px solid rgba(255,255,255,.2);padding-top:8px;
  opacity:0;transform:translateY(4px);transition:var(--t);
}
.tc-cat-tile:hover .tc-cat-cta{opacity:1;transform:translateY(0)}
.tc-cat-cta svg{flex-shrink:0}

/* ═══════════════════════════════════════════════════════
   TÉMOIGNAGES
   ═══════════════════════════════════════════════════════ */
.tc-testi-section{background:var(--c-white)}
.tc-testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.tc-testi-card{
  background:var(--c-surface);border:1.5px solid var(--c-border);
  padding:28px;display:flex;flex-direction:column;gap:16px;
  transition:border-color var(--t),box-shadow var(--t),transform var(--t);
  position:relative;
}
.tc-testi-card::before{
  content:'"';position:absolute;top:16px;right:20px;
  font-family:Georgia,serif;font-size:80px;color:var(--c-orange);
  opacity:.12;line-height:1;pointer-events:none;
}
.tc-testi-card:hover{border-color:var(--c-orange);box-shadow:0 6px 24px rgba(255,69,0,.10);transform:translateY(-3px)}
.tc-testi-stars{display:flex;gap:3px;color:var(--c-gold)}
.tc-testi-text{font-size:14px;line-height:1.75;color:var(--c-dark);flex:1;font-style:italic}
.tc-testi-footer{display:flex;align-items:center;gap:12px;margin-top:4px;border-top:1px solid var(--c-border);padding-top:16px}
.tc-testi-avatar{
  width:40px;height:40px;background:var(--c-black);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-head);font-size:16px;font-weight:800;flex-shrink:0;
}
.tc-testi-info{flex:1;min-width:0}
.tc-testi-info strong{display:block;font-size:13px;font-weight:700;color:var(--c-black)}
.tc-testi-info span{font-size:11px;color:var(--c-gray)}
.tc-testi-date{font-size:11px;color:var(--c-gray-l);white-space:nowrap;flex-shrink:0}
@media(max-width:900px){.tc-testi-grid{grid-template-columns:1fr}}
@media(max-width:680px){.tc-testi-card{padding:20px}}

/* ═══════════════════════════════════════════════════════
   TÉLÉCHARGEMENTS
   ═══════════════════════════════════════════════════════ */
.tc-dl-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;
}
.tc-dl-left{}
.tc-dl-intro{font-size:15px;color:var(--c-gray);line-height:1.75;margin:16px 0 28px}
.tc-dl-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--c-border)}
.tc-dl-list li{
  display:flex;align-items:flex-start;gap:16px;
  padding:18px 0;border-bottom:1px solid var(--c-border);
  transition:var(--t);
}
.tc-dl-list li:hover{color:var(--c-orange)}
.tc-dl-list li svg{color:var(--c-orange);flex-shrink:0;margin-top:2px}
.tc-dl-list li strong{display:block;font-size:14px;font-weight:700;color:var(--c-black);margin-bottom:3px}
.tc-dl-list li span{font-size:12px;color:var(--c-gray)}
.tc-dl-form-card{
  background:var(--c-black);padding:36px;color:#fff;
}
.tc-dl-form-card h3{
  font-family:var(--f-head);font-size:22px;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;color:#fff;margin-bottom:8px;
}
.tc-dl-form-card p{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:28px}
.tc-dl-form-row{margin-bottom:16px}
.tc-dl-form-row label{display:block;font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:6px}
.tc-dl-form-row input{
  width:100%;padding:11px 14px;background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.12);color:#fff;font-size:14px;
  font-family:var(--f-body);transition:border-color var(--t);
}
.tc-dl-form-row input::placeholder{color:rgba(255,255,255,.3)}
.tc-dl-form-row input:focus{border-color:var(--c-orange);outline:none;background:rgba(255,255,255,.09)}
.tc-dl-form-msg{margin-top:12px;font-size:13px;padding:8px 12px;display:none}
.tc-dl-form-msg.success{display:block;background:rgba(45,155,81,.15);color:#2D9B51;border-left:3px solid var(--c-green)}
.tc-dl-form-msg.error{display:block;background:rgba(229,62,62,.15);color:#E53E3E;border-left:3px solid var(--c-red)}
@media(max-width:900px){.tc-dl-grid{grid-template-columns:1fr;gap:40px}}
@media(max-width:680px){.tc-dl-form-card{padding:24px}}

/* ═══════════════════════════════════════════════════════
   PARTENAIRES
   ═══════════════════════════════════════════════════════ */
.tc-partners-section{background:var(--c-white)}
.tc-partners-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:2px;margin-bottom:24px;
}
.tc-partner-item{
  border:1.5px solid var(--c-border);aspect-ratio:3/2;
  display:flex;align-items:center;justify-content:center;
  padding:20px;transition:var(--t);cursor:pointer;
}
.tc-partner-item:hover{border-color:var(--c-orange);background:var(--c-orange-bg)}
.tc-partner-item img{max-height:48px;max-width:100%;object-fit:contain;filter:grayscale(1);opacity:.6;transition:var(--t)}
.tc-partner-item:hover img{filter:none;opacity:1}
.tc-partner-placeholder{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-family:var(--f-head);font-size:10px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;color:var(--c-gray-l);text-align:center;
}
.tc-partner-placeholder svg{color:var(--c-border)}
.tc-partner-item:hover .tc-partner-placeholder{color:var(--c-orange)}
.tc-partner-item:hover .tc-partner-placeholder svg{color:var(--c-orange)}
.tc-partners-note{font-size:14px;color:var(--c-gray);text-align:center}
.tc-partners-note a{color:var(--c-orange);font-weight:600}
.tc-partners-note a:hover{text-decoration:underline}
@media(max-width:960px){.tc-partners-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:540px){.tc-partners-grid{grid-template-columns:repeat(2,1fr)}}

/* ═══════════════════════════════════════════════════════
   SHOP CATS COLLAGE — above product grid on /shop/
   ═══════════════════════════════════════════════════════ */
.tc-shop-cats-collage{padding:40px 0 0;background:var(--c-white)}
.tc-shop-cats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:3px;
  margin-top:20px;
}
@media(max-width:960px){.tc-shop-cats-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.tc-shop-cats-grid{grid-template-columns:repeat(2,1fr)}}

/* ═══════════════════════════════════════════════════════
   WC CATEGORY TILES (shop page collage)
   ═══════════════════════════════════════════════════════ */
.woocommerce ul.products.columns-3,
.woocommerce ul.products.columns-4{
  display:grid!important;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr))!important;
  gap:3px!important;
}
.woocommerce ul.products li.product-category{
  margin:0!important;padding:0!important;
}
.tc-wc-cat-tile{
  display:block;position:relative;overflow:hidden;
  aspect-ratio:4/3;background:var(--c-off);text-decoration:none;
}
.tc-wc-cat-img{position:relative;width:100%;height:100%}
.tc-wc-cat-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease-out);display:block;
}
.tc-wc-cat-tile:hover .tc-wc-cat-img img{transform:scale(1.07)}
.tc-wc-cat-noimg{
  width:100%;height:100%;background:linear-gradient(135deg,var(--c-off),var(--c-border));
  display:flex;align-items:center;justify-content:center;color:var(--c-gray);
}
.tc-wc-cat-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(0,0,0,.88) 0%,rgba(0,0,0,.3) 55%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:22px;transition:var(--t);
}
.tc-wc-cat-tile:hover .tc-wc-cat-overlay{background:linear-gradient(0deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.5) 55%,rgba(0,0,0,.1) 100%)}
.tc-wc-cat-name{
  font-family:var(--f-head);font-size:20px;font-weight:800;
  text-transform:uppercase;color:#fff;letter-spacing:.5px;
  line-height:1.1;display:block;margin-bottom:4px;
}
.tc-wc-cat-count{
  font-size:12px;color:rgba(255,255,255,.55);display:block;margin-bottom:10px;
}
.tc-wc-cat-cta{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-head);font-size:11px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;color:var(--c-orange);
  opacity:0;transform:translateY(6px);transition:var(--t);
}
.tc-wc-cat-tile:hover .tc-wc-cat-cta{opacity:1;transform:translateY(0)}
@media(max-width:680px){
  .tc-wc-cat-name{font-size:15px}
  .tc-wc-cat-overlay{padding:14px}
}

/* ═══════════════════════════════════════════════════════
   BRAND FILTER PILLS
   ═══════════════════════════════════════════════════════ */
.tc-brand-filter{margin-top:6px;padding-top:10px;border-top:1px solid var(--c-border)}
.tc-filter-label{font-family:var(--f-head);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--c-gray);display:inline-flex;align-items:center;margin-right:4px}
