/* =========================================================
   CENTRE FOR AGRICULTURE PRODUCTION (CAP)
   Style — Elegant agricultural research institute aesthetic
   ========================================================= */

:root{
  /* Palette — deep forest, cream, gold */
  --green-900:#0d2118;
  --green-800:#13301f;
  --green-700:#1a4030;
  --green-600:#23553f;
  --green-500:#2f6b50;
  --green-400:#4a8b6a;
  --green-300:#88b59d;

  --cream-50:#fbf8f2;
  --cream-100:#f7f3ea;
  --cream-200:#ede5d3;
  --cream-300:#dccdb2;

  --gold-500:#c9a961;
  --gold-400:#d8bf82;
  --gold-300:#e6d3a4;

  --ink-900:#0a1410;
  --ink-700:#243027;
  --ink-500:#4a5a52;
  --ink-400:#6f7d75;
  --ink-300:#aab4ad;

  --bg:#fbf8f2;
  --surface:#ffffff;

  /* Typography */
  --font-display: "Cormorant Garamond", "Times New Roman", serif;
  --font-body: "Outfit", system-ui, sans-serif;
  --font-script: "Caveat", cursive;

  /* Layout */
  --container: 1280px;
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 24px;
  --shadow-sm: 0 2px 12px rgba(13,33,24,.06);
  --shadow-md: 0 12px 40px rgba(13,33,24,.10);
  --shadow-lg: 0 28px 80px rgba(13,33,24,.18);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font-body);
  font-weight:400;
  color:var(--ink-700);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
ul{list-style:none;padding:0;margin:0;}

/* Typography rhythm */
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:-.01em;margin:0;color:var(--green-900);}
.italic{font-style:italic;font-weight:400;color:var(--green-600);}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 2rem;
}

@media (max-width:640px){
  .container{padding:0 1.25rem;}
}

/* ========== LOADER ========== */
.loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--green-900);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;
  transition:opacity .8s var(--ease), visibility .8s var(--ease);
}
.loader.hide{opacity:0;visibility:hidden;}
.loader-leaf{animation:leafPulse 1.4s var(--ease) infinite;color:var(--gold-500);}
.loader p{color:var(--cream-200);font-family:var(--font-display);font-style:italic;letter-spacing:.04em;}
@keyframes leafPulse{0%,100%{transform:scale(.92) rotate(-3deg);}50%{transform:scale(1.08) rotate(3deg);}}

/* ========== NAVBAR ========== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1rem 0;
  background:transparent;
  transition:background .35s var(--ease), padding .35s var(--ease), box-shadow .35s var(--ease);
}
.navbar.scrolled{
  background:rgba(13,33,24,.92);
  backdrop-filter:saturate(120%) blur(12px);
  -webkit-backdrop-filter:saturate(120%) blur(12px);
  padding:.6rem 0;
  box-shadow:0 6px 30px rgba(0,0,0,.18);
}
.nav-inner{
  max-width:var(--container);
  margin:0 auto;padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}

.brand{display:flex;align-items:center;gap:.7rem;color:var(--cream-100);}
.brand-mark{color:var(--gold-500);display:flex;}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.55rem;letter-spacing:.04em;color:var(--cream-100);}
.brand-sub{font-family:var(--font-body);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-200);opacity:.85;margin-top:2px;}

.nav-menu ul{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;justify-content:flex-end;}
.nav-link{
  position:relative;
  padding:.45rem .7rem;
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--cream-100);
  transition:color .25s var(--ease);
}
.nav-link::after{
  content:"";
  position:absolute;left:.7rem;right:.7rem;bottom:.2rem;
  height:1px;background:var(--gold-500);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-link:hover,
.nav-link.active{color:var(--gold-400);}
.nav-link:hover::after,
.nav-link.active::after{transform:scaleX(1);}

.nav-toggle{
  display:none;
  width:36px;height:36px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.nav-toggle span{
  display:block;width:24px;height:1.5px;background:var(--cream-100);
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media (max-width: 1100px){
  .nav-menu{
    position:fixed;inset:0 0 0 auto;
    width:min(86vw,360px);
    background:var(--green-900);
    transform:translateX(110%);
    transition:transform .45s var(--ease);
    padding:6rem 2rem 2rem;
    overflow-y:auto;
  }
  .nav-menu.open{transform:translateX(0);}
  .nav-menu ul{flex-direction:column;align-items:stretch;gap:.25rem;}
  .nav-link{padding:.85rem .5rem;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.06);}
  .nav-link::after{display:none;}
  .nav-toggle{display:flex;z-index:5;}
}

/* ========== HERO ========== */
.hero{
  position:relative;
  height:100vh;min-height:600px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  color:var(--cream-100);
  text-align:center;
  /* NO isolation:isolate — it creates a stacking context that buries z-index:-1/:-2 children */
}
.hero-fallback{
  position:absolute;inset:0;width:100%;height:100%;
  z-index:0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(74,139,106,.45), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(201,169,97,.35), transparent 55%),
    linear-gradient(135deg, var(--green-900) 0%, var(--green-700) 50%, var(--green-800) 100%);
}
.hero-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:1;          /* above fallback, below overlay */
  /* No transform animation on video — causes GPU compositing conflicts in some browsers */
}

.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(180deg, rgba(13,33,24,.55) 0%, rgba(13,33,24,.35) 40%, rgba(13,33,24,.85) 100%),
    radial-gradient(ellipse at center, transparent 0%, rgba(13,33,24,.5) 100%);
}

.hero-content{
  max-width:980px;
  padding:0 1.5rem;
  position:relative;
  z-index:3;          /* above overlay */
  opacity:0;transform:translateY(30px);
  animation: heroIn 1.4s var(--ease) .4s forwards;
}
@keyframes heroIn{to{opacity:1;transform:none;}}

.hero-eyebrow{
  font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold-400);margin:0 0 1.5rem;
  display:inline-flex;align-items:center;gap:.8rem;
}
.hero-eyebrow span{color:var(--gold-500);font-size:1rem;}

.hero-title{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(2.4rem, 6vw, 5.2rem);
  letter-spacing:-.015em;
  color:#fff;
  line-height:1.05;
  margin-bottom:1.5rem;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.hero-title .line-1{display:block;}
.hero-title .line-2{display:block;font-style:italic;color:var(--gold-300);font-size:.7em;margin-top:.1em;}

.hero-divider{
  width:140px;height:1px;background:var(--gold-500);
  margin:1.5rem auto;
  position:relative;
}
.hero-divider::before,.hero-divider::after{
  content:"◇";position:absolute;top:50%;transform:translateY(-50%);
  color:var(--gold-500);font-size:.6rem;
}
.hero-divider::before{left:-18px;}
.hero-divider::after{right:-18px;}

.hero-tagline{
  font-family:var(--font-display);
  font-size:clamp(1.2rem, 2.4vw, 1.85rem);
  font-weight:400;font-style:italic;
  color:var(--cream-100);
  max-width:760px;margin:0 auto 2rem;
  letter-spacing:.01em;
}
.hero-tagline em{color:var(--gold-400);font-style:italic;}

.hero-meta{
  display:inline-flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:1.2rem;
  font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--cream-200);
  padding:.9rem 1.6rem;
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:100px;
  margin-bottom:2.2rem;
}
.hero-meta strong{color:var(--gold-400);font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin-right:.25rem;}
.hero-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--gold-500);opacity:.6;}

.hero-cta{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 2.4rem;
  background:transparent;
  border:1px solid var(--gold-500);
  color:var(--cream-100);
  font-size:.78rem;letter-spacing:.25em;text-transform:uppercase;
  font-weight:500;
  border-radius:100px;
  transition:all .35s var(--ease);
  position:relative;overflow:hidden;
}
.hero-cta::before{
  content:"";position:absolute;inset:0;background:var(--gold-500);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);z-index:-1;
}
.hero-cta:hover{color:var(--green-900);border-color:var(--gold-500);}
.hero-cta:hover::before{transform:scaleX(1);}

.scroll-indicator{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  color:var(--cream-200);
  z-index:3;
  animation: floatBob 2.4s ease-in-out infinite;
}
.mouse{
  width:22px;height:34px;border:1.5px solid currentColor;border-radius:12px;
  display:flex;justify-content:center;padding-top:6px;
}
.wheel{
  width:2px;height:6px;background:currentColor;border-radius:2px;
  animation: wheelDrop 1.6s var(--ease) infinite;
}
.scroll-text{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;}
@keyframes floatBob{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(-8px);}}
@keyframes wheelDrop{0%{transform:translateY(0);opacity:1;}100%{transform:translateY(8px);opacity:0;}}

/* ========== SECTIONS shared ========== */
.section{padding:7rem 0;position:relative;}
.section.about{background:var(--cream-50);}
.section.ecosystem{background:var(--cream-100);}
.section.products{background:var(--green-900);color:var(--cream-100);}
.section.startups{background:var(--cream-50);}
.section.revenue{background:var(--cream-100);}
.section.research{background:var(--green-800);color:var(--cream-100);}
.section.publications{background:var(--cream-50);}
.section.projects{background:var(--cream-100);}
.section.collaborations{background:var(--cream-50);}
.section.awards{background:var(--green-800);color:var(--cream-100);}
.section.training{background:var(--cream-50);}
.section.team{background:var(--cream-100);}
.section.way-forward{background:var(--cream-50);}
.section.all-caps{background:var(--green-900);color:var(--cream-100);}

.section.products h2,
.section.research h2,
.section.awards h2,
.section.all-caps h2{color:var(--cream-100);}
.section.products .italic,
.section.research .italic,
.section.awards .italic,
.section.all-caps .italic{color:var(--gold-300);}

.section-head{text-align:center;max-width:820px;margin:0 auto 4rem;}
.kicker{
  display:inline-block;
  font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold-500);
  padding:.3rem .9rem;
  border:1px solid currentColor;
  border-radius:100px;
  margin-bottom:1.5rem;
}
.section.products .kicker,
.section.research .kicker,
.section.awards .kicker,
.section.all-caps .kicker{color:var(--gold-400);}

.section-title{
  font-size:clamp(2rem, 4.4vw, 3.6rem);
  font-weight:500;
}
.section-lead{
  margin-top:1.2rem;
  font-family:var(--font-display);font-style:italic;
  font-size:1.15rem;color:var(--ink-500);
}
.section.products .section-lead,
.section.research .section-lead,
.section.awards .section-lead,
.section.all-caps .section-lead{color:var(--cream-200);}

/* Reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease), transform .9s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ========== ABOUT ========== */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
  align-items:center;margin-bottom:5rem;
}
.about-text h3{font-size:1.8rem;margin-bottom:1.2rem;color:var(--green-700);}
.about-text p{margin:0 0 1rem;color:var(--ink-700);font-size:1.02rem;}

.about-slideshow{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:5/4;
  box-shadow:var(--shadow-lg);
  background:var(--green-800);
}
.slides{position:absolute;inset:0;}
.slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;
  transition:opacity 1.1s var(--ease), transform 6s linear;
}
.slide.active{opacity:1;transform:scale(1.06);}
.slide-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-style:italic;
  color:var(--cream-200);
  background:
    radial-gradient(ellipse at center, rgba(201,169,97,.2), transparent 60%),
    linear-gradient(135deg, var(--green-700), var(--green-900));
}
.slide-fallback span{font-size:1.2rem;letter-spacing:.1em;}

.slide-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;
  background:rgba(13,33,24,.55);color:var(--cream-100);
  font-size:1.4rem;
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.18);
  transition:background .25s var(--ease);z-index:3;
}
.slide-nav:hover{background:rgba(201,169,97,.85);color:var(--green-900);}
.slide-nav.prev{left:1rem;}
.slide-nav.next{right:1rem;}

.slide-dots{
  position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.45rem;z-index:3;
}
.slide-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.4);
  transition:background .3s var(--ease), width .3s var(--ease);
}
.slide-dot.active{background:var(--gold-500);width:22px;border-radius:6px;}

/* Vision / Mission / Milestone */
.vmm-tabs{margin-top:2rem;}
.vmm-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem;}
.vmm-btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.95rem 1.8rem;
  background:transparent;color:var(--green-700);
  border:1px solid var(--green-700);
  border-radius:100px;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  transition:all .3s var(--ease);
  position:relative;overflow:hidden;
}
.vmm-btn::before{
  content:"";position:absolute;inset:0;background:var(--green-700);
  transform:translateY(101%);transition:transform .35s var(--ease);z-index:-1;
}
.vmm-btn:hover{color:var(--cream-100);}
.vmm-btn:hover::before{transform:translateY(0);}
.vmm-btn.active{background:var(--green-700);color:var(--cream-100);}
.vmm-icon{color:var(--gold-500);}

.vmm-panels{position:relative;}
.vmm-panel{
  display:none;
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:2.5rem;
  box-shadow:var(--shadow-md);
  border:1px solid var(--cream-200);
  animation: vmmIn .6s var(--ease);
}
.vmm-panel.active{display:block;}
@keyframes vmmIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}

.vmm-panel h4{
  font-size:1.7rem;color:var(--green-700);
  margin-bottom:1.4rem;
  padding-bottom:1rem;border-bottom:1px solid var(--cream-200);
}
.vmm-panel ul{display:grid;gap:.9rem;}
.vmm-panel li{
  padding-left:1.6rem;position:relative;
  color:var(--ink-700);font-size:1rem;
}
.vmm-panel li::before{
  content:"◆";position:absolute;left:0;top:0;
  color:var(--gold-500);font-size:.7rem;
}

.milestone-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.milestone-card{
  background:var(--cream-50);
  border:1px solid var(--cream-200);
  border-left:3px solid var(--gold-500);
  padding:1.5rem;border-radius:var(--radius-sm);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.milestone-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.m-year{font-family:var(--font-display);font-style:italic;color:var(--gold-500);font-size:1rem;margin:0 0 .3rem;font-weight:600;}
.milestone-card h5{font-size:1.15rem;margin-bottom:.5rem;color:var(--green-700);}
.milestone-card p{font-size:.92rem;color:var(--ink-500);margin:0;}

/* ========== ECOSYSTEM ========== */
.netflix-carousel{
  position:relative;
  margin-bottom:4rem;
  padding:1rem 0;
}
.nfx-track{
  display:flex;
  gap:1.2rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding:1rem 1.5rem;
  scroll-behavior:smooth;
}
.nfx-track::-webkit-scrollbar{display:none;}
.nfx-card{
  flex:0 0 auto;width:340px;height:230px;
  border-radius:var(--radius-md);overflow:hidden;
  background-size:cover;background-position:center;
  scroll-snap-align:center;
  position:relative;
  box-shadow:var(--shadow-md);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.nfx-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(13,33,24,.85));
}
.nfx-card .nfx-cap{
  position:absolute;left:1.2rem;right:1.2rem;bottom:1.1rem;
  color:var(--cream-100);
  font-family:var(--font-display);font-style:italic;
  font-size:1.1rem;
  z-index:2;
}
.nfx-card.fallback{
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse at center, rgba(201,169,97,.25), transparent 65%),
    linear-gradient(135deg, var(--green-700), var(--green-900));
}
.nfx-card.fallback .nfx-cap{position:static;text-align:center;}
.nfx-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-lg);}

.nfx-arrow,.proj-arrow,.team-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--green-900);color:var(--cream-100);
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;
  box-shadow:var(--shadow-md);
  transition:all .3s var(--ease);
  z-index:5;
}
.nfx-arrow:hover,.proj-arrow:hover,.team-arrow:hover{background:var(--gold-500);color:var(--green-900);}
.nfx-arrow.prev,.proj-arrow.prev,.team-arrow.prev{left:-12px;}
.nfx-arrow.next,.proj-arrow.next,.team-arrow.next{right:-12px;}

/* Unit buttons grid */
.unit-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1rem;
}
.unit-btn{
  position:relative;
  padding:1.4rem 1rem;
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  text-align:center;
  font-family:var(--font-display);
  font-size:1.02rem;
  font-weight:500;
  color:var(--green-800);
  letter-spacing:.005em;
  transition:all .35s var(--ease);
  cursor:pointer;
  overflow:hidden;
}
.unit-btn::before{
  content:"";position:absolute;
  top:0;left:0;right:0;height:3px;
  background:var(--gold-500);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);
}
.unit-btn::after{
  content:"→";position:absolute;
  right:.8rem;top:50%;transform:translate(8px,-50%);
  opacity:0;color:var(--gold-500);
  transition:all .35s var(--ease);
  font-family:var(--font-body);
}
.unit-btn:hover{
  border-color:var(--gold-500);
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(23,40,28,.12);
  background:linear-gradient(180deg, #fff, var(--cream-50));
}
.unit-btn:hover::before{transform:scaleX(1);}
.unit-btn:hover::after{opacity:1;transform:translate(0,-50%);}

/* ========== PRODUCTS ========== */
.product-list{margin-bottom:3.5rem;text-align:center;max-width:920px;margin-left:auto;margin-right:auto;}
.product-tags{
  font-family:var(--font-display);font-style:italic;
  font-size:1.15rem;line-height:1.9;color:var(--cream-200);
  letter-spacing:.005em;
}

.brand-marquee{
  overflow:hidden;
  padding:2rem 0;
  background:rgba(255,255,255,.04);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.brand-track{
  display:flex;gap:3rem;align-items:center;
  animation: marquee 32s linear infinite;
  width:max-content;
}
.brand-marquee:hover .brand-track{animation-play-state:paused;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

.brand-tile{
  flex:0 0 auto;
  height:120px;min-width:200px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:1rem 2rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-md);
  filter:grayscale(1) opacity(.75);
  transition:filter .35s var(--ease),transform .35s var(--ease),border-color .35s var(--ease);
}
.brand-tile:hover{filter:grayscale(0) opacity(1);transform:scale(1.05);border-color:var(--gold-500);}
.brand-tile img{max-height:50px;max-width:160px;object-fit:contain;margin-bottom:.4rem;}
.brand-tile .brand-name-tile{
  font-family:var(--font-display);font-style:italic;
  color:var(--cream-100);font-size:1.05rem;text-align:center;
}
.brand-tile .brand-sub-tile{
  font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-400);margin-top:.3rem;
}

/* ========== STARTUPS ========== */
.startup-buttons{
  display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;
  margin-bottom:3rem;
}
.startup-btn{
  position:relative;
  padding:1rem 1.6rem;
  background:var(--surface);
  border:1px solid var(--cream-300);
  border-radius:100px;
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:500;
  color:var(--green-700);
  transition:all .35s var(--ease);
  cursor:pointer;
}
.startup-btn:hover{background:var(--green-700);color:var(--cream-100);border-color:var(--green-700);transform:translateY(-2px);}
.startup-btn.active{background:var(--green-700);color:var(--gold-300);border-color:var(--green-700);}

.startup-display{
  background:var(--surface);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  border:1px solid var(--cream-200);
  min-height:380px;
  overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  position:relative;
}
.startup-empty{
  grid-column:1 / -1;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-style:italic;font-size:1.3rem;
  color:var(--ink-400);padding:5rem 2rem;
}
.startup-content{padding:3rem 2.5rem;animation: vmmIn .6s var(--ease);}
.startup-content .sc-tag{
  display:inline-block;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-500);
  padding:.25rem .8rem;border:1px solid currentColor;border-radius:100px;
  margin-bottom:1.2rem;
}
.startup-content h3{font-size:1.9rem;color:var(--green-700);margin-bottom:.5rem;}
.startup-content .sc-sub{font-family:var(--font-display);font-style:italic;color:var(--gold-500);margin-bottom:1.2rem;font-size:1.1rem;}
.startup-content p{color:var(--ink-700);font-size:.97rem;margin-bottom:1rem;}

.startup-slide-wrap{
  position:relative;
  background:var(--green-800);
  min-height:380px;
  overflow:hidden;
  animation: vmmIn .6s var(--ease);
}
.startup-slides{position:absolute;inset:0;}

/* ========== REVENUE ========== */
.stat-cards{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;
  margin-bottom:3rem;
}
.stat-card{
  padding:2rem 1.5rem;
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-top:3px solid var(--gold-500);
  border-radius:var(--radius-md);
  text-align:left;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.stat-label{
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--ink-500);margin:0 0 .8rem;
}
.stat-value{
  font-family:var(--font-display);
  font-size:2.4rem;font-weight:600;color:var(--green-700);
  margin:0;line-height:1;
}
.stat-value .suffix{font-size:.9rem;font-style:italic;color:var(--gold-500);font-weight:500;margin-left:.2rem;}
.stat-detail{font-size:.85rem;color:var(--ink-400);margin:.5rem 0 0;font-style:italic;}

.charts-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:1.5rem;
  margin-bottom:3rem;
}
.chart-card{
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  padding:2rem;
  box-shadow:var(--shadow-sm);
}
.chart-card h4{font-size:1.05rem;color:var(--green-700);margin-bottom:1.2rem;font-family:var(--font-display);font-style:italic;font-weight:500;}
.chart-wrap{position:relative;height:300px;}

.revenue-bars{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:2.5rem;
  border:1px solid var(--cream-200);
}
.revenue-bars h4{font-size:1.2rem;color:var(--green-700);margin-bottom:1.5rem;font-style:italic;font-family:var(--font-display);font-weight:500;}
.bar-rows{display:grid;gap:1rem;}
.bar-row{display:grid;grid-template-columns:100px 1fr 100px;gap:1rem;align-items:center;}
.b-label{font-size:.85rem;letter-spacing:.08em;color:var(--ink-500);font-weight:500;}
.bar{height:8px;background:var(--cream-200);border-radius:100px;overflow:hidden;}
.bar-fill{
  height:100%;
  background:linear-gradient(90deg, var(--green-500), var(--gold-500));
  width:0;border-radius:100px;
  transition:width 1.8s var(--ease);
}
.b-val{font-family:var(--font-display);color:var(--green-700);font-weight:600;text-align:right;}

/* ========== RESEARCH ========== */
.research-ticker{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-md);
  padding:1.5rem 2rem;
  display:flex;align-items:center;gap:1.5rem;
  margin-bottom:3rem;
  backdrop-filter:blur(6px);
}
.rt-prefix{
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold-400);white-space:nowrap;
}
.rt-screen{
  flex:1;
  font-family:var(--font-display);font-style:italic;
  font-size:1.3rem;color:var(--cream-100);
  display:flex;align-items:center;min-height:1.5em;
}
.rt-caret{color:var(--gold-500);animation: blink 1s steps(2) infinite;margin-left:2px;}
@keyframes blink{50%{opacity:0;}}

.netflix-carousel.small .nfx-card{width:280px;height:180px;}

.research-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
  margin-top:3rem;
}
.research-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-md);
  padding:1.5rem;
  transition:all .35s var(--ease);
  backdrop-filter:blur(6px);
}
.research-card:hover{background:rgba(201,169,97,.08);border-color:var(--gold-500);transform:translateY(-3px);}
.research-card .rc-num{
  font-family:var(--font-display);font-style:italic;color:var(--gold-400);
  font-size:.85rem;letter-spacing:.1em;margin-bottom:.5rem;
}
.research-card p{margin:0;color:var(--cream-100);font-size:.95rem;line-height:1.5;}

/* ========== PUBLICATIONS ========== */
.pub-stats{
  display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;
  margin-bottom:3.5rem;
}
.pub-stat{
  text-align:center;
  padding:1.8rem 1rem;
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.pub-stat:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.ps-num{
  font-family:var(--font-display);
  font-size:2.2rem;font-weight:600;color:var(--green-700);
  margin:0 0 .3rem;
}
.ps-lbl{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-500);margin:0;}

.pub-tabs{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:1rem;
  border:1px solid var(--cream-200);
  box-shadow:var(--shadow-sm);
}
.pub-tab-buttons{display:flex;gap:.5rem;flex-wrap:wrap;border-bottom:1px solid var(--cream-200);padding-bottom:1rem;margin-bottom:2rem;}
.pub-tab{
  padding:.7rem 1.4rem;
  font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;
  color:var(--ink-500);
  border-radius:100px;
  transition:all .3s var(--ease);
}
.pub-tab:hover{color:var(--green-700);}
.pub-tab.active{background:var(--green-700);color:var(--cream-100);}

.pub-panel{display:none;padding:1rem;}
.pub-panel.active{display:block;animation: vmmIn .5s var(--ease);}
.pub-desc{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:var(--ink-700);margin-bottom:1.5rem;line-height:1.7;}
.pub-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.pub-card{
  padding:1.5rem;
  background:var(--cream-50);
  border:1px solid var(--cream-200);
  border-left:3px solid var(--gold-500);
  border-radius:var(--radius-sm);
  transition:transform .3s var(--ease);
}
.pub-card:hover{transform:translateY(-3px);}
.pub-card h5{font-size:1.05rem;color:var(--green-700);margin:0 0 .5rem;}
.pub-card p{font-size:.9rem;color:var(--ink-500);margin:0;}

/* ========== PROJECTS ========== */
.project-carousel{position:relative;overflow:hidden;}
.project-track{
  display:flex;gap:1.5rem;
  padding:1rem 1rem 2rem;
  will-change:transform;
  transform:translate3d(0,0,0);
}
.project-card{
  flex:0 0 auto;width:360px;
  padding:2rem;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(10px);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.project-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.pj-funder{
  display:inline-block;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--green-600);font-weight:600;
  padding:.3rem .8rem;border:1px solid currentColor;border-radius:100px;
  margin-bottom:1rem;
}
.pj-title{font-size:1.2rem;color:var(--green-800);line-height:1.3;margin-bottom:1rem;font-weight:500;}
.pj-meta{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1rem;}
.pj-meta span{
  font-size:.78rem;padding:.3rem .7rem;
  background:var(--cream-100);border-radius:100px;color:var(--ink-700);
}
.pj-meta span.amount{background:var(--green-700);color:var(--gold-300);}
.pj-meta span.status{background:var(--gold-500);color:var(--green-900);}
.pj-meta span.status.completed{background:var(--green-500);color:var(--cream-100);}

/* ========== COLLABORATIONS ========== */
.collab-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.collab-card{
  padding:2rem 1.5rem;
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  text-align:center;
  transition:all .35s var(--ease);
}
.collab-card:hover{transform:translateY(-4px);border-color:var(--gold-500);box-shadow:var(--shadow-md);}
.collab-card .cb-icon{
  width:48px;height:48px;
  margin:0 auto 1rem;
  display:flex;align-items:center;justify-content:center;
  background:var(--cream-100);border-radius:50%;
  color:var(--green-600);font-family:var(--font-display);font-size:1.4rem;font-style:italic;
}
.collab-card h5{font-size:1.05rem;color:var(--green-700);margin:0 0 .3rem;}
.collab-card p{font-size:.85rem;color:var(--ink-500);margin:0;}

/* ========== AWARDS ========== */
.award-counter{text-align:center;margin-bottom:3rem;}
.ac-big{
  font-family:var(--font-display);
  font-size:clamp(4rem, 10vw, 7rem);
  color:var(--gold-400);
  margin:0;line-height:1;font-weight:600;
}
.ac-lbl{
  font-size:.85rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--cream-200);margin:.5rem 0 0;
}

.award-row{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;
}
.award-card{
  padding:2rem 1.5rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-md);
  text-align:center;
  transition:all .35s var(--ease);
  backdrop-filter:blur(6px);
}
.award-card:hover{transform:translateY(-5px) scale(1.02);border-color:var(--gold-500);background:rgba(201,169,97,.08);}
.aw-icon{
  display:block;font-size:2.4rem;color:var(--gold-400);
  margin-bottom:1rem;
}
.award-card h4{color:var(--cream-100);font-size:1.1rem;margin:0 0 .3rem;}
.award-card p{font-size:.8rem;color:var(--cream-300);margin:0;letter-spacing:.05em;}

/* ========== TRAINING ========== */
.train-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
}
.train-card{
  text-align:center;
  padding:2.5rem 1.5rem;
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  transition:all .35s var(--ease);
  position:relative;overflow:hidden;
}
.train-card::before{
  content:"";position:absolute;
  top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--green-500), var(--gold-500));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease);
}
.train-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.train-card:hover::before{transform:scaleX(1);}
.tg-icon{
  color:var(--green-500);
  margin-bottom:1rem;
  display:flex;justify-content:center;
}
.tg-num{
  font-family:var(--font-display);
  font-size:2.6rem;color:var(--green-700);font-weight:600;
  margin:0 0 .3rem;line-height:1;
}
.tg-lbl{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-500);margin:0;}

/* ========== CORE TEAM GRID ========== */
.team-grid{
  display:grid;
  grid-template-columns:repeat(11, 1fr);
  gap:.75rem;
}
.team-card{
  background:var(--surface);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-md);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  position:relative;
}
.team-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-500);
}
.team-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--green-500),var(--gold-500));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);z-index:2;
}
.team-card:hover::before{transform:scaleX(1);}

/* Role-based accent colors */
.team-card[data-role="ceo"] .tc-role-bar{background:var(--gold-500);}
.team-card[data-role="coordinator"] .tc-role-bar{background:var(--green-500);}
.team-card[data-role="joint-coordinator"] .tc-role-bar{background:var(--green-400);}
.team-card[data-role="co-coordinator"] .tc-role-bar{background:var(--green-400);}
.team-card[data-role="sub-rc"] .tc-role-bar{background:var(--green-300);}
.team-card[data-role="member"] .tc-role-bar{background:var(--cream-300);}

.tc-photo{
  width:100%;
  aspect-ratio:1/1;
  background-size:cover;
  background-position:center top;
  background-color:var(--green-700);
  position:relative;
  flex-shrink:0;
}
.tc-photo.fallback{
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--green-700), var(--green-900));
}
.tc-photo.fallback span{
  font-family:var(--font-display);font-style:italic;
  color:var(--cream-100);font-size:1.6rem;font-weight:300;letter-spacing:.05em;
}
.tc-role-bar{
  height:2px;
  background:var(--cream-300);
  flex-shrink:0;
}
.tc-body{
  padding:.6rem .7rem .7rem;
  flex:1;display:flex;flex-direction:column;gap:.2rem;
}
.tc-role{
  font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-500);font-weight:600;margin:0;line-height:1.2;
}
.tc-name{
  font-family:var(--font-display);font-weight:600;
  font-size:.82rem;color:var(--green-900);margin:0;line-height:1.25;
}
.tc-desig{
  font-family:var(--font-display);font-style:italic;
  font-size:.72rem;color:var(--ink-500);margin:0;line-height:1.2;
}
.tc-unit{
  font-size:.58rem;color:var(--green-600);margin:0;
  border-top:1px solid var(--cream-200);padding-top:.3rem;margin-top:.15rem;
  line-height:1.3;
}
.tc-link-icon{
  display:inline-flex;align-items:center;justify-content:center;
  margin-top:.3rem;
  width:22px;height:22px;
  border-radius:50%;
  background:var(--cream-100);
  border:1px solid var(--cream-300);
  color:var(--green-700);
  font-size:.65rem;
  transition:all .25s var(--ease);
  align-self:flex-start;
  text-decoration:none;
}
.tc-link-icon:hover{background:var(--gold-500);border-color:var(--gold-500);color:var(--green-900);}

@media (max-width:1400px){.team-grid{grid-template-columns:repeat(9,1fr);}}
@media (max-width:1100px){.team-grid{grid-template-columns:repeat(7,1fr);}}
@media (max-width:880px){.team-grid{grid-template-columns:repeat(5,1fr);}}
@media (max-width:640px){.team-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;}}

/* ========== WAY FORWARD ========== */
.roadmap{position:relative;padding:2rem 0;margin-bottom:3.5rem;}
.roadmap-line{
  position:absolute;left:50%;top:0;bottom:0;
  width:2px;background:linear-gradient(180deg, transparent, var(--gold-500), transparent);
  transform:translateX(-50%);
}
.roadmap-items{display:flex;flex-direction:column;gap:2rem;}
.roadmap-item{
  display:grid;grid-template-columns:1fr 60px 1fr;gap:1.5rem;
  align-items:center;
}
.roadmap-item:nth-child(even) .ri-content{grid-column:3;text-align:left;}
.roadmap-item:nth-child(odd) .ri-content{grid-column:1;text-align:right;}
.ri-content{
  background:var(--surface);
  padding:1.4rem 1.6rem;
  border-radius:var(--radius-md);
  border:1px solid var(--cream-200);
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.ri-content:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.ri-content h5{font-size:1.1rem;color:var(--green-700);margin:0 0 .3rem;}
.ri-content p{font-size:.92rem;color:var(--ink-500);margin:0;}
.ri-dot{
  width:18px;height:18px;border-radius:50%;
  background:var(--gold-500);grid-column:2;
  justify-self:center;
  box-shadow:0 0 0 8px rgba(201,169,97,.15), 0 0 0 16px rgba(201,169,97,.06);
}

.research-plan{
  background:var(--surface);
  border-radius:var(--radius-md);
  padding:2.5rem;
  border:1px solid var(--cream-200);
}
.research-plan h4{font-size:1.4rem;color:var(--green-700);margin-bottom:1.5rem;font-style:italic;font-weight:500;}
.rp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;}
.rp-card{
  text-align:center;padding:1.5rem 1rem;
  background:var(--cream-50);
  border:1px solid var(--cream-200);
  border-radius:var(--radius-sm);
  transition:transform .3s var(--ease);
}
.rp-card:hover{transform:translateY(-3px);}
.rp-icon{font-size:1.8rem;display:block;margin-bottom:.7rem;}
.rp-card p{font-size:.88rem;color:var(--ink-700);margin:0;line-height:1.4;}

/* ========== ALL CAPS ========== */
.cap-mosaic{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;
  gap:.8rem;
}
.cap-tile{
  position:relative;border-radius:var(--radius-md);overflow:hidden;
  background-size:cover;background-position:center;
  transition:transform .4s var(--ease);
}
.cap-tile.tall{grid-row:span 2;}
.cap-tile.wide{grid-column:span 2;}
.cap-tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(13,33,24,.85));
}
.cap-tile .ct-cap{
  position:absolute;left:1rem;right:1rem;bottom:1rem;
  color:var(--cream-100);z-index:2;
  font-family:var(--font-display);font-style:italic;
  font-size:1.05rem;
}
.cap-tile.fallback{
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--green-700), var(--green-900));
}
.cap-tile.fallback::after{display:none;}
.cap-tile.fallback .ct-cap{position:static;text-align:center;}
.cap-tile:hover{transform:scale(1.03);}

/* ========== FOOTER ========== */
.footer{background:var(--green-900);color:var(--cream-200);padding:5rem 0 0;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:3rem;padding-bottom:3rem;}
.brand-footer{color:var(--cream-100);margin-bottom:1rem;}
.footer-tag{font-family:var(--font-display);font-style:italic;color:var(--cream-300);max-width:300px;}
.footer h5{font-size:.85rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-400);margin:0 0 1.2rem;font-family:var(--font-body);font-weight:600;}
.footer ul{display:grid;gap:.5rem;}
.footer ul li,.footer ul li a{font-size:.92rem;color:var(--cream-200);transition:color .25s var(--ease);}
.footer ul li a:hover{color:var(--gold-400);}
.footer p{margin:0;line-height:1.7;font-size:.92rem;}
.footer-bar{
  border-top:1px solid rgba(255,255,255,.08);
  padding:1.5rem 2rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  max-width:var(--container);margin:0 auto;
  font-size:.78rem;color:var(--cream-300);letter-spacing:.05em;
}

/* ========== MODAL ========== */
.modal{
  position:fixed;inset:0;z-index:200;
  display:none;align-items:center;justify-content:center;
  padding:2rem;
}
.modal.open{display:flex;animation: vmmIn .35s var(--ease);}
.modal-backdrop{position:absolute;inset:0;background:rgba(10,20,16,.88);backdrop-filter:blur(8px);}
.modal-shell{
  position:relative;
  width:min(1100px,100%);
  max-height:88vh;
  background:var(--surface);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;
}
.modal-close{
  position:absolute;top:1rem;right:1rem;
  width:40px;height:40px;border-radius:50%;
  background:rgba(13,33,24,.85);color:var(--cream-100);
  font-size:1.4rem;z-index:5;
  transition:background .3s var(--ease);
}
.modal-close:hover{background:var(--gold-500);color:var(--green-900);}
.modal-head{padding:1.5rem 2rem;border-bottom:1px solid var(--cream-200);}
.modal-head h3{font-size:1.6rem;color:var(--green-700);margin:0 0 .3rem;}
.modal-head p{margin:0;color:var(--ink-500);font-family:var(--font-display);font-style:italic;}
.modal-body{flex:1;overflow:auto;}
.modal-stage{
  height:520px;
  background:#0a1410;
  position:relative;overflow:hidden;
}
.modal-img{
  position:absolute;inset:0;
  background-size:contain;background-repeat:no-repeat;background-position:center;background-color:#0a1410;
  opacity:0;transition:opacity .6s var(--ease);
}
.modal-img.active{opacity:1;}
.modal-img.fallback{
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at center, rgba(201,169,97,.2), transparent 70%), #0a1410;
}
.modal-img.fallback span{
  font-family:var(--font-display);font-style:italic;color:var(--cream-200);font-size:1.4rem;letter-spacing:.05em;
}
.modal-thumbs{
  display:flex;gap:.6rem;padding:1rem 1.5rem;overflow-x:auto;
  background:var(--cream-50);border-top:1px solid var(--cream-200);
}
.modal-thumbs::-webkit-scrollbar{height:6px;}
.modal-thumbs::-webkit-scrollbar-thumb{background:var(--green-500);border-radius:3px;}
.modal-thumb{
  flex:0 0 auto;width:90px;height:64px;border-radius:6px;
  background-size:cover;background-position:center;background-color:var(--green-700);
  cursor:pointer;opacity:.55;border:2px solid transparent;
  transition:opacity .3s var(--ease), border-color .3s var(--ease);
}
.modal-thumb.active{opacity:1;border-color:var(--gold-500);}
.modal-thumb:hover{opacity:1;}

/* ========== TO TOP ========== */
.to-top{
  position:fixed;bottom:2rem;right:2rem;z-index:80;
  width:48px;height:48px;border-radius:50%;
  background:var(--green-800);color:var(--gold-400);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;
  opacity:0;visibility:hidden;
  transition:all .35s var(--ease);
  box-shadow:var(--shadow-md);
}
.to-top.show{opacity:1;visibility:visible;}
.to-top:hover{background:var(--gold-500);color:var(--green-900);}

/* ========== RESPONSIVE ========== */
@media (max-width: 1100px){
  .unit-grid{grid-template-columns:repeat(4,1fr);}
  .pub-stats{grid-template-columns:repeat(3,1fr);}
  .stat-cards{grid-template-columns:repeat(2,1fr);}
  .train-grid{grid-template-columns:repeat(2,1fr);}
  .collab-grid{grid-template-columns:repeat(3,1fr);}
  .rp-grid{grid-template-columns:repeat(3,1fr);}
  .award-row{grid-template-columns:repeat(3,1fr);}
  .cap-mosaic{grid-template-columns:repeat(3,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
}

@media (max-width: 880px){
  .section{padding:5rem 0;}
  .about-grid{grid-template-columns:1fr;gap:2.5rem;}
  .charts-grid{grid-template-columns:1fr;}
  .startup-display{grid-template-columns:1fr;}
  .milestone-grid{grid-template-columns:1fr;}
  .pub-cards{grid-template-columns:1fr;}
  .team-track{height:auto;min-height:460px;}
  .team-slide{grid-template-columns:1fr;}
  .team-img{height:200px;}
  .team-info{padding:1.6rem;}
  .roadmap-line{left:24px;}
  .roadmap-item{grid-template-columns:48px 1fr !important;}
  .roadmap-item:nth-child(even) .ri-content,
  .roadmap-item:nth-child(odd) .ri-content{grid-column:2;text-align:left;}
  .ri-dot{grid-column:1;}
}

@media (max-width: 640px){
  .unit-grid{grid-template-columns:repeat(2,1fr);}
  .pub-stats{grid-template-columns:repeat(2,1fr);}
  .stat-cards{grid-template-columns:1fr;}
  .train-grid{grid-template-columns:1fr;}
  .collab-grid{grid-template-columns:1fr 1fr;}
  .rp-grid{grid-template-columns:1fr 1fr;}
  .award-row{grid-template-columns:1fr 1fr;}
  .cap-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:160px;}
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .footer-bar{flex-direction:column;text-align:center;}
  .hero-meta{font-size:.7rem;gap:.7rem;padding:.7rem 1rem;}
  .nfx-card{width:280px;height:190px;}
  .project-card{width:90vw;}
  .modal-stage{height:300px;}
  .vmm-panel{padding:1.5rem;}
  .stat-card,.chart-card,.revenue-bars,.research-plan{padding:1.5rem;}
  .bar-row{grid-template-columns:70px 1fr 80px;gap:.7rem;}
}

/* ========== TRAINING SLIDESHOW ========== */
.training-slideshow{
  margin: 3rem auto 0;
  max-width: 1000px;
}
.ts-stage{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--cream-100);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--cream-200);
}
.ts-track{ position: absolute; inset: 0; }
.ts-slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .8s var(--ease);
  pointer-events: none;
}
.ts-slide.active{ opacity: 1; pointer-events: auto; }
.ts-slide img{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.ts-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,.85);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(13,33,24,.08);
  color: var(--green-700);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background .25s var(--ease), color .25s var(--ease), transform .25s var(--ease);
  z-index: 2;
}
.ts-btn:hover{
  background: var(--green-700);
  color: var(--cream-100);
  transform: translateY(-50%) scale(1.06);
}
.ts-prev{ left: 14px; }
.ts-next{ right: 14px; }
.ts-counter{
  position: absolute;
  top: 14px; right: 14px;
  background: rgba(13,33,24,.65);
  color: var(--cream-100);
  font-size: .72rem;
  letter-spacing: .12em;
  padding: .35rem .75rem;
  border-radius: 999px;
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  z-index: 2;
}
.ts-dots{
  display: flex;
  justify-content: center;
  gap: .55rem;
  margin-top: 1.1rem;
  flex-wrap: wrap;
}
.ts-dot{
  width: 9px; height: 9px;
  border-radius: 50%;
  border: none;
  background: var(--cream-300);
  cursor: pointer;
  transition: background .3s var(--ease), width .3s var(--ease);
  padding: 0;
}
.ts-dot.active{
  background: var(--green-500);
  width: 28px;
  border-radius: 999px;
}
.ts-dot:hover{ background: var(--green-700); }
.ts-empty{
  padding: 3rem 1rem;
  text-align: center;
  color: var(--ink-500);
  font-style: italic;
}
@media (max-width: 720px){
  .ts-btn{ width: 38px; height: 38px; }
  .ts-prev{ left: 8px; }
  .ts-next{ right: 8px; }
  .ts-counter{ font-size: .65rem; padding: .25rem .55rem; }
}
