/*
Theme Name: Mall de Piese Premium
Theme URI: https://malldepiese.ro
Author: Mall de Piese
Description: Tema premium pentru piese espressoare DeLonghi
Version: 7.0.0
Requires at least: 6.0
Tested up to: 6.7
WC requires at least: 7.0
WC tested up to: 9.0
License: GNU General Public License v2 or later
Text Domain: malldepiese
Tags: woocommerce, responsive, premium
*/

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Instrument+Serif:ital@0;1&display=swap');

/* =========================================
   DESIGN TOKENS
   ========================================= */
:root {
  --navy:        #0D2144;
  --navy-mid:    #1A3560;
  --navy-light:  #254880;
  --navy-pale:   #EEF3FB;
  --navy-faint:  #F6F9FF;

  --accent:      #E05A1F;
  --accent-dark: #C44D18;
  --accent-pale: #FFF0EA;

  --white:     #FFFFFF;
  --gray-50:   #F8F9FA;
  --gray-100:  #EFF1F5;
  --gray-200:  #DDE1EA;
  --gray-300:  #BEC5D0;
  --gray-500:  #7A8394;
  --gray-700:  #3D4655;
  --gray-900:  #141820;

  --green:      #16A34A;
  --green-pale: #ECFDF5;
  --red:        #DC2626;

  --r-xs:  4px; --r-sm: 8px; --r-md: 12px; --r-lg: 16px;
  --r-xl:  22px; --r-2xl: 32px; --r-pill: 9999px;

  --shadow-xs:   0 1px 3px rgba(13,33,68,.08);
  --shadow-sm:   0 2px 8px rgba(13,33,68,.10);
  --shadow-md:   0 4px 18px rgba(13,33,68,.12);
  --shadow-lg:   0 8px 32px rgba(13,33,68,.14);
  --shadow-xl:   0 16px 56px rgba(13,33,68,.16);
  --shadow-navy: 0 6px 24px rgba(13,33,68,.28);

  --font-display: 'Plus Jakarta Sans', system-ui, sans-serif;
  --font-body:    'Plus Jakarta Sans', system-ui, sans-serif;
  --font-serif:   'Instrument Serif', Georgia, serif;
  --font-mono:    'JetBrains Mono', monospace;
  --transition: .18s ease;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{font-family:var(--font-body);font-size:.9rem;line-height:1.6;color:var(--gray-700);background:var(--gray-50);-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--navy);text-decoration:none;transition:color var(--transition);}
a:hover{color:var(--navy-mid);}
button{cursor:pointer;font-family:var(--font-body);}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:800;line-height:1.1;color:var(--navy);letter-spacing:-.025em;}
h1{font-size:clamp(1.9rem,3.5vw,2.8rem);}
h2{font-size:clamp(1.5rem,2.8vw,2.1rem);}
h3{font-size:clamp(1rem,1.8vw,1.22rem);}
p{margin-bottom:1rem;}p:last-child{margin-bottom:0;}
.container{max-width:1360px;margin:0 auto;padding:0 24px;}
.container--narrow{max-width:900px;margin:0 auto;padding:0 24px;}

/* UTILITIES */
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;}

.section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:8px;}
.section-label::before{content:'';display:block;width:18px;height:2px;background:var(--accent);border-radius:2px;flex-shrink:0;}
.section-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,2.8vw,2.1rem);color:var(--navy);margin-bottom:8px;line-height:1.1;}
.section-sub{font-size:.9rem;color:var(--gray-500);max-width:520px;line-height:1.65;}
.section-header{margin-bottom:32px;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-weight:700;font-size:.84rem;padding:11px 22px;border-radius:var(--r-md);border:2px solid transparent;transition:all var(--transition);white-space:nowrap;cursor:pointer;text-decoration:none;}
.btn--primary{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:var(--shadow-navy);}
.btn--primary:hover{background:var(--navy-mid);border-color:var(--navy-mid);color:#fff;transform:translateY(-1px);}
.btn--accent{background:var(--accent);color:#fff;border-color:var(--accent);}
.btn--accent:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff;transform:translateY(-1px);}
.btn--outline{background:transparent;color:var(--navy);border-color:var(--gray-200);}
.btn--outline:hover{border-color:var(--navy);background:var(--navy-faint);color:var(--navy);}
.btn--ghost-white{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25);backdrop-filter:blur(8px);}
.btn--ghost-white:hover{background:rgba(255,255,255,.22);color:#fff;}
.btn--lg{padding:14px 30px;font-size:.94rem;}
.btn--sm{padding:8px 16px;font-size:.76rem;}
.btn svg{width:16px;height:16px;flex-shrink:0;}

/* TOPBAR */
.header-topbar{background:var(--navy);color:rgba(255,255,255,.72);font-size:.74rem;padding:7px 0;}
.header-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:20px;}
.topbar-item{display:flex;align-items:center;gap:5px;color:rgba(255,255,255,.65);font-size:.73rem;font-weight:500;}
.topbar-item a{color:inherit;}.topbar-item a:hover{color:#fff;}
.topbar-item svg{width:11px;height:11px;opacity:.75;}
.topbar-badge{background:var(--accent);color:#fff;font-size:.65rem;font-weight:800;padding:2px 9px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.08em;}

/* HEADER */
.site-header{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);}
.header-main{padding:0;}
.header-main-inner{display:grid;grid-template-columns:220px 1fr auto;align-items:center;gap:20px;padding:12px 0;}
.site-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.site-logo-icon{width:40px;height:40px;background:var(--navy);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.site-logo-icon svg{color:#fff;width:20px;height:20px;}
.site-logo-text{display:flex;flex-direction:column;line-height:1.1;}
.logo-brand{font-family:var(--font-display);font-weight:800;font-size:1.08rem;color:var(--navy);letter-spacing:-.02em;}
.logo-tagline{font-size:.6rem;color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.09em;}
.header-search{flex:1;}
.search-bar{display:flex;align-items:center;background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--r-md);overflow:hidden;transition:all var(--transition);}
.search-bar:focus-within{border-color:var(--navy);background:#fff;box-shadow:0 0 0 3px rgba(13,33,68,.08);}
.search-bar input{flex:1;padding:10px 16px;background:transparent;border:none;outline:none;font-family:var(--font-body);font-size:.87rem;color:var(--gray-900);}
.search-bar input::placeholder{color:var(--gray-300);}
.search-bar button{padding:10px 20px;background:var(--navy);color:#fff;border:none;transition:background var(--transition);display:flex;align-items:center;}
.search-bar button:hover{background:var(--navy-mid);}
.search-bar button svg{width:16px;height:16px;}
.header-actions{display:flex;align-items:center;gap:7px;}
.header-action-btn{display:flex;align-items:center;gap:6px;padding:9px 13px;border:1.5px solid var(--gray-200);border-radius:var(--r-md);background:#fff;color:var(--gray-700);font-size:.8rem;font-weight:600;text-decoration:none;transition:all var(--transition);position:relative;}
.header-action-btn:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-faint);}
.header-action-btn svg{width:15px;height:15px;}
.cart-btn{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;}
.cart-btn:hover{background:var(--accent-dark)!important;border-color:var(--accent-dark)!important;color:#fff!important;}
.cart-count-badge{position:absolute;top:-6px;right:-6px;background:var(--navy);color:#fff;font-size:.6rem;font-weight:800;min-width:17px;height:17px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid #fff;}
.mobile-menu-toggle{display:none;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;border:1.5px solid var(--gray-200);border-radius:var(--r-md);color:var(--gray-700);}

/* NAV */
.header-nav{background:var(--navy);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:4px;}
.main-menu{display:flex;align-items:center;list-style:none;padding:0;margin:0;gap:0;}
.main-menu>li>a{display:flex;align-items:center;gap:5px;padding:11px 15px;font-family:var(--font-body);font-weight:600;font-size:.81rem;color:rgba(255,255,255,.72);transition:all var(--transition);white-space:nowrap;}
.main-menu>li>a:hover,.main-menu>li.current-menu-item>a{color:#fff;background:rgba(255,255,255,.1);}
.main-menu>li.menu-highlight>a{background:var(--accent);color:#fff;font-weight:700;margin:0 4px;}
.main-menu>li.menu-highlight>a:hover{background:var(--accent-dark);}
.nav-phone{display:flex;align-items:center;gap:6px;font-weight:700;font-size:.82rem;color:rgba(255,255,255,.9);white-space:nowrap;padding:8px 0;}
.nav-phone svg{width:13px;height:13px;}
.nav-phone a{color:inherit;}

/* HERO */
.hero-section{background:linear-gradient(118deg,var(--navy) 0%,var(--navy-mid) 55%,#1E4080 100%);padding:0;overflow:hidden;position:relative;}
.hero-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(ellipse 55% 80% at 100% 50%,rgba(255,255,255,.045) 0%,transparent 55%),radial-gradient(ellipse 35% 40% at 0% 100%,rgba(224,90,31,.12) 0%,transparent 45%);pointer-events:none;}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:560px;}
.hero-content{padding:56px 40px 56px 0;display:flex;flex-direction:column;justify-content:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:5px 14px;border-radius:var(--r-pill);margin-bottom:20px;backdrop-filter:blur(8px);width:fit-content;}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:#4ADE80;box-shadow:0 0 8px #4ADE80;animation:blink-g 2s ease infinite;}
@keyframes blink-g{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.9rem,3.6vw,3rem);color:#fff;line-height:1.06;letter-spacing:-.03em;margin-bottom:16px;}
.hero-title em{font-style:normal;font-family:var(--font-serif);font-weight:400;}
.hero-subtitle{font-size:.95rem;color:rgba(255,255,255,.68);line-height:1.7;margin-bottom:30px;max-width:400px;font-weight:400;}
.hero-actions{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:40px;}
.hero-actions .btn--primary{background:#fff;color:var(--navy);border-color:#fff;box-shadow:0 8px 28px rgba(0,0,0,.2);}
.hero-actions .btn--primary:hover{background:var(--navy-pale);color:var(--navy);transform:translateY(-2px);box-shadow:0 14px 36px rgba(0,0,0,.28);}
.hero-stats{display:flex;gap:0;border-top:1px solid rgba(255,255,255,.12);padding-top:26px;}
.hero-stat{flex:1;padding-right:24px;border-right:1px solid rgba(255,255,255,.12);}
.hero-stat:last-child{border-right:none;padding-right:0;padding-left:24px;}
.hero-stat:first-child{padding-left:0;}
.hero-stat-value{font-family:var(--font-display);font-weight:800;font-size:1.8rem;color:#fff;line-height:1;margin-bottom:3px;}
.hero-stat-label{font-size:.67rem;color:rgba(255,255,255,.52);text-transform:uppercase;letter-spacing:.09em;font-weight:500;}

/* Hero visual */
.hero-visual{display:flex;align-items:center;justify-content:center;position:relative;padding:0;}
.hero-products-layout{display:grid;grid-template-columns:1.22fr .78fr;gap:12px;width:100%;align-items:end;}
.hero-main-product{background:#fff;border-radius:var(--r-xl);overflow:hidden;text-decoration:none;color:inherit;box-shadow:0 32px 80px rgba(0,0,0,.28);display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease;}
.hero-main-product:hover{transform:translateY(-6px);box-shadow:0 44px 100px rgba(0,0,0,.36);}
.hero-main-product-media{background:var(--gray-50);aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:22px;overflow:hidden;}
.hero-main-product-media img{width:100%;height:100%;object-fit:contain;transition:transform .4s ease;}
.hero-main-product:hover .hero-main-product-media img{transform:scale(1.06);}
.hero-main-product-body{padding:16px;}
.hero-main-product-kicker{display:inline-block;font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:5px;}
.hero-main-product h3{font-size:.88rem;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:5px;}
.hero-main-product-price{font-size:1rem;font-weight:800;color:var(--navy);}
.hero-product-grid{display:grid;grid-template-rows:repeat(2,1fr);gap:12px;}
.hero-mini-product{background:#fff;border-radius:var(--r-lg);overflow:hidden;text-decoration:none;color:inherit;box-shadow:0 16px 44px rgba(0,0,0,.20);display:flex;flex-direction:column;transition:transform .22s ease,box-shadow .22s ease;}
.hero-mini-product:hover{transform:translateY(-4px);box-shadow:0 24px 60px rgba(0,0,0,.28);}
.hero-mini-product-media{background:var(--gray-50);padding:12px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;}
.hero-mini-product-media img{width:100%;height:100%;object-fit:contain;transition:transform .35s;}
.hero-mini-product:hover .hero-mini-product-media img{transform:scale(1.08);}
.hero-mini-product-title{padding:9px 11px;font-size:.72rem;font-weight:700;color:var(--navy);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeRight{from{opacity:0;transform:translateX(22px)}to{opacity:1;transform:translateX(0)}}
.hero-content{animation:fadeUp .6s ease .08s both;}
.hero-main-product{animation:fadeRight .55s ease .18s both;}
.hero-product-grid .hero-mini-product:nth-child(1){animation:fadeRight .5s ease .28s both;}
.hero-product-grid .hero-mini-product:nth-child(2){animation:fadeRight .5s ease .38s both;}

/* TRUST BAR */
.trust-bar{background:#fff;border-bottom:1px solid var(--gray-200);padding:12px 0;}
.trust-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:4px;flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--gray-700);font-weight:600;padding:8px 16px;border-right:1px solid var(--gray-100);}
.trust-item:last-child{border-right:none;}
.trust-icon{width:32px;height:32px;background:var(--navy-pale);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0;}
.trust-icon svg{width:15px;height:15px;}
.trust-item-title{font-weight:700;font-size:.78rem;color:var(--navy);line-height:1.2;}
.trust-item-desc{font-size:.67rem;color:var(--gray-500);font-weight:400;}

/* CAT NAV */
.cat-nav-section{background:#fff;padding:24px 0;border-bottom:1px solid var(--gray-100);}
.cat-nav-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;}
.cat-nav-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;padding:14px 6px;border:1.5px solid var(--gray-100);border-radius:var(--r-lg);text-decoration:none;color:var(--gray-700);font-size:.7rem;font-weight:600;transition:all .2s;background:#fff;}
.cat-nav-card:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-faint);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.cat-nav-icon{width:44px;height:44px;background:var(--gray-50);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .2s;border:1.5px solid var(--gray-100);}
.cat-nav-card:hover .cat-nav-icon{background:var(--navy);border-color:var(--navy);}
.cat-nav-name{line-height:1.3;color:inherit;}
.cat-nav-count{font-size:.62rem;color:var(--gray-500);font-weight:400;}

/* MODEL FINDER — SPLIT LAYOUT */
.model-finder-section {
  background: linear-gradient(110deg, var(--navy) 0%, var(--navy-mid) 55%, #1E4080 100%);
  padding: 28px 0;
  position: relative;
  overflow: hidden;
}
.model-finder-section::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 55% 100% at 100% 50%, rgba(255,255,255,.05), transparent 60%);
  pointer-events: none;
}

.model-finder-split {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 40px;
  align-items: center;
}

/* LEFT */
.mfs-left { display: flex; flex-direction: column; justify-content: center; }
.mfs-left .section-label { color: rgba(255,255,255,.55); margin-bottom: 8px; }
.mfs-left .section-label::before { background: rgba(255,255,255,.35); }
.mfs-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.35rem, 2.2vw, 1.85rem);
  color: #fff;
  line-height: 1.12;
  letter-spacing: -.025em;
  margin-bottom: 10px;
}
.mfs-sub {
  font-size: .85rem;
  color: rgba(255,255,255,.6);
  line-height: 1.6;
  font-weight: 400;
  max-width: 340px;
}

/* RIGHT */
.mfs-right {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Input row */
.mfs-form { width: 100%; }
.mfs-input-wrap {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.08);
}
.mfs-input-icon {
  padding: 0 14px 0 18px;
  color: var(--gray-300);
  display: flex; align-items: center;
  flex-shrink: 0;
}
.mfs-input-icon svg { width: 17px; height: 17px; }
.mfs-input {
  flex: 1;
  padding: 15px 8px;
  border: none; outline: none;
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--gray-900);
  background: transparent;
}
.mfs-input::placeholder { color: var(--gray-300); }
.mfs-btn {
  padding: 15px 26px;
  background: var(--accent);
  color: #fff;
  border: none;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: .86rem;
  cursor: pointer;
  transition: background var(--transition);
  white-space: nowrap;
  flex-shrink: 0;
}
.mfs-btn:hover { background: var(--accent-dark); }

/* Chips row */
.mfs-chips {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
}
.mfs-chips-label {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.4);
  flex-shrink: 0;
}
.mfs-chip {
  padding: 5px 13px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--r-pill);
  color: rgba(255,255,255,.78);
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
}
.mfs-chip:hover {
  background: rgba(255,255,255,.18);
  color: #fff;
  border-color: rgba(255,255,255,.3);
}

/* Responsive */
@media (max-width: 900px) {
  .model-finder-split { grid-template-columns: 1fr; gap: 20px; }
  .mfs-sub { max-width: 100%; }
}

/* PRODUCTS */
.products-section{padding:48px 0;background:var(--gray-50);}
.products-section-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:24px;flex-wrap:wrap;}
.products-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;}
.products-grid--4col{grid-template-columns:repeat(4,1fr);}

.product-card{background:#fff;border:1.5px solid var(--gray-100);border-radius:var(--r-xl);overflow:hidden;transition:all .2s ease;position:relative;display:flex;flex-direction:column;box-shadow:var(--shadow-xs);}
.product-card:hover{border-color:var(--navy-light);box-shadow:var(--shadow-lg);transform:translateY(-4px);}
.product-card-image-wrap{position:relative;aspect-ratio:1;overflow:hidden;background:#fff;border-bottom:1px solid var(--gray-100);}
.product-card-image-wrap img{width:100%;height:100%;object-fit:contain;padding:12px;transition:transform .4s ease;background:#fff;}
.product-card:hover .product-card-image-wrap img{transform:scale(1.06);}
.product-badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:3px;z-index:2;}
.badge{font-size:.61rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:3px 7px;border-radius:var(--r-xs);}
.badge--sale{background:var(--accent);color:#fff;}
.badge--new{background:var(--navy);color:#fff;}
.badge--stock{background:var(--green);color:#fff;}
.badge--unavailable{background:var(--gray-500);color:#fff;}
.product-wishlist{position:absolute;top:8px;right:8px;width:28px;height:28px;background:#fff;border:1.5px solid var(--gray-200);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);z-index:2;opacity:0;}
.product-card:hover .product-wishlist{opacity:1;}
.product-wishlist:hover{border-color:var(--accent);color:var(--accent);}
.product-wishlist svg{width:12px;height:12px;}
.product-card-body{padding:13px;flex:1;display:flex;flex-direction:column;}
.product-card-cat{font-size:.62rem;font-weight:700;color:var(--navy-light);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px;}
.product-card-title{font-weight:700;font-size:.8rem;color:var(--navy);line-height:1.4;margin-bottom:9px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.product-card-title a{color:inherit;}
.product-card-title a:hover{color:var(--navy-mid);}
.product-card-price{display:flex;align-items:baseline;gap:6px;margin-bottom:10px;flex-wrap:wrap;}
.price-current{font-size:1.08rem;font-weight:800;color:var(--navy);font-family:var(--font-display);}
.price-old{font-size:.76rem;color:var(--gray-300);text-decoration:line-through;}
.price-discount{font-size:.62rem;font-weight:800;color:var(--accent);background:var(--accent-pale);padding:2px 5px;border-radius:var(--r-xs);}
.product-card-footer{display:flex;gap:6px;}
.btn-add-cart{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 10px;background:var(--navy);color:#fff!important;border:none;border-radius:var(--r-sm);font-family:var(--font-body);font-weight:700;font-size:.76rem;cursor:pointer;transition:all var(--transition);text-decoration:none;}
.btn-add-cart:hover{background:var(--navy-mid);color:#fff!important;transform:translateY(-1px);box-shadow:var(--shadow-navy);}
.btn-add-cart svg{width:12px;height:12px;}
.btn-unavailable{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 10px;background:var(--gray-50)!important;color:var(--gray-500)!important;border:1.5px solid var(--gray-200)!important;border-radius:var(--r-sm);font-family:var(--font-body);font-weight:600;font-size:.76rem;cursor:not-allowed;text-decoration:none;}
.btn-view{padding:9px 10px;background:var(--gray-50);color:var(--gray-500);border:1.5px solid var(--gray-200);border-radius:var(--r-sm);cursor:pointer;transition:all var(--transition);text-decoration:none;display:flex;align-items:center;}
.btn-view:hover{background:var(--navy-pale);color:var(--navy);border-color:var(--navy-light);}
.btn-view svg{width:13px;height:13px;}

/* CATEGORIES */
.categories-section{padding:48px 0;background:#fff;}
.categories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.category-card{background:var(--gray-50);border:1.5px solid var(--gray-100);border-radius:var(--r-xl);padding:24px 18px;text-align:center;text-decoration:none;transition:all .2s ease;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;gap:10px;}
.category-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--navy-light));transform:scaleX(0);transition:transform .26s ease;transform-origin:left;}
.category-card:hover{border-color:var(--navy-light);background:var(--navy-faint);box-shadow:var(--shadow-lg);transform:translateY(-4px);color:var(--navy);}
.category-card:hover::after{transform:scaleX(1);}
.category-icon{width:54px;height:54px;background:#fff;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;color:var(--navy-mid);transition:all .2s;border:1.5px solid var(--gray-200);}
.category-card:hover .category-icon{background:var(--navy);color:#fff;border-color:var(--navy);}
.category-name{font-weight:700;font-size:.84rem;color:var(--navy);line-height:1.3;}
.category-count{font-size:.68rem;color:var(--gray-500);}

/* WHY US */
.why-us-section{padding:48px 0;background:var(--navy-faint);}
.why-us-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center;}
.why-us-image-wrap{aspect-ratio:4/3;background:#fff;border-radius:var(--r-2xl);border:1.5px solid var(--gray-200);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:var(--shadow-xl);}
.why-us-image-wrap img{width:100%;height:100%;object-fit:contain;padding:32px;}
.why-us-stat-card{position:absolute;background:#fff;border-radius:var(--r-lg);padding:13px 17px;box-shadow:var(--shadow-lg);border:1.5px solid var(--gray-100);}
.why-us-stat-card--bottom-right{bottom:-14px;right:-14px;}
.why-us-stat-card--top-left{top:16px;left:-14px;}
.stat-number-big{font-family:var(--font-display);font-weight:800;font-size:1.9rem;color:var(--navy);line-height:1;}
.stat-label-small{font-size:.7rem;color:var(--gray-500);font-weight:500;}
.benefits-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;}
.benefit-item{display:flex;gap:13px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--gray-200);}
.benefit-item:last-child{border-bottom:none;}
.benefit-icon{width:40px;height:40px;background:var(--navy-pale);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0;transition:all .2s;border:1.5px solid rgba(13,33,68,.12);}
.benefit-icon svg{width:17px;height:17px;}
.benefit-item:hover .benefit-icon{background:var(--navy);color:#fff;}
.benefit-title{font-weight:700;font-size:.88rem;color:var(--navy);margin-bottom:2px;}
.benefit-desc{font-size:.8rem;color:var(--gray-500);line-height:1.55;font-weight:400;}

/* TESTIMONIALS */
.testimonials-section{padding:48px 0;background:#fff;}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.testimonial-card{background:var(--gray-50);border:1.5px solid var(--gray-100);border-radius:var(--r-xl);padding:24px;transition:all .2s;position:relative;}
.testimonial-card:hover{border-color:var(--navy-light);box-shadow:var(--shadow-md);}
.testimonial-card::before{content:'\201C';position:absolute;top:14px;right:18px;font-size:3.5rem;font-family:Georgia,serif;color:var(--gray-200);line-height:1;}
.testimonial-stars{display:flex;gap:2px;margin-bottom:10px;}
.testimonial-stars svg{width:13px;height:13px;fill:#F59E0B;color:#F59E0B;}
.testimonial-text{font-size:.84rem;color:var(--gray-700);line-height:1.7;margin-bottom:16px;font-weight:400;}
.testimonial-author{display:flex;align-items:center;gap:10px;border-top:1px solid var(--gray-200);padding-top:13px;}
.testimonial-avatar{width:36px;height:36px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.82rem;flex-shrink:0;}
.testimonial-name{font-weight:700;font-size:.82rem;color:var(--navy);}
.testimonial-meta{font-size:.7rem;color:var(--gray-500);}

/* NEWSLETTER */
.newsletter-section{background:linear-gradient(110deg,var(--navy) 0%,var(--navy-mid) 60%,#1E4080 100%);padding:56px 0;position:relative;overflow:hidden;}
.newsletter-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 45% 80% at 95% 50%,rgba(255,255,255,.045),transparent 55%);pointer-events:none;}
.newsletter-inner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.newsletter-title{font-family:var(--font-display);font-weight:800;font-size:1.7rem;color:#fff;margin-bottom:8px;}
.newsletter-desc{color:rgba(255,255,255,.65);font-size:.9rem;font-weight:400;}
.newsletter-form-wrap{display:flex;flex-direction:column;gap:10px;}
.newsletter-input-row{display:flex;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.18);border-radius:var(--r-lg);overflow:hidden;}
.newsletter-input-row input{flex:1;padding:13px 18px;background:transparent;border:none;outline:none;color:#fff;font-family:var(--font-body);font-size:.88rem;}
.newsletter-input-row input::placeholder{color:rgba(255,255,255,.38);}
.newsletter-input-row button{padding:13px 22px;background:var(--accent);color:#fff;border:none;font-family:var(--font-body);font-weight:700;font-size:.86rem;cursor:pointer;transition:background var(--transition);}
.newsletter-input-row button:hover{background:var(--accent-dark);}
.newsletter-note{font-size:.7rem;color:rgba(255,255,255,.42);}
.newsletter-message{font-size:.82rem;margin-top:6px;}

/* FOOTER */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);}
.footer-main{padding:52px 0 32px;display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px;}
.footer-brand .logo-brand{color:#fff;}
.footer-brand .logo-tagline{color:rgba(255,255,255,.38);}
.footer-brand-desc{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.48);margin-bottom:18px;font-weight:300;}
.footer-social{display:flex;gap:7px;}
.social-btn{width:32px;height:32px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.48);text-decoration:none;transition:all var(--transition);}
.social-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.social-btn svg{width:14px;height:14px;}
.footer-col-title{font-family:var(--font-display);font-weight:700;font-size:.75rem;color:rgba(255,255,255,.88);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px;padding-bottom:9px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-links{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px;}
.footer-links a{color:rgba(255,255,255,.48);font-size:.81rem;text-decoration:none;transition:all var(--transition);font-weight:400;display:flex;align-items:center;gap:4px;}
.footer-links a:hover{color:rgba(255,255,255,.88);padding-left:4px;}
.footer-links a svg{width:10px;height:10px;opacity:.5;}
.footer-contact-item{display:flex;align-items:flex-start;gap:8px;margin-bottom:9px;font-size:.81rem;}
.footer-contact-item svg{width:12px;height:12px;color:rgba(255,255,255,.38);flex-shrink:0;margin-top:3px;}
.footer-contact-item a{color:rgba(255,255,255,.58);}
.footer-contact-item a:hover{color:#fff;}
.footer-contact-item span{color:rgba(255,255,255,.52);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:16px 0;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.footer-bottom-left{font-size:.76rem;color:rgba(255,255,255,.32);}
.footer-bottom-left strong{color:rgba(255,255,255,.58);}
.footer-bottom-links{display:flex;gap:16px;}
.footer-bottom-links a{font-size:.76rem;color:rgba(255,255,255,.32);}
.footer-bottom-links a:hover{color:rgba(255,255,255,.78);}

/* SCROLL TOP */
.scroll-top-btn{position:fixed;bottom:22px;right:22px;width:40px;height:40px;background:var(--navy);color:#fff;border:none;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:500;box-shadow:var(--shadow-navy);opacity:0;pointer-events:none;transform:translateY(10px);transition:all .22s;}
.scroll-top-btn.visible{opacity:1;pointer-events:auto;transform:translateY(0);}
.scroll-top-btn:hover{background:var(--navy-mid);transform:translateY(-2px);}
.scroll-top-btn svg{width:17px;height:17px;}

/* MOBILE NAV */
.mobile-nav-overlay{display:none;position:fixed;inset:0;background:rgba(13,33,68,.5);z-index:900;backdrop-filter:blur(4px);}
.mobile-nav-overlay.active{display:block;}
.mobile-nav-drawer{position:fixed;top:0;left:-100%;width:290px;height:100%;background:#fff;z-index:950;transition:left .3s;overflow-y:auto;padding:22px;}
.mobile-nav-drawer.open{left:0;}

/* FADE UP */
.fade-up{opacity:0;transform:translateY(14px);transition:opacity .44s,transform .44s;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* PAGE HERO */
.page-hero{background:linear-gradient(110deg,var(--navy) 0%,var(--navy-mid) 55%,#1E4080 100%);padding:40px 0 32px;color:#fff;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.012) 0px,rgba(255,255,255,.012) 1px,transparent 1px,transparent 18px);pointer-events:none;}
.page-hero-inner{position:relative;z-index:1;}
.page-hero h1{color:#fff;margin-bottom:6px;font-size:clamp(1.4rem,2.8vw,2.1rem);}
.page-hero p{color:rgba(255,255,255,.7);}
.breadcrumb{font-size:.73rem;color:rgba(255,255,255,.48);margin-bottom:9px;}
.breadcrumb a{color:rgba(255,255,255,.68);}
.breadcrumb a:hover{color:#fff;}
.breadcrumb-sep{margin:0 5px;opacity:.38;}

/* SHOP */
.shop-layout{display:grid;grid-template-columns:232px 1fr;gap:22px;padding:32px 0;}
.sidebar-widget{background:#fff;border:1.5px solid var(--gray-100);border-radius:var(--r-xl);padding:18px;margin-bottom:14px;box-shadow:var(--shadow-xs);}
.sidebar-widget-title{font-weight:700;font-size:.77rem;color:var(--navy);text-transform:uppercase;letter-spacing:.09em;margin-bottom:13px;padding-bottom:9px;border-bottom:1.5px solid var(--gray-100);display:flex;align-items:center;gap:6px;}
.sidebar-widget-title svg{width:13px;height:13px;color:var(--navy-light);}
.sidebar-cat-list{list-style:none;padding:0;}
.sidebar-cat-list li{border-bottom:1px solid var(--gray-100);}
.sidebar-cat-list li:last-child{border-bottom:none;}
.sidebar-cat-list a{display:flex;align-items:center;justify-content:space-between;padding:8px 3px;font-size:.81rem;color:var(--gray-700);transition:all var(--transition);border-radius:var(--r-sm);}
.sidebar-cat-list a:hover{color:var(--navy);padding-left:9px;}
.sidebar-cat-count{font-size:.68rem;background:var(--gray-100);color:var(--gray-500);padding:2px 6px;border-radius:var(--r-pill);font-weight:600;}

/* SINGLE PRODUCT */
.single-product-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:32px 0;align-items:start;}
.product-gallery-main{background:var(--gray-50);border-radius:var(--r-xl);border:1.5px solid var(--gray-200);overflow:hidden;aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:18px;margin-bottom:9px;}
.product-gallery-main img{max-width:100%;max-height:100%;object-fit:contain;}
.product-gallery-thumbs{display:flex;gap:7px;}
.gallery-thumb{width:62px;height:62px;border:2px solid var(--gray-200);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all var(--transition);flex-shrink:0;background:var(--gray-50);}
.gallery-thumb:hover,.gallery-thumb.active{border-color:var(--navy);}
.gallery-thumb img{width:100%;height:100%;object-fit:contain;padding:4px;}
.product-info-categories{font-size:.7rem;font-weight:700;color:var(--navy-light);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.product-info-title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.3rem,2.4vw,1.8rem);color:var(--navy);margin-bottom:9px;line-height:1.12;}
.product-info-sku{font-size:.7rem;color:var(--gray-500);margin-bottom:13px;font-family:var(--font-mono);}
.product-info-price{display:flex;align-items:baseline;gap:10px;margin-bottom:20px;padding:13px 0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);}
.product-price-main{font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:var(--navy);}
.product-price-old{font-size:.98rem;color:var(--gray-300);text-decoration:line-through;}
.product-add-cart-row{display:flex;gap:9px;margin-bottom:18px;flex-wrap:wrap;}
.qty-control{display:flex;align-items:center;border:1.5px solid var(--gray-200);border-radius:var(--r-md);overflow:hidden;}
.qty-btn{width:36px;height:44px;background:var(--gray-50);border:none;font-size:1.1rem;cursor:pointer;color:var(--gray-700);transition:all var(--transition);}
.qty-btn:hover{background:var(--navy-pale);color:var(--navy);}
.qty-input{width:44px;text-align:center;border:none;outline:none;font-family:var(--font-body);font-weight:700;font-size:.92rem;color:var(--navy);}
.btn-add-to-cart-main{flex:1;padding:12px 20px;background:var(--navy);color:#fff;border:none;border-radius:var(--r-md);font-family:var(--font-body);font-weight:700;font-size:.92rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;box-shadow:var(--shadow-navy);}
.btn-add-to-cart-main:hover{background:var(--navy-mid);color:#fff;transform:translateY(-1px);}
.product-guarantees{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:18px;}
.guarantee-item{display:flex;align-items:center;gap:6px;padding:8px 11px;background:var(--gray-50);border:1.5px solid var(--gray-100);border-radius:var(--r-md);font-size:.74rem;font-weight:600;color:var(--gray-700);}
.guarantee-item svg{width:12px;height:12px;color:var(--green);flex-shrink:0;}

/* WOO */
.woo-main-content{padding:28px 0 52px;}
.page-content,.entry-content{background:#fff;border:1.5px solid var(--gray-100);border-radius:var(--r-2xl);box-shadow:var(--shadow-xs);padding:28px;}
.woocommerce ul.products li.product a img,.product-card-image-wrap img{background:#fff!important;object-fit:contain;}
.woocommerce div.product div.images,.woocommerce-product-gallery__image img{background:#fff!important;}
body.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,body.woocommerce-checkout #place_order{background:var(--navy)!important;color:#fff!important;font-weight:800!important;border:none!important;border-radius:var(--r-md)!important;}
body.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,body.woocommerce-checkout #place_order:hover{background:var(--navy-mid)!important;color:#fff!important;}
.header-action-btn.cart-btn,.header-action-btn.cart-btn:visited{background:var(--accent)!important;border-color:var(--accent)!important;color:#fff!important;}
.header-action-btn.cart-btn:hover{background:var(--accent-dark)!important;border-color:var(--accent-dark)!important;color:#fff!important;}

/* RESPONSIVE */
@media(max-width:1280px){.products-grid{grid-template-columns:repeat(4,1fr);}.cat-nav-grid{grid-template-columns:repeat(4,1fr);}.footer-main{grid-template-columns:1fr 1fr;gap:24px;}}
@media(max-width:1100px){.categories-grid{grid-template-columns:repeat(3,1fr);}.products-grid{grid-template-columns:repeat(3,1fr);}.hero-inner{grid-template-columns:1fr;}.hero-content{padding:44px 0 28px;}.why-us-grid{grid-template-columns:1fr;}.newsletter-inner{grid-template-columns:1fr;gap:28px;}.shop-layout{grid-template-columns:1fr;}.single-product-layout{grid-template-columns:1fr;}.testimonials-grid{grid-template-columns:repeat(2,1fr);}.hero-products-layout{grid-template-columns:1.1fr .85fr;}}
@media(max-width:900px){.header-main-inner{grid-template-columns:auto 1fr auto;}.header-topbar{display:none;}}
@media(max-width:768px){.header-search{display:none;}.mobile-menu-toggle{display:flex;}.header-nav{display:none;}.products-grid{grid-template-columns:repeat(2,1fr);gap:9px;}.categories-grid{grid-template-columns:repeat(2,1fr);}.cat-nav-grid{grid-template-columns:repeat(4,1fr);}.testimonials-grid{grid-template-columns:1fr;}.footer-main{grid-template-columns:1fr;}.hero-products-layout{grid-template-columns:1fr;}.hero-product-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.products-grid{grid-template-columns:repeat(2,1fr);gap:7px;}.cat-nav-grid{grid-template-columns:repeat(4,1fr);}.hero-actions{flex-direction:column;}.hero-stats{flex-direction:column;gap:0;}.hero-stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.12);padding:10px 0;}.hero-stat:last-child{border-bottom:none;}.product-add-cart-row{flex-direction:column;}.product-guarantees{grid-template-columns:1fr;}}

/* =========================================
   HERO 3D CAROUSEL — PREMIUM
   ========================================= */

.hero-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 20px 0;
}

.hero-carousel-scene {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  perspective: 1100px;
  perspective-origin: 50% 48%;
  position: relative;
}

/* Ambient glow orbs */
.hcs-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(50px);
  animation: orb-drift 8s ease-in-out infinite alternate;
}
.hcs-orb--1 {
  width: 260px; height: 260px;
  background: radial-gradient(circle, rgba(37,72,128,.35) 0%, transparent 70%);
  top: 10%; left: 10%;
  animation-delay: 0s;
}
.hcs-orb--2 {
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(224,90,31,.18) 0%, transparent 70%);
  bottom: 10%; right: 8%;
  animation-delay: -4s;
}
@keyframes orb-drift {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(20px, -20px) scale(1.15); }
}

.hero-carousel-stage {
  width: 310px;
  height: 450px;
  position: relative;
  transform-style: preserve-3d;
}

/* Cards */
.hero-carousel-card {
  position: absolute;
  inset: 0;
  background: #fff;
  border-radius: 24px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  will-change: transform, opacity, filter;
  backface-visibility: hidden;
}

/* Badge */
.hcc-badge {
  position: absolute;
  top: 14px; left: 14px;
  z-index: 3;
  background: var(--accent);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  box-shadow: 0 4px 12px rgba(224,90,31,.4);
}

/* Shine overlay — moves with hover */
.hcc-shine {
  position: absolute;
  inset: 0;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,0) 55%, rgba(255,255,255,.06) 100%);
  pointer-events: none;
  transition: opacity .35s;
  z-index: 2;
}
.hero-carousel-card:not(.active) .hcc-shine { opacity: .5; }

/* Image area */
.hcc-media {
  flex: 1;
  background: #ffffff !important;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  overflow: hidden;
  position: relative;
  min-height: 280px;
}
.hcc-media::after {
  display: none !important;
}
.hcc-media img {
  width: 100%; height: 100%;
  object-fit: contain;
  transition: transform .5s ease;
  position: relative; z-index: 1;
  background: #fff;
  mix-blend-mode: normal;
}
.hero-carousel-card.active .hcc-media img { transform: scale(1.05); }

/* Body */
.hcc-body {
  padding: 16px 18px 18px;
  background: #fff;
  flex-shrink: 0;
  border-top: 1px solid var(--gray-100);
}
.hcc-cat {
  font-size: .64rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--navy-light);
  margin-bottom: 4px;
}
.hcc-title {
  font-size: .88rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.35;
  margin-bottom: 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.hcc-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.hcc-price {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--navy);
  font-family: var(--font-display);
}
.hcc-arrow {
  width: 30px; height: 30px;
  background: var(--navy);
  color: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem;
  transition: background .2s, transform .2s;
  opacity: 0;
  transition: opacity .25s;
}
.hero-carousel-card.active .hcc-arrow { opacity: 1; }
.hero-carousel-card.active:hover .hcc-arrow {
  background: var(--accent);
  transform: translateX(3px);
}

/* Nav arrows */
.hcs-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px; height: 36px;
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.25);
  border-radius: 50%;
  color: #fff;
  font-size: 1rem;
  cursor: pointer;
  transition: all .2s;
  z-index: 20;
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(8px);
}
.hcs-arrow:hover {
  background: rgba(255,255,255,.28);
  border-color: rgba(255,255,255,.5);
  transform: translateY(-50%) scale(1.1);
}
.hcs-arrow--prev { left: -8px; }
.hcs-arrow--next { right: -8px; }

/* Dots */
.hero-carousel-dots {
  display: flex; gap: 8px;
  align-items: center; justify-content: center;
  position: relative; z-index: 5;
}
.hcd-dot {
  width: 7px; height: 7px;
  border-radius: 50%; border: none;
  background: rgba(255,255,255,.28);
  cursor: pointer; padding: 0;
  transition: all .32s ease;
}
.hcd-dot.active {
  background: #fff;
  width: 26px;
  border-radius: 4px;
  box-shadow: 0 0 12px rgba(255,255,255,.5);
}
.hcd-dot:hover:not(.active) { background: rgba(255,255,255,.55); }

/* Responsive */
@media (max-width: 1100px) {
  .hero-carousel-stage { width: 280px; height: 400px; }
  .hero-visual { min-height: 440px; }
  .hcc-media { min-height: 240px; }
}
@media (max-width: 768px) {
  .hero-carousel-stage { width: 240px; height: 350px; }
  .hero-visual { min-height: 380px; }
  .hcc-media { min-height: 200px; }
  .hcs-arrow { display: none; }
}

/* =========================================
   PRODUCTS PER CATEGORY SECTIONS
   ========================================= */
.products-section--cat {
  padding: 40px 0 0;
  background: #fff;
}
.products-section--cat:nth-child(even) {
  background: var(--gray-50);
}
.products-section--cat:last-of-type {
  padding-bottom: 56px;
}

.products-section-header {
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px;
  margin-bottom: 20px; flex-wrap: wrap;
}
.psh-left {
  display: flex; align-items: center; gap: 14px;
}
.psh-icon {
  width: 48px; height: 48px; flex-shrink: 0;
  background: var(--navy-pale); border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; border: 1.5px solid rgba(13,33,68,.1);
}
.psh-left .section-label { margin-bottom: 2px; }
.psh-left .section-title { margin-bottom: 0; font-size: 1.25rem; }

.cat-section-footer {
  padding: 20px 0 0;
  border-top: 1px solid var(--gray-100);
  margin-top: 20px;
}

/* Divider between category sections */
.products-section--cat + .products-section--cat {
  border-top: 1px solid var(--gray-100);
}
