/* cgti-shared.css · Cell & Gene Therapy Innovation · GBX Circle · v1.0
   Flat dark stack — no weave (deep/stone/mid only). Gold #ba9933. Weight ≤400.
   Fibonacci spacing. Breakpoint 900px. */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --deep:#171613;
  --stone:#1E1D1A;
  --mid:#2A2825;
  --cashmere:#F4EFE5;
  --linen:#EDE7D9;
  --gold:#ba9933;
  --g2:rgba(186,153,51,0.236);
  --g3:rgba(186,153,51,0.07);
  --dim:rgba(244,239,229,0.72);
  --dim2:rgba(244,239,229,0.52);
  --serif:'Cormorant',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --hv:'Helvetica Neue',Helvetica,Arial,sans-serif;
  --sp1:5px;--sp2:8px;--sp3:13px;--sp4:21px;--sp5:34px;--sp6:55px;--sp7:89px;
}

html{scroll-behavior:smooth}
body{background:var(--deep);color:var(--cashmere);font-family:var(--hv);font-weight:300;line-height:1.76;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}

/* ── HEADER ── */
.hdr{position:fixed;top:0;left:0;right:0;z-index:9999;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp5);background:rgba(23,22,19,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid var(--g2)}
.hdr-mark{display:flex;align-items:center;gap:var(--sp2);text-decoration:none}
.hdr-forum{font-family:var(--sans);font-size:10px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--cashmere)}
.hdr-nav ul.nav-links{list-style:none;display:flex;gap:var(--sp5);align-items:center}
.nav-item{position:relative}
.nav-top{font-family:var(--sans);font-size:10px;font-weight:300;letter-spacing:.16em;color:var(--dim);cursor:pointer;user-select:none;padding:4px 0}
.nav-dd{position:fixed;top:68px;background:rgba(23,22,19,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:.5px solid var(--g2);padding:var(--sp3) var(--sp4);display:flex;flex-direction:column;gap:var(--sp2);min-width:180px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s;z-index:99999}
.nav-links li:hover .nav-dd,.nav-item.dd-open .nav-dd{opacity:1;visibility:visible;pointer-events:auto}
.nav-dd a{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);display:flex;align-items:center;gap:6px;transition:color .2s}
.nav-dd a:hover{color:var(--gold)}
.key-glyph{width:10px;height:10px;flex-shrink:0}
.hdr-cta{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);border:.5px solid var(--g2);padding:var(--sp2) var(--sp3);display:flex;align-items:center;gap:6px;transition:border-color .2s}
.hdr-cta:hover{border-color:var(--gold)}
.hdr-cta svg{width:11px;height:11px;flex-shrink:0}
.mob-menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.mob-menu-btn span{display:block;width:22px;height:1px;background:var(--cashmere);transition:transform .2s,opacity .2s}
.hdr.mob-open .mob-menu-btn span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hdr.mob-open .mob-menu-btn span:nth-child(2){opacity:0}
.hdr.mob-open .mob-menu-btn span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* ── PAGE WRAP ── */
.page-wrap{padding-top:68px}

/* ── PAGE HERO (video — text BELOW, never on top) ── */
.page-hero{width:100%;aspect-ratio:16/9;overflow:hidden;position:relative}
.page-hero video{width:100%;height:100%;object-fit:cover;filter:saturate(.55) contrast(1.08) brightness(.55) sepia(.12) opacity(.65)}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to bottom,transparent,var(--deep));pointer-events:none}

/* ── PAGE HEAD (below hero) ── */
.page-head{padding:var(--sp7) var(--sp5) var(--sp6);max-width:900px}
.page-kicker{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:var(--sp3)}
.page-title{font-family:var(--serif);font-weight:300;font-size:clamp(48px,6.5vw,90px);line-height:.92;margin-bottom:var(--sp4)}
.page-sub{font-family:var(--hv);font-size:12.944px;font-weight:300;line-height:1.7639;letter-spacing:.01618em;color:var(--dim);max-width:60ch}

/* ── SECTION ── */
.pg-sec{padding:var(--sp7) var(--sp5)}
.sec-kicker{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:var(--sp3)}
.sec-h2{font-family:var(--serif);font-weight:300;font-size:clamp(48px,6.5vw,90px);line-height:.92;margin-bottom:var(--sp4)}

/* ── SCROLL REVEAL ── */
.rev{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}
.rev.in{opacity:1;transform:none}

/* ── FOOTER ── */
.ftr{background:var(--deep);border-top:.5px solid var(--g2);padding:var(--sp6) var(--sp5) var(--sp5)}
.ftr-top{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp5);flex-wrap:wrap}
.ftr-mark{display:flex;align-items:center;gap:var(--sp2)}
.ftr-wordmark{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--dim2)}
.ftr-wordmark span{color:var(--gold);font-style:italic}
.ftr-links{display:flex;gap:var(--sp6)}
.ftr-col{display:flex;flex-direction:column;gap:var(--sp2)}
.ftr-col-head{font-family:var(--sans);font-size:8px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:var(--dim2);margin-bottom:var(--sp1)}
.ftr-col a{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--dim2);transition:color .2s}
.ftr-col a:hover{color:var(--gold)}
.ftr-divider{height:.5px;background:var(--g2);margin:var(--sp5) 0 var(--sp4)}
.ftr-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp3)}
.ftr-meta{font-family:var(--hv);font-size:11px;font-weight:300;color:var(--dim2)}
.ftr-tagline{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--gold)}

/* ── GATE OVERLAY ── */
.pg-overlay{position:fixed;inset:0;z-index:99998;background:var(--deep);display:flex;flex-direction:column;overflow-y:auto;transition:opacity .4s,visibility .4s}
.pg-overlay.unlocked{opacity:0;visibility:hidden;pointer-events:none}
.pg-video-wrap{width:100%;aspect-ratio:16/9;overflow:hidden;position:relative;flex-shrink:0}
.pg-video-wrap video{width:100%;height:100%;object-fit:cover;filter:saturate(.55) contrast(1.08) brightness(.55) sepia(.12) opacity(.65)}
.pg-video-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to bottom,transparent,var(--deep));pointer-events:none}
.pg-body{padding:var(--sp6) var(--sp5);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp3);flex:1}
.pg-mark{margin-bottom:var(--sp2)}
.pg-wordmark{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--dim2)}
.pg-wordmark span{color:var(--gold);font-style:italic}
.pg-key{margin:var(--sp2) 0}
.pg-head{font-family:var(--serif);font-weight:300;font-size:clamp(32px,4vw,56px);line-height:1}
.pg-sub{font-family:var(--serif);font-style:italic;font-size:clamp(16px,2vw,22px);color:var(--gold)}
.pg-line{font-family:var(--hv);font-size:12px;font-weight:300;color:var(--dim2)}
.pg-form{display:flex;gap:var(--sp2);align-items:center;margin:var(--sp3) 0;flex-wrap:wrap;justify-content:center}
.pg-input{background:transparent;border:.5px solid var(--g2);color:var(--cashmere);font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;padding:var(--sp2) var(--sp3);outline:none;width:200px}
.pg-input:focus{border-color:var(--gold)}
.pg-btn{background:transparent;border:.5px solid var(--g2);color:var(--gold);font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;padding:var(--sp2) var(--sp4);cursor:pointer;transition:border-color .2s}
.pg-btn:hover{border-color:var(--gold)}
.pg-err{font-family:var(--hv);font-size:11px;font-weight:300;color:#c0392b;opacity:0;transition:opacity .3s;width:100%;text-align:center;margin-top:var(--sp1)}
.pg-err.show{opacity:1}
.pg-join{font-family:var(--hv);font-size:11px;font-weight:300;color:var(--dim2)}
.pg-join a{color:var(--gold);text-decoration:underline}
.pg-closer{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--gold);margin-top:var(--sp2)}

/* ── INDEX SECTIONS ── */
/* Hero display block */
.idx-hero{position:relative;width:100%;overflow:hidden}
.idx-hero video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;filter:saturate(.55) contrast(1.08) brightness(.55) sepia(.12) opacity(.65)}
.idx-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to bottom,transparent,var(--deep));pointer-events:none}
.idx-title-block{padding:var(--sp6) var(--sp5) var(--sp7);max-width:1100px}
.idx-eyebrow{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:var(--sp4)}
.idx-headline{font-family:var(--serif);font-weight:300;font-size:clamp(64px,9vw,120px);line-height:.90;max-width:14ch;margin-bottom:var(--sp4)}
.idx-tricolon{font-family:var(--serif);font-weight:300;font-size:clamp(16px,2vw,22px);line-height:1.4;color:var(--dim);margin-bottom:var(--sp4);font-style:italic}
.idx-venue{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--dim2)}
/* Why section */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp6) var(--sp7);margin-top:var(--sp6)}
.why-card{border-top:.5px solid var(--g2);padding-top:var(--sp4)}
.why-num{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.24em;color:var(--gold);margin-bottom:var(--sp3)}
.why-head{font-family:var(--serif);font-weight:300;font-size:26px;line-height:1.1;margin-bottom:var(--sp3)}
.why-body{font-family:var(--hv);font-size:12.944px;font-weight:300;line-height:1.7639;letter-spacing:.01618em;color:var(--dim);max-width:52ch}
/* Thesis */
.thesis-sec{background:var(--stone)}
.thesis-inner{max-width:800px}
.thesis-pull{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3.5vw,48px);line-height:1.1;margin-bottom:var(--sp5)}
.thesis-body{font-family:var(--hv);font-size:12.944px;font-weight:300;line-height:1.7639;letter-spacing:.01618em;color:var(--dim);max-width:60ch;margin-bottom:var(--sp4)}
.thesis-closer{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--gold)}
/* Feature reel */
.reel-sec{background:var(--deep)}
.reel-video-wrap{width:100%;aspect-ratio:16/9;overflow:hidden;position:relative;margin-bottom:var(--sp5)}
.reel-video-wrap video{width:100%;height:100%;object-fit:cover;filter:saturate(.55) contrast(1.08) brightness(.55) sepia(.12) opacity(.65)}
.reel-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp5);margin-top:var(--sp4)}
/* Leaders grid */
.leaders-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp5);margin-top:var(--sp5)}
.leader-card{position:relative;cursor:default}
.leader-img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center 18%;filter:grayscale(1) contrast(1.05) brightness(.95)}
.leader-body{padding:var(--sp3) 0}
.leader-name{font-family:var(--serif);font-weight:300;font-size:20px;line-height:1.1;margin-bottom:var(--sp2)}
.leader-title{font-family:var(--hv);font-size:11px;font-weight:300;line-height:1.6;color:var(--dim2)}
.leader-org{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:var(--sp2)}
/* Feature photo */
.feat-photo-sec{padding:0}
.feat-photo img,.feat-photo video{width:100%;aspect-ratio:16/9;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.95);display:block}
/* Carousel */
.bc-sec{background:var(--stone);padding:var(--sp7) 0}
.bc-head{padding:0 var(--sp5) var(--sp5)}
.bc-viewport{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.bc-track{display:flex;gap:2px;width:max-content;animation:bcscroll 60s linear infinite}
.bc-track:hover{animation-play-state:paused}
@keyframes bcscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.bc-frame{flex:0 0 auto;width:clamp(300px,32vw,440px);aspect-ratio:16/9;overflow:hidden;position:relative}
.bc-frame img,.bc-frame video{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.95);transition:filter .3s,transform .3s}
.bc-frame:hover img,.bc-frame:hover video{filter:grayscale(.5) contrast(1.05) brightness(1);transform:scale(1.03)}
.bc-cap{position:absolute;bottom:14px;left:16px;font-family:var(--sans);font-size:8px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--cashmere)}
/* Who attends (institutional register) */
.wa-page{background:var(--linen);color:#141414;min-height:100vh}
.wa-header{background:var(--linen);border-bottom:.5px solid rgba(20,20,20,.12);padding:var(--sp6) var(--sp5)}
.wa-kicker{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:#141414;opacity:.5;margin-bottom:var(--sp3)}
.wa-title{font-family:var(--serif);font-weight:300;font-size:clamp(48px,6.5vw,90px);line-height:.92;color:#141414;margin-bottom:var(--sp4)}
.wa-sub{font-family:var(--hv);font-size:12.944px;font-weight:300;line-height:1.7639;letter-spacing:.01618em;color:rgba(20,20,20,.7);max-width:60ch}
.wa-sec{padding:var(--sp7) var(--sp5);background:var(--linen)}
.wa-sec-kicker{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.24em;text-transform:uppercase;color:rgba(20,20,20,.5);margin-bottom:var(--sp3)}
.wa-sec-h2{font-family:var(--serif);font-weight:300;font-size:clamp(36px,4.5vw,64px);line-height:.95;color:#141414;margin-bottom:var(--sp5)}
.wa-tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--sp3);margin-top:var(--sp4)}
.wa-tile{background:#fff;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;padding:var(--sp3);border:.5px solid rgba(20,20,20,.08)}
.wa-tile svg{width:70%;height:70%;max-width:80px;fill:#141414}
.wa-tile-text{font-family:var(--hv);font-size:11px;font-weight:300;text-align:center;color:#141414;line-height:1.3}
/* Positions gate (index only) */
.pos-gate-wrap{position:relative}
.pos-overlay{position:absolute;inset:0;z-index:100;background:rgba(23,22,19,.94);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--sp3);text-align:center;padding:var(--sp5)}
.pos-overlay.unlocked{display:none}
/* Agenda */
.day-tabs{display:flex;gap:var(--sp2);padding:0 var(--sp5) var(--sp4);border-bottom:.5px solid var(--g2);flex-wrap:wrap}
.day-tab{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--dim2);cursor:pointer;padding:var(--sp2) var(--sp4);border:.5px solid transparent;transition:color .2s,border-color .2s}
.day-tab.active{color:var(--gold);border-color:var(--g2)}
.day-panel{display:none;padding:var(--sp5)}
.day-panel.active{display:block}
.track-bar{display:flex;gap:var(--sp2);flex-wrap:wrap;margin-bottom:var(--sp5)}
.track-pill{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--dim2);border:.5px solid var(--g2);padding:var(--sp1) var(--sp3);cursor:pointer;background:transparent;transition:color .2s,border-color .2s}
.track-pill.active{color:var(--gold);border-color:var(--gold)}
.session-card{border-left:1.5px solid var(--g2);padding:var(--sp3) var(--sp4);margin-bottom:var(--sp4);background:var(--stone)}
.session-time{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;color:var(--gold);margin-bottom:var(--sp2)}
.session-title{font-family:var(--serif);font-weight:300;font-size:20px;line-height:1.1;margin-bottom:var(--sp2)}
.session-body{font-family:var(--hv);font-size:12.944px;font-weight:300;line-height:1.7639;color:var(--dim);max-width:60ch}
.session-speaker{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--dim2);margin-top:var(--sp3)}
/* Attend form */
.form-field{margin-bottom:var(--sp4)}
.form-label{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--dim2);display:block;margin-bottom:var(--sp2)}
.form-input,.form-select,.form-textarea{width:100%;background:transparent;border:.5px solid var(--g2);color:var(--cashmere);font-family:var(--hv);font-size:12px;font-weight:300;padding:var(--sp2) var(--sp3);outline:none;transition:border-color .2s;-webkit-appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold)}
.form-select option{background:var(--deep);color:var(--cashmere)}
.form-textarea{resize:vertical;min-height:80px}
.form-submit{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:.22em;text-transform:uppercase;color:var(--deep);background:var(--gold);border:none;padding:var(--sp3) var(--sp6);cursor:pointer;transition:opacity .2s}
.form-submit:hover{opacity:.85}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp4)}
.form-success{font-family:var(--hv);font-size:13px;font-weight:300;color:var(--gold);display:none;margin-top:var(--sp4)}

/* ── MOBILE ── */
@media(max-width:900px){
  .hdr-nav{display:none}.hdr-nav.mob-open{display:block}
  .mob-menu-btn{display:flex}
  .hdr{padding:0 var(--sp4)}
  .hdr.mob-open .hdr-nav{display:block;position:fixed;top:68px;left:0;right:0;background:rgba(23,22,19,.98);border-bottom:.5px solid var(--g2);padding:var(--sp4)}
  .nav-links{flex-direction:column;gap:0}
  .nav-item{border-bottom:.5px solid var(--g2)}
  .nav-top{display:block;padding:var(--sp3) 0;position:relative}
  .nav-top::after{content:'›';position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:14px;color:var(--dim2);transition:transform .2s}
  .nav-item.acc-open>.nav-top::after{transform:translateY(-50%) rotate(90deg)}
  .nav-dd{position:static;background:transparent;border:none;padding:var(--sp2) 0 var(--sp2) var(--sp4);opacity:1;visibility:visible;pointer-events:auto;display:none}
  .hdr.mob-open .nav-item.acc-open .nav-dd{display:flex}
  .why-grid,.leaders-grid,.reel-grid,.form-grid-2{grid-template-columns:1fr}
  .wa-tiles{grid-template-columns:repeat(3,1fr)}
  .ftr-top{flex-direction:column}
  .ftr-links{flex-wrap:wrap;gap:var(--sp4)}
  .page-head,.pg-sec,.idx-title-block{padding-left:var(--sp4);padding-right:var(--sp4)}
  .pg-sec{padding-top:var(--sp6);padding-bottom:var(--sp6)}
}
