/* Hallmark · macrostructure: Workbench · genre: modern-minimal · theme: custom
 * tone: technical/precise · anchor hue: royal-blue (cool) · paper: white (light)
 * pre-emit critique: P5 H4 E4 S5 R4 V4
 * Car2Tour — site vitrine. Tokens locked; no inline colour/font values.
 */

:root {
    /* ---- Palette — ozone-garage's two colors ---- */
    --color-accent: #0058C9;            /* ozone blue */
    --color-accent-strong: #00429A;     /* darker blue (hover) */
    --color-secondary: #E00000;         /* ozone red */
    --color-secondary-strong: #B80000;  /* darker red (hover) */
    --color-support: #0058C9;           /* ozone has 2 colors — support = blue */

    --color-ink: oklch(28% 0 0);                  /* #3F3F3F-ish primary text (ozone) */
    --color-secondary-ink: oklch(20% 0 0);        /* #252525 headings (ozone) */
    --color-ink-soft: oklch(60% 0 0);             /* #989898 body text (ozone) */
    --color-paper: oklch(100% 0 0);               /* white */
    --color-paper-2: oklch(97.5% 0 0);            /* #F8F8F8 section grey (ozone) */
    --color-paper-3: oklch(94% 0 0);
    --color-line: oklch(90% 0 0);                 /* neutral hairline rules */
    --color-focus: #0058C9;

    /* ---- Type — Blinker (the ozone typeface), single family ---- */
    --font-display: 'Blinker', system-ui, sans-serif;
    --font-body: 'Blinker', system-ui, sans-serif;

    --text-display: clamp(2.6rem, 6vw, 4.4rem);
    --text-display-s: clamp(2rem, 4.5vw, 3rem);
    --text-h2: clamp(1.5rem, 3vw, 2.1rem);
    --text-h3: 1.2rem;
    --text-body: 1.0625rem;
    --text-sm: 0.875rem;

    /* ---- Space (4pt scale) ---- */
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1.25rem;
    --space-lg: 2rem;
    --space-xl: 3.5rem;
    --space-2xl: 6rem;

    --radius: 12px;
    --radius-lg: 20px;
    --rule: 1px solid var(--color-line);

    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
    --dur: 220ms;
}

* { box-sizing: border-box; }
html, body { overflow-x: clip; }

body {
    margin: 0;
    font-family: var(--font-body);
    font-size: var(--text-body);
    line-height: 1.6;
    color: var(--color-ink);
    background: var(--color-paper);
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
    font-family: var(--font-display);
    font-style: normal;          /* roman headings only */
    font-weight: 800;
    line-height: 1.1;            /* Blinker reads better a touch looser */
    letter-spacing: -0.01em;
    color: var(--color-secondary-ink, var(--color-ink));
    overflow-wrap: anywhere;
    min-width: 0;
}

a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.c2t-wrap { width: 100%; max-width: 1240px; margin-inline: auto; padding-inline: var(--space-lg); }

/* ---- Top utility bar ---- */
.c2t-topbar { background: var(--color-ink); color: oklch(90% 0.01 250); font-size: var(--text-sm); }
.c2t-topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); min-height: 38px; }
.c2t-topbar__info { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.c2t-topbar a { color: oklch(90% 0.01 250); }
.c2t-topbar a:hover { color: var(--color-paper); text-decoration: none; }
.c2t-topbar__sep { color: oklch(55% 0.02 250); }
.c2t-topbar__social a { font-weight: 600; }

/* ---- Navbar (N1b canonical service nav) ---- */
.c2t-nav {
    position: sticky; top: 0; z-index: 50;
    background: color-mix(in oklch, var(--color-paper) 88%, transparent);
    backdrop-filter: blur(8px);
    border-bottom: var(--rule);
}
/* ozone layout: logo left · menu centered · CTA right */
.c2t-nav__inner {
    display: flex; align-items: center; gap: var(--space-lg);
    min-height: 76px; position: relative;
}
.c2t-brand { display: inline-flex; align-items: center; gap: var(--space-sm); }
.c2t-brand img { height: 50px; width: auto; display: block; }
.c2t-nav__links {
    position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
    display: flex; gap: var(--space-xl); align-items: center;
}
.c2t-nav__links a:not(.c2t-btn) { color: var(--color-secondary-ink); font-weight: 600; font-size: 1rem; white-space: nowrap; }
.c2t-nav__links a:not(.c2t-btn):hover { color: var(--color-accent); text-decoration: none; }
.c2t-nav__cta { margin-left: auto; }
.c2t-nav__links .c2t-nav__cta-mobile { display: none; }
.c2t-nav__toggle { display: none; margin-left: auto; background: none; border: var(--rule); border-radius: 8px; padding: .4rem .6rem; cursor: pointer; font-size: 1.2rem; }

/* ---- Buttons ---- */
.c2t-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    font-family: var(--font-display); font-weight: 700; font-size: var(--text-sm);
    padding: .7rem 1.2rem; border-radius: var(--radius); border: 2px solid transparent;
    cursor: pointer; white-space: nowrap; transition: background var(--dur) var(--ease-out), transform var(--dur) var(--ease-out);
}
.c2t-btn--primary { background: var(--color-accent); color: var(--color-paper); }
.c2t-btn--primary:hover { background: var(--color-accent-strong); text-decoration: none; color: var(--color-paper); }
.c2t-btn--primary:active { transform: translateY(1px); }
.c2t-btn--ghost { background: transparent; color: var(--color-accent); border-color: var(--color-accent); }
.c2t-btn--ghost:hover { background: var(--color-accent); color: var(--color-paper); text-decoration: none; }
.c2t-btn--accent { background: var(--color-secondary); color: var(--color-paper); }
.c2t-btn--accent:hover { background: var(--color-secondary-strong); color: var(--color-paper); text-decoration: none; }
.c2t-btn--accent:active { transform: translateY(1px); }
.c2t-btn--secondary { background: var(--color-secondary); color: var(--color-paper); }
.c2t-btn--secondary:hover { background: var(--color-secondary-strong); color: var(--color-paper); text-decoration: none; }
.c2t-btn--secondary:active { transform: translateY(1px); }
.c2t-btn--block { width: 100%; }
.c2t-btn:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 2px; }
.c2t-btn[disabled] { opacity: .55; cursor: not-allowed; }

/* ---- Hero ---- */
.c2t-hero {
    padding: var(--space-2xl) 0 var(--space-xl);
    border-bottom: var(--rule);
    background: url("../img/hero-bg.svg") center / cover no-repeat, var(--color-paper);
}
.c2t-hero__grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr); gap: var(--space-xl); align-items: center; }
.c2t-hero h1 { font-size: var(--text-display); margin: 0 0 var(--space-md); }
.c2t-hero p.lede { font-size: 1.2rem; color: var(--color-ink-soft); max-width: 46ch; margin: 0 0 var(--space-lg); }
.c2t-eyebrow { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--font-display); font-weight: 700; font-size: var(--text-sm); letter-spacing: .04em; text-transform: uppercase; color: var(--color-support); margin-bottom: var(--space-md); }
.c2t-eyebrow::before { content: ""; width: 14px; height: 14px; border-radius: 50%; background: conic-gradient(var(--color-accent) 0 25%, var(--color-secondary) 25% 50%, var(--color-accent) 50% 75%, var(--color-secondary) 75% 100%); }

/* ---- Section scaffold ---- */
.c2t-section { padding: var(--space-2xl) 0; }
.c2t-section--alt { background: var(--color-paper-2); }
.c2t-section__head { max-width: 60ch; margin: 0 auto var(--space-xl); text-align: center; }
.c2t-section__head h2 { font-size: var(--text-h2); margin: 0 0 var(--space-sm); }
.c2t-section__head p { color: var(--color-ink-soft); margin: 0; }

/* ---- Services grid (Workbench) ---- */
.c2t-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.c2t-card { border: var(--rule); border-radius: var(--radius-lg); padding: var(--space-lg); background: var(--color-paper); transition: transform var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out); }
.c2t-card:hover { transform: translateY(-3px); border-color: var(--color-accent); }
.c2t-card h3 { font-size: var(--text-h3); margin: 0 0 var(--space-xs); }
.c2t-card p { color: var(--color-ink-soft); font-size: var(--text-sm); margin: 0; }
.c2t-card__tag { display: inline-block; width: 28px; height: 28px; border-radius: 8px; background: var(--color-paper-3); margin-bottom: var(--space-sm); position: relative; }
.c2t-card__tag::after { content: ""; position: absolute; inset: 8px; border-radius: 50%; border: 3px solid var(--color-accent); }

/* ---- Proof bar (real idGarages data) ---- */
.c2t-proof { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.c2t-proof__item { text-align: center; padding: var(--space-md); }
.c2t-proof__num { font-family: var(--font-display); font-weight: 800; font-size: 2.4rem; color: var(--color-accent); line-height: 1; }
.c2t-proof__label { color: var(--color-ink-soft); font-size: var(--text-sm); margin-top: var(--space-xs); }

/* ---- Devis form ---- */
.c2t-devis { background: var(--color-paper); border: 2px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-lg); box-shadow: 0 16px 40px -24px color-mix(in srgb, var(--color-accent) 35%, transparent); }
.c2t-devis__skip { margin: var(--space-sm) 0 0; text-align: center; font-size: var(--text-sm); }
.c2t-devis__skip a { color: var(--color-ink-soft); }
/* Step 2 collapses by default so the form stays short; revealed after identify/skip. */
.c2t-step2 { display: none; margin-top: var(--space-md); padding-top: var(--space-md); border-top: var(--rule); }
.c2t-step2.is-on { display: block; }
.c2t-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.c2t-field { margin-bottom: var(--space-md); }
.c2t-field label { display: block; font-weight: 600; font-size: var(--text-sm); margin-bottom: .35rem; }
.c2t-input, .c2t-select, .c2t-textarea {
    width: 100%; padding: .7rem .85rem; font: inherit; color: var(--color-ink);
    background: var(--color-paper); border: var(--rule); border-radius: var(--radius);
    transition: border-color var(--dur) var(--ease-out);
}
.c2t-input:focus, .c2t-select:focus, .c2t-textarea:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-accent) 18%, transparent); }
.c2t-textarea { min-height: 110px; resize: vertical; }

/* License-plate field — "plate-first" euro-plate visual */
.c2t-plate { display: flex; align-items: stretch; border: 2px solid var(--color-ink); border-radius: var(--radius); overflow: hidden; background: var(--color-paper); max-width: 380px; }
.c2t-plate__eu { display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--color-accent); color: var(--color-paper); padding: 0 .6rem; font-family: var(--font-display); font-weight: 800; font-size: .75rem; }
.c2t-plate__eu span { font-size: 1.1rem; }
.c2t-plate input { flex: 1; min-width: 0; border: none; padding: .8rem 1rem; font-family: var(--font-display); font-weight: 800; font-size: 1.4rem; letter-spacing: .12em; text-transform: uppercase; }
.c2t-plate input:focus { outline: none; }

.c2t-vehicle-found { display: none; align-items: center; gap: var(--space-sm); padding: var(--space-sm) var(--space-md); border-radius: var(--radius); background: color-mix(in oklch, var(--color-support) 12%, var(--color-paper)); border: 1px solid color-mix(in oklch, var(--color-support) 40%, var(--color-line)); margin-top: var(--space-sm); }
.c2t-vehicle-found.is-on { display: flex; }
.c2t-manual { display: none; }
.c2t-manual.is-on { display: block; }

.c2t-alert { padding: var(--space-sm) var(--space-md); border-radius: var(--radius); margin-bottom: var(--space-md); font-size: var(--text-sm); }
.c2t-alert--ok { background: color-mix(in oklch, var(--color-support) 14%, var(--color-paper)); border: 1px solid var(--color-support); color: var(--color-ink); }
.c2t-alert--err { background: color-mix(in oklch, var(--color-secondary) 14%, var(--color-paper)); border: 1px solid var(--color-secondary); color: var(--color-ink); }

/* Target-spin loader, reused brand motif */
.c2t-spin { width: 18px; height: 18px; border-radius: 50%; border: 3px solid var(--color-paper-3); border-top-color: var(--color-accent); animation: c2t-rot .7s linear infinite; }
@keyframes c2t-rot { to { transform: rotate(360deg); } }

/* ---- Editable CMS content slot ---- */
.c2t-content { padding: var(--space-2xl) 0; }
.c2t-content :is(h2, h3) { margin-top: var(--space-lg); }

/* ---- Footer (statement) ---- */
.c2t-footer { background: var(--color-ink); color: oklch(88% 0.01 250); padding: var(--space-2xl) 0 var(--space-lg); }
.c2t-footer a { color: oklch(88% 0.01 250); }
.c2t-footer__grid { display: grid; grid-template-columns: minmax(0, 1.4fr) repeat(2, minmax(0, 1fr)); gap: var(--space-lg); }
.c2t-footer h4 { color: var(--color-paper); font-size: var(--text-h3); margin: 0 0 var(--space-sm); }
.c2t-footer__statement { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.4rem, 3vw, 2rem); color: var(--color-paper); max-width: 22ch; line-height: 1.1; }
.c2t-footer__nav { display: flex; flex-wrap: wrap; gap: var(--space-md); margin-top: var(--space-md); }
.c2t-footer__nav a { font-weight: 600; font-size: var(--text-sm); }
.c2t-footer__meta { border-top: 1px solid oklch(30% 0.01 270); margin-top: var(--space-xl); padding-top: var(--space-md); font-size: var(--text-sm); color: oklch(70% 0.01 250); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-sm); }

/* ---- Blog list (re-skin existing) ---- */
.c2t-posts { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-lg); }
.c2t-post img { width: 100%; border-radius: var(--radius); margin-bottom: var(--space-sm); }

/* ---- Hero CTA row ---- */
.c2t-hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-sm); }

/* ---- Section footer (centered button under a grid) ---- */
.c2t-section__foot { margin-top: var(--space-lg); text-align: center; }

/* ---- Process steps ---- */
.c2t-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-lg); }
.c2t-step { position: relative; padding-top: var(--space-md); }
.c2t-step__num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 46px; height: 46px; border-radius: 50%;
    background: var(--color-accent); color: var(--color-paper);
    font-family: var(--font-display); font-weight: 800; font-size: 1.3rem;
    margin-bottom: var(--space-sm);
}
.c2t-step h3 { font-size: var(--text-h3); margin: 0 0 var(--space-xs); }
.c2t-step p { color: var(--color-ink-soft); margin: 0; }

/* Plain card variant (no hover-lift accent, for reason grid) */
.c2t-card--plain:hover { transform: none; border-color: var(--color-accent); }

/* ---- Avis (testimonials) ---- */
.c2t-avis { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); margin-top: var(--space-xl); }
.c2t-quote { margin: 0; padding: var(--space-lg); border: var(--rule); border-radius: var(--radius-lg); background: var(--color-paper); }
.c2t-quote blockquote { margin: 0 0 var(--space-sm); font-size: 1.05rem; line-height: 1.5; }
.c2t-quote figcaption { color: var(--color-support); font-size: var(--text-sm); font-weight: 600; }

/* ---- CTA band ---- */
.c2t-cta { background: var(--color-accent); color: var(--color-paper); padding: var(--space-2xl) 0; }
.c2t-cta__grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr); gap: var(--space-xl); align-items: center; }
.c2t-cta h2 { color: var(--color-paper); font-size: var(--text-h2); margin: 0 0 var(--space-sm); }
.c2t-cta p { color: color-mix(in srgb, var(--color-paper) 80%, var(--color-accent)); margin: 0 0 var(--space-md); }
.c2t-btn--light { background: var(--color-paper); color: var(--color-accent); }
.c2t-btn--light:hover { background: oklch(94% 0.01 250); color: var(--color-accent-strong); text-decoration: none; }
.c2t-cta__hours h3 { color: var(--color-paper); font-size: var(--text-h3); margin: 0 0 var(--space-sm); }
.c2t-cta__hours ul { list-style: none; margin: 0; padding: 0; }
.c2t-cta__hours li { display: flex; justify-content: space-between; gap: var(--space-md); padding: .4rem 0; border-bottom: 1px solid color-mix(in srgb, var(--color-paper) 35%, var(--color-accent)); font-size: var(--text-sm); }
.c2t-cta__hours li span:first-child { font-weight: 600; }

/* ---- Inner page header (À propos / Nos services / Contact) ---- */
.c2t-page-header { padding: var(--space-2xl) 0 var(--space-lg); border-bottom: var(--rule); text-align: center; }
.c2t-page-header .c2t-wrap { max-width: 800px; }
.c2t-page-header h1 { font-size: var(--text-display-s); margin: 0 0 var(--space-sm); }
.c2t-page-header .lede { font-size: 1.15rem; color: var(--color-ink-soft); margin: 0 auto; max-width: 60ch; }
.c2t-page-hero-img { width: 100%; border-radius: var(--radius-lg); margin-top: var(--space-lg); }
.c2t-content--page .c2t-wrap { max-width: 800px; }
.c2t-content--page :is(h2, h3) { margin-top: var(--space-xl); }
.c2t-content--page ul { padding-left: 1.2rem; }
.c2t-content--page li { margin-bottom: var(--space-xs); }

/* ---- Icons ---- */
.c2t-ico { width: 24px; height: 24px; display: inline-block; vertical-align: middle; }
.c2t-ico--star { width: 16px; height: 16px; color: var(--color-secondary); }

/* Icon cards (services with SVG) */
.c2t-card--ico .c2t-card__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 48px; height: 48px; border-radius: 12px;
    background: color-mix(in oklch, var(--color-accent) 10%, var(--color-paper));
    color: var(--color-accent); margin-bottom: var(--space-sm);
}
.c2t-card--ico .c2t-card__icon .c2t-ico { width: 26px; height: 26px; }

/* ---- Stars ---- */
.c2t-stars { display: flex; gap: 2px; margin-bottom: var(--space-sm); }

/* ---- Contact: info + map ---- */
.c2t-contact__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: var(--space-xl); align-items: start; }
.c2t-contact__info h2 { font-size: var(--text-h2); margin: 0 0 var(--space-md); }
.c2t-subhead { display: flex; align-items: center; gap: .5rem; font-size: var(--text-h3); margin: var(--space-lg) 0 var(--space-sm); color: var(--color-accent); }
.c2t-iconlist, .c2t-hourslist { list-style: none; margin: 0 0 var(--space-md); padding: 0; }
.c2t-iconlist li { display: flex; align-items: center; gap: .65rem; padding: .35rem 0; color: var(--color-ink); }
.c2t-iconlist .c2t-ico { color: var(--color-accent); flex: none; }
.c2t-hourslist li { display: flex; justify-content: space-between; gap: var(--space-md); padding: .35rem 0; border-bottom: var(--rule); font-size: var(--text-sm); }
.c2t-hourslist li span:first-child { font-weight: 600; }
.c2t-contact__cta { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin: var(--space-md) 0; }
.c2t-contact__map iframe { width: 100%; height: 420px; border: 0; border-radius: var(--radius-lg); }

/* ---- Payment methods ---- */
.c2t-pay { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-md); max-width: 640px; }
.c2t-pay__item { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md); border: var(--rule); border-radius: var(--radius-lg); background: var(--color-paper); }
.c2t-pay__item .c2t-ico { color: var(--color-accent); flex: none; }
.c2t-pay__item span { color: var(--color-ink-soft); font-size: var(--text-sm); }

/* ---- Ratings breakdown ---- */
.c2t-ratings { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); margin-bottom: var(--space-xl); }
.c2t-rating { display: flex; flex-direction: column; align-items: center; text-align: center; padding: var(--space-md); border: var(--rule); border-radius: var(--radius); background: var(--color-paper); }
.c2t-rating__score { font-family: var(--font-display); font-weight: 800; font-size: 1.8rem; color: var(--color-accent); }
.c2t-rating__label { font-size: var(--text-sm); color: var(--color-ink-soft); }

/* ---- Photo service cards ---- */
.c2t-card--photo { padding: 0; overflow: hidden; }
.c2t-card--photo img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block; }
.c2t-card--photo .c2t-card__b { padding: var(--space-md) var(--space-lg) var(--space-lg); }
.c2t-card--photo .c2t-card__b h3 { margin: 0 0 var(--space-xs); }

/* ---- Nav phone CTA ---- */
.c2t-nav__call { padding-block: .5rem; }

/* ---- Hero car image (AutoFix red SUV) ---- */
.c2t-hero__car { display: block; width: 100%; max-width: 540px; height: auto; margin-top: var(--space-lg); filter: drop-shadow(0 24px 30px color-mix(in srgb, var(--color-accent) 25%, transparent)); }

/* ---- Split section (image + text) ---- */
.c2t-split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: var(--space-xl); align-items: center; }
.c2t-split__media img { width: 100%; height: auto; display: block; }
.c2t-section__head--left { margin: 0 0 var(--space-md); text-align: left; }
.c2t-reasons { list-style: none; margin: 0; padding: 0; }
.c2t-reasons li { position: relative; padding: var(--space-sm) 0 var(--space-sm) 2rem; border-bottom: var(--rule); color: var(--color-ink-soft); }
.c2t-reasons li strong { color: var(--color-ink); }
.c2t-reasons li::before { content: ""; position: absolute; left: 0; top: 1.15rem; width: 14px; height: 14px; border-radius: 50%; background: conic-gradient(var(--color-accent) 0 50%, var(--color-secondary) 50% 100%); }

/* ---- Gallery (real workshop photos) ---- */
.c2t-gallery { padding: var(--space-2xl) 0; }
.c2t-gallery__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.c2t-gallery figure { margin: 0; overflow: hidden; border-radius: var(--radius-lg); aspect-ratio: 4 / 3; }
.c2t-gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur) var(--ease-out); }
.c2t-gallery figure:hover img { transform: scale(1.05); }

/* ====== OZONE-STYLE HERO ====== */
.c2t-hero2 {
    position: relative;
    min-height: 560px;
    display: flex; align-items: center; justify-content: center;
    text-align: center; color: var(--color-paper);
    padding: var(--space-2xl) var(--space-md) calc(var(--space-2xl) + 90px);
    background:
      linear-gradient(color-mix(in srgb, var(--color-accent) 74%, #000 26%) , color-mix(in srgb, var(--color-accent) 58%, #000 42%)),
      url("../14042.webp") center / cover no-repeat;
    background-blend-mode: multiply;
}
.c2t-hero2__inner { max-width: 760px; }
.c2t-hero2 h1 { color: var(--color-paper); font-size: clamp(2.6rem, 6vw, 4rem); letter-spacing: .02em; margin: 0 0 var(--space-sm); text-transform: uppercase; }
.c2t-hero2__sub { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.3rem, 3vw, 2rem); margin: 0 0 var(--space-md); }
.c2t-hero2__lede { font-size: 1.1rem; line-height: 1.6; color: oklch(95% 0 0); margin: 0 auto var(--space-lg); max-width: 56ch; }
.c2t-hero2__lede strong { color: var(--color-paper); }
.c2t-hero2__cta { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; }
.c2t-hero2__cta .c2t-btn { padding: .85rem 1.5rem; font-size: 1rem; }

/* 3 cards + form overlapping the hero bottom */
.c2t-herorow { margin-top: -90px; position: relative; z-index: 2; padding-bottom: var(--space-2xl); }
.c2t-herorow__grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr); gap: 0; align-items: stretch; }
.c2t-herocards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0; border-radius: var(--radius-lg) 0 0 var(--radius-lg); overflow: hidden; box-shadow: 0 20px 50px -30px rgba(0,0,0,.5); }
.c2t-herocard { background: var(--color-paper); padding: 2.25rem 1.5rem; text-align: center; color: var(--color-ink); }
.c2t-herocard--dark { background: #4a4a4a; color: var(--color-paper); }
.c2t-herocard--accent { background: var(--color-accent); color: var(--color-paper); }
.c2t-herocard--dark h3, .c2t-herocard--accent h3 { color: var(--color-paper); }
.c2t-herocard--dark p, .c2t-herocard--accent p { color: rgba(255,255,255,.85); }
.c2t-herocard__ico { width: 52px; height: 52px; display: block; margin: 0 auto 1rem; color: var(--color-accent); }
.c2t-herocard--dark .c2t-herocard__ico, .c2t-herocard--accent .c2t-herocard__ico { color: var(--color-paper); }
.c2t-herocard h3 { font-size: 1.15rem; font-weight: 700; margin: 0 0 1rem; color: var(--color-accent); }
.c2t-herocard--dark h3, .c2t-herocard--accent h3 { color: var(--color-paper); }
.c2t-herocard p { font-size: .95rem; line-height: 1.55; margin: 0; color: var(--color-ink-soft); }
.c2t-herocard--dark p, .c2t-herocard--accent p { color: rgba(255,255,255,.85); }

/* Hero form card (simple contact form, ozone style) */
.c2t-heroform { background: var(--color-paper); border-radius: 0 var(--radius-lg) var(--radius-lg) 0; padding: 2rem; box-shadow: 0 20px 50px -30px rgba(0,0,0,.5); }
.c2t-cform__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.25rem; }
.c2t-cform .c2t-field { margin-bottom: 1rem; }
.c2t-cform label { display: block; font-size: .9rem; color: var(--color-ink); margin-bottom: .35rem; }
.c2t-cform .c2t-input, .c2t-cform .c2t-select, .c2t-cform .c2t-textarea { background: var(--color-paper); }
.c2t-cform .c2t-btn { margin-top: .25rem; padding-block: .85rem; font-size: 1rem; }

/* ---- Hero 3 features ---- */
.c2t-features3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.c2t-feature { padding: var(--space-lg); border: var(--rule); border-radius: var(--radius-lg); background: var(--color-paper); }
.c2t-feature__ico { font-size: 1.8rem; display: block; margin-bottom: var(--space-sm); }
.c2t-feature h3 { font-size: var(--text-h3); margin: 0 0 var(--space-xs); }
.c2t-feature p { color: var(--color-ink-soft); font-size: var(--text-sm); margin: 0; }

/* ---- Numbered cards ---- */
/* ---- Qui sommes-nous (ozone about layout) ---- */
.c2t-about { display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr); gap: var(--space-xl); align-items: start; }
.c2t-about__media { position: relative; }
.c2t-about__media img { width: 100%; height: 100%; max-height: 560px; object-fit: cover; border-radius: var(--radius-lg); display: block; }
.c2t-xp {
    position: absolute; top: -18px; left: -18px; z-index: 2;
    width: 118px; height: 118px; border-radius: 50%;
    background: var(--color-accent); color: var(--color-paper);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center; box-shadow: 0 10px 24px -10px rgba(0,0,0,.4);
}
.c2t-xp strong { font-family: var(--font-display); font-weight: 800; font-size: 1.9rem; line-height: 1; }
.c2t-xp span { font-size: .72rem; line-height: 1.15; margin-top: .2rem; }
.c2t-about__body h2 { color: var(--color-accent); font-size: var(--text-h2); margin: 0 0 var(--space-md); }
.c2t-about__body > p { color: var(--color-ink-soft); margin: 0 0 var(--space-md); }
.c2t-eyebrow--red { color: var(--color-secondary); }
.c2t-eyebrow--red::before { display: none; }

.c2t-numgrid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); margin: var(--space-lg) 0; }
.c2t-numcard { position: relative; padding: var(--space-md); border: var(--rule); border-radius: var(--radius); background: var(--color-paper); }
.c2t-numcard__n { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--color-secondary); line-height: 1; display: block; margin-bottom: .35rem; }
.c2t-numcard h3 { font-size: 1.05rem; color: var(--color-accent); margin: 0 0 var(--space-xs); }
.c2t-numcard p { color: var(--color-ink-soft); font-size: .9rem; line-height: 1.5; margin: 0; }

/* ---- Highlight band ---- */
.c2t-band { margin-top: var(--space-xl); padding: var(--space-xl); border-radius: var(--radius-lg); background: linear-gradient(120deg, color-mix(in oklch, var(--color-accent) 10%, var(--color-paper)), color-mix(in oklch, var(--color-support) 10%, var(--color-paper))); border: var(--rule); text-align: center; }
.c2t-band h3 { font-size: var(--text-h2); margin: 0 0 var(--space-sm); }
.c2t-band p { color: var(--color-ink-soft); max-width: 70ch; margin: 0 auto; }

/* ---- Urgent CTA band (full-width red, centered) ---- */
.c2t-urgent { background: var(--color-secondary); color: var(--color-paper); padding: var(--space-2xl) var(--space-md); text-align: center; }
.c2t-urgent h2 { color: var(--color-paper); font-size: var(--text-h2); margin: 0 0 var(--space-md); }
.c2t-urgent p { color: var(--color-paper); font-size: 1.15rem; margin: 0 auto var(--space-lg); max-width: 60ch; }
.c2t-urgent .c2t-btn--primary { background: var(--color-accent); padding: .8rem 1.5rem; }
.c2t-urgent .c2t-btn--primary:hover { background: var(--color-accent-strong); }

/* ---- Pourquoi choisir (text + 3 mini cards left, photo right) ---- */
.c2t-why { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); gap: var(--space-xl); align-items: center; }
.c2t-why__body h2 { color: var(--color-accent); font-size: var(--text-h2); margin: 0 0 var(--space-md); }
.c2t-why__body > p { color: var(--color-ink-soft); margin: 0 0 var(--space-md); line-height: 1.65; }
.c2t-why__cards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-sm); margin-top: var(--space-lg); }
.c2t-whycard { border: var(--rule); border-radius: var(--radius); padding: var(--space-md); text-align: center; background: var(--color-paper); }
.c2t-whycard h3 { color: var(--color-accent); font-size: 1rem; margin: 0 0 var(--space-xs); }
.c2t-whycard p { color: var(--color-ink-soft); font-size: .85rem; line-height: 1.5; margin: 0; }
.c2t-why__media img { width: 100%; height: 100%; max-height: 600px; object-fit: cover; border-radius: var(--radius-lg); display: block; }

/* ---- Nos services automobiles (centered header + icon cards) ---- */
.c2t-svchead { text-align: center; max-width: 820px; margin: 0 auto var(--space-xl); }
.c2t-svchead h2 { color: var(--color-accent); font-size: var(--text-h2); margin: var(--space-xs) 0 var(--space-md); }
.c2t-svchead p { color: var(--color-ink-soft); margin: 0; }
.c2t-eyebrow--center { justify-content: center; }
.c2t-svcgrid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-md); }
.c2t-svccard { background: var(--color-paper); border: var(--rule); border-radius: var(--radius-lg); padding: var(--space-lg); transition: box-shadow var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); }
.c2t-svccard:hover { transform: translateY(-3px); box-shadow: 0 16px 36px -24px rgba(0,0,0,.4); }
.c2t-svccard__ico { width: 44px; height: 44px; color: var(--color-secondary); margin-bottom: var(--space-md); display: block; }
.c2t-svccard h3 { color: var(--color-accent); font-size: 1.15rem; margin: 0 0 var(--space-sm); }
.c2t-svccard p { color: var(--color-ink-soft); font-size: .95rem; line-height: 1.55; margin: 0; }

/* ---- Diagnostic toutes marques (text left + logo carousel right) ---- */
.c2t-marques { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); gap: var(--space-xl); align-items: center; }
.c2t-marques__text h2 { color: var(--color-accent); font-size: var(--text-h2); margin: 0 0 var(--space-md); }
.c2t-marques__text p { color: var(--color-ink-soft); margin: 0; max-width: 46ch; }
.c2t-marques__logos { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.c2t-brandtrack { display: flex; gap: var(--space-xl); width: max-content; animation: c2t-marquee 28s linear infinite; }
.c2t-brandslide { flex: 0 0 auto; width: 120px; height: 90px; display: flex; align-items: center; justify-content: center; }
.c2t-brandslide img { max-width: 100%; max-height: 72px; object-fit: contain; transition: transform var(--dur) var(--ease-out); }
.c2t-brandslide img:hover { transform: scale(1.08); }
@keyframes c2t-marquee { to { transform: translateX(-50%); } }
.c2t-marques__logos:hover .c2t-brandtrack { animation-play-state: paused; }

/* ---- Brands strip (text badges — no trademarked logos) ---- */
.c2t-brands { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--space-sm); margin-top: var(--space-xl); }
.c2t-brands span {
    font-family: var(--font-display); font-weight: 700; font-size: var(--text-sm);
    color: var(--color-ink-soft); padding: .5rem 1rem; border: var(--rule);
    border-radius: 999px; background: var(--color-paper);
    transition: color var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out);
}
.c2t-brands span:hover { color: var(--color-accent); border-color: var(--color-accent); }

/* ---- Split body eyebrow/heading spacing ---- */
.c2t-split__body .c2t-eyebrow { margin-bottom: var(--space-sm); }
.c2t-split__body h2 { font-size: var(--text-h2); margin: 0 0 var(--space-md); }
.c2t-split__body > p { color: var(--color-ink-soft); margin: 0 0 var(--space-md); }

/* ---- FAQ accordion (native <details>) ---- */
.c2t-faq { display: flex; flex-direction: column; gap: var(--space-sm); }
.c2t-faq__item { border: var(--rule); border-radius: var(--radius); background: var(--color-paper); overflow: hidden; }
.c2t-faq__item summary { cursor: pointer; padding: var(--space-md) var(--space-lg); font-family: var(--font-display); font-weight: 700; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: var(--space-md); }
.c2t-faq__item summary::-webkit-details-marker { display: none; }
.c2t-faq__item summary::after { content: "+"; color: var(--color-accent); font-size: 1.4rem; line-height: 1; transition: transform var(--dur) var(--ease-out); }
.c2t-faq__item[open] summary::after { transform: rotate(45deg); }
.c2t-faq__item > div { padding: 0 var(--space-lg) var(--space-md); color: var(--color-ink-soft); }

/* ---- Responsive ---- */
@media (max-width: 860px) {
    .c2t-hero__grid { grid-template-columns: minmax(0, 1fr); }
    .c2t-grid, .c2t-proof, .c2t-footer__grid, .c2t-posts,
    .c2t-steps, .c2t-avis, .c2t-cta__grid,
    .c2t-contact__grid, .c2t-pay, .c2t-ratings,
    .c2t-split, .c2t-gallery__grid,
    .c2t-features3, .c2t-numgrid,
    .c2t-herorow__grid, .c2t-herocards, .c2t-cform__grid,
    .c2t-about, .c2t-marques, .c2t-svcgrid,
    .c2t-why, .c2t-why__cards { grid-template-columns: minmax(0, 1fr); }
    .c2t-why { direction: ltr; }
    .c2t-why__media { order: -1; }
    .c2t-xp { width: 92px; height: 92px; top: -10px; left: -10px; }
    .c2t-xp strong { font-size: 1.5rem; }
    .c2t-herorow { margin-top: -40px; }
    .c2t-herocards { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
    .c2t-heroform { border-radius: 0 0 var(--radius-lg) var(--radius-lg); }
    .c2t-contact__map iframe { height: 300px; }
    .c2t-hero__car { margin-inline: auto; }
    .c2t-hide-sm { display: none; }
    .c2t-topbar__inner { justify-content: center; }
    .c2t-topbar__social { display: none; }
    .c2t-nav__call { display: none; }
    .c2t-nav__cta { display: none; }              /* desktop CTA hidden on mobile */
    .c2t-nav__links .c2t-nav__cta-mobile { display: inline-flex; margin-top: var(--space-xs); }
    .c2t-nav__links {
        display: none; position: absolute; top: 76px; left: 0; right: 0;
        transform: none; flex-direction: column; align-items: stretch; gap: 0;
        background: var(--color-paper); border-bottom: var(--rule); padding: var(--space-sm) var(--space-md);
    }
    .c2t-nav__links.is-open { display: flex; }
    .c2t-nav__links a { padding: .6rem 0; }
    .c2t-nav__toggle { display: inline-block; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
    .c2t-spin { animation: none; }
}
