:root{
  --bg:#ffffff;
  --fg:#111111;
  --muted:#6b6b6b;
  --line:#d3d3d3;
  --panel:#f3f3f3;
  --panel2:#ededed;
  --shadow-sm: 0 1px 0 rgba(0,0,0,.06);
  --shadow-md: 0 10px 22px rgba(0,0,0,.08);
  --radius:18px;
  --radius-lg:22px;
  --container:1120px;
  --header-h:68px;
}

body {
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  background: #f2f2ef;
  color: #121212;
  min-height: 100vh;
  padding: 26px 40px 60px;
}

header {
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.06);
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0;
  position: sticky;
  top: 0;
  z-index: 10;
  height: var(--header-h);
}

.logo {
  display: flex;
  align-items: center;
  gap: 10px;
}
.logo img {
  height: 44px;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: 8px;
}
.logo-mark {
  font-family: "Quicksand", "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.6px;
}

nav ul {
  list-style: none;
  display: flex;
  gap: 32px;
  font-size: 15px;
  font-family: "Quicksand", "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  align-items: center;
}
nav li {
  padding: 6px 0;
  position: relative;
}
nav li:hover::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 2px;
  background: #121212;
}
nav .nav-docent {
  background: #0a0a0a;
  color: #fff;
  padding: 10px 18px;
  border-radius: 999px;
  font-weight: 600;
  transition: background 0.2s ease, transform 0.2s ease;
}
nav .nav-docent:hover {
  background: #333;
  transform: translateY(-1px);
}
nav li:has(.nav-docent):hover::after {
  display: none;
}

.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 42px;
  height: 42px;
  border-radius: 10px;
  border: 1px solid #dcd5cf;
  background: #fff;
  cursor: pointer;
  padding: 8px;
  transition: background 0.2s ease, box-shadow 0.2s ease;
}
.menu-toggle span {
  display: block;
  height: 2px;
  width: 100%;
  background: #121212;
  border-radius: 999px;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.menu-toggle:hover {
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
}
.menu-toggle.open span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
.menu-toggle.open span:nth-child(2) {
  opacity: 0;
}
.menu-toggle.open span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--fg);
  background:var(--bg);
  line-height:1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *, *::before, *::after{animation:none !important; transition:none !important}
}

a{color:inherit; text-decoration:none}

.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:12px;
  top:12px;
  width:auto;
  height:auto;
  padding:10px 12px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:10px;
}

.container{
  max-width:var(--container);
  padding:0 20px;
  margin:0 auto;
}

.container-wide{max-width:1200px}

.site-header{
  position:sticky;
  top:0;
  z-index:10;
  background:rgba(255,255,255,.9);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
  box-shadow:0 6px 18px rgba(0,0,0,.04);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  height:var(--header-h);
}

.brand-mark{
  font-weight:700;
  letter-spacing:.06em;
  font-size:12px;
}

.brand-link{display:inline-flex; align-items:center; gap:10px}
.brand-logo{
  height:34px;
  width:auto;
  display:block;
  object-fit:contain;
}

.nav{
  display:flex;
  gap:18px;
  align-items:center;
}
.nav-link{
  font-size:14px;
  color:#1a1a1a;
  opacity:.85;
  letter-spacing:.02em;
  position:relative;
  padding:10px 2px;
  transition:opacity .2s ease;
}
.nav-link:hover{opacity:1}
.nav-link:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:2px;
  height:1px;
  background:#111;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .22s ease;
  opacity:.55;
}
.nav-link:hover:after{transform:scaleX(1)}
.nav-link.is-active{opacity:1}
.nav-link.is-active:after{transform:scaleX(1); opacity:.9}

.hero{
  height:calc(100svh - var(--header-h));
  min-height:calc(100svh - var(--header-h));
  padding:12px 0;
  display:flex;
}
.hero > .container{
  display:flex;
  flex-direction:column;
  flex:1;
  min-height:100%;
}
.hero-card{padding-top:0}
.hero-banner{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  min-height:0;
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow-md);
}
.hero-img{
  width:100%;
  height:clamp(320px, 50vh, 550px);
  display:block;
  object-fit:cover;
  object-position: center top;
  background:var(--panel);
  filter:saturate(.95) contrast(.98);
}

.hero-overlay{
  position:absolute;
  inset:0;
  padding:28px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.hero-overlay:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.18) 0%,
    rgba(0,0,0,.06) 35%,
    rgba(0,0,0,.12) 100%
  );
}
.hero-overlay > *{position:relative}
.hero-kicker{
  color:#9a9a9a;
  font-size:14px;
  letter-spacing:.02em;
}
.hero-title{
  font-size:clamp(34px, 5vw, 56px);
  font-weight:600;
  letter-spacing:.02em;
  color:#f7f7f7;
  text-shadow:0 1px 0 rgba(0,0,0,.10);
}

.hero-below{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:18px;
  margin-top:12px;
  align-items:center;
  flex:1;
  min-height:0;
}

.intro-title{
  margin:0;
  font-size:18px;
  line-height:1.55;
  font-weight:600;
  max-width:620px;
}
.intro-sub{
  margin:12px 0 0;
  color:var(--muted);
  font-size:15px;
  line-height:1.5;
  max-width:620px;
}
.intro-sub strong{color:#1a1a1a; font-weight:700}

.intro-text{
  margin:12px 0 0;
  color:#2a2a2a;
  font-size:15px;
  line-height:1.55;
  max-width:620px;
}

.collage{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  grid-template-rows: 1fr 1fr;
  gap:14px;
  min-height:clamp(170px, 24vh, 260px);
}
.tile{
  position:relative;
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-md);
  height:100%;
}

.tile-img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  background:var(--panel2);
}

/* Hero collage (clean grid; straight tiles) */
.tile-hero-a{grid-column:1; grid-row:1 / span 2}
.tile-hero-b{grid-column:2; grid-row:1}
.tile-hero-c{grid-column:2; grid-row:2}

@media (prefers-reduced-motion: no-preference){
  .tile-hero-a, .tile-hero-b, .tile-hero-c,
  .athletic-tile-a, .athletic-tile-b, .athletic-tile-c{
    animation:floaty 8s ease-in-out infinite;
    will-change:transform;
  }
  .tile-hero-b, .athletic-tile-b{animation-delay:-2s}
  .tile-hero-c, .athletic-tile-c{animation-delay:-4s}
}

/* Keep the hero collage straight (no rotation/float) */
.tile-hero-a, .tile-hero-b, .tile-hero-c{
  --r:0deg;
  animation:none !important;
  transform:none !important;
}

@keyframes floaty{
  0%,100%{transform:translateY(0) rotate(var(--r, 0deg))}
  50%{transform:translateY(-6px) rotate(var(--r, 0deg))}
}

.tile-hero-a{--r:0deg}
.tile-hero-b{--r:0deg}
.tile-hero-c{--r:0deg}
.athletic-tile-a{--r:10deg}
.athletic-tile-b{--r:-6deg}
.athletic-tile-c{--r:6deg}

.section{padding:44px 0}
.section-alt{border-top:1px solid var(--line)}

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
}
.section-head.split{align-items:center}
 .section-head.center{justify-content:center; align-items:center}

.section-title{
  margin:0;
  font-size:clamp(26px, 3.6vw, 44px);
  line-height:1.05;
  letter-spacing:.01em;
}
.section-kicker{
  margin-top:8px;
  color:var(--muted);
  font-size:clamp(18px, 2.2vw, 26px);
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  font-style:italic;
  letter-spacing:0;
}
.muted{color:var(--muted); font-weight:500}

.rule{flex:1; height:1px; background:var(--line)}

.blog-heading{
  font-size:16px;
  letter-spacing:.18em;
  font-weight:700;
}

/* Athletic header layout (title left, tiles right) */
.athletic-layout{
  display:grid;
  grid-template-columns: 1fr;
  gap:22px;
  align-items:start;
}
.athletic-left{min-width:0}
.athletic-title{display:flex; flex-direction:column; align-items:flex-start}
.athletic-body{max-width:620px}

.athletic-tiles{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
  align-content:start;
  margin-top:18px;
}
.athletic-tile{
  position:relative;
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-md);
  width:100%;
  aspect-ratio: 16 / 10;
  transform:none;
  animation:none;
}
.athletic-tile-a, .athletic-tile-b{--r:0deg}
.athletic-tile-a .tile-img{object-position:50% 45%}
.athletic-tile-b .tile-img{object-position:50% 55%}
.athletic-copy{
  margin:0;
  max-width:620px;
  font-size:15px;
  line-height:1.55;
  color:#2a2a2a;
}
.athletic-copy + .athletic-copy{margin-top:12px}


.spotlight{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:20px;
}
.spotlight-card{
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-sm);
  transition:transform .22s ease, box-shadow .22s ease;
}
.spotlight-card:hover{transform:translateY(-2px); box-shadow:0 14px 30px rgba(0,0,0,.08)}
.spotlight-media{
  height:280px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--panel2);
  overflow:hidden;
}
.spotlight-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.play{
  width:56px;
  height:56px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.15);
  background:#fff;
  cursor:pointer;
  position:relative;
  z-index:1;
  box-shadow:0 10px 22px rgba(0,0,0,.14);
  transition:transform .18s ease, box-shadow .18s ease;
}
.play:hover{transform:scale(1.03); box-shadow:0 14px 30px rgba(0,0,0,.18)}
.play.play-pulse{transform:scale(.96)}
.play:before{
  content:"";
  position:absolute;
  left:23px;
  top:18px;
  width:0;
  height:0;
  border-top:10px solid transparent;
  border-bottom:10px solid transparent;
  border-left:14px solid #111;
}
.spotlight-caption{
  padding:16px 16px 18px;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
  letter-spacing:.01em;
}

/* Blog (single featured card like reference) */
.blog-feature{
  display:grid;
  grid-template-columns: 220px 1fr;
  gap:22px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  box-shadow:var(--shadow-sm);
  align-items:center;
  transition:transform .22s ease, box-shadow .22s ease;
}
.blog-feature:hover{transform:translateY(-2px); box-shadow:0 14px 30px rgba(0,0,0,.08)}
.blog-feature-media{
  width:100%;
  height:170px;
  border-radius:14px;
  display:block;
  object-fit:cover;
  background:var(--panel2);
}
.blog-feature-content{
  display:grid;
  grid-template-columns: minmax(220px, 320px) 1fr;
  gap:22px;
  align-items:start;
}
.blog-feature-title{
  margin:0;
  font-family: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
  font-weight:500;
  letter-spacing:.02em;
  font-size:28px;
  line-height:1.1;
}
.blog-feature-text{
  margin:0;
  color:#2a2a2a;
  font-size:15px;
  line-height:1.55;
}

/* Scroll reveal */
.reveal{opacity:0; transform:translateY(14px);}
.reveal.reveal-in{opacity:1; transform:translateY(0); transition:opacity .6s ease, transform .6s ease}

.footer{
  border-top:1px solid var(--line);
  padding:28px 0;
}
.footer-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
}
.footer-right{display:flex; gap:18px}

/* ===================== TABLET (max-width: 960px) ===================== */
@media (max-width: 960px) {
  body {
    padding: 18px;
  }
  header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: nowrap;
  }
  nav ul {
    gap: 18px;
    flex-wrap: wrap;
  }
  .menu-toggle {
    display: inline-flex;
    margin-left: auto;
    order: 2;
    align-self: center;
  }
  nav {
    width: auto;
    order: 3;
    position: relative;
  }
  nav ul {
    width: min(360px, 100vw - 24px);
    flex-direction: column;
    gap: 12px;
    padding: 12px 14px 10px;
    display: none;
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    left: auto;
    margin-left: auto;
    margin-right: 0;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.12);
    z-index: 100;
  }
  nav ul.open {
    display: flex;
  }
  .hero {
    height: auto;
    min-height: auto;
  }
  .hero-below {
    grid-template-columns: 1fr;
  }
  .collage {
    min-height: 260px;
  }
  .athletic-layout {
    grid-template-columns: 1fr;
  }
  .blog-feature {
    grid-template-columns: 180px 1fr;
  }
  .blog-feature-content {
    grid-template-columns: 1fr;
  }
  .spotlight {
    grid-template-columns: 1fr;
  }
}

/* ===================== MOBILE (max-width: 640px) ===================== */
@media (max-width: 640px) {
  :root {
    --header-h: 60px;
  }
  
  body {
    padding: 12px;
  }
  
  header {
    gap: 10px;
    padding: 10px 14px;
    border-radius: 14px;
  }
  
  .logo img {
    height: 36px;
  }
  
  nav ul {
    gap: 10px;
    font-size: 14px;
    width: calc(100vw - 24px);
    left: 50%;
    right: auto;
    transform: translateX(-50%);
  }
  
  /* Hero Section Mobile */
  .hero {
    height: auto;
    min-height: auto;
    padding: 10px 0;
  }
  
  .hero-img {
    height: 380px;
    object-position: center top;
  }
  
  .hero-banner {
    border-radius: 16px;
  }
  
  .hero-overlay {
    padding: 16px;
  }
  
  .hero-kicker {
    font-size: 12px;
  }
  
  .hero-title {
    font-size: 28px;
  }
  
  .hero-below {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 16px;
  }
  
  .intro-title {
    font-size: 16px;
  }
  
  .intro-text,
  .intro-sub {
    font-size: 14px;
  }
  
  /* Collage Mobile */
  .collage {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    min-height: 200px;
    gap: 10px;
  }
  
  .tile-hero-a {
    grid-column: 1 / span 2;
    grid-row: 1;
  }
  
  .tile-hero-b {
    grid-column: 1;
    grid-row: 2;
  }
  
  .tile-hero-c {
    grid-column: 2;
    grid-row: 2;
  }
  
  .tile {
    border-radius: 14px;
  }
  
  .tile-hero-a .tile-img,
  .tile-hero-b .tile-img,
  .tile-hero-c .tile-img {
    height: 140px;
  }
  
  /* Sections Mobile */
  .section {
    padding: 28px 0;
  }
  
  .section-title {
    font-size: 22px;
  }
  
  .section-kicker {
    font-size: 16px;
  }
  
  .container {
    padding: 0 12px;
  }
  
  /* Athletic Section Mobile */
  .athletic-layout {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .athletic-tiles {
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 14px;
  }
  
  .athletic-tile {
    border-radius: 14px;
    aspect-ratio: 16 / 9;
  }
  
  .athletic-copy {
    font-size: 14px;
  }
  
  /* Spotlight Section Mobile */
  .spotlight {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .spotlight-card {
    border-radius: 14px;
  }
  
  .spotlight-media {
    height: 200px;
  }
  
  .play {
    width: 48px;
    height: 48px;
  }
  
  .play:before {
    left: 19px;
    top: 15px;
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-left: 12px solid #111;
  }
  
  .spotlight-caption {
    padding: 14px;
    font-size: 13px;
  }
  
  /* Blog Section Mobile */
  .blog-feature {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 16px;
    border-radius: 14px;
  }
  
  .blog-feature-media {
    height: 180px;
    border-radius: 12px;
  }
  
  .blog-feature-content {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  
  .blog-feature-title {
    font-size: 22px;
  }
  
  .blog-feature-text {
    font-size: 14px;
  }
  
  .blog-heading {
    font-size: 14px;
  }
  
  /* Footer Mobile */
  .footer {
    padding: 20px 0;
  }
  
  .footer-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 16px;
  }
  
  .footer-left {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  
  .footer-right {
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
  }
  
  .brand-logo {
    height: 28px;
  }
  
  .nav-link {
    font-size: 13px;
  }
}

/* ===================== SMALL MOBILE (max-width: 400px) ===================== */
@media (max-width: 400px) {
  body {
    padding: 8px;
  }
  
  header {
    padding: 8px 12px;
  }
  
  .logo img {
    height: 32px;
  }
  
  .hero-img {
    height: 320px;
  }
  
  .hero-title {
    font-size: 24px;
  }
  
  .collage {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
  }
  
  .tile-hero-a {
    grid-column: 1;
    grid-row: 1;
  }
  
  .tile-hero-b {
    grid-column: 1;
    grid-row: 2;
  }
  
  .tile-hero-c {
    grid-column: 1;
    grid-row: 3;
  }
  
  .tile-hero-a .tile-img,
  .tile-hero-b .tile-img,
  .tile-hero-c .tile-img {
    height: 120px;
  }
  
  .section-title {
    font-size: 20px;
  }
  
  .blog-feature-title {
    font-size: 20px;
  }
}
