/* ============================================================
 * EZ Lettering — storefront pages (cart / checkout / order /
 * shop / category / product). Ported verbatim from the design
 * bundle (site.css shop components + each page inline styles).
 * Loaded after main.css on WC + shop pages.
 * ============================================================ */

/* Let storefront templates own full-width sections (page-head, stepper). */
body.woocommerce .site-main,
body.woocommerce-cart .site-main,
body.woocommerce-checkout .site-main,
body.woocommerce-account .site-main,
body.woocommerce-page .site-main,
body.ezl-storefront .site-main {
	max-width: none;
	margin: 0;
	background: #f5f8fc;
}
body.woocommerce, body.woocommerce-page, body.ezl-storefront { background: #f5f8fc; }
/* Neutralise the generic .wc-page wrapper padding so design .wrap controls width. */
.wc-page { padding: 0 !important; max-width: none !important; }

/* ---- page heading (design) ---- */
.page-head { background: #fff; border-bottom: 1px solid var(--line); padding: 0; text-align: left; }
.page-head .wrap { padding: 26px 28px; }
.crumb { font-size: 12px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
.crumb a { color: inherit; }
.crumb a:hover { color: var(--brand-blue); }
.page-head h1 { margin: 6px 0 0; font-size: 30px; font-weight: 900; color: var(--navy); letter-spacing: -.3px; text-align: left; }

/* ---- stepper (design) ---- */
.stepper { display: flex; align-items: center; justify-content: center; gap: 0; padding: 30px 0 6px; list-style: none; max-width: none; margin: 0; }
.stepper .st { display: flex; align-items: center; gap: 11px; font-weight: 800; font-size: 14px; color: #9aa7b4; text-transform: uppercase; letter-spacing: .03em; }
.stepper .st .n { width: 30px; height: 30px; border-radius: 50%; background: #d7dee7; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.stepper .st.active { color: var(--navy); }
.stepper .st.active .n { background: var(--brand-blue); }
.stepper .st.done .n { background: var(--green); }
.stepper .bar { width: 70px; height: 2px; background: #d7dee7; margin: 0 18px; }
.stepper .bar.done { background: var(--green); }

/* ---- card ---- */
.card { background: #fff; border: 1px solid var(--line); border-radius: 12px; }

/* ---- buttons (design has btn-blue / btn-dark) ---- */
.btn-blue { background: var(--brand-blue); color: #fff; }
.btn-blue:hover { background: var(--brand-blue-d); color: #fff; }
.btn-dark { background: var(--navy); color: #fff; }
.btn-dark:hover { background: var(--navy-deep); color: #fff; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ---- vinyl-style covers ---- */
.cover { position: relative; display: flex; flex-direction: column; justify-content: flex-end; padding: 20px; overflow: hidden; }
.cover::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 90% at 80% 0, rgba(255,255,255,.14), transparent 60%); }
.cover-chip { position: absolute; top: 14px; left: 14px; font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; padding: 5px 11px; border-radius: 20px; z-index: 2; }
.cover-title { position: relative; z-index: 2; line-height: 1.05; font-weight: 400; text-wrap: balance; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; max-width: 100%; word-break: break-word; }
.cover-mark { position: relative; z-index: 2; margin-top: 12px; font-size: 10px; font-weight: 800; letter-spacing: .18em; color: rgba(255,255,255,.55); }
.cover-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }

/* ---- stars ---- */
.stars { display: inline-flex; gap: 1px; letter-spacing: 1px; font-size: 14px; line-height: 1; }
.stars .star { color: #e2c14d; }
.stars .star.empty { color: #d7dee7; }
.stars .star.half { position: relative; color: #d7dee7; }
.stars .star.half::before { content: "★"; position: absolute; left: 0; width: 50%; overflow: hidden; color: #e2c14d; }

/* ============================================================
 * Cart
 * ============================================================ */
.layout { display: grid; grid-template-columns: 1fr 340px; gap: 26px; align-items: start; padding: 26px 0 0; }
@media (max-width: 960px) { .layout { grid-template-columns: 1fr; } }

.citem { display: grid; grid-template-columns: 120px 1fr auto; gap: 22px; padding: 22px; border-bottom: 1px solid var(--line); }
.citem:last-child { border-bottom: none; }
.thumb { width: 120px; height: 120px; border-radius: 10px; border: 1px solid var(--line);
	background: linear-gradient(45deg,#eef2f6 25%,transparent 25%,transparent 75%,#eef2f6 75%), linear-gradient(45deg,#eef2f6 25%,#f7f9fb 25%,#f7f9fb 75%,#eef2f6 75%);
	background-size: 14px 14px; background-position: 0 0, 7px 7px;
	display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 8px; }
.thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.citem .meta h3 { margin: 0 0 3px; font-size: 17px; font-weight: 900; color: var(--navy); }
.citem .meta h3 a { color: inherit; }
.citem .meta .sku { font-size: 11px; font-weight: 700; color: #9aa7b4; text-transform: uppercase; letter-spacing: .05em; margin-bottom: 12px; }
.props { display: grid; grid-template-columns: 1fr 1fr; gap: 7px 26px; max-width: 580px; align-items: start; }
.props .p { display: flex; gap: 8px; font-size: 12.5px; line-height: 1.45; }
.props .p .k { color: var(--muted); font-weight: 600; min-width: 104px; white-space: nowrap; }
.props .p .v { color: var(--ink); font-weight: 700; }
.props .p .v.muted { color: #aeb7c1; font-weight: 600; }
.citem .right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 14px; min-width: 130px; }
.citem .uprice { font-size: 13px; font-weight: 700; color: var(--muted); }
.qty { display: inline-flex; align-items: center; border: 1.5px solid var(--line); border-radius: 8px; overflow: hidden; }
.qty button { width: 34px; height: 36px; border: none; background: #fff; font-size: 18px; font-weight: 700; color: var(--navy); cursor: pointer; }
.qty button:hover { background: var(--sky); }
.qty input { width: 42px; height: 36px; border: none; text-align: center; font-family: inherit; font-size: 15px; font-weight: 800; color: var(--navy); outline: none; -moz-appearance: textfield; }
.qty input::-webkit-outer-spin-button, .qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ltotal { font-size: 20px; font-weight: 900; color: var(--navy); }
.citem-actions { display: inline-flex; flex-direction: column; align-items: flex-end; gap: 9px; }
.edit-design { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 800; color: var(--brand-blue); background: none; border: none; cursor: pointer; text-transform: uppercase; letter-spacing: .03em; text-decoration: none; }
.edit-design:hover { color: var(--navy); }
.edit-design svg { width: 14px; height: 14px; }
.rm { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: #c2454a; background: none; border: none; cursor: pointer; text-transform: uppercase; letter-spacing: .03em; text-decoration: none; }
.rm:hover { color: #9b2f33; }
.rm svg { width: 14px; height: 14px; }

.cartfoot { display: flex; align-items: center; gap: 18px; padding: 20px 22px; border-top: 1px solid var(--line); background: var(--sky); flex-wrap: wrap; }
.coupon { display: flex; gap: 10px; align-items: center; }
.coupon input { font-family: inherit; font-size: 13px; font-weight: 600; border: 1.5px solid var(--line); border-radius: 8px; padding: 11px 13px; width: 180px; outline: none; }
.coupon input:focus { border-color: var(--brand-blue); }
.continue { margin-left: auto; }
.continue a { font-size: 13px; font-weight: 800; color: var(--brand-blue); text-transform: uppercase; letter-spacing: .03em; display: inline-flex; align-items: center; gap: 7px; }

/* cart + checkout shared summary */
.summary { position: sticky; top: 96px; padding: 22px; }
.summary h2 { margin: 0 0 18px; font-size: 15px; font-weight: 900; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.sline { display: flex; justify-content: space-between; font-size: 14px; padding: 9px 0; border-bottom: 1px dashed var(--line); }
.sline .k { color: var(--muted); font-weight: 600; }
.sline .v { font-weight: 800; color: var(--navy); }
.sline.disc .v { color: var(--green-d); }
.stotal { display: flex; justify-content: space-between; align-items: baseline; padding: 16px 0 4px; }
.stotal .k { font-size: 14px; font-weight: 800; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.stotal .v { font-size: 28px; font-weight: 900; color: var(--navy); }
.summary .btn { width: 100%; margin-top: 16px; }
.ship-note { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; color: var(--green-d); margin-top: 14px; justify-content: center; }
.ship-note svg { width: 15px; height: 15px; }

.empty { text-align: center; padding: 70px 20px; }
.empty > svg, .empty .empty-icon { width: 64px; height: 64px; color: #c6d2df; margin: 0 auto 18px; }
.empty h3 { font-size: 20px; font-weight: 900; color: var(--navy); margin: 0 0 8px; }
.empty p { color: var(--muted); font-weight: 600; margin: 0 0 22px; }

@media (max-width: 680px) {
	.citem { grid-template-columns: 80px 1fr; }
	.thumb { width: 80px; height: 80px; }
	.props { grid-template-columns: 1fr; }
	.citem .right { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: space-between; text-align: left; }
	.citem-actions { align-items: flex-start; }
}

/* ============================================================
 * Checkout
 * ============================================================ */
.checkout-layout { display: grid; grid-template-columns: 1fr 380px; gap: 26px; align-items: start; padding: 26px 0 0; }
@media (max-width: 960px) { .checkout-layout { grid-template-columns: 1fr; } }
@media (max-width: 680px) {
	.block .woocommerce-billing-fields__field-wrapper,
	.block .woocommerce-shipping-fields__field-wrapper,
	.block .woocommerce-additional-fields__field-wrapper {
		grid-template-columns: 1fr;
	}
}
.block { padding: 24px; margin-bottom: 22px; }
.block h2 { margin: 0 0 4px; font-size: 16px; font-weight: 900; color: var(--navy); text-transform: uppercase; letter-spacing: .03em; display: flex; align-items: center; gap: 10px; }
.block h2 .n { width: 26px; height: 26px; border-radius: 50%; background: var(--brand-blue); color: #fff; font-size: 13px; display: flex; align-items: center; justify-content: center; }
.block .sub { font-size: 12.5px; color: var(--muted); font-weight: 600; margin: 0 0 18px 36px; }
.block .woocommerce-billing-fields,
.block .woocommerce-shipping-fields,
.block .woocommerce-additional-fields { display: block; }
.block .woocommerce-billing-fields > h3,
.block .woocommerce-shipping-fields > h3,
.block .woocommerce-additional-fields > h3 {
	margin: 0 0 16px;
	color: var(--navy);
	font-size: 18px;
	line-height: 1.2;
	font-weight: 900;
}
.block .woocommerce-billing-fields__field-wrapper,
.block .woocommerce-shipping-fields__field-wrapper,
.block .woocommerce-additional-fields__field-wrapper {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}
.block .form-row-first,
.block .form-row-last {
	float: none;
	width: auto;
}
.block .form-row-wide, .block #billing_address_1_field, .block #billing_address_2_field, .block #billing_email_field, .block #billing_phone_field { grid-column: 1 / -1; }
.block .woocommerce form .form-row, .block .form-row { display: flex; flex-direction: column; gap: 6px; margin: 0; }
.block label { display: block; font-size: 11px; font-weight: 800; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 6px; }
.block input.input-text, .block select, .block textarea, .block .select2-container { width: 100%; font-family: inherit; font-size: 14px; font-weight: 600; color: var(--ink); border: 1.5px solid var(--line); border-radius: 8px; padding: 12px 13px; background: #fff; outline: none; transition: .15s; }
.block input.input-text:focus, .block select:focus { border-color: var(--brand-blue); }

/* checkout order summary */
.checkout-summary { position: sticky; top: 96px; padding: 22px; }
.checkout-summary h2 { margin: 0 0 16px; font-size: 15px; font-weight: 900; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.oi { display: flex; gap: 13px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.oi .th { width: 58px; height: 58px; border-radius: 8px; border: 1px solid var(--line); flex: none; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 5px;
	background: linear-gradient(45deg,#eef2f6 25%,transparent 25%,transparent 75%,#eef2f6 75%), linear-gradient(45deg,#eef2f6 25%,#f7f9fb 25%,#f7f9fb 75%,#eef2f6 75%);
	background-size: 10px 10px; background-position: 0 0, 5px 5px; }
.oi .th img { max-width: 100%; max-height: 100%; object-fit: contain; }
.oi .info { flex: 1; min-width: 0; }
.oi .info b { font-size: 14px; font-weight: 800; color: var(--navy); display: block; margin-bottom: 2px; }
.oi .info .q { font-size: 11.5px; color: var(--muted); font-weight: 700; }
.oi .info .specs { font-size: 11px; color: #8b97a3; font-weight: 600; line-height: 1.45; margin-top: 4px; }
.oi .lp { font-size: 14px; font-weight: 800; color: var(--navy); white-space: nowrap; }
.lock-note { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; color: var(--muted); margin-top: 16px; }
.lock-note svg { width: 15px; height: 15px; color: var(--green-d); }
.checkout-summary .btn, #place_order { width: 100%; margin-top: 18px; }
#place_order { display: inline-flex; align-items: center; justify-content: center; gap: 10px; font-weight: 800; font-size: 14px; letter-spacing: .04em; text-transform: uppercase; border-radius: 7px; padding: 15px 26px; cursor: pointer; border: 2px solid transparent; background: var(--green); color: #fff; box-shadow: 0 4px 14px rgba(84,168,43,.35); }
#place_order:hover { background: var(--green-d); }
.back { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; margin-top: 14px; }
.back:hover { color: var(--brand-blue); }
.back svg { width: 15px; height: 15px; }
.woocommerce-checkout #payment { background: transparent; border-radius: 0; }
.woocommerce-checkout #payment ul.payment_methods { border: 0; padding: 0; }
.woocommerce-checkout #payment div.payment_box { background: var(--sky); }

/* ============================================================
 * Order received (thank you)
 * ============================================================ */
.confirm { max-width: 760px; margin: 0 auto; padding: 24px 0 0; }
.hero-ok { text-align: center; padding: 18px 0 30px; }
.checkwrap { width: 78px; height: 78px; border-radius: 50%; background: var(--green); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; box-shadow: 0 10px 26px rgba(84,168,43,.4); }
.checkwrap svg { width: 40px; height: 40px; color: #fff; }
.hero-ok h1 { font-size: 30px; font-weight: 900; color: var(--navy); margin: 0 0 8px; }
.hero-ok p { font-size: 15px; color: var(--muted); font-weight: 600; margin: 0; }
.ordno { display: inline-block; margin-top: 16px; background: var(--sky); border: 1px dashed #b9cde8; border-radius: 8px; padding: 10px 20px; font-size: 14px; font-weight: 800; color: var(--navy); }
.ordno span { color: var(--brand-blue); }
.panel { padding: 24px; margin-bottom: 20px; }
.panel h2 { margin: 0 0 16px; font-size: 14px; font-weight: 900; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.panel .oi { gap: 15px; padding: 16px 0; }
.panel .oi:last-child { border-bottom: none; }
.panel .oi .th { width: 72px; height: 72px; border-radius: 9px; padding: 6px; background-size: 12px 12px; background-position: 0 0, 6px 6px; }
.panel .oi .info b { font-size: 16px; font-weight: 900; margin-bottom: 6px; }
.panel .oi .lp { font-size: 15px; font-weight: 900; text-align: right; }
.panel .oi .lp small { display: block; font-size: 11px; font-weight: 700; color: var(--muted); }
.totrow { display: flex; justify-content: space-between; font-size: 14px; padding: 8px 0; }
.totrow .k { color: var(--muted); font-weight: 600; }
.totrow .v { font-weight: 800; color: var(--navy); }
.totrow.disc .v { color: var(--green-d); }
.grand { display: flex; justify-content: space-between; align-items: baseline; border-top: 2px solid var(--line); margin-top: 8px; padding-top: 14px; }
.grand .k { font-size: 15px; font-weight: 900; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.grand .v { font-size: 26px; font-weight: 900; color: var(--navy); }
.twocol { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 680px) { .twocol { grid-template-columns: 1fr; } .props { grid-template-columns: 1fr; } }
.infoblock h3 { font-size: 12px; font-weight: 800; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; margin: 0 0 8px; }
.infoblock p { font-size: 13px; color: var(--muted); font-weight: 600; margin: 0; line-height: 1.6; }
.steps-next { display: flex; gap: 14px; margin-top: 6px; }
.nstep { flex: 1; text-align: center; padding: 18px 12px; background: var(--sky); border-radius: 10px; }
.nstep .ic { width: 40px; height: 40px; border-radius: 50%; background: #fff; display: flex; align-items: center; justify-content: center; margin: 0 auto 10px; color: var(--brand-blue); }
.nstep .ic svg { width: 20px; height: 20px; }
.nstep b { font-size: 12.5px; font-weight: 800; color: var(--navy); display: block; margin-bottom: 3px; }
.nstep span { font-size: 11.5px; color: var(--muted); font-weight: 600; }
.cta-row { text-align: center; padding: 8px 0 0; }

/* ============================================================
 * Shop / Category
 * ============================================================ */
.prod-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; transition: .18s; text-decoration: none; position: relative; }
.prod-card:hover { box-shadow: 0 16px 34px rgba(16,78,158,.14); transform: translateY(-4px); border-color: #cfe0f4; }
.prod-card .cover { min-height: 188px; }
.prod-badge { position: absolute; top: 14px; right: 14px; z-index: 3; font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; padding: 5px 11px; border-radius: 20px; background: var(--green); color: #fff; }
.prod-badge.sale { background: #d12b2b; }
.prod-badge.new { background: var(--brand-blue); }
.prod-badge.compliant { background: var(--navy); }
.prod-card .pc-body { padding: 18px 20px 20px; display: flex; flex-direction: column; flex: 1; }
.prod-card .pc-cat { font-size: 11px; font-weight: 800; color: var(--brand-blue); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 8px; }
.prod-card h3 { margin: 0 0 10px; font-size: 17px; font-weight: 900; color: var(--navy); line-height: 1.22; }
.prod-card .pc-rate { display: flex; align-items: center; gap: 7px; margin-bottom: 12px; font-size: 12px; font-weight: 700; color: #8b97a3; }
.prod-card .pc-foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.prod-card .pc-price { font-size: 19px; font-weight: 900; color: var(--navy); display: flex; align-items: baseline; gap: 7px; }
.prod-card .pc-price small { font-size: 12px; font-weight: 700; color: var(--muted); }
.prod-card .pc-price .was { font-size: 13px; font-weight: 700; color: #aeb7c1; text-decoration: line-through; }
.prod-card .pc-btn { flex: none; display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .03em; color: #fff; background: var(--brand-blue); border-radius: 7px; padding: 10px 13px; transition: .14s; }
.prod-card .pc-btn:hover { background: var(--brand-blue-d); }

.shop-layout { display: grid; grid-template-columns: 262px 1fr; gap: 30px; align-items: start; padding: 26px 0 0; }
.sidebar { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 18px; }
.swidget { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 18px; }
.swidget h4 { margin: 0 0 14px; font-size: 12px; font-weight: 900; color: var(--navy); text-transform: uppercase; letter-spacing: .05em; }
.cat-list { display: flex; flex-direction: column; gap: 2px; }
.cat-list a { display: flex; align-items: center; justify-content: space-between; font-size: 13.5px; font-weight: 700; color: var(--ink); padding: 8px 10px; border-radius: 8px; transition: .12s; }
.cat-list a:hover { background: var(--sky); color: var(--brand-blue); }
.cat-list a.active { background: var(--brand-blue); color: #fff; }
.cat-list a .n { font-size: 11px; font-weight: 800; color: #9aa7b4; }
.cat-list a.active .n { color: rgba(255,255,255,.8); }
.searchbox { display: flex; align-items: center; gap: 8px; border: 1.5px solid var(--line); border-radius: 9px; padding: 0 10px; }
.searchbox svg { width: 16px; height: 16px; color: #9aa7b4; flex: none; }
.searchbox input { border: none; outline: none; font-family: inherit; font-size: 13.5px; font-weight: 600; padding: 11px 0; width: 100%; background: none; color: var(--ink); }
.price-row { display: flex; align-items: center; gap: 10px; margin-top: 6px; }
.price-row input[type="number"] { width: 88px; padding: 9px 10px; border: 1.5px solid var(--line); border-radius: 8px; font: inherit; }
.price-val { font-size: 13px; font-weight: 800; color: var(--navy); white-space: nowrap; }
.checks { display: flex; flex-direction: column; gap: 10px; }
.checks label { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 700; color: var(--ink); cursor: pointer; }
.checks input { width: 16px; height: 16px; accent-color: var(--brand-blue); }

.shop-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px 18px; margin-bottom: 22px; flex-wrap: wrap; }
.shop-toolbar .res { font-size: 13px; font-weight: 700; color: var(--muted); }
.shop-toolbar .res b { color: var(--navy); }
.shop-toolbar .sort { display: flex; align-items: center; gap: 9px; }
.shop-toolbar .sort label { font-size: 12px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.shop-toolbar select { font-family: inherit; font-size: 13.5px; font-weight: 700; color: var(--navy); border: 1.5px solid var(--line); border-radius: 8px; padding: 9px 12px; background: #fff; outline: none; cursor: pointer; }

.prod-grid, ul.products { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; list-style: none; margin: 0; padding: 0; }

.pager, .shop-main .woocommerce-pagination { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 40px 0 6px; }
.pager button, .woocommerce-pagination .page-numbers { min-width: 42px; height: 42px; border-radius: 9px; border: 1.5px solid var(--line); background: #fff; font-family: inherit; font-size: 14px; font-weight: 800; color: var(--navy); cursor: pointer; transition: .12s; padding: 0 12px; display: inline-flex; align-items: center; justify-content: center; }
.woocommerce-pagination ul { display: flex; gap: 8px; list-style: none; padding: 0; margin: 0; border: 0; }
.woocommerce-pagination ul li { border: 0; }
.pager button:hover:not([disabled]):not(.active), .woocommerce-pagination .page-numbers:hover:not(.current) { border-color: var(--brand-blue); color: var(--brand-blue); }
.pager button.active, .woocommerce-pagination .page-numbers.current { background: var(--brand-blue); border-color: var(--brand-blue); color: #fff; }

.cat-hero { position: relative; overflow: hidden; color: #fff; background: linear-gradient(135deg, var(--navy), var(--brand-blue-d)); }
.cat-hero .wrap { position: relative; z-index: 2; padding: 40px 28px 44px; }
.cat-hero::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 120% at 85% 0, rgba(255,255,255,.16), transparent 55%); z-index: 1; }
.cat-hero .crumb { color: rgba(255,255,255,.8); }
.cat-hero .crumb a:hover { color: #fff; }
.cat-hero h1 { margin: 10px 0 12px; font-size: 42px; font-weight: 900; letter-spacing: -.6px; color: #fff; }
.cat-hero p { margin: 0; max-width: 600px; font-size: 16px; font-weight: 600; color: rgba(255,255,255,.92); line-height: 1.55; }
.cat-hero .cta { margin-top: 22px; }
@media (max-width: 620px) { .cat-hero h1 { font-size: 32px; } }

@media (max-width: 1000px) { .prod-grid, ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 900px) {
	.shop-layout { grid-template-columns: 1fr; }
	.sidebar { position: static; flex-direction: row; flex-wrap: wrap; }
	.sidebar > form { display: contents; }
	.sidebar .swidget { flex: 1; min-width: 200px; }
}
@media (max-width: 620px) { .prod-grid, ul.products { grid-template-columns: 1fr; } .sidebar { flex-direction: column; } }

/* ============================================================
 * Single product (PDP)
 * ============================================================ */
.pdp { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; padding: 28px 0 0; }
@media (max-width: 900px) { .pdp { grid-template-columns: 1fr; gap: 26px; } }
.gallery .main { border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.gallery .main .cover { min-height: 380px; }
.gallery .main img { width: 100%; height: auto; display: block; }
.gallery .thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 14px; }
.gallery .thumbs .t { border: 2px solid var(--line); border-radius: 10px; overflow: hidden; cursor: pointer; transition: .12s; aspect-ratio: 1; }
.gallery .thumbs .t img { width: 100%; height: 100%; object-fit: cover; }
.gallery .thumbs .t .cover { min-height: 78px; padding: 10px; }
.gallery .thumbs .t .cover-title { font-size: 15px !important; }
.gallery .thumbs .t .cover-chip, .gallery .thumbs .t .cover-mark { display: none; }
.gallery .thumbs .t.sel { border-color: var(--brand-blue); }

.sum .cat { font-size: 12px; font-weight: 800; color: var(--brand-blue); text-transform: uppercase; letter-spacing: .05em; }
.sum h1, .sum .product_title { margin: 10px 0 12px; font-size: 32px; font-weight: 900; color: var(--navy); line-height: 1.12; letter-spacing: -.4px; }
.sum .rate { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 700; color: #8b97a3; margin-bottom: 16px; }
.sum .rate a { color: var(--brand-blue); }
.sum .price { display: flex; align-items: baseline; gap: 12px; margin-bottom: 18px; }
.sum .price .now, .sum .price ins { font-size: 34px; font-weight: 900; color: var(--navy); text-decoration: none; }
.sum .price .now small { font-size: 14px; font-weight: 700; color: var(--muted); }
.sum .price del, .sum .price .was { font-size: 18px; font-weight: 700; color: #aeb7c1; text-decoration: line-through; }
.sum .price .save { font-size: 12px; font-weight: 800; color: #fff; background: #d12b2b; border-radius: 6px; padding: 4px 9px; text-transform: uppercase; letter-spacing: .03em; }
.sum .short { font-size: 15px; color: #42505d; font-weight: 500; line-height: 1.65; margin-bottom: 22px; }
.feat { list-style: none; margin: 0 0 24px; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
.feat li { display: flex; align-items: center; gap: 9px; font-size: 13.5px; font-weight: 700; color: var(--navy); }
.feat li .c { width: 20px; height: 20px; border-radius: 50%; background: var(--green); color: #fff; display: flex; align-items: center; justify-content: center; flex: none; }
.feat li .c svg { width: 11px; height: 11px; }
.config-note { display: flex; gap: 11px; align-items: flex-start; background: var(--sky); border: 1px solid #d4e2f3; border-radius: 10px; padding: 14px 16px; margin-bottom: 18px; }
.config-note svg { width: 20px; height: 20px; color: var(--brand-blue); flex: none; margin-top: 1px; }
.config-note b { color: var(--navy); font-weight: 800; }
.config-note span { font-size: 13px; color: #42505d; font-weight: 600; line-height: 1.5; }
.buy-row, .sum form.cart { display: flex; gap: 12px; align-items: stretch; margin-bottom: 18px; flex-wrap: wrap; }
.sum form.cart .quantity { display: inline-flex; align-items: center; border: 1.5px solid var(--line); border-radius: 9px; overflow: hidden; }
.sum form.cart .quantity input.qty { width: 56px; border: 0; height: 48px; text-align: center; font: inherit; font-size: 16px; font-weight: 800; color: var(--navy); }
.sum form.cart button.single_add_to_cart_button { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 10px; background: var(--green); color: #fff; padding: 0 26px; border-radius: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; font-size: 14px; border: 0; cursor: pointer; box-shadow: 0 4px 14px rgba(84,168,43,.35); }
.sum form.cart button.single_add_to_cart_button:hover { background: var(--green-d); }
.sum .variations { width: 100%; }
.sum .variations select { padding: 10px 12px; border: 1.5px solid var(--line); border-radius: 8px; font: inherit; width: 100%; }
.meta-list { font-size: 12.5px; color: var(--muted); font-weight: 600; line-height: 1.9; border-top: 1px solid var(--line); padding-top: 16px; }
.meta-list b { color: var(--navy); font-weight: 800; }

.tabs { margin: 48px 0 0; }
.tabbar { display: flex; gap: 4px; border-bottom: 2px solid var(--line); flex-wrap: wrap; }
.tabbar button { font-family: inherit; font-size: 14px; font-weight: 800; color: var(--muted); background: none; border: none; padding: 14px 20px; cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; text-transform: uppercase; letter-spacing: .03em; }
.tabbar button.sel { color: var(--navy); border-bottom-color: var(--brand-blue); }
.tabpane { display: none; padding: 28px 0; }
.tabpane.sel { display: block; }
.tabpane h3 { font-size: 20px; font-weight: 900; color: var(--navy); margin: 0 0 14px; }
.tabpane p { font-size: 15px; line-height: 1.75; color: #2a3744; max-width: 760px; margin: 0 0 16px; }
.spec-table { width: 100%; border-collapse: collapse; max-width: 680px; }
.spec-table td, .spec-table th { padding: 13px 16px; border: 1px solid var(--line); font-size: 14px; text-align: left; }
.spec-table td:first-child, .spec-table th { font-weight: 800; color: var(--navy); background: var(--sky); width: 200px; text-transform: uppercase; letter-spacing: .03em; font-size: 12px; }
.spec-table td:last-child { font-weight: 600; color: #2a3744; }

.related { padding: 20px 0 40px; }
.related > h2 { text-align: center; font-size: 24px; font-weight: 900; color: var(--navy); margin: 0 0 26px; }

/* footer spacing parity with design */
.site-footer { margin-top: 0; }

/* ============================================================
 * My Account + front-end auth
 * ============================================================ */
.account-layout { display: grid; grid-template-columns: 240px 1fr; gap: 28px; align-items: start; padding: 26px 0 60px; }
@media (max-width: 860px) { .account-layout { grid-template-columns: 1fr; } }

.account-nav { position: sticky; top: 96px; }
.account-nav ul { list-style: none; margin: 0; padding: 10px; display: flex; flex-direction: column; gap: 4px; background: #fff; border: 1px solid var(--line); border-radius: 12px; }
.account-nav ul li { list-style: none; margin: 0; padding: 0; float: none; width: auto; border: 0; }
.account-nav ul li a { display: flex; align-items: center; gap: 11px; padding: 11px 14px; border-radius: 8px; font-size: 13.5px; font-weight: 700; color: var(--navy); line-height: 1.2; white-space: nowrap; transition: .12s; }
.account-nav ul li a:hover { background: var(--sky); color: var(--brand-blue); }
.account-nav ul li.is-active a { background: var(--brand-blue); color: #fff; }
.account-nav ul li a svg { width: 18px; height: 18px; flex: none; }
.account-nav ul li a span { flex: 1; min-width: 0; }
.account-nav ul li.woocommerce-MyAccount-navigation-link--customer-logout a { color: #c2454a; }
.account-nav ul li.woocommerce-MyAccount-navigation-link--customer-logout a:hover { background: #fdeaea; color: #9b2f33; }
@media (max-width: 860px) {
	.account-nav { position: static; }
	.account-nav ul { flex-direction: row; flex-wrap: wrap; }
	.account-nav ul li a { white-space: nowrap; }
}

.account-content { min-width: 0; }
.account-content > p { color: #42505d; font-size: 15px; line-height: 1.7; }

.dash-welcome { padding: 26px 28px; margin-bottom: 20px; }
.dash-welcome h2 { margin: 0 0 8px; font-size: 22px; color: var(--navy); }
.dash-welcome h2 span { color: var(--brand-blue); }
.dash-welcome p { margin: 0; color: var(--muted); font-weight: 500; font-size: 14.5px; line-height: 1.6; }

.dash-tiles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 720px) { .dash-tiles { grid-template-columns: 1fr 1fr; } }
.dash-tile { display: flex; align-items: center; gap: 14px; padding: 20px; text-decoration: none; transition: .15s; }
.dash-tile:hover { box-shadow: 0 12px 26px rgba(16,78,158,.12); transform: translateY(-3px); border-color: #cfe0f4; }
.dash-ic { width: 46px; height: 46px; border-radius: 12px; background: var(--sky); color: var(--brand-blue); display: flex; align-items: center; justify-content: center; flex: none; }
.dash-tile-cta .dash-ic { background: var(--green); color: #fff; }
.dash-tx b { display: block; font-size: 18px; font-weight: 900; color: var(--navy); line-height: 1.1; }
.dash-tx span { font-size: 12px; font-weight: 700; color: var(--muted); }

/* WC tables / forms inside account */
.account-content .woocommerce-orders-table,
.account-content .shop_table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.account-content .shop_table th { background: var(--sky); color: var(--navy); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; padding: 14px 16px; text-align: left; }
.account-content .shop_table td { padding: 14px 16px; border-top: 1px solid var(--line); font-size: 14px; color: var(--ink); }
.account-content .shop_table .button, .account-content .woocommerce-button { display: inline-flex; align-items: center; justify-content: center; background: var(--brand-blue); color: #fff; padding: 9px 14px; border-radius: 7px; font-weight: 800; font-size: 12px; text-transform: uppercase; letter-spacing: .03em; }
.account-content .woocommerce-Address { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 22px; }
.account-content .woocommerce-Address-title h3 { margin: 0 0 12px; font-size: 16px; color: var(--navy); }
.account-content .addresses { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 680px) { .account-content .addresses { grid-template-columns: 1fr; } }
.account-content form .form-row { margin: 0 0 14px; display: flex; flex-direction: column; gap: 6px; }
.account-content label { font-size: 11px; font-weight: 800; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.account-content input.input-text, .account-content select, .account-content textarea { padding: 12px 13px; border: 1.5px solid var(--line); border-radius: 8px; font: inherit; font-size: 14px; }
.account-content input.input-text:focus, .account-content select:focus { border-color: var(--brand-blue); outline: 0; }
.account-content .button, .account-content button[type="submit"] { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--green); color: #fff; padding: 13px 24px; border-radius: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; font-size: 13px; border: 0; cursor: pointer; box-shadow: 0 4px 14px rgba(84,168,43,.3); }
.account-content .button:hover, .account-content button[type="submit"]:hover { background: var(--green-d); }

/* Auth (login / register / reset) */
.auth-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; padding: 30px 0 70px; max-width: 920px; margin: 0 auto; }
.auth-grid.auth-single { grid-template-columns: 1fr; max-width: 480px; }
@media (max-width: 760px) { .auth-grid { grid-template-columns: 1fr; max-width: 480px; } }
.auth-card { padding: 32px 32px 34px; }
.auth-head h2 { margin: 0 0 6px; font-size: 22px; color: var(--navy); }
.auth-head p { margin: 0 0 22px; color: var(--muted); font-weight: 500; font-size: 14px; line-height: 1.55; }
.auth-form { display: flex; flex-direction: column; gap: 16px; }
.afield { display: flex; flex-direction: column; gap: 7px; }
.afield label { font-size: 11px; font-weight: 800; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; }
.afield input { padding: 13px 14px; border: 1.5px solid var(--line); border-radius: 9px; font: inherit; font-size: 14px; font-weight: 600; color: var(--ink); outline: none; transition: .15s; }
.afield input:focus { border-color: var(--brand-blue); }
.afield-note { font-size: 13px; color: var(--muted); font-weight: 600; margin: 0; }
.auth-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.auth-row .remember { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--ink); cursor: pointer; }
.auth-row .remember input { width: 16px; height: 16px; accent-color: var(--brand-blue); }
.auth-row .forgot { font-size: 13px; font-weight: 800; color: var(--brand-blue); }
.auth-form .btn { width: 100%; margin-top: 4px; }
.auth-register { background: var(--sky); }
.auth-back { display: inline-block; margin-top: 6px; font-size: 13px; font-weight: 800; color: var(--muted); }
.auth-back:hover { color: var(--brand-blue); }

/* WC notices on account/auth */
.woocommerce-error, .woocommerce-message, .woocommerce-info { list-style: none; margin: 0 0 20px; padding: 14px 18px; border-radius: 10px; font-size: 14px; font-weight: 600; border: 1px solid; }
.woocommerce-error { background: #fdeaea; border-color: #f3c0c0; color: #9b2f33; }
.woocommerce-message { background: #eaf7e3; border-color: #c2e3ad; color: var(--green-d); }
.woocommerce-info { background: var(--sky); border-color: #cfe0f4; color: var(--brand-blue-d); }

/* ============================================================
 * My Account — Orders table + Account form polish
 * ============================================================ */
/* Orders / downloads table */
.account-content .woocommerce-orders-table,
.account-content .woocommerce-table--order-downloads,
.account-content table.shop_table { border-collapse: separate; border-spacing: 0; }
.account-content table.shop_table thead th { background: var(--sky); border: 0; border-bottom: 1px solid var(--line); }
.account-content table.shop_table tbody td,
.account-content table.shop_table tbody th { background: #fff; border: 0; border-bottom: 1px solid var(--line); padding: 14px 18px; vertical-align: middle; color: var(--ink); font-size: 14px; font-weight: 600; }
.account-content table.shop_table tbody tr:last-child td { border-bottom: 0; }
.account-content table.shop_table .woocommerce-orders-table__cell-order-number { font-weight: 800; color: var(--navy); }
.account-content table.shop_table .woocommerce-orders-table__cell-order-status { font-weight: 800; color: var(--navy); }
/* status colour cues */
.account-content .order-status, .account-content mark.order-status { background: transparent; }
/* View buttons — flat, no green shadow leak */
.account-content table.shop_table .button,
.account-content table.shop_table .woocommerce-button {
	background: var(--brand-blue); color: #fff; box-shadow: none;
	padding: 9px 16px; font-size: 12px;
}
.account-content table.shop_table .button:hover { background: var(--brand-blue-d); }

/* Account-area pagination → pager pills (not green button) */
.account-content .woocommerce-pagination { display: flex; gap: 8px; justify-content: center; padding: 26px 0 0; }
.account-content .woocommerce-pagination .button,
.account-content .woocommerce-Pagination a,
.account-content .woocommerce-pagination a,
.account-content .woocommerce-pagination .page-numbers {
	background: #fff; color: var(--navy); border: 1.5px solid var(--line);
	box-shadow: none; padding: 11px 18px; border-radius: 9px; font-size: 13px;
}
.account-content .woocommerce-pagination .button:hover,
.account-content .woocommerce-pagination .page-numbers:hover { border-color: var(--brand-blue); color: var(--brand-blue); background: #fff; }
.account-content .woocommerce-pagination .current { background: var(--brand-blue); border-color: var(--brand-blue); color: #fff; }

/* Edit-account form */
.account-content .woocommerce-EditAccountForm,
.account-content .edit-account { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; max-width: 720px; }
.account-content .woocommerce-EditAccountForm .form-row-first { grid-column: 1; }
.account-content .woocommerce-EditAccountForm .form-row-last { grid-column: 2; }
.account-content .woocommerce-EditAccountForm .form-row-wide,
.account-content .woocommerce-EditAccountForm fieldset,
.account-content .woocommerce-EditAccountForm > p.woocommerce-form-row--wide,
.account-content .woocommerce-EditAccountForm > p:last-of-type,
.account-content .woocommerce-EditAccountForm .clear { grid-column: 1 / -1; }
.account-content .woocommerce-EditAccountForm .form-row { margin: 0; }
.account-content .woocommerce-EditAccountForm em,
.account-content .woocommerce-EditAccountForm span.description { display: block; grid-column: 1 / -1; font-size: 12.5px; color: var(--muted); font-style: normal; margin-top: -6px; }

/* fieldset (password change) */
.account-content fieldset { border: 1px solid var(--line); border-radius: 12px; padding: 18px 22px 22px; margin: 6px 0 0; background: var(--sky); }
.account-content fieldset legend { font-size: 12px; font-weight: 800; color: var(--navy); text-transform: uppercase; letter-spacing: .04em; padding: 0 8px; }
.account-content fieldset .form-row { margin: 0 0 14px; }
.account-content fieldset .form-row:last-child { margin-bottom: 0; }

/* password show/hide toggle */
.account-content .password-input { position: relative; display: block; }
.account-content .password-input input { width: 100%; padding-right: 44px; }
.account-content .show-password-input { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); cursor: pointer; color: #9aa7b4; }
.account-content .show-password-input::after { content: "\1F441"; font-size: 15px; }
.account-content .show-password-input.display-password { color: var(--brand-blue); }

/* save button full width-left */
.account-content .woocommerce-EditAccountForm button[type="submit"] { justify-self: start; }

/* ===== Checkout summary — item specs + trust row + payment box (fixes v2) ===== */
.checkout-summary .oi .info .specs { display: flex; flex-direction: column; gap: 3px; margin-top: 8px; padding-top: 8px; border-top: 1px dashed var(--line); }
.checkout-summary .oi .info .specs .p { display: flex; justify-content: space-between; gap: 12px; font-size: 11.5px; line-height: 1.4; }
.checkout-summary .oi .info .specs .p .k { color: var(--muted); font-weight: 600; white-space: nowrap; flex: none; }
.checkout-summary .oi .info .specs .p .v { color: var(--navy); font-weight: 700; text-align: right; word-break: break-word; }
.checkout-summary .oi .info .specs .p .v.muted { color: #aeb7c1; font-weight: 600; }

.checkout-summary .trust-row { display: flex !important; gap: 18px; justify-content: center; margin-top: 16px; flex-wrap: wrap; }
.checkout-summary .trust-row .ti { display: inline-flex !important; align-items: center; gap: 6px; font-size: 11px; font-weight: 700; color: var(--muted); }
.checkout-summary .trust-row .ti svg { width: 14px !important; height: 14px !important; color: var(--green-d); flex: none; }

.woocommerce-checkout #payment ul.payment_methods li { list-style: none; padding: 12px 0; border-bottom: 1px solid var(--line); }
.woocommerce-checkout #payment ul.payment_methods li img { max-height: 24px; width: auto; display: inline-block; vertical-align: middle; margin-left: 6px; }
.woocommerce-checkout #payment ul.payment_methods li label { font-weight: 700; color: var(--navy); }
.woocommerce-checkout #payment div.payment_box { padding: 14px 16px; border-radius: 10px; margin-top: 10px; font-size: 13px; background: #f6f9fc; }
.woocommerce-checkout #payment .wc-stripe-elements-field, .woocommerce-checkout #payment .wc-card-fields { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 12px; }

/* Neutralize change-quantity-on-checkout plugin (cqoc_*) — it injects a
   duplicate product/qty row into the order review and overlaps the summary.
   Real fix is to deactivate that plugin; this hides its output as a fallback. */
.checkout-summary .cqoc_container,
.woocommerce-checkout .cqoc_container,
.woocommerce-checkout [class^="cqoc"],
.woocommerce-checkout [class*=" cqoc"] { display: none !important; }
