.mobile-menu-panel {
    position: fixed;
    inset: 64px 16px auto 16px;
    z-index: 60;
    display: none;
    flex-direction: column;
    gap: 8px;
    padding: 16px;
    background: rgba(251, 249, 248, 0.96);
    border: 1px solid #c1c8c7;
    border-radius: 16px;
    box-shadow: 0 16px 48px rgba(38, 67, 67, 0.18);
    backdrop-filter: blur(16px);
}

.dark .mobile-menu-panel {
    background: rgba(48, 48, 48, 0.96);
    border-color: #505653;
}

.mobile-menu-panel.is-open {
    display: flex;
}

.mobile-menu-panel a {
    padding: 12px 14px;
    border-radius: 12px;
}

.site-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(27, 28, 28, 0.62);
}

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

.site-modal-panel {
    width: min(720px, 100%);
    max-height: min(760px, 86vh);
    overflow: auto;
    border-radius: 18px;
    background: #fbf9f8;
    border: 1px solid #c1c8c7;
    box-shadow: 0 20px 70px rgba(0, 0, 0, 0.24);
}

.dark .site-modal-panel {
    background: #303030;
    border-color: #505653;
}

.search-input {
    width: 100%;
    border: 1px solid #c1c8c7;
    border-radius: 12px;
    padding: 14px 16px;
    background: #ffffff;
    color: #1b1c1c;
}

.dark .search-input {
    background: #393f3c;
    color: #f2f0f0;
    border-color: #505653;
}

.search-result {
    display: block;
    padding: 14px 0;
    border-top: 1px solid rgba(113, 120, 120, 0.28);
}

.lightbox-image {
    max-width: min(1080px, 94vw);
    max-height: 78vh;
    border-radius: 18px;
    object-fit: contain;
    background: #fbf9f8;
}

.modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
    border-radius: 9999px;
    background: rgba(251, 249, 248, 0.92);
    color: #264343;
    display: grid;
    place-items: center;
}

.reference-preview-card {
    overflow: hidden;
    border: 1px solid var(--outline-variant, #c1c8c7);
    border-radius: 10px;
    background: var(--surface-container-low, #ffffff);
}

.reference-preview-frame {
    min-height: 300px;
    max-height: 520px;
    display: grid;
    place-items: center;
    padding: 12px;
    background: #f5f3f3;
    border-bottom: 1px solid rgba(113, 120, 120, 0.2);
    box-sizing: border-box;
}

.reference-preview-image {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 496px;
    object-fit: contain;
    border-radius: 8px;
}

.reference-preview-meta {
    padding: 12px;
}

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

.remove-reference-image {
    width: 40px;
    height: 40px;
    display: inline-grid;
    flex: 0 0 auto;
    place-items: center;
    border-radius: 999px;
    color: var(--error, #ba1a1a);
    background: color-mix(in srgb, var(--error, #ba1a1a) 9%, transparent);
    transition: background-color 180ms ease, transform 180ms ease;
}

.remove-reference-image:hover {
    background: color-mix(in srgb, var(--error, #ba1a1a) 15%, transparent);
    transform: translateY(-1px);
}

.remove-reference-image .material-symbols-outlined {
    font-size: 20px;
}

.generation-task-shell {
    display: block;
    padding: 12px;
    overflow: auto;
}

.generation-task-list {
    display: grid;
    gap: 12px;
    width: 100%;
}

.generation-task-card {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid rgba(113, 120, 120, 0.28);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.72);
}

.generation-task-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.generation-task-status {
    flex: 0 0 auto;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(70, 100, 99, 0.12);
    color: var(--primary, #264343);
    font-size: 13px;
    font-weight: 700;
}

.generation-task-card.is-error .generation-task-status {
    background: rgba(186, 26, 26, 0.1);
    color: var(--error, #ba1a1a);
}

.generation-task-prompt {
    margin: 0;
    color: var(--secondary, #5e5f5b);
    font-size: 14px;
    line-height: 1.5;
}

.generation-task-body {
    min-height: 120px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: rgba(239, 237, 237, 0.72);
    overflow: hidden;
}

.generation-task-loading {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--secondary, #5e5f5b);
    font-size: 14px;
}

.generation-task-card.is-running .generation-task-loading .material-symbols-outlined {
    animation: generation-task-spin 1.2s linear infinite;
}

.generation-task-image-link {
    display: block;
    width: 100%;
}

.generation-task-image {
    display: block;
    width: 100%;
    height: auto;
    max-height: 560px;
    object-fit: contain;
}

.generation-task-error {
    margin: 0;
    padding: 16px;
    color: var(--error, #ba1a1a);
    line-height: 1.5;
    word-break: break-word;
}

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

.landing-switch-main {
    box-sizing: border-box;
    width: 100vw !important;
    max-width: none !important;
    min-height: 100vh;
    height: 100vh;
    margin: 0 !important;
    padding: 0 !important;
    display: grid;
    align-items: stretch;
}

body:has(.landing-switch-main) {
    overflow: hidden;
}

.labs-switch-hero {
    --labs-tone: #07100f;
    --labs-tone-end: #07100f;
    --labs-glow-a: rgba(55, 132, 118, 0.36);
    --labs-glow-b: rgba(196, 232, 117, 0.22);
    position: relative;
    width: 100vw;
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
    display: grid;
    place-items: center;
    border-radius: 0;
    background:
        radial-gradient(circle at 18% 16%, var(--labs-glow-a), transparent 30%),
        radial-gradient(circle at 82% 24%, var(--labs-glow-b), transparent 31%),
        radial-gradient(circle at 54% 82%, rgba(255, 126, 89, 0.18), transparent 32%),
        linear-gradient(135deg, var(--labs-tone), var(--labs-tone-end) 62%);
    color: #fffaf4;
    isolation: isolate;
    box-shadow: none;
}

.labs-switch-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(circle at 50% 48%, rgba(7, 16, 15, 0.12), rgba(7, 16, 15, 0.7) 58%, rgba(7, 16, 15, 0.9)),
        linear-gradient(180deg, rgba(7, 16, 15, 0.35), rgba(7, 16, 15, 0.72));
    pointer-events: none;
}

.labs-transition-layer {
    --labs-pop-a: rgba(112, 255, 218, 0.98);
    --labs-pop-b: rgba(255, 238, 61, 0.96);
    --labs-pop-c: rgba(255, 112, 92, 0.62);
    --labs-pop-d: rgba(96, 168, 255, 0.52);
    --labs-conic-a: rgba(87, 255, 201, 0.42);
    --labs-conic-b: rgba(255, 244, 75, 0.38);
    --labs-conic-c: rgba(255, 109, 92, 0.32);
    --labs-conic-d: rgba(99, 174, 255, 0.34);
    --labs-shade-a: rgba(7, 16, 15, 0.1);
    --labs-shade-b: rgba(7, 16, 15, 0.34);
    position: absolute;
    inset: 0;
    z-index: 2;
    overflow: hidden;
    display: grid;
    place-items: center;
    pointer-events: none;
    background:
        radial-gradient(circle at 27% 28%, var(--labs-pop-a), transparent 18%),
        radial-gradient(circle at 73% 25%, var(--labs-pop-b), transparent 19%),
        radial-gradient(circle at 66% 72%, var(--labs-pop-c), transparent 26%),
        radial-gradient(circle at 31% 76%, var(--labs-pop-d), transparent 23%),
        conic-gradient(from 140deg at 52% 47%, var(--labs-conic-a), var(--labs-conic-b), var(--labs-conic-c), var(--labs-conic-d), var(--labs-conic-a)),
        linear-gradient(135deg, var(--labs-tone, #2f3b21), var(--labs-tone-end, #172315) 70%);
    clip-path: polygon(47% 29%, 58% 28%, 68% 33%, 74% 43%, 73% 56%, 66% 67%, 55% 73%, 42% 71%, 32% 63%, 29% 51%, 32% 39%, 39% 32%);
    contain: paint;
    will-change: clip-path, opacity;
}

.labs-transition-layer::before {
    content: "";
    position: absolute;
    inset: -12%;
    z-index: 1;
    background:
        radial-gradient(circle at 32% 23%, var(--labs-pop-a), transparent 10%),
        radial-gradient(circle at 76% 35%, var(--labs-pop-b), transparent 11%),
        radial-gradient(circle at 44% 80%, var(--labs-pop-c), transparent 14%);
    filter: blur(0.4px) saturate(1.36);
    pointer-events: none;
}

.labs-transition-layer::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    background:
        radial-gradient(circle at 52% 48%, rgba(255, 250, 244, 0.1), var(--labs-shade-a) 44%, var(--labs-shade-b)),
        linear-gradient(180deg, rgba(7, 16, 15, 0.08), var(--labs-shade-b));
    pointer-events: none;
}

.labs-transition-layer .labs-switch-stage {
    inset: -24px;
    z-index: 0;
}

.labs-transition-layer[data-labs-slide="0"] .labs-tile img {
    filter: saturate(1.08) hue-rotate(0deg) contrast(1.02);
}

.labs-transition-layer[data-labs-slide="1"] .labs-tile img {
    filter: saturate(1.28) hue-rotate(-24deg) contrast(1.06);
}

.labs-transition-layer[data-labs-slide="2"] .labs-tile img {
    filter: saturate(1.32) hue-rotate(42deg) contrast(1.08);
}

.labs-transition-layer .labs-switch-copy {
    z-index: 3;
}

.labs-blob-title {
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 4;
    width: min(760px, calc(100% - 40px));
    display: grid;
    gap: 10px;
    justify-items: center;
    text-align: center;
    color: #fffaf4;
    transform: translate(-50%, -50%);
    pointer-events: none;
    will-change: transform, opacity;
}

.labs-blob-title p {
    margin: 0;
    color: rgba(255, 250, 244, 0.82);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
}

.labs-blob-title h2 {
    margin: 0;
    color: #fffaf4;
    font-size: clamp(44px, 8vw, 116px);
    line-height: 0.94;
    letter-spacing: 0;
    text-shadow: 0 14px 48px rgba(0, 0, 0, 0.34);
    text-wrap: balance;
}

.labs-transition-layer .labs-switch-copy h1 {
    text-shadow: 0 8px 42px rgba(0, 0, 0, 0.22);
}

.labs-switch-stage {
    position: absolute;
    inset: -24px;
    z-index: 0;
}

.labs-tile {
    position: absolute;
    overflow: hidden;
    border-radius: 10px;
    background: #172321;
    box-shadow: 0 12px 38px rgba(0, 0, 0, 0.32);
    will-change: transform, opacity, filter;
}

.labs-tile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(1.04) contrast(1.02);
}

.labs-tile-a { left: 3%; top: 4%; width: 16%; height: 22%; }
.labs-tile-b { left: 22%; top: 8%; width: 26%; height: 24%; }
.labs-tile-c { left: 50%; top: 4%; width: 24%; height: 28%; }
.labs-tile-d { right: 2%; top: 10%; width: 20%; height: 21%; }
.labs-tile-e { left: 0; top: 36%; width: 27%; height: 27%; }
.labs-tile-f { left: 31%; top: 36%; width: 26%; height: 27%; }
.labs-tile-g { right: 2%; top: 36%; width: 29%; height: 27%; }
.labs-tile-h { left: 18%; bottom: 3%; width: 60%; height: 24%; }

.labs-switch-copy {
    position: relative;
    z-index: 2;
    width: min(880px, calc(100% - 40px));
    text-align: center;
    display: grid;
    gap: 18px;
    justify-items: center;
}

.labs-switch-copy h1 {
    color: #fffaf4;
    font-size: clamp(52px, 9vw, 126px);
    line-height: 0.95;
    letter-spacing: 0;
    margin: 0;
    text-wrap: balance;
}

.labs-switch-copy p {
    color: rgba(255, 250, 244, 0.86);
    max-width: 720px;
    margin: 0;
}

.labs-switch-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 10px;
}

.labs-switch-actions a,
.labs-switch-button {
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    transition: transform 180ms ease, background-color 180ms ease, color 180ms ease;
}

.labs-switch-actions a {
    padding: 0 28px;
    font: inherit;
    font-weight: 600;
}

.labs-switch-actions a:first-child {
    background: #fffaf4;
    color: #152321;
}

.labs-switch-actions a:last-child {
    background: rgba(255, 250, 244, 0.14);
    border: 1px solid rgba(255, 250, 244, 0.34);
    color: #fffaf4;
}

.labs-switch-actions a:hover,
.labs-switch-button:hover {
    transform: translateY(-2px);
}

.labs-switch-controls {
    position: absolute;
    z-index: 4;
    left: 50%;
    bottom: 22px;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    gap: 20px;
}

.labs-switch-button {
    width: 60px;
    border: 1px solid rgba(255, 250, 244, 0.45);
    background: rgba(7, 16, 15, 0.28);
    color: #fffaf4;
    backdrop-filter: blur(10px);
}

.labs-switch-progress {
    width: 150px;
    height: 6px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 250, 244, 0.28);
}

.labs-switch-progress span {
    display: block;
    width: 33.333%;
    height: 100%;
    border-radius: inherit;
    background: #fffaf4;
    transform-origin: left center;
}

html,
body {
    max-width: 100%;
    overflow-x: hidden;
}

img,
video,
canvas,
svg {
    max-width: 100%;
}

input,
textarea,
select,
button {
    font-size: 16px;
}

@media (min-width: 768px) {
    .mobile-menu-button,
    .mobile-menu-panel {
        display: none !important;
    }
}

@media (max-width: 767px) {
    body {
        -webkit-text-size-adjust: 100%;
    }

    nav .h-16 {
        min-height: 60px;
        height: auto;
    }

    nav .font-display,
    footer .font-display {
        max-width: calc(100vw - 132px);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 22px;
        line-height: 1.2;
    }

    nav button,
    .mobile-menu-button {
        min-width: 44px;
        min-height: 44px;
        display: inline-grid;
        place-items: center;
    }

    .mobile-menu-panel {
        inset: 68px 12px auto 12px;
        border-radius: 14px;
    }

    main {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    main.pt-32,
    main.pt-24 {
        padding-top: 88px !important;
    }

    main .text-display,
    main h1,
    main h1.font-display.text-display {
        font-size: clamp(28px, 8.5vw, 36px) !important;
        line-height: 1.12 !important;
        letter-spacing: 0 !important;
        word-break: keep-all;
        overflow-wrap: normal;
    }

    main .text-body-lg,
    main header p,
    main section p {
        font-size: 16px !important;
        line-height: 1.65 !important;
    }

    .glass-panel {
        border-radius: 14px !important;
    }

    .ambient-shadow {
        box-shadow: 0 8px 24px rgba(61, 90, 90, 0.08);
    }

    .gallery-container {
        gap: 18px !important;
    }

    .gallery-container > div {
        gap: 18px !important;
        margin-top: 0 !important;
    }

    .gallery-item img {
        width: 100% !important;
        height: 280px !important;
        max-height: 68vh;
        object-fit: cover;
    }

    #image-to-image-entry {
        padding: 18px !important;
    }

    #image-to-image-entry .grid {
        gap: 18px !important;
    }

    #image-to-image-entry fieldset {
        grid-template-columns: 1fr !important;
    }

    #image-to-image-result {
        min-height: 220px !important;
    }

    .reference-preview-frame {
        min-height: 320px;
        max-height: 70vh;
    }

    .reference-preview-image {
        max-height: calc(70vh - 24px);
    }

    #image-to-image-submit,
    #gallery-load-more,
    main a,
    main button {
        width: 100%;
        min-height: 44px;
    }

    footer .max-w-container-max {
        align-items: flex-start !important;
        text-align: left;
    }

    footer .flex.gap-unit {
        flex-wrap: wrap;
    }

    .site-modal {
        align-items: flex-end;
        padding: 12px;
    }

    .site-modal-panel {
        width: 100%;
        max-height: 82vh;
        border-radius: 16px;
    }

    .lightbox-image {
        max-width: 94vw;
        max-height: 72vh;
        border-radius: 14px;
    }

    .labs-switch-hero {
        height: 100vh;
        min-height: 100vh;
        border-radius: 0;
    }

    .labs-switch-stage {
        inset: -14px;
    }

    .labs-transition-layer .labs-switch-stage {
        inset: -14px;
    }

    .labs-blob-title {
        width: min(100% - 28px, 520px);
        gap: 8px;
    }

    .labs-blob-title h2 {
        font-size: clamp(38px, 13vw, 66px);
        line-height: 0.98;
    }

    .labs-tile-a { left: -8%; top: 4%; width: 34%; height: 18%; }
    .labs-tile-b { left: 30%; top: 6%; width: 48%; height: 18%; }
    .labs-tile-c { left: 82%; top: 8%; width: 34%; height: 18%; }
    .labs-tile-d { right: -10%; top: 30%; width: 42%; height: 22%; }
    .labs-tile-e { left: -14%; top: 34%; width: 52%; height: 22%; }
    .labs-tile-f { left: 28%; top: 58%; width: 44%; height: 19%; }
    .labs-tile-g { right: -15%; top: 62%; width: 48%; height: 18%; }
    .labs-tile-h { left: -8%; bottom: 3%; width: 70%; height: 17%; }

    .labs-switch-copy {
        width: min(100% - 28px, 520px);
        gap: 14px;
    }

    .labs-switch-copy h1 {
        font-size: clamp(42px, 14vw, 68px) !important;
        line-height: 0.98 !important;
    }

    .labs-switch-actions {
        width: 100%;
    }

    .labs-switch-actions a {
        width: 100%;
    }

    .labs-switch-controls {
        gap: 12px;
        bottom: 16px;
    }

    .labs-switch-button {
        width: 52px !important;
        min-height: 52px !important;
    }

    .labs-switch-progress {
        width: 104px;
    }

    #crud-modal,
    #password-modal {
        padding: 12px !important;
        align-items: flex-end !important;
    }

    #crud-modal-content,
    #password-modal-content {
        width: 100% !important;
        max-width: none !important;
        max-height: 84vh;
        overflow: auto;
        padding: 18px !important;
        border-radius: 16px !important;
    }

    #crud-modal-content .flex.justify-between {
        align-items: flex-start !important;
        gap: 12px;
    }

    #crud-modal-content .flex.justify-end,
    #password-modal-content .flex.justify-center {
        flex-direction: column;
    }

    #crud-modal-content button,
    #password-modal-content button {
        width: 100%;
        min-height: 44px;
    }
}
