.home-shop-hero-section{
  margin-top:var(--sp-32);
}

.home-shop-hero{
  position:relative;
  overflow:hidden;
  display:grid;
  gap:16px;
  padding:18px;
  border-radius:22px;
  background:
    radial-gradient(75% 110% at 0% 0%, rgba(255,255,255,.56) 0%, rgba(255,255,255,.08) 55%, transparent 72%),
    linear-gradient(135deg, #f7efe3 0%, #f1e7d7 100%);
  border:1px solid rgba(174,129,55,.16);
  box-shadow:0 14px 28px rgba(100,73,23,.09);
}

.home-shop-hero::after{
  content:"";
  position:absolute;
  right:-80px;
  top:-80px;
  width:180px;
  height:180px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(199,164,106,.12) 0%, rgba(199,164,106,0) 72%);
  pointer-events:none;
}

.home-shop-hero__intro{
  position:relative;
  z-index:1;
  display:grid;
  gap:10px;
  align-content:start;
  padding-right:0;
}

.home-shop-hero__eyebrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  min-height:28px;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(159,121,48,.2);
  color:#8b6425;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
}

.home-shop-hero__intro h2{
  margin:0;
  font-size:clamp(22px, 2.4vw, 28px);
  line-height:1.12;
  letter-spacing:-.03em;
  max-width:none;
}

.home-shop-hero__desc{
  margin:0;
  max-width:60ch;
  color:#5d6472;
  line-height:1.6;
  font-size:14px;
}

.home-shop-hero__chips{
  display:none;
}

.home-shop-hero__chip{
  display:none;
}

.home-shop-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:2px;
}

.home-shop-hero__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 16px;
  border-radius:999px;
  font-size:13px;
  font-weight:700;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
}

.home-shop-hero__cta--primary{
  color:#fff;
  background:linear-gradient(135deg,#b88936 0%, #8e6726 100%);
  box-shadow:0 14px 28px rgba(143,103,38,.24);
}

.home-shop-hero__cta--ghost{
  color:#7d5b23;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(159,121,48,.22);
}

.home-shop-hero__products{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.home-shop-hero__loading,
.home-shop-hero__empty{
  padding:18px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.72);
  border:1px dashed rgba(15,23,42,.14);
  color:#667085;
  text-align:center;
  font-size:13px;
}

.home-shop-hero__product{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:10px;
  border-radius:16px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 10px 22px rgba(15,23,42,.07);
  backdrop-filter:blur(8px);
  min-width:0;
  height:100%;
}

.home-shop-hero__media{
  position:relative;
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  aspect-ratio:1 / 1;
  min-height:0;
}

.home-shop-hero__media img{
  width:100%;
  height:100%;
  object-fit:contain;
  background:#fff;
  padding:8px;
}

.home-shop-hero__body{
  display:grid;
  gap:7px;
  min-width:0;
  align-content:start;
  flex:1;
  grid-template-rows:auto auto auto 1fr auto auto;
}

.home-shop-hero__meta{
  display:flex;
  flex-wrap:wrap;
  gap:5px;
  align-items:center;
}

.home-shop-hero__badge{
  display:inline-flex;
  align-items:center;
  min-height:20px;
  padding:2px 7px;
  border-radius:999px;
  background:rgba(184,137,54,.12);
  color:#8e6726;
  font-size:10px;
  font-weight:800;
  letter-spacing:.04em;
}

.home-shop-hero__badge--soft{
  background:rgba(15,23,42,.06);
  color:#536072;
}

.home-shop-hero__name{
  margin:0;
  font-size:14px;
  line-height:1.45;
}

.home-shop-hero__effects{
  display:flex;
  flex-wrap:wrap;
  gap:5px;
}

.home-shop-hero__effect-tag{
  display:inline-flex;
  align-items:center;
  min-height:20px;
  padding:2px 7px;
  border-radius:999px;
  background:#f6efe4;
  color:#8a6527;
  border:1px solid rgba(184,137,54,.16);
  font-size:10px;
  font-weight:800;
  letter-spacing:.02em;
}

.home-shop-hero__effect-tag--more{
  background:rgba(15,23,42,.06);
  color:#536072;
  border-color:rgba(15,23,42,.08);
}

.home-shop-hero__name a{
  text-decoration:none;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.home-shop-hero__summary{
  margin:0;
  color:#667085;
  font-size:12px;
  line-height:1.5;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.home-shop-hero__review{
  display:grid;
  gap:4px;
  padding:10px 10px 9px;
  border-radius:12px;
  background:linear-gradient(180deg, rgba(246,239,228,.92), rgba(255,255,255,.92));
  border:1px solid rgba(184,137,54,.12);
}

.home-shop-hero__review-label{
  font-size:10px;
  font-weight:800;
  letter-spacing:.08em;
  color:#9a712c;
  text-transform:uppercase;
}

.home-shop-hero__review-quote{
  margin:0;
  color:#495161;
  font-size:12px;
  line-height:1.55;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.home-shop-hero__review.is-expanded .home-shop-hero__review-quote{
  display:block;
  -webkit-line-clamp:unset;
  overflow:visible;
}

.home-shop-hero__review-toggle{
  width:max-content;
  padding:0;
  border:0;
  background:transparent;
  color:#9a712c;
  font-size:11px;
  font-weight:800;
  line-height:1.2;
  cursor:pointer;
}

.home-shop-hero__review-toggle:hover{
  text-decoration:underline;
}

.home-shop-hero__review-toggle:focus-visible{
  outline:none;
  box-shadow:var(--focus-ring);
  border-radius:6px;
}

.home-shop-hero__review-meta{
  font-size:11px;
  color:#7b8595;
  font-weight:700;
}

.home-shop-hero__footer{
  display:flex;
  align-items:baseline;
  justify-content:flex-start;
  gap:8px;
  margin-top:auto;
}

.home-shop-hero__price{
  display:flex;
  align-items:baseline;
  gap:8px;
  flex-wrap:wrap;
}

.home-shop-hero__price-now{
  font-size:15px;
  font-weight:800;
  color:#111827;
}

.home-shop-hero__price-compare{
  font-size:11px;
  color:#8b93a1;
  text-decoration:line-through;
}

.home-shop-hero__link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  width:100%;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.1);
  background:#fff;
  color:#111827;
  font-size:11px;
  font-weight:700;
  text-decoration:none;
  margin-top:2px;
}

.home-shop-hero__product:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 26px rgba(15,23,42,.1);
}

.home-shop-hero__cta:hover,
.home-shop-hero__link:hover{
  transform:translateY(-1px);
}

.home-shop-hero__cta--ghost:hover,
.home-shop-hero__link:hover{
  border-color:rgba(159,121,48,.34);
}

.home-shop-hero__cta:focus-visible,
.home-shop-hero__link:focus-visible{
  outline:none;
  box-shadow:var(--focus-ring);
}

@media(min-width:920px){
  .home-shop-hero__products{
    grid-template-columns:repeat(3, minmax(0,1fr));
  }

  .home-shop-hero__intro{
    grid-template-columns:minmax(0,1fr) auto;
    align-items:end;
    gap:12px 16px;
  }

  .home-shop-hero__actions{
    grid-column:2;
    grid-row:1 / 4;
    justify-content:flex-end;
    align-self:center;
    flex-direction:row;
    width:auto;
  }

  .home-shop-hero__eyebrow,
  .home-shop-hero__intro h2,
  .home-shop-hero__desc,
  .home-shop-hero__chips{
    grid-column:1;
  }

  .home-shop-hero__desc{
    max-width:none;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .home-shop-hero__product{
    padding:10px;
  }

  .home-shop-hero__media{
    aspect-ratio:1 / 1;
  }
}

@media(min-width:1200px){
  .home-shop-hero{
    padding:22px;
  }
}

@media(max-width:639px){
  .home-shop-hero{
    padding:18px;
  }

  .home-shop-hero__chips{
    display:none;
  }

  .home-shop-hero__actions{
    flex-wrap:nowrap;
    gap:8px;
  }

  .home-shop-hero__cta{
    flex:1 1 0;
    min-width:0;
    padding:0 10px;
    font-size:12px;
  }

  .home-shop-hero__products{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}

@media(max-width:479px){
  .home-shop-hero__products{
    grid-template-columns:1fr;
  }
}
