/* === Minimal, safe styles to support the updated content without changing your brand === */
:root{
  /* Brand */
  --primary: #0A2540;           /* Dark blue */
  --primary-2: #081a2c;         /* Darker blue for gradient depth */
  --accent: #FFB703;            /* Yellow/Orange highlight */
  --accent-contrast: #0A2540;   /* Dark text on yellow/orange */

  --bg-soft: #F5F7FB;
  --text: #0B1220;
  --muted: #5B6472;
  --white: #fff;

  --blue-grad: linear-gradient(135deg, var(--primary), var(--primary-2));
}
:root{
  --primary: #0A2540;
  --primary-2: #183B6A;
  --accent: #FFB703;     /* yellow/orange */
  --accent-2: #FF8E00;

  --blue-grad: linear-gradient(135deg, var(--primary), var(--primary-2));
  --accent-grad: linear-gradient(135deg, var(--accent), var(--accent-2));
}

/* Clean list look (no markers), headline + subline like your screenshot */
.bullets{list-style:none;margin:.75rem 0 0;padding:0;display:grid;gap:.6rem}
.bullets li{margin:0}
.bullets li strong{display:block;font-weight:800;margin-bottom:.15rem}
.bullets li span{display:block;opacity:.95}

/* Base card */
.cards-tight .card{
  border:1px solid #E8EEF7;border-radius:18px;padding:1.25rem;
  box-shadow:0 8px 22px rgba(10,37,64,.06);
  transition:
    background .35s ease, color .35s ease, border-color .35s ease,
    transform .25s ease, opacity .7s ease, clip-path .6s ease;
}

/* BLUE cards (left & right): default gradient + white text; hover -> white */
.card--blue{
  background: var(--blue-grad);
  color:#fff;border-color:transparent;
}
.card--blue .muted{color:#e9f2ff}
.card--blue .bullets li span{color:#eaf2ff}
.card--blue .bullets li strong{color:#fff}
.card--blue:hover{
  background:#fff;color:var(--text);border-color:#E8EEF7;
}
.card--blue:hover .muted{color:var(--muted)}
.card--blue:hover .bullets li span{color:inherit}
.card--blue:hover .bullets li strong{color:inherit}

/* ACCENT card (middle): default yellow/orange gradient + white text; hover -> white */
.card--accent{
  background: var(--accent-grad);
  color:#0A2540; /* ensures headings pass contrast on warm bg */
  color:#fff;    /* final desired look: white text on warm bg */
  border-color:transparent;
}
.card--accent .muted{color:#FFF4D6}
.card--accent .bullets li span{color:#FFF7E3}
.card--accent .bullets li strong{color:#fff}
.card--accent:hover{
  background:#fff;color:var(--text);border-color:#E8EEF7;
}
.card--accent:hover .muted{color:var(--muted)}
.card--accent:hover .bullets li span{color:inherit}
.card--accent:hover .bullets li strong{color:inherit}

/* Subtle hover lift for all */
.cards-tight .card:hover{transform:translateY(-2px)}

/* ===== Reveal on scroll ===== */
.cards-tight .card.reveal{
  opacity:0; transform: translateY(22px);
}
.cards-tight .card.reveal.reveal-in{
  opacity:1; transform: translateY(0);
}

/* Small stagger */
.cards-tight .card.reveal:nth-child(1){ transition-delay: .05s; }
.cards-tight .card.reveal:nth-child(2){ transition-delay: .15s; }
.cards-tight .card.reveal:nth-child(3){ transition-delay: .25s; }


*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text)}
h1,h2,h3,h4,h5{margin:0 0 .5rem}
p{line-height:1.65;margin:0 0 1rem}
a{color:var(--primary);text-decoration:none}
.container{width:min(1100px,92vw);margin:0 auto}

/* ===== NAV ===== */
.main-nav{position:sticky;top:0;background:var(--white);z-index:50;border-bottom:1px solid #E6EAF0}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;gap:1rem}
.brand{display:flex;align-items:center;gap:.5rem;color:var(--text);font-weight:700}
.brand-mark{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:10px;background:var(--primary);color:#fff;font-weight:800}
.brand-text{letter-spacing:.2px}
.hamburger{display:none;background:none;border:0;padding:.35rem}
.hamburger span{display:block;width:24px;height:2px;background:#2A2F3A;margin:5px 0;border-radius:2px}
#mainmenu .nav-links{display:flex;align-items:center;gap:.5rem;list-style:none;margin:0;padding:0}
#mainmenu .nav-links a{padding:.5rem .65rem;border-radius:10px;font-size:.95rem;line-height:1.2}
#mainmenu .nav-links li.push-right{margin-left:auto}
.join-link,.login-link{font-weight:600;letter-spacing:.2px}

/* Buttons */
.btn{
  display:inline-block;font-weight:700;border-radius:12px;padding:.75rem 1.05rem;
  transition:transform .12s ease,box-shadow .12s ease, background .2s ease, color .2s ease, border-color .2s ease;
  box-shadow:0 6px 18px rgba(10,37,64,.06);
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--primary);color:#fff;border:1px solid transparent}
.btn-primary:hover{background:var(--primary-2)}
.btn-accent{background:var(--accent);color:var(--accent-contrast);border:1px solid rgba(0,0,0,.03)}
.btn-accent:hover{filter:brightness(.95)}
.btn-ghost{background:transparent;border:1px dashed #CBD4E1;color:var(--primary)}
.btn-ghost:hover{border-style:solid}

/* ===== HERO SLIDER ===== */
.hero{position:relative;background:linear-gradient(180deg,#fff,var(--bg-soft))}
.slider-wrap{position:relative;padding:1.5rem 0 2.25rem}
.slider{display:grid;grid-auto-flow:column;grid-auto-columns:100%;gap:1rem;overflow:hidden;scroll-behavior:smooth}
.slide{display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:1rem;min-height:58vh;padding:1rem}
.slide-media img,.slide-media video,.slide-media .yt{width:100%;height:100%;object-fit:cover;border-radius:18px;border:1px solid #E8EEF7}
.slide-content{background:#ffffffcc;backdrop-filter:blur(6px);border:1px solid #E8EEF7;border-radius:18px;padding:1rem 1.25rem;box-shadow:0 10px 30px rgba(10,37,64,.06)}
.kicker{color:var(--primary);font-weight:800;letter-spacing:.25px;margin-bottom:.5rem;text-transform:uppercase}
.muted{color:var(--muted)}
.cta-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}

.slider-btn{position:absolute;top:50%;transform:translateY(-50%);border:0;background:#fff;width:42px;height:42px;border-radius:12px;box-shadow:0 6px 20px rgba(0,0,0,.08);cursor:pointer}
.slider-btn.prev{left:.5rem}
.slider-btn.next{right:.5rem}
.slider-dots{display:flex;gap:.4rem;justify-content:center;margin-top:1rem}
.slider-dots button{width:8px;height:8px;border-radius:6px;border:0;background:#C7D2E1}
.slider-dots button.active{width:22px;background:var(--primary)}

/* ===== Sections & Layout ===== */
.section{padding:3rem 0;background:#fff}
.section.bg-soft{background:var(--bg-soft)}
.section-intro h3.center{text-align:center}
.section-intro .large{max-width:980px;margin:.65rem auto 0;text-align:center}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.sm-grid-2{grid-template-columns:repeat(2,1fr)}
.cards-tight .card{padding:1.1rem}
.card{
  border:1px solid #E8EEF7;border-radius:16px;padding:1.25rem;background:#fff;
  box-shadow:0 8px 22px rgba(10,37,64,.05);
  transition:background .25s ease, color .25s ease, border-color .25s ease, transform .2s ease;
}
.card:hover{transform:translateY(-2px)}
.bullets{margin:.5rem 0 0 1.15rem}
.bullets li{margin:.35rem 0}
.large{font-size:1.05rem}

/* --- Requested color behavior for the three cards --- */
/* Default: white card; on hover -> dark blue gradient & white text */
.cards-tight .card{
  background:#fff;color:var(--text);
}
.cards-tight .card:hover{
  background:var(--blue-grad);
  color:#fff;border-color:transparent;
}
.cards-tight .card:hover .muted{color:#e9f2ff}
.cards-tight .card:hover a{color:#fff}
.cards-tight .card:hover .bullets li{color:#f3f7ff}
.cards-tight .card:hover .bullets li strong{color:#fff}

/* Middle card starts dark blue gradient; on hover it flips to white */
.card--featured{
  background:var(--blue-grad);
  color:#fff;border-color:transparent;
}
.card--featured .muted{color:#e9f2ff}
.card--featured .bullets li{color:#f3f7ff}
.card--featured .bullets li strong{color:#fff}
.card--featured a{color:#fff}
.card--featured:hover{
  background:#fff;color:var(--text);border-color:#E8EEF7;
}
.card--featured:hover .muted{color:var(--muted)}
.card--featured:hover .bullets li{color:inherit}
.card--featured:hover .bullets li strong{color:inherit}

/* Mini-cards keep a clean, light look */
.bg-card{background:linear-gradient(180deg,var(--bg-soft),#fff)}
.mini-card{border:1px solid #E8EEF7;border-radius:14px;padding:1rem;background:#fff}

/* Two-col sections */
.two-col{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center}
.illus{display:grid;place-items:center}
.illus-box{width:100%;height:220px;border-radius:20px;background:var(--blue-grad);opacity:.2}

/* Video grid */
.video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:.75rem}
.video-card{border:1px solid #E8EEF7;border-radius:12px;padding:.5rem;background:#fff}
.yt{width:100%;aspect-ratio:16/9;border-radius:8px}

/* Count */
.counter-row{display:flex;justify-content:center;gap:2rem;margin-top:1rem}
.stat{display:grid;place-items:center}
.count{font-size:2rem;font-weight:800;color:var(--primary)}
.plus{font-weight:800;color:var(--primary);margin-left:.2rem}

/* Collage */
.collage{display:grid;grid-template-columns:2fr 1fr;grid-auto-rows:160px;gap:.75rem;margin-top:.75rem}
.collage .c1{background:#e6f3ff;border-radius:14px}
.collage .c2{background:#f7fbff;border-radius:14px}
.collage .c3{background:#e8eef7;border-radius:14px}
.collage .c4{background:#dff2ff;border-radius:14px}

/* Logos marquee */
.logos{background:#fff;border-top:1px solid #E6EAF0}
.marquee{display:flex;gap:2.5rem;align-items:center;overflow:hidden;white-space:nowrap;animation:scroll 25s linear infinite;padding:1rem 0}
.marquee img{height:28px;opacity:.85}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Footer */
.site-footer{background:#0C1624;color:#BFD1E3;margin-top:3rem}
.site-footer .brand-inline{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.site-footer .brand-inline .brand-mark{background:#FFDA7A;color:#0A2540} /* subtle brand echo */
.site-footer h4{color:#EAF4FF;margin:0 0 .6rem}
.footer-grid{display:grid;gap:1.5rem;grid-template-columns:1.2fr 1fr 1fr;padding:2rem 0}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:.35rem}
.foot-links a{color:#BFD1E3}
.legal{border-top:1px solid #1E2A3A}
.legal .container{padding:.9rem 0}
.legal p{margin:0;color:#88A1B8}

/* ===== Responsive ===== */
@media (max-width: 1100px){
  .video-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 960px){
  .grid-3{grid-template-columns:1fr}
  .grid-4,.sm-grid-2{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
  .hamburger{display:block}
  #mainmenu{position:fixed;inset:56px 0 auto 0;background:#fff;border-bottom:1px solid #E6EAF0;transform:translateY(-110%);transition:transform .2s ease}
  #mainmenu.open{transform:translateY(0)}
  #mainmenu .nav-links{flex-direction:column;align-items:flex-start;padding:.75rem 1rem 1rem}
  .slider-btn{display:none}
  .slide{grid-template-columns:1fr}
  .video-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 540px){
  .video-grid{grid-template-columns:1fr}
}

/* Motion preference */
@media (prefers-reduced-motion: reduce){
  .marquee{animation-duration:0.001s}
  .btn, .card{transition:none}
}
/* ====== TYPOGRAPHY UPGRADE (mockup style) ====== */
html, body {
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}
h1, h2, h3, h4, h5 {
  font-family: Poppins, Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  letter-spacing: .2px;
}
h1, h2 { font-weight: 800; }
h3 { font-weight: 700; }

/* Subtle nav style similar to mockup */
#mainmenu .nav-links a {
  font-weight: 600;
  letter-spacing: .4px;
  opacity: .95;
}

/* ====== BRAND & GRADIENTS ====== */
:root{
  --primary: #0A2540;         /* dark blue */
  --primary-2: #183B6A;       /* deeper blue for gradient depth */
  --accent: #FFB703;          /* yellow/orange */
  --accent-2: #FF8E00;        /* deeper orange for gradient depth */

  --blue-grad: linear-gradient(135deg, var(--primary), var(--primary-2));
  --accent-grad: linear-gradient(135deg, var(--accent), var(--accent-2));
}

/* ====== BUTTONS: pill, gradient filled + outline (mockup) ====== */
.btn{
  border-radius: 999px;                 /* pill */
  padding: .85rem 1.25rem;
  font-weight: 700;
  letter-spacing: .2px;
  box-shadow: 0 10px 24px rgba(10,37,64,.12);
  transition: transform .12s ease, box-shadow .12s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 12px 28px rgba(10,37,64,.16); }

/* Primary = filled dark-blue gradient (like JOIN US in mockup) */
.btn-primary{
  background: var(--blue-grad);
  color: #fff;
  border: 0;
}
.btn-primary:hover{ filter: brightness(1.05); }

/* Accent = outline yellow/orange (like SIGN UP in mockup) */
.btn-accent{
  background: transparent;
  color: var(--accent-2);
  border: 2px solid var(--accent);
  box-shadow: 0 10px 24px rgba(255, 142, 0, .12);
}
.btn-accent:hover{
  background: var(--accent-grad);
  color: #0A2540;   /* dark text on warm background */
  border-color: transparent;
  box-shadow: 0 12px 28px rgba(255, 142, 0, .2);
}

/* Optional ghost (kept consistent) */
.btn-ghost{
  background: transparent;
  border: 1px dashed #CBD4E1;
  color: var(--primary);
  border-radius: 999px;
}

/* Ensure CTA rows breathe a bit more (mockup spacing) */
.cta-row { gap: .8rem; }

/* Accessibility focus */
.btn:focus-visible {
  outline: 3px solid rgba(14, 177, 255, .35);
  outline-offset: 2px;
}
/* ==== OVERRIDES: Cards default white; hover to gradients ==== */

/* default state for all three cards */
.cards-tight .card,
.card--blue,
.card--accent{
  background:#fff !important;
  color:var(--text) !important;
  border-color:#E8EEF7 !important;
}
.card--blue .muted,
.card--accent .muted{ color:var(--muted) !important; }
.card--blue .bullets li strong,
.card--accent .bullets li strong{ color:inherit !important; }
.card--blue .bullets li span,
.card--accent .bullets li span{ color:inherit !important; }

/* hover: left & right -> dark light blue gradient with white text */
.card--blue:hover{
  background: var(--blue-grad) !important;
  color:#fff !important;
  border-color:transparent !important;
}
.card--blue:hover .muted,
.card--blue:hover .bullets li strong,
.card--blue:hover .bullets li span{ color:#fff !important; }

/* hover: middle -> yellow/orange gradient with white text */
.card--accent:hover{
  background: var(--accent-grad) !important;
  color:#fff !important;
  border-color:transparent !important;
}
.card--accent:hover .muted,
.card--accent:hover .bullets li strong,
.card--accent:hover .bullets li span{ color:#fff !important; }

/* Coaching overview heading ~2x bigger than your normal h3 */
.section.bg-card h3 {
  font-size: clamp(2rem, 4.2vw, 2.8rem);
  line-height: 1.15;
}

/* Mini-card styling upgrades */
.mini-card{
  border:1px solid #E8EEF7;
  border-radius:16px;
  padding:1rem 1.1rem;
  background:#fff;
  box-shadow:0 8px 20px rgba(10,37,64,.05);
  transition:
    background .35s ease, color .35s ease, border-color .35s ease,
    transform .25s ease, opacity .6s ease;
}

/* Hover: all mini-cards go to blue gradient with white text */
.mini-card:hover{
  background: var(--blue-grad);
  color:#fff;
  border-color: transparent;
  transform: translateY(-2px);
}
.mini-card:hover h5,
.mini-card:hover p{ color:#fff; }

/* Reveal animation (2 cards slide from left, 2 from right) */
.reveal-left, .reveal-right { opacity:0; }
.reveal-left  { transform: translateX(-26px); }
.reveal-right { transform: translateX( 26px); }
.reveal-in { opacity:1; transform: translateX(0); }

/* Small stagger so they don't pop at once */
.grid-4 .mini-card:nth-child(1){ transition-delay: .05s; }
.grid-4 .mini-card:nth-child(2){ transition-delay: .15s; }
.grid-4 .mini-card:nth-child(3){ transition-delay: .25s; }
.grid-4 .mini-card:nth-child(4){ transition-delay: .35s; }

/* Motion safety */
@media (prefers-reduced-motion: reduce){
  .reveal-left, .reveal-right { transform:none; opacity:1; }
  .mini-card { transition: none; }
}
/* Image card style for the right column pictures */
.illus-img{
  width: 100%;
  aspect-ratio: 16 / 10;          /* nice landscape crop */
  object-fit: cover;
  border-radius: 20px;
  border: 1px solid #E8EEF7;
  box-shadow: 0 10px 26px rgba(10,37,64,.10);
  transition: transform .25s ease, box-shadow .25s ease;
}

/* Slight lift on hover to match the panels */
.illus-img:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(10,37,64,.16);
}

/* When stacked on mobile, give the image breathing room */
@media (max-width: 960px){
  .illus{ margin-top: .75rem; }
  .illus-img{ aspect-ratio: 16 / 11; }
}
/* Bigger titles for these sections (same scale as Coaching overview) */
.title-xl{ font-size: clamp(2rem, 4.2vw, 2.8rem); line-height: 1.12; letter-spacing:.2px; margin-bottom:.6rem; }

/* Plain content panel (no border/background) to match screenshot style */
.panel--plain{ background:transparent; border:0; box-shadow:none; padding:0; }
.panel--plain:hover{ transform:none; box-shadow:none; }

/* Black headings + grey body copy (as in screenshots) */
.bullets.clean li strong,
.panel--plain h3, .panel--plain h4, .panel--plain h5{ color: var(--text); }
.bullets.clean li span,
.panel--plain .body-muted{ color: var(--muted); }

/* Right-side images */
.illus-img{
  width:100%; aspect-ratio: 16/10; object-fit:cover;
  border-radius:20px; border:1px solid #E8EEF7;
  box-shadow:0 10px 26px rgba(10,37,64,.10);
  transition: transform .25s ease, box-shadow .25s ease;
}
.illus-img:hover{ transform:translateY(-2px); box-shadow:0 14px 28px rgba(10,37,64,.16); }

@media (max-width:960px){
  .illus{ margin-top:.75rem; }
  .illus-img{ aspect-ratio: 16/11; }
}
/* Slight hover lift on video cards */
.video-card{
  transition: transform .2s ease, box-shadow .2s ease;
}
.video-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(10,37,64,.08);
}
.events-grid{ align-items:start; }

.event-card{
  background:#fff;
  border:1px solid #E8EEF7;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 22px rgba(10,37,64,.06);
  transition: transform .2s ease, box-shadow .2s ease;
}
.event-card:hover{ transform:translateY(-3px); box-shadow:0 12px 28px rgba(10,37,64,.10); }

.event-media{ position:relative; }
.event-img{ width:100%; aspect-ratio: 16/9; object-fit:cover; display:block; }
.badge{
  position:absolute; left:12px; top:12px;
  background: var(--blue-grad); color:#fff;
  font-weight:700; font-size:.78rem; padding:.3rem .55rem; border-radius:999px;
}
.date-pill{
  position:absolute; right:12px; top:12px;
  background:#fff; color:var(--text); border:1px solid #E8EEF7;
  border-radius:12px; padding:.25rem .45rem; display:grid; place-items:center; line-height:1;
}
.date-pill strong{ font-size:.95rem; display:block; }
.date-pill span{ font-size:.7rem; color:var(--muted); display:block; }

.event-body{ padding: .9rem 1rem 1.05rem; }
.event-body h4{ margin:0 0 .25rem; }

.meta{
  list-style:none; display:flex; flex-wrap:wrap; gap:.65rem 1rem;
  padding:0; margin:.5rem 0 .75rem;
  color:var(--muted); font-weight:600;
}
.meta li{ position:relative; padding-left:0; }

@media (max-width:960px){
  .grid-3.events-grid{ grid-template-columns:1fr; }
}
/* ===== Events collage ===== */
.event-collage{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 120px;
  grid-auto-flow: dense;
  gap:.75rem;
}
.event-collage .tile{
  position:relative; overflow:hidden; border-radius:16px;
  border:1px solid #E8EEF7; box-shadow:0 8px 22px rgba(10,37,64,.06);
  transition:transform .25s ease, box-shadow .25s ease;
}
.event-collage .tile img{ width:100%; height:100%; object-fit:cover; display:block; }

/* size variants for mosaic */
.event-collage .tile.wide{ grid-column: span 3; grid-row: span 1; }
.event-collage .tile.tall{ grid-column: span 2; grid-row: span 2; }
.event-collage .tile.big { grid-column: span 3; grid-row: span 2; }

/* hover */
.event-collage .tile:hover{ transform:translateY(-2px); box-shadow:0 12px 28px rgba(10,37,64,.10); }
.event-collage .tile:hover img{ transform:scale(1.03); }

/* responsive */
@media (max-width: 960px){
  .event-collage{ grid-template-columns: repeat(4, 1fr); grid-auto-rows: 110px; }
  .event-collage .tile.big{ grid-column: span 4; grid-row: span 2; }
  .event-collage .tile.wide{ grid-column: span 4; }
  .event-collage .tile.tall{ grid-column: span 2; grid-row: span 2; }
}
@media (max-width: 540px){
  .event-collage{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 110px; }
  .event-collage .tile.big,
  .event-collage .tile.wide{ grid-column: span 2; }
  .event-collage .tile.tall{ grid-column: span 2; grid-row: span 2; }
}
/* Stacked slider container */
.stack-rotator{
  position:relative;
  padding: .25rem 3.5rem;         /* space for nav buttons */
}
.stack{
  position:relative;
  height: 360px;                  /* adjust height as needed */
  list-style:none; margin:0; padding:0;
}
.stack-card{
  position:absolute; inset:0;
  display:grid; place-items:center;
  border-radius:18px;
  overflow:hidden;
  border: 10px solid #fff;        /* "polaroid" frame */
  background:#fff;
  box-shadow: 0 12px 26px rgba(10,37,64,.18);
  transform-origin:center;
  transition: transform .6s ease, opacity .6s ease, filter .6s ease;
  opacity:0; pointer-events:none;
}
.stack-card img{ width:100%; height:100%; object-fit:cover; }

/* States: front, right, left, back */
.stack-card.pos0{                 /* FRONT */
  opacity:1; pointer-events:auto;
  transform: translate(0,0) scale(1) rotate(0deg);
  z-index: 4; filter:none;
  box-shadow: 0 16px 36px rgba(10,37,64,.22);
}
.stack-card.pos1{                 /* RIGHT / DOWN */
  opacity:1;
  transform: translate(16%, 8%) scale(.94) rotate(4deg);
  z-index: 3; filter:brightness(.96) saturate(.96);
}
.stack-card.pos2{                 /* LEFT / DOWN */
  opacity:1;
  transform: translate(-16%, 10%) scale(.92) rotate(-4deg);
  z-index: 2; filter:brightness(.92) saturate(.92);
}
.stack-card.pos3{                 /* BACK */
  opacity:.85;
  transform: translate(0, 22%) scale(.88) rotate(.8deg);
  z-index: 1; filter:brightness(.88) saturate(.9);
}

/* Nav buttons */
.stack-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border:0; cursor:pointer;
  border-radius:12px; background:#fff;
  box-shadow:0 8px 22px rgba(0,0,0,.12);
}
.stack-nav.prev{ left:.25rem }
.stack-nav.next{ right:.25rem }

/* Responsive */
@media (max-width: 960px){
  .stack{ height: 260px; }
  .stack-rotator{ padding: .25rem 2.5rem; }
}
@media (max-width: 540px){
  .stack{ height: 220px; }
  .stack-nav{ display:none; }    /* swipe/auto-only on small screens */
}
/* Center the rotator button below the stack */
#events-stack .stack-rotator{ padding: 0 0 3.25rem; } /* room for button */
#events-stack .stack-nav{
  position:absolute; left:50%; right:auto; top:auto; bottom:.5rem;
  transform:translateX(-50%);
  width:46px; height:46px; border:0; border-radius:12px;
  background:#fff; box-shadow:0 10px 24px rgba(0,0,0,.12); cursor:pointer;
}
#events-stack .stack-nav.prev{ display:none; } /* hide left button; one centered btn */

/* Make the 4 visible layers distinct */
#events-stack .stack-card.pos0{ z-index:4; opacity:1; transform: translate(0,0) scale(1) rotate(0deg); }
#events-stack .stack-card.pos1{ z-index:3; opacity:1; transform: translate(16%,6%) scale(.95) rotate(4deg); }
#events-stack .stack-card.pos2{ z-index:2; opacity:1; transform: translate(-16%,8%) scale(.93) rotate(-4deg); }
#events-stack .stack-card.pos3{ z-index:1; opacity:.9; transform: translate(0,16%) scale(.9) rotate(.8deg); }
/* ===== Nav refinements ===== */
:root{
  --light-blue: #87D8FF; /* hover color for nav items */
}

/* Make the nav span full width and start near screen edge */
.main-nav .container.nav-wrap{
  width: 100%;
  max-width: none;
  padding-inline: 12px;   /* slight space from edges */
}

/* Brand: show logo, hide old text/mark if still present */
.brand{ display:inline-flex; align-items:center; gap:.5rem; padding:0; }
.brand-logo{ height: 32px; width:auto; display:block; }
.brand-mark, .brand-text{ display:none !important; }

/* Tighter desktop menu so items fit one line */
#mainmenu .nav-links{
  flex-wrap: nowrap;
  gap: .35rem;            /* smaller gaps */
}
#mainmenu .nav-links a{
  font-size: .88rem;      /* smaller text */
  padding: .4rem .55rem;  /* slimmer padding */
  line-height: 1.1;
  white-space: nowrap;    /* prevent wrapping per item */
}

/* Hover color: light blue */
#mainmenu .nav-links a:hover,
#mainmenu .nav-links a:focus-visible{
  color: var(--light-blue);
}

/* Keep Join/Login pushed right */
#mainmenu .nav-links li.push-right{ margin-left:auto; }

/* Slightly tighter at medium widths to avoid second line */
@media (max-width: 1240px){
  #mainmenu .nav-links a{
    font-size: .84rem;
    padding: .35rem .45rem;
  }
  .brand-logo{ height: 28px; }
}

/* Mobile behavior unchanged (your existing 960px rules kick in) */
/* ===== Center the menu bar ===== */

/* Keep header full-width, but center the nav content */
.main-nav .container.nav-wrap{
  width: 100%;
  max-width: none;
  position: relative;
  padding-inline: 12px;      /* slight space from edges */
  display: flex;
  align-items: center;
  justify-content: center;   /* <- center the menu bar */
}

/* Pin the logo to the left so centering isn't affected */
.brand{
  position: absolute;
  left: 12px;
  display: inline-flex;
  align-items: center;
}
.brand-logo{ height: 30px; width: auto; }

/* Center the links and keep them on one line */
#mainmenu{ width: 100%; }
#mainmenu .nav-links{
  display: flex;
  justify-content: center;    /* <- center the links */
  flex-wrap: nowrap;
  gap: .4rem;                 /* tighter gaps */
}
#mainmenu .nav-links li.push-right{
  margin-left: 0;             /* neutralize old push-right */
}
#mainmenu .nav-links a{
  font-size: .84rem;          /* smaller so they don't wrap */
  padding: .35rem .5rem;
  line-height: 1.1;
  white-space: nowrap;        /* avoid wrapping per item */
}

/* Hover color to light blue (keeps your earlier request) */
:root{ --light-blue: #87D8FF; }
#mainmenu .nav-links a:hover,
#mainmenu .nav-links a:focus-visible{
  color: var(--light-blue);
}

/* Mobile: keep the hamburger reachable on the right */
@media (max-width: 960px){
  .brand{ position: static; }          /* let it flow on mobile */
  .hamburger{ position: absolute; right: 12px; }
}
/* ==== MOBILE: fully hide the menu when closed; fix "Login on top" ==== */
@media (max-width: 960px){
  /* Your off-canvas panel */
  #mainmenu{
    position: fixed;
    inset: 56px 0 auto 0;
    background:#fff;
    border-bottom:1px solid #E6EAF0;
    transform: translateY(-120%);
    transition: transform .22s ease, opacity .2s ease, visibility .2s ease;
    visibility: hidden;      /* <- prevent any stray text showing */
    opacity: 0;              /* <- fade out */
    pointer-events: none;    /* <- not clickable when closed */
    z-index: 9999;           /* <- ensure it layers above content when open */
  }
  #mainmenu.open{
    transform: translateY(0);
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  /* Stack links neatly inside the opened panel */
  #mainmenu .nav-links{
    flex-direction: column;
    align-items: flex-start;
    padding: .75rem 1rem 1rem;
    width: 100%;
  }
  #mainmenu .nav-links a{
    display: block;
    width: 100%;
    white-space: normal;
  }

  /* Keep the bar itself simple: logo left, hamburger right */
  .main-nav .container.nav-wrap{
    grid-template-columns: auto auto;    /* logo | hamburger */
  }
  .brand{ position: static; }
  .hamburger{ position: absolute; right: 12px; }
}
/* Only make hero taller; keep original behavior */
.hero .slide{ min-height: 72vh; }
@media (max-width: 960px){ .hero .slide{ min-height: 62vh; } }
/* === Keep JOIN / LOGIN on the right (desktop), prevent wrapping === */
@media (min-width: 961px){
  /* Reserve space left for logo and right for actions so the center menu truly centers */
  #mainmenu{
    position: relative;
    width: 100%;
    padding-left: 120px;   /* space for logo on the left */
    padding-right: 160px;  /* space for Join/Login on the right */
  }

  /* Center the main links */
  #mainmenu .nav-main{
    display: flex;
    justify-content: center;
    gap: .4rem;
    flex-wrap: nowrap;
  }

  /* Pin actions to the right, same row */
  #mainmenu .nav-actions{
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    gap: .45rem;
    justify-content: flex-end;
  }
  #mainmenu .nav-actions a{
    white-space: nowrap;     /* never wrap */
  }
}

/* Mobile drawer stays stacked and clean */
@media (max-width: 960px){
  #mainmenu{
    padding-left: 0;
    padding-right: 0;
  }
  #mainmenu .nav-actions{
    position: static;
    transform: none;
    gap: .35rem;
    width: 100%;
  }
}
/* ===== Footer - brand blue version ===== */
.site-footer--brand{
  background: var(--primary);          /* your brand blue */
  color: #EAF4FF;
  border-top: 1px solid rgba(255,255,255,.06);
}
.site-footer--brand .footer-grid{
  display:grid;
  gap:1.5rem;
  grid-template-columns: 1.2fr 1fr 1fr;
  padding:2rem 0;
}
.site-footer--brand h4{ color:#FFFFFF; margin:0 0 .6rem; }

.site-footer--brand .foot-links{
  list-style:none; padding:0; margin:0; display:grid; gap:.4rem;
}
.site-footer--brand .foot-links a{
  color:#CFE2F7; text-decoration:none;
}
.site-footer--brand .foot-links a:hover{ color:#9FD0FF; }

.footer-brand img{
  width:150px; height:auto; display:block; margin-bottom:.6rem;
}
.footer-tagline{ color:#CFE2F7; margin:.25rem 0 1rem; }

/* Social buttons */
.socials{ display:flex; gap:.5rem; padding:0; margin:0; list-style:none; }
.social-btn{
  width:36px; height:36px; display:grid; place-items:center;
  border-radius:999px; background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  transition:transform .15s ease, background .2s ease, border-color .2s ease;
}
.social-btn:hover{
  background:rgba(255,255,255,.18); transform:translateY(-1px);
  border-color: rgba(255,255,255,.28);
}
.social-btn svg{ width:18px; height:18px; fill:#FFFFFF; }

/* Privacy */
.site-footer--brand .privacy a{ color:#CFE2F7; }
.site-footer--brand .privacy a:hover{ color:#9FD0FF; }

/* Legal bar */
.site-footer--brand .legal{
  border-top:1px solid rgba(255,255,255,.08);
}
.site-footer--brand .legal p{ margin:0; color:#BFD1E3; }

/* Responsive */
@media (max-width: 960px){
  .site-footer--brand .footer-grid{
    grid-template-columns: 1fr;
  }
  .footer-brand img{ width:140px; }
}
/* ===== Partner Logo Ticker (full width, left   right) ===== */
.logo-ticker{
  width:100vw;
  margin-left:calc(50% - 50vw); /* break out of container -> full bleed */
  margin-right:calc(50% - 50vw);
  overflow:hidden;
  background:#fff;
  border-top:1px solid #E6EAF0;
  border-bottom:1px solid #E6EAF0;
}

.logo-track{
  display:flex;
  align-items:center;
  gap:2.25rem;                 /* spacing between logos */
  padding:0.9rem 1.25rem;
  width:max-content;           /* allow track to be wider than viewport */
  animation:ticker-ltr 36s linear infinite;  /* left   right flow */
  will-change:transform;
}

.logo-item{
  height:30px;                 /* tweak if needed */
  width:auto;
  filter:grayscale(100%);
  opacity:.6;                  /* slightly reduced by default */
  transition:opacity .2s ease, transform .2s ease;
}
.logo-item:hover{
  opacity:1;                   /* full opacity on hover */
  transform:translateY(-1px);
  /* stays grayscale so it remains monochrome; remove this comment + grayscale()
     if you want color to return on hover */
}

@keyframes ticker-ltr{
  0%   { transform: translateX(-50%); }  /* start off-screen left */
  100% { transform: translateX(0); }     /* end flush right; loops seamlessly */
}

/* Tweak spacing on small screens */
@media (max-width: 640px){
  .logo-track{ gap:1.4rem; padding:0.8rem 1rem; }
  .logo-item{ height:26px; }
}

/* Respect reduced-motion */
@media (prefers-reduced-motion: reduce){
  .logo-track{ animation:none; }
}
/* ===== Partner Logo Ticker tweaks: bigger + pause-on-hover ===== */

/* Bigger logos */
.logo-item{
  height: 40px;              /* was 30px */
  width: auto;
  filter: grayscale(100%);
  opacity: .6;
  transition: opacity .2s ease, transform .2s ease;
}
.logo-item:hover{
  opacity: 1;
  transform: translateY(-1px);
}

/* Pause animation when hovering the ticker (or any logo inside it) */
.logo-track{
  animation-play-state: running; /* explicit default */
}
.logo-ticker:hover .logo-track,
.logo-track:focus-within{         /* also pause if a logo receives keyboard focus */
  animation-play-state: paused;
}

/* Slightly larger on small screens too */
@media (max-width: 640px){
  .logo-item{ height: 32px; }    /* was 26px */
}

/*CSS BY DEEPSEEK FOR NEW PAGES*/
/* ===== SUBPAGE HERO ===== */
.hero-subpage {
  background: var(--blue-grad);
  color: #fff;
  padding: 4rem 0 3rem;
}
.hero-subpage h1 {
  font-size: clamp(2.2rem, 5vw, 3.2rem);
  margin-bottom: 1rem;
  color: #fff;
}
.hero-subpage .large {
  font-size: 1.2rem;
  opacity: 0.95;
  max-width: 700px;
}

/* ===== FORM STYLES ===== */
.form-container {
  max-width: 800px;
  margin: 0 auto;
}
.contact-form {
  margin-top: 2rem;
  background: #fff;
  border-radius: 18px;
  padding: 2rem;
  box-shadow: 0 10px 30px rgba(10,37,64,.08);
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.form-group {
  display: flex;
  flex-direction: column;
}
.form-group.full-width {
  grid-column: 1 / -1;
}
.form-group label {
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--text);
}
.form-group input,
.form-group select,
.form-group textarea {
  padding: 0.85rem;
  border: 1px solid #E8EEF7;
  border-radius: 12px;
  font-family: inherit;
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(10,37,64,.1);
}
.form-submit {
  margin-top: 1.5rem;
  text-align: center;
}

/* ===== ACTIVE NAV LINK ===== */
#mainmenu .nav-links a.active {
  color: var(--light-blue);
  background: rgba(135, 216, 255, 0.1);
}

/* ===== RESPONSIVE ADJUSTMENTS ===== */
@media (max-width: 960px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
  .hero-subpage {
    padding: 3rem 0 2rem;
  }
}
/* ===== TESTIMONIAL STYLES ===== */
.testimonial {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.testimonial-text {
  flex-grow: 1;
  margin-bottom: 1.5rem;
}
.testimonial-author h5 {
  margin-bottom: 0.25rem;
}

/* ===== PROCESS STEPS ===== */
.process-step {
  text-align: center;
  position: relative;
}
.step-number {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--blue-grad);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  margin: 0 auto 1rem;
}

/* ===== MENTOR CARDS ===== */
.mentor-card {
  text-align: center;
}
.mentor-image {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 1rem;
}
.mentor-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mentor-title {
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 0.5rem;
}
.mentor-expertise {
  font-size: 0.9rem;
  margin-bottom: 1.5rem;
  color: var(--muted);
}

/* ===== FORM STYLES ===== */
.form-container {
  max-width: 800px;
  margin: 0 auto;
}
.contact-form {
  margin-top: 2rem;
  background: #fff;
  border-radius: 18px;
  padding: 2rem;
  box-shadow: 0 10px 30px rgba(10,37,64,.08);
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.form-group {
  display: flex;
  flex-direction: column;
}
.form-group.full-width {
  grid-column: 1 / -1;
}
.form-group label {
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--text);
}
.form-group input,
.form-group select,
.form-group textarea {
  padding: 0.85rem;
  border: 1px solid #E8EEF7;
  border-radius: 12px;
  font-family: inherit;
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(10,37,64,.1);
}
.form-submit {
  margin-top: 1.5rem;
  text-align: center;
}

/* ===== ACTIVE NAV LINK ===== */
#mainmenu .nav-links a.active {
  color: var(--light-blue);
  background: rgba(135, 216, 255, 0.1);
}

/* ===== RESPONSIVE ADJUSTMENTS ===== */
@media (max-width: 960px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
  .hero-subpage {
    padding: 3rem 0 2rem;
  }
}
/* ===== HERO — FULL-BLEED, BIGGER, OVERLAY CARD (DESKTOP) ===== */
.hero.hero--fullbleed{
  padding: 0;               /* no extra space above/below */
  background: #fff;
}

/* Break out to full viewport width */
.slider-shell{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  position: relative;
}

/* Bigger with next-slide peek */
.slider{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: min(92vw, 1200px); /* “follow each other” */
  gap: 18px;                             /* peek space */
  overflow: hidden;
  scroll-behavior: smooth;
  align-items: center;
  padding: 0 12px;                       /* tiny side breathing room */
  min-height: 78vh;                      /* bigger desktop */
}

/* Each slide now just holds media + (optional) mobile card */
.slide{
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

/* 16:9 media container */
.media-16x9{
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid #E8EEF7;
  box-shadow: 0 12px 30px rgba(10,37,64,.08);
}
.media-16x9 > img,
.media-16x9 > video,
.media-16x9 > iframe{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  border: 0;
}

/* dark top-to-bottom fade for readability */
.slide-overlay{
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,25,50,.48), rgba(10,25,50,.18) 45%, rgba(10,25,50,.6));
  pointer-events: none;
}

/* Card that sits ON TOP of the media (desktop only) */
.overlay-card{
  position: absolute;
  left: 2.2rem; right: 2.2rem;
  bottom: 2.2rem;                 /* sit lower for cinematic look */
  padding: 1.15rem 1.25rem;
  color: #fff;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 16px;
  backdrop-filter: blur(8px);
  box-shadow: 0 16px 36px rgba(10,37,64,.22);
}
.overlay-card .kicker{ color:#CFE2F7; }
.overlay-card h2{ color:#fff; }
.overlay-card p{ color:#F2F7FF; }
.overlay-card .btn-primary{ background: var(--blue-grad); border:0; color:#fff; }
.overlay-card .btn-accent{ border:2px solid var(--accent); color: var(--accent-2); }

/* Dots under the slider */
.slider-dots{
  display:flex; gap:.4rem; justify-content:center;
  padding: 12px 0 14px;
}
.slider-dots button{ width:8px; height:8px; border-radius:6px; border:0; background:#C7D2E1; }
.slider-dots button.active{ width:22px; background:var(--primary); }

/* Arrows */
.slider-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border:0; cursor:pointer;
  border-radius:12px; background:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.14);
  z-index:2;
}
.slider-btn.prev{ left:12px; }
.slider-btn.next{ right:12px; }

/* ===== Mobile stays UNCHANGED behavior ===== */
.mobile-card{ display:none; }   /* hidden on desktop */

@media (max-width: 960px){
  .slider{
    grid-auto-columns: 92vw;    /* still “follow each other” */
    min-height: 62vh;           /* same as your prior mobile scale */
  }
  .slider-btn{ display:none; }  /* swipe/auto */
  /* turn OFF overlay behavior on mobile */
  .overlay-card{ display:none; }
  .slide-overlay{ display:none; }
  .mobile-card{
    display:block;
    background:#ffffffcc;
    backdrop-filter: blur(6px);
    border:1px solid #E8EEF7;
    border-radius:18px;
    padding:1rem 1.1rem;
    margin-top:.5rem;
    color: var(--text);
  }
}
/* === Global Card Hover Effect === */
.card {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  will-change: transform, box-shadow;
}

.card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 32px rgba(0,0,0,0.18);
}
/* ===== Anti-overscroll (mobile) ===== */

/* 1) Never allow horizontal overflow from full-bleed sections */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

/* 2) Contain scroll chaining (prevents inner scrollers nudging the page) */
@supports (overscroll-behavior: contain) {
  html, body { overscroll-behavior-y: contain; }     /* reduce top/bottom rubber-band in most browsers */
  .hero .slider { overscroll-behavior-x: contain; }  /* prevent sideways nudge while swiping slides */
  .stack-rotator { overscroll-behavior: contain; }
}

/* 3) Ensure full-bleed shells don’t cause width growth */
.slider-shell { overflow: hidden; }

/* 4) On mobile, remove the small side padding in the slider so it can't exceed the viewport */
@media (max-width: 960px) {
  .slider { padding: 0; }
}

/* 5) Defensive: media never exceeds its container width */
img, video, iframe { max-width: 100%; }
