/**
 * Checkout — DomShop "Express First" — 1:1 col mockup HTML
 * Path: assets/css/checkout.css — carica solo su is_checkout()
 */

body.woocommerce-checkout { background:linear-gradient(180deg,#f4f4ef 0%,#ecece5 100%); }

/* Nasconde h1 del page template + container del tema senza padding/max-width */
body.woocommerce-checkout main.ds-main > .ds-container > article > h1,
body.woocommerce-checkout main.ds-main h1.entry-title,
body.woocommerce-checkout main.ds-main article.page > h1 { display:none; }
body.woocommerce-checkout main.ds-main > .ds-container { max-width:none; padding:0; }

.ds-checkout-page { background:transparent; }
.ds-checkout__inner { max-width:1280px; margin:0 auto; padding:0 24px 64px; }

/* ============ BANNER DARK FULL-WIDTH ============ */
.ds-checkout__express-banner {
	background:linear-gradient(135deg,#111 0%,var(--ds-black,#2B2B2B) 100%);
	color:#fff;
	padding:36px 24px 32px;
	margin:0 0 24px;
	border-radius:18px;
	max-width:1280px;
	margin-left:auto;
	margin-right:auto;
}
.ds-checkout__express-banner-inner { max-width:none; margin:0; padding:0; }
.ds-checkout__express-banner-text h2 {
	font-family:"Fraunces","Inter",serif;
	font-weight:800; font-size:28px; letter-spacing:-.5px;
	margin:0 0 8px; color:#fff;
}
.ds-checkout__express-banner-text p {
	margin:0 0 22px; color:rgba(255,255,255,.7); font-size:14px;
}
.ds-checkout__express-wallets { display:block; width:100%; }
.ds-checkout__express-wallets #wcpay-express-checkout-element,
.ds-checkout__express-wallets .StripeElement { width:100%; }

/* ============ NOTICES + COUPON ============ */
.ds-checkout__notices { margin:0 0 16px; }
.ds-checkout__notices:empty { display:none; }

body.woocommerce-checkout .woocommerce-info {
	background:#fffbeb; border:1px solid #fde68a; border-radius:12px;
	padding:14px 18px; font-size:13.5px; color:#78350f;
	margin:0 0 12px; list-style:none;
}
body.woocommerce-checkout .woocommerce-info a,
body.woocommerce-checkout .showcoupon { color:#78350f; font-weight:700; text-decoration:underline; }
body.woocommerce-checkout .woocommerce-form-coupon,
body.woocommerce-checkout .woocommerce-form-login {
	background:#fff; border:1px solid var(--ds-border,rgba(0,0,0,.12));
	border-radius:14px; padding:18px; margin:0 0 14px;
}
body.woocommerce-checkout .woocommerce-form-coupon p,
body.woocommerce-checkout .woocommerce-form-login p { margin:0 0 10px; }
body.woocommerce-checkout .woocommerce-form-coupon p.form-row,
body.woocommerce-checkout .woocommerce-form-login p.form-row { display:flex; gap:10px; align-items:stretch; flex-wrap:wrap; }
body.woocommerce-checkout .woocommerce-form-coupon input[name="coupon_code"] {
	flex:1 1 240px; min-width:0; height:46px; padding:0 14px;
	border:1px solid var(--ds-border,rgba(0,0,0,.12)); border-radius:10px;
	font-size:14px; background:#fff;
}
body.woocommerce-checkout .woocommerce-form-coupon button,
body.woocommerce-checkout .woocommerce-form-login button {
	flex:0 0 auto; height:46px; padding:0 22px;
	background:var(--ds-black,#2B2B2B); color:#fff;
	border:1px solid var(--ds-black,#2B2B2B); border-radius:10px;
	font-weight:700; font-size:13px; cursor:pointer; white-space:nowrap;
}

/* ============ LAYOUT 2 COL ============ */
.ds-checkout__layout {
	display:grid;
	grid-template-columns:1fr 380px;
	gap:24px;
	/* align-items default stretch per consentire sticky child */
}
.ds-checkout__col-main { min-width:0; }
.ds-checkout__col-side { min-width:0; }
.ds-checkout__side-sticky { position:sticky; top:24px; }
@media (max-width:980px) {
	.ds-checkout__layout { grid-template-columns:1fr; }
	.ds-checkout__side-sticky { position:static; }
}

/* ============ MAIN CARD UNICA ============ */
.ds-checkout__main-card {
	background:#fff;
	border:1px solid var(--ds-border,rgba(0,0,0,.12));
	border-radius:18px;
	padding:28px;
}
.ds-checkout__main-title {
	font-family:"Fraunces","Inter",serif;
	font-weight:800; font-size:22px;
	margin:0 0 20px; letter-spacing:-.3px;
	color:var(--ds-black,#2B2B2B);
}
.ds-checkout__section-title {
	font-family:"Fraunces","Inter",serif;
	font-weight:700; font-size:18px;
	margin:22px 0 14px; color:var(--ds-black,#2B2B2B);
}

/* Customer details: 1 sola colonna, niente h3 ne shipping section */
body.woocommerce-checkout #customer_details { display:flex; flex-direction:column; gap:0; }
body.woocommerce-checkout #customer_details .col-1,
body.woocommerce-checkout #customer_details .col-2 {
	width:100%; float:none; background:transparent;
	border:0; padding:0;
}
body.woocommerce-checkout #customer_details .col-2:empty,
body.woocommerce-checkout #customer_details .col-2 > .woocommerce-shipping-fields:empty,
body.woocommerce-checkout #customer_details .col-2 .woocommerce-shipping-fields:empty { display:none; }
body.woocommerce-checkout #customer_details > .col-2:empty { display:none; }
body.woocommerce-checkout .woocommerce-shipping-fields:empty { display:none; }

/* Nascondi h3 di sezione billing (Dettagli di fatturazione) — gia rimosso da override
   ma teniamo come safety se WC core lo aggiunge altrove */
body.woocommerce-checkout .woocommerce-billing-fields > h3,
body.woocommerce-checkout .woocommerce-shipping-fields > h3:not(#ship-to-different-address) { display:none; }

/* Nascondi "Spedire a indirizzo diverso" (mockup non lo ha) */
body.woocommerce-checkout #ship-to-different-address,
body.woocommerce-checkout .woocommerce-shipping-fields { display:none !important; }

/* Form fields */
body.woocommerce-checkout .woocommerce-billing-fields__field-wrapper {
	display:flex; flex-direction:column; gap:12px;
}
body.woocommerce-checkout .form-row { margin:0; padding:0; width:100%; }
body.woocommerce-checkout .form-row-first,
body.woocommerce-checkout .form-row-last { float:none; width:100%; }
body.woocommerce-checkout .form-row label {
	display:block; font-size:12px; font-weight:600;
	color:rgba(0,0,0,.6); margin-bottom:6px;
}
body.woocommerce-checkout .form-row label abbr.required { color:#dc2626; text-decoration:none; }
body.woocommerce-checkout .form-row input.input-text,
body.woocommerce-checkout .form-row textarea,
body.woocommerce-checkout .form-row select {
	width:100%; height:46px; padding:0 14px;
	border:1px solid var(--ds-border,rgba(0,0,0,.12)); border-radius:10px;
	background:#fff; font-size:14px; font-family:inherit;
	color:var(--ds-black,#2B2B2B); outline:none; box-shadow:none;
}
body.woocommerce-checkout .form-row textarea { height:auto; padding:12px 14px; min-height:80px; }
body.woocommerce-checkout .form-row input.input-text:focus,
body.woocommerce-checkout .form-row textarea:focus,
body.woocommerce-checkout .form-row select:focus {
	border-color:var(--ds-black,#2B2B2B); box-shadow:0 0 0 3px rgba(0,0,0,.06);
}

body.woocommerce-checkout .select2-container--default .select2-selection--single {
	height:46px;
	border:1px solid var(--ds-border,rgba(0,0,0,.12)); border-radius:10px;
	background:#fff; display:flex; align-items:center; padding:0 14px;
}
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height:1; padding:0; color:var(--ds-black,#2B2B2B);
}
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
	height:44px; right:10px;
}

/* ============ SHIP-OPT CARDS (nel main) ============ */
.ds-checkout__ship { display:flex; flex-direction:column; gap:10px; }
.ds-checkout__ship-opt {
	display:flex; gap:14px; align-items:center;
	padding:16px 18px;
	border:1px solid var(--ds-border,rgba(0,0,0,.12));
	border-radius:12px;
	background:#fff;
	cursor:pointer;
	transition:border-color .15s, box-shadow .15s;
}
.ds-checkout__ship-opt:hover { border-color:rgba(0,0,0,.3); }
.ds-checkout__ship-opt.is-active {
	border-color:var(--ds-black,#2B2B2B);
	box-shadow:0 0 0 3px rgba(0,0,0,.04);
}
.ds-checkout__ship-opt input[type="radio"] {
	position:absolute; opacity:0; width:1px; height:1px;
}
.ds-checkout__ship-opt .check {
	width:22px; height:22px; border-radius:50%;
	border:2px solid rgba(0,0,0,.22);
	display:inline-flex; align-items:center; justify-content:center;
	flex:0 0 22px;
	color:transparent;
	transition:background .15s, border-color .15s, color .15s;
}
.ds-checkout__ship-opt.is-active .check {
	background:var(--ds-black,#2B2B2B);
	border-color:var(--ds-black,#2B2B2B);
	color:#fff;
}
.ds-checkout__ship-opt .check svg { width:12px; height:12px; }
.ds-checkout__ship-opt .lbl { flex:1; display:flex; flex-direction:column; gap:2px; }
.ds-checkout__ship-opt .lbl .name {
	font-weight:600; font-size:14px; color:var(--ds-black,#2B2B2B);
}
.ds-checkout__ship-opt .lbl .sub {
	font-size:12px; color:rgba(0,0,0,.55); font-weight:400;
}
.ds-checkout__ship-opt .pr {
	font-weight:800; font-size:14px;
	white-space:nowrap; color:var(--ds-black,#2B2B2B);
}

/* ============ PAYMENT BLOCK (nel main, in fondo) ============ */
.ds-checkout__pay-block { margin-top:24px; }
body.woocommerce-checkout #payment {
	background:transparent; border:0; padding:0; margin:0;
}
/* Mostra solo il primo metodo (Carta WCPay), nasconde gli altri e il radio del primo */
body.woocommerce-checkout #payment ul.payment_methods {
	list-style:none; margin:0; padding:0; border:0; background:transparent;
}
/* Lista metodi pagamento — card radio coerenti col design ship-opt */
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method {
	display:block;
	margin:0 0 10px;
	border:1px solid var(--ds-border,rgba(0,0,0,.12));
	border-radius:12px;
	background:#fff;
	overflow:hidden;
	transition:border-color .15s, box-shadow .15s;
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method:hover { border-color:rgba(0,0,0,.3); }
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method:has(input[type="radio"]:checked) {
	border-color:var(--ds-black,#2B2B2B);
	box-shadow:0 0 0 3px rgba(0,0,0,.04);
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method > label {
	display:flex;
	align-items:center;
	gap:12px;
	padding:16px 18px;
	margin:0;
	cursor:pointer;
	font-weight:600;
	font-size:14px;
	color:var(--ds-black,#2B2B2B);
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method > input[type="radio"] {
	position:absolute;
	opacity:0;
	width:1px;
	height:1px;
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method > label::before {
	content:"";
	width:22px;
	height:22px;
	border-radius:50%;
	border:2px solid rgba(0,0,0,.22);
	display:inline-flex;
	align-items:center;
	justify-content:center;
	flex:0 0 22px;
	background:#fff;
	transition:background .15s, border-color .15s;
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method:has(input[type="radio"]:checked) > label::before {
	background:radial-gradient(circle at center, var(--ds-black,#2B2B2B) 35%, #fff 38%);
	border-color:var(--ds-black,#2B2B2B);
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method > label img {
	max-height:22px;
	width:auto;
	margin:0 4px;
	vertical-align:middle;
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method .payment_box {
	padding:0 18px 18px;
	margin:0;
	background:transparent;
	color:rgba(0,0,0,.7);
	font-size:13px;
	border-top:1px solid rgba(0,0,0,.06);
	padding-top:14px;
}
body.woocommerce-checkout #payment ul.payment_methods li.wc_payment_method .payment_box::before { display:none; }

/* Nascondi "Salva le informazioni di pagamento" e privacy policy (mockup non li ha) */
body.woocommerce-checkout #payment .wc-block-components-checkbox,
body.woocommerce-checkout #payment .woocommerce-SavedPaymentMethods-saveNew,
body.woocommerce-checkout #payment .woocommerce-privacy-policy-text { display:none; }
body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper { padding:8px 0 0; font-size:12px; color:rgba(0,0,0,.6); }

/* Place order grande giallo */
body.woocommerce-checkout #payment .form-row.place-order,
body.woocommerce-checkout #payment .place-order { padding:18px 0 0; margin:0; }
body.woocommerce-checkout #place_order {
	display:inline-flex; align-items:center; justify-content:center;
	width:100%; height:56px; padding:0 32px;
	background:var(--ds-yellow,#FFC107); color:var(--ds-black,#2B2B2B);
	border:0; border-radius:14px;
	font-family:inherit;
	font-weight:800; font-size:14px; letter-spacing:.4px; text-transform:uppercase;
	cursor:pointer;
	box-shadow:0 8px 22px rgba(255,193,7,.36);
}
body.woocommerce-checkout #place_order:hover:not(:disabled) {
	background:var(--ds-yellow-dark,#e0a800);
	box-shadow:0 10px 28px rgba(255,193,7,.45);
}
body.woocommerce-checkout #place_order:disabled { opacity:.5; cursor:not-allowed; box-shadow:none; }

/* ============ SIDEBAR — summary ============ */
#order_review.woocommerce-checkout-review-order {
	background:transparent; border:0; border-radius:0; padding:0; overflow:visible;
}
.ds-checkout__summary {
	border-radius:18px; overflow:hidden;
	box-shadow:0 14px 44px rgba(15,23,42,.08);
	background:#fff;
}
.ds-checkout__summary-hero {
	background:#111; color:#fff;
	padding:22px 22px 24px;
}
.ds-checkout__summary-hero .ttl {
	font-size:11px; letter-spacing:1.6px; font-weight:700;
	text-transform:uppercase; color:rgba(255,255,255,.6);
}
.ds-checkout__summary-hero .grand {
	display:flex; align-items:flex-end; justify-content:space-between;
	margin-top:14px; gap:12px;
}
.ds-checkout__summary-hero .grand .l .k {
	font-size:11px; letter-spacing:1px; font-weight:700;
	text-transform:uppercase; color:rgba(255,255,255,.55);
}
.ds-checkout__summary-hero .grand .l .v {
	font-size:13px; color:rgba(255,255,255,.85); margin-top:4px;
}
.ds-checkout__summary-hero .grand .val {
	font-family:"Fraunces","Inter",serif;
	font-weight:800; font-size:32px; letter-spacing:-.6px;
	white-space:nowrap;
}
.ds-checkout__summary-body {
	background:#fff; padding:18px 22px 20px;
	border:1px solid var(--ds-border,rgba(0,0,0,.12));
	border-top:0;
}
.ds-checkout__miniprods { margin:0 0 10px; }
.ds-checkout__miniprod {
	display:flex; gap:12px; align-items:center;
	padding:12px 0;
	border-bottom:1px solid var(--ds-border,rgba(0,0,0,.08));
}
.ds-checkout__miniprod:last-child { border-bottom:0; }
.ds-checkout__miniprod img {
	width:48px; height:48px; border-radius:8px;
	object-fit:cover; background:#eee; flex:0 0 48px;
}
.ds-checkout__miniprod .name {
	flex:1; min-width:0;
	font-size:13.5px; font-weight:600;
	color:var(--ds-black,#2B2B2B); line-height:1.3;
}
.ds-checkout__miniprod .name .qty {
	font-size:11px; color:rgba(0,0,0,.5);
	font-weight:400; margin-top:3px;
}
.ds-checkout__miniprod .price {
	font-size:13.5px; font-weight:700;
	white-space:nowrap; color:var(--ds-black,#2B2B2B);
}
.ds-checkout__summary-rows { margin:10px 0 0; }
.ds-checkout__summary-rows .row {
	display:flex; justify-content:space-between; align-items:center;
	gap:12px; padding:6px 0; font-size:13.5px;
}
.ds-checkout__summary-rows .row .muted { color:rgba(0,0,0,.6); }
.ds-checkout__summary-rows .row .v { font-weight:700; color:var(--ds-black,#2B2B2B); }
.ds-checkout__summary-rows .row.total {
	font-weight:800; font-size:15px;
	border-top:1px dashed var(--ds-border,rgba(0,0,0,.2));
	padding-top:14px; margin-top:8px;
}
.ds-checkout__summary-rows .row.total .v {
	font-family:"Fraunces","Inter",serif; font-size:20px;
}
.ds-checkout__eta {
	margin-top:12px;
	background:#e9f3ec;
	border-radius:10px;
	padding:10px 12px;
	font-size:12.5px;
	font-weight:600;
	color:#1d5235;
}

/* Notices */
body.woocommerce-checkout .woocommerce-error {
	background:#fef2f2; border-radius:10px; padding:12px 14px;
	font-size:13px; color:#991b1b; border-left:3px solid #dc2626;
	list-style:none; margin:0 0 16px;
}
body.woocommerce-checkout .woocommerce-message {
	background:#e9f3ec; border-radius:10px; padding:12px 14px;
	font-size:13px; color:#1d5235; border-left:3px solid #2f7d4a;
	margin:0 0 16px;
}

/* Mobile */
@media (max-width:720px) {
	.ds-checkout__express-banner { padding:28px 20px 26px; border-radius:0; margin:0 -12px 16px; }
	.ds-checkout__express-banner-text h2 { font-size:22px; }
	.ds-checkout__inner { padding:0 12px 32px; }
	.ds-checkout__main-card { padding:20px; }
}

/* ============ PAYMENT_BOX INTERNO (Carta WCPay) ============ */
body.woocommerce-checkout #payment .payment_box .wcpay-upe-form { padding:0; margin:0; }

/* Banner sandbox "Usa la carta di prova..." — discreto, integrato */
body.woocommerce-checkout #payment .payment_box .testmode-info {
	background:rgba(120, 53, 15, .06);
	border:1px solid rgba(120, 53, 15, .15);
	border-radius:10px;
	padding:10px 12px;
	margin:0 0 12px;
	font-size:12.5px;
	color:rgba(120, 53, 15, .9);
	line-height:1.4;
}
body.woocommerce-checkout #payment .payment_box .testmode-info a {
	color:inherit;
	font-weight:700;
	text-decoration:underline;
}
body.woocommerce-checkout #payment .payment_box .testmode-info button.js-woopayments-copy-test-number {
	display:inline-flex;
	align-items:center;
	gap:6px;
	background:#fff;
	border:1px solid rgba(120, 53, 15, .2);
	border-radius:6px;
	padding:2px 8px;
	font:inherit;
	font-weight:700;
	color:inherit;
	cursor:pointer;
	vertical-align:baseline;
}
body.woocommerce-checkout #payment .payment_box .testmode-info button.js-woopayments-copy-test-number:hover {
	background:rgba(120, 53, 15, .08);
}
body.woocommerce-checkout #payment .payment_box .testmode-info button.js-woopayments-copy-test-number i {
	display:inline-block; width:12px; height:12px; opacity:.6;
	background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='9' y='9' width='13' height='13' rx='2'/><path d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1'/></svg>");
	background-size:contain; background-repeat:no-repeat;
}

/* Fieldset WCPay attorno all'iframe Stripe — rimuovi border/padding default */
body.woocommerce-checkout #payment .payment_box fieldset.wc-payment-form {
	padding:0 !important;
	margin:0 !important;
	border:0 !important;
	background:transparent;
}
body.woocommerce-checkout #payment .payment_box .wcpay-upe-element {
	width:100%;
	background:#fff;
	border:1px solid var(--ds-border,rgba(0,0,0,.12));
	border-radius:10px;
	padding:14px 12px;
	transition:border-color .15s, box-shadow .15s;
}
body.woocommerce-checkout #payment .payment_box .wcpay-upe-element.is-focused,
body.woocommerce-checkout #payment .payment_box .wcpay-upe-element:focus-within {
	border-color:var(--ds-black,#2B2B2B);
	box-shadow:0 0 0 3px rgba(0,0,0,.06);
}

/* Place order spostato sotto la sidebar in mobile (relocatePlaceOrder JS) */
@media (max-width: 980px) {
	.ds-checkout__place-order--mobile {
		margin-top:16px !important;
		padding:0 !important;
	}
}

/* Fix Chrome sticky: overflow-x:hidden su html/body rompe sticky figli.
   Usiamo overflow-x:clip che limita visualmente senza creare scroll container. */
html:has(body.woocommerce-checkout),
body.woocommerce-checkout {
	overflow-x: clip !important;
}

