:root {
  --pp-green: #0f8f4f;
  --pp-green-dark: #075f38;
  --pp-lime: #a7f3d0;
  --pp-orange: #f97316;
  --pp-amber: #f59e0b;
  --pp-ink: #0f172a;
  --pp-muted: #64748b;
  --pp-line: rgba(15, 23, 42, .10);
  --pp-card: rgba(255, 255, 255, .86);
  --pp-shadow: 0 22px 55px rgba(15, 23, 42, .11);
  --pp-radius: 28px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.shop-body {
  min-height: 100vh;
  color: var(--pp-ink);
  background:
    radial-gradient(circle at top left, rgba(16, 185, 129, .22), transparent 34rem),
    radial-gradient(circle at top right, rgba(249, 115, 22, .18), transparent 30rem),
    linear-gradient(135deg, #f8fafc 0%, #ecfdf5 48%, #fff7ed 100%);
  background-attachment: fixed;
}
img { max-width: 100%; }
a { text-decoration: none; }

.shop-shell {
  width: 100%;
  max-width: none;
  margin-inline: auto;
  padding-inline: clamp(.5rem, 1vw, 1rem);
}
.shop-section { padding: clamp(1.25rem, 3vw, 2.5rem) 0; }
.shop-card,
.modern-card {
  background: var(--pp-card);
  border: 1px solid rgba(255,255,255,.7);
  border-radius: var(--pp-radius);
  box-shadow: var(--pp-shadow);
  backdrop-filter: blur(18px);
}
.shop-glass {
  background: rgba(255,255,255,.74);
  border: 1px solid rgba(255,255,255,.72);
  box-shadow: 0 18px 45px rgba(15, 23, 42, .10);
  backdrop-filter: blur(16px);
}
.shop-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .4rem .75rem;
  border-radius: 999px;
  background: rgba(16, 185, 129, .11);
  color: var(--pp-green-dark);
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.shop-gradient-text {
  background: linear-gradient(100deg, var(--pp-green-dark), var(--pp-green), var(--pp-orange));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.shop-btn,
.btn-shop {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  min-height: 2.8rem;
  padding: .78rem 1.1rem;
  border: 0;
  border-radius: 999px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease, background .18s ease;
}
.shop-btn:hover,
.btn-shop:hover { transform: translateY(-2px); }
.shop-btn-primary,
.btn-shop-primary {
  color: white;
  background: linear-gradient(135deg, var(--pp-green), var(--pp-green-dark));
  box-shadow: 0 14px 30px rgba(15, 143, 79, .25);
}
.shop-btn-accent,
.btn-shop-accent {
  color: white;
  background: linear-gradient(135deg, var(--pp-orange), var(--pp-amber));
  box-shadow: 0 14px 30px rgba(249, 115, 22, .24);
}
.shop-btn-soft {
  color: var(--pp-green-dark);
  background: rgba(16,185,129,.12);
}
.shop-btn-danger {
  color: white;
  background: linear-gradient(135deg, #ef4444, #b91c1c);
}
.shop-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid var(--pp-line);
  color: var(--pp-green-dark);
  box-shadow: 0 10px 22px rgba(15,23,42,.08);
  transition: transform .18s ease, color .18s ease;
}
.shop-icon-btn:hover { transform: translateY(-2px); color: var(--pp-orange); }
.shop-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.35rem;
  padding-inline: .35rem;
  border-radius: 999px;
  color: white;
  background: var(--pp-orange);
  font-size: .72rem;
  font-weight: 900;
}

.shop-navbar {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(15, 23, 42, .08);
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(18px);
  box-shadow: 0 12px 35px rgba(15,23,42,.07);
}
.shop-nav-inner {
  min-height: 76px;
  display: grid;
  grid-template-columns: auto minmax(180px, 1fr) auto;
  gap: 1rem;
  align-items: center;
}
.shop-logo img { height: 50px; object-fit: contain; }
.shop-search { position: relative; }
.shop-search input,
.shop-input,
.shop-select,
.modern-form input:not([type='checkbox']):not([type='radio']):not([type='file']),
.modern-form select,
.modern-form textarea {
  width: 100%;
  border: 1px solid rgba(15,23,42,.13);
  border-radius: 18px;
  background: rgba(255,255,255,.9);
  color: var(--pp-ink);
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.shop-search input { min-height: 48px; padding: .85rem 3rem .85rem 1rem; }
.shop-input,
.shop-select,
.modern-form input:not([type='checkbox']):not([type='radio']):not([type='file']),
.modern-form select { min-height: 48px; padding: .75rem 1rem; }
.modern-form textarea { min-height: 110px; padding: .9rem 1rem; }
.shop-search input:focus,
.shop-input:focus,
.shop-select:focus,
.modern-form input:focus,
.modern-form select:focus,
.modern-form textarea:focus {
  border-color: rgba(15,143,79,.72);
  box-shadow: 0 0 0 4px rgba(16,185,129,.13);
}
.shop-search-icon {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--pp-green);
}
.shop-live-results {
  position: absolute;
  inset-inline: 0;
  top: calc(100% + .55rem);
  overflow: hidden;
  border-radius: 22px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 18px 45px rgba(15, 23, 42, .16);
  z-index: 70;
}
.shop-nav-actions { display: flex; align-items: center; gap: .75rem; }
.shop-nav-link { display: inline-flex; flex-direction: column; align-items: center; gap: .15rem; color: var(--pp-green-dark); font-size: .76rem; font-weight: 800; }
.shop-nav-link i { font-size: 1.25rem; }
.shop-nav-link:hover { color: var(--pp-orange); }

.shop-hero {
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  padding: clamp(1.5rem, 4vw, 3rem);
  color: white;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.28), transparent 19rem),
    linear-gradient(135deg, #064e3b, #0f8f4f 54%, #f97316);
  box-shadow: 0 24px 60px rgba(6, 78, 59, .24);
}
.shop-hero::after {
  content: '';
  position: absolute;
  width: 22rem;
  height: 22rem;
  border-radius: 999px;
  right: -7rem;
  bottom: -10rem;
  background: rgba(255,255,255,.16);
}
.shop-hero > * { position: relative; z-index: 1; }
.shop-hero h1 { font-size: clamp(2rem, 6vw, 4.7rem); line-height: .98; letter-spacing: -.06em; }
.shop-hero p { color: rgba(255,255,255,.86); }
.shop-stat-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: .85rem; }
.shop-stat { padding: 1rem; border-radius: 22px; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.18); }
.shop-stat strong { display: block; font-size: clamp(1.3rem, 3vw, 2.3rem); }
.shop-filter-bar { padding: 1rem; border-radius: 26px; }

.shop-product-grid {
  display: grid;
  grid-template-columns: repeat(var(--shop-columns, 4), minmax(0, 1fr));
  gap: clamp(1rem, 1.6vw, 1.4rem);
  align-items: stretch;
}
.shop-product-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 100%;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 28px;
  box-shadow: 0 18px 40px rgba(15, 23, 42, .09);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.shop-product-card:hover { transform: translateY(-6px); box-shadow: 0 24px 55px rgba(15, 23, 42, .14); border-color: rgba(15,143,79,.22); }
.shop-product-media {
  aspect-ratio: 4 / 3;
  margin: .75rem;
  border-radius: 23px;
}
.shop-carousel {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255,255,255,.86), rgba(236,253,245,.92)),
    radial-gradient(circle at top left, rgba(15,143,79,.12), transparent 12rem);
  border: 1px solid rgba(15,23,42,.06);
}
.shop-carousel-link { display: block; position: absolute; inset: 0; }
.shop-carousel-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  padding: .7rem;
  opacity: 0;
  transform: scale(.985);
  transition: opacity .42s ease, transform .42s ease;
  filter: saturate(1.03) contrast(1.02);
  backface-visibility: hidden;
  image-rendering: auto;
}
.shop-carousel-slide.is-active { opacity: 1; transform: scale(1); z-index: 2; }
.shop-product-card:hover .shop-carousel-slide.is-active { transform: scale(1.035); }
.shop-image-placeholder {
  display: grid;
  place-items: center;
  align-content: center;
  color: var(--pp-muted);
  background: rgba(255,255,255,.58);
}
.shop-carousel-arrow {
  position: absolute;
  top: 50%;
  z-index: 8;
  display: inline-grid;
  place-items: center;
  width: 2.35rem;
  height: 2.35rem;
  border: 0;
  border-radius: 999px;
  color: var(--pp-green-dark);
  background: rgba(255,255,255,.92);
  box-shadow: 0 14px 30px rgba(15,23,42,.15);
  cursor: pointer;
  opacity: 0;
  transform: translateY(-50%) scale(.94);
  transition: opacity .18s ease, transform .18s ease, color .18s ease;
}
.shop-carousel:hover .shop-carousel-arrow,
.shop-carousel:focus-within .shop-carousel-arrow { opacity: 1; transform: translateY(-50%) scale(1); }
.shop-carousel-arrow:hover { color: var(--pp-orange); }
.shop-carousel-prev { left: .75rem; }
.shop-carousel-next { right: .75rem; }
.shop-carousel-dots {
  position: absolute;
  left: 50%;
  bottom: .75rem;
  z-index: 9;
  display: flex;
  gap: .35rem;
  transform: translateX(-50%);
}
.shop-carousel-dot {
  width: .45rem;
  height: .45rem;
  border-radius: 999px;
  background: rgba(15,23,42,.22);
  transition: width .18s ease, background .18s ease;
}
.shop-carousel-dot.is-active { width: 1.35rem; background: var(--pp-green); }
.shop-product-body { display: flex; flex: 1; flex-direction: column; padding: .25rem 1rem 1rem; }
.shop-price { color: var(--pp-green-dark); font-weight: 950; font-size: 1.25rem; }
.shop-muted { color: var(--pp-muted); }
.shop-stock-track { height: .55rem; border-radius: 999px; background: #e2e8f0; overflow: hidden; }
.shop-stock-fill { height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--pp-green), var(--pp-orange)); }
.shop-rating { color: #f59e0b; }
.shop-empty {
  padding: 4rem 1rem;
  text-align: center;
  color: var(--pp-muted);
}

.shop-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 .7rem;
}
.shop-table th { color: var(--pp-muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; text-align: left; padding: .75rem 1rem; }
.shop-table td { background: rgba(255,255,255,.82); padding: 1rem; border-block: 1px solid rgba(15,23,42,.07); }
.shop-table td:first-child { border-left: 1px solid rgba(15,23,42,.07); border-radius: 18px 0 0 18px; }
.shop-table td:last-child { border-right: 1px solid rgba(15,23,42,.07); border-radius: 0 18px 18px 0; }

.shop-footer {
  margin-top: 3rem;
  border-top: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.74);
  backdrop-filter: blur(16px);
}

.line-clamp-2, .shop-line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 860px) {
  .shop-nav-inner { grid-template-columns: 1fr auto; }
  .shop-logo { order: 1; }
  .shop-nav-actions { order: 2; gap: .35rem; }
  .shop-search { grid-column: 1 / -1; order: 3; }
  .shop-nav-link span:not(.shop-badge) { display: none; }
  .shop-stat-grid { grid-template-columns: 1fr; }
  .shop-hero { border-radius: 26px; }
}

@media (max-width: 560px) {
  .shop-btn { width: 100%; }
  .shop-table { border-spacing: 0 .55rem; }
}


.shop-feature-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.shop-feature-strip > div {
  display: flex;
  align-items: center;
  gap: .9rem;
  padding: 1rem;
  border-radius: 24px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 14px 32px rgba(15,23,42,.07);
}
.shop-feature-strip i { color: var(--pp-green); font-size: 1.35rem; }
.shop-feature-strip strong, .shop-feature-strip small { display: block; }
.shop-feature-strip small { color: var(--pp-muted); font-weight: 700; }
.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.shop-toolbar-controls, .shop-result-summary { display: flex; align-items: center; gap: .7rem; flex-wrap: wrap; }
.shop-control-group { display: inline-flex; align-items: center; gap: .45rem; color: var(--pp-muted); font-size: .82rem; font-weight: 900; }
.shop-compact-select { min-height: 2.6rem; width: auto; min-width: 5rem; padding: .55rem 2.1rem .55rem .85rem; border-radius: 999px; }
.shop-filter-pill { padding: .45rem .75rem; border-radius: 999px; background: #fff7ed; color: #c2410c; font-size: .8rem; font-weight: 900; }
.shop-product-badges { position: absolute; top: 1.1rem; left: 1.1rem; z-index: 20; display: flex; gap: .35rem; flex-wrap: wrap; max-width: calc(100% - 5rem); }
.shop-mini-badge { display: inline-flex; align-items: center; gap: .35rem; padding: .35rem .6rem; border-radius: 999px; font-size: .7rem; font-weight: 950; box-shadow: 0 10px 20px rgba(15,23,42,.09); }
.shop-mini-badge-green { color: #065f46; background: rgba(236,253,245,.94); }
.shop-mini-badge-orange { color: #c2410c; background: rgba(255,247,237,.96); }
.shop-card-features { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 1rem; }
.shop-card-features span { display: inline-flex; align-items: center; gap: .3rem; padding: .35rem .55rem; border-radius: 999px; background: rgba(15,143,79,.08); color: var(--pp-green-dark); font-size: .68rem; font-weight: 900; }
.shop-detail-carousel { min-height: clamp(360px, 48vw, 620px); border-radius: 32px; }
.shop-detail-carousel .shop-carousel-slide { padding: clamp(.7rem, 2vw, 1.35rem); }
.shop-thumbnail-row { display: flex; gap: .75rem; overflow-x: auto; margin-top: 1rem; padding-bottom: .35rem; }
.shop-thumb { width: 5.25rem; height: 5.25rem; flex: 0 0 auto; border: 2px solid rgba(15,23,42,.08); border-radius: 20px; background: white; padding: .25rem; cursor: pointer; opacity: .72; transition: opacity .18s ease, border-color .18s ease, transform .18s ease; }
.shop-thumb:hover, .shop-thumb.is-active { opacity: 1; border-color: var(--pp-green); transform: translateY(-2px); }
.shop-thumb img { width: 100%; height: 100%; object-fit: contain; }
.shop-promise-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .75rem; }
.shop-promise-grid > div { padding: .9rem; border-radius: 20px; background: rgba(15,143,79,.07); border: 1px solid rgba(15,143,79,.10); }
.shop-promise-grid i, .shop-promise-grid strong, .shop-promise-grid span { display: block; }
.shop-promise-grid i { color: var(--pp-green); margin-bottom: .4rem; }
.shop-promise-grid strong { color: var(--pp-ink); font-size: 1rem; }
.shop-promise-grid span { color: var(--pp-muted); font-size: .78rem; font-weight: 700; }
.shop-pagination-bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-top: 1.25rem; padding: 1rem; border-radius: 24px; background: rgba(255,255,255,.76); border: 1px solid rgba(255,255,255,.82); }
.shop-pagination { display: flex; align-items: center; justify-content: center; gap: .65rem; flex-wrap: wrap; margin-block: 1.3rem; }
.shop-page-numbers { display: flex; gap: .45rem; flex-wrap: wrap; justify-content: center; }
.shop-page-btn, .shop-page-number { display: inline-flex; align-items: center; justify-content: center; gap: .45rem; min-width: 2.55rem; min-height: 2.55rem; padding: .6rem .9rem; border-radius: 999px; background: rgba(255,255,255,.9); color: var(--pp-green-dark); font-weight: 950; box-shadow: 0 10px 22px rgba(15,23,42,.08); cursor: pointer; transition: transform .18s ease, background .18s ease, color .18s ease; }
.shop-page-btn:hover, .shop-page-number:hover, .shop-page-number.is-active { transform: translateY(-2px); background: var(--pp-green); color: white; }
.shop-page-btn.is-disabled { opacity: .45; cursor: not-allowed; transform: none; }

@media (max-width: 1080px) { .shop-product-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .shop-feature-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 760px) { .shop-product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .shop-toolbar { align-items: stretch; } .shop-toolbar-controls { width: 100%; } .shop-feature-strip { grid-template-columns: 1fr; } .shop-promise-grid { grid-template-columns: 1fr; } }
@media (max-width: 560px) { .shop-shell { padding-inline: .5rem; } .shop-product-grid { grid-template-columns: 1fr; } .shop-carousel-arrow { opacity: 1; transform: translateY(-50%) scale(1); } }
