:root{
  --bg:#ffffff;
  --text:#000000;
  --muted: rgba(0,0,0,.65);
  --hairline: rgba(0,0,0,.12);
  --header-bg: rgba(255,255,255,.75);

  --maxw: 1100px;
  --radius: 18px;
}

/* Base */
*{ box-sizing:border-box; }

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: var(--bg);
  color: var(--text);
  line-height: 1.45;
}

a{ color: var(--text); text-decoration:none; }
a:hover{ text-decoration: underline; text-underline-offset: 4px; }

.container{
  width: min(var(--maxw), calc(100% - 48px));
  margin: 0 auto;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--header-bg);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--hairline);
}

/* Brand left, email right (no fixed height) */
.nav{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
}

.brand__name{
  font-size: clamp(22px, 2.2vw, 30px);
  letter-spacing: .18em;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1;
  white-space: nowrap;
}

.header-email{
  font-size: 18px;
  color: rgba(0,0,0,0.65);
  white-space: nowrap;
  
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
}
  
/* Mobile: stack nicely */
@media (max-width: 560px){
  .nav{
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 12px 0;
  }
}

/* HERO IMAGE */
.hero{
  position: relative;
  height: 28vh;    
  z-index: 0; 
  isolation: isolate;
  background: url("./hero.png") center / cover no-repeat;
  background-position: center;  
  display: flex;
  align-items: center;
  overflow: hidden; 
}

/* Fade layer */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index: 1;  /* IMPORTANT */
  background: linear-gradient(
    to right,
    rgba(255,255,255,0.88) 0%,
    rgba(255,255,255,0.75) 35%,
    rgba(255,255,255,0.00) 65%
  );
}

/*  .hero__content{ padding-left: 40px; } */ 

.hero .container{
  position: relative;
  z-index: 2;
}
.hero__content{
  position: relative;
  z-index: 2;
  max-width: 520px;
}

.hero__title{
  font-size: clamp(38px, 5vw, 40px);
  letter-spacing: -0.02em;
  margin: 0 0 8px;
}

.hero__tagline{
  margin: 0;
  font-size: 16px;
  color: rgba(0,0,0,.65);
}

/* Intro */
.intro{
  padding: 20px 0;
  border-bottom: 0px solid var(--hairline);
  background: #fff;
}

.intro__text{
  margin: 0;
  font-size: 20px;
  color: var(--muted);
}

/* Partners */
.section{
  padding: 20px 0 80px;
}

/* --- Bios --- */
.partners-grid{
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* bio | divider | bio */
  gap: 28px;
  align-items: start;
}

/* Each bio row: wide image + text block */
.bio{
  display: grid;
  grid-template-columns: 260px 1fr; /* wider image */
  gap: 22px;
  align-items: start;
}

.bio__media{
  width: 220px;
  aspect-ratio: 1 / 1;
  border-radius: 7px;
  overflow: hidden;

  /* background cityscape */
  background-image: url("./bio-background-grey.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  outline: 1px solid rgba(0,0,0,0.06);
  outline-offset: -1px;

  /* IMPORTANT: no depth */
  padding: 0;
  box-shadow: none;
  background-color: transparent;
}

.bio__media img{
  width: 100%;
  height: 100%;
  display: block;

  /* preserves the subject cleanly */
  object-fit: contain;
  object-position: 50% 80%;
}



/* Text stack */
.bio__text{
  padding-top: 6px;
}

.bio__stack{
  display: grid;
  gap: 3px;
}

.bio__name{
  margin: 0;
  font-size: 22px;
  letter-spacing: -0.01em;
}

.bio__meta{
  margin: 0;
  font-size: 16px;
  color: var(--muted);
  font-weight: 600;
}

.bio__meta--strong{
  color: var(--text);
  
}

/* Small horizontal grey bar */
.bio__rule{
  width: 55px;
  height: 1px;
  background: rgba(0,0,0,0.15);
  margin: 16px 0 14px;
}

/* Blurb */
.bio__blurb{
  margin: 0;
  font-size: 16px;
  color: var(--muted);
  max-width: 36ch;
}

/* Vertical divider between bios */
.bio-divider{
  width: 1px;
  height: 172px;                 /* controls how tall it is */
  background: rgba(0,0,0,0.05);
  margin-top: 28px;             /* aligns with name text */
  justify-self: center;
}
.bio-photo {
  width: 360px;
  aspect-ratio: 1 / 1;

  /* BACKGROUND IMAGE */
  background-image: url("./biobackground.jfif");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* “Seated” effect */
  padding: 16px;
  border-radius: 18px;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.18);
}

.bio-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 35%;
  border-radius: 12px;
  display: block;
}
/* Responsive: stack bios, remove vertical divider */
@media (max-width: 900px){
  .partners-grid{
    grid-template-columns: 1fr;
    gap: 26px;
  }

  .bio-divider{
    display: none;
  }

  .bio{
    grid-template-columns: 220px 1fr;
  }

  
  .bio__media{
    overflow: visible !important;
    align-self: start;
    }
}



@media (max-width: 560px){
  .bio__media{
    overflow: hidden;   /* keep the frame */
  }
}

/* Footer */
.footer{
  border-top: 1px solid var(--hairline);
  padding: 18px 0;
  background: rgba(255,255,255,0.9);
}

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

@media (max-width: 520px){
  .hero{
    height: 50vh;
  }

  .partner-card{
    grid-template-columns: 1fr;
  }

  .partner-card__media{
    justify-content:flex-start;
  }
}



.footer a:hover{
  text-decoration-thickness: 2px;
}