/* ============================================
   Fulcore — founders page
   only delta styles; relies on styles.css tokens
   ============================================ */

/* compact hero for founders */
.founders-hero{
  padding-top: clamp(40px, 6vw, 80px);
  padding-bottom: clamp(60px, 7vw, 96px);
  position: relative;
  overflow: hidden;
}
.founders-hero::before{
  content:""; position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 50% 0%, #000 30%, transparent 80%);
  pointer-events: none;
}
.founders-hero__grid{
  position: relative;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: clamp(28px, 4vw, 64px);
  align-items: end;
}
@media (max-width: 980px){
  .founders-hero__grid{ grid-template-columns: 1fr }
}
.founders-hero .h1{ margin-bottom: 22px }
.founders-hero__sub{
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.5;
  color: var(--ink-2);
  max-width: 60ch;
  margin: 0 0 30px;
}

.founders-hero__meta{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  border-top: 1px solid var(--line);
  padding-top: 20px;
  max-width: 560px;
}
.founders-hero__meta li{
  display: flex; flex-direction: column; gap: 6px;
}
.founders-hero__meta .num{
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--lime);
  letter-spacing: 0.08em;
}
.founders-hero__meta .lbl{
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.3;
}

/* stack of avatars on the right */
.founders-hero__stack{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 280px;
}
.fan{
  position: relative;
  width: 320px; height: 280px;
}
.fan__card{
  position: absolute;
  width: 150px; height: 200px;
  border: 1px solid var(--line-2);
  border-radius: 14px;
  background: var(--surface);
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0,0,0,0.4);
}
.fan__card:nth-child(1){ left: 0;   top: 30px; transform: rotate(-6deg) }
.fan__card:nth-child(2){ left: 85px;  top: 5px;  transform: rotate(0deg);  z-index: 2; border-color: var(--lime-deep) }
.fan__card:nth-child(3){ left: 170px; top: 30px; transform: rotate(6deg) }
.fan__card .ph{ inset: 0; position: absolute }
.fan__card .ph__lbl{
  position: absolute; left: 10px; bottom: 10px; right: 10px;
  font-family: var(--ff-mono);
  font-size: 9px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ============================================
   FOUNDERS GRID
   ============================================ */
.section--founders{
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.founders-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 1020px){ .founders-grid{ grid-template-columns: 1fr 1fr } }
@media (max-width: 720px){ .founders-grid{ grid-template-columns: 1fr } }

.fcard{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 22px;
  display: flex; flex-direction: column;
  gap: 22px;
  transition: border-color .2s ease, transform .2s ease;
}
.fcard:hover{ border-color: var(--lime-deep); transform: translateY(-2px) }

.fcard__photo{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 10px;
  background: var(--bg);
  overflow: hidden;
  border: 1px solid var(--line-2);
}
.ph{
  position: absolute; inset: 0;
  background-color: var(--surface-2);
  background-image:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,0.025) 0 2px,
      transparent 2px 14px
    );
}
.ph__crosshair{
  position: absolute; inset: 0;
  background:
    linear-gradient(to right, transparent calc(50% - 0.5px), var(--line-2) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px)) center / 1px 18% no-repeat,
    linear-gradient(to bottom, transparent calc(50% - 0.5px), var(--line-2) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px)) center / 18% 1px no-repeat;
  opacity: 0.7;
}
.ph__corners::before,
.ph__corners::after,
.ph__corners > i::before,
.ph__corners > i::after{
  content:""; position: absolute;
  width: 14px; height: 14px;
  border: 1px solid var(--line-2);
}
.ph__corners::before{ left: 10px;  top: 10px;    border-right: 0; border-bottom: 0 }
.ph__corners::after { right: 10px; top: 10px;    border-left: 0;  border-bottom: 0 }
.ph__corners > i::before{ left: 10px;  bottom: 10px; border-right: 0; border-top: 0 }
.ph__corners > i::after { right: 10px; bottom: 10px; border-left: 0;  border-top: 0 }

.ph__tag{
  position: absolute; left: 12px; top: 12px;
  font-family: var(--ff-mono);
  font-size: 9.5px;
  letter-spacing: 0.08em;
  color: var(--ink-mute);
  text-transform: uppercase;
  background: rgba(12,13,12,0.6);
  padding: 4px 8px;
  border-radius: 4px;
  border: 1px solid var(--line);
}
.ph__name{
  position: absolute; left: 14px; bottom: 14px; right: 14px;
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.05em;
  color: var(--ink-2);
  text-transform: uppercase;
}
.ph__name b{ color: var(--ink) }

.fcard__head{
  display: flex; flex-direction: column; gap: 10px;
}
.fcard__name{
  font-size: clamp(22px, 1.8vw, 26px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0;
}
.fcard__role{
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--lime);
}

.fcard__bio{
  display: flex; flex-direction: column; gap: 8px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.fcard__bio-label{
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.fcard__bio ul{
  display: flex; flex-direction: column; gap: 8px;
}
.fcard__bio li{
  display: flex; gap: 10px;
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.4;
}
.fcard__bio li::before{
  content:""; flex: none;
  width: 8px; height: 1px; background: var(--ink-faint);
  margin-top: 10px;
}
.fcard__bio li b{ color: var(--ink); font-weight: 600 }

.fcard__own{
  padding-top: 18px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 10px;
}
.fcard__own-label{
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.fcard__chips{
  display: flex; flex-wrap: wrap; gap: 6px;
}
.fcard__chips span{
  font-family: var(--ff-mono);
  font-size: 10.5px;
  letter-spacing: 0.02em;
  text-transform: none;
  padding: 5px 9px;
  border: 1px solid var(--line-2);
  border-radius: 999px;
  color: var(--ink-2);
  background: var(--bg);
}


/* ============================================
   TRACK — joint timeline
   ============================================ */
.section--track{ background: var(--bg) }

.track{
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 880px){ .track{ grid-template-columns: 1fr } }

.track__rail{
  position: absolute;
  left: 0; right: 0;
  top: 64px;
  height: 1px;
  background: var(--line);
  z-index: 0;
}
@media (max-width: 880px){ .track__rail{ display: none } }

.tk{
  position: relative;
  z-index: 1;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  background: var(--surface);
  display: flex; flex-direction: column; gap: 14px;
}
.tk__dot{
  position: relative;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--ink-faint);
  margin-bottom: 8px;
}
.tk--now .tk__dot{
  border-color: var(--lime);
  box-shadow: 0 0 0 5px oklch(0.88 0.18 122 / 0.16);
}
.tk--now .tk__dot::after{
  content:""; position: absolute; inset: 1px;
  border-radius: 50%; background: var(--lime);
  animation: pulse 2.2s infinite;
}
.tk--now{ border-color: var(--lime-deep) }

.tk__head{
  display: flex; align-items: baseline; gap: 12px;
  flex-wrap: wrap;
}
.tk__when{
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.tk--now .tk__when{ color: var(--lime) }
.tk__name{
  font-size: clamp(22px, 1.7vw, 28px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0;
}
.tk__desc{
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.45;
  margin: 0;
}
.tk__roles{
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: var(--ff-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}
.tk__roles li{
  display: flex; gap: 8px;
}
.tk__roles li::before{
  content:""; width: 4px; height: 4px; border-radius: 50%;
  background: var(--ink-faint); margin-top: 7px; flex: none;
}
.tk--now .tk__roles li::before{ background: var(--lime) }
.tk__roles li span{ color: var(--ink-2) }

/* ============================================
   PRINCIPLES — what you get directly from founders
   ============================================ */
.section--principles{
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.principles{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
@media (max-width: 1020px){ .principles{ grid-template-columns: 1fr 1fr } }
@media (max-width: 560px){ .principles{ grid-template-columns: 1fr } }

.pr{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  background: var(--surface);
  display: flex; flex-direction: column; gap: 14px;
  min-height: 220px;
}
.pr__num{
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--lime);
  letter-spacing: 0.08em;
}
.pr__title{
  font-size: clamp(18px, 1.4vw, 22px);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0;
}
.pr__desc{
  font-size: 14px;
  line-height: 1.45;
  color: var(--ink-2);
  margin: 0;
  margin-top: auto;
}

/* ============================================
   MANIFESTO
   ============================================ */
.section--manifesto{ background: var(--bg) }

.manifesto{
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(28px, 5vw, 56px);
  background: var(--surface);
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: start;
  position: relative;
  overflow: hidden;
}
@media (max-width: 880px){ .manifesto{ grid-template-columns: 1fr } }

.manifesto::before{
  content:""; position: absolute;
  top: 0; right: 0; width: 360px; height: 360px;
  background: radial-gradient(ellipse, oklch(0.88 0.18 122 / 0.10), transparent 65%);
  filter: blur(20px);
  pointer-events: none;
}
.manifesto__head{
  position: relative;
  z-index: 1;
}
.manifesto__head .qmark{
  font-family: var(--ff-mono);
  font-size: 64px;
  line-height: 1;
  color: var(--lime);
  display: block;
  margin-bottom: 18px;
}
.manifesto__head .h3{
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.2;
}
.manifesto__body{
  position: relative;
  z-index: 1;
  display: flex; flex-direction: column; gap: 18px;
}
.manifesto__body p{
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
}
.manifesto__body p em{
  color: var(--lime);
  font-style: normal;
}
.manifesto__sign{
  display: flex; gap: 18px; align-items: center;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  flex-wrap: wrap;
}
.manifesto__sign b{
  color: var(--ink);
  font-weight: 600;
}

/* ============================================
   CTA strip — link back to main contact
   ============================================ */
.section--cta{
  background: var(--bg-2);
  border-top: 1px solid var(--line);
  padding: clamp(48px, 6vw, 80px) 0;
}
.cta-strip{
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 32px;
  align-items: center;
}
@media (max-width: 880px){ .cta-strip{ grid-template-columns: 1fr } }
.cta-strip__copy h2{
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 14px;
}
.cta-strip__copy p{
  margin: 0;
  color: var(--ink-2);
  max-width: 50ch;
  font-size: 16px;
  line-height: 1.5;
}
.cta-strip__actions{
  display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end;
}
@media (max-width: 880px){ .cta-strip__actions{ justify-content: flex-start } }

/* nav: highlight active link */
.nav__links a.is-active{ color: var(--ink) }
.nav__links a.is-active::after{ transform: scaleX(1) }
