.airp-frontend-wrapper,
.airp-frontend-wrapper * {
    box-sizing: border-box;
}

:root {
    --airp-shortcode-z-index: auto;
    --airp-shortcode-overlay-z-index: 2147482999;
    --airp-modal-z-index: 2147483000;
    --airp-lightbox-z-index: 2147483001;
    --airp-scrollbar-size: 10px;
}

.airp-frontend-wrapper,
.airp-modal,
.airp-lightbox {
    scrollbar-width: thin;
    scrollbar-color: var(--airp-primary-color) var(--airp-chat-background-color);
}

.airp-frontend-wrapper *,
.airp-modal *,
.airp-lightbox * {
    scrollbar-width: thin;
    scrollbar-color: var(--airp-primary-color) var(--airp-chat-background-color);
}

.airp-frontend-wrapper::-webkit-scrollbar,
.airp-frontend-wrapper *::-webkit-scrollbar,
.airp-modal::-webkit-scrollbar,
.airp-modal *::-webkit-scrollbar,
.airp-lightbox::-webkit-scrollbar,
.airp-lightbox *::-webkit-scrollbar {
    width: var(--airp-scrollbar-size);
    height: var(--airp-scrollbar-size);
}

.airp-frontend-wrapper::-webkit-scrollbar-track,
.airp-frontend-wrapper *::-webkit-scrollbar-track,
.airp-modal::-webkit-scrollbar-track,
.airp-modal *::-webkit-scrollbar-track,
.airp-lightbox::-webkit-scrollbar-track,
.airp-lightbox *::-webkit-scrollbar-track {
    border-radius: 999px;
    background: var(--airp-chat-background-color);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--airp-border-color) 35%, transparent);
}

.airp-frontend-wrapper::-webkit-scrollbar-thumb,
.airp-frontend-wrapper *::-webkit-scrollbar-thumb,
.airp-modal::-webkit-scrollbar-thumb,
.airp-modal *::-webkit-scrollbar-thumb,
.airp-lightbox::-webkit-scrollbar-thumb,
.airp-lightbox *::-webkit-scrollbar-thumb {
    border: 2px solid var(--airp-chat-background-color);
    border-radius: 999px;
    background: linear-gradient(180deg, var(--airp-primary-color), var(--airp-secondary-color));
}

.airp-frontend-wrapper::-webkit-scrollbar-thumb:hover,
.airp-frontend-wrapper *::-webkit-scrollbar-thumb:hover,
.airp-modal::-webkit-scrollbar-thumb:hover,
.airp-modal *::-webkit-scrollbar-thumb:hover,
.airp-lightbox::-webkit-scrollbar-thumb:hover,
.airp-lightbox *::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, var(--airp-title-color), var(--airp-primary-color));
}

.airp-frontend-wrapper [hidden] {
    display: none !important;
}

.airp-frontend-wrapper {
    position: relative;
    z-index: var(--airp-shortcode-z-index);
    isolation: auto;
    max-width: var(--airp-max-width);
    margin: 0 auto;
    padding: var(--airp-general-padding);
    color: var(--airp-text-color);
    font-family: var(--airp-font-family);
    font-size: var(--airp-text-size);
    line-height: var(--airp-line-height);
}

.airp-frontend-wrapper.airp-has-open-modal,
.airp-frontend-wrapper:has(.airp-modal.is-open) {
    z-index: var(--airp-shortcode-overlay-z-index);
}

.airp-card,
.airp-panel,
.airp-game-wrapper {
    background: var(--airp-panel-background-color);
    border: 1px solid var(--airp-border-color);
    border-radius: var(--airp-border-radius);
    padding: var(--airp-general-padding);
    color: var(--airp-text-color);
}

.airp-section-title,
.airp-game-title,
.airp-card-title,
.airp-panel-title {
    margin: 0 0 10px;
    color: var(--airp-title-color);
    font-size: var(--airp-title-size);
    line-height: 1.25;
}

.airp-section-subtitle,
.airp-game-meta,
.airp-campaign-item-meta,
.airp-empty-state,
.airp-login-required-text {
    color: var(--airp-muted-text-color);
}

.airp-two-columns,
.airp-campaigns-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.8fr);
    gap: var(--airp-element-gap);
    align-items: start;
}

.airp-campaigns-layout-full {
    grid-template-columns: minmax(0, 1fr);
}

.airp-campaigns-header {
    text-align: center;
}

.airp-campaigns-title {
    font-family: "Cinzel", Georgia, serif;
    text-transform: uppercase;
}

.airp-form,
.airp-chat-input-wrapper {
    display: grid;
    gap: 10px;
}

.airp-label {
    display: block;
    color: var(--airp-text-color);
    font-weight: 700;
}

.airp-campaign-option {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 12px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
}

.airp-campaign-option input {
    margin-top: 3px;
}

.airp-campaign-option strong,
.airp-campaign-option small {
    display: block;
}

.airp-campaign-option small {
    margin-top: 3px;
    color: var(--airp-muted-text-color);
    line-height: 1.4;
}

.airp-referee-mode-field {
    display: grid;
    gap: 8px;
}

.airp-referee-mode-options {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.airp-referee-mode-option {
    display: grid;
    gap: 7px;
    align-content: start;
    min-height: 168px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 10px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    cursor: pointer;
}

.airp-referee-mode-option input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.airp-referee-mode-icon {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 800;
    line-height: 38px;
}

.airp-referee-mode-free .airp-referee-mode-icon {
    background: #1f9d55;
}

.airp-referee-mode-light .airp-referee-mode-icon {
    background: #c28a00;
}

.airp-referee-mode-heavy .airp-referee-mode-icon {
    background: #c24135;
}

.airp-referee-mode-option strong,
.airp-referee-mode-option small {
    display: block;
}

.airp-referee-mode-option small {
    color: var(--airp-muted-text-color);
    line-height: 1.42;
}

.airp-referee-mode-option:has(input:checked) {
    border-color: var(--airp-accent-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 22%, transparent);
}

.airp-referee-mode-option input:checked + .airp-referee-mode-icon {
    outline: 3px solid var(--airp-accent-color);
    outline-offset: 2px;
}

.airp-input,
.airp-textarea,
.airp-chat-textarea {
    width: 100%;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
    color: var(--airp-text-color);
    padding: 12px;
    font-family: var(--airp-font-family);
    font-size: var(--airp-text-size);
}

.airp-input::placeholder,
.airp-textarea::placeholder,
.airp-chat-textarea::placeholder {
    color: var(--airp-muted-text-color);
}

.airp-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 1px solid transparent;
    border-radius: calc(var(--airp-border-radius) / 2);
    padding: 11px 10px;
    font-family: "Cinzel", Georgia, serif;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.airp-button:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.airp-button-label-mobile {
    display: none;
}

.airp-button-primary {
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
}

.airp-button-secondary {
    background: var(--airp-secondary-color);
    border-color: var(--airp-border-color);
    color: var(--airp-button-text-color);
}

.airp-generated-image-step {
    display: grid;
    gap: 12px;
}

.airp-generated-image-preview {
    display: grid;
    place-items: center;
    width: min(100%, 520px);
    aspect-ratio: 1;
    margin: 0 auto;
    overflow: hidden;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
}

.airp-generated-image-preview .airp-lightbox-image {
    display: block;
    width: 100%;
    height: 100%;
    max-height: none;
    margin-bottom: 0;
    border: 0;
    border-radius: 0;
    object-fit: cover;
}

.airp-generated-image-status {
    margin: 0;
    color: var(--airp-muted-text-color);
    font-weight: 700;
}

.airp-generated-image-status.is-error {
    color: var(--airp-danger-color);
}

.airp-button-danger {
    border-color: var(--airp-danger-color);
    background: color-mix(in srgb, var(--airp-danger-color) 10%, var(--airp-surface-color));
    color: var(--airp-danger-color);
}

.airp-offgame-chat-button.is-unread {
    border-color: var(--airp-danger-color);
    background: var(--airp-danger-color);
    color: var(--airp-button-text-color);
}

.airp-button-disabled {
    opacity: 0.65;
    cursor: wait;
}

.airp-button.is-loading {
    min-width: 54px;
    pointer-events: none;
}

.airp-button-spinner {
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 999px;
    animation: airp-spin 0.8s linear infinite;
}

@keyframes airp-spin {
    to {
        transform: rotate(360deg);
    }
}

.airp-link-card,
.airp-campaign-item {
    display: block;
    padding: 10px 12px;
    margin-bottom: 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
    color: var(--airp-text-color);
    text-decoration: none;
}

.airp-campaigns-list-header {
    margin-bottom: 12px;
}

.airp-campaigns-list-header .airp-card-title {
    margin-bottom: 0;
}

.airp-campaigns-list-actions {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: center;
    gap: 8px;
    width: 100%;
}

.airp-campaigns-list-actions .airp-button {
    justify-content: center;
    min-width: 0;
    min-height: 44px;
    padding: 8px 10px;
    text-align: center;
    text-transform: uppercase;
    white-space: normal;
}

.airp-turn-notifications-button {
    width: 100%;
    justify-content: center;
}

.airp-campaigns-list-actions .airp-turn-notifications-button {
    grid-column: 1 / -1;
}

.airp-campaign-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 12px;
}

.airp-campaign-tab {
    display: grid;
    gap: 2px;
    min-width: 0;
    min-height: 58px;
    padding: 9px 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
    color: var(--airp-muted-text-color);
    cursor: pointer;
    font: inherit;
    text-align: center;
}

.airp-campaign-tab.is-active {
    border-color: var(--airp-accent-color);
    background: color-mix(in srgb, var(--airp-accent-color) 12%, var(--airp-chat-background-color));
    color: var(--airp-title-color);
}

.airp-campaign-tab-label {
    font-size: 0.95em;
    font-weight: 850;
    line-height: 1.15;
    text-transform: uppercase;
}

.airp-campaign-tab-hint {
    color: var(--airp-muted-text-color);
    font-size: 0.78em;
    font-weight: 650;
    line-height: 1.2;
}

.airp-campaign-tab-panel[hidden] {
    display: none;
}

.airp-campaign-item-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.airp-campaign-item-link {
    display: block;
    flex: 1 1 auto;
    min-width: 0;
    color: inherit;
    text-decoration: none;
}

.airp-campaign-item-summary {
    display: grid;
    gap: 5px;
    min-width: 0;
}

.airp-campaign-item-summary .airp-campaign-item-title {
    min-width: 0;
    color: var(--airp-title-color);
    font-size: 1.02em;
    font-weight: 850;
    line-height: 1.2;
}

.airp-campaign-item-summary .airp-campaign-item-meta {
    display: grid;
    gap: 3px;
    margin-top: 0;
    color: var(--airp-muted-text-color);
    font-size: 0.9em;
    line-height: 1.35;
}

.airp-campaign-item-summary .airp-campaign-item-meta span {
    display: block;
}

.airp-campaign-item-summary .airp-campaign-item-meta strong {
    color: var(--airp-text-color);
    font-weight: 800;
}

.airp-campaign-item-summary .airp-campaign-item-meta .airp-campaign-referee-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

.airp-campaign-item-summary .airp-campaign-item-meta .airp-referee-badge {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    padding: 2px 8px;
    border-radius: 999px;
    color: #fff;
    font-size: 0.86em;
    font-weight: 850;
    line-height: 1;
}

.airp-referee-badge-free {
    background: #16803a;
}

.airp-referee-badge-light {
    background: #b77905;
}

.airp-referee-badge-heavy {
    background: #b42318;
}

.airp-campaign-item-title {
    display: block;
    font-weight: 800;
}

.airp-campaign-item-meta {
    display: block;
    margin-top: 4px;
    font-size: 0.92em;
}

.airp-campaign-create-dialog {
    width: min(100%, 980px);
}

.airp-campaign-wizard {
    gap: 14px;
}

.airp-wizard-steps {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
}

.airp-wizard-steps-six {
    grid-template-columns: repeat(6, 1fr);
}

.airp-wizard-steps-seven {
    grid-template-columns: repeat(7, 1fr);
}

.airp-wizard-steps span {
    display: grid;
    place-items: center;
    min-height: 34px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
    color: var(--airp-muted-text-color);
    font-weight: 800;
    min-width: 0;
}

.airp-wizard-steps span.is-active,
.airp-wizard-steps span.is-complete {
    border-color: var(--airp-accent-color);
    color: var(--airp-text-color);
}

.airp-wizard-panel {
    display: none;
    gap: 10px;
}

.airp-wizard-panel.is-active {
    display: grid;
}

.airp-wizard-panel h4 {
    margin: 0 0 4px;
    color: var(--airp-heading-color);
    font-size: 1.05rem;
}

.airp-panel-subtitle {
    margin: 12px 0 8px;
    color: var(--airp-heading-color);
    font-size: 0.98rem;
}

.airp-wizard-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 4px;
}

.airp-campaign-mode-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.airp-model-choice-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.airp-model-choice-card {
    display: grid;
    gap: 8px;
    align-content: start;
    min-height: 180px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 12px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    cursor: pointer;
}

.airp-model-choice-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.airp-model-choice-card:has(input:checked) {
    border-color: var(--airp-accent-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 22%, transparent);
}

.airp-model-choice-image {
    display: grid;
    place-items: center;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-surface-color) 86%, #000);
    color: var(--airp-accent-color);
}

.airp-model-choice-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.airp-model-choice-image .dashicons,
.airp-model-choice-plus {
    width: 42px;
    height: 42px;
    font-size: 42px;
}

.airp-model-choice-card strong,
.airp-model-choice-card small,
.airp-model-choice-card em {
    display: block;
}

.airp-model-choice-card strong {
    text-align: center;
}

.airp-model-choice-card small {
    color: var(--airp-muted-text-color);
    line-height: 1.35;
}

.airp-model-choice-card em {
    justify-self: center;
    border: 1px solid color-mix(in srgb, var(--airp-accent-color) 38%, transparent);
    border-radius: 999px;
    padding: 2px 8px;
    color: var(--airp-accent-color);
    font-size: 0.78rem;
    font-style: normal;
    font-weight: 800;
}

.airp-model-description-link {
    justify-self: center;
    border: 0;
    padding: 0;
    background: transparent;
    color: var(--airp-accent-color);
    font: inherit;
    font-weight: 700;
    text-decoration: underline;
    cursor: pointer;
}

.airp-model-description-link:hover {
    color: var(--airp-title-color);
}

.airp-model-choice-custom {
    place-items: center;
    text-align: center;
}

.airp-model-choice-plus {
    color: var(--airp-accent-color);
}

.airp-custom-model-fields {
    display: grid;
    gap: 10px;
    margin-top: 4px;
}

.airp-setting-image-field {
    display: grid;
    gap: 8px;
}

.airp-setting-image-row {
    display: grid;
    grid-template-columns: minmax(150px, 190px) minmax(0, 1fr);
    gap: 12px;
    align-items: start;
}

.airp-setting-image-tile {
    min-height: 150px;
}

.airp-setting-cover-frame {
    display: grid;
    place-items: center;
    width: 100%;
    min-height: 130px;
}

.airp-setting-cover-frame img {
    width: 100%;
    height: 100%;
    min-height: 130px;
    object-fit: cover;
}

.airp-setting-image-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.airp-setting-image-actions .airp-help {
    flex-basis: 100%;
    margin: 0;
}

.airp-custom-archetype-mapping {
    display: grid;
    gap: 14px;
}

.airp-custom-archetype-section {
    display: grid;
    gap: 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 12px;
    background: color-mix(in srgb, var(--airp-surface-color) 92%, var(--airp-accent-color));
}

.airp-custom-archetype-section h5,
.airp-custom-archetype-mapping h5 {
    margin: 0;
    color: var(--airp-heading-color);
    font-size: 0.98rem;
}

.airp-custom-archetype-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.airp-custom-archetype-field {
    display: grid;
    gap: 5px;
}

.airp-campaign-mode-card {
    display: grid;
    gap: 6px;
    align-content: center;
    min-height: 150px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 16px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    cursor: pointer;
}

.airp-campaign-mode-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.airp-campaign-mode-card .dashicons {
    width: 42px;
    height: 42px;
    font-size: 42px;
    color: var(--airp-accent-color);
}

.airp-campaign-mode-card strong,
.airp-campaign-mode-card small {
    display: block;
}

.airp-campaign-mode-card small {
    color: var(--airp-muted-text-color);
    line-height: 1.35;
}

.airp-campaign-mode-card:has(input:checked) {
    border-color: var(--airp-accent-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 22%, transparent);
}

.airp-campaign-mode-card input:checked + .dashicons {
    filter: drop-shadow(0 0 6px color-mix(in srgb, var(--airp-accent-color) 45%, transparent));
}

.airp-feature-locked {
    border-color: #dc2626;
    color: var(--airp-text-color);
    cursor: not-allowed;
    opacity: 0.78;
}

.airp-feature-locked .dashicons,
.airp-feature-locked .airp-referee-mode-icon,
.airp-feature-locked .airp-model-choice-plus {
    color: #dc2626;
}

.airp-feature-locked input {
    cursor: not-allowed;
}

.airp-feature-locked:has(input:checked) {
    border-color: #dc2626;
    box-shadow: none;
}

.airp-upgrade-hint {
    display: block;
    margin-top: 6px;
    color: #dc2626;
    font-size: 0.88em;
    font-weight: 700;
    line-height: 1.35;
}

.airp-upgrade-link {
    color: #dc2626;
    cursor: pointer;
    text-decoration: underline;
}

.airp-upgrade-link:hover,
.airp-upgrade-link:focus {
    color: #991b1b;
}

.airp-plot-spine-create-options,
.airp-plot-spine-manual-fields {
    display: grid;
    gap: 10px;
}

.airp-plot-spine-create-options[hidden],
.airp-plot-spine-manual-fields[hidden] {
    display: none;
}

.airp-segmented-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.airp-plot-spine-length-options {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.airp-segmented-options label {
    display: grid;
    place-items: center;
    min-height: 42px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 8px 10px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    cursor: pointer;
    text-align: center;
    font-weight: 800;
}

.airp-segmented-options small {
    display: block;
    margin-top: 2px;
    color: var(--airp-muted-text-color);
    font-size: 11px;
    font-weight: 600;
}

.airp-segmented-options input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.airp-segmented-options label:has(input:checked) {
    border-color: var(--airp-accent-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 18%, transparent);
}

.airp-segmented-options label:has(input:disabled) {
    opacity: 0.48;
    cursor: not-allowed;
}

.airp-field-error {
    border-color: var(--airp-danger-color) !important;
}

.airp-skill-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.airp-skill-row {
    display: grid;
    gap: 6px;
}

.airp-character-profile-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

@media (max-width: 640px) {
    .airp-campaign-mode-grid,
    .airp-model-choice-grid,
    .airp-referee-mode-options,
    .airp-skill-grid,
    .airp-character-profile-grid,
    .airp-setting-image-row,
    .airp-custom-archetype-grid {
        grid-template-columns: 1fr;
    }

    .airp-campaign-mode-card {
        min-height: 120px;
    }

    .airp-wizard-steps {
        gap: 4px;
    }

    .airp-wizard-steps span {
        min-height: 30px;
        font-size: 0.86rem;
        border-radius: 6px;
    }
}

.airp-radio-line {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 4px 0;
    color: var(--airp-text-color);
    font-weight: 700;
}

.airp-lobby-card {
    display: grid;
    gap: var(--airp-element-gap);
}

.airp-lobby-layout {
    display: grid;
    gap: var(--airp-element-gap);
}

.airp-lobby-panel,
.airp-turn-panel,
.airp-invite-result {
    display: grid;
    gap: 10px;
}

.airp-lobby-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.airp-lobby-panel-header .airp-card-title {
    margin-bottom: 0;
}

.airp-lobby-panel-header .airp-button {
    padding: 8px 12px;
}

.airp-player-list {
    display: grid;
    gap: 8px;
}

.airp-player-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
}

.airp-player-row span,
.airp-player-row strong,
.airp-player-row small {
    display: block;
}

.airp-player-row small {
    color: var(--airp-muted-text-color);
    font-size: 0.85em;
}

.airp-player-row-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex: 0 0 auto;
}

.airp-player-row-actions .airp-icon-button {
    width: 34px;
    height: 34px;
}

.airp-player-row em {
    flex: 0 0 auto;
    font-style: normal;
    font-weight: 800;
}

.airp-player-row em.is-ready {
    color: var(--airp-success-color);
}

.airp-player-row em.is-pending {
    color: var(--airp-muted-text-color);
}

.airp-turn-panel {
    padding: 10px 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
}

.airp-turn-panel span {
    color: var(--airp-muted-text-color);
    font-size: 0.92em;
}

.airp-roster-transition-cta {
    background: #c62828;
    border-color: #c62828;
    color: #fff;
    box-shadow: 0 0 0 3px rgba(198, 40, 40, 0.22);
    font-weight: 900;
}

.airp-roster-transition-cta:hover,
.airp-roster-transition-cta:focus-visible {
    background: #a61f1f;
    border-color: #a61f1f;
    color: #fff;
    box-shadow: 0 0 0 4px rgba(198, 40, 40, 0.32);
}

.airp-copy-spectator-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.airp-copy-spectator-invite {
    width: fit-content;
}

.airp-copy-spectator-status {
    display: block;
    margin-top: 6px;
    color: var(--airp-muted-text-color);
}

.airp-spectator-character-button {
    border-color: var(--airp-player-chat-color);
    background: var(--airp-player-chat-color);
    color: #fff;
}

.airp-world-readonly #airp-modal-diary .airp-diary-actions,
.airp-world-readonly #airp-modal-diary .airp-diary-edit-form,
.airp-world-readonly #airp-modal-diary .airp-diary-section-actions,
.airp-world-readonly #airp-modal-diary .airp-memory-image-input,
.airp-world-readonly #airp-modal-diary .airp-entity-context-meta .airp-context-toggle,
.airp-world-readonly #airp-modal-campaign-info .airp-campaign-info-form {
    display: none !important;
}

.airp-campaign-info-dialog {
    width: min(960px, 96vw);
}

.airp-campaign-info-dialog .airp-modal-body {
    display: grid;
    gap: 16px;
}

.airp-campaign-info-form {
    display: grid;
    gap: 16px;
}

.airp-campaign-info-section {
    display: grid;
    gap: 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 14px;
    background: color-mix(in srgb, var(--airp-surface-color) 76%, transparent);
}

.airp-campaign-info-section h4 {
    margin: 0;
    color: var(--airp-title-color);
    font-size: 0.95rem;
    font-weight: 900;
    text-transform: uppercase;
}

.airp-narrator-avatar-field {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.airp-narrator-avatar-field p {
    margin: 4px 0 0;
    color: var(--airp-muted-text-color);
}

.airp-narrator-avatar-field .airp-image-upload-tile-avatar {
    flex: 0 0 auto;
    width: 124px;
    height: 124px;
}

.airp-narrator-avatar-field .airp-chat-avatar-preview {
    width: 124px;
    height: 124px;
    min-height: 124px;
    overflow: hidden;
}

.airp-image-upload-tile {
    position: relative;
    display: flex;
    align-items: stretch;
    justify-content: stretch;
    width: 100%;
    cursor: pointer;
}

.airp-image-upload-input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.airp-image-upload-empty {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px;
    color: var(--airp-muted-text-color);
    font-size: 0.88em;
    font-weight: 800;
    line-height: 1.25;
    text-align: center;
}

.airp-image-upload-spinner {
    position: absolute;
    top: 50%;
    left: 50%;
    display: none;
    width: 28px;
    height: 28px;
    margin: -14px 0 0 -14px;
    border: 3px solid color-mix(in srgb, var(--airp-surface-color) 70%, transparent);
    border-top-color: var(--airp-primary-color);
    border-radius: 50%;
    animation: airp-upload-spin 0.8s linear infinite;
    z-index: 2;
}

.airp-image-upload-tile.is-uploading::after {
    content: "";
    position: absolute;
    inset: 0;
    background: color-mix(in srgb, var(--airp-surface-color) 70%, transparent);
    border-radius: calc(var(--airp-border-radius) / 2);
    z-index: 1;
}

.airp-image-upload-tile.is-uploading .airp-image-upload-spinner {
    display: block;
}

@keyframes airp-upload-spin {
    to {
        transform: rotate(360deg);
    }
}

.airp-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.airp-login-remember {
    display: inline-flex;
    gap: 8px;
    align-items: center;
    color: var(--airp-muted-text-color);
    font-weight: 700;
}

.airp-auth-divider {
    margin: 16px 0;
    color: var(--airp-muted-text-color);
    font-weight: 700;
    text-align: center;
}

.airp-account-type-box {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    margin: 18px 0;
    padding: 12px 14px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
}

.airp-account-type-label {
    color: var(--airp-muted-text-color);
    font-weight: 700;
}

.airp-account-type-value {
    color: var(--airp-title-color);
    letter-spacing: 0.08em;
}

.airp-account-type-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-left: auto;
}

.airp-account-type-current {
    display: inline-grid;
    justify-items: end;
    gap: 2px;
}

.airp-account-type-current small {
    color: var(--airp-muted-text-color);
    font-size: 0.78rem;
    font-weight: 700;
}

.airp-account-limits-box {
    margin: 18px 0;
}

.airp-account-limits-title {
    margin: 0 0 10px;
    color: var(--airp-title-color);
    font-size: 1.05em;
}

.airp-account-limits-table {
    width: 100%;
    border-collapse: collapse;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    overflow: hidden;
    background: var(--airp-surface-color);
}

.airp-account-limits-table th,
.airp-account-limits-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--airp-border-color);
    text-align: left;
    vertical-align: top;
}

.airp-account-limits-table th {
    color: var(--airp-muted-text-color);
    font-weight: 700;
}

.airp-account-limits-table td {
    color: var(--airp-text-color);
    font-weight: 700;
    text-align: right;
}

.airp-account-limits-table tr:last-child th,
.airp-account-limits-table tr:last-child td {
    border-bottom: 0;
}

.airp-billing-dialog {
    width: 90vw !important;
    max-width: 90vw !important;
    height: 95vh;
    max-height: 95vh;
    overflow: auto;
    padding: 14px;
}

.airp-billing-dialog .airp-modal-header {
    justify-content: flex-end;
    margin-bottom: 2px;
}

.airp-confirm-dialog,
.airp-history-dialog {
    max-width: 640px;
}

.airp-billing-switch {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 0 auto 6px;
}

.airp-billing-switch-label {
    color: var(--airp-muted-text-color);
    font-size: 0.86rem;
    font-weight: 800;
    line-height: 1.1;
}

.airp-billing-switch-label strong {
    color: var(--airp-accent-color);
    font-weight: 900;
}

.airp-billing-toggle {
    position: relative;
    width: 48px;
    height: 24px;
    border: 0;
    border-radius: 999px;
    background: var(--airp-border-color);
    cursor: pointer;
    flex: 0 0 auto;
    padding: 2px;
}

.airp-billing-toggle span {
    display: block;
    width: 20px;
    height: 20px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.28);
    transition: transform 0.16s ease;
}

.airp-billing-toggle.is-yearly {
    background: var(--airp-accent-color);
}

.airp-billing-toggle.is-yearly span {
    transform: translateX(24px);
}

.airp-pricing-table-wrap {
    width: 100%;
    overflow-x: visible;
    margin: 8px 0;
}

.airp-pricing-table {
    width: 100%;
    min-width: 860px;
    border-collapse: collapse;
    border: 1px solid var(--airp-border-color);
    background: var(--airp-surface-color);
}

.entry-content .airp-pricing-table {
    border: 1px solid var(--airp-border-color);
    margin: 0;
    text-align: center;
}

.airp-pricing-mobile-plans {
    display: none;
}

.airp-pricing-table th,
.airp-pricing-table td {
    padding: 5px 8px;
    border-bottom: 1px solid var(--airp-border-color);
    border-right: 1px solid var(--airp-border-color);
    font-size: 0.86rem;
    line-height: 1.15;
    text-align: center;
    vertical-align: middle;
}

.airp-pricing-table th:first-child {
    text-align: left;
}

.airp-pricing-table thead th {
    color: var(--airp-title-color);
    font-weight: 800;
}

.airp-pricing-current {
    color: var(--airp-muted-text-color);
    font-size: 0.85rem;
    font-weight: 800;
}

.airp-price-note {
    color: var(--airp-muted-text-color);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-checkout-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-width: 112px;
    line-height: 1.15;
    white-space: nowrap;
}

.airp-checkout-price {
    font-size: 0.72rem;
    font-weight: 900;
}

.airp-pricing-boolean {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    font-size: 0.95rem;
    font-weight: 900;
    line-height: 1;
}

.airp-pricing-boolean::before {
    display: block;
}

.airp-pricing-boolean.is-active::before {
    content: "\2713";
}

.airp-pricing-boolean.is-inactive::before {
    content: "\2715";
}

.airp-pricing-boolean.is-active {
    color: #16a34a;
}

.airp-pricing-boolean.is-inactive {
    color: #dc2626;
}

.airp-pricing-infinity {
    color: var(--airp-title-color);
    font-size: 1.1rem;
    font-weight: 900;
    line-height: 1;
}

.airp-stripe-checkout-form {
    margin: 0;
}

.airp-one-shot-products {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 10px;
}

.airp-one-shot-product-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 8px 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
}

.airp-one-shot-product-row strong {
    min-width: 0;
    font-size: 0.88rem;
    line-height: 1.2;
}

.airp-pricing-mobile-plan {
    display: grid;
    justify-items: center;
    gap: 8px;
    padding: 14px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
    text-align: center;
}

.airp-pricing-mobile-plan h3 {
    margin: 0;
    color: var(--airp-title-color);
    font-size: 1.05rem;
    font-weight: 900;
}

.airp-pricing-mobile-price,
.airp-pricing-mobile-action {
    display: grid;
    justify-items: center;
}

.airp-pricing-mobile-features {
    display: grid;
    gap: 7px;
    width: 100%;
}

.airp-pricing-mobile-feature {
    display: grid;
    justify-items: center;
    gap: 3px;
    padding: 8px 6px;
    border-top: 1px solid var(--airp-border-color);
}

.airp-pricing-mobile-feature span {
    color: var(--airp-muted-text-color);
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.2;
}

.airp-pricing-mobile-feature strong {
    color: var(--airp-text-color);
    font-size: 0.95rem;
    line-height: 1.2;
}

.airp-quota-badge {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 6px 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
    color: var(--airp-muted-text-color);
    font-size: 0.84rem;
    font-weight: 700;
    line-height: 1.25;
    white-space: nowrap;
}

.airp-wizard-actions .airp-quota-badge {
    margin-right: auto;
}

.airp-chat-input-wrapper .airp-quota-badge {
    align-self: center;
}

.airp-library-quota {
    margin: 10px 0 0;
}

.airp-message-actions .airp-quota-badge,
.airp-modal-header-actions .airp-quota-badge {
    min-height: 30px;
    padding: 5px 8px;
    font-size: 0.78rem;
}

.airp-form-status {
    color: var(--airp-muted-text-color);
    font-size: 0.92em;
    font-weight: 700;
}

.airp-form-status.is-error {
    color: var(--airp-danger-color);
}

.airp-chat-avatar-preview {
    width: 120px;
    height: 120px;
    min-height: 120px;
    border-radius: calc(var(--airp-border-radius) / 2);
}

.airp-chat-avatar-preview .dashicons {
    width: 28px;
    height: 28px;
    font-size: 28px;
}

.airp-character-creator-card {
    max-width: 820px;
    margin: 0 auto;
}

.airp-character-creator-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.airp-character-creator-header .airp-section-title {
    margin-bottom: 0;
}

.airp-character-creator-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.airp-character-fieldset {
    display: grid;
    gap: 12px;
    min-width: 0;
    margin: 0;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    padding: 14px;
}

.airp-character-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.airp-character-vitals-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.airp-stat-roll-row,
.airp-repeatable-item {
    display: grid;
    gap: 8px;
}

.airp-stat-roll-control {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}

.airp-uses-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.airp-stat-input {
    min-width: 0;
}

.airp-stat-roll-result {
    min-height: 1.4em;
    color: var(--airp-muted-text-color);
    font-size: 0.9em;
}

.airp-field-limit {
    color: var(--airp-muted-text-color);
    font-size: 0.82em;
    justify-self: end;
}

.airp-wizard-error {
    margin: 10px 0 0;
    color: var(--airp-danger-color);
    font-weight: 700;
}

.airp-repeatable-list {
    display: grid;
    gap: 12px;
}

.airp-repeatable-item {
    border-top: 1px solid var(--airp-border-color);
    padding-top: 12px;
}

.airp-repeatable-item:first-child {
    border-top: 0;
    padding-top: 0;
}

.airp-character-form .airp-inventory-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
}

.airp-creator-item-card {
    display: grid;
    gap: 12px;
    min-width: 0;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 12px;
    background: var(--airp-surface-color);
}

.airp-repeatable-item.airp-creator-item-card,
.airp-repeatable-item.airp-creator-item-card:first-child {
    border-top: 1px solid var(--airp-border-color);
    padding-top: 12px;
}

.airp-creator-item-card-head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 10px;
    align-items: end;
}

.airp-creator-item-card-head .airp-label,
.airp-creator-item-card-fields .airp-label {
    font-size: 0.82em;
}

.airp-creator-item-card-fields {
    display: grid;
    gap: 10px;
}

.airp-item-preset-picker {
    display: grid;
    gap: 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 12px;
    background: color-mix(in srgb, var(--airp-surface-color) 82%, transparent);
}

.airp-item-preset-picker h5,
.airp-item-preset-picker p {
    margin: 0;
}

.airp-item-preset-picker p,
.airp-preset-empty-hint {
    color: var(--airp-muted-text-color);
    font-size: 0.9em;
}

.airp-item-preset-sections,
.airp-item-preset-section,
.airp-item-preset-subsection {
    display: grid;
    gap: 10px;
}

.airp-item-preset-section {
    border-top: 1px solid var(--airp-border-color);
    padding-top: 10px;
}

.airp-item-preset-section h6,
.airp-item-preset-subsection h6 {
    margin: 0;
    color: var(--airp-title-color);
    font-size: 0.95em;
}

.airp-item-preset-subsection {
    padding: 8px 0 2px;
}

.airp-item-preset-picker [data-airp-item-preset-list] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 8px;
    align-items: start;
    padding: 2px;
}

.airp-item-preset-picker [data-airp-item-preset-list="equipment"] {
    grid-template-columns: 1fr;
}

.airp-skill-card-picker,
.airp-custom-skill-fields {
    display: grid;
    gap: 10px;
}

.airp-skill-card-picker p {
    margin: 0;
    color: var(--airp-muted-text-color);
    font-size: 0.9em;
}

.airp-skill-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    align-items: start;
}

.airp-skill-choice-card {
    min-height: 66px;
}

.airp-custom-skill-fields {
    border-top: 1px solid var(--airp-border-color);
    padding-top: 10px;
}

.airp-custom-skill-fields summary {
    cursor: pointer;
    color: var(--airp-muted-text-color);
    font-weight: 700;
}

.airp-item-preset-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 8px;
    align-items: start;
}

.airp-preset-choice-card,
.airp-skill-preset-preview {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
    min-width: 0;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 9px 10px;
    background: var(--airp-chat-background-color);
    color: var(--airp-text-color);
}

.airp-preset-choice-card {
    cursor: pointer;
}

.airp-preset-choice-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.airp-preset-choice-card:hover,
.airp-preset-choice-card:focus,
.airp-preset-choice-card:focus-within,
.airp-skill-preset-preview:hover,
.airp-skill-preset-preview:focus {
    border-color: var(--airp-accent-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 18%, transparent);
}

.airp-preset-choice-card.is-selected {
    border-color: #22c55e;
    background: color-mix(in srgb, #22c55e 12%, var(--airp-chat-background-color));
    box-shadow: 0 0 0 2px color-mix(in srgb, #22c55e 22%, transparent);
    color: #22c55e;
}

.airp-preset-choice-card.is-selected .airp-preset-card-main strong,
.airp-preset-choice-card.is-selected .airp-preset-card-main small,
.airp-preset-choice-card.is-selected .airp-preset-card-badge {
    color: #22c55e;
}

.airp-preset-choice-card.is-selected .airp-preset-card-badge {
    border-color: #22c55e;
}

.airp-preset-card-main {
    display: grid;
    gap: 2px;
    min-width: 0;
}

.airp-preset-card-main strong,
.airp-preset-card-main small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-preset-card-main small {
    color: var(--airp-muted-text-color);
    font-size: 0.8em;
}

.airp-preset-card-badge {
    max-width: 92px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    padding: 3px 7px;
    color: var(--airp-muted-text-color);
    font-size: 0.76em;
    font-weight: 700;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-preset-tooltip {
    position: absolute;
    left: 10px;
    right: auto;
    bottom: calc(100% + 8px);
    z-index: 30;
    display: none;
    width: min(320px, 86vw);
    max-height: 280px;
    overflow: auto;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 10px;
    background: var(--airp-panel-background-color);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
    color: var(--airp-text-color);
    font-size: 0.9em;
    line-height: 1.35;
}

.airp-preset-choice-card .airp-preset-tooltip,
.airp-skill-preset-preview .airp-preset-tooltip {
    display: none !important;
}

.airp-floating-preset-tooltip {
    position: fixed;
    z-index: var(--airp-lightbox-z-index);
    max-height: 280px;
    overflow: auto;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 10px;
    background: var(--airp-panel-background-color);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
    color: var(--airp-text-color);
    font-size: 0.9em;
    line-height: 1.35;
    pointer-events: none;
}

.airp-preset-tooltip strong,
.airp-preset-tooltip span,
.airp-floating-preset-tooltip strong,
.airp-floating-preset-tooltip span {
    display: block;
}

.airp-preset-tooltip span,
.airp-floating-preset-tooltip span {
    margin-top: 5px;
    color: var(--airp-muted-text-color);
}

.airp-skill-preset-preview-wrap {
    margin-top: 8px;
}

@media (max-width: 760px) {
    .airp-skill-card-grid {
        grid-template-columns: 1fr;
    }
}

.airp-creator-item-card .airp-item-thumb {
    align-self: end;
}

.airp-creator-item-card-description textarea {
    min-height: 88px;
    resize: vertical;
}

.airp-item-actions,
.airp-modal-header-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
}

.airp-header-icon-form {
    display: inline-flex;
    margin: 0;
}

.airp-companion-list {
    display: grid;
    gap: 10px;
}

.airp-companion-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--airp-border-color);
}

.airp-companion-row:last-child {
    border-bottom: 0;
}

.airp-companion-row > div:not(.airp-companion-actions) {
    flex: 1 1 auto;
    min-width: 0;
}

.airp-companion-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
}

.airp-inline-delete-form {
    display: inline;
    margin: 0;
}

.airp-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
    color: var(--airp-text-color);
    cursor: pointer;
}

.airp-icon-button:hover,
.airp-icon-button:focus {
    color: var(--airp-primary-color);
}

.airp-icon-button-danger:hover,
.airp-icon-button-danger:focus {
    color: var(--airp-button-text-color);
    background: var(--airp-danger-color);
}

.airp-inline-edit-form {
    margin-top: 14px;
    border-top: 1px solid var(--airp-border-color);
    padding-top: 14px;
}

.airp-game-wrapper {
    background: var(--airp-background-color);
}

.airp-game-wrapper:fullscreen {
    width: 100vw;
    height: 100vh;
    max-width: none;
    overflow: auto;
}

.airp-game-wrapper:fullscreen .airp-chat-messages {
    height: calc(100vh - 210px);
    max-height: none;
}

.airp-game-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 8px;
}

.airp-lobby-wrapper .airp-game-header .airp-turn-notifications-button,
.airp-game-actions .airp-turn-notifications-button {
    flex: 1 0 100%;
}

.airp-game-wrapper > .airp-game-header {
    display: block;
    margin-bottom: var(--airp-element-gap);
    text-align: center;
}

.airp-game-heading {
    display: block;
}

.airp-game-wrapper > .airp-game-header > .airp-back-button,
.airp-game-wrapper > .airp-game-header > .airp-game-actions {
    display: none;
}

.airp-game-heading .airp-game-title {
    margin-bottom: 0;
    font-family: "Cinzel", Georgia, serif;
    font-size: 36px;
    line-height: 1.08;
}

.airp-game-heading .airp-game-meta {
    display: none;
}

.airp-game-layout {
    display: grid;
    grid-template-columns: 210px minmax(0, 1fr);
    gap: var(--airp-element-gap);
    align-items: start;
}

.airp-game-sidebar {
    display: grid;
    align-content: start;
    gap: 18px;
    position: sticky;
    top: 16px;
}

.airp-sidebar-section {
    display: grid;
    gap: 8px;
}

.airp-sidebar-section .airp-button {
    width: 100%;
    justify-content: center;
    padding-top: 8px;
    padding-bottom: 8px;
}

/* Toggle this rule off to show the manual combat test button again. */
.airp-game-sidebar .airp-combat-start-button[data-airp-combat-source="manual"] {
    display: none;
}

.airp-sidebar-title {
    margin: 0 0 2px;
    color: var(--airp-muted-text-color);
    font-size: 0.86em;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.airp-main-panel,
.airp-chat-panel {
    min-width: 0;
}

.airp-chat-panel {
    display: grid;
    gap: var(--airp-element-gap);
}

.airp-chat-input-wrapper {
    column-gap: 4px;
    row-gap: 10px;
    grid-template-columns: auto auto minmax(220px, 1fr);
    align-items: end;
}

.airp-chat-input-wrapper .airp-chat-textarea {
    grid-column: 1 / -1;
}

.airp-dictation-button {
    min-width: 46px;
}

.airp-dictation-button .dashicons {
    width: 20px;
    height: 20px;
    font-size: 20px;
    line-height: 1;
}

.airp-dictation-button.is-listening {
    border-color: var(--airp-danger-color);
    color: var(--airp-danger-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-danger-color) 20%, transparent);
}

.airp-dice-panel {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    border: 0;
    padding: 0;
    background: transparent;
}

.airp-chat-input-wrapper > .airp-dice-panel {
    display: none;
}

.airp-dice-title {
    color: var(--airp-muted-text-color);
    font-weight: 800;
    text-transform: uppercase;
}

.airp-custom-die-label {
    color: var(--airp-text-color);
    font-weight: 800;
}

.airp-custom-die-input {
    width: 86px;
}

.airp-game-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: var(--airp-element-gap);
}

.airp-game-wrapper > .airp-game-actions {
    display: none;
}

.airp-game-header-actions {
    flex: 1 1 auto;
    justify-content: flex-end;
    margin-top: 0;
}

.airp-context-size {
    margin-top: 0;
    text-align: left;
    color: var(--airp-muted-text-color);
    font-size: 0.92em;
}

.airp-game-wrapper > .airp-context-size {
    display: none;
}

.airp-context-size-inline {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 40px;
}

.airp-context-size strong {
    color: var(--airp-text-color);
}

.airp-context-size.is-over-limit,
.airp-context-size.is-over-limit strong {
    color: var(--airp-danger-color);
}

.airp-chat-messages {
    height: min(72vh, 820px);
    min-height: 460px;
    overflow-y: auto;
    background: var(--airp-chat-background-color);
    border: 1px solid var(--airp-border-color);
    border-radius: var(--airp-border-radius);
    padding: var(--airp-general-padding);
}

.airp-chat-load-all {
    display: flex;
    justify-content: center;
    margin-bottom: 14px;
}

.airp-chat-load-all .airp-button {
    padding: 7px 14px;
    font-size: 0.86rem;
}

@media (min-width: 1025px) {
    .airp-game-wrapper {
        display: grid;
        grid-template-rows: auto minmax(0, 1fr);
        height: calc(100dvh - var(--wp-admin--admin-bar--height, 0px));
        max-height: calc(100dvh - var(--wp-admin--admin-bar--height, 0px));
        overflow: hidden;
    }

    .airp-game-layout {
        align-items: stretch;
        min-height: 0;
    }

    .airp-game-sidebar {
        max-height: 100%;
        overflow-y: auto;
    }

    .airp-sidebar-dice-section .airp-dice-panel {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .airp-main-panel,
    .airp-chat-panel {
        display: grid;
        min-height: 0;
    }

    .airp-chat-panel {
        grid-template-rows: minmax(0, 1fr) auto;
    }

    .airp-chat-input-wrapper {
        display: flex;
        flex-wrap: wrap;
        align-items: end;
        column-gap: 4px;
        row-gap: 10px;
    }

    .airp-chat-input-wrapper .airp-chat-textarea {
        flex: 0 0 100%;
    }

    .airp-chat-messages,
    .airp-game-wrapper:fullscreen .airp-chat-messages {
        height: auto;
        min-height: 0;
        max-height: none;
    }

    .airp-chat-input-wrapper .airp-dictation-button {
        width: auto;
        max-width: max-content;
        flex: 0 0 auto;
    }

    .airp-chat-input-wrapper .airp-chat-submit,
    .airp-chat-input-wrapper .airp-pass-turn-button,
    .airp-chat-input-wrapper .airp-quota-badge {
        flex: 0 0 auto;
    }

    .airp-chat-input-wrapper .airp-context-size-inline {
        flex: 0 0 100%;
    }
}

.airp-chat-message {
    max-width: 88%;
    margin-bottom: 14px;
    border-radius: var(--airp-border-radius);
    padding: 13px 15px;
    color: var(--airp-text-color);
}

.airp-chat-message-user {
    margin-left: auto;
    background: var(--airp-player-message-background);
}

.airp-chat-message-user[style*="--airp-player-bubble-color"] {
    background: color-mix(in srgb, var(--airp-player-bubble-color) 20%, var(--airp-chat-background-color));
    border: 1px solid color-mix(in srgb, var(--airp-player-bubble-color) 42%, var(--airp-border-color));
}

.airp-chat-message-own {
    margin-left: auto;
    margin-right: 0;
}

.airp-chat-message-other {
    margin-left: 0;
    margin-right: auto;
}

.airp-chat-message-ai {
    margin-right: auto;
    background: var(--airp-ai-message-background);
}

.airp-chat-message-referee-denial {
    background: color-mix(in srgb, var(--airp-danger-color) 16%, var(--airp-ai-message-background));
    border: 1px solid var(--airp-danger-color);
    color: var(--airp-danger-color);
}

.airp-chat-message-referee-denial .airp-chat-message-role {
    color: var(--airp-danger-color);
}

.airp-chat-message-referee-denial .airp-referee-denial-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
}

.airp-modal-dialog.airp-combat-dialog {
    position: relative;
    width: 80vw;
    height: 80vh;
    max-width: calc(100vw - 28px);
    max-height: calc(100vh - 28px);
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.airp-combat-dialog .airp-modal-header {
    margin: 0;
    padding: 16px 18px;
    border-bottom: 1px solid var(--airp-border-color);
    background: color-mix(in srgb, var(--airp-chat-background-color) 82%, var(--airp-modal-background-color));
}

.airp-combat-dialog .airp-modal-body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 10px 12px;
    background: var(--airp-chat-background-color);
    overflow: hidden;
}

.airp-combat-status {
    margin-bottom: 6px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--airp-title-color);
    font-size: 0.86rem;
    font-weight: 800;
}

.airp-combat-grid {
    flex: 1 1 auto;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
    gap: 12px;
    align-items: stretch;
}

.airp-combat-column {
    min-width: 0;
    min-height: 0;
    gap: 10px;
}

.airp-combat-column-left {
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
}

.airp-combat-column-right {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
}

.airp-combat-setup-review {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.airp-combat-setup-review[hidden] {
    display: none;
}

.airp-combat-setup-review h4,
.airp-combat-setup-review p {
    margin: 0;
}

.airp-combat-review-textarea {
    min-height: 240px;
    font-family: inherit;
    line-height: 1.45;
}

.airp-combat-side-board {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 2px minmax(0, 1fr);
    gap: 18px;
    align-items: stretch;
    min-height: 390px;
}

.airp-combat-side-divider {
    border-radius: 99px;
    background: linear-gradient(180deg, transparent, var(--airp-accent-color), transparent);
}

.airp-combat-side-column {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.airp-combat-side-column h5 {
    margin: 0;
    color: var(--airp-title-color);
    font-size: 0.9rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.airp-combat-side-list {
    flex: 1;
    display: grid;
    align-content: start;
    gap: 10px;
    min-height: 320px;
    padding: 12px;
    border: 1px dashed var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-chat-background-color);
    transition: border-color 0.16s ease, background 0.16s ease;
}

.airp-combat-side-list.is-drag-over {
    border-color: var(--airp-accent-color);
    background: color-mix(in srgb, var(--airp-accent-color) 8%, var(--airp-chat-background-color));
}

.airp-combat-side-card {
    display: grid;
    gap: 8px;
    padding: 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-modal-background-color);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
    cursor: grab;
}

.airp-combat-side-card.is-locked {
    cursor: default;
    border-color: #22c55e;
}

.airp-combat-side-card-head {
    display: flex;
    gap: 8px;
    align-items: center;
}

.airp-combat-side-summary {
    min-width: 0;
    flex: 1 1 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 8px;
    align-items: center;
    padding: 7px 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-input-background-color);
    color: var(--airp-text-color);
    cursor: pointer;
    font: inherit;
    text-align: left;
}

.airp-combat-side-summary strong {
    overflow: hidden;
    color: var(--airp-title-color);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-side-summary span {
    color: var(--airp-muted-text-color);
    font-size: 0.74rem;
    font-weight: 900;
}

.airp-combat-side-card-head span {
    flex: 0 0 auto;
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-combat-side-card-body {
    display: grid;
    gap: 8px;
}

.airp-combat-side-card.is-collapsed {
    gap: 0;
}

.airp-combat-side-card.is-collapsed .airp-combat-side-card-body {
    display: none;
}

.airp-combat-side-delete {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-panel-background-color);
    color: #ef4444;
    cursor: pointer;
}

.airp-combat-side-delete:hover,
.airp-combat-side-delete:focus {
    border-color: #ef4444;
    background: color-mix(in srgb, #ef4444 10%, var(--airp-panel-background-color));
}

.airp-combat-side-name,
.airp-combat-side-description,
.airp-combat-side-card-fields input {
    width: 100%;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-input-background-color);
    color: var(--airp-text-color);
}

.airp-combat-side-name {
    min-width: 0;
    padding: 7px 8px;
    font-weight: 800;
}

.airp-combat-side-description {
    resize: vertical;
    min-height: 48px;
    padding: 7px 8px;
}

.airp-combat-side-card-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.airp-combat-side-card-wide {
    grid-column: 1 / -1;
}

.airp-combat-side-card-fields label {
    display: grid;
    gap: 4px;
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    font-weight: 800;
}

.airp-combat-side-card-fields input {
    padding: 6px;
}

.airp-combat-side-card-fields select {
    width: 100%;
    padding: 6px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-input-background-color);
    color: var(--airp-text-color);
}

.airp-combat-side-effects {
    display: grid;
    gap: 8px;
}

.airp-combat-side-effect-tools,
.airp-combat-side-effect-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.airp-combat-side-effect-tools strong,
.airp-combat-side-effect-head strong {
    color: var(--airp-title-color);
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.airp-combat-side-effect-list {
    display: grid;
    gap: 8px;
}

.airp-combat-side-effect {
    display: grid;
    gap: 8px;
    padding: 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-panel-background-color) 78%, var(--airp-chat-background-color));
}

.airp-combat-side-effect-remove {
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-panel-background-color);
    color: #ef4444;
    cursor: pointer;
    font-size: 0.72rem;
    font-weight: 800;
    padding: 4px 7px;
}

.airp-combat-side-empty,
.airp-combat-excluded {
    margin: 0;
    color: var(--airp-muted-text-color);
    font-size: 0.86rem;
}

.airp-combat-excluded {
    grid-column: 1 / -1;
    order: 10;
    padding: 10px 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-panel-background-color);
}

.airp-combat-setup-actions {
    grid-column: 1 / -1;
    order: 9;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: flex-end;
    flex: 0 0 auto;
    margin-top: 0;
    padding-top: 10px;
    border-top: 1px solid var(--airp-border-color);
}

.airp-combat-setup-actions .airp-combat-confirm-start {
    width: 100%;
}

.airp-combat-setup-actions .airp-combat-cancel-start[hidden] + .airp-combat-confirm-start {
    grid-column: 1 / -1;
}

@media (max-width: 760px) {
    .airp-combat-side-board {
        grid-template-columns: 1fr;
    }

    .airp-combat-side-divider {
        height: 2px;
        background: linear-gradient(90deg, transparent, var(--airp-accent-color), transparent);
    }
}

.airp-combat-panel {
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-modal-background-color) 92%, var(--airp-chat-background-color));
}

.airp-combat-timeline-panel {
    gap: 6px;
    min-height: 0;
    overflow: hidden;
}

.airp-combat-timeline-panel .airp-form-actions {
    gap: 6px;
    margin-top: 0;
}

.airp-combat-timeline-panel .airp-button {
    padding: 5px 9px;
}

.airp-combat-arena-panel {
    --airp-combat-location-image: url("../images/combat-location-placeholder.png");
    min-height: 0;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.34)),
        radial-gradient(circle at 50% 20%, rgba(255, 255, 255, 0.16), transparent 34%),
        var(--airp-combat-location-image),
        var(--airp-modal-background-color);
    background-position: center;
    background-size: cover;
}

.airp-combat-log-panel {
    min-height: 0;
    gap: 0;
    overflow: hidden;
}

.airp-combat-actions-panel {
    min-height: 0;
    max-height: 32vh;
    overflow: auto;
    align-items: flex-start;
}

.airp-combat-actions-panel .airp-combat-action-form {
    width: 100%;
}

.airp-combat-panel h4 {
    display: none;
}

.airp-combatants {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow: auto;
    padding-right: 2px;
}

.airp-combat-timeline {
    display: grid;
    gap: 4px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.airp-combat-timeline-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.airp-combat-timeline-head strong {
    color: var(--airp-title-color);
    font-size: 0.86rem;
    font-weight: 900;
}

.airp-combat-timeline-head span {
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.airp-combat-timeline-track {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    padding-bottom: 2px;
}

.airp-combat-turn-chip {
    position: relative;
    flex: 0 0 86px;
    display: grid;
    justify-items: center;
    gap: 2px;
    padding: 5px 6px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-modal-background-color);
    color: var(--airp-text-color);
    cursor: pointer;
    font: inherit;
}

.airp-combat-turn-chip .airp-combatant-avatar {
    width: 26px;
    height: 26px;
    font-size: 0.68rem;
}

.airp-combat-turn-chip.is-current {
    border-color: var(--airp-accent-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 18%, transparent);
}

.airp-combat-turn-chip.is-selected,
.airp-combatant.is-selected {
    border-color: var(--airp-primary-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-primary-color) 18%, transparent), 0 12px 26px rgba(0, 0, 0, 0.14);
}

.airp-combatant.is-selected {
    background: color-mix(in srgb, var(--airp-panel-background-color) 84%, transparent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--airp-primary-color) 30%, transparent), 0 12px 26px rgba(0, 0, 0, 0.18);
}

.airp-combat-turn-chip.is-inactive {
    opacity: 0.52;
}

.airp-combat-turn-name {
    width: 100%;
    overflow: hidden;
    color: var(--airp-title-color);
    font-size: 0.74rem;
    font-weight: 900;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-turn-chip small {
    color: var(--airp-muted-text-color);
    font-size: 0.68rem;
    font-weight: 800;
}

.airp-combat-turn-chip em {
    position: absolute;
    top: 5px;
    right: 5px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--airp-accent-color) 22%, var(--airp-panel-background-color));
    color: var(--airp-title-color);
    font-size: 0.66rem;
    font-style: normal;
    font-weight: 900;
}

.airp-combat-arena {
    flex: 1 1 auto;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 2px minmax(0, 1fr);
    gap: 8px;
    align-items: stretch;
}

.airp-combat-details {
    position: relative;
    display: grid;
    gap: 10px;
    width: min(680px, calc(100vw - 64px));
    max-height: min(72vh, 720px);
    overflow: auto;
    padding: 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-panel-background-color) 86%, var(--airp-chat-background-color));
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.48);
}

.airp-combat-details-overlay {
    position: absolute;
    inset: 0;
    z-index: 40;
    display: none;
    place-items: center;
    padding: 24px;
}

.airp-combat-details-overlay.is-open {
    display: grid;
}

.airp-combat-details-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(2px);
}

.airp-combat-details-shell {
    position: relative;
    z-index: 1;
}

.airp-combat-details-close {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 2;
    width: 34px;
    height: 34px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: var(--airp-modal-background-color);
    color: var(--airp-title-color);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
}

.airp-combat-details-close:hover,
.airp-combat-details-close:focus {
    border-color: var(--airp-accent-color);
    color: var(--airp-accent-color);
}

.airp-combat-details-head {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.airp-combat-details-head strong,
.airp-combat-details-head span {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-details-head strong {
    color: var(--airp-title-color);
    font-size: 1rem;
}

.airp-combat-details-head span {
    color: var(--airp-muted-text-color);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-combat-details-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.airp-combat-details-stats span {
    min-width: 0;
    padding: 7px 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-modal-background-color);
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    font-weight: 800;
}

.airp-combat-details-stats strong {
    display: block;
    overflow: hidden;
    color: var(--airp-title-color);
    font-size: 0.82rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-details-section {
    display: grid;
    gap: 5px;
}

.airp-combat-details-section h5 {
    margin: 0;
    color: var(--airp-title-color);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.airp-combat-details-section p {
    margin: 0;
    color: var(--airp-muted-text-color);
    font-size: 0.84rem;
    line-height: 1.4;
}

.airp-combat-npc-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.airp-combat-skill-list {
    display: grid;
    gap: 6px;
}

.airp-combat-skill-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 6px 8px;
    align-items: start;
    padding: 7px 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-modal-background-color) 82%, var(--airp-chat-background-color));
}

.airp-combat-skill-row strong,
.airp-combat-skill-row small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-skill-row strong {
    color: var(--airp-title-color);
    font-size: 0.82rem;
    font-weight: 900;
}

.airp-combat-skill-row small,
.airp-combat-skill-row > span {
    color: var(--airp-muted-text-color);
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
}

.airp-combat-skill-row p {
    grid-column: 1 / -1;
    font-size: 0.76rem;
    line-height: 1.35;
}

.airp-combat-arena-divider {
    border-radius: 99px;
    background: linear-gradient(180deg, transparent, var(--airp-accent-color), transparent);
}

.airp-combat-team {
    min-width: 0;
    display: grid;
    align-content: start;
    gap: 5px;
}

.airp-combat-team-title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 2px;
    color: var(--airp-title-color);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.airp-combat-team-title small {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: var(--airp-panel-background-color);
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    letter-spacing: 0;
}

.airp-combatant {
    width: 100%;
    min-width: 0;
    max-width: none;
    justify-self: center;
    box-sizing: border-box;
    display: grid;
    gap: 5px;
    padding: 7px;
    border: 1px solid color-mix(in srgb, var(--airp-border-color) 70%, transparent);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-panel-background-color) 72%, transparent);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
    transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.airp-combatant.is-hp-healthy {
    border-color: var(--airp-border-color);
}

.airp-combatant.is-hp-wounded {
    border-color: var(--airp-border-color);
}

.airp-combatant.is-hp-critical {
    border-color: var(--airp-border-color);
}

.airp-combatant.is-current {
    border-color: var(--airp-accent-color);
    background: color-mix(in srgb, var(--airp-panel-background-color) 82%, transparent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-accent-color) 36%, transparent), 0 10px 24px rgba(0, 0, 0, 0.16);
}

.airp-combatant.is-damage-flash {
    animation: airp-combat-damage-flash 0.7s ease;
}

@keyframes airp-combat-damage-flash {
    0%,
    100% {
        transform: translateX(0);
        box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
    }

    15%,
    45%,
    75% {
        transform: translateX(-3px);
        box-shadow: 0 0 0 3px color-mix(in srgb, #ef4444 34%, transparent), 0 10px 24px rgba(0, 0, 0, 0.16);
    }

    30%,
    60% {
        transform: translateX(3px);
        box-shadow: 0 0 0 3px color-mix(in srgb, #ef4444 34%, transparent), 0 10px 24px rgba(0, 0, 0, 0.16);
    }
}

.airp-combat-modal.is-picking-target .airp-combatant.is-targetable {
    cursor: pointer;
}

.airp-combat-modal.is-picking-target .airp-combatant.is-targetable:hover,
.airp-combat-modal.is-picking-target .airp-combatant.is-targetable:focus-within {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--airp-primary-color) 72%, var(--airp-border-color));
    background: color-mix(in srgb, var(--airp-panel-background-color) 82%, transparent);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-primary-color) 28%, transparent), 0 12px 26px rgba(0, 0, 0, 0.16);
}

.airp-combatant-head {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
}

.airp-combatant-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    overflow: hidden;
    border: 1px solid var(--airp-border-color);
    border-radius: 50%;
    background: color-mix(in srgb, var(--airp-surface-color) 88%, white);
    color: var(--airp-title-color);
    font-size: 0.78rem;
    font-weight: 900;
}

.airp-combatant-avatar img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.airp-combatant-main {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.airp-combatant-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--airp-title-color);
    font-size: 0.98rem;
}

.airp-combatant-meta {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--airp-muted-text-color);
    font-size: 0.76rem;
    line-height: 1.35;
}

.airp-combat-hp {
    position: relative;
    min-height: 22px;
    overflow: hidden;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: color-mix(in srgb, var(--airp-chat-background-color) 84%, #000);
}

.airp-combat-hp-bar {
    position: absolute;
    inset: 0 auto 0 0;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--airp-hp-bar-start-color), var(--airp-hp-bar-color));
}

.airp-combatant.is-hp-wounded .airp-combat-hp-bar {
    background: linear-gradient(90deg, var(--airp-hp-bar-start-color), var(--airp-hp-bar-color));
}

.airp-combatant.is-hp-critical .airp-combat-hp-bar {
    background: linear-gradient(90deg, var(--airp-hp-bar-start-color), var(--airp-hp-bar-color));
}

.airp-combat-hp-text {
    position: relative;
    z-index: 1;
    display: block;
    padding: 3px 8px;
    color: var(--airp-title-color);
    font-size: 0.72rem;
    font-weight: 900;
    line-height: 1.2;
    text-align: center;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.28);
}

.airp-combat-status-pill {
    justify-self: start;
    padding: 3px 7px;
    border: 1px solid color-mix(in srgb, #ef4444 46%, var(--airp-border-color));
    border-radius: 999px;
    background: color-mix(in srgb, #ef4444 10%, var(--airp-panel-background-color));
    color: #ef4444;
    font-size: 0.7rem;
    font-weight: 900;
}

.airp-combat-effects,
.airp-combat-global-effects div {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.airp-combat-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    min-width: 0;
}

.airp-combat-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    max-width: 100%;
    padding: 3px 7px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: color-mix(in srgb, var(--airp-panel-background-color) 82%, var(--airp-chat-background-color));
    color: var(--airp-muted-text-color);
    font-family: inherit;
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1.15;
    text-align: left;
    cursor: pointer;
}

.airp-combat-tag small {
    color: currentColor;
    font-size: 0.68rem;
    font-weight: 900;
    opacity: 0.72;
}

.airp-combat-tag.is-buff {
    border-color: color-mix(in srgb, #22c55e 50%, var(--airp-border-color));
    background: color-mix(in srgb, #22c55e 12%, var(--airp-panel-background-color));
    color: #15803d;
}

.airp-combat-tag.is-debuff {
    border-color: color-mix(in srgb, #ef4444 52%, var(--airp-border-color));
    background: color-mix(in srgb, #ef4444 11%, var(--airp-panel-background-color));
    color: #dc2626;
}

.airp-combat-tag.is-resistance {
    border-color: color-mix(in srgb, #0ea5e9 48%, var(--airp-border-color));
    background: color-mix(in srgb, #0ea5e9 11%, var(--airp-panel-background-color));
    color: #0369a1;
}

.airp-combat-tag.is-immunity {
    border-color: color-mix(in srgb, #eab308 54%, var(--airp-border-color));
    background: color-mix(in srgb, #eab308 13%, var(--airp-panel-background-color));
    color: #a16207;
}

.airp-combat-tag.is-vulnerability {
    border-color: color-mix(in srgb, #f97316 55%, var(--airp-border-color));
    background: color-mix(in srgb, #f97316 12%, var(--airp-panel-background-color));
    color: #c2410c;
}

.airp-combat-tag.is-more {
    border-style: dashed;
    color: var(--airp-muted-text-color);
}

.airp-combat-effect-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    max-width: 100%;
    padding: 3px 7px;
    border: 1px solid color-mix(in srgb, var(--airp-accent-color) 45%, var(--airp-border-color));
    border-radius: 999px;
    background: color-mix(in srgb, var(--airp-accent-color) 10%, var(--airp-panel-background-color));
    color: var(--airp-title-color);
    font-family: inherit;
    font-size: 0.7rem;
    font-weight: 800;
    text-align: left;
    cursor: pointer;
}

.airp-combat-effect-badge small {
    color: var(--airp-muted-text-color);
    font-size: 0.68rem;
    font-weight: 900;
}

.airp-combat-info-popover {
    position: fixed;
    z-index: 1000002;
    width: min(320px, calc(100vw - 24px));
    max-height: min(360px, calc(100vh - 24px));
    overflow: auto;
    padding: 12px 40px 12px 12px;
    border: 1px solid color-mix(in srgb, var(--airp-accent-color) 38%, var(--airp-border-color));
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-panel-background-color) 92%, var(--airp-chat-background-color));
    color: var(--airp-text-color);
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.42);
}

.airp-combat-info-popover-title {
    display: block;
    margin-bottom: 8px;
    color: var(--airp-title-color);
    font-size: 0.86rem;
    line-height: 1.2;
}

.airp-combat-info-popover-body {
    display: grid;
    gap: 7px;
}

.airp-combat-info-popover-body p {
    display: grid;
    gap: 2px;
    margin: 0;
    color: var(--airp-text-color);
    font-size: 0.78rem;
    line-height: 1.35;
}

.airp-combat-info-popover-body strong {
    color: var(--airp-muted-text-color);
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
}

.airp-combat-info-popover-close {
    position: absolute;
    top: 7px;
    right: 7px;
    width: 26px;
    height: 26px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: var(--airp-modal-background-color);
    color: var(--airp-title-color);
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
}

.airp-combat-global-effects,
.airp-combat-empty-team {
    margin-top: 10px;
    padding: 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-panel-background-color) 78%, var(--airp-chat-background-color));
}

.airp-combat-global-effects {
    display: grid;
    gap: 7px;
}

.airp-combat-global-effects strong {
    color: var(--airp-title-color);
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.airp-combat-empty-team {
    margin: 0;
    color: var(--airp-muted-text-color);
    font-size: 0.82rem;
}

.airp-combat-log {
    flex: 1 1 auto;
    height: 100%;
    min-height: 0;
    overflow: auto;
    display: block;
    margin-bottom: 0;
    padding: 6px 4px;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.airp-combat-log-entry {
    width: fit-content;
    max-width: min(82%, 760px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

.airp-combat-log-entry.airp-chat-message-user {
    margin-left: auto;
    margin-right: 0;
}

.airp-combat-log-entry.airp-chat-message-ai,
.airp-combat-log-entry.airp-chat-message-system,
.airp-combat-message-npc {
    margin-left: 0;
    margin-right: auto;
}

.airp-combat-log-entry .airp-chat-message-content p {
    margin: 0;
}

.airp-combat-log-entry.is-critical-event {
    border: 2px solid #dc2626;
    background: color-mix(in srgb, #dc2626 14%, var(--airp-panel-background-color));
    box-shadow: 0 0 0 3px color-mix(in srgb, #dc2626 18%, transparent), 0 12px 28px rgba(220, 38, 38, 0.22);
}

.airp-combat-log-entry.is-critical-event .airp-chat-message-role,
.airp-combat-log-entry.is-critical-event .airp-chat-message-content {
    color: #dc2626;
    font-weight: 900;
}

.airp-combat-system-compact {
    width: fit-content;
    max-width: min(72%, 620px);
    margin: 4px auto 4px 0;
    padding: 4px 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-system-message-background) 72%, transparent);
    color: var(--airp-muted-text-color);
    font-size: 0.76rem;
}

.airp-combat-system-compact summary {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    font-weight: 900;
    list-style: none;
}

.airp-combat-system-compact summary::-webkit-details-marker {
    display: none;
}

.airp-combat-system-compact .dashicons {
    width: 14px;
    height: 14px;
    font-size: 14px;
}

.airp-combat-system-compact-body {
    margin-top: 5px;
    color: var(--airp-text-color);
    line-height: 1.35;
}

.airp-combat-action-form {
    display: grid;
    gap: 6px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.airp-combat-action-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 6px;
    align-items: center;
}

.airp-combat-action-header span,
.airp-combat-action-header small {
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.airp-combat-action-header strong {
    overflow: hidden;
    color: var(--airp-title-color);
    font-size: 0.9rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-choice-row,
.airp-combat-action-stage {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.airp-combat-choice-tiles {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
}

.airp-combat-action-tile {
    min-width: 0;
    min-height: 52px;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 2px;
    padding: 5px 6px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-modal-background-color);
    color: var(--airp-text-color);
    cursor: pointer;
    font: inherit;
    text-align: center;
}

.airp-combat-action-tile:hover,
.airp-combat-action-tile:focus-visible {
    border-color: var(--airp-primary-color);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--airp-primary-color) 14%, transparent);
    outline: none;
}

.airp-combat-action-tile .dashicons {
    width: 17px;
    height: 17px;
    color: var(--airp-accent-color);
    font-size: 17px;
}

.airp-combat-action-tile strong {
    width: 100%;
    overflow: hidden;
    color: var(--airp-title-color);
    font-size: 0.78rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-action-tile small {
    width: 100%;
    overflow: hidden;
    color: var(--airp-muted-text-color);
    font-size: 0.68rem;
    font-weight: 700;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-stage-head {
    flex: 0 0 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.airp-combat-action-stage h5 {
    margin: 0;
    color: var(--airp-title-color);
    font-size: 0.86rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.airp-combat-stage-back {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-modal-background-color);
    color: var(--airp-muted-text-color);
    cursor: pointer;
    font-size: 0.74rem;
    font-weight: 800;
    padding: 3px 7px;
}

.airp-combat-stage-back .dashicons {
    width: 15px;
    height: 15px;
    font-size: 15px;
}

.airp-combat-action-summary {
    flex: 0 0 100%;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 5px;
}

.airp-combat-action-summary span {
    min-width: 0;
    padding: 5px 7px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-modal-background-color);
    color: var(--airp-muted-text-color);
    font-size: 0.72rem;
    font-weight: 800;
}

.airp-combat-action-summary strong {
    display: block;
    overflow: hidden;
    color: var(--airp-title-color);
    font-size: 0.82rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-combat-action-stage p {
    flex: 0 0 100%;
    margin: 0;
    color: var(--airp-muted-text-color);
    font-size: 0.9rem;
}

.airp-combat-action-stage .airp-combat-stage-hint {
    font-size: 0.82rem;
    line-height: 1.35;
}

.airp-combat-action-stage .airp-chat-textarea {
    flex: 1 1 260px;
    min-height: 42px;
}

.airp-combat-narration-stage {
    align-items: stretch;
}

.airp-combat-narration-stage textarea {
    flex: 1 1 100%;
    min-height: 74px;
    padding: 9px 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-modal-background-color);
    color: var(--airp-text-color);
    resize: vertical;
}

.airp-combat-narration-mechanics {
    flex: 0 0 100%;
    padding: 5px 7px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-panel-background-color);
    color: var(--airp-muted-text-color);
    font-size: 0.76rem;
}

.airp-combat-narration-mechanics summary {
    cursor: pointer;
    font-weight: 900;
}

.airp-combat-narration-mechanics div {
    margin-top: 5px;
    color: var(--airp-text-color);
    line-height: 1.35;
}

.airp-chat-message-loading {
    opacity: 0.8;
}

.airp-chat-message-system {
    margin-right: auto;
    background: var(--airp-system-message-background);
    border: 1px solid var(--airp-system-message-border-color);
    color: var(--airp-system-message-text-color);
}

.airp-suggested-updates {
    display: grid;
    gap: 8px;
    margin-top: 10px;
}

.airp-suggested-update {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    max-width: 100%;
    padding: 7px 10px;
    border: 1px solid var(--airp-system-message-border-color);
    border-radius: 6px;
    background: color-mix(in srgb, var(--airp-system-message-background) 82%, black);
    color: var(--airp-system-message-text-color);
    cursor: pointer;
    text-align: left;
}

.airp-suggested-update.is-confirmed {
    border-color: #34d399;
    color: #34d399;
    cursor: default;
}

.airp-suggested-update.is-discarded {
    border-color: rgba(255, 255, 255, 0.25);
    color: var(--airp-muted-text-color, #b8b8b8);
    cursor: default;
    opacity: 0.72;
}

.airp-suggested-update em {
    font-size: 0.82rem;
    font-style: normal;
    opacity: 0.86;
}

.airp-suggested-update-title {
    margin: -4px 0 8px;
    color: var(--airp-muted-text-color, #b8b8b8);
    font-size: 0.9rem;
}

.airp-suggested-update-text {
    min-height: 220px;
    max-height: 55vh;
    overflow: auto;
    padding: 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    white-space: normal;
}

.airp-suggested-update-edit {
    min-height: 260px;
    resize: vertical;
}

.airp-suggested-update-column-head {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.airp-suggested-update-column-head h4 {
    margin: 0;
}

.airp-suggested-update-lightbox .airp-modal-actions .airp-button {
    margin: 0 2px;
}

.airp-character-update-review-wrap {
    display: grid;
    gap: 12px;
}

.airp-character-update-review-wrap h4 {
    margin: 0;
}

.airp-character-update-name {
    margin: -4px 0 10px;
    color: var(--airp-muted-text-color, #b8b8b8);
    font-size: 0.92rem;
}

.airp-character-update-list {
    display: grid;
    gap: 10px;
}

.airp-character-update-item {
    display: grid;
    gap: 6px;
    padding: 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
}

.airp-character-update-item-head {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: space-between;
}

.airp-character-update-row-toggle {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    width: fit-content;
    color: var(--airp-muted-text-color, #b8b8b8);
    font-size: 0.86rem;
    font-weight: 700;
}

.airp-character-guided-update-edit {
    display: grid;
    gap: 12px;
    margin-top: 4px;
    padding-top: 12px;
    border-top: 1px solid var(--airp-border-color);
}

.airp-character-guided-update-edit h4,
.airp-character-guided-update-edit h5 {
    margin: 0;
    color: var(--airp-title-color);
    font-weight: 700;
}

.airp-character-guided-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.airp-character-guided-group {
    display: grid;
    gap: 10px;
}

.airp-character-guided-card {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    background: var(--airp-chat-background-color);
}

.airp-character-guided-card .airp-label:last-child {
    grid-column: 1 / -1;
}

.airp-character-update-item-head span {
    color: var(--airp-muted-text-color, #b8b8b8);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-character-update-item-head strong,
.airp-character-update-main {
    color: var(--airp-title-color);
}

.airp-character-update-main {
    font-size: 1rem;
    font-weight: 800;
}

.airp-character-update-value {
    width: fit-content;
    max-width: 100%;
    padding: 4px 8px;
    border-radius: 6px;
    background: color-mix(in srgb, var(--airp-accent-color) 16%, transparent);
    color: var(--airp-title-color);
    font-weight: 800;
}

.airp-character-update-meta,
.airp-character-update-item p {
    margin: 0;
    color: var(--airp-muted-text-color, #b8b8b8);
    font-size: 0.9rem;
    line-height: 1.45;
}

.airp-diff-same,
.airp-diff-changed {
    display: inline;
    padding: 1px 2px;
    border-radius: 3px;
}

.airp-diff-same {
    background: rgba(52, 211, 153, 0.22);
    color: color-mix(in srgb, var(--airp-text-color) 80%, #34d399);
}

.airp-diff-changed {
    background: rgba(245, 196, 80, 0.35);
    color: color-mix(in srgb, var(--airp-text-color) 78%, #f5c450);
}

.airp-chat-message-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 7px;
}

.airp-chat-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 34px;
    height: 34px;
    overflow: hidden;
    border: 1px solid var(--airp-border-color);
    border-radius: 50%;
    background: color-mix(in srgb, var(--airp-surface-color) 88%, white);
    color: var(--airp-muted-text-color);
}

button.airp-chat-avatar {
    padding: 0;
    font: inherit;
    cursor: pointer;
}

button.airp-chat-avatar:hover,
button.airp-chat-avatar:focus-visible {
    border-color: var(--airp-primary-color);
    color: var(--airp-primary-color);
    outline: none;
}

.airp-chat-avatar img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.airp-chat-avatar .dashicons {
    width: 20px;
    height: 20px;
    font-size: 20px;
}

.airp-chat-message-role {
    font-size: 0.82em;
    font-weight: 800;
    opacity: 0.8;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.airp-chat-visual-refs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.airp-chat-visual-ref {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    width: 100%;
    min-height: 112px;
    padding: 8px 12px 8px 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    cursor: pointer;
    font: inherit;
    text-align: center;
    box-shadow: 0 1px 3px color-mix(in srgb, #000 18%, transparent);
}

.airp-chat-visual-ref:hover,
.airp-chat-visual-ref:focus-visible {
    border-color: var(--airp-primary-color);
    outline: none;
}

.airp-chat-visual-ref img {
    width: 96px;
    height: 96px;
    border-radius: 6px;
    object-fit: cover;
}

.airp-chat-visual-ref strong,
.airp-chat-visual-ref small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-chat-visual-ref small {
    color: var(--airp-muted-text-color);
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-modal-is-open {
    overflow: hidden;
}

.airp-modal {
    position: fixed;
    inset: 0;
    z-index: var(--airp-modal-z-index);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.airp-modal.is-open {
    display: flex;
}

.airp-modal-backdrop {
    position: absolute;
    inset: 0;
    background: var(--airp-modal-backdrop-color);
    opacity: var(--airp-modal-backdrop-opacity);
}

.airp-modal-dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 980px);
    max-height: min(90vh, 900px);
    overflow: auto;
    border: 1px solid var(--airp-border-color);
    border-radius: var(--airp-border-radius);
    background: var(--airp-modal-background-color);
    color: var(--airp-text-color);
    padding: var(--airp-general-padding);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.45);
}

.airp-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--airp-element-gap);
    margin-bottom: var(--airp-element-gap);
}

.airp-modal-title {
    margin: 0;
    color: var(--airp-title-color);
    font-size: var(--airp-title-size);
}

.airp-modal-close {
    width: 38px;
    height: 38px;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
    color: var(--airp-text-color);
    cursor: pointer;
    font-size: 24px;
    line-height: 1;
}

.airp-modal-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: var(--airp-element-gap);
}

.airp-modal-tab {
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-chat-background-color);
    color: var(--airp-text-color);
    cursor: pointer;
    padding: 9px 12px;
    font-weight: 700;
}

.airp-modal-tab.is-active {
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
}

.airp-tab-panel {
    display: none;
}

.airp-tab-panel.is-active {
    display: block;
}

.airp-diary-entry {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: var(--airp-element-gap);
    padding: 14px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-diary-card-background-color);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
    margin-bottom: 12px;
}

.airp-diary-entry:last-child {
    margin-bottom: 0;
}

.airp-diary-entry-full {
    grid-template-columns: 1fr;
}

.airp-diary-entry h4 {
    margin: 0 0 6px;
    color: var(--airp-title-color);
}

.airp-diary-section-actions {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 12px;
}

.airp-diary-section-actions .airp-button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.airp-diary-entry-title {
    min-width: 0;
}

.airp-entity-title-open {
    display: inline;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--airp-title-color);
    cursor: pointer;
    font: inherit;
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.25;
    text-align: left;
}

.airp-entity-title-open:hover,
.airp-entity-title-open:focus {
    color: var(--airp-primary-color);
    text-decoration: underline;
}

.airp-diary-character-count {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 2px 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: color-mix(in srgb, var(--airp-surface-color) 78%, var(--airp-primary-color));
    color: var(--airp-muted-text-color);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.4;
}

.airp-summary-next-update {
    display: inline-flex;
    align-items: center;
    margin: 8px 0 6px;
    padding: 4px 10px;
    border-radius: 999px;
    background: var(--airp-summary-badge-background-color);
    color: var(--airp-summary-badge-text-color);
    font-size: 0.84rem;
    font-weight: 700;
}

.airp-memory-source-badge {
    display: inline-flex;
    align-items: center;
    margin-left: 6px;
    padding: 2px 7px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 800;
    vertical-align: middle;
}

.airp-memory-source-badge.is-automatic {
    background: var(--airp-automatic-badge-background-color);
    color: var(--airp-automatic-badge-text-color);
}

.airp-memory-source-badge.is-manual {
    background: var(--airp-manual-badge-background-color);
    color: var(--airp-manual-badge-text-color);
}

.airp-diary-view p {
    margin-top: 0;
}

.airp-quest-sections {
    display: grid;
    gap: 10px;
    margin-top: 12px;
}

.airp-quest-section {
    padding: 12px 14px;
    border: 1px solid var(--airp-border-color);
    border-left: 4px solid var(--airp-primary-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-surface-color) 88%, var(--airp-diary-card-background-color));
}

.airp-quest-section h5 {
    margin: 0 0 7px;
    color: var(--airp-muted-text-color);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.airp-quest-section-body {
    color: var(--airp-text-color);
    font-size: 0.95rem;
    line-height: 1.55;
}

.airp-quest-section-body p {
    margin: 0 0 8px;
}

.airp-quest-section-body p:last-child {
    margin-bottom: 0;
}

.airp-quest-section-stato {
    border-left-color: var(--airp-success-color, var(--airp-primary-color));
}

.airp-quest-section-dettagli {
    border-left-color: var(--airp-warning-color, var(--airp-primary-color));
}

.airp-diary-edit-form {
    display: none;
}

.airp-diary-note-create-form:not([hidden]) {
    display: block;
    margin-bottom: 12px;
}

.airp-diary-entry.is-editing .airp-diary-view {
    display: none;
}

.airp-diary-entry.is-editing .airp-diary-edit-form {
    display: block;
}

.airp-diary-entry-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.airp-entity-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 12px;
}

.airp-entity-context-meta {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
}

.airp-context-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--airp-muted-text-color);
    font-size: 0.9em;
    white-space: nowrap;
}

#airp-diary-locations .airp-entity-context-meta .airp-switch-slider,
#airp-diary-npcs .airp-entity-context-meta .airp-switch-slider,
#airp-diary-factions .airp-entity-context-meta .airp-switch-slider,
#airp-diary-quests .airp-entity-context-meta .airp-switch-slider {
    background: var(--airp-danger-color);
}

#airp-diary-locations .airp-entity-context-meta .airp-switch input:checked + .airp-switch-slider,
#airp-diary-npcs .airp-entity-context-meta .airp-switch input:checked + .airp-switch-slider,
#airp-diary-factions .airp-entity-context-meta .airp-switch input:checked + .airp-switch-slider,
#airp-diary-quests .airp-entity-context-meta .airp-switch input:checked + .airp-switch-slider {
    background: var(--airp-success-color);
}

#airp-diary-locations .airp-entity-card.is-context-on .airp-diary-character-count,
#airp-diary-npcs .airp-entity-card.is-context-on .airp-diary-character-count,
#airp-diary-factions .airp-entity-card.is-context-on .airp-diary-character-count,
#airp-diary-quests .airp-entity-card.is-context-on .airp-diary-character-count {
    color: var(--airp-success-color);
}

#airp-diary-locations .airp-entity-card.is-context-off .airp-diary-character-count,
#airp-diary-npcs .airp-entity-card.is-context-off .airp-diary-character-count,
#airp-diary-factions .airp-entity-card.is-context-off .airp-diary-character-count,
#airp-diary-quests .airp-entity-card.is-context-off .airp-diary-character-count {
    color: var(--airp-danger-color);
}

.airp-diary-image-slot,
.airp-character-portrait-placeholder,
.airp-character-portrait-frame,
.airp-character-item-image-frame {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 130px;
    border: 1px dashed var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    color: var(--airp-muted-text-color);
    text-align: center;
}

.airp-diary-image-slot {
    width: 100%;
    min-height: auto;
    aspect-ratio: 1;
    overflow: hidden;
}

.airp-memory-image-control {
    display: grid;
    gap: 8px;
    align-content: start;
}

.airp-memory-image-open {
    display: block;
    position: relative;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: zoom-in;
    overflow: hidden;
    border-radius: calc(var(--airp-border-radius) / 2);
}

#airp-diary-locations .airp-entity-card.is-context-off .airp-memory-image-open::after,
#airp-diary-npcs .airp-entity-card.is-context-off .airp-memory-image-open::after,
#airp-diary-factions .airp-entity-card.is-context-off .airp-memory-image-open::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(128, 128, 128, 0.62);
    pointer-events: none;
}

.airp-memory-image-replace {
    min-height: 36px;
    border: 1px dashed var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    background: var(--airp-surface-color);
}

.airp-entity-lightbox .airp-memory-image-replace {
    display: inline-flex;
    width: auto;
    min-height: 0;
    margin-top: 12px;
    padding: 9px 14px;
    border-style: solid;
    border-color: var(--airp-primary-color);
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
    cursor: pointer;
}

.airp-entity-lightbox .airp-memory-image-replace:hover {
    background: var(--airp-secondary-color);
    border-color: var(--airp-secondary-color);
}

.airp-character-portrait-frame,
.airp-character-item-image-frame {
    width: 100%;
}

.airp-character-portrait-frame .airp-character-portrait-placeholder {
    width: 100%;
    min-height: auto;
    border: 0;
}

.airp-entity-open {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: zoom-in;
}

.airp-entity-title-open.airp-entity-open {
    display: inline;
    width: auto;
    cursor: pointer;
}

.airp-diary-actions .airp-entity-open {
    display: inline-flex;
    width: 36px;
    padding: 0;
    border: 1px solid var(--airp-border-color);
    background: var(--airp-surface-color);
}

.airp-diary-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: calc(var(--airp-border-radius) / 2);
}

.airp-summary-status {
    min-width: 74px;
    color: var(--airp-muted-text-color);
    font-size: 0.84rem;
    font-weight: 700;
    text-align: right;
}

.airp-switch {
    position: relative;
}

.airp-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.airp-switch-slider {
    width: 42px;
    height: 24px;
    border-radius: 999px;
    background: var(--airp-border-color);
    position: relative;
    transition: background 0.2s ease;
    flex: 0 0 auto;
}

.airp-switch-slider::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 5px rgba(15, 23, 42, 0.25);
    transition: transform 0.2s ease;
}

.airp-switch input:checked + .airp-switch-slider {
    background: var(--airp-primary-color);
}

.airp-switch input:checked + .airp-switch-slider::after {
    transform: translateX(18px);
}

.airp-character-sheet-grid {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: var(--airp-element-gap);
    align-items: start;
}

.airp-character-sheet-form.is-readonly .airp-character-edit-fields {
    display: none;
}

.airp-character-sheet-form:not(.is-readonly) .airp-character-readable {
    display: none;
}

.airp-character-edit-fields {
    display: grid;
    gap: 16px;
}

.airp-character-edit-fields > .airp-character-sheet-grid {
    border: 1px solid var(--airp-border-color);
    border-radius: 10px;
    padding: 16px;
    background: var(--airp-character-header-background-color);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.1);
}

.airp-character-edit-section {
    border: 1px solid var(--airp-border-color);
    border-radius: 10px;
    padding: 14px;
    background: var(--airp-character-section-background-color);
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.airp-character-edit-section > legend,
.airp-character-edit-section > h5 {
    margin: 0 0 10px;
    color: var(--airp-title-color);
    font-weight: 800;
}

.airp-character-skill-edit-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 8px;
}

.airp-character-skill-edit-grid .airp-label {
    max-width: 100%;
    overflow: hidden;
    font-size: clamp(0.58rem, 0.72vw, 0.74rem);
    line-height: 1.1;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-character-skill-edit-grid .airp-input {
    padding: 8px;
    text-align: center;
}

.airp-money-inline-input {
    width: 110px;
    min-height: 32px;
    margin: 0 4px;
    padding: 5px 8px;
}

.airp-character-readable {
    display: grid;
    gap: 16px;
}

.airp-character-readable-header {
    display: grid;
    grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
    gap: 18px;
    align-items: stretch;
    border: 1px solid var(--airp-border-color);
    border-radius: 10px;
    padding: 16px;
    background: var(--airp-character-header-background-color);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.1);
}

.airp-character-readable-header > .airp-character-portrait,
.airp-character-readable-header > .airp-character-portrait-placeholder {
    width: 100%;
    min-height: 220px;
    aspect-ratio: 1;
}

.airp-character-readable h4,
.airp-readable-section h5 {
    margin: 0 0 8px;
    color: var(--airp-title-color);
    font-weight: 800;
}

.airp-readable-section h5 {
    text-align: left;
}

.airp-character-readable h4 {
    font-size: 1.55em;
    line-height: 1.1;
    color: var(--airp-title-color);
}

.airp-character-title-level,
.airp-inventory-money-value {
    color: #fff;
}

.airp-character-progress-list {
    display: grid;
    gap: 10px;
}

.airp-character-profile-grid,
.airp-character-profile-edit-grid {
    display: grid;
    gap: 8px;
    margin-bottom: 14px;
}

.airp-character-profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.airp-character-profile-edit-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.airp-character-profile-grid span {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 7px 10px;
    background: var(--airp-character-section-background-color);
}

.airp-character-profile-grid strong {
    color: var(--airp-title-color);
    font-weight: 800;
}

.airp-character-profile-grid em {
    color: var(--airp-text-color);
    font-style: normal;
    font-weight: 800;
    text-align: right;
    overflow-wrap: anywhere;
}

.airp-character-progress-label {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 4px;
    font-size: 0.92em;
}

.airp-character-progress-label strong {
    color: var(--airp-title-color);
}

.airp-character-progress-track {
    height: 12px;
    overflow: hidden;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.12);
}

.airp-hp-track {
    background: var(--airp-hp-bar-background-color);
}

.airp-xp-track {
    background: var(--airp-xp-bar-background-color);
}

.airp-character-progress-fill {
    display: block;
    height: 100%;
    border-radius: inherit;
}

.airp-hp-fill {
    background: linear-gradient(90deg, var(--airp-hp-bar-start-color), var(--airp-hp-bar-color));
}

.airp-xp-fill {
    background: linear-gradient(90deg, var(--airp-xp-bar-start-color), var(--airp-xp-bar-color));
}

.airp-readable-section {
    border: 1px solid var(--airp-border-color);
    border-radius: 10px;
    padding: 14px;
    background: var(--airp-character-section-background-color);
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.airp-readable-section .airp-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 74px;
    margin: 0;
    border: 1px dashed var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-surface-color) 74%, transparent);
    text-align: center;
    font-weight: 700;
}

.airp-readable-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.airp-readable-section-header h5 {
    margin: 0;
}

.airp-inventory-money-label {
    white-space: nowrap;
}

.airp-character-accordion summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    cursor: pointer;
    color: var(--airp-title-color);
    font-weight: 800;
    list-style: none;
}

.airp-character-accordion summary::-webkit-details-marker {
    display: none;
}

.airp-character-accordion summary .dashicons {
    width: 20px;
    height: 20px;
    font-size: 20px;
    line-height: 1;
    flex: 0 0 auto;
}

.airp-character-accordion[open] .airp-accordion-icon-closed,
.airp-character-accordion:not([open]) .airp-accordion-icon-open {
    display: none;
}

.airp-character-accordion p {
    margin-bottom: 0;
}

.airp-readable-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 8px;
}

.airp-readable-stat-grid span {
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 8px 10px;
    background: rgba(15, 23, 42, 0.03);
    text-align: center;
}

.airp-readable-stat-grid strong,
.airp-readable-list strong,
.airp-item-card strong {
    color: var(--airp-title-color);
    font-weight: 800;
}

.airp-readable-stat-grid strong,
.airp-readable-stat-grid em {
    display: block;
}

.airp-readable-stat-grid em {
    margin-top: 4px;
    color: var(--airp-text-color);
    font-size: 1.35em;
    font-style: normal;
    font-weight: 800;
}

.airp-readable-list {
    margin: 0;
    padding-left: 0;
    list-style: none;
}

.airp-readable-list li {
    padding: 10px 0;
    border-bottom: 1px solid var(--airp-border-color);
}

.airp-readable-list li:last-child {
    border-bottom: 0;
}

.airp-campaign-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 0;
}

.airp-campaign-info-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.airp-info-field {
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 12px;
    background: var(--airp-surface-color);
}

.airp-info-field-wide {
    grid-column: 1 / -1;
}

.airp-info-field span {
    display: block;
    margin-bottom: 4px;
    color: var(--airp-muted-text-color);
    font-size: 0.85em;
    font-weight: 700;
}

.airp-info-field strong,
.airp-info-field p {
    margin: 0;
    line-height: 1.5;
}

.airp-plot-spine-viewer {
    margin-top: 0;
}

.airp-plot-spine-panel {
    margin-top: 12px;
    overflow-x: auto;
}

.airp-plot-spine-accordion {
    display: grid;
    gap: 8px;
}

.airp-plot-spine-item {
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
    overflow: hidden;
}

.airp-plot-spine-item-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    border: 0;
    padding: 10px;
    background: transparent;
    color: var(--airp-text-color);
    text-align: left;
    cursor: pointer;
}

.airp-plot-spine-item-title {
    display: grid;
    gap: 2px;
}

.airp-plot-spine-item-title strong {
    font-size: 1.1em;
}

.airp-plot-spine-item-title em {
    color: var(--airp-muted-text-color);
    font-style: normal;
}

.airp-plot-spine-item-title small {
    color: var(--airp-muted-text-color);
    font-size: 0.85em;
    font-weight: 700;
}

.airp-plot-spine-item-body {
    display: grid;
    gap: 10px;
    border-top: 1px solid var(--airp-border-color);
    padding: 10px;
}

.airp-plot-spine-item-body[hidden] {
    display: none;
}

.airp-plot-spine-detail-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
    color: var(--airp-muted-text-color);
    font-weight: 800;
}

.airp-plot-spine-content-text,
.airp-plot-spine-detail-grid p {
    margin: 0;
    white-space: pre-wrap;
}

.airp-plot-spine-content-edit {
    width: 100%;
    min-height: 90px;
}

.airp-plot-spine-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.airp-plot-spine-detail-grid > div {
    border: 1px solid var(--airp-border-color);
    border-radius: 6px;
    padding: 8px;
    background: rgba(255, 255, 255, 0.03);
}

.airp-plot-spine-detail-grid span {
    display: block;
    margin-bottom: 4px;
    color: var(--airp-muted-text-color);
    font-weight: 800;
}

@media (max-width: 720px) {
    .airp-plot-spine-detail-grid {
        grid-template-columns: 1fr;
    }
}

.airp-plot-spine-status {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 0.8em;
    font-weight: 800;
    white-space: nowrap;
}

.airp-plot-spine-status-hidden,
.airp-plot-spine-status-locked {
    background: #3a3f4b;
    color: #fff;
}

.airp-plot-spine-status-hinted,
.airp-plot-spine-status-available {
    background: #d89b1d;
    color: #19130a;
}

.airp-plot-spine-status-partially_revealed,
.airp-plot-spine-status-active {
    background: #2f80ed;
    color: #fff;
}

.airp-plot-spine-status-revealed,
.airp-plot-spine-status-completed {
    background: #2e9d5b;
    color: #fff;
}

.airp-plot-spine-empty {
    margin: 0;
    color: var(--airp-muted-text-color);
}

.airp-plot-spine-recovery {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 12px;
}

.airp-plot-spine-recovery-locked {
    margin-top: 10px;
}

.airp-item-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.airp-item-card {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    width: 100%;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    padding: 8px;
    background: var(--airp-surface-color);
    color: var(--airp-text-color);
    text-align: left;
    cursor: zoom-in;
    transition: border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}

.airp-item-card:hover,
.airp-item-card:focus {
    border-color: var(--airp-primary-color);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.1);
    transform: translateY(-1px);
}

.airp-item-card small {
    display: block;
    color: var(--airp-muted-text-color);
    line-height: 1.35;
}

.airp-item-thumb {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 8px;
    background: rgba(15, 23, 42, 0.08);
    overflow: hidden;
}

.airp-item-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.airp-lightbox {
    position: fixed;
    inset: 0;
    z-index: var(--airp-lightbox-z-index);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.airp-lightbox-backdrop {
    position: absolute;
    inset: 0;
    background: var(--airp-lightbox-backdrop-color);
    opacity: var(--airp-lightbox-backdrop-opacity);
}

.airp-lightbox-dialog {
    position: relative;
    z-index: 1;
    width: min(760px, 96vw);
    max-height: 90vh;
    overflow-y: auto;
    border-radius: 10px;
    background: var(--airp-lightbox-background-color);
    border: 1px solid var(--airp-border-color);
    color: var(--airp-text-color);
    padding: 20px;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.35);
}

.airp-memory-summary-dialog {
    width: min(1180px, 96vw);
}

.airp-confirm-dialog {
    width: min(440px, 94vw);
}

.airp-confirm-dialog p {
    margin: 0 0 18px;
    color: var(--airp-text-color);
}

.airp-history-gift-code td {
    background: color-mix(in srgb, var(--airp-success-color) 12%, transparent);
    font-weight: 700;
}

.airp-death-icon {
    display: grid;
    place-items: center;
    width: 72px;
    height: 72px;
    margin: 0 auto 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    color: #fff;
    background: #7f1d1d;
    font-size: 42px;
    line-height: 1;
}

.airp-death-host-note {
    margin-top: 10px;
    font-size: 0.9rem;
    color: var(--airp-muted-text-color);
}

.airp-death-token-count {
    text-align: center;
}

.airp-lightbox-dialog h3 {
    margin: 0 44px 14px 0;
}

.airp-memory-summary-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
}

.airp-memory-summary-grid h4 {
    margin: 0 0 8px;
}

.airp-memory-summary-original {
    max-height: 52vh;
    overflow-y: auto;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
    padding: 12px;
    background: var(--airp-chat-background-color);
}

.airp-lightbox-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.airp-character-item-type-label {
    display: inline-flex;
    align-items: center;
    margin-bottom: 6px;
    padding: 3px 8px;
    border-radius: 999px;
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-character-item-detail-layout {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 16px;
    align-items: start;
}

.airp-character-item-detail-image {
    margin-bottom: 0;
}

.airp-character-item-detail-body {
    display: grid;
    gap: 12px;
}

.airp-character-item-detail-body p {
    margin: 0;
    line-height: 1.55;
}

.airp-character-item-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.airp-character-item-meta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 9px;
    border: 1px solid var(--airp-border-color);
    border-radius: 999px;
    background: var(--airp-surface-color);
    color: var(--airp-muted-text-color);
    font-size: 0.86rem;
}

.airp-character-item-meta strong {
    color: var(--airp-title-color);
}

.airp-character-item-edit-form,
.airp-character-item-create-form {
    display: grid;
    gap: 10px;
}

.airp-character-item-edit-form[hidden],
.airp-character-item-view[hidden] {
    display: none;
}

.airp-character-item-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.airp-offgame-dialog {
    width: min(560px, 96vw);
}

.airp-offgame-chat {
    display: grid;
    gap: 12px;
}

.airp-offgame-messages {
    display: grid;
    gap: 8px;
    max-height: 46vh;
    overflow-y: auto;
    padding: 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-chat-background-color);
}

.airp-offgame-message {
    max-width: 86%;
    padding: 8px 10px;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
}

.airp-offgame-message.is-own {
    justify-self: end;
    background: color-mix(in srgb, var(--airp-primary-color) 14%, var(--airp-surface-color));
}

.airp-offgame-message-meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 4px;
    color: var(--airp-muted-text-color);
    font-size: 0.78rem;
}

.airp-offgame-message-content p {
    margin: 0;
}

.airp-offgame-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: end;
}

.airp-lightbox-image,
.airp-lightbox-empty {
    width: 100%;
    max-height: 420px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid var(--airp-border-color);
    margin-bottom: 14px;
}

.airp-lightbox-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    color: var(--airp-muted-text-color);
}

.airp-entity-lightbox-image-frame {
    width: min(100%, 520px);
    aspect-ratio: 1;
    margin: 0 auto 14px;
    overflow: hidden;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
}

.airp-entity-lightbox-image-frame .airp-lightbox-image,
.airp-entity-lightbox-image-frame .airp-lightbox-empty {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    max-height: none;
    margin-bottom: 0;
    border: 0;
    border-radius: 0;
}

.airp-entity-lightbox-image-frame .airp-lightbox-image {
    display: block;
    object-fit: cover;
}

.airp-diary-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.airp-diary-title-input {
    max-width: 360px;
}

.airp-character-portrait-field,
.airp-character-main-fields {
    display: grid;
    gap: 10px;
}

.airp-character-portrait {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border: 1px solid var(--airp-border-color);
    border-radius: calc(var(--airp-border-radius) / 2);
}

.airp-character-item-image-frame img {
    display: block;
    width: 100%;
    max-height: 180px;
    object-fit: cover;
    border-radius: calc(var(--airp-border-radius) / 2);
}

.airp-roll-history-list {
    display: grid;
    gap: 10px;
}

.airp-roll-history-item {
    display: grid;
    grid-template-columns: 42px minmax(105px, 140px) minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    width: 100%;
    padding: 12px;
    border: 1px solid var(--airp-border-color);
    border-left: 4px solid var(--airp-player-bubble-color, var(--airp-accent-color));
    background: color-mix(in srgb, var(--airp-surface-color) 94%, var(--airp-player-bubble-color, var(--airp-accent-color)));
    color: inherit;
    text-align: left;
    cursor: pointer;
    font: inherit;
    border-radius: 8px;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.06);
    transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}

.airp-roll-history-avatar {
    width: 38px;
    height: 38px;
}

.airp-roll-history-roll,
.airp-roll-history-meta {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.airp-roll-history-roll strong {
    font-size: 1.08em;
    font-weight: 900;
}

.airp-roll-history-roll small,
.airp-roll-history-meta small {
    color: var(--airp-muted-text-color);
    font-size: 0.86em;
}

.airp-roll-history-meta span {
    overflow-wrap: anywhere;
}

.airp-roll-history-item:hover,
.airp-roll-history-item:focus-visible {
    border-color: var(--airp-player-bubble-color, var(--airp-primary-color));
    background: color-mix(in srgb, var(--airp-primary-color) 10%, var(--airp-surface-color));
    transform: translateY(-1px);
    outline: none;
}

.airp-roll-history-item.is-critical-success {
    background: color-mix(in srgb, var(--airp-success-color) 12%, var(--airp-surface-color));
    border-color: var(--airp-success-color);
    color: var(--airp-success-color);
}

.airp-roll-history-item.is-critical-failure {
    background: color-mix(in srgb, var(--airp-danger-color) 10%, var(--airp-surface-color));
    border-color: var(--airp-danger-color);
    color: var(--airp-danger-color);
}

.airp-roll-history-item.is-critical-success strong,
.airp-roll-history-item.is-critical-failure strong {
    font-weight: 900;
}

.airp-roll-history-item:disabled {
    cursor: not-allowed;
    opacity: 0.58;
    transform: none;
}

.airp-objective-dialog {
    width: min(1040px, 96vw);
    max-width: none;
}

.airp-objective-dialog h3 {
    margin-top: 0;
}

.airp-objective-host-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

.airp-objective-new-adventure-form {
    display: grid;
    gap: 10px;
    margin-top: 16px;
}

.airp-new-adventure-central-cards,
.airp-new-adventure-memory-group {
    display: grid;
    gap: 8px;
}

.airp-new-adventure-memory-group {
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: color-mix(in srgb, var(--airp-surface-color) 92%, var(--airp-chat-background-color));
    padding: 0;
    overflow: hidden;
}

.airp-new-adventure-memory-group summary {
    align-items: center;
    cursor: pointer;
    display: flex;
    gap: 8px;
    justify-content: space-between;
    list-style: none;
    padding: 11px 12px;
    font-weight: 800;
}

.airp-new-adventure-memory-group summary::-webkit-details-marker {
    display: none;
}

.airp-new-adventure-memory-group summary::after {
    content: "\f347";
    color: var(--airp-muted-text-color);
    font-family: dashicons;
    font-size: 18px;
    font-weight: 400;
    line-height: 1;
}

.airp-new-adventure-memory-group[open] summary::after {
    content: "\f343";
}

.airp-new-adventure-memory-group summary small {
    color: var(--airp-muted-text-color);
    font-size: 0.78rem;
    font-weight: 700;
}

.airp-new-adventure-memory-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    padding: 0 12px 12px;
}

.airp-new-adventure-memory-card {
    position: relative;
    cursor: pointer;
    min-width: 0;
}

.airp-new-adventure-memory-input {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
}

.airp-new-adventure-memory-card-inner {
    position: relative;
    display: grid;
    min-width: 0;
    aspect-ratio: 1;
    border: 1px solid var(--airp-border-color);
    border-radius: 8px;
    background: var(--airp-surface-color);
    overflow: hidden;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.airp-new-adventure-memory-card:hover .airp-new-adventure-memory-card-inner,
.airp-new-adventure-memory-card:focus-within .airp-new-adventure-memory-card-inner {
    border-color: color-mix(in srgb, var(--airp-primary-color) 56%, var(--airp-border-color));
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.12);
    transform: translateY(-1px);
}

.airp-new-adventure-memory-card.is-selected .airp-new-adventure-memory-card-inner {
    border-color: var(--airp-primary-color);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--airp-primary-color) 24%, transparent);
}

.airp-new-adventure-memory-card.is-selected .airp-new-adventure-memory-card-inner::after {
    content: "\f147";
    position: absolute;
    top: 8px;
    right: 8px;
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
    font-family: dashicons;
    font-size: 18px;
    line-height: 1;
}

.airp-new-adventure-memory-card-image {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    background: var(--airp-chat-background-color);
    color: var(--airp-muted-text-color);
    overflow: hidden;
}

.airp-new-adventure-memory-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.airp-new-adventure-memory-card-image .dashicons {
    width: 34px;
    height: 34px;
    font-size: 34px;
}

.airp-new-adventure-memory-card-title {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    display: -webkit-box;
    min-height: 48px;
    padding: 22px 9px 9px;
    color: #fff;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.72), rgba(0, 0, 0, 0));
    font-size: 0.88rem;
    font-weight: 800;
    line-height: 1.2;
    overflow: hidden;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.62);
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    word-break: break-word;
}

@media (max-width: 900px) {
    .airp-new-adventure-memory-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .airp-objective-dialog {
        width: min(100%, 96vw);
    }
}

.airp-plot-spine-archives {
    display: grid;
    gap: 8px;
    margin-top: 10px;
}

.airp-plot-spine-archive-json {
    max-height: 420px;
    overflow: auto;
    white-space: pre-wrap;
}

.airp-chat-message-highlight {
    animation: airpMessageHighlight 1.8s ease;
}

@keyframes airpMessageHighlight {
    0%,
    100% {
        box-shadow: none;
    }

    20%,
    70% {
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--airp-primary-color) 36%, transparent);
    }
}

.airp-chat-message-content p:last-child,
.airp-panel-content p:last-child {
    margin-bottom: 0;
}

.airp-panel-title {
    font-size: 18px;
}

.airp-character-stat-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin: 0;
}

.airp-character-vital-list {
    margin-bottom: 12px;
}

.airp-character-stat-item {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    border-bottom: 1px solid var(--airp-border-color);
    padding-bottom: 6px;
}

.airp-character-stat-item dt {
    font-weight: 700;
}

.airp-character-stat-item dd {
    margin: 0;
    color: var(--airp-muted-text-color);
    font-weight: 800;
}

.airp-character-skill-list {
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.airp-character-skill-list .airp-character-stat-item {
    display: grid;
    gap: 3px;
    justify-items: center;
    text-align: center;
}

.airp-character-skill-list .airp-character-stat-item dt {
    max-width: 100%;
    overflow: hidden;
    font-size: clamp(0.58rem, 0.72vw, 0.74rem);
    line-height: 1.1;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-character-skill-list .airp-character-stat-item dd {
    font-size: 0.9rem;
}

.airp-readable-skill-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 8px;
}

.airp-readable-skill-grid span {
    display: grid;
    gap: 3px;
    justify-items: center;
    border-bottom: 1px solid var(--airp-border-color);
    padding-bottom: 6px;
    text-align: center;
}

.airp-readable-skill-grid strong {
    max-width: 100%;
    overflow: hidden;
    font-size: clamp(0.58rem, 0.72vw, 0.74rem);
    line-height: 1.1;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.airp-readable-skill-grid em {
    color: var(--airp-muted-text-color);
    font-style: normal;
    font-weight: 800;
}

.airp-character-inventory-item,
.airp-character-equipment-item,
.airp-character-ability-item,
.airp-character-trait-item {
    padding: 10px 0;
    border-bottom: 1px solid var(--airp-border-color);
}

.airp-character-inventory-item:last-child,
.airp-character-equipment-item:last-child,
.airp-character-ability-item:last-child,
.airp-character-trait-item:last-child {
    border-bottom: 0;
}

.airp-ability-uses {
    display: block;
    margin-top: 4px;
    color: var(--airp-muted-text-color);
    font-size: 0.9em;
    font-weight: 700;
}

.airp-character-equipment-slot {
    display: inline-block;
    margin: 0 0 5px;
    padding: 2px 7px;
    border-radius: 999px;
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
    font-size: 0.75em;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-memory-item {
    padding: 10px 0;
    border-bottom: 1px solid var(--airp-border-color);
}

.airp-memory-item:last-child {
    border-bottom: 0;
}

.airp-memory-item-type {
    display: inline-block;
    margin-bottom: 4px;
    padding: 2px 7px;
    border-radius: 999px;
    background: var(--airp-primary-color);
    color: var(--airp-button-text-color);
    font-size: 0.75em;
    font-weight: 800;
    text-transform: uppercase;
}

.airp-memory-item-title {
    display: block;
    color: var(--airp-text-color);
}

.airp-memory-item-content {
    color: var(--airp-muted-text-color);
    margin: 5px 0 0;
}

.airp-alert {
    padding: 12px;
    border-radius: calc(var(--airp-border-radius) / 2);
    border: 1px solid var(--airp-border-color);
}

.airp-alert-error {
    background: var(--airp-danger-color);
    color: var(--airp-button-text-color);
}

.airp-login-required {
    max-width: 760px;
    margin: 0 auto;
    padding: var(--airp-general-padding);
    border: 1px solid var(--airp-border-color);
    border-radius: var(--airp-border-radius);
    background: var(--airp-panel-background-color);
}

.airp-xp-review-button.is-confirmed {
    background: #247a3d;
    border-color: #56b46f;
    color: #fff;
}

.airp-xp-dialog {
    max-width: 760px;
}

.airp-xp-total {
    margin: 0 0 14px;
    color: var(--airp-text-color);
}

.airp-xp-step {
    display: none;
}

.airp-xp-step.is-active {
    display: block;
}

.airp-xp-character-head {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: 72px 1fr;
    margin-bottom: 16px;
}

.airp-xp-character-head img,
.airp-xp-character-head > .dashicons {
    align-items: center;
    aspect-ratio: 1;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(212, 175, 55, 0.32);
    border-radius: 8px;
    display: flex;
    font-size: 34px;
    height: 72px;
    justify-content: center;
    object-fit: cover;
    width: 72px;
}

.airp-xp-character-head h4 {
    color: var(--airp-title-color);
    margin: 0;
}

.airp-xp-character-head p,
.airp-xp-character-head small {
    display: block;
    margin: 4px 0;
}

.airp-xp-bar {
    background: rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    height: 10px;
    overflow: hidden;
}

.airp-xp-bar span {
    background: #d7b13f;
    display: block;
    height: 100%;
}

.airp-xp-stat-points {
    color: var(--airp-title-color);
    font-weight: 700;
    margin-bottom: 12px;
}

.airp-xp-stat-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.airp-xp-stat-row {
    align-items: center;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(212, 175, 55, 0.22);
    border-radius: 8px;
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr auto auto;
    padding: 10px;
}

.airp-xp-events {
    display: grid;
    gap: 10px;
    list-style: none;
    margin: 0 0 16px;
    padding: 0;
}

.airp-xp-events li {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(212, 175, 55, 0.32);
    border-radius: 8px;
    padding: 12px;
}

.airp-xp-events strong,
.airp-xp-events span {
    display: block;
}

.airp-xp-events span {
    color: var(--airp-title-color);
    font-size: 0.9rem;
    margin-top: 4px;
}

.airp-xp-events p {
    margin: 8px 0 0;
}

.airp-xp-participants {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 12px 0;
}

.airp-xp-participant {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    color: var(--airp-text-color);
    font: inherit;
    padding: 5px 10px;
}

.airp-xp-manage-participant {
    cursor: pointer;
}

.airp-xp-participant.is-active {
    border-color: var(--airp-accent-color);
}

.airp-xp-participant.is-confirmed {
    border-color: #56b46f;
    color: #8fe0a3;
}

.airp-xp-timer {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.9rem;
}

.airp-rephrase-narrator-button {
    bottom: 8px;
    position: absolute;
    right: 8px;
}

.airp-message-reading-button {
    bottom: 8px;
    position: absolute;
    right: 48px;
}

.airp-message-reading-button-solo {
    right: 8px;
}

.airp-message-reading-player {
    display: grid;
    gap: 8px;
    align-items: center;
    width: min(100%, 420px);
    margin-top: 12px;
    padding-right: 86px;
}

.airp-message-reading-player-label {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    gap: 6px;
    border: 1px solid color-mix(in srgb, var(--airp-accent-color) 42%, var(--airp-border-color));
    border-radius: 999px;
    padding: 4px 10px;
    background: color-mix(in srgb, var(--airp-surface-color) 72%, transparent);
    color: var(--airp-accent-color);
    font-weight: 800;
}

.airp-message-reading-player-label .dashicons {
    width: 16px;
    height: 16px;
    font-size: 16px;
}

.airp-message-reading-player-label small {
    opacity: 0.72;
    font-size: 0.78rem;
}

.airp-message-reading-player audio {
    display: block;
    width: 100%;
    height: 36px;
    border: 1px solid color-mix(in srgb, var(--airp-accent-color) 32%, var(--airp-border-color));
    border-radius: 999px;
    padding: 2px;
    background: color-mix(in srgb, var(--airp-surface-color) 82%, var(--airp-chat-background-color));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--airp-accent-color) 12%, transparent);
    color-scheme: dark;
}

.airp-chat-message-ai {
    position: relative;
}

.airp-rephrase-dialog {
    max-width: 520px;
}

@media (max-width: 1024px) {
    .airp-account-type-box,
    .airp-account-type-actions {
        align-items: stretch;
        flex-direction: column;
        text-align: center;
    }

    .airp-account-type-actions {
        margin-left: 0;
    }

    .airp-account-type-current {
        justify-items: center;
    }

    .airp-billing-dialog {
        width: min(95vw, 720px) !important;
        max-width: 95vw !important;
    }

    .airp-billing-switch {
        flex-wrap: wrap;
        text-align: center;
    }

    .airp-pricing-table-wrap {
        display: none;
    }

    .airp-pricing-mobile-plans {
        display: grid;
        gap: 12px;
        justify-items: center;
    }

    .airp-pricing-mobile-plan {
        width: min(100%, 420px);
    }

    .airp-one-shot-products {
        width: min(100%, 420px);
        margin-right: auto;
        margin-left: auto;
    }

    .airp-game-layout,
    .airp-two-columns,
    .airp-campaigns-layout {
        grid-template-columns: 1fr;
    }

    .airp-combat-grid {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        overflow-y: auto;
    }

    .airp-combat-column {
        min-height: auto;
    }

    .airp-modal-dialog.airp-combat-dialog {
        width: min(100%, calc(100vw - 16px));
        max-height: calc(100vh - 16px);
    }

    .airp-combat-dialog .airp-modal-body {
        padding: 12px;
    }

    .airp-combat-arena {
        grid-template-columns: 1fr;
    }

    .airp-combatant {
        width: 100%;
        min-width: 0;
        max-width: none;
    }

    .airp-combat-arena-divider {
        height: 2px;
        background: linear-gradient(90deg, transparent, var(--airp-accent-color), transparent);
    }

    .airp-combat-log {
        min-height: 220px;
        height: auto;
    }

    .airp-combat-choice-row .airp-button,
    .airp-combat-action-stage .airp-button {
        flex: 1 1 150px;
    }

    .airp-combat-choice-tiles {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .airp-chat-message {
        max-width: 100%;
    }

    .airp-game-heading .airp-game-title {
        font-size: 22px;
    }

    .airp-game-sidebar {
        order: 2;
        position: static;
    }

    .airp-main-panel {
        order: 1;
    }

    .airp-sidebar-dice-section {
        display: grid;
        order: 1;
    }

    .airp-game-sidebar > .airp-sidebar-section:first-child {
        order: 2;
    }

    .airp-fullscreen-toggle {
        display: none;
    }

    .airp-chat-input-wrapper > .airp-dice-panel {
        display: none;
    }

    .airp-dice-panel {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .airp-character-form .airp-inventory-list {
        grid-template-columns: 1fr;
    }

    .airp-chat-input-wrapper {
        grid-template-columns: 1fr;
    }

    .airp-chat-input-wrapper .airp-player-action {
        order: 1;
    }

    .airp-chat-input-wrapper .airp-dictation-button,
    .airp-chat-input-wrapper .airp-chat-submit,
    .airp-chat-input-wrapper .airp-pass-turn-button,
    .airp-chat-input-wrapper .airp-quota-badge {
        order: 2;
    }

    .airp-quota-badge {
        white-space: normal;
    }

    .airp-one-shot-products {
        grid-template-columns: 1fr;
    }

    .airp-one-shot-product-row {
        align-items: stretch;
        grid-template-columns: 1fr;
    }

    .airp-context-size-inline {
        display: none;
    }

    .airp-game-wrapper > .airp-context-size {
        display: grid;
        justify-items: center;
        gap: 2px;
        margin-top: var(--airp-element-gap);
        text-align: center;
    }

    .airp-chat-messages {
        min-height: 360px;
    }

    .airp-game-header-actions {
        justify-content: flex-start;
    }

    .airp-campaign-item-main,
    .airp-modal-header {
        align-items: stretch;
    }

    .airp-character-stats-grid,
    .airp-character-vitals-grid,
    .airp-uses-grid,
    .airp-character-stat-list,
    .airp-readable-skill-grid,
    .airp-character-skill-edit-grid,
    .airp-character-sheet-grid,
    .airp-campaign-info-stack,
    .airp-memory-summary-grid,
    .airp-character-guided-grid,
    .airp-character-guided-card,
    .airp-character-readable-header,
    .airp-diary-entry,
    .airp-roll-history-item {
        grid-template-columns: 1fr;
    }

    .airp-roll-history-item {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .airp-roll-history-meta {
        grid-column: 2;
    }

    .airp-narrator-avatar-field {
        grid-template-columns: 1fr;
        justify-items: start;
    }

    .airp-item-card-grid {
        grid-template-columns: 1fr;
    }

    .airp-character-item-detail-layout {
        grid-template-columns: 1fr;
    }

    .airp-entity-card-footer {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 700px) {
    #airp-diary-locations .airp-entity-card,
    #airp-diary-npcs .airp-entity-card,
    #airp-diary-factions .airp-entity-card {
        padding: 10px 12px;
    }

    #airp-diary-locations .airp-entity-card > .airp-memory-image-control,
    #airp-diary-npcs .airp-entity-card > .airp-memory-image-control,
    #airp-diary-factions .airp-entity-card > .airp-memory-image-control,
    #airp-diary-locations .airp-entity-card > .airp-diary-image-slot,
    #airp-diary-npcs .airp-entity-card > .airp-diary-image-slot,
    #airp-diary-factions .airp-entity-card > .airp-diary-image-slot,
    #airp-diary-locations .airp-entity-card .airp-diary-view > p,
    #airp-diary-npcs .airp-entity-card .airp-diary-view > p,
    #airp-diary-factions .airp-entity-card .airp-diary-view > p,
    #airp-diary-locations .airp-entity-card .airp-entity-card-footer,
    #airp-diary-npcs .airp-entity-card .airp-entity-card-footer,
    #airp-diary-factions .airp-entity-card .airp-entity-card-footer {
        display: none;
    }

    #airp-diary-locations .airp-entity-title-open,
    #airp-diary-npcs .airp-entity-title-open,
    #airp-diary-factions .airp-entity-title-open {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 8px 0;
        text-decoration: none;
    }

    #airp-diary-locations .airp-entity-title-open::after,
    #airp-diary-npcs .airp-entity-title-open::after {
        content: "\f177";
        color: var(--airp-muted-text-color);
        flex: 0 0 auto;
        font-family: dashicons;
        font-size: 18px;
        font-weight: 400;
        line-height: 1;
    }

    .airp-character-profile-grid {
        grid-template-columns: 1fr;
    }

    .airp-campaigns-list-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }

    .airp-campaigns-list-actions .airp-button {
        min-height: 46px;
        padding: 8px 10px;
        font-size: 0.82em;
        line-height: 1.15;
    }

    .airp-campaigns-list-actions .dashicons {
        font-size: 17px;
        width: 17px;
        height: 17px;
    }

    .airp-spectator-code-button .airp-button-label-full {
        display: none;
    }

    .airp-spectator-code-button .airp-button-label-mobile {
        display: inline;
    }

    .airp-campaign-tab {
        min-height: 66px;
        padding: 8px 6px;
    }

    .airp-campaign-tab-label {
        font-size: 0.82em;
    }

    .airp-campaign-tab-hint {
        font-size: 0.7em;
    }

    .airp-campaign-item-main {
        flex-direction: column;
        align-items: stretch;
    }

    .airp-campaign-item-link {
        width: 100%;
    }

    .airp-campaign-item-title,
    .airp-campaign-item-meta {
        overflow-wrap: anywhere;
    }

    .airp-campaign-item-main .airp-item-actions {
        width: 100%;
        justify-content: flex-start;
        padding-top: 4px;
    }

    .airp-campaign-item-main .airp-inline-delete-form {
        display: inline-flex;
    }
}
