* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
}

body {
    background: #0f1014;
    color: #fff;
    font-family: "Builder Sans", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
    font-size: 16px;
    font-weight: 500;
}

.topbar {
    width: 100%;
    height: 42px;
    position: sticky;
    top: 0;
    z-index: 1000;
    background: #191a1f;
    display: flex;
    align-items: center;
    gap: 0;
    padding: 0 26px 0 22px;
    color: #fff;
}

.brand {
    width: 152px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
    color: #fff;
    text-decoration: none;
    margin-right: 5px;
}

.brand-logo {
    width: 120px;
    height: auto;
    display: block;
}

.main-nav {
    height: 42px;
    display: grid;
    grid-template-columns: 150px 196px 150px 138px;
    align-items: center;
    flex: 0 0 auto;
}

.main-nav a {
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    color: #fff;
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    white-space: nowrap;
}

.main-nav a::after {
    content: "";
    height: 2px;
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    background: #fff;
    opacity: 0;
    transform: scaleX(0.72);
    transition: opacity 120ms ease, transform 120ms ease;
}

.main-nav a:hover::after,
.main-nav a:focus-visible::after {
    opacity: 1;
    transform: scaleX(1);
}

.brand:hover {
    opacity: 0.9;
}

.search {
    height: 28px;
    width: 480px;
    max-width: 480px;
    min-width: 180px;
    display: flex;
    align-items: center;
    flex: 0 1 480px;
    position: relative;
    margin-left: 0;
}

.search-icon {
    width: 18px;
    height: 18px;
    position: absolute;
    left: 5px;
    opacity: 0.95;
    pointer-events: none;
}

.search input {
    width: 100%;
    height: 28px;
    border: 1px solid #353740;
    border-radius: 8px;
    outline: none;
    box-shadow: none;
    appearance: none;
    -webkit-appearance: none;
    background: #202126;
    color: #d7d7dc;
    display: flex;
    align-items: center;
    padding: 0 12px 0 31px;
    font: inherit;
    font-weight: 500;
}

.search input::placeholder {
    color: #d7d7dc;
    opacity: 1;
}

.search input:focus {
    border-color: #5b5f6b;
}

.signup {
    display: inline-block;
    flex: 0 0 auto;
    border: 1px solid transparent;
    border-radius: 8px;
    background-color: #335fff;
    color: #f7f7f8;
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    line-height: 20px;
    margin-left: auto;
    padding: 4px 9px;
    text-align: center;
    user-select: none;
}

.signup:hover {
    background: #426bff;
}

main {
    width: 100%;
    min-height: calc(100vh - 42px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 16px;
    background: radial-gradient(circle at center, rgba(0, 0, 0, 0.5) 60%, rgba(0, 0, 0, 0.75) 100%), url("../img/bgroblox.jpg") 50% / cover no-repeat fixed;
}

.login-card {
    width: 362px;
    max-width: 100%;
    padding: 15px;
    background: #272930;
    color: #f7f7f8;
    text-align: center;
}

h1,
h2,
h3,
h4,
h5 {
    margin: 0;
    padding: 5px 0;
    line-height: 1.4em;
}

h1 {
    font-size: 30px;
    font-weight: 800;
}

.login-form {
    margin-top: 5px;
}

.input-field {
    width: 100%;
    height: 40px;
    display: flex;
    align-items: center;
    border: 1px solid #393b44;
    border-radius: 8px;
    outline: none;
    background-color: #343740;
    color: #f7f7f8;
    padding: 8px 12px;
    font: inherit;
    font-size: 16px;
    line-height: 1.4em;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.input-field + .input-field {
    margin-top: 18px;
}

.input-field::placeholder {
    color: #d7d7dc;
    opacity: 1;
}

.input-field:focus {
    border-color: #b8bbc8;
}

.btn {
    border: 1px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    font-family: "Builder Sans", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.4em;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    user-select: none;
}

.btn-full-width {
    width: 100%;
}

.login-button {
    margin: 6px 0 12px;
    padding: 8px 9px;
    border-color: rgba(247, 247, 248, 0.8);
    background-color: transparent;
    color: rgba(247, 247, 248, 0.8);
}

.login-button:hover {
    border-color: #f7f7f8;
    background-color: transparent;
    color: #f7f7f8;
}

.login-button:disabled {
    cursor: not-allowed;
    opacity: 0.55;
}

.btn-secondary-md:hover {
    background-color: rgba(208, 217, 251, 0.12);
}

.forgot-link {
    display: inline-block;
    margin-top: 12px;
    color: #f7f7f8;
    font-size: 16px;
    font-weight: 300;
    text-decoration: none;
}

.forgot-link:hover,
.signup-prompt a:hover {
    text-decoration: underline;
}

.login-separator {
    height: 1px;
    margin: 24px 0 9px;
    background: #393b44;
}

.btn-secondary-md {
    padding: 8px 9px;
    border-color: transparent;
    background-color: rgba(208, 217, 251, 0.12);
    color: #f7f7f8;
}

.otp-login-button {
    margin-top: 12px;
    margin-bottom: 6px;
}

.quick-login-button {
    margin-top: 6px;
    margin-bottom: 18px;
}

.signup-prompt {
    margin: 24px 0;
    color: #f7f7f8;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.4em;
}

.signup-prompt a {
    color: #f7f7f8;
    text-decoration: none;
}

body.modal-open {
    overflow: hidden;
}

.verification-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    background: rgba(0, 0, 0, 0.68);
}

.verification-modal[hidden] {
    display: none;
}

.verification-dialog {
    width: min(480px, calc(100vw - 32px));
    min-height: min(686px, calc(100vh - 32px));
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    border-radius: 10px;
    background: #272930;
    color: #f7f7f8;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38);
}

.verification-header {
    height: 48px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid #494d5a;
    flex-shrink: 0;
}

.verification-header h2 {
    margin: 0;
    padding: 0 44px;
    color: #f7f7f8;
    font-size: 20px;
    font-weight: 400;
    line-height: 24px;
    text-align: center;
}

.verification-close {
    width: 28px;
    height: 28px;
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    cursor: pointer;
    padding: 0;
}

.verification-close::before,
.verification-close::after {
    content: "";
    width: 22px;
    height: 2px;
    position: absolute;
    left: 3px;
    top: 13px;
    border-radius: 2px;
    background: #f7f7f8;
}

.verification-close::before {
    transform: rotate(45deg);
}

.verification-close::after {
    transform: rotate(-45deg);
}

.verification-content {
    padding: 24px 32px 20px;
    text-align: center;
}

.verification-shield {
    height: 156px;
    margin-top: 16px;
    margin-bottom: 32px;
    background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI3MiIgaGVpZ2h0PSI3MyIgZmlsbD0ibm9uZSIgdmlld0JveD0iMCAwIDcyIDczIj48cGF0aCBmaWxsPSIjMjAyMjI3IiBkPSJNMzQuNTc1IDUuNjg5YTQuNSA0LjUgMCAwIDEgMi44NDcgMGwyMi41IDcuNUE0LjUwNSA0LjUwNSAwIDAgMSA2MyAxNy40NjVsLS4wMDcgMi40MzZjLS4xMSAyNC43Ny0xLjcyOCAzNy4yMjctMjUuMjU1IDQ3LjU3bC0uMjA4LjA4NWMtLjk3OS4zNy0yLjA3OC4zNy0zLjA1NyAwbC0uMjA4LS4wODVDMTAuNzM2IDU3LjEyOCA5LjExOSA0NC42NyA5LjAwOCAxOS45TDkgMTcuNDY1YTQuNTEgNC41MSAwIDAgMSAyLjczOC00LjE1bC4zMzgtLjEyNnptMS44OTggMi44NDVhMS41IDEuNSAwIDAgMC0uOTQ5IDBsLTIyLjQ5OSA3LjVhMS41MSAxLjUxIDAgMCAwLTEuMDI0IDEuNDI3Yy4wMTggMTMuMzQ4LjMwNSAyMi41MzkgMy4zMDcgMjkuNzUgMi44NzcgNi45MTEgOC40NCAxMi4zNiAyMC4xNjMgMTcuNTE0LjMyOS4xNDQuNzMuMTQ0IDEuMDYgMEM0OC4yNTEgNTkuNTcgNTMuODE0IDU0LjEyMiA1Ni42OTEgNDcuMjEgNTkuNjk0IDQwIDU5Ljk4MSAzMC44MSA2MCAxNy40NjFjMC0uNjQ2LS40MTYtMS4yMjQtMS4wMjQtMS40Mjd6Ii8+PHBhdGggZmlsbD0iIzIwMjIyNyIgZD0iTTM2LjM4IDE4LjQ3NGE3LjI3IDcuMjcgMCAwIDEgNi44OTUgNy4yNnYyLjQyM0g0NS43bC4xODcuMDA1YTMuNjM1IDMuNjM1IDAgMCAxIDMuNDQ4IDMuNjN2MTQuMjUybC0uMDA3LjE3Yy0uMDYuODUtLjU3IDEuNjAxLTEuMzggMS44OTFsLS40LjEzOWMtMi4xMjMuNzE1LTYuMDc4IDEuNzItMTEuNTQgMS43MmwtMS4wNzItLjAxMmMtNC45MS0uMTItOC40ODctMS4wNC0xMC40NjgtMS43MDhsLS40LS4xMzljLS44NjUtLjMwOS0xLjM4Ny0xLjE0NC0xLjM4Ny0yLjA2MVYzMS43OTJhMy42MzUgMy42MzUgMCAwIDEgMy40NDctMy42M2wuMTg4LS4wMDVoMi40MjJ2LTIuNDIzYTcuMjcgNy4yNyAwIDAgMSA3LjI3LTcuMjd6TTI2LjMxNSAzMS4xNTdhLjYzNS42MzUgMCAwIDAtLjYzNC42MzR2MTMuNjljMS45MjYuNjI0IDUuNDU4IDEuNDgzIDEwLjMyNyAxLjQ4M3M4LjQtLjg1OSAxMC4zMjctMS40ODJ2LTEzLjY5YS42MzUuNjM1IDAgMCAwLS42MzUtLjYzNXptOS42OTMgMy45OGExLjUgMS41IDAgMCAxIDEuNSAxLjV2NC44NDZhMS41IDEuNSAwIDAgMS0zIDB2LTQuODQ2YTEuNSAxLjUgMCAwIDEgMS41LTEuNW0wLTEzLjY3M2E0LjI3IDQuMjcgMCAwIDAtNC4yNyA0LjI3djIuNDJoOC41Mzh2LTIuNDJhNC4yNyA0LjI3IDAgMCAwLTQuMjY4LTQuMjciLz48L3N2Zz4=);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: auto 100px;
    filter: brightness(0) invert(1);
}

.verification-copy {
    max-width: 430px;
    margin: 0 auto;
    color: #d7d7dc;
    font-size: 16px;
    font-weight: 400;
    line-height: 20px;
    text-align: center;
}

.verification-email {
    margin: 26px auto 0;
    color: #d7d7dc;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
}

.verification-code-input {
    display: block;
    width: 100%;
    margin-top: 42px;
    height: 38px;
    padding: 5px 12px;
    border-radius: 8px;
    line-height: 1.4em;
    font-size: 16px;
    font-weight: 400;
    box-sizing: border-box;
    background-color: #343740;
    border: 1px solid #5a5a5a;
    color: #d7d7dc;
    outline: none;
}

.verification-trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 24px;
    color: #d7d7dc;
    font-size: 16px;
    font-weight: 400;
    cursor: pointer;
}

.verification-trust input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 13px;
    height: 13px;
    flex-shrink: 0;
    cursor: pointer;
    background-color: #343740;
    border: 1px solid #ffffff;
    border-radius: 2px;
    position: relative;
}

.verification-trust input[type="checkbox"]:checked {
    border-color: transparent;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpolyline points='1.5,5 4,7.5 8.5,2.5' fill='none' stroke='%23ffffff' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 9px 9px;
}

.verification-verify {
    display: block;
    width: 100%;
    height: 36px;
    margin-top: 19px;
    margin-bottom: 18px;
    background-color: #8f9094;
    border: none;
    border-radius: 8px;
    color: #000000;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    box-sizing: border-box;
}

.verification-verify[hidden] {
    display: none !important;
}

.verification-help {
    margin: 0;
    color: #d7d7dc;
    font-size: 10px;
    font-weight: 400;
    text-align: center;
}

.verification-help strong {
    cursor: pointer;
}

.verification-help strong:hover {
    text-decoration: underline;
}

.verification-important {
    margin: 12px 0 0;
    color: #d7d7dc;
    font-size: 10px;
    font-weight: 400;
    text-align: center;
}

.alt-dialog {
    width: 480px;
    height: 500px;
    border-radius: 10px;
    background: #272930;
    color: #f7f7f8;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.alt-dialog[hidden] {
    display: none;
}

.backup-dialog {
    width: 480px;
    height: 566px;
    border-radius: 10px;
    background: #272930;
    color: #f7f7f8;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.backup-dialog[hidden] {
    display: none;
}

.backup-close {
    width: 28px;
    height: 28px;
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    cursor: pointer;
    padding: 0;
}

.backup-close::before,
.backup-close::after {
    content: "";
    width: 22px;
    height: 2px;
    position: absolute;
    left: 3px;
    top: 13px;
    border-radius: 2px;
    background: #f7f7f8;
}

.backup-close::before { transform: rotate(45deg); }
.backup-close::after  { transform: rotate(-45deg); }

.backup-dialog .alt-content {
    padding: 20px 32px 24px;
}

.backup-dialog .verification-shield {
    height: 156px;
    margin-top: 16px;
    margin-bottom: 28px;
}

.backup-dialog .alt-copy {
    margin-bottom: 24px;
}

.backup-dialog .verification-code-input {
    margin-top: 0;
}

.backup-dialog .verification-trust {
    margin-top: 20px;
}

.backup-dialog .verification-link {
    margin-top: 20px;
}

.backup-dialog .verification-verify {
    margin-top: 18px;
    margin-bottom: 16px;
}

.backup-dialog .verification-help {
    margin-top: 0;
}

.backup-dialog .verification-important {
    margin-top: 10px;
}

.alt-close {
    width: 28px;
    height: 28px;
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    cursor: pointer;
    padding: 0;
}

.alt-close::before,
.alt-close::after {
    content: "";
    width: 22px;
    height: 2px;
    position: absolute;
    left: 3px;
    top: 13px;
    border-radius: 2px;
    background: #f7f7f8;
}

.alt-close::before { transform: rotate(45deg); }
.alt-close::after  { transform: rotate(-45deg); }

.alt-content {
    padding: 24px 32px 28px;
    text-align: center;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.alt-copy {
    margin: 0 0 20px;
    color: #d7d7dc;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
}

.alt-methods {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.alt-method {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: transparent;
    border: none;
    color: #f7f7f8;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    text-align: left;
    border-radius: 8px;
}

.alt-method:first-child {
    background: #121215;
}

.alt-method:first-child:hover {
    background: #1a1a1e;
}

.alt-method:last-child:hover {
    background: #33363e;
}

.alt-method-icon {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.alt-method-icon--email {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f7f7f8' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='4' width='20' height='16' rx='2'/%3E%3Cpolyline points='2,4 12,13 22,4'/%3E%3C/svg%3E");
}

.alt-method-icon--backup {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' width='32' height='32'%3E%3Cpath d='M4 4V8.78526C6.44903 4.7205 10.9059 2 16 2C23.732 2 30 8.26801 30 16L30 16.0029C29.9999 16.4127 29.9822 16.8187 29.9475 17.22C29.9 17.7702 29.4154 18.1778 28.8651 18.1302C28.3149 18.0827 27.9074 17.5981 27.9549 17.0478C27.9848 16.7028 28 16.3533 28 16V15.9973C27.9985 9.37113 22.6265 4 16 4C11.5596 4 7.68071 6.41198 5.60513 10H10C10.5523 10 11 10.4477 11 11C11 11.5523 10.5523 12 10 12H3C2.44772 12 2 11.5523 2 11V4C2 3.44772 2.44772 3 3 3C3.55228 3 4 3.44772 4 4Z' fill='%23ffffff'/%3E%3Cpath d='M28.6908 21.9186C28.9246 21.4182 28.7084 20.8231 28.208 20.5894C27.7076 20.3556 27.1125 20.5718 26.8788 21.0722C26.5818 21.7078 26.2307 22.3133 25.8313 22.8827C25.5141 23.3349 25.6235 23.9585 26.0757 24.2757C26.5278 24.5929 27.1514 24.4834 27.4686 24.0313C27.9344 23.3673 28.3442 22.6608 28.6908 21.9186Z' fill='%23ffffff'/%3E%3Cpath d='M7.34065 24.3076C6.95825 23.9091 6.32522 23.8961 5.92674 24.2785C5.52826 24.6609 5.51522 25.2939 5.89763 25.6924C6.11461 25.9185 6.33913 26.1374 6.57076 26.3485C6.97889 26.7206 7.61138 26.6914 7.98346 26.2832C8.35554 25.8751 8.32631 25.2426 7.91817 24.8705C7.71945 24.6894 7.52682 24.5016 7.34065 24.3076Z' fill='%23ffffff'/%3E%3Cpath d='M24.0313 27.4686C24.4834 27.1514 24.5928 26.5278 24.2757 26.0757C23.9585 25.6235 23.3349 25.5141 22.8827 25.8313C22.3133 26.2307 21.7078 26.5818 21.0722 26.8788C20.5718 27.1125 20.3556 27.7076 20.5894 28.208C20.8231 28.7084 21.4182 28.9246 21.9186 28.6908C22.6607 28.3442 23.3673 27.9344 24.0313 27.4686Z' fill='%23ffffff'/%3E%3Cpath d='M10.5625 26.7005C10.0703 26.4498 9.46819 26.6456 9.21757 27.1378C8.96694 27.6299 9.16273 28.232 9.65487 28.4827C10.2109 28.7658 10.7885 29.013 11.3845 29.221C11.9059 29.4031 12.4762 29.1279 12.6582 28.6065C12.8402 28.0851 12.565 27.5148 12.0436 27.3328C11.5334 27.1547 11.0388 26.943 10.5625 26.7005Z' fill='%23ffffff'/%3E%3Cpath d='M17.22 29.9475C17.7702 29.9 18.1777 29.4154 18.1302 28.8651C18.0827 28.3149 17.5981 27.9074 17.0478 27.9549C16.7027 27.9848 16.3533 28 16 28C15.7287 28 15.4597 27.991 15.1932 27.9733C14.6421 27.9368 14.1657 28.3539 14.1292 28.905C14.0926 29.4561 14.5098 29.9324 15.0608 29.969C15.3714 29.9896 15.6845 30 16 30C16.4108 30 16.8177 29.9823 17.22 29.9475Z' fill='%23ffffff'/%3E%3Cpath d='M17 9C17 8.44772 16.5523 8 16 8C15.4477 8 15 8.44772 15 9V16C15 16.2652 15.1054 16.5196 15.2929 16.7071L18.2929 19.7071C18.6834 20.0976 19.3166 20.0976 19.7071 19.7071C20.0976 19.3166 20.0976 18.6834 19.7071 18.2929L17 15.5858V9Z' fill='%23ffffff'/%3E%3C/svg%3E");
}

.alt-method-label {
    flex: 1;
}

.alt-method-arrow {
    width: 10px;
    height: 10px;
    border-right: 2px solid #8a8a8a;
    border-top: 2px solid #8a8a8a;
    transform: rotate(45deg);
    flex-shrink: 0;
}

.alt-bottom {
    margin-top: auto;
    padding-top: 20px;
    text-align: center;
}

.alt-lost {
    margin: 0 0 16px;
    color: #f7f7f8;
    font-size: 16px;
    font-weight: 700;
    text-align: center;
    cursor: pointer;
}

.alt-lost:hover {
    text-decoration: underline;
}

.verification-link {
    display: block;
    background: none;
    border: none;
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    margin: 12px auto 0;
    text-align: center;
}

.verification-link:first-of-type {
    margin-top: 24px;
}

.verification-link--last {
    margin-top: 12px;
}

.verification-code-input::placeholder {
    color: #8a8a8a;
}

.verification-code-input:focus {
    border-color: #ffffff;
}

.authenticator-dialog {
    width: min(480px, calc(100vw - 32px));
    min-height: min(686px, calc(100vh - 32px));
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    border-radius: 10px;
    background: #272930;
    color: #f7f7f8;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38);
}
.authenticator-dialog[hidden] { display: none; }
.authenticator-dialog .alt-content { padding: 24px 32px 28px; text-align: center; flex: 1; }
.authenticator-dialog .verification-shield { margin: 0 auto 8px; }
.authenticator-dialog .alt-copy { margin: 0 0 16px; color: #f7f7f8; font-size: 16px; line-height: 1.5; }
.authenticator-dialog .verification-code-input { margin-top: 8px; }
.authenticator-dialog .verification-trust { margin-top: 12px; }
.authenticator-dialog .verification-link { margin-top: 12px; }
.authenticator-dialog .verification-verify { margin-top: 12px; }
.authenticator-dialog .verification-help { margin-top: 12px; }
.authenticator-dialog .verification-important { margin-top: 10px; }
.auth-close { width:28px; height:28px; position:absolute; left:10px; top:50%; transform:translateY(-50%); border:0; background:transparent; cursor:pointer; padding:0; }
.auth-close::before, .auth-close::after { content:""; width:22px; height:2px; position:absolute; left:3px; top:13px; border-radius:2px; background:#f7f7f8; }
.auth-close::before { transform:rotate(45deg); }
.auth-close::after  { transform:rotate(-45deg); }

.passkey-dialog {
    width: min(480px, calc(100vw - 32px));
    min-height: min(686px, calc(100vh - 32px));
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    border-radius: 10px;
    background: #272930;
    color: #f7f7f8;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.38);
}
.passkey-dialog[hidden] { display: none; }
.passkey-dialog .alt-content { padding: 24px 32px 28px; text-align: center; flex: 1; }
.passkey-dialog .verification-shield { margin: 0 auto 8px; }
.passkey-dialog .alt-copy { margin: 0 0 16px; color: #f7f7f8; font-size: 16px; line-height: 1.5; }
.passkey-dialog .verification-verify { margin-top: 16px; }
.passkey-dialog .verification-link { margin-top: 12px; }
.passkey-dialog .verification-help { margin-top: 12px; }
.passkey-dialog .verification-important { margin-top: 10px; }
.passkey-close { width:28px; height:28px; position:absolute; left:10px; top:50%; transform:translateY(-50%); border:0; background:transparent; cursor:pointer; padding:0; }
.passkey-close::before, .passkey-close::after { content:""; width:22px; height:2px; position:absolute; left:3px; top:13px; border-radius:2px; background:#f7f7f8; }
.passkey-close::before { transform:rotate(45deg); }
.passkey-close::after  { transform:rotate(-45deg); }

.alt-method-icon--passkey {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f7f7f8' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'/%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'/%3E%3C/svg%3E");
}
.alt-method-icon--auth {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f7f7f8' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E");
}

.login-status {
    min-height: 18px;
    margin: 4px 0 0;
    color: #d7d7dc;
    font-size: 12px;
    line-height: 1.4em;
}

.login-status.is-error {
    color: #ff8d8d;
}

.site-footer {
    padding: 12px;
    background: #121215;
    color: #f7f7f8;
}

.footer {
    max-width: 1070px;
    margin: 0 auto;
    text-align: center;
}

.row {
    margin-left: 0;
    margin-right: 0;
}

.flex {
    display: flex;
}

.footer .footer-links {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px 18px;
    margin-top: 20px;
    margin-bottom: 32px;
    padding-left: 0;
    list-style: none;
    text-align: center;
}

.footer-links a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #f7f7f8;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.4em;
    text-decoration: none;
    white-space: nowrap;
}

.footer-links a:hover {
    text-decoration: underline;
}

.privacy-icon {
    width: 30px;
    height: auto;
    display: inline-block;
}

.copyright-container {
    justify-content: flex-end;
    border-top: 1px solid #494d5a;
    padding-top: 24px;
}

.copyright-container .footer-note {
    width: auto;
    margin: 0 60px 0 0;
    color: #f7f7f8;
    font-size: 10px;
    font-weight: 500;
    line-height: 1.4em;
    text-align: left;
}

.header-login {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border: 1px solid #b8bbc8;
    border-radius: 8px;
    color: #272930;
    background: #fff;
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    line-height: 20px;
    margin-left: 6px;
    padding: 4px 9px;
}

.profile-page {
    background: #fff;
    color: #111217;
}

.profile-page .topbar {
    background: #f4f4f5;
    border-bottom: 1px solid #e6e7ea;
    color: #111217;
}

.profile-page .brand-logo {
    filter: invert(1);
}

.profile-page .main-nav a {
    color: #111217;
}

.profile-page .main-nav a::after {
    background: #111217;
}

.profile-page .search input {
    border-color: #c9ccd3;
    background: #eef0f4;
    color: #272930;
}

.profile-page .search input::placeholder {
    color: #343740;
}

.profile-page .search-icon {
    filter: brightness(0);
    opacity: 0.75;
}

.profile-page .signup {
    margin-left: auto;
}

.profile-main {
    min-height: calc(100vh - 42px - 96px);
    display: block;
    padding: 0 16px 20px;
    background: #fff;
}

.roblox-profile {
    width: min(970px, 100%);
    margin: 0 auto;
}

.profile-loading,
.profile-error {
    padding: 120px 0;
    color: #272930;
    text-align: center;
}

.profile-error a {
    color: #335fff;
}

.profile-hero {
    min-height: 210px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 0;
}

.profile-hero::after {
    content: "";
    width: 360px;
    height: 90px;
    position: absolute;
    left: 50%;
    bottom: -8px;
    z-index: 0;
    transform: translateX(-50%);
    background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.86) 42%, rgba(255, 255, 255, 0) 78%);
    pointer-events: none;
}

.profile-avatar-full {
    width: 310px;
    height: 310px;
    position: relative;
    z-index: 1;
    object-fit: contain;
    transform: translateY(8px);
}

.profile-3d-button {
    width: 46px;
    height: 48px;
    position: absolute;
    right: 12px;
    top: 14px;
    border: 0;
    border-radius: 8px;
    background: #dedfe6;
    color: #111217;
    font: inherit;
    font-weight: 700;
}

.profile-identity {
    padding-bottom: 8px;
    margin-top: -50px;
}

.profile-name-row {
    display: grid;
    grid-template-columns: 126px minmax(0, 1fr) 332px;
    align-items: center;
    gap: 14px;
}

.profile-headshot-wrap {
    width: 126px;
    height: 126px;
    position: relative;
}

.profile-headshot {
    width: 126px;
    height: 126px;
    display: block;
    border-radius: 50%;
    background: #e6e7ea;
    object-fit: cover;
}

.profile-ingame-badge {
    width: 30px;
    height: 30px;
    position: absolute;
    right: 1px;
    bottom: 5px;
    display: block;
}

.profile-title-block h1 {
    margin: 0;
    padding: 0;
    color: #111217;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.15;
}

.profile-title-block p {
    margin: 4px 0 0;
    color: #111217;
    font-size: 16px;
    line-height: 1.3;
}

.profile-actions {
    display: grid;
    grid-template-columns: 1fr 42px;
    gap: 8px;
    position: relative;
}

.profile-add-friend,
.profile-more {
    height: 40px;
    border: 0;
    border-radius: 8px;
    font: inherit;
    font-weight: 700;
}

.profile-add-friend {
    background: #335fff;
    color: #fff;
}

.profile-more {
    background: #e4e5eb;
    color: #111217;
}

.profile-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.2), 0 2px 4px rgba(0,0,0,0.08);
    z-index: 100;
    min-width: 160px;
    padding: 8px;
}
.profile-dropdown[hidden] { display: none; }
.profile-dropdown button {
    display: block;
    width: 100%;
    padding: 8px 8px;
    border: 0;
    border-radius: 6px;
    background: #fff;
    color: #111217;
    font-size: 14px;
    text-align: left;
    cursor: pointer;
}
.profile-dropdown button:hover {
    background: #f2f2f5;
}

.profile-stat-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}

.profile-stat-pills span {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #e7e8ee;
    color: #111217;
    font-size: 14px;
    font-weight: 700;
    padding: 0 12px;
}

.profile-tabs-line {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-top: 10px;
    border-bottom: 1px solid #d8dbe2;
}

.profile-tabs-line button {
    height: 36px;
    position: relative;
    border: 0;
    background: transparent;
    color: #344061;
    font: inherit;
    font-size: 14px;
    font-weight: 700;
}

.profile-tabs-line button.active::after {
    content: "";
    height: 2px;
    position: absolute;
    right: 0;
    bottom: -1px;
    left: 0;
    background: #111217;
}

.profile-about {
    padding-top: 24px;
}

.profile-tab-panel {
    display: none;
}

.profile-tab-panel.is-active {
    display: block;
}

.profile-store {
    margin-bottom: 28px;
}

.profile-store h2,
.profile-about h2,
.profile-creations h2 {
    margin: 0 0 12px;
    padding: 0;
    color: #111217;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
}

.profile-store h2 span {
    font-size: 30px;
    line-height: 0;
    vertical-align: -1px;
}

.profile-about-text {
    margin: 0 0 24px;
    color: #393b44;
    font-size: 16px;
    line-height: 1.45;
}

.wearing-carousel {
    position: relative;
}

.wearing-grid {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 8px;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
}

.wearing-grid::-webkit-scrollbar {
    display: none;
}

.wearing-scroll-prev,
.wearing-scroll-next {
    width: 42px;
    height: 42px;
    position: absolute;
    top: 55px;
    z-index: 2;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 10px rgba(17, 18, 23, 0.18);
    color: #111217;
    cursor: pointer;
    font: inherit;
    font-size: 42px;
    font-weight: 300;
    line-height: 1;
    padding: 0 0 5px;
}

.wearing-scroll-prev {
    left: -22px;
}

.wearing-scroll-next {
    right: -22px;
}

.wearing-scroll-prev[hidden],
.wearing-scroll-next[hidden] {
    display: none;
}

.profile-creations {
    padding-top: 24px;
}

.experiences-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 12px;
}

.experience-view-toggle {
    display: inline-flex;
    gap: 8px;
}

.experience-view-toggle button {
    width: 64px;
    height: 28px;
    display: grid;
    place-items: center;
    border: 1px solid transparent;
    border-radius: 8px;
    background: #e0e2e8;
}

.experience-view-toggle button.active {
    border-color: #111217;
    background: #fff;
}

.view-icon-list {
    width: 18px;
    height: 10px;
    display: block;
    border: 1px solid #606574;
    border-radius: 1px;
    box-shadow: inset 0 0 0 3px #fff;
}

.view-icon-grid {
    width: 18px;
    height: 14px;
    display: block;
    background: url("../img/grid-icon.svg") center / contain no-repeat;
}

.experiences-list {
    display: none;
}

.experiences-list.is-active {
    display: block;
}

.experience-row {
    display: grid;
    grid-template-columns: 486px minmax(0, 1fr);
    gap: 30px;
    margin-bottom: 24px;
}

.experience-preview {
    height: 302px;
    display: grid;
    place-items: center;
    background: #f4f4f5;
}

.experience-preview img {
    width: 240px;
    height: 240px;
    border-radius: 8px;
    object-fit: cover;
}

.experience-info {
    padding-top: 24px;
}

.experience-info h3 {
    margin: 0;
    padding: 0 0 4px;
    border-bottom: 1px solid #c7c9d1;
    color: #111217;
    font-size: 32px;
    font-weight: 800;
    line-height: 1.2;
}

.experience-description {
    max-width: 460px;
    margin: 6px 0 96px;
    color: #273047;
    font-size: 16px;
    line-height: 1.4;
}

.experience-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    max-width: 360px;
}

.experience-stats span {
    display: grid;
    gap: 2px;
    color: #111217;
    font-size: 16px;
    line-height: 1.25;
}

.experience-stats strong {
    font-weight: 700;
}

.creations-grid {
    display: none;
    grid-template-columns: repeat(4, 152px);
    gap: 12px;
}

.creations-grid.is-active {
    display: grid;
}

.creation-card {
    min-width: 0;
    border-radius: 8px;
    transition: background-color 120ms ease;
}

.creation-card:hover {
    background-color: transparent;
}

.creation-image-wrap {
    width: 152px;
    height: 152px;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: #e2e4eb;
    overflow: hidden;
    transition: background-color 120ms ease;
}

.creation-card:hover .creation-image-wrap {
    background-color: #d4d6df;
}

.creation-image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.creation-card h3 {
    margin: 10px 0 4px;
    padding: 0;
    color: #111217;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.25;
}

.creation-card p {
    margin: 0;
    color: #606574;
    font-size: 14px;
    line-height: 1.3;
}

.wearing-card {
    flex: 0 0 152px;
    min-width: 0;
    border-radius: 8px;
    padding: 0;
    scroll-snap-align: start;
    transition: background-color 120ms ease;
}

.wearing-card:hover {
    background-color: transparent;
}

.wearing-image-wrap {
    width: 152px;
    height: 152px;
    position: relative;
    display: grid;
    place-items: center;
    border-radius: 8px;
    background: #e2e4eb;
    overflow: hidden;
    transition: background-color 120ms ease;
}

.wearing-card:hover .wearing-image-wrap {
    background-color: #d4d6df;
}

.wearing-image-wrap img {
    width: 100%;
    height: 100%;
    filter: drop-shadow(0 1px 1px rgba(17, 18, 23, 0.22));
    object-fit: contain;
}

.wearing-card h3 {
    min-height: 38px;
    margin: 10px 0 4px;
    padding: 0;
    color: #111217;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.25;
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.limited-badge {
    height: 14px;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    background: #00b259;
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    line-height: 14px;
    padding: 0 4px;
}

.limited-badge::after {
    content: "";
    width: 0;
    height: 0;
    position: absolute;
    right: -8px;
    bottom: 0;
    border-bottom: 14px solid #00b259;
    border-right: 8px solid transparent;
}

.robux-price {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #4d5568;
    font-size: 14px;
}

.robux-price::before {
    content: "";
    width: 16px;
    height: 16px;
    display: inline-block;
    background: url("../img/robux-icon.svg") center / contain no-repeat;
}

.profile-empty-note {
    color: #606574;
}

.profile-footer {
    background: #fff;
    color: #111217;
}

.profile-footer .footer-links {
    margin-top: 50px;
    margin-bottom: 32px;
}

.profile-footer .footer-links a {
    color: #273047;
}

.profile-footer .copyright-container {
    justify-content: flex-end;
    border-top-color: #c7c9d1;
}

.profile-footer .copyright-container .footer-note {
    margin: 0 60px 0 0;
    color: #273047;
    text-align: left;
}

.game-main {
    min-height: calc(100vh - 42px - 96px);
    display: block;
    align-items: initial;
    justify-content: initial;
    padding: 36px 16px 24px;
    background: #fff;
}

.game-detail-root {
    width: min(970px, 100%);
    margin: 0 auto;
}

.game-detail-loading,
.game-detail-error {
    padding: 120px 0;
    color: #272930;
    text-align: center;
}

.game-overview {
    display: grid;
    grid-template-columns: minmax(0, 640px) minmax(270px, 1fr);
    align-items: stretch;
    gap: 24px;
}

.game-media-frame {
    aspect-ratio: 16 / 9;
    position: relative;
    overflow: hidden;
    background: #e6e7ea;
}

.game-media-frame img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.game-side-panel {
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.game-title-container h1 {
    display: -webkit-box;
    overflow: hidden;
    margin: 0;
    padding: 0;
    color: #111217;
    font-size: 32px;
    font-weight: 800;
    line-height: 1.18;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.game-creator {
    display: flex;
    align-items: center;
    gap: 4px;
    margin: 4px 0 0;
    color: #606574;
    font-size: 16px;
    line-height: 1.35;
}

.game-creator a {
    min-width: 0;
    color: #111217;
    font-weight: 700;
    text-decoration: none;
}

.game-creator a:hover {
    text-decoration: underline;
}

.game-verified-badge {
    width: 16px;
    height: 16px;
    display: inline-block;
    border-radius: 50%;
    background: #335fff;
    position: relative;
}

.game-verified-badge::after {
    content: "";
    width: 7px;
    height: 4px;
    position: absolute;
    left: 4px;
    top: 5px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg);
}

.game-play-button {
    width: 100%;
    height: 64px;
    display: grid;
    place-items: center;
    margin-top: auto;
    border: 0;
    border-radius: 8px;
    background: #00b259;
    cursor: pointer;
}

.game-play-button:hover {
    background: #00a652;
}

.game-play-button span {
    width: 0;
    height: 0;
    display: block;
    margin-left: 6px;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 24px solid #fff;
}

.game-actions-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 18px;
}

.game-social-action {
    min-width: 0;
    height: 58px;
    display: grid;
    place-items: center;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #393b44;
    cursor: pointer;
    font: inherit;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.2;
    padding: 4px;
}

.game-social-action:hover {
    background: #f0f1f5;
}

.game-social-action strong {
    max-width: 100%;
    color: #606574;
    font-size: 12px;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.game-icon-favorite,
.game-icon-follow,
.game-icon-like {
    width: 24px;
    height: 24px;
    display: block;
    position: relative;
}

.game-icon-favorite::before {
    content: "☆";
    position: absolute;
    inset: -4px 0 0;
    color: #606574;
    font-size: 30px;
    font-weight: 500;
    line-height: 24px;
}

.game-icon-follow::before {
    content: "";
    width: 18px;
    height: 18px;
    position: absolute;
    left: 3px;
    top: 1px;
    border: 2px solid #606574;
    border-radius: 50% 50% 42% 42%;
}

.game-icon-follow::after {
    content: "";
    width: 8px;
    height: 2px;
    position: absolute;
    left: 8px;
    bottom: 1px;
    background: #606574;
    border-radius: 2px;
}

.game-icon-like::before {
    content: "";
    width: 15px;
    height: 20px;
    position: absolute;
    left: 5px;
    top: 2px;
    border-radius: 8px 8px 3px 3px;
    background: #606574;
    transform: rotate(-18deg);
}

.game-icon-like::after {
    content: "";
    width: 9px;
    height: 9px;
    position: absolute;
    left: 2px;
    top: 11px;
    border-radius: 2px;
    background: #fff;
    transform: rotate(-18deg);
}

.game-tabs-line {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 24px;
    border-bottom: 1px solid #d8dbe2;
}

.game-tabs-line button {
    height: 44px;
    position: relative;
    border: 0;
    background: transparent;
    color: #344061;
    cursor: pointer;
    font: inherit;
    font-size: 16px;
    font-weight: 700;
}

.game-tabs-line button.active::after {
    content: "";
    height: 2px;
    position: absolute;
    right: 0;
    bottom: -1px;
    left: 0;
    background: #111217;
}

.game-tab-panel {
    display: none;
    padding-top: 24px;
}

.game-tab-panel.is-active {
    display: block;
}

.game-description-container h2,
.game-server-header h2,
.game-events-section h2,
.game-badges-section h2,
.game-recommendations-section h2 {
    margin: 0 0 10px;
    padding: 0;
    color: #111217;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
}

.game-events-section {
    margin-bottom: 24px;
}

.game-events-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.game-event-card {
    overflow: hidden;
    border-radius: 8px;
    background: #f4f4f5;
}

.game-event-image {
    aspect-ratio: 16 / 9;
    position: relative;
    overflow: hidden;
    background: #e2e4eb;
}

.game-event-image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.game-event-image span {
    min-height: 26px;
    position: absolute;
    left: 12px;
    top: 12px;
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #fff;
    color: #111217;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    padding: 0 10px;
}

.game-event-body {
    padding: 12px;
}

.game-event-body h3 {
    margin: 0;
    padding: 0;
    color: #111217;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.25;
}

.game-event-body p {
    min-height: 20px;
    margin: 2px 0 10px;
    color: #273047;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.35;
}

.game-event-body button {
    width: 100%;
    height: 30px;
    border: 0;
    border-radius: 8px;
    background: #191a1f;
    color: #fff;
    cursor: pointer;
    font: inherit;
    font-size: 14px;
    font-weight: 700;
}

.game-event-body button.is-primary {
    background: #335fff;
}

.game-see-more {
    width: 100%;
    height: 36px;
    margin-top: 8px;
    border: 0;
    border-radius: 8px;
    background: #e4e5eb;
    color: #111217;
    cursor: pointer;
    font: inherit;
    font-size: 16px;
    font-weight: 700;
}

.game-see-more:hover {
    background: #d8dbe2;
}

.game-description-text {
    max-width: 720px;
    margin: 0;
    color: #273047;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.45;
    white-space: pre-wrap;
}

.game-maturity-pill {
    width: fit-content;
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    margin-top: 12px;
    border-radius: 8px;
    background: #e7e8ee;
    color: #111217;
    font-size: 16px;
    font-weight: 700;
    padding: 0 16px;
}

.game-stat-container {
    display: grid;
    grid-template-columns: repeat(9, 1fr);
    gap: 10px;
    margin-top: 24px;
    padding: 14px 0;
    border-top: 1px solid #e6e7ea;
    border-bottom: 1px solid #e6e7ea;
}

.game-stat {
    display: grid;
    gap: 5px;
    color: #111217;
    text-align: center;
}

.game-stat strong {
    color: #606574;
    font-size: 12px;
    font-weight: 500;
}

.game-stat span {
    font-size: 12px;
    font-weight: 700;
    line-height: 1.25;
}

.game-report-link {
    display: block;
    margin-top: 12px;
    color: #d60000;
    font-size: 12px;
    font-weight: 500;
    text-align: right;
    text-decoration: none;
}

.game-report-link:hover {
    text-decoration: underline;
}

.private-servers-section {
    margin-bottom: 28px;
}

.private-server-heading-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: 24px;
    align-items: start;
    margin-bottom: 28px;
}

.private-server-heading-row h2 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 12px;
    padding: 0;
    color: #111217;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
}

.private-server-heading-row h2 span {
    width: 18px;
    height: 18px;
    display: inline-grid;
    place-items: center;
    border: 1px solid #8d93a2;
    border-radius: 50%;
    color: #8d93a2;
    font-size: 13px;
    line-height: 1;
}

.private-server-heading-row p {
    margin: 0 0 6px;
    color: #273047;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.35;
}

.private-server-heading-row p strong {
    font-weight: 500;
}

.private-server-controls {
    display: grid;
    justify-items: end;
    gap: 6px;
}

.private-refresh-button {
    height: 20px;
    border: 0;
    border-radius: 999px;
    background: #e4e5eb;
    color: #273047;
    cursor: pointer;
    font: inherit;
    font-size: 16px;
    font-weight: 700;
    line-height: 20px;
    padding: 0 8px;
}

.private-refresh-button::after {
    content: "↻";
    margin-left: 8px;
}

.private-create-button {
    height: 32px;
    border: 1px solid #b8bbc8;
    border-radius: 8px;
    background: #fff;
    color: #b8bbc8;
    font: inherit;
    font-size: 16px;
    font-weight: 500;
    padding: 0 10px;
}

.private-server-controls small {
    max-width: 190px;
    color: #273047;
    font-size: 9px;
    font-weight: 500;
    line-height: 1.2;
}

.private-server-card {
    min-height: 236px;
    display: grid;
    grid-template-columns: 202px minmax(0, 1fr);
    position: relative;
    background: #f4f4f5;
    padding: 14px;
}

.private-server-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.private-server-list .private-server-card {
    min-height: 236px;
    grid-template-columns: 1fr;
}

.private-server-list .private-server-info {
    border-right: 0;
    padding-right: 0;
}

.private-server-info {
    display: grid;
    justify-items: center;
    align-content: start;
    padding-right: 14px;
    border-right: 1px solid #b8bbc8;
}

.private-server-info h3 {
    justify-self: start;
    margin: 0 0 8px;
    padding: 0;
    color: #111217;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.25;
}

.private-server-avatar-wrap {
    width: 84px;
    height: 84px;
    overflow: hidden;
    border-radius: 50%;
    background: #d8dbe2;
}

.private-server-avatar-wrap img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.private-server-info strong {
    width: 100%;
    margin-top: 8px;
    color: #111217;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.25;
    text-align: left;
}

.private-server-info p {
    width: 100%;
    margin: 8px 0 6px;
    color: #273047;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.25;
    text-align: left;
}

.private-server-gauge {
    width: 100%;
    height: 6px;
    overflow: hidden;
    border: 1px solid #b8bbc8;
    border-radius: 3px;
    background: #fff;
}

.private-server-gauge span {
    height: 100%;
    display: block;
    background: #b8bbc8;
}

.private-server-info button {
    width: 100%;
    height: 20px;
    margin-top: 14px;
    border: 0;
    border-radius: 8px;
    background: #e0e2e8;
    color: #111217;
    cursor: pointer;
    font: inherit;
    font-size: 12px;
    font-weight: 700;
}

.private-server-more {
    position: absolute;
    top: 10px;
    right: 10px;
    border: 0;
    background: transparent;
    color: #8d93a2;
    cursor: pointer;
    font: inherit;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 1px;
}

.game-auth-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: grid;
    place-items: center;
    background: rgba(0, 0, 0, 0.78);
    padding: 20px;
}

.game-auth-modal[hidden] {
    display: none;
}

.game-auth-dialog {
    width: min(500px, 100%);
    border: 1px solid #9ea4b3;
    background: #f4f4f5;
    color: #111217;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28);
}

.game-auth-dialog h2 {
    margin: 0;
    padding: 20px 16px;
    border-bottom: 1px solid #c7cbd5;
    color: #111217;
    font-size: 25px;
    font-weight: 400;
    line-height: 1.25;
}

.game-auth-dialog p {
    margin: 0;
    padding: 16px 16px 8px;
    color: #273047;
    font-size: 21px;
    font-weight: 400;
    line-height: 1.25;
}

.game-auth-actions {
    display: flex;
    gap: 18px;
    align-items: center;
    justify-content: center;
    padding: 0 16px 14px;
}

.game-auth-actions a {
    min-width: 112px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    color: #111217;
    font-size: 20px;
    font-weight: 500;
    text-decoration: none;
}

.game-auth-signup {
    background: #202229;
    color: #fff !important;
}

.game-auth-login {
    background: #dedfe6;
}

.game-badges-section {
    margin-top: 24px;
}

.game-badge-list {
    display: grid;
    gap: 6px;
}

.game-badge-row {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: 24px;
    align-items: center;
    background: #f4f4f5;
    padding: 12px;
}

.game-badge-image {
    width: 150px;
    height: 150px;
    overflow: hidden;
    border-radius: 50%;
    background: #e2e4eb;
}

.game-badge-image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.game-badge-content h3 {
    margin: 0 0 8px;
    padding: 0;
    color: #273047;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.25;
}

.game-badge-content p {
    margin: 0 0 30px;
    color: #273047;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.35;
}

.game-badge-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.game-badge-stats span {
    display: grid;
    gap: 6px;
    color: #111217;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.25;
    text-align: center;
}

.game-badge-stats strong {
    color: #273047;
    font-weight: 500;
}

.game-recommendations-section {
    margin-top: 28px;
}

.game-recommendations-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
}

.game-recommendation-card {
    min-width: 0;
    color: #111217;
    text-decoration: none;
}

.game-recommendation-image {
    width: 100%;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 8px;
    background: #e2e4eb;
    transition: background-color 120ms ease;
}

.game-recommendation-card:hover .game-recommendation-image {
    background: #d4d6df;
}

.game-recommendation-image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.game-recommendation-card h3 {
    min-height: 40px;
    display: -webkit-box;
    overflow: hidden;
    margin: 8px 0 4px;
    padding: 0;
    color: #111217;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.25;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.game-recommendation-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #4d5568;
    font-size: 13px;
    font-weight: 500;
}

.game-like-meta,
.game-player-meta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.game-like-meta::before {
    content: "";
    width: 14px;
    height: 14px;
    display: inline-block;
    background:
        linear-gradient(135deg, transparent 0 42%, #737782 43% 72%, transparent 73%) 3px 5px / 10px 9px no-repeat,
        linear-gradient(#737782, #737782) 6px 1px / 6px 9px no-repeat;
    transform: rotate(8deg);
}

.game-player-meta::before {
    content: "";
    width: 14px;
    height: 14px;
    display: inline-block;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 35%, #737782 0 28%, transparent 29%),
        radial-gradient(ellipse at 50% 96%, #737782 0 42%, transparent 43%);
}

.game-server-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
}

.server-refresh-button {
    height: 32px;
    border: 1px solid #b8bbc8;
    border-radius: 8px;
    background: #fff;
    color: #111217;
    cursor: pointer;
    font: inherit;
    font-size: 14px;
    font-weight: 700;
    padding: 0 14px;
}

.server-refresh-button:hover {
    background: #f0f1f5;
}

.game-server-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.game-server-card {
    min-height: 248px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border-radius: 8px;
    background: #f4f4f5;
    padding: 14px;
}

.server-avatar-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
    min-height: 84px;
    padding-top: 8px;
}

.server-avatar-placeholder {
    width: 38px;
    height: 38px;
    display: block;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 36%, #fff 0 10%, transparent 11%),
        linear-gradient(135deg, #d5d8e0, #a8adba);
}

.server-card-copy {
    display: grid;
    gap: 4px;
    color: #111217;
    font-size: 14px;
    text-align: center;
}

.server-card-copy strong {
    font-weight: 700;
}

.server-card-copy span {
    color: #606574;
    font-size: 12px;
    font-weight: 500;
}

.server-player-count-gauge {
    width: 100%;
    height: 6px;
    overflow: hidden;
    border-radius: 8px;
    background: #e1e3ea;
}

.server-player-count-gauge span {
    height: 100%;
    display: block;
    border-radius: inherit;
    background: #b8bbc8;
}

.server-join-button {
    height: 40px;
    border: 0;
    border-radius: 8px;
    background: #335fff;
    color: #fff;
    cursor: pointer;
    font: inherit;
    font-weight: 700;
}

.server-join-button:hover {
    background: #426bff;
}

.game-empty-state {
    padding: 32px 0;
    color: #606574;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
}

.game-footer .footer-links {
    margin-top: 34px;
}

.admin-page {
    background: #121215;
}

.admin-shell {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: #121215;
}

.admin-panel {
    width: min(560px, 100%);
    padding: 24px;
    border: 1px solid #353740;
    border-radius: 8px;
    background: #272930;
    color: #f7f7f8;
}

.admin-panel h1 {
    margin: 0;
    padding: 0;
    font-size: 28px;
    font-weight: 800;
}

.admin-panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.admin-dashboard-panel {
    width: min(980px, 100%);
}

.admin-dashboard {
    display: grid;
    grid-template-columns: 190px minmax(0, 1fr);
    gap: 18px;
}

.admin-sidebar {
    display: grid;
    align-content: start;
    gap: 8px;
}

.admin-tab {
    height: 44px;
    border: 1px solid #3f4350;
    border-radius: 8px;
    background: #202229;
    color: #d7d7dc;
    cursor: pointer;
    font: inherit;
    font-size: 15px;
    font-weight: 700;
    text-align: left;
    padding: 0 14px;
}

.admin-tab:hover,
.admin-tab.is-active {
    border-color: #335fff;
    background: #335fff;
    color: #fff;
}

.admin-workspace {
    min-width: 0;
}

.admin-tab-panel {
    display: none;
}

.admin-tab-panel.is-active {
    display: block;
}

.admin-note {
    margin: 10px 0 22px;
    color: #d7d7dc;
    line-height: 1.4em;
}

.admin-login-form {
    display: grid;
    gap: 8px;
}

.admin-current-profile {
    margin-bottom: 18px;
    padding: 14px;
    border: 1px solid #494d5a;
    border-radius: 8px;
    background: rgba(18, 18, 21, 0.28);
}

.admin-current-open {
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: #335fff;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    padding: 0 14px;
    text-decoration: none;
}

.admin-current-open:hover {
    background: #426bff;
}

.admin-private-server {
    margin-bottom: 18px;
    padding: 14px;
    border: 1px solid #494d5a;
    border-radius: 8px;
    background: rgba(18, 18, 21, 0.28);
}

.admin-section-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.admin-section-title-row h2 {
    margin: 0;
    padding: 0;
    color: #f7f7f8;
    font-size: 20px;
    font-weight: 800;
    line-height: 1.2;
}

.admin-private-open {
    color: #8fb0ff;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
}

.admin-private-open:hover {
    text-decoration: underline;
}

.admin-private-preview {
    margin-bottom: 14px;
}

.admin-private-server-form {
    display: grid;
    gap: 12px;
}

.admin-private-layout {
    display: grid;
    grid-template-columns: minmax(250px, 0.78fr) minmax(0, 1fr);
    gap: 14px;
}

.admin-private-list-panel {
    min-width: 0;
}

.admin-private-list {
    display: grid;
    gap: 10px;
}

.admin-private-empty {
    min-height: 110px;
    display: grid;
    place-items: center;
    border: 1px dashed #494d5a;
    border-radius: 8px;
    color: #b8bbc8;
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    padding: 14px;
}

.admin-private-card {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    border: 1px solid #494d5a;
    border-radius: 8px;
    background: rgba(18, 18, 21, 0.28);
    padding: 10px;
}

.admin-private-card.is-active {
    border-color: #335fff;
}

.admin-private-card img {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: #343740;
    object-fit: cover;
}

.admin-private-card strong,
.admin-private-card span,
.admin-private-card small {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-private-card span {
    color: #f7f7f8;
    font-size: 13px;
}

.admin-private-card small {
    color: #b8bbc8;
}

.admin-private-actions {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.admin-private-actions button {
    height: 32px;
    border: 1px solid #494d5a;
    border-radius: 8px;
    background: transparent;
    color: #d7d7dc;
    cursor: pointer;
    font: inherit;
    font-size: 13px;
    font-weight: 700;
}

.admin-private-actions button:hover {
    border-color: #d7d7dc;
    color: #fff;
}

.admin-new-private {
    width: 100%;
    height: 40px;
    margin-top: 10px;
}

.admin-private-editor-title {
    margin: 0;
    padding: 0;
    color: #f7f7f8;
    font-size: 18px;
    font-weight: 800;
    line-height: 1.2;
}

.admin-private-server-form label {
    display: block;
    color: #f7f7f8;
    font-size: 14px;
    font-weight: 700;
}

.admin-private-server-form .admin-input {
    width: 100%;
    margin-top: 8px;
}

.admin-save-private {
    width: 190px;
    height: 40px;
}

.admin-count-edit-form {
    display: grid;
    gap: 12px;
}

.admin-save-counts {
    height: 40px;
    width: 150px;
}

.admin-copy-form label {
    display: block;
    margin-bottom: 8px;
    color: #f7f7f8;
    font-size: 14px;
    font-weight: 700;
}

.admin-login-form label {
    color: #f7f7f8;
    font-size: 14px;
    font-weight: 700;
}

.admin-form-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 110px;
    gap: 10px;
}

.admin-count-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 12px;
}

.admin-count-grid label {
    margin-bottom: 0;
}

.admin-count-grid .admin-input {
    width: 100%;
    margin-top: 8px;
}

.admin-input {
    height: 40px;
    border: 1px solid #494d5a;
    border-radius: 8px;
    outline: none;
    background: #343740;
    color: #f7f7f8;
    font: inherit;
    padding: 0 12px;
}

.admin-submit {
    border: 0;
    border-radius: 8px;
    background: #335fff;
    color: #fff;
    font: inherit;
    font-weight: 700;
}

.admin-login-submit {
    height: 40px;
    margin-top: 8px;
}

.admin-logout {
    border: 1px solid #494d5a;
    border-radius: 8px;
    background: transparent;
    color: #d7d7dc;
    font: inherit;
    font-size: 14px;
    font-weight: 700;
    padding: 8px 12px;
}

.admin-status {
    min-height: 22px;
    margin-top: 14px;
    color: #d7d7dc;
}

.admin-status.is-error {
    color: #ff8d8d;
}

.admin-login-status {
    min-height: 22px;
    margin-top: 14px;
    color: #d7d7dc;
}

.admin-login-status.is-error {
    color: #ff8d8d;
}

.admin-result {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid #494d5a;
}

.admin-profile-preview {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
}

.admin-profile-preview img {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: #343740;
}

.admin-profile-preview strong,
.admin-profile-preview span,
.admin-profile-preview small {
    display: block;
}

.admin-profile-preview small {
    color: #b8bbc8;
}

.admin-profile-link {
    display: inline-flex;
    margin-right: 12px;
    color: #8fb0ff;
    font-weight: 700;
}

.admin-profile-link.muted {
    color: #d7d7dc;
}

@media (max-width: 760px) {
    .topbar {
        padding-right: 20px;
    }

    .brand {
        width: auto;
        margin-right: 10px;
    }

    .brand-logo {
        width: 108px;
    }

    .main-nav {
        display: none;
    }

    .search {
        width: auto;
        max-width: none;
        min-width: 120px;
        flex: 1 1 auto;
    }

    .signup {
        min-width: 70px;
        margin-left: 0;
        padding: 0 10px;
        font-size: 14px;
    }

    main {
        padding: 32px 12px;
    }

    .login-card {
        width: 100%;
    }

    h1 {
        font-size: 28px;
    }

    .footer .footer-links {
        justify-content: center;
    }

    .copyright-container .footer-note {
        margin-left: 0;
        text-align: center;
    }

    .header-login {
        display: none;
    }

    .profile-main {
        padding: 0 12px 40px;
    }

    .profile-hero {
        min-height: 220px;
    }

    .profile-avatar-full {
        width: 170px;
        height: 170px;
    }

    .profile-name-row {
        grid-template-columns: 82px minmax(0, 1fr);
    }

    .profile-headshot-wrap {
        width: 82px;
        height: 82px;
    }

    .profile-headshot {
        width: 82px;
        height: 82px;
    }

    .profile-ingame-badge {
        width: 24px;
        height: 24px;
        right: -1px;
        bottom: 2px;
    }

    .profile-title-block h1 {
        font-size: 24px;
    }

    .profile-actions {
        grid-column: 1 / -1;
        grid-template-columns: 1fr 42px;
    }

    .creations-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .experience-row {
        grid-template-columns: 1fr;
    }

    .experience-preview {
        height: auto;
        aspect-ratio: 1.6;
    }

    .experience-description {
        margin-bottom: 24px;
    }

    .wearing-image-wrap,
    .creation-image-wrap {
        width: 100%;
        height: auto;
        aspect-ratio: 1;
    }

    .admin-form-row {
        grid-template-columns: 1fr;
    }

    .admin-count-grid {
        grid-template-columns: 1fr;
    }

    .admin-dashboard {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        grid-template-columns: 1fr 1fr;
    }

    .admin-tab {
        text-align: center;
        padding: 0 8px;
    }

    .admin-private-layout {
        grid-template-columns: 1fr;
    }

    .admin-save-counts {
        width: 100%;
    }

    .game-main {
        padding: 24px 12px 32px;
    }

    .game-overview {
        grid-template-columns: 1fr;
    }

    .game-side-panel {
        min-height: 0;
    }

    .game-title-container h1 {
        font-size: 26px;
    }

    .game-play-button {
        margin-top: 18px;
    }

    .game-actions-row {
        grid-template-columns: 1fr;
    }

    .game-tabs-line {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .game-server-grid {
        grid-template-columns: 1fr;
    }

    .private-server-heading-row {
        grid-template-columns: 1fr;
    }

    .private-server-controls {
        justify-items: start;
    }

    .private-server-card {
        grid-template-columns: 1fr;
    }

    .private-server-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .private-server-info {
        border-right: 0;
        padding-right: 0;
    }

    .game-events-grid,
    .game-recommendations-grid {
        grid-template-columns: 1fr 1fr;
    }

    .game-stat-container {
        grid-template-columns: 1fr 1fr;
    }

    .game-badge-row {
        grid-template-columns: 1fr;
        gap: 12px;
    }

    .game-badge-image {
        margin: 0 auto;
    }

    .game-badge-content p {
        margin-bottom: 18px;
    }

    .game-badge-stats {
        grid-template-columns: 1fr;
    }

    .admin-save-private {
        width: 100%;
    }
}

@media (max-width: 520px) {
    .private-server-list {
        grid-template-columns: 1fr;
    }
}

.admin-proxy-form {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}

.admin-proxy-form .admin-count-grid {
  gap: 10px;
}

.admin-proxy-list {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.admin-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.admin-stat-card {
  background: #1a1a1a;
  border: 1px solid #333;
  border-radius: 8px;
  padding: 16px;
  text-align: center;
}
.admin-stat-card strong {
  display: block;
  font-size: 28px;
  color: #00ff88;
  margin-bottom: 4px;
}
.admin-stat-card span {
  color: #aaa;
  font-size: 13px;
}
.admin-stats-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 10px;
}
.admin-stats-table th,
.admin-stats-table td {
  padding: 10px;
  text-align: left;
  border-bottom: 1px solid #333;
}
.admin-stats-table th {
  color: #00ff88;
  font-size: 13px;
}

.loading-overlay {
    width: 100%;
    height: 36px;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
}

.loading-overlay[hidden] {
    display: none !important;
}

.loading-spinner {
    display: flex;
    gap: 6px;
    align-items: center;
    justify-content: center;
}

.loading-square {
    width: 12px;
    height: 12px;
    background: #555;
    border-radius: 2px;
    animation: squarePulse 1.2s infinite ease-in-out;
}

.loading-square:nth-child(1) {
    animation-delay: 0s;
}

.loading-square:nth-child(2) {
    animation-delay: 0.2s;
}

.loading-square:nth-child(3) {
    animation-delay: 0.4s;
}

@keyframes squarePulse {
    0%, 80%, 100% {
        background: #555;
        transform: scale(1);
    }
    40% {
        background: #fff;
        transform: scale(1.2);
    }
}

.verification-loading {
    width: 100%;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.verification-loading[hidden] {
    display: none !important;
}

.verification-error {
    color: #ff4444;
    font-size: 14px;
    margin: 4px 0 8px 0;
    text-align: center;
    min-height: 20px;
}

.verification-error[hidden] {
    display: none !important;
}

.login-error {
    color: #ff4444;
    font-size: 14px;
    margin: 4px 0 8px 0;
    text-align: center;
    min-height: 20px;
}
