:root {
    --apg-airbnb: #ff5a5f;
    --apg-page: #fff9f9;
    --apg-ink: #111111;
    --apg-card: #ffffff;
    --apg-yellow: #facc15;
    --apg-green: #34d399;
    --apg-shadow-sm: 4px 4px 0 var(--apg-ink);
    --apg-shadow: 8px 8px 0 var(--apg-ink);
    --apg-shadow-lg: 12px 12px 0 var(--apg-ink);
    --font-sans: 'Inter', ui-sans-serif, system-ui, sans-serif;
    --font-display: 'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
}

* {
    box-sizing: border-box;
}

[hidden] {
    display: none !important;
}

body {
    min-height: 100vh;
    margin: 0;
    background:
        radial-gradient(circle at 10% 12%, rgba(255, 90, 95, 0.16), transparent 24rem),
        linear-gradient(135deg, #fff9f9 0%, #fff4df 100%);
    color: var(--apg-ink);
    font-family: var(--font-sans);
}

body.game-result-open {
    overflow: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input {
    font: inherit;
}

h1,
h2,
h3,
.apg-display {
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.apg-shell {
    width: 95%;
    margin-inline: auto;
    padding-block: 2rem;
}

.apg-navbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 2.5rem;
    padding: 1.25rem;
    background: var(--apg-card);
    border: 4px solid var(--apg-ink);
    border-radius: 1.5rem;
    box-shadow: var(--apg-shadow);
}

.apg-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.apg-logo {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: var(--apg-airbnb);
    color: white;
}

.apg-accent {
    color: var(--apg-airbnb);
}

.apg-card,
.apg-card-lg {
    background: var(--apg-card);
    border: 4px solid var(--apg-ink);
}

.apg-card {
    border-radius: 2rem;
    box-shadow: var(--apg-shadow);
}

.apg-card-lg {
    border-radius: 2.5rem;
    box-shadow: var(--apg-shadow);
}

.apg-panel {
    background: var(--apg-airbnb);
    border: 4px solid var(--apg-ink);
    border-radius: 2.5rem;
    box-shadow: var(--apg-shadow);
}

.apg-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1.25rem;
    background: white;
    color: var(--apg-ink);
    box-shadow: 0 6px 0 var(--apg-ink);
    cursor: pointer;
    font-family: var(--font-display);
    font-weight: 900;
    text-transform: uppercase;
    transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease;
}

.apg-button:hover {
    background: var(--apg-yellow);
}

.apg-button:active {
    transform: translateY(6px);
    box-shadow: 0 0 0 var(--apg-ink);
}

.apg-audio-unlock {
    position: fixed;
    right: clamp(1rem, 3vw, 2rem);
    bottom: clamp(1rem, 3vw, 2rem);
    z-index: 60;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 3.25rem;
    padding: 0.65rem 1rem;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: var(--apg-yellow);
    color: var(--apg-ink);
    box-shadow: var(--apg-shadow);
    cursor: pointer;
    font-family: var(--font-display);
    font-weight: 900;
    text-transform: uppercase;
    transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease;
}

.apg-audio-unlock:hover {
    background: white;
    transform: translate(-0.12rem, -0.12rem);
}

.apg-audio-unlock:active {
    transform: translate(0.25rem, 0.25rem);
    box-shadow: var(--apg-shadow-sm);
}

.apg-audio-unlock-icon {
    display: grid;
    width: 2rem;
    height: 2rem;
    place-items: center;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: white;
    line-height: 1;
}

.apg-cookie-banner {
    position: fixed;
    right: clamp(1rem, 3vw, 2rem);
    bottom: clamp(1rem, 3vw, 2rem);
    left: clamp(1rem, 3vw, 2rem);
    z-index: 70;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    width: min(100% - 2rem, 64rem);
    margin-inline: auto;
    padding: 1rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1.5rem;
    background: white;
    box-shadow: var(--apg-shadow-lg);
}

.apg-cookie-copy {
    display: grid;
    gap: 0.35rem;
    min-width: 0;
}

.apg-cookie-copy strong,
.apg-cookie-panel-heading h2,
.apg-cookie-toggle strong {
    font-family: var(--font-display);
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.apg-cookie-copy strong {
    font-size: clamp(1.25rem, 2vw, 1.7rem);
}

.apg-cookie-copy p,
.apg-cookie-panel-heading p,
.apg-cookie-toggle small {
    margin: 0;
    color: #475569;
    font-weight: 800;
    line-height: 1.35;
}

.apg-cookie-actions,
.apg-cookie-modal-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: flex-end;
}

.apg-cookie-button {
    min-height: 3rem;
    padding-inline: 0.9rem;
    border-width: 3px;
    border-radius: 1rem;
    box-shadow: 0 5px 0 var(--apg-ink);
    font-size: 0.9rem;
}

.apg-cookie-accept {
    background: var(--apg-yellow);
}

.apg-cookie-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: grid;
    place-items: center;
    padding: clamp(1rem, 4vw, 2rem);
}

.apg-cookie-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(17, 17, 17, 0.58);
    backdrop-filter: blur(8px);
}

.apg-cookie-panel {
    position: relative;
    z-index: 1;
    display: grid;
    width: min(100%, 42rem);
    gap: 1rem;
    padding: clamp(1rem, 3vw, 1.5rem);
    border: 4px solid var(--apg-ink);
    border-radius: 1.75rem;
    background: linear-gradient(135deg, white, #fff8df);
    box-shadow: var(--apg-shadow-lg);
}

.apg-cookie-panel-heading {
    display: grid;
    gap: 0.65rem;
}

.apg-cookie-panel-heading h2 {
    margin: 0;
    font-size: clamp(2rem, 5vw, 3.5rem);
}

.apg-cookie-toggle-list {
    display: grid;
    gap: 0.75rem;
}

.apg-cookie-toggle {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 0.9rem;
    border: 3px solid var(--apg-ink);
    border-radius: 1.1rem;
    background: white;
    box-shadow: var(--apg-shadow-sm);
}

.apg-cookie-toggle span:first-child {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
}

.apg-cookie-toggle input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
}

.apg-cookie-toggle input:disabled + .settings-switch {
    opacity: 0.7;
}

.apg-cookie-toggle input:checked + .settings-switch {
    background: var(--apg-green);
}

.apg-cookie-toggle input:checked + .settings-switch::after {
    transform: translateX(2.25rem);
}

.apg-cookie-banner ~ .apg-audio-unlock {
    display: none;
}

.apg-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.85rem;
    border: 2px solid var(--apg-ink);
    border-radius: 999px;
    background: white;
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
}

.apg-stat {
    display: flex;
    min-width: 6rem;
    flex-direction: column;
    align-items: center;
    padding: 0.5rem 1rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1rem;
    box-shadow: var(--apg-shadow-sm);
    font-weight: 900;
}

.apg-stat-label {
    font-size: 0.65rem;
    line-height: 1;
    text-transform: uppercase;
    opacity: 0.6;
}

.apg-stat-value {
    font-size: 1.25rem;
    line-height: 1.2;
}

.apg-header-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.game-music-toggle {
    display: inline-flex;
    min-height: 2.6rem;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.7rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: var(--apg-ink);
    box-shadow: 3px 3px 0 var(--apg-ink);
    cursor: pointer;
    font-family: var(--font-display);
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
    transition: transform 120ms ease, box-shadow 120ms ease, opacity 120ms ease;
}

.game-music-toggle:hover {
    transform: translate(-1px, -1px);
    box-shadow: 4px 4px 0 var(--apg-ink);
}

.game-music-toggle:active {
    transform: translate(3px, 3px);
    box-shadow: 0 0 0 var(--apg-ink);
}

.game-music-toggle[data-enabled='false'] {
    opacity: 0.62;
}

.game-music-toggle-icon {
    display: grid;
    width: 1.35rem;
    height: 1.35rem;
    place-items: center;
    border: 2px solid var(--apg-ink);
    border-radius: 999px;
    background: var(--apg-yellow);
    font-size: 0.9rem;
    line-height: 1;
}

.game-progress {
    --game-progress: 0%;
    display: grid;
    min-width: min(17rem, 42vw);
    gap: 0.45rem;
    padding: 0.55rem 0.75rem 0.65rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1rem;
    background: white;
    box-shadow: var(--apg-shadow-sm);
}

.game-progress-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.game-progress-value {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 900;
    line-height: 1;
}

.game-progress-track {
    position: relative;
    height: 0.75rem;
    overflow: hidden;
    border: 2px solid var(--apg-ink);
    border-radius: 999px;
    background: #fff4df;
}

.game-progress-fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: var(--game-progress);
    border-right: 2px solid var(--apg-ink);
    border-radius: inherit;
    background: linear-gradient(90deg, var(--apg-airbnb), var(--apg-yellow));
    transition: width 220ms ease;
}

.apg-input {
    width: 100%;
    border: 4px solid var(--apg-ink);
    border-radius: 1.25rem;
    background: white;
    padding: 0.875rem 1rem;
    font-weight: 800;
    box-shadow: var(--apg-shadow-sm);
}

.apg-input:focus {
    outline: 3px solid var(--apg-yellow);
    outline-offset: 2px;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    margin: 0;
    -webkit-appearance: none;
}

.game-grid {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(20rem, 0.85fr);
    gap: 2rem;
    align-items: start;
}

.game-listing {
    overflow: hidden;
}

.game-photo-wrap {
    position: relative;
    height: 28rem;
    background: var(--apg-yellow);
    border-bottom: 4px solid var(--apg-ink);
    overflow: hidden;
}

.game-photo-track {
    display: flex;
    width: 100%;
    height: 100%;
    pointer-events: none;
    transform: translate3d(0, 0, 0);
    transition: transform 260ms cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}

.game-photo-slide {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    background: var(--apg-yellow);
}

.game-photo {
    display: block;
    height: 100%;
    width: auto;
    max-width: none;
    pointer-events: none;
}

.game-photo-slide.is-broken::after {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 2rem;
    background: var(--apg-yellow);
    color: var(--apg-ink);
    content: "Photo impossible a charger";
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
}

.game-photo-placeholder {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 2rem;
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
}

.game-photo-badges {
    position: absolute;
    top: 1.25rem;
    left: 1.25rem;
    z-index: 3;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    pointer-events: none;
}

.game-photo-capacity {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    z-index: 3;
    pointer-events: none;
}

.game-photo-count {
    position: absolute;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 3;
    pointer-events: none;
}

.game-listing-body {
    padding: 1.25rem;
}

.game-details {
    display: grid;
    gap: 0.55rem;
}

.game-title {
    margin: 0 0 0.9rem;
    line-height: 0.92;
}

.game-property-type,
.game-location-subtitle,
.game-stay-dates {
    margin: 0;
}

.game-property-type {
    color: var(--apg-airbnb);
    font-size: 0.85rem;
    font-weight: 900;
    text-transform: uppercase;
}

.game-location-subtitle {
    color: #334155;
    font-size: 0.95rem;
    font-weight: 800;
}

.game-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
    color: #475569;
    font-weight: 900;
    text-transform: uppercase;
}

.game-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.game-stay-dates {
    color: #475569;
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.game-sub-items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.game-sub-item {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.25rem 0.7rem;
    border: 2px solid var(--apg-ink);
    border-radius: 999px;
    background: rgba(255, 90, 95, 0.08);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.game-panel {
    grid-column: 1 / -1;
    display: grid;
    min-height: auto;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.42fr);
    align-items: center;
    gap: 1.25rem;
    padding: 1rem;
}

.game-panel-guess {
    display: grid;
    grid-template-columns: minmax(10rem, 0.45fr) minmax(16rem, 1fr);
    align-items: center;
    gap: 0.85rem;
}

.game-panel-actions {
    min-width: 0;
}

.game-map-card {
    overflow: hidden;
}

.game-map-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
    border-bottom: 4px solid var(--apg-ink);
}

.game-map-title {
    margin: 0;
    font-size: clamp(1.2rem, 2vw, 1.6rem);
    line-height: 0.95;
}

.game-map-subtitle {
    margin-top: 0.4rem;
    color: #475569;
    font-size: 0.8rem;
    font-weight: 900;
    text-transform: uppercase;
}

.game-map-wrap {
    position: relative;
    min-height: 18rem;
    background: var(--apg-yellow);
}

.game-map {
    width: 100%;
    min-height: 18rem;
    height: clamp(18rem, 34vw, 26rem);
    z-index: 1;
}

.game-map-empty {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 1.5rem;
    background: var(--apg-yellow);
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
}

.game-panel-title {
    margin: 0;
    color: white;
    font-size: clamp(1.45rem, 2.5vw, 2.2rem);
    line-height: 0.95;
}

.game-panel-entry {
    display: grid;
    gap: 0.75rem;
}

.game-timer {
    --game-timer-progress: 100%;
    display: grid;
    gap: 0.4rem;
    padding: 0.8rem 0.95rem 0.95rem;
    background: white;
    border: 4px solid var(--apg-ink);
    border-radius: 1.35rem;
    box-shadow: var(--apg-shadow-sm);
}

.game-timer-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.game-timer-value {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 900;
    line-height: 1;
}

.game-timer-track {
    position: relative;
    height: 0.85rem;
    overflow: hidden;
    border: 2px solid var(--apg-ink);
    border-radius: 999px;
    background: #fee2e2;
}

.game-timer-fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: var(--game-timer-progress);
    border-right: 2px solid var(--apg-ink);
    border-radius: inherit;
    background: linear-gradient(90deg, #22c55e, #facc15);
    transition: width 1s linear, background 180ms ease;
}

.game-timer[data-state='warning'] .game-timer-fill {
    background: linear-gradient(90deg, #f59e0b, #fb923c);
}

.game-timer[data-state='danger'] .game-timer-fill {
    background: linear-gradient(90deg, #ef4444, #f97316);
}

.game-panel-heading {
    display: grid;
    gap: 0.4rem;
    padding-left: 0.25rem;
}

.game-panel-heading .apg-stat-label {
    color: white;
    opacity: 0.72;
}

.game-guess-box {
    display: grid;
    gap: 0.35rem;
    min-height: 5.75rem;
    padding: 0.8rem 1rem;
    background: white;
    border: 4px solid var(--apg-ink);
    border-radius: 1.25rem;
    box-shadow: var(--apg-shadow-sm);
    text-align: center;
}

.game-input-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.game-currency {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 900;
}

.game-price-input {
    width: min(100%, 11rem);
    border: 0;
    font-family: var(--font-display);
    font-size: clamp(2.35rem, 4vw, 3.35rem);
    font-weight: 900;
    text-align: center;
}

.game-price-input:focus {
    outline: 0;
}

.game-steps {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.game-step-button {
    min-height: 3.25rem;
    border-width: 2px;
    box-shadow: var(--apg-shadow-sm);
}

.game-result-modal {
    position: fixed;
    inset: 0;
    z-index: 40;
    display: grid;
    place-items: center;
    padding: clamp(1rem, 4vw, 2rem);
}

.game-result-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(17, 17, 17, 0.6);
    backdrop-filter: blur(10px);
}

.game-result-card {
    position: relative;
    z-index: 1;
    display: grid;
    width: min(100%, 56rem);
    gap: 1.25rem;
    padding: clamp(1.25rem, 3vw, 2rem);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(255, 249, 249, 0.98));
    border: 4px solid var(--apg-ink);
    border-radius: 2rem;
    box-shadow: var(--apg-shadow-lg);
}

.game-result-hero {
    display: grid;
    gap: 0.6rem;
}

.game-perfect-burst {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    border-radius: inherit;
}

.game-result-pill {
    display: inline-flex;
    align-items: center;
    justify-self: start;
    min-height: 2.3rem;
    padding: 0.35rem 0.95rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: white;
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 900;
    text-transform: uppercase;
    box-shadow: var(--apg-shadow-sm);
}

.game-result-heading {
    margin: 0;
    font-size: clamp(2rem, 5vw, 4rem);
    line-height: 0.92;
}

.game-perfect-banner {
    display: inline-flex;
    align-items: center;
    justify-self: start;
    padding: 0.45rem 0.95rem;
    background: #facc15;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    box-shadow: var(--apg-shadow-sm);
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 900;
    text-transform: uppercase;
}

.game-result-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.game-result-metric {
    display: grid;
    gap: 0.45rem;
    padding: 1rem;
    background: white;
    border: 3px solid var(--apg-ink);
    border-radius: 1.5rem;
    box-shadow: var(--apg-shadow-sm);
}

.game-result-score-box {
    align-content: start;
}

.game-result-grid > .game-result-metric:nth-child(-n + 2) {
    padding: 1.2rem;
}

.game-result-price,
.game-result-score,
.game-result-total strong {
    font-family: var(--font-display);
    font-weight: 900;
    line-height: 1;
}

.game-result-price {
    color: var(--apg-ink);
    font-size: clamp(2.35rem, 5vw, 4.5rem);
}

.game-result-score {
    font-size: clamp(2.35rem, 5vw, 4rem);
}

.game-result-score-copy,
.game-result-text {
    margin: 0;
    font-weight: 800;
    color: #334155;
}

.game-result-text {
    max-width: 48rem;
    font-size: clamp(1rem, 1.8vw, 1.15rem);
}

.game-result-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.game-result-total {
    display: grid;
    gap: 0.25rem;
}

.game-result-total strong {
    font-size: clamp(1.5rem, 3vw, 2.4rem);
}

.game-result-actions .game-next-button {
    width: auto;
    min-width: 12rem;
}

.game-result-modal[data-state='success'] .game-result-card {
    background: linear-gradient(135deg, rgba(187, 247, 208, 0.98), rgba(240, 253, 244, 0.98));
}

.game-result-modal[data-state='success'] .game-result-pill,
.game-result-modal[data-state='success'] .game-result-score-box {
    background: rgba(34, 197, 94, 0.32);
}

.game-result-modal[data-state='success'] .game-result-price,
.game-result-modal[data-state='success'] .game-result-score,
.game-result-modal[data-state='success'] .game-result-total strong {
    color: #15803d;
}

.game-result-modal[data-state='warning'] .game-result-card {
    background: linear-gradient(135deg, rgba(254, 215, 170, 0.98), rgba(255, 247, 237, 0.98));
}

.game-result-modal[data-state='warning'] .game-result-pill,
.game-result-modal[data-state='warning'] .game-result-score-box {
    background: rgba(249, 115, 22, 0.3);
}

.game-result-modal[data-state='warning'] .game-result-price,
.game-result-modal[data-state='warning'] .game-result-score,
.game-result-modal[data-state='warning'] .game-result-total strong {
    color: #c2410c;
}

.game-result-modal[data-state='danger'] .game-result-card {
    background: linear-gradient(135deg, rgba(254, 202, 202, 0.98), rgba(254, 242, 242, 0.98));
}

.game-result-modal[data-state='danger'] .game-result-pill,
.game-result-modal[data-state='danger'] .game-result-score-box {
    background: rgba(239, 68, 68, 0.28);
}

.game-result-modal[data-state='danger'] .game-result-price,
.game-result-modal[data-state='danger'] .game-result-score,
.game-result-modal[data-state='danger'] .game-result-total strong {
    color: #b91c1c;
}

.game-result-modal[data-perfect='true'] .game-result-card {
    background: linear-gradient(135deg, rgba(254, 240, 138, 0.98), rgba(255, 255, 255, 0.98));
}

.game-result-modal[data-perfect='true'] .game-result-pill,
.game-result-modal[data-perfect='true'] .game-result-score-box,
.game-result-modal[data-perfect='true'] .game-result-metric {
    background: rgba(250, 204, 21, 0.22);
}

.game-result-modal[data-perfect='true'] .game-result-price,
.game-result-modal[data-perfect='true'] .game-result-score,
.game-result-modal[data-perfect='true'] .game-result-total strong {
    color: #b45309;
}

.game-confetti-piece {
    position: absolute;
    top: -1.25rem;
    left: var(--piece-x);
    width: 0.9rem;
    height: 1.6rem;
    border: 2px solid var(--apg-ink);
    border-radius: 0.3rem;
    background: #facc15;
    box-shadow: 2px 2px 0 var(--apg-ink);
    transform: translateX(-50%) rotate(var(--piece-rotate));
    animation: game-confetti-fall 1200ms ease-out forwards;
    animation-delay: var(--piece-delay);
}

.game-confetti-piece:nth-child(3n) {
    background: #34d399;
}

.game-confetti-piece:nth-child(3n + 1) {
    background: #ff5a5f;
}

.game-confetti-piece:nth-child(3n + 2) {
    background: #60a5fa;
}

@keyframes game-confetti-fall {
    0% {
        opacity: 0;
        transform: translate(-50%, -0.5rem) rotate(0deg) scale(0.85);
    }

    15% {
        opacity: 1;
    }

    100% {
        opacity: 0;
        transform: translate(-50%, 22rem) rotate(240deg) scale(1);
    }
}

.game-finish-card {
    width: min(100%, 44rem);
    max-height: calc(100dvh - clamp(2rem, 8vw, 4rem));
    align-content: start;
    justify-items: center;
    overflow-y: auto;
    overscroll-behavior: contain;
    text-align: center;
    background: linear-gradient(135deg, rgba(255, 240, 196, 0.98), rgba(255, 255, 255, 0.98));
}

@supports not (height: 100dvh) {
    .game-finish-card {
        max-height: calc(100vh - clamp(2rem, 8vw, 4rem));
    }
}

.game-finish-score-wrap {
    display: grid;
    gap: 0.45rem;
    width: min(100%, 20rem);
    padding: 1.2rem 1rem;
    background: white;
    border: 4px solid var(--apg-ink);
    border-radius: 1.75rem;
    box-shadow: var(--apg-shadow);
}

.game-finish-score {
    color: var(--apg-airbnb);
    font-family: var(--font-display);
    font-size: clamp(3rem, 8vw, 5.5rem);
    font-weight: 900;
    line-height: 0.95;
}

.game-finish-actions {
    display: grid;
    width: min(100%, 28rem);
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.game-finish-button {
    min-height: 4rem;
    padding-inline: 1rem;
    font-size: 1rem;
}

.game-finish-button-secondary {
    background: var(--apg-yellow);
}

.game-finish-button-secondary:hover {
    background: #f59e0b;
}

.game-finish-share-feedback {
    min-height: 1.25rem;
    margin: 0;
    font-weight: 800;
    color: #334155;
}

.game-seen-listings {
    display: grid;
    width: min(100%, 34rem);
    gap: 0.65rem;
    padding: 1rem;
    border: 3px solid var(--apg-ink);
    border-radius: 1.35rem;
    background: white;
    box-shadow: var(--apg-shadow-sm);
    text-align: left;
}

.game-seen-listings[hidden] {
    display: none;
}

.game-seen-listings-list {
    display: grid;
    gap: 0.55rem;
}

.game-seen-listing-link {
    display: grid;
    gap: 0.2rem;
    padding: 0.75rem 0.85rem;
    border: 2px solid var(--apg-ink);
    border-radius: 1rem;
    color: inherit;
    text-decoration: none;
    background: #fffdf7;
}

.game-seen-listing-link strong {
    font-family: var(--font-display);
    font-weight: 900;
    text-transform: uppercase;
}

.game-seen-listing-link span,
.game-seen-listings p {
    margin: 0;
    color: #475569;
    font-weight: 800;
}

.game-check-button,
.game-next-button {
    width: 100%;
    min-height: 5.75rem;
    font-size: 1.2rem;
}

.game-next-button {
    min-width: 8rem;
}

.game-empty {
    padding: 2rem;
    text-align: center;
}

.game-empty h1 {
    margin: 0 0 1rem;
    font-size: 2rem;
    line-height: 0.95;
}

.game-empty p {
    max-width: 36rem;
    margin-inline: auto;
    color: #475569;
    font-weight: 800;
}

.legal-shell {
    width: min(100% - 2rem, 78rem);
}

.legal-navbar {
    margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.legal-nav-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.legal-action-button,
.legal-cookie-button {
    min-height: 3.25rem;
    padding-inline: 1rem;
}

.legal-hero {
    position: relative;
    display: grid;
    gap: 1rem;
    overflow: hidden;
    margin-bottom: clamp(1.25rem, 3vw, 2rem);
    padding: clamp(1.25rem, 4vw, 2.5rem);
    border: 4px solid var(--apg-ink);
    border-radius: 2rem;
    background:
        linear-gradient(135deg, rgba(255, 90, 95, 0.94), rgba(250, 204, 21, 0.72)),
        radial-gradient(circle at 90% 12%, rgba(255, 255, 255, 0.7), transparent 12rem);
    box-shadow: var(--apg-shadow-lg);
}

.legal-hero::after {
    content: "";
    position: absolute;
    right: -5rem;
    bottom: -6rem;
    width: 16rem;
    aspect-ratio: 1;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.22);
}

.legal-hero h1,
.legal-hero p,
.legal-hero .home-kicker {
    position: relative;
    z-index: 1;
}

.legal-hero h1 {
    max-width: 12ch;
    margin: 0;
    color: white;
    font-size: clamp(3rem, 7vw, 6rem);
    line-height: 0.9;
    text-shadow: 5px 5px 0 var(--apg-ink);
}

.legal-hero p {
    max-width: 44rem;
    margin: 0;
    color: white;
    font-size: clamp(1rem, 1.8vw, 1.15rem);
    font-weight: 900;
    line-height: 1.45;
    text-shadow: 2px 2px 0 rgba(17, 17, 17, 0.28);
}

.legal-layout {
    display: grid;
    grid-template-columns: minmax(13rem, 0.35fr) minmax(0, 1fr);
    gap: clamp(1rem, 3vw, 1.5rem);
    align-items: start;
}

.legal-summary {
    position: sticky;
    top: 1rem;
    display: grid;
    gap: 0.65rem;
    padding: 1rem;
}

.legal-summary a {
    display: flex;
    align-items: center;
    min-height: 2.65rem;
    padding: 0.5rem 0.75rem;
    border: 3px solid var(--apg-ink);
    border-radius: 0.9rem;
    background: #fffdf7;
    box-shadow: var(--apg-shadow-sm);
    font-weight: 900;
    text-decoration: none;
}

.legal-content {
    display: grid;
    gap: 1rem;
}

.legal-section {
    display: grid;
    gap: 0.8rem;
    padding: clamp(1rem, 3vw, 1.5rem);
}

.legal-section h2 {
    margin: 0;
    font-size: clamp(1.7rem, 3vw, 2.7rem);
    line-height: 0.95;
}

.legal-section p {
    margin: 0;
    color: #334155;
    font-weight: 800;
    line-height: 1.55;
}

.legal-definition-list {
    display: grid;
    gap: 0.75rem;
    margin: 0;
}

.legal-definition-list div {
    display: grid;
    gap: 0.25rem;
    padding: 0.85rem;
    border: 3px solid var(--apg-ink);
    border-radius: 1rem;
    background: #fffdf7;
    box-shadow: var(--apg-shadow-sm);
}

.legal-definition-list dt {
    font-family: var(--font-display);
    font-weight: 900;
    text-transform: uppercase;
}

.legal-definition-list dd {
    margin: 0;
    color: #475569;
    font-weight: 800;
}

.legal-contact-box {
    display: inline-flex;
    width: fit-content;
    padding: 0.75rem 1rem;
    border: 3px solid var(--apg-ink);
    border-radius: 1rem;
    background: var(--apg-yellow);
    box-shadow: var(--apg-shadow-sm);
    color: var(--apg-ink) !important;
    font-family: var(--font-display);
}

.settings-shell {
    width: min(100% - 2rem, 76rem);
}

.settings-navbar {
    margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.settings-back-button {
    min-height: 3.25rem;
    padding-inline: 1rem;
}

.settings-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(22rem, 1.05fr);
    gap: clamp(1.25rem, 4vw, 3rem);
    align-items: stretch;
}

.settings-hero {
    position: relative;
    display: grid;
    min-height: 31rem;
    align-content: space-between;
    gap: 1.5rem;
    overflow: hidden;
    padding: clamp(1.25rem, 3vw, 2rem);
    border: 4px solid var(--apg-ink);
    border-radius: 2rem;
    background:
        linear-gradient(135deg, rgba(255, 90, 95, 0.94), rgba(250, 204, 21, 0.72)),
        radial-gradient(circle at 80% 12%, rgba(255, 255, 255, 0.74), transparent 12rem);
    box-shadow: var(--apg-shadow-lg);
}

.settings-hero::after {
    content: "";
    position: absolute;
    right: -5rem;
    bottom: -5rem;
    width: 14rem;
    aspect-ratio: 1;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.24);
}

.settings-hero h1 {
    position: relative;
    z-index: 1;
    max-width: 100%;
    margin: 0;
    color: white;
    font-size: clamp(3rem, 4.6vw, 4.2rem);
    line-height: 0.88;
    text-shadow: 5px 5px 0 var(--apg-ink);
}

.settings-hero p {
    position: relative;
    z-index: 1;
    max-width: 32rem;
    margin: 0;
    color: white;
    font-size: clamp(1rem, 1.8vw, 1.15rem);
    font-weight: 900;
    line-height: 1.45;
    text-shadow: 2px 2px 0 rgba(17, 17, 17, 0.28);
}

.settings-sound-card {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: min(100%, 18rem);
    min-height: 7rem;
    padding: 1.2rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1.5rem;
    background: white;
    box-shadow: var(--apg-shadow);
    transform: rotate(-2deg);
}

.settings-sound-dot {
    width: 3.4rem;
    height: 3.4rem;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: var(--apg-airbnb);
    box-shadow: var(--apg-shadow-sm);
}

.settings-sound-wave {
    width: 1rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: var(--apg-yellow);
}

.settings-sound-wave:nth-child(2) {
    height: 2.2rem;
}

.settings-sound-wave:nth-child(3) {
    height: 4rem;
    background: var(--apg-green);
}

.settings-sound-wave:nth-child(4) {
    height: 3rem;
}

.settings-panel {
    display: grid;
    gap: 1rem;
    padding: clamp(1rem, 3vw, 1.5rem);
}

.settings-control,
.settings-toggle,
.settings-actions {
    border: 3px solid var(--apg-ink);
    border-radius: 1.35rem;
    background: #fffdf7;
    box-shadow: var(--apg-shadow-sm);
}

.settings-control {
    display: grid;
    gap: 1rem;
    padding: 1.1rem;
}

.settings-control-copy,
.settings-toggle-copy {
    display: grid;
    gap: 0.35rem;
}

.settings-control label,
.settings-toggle-title {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2vw, 1.65rem);
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.settings-control p,
.settings-toggle-description,
.settings-note {
    margin: 0;
    color: #475569;
    font-weight: 800;
    line-height: 1.35;
}

.settings-volume-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
}

.settings-range {
    --settings-volume: 35%;
    width: 100%;
    height: 1.35rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    appearance: none;
    background:
        linear-gradient(90deg, var(--apg-airbnb), var(--apg-yellow)) 0 / var(--settings-volume) 100% no-repeat,
        white;
    box-shadow: inset 2px 2px 0 rgba(17, 17, 17, 0.12);
}

.settings-range::-webkit-slider-thumb {
    width: 2.1rem;
    height: 2.1rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    appearance: none;
    background: white;
    box-shadow: var(--apg-shadow-sm);
    cursor: grab;
}

.settings-range::-moz-range-thumb {
    width: 2.1rem;
    height: 2.1rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: white;
    box-shadow: var(--apg-shadow-sm);
    cursor: grab;
}

.settings-volume-value {
    min-width: 4rem;
    padding: 0.45rem 0.65rem;
    border: 3px solid var(--apg-ink);
    border-radius: 0.8rem;
    background: white;
    box-shadow: var(--apg-shadow-sm);
    font-family: var(--font-display);
    font-weight: 900;
    text-align: center;
}

.settings-toggle {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1.1rem;
    cursor: pointer;
}

.settings-toggle input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
}

.settings-switch {
    position: relative;
    width: 5rem;
    height: 2.6rem;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: #e2e8f0;
    box-shadow: var(--apg-shadow-sm);
    transition: background 140ms ease;
}

.settings-switch::after {
    content: "";
    position: absolute;
    top: 0.25rem;
    left: 0.25rem;
    width: 1.55rem;
    height: 1.55rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: white;
    transition: transform 140ms ease;
}

.settings-toggle input:checked + .settings-switch {
    background: var(--apg-green);
}

.settings-toggle input:checked + .settings-switch::after {
    transform: translateX(2.25rem);
}

.settings-toggle:focus-within,
.settings-range:focus-visible {
    outline: 3px solid var(--apg-yellow);
    outline-offset: 3px;
}

.settings-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
}

.settings-test-button {
    min-height: 3.5rem;
    padding-inline: 1rem;
}

@media (max-width: 900px) {
    .legal-layout {
        grid-template-columns: 1fr;
    }

    .legal-summary {
        position: static;
    }

    .settings-layout {
        grid-template-columns: 1fr;
    }

    .settings-hero {
        min-height: 24rem;
    }
}

@media (max-width: 700px) {
    .apg-cookie-banner {
        right: 1rem;
        bottom: 0.5rem;
        left: 1rem;
        grid-template-columns: 1fr;
        width: auto;
        max-width: calc(100vw - 2rem);
        overflow: hidden;
        border-radius: 1.1rem;
        box-shadow: var(--apg-shadow);
    }

    .apg-cookie-copy strong {
        font-size: clamp(1.15rem, 5vw, 1.45rem);
        overflow-wrap: anywhere;
    }

    .apg-cookie-copy p,
    .apg-cookie-panel-heading p,
    .apg-cookie-toggle small {
        max-width: 18rem;
        overflow-wrap: break-word;
    }

    .apg-cookie-actions,
    .apg-cookie-modal-actions {
        display: grid;
        grid-template-columns: 1fr;
        justify-content: stretch;
    }

    .apg-cookie-button {
        width: 100%;
    }

    .apg-cookie-panel {
        max-height: calc(100vh - 2rem);
        max-height: calc(100dvh - 2rem);
        overflow-y: auto;
        border-radius: 1.25rem;
    }

    .apg-cookie-toggle {
        grid-template-columns: 1fr;
    }

    .apg-shell.legal-shell {
        width: calc(100vw - 6rem);
        max-width: 16rem;
        overflow-x: clip;
        padding-block: 1rem;
    }

    .legal-page,
    .legal-layout,
    .legal-content,
    .legal-summary,
    .legal-section {
        min-width: 0;
    }

    .legal-navbar,
    .legal-nav-actions,
    .legal-action-button {
        width: 100%;
    }

    .legal-hero {
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .legal-hero h1 {
        font-size: clamp(2.15rem, 10vw, 2.75rem);
        text-shadow: 3px 3px 0 var(--apg-ink);
        overflow-wrap: anywhere;
    }

    .legal-hero p,
    .legal-section p,
    .legal-definition-list dd {
        max-width: 100%;
        overflow-wrap: break-word;
    }

    .legal-summary,
    .legal-section {
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .apg-shell.settings-shell {
        width: calc(100vw - 6rem);
        max-width: 16rem;
        overflow-x: clip;
        padding-block: 1rem;
    }

    .settings-navbar {
        align-items: stretch;
        box-shadow: var(--apg-shadow-sm);
    }

    .settings-back-button {
        width: 100%;
    }

    .settings-hero {
        min-width: 0;
        min-height: auto;
        overflow: hidden;
        padding: 1rem;
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .settings-hero h1 {
        max-width: 100%;
        font-size: clamp(2.15rem, 10vw, 2.7rem);
        text-shadow: 3px 3px 0 var(--apg-ink);
        overflow-wrap: anywhere;
    }

    .settings-hero p {
        max-width: 18rem;
        overflow-wrap: break-word;
    }

    .settings-sound-card {
        width: 100%;
        min-height: 5.5rem;
        transform: none;
    }

    .settings-panel {
        min-width: 0;
        overflow: hidden;
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .settings-volume-row,
    .settings-toggle,
    .settings-actions {
        grid-template-columns: 1fr;
    }

    .settings-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .settings-control,
    .settings-toggle,
    .settings-actions,
    .settings-control-copy,
    .settings-toggle-copy {
        min-width: 0;
    }

    .settings-control p,
    .settings-toggle-description,
    .settings-note {
        max-width: 100%;
        overflow-wrap: break-word;
    }

    .settings-control p,
    .settings-toggle-description {
        display: none;
    }

    .settings-control-copy,
    .settings-toggle-copy {
        max-width: calc(100vw - 6rem);
    }

    .settings-switch {
        justify-self: start;
    }
}

.home-shell {
    width: min(100% - 2rem, 78rem);
    min-height: 100vh;
    display: grid;
    align-items: center;
}

.home-menu {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(20rem, 0.92fr);
    gap: clamp(1.25rem, 3vw, 2.5rem);
    align-items: stretch;
    perspective: 1200px;
}

.home-menu::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    background:
        linear-gradient(rgba(17, 17, 17, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(17, 17, 17, 0.035) 1px, transparent 1px);
    background-size: 2.75rem 2.75rem;
    mask-image: radial-gradient(circle at center, black, transparent 72%);
}

.home-stage,
.home-menu-list {
    animation: home-enter 520ms ease both;
}

.home-stage {
    position: relative;
    min-height: 34rem;
    overflow: hidden;
    padding: clamp(1.25rem, 3vw, 2rem);
    border: 4px solid var(--apg-ink);
    border-radius: 2rem;
    background:
        linear-gradient(135deg, rgba(255, 90, 95, 0.92), rgba(255, 90, 95, 0.78) 42%, rgba(250, 204, 21, 0.72)),
        radial-gradient(circle at 86% 18%, rgba(255, 255, 255, 0.8), transparent 11rem);
    box-shadow: var(--apg-shadow-lg);
    transform: rotateY(-3deg) rotateX(1deg);
}

.home-stage::before,
.home-stage::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.home-stage::before {
    inset: 1rem;
    border: 2px solid rgba(255, 255, 255, 0.5);
    border-radius: 1.35rem;
}

.home-stage::after {
    right: -7rem;
    bottom: -7rem;
    width: 18rem;
    aspect-ratio: 1;
    border: 4px solid var(--apg-ink);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.28);
    box-shadow: inset 10px 10px 0 rgba(255, 255, 255, 0.2);
}

.home-brand-lockup {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: fit-content;
    max-width: 100%;
    padding: 0.75rem 1rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1.25rem;
    background: white;
    box-shadow: var(--apg-shadow-sm);
    font-family: var(--font-display);
    font-size: clamp(1.05rem, 2vw, 1.45rem);
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.home-logo {
    width: 2.75rem;
    height: 2.75rem;
}

.home-hero {
    position: relative;
    z-index: 1;
    display: grid;
    min-height: 26rem;
    grid-template-columns: minmax(0, 1fr) minmax(13rem, 0.72fr);
    gap: 1rem;
    align-items: end;
    margin-top: 2rem;
}

.home-hero-copy {
    display: grid;
    gap: 1rem;
    align-self: center;
}

.home-kicker,
.home-menu-tag {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 2rem;
    padding: 0.3rem 0.8rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: white;
    box-shadow: var(--apg-shadow-sm);
    font-family: var(--font-display);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.home-hero h1 {
    max-width: 11ch;
    margin: 0;
    color: white;
    font-size: clamp(3.2rem, 6vw, 5.8rem);
    line-height: 0.9;
    text-shadow: 5px 5px 0 var(--apg-ink);
}

.home-hero p {
    max-width: 36rem;
    margin: 0;
    color: white;
    font-size: clamp(1rem, 1.8vw, 1.18rem);
    font-weight: 900;
    line-height: 1.45;
    text-shadow: 2px 2px 0 rgba(17, 17, 17, 0.28);
}

.home-preview {
    position: relative;
    min-height: 23rem;
    transform-style: preserve-3d;
}

.home-preview-card,
.home-preview-score {
    position: absolute;
    border: 4px solid var(--apg-ink);
    box-shadow: var(--apg-shadow);
}

.home-preview-card-main {
    right: 0;
    bottom: 1.5rem;
    z-index: 2;
    width: min(100%, 16.5rem);
    overflow: hidden;
    border-radius: 1.6rem;
    background: white;
    transform: rotate(-4deg) translateZ(4rem);
    animation: home-float 5s ease-in-out infinite;
}

.home-preview-image {
    height: 12rem;
    border-bottom: 4px solid var(--apg-ink);
    background:
        linear-gradient(135deg, rgba(17, 17, 17, 0.18), transparent 54%),
        url("https://images.unsplash.com/photo-1512917774080-9991f1c4c750?auto=format&fit=crop&q=80&w=1000") center / cover;
}

.home-preview-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem;
}

.home-preview-content span {
    display: block;
    width: 7rem;
    height: 1.2rem;
    border: 3px solid var(--apg-ink);
    border-radius: 999px;
    background: var(--apg-yellow);
}

.home-preview-content strong,
.home-preview-score strong {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 900;
    line-height: 1;
}

.home-preview-card-back {
    top: 2.5rem;
    right: 3.5rem;
    z-index: 1;
    display: grid;
    width: 8.5rem;
    height: 8.5rem;
    place-items: center;
    border-radius: 1.4rem;
    background: #34d399;
    font-family: var(--font-display);
    font-weight: 900;
    text-transform: uppercase;
    transform: rotate(7deg) translateZ(1rem);
}

.home-preview-score {
    top: 9rem;
    left: -0.75rem;
    z-index: 3;
    display: grid;
    gap: 0.25rem;
    padding: 0.8rem 1rem;
    border-radius: 1.1rem;
    background: white;
    transform: rotate(5deg) translateZ(6rem);
    animation: home-pop 480ms ease 280ms both;
}

.home-preview-score span {
    font-size: 0.65rem;
    font-weight: 900;
    text-transform: uppercase;
    opacity: 0.6;
}

.home-menu-list {
    display: grid;
    align-content: center;
    gap: 0.9rem;
    animation-delay: 90ms;
}

.home-menu-item {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    width: 100%;
    min-height: 6.4rem;
    padding: 1rem;
    border: 4px solid var(--apg-ink);
    border-radius: 1.35rem;
    background: white;
    color: var(--apg-ink);
    box-shadow: var(--apg-shadow);
    text-align: left;
    text-decoration: none;
    transform: translateY(0);
    animation: home-item-enter 460ms ease both;
    animation-delay: var(--item-delay);
    transition: transform 150ms ease, box-shadow 150ms ease, background 150ms ease, filter 150ms ease;
}

.home-menu-item.is-active {
    background: linear-gradient(135deg, white 0%, #fff7cf 100%);
}

.home-menu-item.is-active::after {
    content: "";
    position: absolute;
    inset: -4px;
    z-index: -1;
    border-radius: inherit;
    background: var(--apg-airbnb);
    transform: translate(0.45rem, 0.45rem);
}

.home-menu-item.is-active:hover {
    transform: translate(-0.18rem, -0.18rem) scale(1.015);
    box-shadow: 12px 12px 0 var(--apg-ink);
}

.home-menu-item.is-active:hover .home-menu-icon {
    transform: rotate(-5deg) scale(1.08);
}

.home-menu-item.is-active:active {
    transform: translate(0.25rem, 0.25rem);
    box-shadow: var(--apg-shadow-sm);
}

.home-menu-item.is-disabled {
    cursor: not-allowed;
    filter: grayscale(0.85);
    opacity: 0.58;
}

.home-menu-icon {
    display: grid;
    width: 3.6rem;
    height: 3.6rem;
    place-items: center;
    border: 3px solid var(--apg-ink);
    border-radius: 1rem;
    background: var(--apg-airbnb);
    color: white;
    box-shadow: var(--apg-shadow-sm);
    transition: transform 150ms ease;
}

.home-menu-item.is-disabled .home-menu-icon {
    background: #cbd5e1;
    color: #475569;
}

.home-menu-copy {
    display: grid;
    min-width: 0;
    gap: 0.25rem;
}

.home-menu-label {
    font-family: var(--font-display);
    font-size: clamp(1.25rem, 2.4vw, 1.8rem);
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.home-menu-description {
    color: #475569;
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1.3;
}

.home-menu-tag {
    justify-self: end;
    background: var(--apg-yellow);
    white-space: nowrap;
}

.home-menu-item.is-disabled .home-menu-tag {
    background: #e2e8f0;
    color: #475569;
}

@keyframes home-enter {
    from {
        opacity: 0;
        transform: translateY(1rem) scale(0.98);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes home-item-enter {
    from {
        opacity: 0;
        transform: translateX(1.25rem);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes home-float {
    0%,
    100% {
        transform: rotate(-4deg) translateY(0) translateZ(4rem);
    }

    50% {
        transform: rotate(-2deg) translateY(-0.7rem) translateZ(4rem);
    }
}

@keyframes home-pop {
    from {
        opacity: 0;
        transform: rotate(5deg) translateY(0.8rem) translateZ(6rem) scale(0.92);
    }

    to {
        opacity: 1;
        transform: rotate(5deg) translateY(0) translateZ(6rem) scale(1);
    }
}

@media (max-width: 980px) {
    .home-shell {
        align-items: start;
    }

    .home-menu {
        grid-template-columns: 1fr;
    }

    .home-stage {
        min-height: auto;
        transform: none;
    }

    .home-hero {
        min-height: auto;
    }
}

@media (max-width: 700px) {
    .apg-shell.home-shell {
        width: min(100% - 2rem, 78rem);
        overflow-x: clip;
    }

    .home-stage {
        min-width: 0;
        padding: 1rem;
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .home-menu,
    .home-menu-list,
    .home-hero-copy {
        min-width: 0;
    }

    .home-brand-lockup {
        width: 100%;
        font-size: 1rem;
    }

    .home-hero {
        grid-template-columns: 1fr;
        gap: 1.25rem;
        margin-top: 1.25rem;
    }

    .home-hero h1 {
        max-width: 8.5ch;
        font-size: clamp(2.5rem, 13.5vw, 3.45rem);
        text-shadow: 3px 3px 0 var(--apg-ink);
    }

    .home-hero p {
        max-width: 19rem;
        overflow-wrap: break-word;
    }

    .home-preview {
        display: grid;
        min-height: auto;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 0.75rem;
    }

    .home-preview-card-main {
        position: relative;
        right: auto;
        bottom: auto;
        grid-column: 1 / -1;
        width: calc(100% - 2rem);
        transform: none;
    }

    .home-preview-image {
        height: 7.25rem;
    }

    .home-preview-card-back {
        position: relative;
        top: auto;
        right: auto;
        width: 100%;
        height: auto;
        min-height: 5.75rem;
        transform: none;
    }

    .home-preview-score {
        position: relative;
        inset: auto;
        align-content: center;
        transform: none;
    }

    .home-preview-content {
        padding: 0.8rem;
    }

    .home-preview-content strong,
    .home-preview-score strong {
        font-size: 1.55rem;
    }

    .home-menu-item {
        grid-template-columns: auto minmax(0, 1fr);
        min-height: auto;
        min-width: 0;
        overflow: hidden;
        padding: 0.85rem;
        border-radius: 1rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .home-menu-tag {
        grid-column: 2;
        justify-self: start;
        max-width: 100%;
        white-space: normal;
    }

    .home-menu-description {
        display: none;
    }

    .home-menu-icon {
        width: 3rem;
        height: 3rem;
        border-radius: 0.85rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .home-stage,
    .home-menu-list,
    .home-menu-item,
    .home-preview-card-main,
    .home-preview-score {
        animation: none;
    }

    .home-menu-item,
    .home-menu-icon {
        transition: none;
    }
}

@media (max-width: 900px) {
    .game-panel {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .apg-shell {
        width: min(100% - 1rem, 72rem);
        padding-block: 1rem;
    }

    .apg-navbar {
        align-items: flex-start;
        flex-direction: column;
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .game-grid {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }

    .game-result-card,
    .game-result-grid {
        grid-template-columns: 1fr;
    }

    .game-result-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .game-result-actions .game-next-button {
        width: 100%;
        min-width: 0;
    }

    .game-finish-actions {
        grid-template-columns: 1fr;
        width: 100%;
    }

    .apg-header-actions,
    .game-progress {
        width: 100%;
    }

    .game-progress {
        min-width: 0;
    }

    .game-panel {
        align-items: stretch;
        min-height: auto;
    }

    .game-panel-guess {
        grid-template-columns: 1fr;
    }

    .game-panel-heading {
        padding-left: 0;
        text-align: center;
    }

    .game-panel-title {
        text-align: center;
    }

    .game-next-button {
        min-width: 0;
    }

    .game-photo-wrap {
        height: 20rem;
    }
}

.game-photo-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    pointer-events: auto;
    touch-action: manipulation;
}

.game-photo-nav > * {
    pointer-events: none;
}

#game-photo-prev {
    left: 1rem;
}

#game-photo-next {
    right: 1rem;
}

@media (min-width: 701px) {
    .apg-shell-game {
        display: flex;
        height: 100vh;
        height: 100dvh;
        min-height: 100vh;
        min-height: 100dvh;
        flex-direction: column;
        padding-block: clamp(0.45rem, 1.2vh, 0.85rem);
    }

    .apg-shell-game .apg-navbar {
        flex: 0 0 auto;
        margin-bottom: clamp(0.45rem, 1.1vh, 0.85rem);
        padding: clamp(0.4rem, 0.9vh, 0.65rem) clamp(0.7rem, 1.5vw, 1rem);
        border-radius: 1.1rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .apg-shell-game .apg-brand {
        font-size: clamp(1rem, 2vw, 1.45rem);
    }

    .apg-shell-game .apg-logo {
        width: clamp(2rem, 4.5vh, 2.4rem);
        height: clamp(2rem, 4.5vh, 2.4rem);
        border-width: 3px;
    }

    .apg-shell-game .apg-header-actions {
        gap: 0.5rem;
    }

    .apg-shell-game .game-progress {
        min-width: min(14rem, 34vw);
        gap: 0.28rem;
        padding: 0.28rem 0.55rem 0.4rem;
        border-width: 3px;
        border-radius: 0.75rem;
        box-shadow: 3px 3px 0 var(--apg-ink);
    }

    .apg-shell-game .game-progress-value {
        font-size: 0.88rem;
    }

    .apg-shell-game .game-progress-track {
        height: 0.55rem;
        border-width: 2px;
    }

    .apg-shell-game .apg-stat {
        min-width: 4.75rem;
        padding: 0.25rem 0.6rem;
        border-width: 3px;
        border-radius: 0.75rem;
        box-shadow: 3px 3px 0 var(--apg-ink);
    }

    .apg-shell-game .apg-stat-value {
        font-size: 1rem;
    }

    .apg-shell-game .apg-badge {
        padding: 0.25rem 0.6rem;
        font-size: 0.68rem;
    }

    .apg-shell-game main {
        display: flex;
        min-height: 0;
        flex: 1 1 0;
    }

    .game-grid {
        width: 100%;
        height: calc(100vh - 5.25rem);
        max-height: calc(97dvh - 5.25rem);
        min-height: 0;
        flex: 1 1 auto;
        grid-template-columns: minmax(0, 2fr) minmax(18rem, 0.72fr);
        grid-template-rows: minmax(0, 1fr) auto;
        align-items: stretch;
    }

    .game-listing {
        display: grid;
        height: 100%;
        min-height: 0;
        grid-template-rows: minmax(0, 1fr) auto;
    }

    .game-photo-wrap {
        height: auto;
        min-height: 0;
        aspect-ratio: auto;
    }

    .game-listing-body {
        padding: clamp(0.45rem, 1vh, 0.85rem);
    }

    .game-details {
        gap: 0.35rem;
    }

    .game-title {
        display: -webkit-box;
        margin: 0;
        overflow: hidden;
        font-size: clamp(0.95rem, 1.75vw, 1.35rem);
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
    }

    .game-property-type {
        font-size: 0.72rem;
    }

    .game-location-subtitle,
    .game-stay-dates,
    .game-sub-item {
        font-size: 0.68rem;
    }

    .game-meta {
        gap: 0.45rem;
        margin-bottom: 0;
        font-size: 0.72rem;
    }

    .game-sub-item {
        min-height: 1.65rem;
        padding: 0.18rem 0.55rem;
    }

    .game-sidebar,
    .game-map-card {
        height: 100%;
        min-height: 0;
    }

    .game-map-card {
        display: grid;
        grid-template-rows: auto minmax(0, 1fr);
    }

    .game-map-header {
        padding: clamp(0.55rem, 1vh, 0.85rem) clamp(0.7rem, 1.3vw, 1rem);
    }

    .game-map-wrap,
    .game-map {
        height: 100%;
        min-height: 0;
    }

    .game-panel {
        display: grid;
        min-height: 0;
        grid-column: 1 / -1;
        grid-template-columns: minmax(0, 1fr) minmax(10rem, 0.3fr);
        align-items: center;
        gap: clamp(0.45rem, 0.85vh, 0.7rem);
        padding: clamp(0.3rem, 0.75vh, 0.55rem);
        border-radius: 1.25rem;
        box-shadow: var(--apg-shadow-sm);
    }

    .game-panel-guess {
        display: grid;
        grid-template-columns: minmax(6.2rem, 0.32fr) minmax(10rem, 1fr);
        align-items: center;
        gap: 0.5rem;
    }

    .game-panel-entry {
        gap: 0.45rem;
    }

    .game-panel-heading {
        gap: 0.1rem;
        padding-left: 0.1rem;
    }

    .game-panel-title {
        margin: 0;
        font-size: clamp(0.95rem, 1.75vw, 1.35rem);
    }

    .game-guess-box {
        min-height: 2.7rem;
        padding: 0.2rem 0.55rem;
        border-width: 3px;
        border-radius: 0.8rem;
        box-shadow: 3px 3px 0 var(--apg-ink);
    }

    .game-timer {
        gap: 0.25rem;
        padding: 0.35rem 0.55rem 0.45rem;
        border-width: 3px;
        border-radius: 0.8rem;
        box-shadow: 3px 3px 0 var(--apg-ink);
    }

    .game-timer-value {
        font-size: 0.92rem;
    }

    .game-timer-track {
        height: 0.6rem;
    }

    .game-currency {
        font-size: clamp(1.05rem, 1.85vw, 1.45rem);
    }

    .game-price-input {
        width: min(100%, 7.1rem);
        font-size: clamp(1.35rem, 2.35vw, 1.95rem);
    }

    .game-check-button,
    .game-next-button {
        min-height: 2.9rem;
        padding-inline: 0.85rem;
        border-radius: 0.8rem;
        box-shadow: 0 4px 0 var(--apg-ink);
        font-size: 0.88rem;
    }

    .game-result-card {
        gap: 0.85rem;
        padding: 0.85rem;
        border-width: 3px;
        border-radius: 1rem;
        box-shadow: 3px 3px 0 var(--apg-ink);
    }

    .game-result-price {
        font-size: clamp(1.05rem, 1.95vw, 1.45rem);
    }

    .game-result-text,
    .game-result-score-copy {
        font-size: 0.72rem;
    }

    .game-result-score {
        font-size: clamp(1.2rem, 2.2vw, 1.8rem);
    }

    .game-finish-score {
        font-size: clamp(2.1rem, 7vw, 3.2rem);
    }
}

@media (min-width: 701px) and (max-height: 760px) {
    .apg-shell-game {
        padding-block: 0.35rem;
    }

    .apg-shell-game .apg-navbar {
        margin-bottom: 0.45rem;
        padding-block: 0.3rem;
    }

    .game-grid {
        gap: 0.55rem 0.85rem;
    }

    .game-listing-body,
    .game-map-header {
        padding-block: 0.4rem;
    }

    .game-title {
        font-size: clamp(1.1rem, 2.2vw, 1.5rem);
        -webkit-line-clamp: 1;
    }

    .game-details {
        gap: 0.25rem;
    }

    .game-location-subtitle,
    .game-stay-dates,
    .game-meta,
    .game-sub-item {
        font-size: 0.64rem;
    }

    .game-sub-items {
        gap: 0.3rem;
    }

    .game-panel {
        gap: 0.4rem;
        padding: 0.28rem;
    }

    .game-guess-box,
    .game-check-button,
    .game-next-button {
        min-height: 2.65rem;
    }

    .game-result-text,
    .game-result-score-copy {
        display: none;
    }
}

.apg-button:disabled {
    cursor: not-allowed;
    filter: grayscale(0.45);
    opacity: 0.6;
}

.apg-button:disabled:hover {
    background: white;
}

.multiplayer-screen {
    width: 100%;
    align-items: start;
}

.multiplayer-entry-stack {
    display: grid;
    gap: 1rem;
    min-width: 0;
}

.multiplayer-card,
.multiplayer-lobby {
    display: grid;
    gap: 1.1rem;
    min-width: 0;
    padding: clamp(1rem, 2vw, 1.5rem);
}

.multiplayer-card {
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.62fr);
    align-items: start;
}

.multiplayer-card .game-result-hero {
    grid-column: 1 / -1;
}

.multiplayer-config {
    display: grid;
    gap: 1rem;
    min-width: 0;
    padding: clamp(1rem, 2vw, 1.35rem);
}

.multiplayer-form-grid,
.multiplayer-config-grid {
    display: grid;
    gap: 0.9rem;
}

.multiplayer-form-grid {
    grid-template-columns: minmax(0, 1fr) minmax(11rem, 0.38fr);
    align-items: end;
}

.multiplayer-join-card {
    display: grid;
    gap: 0.9rem;
    min-width: 0;
    padding: 1rem;
}

.multiplayer-join-heading {
    display: grid;
    gap: 0.3rem;
}

.multiplayer-join-heading strong {
    font-family: var(--font-display);
    font-size: clamp(1.2rem, 2vw, 1.55rem);
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.multiplayer-join-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(11rem, 0.38fr);
    gap: 0.9rem;
    align-items: end;
}

.multiplayer-field {
    display: grid;
    gap: 0.45rem;
    min-width: 0;
}

.multiplayer-action-button,
.multiplayer-start-button,
.multiplayer-save-settings-button,
.multiplayer-leave-button {
    min-height: 3.85rem;
    padding-inline: 1rem;
}

.multiplayer-start-button {
    background: var(--apg-airbnb);
    color: white;
}

.multiplayer-start-button:hover {
    background: #e64857;
}

.multiplayer-save-settings-button {
    width: 100%;
    min-height: 3.5rem;
}

.multiplayer-copy-button {
    min-height: 2.9rem;
    padding-inline: 0.8rem;
    border-width: 3px;
    border-radius: 0.95rem;
    box-shadow: var(--apg-shadow-sm);
    font-size: 0.85rem;
}

.multiplayer-copy-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.multiplayer-room-code-box {
    display: grid;
    gap: 0.55rem;
    padding: 0.8rem;
    border: 3px solid var(--apg-ink);
    border-radius: 1.1rem;
    background: white;
    box-shadow: var(--apg-shadow-sm);
}

.multiplayer-room-code-box strong {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 4vw, 2.6rem);
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
}

.multiplayer-feedback,
.multiplayer-waiting {
    min-height: 1.2rem;
    margin: 0;
    color: #475569;
    font-weight: 900;
}

.multiplayer-feedback[data-state='error'] {
    color: #b91c1c;
}

.multiplayer-feedback[data-state='success'] {
    color: #15803d;
}

.multiplayer-lobby {
    grid-column: 1 / -1;
}

.multiplayer-lobby-header,
.multiplayer-lobby-actions {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
}

.multiplayer-lobby-actions .multiplayer-waiting {
    flex: 1 1 auto;
}

.multiplayer-lobby-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(16rem, 0.45fr);
    gap: 1rem;
}

.multiplayer-player-list,
.multiplayer-room-settings,
.game-multiplayer-list,
.game-final-leaderboard {
    display: grid;
    gap: 0.55rem;
}

.multiplayer-player-row,
.multiplayer-room-settings > div,
.game-multiplayer-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.65rem;
    align-items: center;
    min-width: 0;
    padding: 0.75rem 0.85rem;
    border: 3px solid var(--apg-ink);
    border-radius: 1rem;
    background: #fffdf7;
    box-shadow: var(--apg-shadow-sm);
}

.multiplayer-room-settings > div {
    background: var(--apg-airbnb);
    color: white;
}

.multiplayer-settings-card {
    width: min(100%, 34rem);
    max-height: calc(100dvh - clamp(2rem, 8vw, 4rem));
    overflow-y: auto;
}

.multiplayer-lobby-config {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
    background: white;
    color: var(--apg-ink);
}

.multiplayer-lobby-config .apg-stat-label {
    color: #475569;
    opacity: 1;
}

.multiplayer-settings-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
}

.multiplayer-room-settings > div .apg-stat-label {
    color: white;
    opacity: 0.8;
}

.multiplayer-player-row strong,
.multiplayer-room-settings strong,
.game-multiplayer-row strong,
.game-multiplayer-row span {
    font-family: var(--font-display);
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.game-multiplayer-row small {
    grid-column: 1 / -1;
    color: #475569;
    font-weight: 900;
    text-transform: uppercase;
}

.game-multiplayer-breakdown {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.game-final-leaderboard {
    width: min(100%, 30rem);
    max-height: min(18rem, 34dvh);
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-right: 0.25rem;
}

@media (max-width: 900px) {
    .multiplayer-screen,
    .multiplayer-card,
    .multiplayer-lobby-grid,
    .game-multiplayer-breakdown {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .multiplayer-form-grid,
    .multiplayer-join-grid,
    .multiplayer-lobby-header,
    .multiplayer-lobby-actions,
    .multiplayer-settings-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .multiplayer-copy-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .multiplayer-action-button,
    .multiplayer-start-button,
    .multiplayer-leave-button {
        width: 100%;
    }
}
