/* Claris2 visual system */

@font-face{
  font-family: "Literata";
  src: url("assets/fonts/literata-variable.woff2") format("woff2");
  font-style: normal;
  font-weight: 200 900;
  font-display: swap;
}

@font-face{
  font-family: "Apercu Pro";
  src: url("assets/fonts/apercu-regular-pro.woff2") format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face{
  font-family: "Apercu Pro";
  src: url("assets/fonts/apercu-medium-pro.woff2") format("woff2");
  font-style: normal;
  font-weight: 500;
  font-display: swap;
}

:root{
  color-scheme: dark;
  --ink: rgb(238,238,238);
  --rule: #cbc3b6;
  --maxw: 1120px;
  --padx: clamp(22px, 4vw, 56px);
}

*{ box-sizing: border-box; }
html, body{
  height: 100%;
  background: rgb(70,70,70);
}
body{
  margin: 0;
  color: var(--ink);
  background: rgb(70,70,70);
  font-family: "Literata", "Iowan Old Style", "Baskerville", "Times New Roman", Times, serif;
  line-height: 1.62;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-optical-sizing: auto;
}

a{
  color: inherit;
  text-decoration: none;
}

a:hover{
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

a:focus-visible{
  outline: 2px solid rgba(31,29,26,0.45);
  outline-offset: 3px;
}

.wrap{
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

header{
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid var(--rule);
  background: rgb(238,238,238);
  color: rgb(100,100,100);
  backdrop-filter: blur(8px);
}

.header-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 20px var(--padx);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

.brand{
  display: inline-flex;
  align-items: center;
}

.brand img{
  height: 30px;
  width: auto;
  display: block;
}

.nav{
  display: flex;
  gap: clamp(14px, 2vw, 30px);
  flex-wrap: wrap;
  font-family: "Apercu Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: inherit;
}

.nav a{
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
}

.nav a:hover,
.nav a:focus-visible{
  border-bottom-color: currentColor;
  text-decoration: none;
  color: inherit;
}

main{
  flex: 1;
}

.main-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: clamp(48px, 8vw, 100px) var(--padx) 56px;
}

.section{
  padding: clamp(44px, 7vw, 86px) 0;
  border-bottom: 1px solid var(--rule);
  scroll-margin-top: 120px;
}

.section:last-of-type{
  border-bottom: none;
  padding-bottom: 16px;
}

.hero{
  margin-bottom: clamp(28px, 5vw, 50px);
}

.section#services .hero{
  margin-bottom: 14px;
}

.section#contact .hero{
  margin-bottom: 14px;
}

.kicker,
.small{
  font-family: "Apercu Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400;
  color: inherit;
}

.kicker{
  margin: 0 0 14px;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

h1{
  margin: 0;
  font-size: clamp(40px, 7vw, 86px);
  font-family: "Apercu Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.012em;
}

h2{
  margin: 0 0 12px;
  font-size: clamp(27px, 3vw, 42px);
  font-family: "Apercu Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  line-height: 1.12;
}

h3{
  margin: 20px 0 10px;
  font-size: clamp(20px, 2.2vw, 30px);
  font-family: "Apercu Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
}

p,
.list{
  margin: 0 0 14px;
  font-size: clamp(18px, 1.65vw, 24px);
}

.lede{
  max-width: 68ch;
  color: inherit;
}

.block{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(26px, 3vw, 42px);
}

.card{
  padding-top: 6px;
}

.block .card + .card{
  border-left: 0;
  padding-left: 0;
}

.block .card:nth-child(even){
  border-left: 1px solid var(--rule);
  padding-left: clamp(20px, 2.2vw, 34px);
}

.contact-inline{
  max-width: 76ch;
}

.contact-inline-link{
  font-weight: 700;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

.contact-meta{
  font-size: 0.85em;
  line-height: 1.4;
}

.list{
  padding-left: 20px;
}

.small{
  font-size: 12px;
  letter-spacing: 0.05em;
}

.main-inner > .card{
  max-width: 76ch;
  padding-top: 0;
}

.main-inner > .card p,
.main-inner > .card li{
  font-size: clamp(17px, 1.2vw, 20px);
}

.legal-updated{
  margin-top: 14px;
  margin-bottom: 0;
}

.legal-doc h2{
  margin-top: 28px;
  margin-bottom: 8px;
  font-size: clamp(21px, 2.1vw, 30px);
  font-weight: 500;
  line-height: 1.2;
}

.legal-doc h2:first-child{
  margin-top: 0;
}

.legal-doc p{
  margin-bottom: 10px;
}

.legal-doc .legal-address{
  margin-bottom: 12px;
  line-height: 1.4;
}

.legal-doc code{
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 0.9em;
}

hr{
  border: 0;
  border-top: 1px solid var(--rule);
  margin: 24px 0;
}

footer{
  border-top: 1px solid var(--rule);
  background: rgb(238,238,238);
  color: rgb(100,100,100);
}

.footer-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 16px var(--padx) 22px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.footer-links{
  display: flex;
  gap: 16px;
  font-family: "Apercu Pro", "Avenir Next", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: inherit;
}

@media (max-width: 900px){
  .header-inner{
    align-items: flex-start;
    flex-direction: column;
  }

  .block{
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .card + .card{
    border-left: 0;
    border-top: 1px solid var(--rule);
    padding-left: 0;
    padding-top: 24px;
  }

  .block .card:nth-child(even){
    border-left: 0;
    padding-left: 0;
  }

  .footer-inner{
    flex-direction: column;
    gap: 10px;
  }
}
