/* ============================================================
   ZERO NINE ATHLETIC MANAGEMENT
   Shared shabby-chic system + landing components
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --paper:#E9E9E0; --paper-2:#E0E1D6; --paper-3:#D4D6C8;
  --ink:#23302A; --ink-soft:#5B655C; --ink-faint:#8C958A;
  --line:rgba(35,48,42,.20); --line-soft:rgba(35,48,42,.12);
  --sage:#9AAA8E; --sage-deep:#5E6F54;
  --rose:#9FB0AE; --brass:#B09A55; --brass-deep:#7E6C32; --taupe:#A9A98C;
  --serif:'Cormorant Garamond',serif;
  --sans:'Hanken Grotesk',sans-serif;
  --maxw:1200px;
  --gut:clamp(22px,5vw,72px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);color:var(--ink);font-family:var(--serif);
  -webkit-font-smoothing:antialiased;line-height:1.5;position:relative;overflow-x:hidden;
}
/* paper grain + vignette */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection{background:var(--rose);color:var(--paper)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}

/* ---------- helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);position:relative;z-index:2}
.label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft)}
.serif-i{font-style:italic}
.brass{color:var(--brass)}
.muted{color:var(--ink-soft)}
h1,h2,h3,h4{font-weight:500;line-height:1.02;letter-spacing:.005em}
.display{font-weight:500;text-transform:uppercase;letter-spacing:.02em;line-height:.95}

.orn{display:flex;align-items:center;justify-content:center;gap:14px}
.orn::before,.orn::after{content:"";height:1px;width:var(--w,60px);background:linear-gradient(90deg,transparent,var(--line),transparent)}
.orn .dia{width:6px;height:6px;background:var(--brass);transform:rotate(45deg)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:12px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;padding:15px 26px;border-radius:3px;border:1px solid transparent;
  transition:all .25s ease;white-space:nowrap}
.btn .arr{transition:transform .25s ease}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:#1a2620}
.btn-brass{background:var(--brass);color:#2b2912}
.btn-brass:hover{background:var(--brass-deep);color:var(--paper)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);background:rgba(35,48,42,.04)}
.btn-lg{padding:18px 32px}

/* ============================================================ NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gut);transition:background .3s ease,border-color .3s ease,padding .3s ease;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(233,233,224,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:12px var(--gut)}
.brand{display:flex;align-items:center;gap:13px}
.brand .mono{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.02em;color:var(--paper);
  background:var(--ink);width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:4px;white-space:nowrap}
.brand .mono .amp{color:var(--brass)}
.brand .nm{font-family:var(--serif);font-weight:600;font-size:19px;text-transform:uppercase;letter-spacing:.06em;line-height:1}
.brand .nm small{display:block;font-family:var(--sans);font-weight:600;font-size:8px;letter-spacing:.32em;color:var(--ink-soft);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:0;color:var(--ink)}

/* ============================================================ HERO */
.hero{padding:clamp(130px,17vw,200px) 0 clamp(60px,8vw,110px);position:relative;overflow:hidden}
.hero .wm{position:absolute;right:calc(-1*var(--gut));top:8%;font-family:var(--serif);font-weight:500;font-size:clamp(260px,40vw,620px);
  line-height:.8;color:rgba(35,48,42,.05);pointer-events:none;user-select:none;letter-spacing:.02em;z-index:1}
.hero-inner{position:relative;z-index:2;max-width:880px}
.hero .est{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(18px,2.2vw,26px);color:var(--brass);margin:24px 0 14px}
.hero h1{font-size:clamp(46px,8vw,104px);line-height:.96;letter-spacing:.005em}
.hero h1 em{font-style:italic;color:var(--ink-soft)}
.hero p.lead{font-size:clamp(18px,1.8vw,22px);color:var(--ink-soft);max-width:60ch;margin-top:30px;line-height:1.5}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}

/* proof strip */
.proof{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2)}
.proof .row{display:flex;flex-wrap:wrap;gap:30px 56px;align-items:center;justify-content:center;padding:22px 0}
.proof .row span{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.proof .row .dot{width:5px;height:5px;border-radius:50%;background:var(--brass)}

/* ============================================================ SECTION SCAFFOLD */
.section{padding:clamp(64px,9vw,128px) 0;position:relative}
.sec-head{margin-bottom:54px}
.sec-head .top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.sec-head .no{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--brass);display:block;margin-bottom:14px}
.sec-head h2{font-size:clamp(32px,5vw,60px);line-height:1}
.sec-head h2 em{font-style:italic;color:var(--ink-soft)}
.sec-head p{font-size:clamp(16px,1.6vw,19px);color:var(--ink-soft);max-width:46ch;margin-bottom:4px}

/* ============================================================ SERVICES */
.svc-list{border-top:1px solid var(--line)}
.svc{display:grid;grid-template-columns:90px 1fr 1.1fr;gap:30px;padding:38px 0;border-bottom:1px solid var(--line);align-items:start;transition:background .25s ease}
.svc:hover{background:var(--paper-2)}
.svc .svc-no{font-family:var(--serif);font-style:italic;font-size:32px;color:var(--brass)}
.svc h3{font-size:clamp(26px,3vw,38px)}
.svc .svc-tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px}
.svc .svc-tags span{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);border-radius:100px;padding:5px 11px}
.svc p{font-size:17px;color:var(--ink-soft);line-height:1.55}
@media(max-width:760px){.svc{grid-template-columns:1fr;gap:12px;padding:30px 0}.svc .svc-no{font-size:26px}}

/* ============================================================ ROSTER */
.roster-sec{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.roster-filters{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:36px}
.chip{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:9px 16px;
  border:1px solid var(--line);border-radius:100px;color:var(--ink-soft);background:transparent;transition:all .2s}
.chip:hover{color:var(--ink)}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.roster-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:900px){.roster-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.roster-grid{grid-template-columns:1fr}}
.athlete{background:var(--paper);border:1px solid var(--line);border-radius:5px;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}
.athlete:hover{transform:translateY(-5px);box-shadow:0 22px 40px -26px rgba(35,48,42,.5)}
.athlete .photo{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--paper-3)}
.athlete .photo image-slot{width:100%;height:100%;filter:grayscale(.28) contrast(.96) brightness(1.02)}
.athlete .num{position:absolute;top:10px;right:14px;z-index:3;font-family:var(--serif);font-weight:600;font-size:34px;color:rgba(233,233,224,.7)}
.athlete .sport{position:absolute;top:12px;left:12px;z-index:3;font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(35,48,42,.9);color:var(--paper);padding:5px 10px;border-radius:100px}
.athlete .info{padding:16px 18px}
.athlete .info .nm{font-family:var(--serif);font-weight:600;font-size:21px;text-transform:uppercase;letter-spacing:.02em;line-height:1}
.athlete .info .meta{font-family:var(--sans);font-size:11px;letter-spacing:.04em;color:var(--ink-soft);margin-top:7px;text-transform:uppercase}
.athlete.hide{display:none}

/* ============================================================ BRANDS / STEPS */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:5px;overflow:hidden;margin-top:50px}
.step{background:var(--paper);padding:34px 30px}
.step .s-no{font-family:var(--serif);font-style:italic;font-size:46px;color:var(--brass);line-height:.8}
.step h4{font-family:var(--serif);font-weight:600;font-size:23px;margin:16px 0 10px}
.step p{font-size:15.5px;color:var(--ink-soft);line-height:1.55}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* ============================================================ MISSION */
.mission{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.mission::before{content:"";position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.mission .label{color:var(--brass)}
.mission .quote{font-size:clamp(28px,4vw,52px);line-height:1.1;max-width:20ch;margin:26px 0 22px}
.mission .quote em{font-style:italic;color:var(--brass)}
.mission p{color:rgba(233,233,224,.72);font-size:18px;max-width:60ch;line-height:1.55}
.mission .pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:54px}
@media(max-width:760px){.mission .pillars{grid-template-columns:1fr 1fr;gap:24px}}
.mission .pillar .pn{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.16em;color:var(--brass)}
.mission .pillar h4{font-family:var(--serif);font-weight:600;font-size:20px;margin:10px 0 8px}
.mission .pillar p{font-size:14.5px;color:rgba(233,233,224,.66)}

/* ============================================================ CONTACT */
.contact-card{border:1px solid var(--line);border-radius:6px;background:var(--paper-2);padding:clamp(28px,4vw,56px)}
.cta-tabs{display:inline-flex;gap:5px;padding:5px;border:1px solid var(--line);border-radius:100px;margin-bottom:34px;background:var(--paper)}
.cta-tab{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:11px 22px;border-radius:100px;color:var(--ink-soft);background:transparent;border:0;transition:all .2s}
.cta-tab.active{background:var(--ink);color:var(--paper)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.field input,.field select,.field textarea{font-family:var(--serif);font-size:18px;color:var(--ink);background:var(--paper);
  border:1px solid var(--line);border-radius:4px;padding:13px 15px;transition:border-color .2s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brass)}
.field textarea{resize:vertical;min-height:96px}
.field select{appearance:none;cursor:pointer}
.form-foot{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:24px;flex-wrap:wrap}
.form-note{font-family:var(--sans);font-size:11px;color:var(--ink-faint);letter-spacing:.02em;max-width:40ch}
.form-ok{display:none;padding:28px;border:1px solid var(--brass);border-radius:6px;background:rgba(177,145,80,.08);font-family:var(--serif);font-style:italic;font-size:19px;color:var(--brass-deep)}
.form-ok.show{display:block}
@media(max-width:620px){.form-grid{grid-template-columns:1fr}}

/* ============================================================ FOOTER */
.footer{padding:72px 0 36px;border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:48px;border-bottom:1px solid var(--line)}
.foot-brand .nm{font-family:var(--serif);font-weight:500;font-size:30px;text-transform:uppercase;letter-spacing:.04em}
.foot-brand .am{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}
.foot-brand p{color:var(--ink-soft);font-size:15px;margin-top:18px;max-width:30ch;font-style:italic}
.foot-col h5{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px}
.foot-col a{display:block;color:var(--ink-soft);font-size:15px;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--brass)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-family:var(--sans);font-size:11px;letter-spacing:.06em;color:var(--ink-faint);flex-wrap:wrap;gap:12px}
@media(max-width:820px){.foot-top{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.foot-top{grid-template-columns:1fr}}

/* ============================================================ REVEAL (keyframe, .js-gated) */
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.js .reveal{opacity:0}
.js .reveal.in{animation:rise .8s cubic-bezier(.2,.7,.3,1) both}
.js .reveal.in[data-d="1"]{animation-delay:.08s}
.js .reveal.in[data-d="2"]{animation-delay:.16s}
.js .reveal.in[data-d="3"]{animation-delay:.24s}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1}.js .reveal.in{animation:none}}

@media(max-width:980px){.nav-links{display:none}.nav-toggle{display:block}}

/* ============================================================ FIXED MEDIA (no drag-drop on front end) */
.zn-fimg{width:100%;height:100%;object-fit:cover;display:block;user-select:none;-webkit-user-drag:none}
.zn-fimg.zn-real{filter:grayscale(.16) contrast(.98) brightness(1.02)}
.zn-fph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:
    repeating-linear-gradient(135deg, rgba(35,48,42,.025) 0 10px, transparent 10px 20px),
    var(--paper-3);
  color:var(--ink-faint)}
.zn-fph-mono{font-family:var(--serif);font-weight:600;font-size:clamp(30px,5vw,52px);letter-spacing:.02em;color:var(--ink-soft);line-height:1}
.zn-fph-lab{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);
  border:1px solid var(--line);border-radius:100px;padding:4px 11px}
.zn-media-wrap{position:absolute;inset:0}

/* type toggle (Real / Avatar / Cartoon) */
.zn-toggle{display:inline-flex;gap:4px;padding:4px;border-radius:100px;background:rgba(20,28,23,.55);backdrop-filter:blur(4px);border:1px solid rgba(233,233,224,.18)}
.zn-toggle button{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(233,233,224,.72);
  background:transparent;border:0;border-radius:100px;padding:7px 13px;transition:all .2s;cursor:pointer}
.zn-toggle button.active{background:var(--brass);color:#1a2410}
.zn-toggle button:hover:not(.active){color:var(--paper)}
