/* GreenFeathers - Checkout pagina */
:root {
    --gf-green: #2e9e2e;
    --gf-green-dark: #1a6b1a;
    --gf-green-50: #f1f8f1;
    --gf-border: #e5e7eb;
    --gf-text: #1f2a24;
    --gf-muted: #6b7280;
    --gf-error: #ef4444;
    --gf-error-bg: #fef2f2;
}

* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: 'Segoe UI', system-ui, -apple-system, Arial, sans-serif;
    background: #f7faf7;
    color: var(--gf-text);
}

/* Header */
.checkout-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 24px; background: #fff; border-bottom: 1px solid var(--gf-border);
}
.checkout-logo { display: flex; align-items: center; gap: 8px; font-size: 20px; color: var(--gf-green-dark); text-decoration: none; }
.checkout-logo strong { color: var(--gf-green); }
.logo-leaf { font-size: 22px; }
.checkout-back {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--gf-green); color: #fff; text-decoration: none;
    font-size: 14px; font-weight: 600; padding: 9px 16px; border-radius: 999px;
    transition: background .15s;
}
.checkout-back:hover { background: var(--gf-green-dark); color: #fff; }

/* Layout */
.checkout-wrap { max-width: 1240px; margin: 0 auto; padding: 48px 24px 80px; }
.checkout-title { font-size: 32px; margin: 0 0 28px; }
.checkout-layout { display: grid; grid-template-columns: 1fr 420px; gap: 32px; align-items: start; }
@media (max-width: 860px) { .checkout-layout { grid-template-columns: 1fr; } }

/* Cards */
.checkout-card {
    background: #fff; border: 1px solid var(--gf-border); border-radius: 14px;
    padding: 28px; margin-bottom: 22px;
}
.checkout-card-title {
    display: flex; align-items: center; gap: 10px;
    font-size: 19px; margin: 0 0 20px; color: var(--gf-text);
}
.checkout-card-title svg { color: var(--gf-green); }

/* Forms */
.form-row { display: flex; gap: 14px; margin-bottom: 4px; }
.form-row.two-col .form-group { flex: 1; }
.form-group { margin-bottom: 16px; display: flex; flex-direction: column; }
.form-group.full { width: 100%; }
.form-group label { font-size: 14px; font-weight: 500; margin-bottom: 6px; color: #374151; }
.form-group input {
    padding: 13px 14px; border: 1px solid var(--gf-border); border-radius: 8px;
    font-size: 15px; outline: none; transition: border-color .15s, box-shadow .15s, background .15s;
}
.form-group input:focus { border-color: var(--gf-green); box-shadow: 0 0 0 3px rgba(46,158,46,.12); }

/* Red validation state */
.form-group input.input-error,
.checkout-card.card-error input.input-error {
    border-color: var(--gf-error) !important;
    background: var(--gf-error-bg);
    box-shadow: 0 0 0 3px rgba(239,68,68,.10);
}
.form-group input.input-error::placeholder { color: #f7a3a3; }
.field-error-msg { color: var(--gf-error); font-size: 12px; margin-top: 4px; }
.checkout-card.card-error { border-color: rgba(239,68,68,.5); }

.address-hint { font-size: 12.5px; color: var(--gf-muted); margin: 0 0 12px; background: #fafafa; padding: 8px 10px; border-radius: 6px; }

.address-lookup-result {
    display: flex; align-items: center; gap: 8px; margin-top: 6px;
    font-size: 13px; color: var(--gf-green-dark); background: var(--gf-green-50);
    padding: 8px 12px; border-radius: 8px;
}

/* Delivery options */
.delivery-options { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 480px) { .delivery-options { grid-template-columns: 1fr; } }
.delivery-option {
    position: relative; border: 1.5px solid var(--gf-border); border-radius: 10px;
    padding: 14px; cursor: pointer; transition: all .15s;
}
.delivery-option input { position: absolute; opacity: 0; }
.delivery-option.active { border-color: var(--gf-green); background: var(--gf-green-50); }
.do-content { display: flex; align-items: center; gap: 12px; }
.do-content svg { color: var(--gf-green); flex-shrink: 0; }
.do-title { display: block; font-weight: 600; font-size: 14px; }
.do-sub { display: block; font-size: 12px; color: var(--gf-muted); }

/* ParcelShop */
.parcelshop-list { display: flex; flex-direction: column; gap: 8px; }
.ps-hint, .ps-empty, .ps-loading { font-size: 13px; color: var(--gf-muted); padding: 6px 0; }
.parcelshop-option {
    display: block; border: 1.5px solid var(--gf-border); border-radius: 10px;
    padding: 12px; cursor: pointer; transition: all .15s;
}
.parcelshop-option input { position: absolute; opacity: 0; }
.parcelshop-option.active { border-color: var(--gf-green); background: var(--gf-green-50); }
.ps-name { display: block; font-weight: 600; font-size: 14px; }
.ps-address { display: block; font-size: 12.5px; color: var(--gf-muted); }
.ps-distance { display: inline-block; font-size: 11.5px; color: var(--gf-green-dark); margin-top: 2px; }

/* Payment */
.payment-methods { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.payment-method {
    display: flex; align-items: center; gap: 10px; padding: 12px 14px;
    border: 1.5px solid var(--gf-border); border-radius: 10px; cursor: pointer; transition: all .15s;
}
.payment-method input { position: absolute; opacity: 0; }
.payment-method.active { border-color: var(--gf-green); background: var(--gf-green-50); }
.pm-icon { display: flex; }
.pm-label { font-weight: 600; font-size: 14px; }
.stripe-element-wrap { padding: 12px; border: 1px solid var(--gf-border); border-radius: 8px; background: #fff; }
.payment-error { margin-top: 12px; padding: 10px 12px; background: var(--gf-error-bg); border: 1px solid #fecaca; border-radius: 8px; color: #b91c1c; font-size: 13px; }

/* Pay button */
.btn-checkout-pay {
    width: 100%; padding: 18px; background: var(--gf-green); color: #fff; border: none;
    border-radius: 10px; font-size: 17px; font-weight: 600; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: 8px; transition: background .15s;
}
.btn-checkout-pay:hover { background: var(--gf-green-dark); }
.btn-checkout-pay:disabled { opacity: .7; cursor: default; }
.spin { animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Summary */
.checkout-summary-sticky {
    background: #fff; border: 1px solid var(--gf-border); border-radius: 14px;
    padding: 28px; position: sticky; top: 24px;
}
.checkout-items { display: flex; flex-direction: column; gap: 16px; margin-bottom: 20px; }
.checkout-item { display: flex; align-items: center; gap: 14px; }
.ci-image { position: relative; width: 80px; height: 80px; border-radius: 12px; background: var(--gf-green-50); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 32px; overflow: visible; }
.ci-image img { width: 100%; height: 100%; object-fit: contain; border-radius: 12px; }
.ci-qty { position: absolute; top: -7px; right: -7px; background: var(--gf-green); color: #fff; font-size: 12px; font-weight: 600; width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.ci-info { flex: 1; }
.ci-name { display: block; font-size: 15px; font-weight: 500; }
.ci-price { font-size: 16px; font-weight: 600; white-space: nowrap; }

.checkout-discount { border-top: 1px solid var(--gf-border); padding-top: 14px; margin-bottom: 14px; }
.discount-input-row { display: flex; gap: 6px; }
.discount-input-row input { flex: 1; padding: 8px 10px; border: 1px solid var(--gf-border); border-radius: 6px; font-size: 13px; }
.btn-discount { white-space: nowrap; padding: 8px 14px; font-size: 12px; background: #fff; border: 1px solid var(--gf-border); border-radius: 6px; cursor: pointer; }
.btn-discount:hover { border-color: var(--gf-green); color: var(--gf-green); }
.discount-applied-row { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--gf-green-50); border: 1px solid #bbf7d0; border-radius: 6px; }
.discount-applied-row span { flex: 1; font-size: 13px; color: var(--gf-green-dark); }
.discount-remove { background: none; border: none; cursor: pointer; padding: 2px; color: #9ca3af; display: flex; }
.discount-msg { font-size: 12px; margin-top: 4px; }

.checkout-totals { border-top: 1px solid var(--gf-border); padding-top: 16px; }
.ct-row { display: flex; justify-content: space-between; font-size: 15px; margin-bottom: 10px; color: #374151; }
.ct-free { color: var(--gf-green); font-weight: 500; }
.ct-discount { color: var(--gf-green); font-weight: 500; }
.ct-total { font-size: 20px; font-weight: 700; color: var(--gf-text); border-top: 1px solid var(--gf-border); padding-top: 12px; margin-top: 2px; }

/* Kaarttitel met item in de hoek (Bezorging + buiten-NL toggle) */
.checkout-card-title--between { justify-content: space-between; }
.cct-label { display: inline-flex; align-items: center; gap: 10px; }

/* "Levering buiten NL"-toggle — compact, rechtsboven in de hoek, geen achtergrond */
.intl-toggle { display: inline-flex; align-items: center; gap: 7px; cursor: pointer; }
.intl-toggle-text { font-size: 12px; font-weight: 500; color: var(--gf-muted); white-space: nowrap; }
.intl-toggle-switch { position: relative; display: inline-block; width: 36px; height: 20px; flex-shrink: 0; }
.intl-toggle-switch input { opacity: 0; width: 0; height: 0; }
.intl-toggle-slider { position: absolute; inset: 0; background: #cbd5e1; border-radius: 20px; transition: background .2s; }
.intl-toggle-slider::before { content: ''; position: absolute; height: 14px; width: 14px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: transform .2s; }
.intl-toggle-switch input:checked + .intl-toggle-slider { background: var(--gf-green); }
.intl-toggle-switch input:checked + .intl-toggle-slider::before { transform: translateX(16px); }
