/* ============================================================
   ABOUT PAGE
   ============================================================ */
.founder { padding-top: clamp(20px, 4vh, 50px); }
.founder__grid { display: grid; grid-template-columns: 0.82fr 1.18fr; gap: clamp(36px, 6vw, 84px); align-items: center; }
@media (max-width: 920px){ .founder__grid { grid-template-columns: 1fr; gap: 40px; } }
.founder__portrait { position: relative; aspect-ratio: 4/5; border: 1px solid var(--line); overflow: hidden; background: var(--ink); }
.founder__portrait .founder__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.founder__portrait::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, transparent 58%, rgba(10,10,10,0.42)); }
.founder__portrait .ph-stripes { position: absolute; inset: 0; }
.founder__portrait .ph-label { position: absolute; bottom: 16px; left: 18px; right: 18px; font-family: var(--sans); font-size: 11px; letter-spacing: 0.16em; color: var(--text-faint); }
.founder__frame { position: absolute; inset: 14px; border: 1px solid var(--line); pointer-events: none; z-index: 2; }
.founder__name { font-family: var(--display); font-size: clamp(40px, 5vw, 64px); color: var(--gold-light); line-height: 0.9; margin: 6px 0 4px; }
.founder__role { font-family: var(--heading); font-size: 13px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 26px; }
.founder__bio p { color: var(--text); margin-bottom: 18px; }
.founder__bio p:first-of-type { font-size: 19px; color: var(--cream); }

/* timeline */
.timeline { background: linear-gradient(180deg, rgba(20,16,8,0.0), rgba(20,16,8,0.35)); }
.timeline__head { text-align: center; margin-bottom: 60px; }
.tl-years { display: flex; justify-content: space-between; position: relative; max-width: 760px; margin: 0 auto 56px; }
.tl-years::before { content: ""; position: absolute; left: 0; right: 0; top: 11px; height: 1px; background: var(--line); }
.tl-years::after { content: ""; position: absolute; left: 0; top: 11px; height: 1px; background: var(--gold-grad); width: var(--progress, 0%); transition: width .6s var(--ease); box-shadow: 0 0 12px rgba(212,175,55,0.6); }
.tl-year { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 16px; background: none; border: 0; color: var(--text-dim); transition: color .35s; }
.tl-year__dot { width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--line); background: var(--black); display: grid; place-items: center; transition: all .4s var(--ease); }
.tl-year__dot::after { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--text-faint); transition: all .4s var(--ease); }
.tl-year__lbl { font-family: var(--display); font-size: 26px; letter-spacing: 0.04em; }
.tl-year:hover { color: var(--text); }
.tl-year.active { color: var(--gold); }
.tl-year.active .tl-year__dot { border-color: var(--gold); box-shadow: 0 0 18px rgba(212,175,55,0.5); transform: scale(1.15); }
.tl-year.active .tl-year__dot::after { background: var(--gold); width: 9px; height: 9px; }

.tl-panel { max-width: 820px; margin: 0 auto; min-height: 200px; position: relative; }
.tl-card { position: absolute; inset: 0; opacity: 0; transform: translateY(20px); transition: opacity .55s var(--ease), transform .55s var(--ease); pointer-events: none; text-align: center; }
.tl-card.active { opacity: 1; transform: none; pointer-events: auto; position: relative; }
.tl-card__tag { font-family: var(--heading); font-size: 12px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold); }
.tl-card h3 { font-size: clamp(28px, 4vw, 44px); color: var(--cream); margin: 16px 0 18px; }
.tl-card p { color: var(--text); max-width: 60ch; margin: 0 auto; font-size: 17px; }

/* mission vision */
.mv__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
@media (max-width: 820px){ .mv__grid { grid-template-columns: 1fr; } }
.mv-card { position: relative; padding: clamp(34px, 4vw, 56px); border: 1px solid var(--line); background: linear-gradient(150deg, rgba(212,175,55,0.05), rgba(20,16,8,0.2)); overflow: hidden; }
.mv-card::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 2px; background: var(--gold-grad); transform: scaleX(0); transform-origin: left; transition: transform .7s var(--ease); }
.mv-card.in::before { transform: scaleX(1); }
.mv-card__no { font-family: var(--display); font-size: 56px; color: rgba(212,175,55,0.25); line-height: 1; }
.mv-card h3 { font-size: clamp(26px, 3vw, 38px); color: var(--cream); margin: 8px 0 18px; }
.mv-card p { color: var(--text); }

/* quote */
.quote { text-align: center; position: relative; }
.quote__mark { font-family: var(--display); font-size: clamp(120px, 18vw, 240px); color: rgba(212,175,55,0.12); line-height: 0.6; height: 0.4em; display: block; }
.quote__text { font-family: var(--heading); font-weight: 300; font-size: clamp(26px, 4.2vw, 56px); line-height: 1.18; color: var(--cream); max-width: 18ch; margin: 0 auto; letter-spacing: -0.01em; }
.quote__text .gold-text { font-weight: 500; }
.quote__by { margin-top: 36px; font-family: var(--heading); font-size: 13px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold); }
