/* ═══════════════════════════════════════════════════════════
   AaoPanditji — Samagri Cart UI
   Shared styling for: samagri-page.php (shop) card add-to-cart
   controls, floating cart bar, and slide-in cart drawer.
   ═══════════════════════════════════════════════════════════ */

:root{
  --sm-sf:#F97316;
  --sm-maroon:#7F1D1D;
  --sm-border:#F0D090;
  --sm-mid:#5C3D1E;
  --sm-cream:#FFFBF5;
  --sm-green:#16A34A;
}

/* ── Qty stepper on item cards ── */
.sm-qty-row{display:flex;align-items:center;gap:0;margin-bottom:10px;border:1.5px solid var(--sm-border);border-radius:10px;overflow:hidden;width:fit-content;}
.sm-qty-btn{background:#FFF3E8;border:none;width:30px;height:30px;font-size:16px;font-weight:700;color:var(--sm-sf);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.sm-qty-btn:hover{background:var(--sm-sf);color:#fff;}
.sm-qty-val{width:36px;text-align:center;font-size:13px;font-weight:700;color:var(--sm-maroon);}

/* ── Add to cart button (replaces plain WhatsApp link on cards) ── */
.sm-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;text-align:center;background:linear-gradient(135deg,var(--sm-sf),#EA6B0E);color:#fff;padding:9px;border-radius:10px;border:none;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .2s,background .2s;}
.sm-add-btn:hover{opacity:.9;}
.sm-add-btn.in-cart{background:var(--sm-green);}

/* ── Kit add-to-cart button ── */
.sm-kit-btn{display:block;width:100%;text-align:center;background:linear-gradient(135deg,var(--sm-maroon),#92400E);color:#FCD34D;padding:12px;border-radius:12px;border:none;text-decoration:none;font-weight:700;font-size:14px;font-family:inherit;cursor:pointer;transition:opacity .2s,background .2s;}
.sm-kit-btn:hover{opacity:.92;}
.sm-kit-btn.in-cart{background:linear-gradient(135deg,var(--sm-green),#15803D);color:#fff;}

/* ── Floating cart bar ── */
.sm-cart-bar{position:fixed;left:50%;bottom:18px;transform:translate(-50%,120%);z-index:9998;background:linear-gradient(135deg,var(--sm-maroon),#B45309);color:#fff;padding:12px 14px 12px 18px;border-radius:50px;box-shadow:0 8px 28px rgba(0,0,0,.28);display:flex;align-items:center;gap:14px;transition:transform .25s ease;max-width:92vw;}
.sm-cart-bar.show{transform:translate(-50%,0);}
.sm-cart-bar-info{font-size:13px;font-weight:600;white-space:nowrap;}
.sm-cart-bar-info b{color:#FCD34D;}
.sm-cart-bar-btn{background:#FCD34D;color:var(--sm-maroon);border:none;padding:9px 18px;border-radius:50px;font-weight:800;font-size:13px;cursor:pointer;white-space:nowrap;}

/* ── Drawer overlay ── */
.sm-cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9999;opacity:0;pointer-events:none;transition:opacity .25s;}
.sm-cart-overlay.show{opacity:1;pointer-events:auto;}

/* ── Drawer panel ── */
.sm-cart-drawer{position:fixed;top:0;right:0;height:100%;width:100%;max-width:400px;background:#fff;z-index:10000;transform:translateX(100%);transition:transform .28s ease;display:flex;flex-direction:column;box-shadow:-8px 0 30px rgba(0,0,0,.2);}
.sm-cart-drawer.show{transform:translateX(0);}
.sm-cart-head{background:linear-gradient(135deg,var(--sm-maroon),#B45309);color:#fff;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.sm-cart-head h3{font-family:'Rozha One',serif;font-size:19px;margin:0;color:#FCD34D;}
.sm-cart-close{background:rgba(255,255,255,.15);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:16px;cursor:pointer;flex-shrink:0;}

.sm-cart-body{flex:1;overflow-y:auto;padding:16px 20px;}
.sm-cart-empty-state{text-align:center;padding:60px 10px;color:#999;}
.sm-cart-empty-state .icon{font-size:44px;margin-bottom:12px;}
.sm-cart-empty-state p{font-size:13px;}

.sm-cart-row{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px dashed var(--sm-border);}
.sm-cart-row-icon{font-size:26px;flex-shrink:0;width:36px;text-align:center;}
.sm-cart-row-main{flex:1;min-width:0;}
.sm-cart-row-name{font-size:13px;font-weight:700;color:var(--sm-maroon);margin-bottom:2px;}
.sm-cart-row-unit{font-size:11px;color:#999;}
.sm-cart-row-qty{display:flex;align-items:center;gap:0;border:1px solid var(--sm-border);border-radius:8px;overflow:hidden;flex-shrink:0;}
.sm-cart-row-qty button{background:#FFF3E8;border:none;width:24px;height:24px;font-size:14px;color:var(--sm-sf);cursor:pointer;}
.sm-cart-row-qty span{width:26px;text-align:center;font-size:12px;font-weight:700;}
.sm-cart-row-price{font-size:13px;font-weight:800;color:var(--sm-sf);width:64px;text-align:right;flex-shrink:0;}
.sm-cart-row-remove{background:none;border:none;color:#C33;font-size:16px;cursor:pointer;flex-shrink:0;padding:2px 4px;}

.sm-cart-foot{border-top:1.5px solid var(--sm-border);padding:16px 20px 20px;flex-shrink:0;background:var(--sm-cream);}
.sm-cart-total-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.sm-cart-total-row span{font-size:14px;font-weight:700;color:var(--sm-mid);}
.sm-cart-total-row b{font-size:22px;color:var(--sm-maroon);font-family:'Rozha One',serif;}
.sm-cart-checkout-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:#25D366;color:#fff;padding:13px;border-radius:12px;border:none;font-weight:700;font-size:14px;cursor:pointer;margin-bottom:8px;}
.sm-cart-checkout-btn:hover{opacity:.92;}
.sm-cart-secondary-row{display:flex;gap:8px;}
.sm-cart-clear-btn,.sm-cart-call-btn{flex:1;text-align:center;background:#fff;border:1.5px solid var(--sm-border);color:var(--sm-mid);padding:9px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;text-decoration:none;}
.sm-cart-clear-btn:hover{border-color:#C33;color:#C33;}

@media(max-width:600px){
  .sm-cart-drawer{max-width:100%;}
  .sm-cart-bar-info{font-size:12px;}
}

/* ═══════════════════════════════════════════════════════════
   Item-level Samagri Catalog — inside Book Pandit form
   Classes here are consumed by assets/js/samagri-booking.js
   ═══════════════════════════════════════════════════════════ */
.samagri-catalog-wrap{border:1.5px solid var(--sm-border);border-radius:14px;padding:16px;background:var(--sm-cream);margin-top:6px;}
.samagri-step-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.samagri-step-toggle-btn{background:#FFF3E8;border:1.5px solid var(--sm-border);color:var(--sm-sf);font-weight:700;font-size:12px;padding:6px 14px;border-radius:50px;cursor:pointer;}

.samagri-filters-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:8px;margin:14px 0;width:100%;max-width:100%;min-width:0;}
.samagri-filters-row .finput{padding:8px 10px;font-size:12px;min-width:0;}
@media(max-width:600px){.samagri-filters-row{grid-template-columns:1fr;}}

.samagri-kits-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;margin-bottom:16px;max-width:100%;}
.kit-card{flex:0 0 150px;background:#fff;border:1.5px solid var(--sm-border);border-radius:12px;padding:12px;cursor:pointer;transition:border-color .2s,box-shadow .2s;}
.kit-card:hover{border-color:var(--sm-sf);}
.kit-card.selected{border-color:var(--sm-green);background:#F0FFF4;box-shadow:0 0 0 2px rgba(22,163,74,.15);}
.kit-card-badge{font-size:10px;font-weight:700;color:var(--sm-sf);text-transform:uppercase;margin-bottom:6px;}
.kit-card-name{font-size:12px;font-weight:700;color:var(--sm-maroon);margin-bottom:4px;line-height:1.3;}
.kit-card-price{font-size:14px;font-weight:800;color:var(--sm-sf);}

.samagri-category-group{margin-bottom:16px;min-width:0;max-width:100%;}
.samagri-cat-heading{font-size:12px;font-weight:800;color:var(--sm-maroon);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px;}
.samagri-items-list{display:flex;flex-direction:column;gap:6px;min-width:0;max-width:100%;}
.samagri-booking-item{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--sm-border);border-radius:10px;padding:9px 12px;cursor:pointer;transition:border-color .15s,background .15s;min-width:0;max-width:100%;box-sizing:border-box;flex-wrap:wrap;}
.samagri-booking-item:hover{border-color:var(--sm-sf);}
.samagri-booking-item.item-selected{border-color:var(--sm-green);background:#F0FFF4;}
.samagri-booking-item .samagri-checkbox{width:16px;height:16px;flex-shrink:0;accent-color:var(--sm-green);}
.sbi-icon{font-size:18px;flex-shrink:0;}
.sbi-name{flex:1;min-width:120px;font-size:13px;font-weight:600;color:var(--sm-mid);overflow-wrap:break-word;word-break:break-word;}
.sbi-name small{display:block;font-size:11px;font-weight:400;color:#999;margin-top:1px;}
.qty-controls{display:flex;align-items:center;border:1px solid var(--sm-border);border-radius:8px;overflow:hidden;flex-shrink:0;}
.qty-controls .qty-btn{background:#FFF3E8;border:none;width:24px;height:24px;font-size:14px;color:var(--sm-sf);cursor:pointer;}
.qty-controls .qty-input{width:32px;height:24px;text-align:center;border:none;font-size:12px;font-weight:700;-moz-appearance:textfield;}
.qty-controls .qty-input::-webkit-outer-spin-button,.qty-controls .qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.sbi-subtotal{font-size:12px;font-weight:800;color:var(--sm-sf);width:56px;flex-shrink:0;text-align:right;}

.samagri-cart-summary{background:#fff;border:1.5px dashed var(--sm-border);border-radius:12px;padding:14px;margin-top:10px;min-width:0;max-width:100%;overflow-x:hidden;box-sizing:border-box;}
.scs-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:800;color:var(--sm-maroon);margin-bottom:10px;flex-wrap:wrap;gap:6px;}
.scs-head #clear-samagri-cart{background:none;border:none;color:#C33;font-size:11px;font-weight:700;cursor:pointer;text-decoration:underline;}
.cart-item-row{display:flex;align-items:center;gap:8px;font-size:12px;padding:5px 0;border-bottom:1px dashed #eee;min-width:0;max-width:100%;}
.cart-item-name{flex:1;min-width:0;color:var(--sm-mid);overflow-wrap:break-word;word-break:break-word;}
.cart-item-qty{color:#999;flex-shrink:0;white-space:nowrap;}
.cart-item-price{font-weight:700;color:var(--sm-sf);width:60px;flex-shrink:0;text-align:right;}
.cart-empty{font-size:12px;color:#999;text-align:center;padding:10px 0;}
.scs-total{display:flex;justify-content:space-between;font-size:14px;font-weight:800;color:var(--sm-maroon);margin-top:10px;padding-top:10px;border-top:1.5px solid var(--sm-border);}


/* ═══════════════════════════════════════════════════════════
   Homepage — "Popular Puja Samagri" section
   Signature: thali-circle item icons + wax-seal kit badges +
   a hand-drawn marigold-garland divider. Built on the site's
   existing maroon/saffron/gold system (Rozha One + Poppins).
   ═══════════════════════════════════════════════════════════ */
.hsm-section{position:relative;padding:80px 20px 70px;background:
    radial-gradient(circle at 12% 15%, rgba(249,115,22,.05) 0%, transparent 40%),
    radial-gradient(circle at 88% 80%, rgba(127,29,29,.05) 0%, transparent 45%),
    #FFFBF5;
  overflow:hidden;}
.hsm-inner{max-width:1180px;margin:0 auto;position:relative;z-index:1;}

.hsm-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:20px;}
.hsm-head-label{display:inline-flex;align-items:center;gap:7px;color:#B45309;font-family:"Noto Serif Devanagari","Poppins",sans-serif;font-size:13px;font-weight:600;letter-spacing:.3px;margin-bottom:12px;}
.hsm-head-label::before{content:'🪔';font-size:15px;}
.hsm-head h2{font-family:'Rozha One',serif;font-size:clamp(26px,4vw,38px);color:#7F1D1D;margin:0;line-height:1.15;}
.hsm-head p{color:#5C3D1E;font-size:14px;margin-top:8px;font-family:"Poppins",sans-serif;max-width:420px;}
.hsm-view-all{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;background:transparent;color:#7F1D1D;padding:10px 4px;border-bottom:2px solid #7F1D1D;font-weight:700;font-size:13.5px;text-decoration:none;white-space:nowrap;transition:gap .2s,color .2s;}
.hsm-view-all:hover{gap:12px;color:#F97316;border-color:#F97316;}

/* Hand-drawn marigold garland divider between the header and the cards */
.hsm-garland{height:22px;margin:8px 0 34px;background-image:radial-gradient(circle, #F59E0B 0 3.5px, transparent 4px);background-size:22px 22px;background-position:0 4px;background-repeat:repeat-x;opacity:.55;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}

/* ── Kit cards: wax-seal badge, parchment-style card ── */
.hsm-kits-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:44px;align-items:stretch;}
.hsm-kit-card{position:relative;display:flex;flex-direction:column;height:100%;background:linear-gradient(160deg,#FFFDF9,#FEF3C7 130%);border:1px solid #F0D090;border-radius:4px 16px 16px 4px;padding:24px 18px 18px;box-shadow:0 1px 2px rgba(127,29,29,.04);transition:transform .2s,box-shadow .2s;}
.hsm-kit-card:hover{transform:translateY(-3px);box-shadow:0 14px 28px -12px rgba(127,29,29,.25);}
.hsm-kit-card::before{content:'';position:absolute;left:0;top:14px;bottom:14px;width:3px;background:#F97316;border-radius:2px;}
.hsm-kit-seal{position:absolute;top:-12px;right:16px;width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#7F1D1D,#B45309);display:flex;align-items:center;justify-content:center;font-size:17px;transform:rotate(-8deg);box-shadow:0 4px 10px rgba(127,29,29,.35);border:2px solid #FCD34D;}
.hsm-kit-label{font-size:10.5px;font-weight:700;color:#B45309;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-family:"Poppins",sans-serif;}
.hsm-kit-card-name{font-family:'Rozha One',serif;font-size:16.5px;color:#7F1D1D;margin:6px 0 8px;line-height:1.3;padding-right:36px;}
.hsm-kit-card-price{font-size:19px;font-weight:800;color:#F97316;font-family:"Poppins",sans-serif;margin-bottom:14px;}
.hsm-kit-card-price small{font-weight:400;color:#B08968;font-size:11px;}
.hsm-kit-card .sm-kit-btn{margin-top:auto;}

/* ── Item cards: thali-circle icon frame, clean grid ── */
.hsm-items-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:stretch;}
.hsm-item-card{display:flex;flex-direction:column;height:100%;background:#fff;border:1px solid #F5E6C8;border-radius:14px;padding:18px 12px 16px;text-align:center;transition:border-color .2s,box-shadow .2s,transform .2s;}
.hsm-item-card:hover{border-color:#F97316;box-shadow:0 10px 24px -14px rgba(127,29,29,.3);transform:translateY(-2px);}
.hsm-item-icon-frame{width:64px;height:64px;margin:0 auto 10px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#FFF7E8,#FEF3C7 70%);border:1.5px dashed #F0D090;display:flex;align-items:center;justify-content:center;font-size:28px;overflow:hidden;transition:border-color .2s,transform .2s;}
.hsm-item-icon-frame img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
.hsm-item-card:hover .hsm-item-icon-frame{border-color:#F97316;border-style:solid;transform:scale(1.05);}
.hsm-item-name{font-size:13px;font-weight:700;color:#4A2E12;margin-bottom:3px;line-height:1.3;min-height:34px;font-family:"Poppins",sans-serif;}
.hsm-item-price{font-size:13px;font-weight:800;color:#F97316;margin-bottom:12px;font-family:"Poppins",sans-serif;}
.hsm-item-price small{font-weight:400;color:#B08968;font-size:11px;}
.hsm-item-card .sm-qty-row{margin-top:auto;}
.hsm-item-card .sm-add-btn{margin-top:8px;}

/* Tablet: 768px–900px — unchanged from original */
@media(max-width:900px) and (min-width:768px){
  .hsm-kits-row{grid-template-columns:repeat(2,1fr);}
  .hsm-items-row{grid-template-columns:repeat(3,1fr);}
}

/* Mobile: below 768px — 1 product card per row, full width */
@media(max-width:767px){
  .hsm-section{padding:56px 16px 50px;}
  .hsm-kits-row{grid-template-columns:1fr;gap:14px;margin-bottom:32px;}
  .hsm-items-row{grid-template-columns:1fr;gap:14px;}
  .hsm-kit-card{padding:22px 20px 20px;}
  .hsm-item-card{padding:20px 18px 18px;}
  .hsm-item-icon-frame{width:60px;height:60px;font-size:26px;}
  .hsm-item-name{min-height:0;}
  .hsm-item-card .sm-qty-row{margin:0 auto 10px;}
}

/* ═══════════════════════════════════════════════════════════
   Checkout form (customer details + payment method)
   ═══════════════════════════════════════════════════════════ */
.sm-checkout-back{background:none;border:none;color:var(--sm-maroon);font-weight:700;font-size:13px;cursor:pointer;padding:0 0 14px;}
.sm-checkout-back:hover{text-decoration:underline;}
.sm-checkout-total-mini{background:var(--sm-cream);border:1px solid var(--sm-border);border-radius:10px;padding:10px 14px;font-size:13px;font-weight:700;color:var(--sm-mid);margin-bottom:16px;}
.sm-checkout-total-mini b{color:var(--sm-maroon);font-size:16px;}

.sm-field{margin-bottom:14px;}
.sm-field label{display:block;font-size:12px;font-weight:700;color:var(--sm-mid);margin-bottom:5px;}
.sm-field input,.sm-field select,.sm-field textarea{width:100%;padding:10px 12px;border:1.5px solid var(--sm-border);border-radius:10px;font-size:13px;font-family:inherit;color:var(--sm-maroon);background:#fff;}
.sm-field input:focus,.sm-field select:focus,.sm-field textarea:focus{outline:none;border-color:var(--sm-sf);}
.sm-field textarea{resize:vertical;min-height:56px;}
.sm-field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

.sm-pay-options{display:flex;flex-direction:column;gap:8px;}
.sm-pay-opt{display:flex;align-items:center;gap:8px;border:1.5px solid var(--sm-border);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;color:var(--sm-mid);cursor:pointer;transition:border-color .2s,background .2s;}
.sm-pay-opt:has(input:checked){border-color:var(--sm-sf);background:#FFF7ED;color:var(--sm-maroon);}
.sm-pay-opt input{width:auto;margin:0;}

.sm-checkout-error{background:#FEF2F2;border:1.5px solid #FCA5A5;color:#B91C1C;font-size:12.5px;font-weight:600;padding:10px 12px;border-radius:10px;margin-bottom:14px;}

/* ── Order success screen ── */
.sm-order-success{text-align:center;padding:24px 6px;}
.sm-order-success .icon{font-size:48px;margin-bottom:10px;}
.sm-order-success h4{font-family:'Rozha One',serif;color:var(--sm-maroon);font-size:20px;margin:0 0 12px;}
.sm-order-id-badge{display:inline-block;background:var(--sm-maroon);color:#FCD34D;font-weight:800;font-size:14px;letter-spacing:.5px;padding:8px 18px;border-radius:50px;margin-bottom:14px;}
.sm-order-success p{font-size:12.5px;color:#888;margin-bottom:18px;line-height:1.5;}

/* ═══════════════════════════════════════════════════════════
   Order tracking (Order ID + Mobile lookup)
   ═══════════════════════════════════════════════════════════ */
.sm-track-trigger{position:fixed;left:18px;bottom:18px;z-index:9997;background:#fff;color:var(--sm-maroon);border:1.5px solid var(--sm-border);padding:10px 16px;border-radius:50px;font-weight:700;font-size:12.5px;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.12);}
.sm-track-trigger:hover{border-color:var(--sm-sf);}

.sm-track-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:10001;opacity:0;pointer-events:none;transition:opacity .25s;}
.sm-track-overlay.show{opacity:1;pointer-events:auto;}
.sm-track-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%);width:92%;max-width:380px;max-height:85vh;overflow-y:auto;background:#fff;border-radius:16px;z-index:10002;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.sm-track-modal.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%);}
.sm-track-head{background:linear-gradient(135deg,var(--sm-maroon),#B45309);color:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-radius:16px 16px 0 0;}
.sm-track-head h3{font-family:'Rozha One',serif;font-size:17px;margin:0;color:#FCD34D;}
.sm-track-head button{background:rgba(255,255,255,.15);border:none;color:#fff;width:28px;height:28px;border-radius:50%;font-size:14px;cursor:pointer;}
.sm-track-body{padding:18px 20px 22px;}

.sm-track-status-badge{display:inline-block;background:var(--sm-sf);color:#fff;font-weight:700;font-size:12.5px;padding:6px 14px;border-radius:50px;margin-bottom:14px;}
.sm-track-detail-row{display:flex;justify-content:space-between;font-size:12.5px;padding:6px 0;border-bottom:1px dashed var(--sm-border);color:var(--sm-mid);}
.sm-track-detail-row b{color:var(--sm-maroon);}
.sm-track-items{margin-top:12px;}
.sm-track-item-row{font-size:12px;color:var(--sm-mid);padding:4px 0;}

@media(max-width:600px){
  .sm-track-trigger{left:12px;bottom:12px;padding:9px 14px;font-size:12px;}
}

