/* ============================================================
   ФФРО — shared component styles (used across pages)
   ============================================================ */

/* scroll progress bar */
.progress{ position:fixed; top:0; left:0; height:3px; width:100%; z-index:120;
  background:linear-gradient(90deg,var(--white),var(--blue) 45%,var(--red));
  transform:scaleX(0); transform-origin:left; }

/* ---------- Page hero (subpages) ---------- */
.page-hero{ position:relative; padding-top:clamp(150px,16vw,230px); padding-bottom:clamp(60px,7vw,104px); overflow:hidden; border-bottom:1px solid var(--line); }
.page-hero__bg{ position:absolute; inset:-12% 0; z-index:0; }
.page-hero__bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.55) brightness(.42) contrast(1.05); }
.page-hero::after{ content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(8,11,17,.72), rgba(8,11,17,.92)); }
.page-hero .container{ position:relative; z-index:2; }
.page-hero h1{ font-size:var(--fs-display); text-transform:uppercase; margin-top:22px; color:var(--white); max-width:18ch; }
.page-hero p{ margin-top:22px; color:var(--ink-soft); font-size:var(--fs-lead); max-width:62ch; }
.breadcrumb{ display:flex; gap:10px; align-items:center; font-size:13px; color:var(--muted); letter-spacing:.04em; }
.breadcrumb a:hover{ color:var(--ink); }
.breadcrumb span{ color:var(--muted-2); }

/* ---------- Stats band ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-soft);
  border:1px solid var(--line-soft); border-radius:var(--radius-lg); overflow:hidden; }
.stat{ background:var(--surface); padding:clamp(28px,3vw,46px); position:relative; }
.stat__num{ font-family:var(--font-display); font-weight:600; font-size:clamp(46px,5.4vw,82px); line-height:.96; color:var(--white); letter-spacing:-.01em; display:flex; align-items:flex-start; }
.stat__num .suffix{ font-size:.42em; color:var(--red); margin-left:4px; margin-top:.25em; }
.stat__label{ margin-top:14px; color:var(--muted); font-size:14.5px; line-height:1.4; max-width:22ch; }
.stat::before{ content:""; position:absolute; left:clamp(28px,3vw,46px); top:0; width:40px; height:3px; background:var(--red); }
.stat:nth-child(2)::before{ background:var(--blue); }
.stat:nth-child(3)::before{ background:var(--white); }
.stat:nth-child(4)::before{ background:var(--red); }
@media (max-width:880px){ .stats{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .stats{ grid-template-columns:1fr; } }

/* ---------- Weapon cards ---------- */
.weapons{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.weapon{ position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:clamp(420px,46vw,560px);
  display:flex; flex-direction:column; justify-content:flex-end; border:1px solid var(--line-soft);
  transition:transform .6s var(--ease), box-shadow .6s; isolation:isolate; }
.weapon:hover{ transform:translateY(-8px); box-shadow:var(--shadow-card); }
.weapon__img{ position:absolute; inset:0; z-index:-2; }
.weapon__img img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.5) contrast(1.05) brightness(.8); transition:transform 1.2s var(--ease-out), filter .6s; }
.weapon:hover .weapon__img img{ transform:scale(1.08); filter:grayscale(.1) contrast(1.08) brightness(.9); }
.weapon__veil{ position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(8,10,15,.15) 0%, rgba(8,10,15,.55) 55%, rgba(8,10,15,.95) 100%); }
.weapon__accent{ position:absolute; top:0; left:0; right:0; height:4px; z-index:1; transform:scaleX(0); transform-origin:left; transition:transform .6s var(--ease); }
.weapon:hover .weapon__accent{ transform:scaleX(1); }
.weapon--saber .weapon__accent{ background:var(--red); }
.weapon--epee .weapon__accent{ background:var(--blue-bright); }
.weapon--foil .weapon__accent{ background:var(--white); }
.weapon__body{ position:relative; padding:clamp(26px,2.4vw,38px); z-index:1; }
.weapon__idx{ font-family:var(--font-display); font-size:14px; letter-spacing:.3em; color:var(--muted); }
.weapon__name{ font-family:var(--font-display); font-weight:600; font-size:clamp(30px,3vw,44px); text-transform:uppercase; margin-top:8px; color:#fff; }
.weapon__name .en{ display:block; font-size:.36em; letter-spacing:.34em; color:var(--muted); margin-top:8px; font-weight:500; }
.weapon__desc{ color:var(--ink-soft); margin-top:16px; font-size:15.5px; max-height:0; opacity:0; overflow:hidden;
  transition:max-height .6s var(--ease), opacity .5s, margin-top .5s; }
.weapon:hover .weapon__desc{ max-height:160px; opacity:1; }
@media (max-width:880px){ .weapons{ grid-template-columns:1fr; } .weapon{ min-height:380px; } .weapon__desc{ max-height:160px; opacity:1; } }

/* ---------- Event / calendar rows ---------- */
.events{ display:flex; flex-direction:column; }
.event{ display:grid; grid-template-columns:130px 1fr auto; gap:32px; align-items:center;
  padding:30px 8px; border-top:1px solid var(--line-soft); transition:padding-left .4s var(--ease), background .4s; position:relative; }
.event:last-child{ border-bottom:1px solid var(--line-soft); }
.event::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--red); transform:scaleY(0); transform-origin:top; transition:transform .4s var(--ease); }
.event:hover{ padding-left:24px; background:linear-gradient(90deg, rgba(255,255,255,.025), transparent 40%); }
.event:hover::before{ transform:scaleY(1); }
.event__date{ text-align:center; }
.event__day{ font-family:var(--font-display); font-weight:600; font-size:38px; line-height:1; color:var(--white); }
.event__mon{ font-size:12.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin-top:6px; }
.event__main h3{ font-family:var(--font-display); font-weight:500; font-size:clamp(20px,2vw,27px); text-transform:uppercase; color:var(--ink); }
.event__meta{ display:flex; gap:18px; flex-wrap:wrap; margin-top:12px; color:var(--muted); font-size:14px; }
.event__meta span{ display:inline-flex; align-items:center; gap:7px; }
.event__tags{ display:flex; gap:8px; }
@media (max-width:780px){ .event{ grid-template-columns:84px 1fr; } .event__tags{ display:none; } .event__day{ font-size:30px; } }

/* ---------- Empty content placeholders ---------- */
.placeholder-card{
  border:1px solid var(--line-soft); border-radius:var(--radius); background:var(--surface);
  padding:clamp(26px,3vw,42px); min-height:180px; display:flex; flex-direction:column; justify-content:center;
}
.placeholder-card__mark{ margin-bottom:18px; }
.placeholder-card h3{ font-family:var(--font-display); font-weight:500; font-size:clamp(21px,2vw,28px); text-transform:uppercase; color:var(--white); }
.placeholder-card p{ margin-top:12px; color:var(--muted); max-width:54ch; }
.events .placeholder-card{ border-top:1px solid var(--line-soft); border-radius:0; background:transparent; }
.grid > .placeholder-card{ grid-column:1/-1; }

/* ---------- News cards ---------- */
.news-card{ display:flex; flex-direction:column; height:100%; }
.news-card .card__media{ aspect-ratio:16/10; }
.news-card__cat{ position:absolute; top:16px; left:16px; z-index:2; }
.news-card__date{ font-size:13px; color:var(--muted); letter-spacing:.04em; }
.news-card h3{ font-family:var(--font-display); font-weight:500; font-size:21px; line-height:1.16; text-transform:uppercase; margin-top:12px; color:var(--ink); transition:color .3s; }
.news-card:hover h3{ color:var(--red-bright); }
.news-card p{ color:var(--muted); font-size:14.5px; margin-top:12px; }
.news-card__foot{ margin-top:auto; padding-top:20px; }

.news-feature{ display:grid; grid-template-columns:1.15fr .85fr; gap:0; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line-soft); background:var(--surface); }
.news-feature__media{ position:relative; min-height:340px; }
.news-feature__media img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.2) contrast(1.04); }
.news-feature__body{ padding:clamp(30px,3vw,52px); display:flex; flex-direction:column; justify-content:center; }
.news-feature__body h3{ font-family:var(--font-display); font-weight:600; font-size:clamp(24px,2.5vw,38px); text-transform:uppercase; line-height:1.05; margin-top:18px; color:var(--white); }
.news-feature__body p{ color:var(--ink-soft); margin-top:18px; font-size:16px; }
@media (max-width:880px){ .news-feature{ grid-template-columns:1fr; } .news-feature__media{ min-height:240px; } }

/* ---------- Athlete cards ---------- */
.athlete{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line-soft);
  min-height:clamp(380px,40vw,460px); display:flex; flex-direction:column; justify-content:flex-end;
  transition:transform .5s var(--ease), box-shadow .5s; }
.athlete:hover{ transform:translateY(-6px); box-shadow:var(--shadow-card); }
.athlete__img{ position:absolute; inset:0; z-index:-2; }
.athlete__img img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.55) contrast(1.05); transition:transform 1.1s var(--ease-out), filter .5s; }
.athlete:hover .athlete__img img{ transform:scale(1.06); filter:grayscale(.1); }
.athlete__img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 38%, rgba(8,10,15,.55) 66%, rgba(8,10,15,.96)); }
.athlete__body{ position:relative; padding:24px; z-index:1; }
.athlete__weapon{ display:inline-flex; align-items:center; gap:8px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:12px; }
.athlete__name{ font-family:var(--font-display); font-weight:600; font-size:25px; text-transform:uppercase; color:#fff; line-height:1.02; }
.athlete__rank{ color:var(--muted); font-size:13.5px; margin-top:8px; }
.athlete__badge{ position:absolute; top:18px; right:18px; z-index:1; width:46px; height:46px; border-radius:50%;
  background:rgba(8,10,15,.55); border:1px solid rgba(255,255,255,.18); backdrop-filter:blur(6px);
  display:grid; place-items:center; font-family:var(--font-display); font-weight:600; font-size:13px; color:#fff; }

/* ---------- Coach cards ---------- */
.coach{ display:flex; gap:20px; align-items:center; padding:22px; border:1px solid var(--line-soft); border-radius:var(--radius); background:var(--surface); transition:.4s; }
.coach:hover{ border-color:var(--line); transform:translateY(-4px); }
.coach__photo{ width:88px; height:88px; flex:0 0 auto; border-radius:14px; overflow:hidden; }
.coach__photo img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.4); }
.coach__name{ font-family:var(--font-display); font-weight:500; font-size:20px; text-transform:uppercase; color:var(--ink); }
.coach__role{ color:var(--red-bright); font-size:13px; letter-spacing:.04em; margin-top:5px; }
.coach__meta{ color:var(--muted); font-size:13.5px; margin-top:7px; }

/* ---------- Schools list ---------- */
.school{ display:flex; align-items:center; gap:18px; padding:20px 0; border-top:1px solid var(--line-soft); }
.school:last-child{ border-bottom:1px solid var(--line-soft); }
.school__icon{ width:46px; height:46px; flex:0 0 auto; border-radius:11px; border:1px solid var(--line); display:grid; place-items:center; color:var(--blue-bright); }
.school__name{ font-family:var(--font-display); font-weight:500; font-size:18px; text-transform:uppercase; color:var(--ink); }
.school__addr{ color:var(--muted); font-size:14px; margin-top:3px; }

/* ---------- Join steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; counter-reset:step; }
.step{ position:relative; padding:30px; border:1px solid var(--line-soft); border-radius:var(--radius); background:var(--surface); transition:.4s; }
.step:hover{ border-color:var(--line); transform:translateY(-5px); }
.step__n{ font-family:var(--font-display); font-weight:600; font-size:54px; line-height:1; color:var(--surface-3); -webkit-text-stroke:1px var(--line); }
.step:hover .step__n{ color:var(--red); -webkit-text-stroke:0; transition:.4s; }
.step h3{ font-family:var(--font-display); font-weight:500; font-size:19px; text-transform:uppercase; color:var(--ink); margin-top:16px; }
.step p{ color:var(--muted); font-size:14.5px; margin-top:10px; }
@media (max-width:880px){ .steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .steps{ grid-template-columns:1fr; } }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; border-radius:var(--radius-lg); overflow:hidden; padding:clamp(44px,6vw,90px); border:1px solid var(--line); isolation:isolate; }
.cta-band__bg{ position:absolute; inset:0; z-index:-2; }
.cta-band__bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.5) brightness(.4); }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(120deg, rgba(11,14,20,.92) 30%, rgba(226,42,57,.32)); }
.cta-band h2{ font-size:var(--fs-h2); text-transform:uppercase; max-width:20ch; color:#fff; }
.cta-band p{ color:var(--ink-soft); font-size:var(--fs-lead); max-width:52ch; margin-top:18px; }
.cta-band__actions{ display:flex; gap:16px; flex-wrap:wrap; margin-top:34px; }

/* ---------- Gallery carousel ---------- */
.carousel{ position:relative; }
.carousel__track{ display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:8px;
  scrollbar-width:none; cursor:grab; }
.carousel__track::-webkit-scrollbar{ display:none; }
.carousel__track.dragging{ cursor:grabbing; scroll-snap-type:none; }
.gallery-item{ flex:0 0 clamp(280px,32vw,440px); scroll-snap-align:start; border-radius:var(--radius); overflow:hidden; position:relative; aspect-ratio:4/5; border:1px solid var(--line-soft); }
.gallery-item img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.35) contrast(1.05); transition:transform 1s var(--ease-out), filter .5s; pointer-events:none; }
.gallery-item:hover img{ transform:scale(1.05); filter:grayscale(0); }
.gallery-item__cap{ position:absolute; left:0; right:0; bottom:0; padding:22px; z-index:1;
  background:linear-gradient(180deg, transparent, rgba(8,10,15,.85)); font-size:14px; color:var(--ink-soft); }
.gallery-item::before{ content:"+"; position:absolute; top:16px; right:16px; z-index:2; width:36px; height:36px; border-radius:50%;
  background:rgba(8,10,15,.5); border:1px solid rgba(255,255,255,.2); color:#fff; display:grid; place-items:center; font-size:22px; line-height:1; opacity:0; transform:scale(.7); transition:.35s; }
.gallery-item:hover::before{ opacity:1; transform:scale(1); }
.carousel__nav{ display:flex; gap:12px; }
.car-btn{ width:54px; height:54px; border-radius:50%; border:1px solid var(--line); background:rgba(255,255,255,.02); color:var(--ink); display:grid; place-items:center; transition:.3s; }
.car-btn:hover:not(:disabled){ border-color:var(--white); background:var(--white); color:var(--bg); }
.car-btn:disabled{ opacity:.3; cursor:not-allowed; }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(6,8,12,.94); backdrop-filter:blur(8px);
  display:grid; place-items:center; padding:5vw; opacity:0; visibility:hidden; transition:opacity .4s, visibility .4s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:90vw; max-height:86vh; border-radius:10px; box-shadow:0 40px 120px rgba(0,0,0,.7); }
.lightbox__close{ position:absolute; top:28px; right:32px; width:52px; height:52px; border-radius:50%; border:1px solid var(--line); background:rgba(255,255,255,.04); color:#fff; font-size:24px; }

/* ---------- Partners ---------- */
.partners{ display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line-soft); border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; }
.partner{ background:var(--surface); display:grid; place-items:center; padding:38px 24px; min-height:130px; transition:.4s; }
.partner:hover{ background:var(--surface-2); }
.partner span{ font-family:var(--font-display); font-weight:600; font-size:17px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); text-align:center; transition:color .4s; }
.partner:hover span{ color:var(--ink); }
@media (max-width:880px){ .partners{ grid-template-columns:repeat(2,1fr); } }

/* ---------- Contact blocks ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contact-item{ display:flex; gap:18px; padding:24px 0; border-top:1px solid var(--line-soft); }
.contact-item__icon{ width:48px; height:48px; flex:0 0 auto; border-radius:12px; border:1px solid var(--line); display:grid; place-items:center; color:var(--red-bright); }
.contact-item h4{ font-family:var(--font-display); font-weight:500; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.contact-item p{ font-size:17px; color:var(--ink); margin-top:6px; }
.map{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); min-height:420px; position:relative; background:var(--surface); }
.map iframe{ width:100%; height:100%; min-height:420px; border:0; filter:grayscale(.4) invert(.92) contrast(.9); }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; gap:36px; } }

/* form */
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; font-weight:600; }
.field input,.field select,.field textarea{ width:100%; padding:15px 18px; background:var(--surface-2); border:1px solid var(--line); border-radius:12px; color:var(--ink); font-family:inherit; font-size:16px; transition:.3s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(44,107,224,.18); }
.field textarea{ resize:vertical; min-height:130px; }
.ffro-hp{ position:absolute!important; left:-10000px!important; width:1px!important; height:1px!important; overflow:hidden!important; opacity:0!important; pointer-events:none!important; }
.consent-block{ margin:4px 0 20px; }
.field--consent{ display:grid; grid-template-columns:20px 1fr; gap:12px; align-items:start; margin-bottom:12px; cursor:pointer; }
.field--consent input{ width:20px; height:20px; margin-top:2px; accent-color:var(--red); }
.field--consent span{ color:var(--ink-soft); font-size:13.5px; line-height:1.5; letter-spacing:0; text-transform:none; font-weight:500; }
.consent-details{ border:1px solid var(--line-soft); border-radius:12px; background:rgba(255,255,255,.025); overflow:hidden; }
.consent-details summary{ cursor:pointer; padding:12px 14px; color:var(--muted); font-size:12px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; }
.consent-details[open] summary{ border-bottom:1px solid var(--line-soft); color:var(--ink); }
.consent-details__body{ max-height:260px; overflow:auto; padding:14px; color:var(--muted); font-size:13.5px; line-height:1.55; }
.consent-details__body p{ margin:0 0 12px; }
.consent-details__body p:last-child{ margin-bottom:0; }
.form-feedback{ min-height:22px; margin-top:14px; color:var(--muted); font-size:14px; line-height:1.45; text-align:center; }
.form-feedback.is-ok{ color:#8df0b8; }
.form-feedback.is-error{ color:#ff8a94; }
form[data-application-form].is-sending button[type="submit"]{ opacity:.72; pointer-events:none; }

/* section number watermark */
.sec-index{ font-family:var(--font-display); font-weight:600; font-size:14px; letter-spacing:.3em; color:var(--muted-2); }

/* ---------- Timeline (история) ---------- */
.timeline{ position:relative; padding-left:0; }
.tl-row{ display:grid; grid-template-columns:160px 1fr; gap:40px; padding:34px 0; border-top:1px solid var(--line-soft); position:relative; }
.tl-row:last-child{ border-bottom:1px solid var(--line-soft); }
.tl-year{ font-family:var(--font-display); font-weight:600; font-size:clamp(40px,4vw,64px); line-height:.9; color:var(--white); position:relative; }
.tl-year::after{ content:""; position:absolute; right:-21px; top:8px; width:11px; height:11px; border-radius:50%; background:var(--red); box-shadow:0 0 0 5px rgba(226,42,57,.15); }
.tl-body h3{ font-family:var(--font-display); font-weight:500; font-size:clamp(20px,2vw,26px); text-transform:uppercase; color:var(--ink); }
.tl-body p{ color:var(--muted); margin-top:12px; font-size:15.5px; max-width:60ch; }
@media (max-width:680px){ .tl-row{ grid-template-columns:1fr; gap:14px; } .tl-year::after{ display:none; } }

/* ---------- Leadership ---------- */
.lead-card{ text-align:left; }
.lead-card .card__media{ aspect-ratio:3/4; }
.lead-card__body{ padding:22px 4px 0; }
.lead-card__name{ font-family:var(--font-display); font-weight:500; font-size:21px; text-transform:uppercase; color:var(--ink); }
.lead-card__role{ color:var(--red-bright); font-size:13.5px; margin-top:6px; letter-spacing:.02em; }
.lead-card__bio{ color:var(--muted); font-size:14px; margin-top:10px; }

/* ---------- Documents ---------- */
.doc{ display:flex; align-items:center; gap:18px; padding:20px 22px; border:1px solid var(--line-soft); border-radius:var(--radius); background:var(--surface); transition:.35s; }
.doc:hover{ border-color:var(--line); transform:translateX(5px); }
.doc__icon{ width:44px; height:44px; flex:0 0 auto; border-radius:10px; background:rgba(226,42,57,.12); border:1px solid rgba(226,42,57,.3); display:grid; place-items:center; color:var(--red-bright); }
.doc__name{ font-weight:600; font-size:15.5px; color:var(--ink); }
.doc__meta{ color:var(--muted); font-size:13px; margin-top:3px; }
.doc__dl{ margin-left:auto; color:var(--muted); transition:.3s; }
.doc:hover .doc__dl{ color:var(--white); }

/* ---------- Results table ---------- */
.table-wrap{ border:1px solid var(--line-soft); border-radius:var(--radius); overflow:hidden; }
.rtable{ width:100%; border-collapse:collapse; font-size:15px; }
.rtable th{ text-align:left; font-family:var(--font-display); font-weight:500; font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); padding:18px 22px; background:var(--surface-2); border-bottom:1px solid var(--line); }
.rtable td{ padding:18px 22px; border-bottom:1px solid var(--line-soft); color:var(--ink-soft); }
.rtable tr:last-child td{ border-bottom:0; }
.rtable tbody tr{ transition:background .3s; }
.rtable tbody tr:hover{ background:rgba(255,255,255,.02); }
.rtable .place{ font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--white); }
.medal{ display:inline-grid; place-items:center; width:30px; height:30px; border-radius:50%; font-size:13px; font-weight:700; color:#0b0e14; }
.medal--g{ background:linear-gradient(145deg,#FFD777,#E0A23A); }
.medal--s{ background:linear-gradient(145deg,#E2E7EF,#A7B0C0); }
.medal--b{ background:linear-gradient(145deg,#E2A579,#B5764A); }
.rtable .athlete-name{ color:var(--white); font-weight:600; }
@media (max-width:680px){ .rtable .hide-sm{ display:none; } .rtable th,.rtable td{ padding:14px; } }

/* ---------- Tabs ---------- */
.tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:36px; }
.tab{ padding:12px 22px; border:1px solid var(--line); border-radius:100px; background:transparent; color:var(--muted); font-family:var(--font-display); font-weight:500; font-size:14px; letter-spacing:.08em; text-transform:uppercase; transition:.3s; }
.tab:hover{ color:var(--ink); border-color:var(--line); }
.tab.active{ background:var(--white); color:var(--bg); border-color:var(--white); }
.tab-panel{ display:none; }
.tab-panel.active{ display:block; animation:fadeIn .5s var(--ease); }
@keyframes fadeIn{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }

/* ---------- FAQ ---------- */
.faq-item{ border-top:1px solid var(--line-soft); }
.faq-item:last-child{ border-bottom:1px solid var(--line-soft); }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:24px; padding:26px 4px; background:transparent; border:0; text-align:left; color:var(--ink); font-family:var(--font-display); font-weight:500; font-size:clamp(18px,1.8vw,23px); text-transform:uppercase; transition:color .3s; }
.faq-q:hover{ color:var(--white); }
.faq-q__icon{ flex:0 0 auto; width:34px; height:34px; border-radius:50%; border:1px solid var(--line); display:grid; place-items:center; position:relative; transition:.35s; }
.faq-q__icon::before,.faq-q__icon::after{ content:""; position:absolute; background:var(--ink); border-radius:2px; }
.faq-q__icon::before{ width:13px; height:2px; }
.faq-q__icon::after{ width:2px; height:13px; transition:transform .35s var(--ease); }
.faq-item.open .faq-q__icon{ background:var(--red); border-color:var(--red); }
.faq-item.open .faq-q__icon::after{ transform:scaleY(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ease); }
.faq-a__inner{ padding:0 4px 28px; color:var(--muted); font-size:16px; max-width:70ch; }

/* ---------- News list (news page) ---------- */
.news-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:1080px){ .news-list{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:680px){ .news-list{ grid-template-columns:1fr; } }

/* prose */
.prose p{ color:var(--ink-soft); font-size:17px; line-height:1.7; margin-bottom:20px; }
.prose h3{ font-family:var(--font-display); font-weight:500; text-transform:uppercase; font-size:24px; color:var(--white); margin:34px 0 16px; }
.prose ul{ margin:0 0 20px; padding-left:0; list-style:none; }
.prose li{ position:relative; padding-left:30px; color:var(--ink-soft); margin-bottom:12px; }
.prose li::before{ content:""; position:absolute; left:0; top:11px; width:14px; height:2px; background:var(--red); }

/* pill row */
.pill-row{ display:flex; gap:10px; flex-wrap:wrap; }
