body.identity-page,
body.subscription-auth-page,
body.admin-page {
    --tp-inner-surface: linear-gradient(135deg, rgb(var(--tp-surface-rgb) / 0.94) 0%, rgb(var(--tp-cream-rgb) / 0.96) 52%, rgb(var(--tp-deep-rgb) / 0.90) 100%);
    --tp-inner-surface-soft: linear-gradient(180deg, rgb(var(--tp-surface-rgb) / 0.90) 0%, rgb(var(--tp-cream-rgb) / 0.84) 100%);
    --tp-inner-fill: rgb(var(--tp-surface-rgb) / 0.82);
    --tp-inner-fill-soft: rgb(var(--tp-surface-rgb) / 0.70);
    --tp-inner-fill-strong: rgb(var(--tp-surface-rgb) / 0.94);
    --tp-inner-border: var(--tp-border);
    --tp-inner-border-strong: var(--tp-border-strong);
    --tp-inner-text: var(--tp-text-primary);
    --tp-inner-text-secondary: var(--tp-text-secondary);
    --tp-inner-text-muted: var(--tp-text-muted);
    --tp-inner-shadow: 0 22px 46px rgb(var(--tp-shadow-rgb) / 0.10);
    background: var(--tp-page-background);
    color: var(--tp-inner-text);
}

body.identity-page .main-container,
body.subscription-auth-page .main-container {
    max-width: 1120px;
    margin-top: clamp(1.5rem, 4vw, 2.5rem) !important;
    margin-bottom: 2.5rem !important;
}

body.identity-page .main-container > main,
body.subscription-auth-page .main-container > main {
    padding-bottom: 4rem;
}

.identity-shell {
    max-width: 980px;
    margin: 0 auto;
}

.identity-shell--narrow {
    max-width: 720px;
}

.identity-auth-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.82fr);
    gap: 1.25rem;
    align-items: start;
}

.identity-panel {
    position: relative;
    overflow: hidden;
    background: var(--tp-inner-surface);
    border: 1px solid var(--tp-inner-border);
    border-radius: 32px;
    box-shadow: var(--tp-inner-shadow);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    padding: clamp(1.75rem, 4vw, 3rem);
    color: var(--tp-inner-text);
}

.identity-panel::before,
.identity-panel::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.identity-panel::before {
    width: 18rem;
    height: 18rem;
    top: -7rem;
    right: -5rem;
    background: radial-gradient(circle, rgb(var(--tp-gold-rgb) / 0.12) 0%, transparent 70%);
}

.identity-panel::after {
    width: 14rem;
    height: 14rem;
    bottom: -8rem;
    left: -4rem;
    background: radial-gradient(circle, rgb(var(--tp-deep-rgb) / 0.48) 0%, transparent 70%);
}

.identity-panel > * {
    position: relative;
    z-index: 1;
}

.identity-panel--compact {
    padding: clamp(1.4rem, 3vw, 2.1rem);
}

.identity-panel--aside {
    background: var(--tp-inner-surface-soft);
}

.identity-eyebrow {
    font-size: 0.68rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--tp-gold);
    font-weight: 700;
    margin-bottom: 1rem;
}

.identity-title {
    font-size: clamp(2rem, 4vw, 3.35rem);
    font-weight: 300;
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: var(--tp-inner-text);
    margin: 0;
}

.identity-section-title {
    font-size: clamp(1.15rem, 2vw, 1.45rem);
    line-height: 1.3;
    color: var(--tp-inner-text);
    margin: 0;
}

.identity-subtitle {
    max-width: 60ch;
    margin: 1rem 0 0;
    font-size: 1rem;
    line-height: 1.75;
    color: var(--tp-inner-text-secondary);
}

.identity-note {
    margin: 1rem 0 0;
    line-height: 1.7;
    color: var(--tp-inner-text-secondary);
}

.identity-form-stack {
    margin-top: 1.5rem;
}

.identity-form-stack > * + * {
    margin-top: 1rem;
}

.identity-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem 1.2rem;
    margin-top: 1.4rem;
}

.identity-links a {
    text-decoration: none;
    font-weight: 600;
    color: var(--tp-inner-text);
}

.identity-links a:hover {
    color: var(--tp-link-hover);
}

.identity-external-actions {
    display: grid;
    gap: 0.75rem;
}

.identity-external-actions .btn {
    width: 100%;
}

.identity-manage-shell {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.identity-manage-grid {
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 1.5rem;
}

.identity-manage-nav {
    gap: 0.65rem;
}

.identity-manage-nav .nav-link {
    display: block;
    background: var(--tp-inner-fill-soft);
    border: 1px solid var(--tp-inner-border);
    color: var(--tp-inner-text);
    border-radius: 18px;
    padding: 0.9rem 1rem;
    font-weight: 600;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.identity-manage-nav .nav-link:hover,
.identity-manage-nav .nav-link:focus {
    background: rgb(var(--tp-surface-rgb) / 0.08);
    color: var(--tp-inner-text);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
    transform: translateY(-1px);
}

.identity-manage-nav .nav-link.active,
.identity-manage-nav .show > .nav-link {
    background: rgb(var(--tp-surface-rgb) / 0.14);
    border-color: var(--tp-inner-border-strong);
    color: var(--tp-inner-text);
    box-shadow: 0 16px 28px rgba(0, 0, 0, 0.2);
}

.identity-manage-content h4 {
    font-size: 1.35rem;
    line-height: 1.3;
    color: var(--tp-inner-text);
    margin: 0 0 1.25rem;
}

.identity-manage-content .row {
    row-gap: 1rem;
}

.identity-manage-content .form-group {
    margin-bottom: 1rem;
}

.identity-manage-content label {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 0.74rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--tp-inner-text-secondary);
    font-weight: 700;
}

body.identity-page .alert,
.identity-manage-content .alert,
body.subscription-auth-page .alert {
    background: var(--tp-inner-fill-soft);
    border: 1px solid var(--tp-inner-border);
    border-radius: 20px;
    color: var(--tp-inner-text);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.16);
}

body.identity-page .alert-danger,
.identity-manage-content .alert-danger,
body.subscription-auth-page .alert-danger {
    background: rgba(122, 45, 41, 0.22);
    border-color: rgba(255, 179, 171, 0.24);
    color: #ffb3ab;
}

body.identity-page .alert-info,
.identity-manage-content .alert-info,
body.subscription-auth-page .alert-info {
    background: rgba(18, 88, 137, 0.10);
    border-color: rgba(18, 88, 137, 0.22);
    color: var(--tp-text-primary);
}

body.identity-page .text-danger,
.identity-manage-content .text-danger,
body.subscription-auth-page .text-danger {
    color: #ffb3ab !important;
}

body.identity-page .form-control,
body.identity-page .form-select,
body.identity-page select.form-control,
body.identity-page select.form-select,
.identity-manage-content .form-control,
.identity-manage-content .form-select,
.identity-manage-content select.form-control,
.identity-manage-content select.form-select,
body.subscription-auth-page .form-control {
    background: var(--tp-inner-fill-soft);
    border: 1px solid var(--tp-inner-border-strong);
    color: var(--tp-inner-text);
    border-radius: 18px;
    padding: 0.85rem 1rem;
    box-shadow: inset 0 1px 0 rgb(var(--tp-surface-rgb) / 0.08);
}

.floating-label-group .form-control::placeholder {
    color: transparent;
}

body.identity-page .form-control:focus,
body.identity-page .form-select:focus,
body.identity-page select.form-control:focus,
body.identity-page select.form-select:focus,
.identity-manage-content .form-control:focus,
.identity-manage-content .form-select:focus,
.identity-manage-content select.form-control:focus,
.identity-manage-content select.form-select:focus,
body.subscription-auth-page .form-control:focus {
    border-color: var(--tp-gold);
    box-shadow: 0 0 0 0.2rem rgb(var(--tp-gold-rgb) / 0.18);
}

body.identity-page .form-control[disabled],
body.identity-page .form-control[readonly],
.identity-manage-content .form-control[disabled],
.identity-manage-content .form-control[readonly],
body.subscription-auth-page .form-control[disabled],
body.subscription-auth-page .form-control[readonly] {
    background: var(--tp-inner-fill);
    color: var(--tp-inner-text-secondary);
}

body.identity-page main .btn,
.identity-manage-content .btn,
body.subscription-auth-page main .btn,
body.subscription-auth-page .btncustom,
body.subscription-auth-page .btn2 {
    border-radius: 999px;
    padding: 0.85rem 1.25rem;
    font-weight: 600;
    border: 1px solid transparent;
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

body.identity-page main .btn:hover,
.identity-manage-content .btn:hover,
body.subscription-auth-page main .btn:hover,
body.subscription-auth-page .btncustom:hover,
body.subscription-auth-page .btn2:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.24);
}

body.identity-page main .btn-primary,
.identity-manage-content .btn-primary,
body.subscription-auth-page .btn-gift,
body.subscription-auth-page .btncustom {
    background: linear-gradient(180deg, var(--tp-slate) 0%, var(--tp-gold) 100%);
    border-color: var(--tp-gold);
    color: var(--tp-ivory);
}

body.identity-page main .btn-primary:hover,
.identity-manage-content .btn-primary:hover,
body.subscription-auth-page .btn-gift:hover,
body.subscription-auth-page .btncustom:hover {
    background: linear-gradient(180deg, var(--tp-gold) 0%, var(--tp-gold-light) 100%);
    border-color: var(--tp-gold-light);
    color: var(--tp-ivory);
}

body.identity-page main .btn-outline-primary,
.identity-manage-content .btn-outline-primary {
    background: transparent;
    border-color: var(--tp-inner-border-strong);
    color: var(--tp-inner-text);
}

body.identity-page main .btn-outline-primary:hover,
.identity-manage-content .btn-outline-primary:hover {
    background: rgb(var(--tp-surface-rgb) / 0.08);
    border-color: rgb(var(--tp-surface-rgb) / 0.24);
    color: var(--tp-inner-text);
}

body.identity-page main .btn-danger,
.identity-manage-content .btn-danger,
.identity-manage-content .btn-outline-danger,
body.subscription-auth-page .btn-reset,
body.subscription-auth-page .btn2 {
    background: #7a2d29;
    border-color: #7a2d29;
    color: var(--tp-ivory);
}

body.identity-page main .btn-danger:hover,
.identity-manage-content .btn-danger:hover,
.identity-manage-content .btn-outline-danger:hover,
body.subscription-auth-page .btn-reset:hover,
body.subscription-auth-page .btn2:hover {
    background: #5d1f1c;
    border-color: #5d1f1c;
    color: var(--tp-ivory);
}

body.identity-page main .btn-link,
.identity-manage-content .btn-link {
    color: var(--tp-inner-text-secondary);
    text-decoration: none;
    box-shadow: none;
    padding-left: 0;
    padding-right: 0;
}

body.identity-page main .btn-link:hover,
.identity-manage-content .btn-link:hover {
    color: var(--tp-inner-text);
    box-shadow: none;
}

.floating-label-group {
    position: relative;
    margin-bottom: 1rem;
}

.floating-label-group .form-control {
    min-height: 60px;
    padding-top: 1.35rem;
    padding-bottom: 0.55rem;
}

.floating-label-group .floating-label {
    position: absolute;
    top: 0.6rem;
    left: 1rem;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--tp-inner-text-muted);
    pointer-events: none;
    transition: color 0.2s ease;
}

.floating-label-group .form-control:focus + .floating-label,
.floating-label-group .form-control:not(:placeholder-shown) + .floating-label,
.floating-label-group .form-control[disabled] + .floating-label,
.floating-label-group .form-control[readonly] + .floating-label {
    color: var(--tp-inner-text-secondary);
}

body.identity-page .checkbox label,
body.identity-page .form-check-label {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    color: var(--tp-inner-text-secondary);
    font-weight: 500;
    text-transform: none;
    letter-spacing: normal;
    font-size: 0.95rem;
}

body.identity-page .form-check-input,
.identity-manage-content .form-check-input {
    border-color: var(--tp-inner-border-strong);
}

.identity-manage-content .input-group {
    align-items: stretch;
}

.identity-manage-content .input-group .form-control {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.identity-manage-content .input-group > .btn,
.identity-manage-content .input-group > .input-group-text {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    margin-left: -1px;
}

.identity-manage-content .input-group-text {
    background: var(--tp-inner-fill-soft);
    border: 1px solid var(--tp-inner-border-strong);
    color: var(--tp-inner-text-secondary);
}

.identity-manage-stack {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.identity-form-shell {
    max-width: 760px;
}

.identity-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.identity-actions .btn,
.identity-inline-actions .btn {
    margin: 0;
}

.identity-inline-actions {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.identity-callout {
    padding: 1.1rem 1.2rem;
    border-radius: 22px;
    border: 1px solid var(--tp-inner-border);
    background: var(--tp-inner-fill-soft);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.14);
}

.identity-callout > :last-child {
    margin-bottom: 0;
}

.identity-callout--danger {
    background: rgba(122, 45, 41, 0.08);
    border-color: rgba(122, 45, 41, 0.16);
}

.identity-callout--warning {
    background: rgba(188, 134, 44, 0.10);
    border-color: rgba(188, 134, 44, 0.18);
}

.identity-callout--info {
    background: rgba(18, 88, 137, 0.08);
    border-color: rgba(18, 88, 137, 0.18);
}

.identity-detail-list {
    display: grid;
    gap: 0.9rem;
}

.identity-detail-list > div {
    padding: 1rem 1.1rem;
    border-radius: 18px;
    border: 1px solid var(--tp-inner-border);
    background: var(--tp-inner-fill-soft);
}

.identity-detail-list dt {
    margin: 0 0 0.25rem;
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--tp-inner-text-secondary);
    font-weight: 700;
}

.identity-detail-list dd {
    margin: 0;
    color: var(--tp-inner-text);
}

.identity-note-list,
.identity-helper-list {
    margin: 0;
    padding-left: 1.2rem;
    color: var(--tp-inner-text-secondary);
    line-height: 1.75;
}

.identity-code-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 0.85rem;
}

.identity-code-chip,
code.recovery-code {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0.85rem 1rem;
    border-radius: 16px;
    background: var(--tp-slate);
    color: var(--tp-ivory);
    font-size: 0.95rem;
    letter-spacing: 0.08em;
}

.identity-table-wrap {
    overflow: hidden;
    border-radius: 20px;
    border: 1px solid var(--tp-inner-border);
    background: var(--tp-inner-fill-soft);
}

.identity-table-wrap .table {
    margin-bottom: 0;
}

.identity-qr-shell {
    display: grid;
    gap: 1rem;
    justify-items: start;
}

.identity-qr-code {
    display: inline-flex;
    padding: 1rem;
    border-radius: 24px;
    background: rgb(var(--tp-surface-rgb) / 0.92);
    border: 1px solid var(--tp-border);
    box-shadow: 0 16px 34px rgb(var(--tp-shadow-rgb) / 0.10);
}

.identity-avatar-panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.identity-avatar-frame {
    width: min(100%, 350px);
    aspect-ratio: 1;
    border-radius: 28px;
    overflow: hidden;
    border: 1px solid var(--tp-inner-border);
    background: var(--tp-inner-fill-soft);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
}

.identity-avatar-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.identity-link-button {
    white-space: nowrap;
}

body.identity-page .btn-default,
.identity-manage-content .btn-default,
body.admin-page .btn-default {
    background: transparent;
    border-color: var(--tp-inner-border-strong);
    color: var(--tp-inner-text);
}

body.identity-page .btn-default:hover,
.identity-manage-content .btn-default:hover,
body.admin-page .btn-default:hover {
    background: rgb(var(--tp-surface-rgb) / 0.08);
    border-color: rgb(var(--tp-surface-rgb) / 0.24);
    color: var(--tp-inner-text);
}

body.admin-page .main-container {
    max-width: 1280px;
    margin-top: clamp(1.5rem, 4vw, 2.5rem) !important;
    margin-bottom: 3rem !important;
}

body.admin-page .main-container > main {
    padding-bottom: 4rem;
}

body.admin-page .container,
body.admin-page .container-fluid {
    padding-left: 0;
    padding-right: 0;
}

body.admin-page .card,
body.admin-page .subscription-auth-card {
    background: var(--tp-inner-surface) !important;
    border: 1px solid var(--tp-inner-border) !important;
    border-radius: 28px !important;
    box-shadow: var(--tp-inner-shadow) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    overflow: hidden;
}

body.admin-page .card-header {
    background: var(--tp-inner-fill-soft) !important;
    border-bottom: 1px solid var(--tp-inner-border) !important;
    padding: 1rem 1.25rem;
}

body.admin-page .card-body,
body.admin-page .card-footer {
    color: var(--tp-inner-text);
}

body.admin-page .table {
    --bs-table-bg: transparent;
    --bs-table-accent-bg: transparent;
    --bs-table-striped-bg: rgb(var(--tp-surface-rgb) / 0.04);
    --bs-table-hover-bg: rgb(var(--tp-surface-rgb) / 0.08);
    color: var(--tp-inner-text-secondary);
}

body.admin-page .table > :not(caption) > * > * {
    padding: 0.95rem 1rem;
    border-bottom-color: rgb(var(--tp-gold-rgb) / 0.10);
    vertical-align: middle;
}

body.admin-page .table thead th,
body.admin-page .table-dark th,
body.admin-page .thead-light th {
    background: var(--tp-slate) !important;
    color: var(--tp-ivory) !important;
    border-bottom: none;
    font-size: 0.76rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 600;
}

body.admin-page .table-borderless > :not(caption) > * > * {
    border-bottom-width: 0;
}

body.admin-page .form-control,
body.admin-page .form-select,
body.admin-page select.form-control,
body.admin-page select.form-select,
body.admin-page textarea.form-control,
body.admin-page textarea {
    background: var(--tp-inner-fill-soft);
    border: 1px solid var(--tp-inner-border-strong);
    color: var(--tp-inner-text);
    border-radius: 18px;
    padding: 0.85rem 1rem;
    box-shadow: inset 0 1px 0 rgb(var(--tp-surface-rgb) / 0.08);
}

body.admin-page .form-control:focus,
body.admin-page .form-select:focus,
body.admin-page textarea.form-control:focus,
body.admin-page textarea:focus {
    border-color: var(--tp-gold);
    box-shadow: 0 0 0 0.2rem rgb(var(--tp-gold-rgb) / 0.12);
}

body.admin-page .form-group {
    margin-bottom: 1rem;
}

body.admin-page label,
body.admin-page .form-label {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 0.74rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--tp-inner-text-secondary);
    font-weight: 700;
}

body.admin-page .btn,
body.admin-page .btncustom2 {
    border-radius: 999px;
    padding: 0.8rem 1.2rem;
    font-weight: 600;
    border: 1px solid transparent;
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
    transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

body.admin-page .btn:hover,
body.admin-page .btncustom2:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.24);
}

body.admin-page .btn-primary,
body.admin-page .btn-info,
body.admin-page .btncustom2 {
    background: linear-gradient(180deg, var(--tp-slate) 0%, var(--tp-gold) 100%);
    border-color: var(--tp-gold);
    color: var(--tp-ivory);
}

body.admin-page .btn-primary:hover,
body.admin-page .btn-info:hover,
body.admin-page .btncustom2:hover {
    background: linear-gradient(180deg, var(--tp-gold) 0%, var(--tp-gold-light) 100%);
    border-color: var(--tp-gold-light);
    color: var(--tp-ivory);
}

body.admin-page .btn-secondary,
body.admin-page .btn-outline-secondary,
body.admin-page .btn-outline-info,
body.admin-page .btn-outline-success {
    background: transparent;
    border-color: var(--tp-inner-border-strong);
    color: var(--tp-inner-text);
}

body.admin-page .btn-secondary:hover,
body.admin-page .btn-outline-secondary:hover,
body.admin-page .btn-outline-info:hover,
body.admin-page .btn-outline-success:hover {
    background: rgb(var(--tp-surface-rgb) / 0.08);
    border-color: rgb(var(--tp-surface-rgb) / 0.24);
    color: var(--tp-inner-text);
}

body.admin-page .btn-danger {
    background: #7a2d29;
    border-color: #7a2d29;
    color: var(--tp-ivory);
}

body.admin-page .btn-danger:hover {
    background: #5d1f1c;
    border-color: #5d1f1c;
    color: var(--tp-ivory);
}

body.admin-page .btn-link {
    color: var(--tp-inner-text-secondary);
    box-shadow: none;
    text-decoration: none;
}

body.admin-page .btn-link:hover {
    color: var(--tp-inner-text);
    box-shadow: none;
}

body.admin-page .btn-block {
    display: inline-flex;
    width: 100%;
    justify-content: center;
}

body.admin-page .alert {
    background: var(--tp-inner-fill-soft);
    border: 1px solid var(--tp-inner-border);
    border-radius: 20px;
    color: var(--tp-inner-text);
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.16);
}

body.admin-page .alert-success {
    background: rgba(23, 92, 60, 0.10);
    border-color: rgba(23, 92, 60, 0.18);
    color: #175c3c;
}

body.admin-page .alert-danger {
    background: rgba(122, 45, 41, 0.10);
    border-color: rgba(122, 45, 41, 0.20);
    color: #7a2d29;
}

body.admin-page .alert-warning {
    background: rgba(188, 134, 44, 0.10);
    border-color: rgba(188, 134, 44, 0.20);
    color: #8a6123;
}

body.admin-page .alert-info {
    background: rgba(18, 88, 137, 0.10);
    border-color: rgba(18, 88, 137, 0.20);
    color: #125889;
}

body.admin-page .badge,
body.admin-page .badge-success,
body.admin-page .badge-danger,
body.admin-page .badge-warning,
body.admin-page .badge-secondary,
body.admin-page .badge-info,
body.admin-page .badge-primary,
body.admin-page .badge-light,
body.admin-page .bg-primary,
body.admin-page .bg-success,
body.admin-page .bg-danger,
body.admin-page .bg-warning,
body.admin-page .bg-secondary,
body.admin-page .bg-info,
body.admin-page .bg-light {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    font-weight: 700;
    letter-spacing: 0.04em;
}

body.admin-page .badge-primary,
body.admin-page .bg-primary {
    background: var(--tp-slate) !important;
    color: var(--tp-ivory) !important;
}

body.admin-page .badge-success,
body.admin-page .bg-success {
    background: #175c3c !important;
    color: #f6fff8 !important;
}

body.admin-page .badge-danger,
body.admin-page .bg-danger {
    background: #7a2d29 !important;
    color: var(--tp-ivory) !important;
}

body.admin-page .badge-warning,
body.admin-page .bg-warning {
    background: #c89a3d !important;
    color: #2f2205 !important;
}

body.admin-page .badge-secondary,
body.admin-page .bg-secondary {
    background: rgb(var(--tp-surface-rgb) / 0.12) !important;
    color: var(--tp-inner-text) !important;
}

body.admin-page .badge-info,
body.admin-page .bg-info {
    background: #125889 !important;
    color: #eff8ff !important;
}

body.admin-page .badge-light,
body.admin-page .bg-light {
    background: rgb(var(--tp-surface-rgb) / 0.12) !important;
    color: var(--tp-inner-text) !important;
    border: 1px solid var(--tp-inner-border);
}

body.admin-page .progress {
    background: rgb(var(--tp-slate-rgb) / 0.08);
    border-radius: 999px;
    overflow: hidden;
}

body.admin-page .progress-bar {
    border-radius: 999px;
}

body.admin-page pre {
    border-radius: 22px;
    border: 1px solid var(--tp-inner-border);
    background: var(--tp-inner-fill-soft) !important;
    color: var(--tp-inner-text);
}

body.identity-page .text-muted,
body.subscription-auth-page .text-muted,
body.admin-page .text-muted {
    color: var(--tp-inner-text-muted) !important;
}

body.admin-page code {
    color: #caecff;
}

body.admin-page .iframe-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid var(--tp-inner-border);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.18);
}

body.admin-page .iframe-container iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

body.admin-page textarea,
body.admin-page #htmlCodeTextArea,
body.admin-page #participateLink {
    width: 100%;
}

body.admin-page .collapse .card {
    box-shadow: none !important;
    border-radius: 22px !important;
}

body.admin-page .admin-page-shell {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

body.admin-page .admin-split-grid {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.admin-page .admin-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

body.admin-page .admin-stack {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

body.admin-page .admin-card-title {
    color: var(--tp-inner-text);
    font-weight: 600;
    letter-spacing: -0.02em;
}

body.admin-page .admin-card-subtitle {
    margin: 0.45rem 0 0;
    color: var(--tp-inner-text-muted);
}

body.admin-page .admin-html-preview {
    color: var(--tp-inner-text-secondary);
    white-space: pre-line;
}

body.admin-page .admin-detail-key {
    width: 40%;
}

body.admin-page .admin-detail-key-sm {
    width: 150px;
}

body.admin-page .admin-detail-key-md {
    width: 180px;
}

body.admin-page .admin-avatar {
    width: 40px;
    height: 40px;
    object-fit: cover;
    flex-shrink: 0;
}

body.admin-page .card-header.bg-light {
    background-color: rgb(var(--tp-surface-rgb) / 0.6) !important;
    color: var(--tp-inner-text) !important;
}

body.admin-page .card-header.bg-light h6,
body.admin-page .card-header.bg-light .h6 {
    color: var(--tp-inner-text) !important;
}

body.admin-page code {
    color: var(--tp-inner-text) !important;
    background: rgb(var(--tp-surface-rgb) / 0.55);
    border: 1px solid var(--tp-inner-border);
    border-radius: 6px;
    padding: 0.15rem 0.4rem;
}

body.admin-page .admin-scroll-pre {
    max-height: 400px;
    overflow-y: auto;
}

body.admin-page .admin-progress-md {
    height: 1.25rem;
}

body.admin-page .admin-progress-lg {
    height: 2rem;
}

body.admin-page .admin-stat-card {
    text-align: center;
}

body.admin-page .admin-stat-label {
    display: block;
    margin-bottom: 0.75rem;
    font-size: 0.74rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--tp-inner-text-muted);
    font-weight: 700;
}

body.admin-page .admin-stat-value {
    color: var(--tp-inner-text);
    font-size: clamp(2.8rem, 7vw, 4.6rem);
    font-weight: 300;
    line-height: 1;
    letter-spacing: -0.05em;
}

body.admin-page .admin-empty-state {
    padding: clamp(1.5rem, 4vw, 2.5rem);
    text-align: center;
}

body.admin-page .admin-empty-state .fas {
    color: var(--tp-inner-text-muted);
}

body.admin-page .admin-list-centered {
    max-width: 600px;
    margin: 0 auto;
}

body.admin-page .admin-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

body.admin-page .admin-action-row > * {
    margin: 0;
}

@media (max-width: 991px) {
    body.admin-page .admin-split-grid {
        grid-template-columns: 1fr;
    }
}

.subscription-auth-shell {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.subscription-auth-container {
    max-width: 1040px;
    margin: 0 auto;
    padding: 0 0 4rem;
    color: var(--tp-inner-text);
}

.subscription-auth-hero {
    text-align: center;
}

.subscription-auth-card,
.subscription-auth-page .serial-container {
    background: var(--tp-inner-surface-soft) !important;
    border: 1px solid var(--tp-inner-border) !important;
    border-radius: 24px !important;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
    color: var(--tp-inner-text);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.subscription-auth-card:hover,
.subscription-auth-page .serial-container:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 48px rgba(0, 0, 0, 0.24);
}

.subscription-auth-page .serial-container h3,
.subscription-auth-page .subscription-upgrade-section h3 {
    color: var(--tp-inner-text);
    font-weight: 600;
    letter-spacing: -0.02em;
}

.subscription-auth-page .status-badge {
    padding: 0.55rem 1rem;
    border-radius: 999px;
    font-weight: 700;
    display: inline-block;
    font-size: 0.76rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.subscription-auth-page .status-active {
    background: #175c3c;
    color: #f6fff8;
}

.subscription-auth-page .status-inactive {
    background: rgb(var(--tp-surface-rgb) / 0.12);
    color: var(--tp-inner-text-secondary);
}

.subscription-auth-status-row {
    width: min(100%, 550px);
    margin: 0 auto 0.75rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.subscription-auth-email-row {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.subscription-auth-input {
    max-width: 400px;
}

.subscription-auth-note {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
    text-align: left;
}

.subscription-auth-legacy-card {
    background: linear-gradient(135deg, #96bf48 0%, #5f9025 100%);
    border-radius: 28px;
    border: none;
    color: #fff;
    padding: 1.5rem;
    box-shadow: 0 18px 42px rgba(45, 90, 25, 0.22);
}

.subscription-auth-legacy-card h5,
.subscription-auth-legacy-card p {
    color: inherit;
}

.subscription-auth-legacy-link {
    font-weight: 600;
}

.subscription-auth-upgrade {
    background: linear-gradient(135deg, var(--tp-slate) 0%, var(--tp-gold-light) 100%);
    border-radius: 28px;
    color: var(--tp-ivory);
    box-shadow: 0 18px 42px rgb(var(--tp-shadow-rgb) / 0.22);
}

.subscription-auth-upgrade h3,
.subscription-auth-upgrade p {
    color: inherit !important;
}

body.subscription-auth-page .modal {
    display: none;
    position: fixed;
    z-index: 1200;
    inset: 0;
    overflow: auto;
    padding-top: 8vh;
    background: rgb(var(--tp-shadow-rgb) / 0.56);
}

body.subscription-auth-page .modal-content {
    width: min(92vw, 540px);
    margin: auto;
    padding: 1.5rem;
    border-radius: 24px;
    border: 1px solid var(--tp-border);
    box-shadow: 0 24px 60px rgb(var(--tp-shadow-rgb) / 0.24);
    background: linear-gradient(180deg, rgb(var(--tp-surface-rgb) / 0.94), rgb(var(--tp-ivory-rgb) / 0.96));
    color: var(--tp-text-primary);
}

body.subscription-auth-page .modal-content p {
    margin-bottom: 1.25rem;
    line-height: 1.7;
}

@media (max-width: 991.98px) {
    .identity-auth-grid,
    .identity-manage-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .identity-panel {
        border-radius: 26px;
        padding: 1.4rem;
    }

    .identity-title {
        font-size: 2rem;
    }

    .identity-links {
        flex-direction: column;
        align-items: flex-start;
    }

    .subscription-auth-status-row,
    .subscription-auth-email-row {
        flex-direction: column;
        align-items: stretch;
    }

    .subscription-auth-input {
        max-width: 100%;
    }
}


