.esc-store-home{--brand:#1b5223;--accent:#e68d0f;--ink:#101314;--line:#e7edf0;--muted:#5e6a64}
.esc-store-home *{box-sizing:border-box}
.esc-store-home .ctr{max-width:1120px;margin:0 auto;padding:14px 12px}

/* Header */
.esc-store-home .head{border:2px solid var(--brand);border-radius:16px;background:#fff;padding:12px;margin-bottom:12px}
.esc-store-home .kicker{display:inline-flex;gap:8px;align-items:center;background:#fbfdfb;border:1px solid var(--line);padding:6px 10px;border-radius:999px;font-weight:900;font-size:12px;color:#1c2f22}
.esc-store-home .title{margin:8px 0 4px;color:#14311a;font-weight:900;font-size:clamp(20px,3vw,28px)}
.esc-store-home .sub{margin:0;color:#3a4640;line-height:1.4}

/* Carousel */
.esc-store-home .caro{position:relative}
.esc-store-home .caro-track{
  display:flex; gap:12px; overflow-x:auto; scroll-snap-type:x mandatory; padding:0 2px 4px;
  -webkit-overflow-scrolling:touch; scrollbar-width:none;
}
.esc-store-home .caro-track::-webkit-scrollbar{display:none}
.esc-store-home .caro .card{
  flex:0 0 86%; scroll-snap-align:start;
}
.esc-store-home .caro-btn{
  position:absolute; top:-38px; width:32px; height:32px; border-radius:999px;
  border:2px solid var(--brand); background:#fff; color:#15361b; font-weight:900; cursor:pointer;
  display:inline-grid; place-items:center; line-height:1;
}
.esc-store-home .caro-btn:hover{background:#f6faf7}
.esc-store-home .caro-btn.prev{right:46px}
.esc-store-home .caro-btn.next{right:8px}

/* Desktop: grid and hide arrows */
@media(min-width:860px){
  .esc-store-home .caro-track{
    display:grid; grid-template-columns:1fr 1fr; gap:12px; overflow:visible; scroll-snap-type:none;
  }
  .esc-store-home .caro .card{flex:initial}
  .esc-store-home .caro-btn{display:none}
}

/* Product card */
.esc-store-home .card{
  background:#fff;border:2px solid var(--brand);border-radius:14px;overflow:hidden;display:flex;flex-direction:column
}
.esc-store-home .media{
  position:relative;background:#f6f9f7; 
  aspect-ratio:1/1; max-height:260px; /* ↓ shorter product height */
}
@media(min-width:860px){
  .esc-store-home .media{max-height:320px}
}
.esc-store-home .media img{
  width:100%;height:100%;object-fit:contain;display:block;padding:8px
}
.esc-store-home .body{padding:12px}
.esc-store-home .name{margin:0 0 4px;color:#15361b;font-size:17px;font-weight:900}
.esc-store-home .tag{display:inline-flex;gap:6px;align-items:center;margin:0 0 6px;background:#fff7ec;border:1px solid #ffe0b5;color:#6b3b02;font-weight:900;border-radius:999px;padding:3px 8px;font-size:11px}
.esc-store-home .price-row{display:flex;align-items:baseline;gap:8px;margin-top:2px}
.esc-store-home .price{font-weight:900;color:#101314;font-size:17px}
.esc-store-home .per{color:#596760;font-weight:800;font-size:11px}

/* Controls: always horizontal */
.esc-store-home .row.controls{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
.esc-store-home .row.controls .col{min-width:0}
.esc-store-home label{font-weight:800;color:#19371d;font-size:12px}
.esc-store-home select,
.esc-store-home input[type="number"]{width:100%;padding:9px;border:1.5px solid var(--line);border-radius:10px;background:#fbfdfb;color:#12251a;font-size:14px}
.esc-store-home input[type="number"]{appearance:textfield}
.esc-store-home input[type="number"]::-webkit-outer-spin-button,
.esc-store-home input[type="number"]::-webkit-inner-spin-button{appearance:none;margin:0}

.esc-store-home .subtle{color:#58645f;font-size:12px;font-weight:800;margin-top:6px}
.esc-store-home .cta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.esc-store-home .btn{appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;font-weight:900;border-radius:12px;padding:9px 14px}
.esc-store-home .btn-primary{background:var(--accent);border:2px solid var(--accent);color:#101314}
.esc-store-home .btn-primary:hover{background:#fff;color:#1b5223;border-color:#fff;box-shadow:inset 0 0 0 2px var(--brand)}

/* Modal (tiny) */
.esc-store-home .overlay{position:fixed;inset:0;background:rgba(0,0,0,.48);display:none;align-items:flex-start;justify-content:center;z-index:9999;padding:20px 10px}
.esc-store-home .modal{width:100%;max-width:520px;margin-top:7vh;background:#fff;border:2px solid var(--brand);border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.25);overflow:hidden}
.esc-store-home .m-head{display:flex;align-items:center;justify-content:space-between;background:#f6faf7;padding:10px 12px;border-bottom:1px solid var(--line)}
.esc-store-home .m-title{margin:0;color:#14311a;font-weight:900;font-size:18px}
.esc-store-home .m-close{appearance:none;background:transparent;border:0;font-size:22px;line-height:1;color:#17341b;cursor:pointer;padding:4px;border-radius:8px}
.esc-store-home .m-body{max-height:68vh;overflow:auto;padding:12px}
.esc-store-home .m-row{display:grid;gap:8px}
@media(min-width:520px){.esc-store-home .m-row.two{grid-template-columns:1fr 1fr}}
.esc-store-home .summary{border:1px solid var(--line);background:#fbfdfb;border-radius:10px;padding:10px;margin-bottom:10px}
.esc-store-home .summary h4{margin:0 0 6px;color:#15361b;font-weight:900}
.esc-store-home .summary p{margin:2px 0;color:#334047;font-weight:800}
.esc-store-home .hint{color:#596760;font-size:12px;margin-top:5px}
.esc-store-home .m-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.esc-store-home .btn-wa{background:#25D366;border:2px solid #25D366;color:#101314}
.esc-store-home .btn-wa:hover{background:#fff;color:#1b5223;border-color:#25D366;box-shadow:inset 0 0 0 2px #25D366}
