/* ============ Journey Sports Group — refined editorial ============ */
:root{
  --navy:#121E40;
  --navy-deep:#0C1430;
  --navy-2:#0E1A38;
  --cream:#F1E9D6;
  --gold:#DAB45C;
  --muted:rgba(241,233,214,.56);
  --line:rgba(241,233,214,.12);
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --serif:"Newsreader",Georgia,serif;
  --pad:clamp(1.25rem,5vw,7rem);
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--navy);
  color:var(--cream);
  font-family:var(--body);
  font-weight:400;
  line-height:1.6;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--navy-deep)}

/* grain overlay */
.grain{
  position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* shared */
.eyebrow{
  font-family:var(--body);font-weight:600;font-size:.72rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
}
.section-head{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.section-title{
  font-family:var(--display);font-weight:700;
  font-size:clamp(1.9rem,4.6vw,3.6rem);line-height:1.02;letter-spacing:-.025em;
  margin-top:1rem;max-width:16ch;
}
em{font-style:normal}

.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--body);font-weight:600;font-size:.98rem;
  padding:.95em 1.6em;border-radius:100px;transition:.35s cubic-bezier(.2,.7,.2,1);
}
.btn--gold{background:var(--gold);color:var(--navy-deep)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 14px 34px -12px rgba(218,180,92,.6)}
.btn--ghost{border:1px solid var(--line);color:var(--cream)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold)}

/* reveal (progressive enhancement — only hidden when JS active) */
html.js .reveal{opacity:0;transform:translateY(30px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--d,0)*.085s);will-change:opacity,transform}
html.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--pad);transition:.4s ease;
}
.nav--scrolled{background:rgba(12,20,48,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);padding-top:.8rem;padding-bottom:.8rem}
.nav__brand img{height:34px;width:auto;opacity:.95}
.nav__links{display:flex;align-items:center;gap:clamp(1.2rem,3vw,2.4rem)}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--muted);transition:.25s}
.nav__links a:hover{color:var(--cream)}
.nav__cta{
  color:var(--cream)!important;border:1px solid var(--line);
  padding:.55em 1.15em;border-radius:100px;
}
.nav__cta:hover{border-color:var(--gold);color:var(--gold)!important}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;padding:8rem var(--pad) 0;overflow:hidden;
  background:
    linear-gradient(180deg,rgba(18,30,64,.30) 0%,rgba(12,20,48,.80) 100%),
    radial-gradient(120% 120% at 8% 108%,rgba(12,20,48,.6),transparent 55%),
    url("assets/img/hero-atmosphere.jpg") center/cover no-repeat,
    var(--navy-deep);
}
.hero__glow{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(12,20,48,.45),transparent 22%)}
/* 3D animated globe centerpiece */
.scene{width:clamp(180px,23vw,310px);aspect-ratio:1;margin:0 auto;perspective:1000px;
  animation:globeIntro 1.4s cubic-bezier(.2,.75,.25,1) both}
.globe{position:relative;width:100%;height:100%;transform-style:preserve-3d;
  animation:globeSpin 24s linear infinite}
.globe::before{content:"";position:absolute;inset:24%;border-radius:50%;
  background:radial-gradient(circle,rgba(218,180,92,.30),transparent 72%);filter:blur(10px)}
.meridian{position:absolute;inset:0;border:1px solid rgba(241,233,214,.20);border-radius:50%}
.meridian.gold{border-color:rgba(218,180,92,.6)}
.latitude--eq{position:absolute;inset:0;border:1px solid rgba(241,233,214,.16);
  border-radius:50%;transform:rotateX(90deg)}
@keyframes globeSpin{to{transform:rotateY(360deg)}}
@keyframes globeIntro{from{opacity:0;transform:scale(.55) rotate(-10deg)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.globe{animation:none}.scene{animation:none}}

.hero__inner{position:relative;z-index:2;max-width:920px;margin:0 auto;width:100%;
  display:flex;flex-direction:column;align-items:center;text-align:center}
.hero__wordmark{width:clamp(240px,32vw,440px);height:auto;margin-top:2rem}
.hero .eyebrow{margin-top:1.4rem}
.hero__title{font-family:var(--display);font-weight:800;
  font-size:clamp(2.6rem,7vw,6.2rem);line-height:1.0;letter-spacing:-.03em;
  margin:1.1rem 0 0;max-width:18ch}
.hero__accent{color:var(--cream)}
.hero__title .dot{color:var(--gold)}
.hero__sub{margin-top:1.5rem;max-width:48ch;font-size:clamp(1.02rem,1.5vw,1.25rem);
  color:var(--muted);line-height:1.55}
.hero__actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.9rem;margin-top:2.2rem}

/* ticker */
.ticker{position:relative;z-index:2;margin-top:clamp(3rem,7vw,6rem);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.05rem 0;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.ticker__track{display:flex;width:max-content;animation:marquee 48s linear infinite}
.ticker__set{display:flex}
.ticker i{font-style:normal;font-weight:500;font-size:.92rem;letter-spacing:.04em;
  color:var(--muted);white-space:nowrap;display:inline-flex;align-items:center}
.ticker i::after{content:"";width:5px;height:5px;border-radius:50%;
  background:var(--gold);margin:0 1.9rem;opacity:.85}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============ MANIFESTO ============ */
.manifesto{max-width:var(--maxw);margin:0 auto;
  padding:clamp(6rem,15vw,12rem) var(--pad)}
.manifesto__line{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.7rem,4.4vw,3.4rem);line-height:1.18;letter-spacing:-.02em;
  max-width:20ch;margin-top:1.6rem;
}
.manifesto__line em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gold)}

/* ============ APPROACH ============ */
.approach{padding:clamp(3rem,8vw,6rem) 0}
.pillars{max-width:var(--maxw);margin:clamp(2.5rem,6vw,4.5rem) auto 0;
  padding:0 var(--pad);display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(1rem,2.4vw,2rem)}
.pillar{border-top:1px solid var(--line);padding:2rem 0 0;position:relative}
/* gold hairline draws across the top as each pillar reveals (staggered via --d) */
.pillar::before{content:"";position:absolute;top:-1px;left:0;width:100%;height:2px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .85s cubic-bezier(.2,.7,.2,1);
  transition-delay:calc(var(--d,0)*.085s + .12s)}
html.js .pillar.in::before{transform:scaleX(1)}
@media (prefers-reduced-motion:reduce){.pillar::before{transform:scaleX(1);transition:none}}
.pillar__num{font-family:var(--display);font-weight:700;color:var(--gold);
  font-size:1rem;letter-spacing:.05em}
.pillar__title{font-family:var(--display);font-weight:700;
  font-size:clamp(1.4rem,2.4vw,1.95rem);line-height:1.05;letter-spacing:-.02em;
  margin:1.3rem 0 .9rem}
.pillar__body{color:var(--muted);font-size:1.02rem;max-width:34ch}

/* ============ MODEL ============ */
.model{margin:clamp(4rem,10vw,8rem) 0;padding:clamp(4rem,8vw,6.5rem) var(--pad);
  background:
    radial-gradient(90% 120% at 50% 0%,rgba(218,180,92,.08),transparent 60%),
    var(--navy-deep);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.model__head{max-width:var(--maxw);margin:0 auto;text-align:center;display:flex;
  flex-direction:column;align-items:center}
.model__head .section-title{max-width:18ch}
.model__note{color:var(--muted);margin-top:1.1rem;max-width:46ch}
.model__grid{max-width:980px;margin:clamp(3rem,6vw,4.5rem) auto 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}
.stat{display:flex;flex-direction:column;gap:.4rem;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-1rem;top:18%;
  bottom:18%;width:1px;background:var(--line)}
.stat__num{font-family:var(--display);font-weight:800;color:var(--gold);
  font-size:clamp(2.6rem,6vw,4.6rem);line-height:1;letter-spacing:-.03em}
.stat__label{font-weight:600;letter-spacing:.04em;color:var(--cream)}

/* ============ SERVICES ============ */
.services{padding:clamp(3rem,8vw,6rem) 0}
.services__list{max-width:var(--maxw);margin:clamp(2.5rem,6vw,4.5rem) auto 0;
  padding:0 var(--pad);list-style:none;
  display:grid;grid-template-columns:1fr 1fr;gap:0}
.service{display:flex;gap:1.4rem;padding:1.9rem 0;border-top:1px solid var(--line);
  align-items:baseline}
.services__list .service:nth-child(odd){padding-right:clamp(1rem,3vw,3rem)}
.services__list .service:nth-child(even){padding-left:clamp(1rem,3vw,3rem);
  border-left:1px solid var(--line)}
.service__num{font-family:var(--display);font-weight:700;color:var(--gold);
  font-size:.95rem;flex-shrink:0;padding-top:.2rem}
.service h3{font-family:var(--display);font-weight:600;font-size:1.22rem;
  letter-spacing:-.01em;margin-bottom:.4rem}
.service p{color:var(--muted);font-size:.98rem;max-width:40ch}

/* ============ TEAM ============ */
.team{padding:clamp(3rem,8vw,6rem) 0 clamp(4rem,10vw,8rem)}
.team__grid{max-width:1060px;margin:clamp(2.5rem,6vw,4.5rem) auto 0;
  padding:0 var(--pad);display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(1rem,2.4vw,1.8rem)}
.member{display:flex;align-items:center;gap:clamp(.9rem,1.8vw,1.4rem);
  border:1px solid var(--line);border-radius:16px;
  padding:clamp(1.3rem,1.8vw,1.85rem);transition:.4s cubic-bezier(.2,.7,.2,1);
  background:linear-gradient(180deg,rgba(241,233,214,.02),transparent)}
.member:hover{border-color:rgba(218,180,92,.45);transform:translateY(-4px)}
.member__info{flex:1;min-width:0;text-align:center}
.member__photo{flex-shrink:0;width:clamp(116px,31%,150px);aspect-ratio:2/3;
  border:2px solid var(--gold);border-radius:12px;overflow:hidden;position:relative;
  color:var(--gold);background:linear-gradient(160deg,var(--navy-2),var(--navy-deep))}
.member__photo img{width:100%;height:100%;object-fit:cover;display:block}
.member__ph{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center}
.member__ph svg{width:64%;height:auto;opacity:.3}
.member__mark{width:64px;height:64px;border-radius:50%;border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem;
  color:var(--gold);font-family:var(--display);font-weight:700;font-size:1.15rem}
.member__name{font-family:var(--display);font-weight:700;
  font-size:clamp(1.3rem,2vw,1.55rem);letter-spacing:-.02em}
.member__role{color:var(--cream);margin-top:.3rem}
.member__tag{color:var(--gold);font-size:.82rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;margin-top:.9rem}

/* ============ CONTACT / FOOTER ============ */
.contact{position:relative;padding:clamp(5rem,12vw,9rem) var(--pad) 0;
  background:
    linear-gradient(180deg,var(--navy) 0%,rgba(12,20,48,.74) 52%,rgba(12,20,48,.5) 100%),
    url("assets/img/contact-atmosphere.jpg") center/cover no-repeat,
    var(--navy-deep)}
.contact__inner{max-width:var(--maxw);margin:0 auto;text-align:center;
  display:flex;flex-direction:column;align-items:center}
.contact__title{font-family:var(--display);font-weight:800;
  font-size:clamp(2.6rem,8vw,6.5rem);line-height:.95;letter-spacing:-.035em;
  margin-top:1.1rem}
.contact__sub{color:var(--muted);margin-top:1.4rem;max-width:44ch}
.contact__email{font-family:var(--display);font-weight:600;
  font-size:clamp(1.3rem,3.6vw,2.4rem);letter-spacing:-.02em;margin-top:2.4rem;
  color:var(--cream);border-bottom:1px solid var(--line);padding-bottom:.25rem;
  transition:.3s}
.contact__email:hover{color:var(--gold);border-color:var(--gold)}
.foot{max-width:var(--maxw);margin:clamp(5rem,12vw,8rem) auto 0;
  padding:2.2rem 0;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  flex-wrap:wrap}
.foot__logo{height:30px;width:auto;opacity:.8}
.foot__meta{display:flex;gap:2rem;color:var(--muted);font-size:.84rem;
  letter-spacing:.02em;flex-wrap:wrap}
.foot__meta a{color:var(--cream);transition:color .25s}
.foot__meta a:hover{color:var(--gold)}

/* ============ THE JOURNEY (scroll word-fill) ============ */
.journey{position:relative;height:230vh}
.journey__sticky{position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;justify-content:center;
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.journey__eyebrow{margin-bottom:1.7rem}
.journey__text{font-family:var(--display);font-weight:700;
  font-size:clamp(1.4rem,2.9vw,2.3rem);line-height:1.34;letter-spacing:-.015em;max-width:30ch}
/* words dim only when JS is active; without JS the text reads normally */
html.js .journey__text .w{color:rgba(241,233,214,.16);transition:color .5s cubic-bezier(.2,.7,.2,1)}
html.js .journey__text .w.lit{color:var(--cream)}
html.js .journey__text .w.g.lit{color:var(--gold)}
@media (prefers-reduced-motion:reduce){
  .journey{height:auto}
  .journey__sticky{position:static;height:auto;padding-top:clamp(5rem,12vw,9rem);padding-bottom:clamp(5rem,12vw,9rem)}
  html.js .journey__text .w{color:var(--cream)}
  html.js .journey__text .w.g{color:var(--gold)}
}

/* ============ CONTACT FORM ============ */
.cform{width:100%;max-width:560px;margin:3.2rem auto .5rem;text-align:left;
  display:flex;flex-direction:column;gap:1.55rem}
.cform__row{display:grid;grid-template-columns:1fr 1fr;gap:1.55rem}
.cform__field{display:flex;flex-direction:column;gap:.55rem}
.cform__field>span{font-size:.72rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold)}
.cform__field input,.cform__field textarea{
  font-family:var(--body);font-size:1rem;color:var(--cream);line-height:1.5;
  background:transparent;border:none;border-bottom:1px solid var(--line);
  padding:.6rem 0;width:100%;resize:vertical;transition:border-color .3s}
.cform__field textarea{min-height:104px}
.cform__field input:focus,.cform__field textarea:focus{outline:none;border-color:var(--gold)}
.cform__field input::placeholder,.cform__field textarea::placeholder{color:rgba(241,233,214,.32)}
.cform__field input:-webkit-autofill{
  -webkit-text-fill-color:var(--cream);
  -webkit-box-shadow:0 0 0 1000px var(--navy-deep) inset;
  transition:background-color 9999s ease-in-out 0s}
.cform__hp{position:absolute!important;left:-9999px;opacity:0;height:0;width:0;pointer-events:none}
.cform__submit{align-self:flex-start;margin-top:.5rem;border:none;cursor:pointer}
.cform__submit:disabled{opacity:.6;cursor:default}
.cform__status{font-size:.95rem;min-height:1.2em;margin:-.5rem 0 0}
.cform__status.is-ok{color:var(--gold)}
.cform__status.is-err{color:#E79A9A}
.contact__or{color:var(--muted);font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;margin-top:3rem}
.contact .contact__email{margin-top:.9rem}

/* ============ WHY WE'RE DIFFERENT ============ */
.why{padding:clamp(3rem,8vw,6rem) 0}
.why .section-title{max-width:none}
.why .section-title em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gold)}
.why__grid{max-width:var(--maxw);margin:clamp(2.5rem,6vw,4.5rem) auto 0;padding:0 var(--pad);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2.4vw,1.6rem)}
.why__col{border:1px solid var(--line);border-radius:16px;
  padding:clamp(1.8rem,3vw,2.6rem);transition:.4s cubic-bezier(.2,.7,.2,1)}
.why__col--old{background:linear-gradient(180deg,rgba(241,233,214,.015),transparent)}
.why__col--jsg{border-color:rgba(218,180,92,.42);
  background:linear-gradient(180deg,rgba(218,180,92,.07),transparent)}
.why__col--jsg:hover{transform:translateY(-4px);border-color:rgba(218,180,92,.7)}
.why__label{font-family:var(--body);font-weight:600;font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:1.6rem}
.why__col--old .why__label{color:var(--muted)}
.why__col--jsg .why__label{color:var(--gold)}
.why__list{list-style:none;display:flex;flex-direction:column;gap:1.1rem}
.why__list li{position:relative;padding-left:1.7rem;font-size:1.02rem;line-height:1.5}
.why__col--old .why__list li{color:var(--muted)}
.why__col--old .why__list li::before{content:"";position:absolute;left:0;top:.66em;
  width:11px;height:1px;background:rgba(241,233,214,.32)}
.why__col--jsg .why__list li{color:var(--cream)}
.why__col--jsg .why__list li::before{content:"";position:absolute;left:0;top:.5em;
  width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* ============ HOVER MICRO-INTERACTIONS ============ */
.pillar__title{transition:color .3s}
.pillar:hover .pillar__title{color:var(--gold)}
.service>div{transition:transform .38s cubic-bezier(.2,.7,.2,1)}
.service h3,.service__num{transition:color .3s}
.service:hover>div{transform:translateX(6px)}
.service:hover h3{color:var(--gold)}
.service:hover .service__num{color:var(--cream)}

/* ============ RESPONSIVE ============ */
@media (max-width:860px){
  .nav__links a:not(.nav__cta){display:none}
  .pillars{grid-template-columns:1fr;gap:0}
  .pillar{padding:1.8rem 0}
  .services__list{grid-template-columns:1fr}
  .services__list .service:nth-child(even){padding-left:0;border-left:none}
  .services__list .service:nth-child(odd){padding-right:0}
  .stat:not(:last-child)::after{display:none}
  .model__grid{gap:2.4rem}
  .team__grid{grid-template-columns:1fr}
  /* hero stays centered on mobile (matches desktop + the centered globe/logo); everything else is left-aligned */
  .scene{margin:0 auto .4rem;width:clamp(150px,42vw,220px)}
  .hero__wordmark{width:min(74vw,320px);margin-top:1.4rem}
  .hero__title{font-size:clamp(1.65rem,7.2vw,2.9rem);line-height:1.06;max-width:none}
  .hero__sub{font-size:clamp(.98rem,2.4vw,1.1rem)}
  .cform__row{grid-template-columns:1fr}
  .journey__text{max-width:none}
  .why__grid{grid-template-columns:1fr}
  .why .section-title{font-size:clamp(1.45rem,6vw,2rem)}
}
@media (max-width:520px){
  .model__grid{grid-template-columns:1fr}
  .foot{flex-direction:column;align-items:flex-start;gap:1.2rem}
}
