:root{
  --ink:#111827;
  --muted:#506070;
  --paper:#f6f2ff;
  --panel:#ffffff;
  --line:#111827;
  --deep:#15122a;
  --violet:#7b2cff;
  --mint:#00cfa6;
  --coral:#ff5a3d;
  --sun:#ffd43b;
  --blue:#228be6;
  --rose:#ff4f8b;
  --aqua:#dffcf7;
  --lilac:#efe4ff;
  --peach:#ffe9dd;
  --shadow:10px 12px 0 rgba(17,24,39,.12);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.58;
}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.site-header{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:16px clamp(18px,5vw,72px);
  background:var(--sun);
  border-bottom:5px solid var(--deep);
  position:sticky;
  top:0;
  z-index:10;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:23px;
  font-weight:900;
  color:var(--deep);
}
.brand span{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:16px;
  background:var(--violet);
  color:#fff;
  border:3px solid var(--deep);
  box-shadow:5px 5px 0 var(--mint);
}
.main-nav{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.main-nav a{
  padding:10px 14px;
  border:2px solid var(--deep);
  border-radius:999px;
  background:#fff;
  color:var(--deep);
  font-weight:900;
}
.main-nav a:hover{
  background:var(--mint);
}
main{overflow:hidden}
.kicker{
  width:max-content;
  max-width:100%;
  padding:7px 11px;
  border:2px solid var(--deep);
  border-radius:999px;
  background:var(--mint);
  color:var(--deep);
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:.12em;
  font-weight:900;
  margin:0 0 18px;
}
h1{
  font-size:clamp(38px,5.7vw,74px);
  line-height:1;
  margin:0 0 18px;
  letter-spacing:0;
}
h2{
  font-size:clamp(23px,2.7vw,34px);
  line-height:1.12;
  margin:0 0 12px;
  letter-spacing:0;
}
p{font-size:17px;color:var(--muted);margin:0 0 14px}
.hero.image-first,
.about-ribbon,
.service-columns,
.contact-strip{
  display:grid;
  gap:24px;
  padding:clamp(38px,7vw,86px) clamp(18px,5vw,72px) 36px;
  align-items:stretch;
}
.hero.image-first{
  grid-template-columns:minmax(320px,.96fr) minmax(0,1.04fr);
  background:var(--lilac);
}
.hero.image-first figure,
.about-ribbon figure,
.contact-strip figure,
.image-pair figure,
.timeline-layout figure,
.contact-layout figure,
.band figure{
  margin:0;
  border:4px solid var(--deep);
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.hero.image-first figure{min-height:520px}
.hero-copy,
.text-block,
.board-title,
.contact-box,
.simple-page section{
  background:#fff;
  border:4px solid var(--deep);
  border-radius:30px;
  padding:clamp(24px,4vw,46px);
  box-shadow:var(--shadow);
}
.hero-copy{
  align-self:center;
  background:var(--peach);
}
.band{
  display:grid;
  grid-template-columns:.82fr 1.08fr .82fr;
  gap:24px;
  padding:34px clamp(18px,5vw,72px);
  background:var(--aqua);
  align-items:stretch;
}
.band .text-block{
  background:#fff;
  border-color:var(--violet);
}
.band figure{min-height:360px}
.feature-list,
.service-rows{
  display:grid;
  gap:18px;
}
.feature-list article,
.service-rows article,
.detail-strip div{
  display:grid;
  grid-template-columns:60px minmax(0,1fr);
  grid-template-areas:"num title" "num copy";
  column-gap:18px;
  row-gap:8px;
  align-items:start;
  background:#fff;
  border:4px solid var(--deep);
  border-radius:26px;
  padding:22px;
  box-shadow:7px 8px 0 rgba(17,24,39,.11);
}
.feature-list article:nth-child(1),
.service-rows article:nth-child(1),
.detail-strip div:nth-child(1){background:var(--peach)}
.feature-list article:nth-child(2),
.service-rows article:nth-child(2),
.detail-strip div:nth-child(2){background:var(--aqua)}
.feature-list article:nth-child(3),
.service-rows article:nth-child(3),
.detail-strip div:nth-child(3){background:var(--lilac)}
.feature-list span,
.service-rows span,
.detail-strip span{
  grid-area:num;
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:16px;
  border:3px solid var(--deep);
  background:var(--coral);
  color:#fff;
  font-weight:900;
}
.feature-list article:nth-child(2) span,
.service-rows article:nth-child(2) span,
.detail-strip div:nth-child(2) span{background:var(--blue)}
.feature-list article:nth-child(3) span,
.service-rows article:nth-child(3) span,
.detail-strip div:nth-child(3) span{background:var(--violet)}
.feature-list h2,
.service-rows h2{grid-area:title;font-size:clamp(22px,2.2vw,30px);margin:0;color:var(--ink)}
.feature-list p,
.service-rows p{grid-area:copy;max-width:68ch;margin:0;color:var(--muted)}
.detail-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  padding:34px clamp(18px,5vw,72px) 76px;
}
.detail-strip strong{
  grid-area:title;
  display:block;
  font-size:20px;
  margin:0;
  color:var(--ink);
}
.detail-strip p{grid-area:copy;margin:0}
.about-ribbon{
  grid-template-columns:.92fr 1.08fr;
  background:var(--peach);
}
.about-ribbon figure{min-height:500px}
.about-ribbon .hero-copy{
  background:#fff;
  border-color:var(--rose);
}
.timeline-layout{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:24px;
  padding:34px clamp(18px,5vw,72px);
  background:var(--aqua);
  align-items:stretch;
}
.timeline-layout figure{min-height:440px}
.service-columns{
  grid-template-columns:.82fr 1.18fr;
  background:var(--lilac);
}
.service-columns .board-title{
  background:var(--sun);
}
.image-pair{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:24px;
  padding:34px clamp(18px,5vw,72px);
  background:var(--peach);
}
.image-pair figure{min-height:380px}
.contact-strip{
  grid-template-columns:.86fr 1.14fr;
  background:var(--aqua);
}
.contact-strip figure{min-height:420px}
.contact-strip .hero-copy{
  background:var(--sun);
}
.contact-layout{
  display:grid;
  grid-template-columns:.82fr 1.08fr .78fr;
  gap:24px;
  padding:34px clamp(18px,5vw,72px);
  background:var(--lilac);
  align-items:stretch;
}
.contact-box{
  background:var(--peach);
}
.contact-layout figure{min-height:360px}
form{
  display:grid;
  gap:12px;
  background:#fff;
  border:4px solid var(--deep);
  border-radius:28px;
  padding:24px;
  box-shadow:var(--shadow);
}
label{
  display:grid;
  gap:6px;
  color:var(--deep);
  font-weight:900;
}
input,
textarea{
  width:100%;
  border:3px solid var(--deep);
  border-radius:14px;
  padding:13px 14px;
  font:inherit;
  background:#fff;
}
textarea{min-height:128px;resize:vertical}
button{
  border:3px solid var(--deep);
  border-radius:999px;
  padding:14px 20px;
  background:var(--mint);
  color:var(--deep);
  font-weight:900;
  justify-self:start;
  cursor:pointer;
  box-shadow:5px 5px 0 var(--violet);
}
.simple-page{
  padding:clamp(44px,8vw,96px) clamp(18px,5vw,72px);
  min-height:58vh;
  background:var(--aqua);
}
.simple-page section{
  max-width:900px;
  background:#fff;
}
.site-footer{
  display:flex;
  justify-content:space-between;
  gap:20px;
  padding:30px clamp(18px,5vw,72px);
  background:var(--deep);
  color:#fff;
  border-top:8px solid var(--sun);
}
.site-footer p,
.site-footer a{color:rgba(255,255,255,.82)}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
@media (max-width:900px){
  .site-header{align-items:flex-start;flex-direction:column}
  .main-nav{justify-content:flex-start}
  .hero.image-first,
  .band,
  .about-ribbon,
  .timeline-layout,
  .service-columns,
  .image-pair,
  .contact-strip,
  .contact-layout{grid-template-columns:1fr}
  .detail-strip{grid-template-columns:1fr}
  .hero.image-first figure,
  .about-ribbon figure,
  .contact-strip figure{min-height:310px}
  h1{font-size:42px}
}
@media (max-width:560px){
  .hero.image-first,
  .band,
  .about-ribbon,
  .timeline-layout,
  .service-columns,
  .image-pair,
  .contact-strip,
  .contact-layout,
  .detail-strip{padding-left:16px;padding-right:16px}
  .feature-list article,
  .service-rows article,
  .detail-strip div{grid-template-columns:1fr;grid-template-areas:"num" "title" "copy"}
  h1{font-size:36px}
}