/* =========================
   UTILITIES – SPACING
   ========================= */
.my-1 { margin-block: var(--space-1); }
.my-2 { margin-block: var(--space-2); }
.my-3 { margin-block: var(--space-3); }
.my-4 { margin-block: var(--space-4); }
.my-5 { margin-block: var(--space-5); }
.my-6 { margin-block: var(--space-6); }
.my-7 { margin-block: var(--space-7); }
.mb-1 { margin-bottom: var(--space-1); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-7 { margin-bottom: var(--space-7); }
.mx-1 { margin-inline: var(--space-1); }
.mx-2 { margin-inline: var(--space-2); }
.mx-3 { margin-inline: var(--space-3); }
.mx-4 { margin-inline: var(--space-4); }
.mx-5 { margin-inline: var(--space-5); }
.mx-6 { margin-inline: var(--space-6); }
.mx-7 { margin-inline: var(--space-7); }
.mt-1 { margin-top: var(--space-1); }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mt-7 { margin-top: var(--space-7); }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-5 { padding: var(--space-5); }
.p-6 { padding: var(--space-6); }
.p-7 { padding: var(--space-7); }
.border-top { border-top: 1px solid var(--color-border); }
.ml-auto{margin-left:auto;}

/* =========================
   ACCESS SKIP LINK
   ========================= */
.skip-link { position: absolute; top: -1000px; left: -1000px; }
.skip-link:focus { top: 8px; left: 8px; background: var(--color-surface); color: var(--color-text); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); box-shadow: var(--shadow-1); }

/* =========================
   LANDING
   ========================= */
.landing-page { position: relative; min-height: 70dvh; padding: var(--space-6) var(--space-5); display: grid; place-items: center; text-align: center; gap: var(--space-3); overflow: hidden; }
.landing-page::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg,color-mix(in hsl,var(--color-bg) 0%,transparent) 0%,color-mix(in hsl,var(--color-bg) 25%,transparent) 60%,color-mix(in hsl,var(--color-bg) 45%,transparent) 100%); pointer-events: none; z-index: 0; }
.landing-content { position: relative; z-index: 1; display: grid; justify-items: center; gap: var(--space-3); }
.typing-background { position: absolute; inset: 0; display: block; overflow: hidden; pointer-events: none; z-index: 0; }
.line { display: block; white-space: nowrap; font-family: var(--font-mono); font-weight: 800; letter-spacing: 0.08em; font-size: calc(clamp(12px,1.6vw,16px) * var(--ui-scale)); opacity: 0.12; color: var(--color-link); animation-name: fall; animation-timing-function: linear; animation-iteration-count: infinite; will-change: transform; }
.status { font-size: calc(clamp(3rem,8vw,7rem) * var(--ui-scale)); }
.lead { font-size: calc(clamp(1.125rem,2vw,1.375rem) * var(--ui-scale)); }
@keyframes fall { from { transform: translate3d(0,-100%,0); } to { transform: translate3d(0,100%,0); } }
.brand-logo { inline-size: clamp(var(--brand-logo-min),var(--brand-logo-vw),var(--brand-logo-max)); block-size: clamp(var(--brand-logo-min),var(--brand-logo-vw),var(--brand-logo-max)); border-radius: var(--radius-md); box-shadow: var(--shadow-1); }
.landing-header { color: inherit; text-decoration: none; animation: fadeInDown 1.2s ease both; }
h1.landing-header { font-size: clamp(var(--landing-h1-min),var(--landing-h1-vw),var(--landing-h1-max)); }
h2.landing-header { font-size: clamp(var(--landing-h2-min),var(--landing-h2-vw),var(--landing-h2-max)); }
.yellow-text { color: var(--color-primary); }
.hidden { display: none !important; }
.admin-hidden{display:none!important;}
@keyframes fadeInDown { from { opacity: 0; transform: translate3d(0,-18px,0); } to { opacity: 1; transform: translate3d(0,0,0); } }

/* =========================
   BUTTONS & ACTIONS
   ========================= */
.actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); flex-wrap: wrap; justify-content: center; }
.btn { appearance: none; border: 1px solid transparent; border-radius: var(--radius-md); padding: var(--space-3) var(--space-5); font-weight: 700; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2); cursor: pointer; transition: transform 120ms ease,background-color 120ms ease,border-color 120ms ease,color 120ms ease; }
.btn:hover { transform: translateY(-1px); }
.btn:focus-visible { outline: 2px solid var(--color-link); outline-offset: 2px; }
.btn-primary { background: var(--color-primary); color: var(--color-primary-contrast); border-color: transparent; }
.btn-primary:hover,.btn-primary:focus-visible { background: var(--color-primary-hover); border-color: var(--color-primary-hover); color: var(--color-primary-contrast); }
.btn-primary:active { background: var(--color-primary-active); border-color: var(--color-primary-active); color: var(--color-primary-contrast); transform: translateY(0); }
.btn-secondary { background: transparent; color: var(--color-link); border: 1px solid var(--color-border); }
.btn-secondary:hover { background: color-mix(in hsl,var(--color-link) 12%,transparent); border-color: var(--color-link); }

/* =========================
   FORMS
   ========================= */
.form-control { background-color: color-mix(in hsl,var(--color-surface) 96%,var(--color-bg)); color: var(--color-text); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4); width: 100%; }
.form-control::placeholder { color: var(--color-muted); }
.login-form,.form-container { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-5); width: min(620px,100%); box-shadow: var(--shadow-1); }
.form-container .actions { flex-direction: column; align-items: center; }
.terminal-box,.surface-box { background: color-mix(in hsl,var(--color-surface) 80%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-5); box-shadow: var(--shadow-1); }
.terminal-box { font-family: var(--font-mono); font-size: var(--terminal-font-size,0.94rem); }
.surface-box { font-family: inherit; font-size: inherit; }
.alert-link { color: var(--color-link); font-weight: 700; }
.alert-link:hover,.footer-link:hover,.footer-link:focus-visible { color: var(--color-link-hover); text-decoration: underline; outline: none; }

/* =========================
   FOOTER
   ========================= */
.site-footer { width: 100%; margin-top: auto; border-top: 1px solid var(--color-border); background: color-mix(in hsl,var(--color-surface) 88%,var(--color-bg)); }
.footer-nav { max-width: var(--max-content-width); margin-inline: auto; padding: var(--space-5); }
.footer-list { list-style: none; padding: 0; margin: 0 0 var(--space-3) 0; display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: center; }
.footer-link { color: var(--color-link); text-decoration: none; font-weight: 700; }

/* =========================
   MISC UTILITIES
   ========================= */
.text-center { text-align: center; }
.muted { color: var(--color-muted); }
.no-top-padding { padding-top: 0 !important; }

/* =========================
   SIMPLE LISTS
   ========================= */
.list-group { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-2); }
.list-group-item { padding: var(--space-3) var(--space-4); background: color-mix(in hsl,var(--color-surface) 92%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: var(--radius-sm); color: var(--color-text); transition: background-color 120ms ease,border-color 120ms ease; }
.list-group-item:hover { background: color-mix(in hsl,var(--color-surface) 86%,var(--color-bg)); border-color: color-mix(in hsl,var(--color-border) 85%,var(--color-link)); }

/* =========================
   GENERIC TABLE
   ========================= */
.table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 0.95rem; color: var(--color-text); background: transparent; }
.table thead th { text-align: left; background: linear-gradient(to bottom,rgba(255,255,255,0.06),rgba(255,255,255,0.02)); color: var(--color-text); font-weight: 600; font-size: 0.9rem; padding: 0.6rem 0.75rem; border-bottom: 1px solid var(--color-border); }
.table td { padding: 0.55rem 0.75rem; vertical-align: top; border-bottom: 1px solid var(--row-divider); }
.table tbody tr:nth-child(even) { background: rgba(255,255,255,0.03); }
.table tbody tr:hover { background: rgba(255,255,255,0.06); }

/* =========================
   TABLE CONTAINER
   ========================= */
.table-container { max-height: 70vh; overflow: auto; background: inherit; border: 1px solid var(--color-border); border-radius: 10px; }
.table-responsive { max-height: 70vh; overflow: auto; background: inherit; border: 1px solid var(--color-border); border-radius: 10px; }
@media (max-width: 768px) { .table-container,.table-responsive { max-height: 60vh; } }
@media (max-width: 480px) { .table-container,.table-responsive { max-height: 52vh; } }

/* =========================
   FORM LAYOUT HELPERS
   ========================= */
.surface-box .form-container { width: 100%; }
.form-control-inline { width: auto; min-width: 200px; }
input[type="search"].form-control { max-width: 320px; }

/* =========================
   RANGE INPUT
   ========================= */
.range-input { appearance: none; width: 100%; height: 8px; border-radius: 999px; background: linear-gradient(to right,var(--color-primary) 0%,var(--color-primary) 0%,var(--color-track) 0%,var(--color-track) 100%); outline: none; border: 1px solid var(--color-border); }
.range-input::-webkit-slider-runnable-track { height: 8px; border-radius: 999px; background: transparent; }
.range-input::-webkit-slider-thumb { appearance: none; width: 18px; height: 18px; margin-top: -6px; background: var(--color-primary); border: 2px solid var(--color-primary-contrast); border-radius: 50%; cursor: pointer; }
.range-input::-moz-range-track { height: 8px; border-radius: 999px; background: transparent; }
.range-input::-moz-range-thumb { width: 18px; height: 18px; background: var(--color-primary); border: 2px solid var(--color-primary-contrast); border-radius: 50%; cursor: pointer; }

/* =========================
   RESULTS & RARITY
   ========================= */
.results-grid { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); }
.rarity-group { border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-3); }
.gold-change { margin-left: 8px; font-weight: 700; color: var(--color-success); opacity: 0; trans1orm: translateY(-6px); transition: opacity 160ms ease,transform 160ms ease,color 120ms ease; }
.gold-change.show { opacity: 1; transform: translateY(0); }
.gold-change.negative { color: var(--color-danger); }

/* =========================
   ACTIONS & CONTROLS
   ========================= */
.list-actions-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; margin-top: 10px; }
@media (max-width: 700px) { .list-actions-grid { grid-template-columns: 1fr; } }
.action-card { background: color-mix(in hsl,var(--color-surface) 90%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: 8px; padding: 12px; }
.action-title { font-size: 0.95rem; font-weight: 600; margin: 0 0 8px 0; }
.actions-row { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.actions-row-wrap { flex-wrap: wrap; }
.action-inline { display: inline-flex; align-items: center; gap: 6px; color: var(--muted-color,#9aa0a6); font-size: 0.9rem; }
.btn-ghost { background: transparent; border: 1px dashed var(--color-border,rgba(255,255,255,0.2)); color: inherit; padding: 6px 10px; border-radius: 6px; }
.action-more { margin-top: 6px; }
.action-more > summary { cursor: pointer; user-select: none; list-style: none; color: var(--link-color,#0d6efd); font-weight: 500; font-size: 0.92rem; padding: 2px 0; }
.action-more > summary::-webkit-details-marker { display: none; }
.file-input-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; border: 0; padding: 0; margin: -1px; }
.btn[aria-busy="true"] { opacity: 0.75; cursor: wait; pointer-events: none; }

/* =========================
   VALIDATION MESSAGES
   ========================= */
.invalid-feedback { display: none; margin-top: var(--space-2); color: var(--color-danger); font-size: 0.875rem; line-height: 1.4; }
.form-control.is-invalid,.form-control:invalid,.form-control[aria-invalid="true"] { border-color: color-mix(in hsl,var(--color-danger) 70%,var(--color-border)); box-shadow: 0 0 0 0.2rem color-mix(in hsl,var(--color-danger) 25%,transparent); background-color: color-mix(in hsl,var(--color-surface) 96%,var(--color-bg)); }
.form-control.is-invalid + .invalid-feedback,.form-control:invalid + .invalid-feedback,.form-control[aria-invalid="true"] + .invalid-feedback,.invalid-feedback.show { display: block; }
.valid-feedback { display: none; margin-top: var(--space-2); color: var(--color-success); font-size: 0.875rem; line-height: 1.4; }
.form-control.is-valid,.form-control:valid { border-color: color-mix(in hsl,var(--color-success) 60%,var(--color-border)); }
.form-control.is-valid + .valid-feedback,.form-control:valid + .valid-feedback,.valid-feedback.show { display: block; }

/* =========================
   TEXT CLAMP UTILITY
   ========================= */
.clamp { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* =========================
   ADMIN HELPERS
   ========================= */
.visually-hidden { position: absolute !important; width: 1px !important; height: 1px !important; padding: 0 !important; margin: -1px !important; overflow: hidden !important; clip: rect(0,0,0,0) !important; white-space: nowrap !important; border: 0 !important; }
.pre-scrollable { max-height: 320px; overflow: auto; padding: var(--space-3); background: color-mix(in hsl,var(--color-surface) 92%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: var(--radius-sm); }
.align-items-end { align-items: end; }
.h4 { font-size: 1.125rem; line-height: 1.35; margin: 0 0 var(--space-2) 0; }
.col-auto { grid-column: span 12; }
@media (min-width: 576px) { .col-auto { grid-column: span 3; } }

/* =========================
   ANNOUNCEMENTS
   ========================= */
.announcement-badge,.announcement-added,.announcement-gold { display: inline-flex; align-items: center; padding: 2px 8px; gap: 6px; border-radius: 999px; font-size: 0.76rem; font-weight: 600; line-height: 1; background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); border: 1px solid var(--color-border); color: var(--color-text); }
.announcement-badge { background: color-mix(in hsl,var(--color-surface) 92%,var(--color-bg)); border-color: var(--color-border); color: var(--color-muted); }
.announcement-added { background: color-mix(in hsl,var(--color-success) 10%,transparent); border-color: color-mix(in hsl,var(--color-success) 30%,var(--color-border)); color: color-mix(in hsl,var(--color-text) 85%,var(--color-success) 15%); }
.announcement-gold { background: color-mix(in hsl,var(--color-primary) 12%,transparent); border-color: color-mix(in hsl,var(--color-primary) 40%,var(--color-border)); color: color-mix(in hsl,var(--color-text) 85%,var(--color-primary) 15%); }

/* =========================
   ANNOUNCEMENTS FILTER CONTROLS
   ========================= */
.announcements-controls { display: grid; gap: 10px; margin-bottom: var(--space-3); background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4) var(--space-4); }
.announcements-filters { display: flex; flex-wrap: wrap; gap: 16px; align-items: flex-end; }
.filter-group { display: flex; flex-direction: column; gap: 4px; min-width: 140px; }
.filter-group label { font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.55px; font-weight: 600; color: var(--color-muted); padding-left: 2px; }
.inline-control { min-width: 160px; font-size: 0.8rem; }
.announcements-summary { font-size: 0.75rem; letter-spacing: 0.3px; font-weight: 600; padding: 4px 6px 2px; border-top: 1px solid var(--color-border); opacity: 0.85; }
@media (max-width: 640px) { .inline-control { width: 100%; min-width: 0; } .filter-group { flex: 1 1 100%; } .announcements-filters { gap: 10px; } }

/* =========================
   RECOGNITION DASHBOARD
   ========================= */
.recognition-dashboard { display: block; margin-top: var(--space-2); }

.recognition-grid { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); max-width: 100%; box-sizing: border-box; }

.recognition-card { background: color-mix(in hsl,var(--color-surface) 90%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); box-shadow: var(--shadow-1); max-width: 100%; overflow-wrap: anywhere; }

.metrics-grid { display: grid; gap: var(--space-2); grid-template-columns: repeat(4,minmax(0,1fr)); }

@media (max-width: 720px) { .recognition-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .metrics-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (max-width: 480px) { .recognition-grid { grid-template-columns: 1fr; } }

.metric-item { background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-3); }
.metric-label { font-size: 0.82rem; color: var(--color-muted); }
.metric-value { font-weight: 800; font-size: 1.15rem; }

.players-list .player-row { display: flex; align-items: center; justify-content: space-between; }
.players-list .player-left { display: inline-flex; align-items: baseline; gap: 8px; }
.players-list .player-rank { font-family: var(--font-mono); }
.players-list .player-right { font-family: var(--font-mono); }

/* =========================
   TEAMS
   ========================= */
:root { --team-card-surface-ratio: 56%; --team-card-primary-ratio: 2%; }
.teams-list { margin-top: var(--space-2); }
.team-card { display: grid; gap: var(--space-2); }
.team-card .actions-row { margin-top: var(--space-2); }
.team-meta { color: var(--color-muted); }
.team-members { color: var(--color-muted); overflow: visible; text-overflow: ellipsis; white-space: nowrap; }
.captain-tools { margin-top: var(--space-3); padding: var(--space-3); background: color-mix(in hsl,var(--color-surface) 92%,var(--color-bg)); border: 1px dashed var(--color-border); border-radius: var(--radius-sm); }
.captain-tools .list-group { margin-top: var(--space-2); }
.captain-tools .list-group-item { background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); }
.input { background-color: color-mix(in hsl,var(--color-surface) 96%,var(--color-bg)); color: var(--color-text); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-3) var(--space-4); min-width: 200px; }
select.input { padding-right: var(--space-5); }
.input::placeholder { color: var(--color-muted); }
.input:focus-visible { outline: 2px solid var(--color-link); outline-offset: 2px; }
@media (max-width: 700px) { .team-members { white-space: normal; } .input { width: 100%; min-width: 0; } }

/* =========================
   TEAM ENHANCEMENTS 
   ========================= */
.teams-list .team-card { position: relative; padding: var(--space-4) var(--space-4) calc(var(--space-4) + 2px); background: linear-gradient(145deg,color-mix(in hsl,var(--color-surface) var(--team-card-surface-ratio),var(--color-bg)) 0%,color-mix(in hsl,var(--color-primary) var(--team-card-primary-ratio),var(--color-surface)) 100%); border: 1px solid color-mix(in hsl,var(--color-border) 90%,var(--color-primary)); border-radius: var(--radius-md); box-shadow: var(--shadow-1); gap: var(--space-3); transition: border-color 160ms ease,background 200ms ease,transform 160ms ease,box-shadow 160ms ease; overflow: hidden; will-change: transform; }
.teams-list .team-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 18% 20%,color-mix(in hsl,var(--color-primary) calc(var(--team-card-primary-ratio) * 2),transparent),transparent 65%),linear-gradient(120deg,transparent 0%,color-mix(in hsl,var(--color-primary) calc(var(--team-card-primary-ratio) * 3),transparent) 45%,transparent 85%); opacity: 0; pointer-events: none; transition: opacity 260ms ease; }
.teams-list .team-card:hover,.teams-list .team-card:focus-within { transform: translateY(-2px); border-color: color-mix(in hsl,var(--color-primary) 55%,var(--color-border)); }
.teams-list .team-card:hover::before,.teams-list .team-card:focus-within::before { opacity: 0.4; }
.team-card strong { font-size: 0.95rem; letter-spacing: 0.25px; font-weight: 700; text-shadow: 0 1px 0 rgba(0,0,0,0.25); }
.team-meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: 0.72rem; letter-spacing: 0.55px; text-transform: uppercase; font-weight: 600; color: color-mix(in hsl,var(--color-muted) 88%,var(--color-text)); background: color-mix(in hsl,var(--color-surface) 90%,var(--color-bg)); padding: 6px 10px; border: 1px solid color-mix(in hsl,var(--color-border) 85%,var(--color-primary)); border-radius: 999px; line-height: 1.2; }
.team-members { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.25px; background: color-mix(in hsl,var(--color-surface) 96%,var(--color-bg)); padding: 24px 14px 12px; border: 1px solid var(--color-border); border-radius: 18px; max-width: 100%; position: relative; line-height: 1.4; white-space: normal; overflow: hidden; text-overflow: initial; word-break: break-word; }
.team-members::before { content: "Members"; position: absolute; top: 2px; left: 10px; font-size: 0.58rem; letter-spacing: 0.6px; padding: 2px 8px 3px; background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); border: 1px solid var(--color-border); border-radius: 999px; font-weight: 700; text-transform: uppercase; color: var(--color-muted); }
@media (max-width: 700px) { .team-members { padding-top: 10px; } .team-members::before { content: none !important; } }
.team-card .actions-row { margin-top: var(--space-2); padding-top: 6px; border-top: 1px solid color-mix(in hsl,var(--color-border) 80%,var(--color-primary)); }
.team-card .actions-row .btn { font-size: 0.78rem; padding: 6px 12px; font-weight: 600; letter-spacing: 0.3px; }
.team-card .actions-row .btn-primary { background: linear-gradient(135deg,color-mix(in hsl,var(--color-primary) 82%,var(--color-primary-hover)) 0%,var(--color-primary) 55%); box-shadow: 0 2px 5px -2px rgba(0,0,0,0.4),0 0 0 1px color-mix(in hsl,var(--color-primary) 55%,transparent); }
.team-card .actions-row .btn-primary:hover { background: linear-gradient(135deg,var(--color-primary-hover) 0%,color-mix(in hsl,var(--color-primary) 92%,var(--color-primary-hover)) 70%); }
.team-card .actions-row .btn-secondary { border-style: dashed; background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); }
.team-card .actions-row .btn-secondary:hover { background: color-mix(in hsl,var(--color-surface) 88%,var(--color-bg)); border-color: var(--color-link); }
.captain-tools { position: relative; margin-top: var(--space-3); padding: var(--space-4) var(--space-4) var(--space-3); border-radius: var(--radius-md); border: 1px dashed color-mix(in hsl,var(--color-border) 70%,var(--color-primary)); background: linear-gradient(140deg,color-mix(in hsl,var(--color-surface) 96%,var(--color-bg)) 0%,color-mix(in hsl,var(--color-surface) 90%,var(--color-bg)) 100%); box-shadow: inset 0 0 0 1px color-mix(in hsl,var(--color-border) 70%,transparent),0 3px 10px -4px rgba(0,0,0,0.45); gap: var(--space-3); display: grid; }
.captain-tools::before { content: "Captain Tools"; position: absolute; top: -10px; left: 14px; padding: 2px 10px 3px; background: color-mix(in hsl,var(--color-surface) 96%,var(--color-bg)); border: 1px solid color-mix(in hsl,var(--color-border) 75%,var(--color-primary)); border-radius: 999px; font-size: 0.58rem; letter-spacing: 0.65px; font-weight: 700; text-transform: uppercase; color: var(--color-muted); }
.captain-tools .list-group { margin-top: var(--space-2); gap: 4px; }
.captain-tools .list-group-item { background: color-mix(in hsl,var(--color-surface) 94%,var(--color-bg)); border: 1px solid color-mix(in hsl,var(--color-border) 70%,var(--color-primary)); box-shadow: 0 1px 4px -1px rgba(0,0,0,0.4); font-size: 0.75rem; padding: 8px 10px; }
.captain-tools .actions-row { margin-top: 4px; padding-top: 4px; border-top: 1px solid color-mix(in hsl,var(--color-border) 75%,var(--color-primary)); }
.team-card:has(.captain-tools) { border-color: color-mix(in hsl,var(--color-primary) 50%,var(--color-border)); box-shadow: 0 0 0 1px color-mix(in hsl,var(--color-primary) 45%,transparent),0 6px 18px -10px rgba(0,0,0,0.5),0 2px 6px -2px rgba(0,0,0,0.35); }
.no-has .team-card .captain-tools { outline: 1px solid var(--color-primary); }
@media (max-width: 700px) { .teams-list .team-card { padding: var(--space-4) var(--space-3) var(--space-4); } .team-meta { font-size: 0.64rem; gap: 6px; padding: 6px 8px; } .team-members { font-size: 0.7rem; padding: 8px 12px 10px; } .captain-tools { padding: var(--space-4) var(--space-3) var(--space-3); } }

/* =========================
   RESPONSIVE SYSTEM
   ========================= */
.d-none { display: none !important; }
.d-inline { display: inline !important; }
.d-inline-block { display: inline-block !important; }
.d-block { display: block !important; }
.d-flex { display: flex !important; }
.d-inline-flex { display: inline-flex !important; }
.d-grid { display: grid !important; }

@media (max-width: 1200px) { .d-xl-none { display: none !important; } .d-xl-inline { display: inline !important; } .d-xl-inline-block { display: inline-block !important; } .d-xl-block { display: block !important; } .d-xl-flex { display: flex !important; } .d-xl-inline-flex { display: inline-flex !important; } .stack-xl { flex-direction: column !important; } .wrap-xl { flex-wrap: wrap !important; } }

@media (max-width: 992px) { .d-lg-none { display: none !important; } .d-lg-inline { display: inline !important; } .d-lg-inline-block { display: inline-block !important; } .d-lg-block { display: block !important; } .d-lg-flex { display: flex !important; } .d-lg-inline-flex { display: inline-flex !important; } .stack-lg { flex-direction: column !important; } .wrap-lg { flex-wrap: wrap !important; } .container { padding-inline: var(--space-4); } }

@media (max-width: 768px) { .d-md-none { display: none !important; } .d-md-inline { display: inline !important; } .d-md-inline-block { display: inline-block !important; } .d-md-block { display: block !important; } .d-md-flex { display: flex !important; } .d-md-inline-flex { display: inline-flex !important; } .stack-md { flex-direction: column !important; } .wrap-md { flex-wrap: wrap !important; } .tabs { overflow-x: auto; white-space: nowrap; scrollbar-width: thin; } .tabs::-webkit-scrollbar { height: 6px; } .tabs::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 3px; } }

@media (max-width: 640px) { .d-sm-none { display: none !important; } .d-sm-inline { display: inline !important; } .d-sm-inline-block { display: inline-block !important; } .d-sm-block { display: block !important; } .d-sm-flex { display: flex !important; } .d-sm-inline-flex { display: inline-flex !important; } .stack-sm { flex-direction: column !important; } .wrap-sm { flex-wrap: wrap !important; } .row { grid-template-columns: repeat(6,minmax(0,1fr)); } .col-sm-6 { grid-column: span 6; } .container { padding-inline: var(--space-3); } }

@media (max-width: 480px) { .d-xs-none { display: none !important; } .d-xs-inline { display: inline !important; } .d-xs-inline-block { display: inline-block !important; } .d-xs-block { display: block !important; } .d-xs-flex { display: flex !important; } .d-xs-inline-flex { display: inline-flex !important; } .stack-xs { flex-direction: column !important; } .wrap-xs { flex-wrap: wrap !important; } .row { grid-template-columns: repeat(4,minmax(0,1fr)); } .container { padding-inline: var(--space-2); } }

.justify-center { justify-content: center !important; }
.justify-between { justify-content: space-between !important; }
.items-center { align-items: center !important; }
.w-100 { width: 100% !important; }

/* =========================
   ANALYZER UTILITIES
   ========================= */
.font-mono{font-family:var(--font-mono)}.summary-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.summary-label{font-weight:600;letter-spacing:.3px}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--color-muted);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;vertical-align:text-bottom}@keyframes spin{to{transform:rotate(360deg)}}.token-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-2)}.token-cell{padding:var(--space-2) var(--space-3);background:color-mix(in hsl,var(--color-surface) 92%,var(--color-bg));border:1px solid var(--color-border);border-radius:var(--radius-sm);text-align:center;font-family:var(--font-mono);font-size:.85rem;word-break:break-all}

/* ============================================================
 * TOOLTIP COMPONENT 
 * ============================================================ */
.tooltip{position:fixed;z-index:1050;pointer-events:none;background:color-mix(in hsl,var(--color-surface) 95%,var(--color-bg));color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;padding:8px 10px;font-size:.78rem;line-height:1.35;box-shadow:0 4px 14px rgba(0,0,0,.35);max-width:240px;opacity:0;transition:opacity 90ms ease}.tooltip.is-visible{opacity:1}.equip-item{cursor:help}.equip-item:hover{text-decoration:underline}
#sponsorTooltip{position:fixed;z-index:1050;pointer-events:none;padding:8px 14px;font-size:.86rem;font-weight:700;letter-spacing:.3px;background:color-mix(in hsl,var(--color-surface)92%,var(--color-bg));color:var(--color-primary);border:1px solid color-mix(in hsl,var(--color-primary)65%,var(--color-border));border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.45),inset 0 0 0 1px rgba(255,255,255,.04);text-shadow:0 0 2px rgba(251,238,35,.4);backdrop-filter:saturate(120%) blur(4px);opacity:0;transition:opacity 120ms ease;}
#sponsorTooltip::before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.08)0%,transparent 45%);pointer-events:none;}

/* ==================================
   SPONSOR BAR
   ================================== */
.sponsor-bar{--sponsor-bar-height:95px;background:color-mix(in hsl,var(--color-surface) 94%,var(--color-bg));border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);overflow:hidden;min-height:var(--sponsor-bar-height);display:flex;align-items:center;}
.sponsor-carousel{display:flex;gap:48px;align-items:center;width:max-content;animation:sponsor-scroll 70s linear infinite;}
.sponsor-logo{width:75px;height:75px;object-fit:contain;opacity:.15;transition:opacity .5s ease;filter:grayscale(55%);}
.sponsor-logo:hover,.sponsor-logo:focus-visible{opacity:1;filter:none;}
@keyframes sponsor-scroll{from{transform:translateX(100vw);}to{transform:translateX(-100%);}}

/* ========================= 
   TAB-PANEL STABILISER
   ========================= */
.tab-panels{min-height:var(--tab-panels-min-h,auto);position:relative;}

/* ======================================================================
   LOOT-REVEAL ANIMATIONS
   ====================================================================== */
@keyframes groupPop {
  0%   { transform: scale(0.6) rotate(-2deg); opacity: 0; }
  60%  { transform: scale(1.05) rotate(0deg);  opacity: 1; }
  100% { transform: scale(1)    rotate(0deg);  opacity: 1; }
}

.rarity-group-reveal {
  animation: groupPop 0.55s cubic-bezier(.25,.7,.3,1.1) both;
  will-change: transform, opacity;
}

.rarity-group--legendary { box-shadow: 0 0 14px 3px var(--rarity-color-legendary / 70%); }
.rarity-group--mythic    { box-shadow: 0 0 16px 4px var(--rarity-color-mythic   / 80%); }

.rarity-group--legendary > summary .rarity-title { color: var(--rarity-color-legendary); }
.rarity-group--mythic    > summary .rarity-title { color: var(--rarity-color-mythic); }

@keyframes confettiFall {
  0%   { transform: translateY(-10vh) rotate(0deg);   opacity: 1; }
  100% { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}

.confetti-piece {
  position: fixed;
  top: 0;
  width: 8px;
  height: 8px;
  background: var(--color-primary);
  border-radius: 2px;
  pointer-events: none;
  z-index: 1051;
  opacity: 0;
  animation: confettiFall 1.8s linear forwards;
}
