/* ============================================================
   CVT (Global) — redesign stylesheet
   Direction: light, bright, trustworthy. Professional blue +
   warm coral accent. Schibsted Grotesk / Hanken Grotesk.
   ============================================================ */
:root{
  --blue:#1A4A7D;
  --blue-deep:#123A66;
  --blue-tint:#EAF1F9;
  --ink:#15243A;
  --accent:#F26B3A;
  --accent-deep:#D8521F;
  --accent-tint:#FFF0E9;
  --paper:#FFFFFF;
  --paper-2:#F6F9FC;
  --slate:#48566A;
  --slate-2:#74808F;
  --line:#E2E9F1;
  --line-2:#EDF1F6;
  --radius:16px;
  --radius-sm:11px;
  --maxw:1180px;
  --shadow:0 18px 40px -24px rgba(20,40,70,.28);
  --shadow-sm:0 8px 22px -16px rgba(20,40,70,.32);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Hanken Grotesk',system-ui,sans-serif;color:var(--ink);
  background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Schibsted Grotesk',sans-serif;line-height:1.1;letter-spacing:-.02em;margin:0;font-weight:700}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 26px}

/* eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:13px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--accent-deep);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent);border-radius:2px}
.eyebrow.on-dark{color:#FFB592}
.eyebrow.on-dark::before{background:#FFB592}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:15px;
  font-family:'Hanken Grotesk',sans-serif;padding:13px 24px;border-radius:999px;
  border:1.6px solid transparent;cursor:pointer;transition:transform .15s,background .2s,color .2s,border-color .2s;
}
.btn:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
.btn--accent{background:var(--accent);color:#fff}
.btn--accent:hover{background:var(--accent-deep);transform:translateY(-2px)}
.btn--blue{background:var(--blue);color:#fff}
.btn--blue:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn--outline{border-color:var(--blue);color:var(--blue)}
.btn--outline:hover{background:var(--blue);color:#fff;transform:translateY(-2px)}
.btn--light{border-color:rgba(255,255,255,.45);color:#fff}
.btn--light:hover{background:#fff;color:var(--blue);transform:translateY(-2px)}
.arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------------- Header ---------------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px}
.nav__logo img{height:54px;width:auto}
.nav__menu{display:flex;align-items:stretch;gap:6px;margin-left:auto;height:78px}
.nav__menu a{display:flex;align-items:center;height:100%;padding:0 16px;font-weight:600;font-size:17px;color:var(--slate);position:relative;border-radius:9px 9px 0 0;transition:color .2s,background .2s}
.nav__menu a:hover{color:var(--blue);background:var(--blue-tint)}
.nav__menu a.active{color:var(--blue);background:var(--blue-tint)}
.nav__menu a::after{content:"";position:absolute;left:12px;right:12px;bottom:0;height:3px;background:var(--accent);border-radius:3px 3px 0 0;transform:scaleX(0);transform-origin:center;transition:transform .22s}
.nav__menu a:hover::after,.nav__menu a.active::after{transform:scaleX(1)}
.nav__right{display:flex;align-items:center;gap:18px}
.nav__cta{gap:9px}
.nav__cta-num{font-weight:700;white-space:nowrap}
.nav__cta-sep{opacity:.55;font-weight:400;margin:0 -2px}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
@media(max-width:940px){
  .nav__menu{display:none}
  .nav__toggle{display:block}
  .nav__menu.open{display:flex;position:absolute;top:78px;left:0;right:0;height:auto;background:#fff;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 26px 22px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav__menu.open a{padding:13px 6px;width:100%;height:auto;border-radius:0;background:none;border-bottom:1px solid var(--line-2);font-size:18px}
  .nav__menu.open a::after{display:none}
}
@media(max-width:560px){
  .nav__logo img{height:44px}
  .nav__cta{padding:11px 16px;font-size:14px}
  .nav__cta-sep,.nav__cta-label{display:none}
}

/* ---------------- Hero ---------------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 500px at 85% -10%,var(--blue-tint),transparent 60%),
  linear-gradient(180deg,#FBFCFE 0%,#fff 100%)}
.hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(26,74,125,.06) 1px,transparent 1px);background-size:22px 22px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 70%);mask-image:linear-gradient(180deg,#000,transparent 70%);pointer-events:none}
.hero .container{position:relative;z-index:1;padding-top:74px;padding-bottom:78px}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(34px,5vw,58px);font-weight:800;letter-spacing:-.035em;max-width:14ch}
.hero h1 .u{background:linear-gradient(180deg,transparent 62%,#FFD9C7 62%);padding:0 2px}
.hero .lede{font-size:19px;color:var(--slate);max-width:520px;margin-top:22px}
.hero__cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px}
.hero__chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.chip{font-size:13.5px;font-weight:600;color:var(--blue);background:#fff;border:1px solid var(--line);padding:7px 14px;border-radius:999px;transition:border-color .2s,color .2s}
.chip:hover{border-color:var(--accent);color:var(--accent-deep)}

/* hero feedback card (signature: "unsolicited customer feedback") */
.feedback-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;box-shadow:var(--shadow);position:relative}
.feedback-card::before{content:"\201C";position:absolute;top:6px;left:22px;font-family:Georgia,serif;font-size:90px;color:var(--accent);opacity:.18;line-height:1}
.feedback-tag{display:inline-block;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-deep);background:var(--accent-tint);padding:5px 12px;border-radius:999px;margin-bottom:16px}
.feedback-quote{font-family:'Schibsted Grotesk';font-weight:500;font-size:18px;line-height:1.5;color:var(--ink);letter-spacing:-.005em;min-height:150px;transition:opacity .35s ease}
.feedback-body{transition:opacity .35s ease}
.feedback-card.fading .feedback-body{opacity:0}
.feedback-by{margin-top:16px;font-size:14px;color:var(--slate-2);font-weight:500}
.feedback-dots{display:flex;gap:7px;margin-top:18px;flex-wrap:wrap}
.feedback-dots span{width:7px;height:7px;border-radius:50%;background:var(--line);cursor:pointer;transition:width .25s,background .25s}
.feedback-dots span:hover{background:var(--mist)}
.feedback-dots span.on{background:var(--accent);width:20px;border-radius:999px}

/* ---------------- Sections ---------------- */
.section{padding:92px 0}
.section--tint{background:var(--paper-2)}
.section--blue{background:var(--blue);color:#fff}
.section--blue h2,.section--blue h3{color:#fff}
.section__head{max-width:680px;margin-bottom:46px}
.section__head h2{font-size:clamp(27px,3.4vw,40px);margin-top:16px;font-weight:700}
.section__head p{color:var(--slate);font-size:18px;margin-top:14px}
.section--blue .section__head p{color:#cfe0f0}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* trust strip */
.trust{background:var(--ink)}
.trust .container{display:flex;flex-direction:column;align-items:center;gap:26px;text-align:center;padding-top:50px;padding-bottom:50px}
.trust__label{font-size:15px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#aebfd1}
.trust__logos{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.trust__logos img{width:262px;height:150px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 12px 28px -18px rgba(0,0,0,.5);transition:transform .2s,box-shadow .2s}
.trust__logos img:hover{transform:translateY(-3px);box-shadow:0 18px 34px -18px rgba(0,0,0,.55)}
@media(max-width:560px){.trust__logos img{width:100%;max-width:300px;height:132px;padding:18px}.trust__logos{gap:16px}}
.trust__links{display:flex;gap:8px;flex-wrap:wrap}

/* trio (our story / approach / technology) */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.trio__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;transition:transform .2s,box-shadow .2s,border-color .2s}
.trio__item:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blue-tint)}
.trio__ic{width:50px;height:50px;border-radius:13px;background:var(--blue-tint);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.trio__item h3{font-size:21px;margin-bottom:12px;color:var(--blue)}
.trio__item p{color:var(--slate);font-size:15.5px}
.trio__item p+p{margin-top:12px}

/* services */
.svc-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:46px}
.svc-tab{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 26px 24px;border-top:4px solid var(--accent)}
.svc-tab h3{font-size:20px;color:var(--ink)}
.svc-tab span{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-deep)}
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.detail{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.detail h4{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:16px}
.detail p{color:var(--slate);font-size:15px}
.detail p+p{margin-top:12px}
.ticklist{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.ticklist li{position:relative;padding-left:28px;font-size:15px;color:var(--slate)}
.ticklist li::before{content:"";position:absolute;left:0;top:8px;width:16px;height:16px;border-radius:50%;background:var(--accent-tint);border:1.5px solid var(--accent)}
.ticklist li::after{content:"";position:absolute;left:5px;top:11px;width:5px;height:8px;border-right:2px solid var(--accent-deep);border-bottom:2px solid var(--accent-deep);transform:rotate(40deg)}

/* feature rows (genesys 01/02/03) */
.frows{display:grid;gap:18px}
.frow{display:grid;grid-template-columns:90px 1fr;gap:24px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 32px;transition:transform .2s,box-shadow .2s}
.frow:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.frow__n{font-family:'Schibsted Grotesk';font-weight:800;font-size:40px;color:var(--blue-tint);-webkit-text-stroke:1px var(--blue);letter-spacing:-.04em}
.frow h3{font-size:21px;margin-bottom:8px}
.frow p{color:var(--slate);font-size:15.5px;max-width:62ch}

/* split (image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split--narrow{grid-template-columns:.9fr 1.1fr}
.split img{border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-sm);width:100%}
.split h2{font-size:clamp(25px,3vw,36px);margin:14px 0 16px}
.split p{color:var(--slate);font-size:16.5px}
.split p+p{margin-top:14px}
.logo-row{display:flex;align-items:center;gap:26px;flex-wrap:wrap;margin-bottom:8px}
.logo-row img{height:54px;width:auto;border:0;box-shadow:none}

/* cases */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s}
.case:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.case__img{aspect-ratio:16/10;overflow:hidden;background:var(--blue-tint)}
.case__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.case:hover .case__img img{transform:scale(1.05)}
.case__body{padding:24px;display:flex;flex-direction:column;flex:1}
.case__tag{font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:10px}
.case h3{font-size:19px;margin-bottom:10px}
.case p{color:var(--slate);font-size:14.5px;flex:1}
.case__more{margin-top:16px;font-weight:700;font-size:14px;color:var(--blue);display:inline-flex;gap:7px}
.case:hover .case__more{color:var(--accent-deep)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px}
.contact-card h3{font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:18px}
.contact-big{font-family:'Schibsted Grotesk';font-weight:800;font-size:clamp(28px,4vw,40px);color:var(--ink);letter-spacing:-.02em}
.contact-sub{font-size:16px;color:var(--slate);margin-top:6px}
.contact-line{display:flex;gap:12px;align-items:baseline;padding:12px 0;border-top:1px solid var(--line-2)}
.contact-line:first-of-type{border-top:0}
.contact-line .k{font-weight:700;color:var(--ink);min-width:96px}
.contact-line .v{color:var(--slate)}
.contact-link{color:var(--blue);font-weight:600}
.contact-link:hover{color:var(--accent-deep)}
.office{display:grid;gap:4px}
.office strong{font-family:'Schibsted Grotesk';font-size:17px}
.offices{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}

/* cta band */
.cta-band{background:linear-gradient(120deg,var(--blue-deep),var(--blue));border-radius:24px;padding:62px 54px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;right:-60px;top:-60px;width:260px;height:260px;border-radius:50%;background:rgba(242,107,58,.22);filter:blur(10px)}
.cta-band h2{font-size:clamp(26px,3.4vw,40px);max-width:18ch;margin:0 auto;position:relative}
.cta-band p{color:#cfe0f0;font-size:18px;max-width:54ch;margin:16px auto 30px;position:relative}
.cta-band__row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* footer */
.footer{background:var(--ink);color:#aeb9c6;padding:62px 0 28px}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;margin-bottom:42px}
.footer__logo{height:42px;width:auto;margin-bottom:18px;background:#fff;border-radius:11px;padding:9px 13px;opacity:1}
.footer__brand p{font-size:14.5px;color:#90a0b0;max-width:280px}
.footer__tel{display:inline-block;margin-top:16px;font-family:'Schibsted Grotesk';font-weight:700;font-size:21px;color:#fff;letter-spacing:.01em;transition:color .2s}
.footer__tel:hover{color:var(--accent)}
.footer h4{font-family:'Schibsted Grotesk';font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:#fff;margin-bottom:16px;font-weight:700}
.footer a{display:block;font-size:14.5px;color:#aeb9c6;margin-bottom:10px;transition:color .2s}
.footer a:hover{color:#fff}
.footer__badges{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:22px}
.footer__badges img{width:152px;height:90px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:#7e8c9b}
.footer__bottom a{display:inline;color:#7e8c9b;margin:0}
.footer__bottom a:hover{color:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------------- Subpages (resources / legal) ---------------- */
.subhero{background:radial-gradient(900px 380px at 82% -20%,var(--blue-tint),transparent 60%),linear-gradient(180deg,#FBFCFE,#fff);border-bottom:1px solid var(--line)}
.subhero .container{padding-top:56px;padding-bottom:50px}
.breadcrumb{font-size:13.5px;color:var(--slate-2);margin-bottom:16px}
.breadcrumb a{color:var(--blue);font-weight:600}
.breadcrumb a:hover{color:var(--accent-deep)}
.subhero h1{font-size:clamp(29px,4.2vw,46px);font-weight:800;letter-spacing:-.03em;max-width:20ch}
.subhero p{color:var(--slate);font-size:18px;max-width:62ch;margin-top:16px}

.res-group{margin-bottom:44px}
.res-group:last-child{margin-bottom:0}
.res-group__title{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.res-group__title h2{font-size:23px}
.res-group__title .bar{width:30px;height:3px;border-radius:3px;background:var(--accent)}
.res-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.res-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;transition:transform .2s,box-shadow .2s,border-color .2s}
.res-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--blue-tint)}
.res-card h3{font-size:18px;color:var(--blue);margin-bottom:8px}
.res-card p{color:var(--slate);font-size:15px;margin-bottom:16px}
.res-links{display:flex;flex-wrap:wrap;gap:10px}
.res-links a{font-size:13.5px;font-weight:600;color:var(--blue);border:1px solid var(--line);border-radius:999px;padding:8px 15px;transition:border-color .2s,color .2s,background .2s}
.res-links a:hover{border-color:var(--accent);color:var(--accent-deep);background:var(--accent-tint)}

.alert{background:var(--accent-tint);border:1px solid var(--accent);border-radius:14px;padding:18px 22px;margin:0 0 30px;color:var(--ink);font-weight:500;display:flex;gap:14px;align-items:flex-start}
.alert svg{flex:0 0 auto;margin-top:2px}
.alert strong{color:var(--accent-deep)}
.callout-list{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.callout-list li{background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:10px;padding:16px 20px;font-size:15.5px;color:var(--slate)}
.callout-list li strong{color:var(--ink)}

.legal{max-width:840px;margin:0 auto}
.legal .meta{font-size:14px;color:var(--slate-2);margin-bottom:28px;font-weight:600;letter-spacing:.02em}
.legal p{color:var(--slate);font-size:16px;margin-bottom:18px}
.legal h2{font-size:21px;margin:36px 0 14px}
.legal h3{font-size:17px;margin:26px 0 10px;color:var(--blue)}
.legal ol,.legal ul{color:var(--slate);font-size:16px;padding-left:22px;margin-bottom:18px}
.legal li{margin-bottom:12px}
.legal a{color:var(--blue);font-weight:600;word-break:break-word}
.legal a:hover{color:var(--accent-deep)}

/* ---------------- Video block ---------------- */
.video-block{position:relative;max-width:940px;margin:0 auto;aspect-ratio:16/9;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);cursor:pointer;background:#0b1b2e}
.video-block .poster{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.video-block:hover .poster{transform:scale(1.04)}
.video-block::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,27,46,.2),rgba(11,27,46,.55));transition:background .3s;pointer-events:none}
.video-block:hover::after{background:linear-gradient(180deg,rgba(11,27,46,.15),rgba(11,27,46,.42))}
.video-play{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}
.video-play .pbtn{width:84px;height:84px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px -8px rgba(242,107,58,.65);transition:transform .2s,background .2s}
.video-block:hover .pbtn{transform:scale(1.08);background:var(--accent-deep)}
.video-play .vlabel{font-family:'Schibsted Grotesk';font-weight:700;font-size:18px;color:#fff;letter-spacing:-.01em;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.video-block iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:3}

/* inline video embeds */
.video-embed{position:relative;width:100%;aspect-ratio:16/9;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#000}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:1100px;margin:0 auto}
.video-figure{margin:0}
.video-figure figcaption{margin-top:14px;font-size:14.5px;color:var(--slate);font-weight:500;text-align:center}
@media(max-width:760px){.video-grid{grid-template-columns:1fr}}

/* maps */
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.map-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.map-embed{position:relative;width:100%;aspect-ratio:4/3;background:var(--blue-tint)}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.map-cap{padding:20px 22px;display:flex;align-items:flex-start;gap:12px}
.map-cap h3{font-family:'Schibsted Grotesk';font-size:19px;margin-bottom:4px}
.map-cap p{font-size:16px;color:var(--slate)}
.map-pin{flex:0 0 auto;color:var(--accent-deep);margin-top:2px}
@media(max-width:760px){.map-grid{grid-template-columns:1fr}}

/* responsive */
@media(max-width:940px){
  .hero__grid{grid-template-columns:1fr;gap:38px}
  .trio,.detail-grid,.svc-tabs,.cases,.offices{grid-template-columns:1fr}
  .res-grid{grid-template-columns:1fr}
  .split,.contact-grid{grid-template-columns:1fr;gap:30px}
  .footer__grid{grid-template-columns:1fr 1fr}
  .frow{grid-template-columns:1fr;gap:8px}
  .trust__logos{margin-left:0}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .section{padding:62px 0}
  .cta-band{padding:44px 24px}
  .footer__grid{grid-template-columns:1fr}
  .offices{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* Contact details rendered as images (anti-scrape) */
.contact-img{height:23px;width:auto;display:inline-block;vertical-align:middle}
.contact-img--tel{height:25px}
.email-row{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.email-row .contact-img{height:32px}
.email-esc{display:inline-flex;align-items:center;gap:8px}
.muted{color:var(--slate-2);font-size:14px}
