/* ============================================================
   ROSTER page styles
   ============================================================ */
.roster { position: relative; z-index: 2; padding-top: var(--nav-h); }

/* ---- hero ---- */
.roster__hero { padding: 72px 0 0; position: relative; overflow: hidden; background: transparent; }
.roster__hero .container { position: relative; z-index: 2; }
.roster__strip { position: relative; z-index: 2; }
.roster__hero-row { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: end; padding-bottom: 48px; }
.roster__title { font-size: clamp(40px, 7vw, 88px); margin: 14px 0 0; }
.roster__lede { color: var(--text-dim); font-size: 15px; line-height: 1.7; max-width: 42ch; margin: 0 0 6px; }
.roster__strip { background: transparent; }
.roster__strip-in { display: flex; gap: 48px; padding: 6px 32px 30px; flex-wrap: wrap; }
.roster__strip-in span { color: var(--text-mute); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; }
.roster__strip-in .num { color: var(--text); font-family: var(--font-display); font-weight: 700; margin-right: 4px; }
@media (max-width: 860px){ .roster__hero-row{ grid-template-columns: 1fr; gap: 22px; } .roster__strip-in{ gap: 24px; } }

/* ---- filters ---- */
.filters { padding: 26px 28px 22px; position: relative; z-index: 2; margin: 4px 0 36px; background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-lg); }
.filters__bar { display: flex; gap: 16px; align-items: center; margin-bottom: 22px; }
.search { flex: 1; display: flex; align-items: center; gap: 10px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 0 14px; height: 48px; transition: border-color .3s var(--ease); }
.search:focus-within { border-color: var(--border-strong); }
.search__ico { color: var(--text-mute); font-size: 18px; }
.search input { flex: 1; background: none; border: 0; outline: 0; color: var(--text); font-family: var(--font-mono); font-size: 14px; }
.search input::placeholder { color: var(--text-mute); }
.search__clear { background: none; border: 0; color: var(--text-mute); cursor: pointer; font-size: 13px; }
.filters__sort { display: flex; align-items: center; gap: 10px; }

select { font-family: var(--font-mono); font-size: 13px; background: var(--surface); color: var(--text); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 14px; cursor: pointer; outline: none; appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--text-mute) 50%), linear-gradient(135deg, var(--text-mute) 50%, transparent 50%); background-position: calc(100% - 16px) center, calc(100% - 11px) center; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: 34px; transition: border-color .3s var(--ease); }
select:hover { border-color: var(--border-strong); }

.filters__groups { display: grid; grid-template-columns: 1fr 0.5fr; gap: 36px; padding-bottom: 18px; align-items: start; }
.fgroup { display: flex; flex-direction: column; gap: 9px; }
.fgroup--loc .locsel { width: 100%; }
.fgroup--cats { padding-top: 18px; border-top: 1px solid var(--border-soft); }
@media (max-width: 860px){ .filters__groups{ grid-template-columns: 1fr; gap: 18px; } .filters__bar{ flex-direction: column; align-items: stretch; } }

.chipgroup { display: flex; flex-wrap: wrap; gap: 7px; }
.chip { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.03em; color: var(--text-dim); background: transparent; border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 7px 13px; cursor: pointer; transition: all .25s var(--ease); white-space: nowrap; }
.chip:hover { border-color: var(--border-strong); color: var(--text); }
.chip--on { background: var(--white); color: var(--black); border-color: var(--white); font-weight: 600; }

.filters__meta { display: flex; align-items: center; gap: 18px; padding-top: 20px; }
.filters__count { color: var(--text-mute); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.filters__count .num { color: var(--text); }
.filters__clear { background: none; border: 0; color: var(--text-dim); cursor: pointer; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.filters__clear:hover { color: var(--text); }

/* ---- grid ---- */
.roster__grid { display: grid; gap: 16px; padding-bottom: 120px; }
.roster__grid--detailed { grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); }
.roster__grid--editorial { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 18px; }
.roster__grid--compact { grid-template-columns: 1fr; gap: 0; }
.roster__grid--dense.roster__grid--detailed { grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); }

/* ---- card base ---- */
.ccard { text-align: left; font-family: var(--font-mono); color: var(--text); background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); cursor: pointer; position: relative; overflow: hidden; transition: border-color .4s var(--ease), background .4s var(--ease), transform .4s var(--ease); }
.ccard::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, rgba(255,255,255,0.05), transparent 60%); opacity: 0; transition: opacity .4s var(--ease); pointer-events: none; }
.ccard:hover { border-color: var(--border-strong); background: var(--surface-2); transform: translateY(-2px); }
.ccard:hover::before { opacity: 1; }
.ccard__handle { color: var(--text-mute); font-size: 12px; }
.ccard__cats { display: flex; flex-wrap: wrap; gap: 6px; }
.ccard__tier { font-size: 9.5px; letter-spacing: 0.16em; color: var(--text-mute); border: 1px solid var(--border); border-radius: var(--radius-pill); padding: 3px 8px; }
.ccard__topcat { font-size: 9.5px; letter-spacing: 0.16em; color: var(--accent); border: 1px solid rgba(199,168,109,0.32); border-radius: var(--radius-pill); padding: 3px 9px; background: rgba(199,168,109,0.06); flex: none; }

/* detailed */
.ccard--detail { padding: 20px; display: flex; flex-direction: column; gap: 16px; }
.ccard__top { display: flex; align-items: center; gap: 13px; }
.ccard__id { flex: 1; min-width: 0; }
.ccard__name { font-weight: 600; font-size: 16px; letter-spacing: -0.01em; }
.ccard__plats { display: grid; grid-template-columns: repeat(auto-fit, minmax(72px, 1fr)); gap: 8px; padding: 14px 0; border-top: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); }
.pf-stat { display: flex; align-items: center; gap: 7px; }
.pf-stat__ico { color: var(--text-mute); display: inline-flex; transition: color .35s var(--ease); }
.ccard:hover .pf-stat__ico { color: var(--accent); }
.pf-stat__val { font-size: 14px; font-weight: 600; }
.ccard__foot { display: flex; align-items: center; justify-content: space-between; }
.ccard__reach { display: flex; flex-direction: column; }
.ccard__reach .num { font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.ccard__reach em { font-style: normal; color: var(--text-mute); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; }
.ccard__view { font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-dim); display: inline-flex; gap: 6px; }
.ccard:hover .ccard__view { color: var(--text); }
.arr { transition: transform .4s var(--ease); display: inline-block; }
.ccard:hover .arr { transform: translateX(3px); }

/* compact (rows) */
.roster__grid--compact .ccard--compact { border-radius: 0; border-bottom: 0; }
.roster__grid--compact .ccard--compact:first-child { border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.roster__grid--compact .ccard--compact:last-child { border-radius: 0 0 var(--radius-lg) var(--radius-lg); border-bottom: 1px solid var(--border); }
.ccard--compact { display: grid; grid-template-columns: auto 1.4fr 2fr auto auto; align-items: center; gap: 20px; padding: 14px 20px; }
.ccard--compact:hover { transform: none; }
.ccard__c-name { font-weight: 600; font-size: 15px; }
.ccard__c-handle { color: var(--text-mute); font-size: 12px; }
.ccard__c-plats { display: flex; flex-wrap: wrap; gap: 14px; }
.pcode { font-size: 11px; color: var(--text-mute); letter-spacing: 0.04em; display: inline-flex; align-items: center; gap: 5px; }
.pcode b { color: var(--text); font-weight: 600; }
.ccard__c-reach { text-align: right; }
.ccard__c-reach .num { font-family: var(--font-display); font-weight: 700; font-size: 16px; display: block; }
.ccard__c-reach em { font-style: normal; color: var(--text-mute); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; }
.ccard__arr { color: var(--text-mute); font-size: 16px; transition: transform .3s var(--ease), color .3s var(--ease); }
.ccard--compact:hover .ccard__arr { color: var(--text); transform: translateX(3px); }
@media (max-width: 760px){ .ccard--compact{ grid-template-columns: auto 1fr auto; } .ccard__c-plats{ display: none; } }

/* editorial */
.ccard--ed { display: flex; flex-direction: column; padding: 26px 24px 0; }
.ccard__ed-top { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; padding-bottom: 22px; }
.ccard--ed .ccard__tier { position: absolute; top: 0; right: 0; }
.ccard__ed-avatar { margin-bottom: 16px; }
.ccard__ed-avatar .avatar { box-shadow: 0 0 0 1px var(--border), 0 8px 24px rgba(0,0,0,0.4); }
.ccard__ed-name { font-size: 23px; margin: 0 0 3px; }
.ccard__cats--center { justify-content: center; margin-top: 14px; }
.ccard__ed-plats { display: grid; grid-template-columns: repeat(auto-fit, minmax(72px,1fr)); gap: 10px; padding: 18px 0; border-top: 1px solid var(--border-soft); }
.ccard__ed-foot { display: flex; align-items: center; justify-content: space-between; padding: 16px 0; border-top: 1px solid var(--border-soft); margin-top: auto; }
.ccard--ed:hover .ccard__view { color: var(--text); }

/* ---- avatar ---- */
.avatar { position: relative; flex: none; display: flex; align-items: center; justify-content: center; overflow: hidden; border: 1px solid var(--border); }
.avatar__init { font-family: var(--font-display); font-weight: 700; color: rgba(255,255,255,0.82); letter-spacing: 0.02em; }
.avatar__ph { position: absolute; bottom: 4px; left: 0; right: 0; text-align: center; font-size: 6.5px; letter-spacing: 0.2em; color: rgba(255,255,255,0.28); }

/* ---- empty ---- */
.roster__empty { display: flex; flex-direction: column; align-items: center; gap: 18px; padding: 100px 0 140px; color: var(--text-mute); }

/* ============================================================
   MODAL / detail drawer
   ============================================================ */
.modal-scrim { position: fixed; inset: 0; z-index: 200; background: rgba(4,4,6,0.74); backdrop-filter: blur(6px); display: flex; justify-content: flex-end; opacity: 1; }
.modal--detail { width: min(1000px, 100%); height: 100%; display: flex; background: var(--bg-elev); border-left: 1px solid var(--border); position: relative; }
.modal__close { position: absolute; top: 22px; right: 22px; z-index: 6; width: 38px; height: 38px; border: 1px solid var(--border); background: rgba(20,9,14,0.6); backdrop-filter: blur(6px); color: var(--text-dim); border-radius: var(--radius); cursor: pointer; font-size: 14px; transition: all .3s var(--ease); }
.modal__close:hover { background: var(--white); color: var(--black); border-color: var(--white); }

/* ---- left stage: portrait + content grid ---- */
.modal__stage { width: 420px; flex: none; display: flex; flex-direction: column; background: var(--bg); border-right: 1px solid var(--border); overflow: hidden; }
.stage__portrait { position: relative; flex: 1 1 auto; min-height: 300px; overflow: hidden; }
.stage__portrait img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 50% 24%; display: block; }
.stage__portrait-fallback { position: absolute; inset: 0; display: grid; place-items: center; background: repeating-linear-gradient(45deg, #181016 0 2px, #0c0a0d 2px 11px); }
.stage__portrait-fallback span { font-family: var(--font-display); font-weight: 700; font-size: 64px; color: rgba(255,255,255,0.22); }
.stage__scrim { position: absolute; inset: 0; background:
    linear-gradient(to top, rgba(20,9,14,0.96) 4%, rgba(20,9,14,0.45) 38%, transparent 64%),
    linear-gradient(115deg, rgba(199,168,109,0.20), transparent 52%); }
.stage__cap { position: absolute; left: 0; right: 0; bottom: 0; padding: 26px 26px 24px; z-index: 2; }
.stage__cats { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.stage__name { font-size: clamp(26px, 3vw, 34px); margin: 0; }
.stage__handle { color: var(--text-dim); font-size: 12px; margin-top: 7px; letter-spacing: 0.02em; }
.stage__content { flex: none; padding: 22px 22px 24px; border-top: 1px solid var(--border); background: var(--bg-elev); }
.stage__content-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 13px; }
.stage__content-note { font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-mute); }
.stage__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ctile { position: relative; aspect-ratio: 16 / 10; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; display: flex; align-items: flex-end; padding: 9px 10px; transition: border-color .35s var(--ease); }
.ctile:hover { border-color: rgba(199,168,109,0.4); }
.ctile__pf { position: absolute; top: 8px; left: 9px; font-size: 9px; letter-spacing: 0.14em; color: var(--text-dim); }
.ctile__play { position: absolute; top: 7px; right: 8px; color: var(--accent); opacity: 0.85; display: grid; place-items: center; }
.ctile__label { font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-mute); }

/* ---- right body ---- */
.modal__body { flex: 1; min-width: 0; overflow-y: auto; padding: 54px 40px 56px; }
.modal__body::-webkit-scrollbar { width: 8px; } .modal__body::-webkit-scrollbar-thumb { background: var(--surface-3); border-radius: 99px; }
.modal__bio { color: var(--text-dim); line-height: 1.7; font-size: 14px; margin: 2px 0 28px; }

@media (max-width: 900px){
  .modal--detail { flex-direction: column; width: 100%; overflow-y: auto; }
  .modal--detail::-webkit-scrollbar { width: 8px; } .modal--detail::-webkit-scrollbar-thumb { background: var(--surface-3); border-radius: 99px; }
  .modal__stage { width: 100%; flex: none; }
  .stage__portrait { height: 340px; min-height: 340px; flex: none; }
  .modal__body { overflow: visible; padding: 30px 24px 48px; }
}
.modal__stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.dstat { background: var(--surface); padding: 18px; }
.dstat__v { font-family: var(--font-display); font-weight: 700; font-size: 24px; }
.dstat__k { color: var(--text-mute); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; margin-top: 4px; }
.dstat__sub { color: var(--text-dim); font-size: 11px; margin-top: 3px; }
.modal__platforms { margin: 32px 0 24px; }
.platrow { display: grid; grid-template-columns: 22px 1fr 120px auto; align-items: center; gap: 14px; padding: 10px 0; border-bottom: 1px solid var(--border-soft); }
.platrow__code { color: var(--text-mute); display: inline-flex; align-items: center; }
.platrow__label { font-size: 13px; }
.platrow__bar { height: 4px; background: var(--surface-2); border-radius: 99px; overflow: hidden; }
.platrow__bar i { display: block; height: 100%; background: var(--accent); border-radius: 99px; transition: width .8s var(--ease); }
.platrow__val { font-size: 14px; font-weight: 600; text-align: right; }
.modal__aud { font-size: 11px; color: var(--text-mute); padding: 14px 0 0; }
.modal__cta { margin-top: 32px; padding-top: 28px; border-top: 1px solid var(--border); }
.modal__cta-note { display: block; color: var(--text-mute); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; margin-top: 14px; }

/* ---- inquiry form ---- */
.inq { display: flex; flex-direction: column; gap: 16px; }
.inq__row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 520px){ .inq__row2{ grid-template-columns: 1fr; } }
.field { display: flex; flex-direction: column; gap: 7px; }
.field__label { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-mute); }
.field__err { color: #ff6b6b; letter-spacing: 0.04em; }
.field input, .field textarea, .field select { width: 100%; font-family: var(--font-mono); font-size: 14px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 14px; color: var(--text); outline: none; transition: border-color .3s var(--ease); resize: vertical; }
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--border-strong); }
.field input::placeholder, .field textarea::placeholder { color: var(--text-mute); }
.field--err input, .field--err textarea { border-color: rgba(255,107,107,0.5); }
.inq__submit { justify-content: center; margin-top: 4px; }
.inq__fine { color: var(--text-mute); font-size: 11px; text-align: center; margin: 2px 0 0; }
.inq--done { align-items: center; text-align: center; padding: 18px 0; gap: 14px; }
.inq__check { } /* no keyframe entrance — animations freeze invisible in throttled preview */
.inq--done h4 { font-size: 26px; margin: 0; }
.inq--done p { color: var(--text-dim); font-size: 14px; line-height: 1.7; max-width: 40ch; margin: 0; }
.inq__ref { font-size: 12px; letter-spacing: 0.1em; color: var(--text-mute); border: 1px dashed var(--border-strong); border-radius: var(--radius); padding: 10px 16px; }
.inq__formwrap { }

/* ---- Mobile: compact 2-up editorial roster cards (see more creators per screen) ---- */
@media (max-width: 640px){
  .roster__grid--editorial { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .ccard--ed { padding: 14px 10px 0; border-radius: var(--radius); }
  .ccard__ed-top { padding-bottom: 12px; }
  .ccard__ed-avatar { margin-bottom: 9px; }
  .ccard__ed-avatar .avatar { width: 60px !important; height: 60px !important; }
  .ccard__ed-name { font-size: 14px; margin: 0 0 2px; line-height: 1.15; }
  .ccard__handle { font-size: 10.5px; }
  .ccard__cats--center { margin-top: 8px; gap: 4px; }
  .ccard__cats--center .tag { font-size: 8.5px; padding: 2px 7px; letter-spacing: 0.04em; }
  .ccard__cats--center .tag:nth-child(n+3) { display: none; }   /* top 2 categories */
  .ccard__ed-plats { display: flex; flex-wrap: wrap; justify-content: center; gap: 5px 12px; padding: 10px 0; }
  .ccard__ed-plats .pf-stat:nth-child(n+4) { display: none; }   /* top 3 platforms (sorted by reach) */
  .pf-stat { gap: 5px; }
  .pf-stat__val { font-size: 12px; }
  .ccard__ed-foot { padding: 10px 0; flex-wrap: wrap; gap: 4px; }
  .ccard__reach .num { font-size: 14px; }
  .ccard__reach em { font-size: 8px; letter-spacing: 0.05em; }
  .ccard__view { font-size: 9.5px; letter-spacing: 0.04em; }
}

/* ---- Very small phones: keep the 2-up but tighten the gutter further ---- */
@media (max-width: 380px){
  .roster__grid--editorial { gap: 8px; }
  .ccard--ed { padding: 12px 8px 0; }
}
