/* ═══════════════════════════════════════════════════════════════
   SRRC Website — Main stylesheet
   Adapted from mockup design + responsive + admin
═══════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --red:    #e12625;
  --red-d:  #b81e1d;
  --red-l:  #fff0f0;
  --ink:    #0d0d0d;
  --ink2:   #3d3d3d;
  --ink3:   #888;
  --border: #e8e8e8;
  --bg:     #f4f4f2;
  --white:  #ffffff;
  --W:      1140px;
}

html { scroll-behavior: smooth; }
body { font-family: 'Barlow', sans-serif; background: var(--white); color: var(--ink); -webkit-font-smoothing: antialiased; }

/* ─── TOPBAR ─────────────────────────────────────────────────────── */
.tb { background: #0d0d0d; height: 36px; display: flex; align-items: center; padding: 0 40px; }
.tb-l { display: flex; gap: 20px; flex: 1; }
.tb-a { font-size: 11px; color: rgba(255,255,255,.38); display: flex; align-items: center; gap: 4px; text-decoration: none; transition: color .15s; }
.tb-a:hover { color: rgba(255,255,255,.8); }
.tb-a i { font-size: 12px; }
.tb-r { display: flex; align-items: center; gap: 5px; }
.lb { background: none; border: none; padding: 2px 9px; border-radius: 3px; font-size: 11px; font-weight: 700; color: rgba(255,255,255,.28); cursor: pointer; font-family: inherit; letter-spacing: .5px; transition: all .15s; text-decoration: none; }
.lb.on { background: var(--red); color: white; }
.tsoc { background: none; border: none; color: rgba(255,255,255,.28); cursor: pointer; width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; transition: color .15s; text-decoration: none; }
.tsoc:hover { color: white; }
.tsoc i { font-size: 14px; }

/* ─── HEADER ─────────────────────────────────────────────────────── */
.hdr { background: white; border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 200; }
.hdr-in { max-width: var(--W); margin: 0 auto; padding: 0 40px; display: flex; align-items: center; height: 68px; gap: 32px; }
.logo-link { flex-shrink: 0; }
.logo { height: 40px; cursor: pointer; }
nav { display: flex; align-items: stretch; flex: 1; height: 68px; flex-wrap: wrap; overflow: visible; }
.ni { position: relative; }
.nb { background: none; border: none; border-bottom: 2.5px solid transparent; height: 68px; padding: 0 13px; font-size: 12.5px; font-weight: 700; color: var(--ink2); cursor: pointer; font-family: inherit; letter-spacing: .4px; text-transform: uppercase; display: flex; align-items: center; gap: 4px; transition: all .15s; white-space: nowrap; text-decoration: none; }
.nb:hover, .nb.on { color: var(--red); border-bottom-color: var(--red); }
.nb .ch { font-size: 10px; color: var(--ink3); transition: transform .15s; }
.ni:hover .nb .ch { transform: rotate(180deg); }
.dd { position: absolute; top: 100%; left: 0; background: white; border: 1px solid var(--border); border-top: 2.5px solid var(--red); border-radius: 0 0 10px 10px; padding: 6px 0; min-width: 218px; z-index: 300; box-shadow: 0 8px 32px rgba(0,0,0,.1); opacity: 0; pointer-events: none; transform: translateY(-5px); transition: all .18s; }
.ni:hover .dd { opacity: 1; pointer-events: all; transform: translateY(0); }
.ddi { display: block; width: 100%; padding: 9px 18px; font-size: 13px; color: var(--ink2); background: none; border: none; font-family: inherit; text-align: left; font-weight: 500; cursor: pointer; transition: background .1s; text-decoration: none; }
.ddi:hover { background: var(--red-l); color: var(--red); }
.dd-s { height: 1px; background: var(--border); margin: 4px 0; }
.hdr-r { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.icon-btn { width: 34px; height: 34px; border: 1.5px solid var(--border); border-radius: 7px; background: none; color: var(--ink3); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .15s; text-decoration: none; }
.icon-btn:hover { border-color: var(--red); color: var(--red); }

/* ─── HERO ───────────────────────────────────────────────────────── */
.hero { height: 520px; display: grid; grid-template-columns: 1fr 1fr; position: relative; overflow: hidden; }
.hero-side { position: relative; overflow: hidden; display: flex; align-items: flex-end; }
.hero-rnr { background: linear-gradient(150deg,#1a0303 0%,#5a0e0e 40%,#c42020 80%,#e12625 100%); }
.hero-bw  { background: linear-gradient(150deg,#0a0a0a 0%,#1a1a1a 40%,#2d2d2d 80%,#3d3d3d 100%); }
.hero-side::before { content:''; position: absolute; inset: 0; background-image: repeating-linear-gradient(-50deg,transparent 0,transparent 50px,rgba(255,255,255,.028) 50px,rgba(255,255,255,.028) 51px); }
.hero-illus { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.hero-badge { position: absolute; top: 28px; left: 28px; display: flex; align-items: center; gap: 8px; font-size: 10px; font-weight: 800; letter-spacing: 2.5px; text-transform: uppercase; color: rgba(255,255,255,.55); }
.hero-badge::before { content: ''; width: 18px; height: 1.5px; background: var(--red); }
.hero-bw .hero-badge::before { background: rgba(255,255,255,.4); }
.hero-content { position: relative; z-index: 2; padding: 0 32px 44px; width: 100%; }
.hero-disc { font-family: 'Barlow Condensed', sans-serif; font-size: 56px; font-weight: 900; line-height: .9; color: white; text-transform: uppercase; letter-spacing: -1.5px; margin-bottom: 14px; }
.hero-disc em { font-style: italic; opacity: .55; display: block; font-size: .62em; letter-spacing: -0.5px; }
.hero-tagline { font-size: 13px; color: rgba(255,255,255,.5); line-height: 1.6; max-width: 240px; margin-bottom: 20px; }
.hero-eyebrow { font-size: 10.5px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.42); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.hero-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--red); }
.hero-cta { display: inline-flex; align-items: center; gap: 7px; padding: 10px 20px; border-radius: 8px; font-size: 12.5px; font-weight: 700; cursor: pointer; font-family: inherit; letter-spacing: .2px; transition: all .18s; text-decoration: none; border: none; }
.hero-cta-r { background: white; color: var(--red); }
.hero-cta-r:hover { background: var(--red-l); }
.hero-cta-g { background: rgba(255,255,255,.12); color: white; border: 1.5px solid rgba(255,255,255,.25); }
.hero-cta-g:hover { background: rgba(255,255,255,.2); border-color: rgba(255,255,255,.5); }
.hero-center { position: absolute; top: 0; bottom: 0; left: 50%; transform: translateX(-50%); width: 2px; background: rgba(255,255,255,.12); z-index: 10; }
.hero-center-badge { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); background: white; border-radius: 50%; width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; z-index: 11; box-shadow: 0 4px 20px rgba(0,0,0,.3); }
.hero-strip { position: absolute; bottom: 0; left: 0; right: 0; background: rgba(10,10,10,.75); backdrop-filter: blur(12px); display: flex; border-top: 1px solid rgba(255,255,255,.07); z-index: 10; }
.hs { flex: 1; padding: 12px 32px; border-right: 1px solid rgba(255,255,255,.07); }
.hs:last-child { border-right: none; }
.hs-n { font-family: 'Barlow Condensed', sans-serif; font-size: 26px; font-weight: 900; color: white; line-height: 1; }
.hs-l { font-size: 10px; text-transform: uppercase; letter-spacing: .5px; color: rgba(255,255,255,.35); margin-top: 2px; }

/* ─── PROFIL BAR ─────────────────────────────────────────────────── */
.pb-outer { background: white; border-bottom: 1px solid var(--border); }
.pb-in { max-width: var(--W); margin: 0 auto; padding: 14px 40px; }
.pb-lbl { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ink3); margin-bottom: 10px; }
.pb-btns { display: flex; gap: 7px; flex-wrap: wrap; }
.pbb { padding: 7px 14px; border: 1.5px solid var(--border); border-radius: 100px; background: white; cursor: pointer; font-family: inherit; font-size: 12.5px; font-weight: 600; color: var(--ink2); display: flex; align-items: center; gap: 5px; transition: all .18s; text-decoration: none; }
.pbb i { font-size: 15px; color: var(--ink3); }
.pbb:hover { border-color: var(--red); background: var(--red-l); color: var(--red); }
.pbb:hover i { color: var(--red); }

/* ─── TICKER ─────────────────────────────────────────────────────── */
.ticker { background: var(--red); }
.ticker-in { max-width: var(--W); margin: 0 auto; padding: 11px 40px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.t-pulse { width: 7px; height: 7px; background: white; border-radius: 50%; box-shadow: 0 0 0 3px rgba(255,255,255,.2); flex-shrink: 0; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100% { box-shadow: 0 0 0 3px rgba(255,255,255,.2); } 50% { box-shadow: 0 0 0 7px rgba(255,255,255,.04); } }
.t-info { flex: 1; min-width: 180px; }
.t-title { font-size: 14px; font-weight: 800; color: white; }
.t-sub { font-size: 11px; color: rgba(255,255,255,.65); margin-top: 1px; }
.cd { display: flex; align-items: center; gap: 5px; }
.cdb { background: rgba(0,0,0,.16); border-radius: 6px; padding: 4px 9px; text-align: center; min-width: 42px; }
.cdn { font-family: 'Barlow Condensed', sans-serif; font-size: 21px; font-weight: 900; color: white; line-height: 1; }
.cdl { font-size: 8px; text-transform: uppercase; color: rgba(255,255,255,.5); letter-spacing: .5px; }
.cds { font-size: 14px; font-weight: 800; color: rgba(255,255,255,.3); }
.t-btn { padding: 8px 18px; background: white; color: var(--red); border: none; border-radius: 6px; font-size: 12.5px; font-weight: 800; cursor: pointer; font-family: inherit; margin-left: 10px; white-space: nowrap; transition: opacity .15s; text-decoration: none; display: inline-block; }
.t-btn:hover { opacity: .88; }

/* ─── HOME CARDS ─────────────────────────────────────────────────── */
.home-cards { background: var(--bg); }
.home-cards-in { max-width: var(--W); margin: 0 auto; padding: 32px 40px; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 18px; }
.card { background: white; border-radius: 14px; overflow: hidden; box-shadow: 0 2px 20px rgba(0,0,0,.055); }
.card-h { padding: 16px 20px 13px; display: flex; align-items: center; justify-content: space-between; }
.ch-l { display: flex; align-items: center; gap: 9px; }
.c-ico { width: 32px; height: 32px; border-radius: 8px; background: var(--red); display: flex; align-items: center; justify-content: center; }
.c-ico i { font-size: 16px; color: white; }
.c-title { font-size: 13px; font-weight: 800; color: var(--ink); text-transform: uppercase; letter-spacing: .2px; }
.c-more { font-size: 12px; font-weight: 700; color: var(--red); background: none; border: none; cursor: pointer; font-family: inherit; display: flex; align-items: center; gap: 3px; transition: gap .15s; text-decoration: none; }
.c-more:hover { gap: 6px; }
.c-line { height: 1px; background: var(--border); margin: 0 20px; }
.card-body { padding: 6px 20px 12px; }
.cal-item { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.cal-item:last-of-type { border-bottom: none; }
.cal-dt { min-width: 32px; text-align: center; }
.cal-d { font-family: 'Barlow Condensed', sans-serif; font-size: 23px; font-weight: 900; color: var(--red); line-height: 1; }
.cal-m { font-size: 9px; text-transform: uppercase; color: var(--ink3); letter-spacing: .4px; }
.cal-txt { flex: 1; }
.cal-name { font-size: 12.5px; font-weight: 700; color: var(--ink); }
.cal-loc { font-size: 11px; color: var(--ink3); display: flex; align-items: center; gap: 2px; margin-top: 1px; }
.add-cal { width: 28px; height: 28px; border: 1.5px solid var(--border); border-radius: 7px; background: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--ink3); flex-shrink: 0; transition: all .18s; text-decoration: none; }
.add-cal:hover { background: var(--red); border-color: var(--red); color: white; transform: scale(1.06); }
.add-cal i { font-size: 14px; }
.doc-item { display: flex; align-items: center; gap: 9px; padding: 8px 0; border-bottom: 1px solid var(--border); cursor: pointer; text-decoration: none; }
.doc-item:last-of-type { border-bottom: none; }
.doc-item:hover .dn { color: var(--red); }
.dbg { font-size: 9px; font-weight: 800; padding: 2px 5px; border-radius: 4px; letter-spacing: .3px; }
.bp { background: #fff0f0; color: #b81e1d; }
.bx { background: #f0faf0; color: #1a7035; }
.bd { background: #eff4ff; color: #1a4296; }
.bo { background: #f4f4f4; color: #555; }
.dn { font-size: 12.5px; font-weight: 600; color: var(--ink); flex: 1; transition: color .15s; line-height: 1.3; }
.da { font-size: 13px; color: var(--ink3); }
.ni-item { padding: 10px 0; border-bottom: 1px solid var(--border); cursor: pointer; }
.ni-item:last-of-type { border-bottom: none; }
.ni-item:hover .n-title { color: var(--red); }
.n-tag { display: inline-flex; font-size: 9px; font-weight: 800; padding: 2px 7px; border-radius: 4px; text-transform: uppercase; letter-spacing: .4px; margin-bottom: 4px; }
.nf { background: #fff0f0; color: #b81e1d; }
.nc { background: #f0f0f0; color: #555; }
.nm { background: #f0faf0; color: #1a7035; }
.n-date { font-size: 10px; color: var(--ink3); margin-bottom: 2px; }
.n-title { font-size: 12.5px; font-weight: 700; color: var(--ink); line-height: 1.4; transition: color .15s; }

/* ─── DISCIPLINES ────────────────────────────────────────────────── */
.disc-section { background: white; padding: 64px 0; }
.disc-in { max-width: var(--W); margin: 0 auto; padding: 0 40px; }
.disc-title { font-family: 'Barlow Condensed', sans-serif; font-size: 48px; font-weight: 900; text-transform: uppercase; letter-spacing: -1px; margin-bottom: 6px; color: var(--ink); }
.disc-title span { color: var(--red); }
.disc-subtitle { font-size: 15px; color: var(--ink3); margin-bottom: 40px; }
.disc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.disc-card { border-radius: 18px; overflow: hidden; }
.disc-card-visual { height: 240px; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.disc-card-rnr .disc-card-visual { background: linear-gradient(140deg,#1a0303,#7a1212,#e12625); }
.disc-card-bw .disc-card-visual  { background: linear-gradient(140deg,#0a0a0a,#1a1a1a,#444); }
.disc-card-visual::before { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(-45deg,transparent 0,transparent 40px,rgba(255,255,255,.03) 40px,rgba(255,255,255,.03) 41px); }
.disc-pill { position: absolute; top: 18px; left: 18px; z-index: 4; background: rgba(255,255,255,.15); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,.2); border-radius: 100px; padding: 5px 12px; font-size: 10.5px; font-weight: 700; color: white; letter-spacing: 1px; text-transform: uppercase; }
.disc-card-rnr .disc-pill { background: rgba(225,38,37,.35); border-color: rgba(225,38,37,.4); }
.disc-card-body { background: var(--bg); padding: 24px 26px 26px; }
.disc-card-title { font-family: 'Barlow Condensed', sans-serif; font-size: 32px; font-weight: 900; text-transform: uppercase; letter-spacing: -.5px; margin-bottom: 8px; line-height: 1; }
.disc-card-rnr .disc-card-title { color: var(--red); }
.disc-card-bw  .disc-card-title { color: var(--ink); }
.disc-card-desc { font-size: 13.5px; color: var(--ink2); line-height: 1.75; margin-bottom: 18px; }
.disc-links { display: flex; gap: 8px; flex-wrap: wrap; }
.disc-link { padding: 8px 16px; border-radius: 8px; font-size: 12.5px; font-weight: 700; cursor: pointer; font-family: inherit; border: none; transition: all .15s; display: inline-flex; align-items: center; gap: 5px; text-decoration: none; }
.disc-link-p { background: var(--red); color: white; }
.disc-link-p:hover { background: var(--red-d); }
.disc-link-s { background: white; color: var(--ink); border: 1.5px solid var(--border); }
.disc-link-s:hover { border-color: var(--red); color: var(--red); }

/* ─── PAGE HEADER ────────────────────────────────────────────────── */
.pg-top { background: var(--ink); padding: 48px 40px 42px; position: relative; overflow: hidden; }
.pg-top::before { content: ''; position: absolute; inset: 0; background: linear-gradient(115deg,rgba(225,38,37,.55) 0%,transparent 55%); }
.pg-top::after  { content: ''; position: absolute; inset: 0; background-image: repeating-linear-gradient(-50deg,transparent 0,transparent 55px,rgba(255,255,255,.015) 55px,rgba(255,255,255,.015) 56px); }
.pg-top-in { max-width: var(--W); margin: 0 auto; position: relative; z-index: 1; }
.pg-ew { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: 10px; }
.pg-ew a { color: rgba(255,255,255,.4); text-decoration: none; }
.pg-h1 { font-family: 'Barlow Condensed', sans-serif; font-size: 48px; font-weight: 900; color: white; text-transform: uppercase; letter-spacing: -1.5px; line-height: 1; }
.pg-sub { font-size: 13.5px; color: rgba(255,255,255,.38); margin-top: 8px; }
.pg-body { max-width: var(--W); margin: 0 auto; padding: 36px 40px; }

/* ─── GENERIC CONTENT ────────────────────────────────────────────── */
.content-box { background: white; border-radius: 14px; padding: 28px; margin-bottom: 16px; box-shadow: 0 2px 14px rgba(0,0,0,.05); }
.content-box h2, .content-box h3 { font-size: 15px; font-weight: 800; color: var(--ink); margin-bottom: 14px; text-transform: uppercase; letter-spacing: .3px; padding-bottom: 10px; border-bottom: 2px solid var(--red); }
.content-box p { font-size: 13.5px; color: var(--ink2); line-height: 1.78; margin-bottom: 12px; }
.content-box p:last-child { margin-bottom: 0; }
.content-box ul, .content-box ol { font-size: 13.5px; color: var(--ink2); line-height: 1.9; padding-left: 20px; margin-bottom: 12px; }
.content-box a { color: var(--red); text-decoration: none; font-weight: 600; }
.pg-2col { display: grid; grid-template-columns: 2fr 1fr; gap: 22px; }
.sb { display: flex; flex-direction: column; gap: 12px; }
.sb-box { background: white; border-radius: 14px; padding: 20px; box-shadow: 0 2px 12px rgba(0,0,0,.05); }
.sb-box h4 { font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ink3); margin-bottom: 13px; }
.sb-lk { display: block; font-size: 13px; font-weight: 600; color: var(--ink2); padding: 7px 0; border-bottom: 1px solid var(--border); cursor: pointer; background: none; border-left: none; border-right: none; border-top: none; font-family: inherit; text-align: left; transition: color .15s; text-decoration: none; }
.sb-lk:last-child { border-bottom: none; }
.sb-lk:hover { color: var(--red); }
.doc-list { background: white; border-radius: 14px; overflow: hidden; box-shadow: 0 2px 14px rgba(0,0,0,.05); }
.dlr { display: flex; align-items: center; gap: 11px; padding: 12px 18px; border-bottom: 1px solid var(--border); cursor: pointer; transition: background .1s; text-decoration: none; color: inherit; }
.dlr:last-child { border-bottom: none; }
.dlr:hover { background: var(--bg); }
.dl-n { flex: 1; font-size: 13px; font-weight: 600; color: var(--ink); }
.dl-sz { font-size: 11px; color: var(--ink3); }
.dl-btn { width: 28px; height: 28px; border: 1.5px solid var(--border); border-radius: 6px; background: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: var(--ink3); transition: all .15s; flex-shrink: 0; }
.dl-btn:hover { background: var(--red); color: white; border-color: var(--red); }
.nf-row { display: flex; gap: 16px; padding: 15px 0; border-bottom: 1px solid var(--border); cursor: pointer; }
.nf-row:last-of-type { border-bottom: none; }
.nf-row:hover .nf-t { color: var(--red); }
.nf-date { font-size: 11px; color: var(--ink3); min-width: 80px; padding-top: 2px; }
.nf-t { font-size: 13.5px; font-weight: 700; color: var(--ink); margin-bottom: 2px; transition: color .15s; }
.nf-sub { font-size: 12px; color: var(--ink3); }
.fb { padding: 7px 16px; border: 1.5px solid var(--border); border-radius: 100px; font-size: 12.5px; font-weight: 700; cursor: pointer; font-family: inherit; background: white; color: var(--ink2); transition: all .15s; text-decoration: none; display: inline-block; }
.fb.on, .fb:hover { background: var(--red); color: white; border-color: var(--red); }
.cal-sh { font-family: 'Barlow Condensed', sans-serif; font-size: 22px; font-weight: 900; text-transform: uppercase; letter-spacing: .5px; color: var(--red); padding: 14px 0 7px; border-top: 3px solid var(--red); margin-top: 20px; }
.cal-sh:first-child { margin-top: 0; }
.clubs-g { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.club-c { background: white; border: 1.5px solid var(--border); border-radius: 12px; padding: 16px; transition: border-color .15s; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.club-c:hover { border-color: var(--red); }
.club-n { font-size: 13.5px; font-weight: 800; color: var(--ink); margin-bottom: 5px; }
.club-i { font-size: 12px; color: var(--ink3); line-height: 1.7; }
.club-i a { color: var(--red); text-decoration: none; font-weight: 600; }
.canton-h { font-size: 10.5px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ink3); padding: 9px 0 8px; border-bottom: 2px solid var(--red); margin-top: 22px; margin-bottom: 13px; }
.canton-h:first-child { margin-top: 0; }

/* ─── FOOTER ─────────────────────────────────────────────────────── */
footer { background: var(--ink); }
.ft { max-width: var(--W); margin: 0 auto; padding: 48px 40px 32px; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px; border-bottom: 1px solid rgba(255,255,255,.06); }
.f-brand p { font-size: 12.5px; color: rgba(255,255,255,.28); line-height: 1.8; margin-top: 14px; }
.f-col h4 { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,.18); margin-bottom: 15px; }
.fl { display: block; font-size: 13px; font-weight: 500; color: rgba(255,255,255,.38); cursor: pointer; background: none; border: none; font-family: inherit; text-align: left; padding: 0 0 9px; transition: color .15s; text-decoration: none; }
.fl:hover { color: rgba(255,255,255,.9); }
.fb-ot { max-width: var(--W); margin: 0 auto; padding: 15px 40px; display: flex; align-items: center; justify-content: space-between; }
.f-copy { font-size: 11px; color: rgba(255,255,255,.18); }
.f-soc { display: flex; gap: 5px; }
.fsb { width: 30px; height: 30px; border: 1px solid rgba(255,255,255,.1); border-radius: 7px; background: none; cursor: pointer; color: rgba(255,255,255,.25); display: flex; align-items: center; justify-content: center; transition: all .15s; text-decoration: none; }
.fsb:hover { border-color: var(--red); color: var(--red); }
.fsb i { font-size: 14px; }

/* ════════════════════════════════════════════════════════════════
   ADMIN STYLES
════════════════════════════════════════════════════════════════ */

.admin-body { background: #f0f2f5; min-height: 100vh; }
.admin-wrap { display: flex; min-height: 100vh; }

/* Sidebar */
.admin-sidebar { width: 240px; background: #1a1a2e; display: flex; flex-direction: column; position: fixed; top: 0; bottom: 0; left: 0; z-index: 100; overflow-y: auto; }
.admin-sidebar-logo { padding: 20px 20px 16px; border-bottom: 1px solid rgba(255,255,255,.06); }
.admin-nav { flex: 1; padding: 12px 0; }
.admin-nav-label { font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; color: rgba(255,255,255,.2); padding: 14px 20px 6px; }
.admin-nav-group { margin-bottom: 2px; }
.admin-nav-item { display: flex; align-items: center; gap: 10px; padding: 9px 20px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.5); text-decoration: none; transition: all .15s; cursor: pointer; background: none; border: none; width: 100%; font-family: inherit; }
.admin-nav-item i { font-size: 17px; flex-shrink: 0; }
.admin-nav-item:hover { color: white; background: rgba(255,255,255,.06); }
.admin-nav-item.active { color: white; background: rgba(225,38,37,.2); border-right: 3px solid var(--red); }
.admin-sidebar-footer { padding: 12px 0; border-top: 1px solid rgba(255,255,255,.06); }
.admin-logout { color: rgba(255,100,100,.6) !important; }
.admin-logout:hover { color: #ff6464 !important; background: rgba(255,50,50,.1) !important; }

/* Main area */
.admin-main { margin-left: 240px; flex: 1; display: flex; flex-direction: column; min-height: 100vh; }
.admin-topbar { background: white; border-bottom: 1px solid var(--border); padding: 0 32px; height: 60px; display: flex; align-items: center; gap: 16px; position: sticky; top: 0; z-index: 50; }
.admin-menu-toggle { display: none; background: none; border: none; cursor: pointer; font-size: 20px; color: var(--ink2); }
.admin-page-title { font-size: 17px; font-weight: 800; color: var(--ink); flex: 1; }
.admin-topbar-r { display: flex; align-items: center; gap: 10px; }
.admin-user { font-size: 13px; font-weight: 600; color: var(--ink3); display: flex; align-items: center; gap: 6px; }
.admin-role-badge { font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 100px; background: #f0f0f0; color: #666; text-transform: uppercase; }
.admin-content { padding: 28px 32px; flex: 1; }

/* Flash messages */
.admin-flash { padding: 0 32px; margin-top: 4px; }
.flash-success, .flash-error, .flash-warning { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-radius: 10px; font-size: 13.5px; font-weight: 600; margin-bottom: 8px; }
.flash-success { background: #f0faf0; color: #166534; border: 1px solid #bbf7d0; }
.flash-error   { background: #fff0f0; color: #991b1b; border: 1px solid #fecaca; }
.flash-warning { background: #fffbeb; color: #92400e; border: 1px solid #fde68a; }

/* Panels */
.admin-panel { background: white; border-radius: 12px; overflow: hidden; box-shadow: 0 1px 8px rgba(0,0,0,.06); }
.admin-panel-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; border-bottom: 1px solid var(--border); font-size: 13px; font-weight: 800; color: var(--ink); text-transform: uppercase; letter-spacing: .3px; }
.admin-panel-body { padding: 20px; }
.admin-empty { padding: 28px 20px; text-align: center; color: var(--ink3); font-size: 13.5px; }
.admin-empty a { color: var(--red); font-weight: 700; }
.admin-dash-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 20px; }

/* Stats grid */
.admin-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 0; }
.admin-stat-card { background: white; border-radius: 12px; padding: 20px; box-shadow: 0 1px 8px rgba(0,0,0,.06); }
.admin-stat-icon { width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.admin-stat-icon i { font-size: 22px; }
.admin-stat-val { font-family: 'Barlow Condensed', sans-serif; font-size: 36px; font-weight: 900; color: var(--ink); line-height: 1; }
.admin-stat-lbl { font-size: 12px; color: var(--ink3); font-weight: 600; margin-top: 3px; }
.admin-stat-link { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 700; color: var(--red); text-decoration: none; margin-top: 10px; transition: gap .1s; }
.admin-stat-link:hover { gap: 7px; }

/* Tables */
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: var(--ink3); padding: 10px 16px; border-bottom: 1px solid var(--border); text-align: left; background: #fafafa; }
.admin-table td { padding: 11px 16px; border-bottom: 1px solid var(--border); font-size: 13px; color: var(--ink2); vertical-align: middle; }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: #fafcff; }
.admin-actions { display: flex; gap: 6px; }

/* Badges */
.admin-badge { display: inline-flex; align-items: center; font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: 100px; text-transform: uppercase; letter-spacing: .3px; }
.badge-green { background: #f0faf0; color: #166534; }
.badge-gray  { background: #f4f4f4; color: #666; }
.badge-red   { background: #fff0f0; color: #991b1b; }

/* Buttons */
.admin-btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 12.5px; font-weight: 700; cursor: pointer; font-family: inherit; background: white; color: var(--ink2); text-decoration: none; transition: all .15s; white-space: nowrap; }
.admin-btn:hover { border-color: var(--ink3); color: var(--ink); }
.admin-btn-sm { padding: 5px 10px; font-size: 12px; border-radius: 6px; }
.admin-btn-primary { background: var(--red); border-color: var(--red); color: white; }
.admin-btn-primary:hover { background: var(--red-d); border-color: var(--red-d); color: white; }
.admin-btn-danger { background: none; border-color: #fecaca; color: #dc2626; }
.admin-btn-danger:hover { background: #fff0f0; }

/* Forms */
.admin-form-group { margin-bottom: 16px; }
.admin-form-group:last-child { margin-bottom: 0; }
.admin-label { display: block; font-size: 12px; font-weight: 700; color: var(--ink2); margin-bottom: 5px; }
.admin-input { display: block; width: 100%; padding: 9px 12px; border: 1.5px solid var(--border); border-radius: 8px; font-size: 13.5px; font-family: inherit; color: var(--ink); background: white; transition: border-color .15s; }
.admin-input:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3px rgba(225,38,37,.08); }
textarea.admin-input { resize: vertical; }
select.admin-input { cursor: pointer; }
input[type="file"].admin-input { padding: 7px 12px; cursor: pointer; }
.admin-hint { font-size: 11px; color: var(--ink3); margin-top: 4px; }
.admin-check-label { display: flex; align-items: center; gap: 8px; font-size: 13.5px; font-weight: 600; color: var(--ink2); cursor: pointer; }
.admin-check-label input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; accent-color: var(--red); }
.admin-form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }

/* Login page */
.admin-login-body { background: linear-gradient(135deg, #0d0d0d 0%, #1a0303 50%, #2d0505 100%); min-height: 100vh; display: flex; align-items: center; justify-content: center; }
.admin-login-wrap { width: 100%; max-width: 420px; padding: 20px; }
.admin-login-box { background: white; border-radius: 18px; padding: 36px; box-shadow: 0 20px 60px rgba(0,0,0,.4); }
.admin-login-logo { margin-bottom: 24px; }

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════════════ */

@media (max-width: 1024px) {
  .home-cards-in { grid-template-columns: 1fr 1fr; }
  .disc-title { font-size: 36px; }
  .ft { grid-template-columns: 1fr 1fr; gap: 28px; }
  .admin-stats-grid { grid-template-columns: 1fr 1fr; }
  .admin-dash-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  /* Topbar */
  .tb { padding: 0 16px; height: auto; min-height: 36px; flex-wrap: wrap; }
  .tb-l { display: none; }

  /* Header */
  .hdr-in { padding: 0 16px; gap: 12px; height: 58px; }
  .logo { height: 32px; }
  nav { display: none; }
  .hdr-in .icon-btn:not([aria-label="Administration"]) { display: none; }

  /* Add a mobile menu button */
  .hdr-in { position: relative; }

  /* Hero */
  .hero { height: auto; grid-template-columns: 1fr; min-height: 400px; }
  .hero-bw { display: none; }
  .hero-rnr { min-height: 380px; }
  .hero-center { display: none; }
  .hero-strip { position: relative; flex-wrap: wrap; }
  .hs { padding: 10px 16px; }
  .hero-disc { font-size: 40px; }
  .hero-content { padding: 0 20px 140px; }

  /* Ticker */
  .ticker-in { padding: 10px 16px; flex-wrap: wrap; gap: 10px; }
  .cd { display: none; }

  /* Home cards */
  .home-cards-in { grid-template-columns: 1fr; padding: 20px 16px; }

  /* Profile bar */
  .pb-in { padding: 12px 16px; }

  /* Disciplines */
  .disc-section { padding: 40px 0; }
  .disc-in { padding: 0 16px; }
  .disc-grid { grid-template-columns: 1fr; }
  .disc-title { font-size: 32px; }

  /* Page header */
  .pg-top { padding: 32px 16px 28px; }
  .pg-h1 { font-size: 34px; }
  .pg-body { padding: 20px 16px; }
  .pg-2col { grid-template-columns: 1fr; }
  .sb { display: none; }

  /* Footer */
  .ft { padding: 32px 16px 24px; grid-template-columns: 1fr; gap: 24px; }
  .fb-ot { padding: 12px 16px; flex-direction: column; gap: 8px; text-align: center; }

  /* Clubs */
  .clubs-g { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  /* Admin responsive */
  .admin-sidebar { display: none; }
  .admin-sidebar.open { display: flex; }
  .admin-main { margin-left: 0; }
  .admin-menu-toggle { display: flex; }
  .admin-content { padding: 16px; }
  .admin-topbar { padding: 0 16px; }
  .admin-form-grid-2 { grid-template-columns: 1fr; }
  .admin-stats-grid { grid-template-columns: 1fr 1fr; }
  .admin-table { font-size: 12px; }
  .admin-table th, .admin-table td { padding: 8px 10px; }
}
