/* ===== Design tokens ===== */
:root{
  --navy-900:#151A22;
  --navy-800:#1B222D;
  --navy-700:#16283F;
  --navy-600:#1E3A5F;
  --navy-500:#2A4A70;
  --navy-help:#1B2E48;
  --cream:#FAF8F4;
  --tint:#F1EEE7;
  --amber:#C9803B;
  --amber-light:#D6975E;
  /* Darker amber for text on light backgrounds — #C9803B fails WCAG AA (~3.2:1)
     for small text on cream/white; this passes (~5.7:1). Keep --amber for
     decorative fills and for text sitting on the dark navy sections. */
  --amber-ink:#8F551F;
  --ink:#151A22;
  --ink-soft:#3A4250;
  --grey:#5B6270;
  /* Darkened from #8A8375 (~3.8:1, fails AA) to meet 4.5:1 on white/tint. */
  --grey-light:#726B5C;
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-body:'Manrope',system-ui,sans-serif;
  --max-width:1440px;
  --gutter:clamp(20px,5vw,64px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream);
  font-family:var(--font-body);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4,p,ul,ol,li,figure,blockquote,form{margin:0;padding:0}
ul,ol{list-style:none}
a{color:inherit}
img{max-width:100%;display:block}
input,textarea,button{font-family:var(--font-body)}
button{cursor:pointer}

.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--amber);color:var(--ink);
  padding:12px 20px;z-index:1000;font-weight:700;border-radius:0 0 8px 0;
}
.skip-link:focus{left:0}

:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

.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;
}

/* ===== Scroll progress ===== */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;background:rgba(21,26,34,.08);z-index:999}
.scroll-progress__bar{height:100%;background:var(--amber);width:0%;transition:width .08s linear}

.page{width:100%;max-width:var(--max-width);margin:0 auto;background:var(--cream);color:var(--ink);overflow:hidden}

/* Default eyebrow sits on light backgrounds, so it needs the darker amber-ink
   for AA contrast; sections on dark navy backgrounds override back to --amber
   below, since that already has enough contrast against navy. */
.eyebrow{font:700 12px var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--amber-ink);margin-bottom:8px}
.section--dark .eyebrow,.help .eyebrow{color:var(--amber)}

.section{padding:clamp(64px,7vw,100px) var(--gutter)}
.section--dark{background:var(--navy-900)}
.section--tint{background:var(--tint)}
.section__title{font:700 clamp(24px,2.8vw,38px)/1.2 var(--font-display);color:var(--ink);max-width:680px;margin-bottom:36px}
.section__title--tight{margin-bottom:0}
.section__intro{font:600 clamp(16px,1.6vw,19px)/1.5 var(--font-display);color:var(--grey);font-style:italic;max-width:640px;margin-bottom:32px}
.section__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:36px}
.section__head--pad{padding:0 var(--gutter);margin-bottom:32px}

/* ===== Hero ===== */
.hero{position:relative}
.hero__band{
  position:relative;height:clamp(180px,20vw,260px);overflow:hidden;
  background:linear-gradient(125deg,var(--navy-700) 0%,var(--navy-600) 55%,var(--navy-500) 100%);
}
/* Optional real banner (see HTML comment above): comes first in the markup
   so — with everything else left at its default stacking order — it paints
   behind the texture, glow, and labels automatically. */
.hero__band-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__band-texture{
  position:absolute;inset:0;
  background:repeating-linear-gradient(115deg,rgba(255,255,255,.05) 0 2px,transparent 2px 30px);
}
.hero__band-glow{
  position:absolute;right:-40px;top:-60px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,128,59,.28),transparent 70%);
}
.hero__band-labels{
  position:absolute;inset:0;display:flex;justify-content:space-between;align-items:flex-start;
  padding:clamp(20px,3vw,36px) var(--gutter);
}
.hero__band-labels span{
  font:700 12px var(--font-display);letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);
}

.hero__card{
  position:relative;margin:clamp(-56px,-6vw,-72px) var(--gutter) 0;background:#fff;border-radius:14px;
  box-shadow:0 24px 60px -12px rgba(21,26,34,.25);padding:clamp(24px,3.2vw,40px) clamp(24px,3.6vw,44px);
  display:flex;gap:clamp(20px,3vw,36px);align-items:center;flex-wrap:wrap;justify-content:space-between;z-index:2;
}
/* Groups the photo + name/subhead so they never grow apart from each other —
   any leftover width on wide screens becomes a single gap before hero__stats
   (via justify-content:space-between above) instead of empty space getting
   swallowed inside the text column. */
.hero__person{display:flex;flex-wrap:wrap;gap:clamp(20px,3vw,36px);align-items:center;flex:0 1 640px;min-width:280px}
.hero__avatar{
  position:relative;width:clamp(96px,11vw,132px);aspect-ratio:1;border-radius:50%;flex:none;
  overflow:hidden;background:repeating-linear-gradient(45deg,var(--navy-500) 0 10px,var(--navy-600) 10px 20px);
  border:4px solid var(--cream);box-shadow:0 0 0 3px rgba(30,58,95,.15);
  display:flex;align-items:center;justify-content:center;text-align:center;
}
/* Absolute + inset:0 (rather than width/height:100% on a flex child) is the
   reliable way to make a photo fill a circular crop — percentage heights on
   flex children are inconsistently honored across browsers. */
.hero__avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;border-radius:50%}
.hero__avatar span{font:600 10px/1.4 ui-monospace,monospace;color:rgba(255,255,255,.85)}
.hero__intro{flex:1 1 320px;min-width:260px}
.hero__intro h1{font:700 clamp(32px,4.4vw,52px)/1.02 var(--font-display);color:var(--ink);letter-spacing:-.01em}
.hero__subhead{margin-top:12px;font:600 clamp(14.5px,1.5vw,17px)/1.5;color:var(--ink-soft);max-width:560px}
.hero__stats{flex:0 0 auto;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;min-width:220px}
.hero__years{background:var(--navy-900);color:#fff;padding:12px 18px;border-radius:10px;text-align:center;min-width:96px}
.hero__years-num{display:block;font:700 22px var(--font-display);color:var(--amber)}
.hero__years-label{display:block;font:700 9.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:2px}
.hero__sells{background:var(--tint);padding:10px 16px;border-radius:10px;min-width:190px}
.hero__sells-title{display:block;font:700 9px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);margin-bottom:6px}
.hero__sells ul{display:flex;flex-direction:column;gap:4px}
.hero__sells li{display:flex;align-items:center;gap:7px;font:700 11.5px var(--font-display);color:var(--ink)}
.hero__sells li::before{content:'';width:7px;height:7px;border-radius:2px;background:var(--navy-600);flex:none}

/* ===== Bio ===== */
.bio{max-width:900px;margin-left:auto;margin-right:auto}
.bio__text{font:500 clamp(19px,2vw,25px)/1.6 var(--font-display);color:var(--ink)}

/* ===== Achievements / carousel ===== */
.achievements{padding-bottom:clamp(72px,8vw,110px)}
.achievements h2{font:700 clamp(26px,3vw,38px)/1.15 var(--font-display);color:#fff;max-width:640px}
.carousel-controls{display:flex;gap:10px;flex:none}
.carousel-btn{
  width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(255,255,255,.3);background:transparent;
  font:700 16px var(--font-display);color:#fff;
}
.carousel-btn--primary{border-color:var(--amber);background:var(--amber);color:var(--navy-900)}
.carousel-btn--outline{border-color:var(--ink);background:#fff;color:var(--ink)}
.carousel-btn--dark{border-color:var(--ink);background:var(--ink);color:#fff}

.carousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 4px 14px;scrollbar-width:none}
.carousel::-webkit-scrollbar{display:none}
.carousel--testimonials{padding:4px var(--gutter) 14px}

/* When every card fits without scrolling, let them share the row evenly instead of showing a rail */
.carousel.carousel--fits{
  overflow-x:visible;scroll-snap-type:none;padding:4px 0 14px;
}
.carousel.carousel--fits .stat-card{flex:1 1 200px;max-width:250px}
.carousel.carousel--fits .testimonial-card{flex:1 1 280px;max-width:380px}
.carousel-controls[hidden]{display:none}

.stat-card{
  scroll-snap-align:start;flex:0 0 clamp(190px,22vw,235px);background:var(--navy-800);border-radius:14px;padding:24px 22px;
}
.stat-card--r1{transform:rotate(-1deg)}
.stat-card--r2{transform:rotate(.8deg)}
.stat-card--r3{transform:rotate(-.6deg)}
.stat-card--r4{transform:rotate(1deg)}
.stat-card--r5{transform:rotate(-.9deg)}
.stat-number{margin-top:16px;font:700 34px var(--font-display);color:#fff}
.stat-desc{margin-top:10px;font:500 13px/1.55;color:rgba(255,255,255,.65)}
.stat-icon{display:block;width:38px;height:38px}
.stat-icon--ring{border-radius:50%;border:3px solid var(--amber);position:relative}
.stat-icon--ring::after{content:'';width:12px;height:12px;background:var(--amber);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.stat-icon--clock{border-radius:50%;border:3px solid var(--amber);position:relative}
.stat-icon--clock::after{content:'';position:absolute;top:50%;left:50%;width:2px;height:12px;background:var(--amber);transform-origin:bottom center;transform:translate(-50%,-100%) rotate(35deg)}
.stat-icon--bars{display:flex;align-items:flex-end;gap:4px;height:38px;background:none}
.stat-icon--bars .bar{width:8px;background:var(--amber);border-radius:2px;display:block}
.stat-icon--bars .bar--1{height:40%}
.stat-icon--bars .bar--2{height:70%}
.stat-icon--bars .bar--3{height:100%}
.stat-icon--diamond{width:26px;height:26px;background:var(--amber);transform:rotate(45deg);border-radius:3px}
.stat-icon--arrow{font:700 30px var(--font-display);color:var(--amber);line-height:1;height:auto}

/* ===== Expertise ===== */
.expertise__steps{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.expertise__line{position:absolute;left:6%;right:6%;top:22px;height:2px;background:repeating-linear-gradient(90deg,rgba(30,58,95,.25) 0 8px,transparent 8px 14px);z-index:0}
.expertise__step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;min-width:150px}
.expertise__icon{width:44px;height:44px;border-radius:50%;background:#fff;border:2px solid var(--navy-600);display:flex;align-items:center;justify-content:center}
.expertise__icon--filled{background:var(--amber);border-color:var(--amber)}
.expertise__step h3{margin-top:16px;font:700 18px var(--font-display);color:var(--navy-600)}
.expertise__step:nth-child(4) h3{color:var(--ink)}
.expertise__tag{margin-top:3px;font:700 11px;color:var(--amber-ink)}
.expertise__step p:last-child{margin-top:10px;font:500 13px/1.5;color:var(--ink-soft)}
.icon-target{width:38px;height:38px;border-radius:50%;border:3px solid var(--navy-600);position:relative;display:block}
.icon-target::after{content:'';width:12px;height:12px;background:var(--navy-600);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.icon-bars{display:flex;align-items:flex-end;justify-content:center;gap:3px;padding:9px 0 8px;width:100%;height:100%}
.icon-bars .bar{width:5px;background:var(--navy-600);border-radius:1px;display:block}
.icon-bars .bar--1{height:8px}
.icon-bars .bar--2{height:14px}
.icon-bars .bar--3{height:20px}
.icon-doc{width:22px;height:16px;border:2.5px solid var(--navy-600);border-radius:4px;display:block}
.icon-flag{position:relative;width:16px;height:18px;display:block}
.icon-flag::before{content:'';position:absolute;left:0;top:0;width:2px;height:100%;background:var(--navy-900);border-radius:1px}
.icon-flag::after{content:'';position:absolute;left:3px;top:1px;width:12px;height:10px;background:var(--navy-900);clip-path:polygon(0 0,100% 50%,0 100%)}
.icon-check{width:18px;height:12px;border-left:3px solid var(--navy-600);border-bottom:3px solid var(--navy-600);transform:rotate(-45deg) translate(1px,-2px);display:block}

/* ===== Industries ===== */
.industries__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.industry-card{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden}
/* Optional real photo (see HTML comment above the grid): sits behind the
   gradient/label, in front of the striped CSS pattern. */
.industry-card__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.industry-card::before{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(21,26,34,.78),rgba(21,26,34,.15));z-index:2}
.industry-card--media{background:repeating-linear-gradient(35deg,var(--navy-600) 0 8px,#254568 8px 16px)}
.industry-card--academics{background:repeating-linear-gradient(-35deg,var(--amber) 0 8px,var(--amber-light) 8px 16px)}
.industry-card--government{background:repeating-linear-gradient(35deg,var(--ink-soft) 0 8px,#4A5262 8px 16px)}
.industry-card--lifesciences{background:repeating-linear-gradient(-35deg,var(--navy-600) 0 8px,var(--navy-500) 8px 16px)}
.industry-card--nonprofits{background:repeating-linear-gradient(35deg,var(--amber) 0 8px,#BE7434 8px 16px)}
.industry-card--fmcg{background:repeating-linear-gradient(-35deg,var(--ink-soft) 0 8px,#2D333F 8px 16px)}
.industry-card__badge{
  position:absolute;top:14px;left:14px;width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;font:700 15px var(--font-display);color:#fff;z-index:3;
}
.industry-card__label{position:absolute;bottom:14px;left:14px;font:700 15px var(--font-display);color:#fff;z-index:3}

/* ===== What I've Sold ===== */
.sold__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.sold-card{padding:28px;border-radius:14px;background:var(--navy-900)}
.sold-card h3{margin-top:18px;font:700 17px var(--font-display);color:#fff}
.sold-card p{margin-top:8px;font:500 14px/1.6;color:rgba(255,255,255,.65)}
.sold-icon{width:46px;height:46px;border-radius:10px;background:var(--amber);display:flex;align-items:center;justify-content:center}
.icon-grid{display:grid;grid-template-columns:repeat(2,7px);grid-template-rows:repeat(2,7px);gap:3px}
.icon-grid::before,.icon-grid::after{content:'';background:var(--navy-900);border-radius:2px}
.icon-lines{display:flex;flex-direction:column;gap:4px;width:20px}
.icon-lines::before,.icon-lines::after{content:'';height:3px;background:var(--navy-900);border-radius:2px;display:block}
.icon-lines::before{width:100%}
.icon-lines::after{width:70%}
.icon-people{position:relative;width:26px;height:20px}
.icon-people::before,.icon-people::after{content:'';position:absolute;bottom:0;width:11px;height:11px;border-radius:50%;background:var(--navy-900)}
.icon-people::before{left:0}
.icon-people::after{right:0}

/* ===== Experience ===== */
.experience__logos{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:48px;justify-content:center}
.experience__logos li{
  flex:0 1 clamp(150px,22%,200px);background:#fff;border-radius:10px;padding:16px 14px;
  box-shadow:0 4px 14px rgba(21,26,34,.06);display:flex;flex-direction:column;align-items:flex-start;
}
.experience__mark{
  position:relative;overflow:hidden;width:34px;height:34px;border-radius:8px;background:var(--navy-600);color:#fff;
  display:flex;align-items:center;justify-content:center;font:700 15px var(--font-display);
}
/* Optional real logo (see HTML comment above the list): sits on top of and
   fully covers the letter mark once uncommented — no need to remove anything. */
.experience__logo-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#fff;padding:3px}
.experience__name{margin-top:10px;font:700 13px var(--font-display);color:var(--ink)}
.experience__role{margin-top:2px;font:600 11px;color:var(--grey)}
.experience__years{margin-top:6px;font:700 10.5px;color:var(--amber-ink)}

.experience__summary{
  display:flex;gap:clamp(24px,4vw,56px);flex-wrap:wrap;align-items:flex-start;
  border-top:2px solid rgba(21,26,34,.1);padding-top:36px;
  max-width:1100px;margin:0 auto;
}
.experience__figure{
  flex:0 0 auto;font:700 clamp(60px,7vw,96px)/1 var(--font-display);color:var(--navy-600);
  display:flex;flex-direction:column;align-items:center;
}
.experience__figure span{font:700 18px var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--amber-ink);margin-top:8px}
.experience__copy{flex:1 1 480px;min-width:280px;max-width:820px}
.experience__copy p{font:500 15.5px/1.75;color:var(--ink-soft)}
.pill-list{margin-top:20px;display:flex;flex-wrap:wrap;gap:9px}
.pill{padding:7px 14px;background:#fff;border-radius:999px;font:700 11.5px var(--font-display);color:var(--navy-600)}
.pill--dark{background:var(--navy-800);color:#fff}

/* ===== Testimonials ===== */
.testimonials{padding:clamp(64px,7vw,100px) 0}
.testimonial-card{
  scroll-snap-align:start;flex:0 0 clamp(280px,32vw,380px);background:var(--tint);padding:28px;border-radius:14px;
  border-left:4px solid var(--navy-600);
}
.testimonial-card blockquote{font:500 14px/1.65;color:var(--ink)}
.testimonial-card figcaption{margin-top:16px;font:700 13px var(--font-display);color:var(--navy-600)}
.testimonial-card figcaption span{font-weight:500;color:var(--grey-light)}
.testimonial-card--placeholder{
  background:#fff;border:1.5px dashed rgba(21,26,34,.18);border-left:1.5px dashed rgba(21,26,34,.18);
  display:flex;align-items:center;justify-content:center;
}
.testimonial-card--placeholder span{font:600 13px ui-monospace,monospace;color:var(--grey-light);text-align:center}

/* ===== Certifications ===== */
.credentials__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:56px}
.education-list{display:flex;flex-direction:column;gap:14px}
.education-list li{font:600 14.5px/1.4 var(--font-display);color:#fff}
.education-list li span{display:block;font:500 13px var(--font-body);color:rgba(255,255,255,.55);margin-top:2px}

/* ===== How I Can Help ===== */
.help{position:relative;padding:clamp(64px,7vw,110px) var(--gutter);background:linear-gradient(160deg,var(--navy-700) 0%,var(--navy-600) 100%);overflow:hidden}
.help__texture{position:absolute;inset:0;background:repeating-linear-gradient(115deg,rgba(255,255,255,.04) 0 2px,transparent 2px 34px)}
.help__intro{position:relative;text-align:center;max-width:720px;margin:0 auto 56px}
.help__intro h2{font:700 clamp(28px,3.4vw,44px)/1.15 var(--font-display);color:#fff}
.help__sub{margin-top:14px;font:500 15px/1.6;color:rgba(255,255,255,.7)}
.help__grid{position:relative;display:flex;align-items:stretch;gap:20px;flex-wrap:wrap;justify-content:center;max-width:1180px;margin:0 auto}
.help-card{
  flex:0 1 clamp(230px,30%,300px);background:var(--navy-help);border-radius:18px;padding:32px 28px;
  display:flex;flex-direction:column;min-height:280px;
}
.help-card--accent{background:var(--amber)}
.help-card__ring{
  width:54px;height:54px;border-radius:50%;
  background:conic-gradient(var(--amber) 0% var(--pct,20%), rgba(255,255,255,.14) var(--pct,20%) 100%);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;flex:none;
}
.help-card__ring--full{background:conic-gradient(var(--navy-900) 0% 100%, var(--navy-900) 0)}
.help-card__step{width:42px;height:42px;border-radius:50%;background:var(--navy-help);display:flex;align-items:center;justify-content:center;font:700 13px var(--font-display);color:#fff}
.help-card--accent .help-card__step{background:var(--amber);color:var(--ink)}
.help-card__label{font:700 11px var(--font-display);color:var(--amber);letter-spacing:.06em}
.help-card--accent .help-card__label{color:var(--ink)}
.help-card h3{margin-top:8px;font:700 16px var(--font-display);color:#fff}
.help-card--accent h3{color:var(--ink)}
.help-card p{margin-top:10px;font:500 13px/1.6;color:rgba(255,255,255,.7)}
.help-card--accent p{color:rgba(21,26,34,.8)}

/* ===== Contact ===== */
.contact{background:var(--cream)}
.contact__wrap{display:flex;flex-wrap:wrap;gap:48px;justify-content:space-between;max-width:960px;margin:0 auto}
.contact__info{flex:1 1 320px;max-width:460px}
.contact__info h2{font:700 clamp(28px,3.2vw,40px)/1.15 var(--font-display);color:var(--ink)}
.contact__info>p{margin-top:16px;font:500 15px/1.6;color:var(--grey)}
.contact__links{margin-top:28px;display:flex;flex-direction:column;gap:12px;max-width:280px}
.contact__link{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:10px;text-decoration:none;font:700 14px var(--font-display)}
.contact__link--dark{background:var(--navy-900);color:#fff}
.contact__link--blue{background:var(--navy-600);color:#fff}
.contact__link--outline{background:#fff;border:1.5px solid rgba(21,26,34,.15);color:var(--ink)}
.contact__link-icon{
  width:30px;height:30px;border-radius:50%;background:var(--amber);flex:none;display:flex;
  align-items:center;justify-content:center;font:700 13px var(--font-display);color:var(--ink);
}
.contact__link-icon--light{background:#fff;color:var(--navy-600)}
.contact__link-icon--tint{background:var(--tint);color:var(--ink);font-size:15px}

.contact__form{flex:1 1 320px;max-width:420px;display:flex;flex-direction:column;gap:14px}
.contact__form-title{margin-bottom:4px;font:700 20px var(--font-display);color:var(--ink)}
.contact__form label{display:flex;flex-direction:column;gap:6px;font:600 12px var(--font-display);color:var(--grey)}
.contact__form input,.contact__form textarea{
  padding:12px 14px;background:#fff;border:1px solid rgba(21,26,34,.15);border-radius:8px;color:var(--ink);
  font:500 14px var(--font-body);width:100%;
}
.contact__form textarea{resize:vertical}
.contact__form button{margin-top:6px;padding:14px 20px;background:var(--amber);border:none;border-radius:8px;color:var(--ink);font:700 14px var(--font-display)}
.contact__form button:disabled{opacity:.6;cursor:not-allowed}
.hp-field{position:absolute;left:-9999px}
.form-status{font:600 13px var(--font-body);min-height:1.2em}
.form-status--ok{color:#2e7d32}
.form-status--err{color:#c62828}

/* ===== Motion & responsive ===== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .carousel{scroll-behavior:auto}
}

@media (max-width: 860px){
  .expertise__steps{grid-template-columns:repeat(2,1fr);row-gap:32px}
  .expertise__line{display:none}
  .credentials__grid{grid-template-columns:1fr;gap:32px}
}

@media (max-width: 600px){
  .hero__stats{justify-content:flex-start}
  .section__head{align-items:flex-start}
}
