/* ==========================================================================
   GrowDeshi — Cart page (is_cart()). Reads WC()->cart server-side; live
   qty/remove/coupon via assets/js/cart-page.js (Store API). Cross-sell cards
   reuse .pcard / .shop-grid from shop.css (also enqueued here).
   ========================================================================== */

.cartp { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-pad) clamp(32px, 5vw, 56px); }

/* Breadcrumb */
.cartp__crumbs { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; padding: 14px 0; font-family: var(--font-ui); font-size: 12px; }
.cartp__crumbs a { color: #52B788; font-weight: 600; text-decoration: none; }
.cartp__crumbs a:hover { color: #2D6A4F; text-decoration: underline; }
.cartp__crumbs .ph { color: #9C9A92; font-size: 12px; }
.cartp__crumb-current { color: #5C4033; font-weight: 600; }

/* Head */
.cartp__head { padding: 8px 0 4px; }
.cartp__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-ui); font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: #52B788; }
.cartp__eyebrow [lang="bn"] { text-transform: none; font-family: var(--font-bengali); }
.cartp__eyebrow--teal { color: #0F6E56; }
.cartp__rule { width: 16px; height: 1px; background: #52B788; opacity: 0.6; }
.cartp__title { font-family: var(--font-bengali); font-weight: 800; font-size: clamp(28px, 3.4vw, 38px); line-height: 1.15; letter-spacing: -0.6px; color: #1A2E24; margin: 8px 0 0; }
.cartp__title-count { font-size: 0.5em; font-weight: 600; color: #9C9A92; }

/* Step indicator — full-width framed row; connectors stretch between steps */
.cartp__steps { display: flex; align-items: center; list-style: none; margin: 16px 0 24px; padding: 14px clamp(16px, 4vw, 28px); border: 0.5px solid var(--c-line); border-radius: 14px; background: #fff; }
.cartp__step { display: flex; align-items: center; gap: 10px; }
.cartp__step:not(:last-child) { flex: 1; }
.cartp__step:not(:last-child)::after { content: ""; flex: 1; height: 1.5px; background: #E8E6DF; margin: 0 clamp(10px, 2vw, 18px); }
.cartp__step-dot { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 999px; background: #fff; border: 1px solid #E8E6DF; color: #9C9A92; font-size: 15px; }
.cartp__step.is-active .cartp__step-dot { background: #2D6A4F; border-color: #2D6A4F; color: #D8F3DC; }
.cartp__step-label { font-family: var(--font-bengali); font-size: 12.5px; font-weight: 600; color: #9C9A92; }
.cartp__step.is-active .cartp__step-label { color: #1A2E24; }

/* Empty state */
.cartp__empty { display: flex; flex-direction: column; align-items: center; text-align: center; padding: clamp(32px, 7vw, 72px) 16px; }
.cartp__empty-icon { position: relative; width: 120px; height: 120px; border-radius: 999px; background: #D8F3DC; display: inline-flex; align-items: center; justify-content: center; color: #2D6A4F; font-size: 46px; }
.cartp__empty-sparkle { position: absolute; top: -6px; right: -2px; width: 34px; height: 34px; }
.cartp__empty-title { font-family: var(--font-bengali); font-weight: 800; font-size: 22px; color: #1A2E24; margin: 22px 0 6px; }
.cartp__empty-desc { font-family: var(--font-bengali); font-size: 14px; line-height: 1.7; color: #6B6960; max-width: 460px; margin: 0 0 22px; }
.cartp__empty-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.cartp__btn { display: inline-flex; align-items: center; gap: 8px; height: 48px; padding: 0 22px; border-radius: 12px; font-family: var(--font-bengali); font-weight: 700; font-size: 14px; text-decoration: none; cursor: pointer; border: 1px solid transparent; transition: background .18s, border-color .18s; }
.cartp__btn--primary { background: #2D6A4F; color: #D8F3DC; }
.cartp__btn--primary:hover { background: #085041; }
.cartp__btn--ghost { background: #fff; color: #2D6A4F; border-color: #E8E6DF; }
.cartp__btn--ghost:hover { background: #F6F4EF; }

/* Two-column layout */
.cartp__grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 1024px) { .cartp__grid { grid-template-columns: 1.7fr 1fr; gap: 32px; align-items: start; } }

/* Items card */
.cartp__items-card { border: 0.5px solid var(--c-line); border-radius: 16px; background: #fff; overflow: hidden; box-shadow: 0 4px 12px rgba(45,106,79,0.06); }
.cartp__items-head { display: none; }
@media (min-width: 760px) {
	.cartp__items-head { display: grid; grid-template-columns: 100px 1fr 140px 120px 40px; gap: 14px; align-items: center; padding: 12px 18px; background: #F6F4EF; font-family: var(--font-ui); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #6B6960; }
	.cartp__items-head span:nth-child(2) { grid-column: 3; text-align: center; }
	.cartp__items-head span:nth-child(3) { grid-column: 4; text-align: right; }
	.cartp__items-head span:first-child { grid-column: 1 / 3; }
}

/* Line item */
.cartp-line { position: relative; display: grid; grid-template-columns: 80px 1fr; gap: 14px; padding: 16px 18px; border-bottom: 0.5px solid var(--c-line); }
.cartp-line:last-child { border-bottom: none; }
@media (min-width: 760px) { .cartp-line { grid-template-columns: 100px 1fr 140px 120px 40px; align-items: center; } }
.cartp-line__media { display: block; border-radius: 10px; overflow: hidden; background: #D8F3DC; aspect-ratio: 1/1; }
.cartp-line__media .cartp-line__img,
.cartp-line__media img { width: 100%; height: 100%; object-fit: contain; padding: 8px; }
.cartp-line__info { min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.cartp-line__cat { font-family: var(--font-ui); font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: #52B788; }
.cartp-line__cat [lang="bn"] { text-transform: none; font-family: var(--font-bengali); }
.cartp-line__title { font-family: var(--font-bengali); font-weight: 700; font-size: 15px; color: #1A2E24; text-decoration: none; line-height: 1.35; }
.cartp-line__title:hover { color: #2D6A4F; }
.cartp-line__meta { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-bengali); font-size: 11.5px; font-weight: 600; margin-top: 2px; }
.cartp-line__meta .ph { font-size: 13px; }
.cartp-line__meta--in { color: #2D6A4F; }
.cartp-line__meta--low { color: #F4A261; }
.cartp-line__meta--out { color: #E63946; }
.cartp-line__actions { display: flex; align-items: center; gap: 8px; margin-top: 8px; }
.cartp-line__act { display: inline-flex; align-items: center; gap: 4px; border: none; background: none; padding: 0; cursor: pointer; font-family: var(--font-bengali); font-size: 12px; font-weight: 600; }
.cartp-line__save { color: #0F6E56; }
.cartp-line__rm-link { color: #E63946; }
.cartp-line__act:hover { text-decoration: underline; }
.cartp-line__sep { color: #D9D5C7; }

/* Qty stepper */
.cartp-line__qtycell { grid-column: 1 / -1; }
@media (min-width: 760px) { .cartp-line__qtycell { grid-column: auto; justify-self: center; } }
.cartp-qty { display: inline-flex; align-items: center; height: 40px; border: 1px solid var(--c-line); border-radius: 10px; background: #fff; overflow: hidden; }
.cartp-qty button { width: 38px; height: 100%; border: none; background: transparent; color: #2D6A4F; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-size: 14px; }
.cartp-qty button:hover { background: #F6F4EF; }
.cartp-qty button[data-dec] .ph-trash { color: #E63946; }
.cartp-qty span { min-width: 34px; text-align: center; font-family: var(--font-ui); font-size: 14px; font-weight: 700; color: #1A2E24; }

/* Line total */
.cartp-line__totalcell { grid-column: 2 / 3; text-align: left; }
@media (min-width: 760px) { .cartp-line__totalcell { grid-column: auto; text-align: right; } }
.cartp-line__total { font-family: var(--font-bengali); font-weight: 800; font-size: 17px; color: #2D6A4F; }
.cartp-line__unit { font-family: var(--font-ui); font-size: 11px; color: #9C9A92; margin-top: 2px; }

/* Remove (desktop icon) */
.cartp-line__remove { position: absolute; top: 12px; right: 12px; width: 32px; height: 32px; border: none; border-radius: 999px; background: transparent; color: #9C9A92; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; font-size: 15px; }
.cartp-line__remove:hover { background: #FCEBEB; color: #E63946; }
@media (min-width: 760px) { .cartp-line__remove { position: static; justify-self: center; } }
@media (max-width: 759px) { .cartp-line__actions .cartp-line__rm-link { display: inline-flex; } .cartp-line__remove { display: none; } }

/* Items footer: coupon + continue */
.cartp__items-foot { display: grid; grid-template-columns: 1fr; gap: 16px; padding: 18px; background: #F6F4EF; }
@media (min-width: 600px) { .cartp__items-foot { grid-template-columns: 1fr auto; align-items: start; } }
.cartp__coupon { min-width: 0; }
.cartp__coupon-field { display: flex; align-items: center; gap: 8px; position: relative; }
.cartp__coupon-pre { position: absolute; left: 12px; color: #9C9A92; font-size: 15px; }
.cartp__coupon-input { flex: 1; height: 44px; border: 1px solid var(--c-line); border-radius: 10px; padding: 0 12px 0 34px; font-family: var(--font-ui); font-size: 13.5px; background: #fff; outline: none; }
.cartp__coupon-input:focus { border-color: #52B788; box-shadow: 0 0 0 3px rgba(82,183,136,0.15); }
.cartp__coupon-apply { height: 44px; padding: 0 18px; border: none; border-radius: 10px; background: #0F6E56; color: #fff; font-family: var(--font-bengali); font-weight: 700; font-size: 13.5px; cursor: pointer; flex-shrink: 0; }
.cartp__coupon-apply:hover { background: #085041; }
.cartp__coupon-apply[disabled] { opacity: .6; cursor: default; }
.cartp__coupon-error { color: #E63946; font-family: var(--font-bengali); font-size: 11.5px; margin: 6px 0 0; display: inline-flex; align-items: center; gap: 5px; }
.cartp__coupon-applied { display: inline-flex; align-items: center; gap: 10px; padding: 10px 14px; background: #D8F3DC; border: 1px solid #9FE1CB; border-radius: 12px; }
.cartp__coupon-icon { display: inline-flex; width: 28px; height: 28px; align-items: center; justify-content: center; border-radius: 999px; background: #fff; color: #2D6A4F; }
.cartp__coupon-info { font-family: var(--font-ui); font-size: 13px; font-weight: 700; color: #2D6A4F; }
.cartp__coupon-info [lang="bn"] { font-weight: 600; font-family: var(--font-bengali); }
.cartp__coupon-clear { width: 26px; height: 26px; border: none; border-radius: 999px; background: transparent; color: #0F6E56; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.cartp__coupon-clear:hover { background: rgba(15,110,86,0.12); }
.cartp__continue { display: inline-flex; align-items: center; gap: 8px; justify-self: start; height: 44px; padding: 0 16px; box-sizing: border-box; font-family: var(--font-bengali); font-size: 13.5px; font-weight: 600; color: #0F6E56; text-decoration: none; border: 1px solid #E8E6DF; border-radius: 10px; background: #fff; white-space: nowrap; }
@media (min-width: 600px) { .cartp__continue { justify-self: end; } }
.cartp__continue:hover { background: #fff; }

/* Order summary */
.cartp__summary-card { border: 0.5px solid var(--c-line); border-radius: 16px; background: #fff; overflow: hidden; box-shadow: 0 4px 12px rgba(45,106,79,0.06); }
@media (min-width: 1024px) { .cartp__summary { position: sticky; top: calc(var(--header-h, 72px) + 16px); } }
.cartp__summary-head { padding: 18px; background: #F6F4EF; border-bottom: 0.5px solid var(--c-line); }
.cartp__summary-sub { font-family: var(--font-bengali); font-size: 12.5px; color: #6B6960; margin-top: 4px; }
.cartp__progress { padding: 14px 18px; background: #FFFCF5; border-bottom: 0.5px solid var(--c-line); }
.cartp__progress-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.cartp__progress-text { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-bengali); font-size: 12px; color: #5C4033; }
.cartp__progress-text .ph { color: #0F6E56; font-size: 14px; }
.cartp__progress-pct { font-family: var(--font-ui); font-size: 12px; font-weight: 700; color: #2D6A4F; }
.cartp__progress-bar { height: 6px; border-radius: 999px; background: #E8E6DF; overflow: hidden; }
.cartp__progress-bar span { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, #52B788, #F4A261); transition: width .4s ease; }
.cartp__totals { padding: 16px 18px; display: flex; flex-direction: column; gap: 9px; }
.cartp__total-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; font-family: var(--font-bengali); font-size: 13px; color: #6B6960; }
.cartp__total-row span:last-child { font-family: var(--font-ui); font-weight: 700; color: #1A2E24; }
.cartp__total-row--discount span:last-child { color: #E63946; }
.cartp__free { display: inline-flex; align-items: center; gap: 5px; color: #2D6A4F !important; font-weight: 700; }
.cartp__delivery-note { font-family: var(--font-bengali) !important; font-weight: 600 !important; color: #9C9A92 !important; font-size: 12px; }
.cartp__total-row--grand { padding-top: 12px; margin-top: 4px; border-top: 1px dashed var(--c-line); }
.cartp__total-row--grand span:first-child { text-transform: uppercase; font-family: var(--font-ui); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; color: #0F6E56; }
.cartp__grand { font-family: var(--font-bengali) !important; font-size: 26px !important; font-weight: 800 !important; color: #2D6A4F !important; letter-spacing: -0.4px; }
.cartp__vat { text-align: right; font-family: var(--font-bengali); font-size: 11px; color: #9C9A92; margin: 2px 0 0; }
.cartp__checkout { display: flex; align-items: center; justify-content: center; gap: 8px; margin: 0 18px 16px; height: 52px; border-radius: 12px; background: #2D6A4F; color: #D8F3DC; font-family: var(--font-bengali); font-weight: 700; font-size: 14px; text-decoration: none; transition: background .18s; }
.cartp__checkout:hover { background: #085041; }
.cartp__assure { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; padding: 0 18px 18px; }
.cartp__assure span { display: inline-flex; flex-direction: column; align-items: center; gap: 4px; text-align: center; padding: 8px 4px; border-radius: 10px; background: #F6F4EF; font-family: var(--font-bengali); font-size: 10px; font-weight: 600; color: #0F6E56; }
.cartp__assure .ph { font-size: 15px; color: #52B788; }

/* Cross-sell */
.cartp-cross { border-top: 0.5px solid var(--c-line); }
.cartp-cross__inner { max-width: var(--container-max); margin: 0 auto; padding: clamp(32px, 5vw, 48px) var(--container-pad); }
.cartp-cross__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.cartp-cross__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-ui); font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: #52B788; }
.cartp-cross__eyebrow [lang="bn"] { text-transform: none; font-family: var(--font-bengali); }
.cartp-cross__rule { width: 16px; height: 1px; background: #52B788; opacity: 0.6; }
.cartp-cross__all { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-bengali); font-size: 12.5px; font-weight: 700; color: #52B788; text-decoration: none; }
.cartp-cross__all:hover { color: #2D6A4F; }
@media (max-width: 600px) { .cartp-cross__all { display: none; } }
.cartp-cross__title { font-family: var(--font-bengali); font-weight: 800; font-size: 22px; letter-spacing: -0.3px; color: #1A2E24; margin: 6px 0 16px; }
