/* GC Repair — klant-boekingspagina */

/* Huisstijl: vaste magenta accentkleur (precies zoals het ontwerp). Stel
   desgewenst een andere accentkleur in via Instellingen -> Huisstijl; die komt
   als inline --gcr-accent op de wrapper en overschrijft deze waarde. */
.gcr-booking,
.gcr-search {
        --gcr-accent: #a51c7c;
        --gcr-accent-strong: color-mix(in srgb, var(--gcr-accent) 82%, #000);
        --gcr-accent-glow: color-mix(in srgb, var(--gcr-accent) 14%, transparent);
        --gcr-accent-ring: color-mix(in srgb, var(--gcr-accent) 28%, transparent);
        --gcr-accent-tint: color-mix(in srgb, var(--gcr-accent) 7%, #fff);
        --gcr-on-accent: #fff;
}

.gcr-booking {
        max-width: 1080px;
        margin: 0 auto;
        font-size: 16px;
        color: #1f2329;
}
/* Bestaande koptekst blijft in de DOM voor SEO/structured data, maar wordt
   visueel verborgen: de hero-kop hieronder is de zichtbare titel (precies zoals
   het ontwerp). */
.gcr-booking-title {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
}

/* Hero-kop: "REPARATIES" + grote tweeregelige titel met accentstreep. */
.gcr-hero {
        text-align: center;
        margin: 0 0 30px;
        padding-top: 84px;
}
.gcr-hero-eyebrow {
        display: block;
        text-transform: uppercase;
        letter-spacing: .28em;
        font-size: .72em;
        font-weight: 700;
        color: var(--gcr-accent);
        margin-bottom: 12px;
}
.gcr-hero-title {
        margin: 0;
        font-weight: 800;
        font-size: clamp(1.7em, 4.6vw, 2.5em);
        line-height: 1.2;
        padding-top: .08em;
        letter-spacing: -.01em;
        color: #160611;
}
.gcr-hero-line {
        display: block;
}
.gcr-hero-em {
        position: relative;
        font-style: normal;
        white-space: nowrap;
        padding-bottom: .04em;
}
.gcr-hero-em::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        height: .14em;
        border-radius: 6px;
        background: linear-gradient(90deg, #ff8a00, #ff2e9a);
}
/* Snelle model-zoekbalk op de boekingspagina (tussen titel en stappen). */
.gcr-booking-search {
        max-width: 620px;
        margin: 0 auto 34px;
}

.gcr-cat-title { margin: 4px 0 14px; }
.gcr-cat-model { color: var(--gcr-accent); font-weight: 600; }

.gcr-step { margin: 0 0 14px; font-size: 0.9em; color: #5a6169; }
.gcr-step a { text-decoration: none; }
.gcr-muted { color: #6b7280; }
.gcr-req { color: #c0392b; }

.gcr-alert {
        padding: 12px 16px;
        border-radius: 8px;
        margin-bottom: 18px;
        font-weight: 500;
}
.gcr-alert-ok { background: #e6f5ea; color: #146c2e; border: 1px solid #b6e0c2; }
.gcr-alert-err { background: #fdeaea; color: #a02322; border: 1px solid #f3c2c2; }

.gcr-notice {
        padding: 10px 14px;
        border-radius: 8px;
        margin-bottom: 18px;
        background: #f3f4f6;
        color: #4b5563;
        border: 1px solid #e5e7eb;
        font-size: 14px;
}

.gcr-hours .gcr-hours-title {
        display: block;
        font-weight: 600;
        color: #374151;
        margin-bottom: 6px;
}
.gcr-hours-list {
        list-style: none;
        margin: 0;
        padding: 0;
}
.gcr-hours-row {
        display: flex;
        justify-content: space-between;
        gap: 16px;
        padding: 2px 0;
}
.gcr-hours-row .gcr-hours-day {
        text-transform: capitalize;
}
.gcr-hours-row .gcr-hours-time {
        font-variant-numeric: tabular-nums;
}
.gcr-hours-closed {
        color: #9ca3af;
}
.gcr-hours-closed .gcr-hours-time {
        font-style: italic;
}

/* Stap 1: categorie-tegels */
.gcr-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
        gap: 20px;
        margin-bottom: 56px;
}
.gcr-tile {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 16px;
        min-height: 168px;
        padding: 32px 16px;
        border: 1px solid #e2e5ea;
        border-radius: 16px;
        text-decoration: none;
        color: inherit;
        background: #fff;
        transition: border-color .15s, box-shadow .15s, transform .15s;
}
.gcr-tile:hover {
        border-color: var(--gcr-accent);
        box-shadow: 0 8px 22px var(--gcr-accent-glow);
        transform: translateY(-3px);
}
.gcr-tile-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 1.1em;
        font-size: 3.6em;
        line-height: 1;
}
.gcr-tile-name { font-weight: 700; font-size: 1.08em; }

/* Stap 1: zoekblok ("Welk model heb je?") boven het merken-/modellenraster. */
.gcr-search-q { font-size: 1.32em; font-weight: 400; margin: 8px 0 14px; }
.gcr-search-q strong { font-weight: 800; }
.gcr-find-wrap { margin: 0 0 30px; scroll-margin-top: 90px; }

/* Stap 1: merkenraster. Tegels zijn compacter dan de categorie-tegels en
   tonen een nette tekst-wordmark (of een aangeleverd logobestand). */
.gcr-brand-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 16px; }
.gcr-brand-tile { min-height: 100px; padding: 20px 14px; gap: 0; }
.gcr-brand-name {
        font-weight: 700;
        font-size: 1.12em;
        letter-spacing: .2px;
        color: #5b6473;
        text-align: center;
        transition: color .15s;
}
.gcr-brand-tile:hover .gcr-brand-name { color: var(--gcr-accent); }
.gcr-brand-logo {
        display: block;
        max-height: 40px;
        max-width: 82%;
        width: auto;
        height: auto;
        object-fit: contain;
}

/* Stap 1: modellenraster van één merk. Toestelfoto + modelnaam + modelcode. */
.gcr-count-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 26px;
        height: 22px;
        padding: 0 9px;
        border-radius: 999px;
        background: var(--gcr-accent);
        color: var(--gcr-on-accent, #fff);
        font-size: .8em;
        font-weight: 700;
        line-height: 1;
}
.gcr-model-grid { gap: 16px; }
.gcr-model-tile {
        min-height: 158px;
        padding: 20px 14px 18px;
        gap: 10px;
        justify-content: flex-start;
        text-align: center;
}
.gcr-model-img {
        display: block;
        height: 84px;
        width: auto;
        max-width: 64px;
        object-fit: contain;
        margin-bottom: 2px;
}
.gcr-model-tile .gcr-tile-name { font-size: 1.02em; }
.gcr-model-code {
        color: var(--gcr-accent);
        font-size: .78em;
        font-weight: 600;
        letter-spacing: .2px;
}
/* "Vind mijn model"-tegel: gestippelde accentrand met telefoon-icoon. */
.gcr-find-tile { border-style: dashed; border-color: color-mix(in srgb, var(--gcr-accent) 45%, #e2e5ea); }
.gcr-find-tile .gcr-tile-name { color: var(--gcr-accent); }
.gcr-find-ico { display: flex; align-items: center; justify-content: center; height: 84px; color: var(--gcr-accent); }

/* Stap 2: lijst */
.gcr-list { list-style: none; margin: 0; padding: 0; }
.gcr-list-item {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        padding: 12px 14px;
        border: 1px solid #e8eaee;
        border-radius: 10px;
        margin-bottom: 10px;
        background: #fff;
}
.gcr-list-main { display: flex; align-items: center; gap: 12px; }
.gcr-list-thumb {
        width: 48px; height: 48px; object-fit: contain;
        border: 1px solid #eee; border-radius: 8px; background: #fff; padding: 3px;
}
.gcr-list-name { display: block; font-weight: 600; }
.gcr-list-price { display: block; color: var(--gcr-accent); font-weight: 600; }

/* Stap 3: samenvatting + formulier */
.gcr-summary {
        display: flex;
        align-items: center;
        gap: 14px;
        padding: 16px;
        border: 1px solid #e2e5ea;
        border-radius: 12px;
        background: #f8fafc;
        margin-bottom: 18px;
}
.gcr-summary-thumb {
        width: 64px; height: 64px; object-fit: contain;
        background: #fff; border: 1px solid #eee; border-radius: 8px; padding: 4px;
}
.gcr-summary-name { display: block; font-weight: 700; font-size: 1.1em; }
.gcr-summary-cat { display: block; color: #6b7280; font-size: 0.9em; }
.gcr-summary-price { display: block; color: var(--gcr-accent); font-weight: 700; font-size: 1.15em; margin-top: 4px; }

/* Stap 3: twee-koloms afronden (links plannen, rechts overzicht + gegevens) */
.gcr-checkout-head {
        display: flex;
        align-items: center;
        gap: 14px;
        margin: 0 0 20px;
}
.gcr-checkout-title {
        margin: 0;
        font-weight: 800;
        font-size: clamp(1.3em, 3.2vw, 1.7em);
        color: color-mix(in srgb, var(--gcr-accent) 22%, #160611);
}
.gcr-form.gcr-checkout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
        gap: 22px;
        align-items: start;
}
.gcr-checkout-main {
        display: flex;
        flex-direction: column;
        gap: 18px;
        min-width: 0;
}
.gcr-checkout-side {
        display: flex;
        flex-direction: column;
        gap: 14px;
        min-width: 0;
        border: 1px solid #e7d4e3;
        border-radius: 16px;
        background: #fff;
        padding: 18px;
        box-shadow: 0 10px 30px rgba(120, 18, 86, .07);
}
.gcr-checkout-device {
        display: flex;
        align-items: center;
        gap: 12px;
        padding-bottom: 14px;
        border-bottom: 1px solid #f0e6ed;
}
.gcr-checkout-device-img {
        width: 52px; height: 52px; object-fit: contain;
        background: #fff; border: 1px solid #eee; border-radius: 10px; padding: 4px;
        flex: none;
}
.gcr-checkout-device-meta { display: flex; flex-direction: column; min-width: 0; }
.gcr-checkout-device-name { font-weight: 700; font-size: 1.02em; }
.gcr-checkout-device-sub { color: var(--gcr-accent); font-weight: 600; font-size: .85em; text-transform: capitalize; }
.gcr-section-tight { margin: 2px 0 6px; }
.gcr-checkout-side .gcr-summary { flex-direction: column; align-items: stretch; }
.gcr-checkout-side .gcr-btn-primary { width: 100%; text-align: center; align-self: stretch; }
.gcr-service-badge {
        flex: none;
        margin-left: auto;
        align-self: center;
        font-size: .76em;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: .03em;
        color: var(--gcr-accent);
        background: var(--gcr-accent-tint);
        border: 1px solid color-mix(in srgb, var(--gcr-accent) 25%, #fff);
        padding: 3px 10px;
        border-radius: 999px;
}
@media (max-width: 720px) {
        .gcr-form.gcr-checkout { grid-template-columns: 1fr; }
}

.gcr-form { display: flex; flex-direction: column; gap: 14px; }
.gcr-label { display: flex; flex-direction: column; gap: 5px; font-weight: 600; font-size: 0.95em; }
.gcr-label input,
.gcr-label select,
.gcr-label textarea {
        font-size: 16px;
        padding: 10px 12px;
        border: 1px solid #cbd2dc;
        border-radius: 8px;
        width: 100%;
        box-sizing: border-box;
        font-weight: 400;
}
.gcr-label input:focus,
.gcr-label select:focus,
.gcr-label textarea:focus {
        outline: none;
        border-color: var(--gcr-accent);
        box-shadow: 0 0 0 3px var(--gcr-accent-ring);
}

.gcr-hp { position: absolute; left: -9999px; height: 0; overflow: hidden; }

.gcr-btn {
        display: inline-block;
        padding: 10px 18px;
        border-radius: 8px;
        background: #eef2f7;
        color: #1f2329;
        text-decoration: none;
        font-weight: 600;
        border: none;
        cursor: pointer;
        font-size: 0.95em;
}
.gcr-btn:hover { background: #e2e8f0; }
.gcr-btn-primary { background: var(--gcr-accent); color: var(--gcr-on-accent); align-self: flex-start; padding: 12px 22px; }
.gcr-btn-primary:hover { background: var(--gcr-accent-strong); }

/* Afspraak: datum + tijd */
.gcr-appt {
        border: 1px solid #e2e5ea;
        border-radius: 12px;
        padding: 16px;
        background: #f8fafc;
}
.gcr-appt-title { margin: 0 0 12px; font-weight: 700; font-size: 0.98em; }
.gcr-appt-date {
        display: none;
        font-size: 16px;
        padding: 10px 12px;
        border: 1px solid #cbd2dc;
        border-radius: 8px;
        background: #fff;
        margin-bottom: 14px;
        max-width: 100%;
}
.gcr-appt.gcr-js .gcr-appt-date { display: block; }
.gcr-appt.gcr-js .gcr-day legend { display: none; }

.gcr-day {
        border: none;
        margin: 0 0 14px;
        padding: 0;
}
.gcr-day legend {
        font-weight: 600;
        padding: 0;
        margin-bottom: 8px;
        text-transform: capitalize;
}
.gcr-slots {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(86px, 1fr));
        gap: 8px;
}
.gcr-slot {
        display: block;
        position: relative;
}
.gcr-slot input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
}
.gcr-slot span {
        display: block;
        text-align: center;
        padding: 9px 6px;
        border: 1px solid #cbd2dc;
        border-radius: 8px;
        background: #fff;
        cursor: pointer;
        font-weight: 600;
        font-size: 0.95em;
        transition: border-color .12s, background .12s, color .12s;
}
.gcr-slot input:hover + span { border-color: var(--gcr-accent); }
.gcr-slot input:focus-visible + span { box-shadow: 0 0 0 3px var(--gcr-accent-ring); }
.gcr-slot input:checked + span { background: var(--gcr-accent); border-color: var(--gcr-accent); color: var(--gcr-on-accent); }

/* ------------------------------------------------------------------ *
 * v2-stijl: voortgangsbalk, toestel-koptekst, kleur-swatches, kaarten
 * ------------------------------------------------------------------ */

/* Voortgangsbalk (Apparaten -> Reparaties -> Afronden) */
.gcr-steps {
        position: relative;
        display: flex;
        justify-content: space-between;
        gap: 8px;
        margin: 0 0 24px;
}
.gcr-steps-bar {
        position: absolute;
        top: 15px;
        left: 7%;
        right: 7%;
        height: 3px;
        background: #e2e5ea;
        border-radius: 3px;
        z-index: 0;
}
.gcr-steps-bar i {
        display: block;
        height: 100%;
        background: var(--gcr-accent);
        border-radius: 3px;
        transition: width .3s ease;
}
.gcr-step-seg {
        position: relative;
        z-index: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 7px;
        flex: 1;
}
.gcr-step-dot {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border-radius: 50%;
        background: #fff;
        border: 2px solid #cbd2dc;
        color: #6b7280;
        font-weight: 700;
        font-size: 0.9em;
}
.gcr-step-seg.active .gcr-step-dot {
        border-color: var(--gcr-accent);
        color: var(--gcr-accent);
        box-shadow: 0 0 0 4px var(--gcr-accent-glow);
}
.gcr-step-seg.done .gcr-step-dot {
        background: var(--gcr-accent);
        border-color: var(--gcr-accent);
        color: var(--gcr-on-accent);
}
.gcr-step-lbl { font-size: 0.82em; color: #6b7280; font-weight: 600; }
.gcr-step-seg.active .gcr-step-lbl,
.gcr-step-seg.done .gcr-step-lbl { color: #1f2329; }

/* Sectiekop met blauw bolletje */
.gcr-section {
        display: flex;
        align-items: center;
        gap: 9px;
        margin: 22px 0 12px;
        font-weight: 700;
        font-size: 1.02em;
}
.gcr-section-row { justify-content: space-between; }
.gcr-section-l { display: flex; align-items: center; gap: 9px; }
.gcr-dot {
        display: inline-block;
        width: 9px;
        height: 9px;
        border-radius: 50%;
        background: var(--gcr-accent);
        flex: none;
}
.gcr-vat {
        display: inline-flex;
        gap: 2px;
        padding: 2px;
        border: 1px solid #cdd6e0;
        border-radius: 999px;
        background: #f1f4f8;
        vertical-align: middle;
}
.gcr-vat-opt {
        appearance: none;
        border: 0;
        background: transparent;
        cursor: pointer;
        font: inherit;
        font-size: 0.78em;
        font-weight: 600;
        color: #5a6472;
        padding: 3px 12px;
        border-radius: 999px;
        line-height: 1.4;
}
.gcr-vat-opt.is-active {
        background: var(--gcr-accent);
        color: #fff;
}

/* Toestel-koptekst */
.gcr-device {
        display: flex;
        align-items: center;
        gap: 14px;
        padding: 14px 16px;
        border: 1px solid #e2e5ea;
        border-radius: 12px;
        background: #f8fafc;
}
.gcr-device-back {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 38px;
        height: 38px;
        flex: none;
        border-radius: 9px;
        border: 1px solid #cbd2dc;
        background: #fff;
        color: #1f2329;
        text-decoration: none;
        font-size: 1.2em;
        line-height: 1;
}
.gcr-device-back:hover { border-color: var(--gcr-accent); color: var(--gcr-accent); }
.gcr-device-img {
        width: 48px; height: 48px; flex: none;
        object-fit: contain; background: #fff;
        border: 1px solid #eee; border-radius: 9px; padding: 4px;
}
.gcr-device-meta { display: flex; flex-direction: column; gap: 2px; }
.gcr-device-name { font-weight: 700; font-size: 1.08em; }
.gcr-device-cat { color: #6b7280; font-size: 0.88em; }

/* Kleur-swatches */
.gcr-colors {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
}
.gcr-swatch {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 7px 13px 7px 9px;
        border: 1px solid #e2e5ea;
        border-radius: 999px;
        background: #fff;
        cursor: pointer;
        font-size: 0.9em;
        font-weight: 600;
        transition: border-color .12s, box-shadow .12s;
}
.gcr-swatch:hover { border-color: var(--gcr-accent); }
.gcr-swatch.is-selected {
        border-color: var(--gcr-accent);
        box-shadow: 0 0 0 3px var(--gcr-accent-glow);
}
.gcr-swatch input { position: absolute; opacity: 0; pointer-events: none; }
.gcr-swatch-chip {
        display: inline-block;
        width: 20px;
        height: 20px;
        border-radius: 50%;
        border: 1px solid rgba(0, 0, 0, .15);
        flex: none;
}

/* Reparatiekaarten */
.gcr-repairs {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
        gap: 14px;
}
.gcr-repair {
        position: relative;
        display: block;
        padding: 16px 16px 18px;
        border: 1px solid #e2e5ea;
        border-radius: 12px;
        background: #fff;
        text-decoration: none;
        color: inherit;
        transition: border-color .15s, box-shadow .15s, transform .15s;
}
.gcr-repair:hover {
        border-color: var(--gcr-accent);
        box-shadow: 0 6px 18px var(--gcr-accent-glow);
        transform: translateY(-2px);
}
.gcr-repair-price { position: absolute; top: 14px; right: 14px; text-align: right; }
.gcr-price-badge {
        display: inline-flex;
        flex-direction: column;
        align-items: flex-end;
        line-height: 1.1;
}
.gcr-price-cap { font-size: 0.68em; color: #6b7280; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; }
.gcr-price-amt { font-size: 1.1em; font-weight: 800; color: var(--gcr-accent); }
.gcr-price-req {
        font-size: 0.74em;
        font-weight: 700;
        color: #92400e;
        background: #fef3c7;
        border: 1px solid #fde68a;
        padding: 4px 9px;
        border-radius: 999px;
}
.gcr-repair-top { display: flex; align-items: flex-start; gap: 12px; padding-right: 78px; }
.gcr-repair-ico {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 42px; height: 42px; flex: none;
        border-radius: 10px;
        background: #eef2ff;
        font-size: 1.35em;
        line-height: 1;
        color: var(--gcr-accent);
}
.gcr-repair-ico .gcr-ico-svg { width: 24px; height: 24px; display: block; }
.gcr-repair-ttl { display: flex; flex-direction: column; gap: 3px; }
.gcr-repair-name { font-weight: 700; font-size: 1.02em; }
.gcr-repair-dur {
        font-size: 0.74em;
        font-weight: 700;
        color: #5a6169;
        text-transform: uppercase;
        letter-spacing: .03em;
}
.gcr-repair-desc { margin: 12px 0 0; color: #5a6169; font-size: 0.9em; line-height: 1.45; }

/* Reparatie-categorie-accordeons (stap 2) */
.gcr-accordions { display: flex; flex-direction: column; gap: 12px; }
.gcr-accordion {
        border: 1px solid #e2e5ea;
        border-radius: 12px;
        background: #fff;
        overflow: hidden;
}
.gcr-accordion[open] { border-color: var(--gcr-accent-ring); box-shadow: 0 4px 16px var(--gcr-accent-glow); }
.gcr-acc-sum {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 14px 16px;
        cursor: pointer;
        list-style: none;
        user-select: none;
}
.gcr-acc-sum::-webkit-details-marker { display: none; }
.gcr-acc-ico {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 38px; height: 38px; flex: none;
        border-radius: 10px;
        background: #eef2ff;
        font-size: 1.25em;
        line-height: 1;
        color: var(--gcr-accent);
}
.gcr-acc-ico .gcr-ico-svg { width: 22px; height: 22px; display: block; }
.gcr-acc-ttl { font-weight: 700; font-size: 1.02em; flex: 1; min-width: 0; }
.gcr-acc-count {
        font-size: .76em;
        font-weight: 700;
        color: var(--gcr-accent);
        background: var(--gcr-accent-glow);
        padding: 4px 10px;
        border-radius: 999px;
        white-space: nowrap;
}
.gcr-acc-chev {
        flex: none;
        color: #9aa1ab;
        font-size: .9em;
        line-height: 1;
        transition: transform .2s ease;
}
.gcr-accordion[open] .gcr-acc-chev { transform: rotate(180deg); }
.gcr-acc-body { padding: 0 16px 16px; }

/* Gekozen kleur op stap 3 */
.gcr-chosen-color {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px 14px;
        border: 1px solid #e2e5ea;
        border-radius: 10px;
        background: #f8fafc;
        font-size: 0.95em;
}
.gcr-chosen-color-txt { flex: 1; }
.gcr-chosen-color-edit { font-size: 0.85em; text-decoration: none; color: var(--gcr-accent); font-weight: 600; }
.gcr-chosen-color-edit:hover { text-decoration: underline; }

@media (max-width: 520px) {
        .gcr-list-item { flex-direction: column; align-items: stretch; }
        .gcr-btn { text-align: center; }
        .gcr-slots { grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)); }
        .gcr-repairs { grid-template-columns: 1fr; }
        .gcr-step-lbl { font-size: 0.72em; }
}

/* ------------------------------------------------------------------ *
 * Zoekbalk-shortcode [gc_repair_search]
 * ------------------------------------------------------------------ */
.gcr-search {
        max-width: 620px;
        margin: 0 auto;
        font-size: 16px;
        color: #1f2329;
        position: relative;
}
.gcr-search-heading { margin: 0 0 10px; font-weight: 600; }
.gcr-search-form {
        display: flex;
        align-items: center;
        gap: 10px;
        background: #fff;
        border: 1px solid #e3e5ea;
        border-radius: 999px;
        padding: 7px 7px 7px 28px;
        box-shadow: 0 6px 22px rgba(16, 24, 40, .10);
        transition: border-color .15s, box-shadow .15s;
}
.gcr-search-form:focus-within {
        border-color: var(--gcr-accent);
        box-shadow: 0 0 0 3px var(--gcr-accent-glow);
}
.gcr-search-input {
        flex: 1;
        border: 0;
        outline: 0;
        background: transparent;
        font-size: 1.2em;
        color: inherit;
        padding: 11px 2px;
        min-width: 0;
}
.gcr-search-input::placeholder { color: #8a9099; opacity: 1; }
.gcr-search-btn {
        flex: none;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 54px;
        height: 54px;
        border: 0;
        border-radius: 16px;
        background: var(--gcr-accent);
        color: var(--gcr-on-accent);
        cursor: pointer;
        transition: background .15s;
}
.gcr-search-btn:hover { background: var(--gcr-accent-strong); }
.gcr-search-btn-ico { width: 24px; height: 24px; display: block; }

.gcr-is-busy .gcr-search-form { border-color: var(--gcr-accent); }

/* ------------------------------------------------------------------ *
 * Zoekresultaten — licht pop-up venster (foto 2)
 * ------------------------------------------------------------------ */

.gcr-search-results, .gcr-search-results * { box-sizing: border-box; }

/* Standaard (no-JS server-render): de pop-up verschijnt inline onder het veld. */
.gcr-search-results { margin-top: 14px; }
.gcr-search-results:empty { display: none; }

/* Met JavaScript: een nette dropdown direct ONDER het zoekveld
 * (geankerd aan .gcr-search), geen schermvullende overlay. */
.gcr-search-results.gcr-open {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        z-index: 9999;
        margin-top: 10px;
}

.gcr-search-modal { width: 100%; }

.gcr-search-card {
        display: flex;
        flex-direction: column;
        background: #fff;
        border: 1px solid #e7e9ee;
        border-radius: 18px;
        box-shadow: 0 18px 48px rgba(16, 24, 40, .18);
        overflow: hidden;
        text-align: left;
}
.gcr-search-results.gcr-open .gcr-search-card { max-height: 70vh; }

.gcr-search-cardhead {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        padding: 16px 22px;
        border-bottom: 1px solid #eef0f3;
}
.gcr-search-close {
        flex: none;
        margin-left: auto;
        width: 44px;
        height: 44px;
        border: 0;
        border-radius: 12px;
        background: #9aa1ab;
        color: #fff;
        font-size: 1.5rem;
        line-height: 1;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: background .15s;
}
.gcr-search-close:hover { background: #7c828c; }

.gcr-search-cardbody { overflow-y: auto; -webkit-overflow-scrolling: touch; }

.gcr-search-empty {
        margin: 0;
        padding: 22px;
        color: #5a6169;
}
.gcr-search-empty a { color: var(--gcr-accent); font-weight: 600; text-decoration: none; }
.gcr-search-empty a:hover { text-decoration: underline; }

.gcr-search-list { list-style: none; margin: 0; padding: 0; }
.gcr-sresult {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 14px 22px;
        border-top: 1px solid #eef0f3;
}
.gcr-sresult:first-child { border-top: 0; }

.gcr-sresult-ico {
        flex: none;
        width: 42px;
        height: 50px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 8px;
        overflow: hidden;
}
.gcr-sresult-ico img { width: 100%; height: 100%; object-fit: contain; }
.gcr-sresult-glyph { font-size: 1.9rem; line-height: 1; }

.gcr-sresult-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 9px; }
.gcr-sresult-name {
        display: inline-block;
        text-decoration: none;
        font-size: 1.72rem;
        line-height: 1.2;
        padding: 2px 0;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
}
.gcr-sresult-name:hover .gcr-sresult-model { text-decoration: underline; }
.gcr-sresult-brand { color: #8b3fb0; font-weight: 600; }
.gcr-sresult-model { color: #1f2329; font-weight: 700; }

.gcr-sresult-repairs { display: flex; flex-wrap: wrap; gap: 12px; }
.gcr-srepair {
        display: inline-flex;
        align-items: baseline;
        gap: 7px;
        padding: 12px 18px;
        border-radius: 14px;
        background: #f7edf6;
        text-decoration: none;
        color: inherit;
        font-size: 1.1rem;
        line-height: 1.2;
        transition: background .12s;
}
.gcr-srepair:hover { background: #f0e1ee; }
.gcr-srepair-name { color: #3a3f47; }
.gcr-srepair-price { color: #c2185b; font-weight: 700; }
.gcr-srepair-more {
        background: #f7edf6;
        color: #c2185b;
        font-weight: 700;
}
.gcr-srepair-more:hover { background: #f0e1ee; }

/* ---- Inline kwaliteitsvarianten-flyout (kiezen direct in de zoek-dropdown) ---- */
.gcr-srepair-wrap {
        position: relative;
        display: inline-flex;
}
.gcr-srepair-toggle.gcr-fly-open {
        background: #8b3fb0;
        color: #fff;
        border-color: #8b3fb0;
}
.gcr-srepair-toggle.gcr-fly-open .gcr-srepair-price { color: #fff; }
.gcr-srepair-fly {
        position: absolute;
        top: calc(100% + 10px);
        left: 0;
        z-index: 30;
        width: 460px;
        max-width: min(90vw, 520px);
        background: #fff;
        border: 1px solid #ece0f3;
        border-radius: 16px;
        box-shadow: 0 18px 48px rgba(31, 39, 51, .18);
        overflow: hidden;
}
.gcr-srepair-fly[hidden] { display: none; }
.gcr-fly-list {
        list-style: none;
        margin: 0;
        padding: 6px;
}
.gcr-fly-item { display: block; }
.gcr-fly-item + .gcr-fly-item { border-top: 1px solid #f1edf5; }
.gcr-fly-row {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
                "head price"
                "dur  price"
                "desc desc";
        gap: 2px 14px;
        align-items: baseline;
        padding: 14px 16px;
        text-decoration: none;
        color: #1f2733;
        border-radius: 12px;
        transition: background .12s;
}
.gcr-fly-row:hover { background: #faf5fd; }
.gcr-fly-head {
        grid-area: head;
        display: flex;
        align-items: center;
        flex-wrap: wrap;
        gap: 8px;
}
.gcr-fly-q {
        font-size: 1.06rem;
        font-weight: 800;
        color: #1f2733;
}
.gcr-fly-badge {
        display: inline-flex;
        align-items: center;
        padding: 3px 10px;
        border-radius: 999px;
        font-size: .78rem;
        font-weight: 700;
        line-height: 1.2;
        background: #fbe4f1;
        color: #b0167a;
}
.gcr-fly-badge-pop {
        display: inline-flex;
        align-items: center;
        gap: 5px;
        padding: 3px 10px;
        border-radius: 999px;
        font-size: .78rem;
        font-weight: 700;
        line-height: 1.2;
        background: #e3f7e8;
        color: #1f8a3b;
}
.gcr-fly-dur {
        grid-area: dur;
        font-size: .82rem;
        font-weight: 700;
        letter-spacing: .04em;
        text-transform: uppercase;
        color: #8b3fb0;
}
.gcr-fly-desc {
        grid-area: desc;
        margin-top: 4px;
        font-size: .9rem;
        line-height: 1.4;
        color: #5b6573;
}
.gcr-fly-price {
        grid-area: price;
        align-self: center;
        font-size: 1.45rem;
        font-weight: 800;
        color: #1f2733;
        white-space: nowrap;
}

@media (max-width: 600px) {
        .gcr-search-form { padding: 6px 6px 6px 20px; }
        .gcr-search-input { font-size: 1.05em; }
        .gcr-search-btn { width: 48px; height: 48px; border-radius: 14px; }

        .gcr-search-results.gcr-open .gcr-search-card { max-height: 72vh; }
        .gcr-search-cardhead { padding: 14px 16px; }
        .gcr-sresult { padding: 13px 16px; gap: 13px; }
        .gcr-sresult-ico { width: 40px; height: 48px; }
        .gcr-sresult-name { font-size: 1.42rem; }
        .gcr-sresult-repairs { gap: 9px; }
        .gcr-srepair { padding: 10px 14px; font-size: 1.02rem; }

        .gcr-srepair-wrap { display: block; }
        .gcr-srepair-fly { width: 100%; max-width: 100%; }
        .gcr-fly-row { padding: 12px 14px; }
        .gcr-fly-price { font-size: 1.3rem; }
}

/* ====================================================================== *
 * Winkelmand ("Reparatie lijst") + kwaliteitsvarianten
 * ====================================================================== */

/* Layout: reparaties links, winkelmand rechts. Zonder JS één kolom en de
 * mand verborgen (de klant kiest dan één reparatie via een directe link). */
.gcr-shop { display: block; }
.gcr-shop-main { min-width: 0; }
.gcr-cart { display: none; }
.gcr-shop.gcr-js-cart {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 300px;
        gap: 20px;
        align-items: start;
}
.gcr-shop.gcr-js-cart .gcr-cart { display: block; }

.gcr-cart {
        position: sticky;
        top: 16px;
        border: 1px solid #e2e5ea;
        border-radius: 14px;
        background: #fff;
        padding: 16px 16px 26px;
        box-shadow: 0 6px 20px rgba(15, 23, 42, .05);
}
.gcr-cart-head { display: flex; align-items: center; gap: 9px; font-weight: 800; font-size: 1.05em; }
.gcr-cart-ico { font-size: 1.2em; line-height: 1; }
.gcr-cart-device { margin-top: 4px; color: #6b7280; font-size: .86em; }
.gcr-cart-items { margin: 14px 0 0; display: flex; flex-direction: column; gap: 8px; }
.gcr-cart-item {
        display: flex; align-items: center; gap: 8px;
        padding: 9px 10px; border: 1px solid #eef1f5; border-radius: 10px; background: #f8fafc;
}
.gcr-cart-item-label { flex: 1; min-width: 0; font-size: .9em; font-weight: 600; }
.gcr-cart-item-price { font-weight: 700; color: #146c2e; font-size: .9em; white-space: nowrap; }
.gcr-cart-item-rm {
        flex: none; width: 24px; height: 24px; border-radius: 50%;
        border: 1px solid #e2e5ea; background: #fff; color: #6b7280;
        cursor: pointer; line-height: 1; font-size: 1em; padding: 0;
}
.gcr-cart-item-rm:hover { border-color: #dc2626; color: #dc2626; }
.gcr-cart-empty { margin-top: 14px; color: #6b7280; font-size: .88em; line-height: 1.45; }
.gcr-cart-totals { margin: 14px 0 0; border-top: 1px dashed #e2e5ea; padding-top: 12px; display: flex; flex-direction: column; gap: 6px; }
.gcr-cart-total-row { display: flex; justify-content: space-between; font-size: .9em; color: #5a6169; }
.gcr-cart-total-muted span:last-child { color: #9aa1ab; }
.gcr-cart-total-discount { color: #15803d; font-weight: 700; }
.gcr-cart-total-discount span:last-child { color: #15803d; }
.gcr-cart-grand { margin-top: 10px; padding-top: 12px; border-top: 1px solid #eef1f5; }
.gcr-cart-total-grand { display: flex; justify-content: space-between; font-size: 1.05em; font-weight: 800; color: #1f2329; }

/* Couponveld */
.gcr-coupon { margin-top: 12px; display: flex; flex-direction: column; gap: 6px; }
.gcr-coupon-lbl { font-size: .82em; font-weight: 700; color: #5a6169; }
.gcr-coupon-row { display: flex; gap: 8px; }
.gcr-coupon-input {
        flex: 1; min-width: 0;
        padding: 9px 11px;
        border: 1px solid #cdd6e0;
        border-radius: 9px;
        font: inherit; font-size: .88em;
        background: #fff;
}
.gcr-coupon-input:focus { outline: none; border-color: var(--gcr-accent); box-shadow: 0 0 0 3px var(--gcr-accent-glow); }
.gcr-coupon-btn {
        flex: none;
        padding: 9px 14px;
        border: 1px solid #cdd6e0;
        border-radius: 9px;
        background: #f1f4f8;
        color: #374151;
        font: inherit; font-size: .85em; font-weight: 700;
        cursor: pointer;
}
.gcr-coupon-btn:hover { border-color: var(--gcr-accent); color: var(--gcr-accent); }
.gcr-coupon-btn:disabled { opacity: .6; cursor: default; }
.gcr-coupon-input[readonly] { background: #f6f8fb; color: #5a6169; }
.gcr-coupon-msg { margin: 0; font-size: .82em; line-height: 1.4; }
.gcr-coupon-msg.is-ok { color: #15803d; }
.gcr-coupon-msg.is-warn { color: #b45309; }
.gcr-coupon-msg.is-error { color: #dc2626; }

/* Winkelmand-knoppen: offerte (secundair) + volgende stap (primair) met subtekst */
.gcr-cart-checkout, .gcr-cart-offer {
        margin-top: 12px;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 1px;
        align-self: stretch;
        justify-content: center;
        text-align: center;
        line-height: 1.25;
}
.gcr-cart-checkout[aria-disabled="true"], .gcr-cart-offer[aria-disabled="true"] { opacity: .5; pointer-events: none; }
.gcr-btn-offer {
        background: #fff;
        color: var(--gcr-accent);
        border: 1px solid var(--gcr-accent);
}
.gcr-btn-offer:hover { background: var(--gcr-accent-glow); }
.gcr-btn-main { font-weight: 700; }
.gcr-btn-sub { font-size: .72em; font-weight: 500; opacity: .85; }
.gcr-cart-note { margin: 10px 0 0; font-size: .76em; color: #9aa1ab; line-height: 1.4; }

/* Kwaliteitsvarianten binnen een reparatiekaart */
.gcr-variants { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.gcr-variant {
        display: flex; align-items: center; justify-content: space-between; gap: 12px;
        padding: 10px 12px; border: 1px solid #e2e5ea; border-radius: 10px;
        background: #f8fafc; text-decoration: none; color: inherit;
        transition: border-color .12s, background .12s;
}
.gcr-variant:hover { border-color: var(--gcr-accent); background: var(--gcr-accent-tint); }
.gcr-variant-info { display: flex; align-items: center; gap: 8px; min-width: 0; }
.gcr-variant-q { font-weight: 600; font-size: .92em; }
.gcr-variant-badge {
        font-size: .68em; font-weight: 800; text-transform: uppercase; letter-spacing: .03em;
        color: var(--gcr-on-accent); background: var(--gcr-accent);
        padding: 3px 8px; border-radius: 999px; white-space: nowrap;
}
.gcr-variant-right { display: flex; align-items: center; gap: 10px; }
.gcr-variant-price { font-weight: 800; color: #146c2e; font-size: .95em; white-space: nowrap; }
.gcr-variant-req { color: #92400e; }
.gcr-variant-add {
        flex: none; width: 24px; height: 24px; border-radius: 50%;
        display: none; align-items: center; justify-content: center;
        background: var(--gcr-accent); color: var(--gcr-on-accent);
        font-weight: 700; line-height: 1; font-size: 1.05em;
}
/* "+"-knop + toegevoegd-staat alleen wanneer JS de mand bestuurt */
.gcr-js-cart .gcr-variant-add { display: inline-flex; }
.gcr-js-cart .gcr-variant.gcr-is-added { border-color: #146c2e; background: #e6f5ea; }
.gcr-js-cart .gcr-variant.gcr-is-added .gcr-variant-add { background: #146c2e; font-size: 0; }
.gcr-js-cart .gcr-variant.gcr-is-added .gcr-variant-add::before { content: '\2713'; font-size: 14px; }

@media (max-width: 720px) {
        .gcr-shop.gcr-js-cart { grid-template-columns: 1fr; }
        .gcr-cart { position: static; }
}

/* ------------------------------------------------------------------ *
 * Offerteflow: servicemethode + adres
 * ------------------------------------------------------------------ */
.gcr-offerfields { display: grid; gap: 18px; margin: 6px 0 4px; }
.gcr-service { display: grid; gap: 10px; }
.gcr-service-opt {
display: flex; align-items: center; gap: 12px;
border: 2px solid var(--gcr-border, #d9dee6); border-radius: 12px;
padding: 12px 14px; cursor: pointer; transition: border-color .15s, background .15s;
}
.gcr-service-opt:hover { border-color: var(--gcr-accent); }
.gcr-service-opt input { flex: none; }
.gcr-service-opt:has(input:checked) { border-color: var(--gcr-accent); background: var(--gcr-accent-tint); }
.gcr-service-body { display: flex; align-items: flex-start; gap: 10px; }
.gcr-service-ico { font-size: 1.4em; line-height: 1; }
.gcr-service-txt { display: flex; flex-direction: column; gap: 2px; }
.gcr-service-ttl { font-weight: 700; }
.gcr-service-desc { font-size: .9em; color: #5a6472; }
.gcr-address-hint { font-weight: 400; font-size: .82em; color: #5a6472; }
.gcr-address-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 12px; }
.gcr-address-grid .gcr-address-postcode { grid-column: 1 / 2; }
.gcr-address-grid .gcr-address-city { grid-column: 2 / 3; }
/* Adres-nadruk wanneer "opsturen" actief is (JS voegt class toe). */
.gcr-address.gcr-address-required .gcr-appt-title { color: var(--gcr-accent); }
@media (max-width: 520px) {
.gcr-address-grid { grid-template-columns: 1fr; }
.gcr-address-grid .gcr-address-postcode,
.gcr-address-grid .gcr-address-city { grid-column: auto; }
}

/* in3-financieringsteaser ("of 3 × €X") */
.gcr-in3 {
        margin: 4px 0 0;
        font-size: 0.82em;
        font-weight: 600;
        color: #6b3fa0;
}
.gcr-summary-total .gcr-in3 {
        text-align: right;
}

/* Klanttype particulier/zakelijk */
.gcr-custtype {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin: 0 0 12px;
}
.gcr-custtype-opt {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        border: 1px solid #cdd6e0;
        border-radius: 10px;
        padding: 8px 14px;
        cursor: pointer;
        font-weight: 600;
}
.gcr-custtype-opt:has(input:checked) {
        border-color: var(--gcr-accent);
        background: var(--gcr-accent-tint);
}
.gcr-custtype-opt input {
        flex: none;
}

/* Bedrijfsblok (zichtbaar bij zakelijk) */
.gcr-business {
        display: grid;
        gap: 12px;
        margin: 0 0 12px;
}
.gcr-business[hidden] {
        display: none;
}

/* Voor-/achternaam naast elkaar */
.gcr-field-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
}

/* Samenvatting-uitklap ("Bekijk details") */
.gcr-summary-acc {
        border: 1px solid #e2e8f0;
        border-radius: 10px;
        margin: 0 0 12px;
        background: #fafbfc;
}
.gcr-summary-acc-sum {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        padding: 10px 14px;
        cursor: pointer;
        font-weight: 700;
        list-style: none;
}
.gcr-summary-acc-sum::-webkit-details-marker {
        display: none;
}
.gcr-summary-acc-sum::after {
        content: "\025be";
        color: #5a6472;
        transition: transform 0.15s ease;
}
.gcr-summary-acc[open] .gcr-summary-acc-sum::after {
        transform: rotate(180deg);
}
.gcr-summary-acc-count {
        font-weight: 600;
        color: #5a6472;
        margin-left: auto;
}

/* "Toon alle reparaties" — secundaire standaard reparaties achter een disclosure */
.gcr-more {
        margin: 14px 0 0;
}
.gcr-more-sum {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 8px 14px;
        cursor: pointer;
        font-weight: 700;
        color: #1f2937;
        background: #fafbfc;
        border: 1px solid #e2e8f0;
        border-radius: 999px;
        list-style: none;
        user-select: none;
}
.gcr-more-sum:hover {
        background: #f1f5f9;
}
.gcr-more-sum::-webkit-details-marker {
        display: none;
}
.gcr-more-sum::after {
        content: "\025be";
        color: #5a6472;
        transition: transform 0.15s ease;
}
.gcr-more[open] .gcr-more-sum::after {
        transform: rotate(180deg);
}
.gcr-more-list {
        margin-top: 14px;
}

/* Zakelijk-badge (admin) */
.gcr-badge-business {
        display: inline-block;
        font-size: 0.72em;
        font-weight: 700;
        color: #6b3fa0;
        background: #f0e9fb;
        border: 1px solid #d8c6f0;
        padding: 1px 8px;
        border-radius: 999px;
}

@media (max-width: 520px) {
        .gcr-field-grid {
                grid-template-columns: 1fr;
        }
}

/* Kwaliteitsvariant-regels (standaard reparaties): duur naast het label. */
.gcr-variant-dur {
        display: inline-block;
        margin-left: 8px;
        font-size: .82em;
        color: var(--gcr-muted, #6b7280);
}
.gcr-has-variants .gcr-variants { gap: 6px; }

/* ==================================================================
 * Checkout / offerte — herontwerp naar de paarse referentie (foto 1).
 * Strakke kaart, drijvende labels, servicemethode met vinkje rechts,
 * groot totaalvak, gestapelde knop en keurmerken-rij. Alle kleuren
 * volgen de ingestelde merkkleur (--gcr-accent), niets hardcoded.
 * Dit blok staat bewust achteraan zodat het eerdere regels overschrijft.
 * ================================================================== */

/* Rechterkaart: neutrale rand + zachte schaduw (accent-onafhankelijk). */
.gcr-checkout-side {
        border-color: #e6e9ef;
        box-shadow: 0 10px 30px rgba(17, 24, 39, .06);
}

/* Iets smallere linkerkolom, bredere rechterkolom (zoals foto 1). Alleen op
 * desktop; onder 720px blijft de bestaande enkele kolom staan. */
@media (min-width: 721px) {
        .gcr-form.gcr-checkout { grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr); }
}

/* Terugknop als zachte chip. */
.gcr-checkout-head .gcr-device-back {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 38px;
        height: 38px;
        border-radius: 12px;
        background: var(--gcr-accent-tint);
        color: var(--gcr-accent);
        font-size: 1.05em;
        text-decoration: none;
        flex: none;
}
.gcr-checkout-head .gcr-device-back:hover { background: var(--gcr-accent-glow, var(--gcr-accent-tint)); }

/* Servicemethode-kaart: icoon links, tekst, vinkje rechts. */
.gcr-service-opt {
        display: flex;
        align-items: center;
        gap: 14px;
        position: relative;
}
.gcr-service-txt { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.gcr-service-ttl-row { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.gcr-service-opt input[type="radio"] {
        position: absolute;
        opacity: 0;
        pointer-events: none;
}
.gcr-service-badge { margin: 0; }
.gcr-service-check {
        flex: none;
        margin-left: auto;
        width: 22px;
        height: 22px;
        border: 2px solid #cbd2dc;
        border-radius: 7px;
        background: #fff;
        position: relative;
        transition: border-color .15s, background .15s;
}
.gcr-service-opt:has( input:checked ) .gcr-service-check,
.gcr-service-opt.is-checked .gcr-service-check {
        border-color: var(--gcr-accent);
        background: var(--gcr-accent);
}
.gcr-service-opt:has( input:checked ) .gcr-service-check::after,
.gcr-service-opt.is-checked .gcr-service-check::after {
        content: "";
        position: absolute;
        left: 6px;
        top: 2px;
        width: 6px;
        height: 11px;
        border: solid #fff;
        border-width: 0 2px 2px 0;
        transform: rotate(45deg);
}
.gcr-service-opt:has( input:checked ),
.gcr-service-opt.is-checked {
        border-color: var(--gcr-accent);
        background: var(--gcr-accent-tint);
}
.gcr-service-opt:focus-within { border-color: var(--gcr-accent); }

/* Drijvende labels: uppercase label op de bovenrand van het veld. */
.gcr-checkout .gcr-fl { position: relative; gap: 0; }
.gcr-checkout .gcr-fl .gcr-flab {
        position: absolute;
        top: -8px;
        left: 12px;
        padding: 0 6px;
        background: #fff;
        font-size: .66rem;
        font-weight: 700;
        letter-spacing: .04em;
        text-transform: uppercase;
        color: #6b7280;
        line-height: 1.2;
        z-index: 1;
        pointer-events: none;
}
.gcr-checkout .gcr-fl .gcr-req { color: #c0392b; }
.gcr-checkout .gcr-fl input,
.gcr-checkout .gcr-fl textarea { padding-top: 14px; }

/* Totaalvak (foto 1). */
.gcr-totaalbox {
        border: 1px solid #e2e8f0;
        border-radius: 14px;
        background: #f8fafc;
        padding: 14px 16px;
        margin: 4px 0 14px;
}
.gcr-totaalbox-head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
}
.gcr-totaalbox-l { display: flex; flex-direction: column; }
.gcr-totaalbox-ttl { font-weight: 700; font-size: 1.05em; }
.gcr-totaalbox-vat { font-size: .8em; color: #6b7280; }
.gcr-totaalbox-amt {
        font-size: 1.5em;
        font-weight: 800;
        color: color-mix(in srgb, var(--gcr-accent) 35%, #160611);
}
.gcr-totaalbox .gcr-summary-acc { margin: 12px 0 0; background: #fff; }
.gcr-totaalbox .gcr-in3 { margin-top: 10px; }

/* Klanttype als vierkante keuzevakjes (foto 1). */
.gcr-custtype-lbl { font-weight: 700; font-size: .9em; margin-right: 4px; }
.gcr-custtype-opt {
        position: relative;
        border: 0;
        background: transparent;
        padding: 0;
        gap: 8px;
}
.gcr-custtype-opt:has( input:checked ),
.gcr-custtype-opt.is-checked { background: transparent; }
.gcr-custtype-opt input { position: absolute; opacity: 0; pointer-events: none; }
.gcr-custtype-opt::before {
        content: "";
        flex: none;
        width: 18px;
        height: 18px;
        border: 2px solid #cbd2dc;
        border-radius: 5px;
        background: #fff;
        transition: border-color .15s, background .15s;
}
.gcr-custtype-opt:has( input:checked )::before,
.gcr-custtype-opt.is-checked::before {
        border-color: var(--gcr-accent);
        background: var(--gcr-accent);
}
.gcr-custtype-opt:has( input:checked )::after,
.gcr-custtype-opt.is-checked::after {
        content: "";
        position: absolute;
        left: 6px;
        top: 50%;
        width: 4px;
        height: 9px;
        border: solid #fff;
        border-width: 0 2px 2px 0;
        transform: translateY(-60%) rotate(45deg);
}

/* Totaal-herhaling boven de knop. */
.gcr-checkout-recap {
        text-align: right;
        font-size: .92em;
        color: #4b5563;
        margin: 6px 0 4px;
}
.gcr-checkout-recap strong { color: #111827; }

/* Gestapelde primaire knop met subtitel + accent-verloop. */
.gcr-btn-primary.gcr-btn-stack {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2px;
        align-self: stretch;
        width: 100%;
        padding: 14px 22px;
        border-radius: 12px;
        background: linear-gradient(135deg, var(--gcr-accent), var(--gcr-accent-strong, var(--gcr-accent)));
        box-shadow: 0 10px 24px color-mix(in srgb, var(--gcr-accent) 35%, transparent);
}
.gcr-btn-primary.gcr-btn-stack:hover {
        filter: brightness(1.04);
        background: linear-gradient(135deg, var(--gcr-accent), var(--gcr-accent-strong, var(--gcr-accent)));
}
.gcr-btn-primary .gcr-btn-main { font-weight: 800; font-size: 1.02em; }
.gcr-btn-primary .gcr-btn-sub { font-size: .76em; font-weight: 500; opacity: .9; }

/* Keurmerken-rij onder het formulier. */
.gcr-trust {
        list-style: none;
        margin: 22px 0 0;
        padding: 18px 0 0;
        border-top: 1px solid #eef0f3;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 14px 28px;
}
.gcr-trust-item {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-size: .92em;
        font-weight: 600;
        color: #374151;
}
.gcr-trust-ico {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 20px;
        height: 20px;
        border-radius: 50%;
        background: #1faa59;
        color: #fff;
        font-size: .72em;
        flex: none;
}
