
:root{
  /* Atmosphere */
  --pine:#1A3D4D;

  /* Clarity */
  --silk:#F7F4EE;
  --ink:#0f1a20;

  /* Human warmth */
  --sand:#D6A864;

  /* Layout */
  --maxw:1180px;

  /* Type */
  --fs-body:19px;
  --fs-sub-heading:23px;
  --fs-heading:31px;
  --fs-statement:41px;
}

/* Reset */
*{box-sizing:border-box}
html,body{height:100%;margin:0}

/* Base */
body{
  font-family:'Mulish', ui-sans-serif, system-ui, sans-serif;
  font-weight:300;
  font-size:var(--fs-body);
  line-height:1.55;
  color:var(--silk);
  background:var(--pine);
}

/* Header */
.header{
  position:fixed;
  inset:0 0 auto 0;
  height:94px;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 28px;
  letter-spacing:.04em;
}

.brand a{
  font-size:var(--fs-heading);
  font-weight:400;
  letter-spacing:.06em;
  color:var(--silk);
  text-decoration:none;
}

.brand{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.brand-meta{
  margin:2px 0 0;

  font-size:17px;
  line-height:1.25;
  letter-spacing:.04em;

  color:rgba(247,244,238,.62);
}

/* Toggle */
.menu-toggle{
  position:fixed;
  top:28px;
  right:28px;
  width:42px;
  height:42px;
  z-index:1200;
  background:none;
  border:0;
  padding:0;
  cursor:pointer;
}

.menu-toggle .line{
  position:absolute;
  top:50%;
  left:50%;
  width:32px;
  height:1px;
  background:var(--silk);
  transform-origin:center;
  transition:transform .35s ease;
}

.menu-toggle .horizontal{
  transform:translate(-50%,-50%) rotate(0deg);
}

.menu-toggle .vertical{
  transform:translate(-50%,-50%) rotate(90deg);
}

.menu-toggle.is-open .horizontal{
  transform:translate(-50%,-50%) rotate(45deg);
}

.menu-toggle.is-open .vertical{
  transform:translate(-50%,-50%) rotate(-45deg);
}

/* Menu */
.menu{
  position:fixed;
  inset:0;
  z-index:1100;

  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-end;

  padding:48px;
  background:var(--pine);

  opacity:0;
  pointer-events:none;
  transition:opacity .3s ease;
}

.menu.is-open{
  opacity:1;
  pointer-events:auto;
}

.menu a{
  margin:8px 0;
  color:var(--silk);
  text-decoration:none;
  font-size:clamp(28px,5vw,64px);
  font-weight:300;
  transition:color .2s ease, transform .2s ease;
}

.menu a:hover{
  color:var(--sand);
  transform:translateX(-6px);
}

/* Hero */
.hero{
  position:relative;
  min-height:100vh;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:var(--pine);
  color:var(--silk);
}

.hero video,
.hero img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.28;
}

.hero-tint{
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(26,61,77,.12),
    rgba(26,61,77,.28)
  );
}

.hero .inner{
  position:relative;
  z-index:2;
  width:100%;
  max-width:760px;
  padding:0 24px;
  text-align:left;
}

/* Statements */
.statement{
  max-width:32ch;
  font-size:var(--fs-statement);
  opacity:0;
  transform:translateY(10px);
  animation:fadeUp 1s ease forwards;
}

.hero-arrow {
  text-align: center;
  font-size: var(--fs-statement);
  margin: 40px 0 0;
  opacity: 0;
  transform: translateY(10px);
  animation: fadeUp 1s ease forwards;
}

.fade-up
{ 
  opacity:0; 
  transform:translateY(10px); 
  animation:fadeUp 1s 
  ease forwards; 
}

.delay-1{animation-delay:.3s}
.delay-2{animation-delay:1.1s}
.delay-3{animation-delay:1.9s}
.delay-4{animation-delay:2.7s}
.delay-5{animation-delay:3.5s}
.delay-5{animation-delay:4.3s}

@keyframes fadeUp{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* CTA */
.cta{
  display:inline-block;
  margin-top:36px;
  padding:10px 14px;

  border:1px solid rgba(247,244,238,.28);
  border-radius:2px;

  color:var(--silk);
  background:transparent;

  text-decoration:none;
  font-weight:400;
  letter-spacing:.04em;

  transition:all .2s ease;
}

.cta:hover{
  background:var(--sand);
  border-color:var(--sand);
  color:var(--pine);
}

/* Sections */
.section{
  padding:84px 24px;
}

.wrap{
  max-width:var(--maxw);
  margin:0 auto;
}

/* Typography */
h1{
  margin:0 0 12px;
  font-size:clamp(42px,7vw,96px);
  line-height:1.05;
  letter-spacing:-.02em;
  font-weight:300;
}

h2{
  margin:0 0 24px;
  font-size:var(--fs-heading);
  line-height:1.1;
  letter-spacing:-.01em;
  font-weight:400;
}

h3{
  margin:18px 0 6px;
  font-size:var(--fs-sub-heading);
  line-height:1.2;
  font-weight:400;
}

.copy-xl{
  max-width:840px;
  font-size:var(--fs-body);
}

.mute{
  opacity:.6;
}

/* Grids */
.grid-3{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(3,1fr);
}

.grid-2{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(2,1fr);
}

/* Cards */
.card{
  padding:20px;
  border:1px solid rgba(247,244,238,.08);
  border-radius:18px;
  background:rgba(247,244,238,.04);
}

/* Media */
img{
  max-width:100%;
  height:auto;
  display:block;
}

.figure{
  width:120px;
  margin-bottom:18px;
  overflow:hidden;
  border-radius:2px;
}

.figure img{
  width:100%;
}

/* Testimonials */
.testimonial-card{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:24px;
  align-items:start;

  margin-bottom:24px;
  padding:24px 0;

  border-top:1px solid rgba(247,244,238,.08);
}

.testimonial-image{
  width:120px;
  overflow:hidden;
  border-radius:2px;
  opacity:.92;
}

.testimonial-image img{
  width:100%;
  filter:grayscale(100%);
}

.testimonial-text{
  color:var(--silk);
}

.testimonial-text p{
  margin-top:0;
}

/* Ratio media */
.ratio{
  position:relative;
  width:100%;
  padding-top:56.25%;
  overflow:hidden;
}

.ratio > *{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Footer */

.footer{
  position:fixed;
  right:57px;
  bottom:47px;

  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;

  color:rgba(247,244,238,.72);

  font-size:var(--fs-body);
  letter-spacing:.04em;

  text-align:right;
  line-height:1.5;
}

.footer a{
  color:var(--silk);
  text-decoration:none;

  opacity:.72;
  transition:opacity .2s ease;
}

.footer a:hover{
  opacity:1;
}


.footer p{
  margin:0;
}

/* Responsive */
@media (max-width:1000px){
  .grid-3{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width:680px){
  .grid-3,
  .grid-2,
  .testimonial-card{
    grid-template-columns:1fr;
  }

  .hero{
    min-height:100svh;
  }

  .statement{
    font-size:var(--fs-sub-heading);
    max-width:24ch;
  }

  .menu{
    align-items:flex-start;
    padding:32px;
  }

  .testimonial-image{
    width:96px;
  }

  .footer{
    font-size:14px;
  }
}

