:root{
  --bg:#ffffff;
  --text:#0f172a;
  --muted:#4b5563;
  --border:#e5e7eb;
  --shadow:0 18px 40px rgba(2,6,23,.10);
  --btn:#0b0b0f;
  --btnHover:#000;
  --hover:#C05039;
  --radius:16px;

  /* footer */
  --footerBg:#050505;
  --footerText:#cbd5e1;
  --footerTitle:#ffffff;
  --footerLine:rgba(255,255,255,.10);
}

*{ box-sizing:border-box; }

body{
  background:var(--bg);
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  overflow-x:hidden;
}

/* =========================
   NAV
   ========================= */
.u-nav{
  background:#fff;
  border-bottom:1px solid rgba(229,231,235,.7);
}

.u-brand{
  font-weight:900;
  letter-spacing:.6px;
  color:#111827;
  text-transform:uppercase;
}

.u-link{
  color:#111827;
  font-weight:700;
  letter-spacing:.4px;
  text-transform:uppercase;
  font-size:13px;
  opacity:.90;
  transition:color .15s ease, transform .15s ease, opacity .15s ease;
}
.u-link:hover{
  color:var(--hover);
  opacity:1;
  transform:translateY(-1px);
}

.u-toggler{
  border:1px solid var(--border) !important;
  border-radius:14px;
  padding:10px 12px;
  box-shadow:0 10px 24px rgba(2,6,23,.06);
}
.u-toggler:focus{
  box-shadow:0 0 0 4px rgba(192,80,57,.18);
}

.u-iconbtn{
  height:42px;
  width:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  background:#fff;
  border-radius:14px;
  box-shadow:0 10px 24px rgba(2,6,23,.06);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease, background .15s ease;
  cursor:pointer;
  color:#111827;
}
.u-iconbtn i{ color:inherit; opacity:.9; }

.u-iconbtn:hover{
  transform:translateY(-1px);
  border-color:rgba(192,80,57,.55);
  box-shadow:0 14px 28px rgba(2,6,23,.10);
  color:var(--hover);
}

.u-buy{
  background:var(--btn);
  color:#fff;
  border:none;
  border-radius:14px;
  padding:10px 18px;
  font-weight:900;
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.u-buy:hover{
  background:var(--hover);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(2,6,23,.14);
}

/* =========================
   OFFCANVAS
   ========================= */
.u-offcanvas{
  width:320px;
  border-left:1px solid rgba(229,231,235,.8);
  box-shadow:-22px 0 50px rgba(2,6,23,.18);
}

.u-offcanvas-title{
  font-weight:900;
  letter-spacing:.6px;
  text-transform:uppercase;
}

.u-close:focus{
  box-shadow:0 0 0 4px rgba(192,80,57,.18);
}

.u-offcanvas-links .u-link{
  padding:12px 0;
  border-bottom:1px solid rgba(229,231,235,.65);
}
.u-offcanvas-links .u-link:hover{ color:var(--hover); }

.u-offcanvas-actions .u-iconbtn{
  width:100%;
  justify-content:center;
  gap:10px;
  border-radius:14px;
}

/* =========================
   HERO
   ========================= */
.u-hero{ padding:34px 0 30px; }

.u-title{
  font-weight:900;
  font-size:clamp(44px, 5vw, 74px);
  line-height:1.0;
  margin:0;
  color:#0b0b0f;
}

.u-sub{
  color:var(--muted);
  margin-top:16px;
  max-width:540px;
  font-weight:600;
  line-height:1.7;
}

.u-btn-primary{
  background:var(--btn);
  color:#fff;
  border:none;
  border-radius:14px;
  padding:12px 18px;
  font-weight:900;
  min-width:160px;
  transition:transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.u-btn-primary:hover{
  background:var(--hover);
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(2,6,23,.14);
}

.u-btn-outline{
  background:#fff;
  border:1px solid var(--border);
  color:#111827;
  border-radius:14px;
  padding:12px 18px;
  font-weight:900;
  min-width:160px;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease;
}
.u-btn-outline:hover{
  border-color:rgba(192,80,57,.55);
  color:var(--hover);
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(2,6,23,.10);
}

/* FEATURES */
.u-features{ margin-top:42px; color:#111827; }
.u-feature{ display:flex; align-items:flex-start; gap:12px; }
.u-feature i{
  font-size:20px; color:#111827; opacity:.8;
  margin-top:2px; width:24px; text-align:center;
}
.u-feature .t1{ font-weight:900; font-size:13px; }
.u-feature .t2{ color:var(--muted); font-weight:700; font-size:12px; margin-top:2px; }

/* COLLAGE */
.u-collage-wrap{
  position:relative;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px 0 40px;
}
.u-collage{
  position:relative;
  width:min(600px, 100%);
  height:clamp(360px, 52vw, 520px);
}
.u-photo{
  position:absolute;
  overflow:hidden;
  background:#fff;
  padding:14px;
  border-radius:999px 999px 28px 28px;
  border:1px solid rgba(226,232,240,.9);
  box-shadow:0 18px 40px rgba(2,6,23,.14);
  z-index:2;
  transition:transform .18s ease, box-shadow .18s ease;
}
.u-photo:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 50px rgba(2,6,23,.18);
}
.u-photo img{
  display:block; width:100%; height:100%;
  object-fit:cover; object-position:center top;
  border-radius:999px 999px 22px 22px;
}
.p1{
  width:clamp(170px, 23vw, 240px);
  height:clamp(280px, 38vw, 450px);
  left:6%; top:6%;
  transform:rotate(-2deg);
  z-index:2;
}
.p2{
  width:clamp(170px, 23vw, 240px);
  height:clamp(280px, 38vw, 450px);
  left:36%; top:20%;
  transform:rotate(2deg);
  z-index:4;
}
.p3{
  width:clamp(170px, 23vw, 240px);
  height:clamp(280px, 38vw, 450px);
  left:66%; top:32%;
  transform:rotate(-1deg);
  z-index:2;
}

/* badges */
.u-badge{
  position:absolute;
  z-index:5;
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  padding:14px 18px;
  font-weight:900;
  font-size:13px;
  box-shadow:0 14px 32px rgba(2,6,23,.12);
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:#111827;
  white-space:nowrap;
}
.badge-top{ top:6%; right:6%; }
.badge-bottom{ bottom:4%; left:22%; }

/* =========================
   FOOTER (LIKE IMAGE)
   ========================= */
.u-footer{
  background:var(--footerBg);
  color:var(--footerText);
}

.u-footer-brand{
  color:#fff;
  font-weight:900;
  letter-spacing:.8px;
  text-transform:uppercase;
  margin:0;
}

.u-footer-text{
  color:rgba(203,213,225,.9);
  line-height:1.8;
  font-weight:600;
  max-width:360px;
}

.u-footer-title{
  color:var(--footerTitle);
  font-weight:900;
  margin-bottom:14px;
}

.u-footer-links{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.u-footer-links a{
  color:rgba(203,213,225,.9);
  text-decoration:none;
  font-weight:600;
  transition:color .15s ease;
}
.u-footer-links a:hover{
  color:var(--hover);
}

/* email + join */
.u-footer-form{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.u-footer-input{
  flex:1;
  min-width:220px;
  height:46px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.14);
  color:#fff;
  padding:0 18px;
  outline:none;
}
.u-footer-input::placeholder{ color:rgba(255,255,255,.75); }
.u-footer-input:focus{
  border-color:rgba(192,80,57,.65);
  box-shadow:0 0 0 4px rgba(192,80,57,.20);
}

.u-footer-btn{
  height:46px;
  border-radius:999px;
  border:none;
  padding:0 22px;
  font-weight:900;
  background:#fff;
  color:#111;
  transition:transform .15s ease, background .15s ease, color .15s ease;
}
.u-footer-btn:hover{
  background:var(--hover);
  color:#fff;
  transform:translateY(-1px);
}

/* socials */
.u-footer-social{
  display:flex;
  gap:18px;
}
.u-social{
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  text-decoration:none;
  transition:transform .15s ease, border-color .15s ease, color .15s ease;
}
.u-social:hover{
  transform:translateY(-1px);
  border-color:rgba(192,80,57,.6);
  color:var(--hover);
}

/* bottom line */
.u-footer-bottom{
  border-top:1px solid var(--footerLine);
  text-align:center;
}
.u-footer-copy{
  color:rgba(203,213,225,.75);
  font-weight:600;
  font-size:13px;
}

/* =========================
   RESPONSIVE
   ========================= */
@media (max-width: 991.98px){
  .u-hero{ padding-top:22px; }
  .u-features{ margin-top:28px; }

  .u-collage{
    width:min(560px, 100%);
    height:clamp(340px, 70vw, 460px);
  }
  .p1{ left:8%; top:14%; }
  .p2{ left:38%; top:10%; }
  .p3{ left:68%; top:22%; }

  .badge-top{ top:4%; right:4%; }
  .badge-bottom{ bottom:3%; left:28%; }

  .u-offcanvas{ width:88vw; max-width:360px; }
}

@media (max-width: 575.98px){
  .u-title{ font-size:42px; }
  .u-sub{ font-size:14px; }

  .u-btn-primary,
  .u-btn-outline{ width:100%; }

  .u-collage{ width:100%; height:420px; }
  .p1{ width:150px; height:290px; left:1%; top:30%; }
  .p2{ width:165px; height:320px; left:20%; top:22%; }
  .p3{ width:150px; height:290px; left:43%; top:30%; }

  .u-badge{ font-size:12px; padding:12px 14px; }
  .badge-bottom{ left:18%; }

  .u-footer-form{ flex-direction:column; }
  .u-footer-btn{ width:160px; }
}
.u-collage-wrap {
  position: relative;
  width: 100%;
}

.center-div {
  display: flex;
  justify-content: center;
  align-items: center;
}

/* =========================
   TRUST / BENEFITS STRIP
   ========================= */
.u-trust{
  background:#f3f4f6;                 /* light gray band */
  border-top:1px solid rgba(229,231,235,.9);
  border-bottom:1px solid rgba(229,231,235,.9);
  padding:42px 0;
  margin-top:84px;
}

.u-trust-item{
  max-width: 260px;
  margin: 0 auto;
}

.u-trust-icon{
  font-size:28px;
  color:#111827;
  opacity:.85;
  margin-bottom:12px;
}

.u-trust-title{
  font-weight:900;
  letter-spacing:.2px;
  margin-bottom:8px;
  color:#111827;
}

.u-trust-text{
  margin:0;
  color: var(--muted);
  font-weight:600;
  line-height:1.55;
  font-size:13px;
}

/* Slight spacing tune for small screens */
@media (max-width: 575.98px){
  .u-trust{
    padding:34px 0;
    margin-top:24px;
  }
  .u-trust-item{
    max-width: 320px;
  }
}



/* =========================
   CATEGORIES (MATCH SCREENSHOT)
   ========================= */
.u-categories{
  padding: 60px 0 40px;
  background: #fff;
}

.u-categories-head{
  margin-bottom: 34px;
}

.u-categories-title{
  font-size: 52px;
  font-weight: 1000;
  letter-spacing: -0.5px;
  margin: 0;
  color:#0b0b0f;
}

.u-categories-sub{
  margin: 10px auto 0;
  max-width: 720px;
  color: var(--muted);
  font-weight: 700;
  font-size: 14px;
}

/* card */
.u-cat-card{
  position: relative;
  display: block;
  width: 100%;
  height: 370px;
  border-radius: 22px;
  overflow: hidden;
  background: #f3f4f6;
  box-shadow: 0 18px 40px rgba(2,6,23,.08);
  transition: .22s ease;
  text-decoration: none;
}

.u-cat-card img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  filter: saturate(1.02);
  transform: scale(1.0);
  transition: .22s ease;
}

.u-cat-pill{
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  background: #fff;
  border: 1px solid rgba(229,231,235,.9);
  padding: 10px 22px;
  border-radius: 999px;
  font-weight: 900;
  letter-spacing: .6px;
  font-size: 12px;
  color: #111827;
  box-shadow: 0 14px 30px rgba(2,6,23,.14);
  transition: .22s ease;
}

/* hover like your vibe */
.u-cat-card:hover{
  transform: translateY(-4px);
}
.u-cat-card:hover img{
  transform: scale(1.03);
}
.u-cat-card:hover .u-cat-pill{
  border-color: rgba(192,80,57,.55);
  color: var(--hover);
}


@media (max-width: 575.98px){

  .u-categories{ padding: 46px 0 30px; }
  .u-categories-title{ font-size: 38px; }
  .u-cat-card{ height: 320px; }
}

/* =========================
   LIMITED OFFER / COUNTDOWN
   ========================= */
.u-deal{
  padding: 70px 0 60px;
  background: #fff;
}

.u-deal-box{
  background: #f3f4f6;
  border: 1px solid rgba(229,231,235,.9);
  border-radius: 22px;
  padding: 48px 44px;
  box-shadow: 0 18px 40px rgba(2,6,23,.08);
}

.u-deal-title{
  font-size: 46px;
  font-weight: 1000;
  line-height: 1.05;
  margin: 0;
  color: #0b0b0f;
}

.u-deal-sub{
  margin-top: 14px;
  max-width: 520px;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.7;
  font-size: 14px;
}

.u-timer{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.u-timebox{
  width: 88px;
  height: 78px;
  background: #fff;
  border: 1px solid rgba(229,231,235,.95);
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction: column;
  box-shadow: 0 10px 24px rgba(2,6,23,.06);
}

.u-num{
  font-weight: 1000;
  font-size: 26px;
  color: #0b0b0f;
  line-height: 1;
}

.u-lbl{
  margin-top: 4px;
  font-weight: 800;
  font-size: 12px;
  color: #6b7280;
}

.u-deal-note{
  margin-top: 12px;
  color: #6b7280;
  font-weight: 700;
  font-size: 12px;
}

.u-deal-btn{
  margin-top: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  border-radius: 12px;
  background: #0b0b0f;
  color: #fff;
  font-weight: 900;
  letter-spacing: .4px;
  border: none;
  transition: .2s ease;
  text-transform: uppercase;
  font-size: 13px;
}
.u-deal-btn:hover{
  background: var(--hover);
  color: #fff;
  transform: translateY(-1px);
}

/* Equipment image on right */
.u-deal-image{
  width: 100%;
  display:flex;
  justify-content: center;
  align-items: center;
}

.u-deal-image img{
  width: min(420px, 100%);
  height: auto;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 20px 40px rgba(2,6,23,.15));
}

/* Responsive */
@media (max-width: 991.98px){
  .u-deal-box{
    padding: 36px 22px;
  }
  .u-deal-title{
    font-size: 36px;
  }
  .u-timebox{
    width: 82px;
    height: 74px;
  }
}

@media (max-width: 575.98px){
  .u-deal-title{
    font-size: 32px;
  }
  .u-timer{
    gap: 10px;
  }
  .u-timebox{
    width: 76px;
    height: 70px;
  }
}

/* =========================
   CONTACT + GPS
   ========================= */
.u-contact{
  padding: 80px 0 70px;
  background: #fff;
}

.u-contact-head{
  max-width: 780px;
  margin: 0 auto;
}

.u-contact-title{
  font-weight: 1000;
  font-size: clamp(30px, 3.2vw, 44px);
  margin: 0;
  color: #0b0b0f;
}

.u-contact-sub{
  margin-top: 12px;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.7;
}

.u-contact-card{
  border: 1px solid rgba(229,231,235,.9);
  border-radius: 22px;
  background: #fff;
  padding: 28px 26px;
  box-shadow: 0 18px 40px rgba(2,6,23,.06);
}

.u-card-title{
  font-weight: 1000;
  margin: 0 0 14px;
  color: #0b0b0f;
}

.u-card-sub{
  color: var(--muted);
  font-weight: 700;
  font-size: 13px;
}

/* inputs */
.u-label{
  font-weight: 900;
  font-size: 13px;
  color: #111827;
  margin-bottom: 8px;
  display: block;
}

.u-input, .u-textarea{
  width: 100%;
  border: 1px solid rgba(229,231,235,.95);
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 700;
  outline: none;
  transition: .2s ease;
  background: #fff;
}

.u-textarea{ resize: vertical; }

.u-input:focus, .u-textarea:focus{
  border-color: rgba(192,80,57,.65);
  box-shadow: 0 0 0 4px rgba(192,80,57,.12);
}

.u-form-note{
  color: #6b7280;
  font-weight: 700;
  font-size: 12px;
}

/* buttons */
.u-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 12px;
  padding: 12px 16px;
  font-weight: 900;
  border: 1px solid transparent;
  transition: .2s ease;
  text-decoration: none;
  white-space: nowrap;
}

.u-btn-dark{
  background: #0b0b0f;
  color: #fff;
}
.u-btn-dark:hover{
  background: var(--hover);
  color: #fff;
  transform: translateY(-1px);
}

.u-btn-outline2{
  background: #fff;
  border: 1px solid rgba(229,231,235,.95);
  color: #0b0b0f;
}
.u-btn-outline2:hover{
  border-color: var(--hover);
  color: var(--hover);
  transform: translateY(-1px);
}

/* small button */
.u-btn-sm{
  padding: 10px 12px;
  border-radius: 12px;
  font-size: 13px;
}

/* Location box */
.u-loc-box{
  border: 1px solid rgba(229,231,235,.9);
  border-radius: 18px;
  padding: 16px;
  background: #f9fafb;
}

.u-loc-row{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.u-loc-item{
  background: #fff;
  border: 1px solid rgba(229,231,235,.95);
  border-radius: 14px;
  padding: 12px;
}

.u-loc-label{
  color: #6b7280;
  font-weight: 800;
  font-size: 12px;
}

.u-loc-value{
  margin-top: 6px;
  font-weight: 1000;
  font-size: 14px;
  color: #0b0b0f;
}

.u-loc-status{
  color: #111827;
  font-weight: 800;
  font-size: 13px;
}

/* Mini contact row */
.u-contact-mini{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.u-mini{
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(229,231,235,.95);
  background: #fff;
}

.u-mini i{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f9fafb;
  color: #0b0b0f;
}

.u-mini-t{
  font-weight: 1000;
  font-size: 13px;
}

.u-mini-s{
  color: #6b7280;
  font-weight: 800;
  font-size: 12px;
  margin-top: 2px;
}

/* Responsive */
@media (max-width: 991.98px){
  .u-contact{ padding: 60px 0 55px; }
  .u-contact-card{ padding: 22px 18px; }
  .u-loc-row{ grid-template-columns: 1fr; }
  .u-contact-mini{ grid-template-columns: 1fr; }
  .u-map iframe{ height: 260px; }
}


/* FULL WIDTH LOCATION TWEAKS */
.u-contact-card-wide{
  padding: 32px 32px;
}

.u-map-wide iframe{
  width: 100%;
  height: 420px;
  border-radius: 18px;
  border: 0;
}

/* Tablet */
@media (max-width: 991.98px){
  .u-map-wide iframe{
    height: 320px;
  }
}

/* Mobile */
@media (max-width: 575.98px){
  .u-contact-card-wide{
    padding: 22px 18px;
  }

  .u-map-wide iframe{
    height: 260px;
  }
}


/* WhatsApp contact style */
.u-mini-whatsapp i{
  background: #25D366;
  color: #fff;
}

.u-mini-whatsapp .u-mini-s{
  color: #25D366;
  font-weight: 900;
  text-decoration: none;
}

.u-mini-whatsapp .u-mini-s:hover{
  text-decoration: underline;
}


:root{
  --hover:#C05039;
}

/* =========================
   FEATURED PRODUCTS
   ========================= */
.u-products{
  padding: 70px 0 60px;
  background: #fff;
}

.u-products-head{
  max-width: 820px;
  margin: 0 auto;
}

.u-products-title{
  font-weight: 1000;
  font-size: clamp(28px, 3vw, 42px);
  margin: 0;
  color: #0b0b0f;
}

.u-products-sub{
  margin-top: 12px;
  color: var(--muted);
  font-weight: 700;
  line-height: 1.7;
}

/* grid */
.u-products-grid{
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

/* card */
.u-prod-card{
  border: 1px solid rgba(229,231,235,.95);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(2,6,23,.06);
  overflow: hidden;
  transition: .2s ease;
  display: flex;
  flex-direction: column;
}

.u-prod-card:hover{
  transform: translateY(-3px);
  border-color: rgba(192,80,57,.45);
  box-shadow: 0 22px 50px rgba(2,6,23,.10);
}

/* image area */
.u-prod-media{
  background: #f9fafb;
  padding: 16px;
  display: grid;
  place-items: center;
  min-height: 190px;
}

.u-prod-media img{
  width: 100%;
  max-width: 190px;
  height: 170px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 18px 24px rgba(2,6,23,.10));
}

/* text */
.u-prod-body{
  padding: 14px 14px 16px;
}

.u-prod-name{
  font-weight: 1000;
  font-size: 14px;
  margin: 0;
  color: #0b0b0f;
}

.u-prod-desc{
  margin: 8px 0 12px;
  color: #6b7280;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.55;
}

/* button */
.u-prod-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 900;
  font-size: 13px;
  text-decoration: none;
  border: 1px solid rgba(229,231,235,.95);
  color: #0b0b0f;
  background: #fff;
  transition: .2s ease;
  width: 100%;
}

.u-prod-btn:hover{
  background: var(--hover);
  border-color: var(--hover);
  color: #fff;
}

/* responsive */
@media (max-width: 1199.98px){
  .u-products-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 767.98px){
  .u-products{ padding: 55px 0 50px; }
  .u-products-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 575.98px){
  .u-products-grid{ grid-template-columns: 1fr; }
  .u-prod-media{ min-height: 170px; }
  .u-prod-media img{ height: 150px; }
}


/* =========================
   SCROLL REVEAL ANIMATION
   ========================= */
.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .75s ease, transform .75s ease;
  will-change: opacity, transform;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Variants */
.reveal.reveal-up { transform: translateY(22px); }
.reveal.reveal-left { transform: translateX(-22px); }
.reveal.reveal-right { transform: translateX(22px); }
.reveal.reveal-zoom { transform: scale(.96); }

/* Stagger delay via CSS variable */
.reveal.is-visible {
  transition-delay: var(--d, 0ms);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.is-visible {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
