/* ============================================
   Carrosserie Nouvelle — Bussigny
   Stylesheet unique, vanilla CSS, custom props
   ============================================ */

/* --- Reset minimal --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;scroll-behavior:smooth}
body{min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,picture,svg,video{display:block;max-width:100%;height:auto}
button,input,select,textarea{font:inherit;color:inherit}
button{background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* --- Tokens --- */
:root{
  --ink:#0B0F14;
  --ink-soft:#1A2028;
  --muted:#5C6773;
  --line:#E4E8ED;
  --surface:#FFFFFF;
  --bg:#F7F8FA;
  --bg-alt:#ECEFF3;
  --accent:#09A1D1;
  --accent-dark:#0780A6;
  --accent-soft:#E5F4FA;
  --brand:#09A1D1;
  --danger:#B91C1C;
  --success:#166534;

  --font-sans:"Inter", -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-display:"Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;

  --radius-sm:6px;
  --radius:12px;
  --radius-lg:20px;

  --shadow-sm:0 1px 2px rgba(11,15,20,.05);
  --shadow:0 6px 20px -8px rgba(11,15,20,.15);
  --shadow-lg:0 30px 60px -20px rgba(11,15,20,.25);

  --container:1200px;
  --gutter:clamp(1rem,3vw,2rem);

  --step--1:clamp(.83rem,.82rem + .05vw,.88rem);
  --step-0:clamp(.95rem,.93rem + .1vw,1rem);
  --step-1:clamp(1.1rem,1.05rem + .25vw,1.2rem);
  --step-2:clamp(1.3rem,1.2rem + .5vw,1.55rem);
  --step-3:clamp(1.6rem,1.4rem + 1vw,2.1rem);
  --step-4:clamp(2rem,1.6rem + 2vw,3rem);
  --step-5:clamp(2.5rem,2rem + 2.5vw,4rem);
  --step-6:clamp(3rem,2.2rem + 4vw,5.25rem);
}

body{
  font-family:var(--font-sans);
  font-size:var(--step-0);
  color:var(--ink);
  background:var(--surface);
  font-feature-settings:"ss01","cv11";
}

/* --- Layout --- */
.wrap{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(3rem,6vw,6rem)}
.section--tight{padding-block:clamp(2rem,4vw,4rem)}
.section--alt{background:var(--bg)}
.section--ink{background:var(--ink);color:#fff}
.section--ink .muted{color:rgba(255,255,255,.65)}

.grid{display:grid;gap:clamp(1rem,2vw,1.75rem)}
.grid--2{grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))}
.grid--3{grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr))}
.grid--bento{grid-template-columns:repeat(12,1fr);gap:1rem}
@media (max-width:768px){.grid--bento{grid-template-columns:repeat(2,1fr)}}

.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:var(--step--1);font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent);
}
.eyebrow::before{content:"";width:1.25rem;height:1px;background:currentColor}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:var(--step-5);letter-spacing:-.035em;line-height:1.05}
h2{font-size:var(--step-4);letter-spacing:-.03em}
h3{font-size:var(--step-2)}
h4{font-size:var(--step-1);letter-spacing:-.01em}
p{color:var(--ink-soft)}
.lead{font-size:var(--step-1);color:var(--ink-soft);max-width:60ch}
.muted{color:var(--muted)}

/* --- Top bar (promo) --- */
.topbar{
  background:var(--ink);color:#fff;font-size:var(--step--1);
  padding:.5rem var(--gutter);text-align:center;
}
.topbar strong{color:#fff;font-weight:600}
.topbar a{border-bottom:1px solid rgba(255,255,255,.4)}
.topbar a:hover{border-color:#fff}

/* --- Header --- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;min-height:68px;gap:1rem}
.logo{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-weight:700;font-size:var(--step-1);color:var(--brand);letter-spacing:-.01em}
.logo-mark{height:36px;width:auto;display:block;flex-shrink:0}
.logo small{display:block;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:500;line-height:1;margin-top:2px}
.site-footer .logo{color:#fff}
.site-footer .logo-mark{filter:brightness(0) invert(1)}

.nav{display:flex;align-items:center;gap:.25rem}
.nav a{padding:.5rem .9rem;border-radius:8px;font-weight:500;font-size:var(--step-0);color:var(--ink-soft);transition:background .15s,color .15s}
.nav a:hover{background:var(--bg);color:var(--ink)}
.nav a[aria-current="page"]{color:var(--accent);font-weight:600}

.header-cta{display:flex;align-items:center;gap:.5rem}
.burger{display:none;width:40px;height:40px;border-radius:8px;align-items:center;justify-content:center;color:var(--ink)}
.burger svg{width:22px;height:22px}
.burger:hover{background:var(--bg)}

@media (max-width:940px){
  .nav{
    position:fixed;inset:68px 0 auto 0;
    background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;
    padding:1rem var(--gutter);gap:0;
    transform:translateY(-110%);transition:transform .25s ease;
    box-shadow:var(--shadow-lg);
  }
  .nav a{padding:.9rem .5rem;border-bottom:1px solid var(--line)}
  .nav a:last-child{border-bottom:0}
  .nav.is-open{transform:translateY(0)}
  .burger{display:flex}
  .header-cta .btn--tel{display:none}
}

/* --- Buttons --- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.35rem;border-radius:999px;font-weight:600;font-size:var(--step-0);
  transition:transform .15s,background .2s,color .2s,box-shadow .2s,border-color .2s;
  line-height:1;white-space:nowrap;cursor:pointer;
  border:1px solid transparent;
}
.btn--primary{background:var(--accent);color:#fff;box-shadow:0 6px 20px -6px rgba(11,61,145,.5)}
.btn--primary:hover{background:var(--accent-dark);transform:translateY(-1px)}
.btn--outline{border-color:var(--line);color:var(--ink);background:#fff}
.btn--outline:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn--ghost{color:var(--ink);padding-inline:.9rem}
.btn--ghost:hover{background:var(--bg)}
.btn--tel{color:var(--ink);font-weight:600;padding-inline:.75rem}
.btn--tel:hover{color:var(--accent)}
.btn--lg{padding:1.05rem 1.85rem;font-size:var(--step-1)}
.btn--block{display:flex;width:100%}
.btn svg{width:1em;height:1em}

/* --- Hero --- */
.hero{padding:clamp(3rem,6vw,5.5rem) 0 clamp(2rem,5vw,4rem);position:relative;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(800px 500px at 85% -10%,rgba(11,61,145,.09),transparent 60%),
    radial-gradient(600px 400px at -5% 110%,rgba(11,61,145,.06),transparent 60%);
}
.hero__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media (max-width:940px){.hero__grid{grid-template-columns:1fr}}
.hero h1{margin:.9rem 0 1.2rem}
.hero .lead{margin-bottom:1.75rem}
.hero__ctas{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2rem}
.hero__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding-top:1.75rem;border-top:1px solid var(--line)}
.hero__stat strong{display:block;font-family:var(--font-display);font-size:var(--step-3);font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}
.hero__stat span{display:block;margin-top:.4rem;font-size:var(--step--1);color:var(--muted)}

.hero__visual{
  aspect-ratio:4/5;border-radius:var(--radius-lg);position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg);background:var(--ink);
}
.hero__visual > img{width:100%;height:100%;object-fit:cover;display:block}
.hero__visual::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(11,15,20,.0) 30%,rgba(11,15,20,.55) 100%),
    linear-gradient(135deg,rgba(9,161,209,.1) 0%,transparent 50%);
}
.hero__badge{z-index:2}
.hero__badge{
  position:absolute;left:1.25rem;bottom:1.25rem;z-index:2;
  background:rgba(255,255,255,.96);backdrop-filter:blur(10px);
  padding:.9rem 1.1rem;border-radius:12px;display:flex;align-items:center;gap:.75rem;
  box-shadow:var(--shadow);max-width:calc(100% - 2.5rem);
}
.hero__badge svg{width:32px;height:32px;color:var(--accent);flex-shrink:0}
.hero__badge strong{display:block;font-size:.95rem;line-height:1.2}
.hero__badge span{display:block;font-size:.8rem;color:var(--muted)}

/* --- Trust strip --- */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding-block:1.5rem;background:#fff}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:center;text-align:center}
@media (max-width:700px){.trust__grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}
.trust__item{display:flex;align-items:center;justify-content:center;gap:.65rem;font-size:var(--step--1);color:var(--ink-soft);font-weight:500}
.trust__item svg{width:22px;height:22px;color:var(--accent);flex-shrink:0}

/* --- Bento services --- */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}
@media (max-width:940px){.bento{grid-template-columns:repeat(2,1fr)}}
.bento__card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.25rem,2.5vw,1.85rem);
  display:flex;flex-direction:column;gap:.85rem;min-height:220px;
  transition:transform .2s,box-shadow .2s,border-color .2s;position:relative;overflow:hidden;
}
.bento__card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow)}
.bento__card--feature{
  grid-column:span 3;min-height:280px;
  background:linear-gradient(135deg,var(--ink) 0%,#1A2C4D 100%);color:#fff;
}
.bento__card--feature h3,.bento__card--feature p{color:#fff}
.bento__card--feature p{color:rgba(255,255,255,.8)}
.bento__card--wide{grid-column:span 4}
.bento__card--mid{grid-column:span 2}
@media (max-width:940px){
  .bento__card--feature,.bento__card--wide,.bento__card--mid{grid-column:span 2}
}
.bento__icon{width:44px;height:44px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex-shrink:0}
.bento__card--feature .bento__icon{background:rgba(255,255,255,.12);color:#fff}
.bento__icon svg{width:22px;height:22px}
.bento__card h3{font-size:var(--step-1)}
.bento__card p{font-size:var(--step-0);color:var(--muted);margin-top:auto}
.bento__card--feature p{color:rgba(255,255,255,.75)}
.bento__link{color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:.35rem;margin-top:.25rem}
.bento__card--feature .bento__link{color:#fff}
.bento__link::after{content:"→";transition:transform .2s}
.bento__card:hover .bento__link::after{transform:translateX(4px)}

/* --- Process --- */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;counter-reset:step}
@media (max-width:960px){.process{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.process{grid-template-columns:1fr}}
.step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.25rem;
  position:relative;counter-increment:step;
}
.step::before{
  content:"0" counter(step);display:block;font-family:var(--font-display);
  font-size:var(--step-3);font-weight:700;color:var(--accent);line-height:1;margin-bottom:.75rem;
  letter-spacing:-.03em;
}
.step h4{margin-bottom:.4rem;font-size:var(--step-1)}
.step p{font-size:.92rem;color:var(--muted)}

/* --- Partners strip --- */
.partners{padding-block:2rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.partners__title{text-align:center;font-size:var(--step--1);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:1.5rem}
.partners__list{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(1.5rem,4vw,3rem)}
.partner{font-family:var(--font-display);font-size:var(--step-2);font-weight:700;color:var(--ink-soft);letter-spacing:-.02em;opacity:.55;transition:opacity .2s}
.partner:hover{opacity:1}
.partner--italic{font-style:italic;letter-spacing:-.03em}
.partner--condensed{font-stretch:condensed;letter-spacing:.03em;text-transform:uppercase;font-size:var(--step-1)}

/* --- Testimonial --- */
.testimonial{max-width:780px;margin-inline:auto;text-align:center}
.testimonial blockquote{
  font-family:var(--font-display);font-size:var(--step-3);line-height:1.25;
  font-weight:400;letter-spacing:-.02em;color:var(--ink);margin-bottom:1.5rem;
}
.testimonial blockquote::before{content:"«  "}
.testimonial blockquote::after{content:"  »"}
.testimonial cite{font-style:normal;color:var(--muted);font-size:var(--step-0);font-weight:500}
.testimonial cite strong{color:var(--ink);font-weight:600}
.stars{display:inline-flex;gap:2px;color:#F5A623;margin-bottom:1rem}
.stars svg{width:18px;height:18px;fill:currentColor}

/* --- Zone --- */
.zone{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
@media (max-width:860px){.zone{grid-template-columns:1fr}}
.zone__map{
  aspect-ratio:4/3;border-radius:var(--radius-lg);background:var(--ink);position:relative;overflow:hidden;
  background:
    linear-gradient(135deg,#0B0F14 0%,#1A2028 100%);
}
.zone__map::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.zone__pin{
  position:absolute;top:48%;left:32%;width:20px;height:20px;
  background:var(--accent);border-radius:50%;box-shadow:0 0 0 6px rgba(11,61,145,.3),0 0 0 14px rgba(11,61,145,.15);
}
.zone__pin::after{
  content:"Bussigny";position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);
  color:#fff;font-weight:600;font-size:.85rem;white-space:nowrap;
}
.zone__label{position:absolute;color:rgba(255,255,255,.55);font-size:.75rem;font-weight:500;letter-spacing:.05em}
.zone__cities{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.zone__city{
  padding:.45rem .9rem;border:1px solid var(--line);border-radius:999px;font-size:var(--step--1);
  color:var(--ink-soft);background:#fff;font-weight:500;transition:all .15s;
}
.zone__city:hover,.zone__city[aria-current="page"]{background:var(--accent);color:#fff;border-color:var(--accent)}

/* --- FAQ --- */
.faq{max-width:820px;margin-inline:auto}
.faq details{
  border-top:1px solid var(--line);padding:1.25rem 0;
}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{
  list-style:none;cursor:pointer;font-weight:600;font-size:var(--step-1);
  color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:1.5rem;font-weight:400;color:var(--accent);
  transition:transform .2s;flex-shrink:0;line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details > p{padding-top:1rem;color:var(--ink-soft);max-width:70ch}

/* --- CTA final --- */
.cta{
  background:var(--ink);color:#fff;border-radius:var(--radius-lg);
  padding:clamp(2rem,5vw,4rem) clamp(1.5rem,4vw,3rem);
  display:grid;grid-template-columns:1.2fr 1fr;gap:2rem;align-items:center;
}
@media (max-width:860px){.cta{grid-template-columns:1fr;text-align:center}}
.cta h2,.cta p{color:#fff}
.cta p{color:rgba(255,255,255,.75)}
.cta .btn--primary{background:#fff;color:var(--ink)}
.cta .btn--primary:hover{background:var(--accent);color:#fff}
.cta .btn--outline{color:#fff;border-color:rgba(255,255,255,.3);background:transparent}
.cta .btn--outline:hover{background:#fff;color:var(--ink);border-color:#fff}

/* --- Form --- */
.form{display:grid;gap:1rem;max-width:640px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:560px){.form__row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-weight:500;font-size:var(--step--1);color:var(--ink-soft)}
.field label abbr{color:var(--danger);text-decoration:none;margin-left:2px}
.field input,.field select,.field textarea{
  padding:.8rem 1rem;border:1px solid var(--line);border-radius:10px;background:#fff;
  font-size:var(--step-0);color:var(--ink);transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(11,61,145,.15);
}
.field textarea{min-height:130px;resize:vertical;font-family:inherit}
.field__check{flex-direction:row;align-items:flex-start;gap:.6rem}
.field__check input{width:18px;height:18px;margin-top:3px;accent-color:var(--accent)}
.field__check label{font-size:.9rem;color:var(--ink-soft);font-weight:400;line-height:1.5}
.field__hint{font-size:.8rem;color:var(--muted)}

/* --- Footer --- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7);padding-block:clamp(3rem,5vw,4rem) 2rem;font-size:.95rem}
.site-footer a{color:rgba(255,255,255,.7);transition:color .15s}
.site-footer a:hover{color:#fff}
.footer__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:clamp(1.5rem,3vw,3rem);margin-bottom:3rem}
@media (max-width:780px){.footer__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:460px){.footer__grid{grid-template-columns:1fr}}
.footer__brand{max-width:320px}
.footer__brand .logo{color:#fff;margin-bottom:.85rem}
.footer__brand .logo small{color:rgba(255,255,255,.55)}
.footer__brand p{color:rgba(255,255,255,.65);font-size:.92rem;line-height:1.65}
.footer__col h5{color:#fff;font-family:var(--font-display);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;margin-bottom:1rem}
.footer__col ul{display:flex;flex-direction:column;gap:.55rem}
.footer__col a{font-size:.93rem}
.footer__contact{font-style:normal;line-height:1.7}
.footer__contact a{display:inline-flex;align-items:center;gap:.4rem}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  font-size:.82rem;color:rgba(255,255,255,.55);
}
.footer__legal{display:flex;gap:1.25rem;flex-wrap:wrap}

/* --- Cookies banner --- */
.cookies{
  position:fixed;bottom:1rem;left:1rem;right:1rem;z-index:100;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.25rem;box-shadow:var(--shadow-lg);max-width:540px;
  display:none;flex-direction:column;gap:1rem;
}
.cookies.is-visible{display:flex;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookies h4{font-size:var(--step-1);margin-bottom:.3rem}
.cookies p{font-size:.88rem;color:var(--ink-soft);line-height:1.5}
.cookies p a{color:var(--accent);text-decoration:underline}
.cookies__actions{display:flex;gap:.6rem;flex-wrap:wrap}
.cookies__actions .btn{padding:.6rem 1rem;font-size:.88rem}

/* --- Page hero (inner pages) --- */
.page-hero{
  padding:clamp(3rem,6vw,5rem) 0 clamp(2rem,4vw,3rem);
  background:
    radial-gradient(600px 300px at 90% 0%,rgba(11,61,145,.08),transparent 60%),
    var(--bg);
}
.page-hero .eyebrow{margin-bottom:.75rem}
.page-hero h1{max-width:18ch}
.page-hero .lead{margin-top:1rem}
.breadcrumbs{display:flex;gap:.35rem;font-size:.85rem;color:var(--muted);margin-bottom:1rem;flex-wrap:wrap}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs [aria-current]{color:var(--ink);font-weight:500}
.breadcrumbs span{color:var(--line)}

/* --- Content blocks --- */
.prose{max-width:72ch}
.prose h2{margin-top:2.5rem;margin-bottom:1rem}
.prose h2:first-child{margin-top:0}
.prose h3{margin-top:2rem;margin-bottom:.6rem}
.prose p{margin-bottom:1.1rem;color:var(--ink-soft);font-size:var(--step-0)}
.prose ul,.prose ol{margin-bottom:1.1rem;padding-left:1.25rem}
.prose ul li,.prose ol li{list-style:disc;margin-bottom:.4rem;color:var(--ink-soft)}
.prose ol li{list-style:decimal}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose strong{color:var(--ink);font-weight:600}

.twocol{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
@media (max-width:860px){.twocol{grid-template-columns:1fr}}
.infocard{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.75rem;position:sticky;top:100px;
}
.infocard h3{font-size:var(--step-1);margin-bottom:1rem}
.infocard ul{display:flex;flex-direction:column;gap:.75rem}
.infocard li{display:flex;gap:.75rem;align-items:flex-start;font-size:.92rem;color:var(--ink-soft)}
.infocard svg{width:18px;height:18px;color:var(--accent);flex-shrink:0;margin-top:3px}

/* --- Services detail grid --- */
.srv-list{display:grid;gap:1.5rem}
.srv-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.75rem;display:grid;grid-template-columns:56px 1fr;gap:1.25rem;align-items:start;
}
@media (max-width:560px){.srv-item{grid-template-columns:1fr;gap:1rem}}
.srv-item__icon{width:56px;height:56px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}
.srv-item__icon svg{width:28px;height:28px}
.srv-item h3{font-size:var(--step-2);margin-bottom:.5rem}
.srv-item ul{margin-top:.75rem;padding-left:1.2rem}
.srv-item li{list-style:disc;margin-bottom:.25rem;color:var(--ink-soft);font-size:.93rem}

/* --- Utilities --- */
.center{text-align:center}
.mt-1{margin-top:.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}
.mt-4{margin-top:2rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.5rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.flex{display:flex}
.gap-1{gap:.5rem}
.gap-2{gap:1rem}
.wrap-header{max-width:820px;margin-inline:auto;text-align:center;margin-bottom:clamp(2rem,4vw,3.5rem)}
.wrap-header p{max-width:52ch;margin-inline:auto;margin-top:1rem}

/* --- Skip link --- */
.skip{position:absolute;left:-9999px;top:auto;z-index:200}
.skip:focus{left:1rem;top:1rem;background:var(--accent);color:#fff;padding:.75rem 1rem;border-radius:8px}

/* --- Reduced motion --- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
}

/* --- Print --- */
@media print{
  .site-header,.site-footer,.cookies,.topbar,.cta{display:none}
  body{background:#fff;color:#000}
}
