/* Main Stylesheet */
/* All class names are randomised and non-semantic */

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

:root {
  --c-bg:        #090c14;
  --c-surf1:     #0f1420;
  --c-surf2:     #151b2e;
  --c-surf3:     #1c2338;
  --c-border:    #242d44;
  --c-gold:      #e0a020;
  --c-gold-lt:   #f0b830;
  --c-blue:      #3a7fd4;
  --c-blue-lt:   #5096e8;
  --c-green:     #28a86e;
  --c-red:       #d44040;
  --c-warn:      #e08020;
  --c-txt1:      #edf0f5;
  --c-txt2:      #9aa3b8;
  --c-txt3:      #5e6880;
  --c-white:     #ffffff;
  --f-head:      'Inter', 'Segoe UI', system-ui, sans-serif;
  --f-body:      'Inter', 'Segoe UI', system-ui, sans-serif;
  --r-sm:        6px;
  --r-md:        10px;
  --r-lg:        16px;
  --shadow-sm:   0 2px 8px rgba(0,0,0,.35);
  --shadow-md:   0 4px 20px rgba(0,0,0,.5);
  --shadow-lg:   0 8px 40px rgba(0,0,0,.6);
  --transition:  0.22s ease;
}

html { font-size: 16px; scroll-behavior: smooth; }

body {
  background: var(--c-bg);
  color: var(--c-txt1);
  font-family: var(--f-body);
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}

img { display: block; max-width: 100%; height: auto; }
a { color: var(--c-gold); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--c-gold-lt); }
ul { list-style: none; }

/* ── Typography ── */
.xq7 { font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 700; line-height: 1.18; letter-spacing: -.02em; }
.mz4 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 700; line-height: 1.22; letter-spacing: -.015em; }
.kp9 { font-size: clamp(1.1rem, 2vw, 1.35rem); font-weight: 600; line-height: 1.3; }
.nf2 { font-size: .9rem; color: var(--c-txt2); line-height: 1.6; }
.wr6 { font-size: .8rem; color: var(--c-txt3); }

/* ── Layout ── */
.pvx { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.pvx--wide { max-width: 1400px; margin: 0 auto; padding: 0 24px; }
.grd2 { display: grid; gap: 24px; }
.grd2--2 { grid-template-columns: repeat(2, 1fr); }
.grd2--3 { grid-template-columns: repeat(3, 1fr); }
.grd2--4 { grid-template-columns: repeat(4, 1fr); }
.flx { display: flex; align-items: center; }
.flx--gap { gap: 16px; }
.flx--between { justify-content: space-between; }
.flx--center { justify-content: center; }
.flx--col { flex-direction: column; }
.flx--wrap { flex-wrap: wrap; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 28px; border-radius: var(--r-md); border: none; cursor: pointer;
  font-size: .95rem; font-weight: 600; font-family: var(--f-body);
  transition: all var(--transition); white-space: nowrap;
  text-decoration: none; line-height: 1;
}
.btn--gold {
  background: var(--c-gold); color: #000;
}
.btn--gold:hover { background: var(--c-gold-lt); color: #000; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(224,160,32,.4); }
.btn--outline {
  background: transparent; color: var(--c-txt1); border: 1.5px solid var(--c-border);
}
.btn--outline:hover { border-color: var(--c-gold); color: var(--c-gold); }
.btn--blue {
  background: var(--c-blue); color: #fff;
}
.btn--blue:hover { background: var(--c-blue-lt); color: #fff; transform: translateY(-1px); }
.btn--sm { padding: 8px 18px; font-size: .85rem; }
.btn--lg { padding: 15px 36px; font-size: 1.05rem; }

/* ── Age Verification Modal ── */
.agemod {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(5,8,16,.97);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
}
.agemod.hidden { display: none; }
.agemod__box {
  background: var(--c-surf2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  max-width: 480px; width: 100%;
  padding: 48px 40px;
  text-align: center;
  box-shadow: var(--shadow-lg);
}
.agemod__badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--c-surf3);
  border: 2.5px solid var(--c-gold);
  font-size: 1.5rem; font-weight: 800; color: var(--c-gold);
  margin: 0 auto 24px;
}
.agemod__title { font-size: 1.6rem; font-weight: 700; margin-bottom: 12px; }
.agemod__text { color: var(--c-txt2); font-size: .95rem; line-height: 1.65; margin-bottom: 32px; }
.agemod__btns { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.agemod__denied {
  display: none;
  background: var(--c-surf1);
  border: 1px solid var(--c-red);
  border-radius: var(--r-md);
  padding: 24px;
  color: var(--c-txt2);
  font-size: .9rem;
}

/* ── Cookie Banner ── */
.ckb {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 8000;
  background: var(--c-surf2);
  border-top: 1px solid var(--c-border);
  padding: 20px 0;
  transform: translateY(100%);
  transition: transform 0.4s ease;
  box-shadow: 0 -4px 24px rgba(0,0,0,.5);
}
.ckb.visible { transform: translateY(0); }
.ckb__inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
}
.ckb__txt { flex: 1; min-width: 260px; font-size: .88rem; color: var(--c-txt2); line-height: 1.55; }
.ckb__btns { display: flex; gap: 10px; flex-wrap: wrap; flex-shrink: 0; }

/* ── Navigation ── */
.nav {
  position: sticky; top: 0; z-index: 1000;
  background: rgba(9,12,20,.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--c-border);
}
.nav__inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  height: 68px;
  display: flex; align-items: center; justify-content: space-between;
}
.nav__brand {
  display: flex; align-items: center; gap: 10px;
  font-size: 1.2rem; font-weight: 800; color: var(--c-txt1);
  text-decoration: none;
}
.nav__brand:hover { color: var(--c-txt1); }
.nav__brand-mark {
  width: 36px; height: 36px;
  border-radius: 8px;
  flex-shrink: 0;
  object-fit: contain;
}
.nav__brand-txt span { color: var(--c-gold); }
.nav__menu {
  display: flex; align-items: center; gap: 4px;
}
.nav__item {
  font-size: .88rem; font-weight: 500; color: var(--c-txt2);
  padding: 8px 14px; border-radius: var(--r-sm);
  transition: all var(--transition);
  text-decoration: none; display: block;
}
.nav__item:hover, .nav__item.active { color: var(--c-txt1); background: var(--c-surf2); }
.nav__toggle {
  display: none;
  background: none; border: none; cursor: pointer;
  padding: 8px; color: var(--c-txt1); font-size: 1.4rem;
  flex-direction: column; gap: 5px;
}
.nav__toggle-bar {
  display: block; width: 24px; height: 2px;
  background: var(--c-txt1); border-radius: 2px;
  transition: all var(--transition);
}
.nav__mob { display: none; flex-direction: column; }
.nav__mob.open {
  display: flex;
  padding: 12px 24px 20px;
  border-top: 1px solid var(--c-border);
  background: var(--c-surf1);
}
.nav__mob .nav__item { padding: 10px 12px; border-radius: var(--r-sm); }

/* ── Hero ── */
.hero {
  padding: 80px 0 72px;
  background: linear-gradient(160deg, #0c1122 0%, #090c14 60%);
  position: relative; overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 600px; height: 400px;
  background: radial-gradient(ellipse, rgba(224,160,32,.07) 0%, transparent 70%);
  pointer-events: none;
}
.hero__inner {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.hero__label {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; background: var(--c-surf3); border: 1px solid var(--c-border);
  border-radius: 100px; font-size: .8rem; color: var(--c-txt2);
  margin-bottom: 20px;
}
.hero__label-dot { width: 7px; height: 7px; background: var(--c-green); border-radius: 50%; animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.85)} }
.hero__title { margin-bottom: 18px; }
.hero__desc { color: var(--c-txt2); font-size: 1.05rem; line-height: 1.7; margin-bottom: 32px; max-width: 480px; }
.hero__btns { display: flex; gap: 14px; flex-wrap: wrap; }
.hero__visual {
  display: flex; align-items: center; justify-content: center;
}
.hero__stats {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; width: 100%;
}
.hero__stat {
  background: var(--c-surf2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: 22px 20px;
  text-align: center;
}
.hero__stat-num { font-size: 1.8rem; font-weight: 800; color: var(--c-gold); line-height: 1; margin-bottom: 6px; }
.hero__stat-lbl { font-size: .8rem; color: var(--c-txt2); }

/* ── Section ── */
.sec { padding: 64px 0; }
.sec--alt { background: var(--c-surf1); }
.sec--dark { background: var(--c-surf2); }
.sec__head { text-align: center; margin-bottom: 48px; }
.sec__label {
  display: inline-block; padding: 5px 14px;
  background: rgba(224,160,32,.1); border: 1px solid rgba(224,160,32,.25);
  border-radius: 100px; font-size: .78rem; font-weight: 600;
  color: var(--c-gold); letter-spacing: .06em; text-transform: uppercase;
  margin-bottom: 14px;
}
.sec__title { margin-bottom: 14px; }
.sec__desc { color: var(--c-txt2); max-width: 580px; margin: 0 auto; line-height: 1.7; }

/* ── Listing Cards ── */
.lcrd {
  background: var(--c-surf1);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.lcrd:hover { border-color: var(--c-gold); box-shadow: 0 0 0 1px rgba(224,160,32,.15), var(--shadow-md); }
.lcrd__top {
  background: var(--c-surf2);
  padding: 28px 28px 24px;
  border-bottom: 1px solid var(--c-border);
  display: flex; align-items: center; gap: 20px;
}
.lcrd__logo {
  width: 88px; height: 56px;
  object-fit: contain; object-position: center;
  flex-shrink: 0;
}
.lcrd__meta { flex: 1; }
.lcrd__name { font-size: 1.15rem; font-weight: 700; margin-bottom: 4px; }
.lcrd__tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.lcrd__tag {
  padding: 3px 10px; background: var(--c-surf3); border: 1px solid var(--c-border);
  border-radius: 100px; font-size: .73rem; color: var(--c-txt2); font-weight: 500;
}
.lcrd__body { padding: 24px 28px; }
.lcrd__desc { color: var(--c-txt2); font-size: .9rem; line-height: 1.65; margin-bottom: 20px; }
.lcrd__feats { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.lcrd__feat {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .88rem; color: var(--c-txt2); line-height: 1.5;
}
.lcrd__feat-ic { color: var(--c-green); flex-shrink: 0; font-size: 1rem; margin-top: 1px; }
.lcrd__foot {
  padding: 18px 28px;
  border-top: 1px solid var(--c-border);
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  background: var(--c-surf2);
}
.lcrd__disclaimer { font-size: .75rem; color: var(--c-txt3); }

/* ── Info Card ── */
.icrd {
  background: var(--c-surf1);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 28px;
  transition: border-color var(--transition);
}
.icrd:hover { border-color: rgba(224,160,32,.4); }
.icrd__icon {
  width: 44px; height: 44px;
  background: rgba(224,160,32,.1);
  border: 1px solid rgba(224,160,32,.2);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; margin-bottom: 16px;
}
.icrd__title { font-size: 1rem; font-weight: 700; margin-bottom: 10px; }
.icrd__text { font-size: .88rem; color: var(--c-txt2); line-height: 1.65; }

/* ── Support Org Cards ── */
.sorc {
  background: var(--c-surf2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 16px;
  transition: border-color var(--transition);
}
.sorc:hover { border-color: rgba(224,160,32,.35); }
.sorc__logo {
  height: 48px; width: auto; max-width: 160px;
  object-fit: contain; filter: brightness(0) invert(1);
  transition: filter var(--transition);
}
.sorc:hover .sorc__logo { filter: none; }
.sorc__name { font-size: .95rem; font-weight: 700; }
.sorc__desc { font-size: .83rem; color: var(--c-txt2); line-height: 1.6; }
.sorc__link {
  font-size: .82rem; font-weight: 600; color: var(--c-gold);
  border: 1px solid rgba(224,160,32,.3); border-radius: 100px;
  padding: 6px 16px;
  transition: all var(--transition);
}
.sorc__link:hover { background: var(--c-gold); color: #000; }

/* ── FAQ / Accordion ── */
.acdn { display: flex; flex-direction: column; gap: 8px; }
.acdn__item {
  background: var(--c-surf1);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.acdn__hdr {
  width: 100%; background: none; border: none; cursor: pointer;
  padding: 18px 22px; text-align: left;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  font-family: var(--f-body); color: var(--c-txt1); font-size: .95rem; font-weight: 600;
  transition: background var(--transition);
}
.acdn__hdr:hover { background: var(--c-surf2); }
.acdn__arr {
  flex-shrink: 0; font-size: .85rem; color: var(--c-txt3);
  transition: transform var(--transition);
}
.acdn__item.open .acdn__arr { transform: rotate(180deg); }
.acdn__body {
  max-height: 0; overflow: hidden; transition: max-height .3s ease;
}
.acdn__body-inner {
  padding: 4px 22px 20px;
  color: var(--c-txt2); font-size: .9rem; line-height: 1.7;
}

/* ── Page Hero (inner pages) ── */
.phro {
  padding: 56px 0 48px;
  background: linear-gradient(180deg, #0f1420 0%, #090c14 100%);
  border-bottom: 1px solid var(--c-border);
  text-align: center;
}
.phro__label {
  display: inline-block; padding: 5px 14px;
  background: rgba(224,160,32,.1); border: 1px solid rgba(224,160,32,.2);
  border-radius: 100px; font-size: .78rem; font-weight: 600;
  color: var(--c-gold); letter-spacing: .05em; text-transform: uppercase;
  margin-bottom: 14px;
}
.phro__title { margin-bottom: 14px; }
.phro__desc { color: var(--c-txt2); max-width: 560px; margin: 0 auto; }

/* ── Breadcrumb ── */
.brcr {
  padding: 14px 0; border-bottom: 1px solid var(--c-border);
  background: var(--c-surf1);
}
.brcr__list { display: flex; align-items: center; gap: 8px; font-size: .82rem; }
.brcr__item { color: var(--c-txt3); }
.brcr__sep { color: var(--c-txt3); }
.brcr__item a { color: var(--c-txt2); }
.brcr__item a:hover { color: var(--c-gold); }
.brcr__item.active { color: var(--c-txt2); }

/* ── Profile Page ── */
.prf {
  max-width: 900px; margin: 0 auto; padding: 48px 24px 64px;
}
.prf__card {
  background: var(--c-surf1);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden; margin-bottom: 32px;
}
.prf__head {
  background: var(--c-surf2);
  padding: 36px 36px 32px;
  border-bottom: 1px solid var(--c-border);
  display: flex; gap: 28px; align-items: flex-start; flex-wrap: wrap;
}
.prf__logo {
  width: 120px; height: 72px;
  object-fit: contain; flex-shrink: 0;
}
.prf__info { flex: 1; }
.prf__name { font-size: 1.5rem; font-weight: 800; margin-bottom: 8px; }
.prf__badges { display: flex; gap: 8px; flex-wrap: wrap; }
.prf__badge {
  padding: 4px 12px; border-radius: 100px; font-size: .75rem; font-weight: 600;
}
.prf__badge--blue { background: rgba(58,127,212,.15); border: 1px solid rgba(58,127,212,.3); color: var(--c-blue-lt); }
.prf__badge--gold { background: rgba(224,160,32,.1); border: 1px solid rgba(224,160,32,.25); color: var(--c-gold); }
.prf__badge--green { background: rgba(40,168,110,.1); border: 1px solid rgba(40,168,110,.25); color: var(--c-green); }
.prf__body { padding: 32px 36px; }
.prf__section-title {
  font-size: 1.05rem; font-weight: 700; color: var(--c-txt1);
  padding-bottom: 12px; margin-bottom: 18px;
  border-bottom: 1px solid var(--c-border);
}
.prf__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 28px; }
.prf__kv {
  background: var(--c-surf2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: 14px 16px;
}
.prf__kv-k { font-size: .75rem; font-weight: 600; color: var(--c-txt3); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
.prf__kv-v { font-size: .9rem; font-weight: 600; color: var(--c-txt1); }
.prf__text { font-size: .9rem; color: var(--c-txt2); line-height: 1.72; margin-bottom: 24px; }
.prf__feats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 24px; }
.prf__feat {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .88rem; color: var(--c-txt2); line-height: 1.5;
}
.prf__feat-ic { color: var(--c-green); flex-shrink: 0; }
.prf__notice {
  background: rgba(224,160,32,.06);
  border: 1px solid rgba(224,160,32,.2);
  border-radius: var(--r-md);
  padding: 18px 20px;
  font-size: .85rem; color: var(--c-txt2); line-height: 1.65;
}
.prf__notice strong { color: var(--c-gold); }
.prf__cta {
  text-align: center;
  padding: 28px 36px;
  background: var(--c-surf2);
  border-top: 1px solid var(--c-border);
}

/* ── Legal Page ── */
.lgp {
  max-width: 820px; margin: 0 auto; padding: 48px 24px 72px;
}
.lgp h2 { font-size: 1.2rem; font-weight: 700; margin: 36px 0 12px; color: var(--c-txt1); }
.lgp h3 { font-size: 1rem; font-weight: 700; margin: 24px 0 10px; color: var(--c-txt1); }
.lgp p { font-size: .9rem; color: var(--c-txt2); line-height: 1.75; margin-bottom: 14px; }
.lgp ul { padding-left: 20px; list-style: disc; margin-bottom: 14px; }
.lgp ul li { font-size: .9rem; color: var(--c-txt2); line-height: 1.7; margin-bottom: 6px; }
.lgp a { color: var(--c-gold); }
.lgp__meta {
  background: var(--c-surf2); border: 1px solid var(--c-border);
  border-radius: var(--r-md); padding: 16px 20px;
  font-size: .82rem; color: var(--c-txt3); margin-bottom: 36px;
}

/* ── Responsible page ── */
.rsp__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.rsp__card {
  background: var(--c-surf1); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: 28px;
}
.rsp__card--wide { grid-column: span 2; }
.rsp__card-icon {
  width: 48px; height: 48px;
  background: rgba(224,160,32,.1); border: 1px solid rgba(224,160,32,.2);
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; margin-bottom: 16px;
}
.rsp__card-icon--blue { background: rgba(58,127,212,.1); border-color: rgba(58,127,212,.25); }
.rsp__card-icon--green { background: rgba(40,168,110,.1); border-color: rgba(40,168,110,.25); }
.rsp__card-icon--red { background: rgba(212,64,64,.1); border-color: rgba(212,64,64,.25); }
.rsp__card-title { font-size: 1.05rem; font-weight: 700; margin-bottom: 12px; }
.rsp__card-text { font-size: .88rem; color: var(--c-txt2); line-height: 1.7; }
.rsp__list { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.rsp__list-item {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .88rem; color: var(--c-txt2); line-height: 1.5;
}
.rsp__list-dot { width: 7px; height: 7px; background: var(--c-gold); border-radius: 50%; flex-shrink: 0; margin-top: 6px; }

/* ── About page ── */
.abt__team { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.abt__value {
  background: var(--c-surf1); border: 1px solid var(--c-border);
  border-radius: var(--r-md); padding: 24px;
}
.abt__value-title { font-size: .95rem; font-weight: 700; margin-bottom: 8px; color: var(--c-gold); }
.abt__value-text { font-size: .87rem; color: var(--c-txt2); line-height: 1.65; }

/* ── Footer ── */
.ftr {
  background: var(--c-surf1);
  border-top: 1px solid var(--c-border);
  padding-top: 56px;
}
.ftr__main {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 48px;
}
.ftr__brand-logo {
  display: flex; align-items: center; gap: 10px;
  font-size: 1.15rem; font-weight: 800; color: var(--c-txt1);
  margin-bottom: 16px; text-decoration: none;
}
.ftr__brand-logo:hover { color: var(--c-txt1); }
.ftr__brand-mark {
  width: 34px; height: 34px;
  border-radius: 7px;
  flex-shrink: 0;
  object-fit: contain;
}
.ftr__brand-txt span { color: var(--c-gold); }
.ftr__brand-desc { font-size: .83rem; color: var(--c-txt3); line-height: 1.65; margin-bottom: 20px; }
.ftr__email { font-size: .85rem; color: var(--c-txt2); }
.ftr__email a { color: var(--c-gold); }
.ftr__col-title {
  font-size: .78rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--c-txt3); margin-bottom: 16px;
}
.ftr__links { display: flex; flex-direction: column; gap: 10px; }
.ftr__link {
  font-size: .87rem; color: var(--c-txt2);
  transition: color var(--transition);
}
.ftr__link:hover { color: var(--c-gold); }
.ftr__orgs {
  max-width: 1200px; margin: 0 auto; padding: 0 24px 40px;
  border-top: 1px solid var(--c-border); padding-top: 40px;
}
.ftr__orgs-title {
  font-size: .78rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .07em; color: var(--c-txt3); margin-bottom: 24px;
  text-align: center;
}
.ftr__orgs-grid {
  display: flex; align-items: center; justify-content: center;
  gap: 32px; flex-wrap: wrap;
}
.ftr__org {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  text-decoration: none;
}
.ftr__org-img {
  height: 40px; width: auto; max-width: 140px;
  object-fit: contain;
  filter: brightness(0) invert(1) opacity(.55);
  transition: filter var(--transition);
}
.ftr__org:hover .ftr__org-img { filter: brightness(0) invert(1) opacity(.9); }
.ftr__org-name { font-size: .74rem; color: var(--c-txt3); }
.ftr__disclaimer {
  max-width: 1200px; margin: 0 auto; padding: 28px 24px;
  border-top: 1px solid var(--c-border);
  font-size: .78rem; color: var(--c-txt3); line-height: 1.7; text-align: center;
}
.ftr__bottom {
  background: rgba(0,0,0,.3);
  padding: 16px 24px;
  text-align: center;
  font-size: .78rem; color: var(--c-txt3);
  display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap;
}
.ftr__18 {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--c-surf3); border: 1.5px solid var(--c-red);
  color: var(--c-red); font-size: .7rem; font-weight: 800; flex-shrink: 0;
}

/* ── Utilities ── */
.mt8  { margin-top: 8px; }
.mt16 { margin-top: 16px; }
.mt24 { margin-top: 24px; }
.mt32 { margin-top: 32px; }
.mt48 { margin-top: 48px; }
.mb8  { margin-bottom: 8px; }
.mb16 { margin-bottom: 16px; }
.mb24 { margin-bottom: 24px; }
.mb32 { margin-bottom: 32px; }
.mb48 { margin-bottom: 48px; }
.txt-c { text-align: center; }
.txt-gold { color: var(--c-gold); }
.txt-muted { color: var(--c-txt2); }
.divider { height: 1px; background: var(--c-border); margin: 32px 0; }
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: 100px;
  font-size: .75rem; font-weight: 600;
  background: var(--c-surf3); border: 1px solid var(--c-border); color: var(--c-txt2);
}
.chip--green { background: rgba(40,168,110,.1); border-color: rgba(40,168,110,.25); color: var(--c-green); }
.chip--blue  { background: rgba(58,127,212,.1); border-color: rgba(58,127,212,.25); color: var(--c-blue-lt); }
.chip--gold  { background: rgba(224,160,32,.1);  border-color: rgba(224,160,32,.25);  color: var(--c-gold); }
.chip--red   { background: rgba(212,64,64,.1);  border-color: rgba(212,64,64,.25);  color: var(--c-red); }

/* ── Skip link ── */
.skip-link {
  position: absolute; top: -100px; left: 24px; z-index: 10000;
  background: var(--c-gold); color: #000; padding: 10px 18px;
  border-radius: 0 0 var(--r-sm) var(--r-sm); font-weight: 700; font-size: .9rem;
  transition: top var(--transition);
}
.skip-link:focus { top: 0; color: #000; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .ftr__main { grid-template-columns: 1fr 1fr; gap: 32px; }
  .hero__inner { grid-template-columns: 1fr; }
  .hero__visual { display: none; }
  .grd2--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .nav__menu { display: none; }
  .nav__toggle { display: flex; }
  .hero { padding: 56px 0 48px; }
  .sec { padding: 48px 0; }
  .grd2--2, .grd2--3 { grid-template-columns: 1fr; }
  .ftr__main { grid-template-columns: 1fr 1fr; gap: 28px; }
  .prf__grid { grid-template-columns: 1fr; }
  .prf__feats { grid-template-columns: 1fr; }
  .rsp__grid { grid-template-columns: 1fr; }
  .rsp__card--wide { grid-column: span 1; }
  .abt__team { grid-template-columns: 1fr; }
  .lcrd__top { flex-direction: column; align-items: flex-start; }
  .lcrd__logo { width: 72px; height: 46px; }
  .prf__head { flex-direction: column; }
  .prf__logo { width: 96px; height: 58px; }
}
@media (max-width: 540px) {
  .pvx { padding: 0 16px; }
  .ftr__main { grid-template-columns: 1fr; }
  .hero__stats { grid-template-columns: 1fr 1fr; }
  .agemod__box { padding: 32px 24px; }
  .grd2--4 { grid-template-columns: 1fr; }
  .lcrd__foot { flex-direction: column; align-items: flex-start; }
  .lcrd__logo { width: 64px; height: 40px; }
  .prf__logo { width: 84px; height: 50px; }
}
