﻿html,
body {
    background: #ffffff;
    color: #121212;
    font-family: "Futura Light", Futura, "Avenir Next", "Segoe UI Light", "Segoe UI", Arial, sans-serif;
    margin: 0;
}

.beta-gate-shell {
    align-items: center;
    background:
        radial-gradient(circle at top right, rgba(119, 149, 163, .18), transparent 24%),
        linear-gradient(180deg, #ffffff, #f7f9fa);
    display: flex;
    justify-content: center;
    min-height: 100vh;
    padding: 1.5rem;
}

.beta-gate-card {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    box-shadow: 0 18px 60px rgba(0, 0, 0, .08);
    max-width: 32rem;
    padding: 2rem;
    width: min(100%, 32rem);
}

.beta-gate-loading {
    text-align: center;
}

.beta-gate-logo {
    display: block;
    height: 5.2rem;
    margin-bottom: 1rem;
    object-fit: cover;
    width: 5.2rem;
}

.beta-gate-card h1 {
    color: #111111;
    font-size: clamp(2rem, 6vw, 3.2rem);
    font-weight: 300;
    line-height: 1.02;
    margin: 0;
}

.beta-gate-copy {
    color: #222222;
    line-height: 1.65;
    margin: 1rem 0 0;
}

.beta-gate-form {
    display: grid;
    gap: .75rem;
    grid-template-columns: minmax(0, 1fr) auto;
    margin-top: 1.35rem;
}

.beta-gate-form input {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    font: inherit;
    min-height: 2.8rem;
    min-width: 0;
    padding: 0 .85rem;
    width: 100%;
}

.beta-gate-message {
    margin-top: 1rem !important;
}

.welcome-overlay {
    align-items: center;
    background: rgba(17, 17, 17, .64);
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 1.25rem;
    position: fixed;
    z-index: 1200;
}

.welcome-card {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    box-shadow: 0 18px 60px rgba(0, 0, 0, .14);
    max-width: 38rem;
    padding: 1.5rem;
    width: min(100%, 38rem);
}

.welcome-card h2 {
    color: #111111;
    font-size: clamp(1.8rem, 5vw, 2.8rem);
    font-weight: 300;
    line-height: 1.05;
    margin: 0;
}

.welcome-card p:not(.eyebrow) {
    color: #333333;
    line-height: 1.6;
    margin: .8rem 0 0;
}

.welcome-form {
    display: grid;
    gap: .8rem;
    margin-top: 1rem;
}

.welcome-form input[type="email"] {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    font: inherit;
    min-height: 2.8rem;
    padding: 0 .85rem;
    width: 100%;
}

.terms-row {
    align-items: flex-start;
}

.terms-row span {
    color: #111111;
    line-height: 1.5;
}

.welcome-actions {
    display: flex;
    justify-content: flex-end;
}

.admin-shell {
    display: grid;
    gap: 1rem;
    margin-top: 1rem;
}

.admin-login-card,
.admin-card {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    padding: 1.35rem;
}

.admin-login-card {
    margin: 2rem auto 0;
    max-width: 34rem;
    width: min(100%, 34rem);
}

.admin-login-card h1,
.admin-header h1,
.admin-card h2,
.admin-chip-card h3 {
    color: #111111;
    font-weight: 300;
    margin: 0;
}

.admin-login-form,
.admin-search,
.admin-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.admin-login-form {
    margin-top: 1rem;
}

.admin-login-form input,
.admin-search input,
.admin-form-grid input,
.admin-form-grid select,
.admin-chip-actions select,
.admin-import-area {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    font: inherit;
}

.admin-login-form input,
.admin-search input,
.admin-form-grid input,
.admin-form-grid select,
.admin-chip-actions select {
    min-height: 2.75rem;
    min-width: 0;
    padding: 0 .8rem;
}

.admin-import-area {
    min-height: 11rem;
    padding: .8rem;
    resize: vertical;
    width: 100%;
}

.admin-header {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

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

.admin-form-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 1rem 0;
}

.admin-form-grid label,
.admin-chip-actions label {
    display: grid;
    gap: .4rem;
}

.admin-form-grid span,
.admin-chip-actions span {
    color: #111111;
    font-size: .86rem;
}

.admin-token-box {
    display: grid;
    gap: .55rem;
    margin-top: 1rem;
}

.admin-token-box textarea {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    color: #111111;
    font: inherit;
    padding: .8rem;
    width: 100%;
}

.admin-list-card {
    display: grid;
    gap: 1rem;
}

.admin-tab-bar {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}

.admin-tab-bar button {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .45);
    border-radius: 8px;
    color: #111111;
    cursor: pointer;
    font: inherit;
    min-height: 2.7rem;
    padding: 0 1rem;
}

.admin-tab-bar button.is-active {
    background: #1f1f1f;
    border-color: #1f1f1f;
    color: #ffffff;
}

.admin-list-header {
    align-items: end;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.admin-list-header p {
    color: #4b5d65;
    margin: .45rem 0 0;
}

.admin-search input {
    min-width: min(100%, 20rem);
}

.admin-filter-bar {
    align-items: end;
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-filter-bar label {
    display: grid;
    gap: .4rem;
}

.admin-filter-bar span {
    color: #111111;
    font-size: .86rem;
}

.admin-filter-bar select {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    min-height: 2.75rem;
    min-width: 0;
    padding: 0 .8rem;
}

.admin-filter-reset {
    align-self: end;
}

.admin-chip-list {
    display: grid;
    gap: .85rem;
}

.admin-flow-list {
    display: grid;
    gap: .85rem;
}

.admin-flow-card {
    align-items: start;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, .9fr) minmax(280px, 1.1fr) minmax(180px, .45fr);
    padding: 1rem;
}

.admin-flow-card h3 {
    color: #111111;
    font-size: 1.25rem;
    font-weight: 300;
    margin: 0;
    overflow-wrap: anywhere;
}

.admin-flow-card p {
    color: #333333;
    margin: .35rem 0 0;
    overflow-wrap: anywhere;
}

.admin-chip-card {
    align-items: start;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.3fr) minmax(220px, .7fr);
    padding: 1rem;
}

.admin-chip-meta p {
    color: #333333;
    margin: .35rem 0 0;
    overflow-wrap: anywhere;
}

.admin-pro-flow {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
    padding: .85rem;
}

.admin-pro-flow-header {
    align-items: baseline;
    display: flex;
    flex-wrap: wrap;
    gap: .45rem .75rem;
    justify-content: space-between;
}

.admin-pro-flow-header strong {
    color: #111111;
    font-weight: 500;
}

.admin-pro-flow-header span,
.admin-pro-flow-details span {
    color: #4b5d65;
    font-size: .86rem;
}

.admin-pro-flow ol {
    display: grid;
    gap: .65rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.admin-pro-flow li {
    align-items: start;
    display: grid;
    gap: .55rem;
    grid-template-columns: auto minmax(0, 1fr);
}

.admin-pro-flow li div {
    display: grid;
    gap: .16rem;
}

.admin-pro-flow li strong {
    color: #111111;
    font-size: .92rem;
    font-weight: 500;
}

.admin-pro-flow li span:not(.admin-pro-flow-dot) {
    color: #4b5d65;
    font-size: .84rem;
}

.admin-pro-flow-dot {
    background: #dfe7eb;
    border: 2px solid #ffffff;
    border-radius: 999px;
    box-shadow: 0 0 0 1px rgba(119, 149, 163, .4);
    height: .85rem;
    margin-top: .22rem;
    width: .85rem;
}

.admin-pro-flow li.is-done .admin-pro-flow-dot {
    background: #3f7f64;
    box-shadow: 0 0 0 1px rgba(63, 127, 100, .35);
}

.admin-pro-flow li.is-current .admin-pro-flow-dot {
    animation: pro-flow-pulse 1.6s ease-in-out infinite;
    background: #7795a3;
    box-shadow: 0 0 0 1px rgba(119, 149, 163, .5);
}

.admin-pro-flow li.is-warning .admin-pro-flow-dot {
    background: #b56b35;
    box-shadow: 0 0 0 1px rgba(181, 107, 53, .45);
}

.admin-pro-flow-details {
    border-top: 1px solid rgba(119, 149, 163, .22);
    display: grid;
    gap: .3rem;
    padding-top: .65rem;
}

@keyframes pro-flow-pulse {
    0%,
    100% {
        box-shadow: 0 0 0 1px rgba(119, 149, 163, .55), 0 0 0 0 rgba(119, 149, 163, .3);
    }

    50% {
        box-shadow: 0 0 0 1px rgba(119, 149, 163, .55), 0 0 0 .35rem rgba(119, 149, 163, 0);
    }
}

.admin-chip-actions {
    display: grid;
    gap: .7rem;
    justify-items: stretch;
}

h1:focus {
    outline: none;
}

a,
.btn-link {
    color: #7795a3;
}

.start-hero {
    background: #ffffff;
    border-bottom: 1px solid rgba(18, 18, 18, .12);
    border-radius: 0;
    box-shadow: none;
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1fr) minmax(300px, .95fr);
    align-items: center;
    min-height: 24rem;
    overflow: hidden;
    padding: 1.4rem 0 2.5rem;
    position: relative;
}

.start-hero::before {
    display: none;
}

.hero-logo {
    display: block;
    height: 5.75rem;
    margin-bottom: 1.3rem;
    object-fit: cover;
    width: 5.75rem;
}

.start-copy h1 {
    color: #111111;
    font-size: clamp(2.7rem, 7vw, 5.4rem);
    font-weight: 300;
    line-height: 1.02;
    margin: 0;
    max-width: 12ch;
}

.start-copy p {
    color: #222222;
    font-size: 1.12rem;
    line-height: 1.65;
    margin: 1.2rem 0 0;
    max-width: 39rem;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .85rem;
    margin-top: 1.5rem;
}

.hero-media {
    display: flex;
    justify-content: flex-end;
}

.hero-video-frame {
    aspect-ratio: 1 / 1;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, .42), rgba(119, 149, 163, .14) 44%, rgba(119, 149, 163, .28)),
        linear-gradient(180deg, rgba(244, 246, 247, .96), rgba(223, 231, 235, .96));
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(17, 17, 17, .08);
    overflow: hidden;
    position: relative;
    width: min(100%, 28rem);
}

.hero-video-frame::before {
    background: url("../images/resin-memory-pendant.png") center / cover no-repeat;
    content: "";
    filter: blur(18px) saturate(.86);
    inset: 0;
    opacity: .24;
    position: absolute;
    transform: scale(1.08);
}

.hero-video {
    display: block;
    height: 100%;
    object-fit: contain;
    position: relative;
    width: 100%;
    z-index: 1;
}

.inline-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.link-action,
.secondary-action {
    align-items: center;
    border-radius: 8px;
    display: inline-flex;
    font-weight: 400;
    min-height: 2.9rem;
    padding: 0 1rem;
    text-decoration: none;
}

.secondary-action {
    background: transparent;
    border: 1px solid rgba(119, 149, 163, .8);
    color: #121212;
}

.start-steps {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 1rem;
}

.access-panel {
    background: #ffffff;
    border: 1px solid rgba(18, 18, 18, .14);
    border-radius: 8px;
    display: grid;
    gap: 1.25rem;
    grid-template-columns: minmax(260px, .8fr) minmax(320px, .9fr);
    margin-top: 0;
    padding: 1.4rem;
}

.access-intro h2 {
    color: #111111;
    font-size: clamp(1.7rem, 4vw, 2.8rem);
    font-weight: 300;
    line-height: 1;
    margin: 0;
    max-width: 11ch;
}

.access-intro p:not(.eyebrow) {
    color: #222222;
    line-height: 1.6;
    margin: .85rem 0 0;
}

.mobile-copy {
    display: none;
}

.access-methods {
    display: grid;
    gap: .85rem;
    grid-template-columns: minmax(0, 1fr);
}

.access-method {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .4);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: .85rem;
    min-height: 14rem;
    padding: 1rem;
}

.mobile-scan-method {
    display: none;
}

.primary-code-method {
    background: #ffffff;
}

.method-kicker {
    color: #7795a3;
    display: block;
    font-size: .78rem;
    margin-bottom: .65rem;
}

.access-method h3 {
    color: #111111;
    font-size: 1.25rem;
    font-weight: 300;
    margin: 0;
}

.access-method p {
    color: #333333;
    line-height: 1.5;
    margin: .55rem 0 0;
}

.secondary-button {
    background: transparent;
    border: 1px solid rgba(119, 149, 163, .55);
    border-radius: 8px;
    color: #111111;
    cursor: pointer;
    font-weight: 400;
    min-height: 2.75rem;
    padding: 0 1rem;
}

.method-message {
    background: rgba(119, 149, 163, .14);
    border-radius: 8px;
    color: #111111 !important;
    font-size: .9rem;
    margin-top: auto !important;
    padding: .7rem;
}

.method-message-error {
    background: rgba(181, 57, 57, .12);
    border: 1px solid rgba(181, 57, 57, .28);
    color: #7a1f1f !important;
    font-size: 1rem;
    font-weight: 500;
    padding: .9rem 1rem;
}

.manual-code {
    display: grid;
    gap: .55rem;
    margin-top: auto;
}

.manual-code input {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .85);
    border-radius: 8px;
    color: #111111;
    min-height: 2.75rem;
    padding: 0 .85rem;
    width: 100%;
}

.manual-code input::placeholder {
    color: #8ea9b5;
}

.qr-preview {
    aspect-ratio: 4 / 3;
    background: #111719;
    border: 1px solid rgba(119, 149, 163, .26);
    border-radius: 8px;
    display: none;
    object-fit: cover;
    width: 100%;
}

.qr-preview.is-active {
    display: block;
}

.info-tabs-section {
    background: #ffffff;
    border: 1px solid rgba(18, 18, 18, .12);
    border-radius: 8px;
    margin-top: 1rem;
    padding: 1.25rem;
}

.info-tabs-intro {
    max-width: 48rem;
}

.info-tabs-intro h2 {
    color: #111111;
    font-size: clamp(1.8rem, 4vw, 3.1rem);
    font-weight: 300;
    line-height: 1.08;
    margin: 0;
}

.info-tabs-intro p:not(.eyebrow) {
    color: #333333;
    line-height: 1.65;
    margin: .85rem 0 0;
}

.info-tab-buttons {
    border-bottom: 1px solid rgba(119, 149, 163, .32);
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
    margin-top: 1.1rem;
}

.info-tab-button {
    background: transparent;
    border: 0;
    border-bottom: 2px solid transparent;
    color: #333333;
    cursor: pointer;
    font: inherit;
    padding: .7rem .8rem;
}

.info-tab-button.active {
    border-bottom-color: #7795a3;
    color: #111111;
}

.info-tab-panel {
    margin-top: 1.2rem;
}

.memory-explainer,
.flow-panel {
    align-items: center;
    display: grid;
    gap: 1.25rem;
    grid-template-columns: minmax(230px, .85fr) minmax(0, 1fr);
}

.warm-photo {
    aspect-ratio: 1 / 1;
    background: #f5f0eb;
    border-radius: 8px;
    margin: 0;
    overflow: hidden;
}

.warm-photo img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.memory-explainer h3,
.use-case-grid h3 {
    color: #111111;
    font-size: 1.35rem;
    font-weight: 300;
    margin: 0;
}

.memory-explainer p,
.use-case-grid p,
.flow-panel span {
    color: #333333;
    line-height: 1.55;
}

.feature-pills {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1rem;
}

.feature-pills span {
    background: rgba(119, 149, 163, .16);
    border-radius: 999px;
    color: #111111;
    padding: .45rem .75rem;
}

.flow-panel {
    grid-template-columns: minmax(180px, .55fr) minmax(0, 1fr);
}

.flow-panel img {
    background: #050505;
    border-radius: 8px;
    max-width: 18rem;
    width: 100%;
}

.flow-panel ol {
    display: grid;
    gap: .75rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.flow-panel li {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .28);
    border-radius: 8px;
    padding: .9rem;
}

.flow-panel strong,
.flow-panel span {
    display: block;
}

.flow-panel strong {
    color: #111111;
    font-weight: 300;
}

.flow-panel span {
    margin-top: .25rem;
}

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

.use-case-grid article {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .28);
    border-radius: 8px;
    display: grid;
    gap: .9rem;
    padding: 1rem;
}

.use-case-grid span {
    color: #7795a3;
    display: block;
    font-size: .78rem;
    margin-bottom: .6rem;
    text-transform: uppercase;
}

.use-case-image {
    aspect-ratio: 4 / 5;
    border-radius: 8px;
    margin: 0;
    overflow: hidden;
}

.use-case-image img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.start-steps article {
    background: #ffffff;
    border: 1px solid rgba(18, 18, 18, .12);
    border-radius: 8px;
    display: grid;
    gap: .55rem;
    padding: 1rem;
}

.start-steps strong {
    align-items: center;
    background: #7795a3;
    border-radius: 50%;
    color: #050505;
    display: flex;
    font-weight: 700;
    height: 2rem;
    justify-content: center;
    width: 2rem;
}

.start-steps h2 {
    color: #111111;
    font-size: 1rem;
    font-weight: 300;
    margin: .8rem 0 .3rem;
}

.start-steps p {
    color: #333333;
    margin: 0;
}

.inline-link {
    color: #567180;
    font-size: .92rem;
    text-decoration: underline;
    text-underline-offset: .15rem;
}

.inline-link:hover {
    color: #111111;
}

.memory-header {
    align-items: flex-start;
    background: #ffffff;
    border: 1px solid rgba(18, 18, 18, .12);
    border-radius: 8px;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    padding: 1.25rem;
}

.memory-header h1 {
    color: #111111;
    font-size: clamp(2rem, 6vw, 3.8rem);
    font-weight: 300;
    line-height: 1;
    margin: 0;
    max-width: 12ch;
}

.memory-header p {
    color: #333333;
    margin: .75rem 0 0;
    max-width: 42rem;
}

.memory-header .memory-subtitle {
    color: #7795a3;
    font-size: .82rem;
    letter-spacing: 0;
    margin-top: .7rem;
    text-transform: uppercase;
}

.memory-header .header-actions,
.memory-header > div:first-child > p:last-child:not(.memory-subtitle):not(.eyebrow) {
    display: none;
}

.plan-panel,
.password-panel,
.plan-compare-panel {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    margin-top: 1rem;
    padding: 1.1rem;
}

.plan-panel.is-pro {
    background: linear-gradient(135deg, rgba(119, 149, 163, .12), rgba(255, 255, 255, 1) 55%);
}

.plan-panel h2,
.password-panel h2,
.plan-compare-panel h2 {
    color: #111111;
    font-size: 1.45rem;
    font-weight: 300;
    margin: 0;
}

.plan-panel p:not(.eyebrow),
.password-panel p:not(.eyebrow),
.plan-compare-panel p:not(.eyebrow) {
    color: #333333;
    line-height: 1.6;
    margin: .45rem 0 0;
}

.plan-grid,
.plan-compare-grid {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 1rem;
}

.plan-stat,
.compare-column {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .22);
    border-radius: 8px;
    display: grid;
    gap: .4rem;
    padding: .9rem;
}

.plan-stat strong,
.compare-column strong {
    color: #111111;
    font-size: 1rem;
    font-weight: 400;
}

.plan-stat span,
.compare-column span,
.helper-copy {
    color: #333333;
    line-height: 1.5;
}

.plan-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    margin-top: 1rem;
}

.compare-column.is-active {
    animation: active-plan-glow 3.8s ease-in-out infinite;
    border-color: rgba(86, 139, 164, .92);
    box-shadow:
        inset 0 0 0 1px rgba(86, 139, 164, .5),
        0 0 0 3px rgba(86, 139, 164, .08),
        0 0 18px rgba(86, 139, 164, .18);
    position: relative;
}

.compare-column.is-active::after {
    background: #568ba4;
    border-radius: 999px;
    color: #ffffff;
    content: "Aktiv";
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 0;
    padding: .18rem .5rem;
    position: absolute;
    right: .7rem;
    top: .7rem;
}

@keyframes active-plan-glow {
    0%,
    100% {
        box-shadow:
            inset 0 0 0 1px rgba(86, 139, 164, .5),
            0 0 0 3px rgba(86, 139, 164, .08),
            0 0 18px rgba(86, 139, 164, .16);
    }

    50% {
        box-shadow:
            inset 0 0 0 1px rgba(86, 139, 164, .7),
            0 0 0 4px rgba(86, 139, 164, .12),
            0 0 26px rgba(86, 139, 164, .26);
    }
}

@media (prefers-reduced-motion: reduce) {
    .compare-column.is-active {
        animation: none;
    }
}

.compare-column ul {
    color: #333333;
    line-height: 1.55;
    margin: .2rem 0 0;
    padding-left: 1.1rem;
}

.plans-page {
    display: grid;
    gap: 1rem;
}

.plans-hero,
.plans-highlights article {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    padding: 1.25rem;
}

.plans-hero h1 {
    color: #111111;
    font-size: clamp(2rem, 5vw, 3.4rem);
    font-weight: 300;
    margin: 0;
}

.plans-hero p:not(.eyebrow),
.plans-highlights p {
    color: #333333;
    line-height: 1.6;
    margin: .55rem 0 0;
    max-width: 52rem;
}

.plans-compare-panel {
    margin-top: 0;
}

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

.plans-highlights h2 {
    color: #111111;
    font-size: 1.3rem;
    font-weight: 300;
    margin: 0;
}

.plans-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.password-form {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
}

.toggle-row {
    align-items: center;
    display: inline-flex;
    gap: .65rem;
}

.toggle-row input {
    accent-color: #7795a3;
}

.eyebrow {
    color: #7795a3 !important;
    font-size: .78rem;
    font-weight: 400;
    letter-spacing: 0;
    margin: 0 0 .5rem !important;
    text-transform: uppercase;
}

.status-pill {
    background: rgba(119, 149, 163, .2);
    border-radius: 999px;
    color: #111111;
    font-weight: 400;
    padding: .45rem .8rem;
    white-space: nowrap;
}

.header-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .7rem;
    justify-content: flex-end;
}

.memory-showcase {
    align-items: center;
    background: #ffffff;
    border-bottom: 1px solid rgba(18, 18, 18, .12);
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, .75fr) minmax(260px, 1fr);
    margin-top: 1rem;
    padding: 1.25rem 0;
}

.memory-showcase > div:first-child:not(.showcase-preview) {
    display: none;
}

.memory-showcase {
    grid-template-columns: 1fr;
}

.memory-showcase h2 {
    color: #111111;
    font-size: clamp(1.8rem, 5vw, 3.4rem);
    font-weight: 300;
    line-height: 1.05;
    margin: 0;
    max-width: 11ch;
}

.memory-showcase p:not(.eyebrow) {
    color: #333333;
    line-height: 1.6;
    margin: .85rem 0 0;
    max-width: 33rem;
}

.showcase-preview {
    align-items: center;
    aspect-ratio: 16 / 10;
    background: #050505;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: flex;
    justify-content: center;
    overflow: hidden;
    width: 100%;
}

.showcase-preview img,
.showcase-preview video {
    animation: showcase-fade .9s ease;
}

@keyframes showcase-fade {
    from {
        opacity: .35;
        transform: scale(1.015);
    }

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

.showcase-preview img,
.showcase-preview video,
.viewer-preview img,
.viewer-preview video,
.manage-preview img,
.manage-preview video {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.media-preview-button {
    background: transparent;
    border: 0;
    cursor: zoom-in;
    display: block;
    height: 100%;
    padding: 0;
    width: 100%;
}

.viewer-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    margin-top: 1rem;
}

.viewer-grid-pro {
    align-items: stretch;
    grid-auto-flow: dense;
    grid-auto-rows: 8.5rem;
    grid-template-columns: repeat(12, minmax(0, 1fr));
}

.viewer-card {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: .85rem;
    padding: .85rem;
}

.viewer-grid-pro .viewer-card {
    background: linear-gradient(180deg, #ffffff 0%, #f9fbfc 100%);
    box-shadow: 0 16px 38px rgba(17, 17, 17, .06);
    grid-column: span 4;
    grid-row: span 2;
    min-height: 0;
}

.viewer-grid-pro .viewer-card.is-wide-media {
    grid-column: span 6;
}

.viewer-grid-pro .viewer-card.is-tall-media {
    grid-row: span 3;
}

.viewer-grid-pro .viewer-card.is-natural-portrait {
    grid-column: span 4;
    grid-row: span 4;
}

.viewer-grid-pro .viewer-card.is-natural-landscape {
    grid-column: span 6;
    grid-row: span 2;
}

.viewer-grid-pro .viewer-card.is-natural-square {
    grid-column: span 4;
    grid-row: span 3;
}

.viewer-grid-pro .viewer-card.is-feature-text {
    grid-column: span 6;
    grid-row: span 3;
}

.viewer-grid-pro .viewer-card.is-story-text {
    grid-column: span 8;
    grid-row: span 4;
}

.viewer-grid-pro .viewer-card.is-contact-text {
    grid-column: 1 / -1;
    grid-row: auto;
}

.viewer-grid-pro .viewer-card.is-note-text {
    grid-column: span 4;
    grid-row: span 2;
}

.viewer-grid-pro .viewer-card.is-audio-media {
    grid-column: span 6;
    grid-row: span 1;
}

.viewer-preview {
    align-items: center;
    aspect-ratio: 4 / 3;
    background: #050505;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    overflow: hidden;
    width: 100%;
}

.viewer-grid-pro .viewer-preview {
    aspect-ratio: auto;
    flex: 1;
    min-height: 0;
}

.viewer-grid-pro .viewer-card:not(.viewer-card-text) .viewer-preview {
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .22);
}

.viewer-grid-pro .viewer-card:not(.viewer-card-text) .viewer-preview img,
.viewer-grid-pro .viewer-card:not(.viewer-card-text) .viewer-preview video {
    background: #f7f9fa;
    object-fit: contain;
}

.viewer-card span {
    color: #7795a3;
    display: block;
    font-size: .78rem;
}

.viewer-card h2 {
    color: #111111;
    font-size: 1rem;
    font-weight: 300;
    margin: .25rem 0 0;
    overflow-wrap: anywhere;
}

.viewer-card.viewer-card-text .viewer-preview {
    align-items: stretch;
    aspect-ratio: auto;
    background: transparent;
}

.viewer-grid-pro .viewer-card.viewer-card-text .viewer-preview {
    min-height: 0;
}

.lightbox-backdrop {
    align-items: center;
    background: rgba(10, 10, 10, .88);
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 1.25rem;
    position: fixed;
    z-index: 1200;
}

.lightbox-shell {
    align-items: center;
    display: grid;
    gap: .85rem;
    grid-template-columns: auto minmax(0, 1fr) auto;
    max-height: 92vh;
    max-width: min(1100px, 100%);
    position: relative;
    width: 100%;
}

.lightbox-stage {
    align-items: center;
    display: flex;
    grid-column: 2;
    justify-content: center;
    max-height: 82vh;
    overflow: hidden;
}

.lightbox-stage img {
    border-radius: 8px;
    max-height: 82vh;
    max-width: 100%;
    object-fit: cover;
    width: auto;
}

.lightbox-close,
.lightbox-nav {
    align-items: center;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 999px;
    color: #ffffff;
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
}

.lightbox-close {
    font-size: 1.5rem;
    height: 2.5rem;
    position: absolute;
    right: 0;
    top: -3rem;
    width: 2.5rem;
}

.lightbox-nav {
    font-size: 2rem;
    height: 3rem;
    width: 3rem;
}

.lightbox-nav-prev {
    grid-column: 1;
}

.lightbox-nav-next {
    grid-column: 3;
}

.lightbox-caption {
    align-items: center;
    color: #ffffff;
    display: flex;
    gap: .85rem;
    grid-column: 1 / -1;
    justify-content: space-between;
}

.lightbox-caption strong,
.lightbox-caption span {
    overflow-wrap: anywhere;
}

.empty-memory {
    background: #ffffff;
    border: 1px dashed rgba(119, 149, 163, .5);
    border-radius: 8px;
    margin-top: 1rem;
    padding: 1.25rem;
}

.empty-memory h2 {
    color: #111111;
    font-size: 1.25rem;
    font-weight: 300;
    margin: 0;
}

.empty-memory p {
    color: #333333;
    margin: .45rem 0 1rem;
}

.editor-panel {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    margin-top: 1rem;
    padding: 1rem;
}

.editor-group {
    background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(247, 249, 250, .96));
    border: 1px solid rgba(119, 149, 163, .28);
    border-radius: 8px;
    box-shadow: 0 10px 30px rgba(17, 17, 17, .04);
    margin-top: 1rem;
    padding: 1rem;
}

.editor-group-heading {
    border-bottom: 1px solid rgba(119, 149, 163, .18);
    margin-bottom: 1rem;
    padding-bottom: .9rem;
}

.editor-group-heading h3 {
    color: #111111;
    font-size: 1.2rem;
    font-weight: 300;
    margin: 0;
}

.editor-group-heading p:not(.eyebrow) {
    color: #4b5d65;
    line-height: 1.55;
    margin: .35rem 0 0;
}

.editor-group .title-editor,
.editor-group .upload-panel,
.editor-group .text-panel,
.editor-group .plan-compare-panel,
.editor-group .password-panel,
.editor-group .manage-list,
.editor-group .message-box {
    margin-top: 0;
}

.editor-group .password-panel + .title-editor,
.editor-group .title-editor + .manage-list,
.editor-group .title-editor + .message-box,
.editor-group .upload-panel + .text-panel {
    margin-top: .9rem;
}

.editor-group-plan {
    background: linear-gradient(180deg, rgba(119, 149, 163, .08), rgba(255, 255, 255, .96));
}

.editor-heading {
    align-items: flex-start;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.editor-heading h2 {
    color: #111111;
    font-size: 1.45rem;
    font-weight: 300;
    margin: 0;
}

.editor-heading p:not(.eyebrow) {
    color: #333333;
    margin: .35rem 0 0;
}

.trial-mode-notice {
    background: #fff4d6;
    border: 1px solid rgba(184, 122, 0, .42);
    border-left: 4px solid #b87a00;
    border-radius: 8px;
    color: #3f2a00;
    display: grid;
    gap: .25rem;
    margin-top: .65rem;
    max-width: 44rem;
    padding: .8rem .95rem;
}

.trial-mode-notice strong {
    color: #111111;
    font-size: .92rem;
}

.trial-mode-notice span {
    line-height: 1.45;
}

.title-editor {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: .65rem;
    margin-top: 1rem;
    padding: 1rem;
}

.title-editor label,
.manage-copy label {
    color: #111111;
    display: block;
    font-size: .85rem;
    margin-bottom: .35rem;
}

.title-editor-form,
.media-title-form {
    display: grid;
    gap: .55rem;
    grid-template-columns: minmax(0, 1fr);
}

.title-editor input,
.media-title-form input,
.manage-textarea {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    font: inherit;
    min-height: 2.6rem;
    min-width: 0;
    padding: 0 .75rem;
    width: 100%;
}

.manage-textarea {
    line-height: 1.5;
    margin-top: .55rem;
    min-height: 6rem;
    padding: .75rem;
    resize: vertical;
}

.field-message {
    background: rgba(119, 149, 163, .12);
    border-radius: 8px;
    color: #111111 !important;
    font-size: .86rem;
    padding: .45rem .6rem;
}

.manage-list {
    display: grid;
    gap: .75rem;
    margin-top: 1rem;
}

.manage-item {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: .85rem;
    grid-template-columns: auto 5.5rem minmax(0, 1fr) auto;
    padding: .75rem;
}

.manage-item.is-text-item {
    align-items: start;
    grid-template-columns: auto minmax(0, 1fr) auto;
}

.order-controls {
    display: grid;
    gap: .35rem;
}

.icon-button {
    align-items: center;
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .45);
    border-radius: 8px;
    color: #111111;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    height: 2.15rem;
    justify-content: center;
    line-height: 1;
    width: 2.15rem;
}

.icon-button:hover:not(:disabled) {
    background: rgba(119, 149, 163, .14);
}

.icon-button:disabled {
    cursor: not-allowed;
    opacity: .35;
}

.manage-preview {
    align-items: center;
    aspect-ratio: 1 / 1;
    background: #050505;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    overflow: hidden;
}

.manage-copy {
    min-width: 0;
}

.manage-copy h3 {
    color: #111111;
    font-size: 1rem;
    font-weight: 300;
    margin: 0;
    overflow-wrap: anywhere;
}

.manage-copy p {
    color: #333333;
    margin: .25rem 0 0;
}

.text-edit-shell {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1fr) minmax(240px, .9fr);
}

.text-result-preview {
    display: grid;
    gap: .35rem;
}

.text-result-card {
    border: 1px solid rgba(119, 149, 163, .22);
    border-radius: 8px;
    min-height: 11rem;
    overflow: auto;
}

.danger-button {
    background: #111111;
    border: 0;
    border-radius: 8px;
    color: #ffffff;
    cursor: pointer;
    font-weight: 400;
    min-height: 2.5rem;
    padding: 0 .9rem;
}

.danger-button:disabled {
    cursor: wait;
    opacity: .65;
}

.audio-stage {
    align-items: center;
    color: #d8e5ea;
    display: grid;
    gap: .75rem;
    padding: 1rem;
    width: 100%;
}

.audio-stage span {
    color: #d8e5ea;
}

.text-stage {
    background: #f7f9fa;
    color: #111111;
    display: grid;
    gap: .5rem;
    height: 100%;
    overflow: auto;
    padding: 1rem;
    width: 100%;
}

.text-stage strong {
    font-weight: 300;
}

.text-stage p {
    color: #333333;
    line-height: 1.55;
    margin: 0;
    white-space: pre-wrap;
}

.viewer-card.viewer-card-text .text-stage {
    min-height: 16rem;
    padding: 1.35rem;
}

.viewer-grid-pro .viewer-card.viewer-card-text .text-stage {
    background: #f7f9fa;
    display: flex;
    min-height: 0;
    overflow: hidden;
    padding: clamp(1.15rem, 2.2vw, 1.8rem);
}

.viewer-card.viewer-card-text .text-stage p {
    color: #111111;
    font-size: 1.32rem;
    line-height: 1.65;
}

.viewer-grid-pro .viewer-card.viewer-card-text .text-stage p {
    align-self: center;
    font-size: clamp(1.15rem, 2.1vw, 1.55rem);
    line-height: 1.7;
    overflow-wrap: anywhere;
    word-break: normal;
}

.viewer-grid-pro .viewer-card.is-feature-text .text-stage p {
    font-size: clamp(1.2rem, 2.3vw, 1.75rem);
}

.viewer-grid-pro .viewer-card.is-story-text .text-stage p {
    font-size: clamp(1.18rem, 2vw, 1.55rem);
}

.viewer-grid-pro .viewer-card.is-contact-text .text-stage {
    min-height: auto;
    overflow: visible;
}

.viewer-grid-pro .viewer-card.is-contact-text .text-stage p {
    align-self: start;
    columns: 2 18rem;
    column-gap: 2rem;
    font-size: clamp(1rem, 1.8vw, 1.35rem);
    line-height: 1.7;
}

.media-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    margin-top: 1rem;
}

.media-card,
.action-band,
.shop-band,
.message-box,
.info-row {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
}

.media-card {
    background: #ffffff;
    display: flex;
    flex-direction: column;
    gap: .85rem;
    padding: 1rem;
}

.media-preview {
    align-items: center;
    aspect-ratio: 16 / 10;
    background: #050505;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: flex;
    justify-content: center;
    overflow: hidden;
    width: 100%;
}

.media-preview img,
.media-preview video {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.media-preview audio {
    padding: 0 .6rem;
    width: 100%;
}

.media-icon {
    align-items: center;
    background: rgba(119, 149, 163, .2);
    border-radius: 8px;
    color: #d8e5ea;
    display: flex;
    font-weight: 400;
    height: 3.3rem;
    justify-content: center;
    min-width: 4.2rem;
}

.media-card h2,
.action-band h2 {
    color: #111111;
    font-size: 1rem;
    font-weight: 300;
    margin: 0;
}

.media-card p,
.action-band p,
.info-row span {
    color: #333333;
    margin: .35rem 0 0;
}

.action-band {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-top: 1rem;
    padding: 1.25rem;
    background: #ffffff;
}

.upgrade-band {
    align-items: stretch;
    display: grid;
    gap: 1.25rem;
    grid-template-columns: minmax(0, 1fr) minmax(13rem, 16rem);
}

.upgrade-copy {
    display: grid;
    gap: .45rem;
    min-width: 0;
}

.upgrade-copy .field-message {
    margin-top: .35rem !important;
    max-width: 100%;
}

.upgrade-price {
    color: #111111 !important;
    font-size: 1.05rem;
    font-weight: 500;
    margin-top: .15rem !important;
}

.upgrade-actions {
    align-items: stretch;
    align-self: center;
    display: grid;
    gap: .65rem;
    justify-self: stretch;
}

.upgrade-actions .inline-input,
.upgrade-actions .primary-action,
.upgrade-actions .secondary-button {
    width: 100%;
}

.trial-email-prompt {
    display: grid;
    gap: .35rem;
}

.trial-email-prompt span {
    color: #47545a;
    font-size: .82rem;
    line-height: 1.35;
}

.trial-email-prompt .trial-email-error {
    color: #9b2f2f;
    font-weight: 500;
}

.email-update-box {
    background: rgba(255, 255, 255, .66);
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: .55rem;
    padding: .75rem;
}

.email-update-box span {
    color: #333333;
    font-size: .84rem;
    line-height: 1.35;
}

.editor-email-box {
    background: #ffffff;
    margin: 0;
}

.editor-email-box h3 {
    color: #111111;
    font-size: 1.1rem;
    font-weight: 300;
    margin: 0;
}

.editor-email-box p:not(.eyebrow) {
    color: #333333;
    margin: .25rem 0 0;
}

.inline-input {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .85);
    border-radius: 8px;
    color: #111111;
    min-height: 2.75rem;
    padding: 0 .85rem;
    width: 100%;
}

.inline-input::placeholder {
    color: #8ea9b5;
}

.inline-input.input-error {
    border-color: #b84d4d;
    box-shadow: 0 0 0 3px rgba(184, 77, 77, .12);
}

.memory-meta-band {
    align-items: center;
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-top: 1rem;
    padding: 1.25rem;
}

.memory-meta-band h2 {
    color: #111111;
    font-size: 1rem;
    font-weight: 300;
    margin: 0;
}

.memory-meta-band p:not(.eyebrow) {
    color: #333333;
    margin: .35rem 0 0;
}

.header-actions {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    justify-content: flex-end;
}

.claim-panel,
.upload-panel,
.text-panel {
    background: #ffffff;
    border: 1px solid rgba(18, 18, 18, .12);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    margin-top: 1rem;
    padding: 1.25rem;
}

.claim-panel h2,
.upload-panel h2,
.text-panel h2 {
    color: #111111;
    font-size: 1.25rem;
    font-weight: 300;
    margin: 0;
}

.claim-panel p,
.upload-panel p,
.text-panel p {
    color: #333333;
    margin: .35rem 0 0;
}

.text-form {
    display: grid;
    gap: .65rem;
}

.rich-text-toolbar {
    align-items: end;
    display: grid;
    gap: .65rem;
    grid-template-columns: repeat(4, minmax(0, auto));
}

.rich-text-toolbar label {
    display: grid;
    gap: .35rem;
}

.rich-text-toolbar span {
    color: #111111;
    font-size: .85rem;
}

.rich-text-toolbar select {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    font: inherit;
    min-height: 2.6rem;
    padding: 0 .75rem;
}

.format-button {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    cursor: pointer;
    font: inherit;
    min-height: 2.6rem;
    padding: 0 .9rem;
}

.rich-text-preview,
.text-stage {
    display: grid;
    gap: .45rem;
}

.rich-text-preview {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .22);
    border-radius: 8px;
    padding: .8rem;
}

.font-preview.font-futura,
.text-stage.font-futura {
    font-family: "Futura Light", Futura, "Avenir Next", "Segoe UI Light", "Segoe UI", Arial, sans-serif;
}

.font-preview.font-serif,
.text-stage.font-serif {
    font-family: Georgia, "Times New Roman", serif;
}

.font-preview.font-handwritten,
.text-stage.font-handwritten {
    font-family: "Segoe Print", "Bradley Hand", cursive;
}

.font-preview.size-small,
.text-stage.size-small {
    font-size: .92rem;
}

.font-preview.size-medium,
.text-stage.size-medium {
    font-size: 1rem;
}

.font-preview.size-large,
.text-stage.size-large {
    font-size: 1.18rem;
}

.font-preview.is-bold,
.text-stage.is-bold {
    font-weight: 700;
}

.font-preview.is-italic,
.text-stage.is-italic {
    font-style: italic;
}

.contact-form-grid {
    display: grid;
    gap: .65rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.text-form input,
.text-form textarea {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    font: inherit;
    padding: .75rem;
    width: 100%;
}

.text-form textarea {
    resize: vertical;
}

.claim-form {
    display: grid;
    gap: .75rem;
    grid-template-columns: minmax(0, 1fr) auto;
}

.claim-form input {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .75);
    border-radius: 8px;
    color: #111111;
    min-height: 2.75rem;
    padding: 0 .85rem;
}

.file-picker {
    align-items: center;
    background: #f7f9fa;
    border: 1px dashed rgba(119, 149, 163, .55);
    border-radius: 8px;
    box-sizing: border-box;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    min-width: 0;
    overflow: hidden;
    padding: .75rem;
    position: relative;
    width: 100%;
}

.file-picker-button {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .35);
    border-radius: 999px;
    color: #111111;
    font-weight: 400;
    min-height: 2.3rem;
    padding: .45rem .9rem;
    white-space: nowrap;
}

.file-picker span {
    color: #333333;
    flex: 1 1 10rem;
    min-width: 0;
    overflow-wrap: anywhere;
}

.file-picker-input {
    cursor: pointer;
    height: 100%;
    inset: 0;
    opacity: 0;
    position: absolute;
    width: 100%;
}

.selected-files {
    color: #333333;
    margin: 0;
    padding-left: 1.2rem;
}

.shop-band {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin-top: 1rem;
    padding: 1.25rem;
    background: #222222;
}

.shop-band h2 {
    color: #ffffff;
    font-size: 1.25rem;
    font-weight: 300;
    margin: 0;
}

.shop-band p:not(.eyebrow) {
    color: #f5f5f5;
    margin: .45rem 0 0;
    max-width: 42rem;
}

.shop-hero {
    align-content: end;
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .96) 0%, rgba(255, 255, 255, .88) 40%, rgba(255, 255, 255, .08) 100%),
        url("../images/resin-memory-pendant.png") right center / min(48rem, 65vw) auto no-repeat,
        #f7f9fa;
    border-bottom: 1px solid rgba(18, 18, 18, .12);
    display: grid;
    min-height: clamp(28rem, 68vh, 42rem);
    padding: 4rem 0 5rem;
}

.shop-hero h1 {
    color: #111111;
    font-size: clamp(3rem, 8vw, 6.6rem);
    font-weight: 300;
    letter-spacing: 0;
    line-height: .95;
    margin: 0;
    max-width: 10ch;
}

.shop-hero p:not(.eyebrow) {
    color: #222222;
    font-size: clamp(1.05rem, 2vw, 1.35rem);
    line-height: 1.55;
    margin: 1.2rem 0 0;
    max-width: 42rem;
}

.artwork-hero {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .96) 0%, rgba(255, 255, 255, .84) 44%, rgba(255, 255, 255, .12) 100%),
        url("../images/use-case-keychain-letter.png") right center / min(46rem, 62vw) auto no-repeat,
        #f7f9fa;
}

.resin-shop-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 1rem;
}

.resin-shop-card {
    align-items: stretch;
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    grid-template-rows: auto 1fr auto;
    min-height: 27rem;
    padding: 1rem;
}

.resin-shop-card figure {
    align-items: center;
    aspect-ratio: 16 / 9;
    background: #ffffff;
    border-radius: 8px;
    display: flex;
    justify-content: center;
    margin: 0;
    overflow: hidden;
}

.resin-shop-card img {
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.resin-shop-card:first-child img {
    filter: none;
    opacity: 1;
}

.resin-shop-card h2,
.shop-steps-section h2,
.finished-artwork-cta h2 {
    color: #111111;
    font-size: clamp(1.7rem, 4vw, 2.8rem);
    font-weight: 300;
    line-height: 1.06;
    margin: 0;
}

.resin-shop-card p:not(.eyebrow),
.finished-artwork-cta p:not(.eyebrow) {
    color: #333333;
    line-height: 1.55;
    margin: .8rem 0 0;
}

.resin-shop-card .product-price {
    color: #7a4e0a;
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.25;
    margin: .65rem 0 0;
}

.resin-shop-card ul {
    color: #333333;
    line-height: 1.55;
    margin: 1rem 0 0;
    padding-left: 1.1rem;
}

.chip-spec-section {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    margin-top: 1rem;
    padding: 1.35rem;
}

.chip-spec-heading h2 {
    color: #111111;
    font-size: clamp(1.8rem, 5vw, 3.4rem);
    font-weight: 300;
    line-height: 1.05;
    margin: 0;
}

.chip-spec-heading p:not(.eyebrow) {
    color: #333333;
    line-height: 1.55;
    margin: .75rem 0 0;
    max-width: 48rem;
}

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

.chip-spec-card {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    padding: 1rem;
}

.chip-spec-card.is-highlighted {
    border-color: rgba(190, 128, 35, .42);
}

.chip-spec-card h3 {
    color: #111111;
    font-size: clamp(1.35rem, 3vw, 2rem);
    font-weight: 300;
    line-height: 1.12;
    margin: 0;
}

.chip-spec-card dl {
    display: grid;
    gap: .75rem;
    margin: 1rem 0 0;
}

.chip-spec-card dl div {
    border-top: 1px solid rgba(119, 149, 163, .22);
    display: grid;
    gap: .2rem;
    padding-top: .75rem;
}

.chip-spec-card dt {
    color: #111111;
    font-size: .84rem;
    font-weight: 600;
    text-transform: uppercase;
}

.chip-spec-card dd {
    color: #333333;
    line-height: 1.5;
    margin: 0;
}

.chip-trust-row {
    display: grid;
    gap: .65rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.chip-trust-row span {
    background: #222222;
    border-radius: 8px;
    color: #ffffff;
    padding: .85rem;
    text-align: center;
}

.shop-feature-band {
    background: #222222;
    border-radius: 8px;
    display: grid;
    gap: 1px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 1rem;
    overflow: hidden;
}

.shop-feature-band article {
    background: rgba(255, 255, 255, .05);
    display: grid;
    gap: .35rem;
    padding: 1.1rem;
}

.shop-feature-band strong {
    color: #ffffff;
    font-weight: 400;
}

.shop-feature-band span {
    color: #dce7eb;
    line-height: 1.45;
}

.shop-steps-section,
.shop-faq-section,
.finished-artwork-cta {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    margin-top: 1rem;
    padding: 1.35rem;
}

.shop-steps-section ol {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    list-style: none;
    margin: 0;
    padding: 0;
}

.shop-steps-section li {
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    padding: 1rem;
}

.shop-steps-section li > span {
    align-items: center;
    background: #7795a3;
    border-radius: 999px;
    color: #111111;
    display: inline-flex;
    font-weight: 600;
    height: 2.1rem;
    justify-content: center;
    margin-bottom: .75rem;
    width: 2.1rem;
}

.shop-steps-section strong {
    color: #111111;
    display: block;
    font-weight: 400;
}

.shop-steps-section p {
    color: #333333;
    line-height: 1.5;
    margin: .5rem 0 0;
}

.shop-faq-section h2 {
    color: #111111;
    font-size: clamp(1.7rem, 4vw, 2.8rem);
    font-weight: 300;
    line-height: 1.06;
    margin: 0;
}

.shop-faq-list {
    display: grid;
    gap: .7rem;
}

.shop-faq-list details {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    overflow: hidden;
}

.shop-faq-list summary {
    color: #111111;
    cursor: pointer;
    font-weight: 400;
    line-height: 1.35;
    list-style: none;
    padding: 1rem 3rem 1rem 1rem;
    position: relative;
}

.shop-faq-list summary::-webkit-details-marker {
    display: none;
}

.shop-faq-list summary::after {
    align-items: center;
    border: 1px solid rgba(119, 149, 163, .45);
    border-radius: 999px;
    color: #7795a3;
    content: "+";
    display: inline-flex;
    font-size: 1.1rem;
    height: 1.5rem;
    justify-content: center;
    position: absolute;
    right: .9rem;
    top: .85rem;
    width: 1.5rem;
}

.shop-faq-list details[open] {
    background: #ffffff;
    border-color: rgba(119, 149, 163, .5);
}

.shop-faq-list details[open] summary::after {
    content: "-";
}

.shop-faq-list p {
    border-top: 1px solid rgba(119, 149, 163, .18);
    color: #333333;
    line-height: 1.55;
    margin: 0;
    padding: 0 1rem 1rem;
}

.finished-artwork-cta {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .78)),
        url("../images/use-case-keychain-letter.png") right center / min(22rem, 42vw) auto no-repeat,
        #f7f9fa;
    min-height: 17rem;
}

.finished-artwork-cta .link-action {
    justify-self: start;
}

.art-store-section,
.art-checkout-section {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    margin-top: 1rem;
    padding: 1.35rem;
}

.art-store-heading h2,
.art-checkout-section h2 {
    color: #111111;
    font-size: clamp(1.8rem, 5vw, 3.4rem);
    font-weight: 300;
    line-height: 1.05;
    margin: 0;
}

.art-store-heading p:not(.eyebrow),
.art-checkout-section p:not(.eyebrow) {
    color: #333333;
    line-height: 1.55;
    margin: .75rem 0 0;
    max-width: 48rem;
}

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

.art-product-grid.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.art-detail-page {
    display: grid;
    gap: 1rem;
}

.text-link {
    color: #56717d;
    text-decoration: underline;
    text-underline-offset: .18em;
}

.art-detail-layout {
    align-items: start;
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: 1.5rem;
    grid-template-columns: minmax(0, 1.15fr) minmax(20rem, .85fr);
    padding: 1rem;
}

.art-detail-layout figure {
    background: #f7f9fa;
    border-radius: 8px;
    display: grid;
    gap: .75rem;
    margin: 0;
    overflow: hidden;
    padding: .75rem;
}

.art-detail-layout figure > img,
.art-detail-layout figure > video {
    aspect-ratio: 1 / 1;
    border-radius: 8px;
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.art-media-strip {
    display: grid;
    gap: .5rem;
    grid-template-columns: repeat(auto-fit, minmax(4.5rem, 1fr));
}

.art-media-strip button {
    aspect-ratio: 1 / 1;
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .32);
    border-radius: 8px;
    cursor: pointer;
    display: grid;
    overflow: hidden;
    padding: 0;
    place-items: center;
}

.art-media-strip button.is-active {
    border-color: #56717d;
    box-shadow: 0 0 0 2px rgba(119, 149, 163, .2);
}

.art-media-strip img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.art-media-strip span {
    color: #56717d;
    font-size: .85rem;
    font-weight: 600;
}

.art-detail-layout h2 {
    color: #111111;
    font-size: clamp(2rem, 5vw, 4.2rem);
    font-weight: 300;
    line-height: 1;
    margin: 0;
}

.art-detail-copy {
    display: grid;
    gap: 1rem;
}

.art-detail-copy > p:not(.eyebrow) {
    color: #333333;
    line-height: 1.6;
    margin: 0;
}

.art-buy-box {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .22);
    border-radius: 8px;
    display: grid;
    gap: .85rem;
    padding: 1rem;
}

.art-price-line {
    display: grid;
    gap: .25rem;
}

.art-price-line span {
    color: #111111;
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 1;
}

.art-price-line small {
    color: #56717d;
    font-size: .95rem;
}

.art-product-options {
    display: grid;
    gap: .75rem;
}

.art-product-options label {
    display: grid;
    gap: .35rem;
}

.art-product-options span {
    color: #56717d;
    font-size: .9rem;
}

.art-product-options select {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .55);
    border-radius: 8px;
    color: #111111;
    padding: .75rem .85rem;
    width: 100%;
}

.art-detail-notes {
    display: grid;
    gap: .75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.art-detail-notes div {
    border: 1px solid rgba(119, 149, 163, .22);
    border-radius: 8px;
    display: grid;
    gap: .35rem;
    padding: .9rem;
}

.art-detail-notes strong {
    color: #111111;
    font-weight: 600;
}

.art-detail-notes span {
    color: #333333;
    line-height: 1.45;
}

.art-detail-layout .primary-action {
    margin-top: 1rem;
}

.art-detail-longtext {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: .75rem;
    padding: 1.35rem;
}

.art-detail-longtext h2 {
    color: #111111;
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 300;
    line-height: 1.08;
    margin: 0;
}

.art-detail-longtext p:not(.eyebrow) {
    color: #333333;
    line-height: 1.65;
    margin: 0;
    max-width: 58rem;
    white-space: pre-line;
}

.art-recommendations {
    border-top: 1px solid rgba(119, 149, 163, .24);
    display: grid;
    gap: 1rem;
    margin-top: 1.25rem;
    padding-top: 1.25rem;
}

.art-store-heading.compact h2 {
    font-size: clamp(1.7rem, 4vw, 2.8rem);
}

.art-product-card {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    grid-template-rows: auto 1fr auto;
    padding: 1rem;
}

.art-product-card figure {
    aspect-ratio: 4 / 3;
    background: #ffffff;
    border-radius: 8px;
    margin: 0;
    overflow: hidden;
}

.art-product-card img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.art-product-card h3 {
    color: #111111;
    font-size: clamp(1.35rem, 3vw, 2rem);
    font-weight: 300;
    line-height: 1.12;
    margin: 0;
}

.art-product-card p:not(.eyebrow),
.art-product-meta {
    color: #333333;
    line-height: 1.5;
}

.art-product-meta {
    display: grid;
    gap: .25rem;
    margin-top: .75rem;
}

.art-product-meta span:first-child {
    color: #111111;
    font-weight: 600;
}

.art-product-meta small {
    color: #56717d;
    font-size: .88rem;
    line-height: 1.35;
}

.art-checkout-grid {
    display: grid;
    gap: .9rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.art-checkout-grid label,
.art-checkout-terms label {
    display: grid;
    gap: .35rem;
}

.art-checkout-grid .wide {
    grid-column: 1 / -1;
}

.art-checkout-grid input,
.art-checkout-grid select,
.art-checkout-grid textarea,
.admin-art-editor input,
.admin-art-editor select,
.admin-art-editor textarea {
    border: 1px solid rgba(119, 149, 163, .55);
    border-radius: 8px;
    color: #111111;
    padding: .75rem .85rem;
    width: 100%;
}

.art-checkout-terms {
    background: #f7f9fa;
    border-radius: 8px;
    display: grid;
    gap: .8rem;
    padding: 1rem;
}

.art-checkout-terms label {
    align-items: start;
    grid-template-columns: auto 1fr;
}

.admin-art-editor {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.admin-art-editor .wide {
    grid-column: 1 / -1;
}

.admin-art-preview-panel {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .24);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.admin-art-preview-panel h3 {
    color: #111111;
    font-size: 1.35rem;
    font-weight: 500;
    margin: 0;
}

.admin-art-preview-panel p {
    color: #56717d;
    line-height: 1.45;
    margin: .25rem 0 0;
}

.admin-art-preview-grid,
.admin-art-variant-preview-grid {
    display: grid;
    gap: .85rem;
    grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
}

.admin-art-image-preview,
.admin-art-variant-preview-grid article {
    background: #f7f9fa;
    border: 1px solid rgba(119, 149, 163, .22);
    border-radius: 8px;
    display: grid;
    gap: .5rem;
    margin: 0;
    min-width: 0;
    overflow: hidden;
    padding: .6rem;
}

.admin-art-image-preview img,
.admin-art-variant-preview-grid img {
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.admin-art-image-preview strong,
.admin-art-variant-preview-grid span {
    color: #111111;
    font-weight: 600;
}

.admin-art-image-preview code {
    background: #ffffff;
    border-radius: 6px;
    color: #56717d;
    display: block;
    font-size: .75rem;
    max-height: 4.5rem;
    overflow: auto;
    padding: .45rem;
    word-break: break-all;
}

.admin-art-image-preview small {
    color: #56717d;
    font-size: .78rem;
    line-height: 1.35;
    word-break: break-all;
}

.admin-art-video-preview {
    aspect-ratio: 4 / 3;
    background: #1d1d1d;
    border-radius: 6px;
    color: #ffffff;
    display: grid;
    font-weight: 600;
    place-items: center;
}

.site-footer {
    background: #ffffff;
    border-top: 1px solid rgba(18, 18, 18, .12);
    margin-top: 1rem;
    padding: 1.4rem 0 2rem;
}

.footer-main {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.25rem;
    justify-content: center;
}

.footer-brand {
    align-items: center;
    display: flex;
    gap: .75rem;
    min-width: min(100%, 18rem);
}

.footer-brand img {
    background: #050505;
    border-radius: 8px;
    height: 3.1rem;
    object-fit: cover;
    width: 3.1rem;
}

.footer-brand strong,
.footer-brand span {
    display: block;
}

.footer-brand strong {
    color: #111111;
    font-weight: 300;
}

.footer-brand span,
.footer-note {
    color: #5d6f77;
    font-size: .88rem;
}

.social-links {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    justify-content: center;
}

.social-icon {
    align-items: center;
    border-radius: 6px;
    color: #ffffff;
    display: inline-flex;
    flex: 0 0 1.65rem;
    font-family: Arial, sans-serif;
    font-size: .9rem;
    font-weight: 700;
    height: 1.65rem;
    justify-content: center;
    position: relative;
    text-decoration: none;
    width: 1.65rem;
    min-width: 1.65rem;
    max-width: 1.65rem;
    overflow: hidden;
}

.social-icon img {
    display: block;
    height: 100%;
    max-height: 100%;
    max-width: 100%;
    object-fit: cover;
    width: 100%;
}

.footer-mail {
    color: #7795a3;
    overflow-wrap: anywhere;
    text-decoration: none;
}

.language-select {
    align-items: center;
    color: #111111;
    display: inline-flex;
    gap: .5rem;
}

.language-select select {
    background: #ffffff;
    border: 1px solid rgba(119, 149, 163, .55);
    border-radius: 8px;
    color: #111111;
    min-height: 2.35rem;
    padding: 0 .6rem;
}

.footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem 1.8rem;
    justify-content: center;
    margin-top: 1.35rem;
}

.footer-links a {
    color: #5d6f77;
    font-size: .9rem;
}

.footer-note {
    margin: 1.2rem auto 0;
    max-width: 42rem;
    text-align: center;
}

.primary-action {
    background: #7795a3;
    border: 0;
    border-radius: 8px;
    color: #050505;
    cursor: pointer;
    font-weight: 400;
    min-height: 2.75rem;
    padding: 0 1rem;
}

.message-box {
    background: #ffffff;
    color: #111111;
    margin-top: 1rem;
    padding: 1rem;
}

.purchase-success-message {
    background: rgba(86, 139, 100, .12);
    border-color: rgba(86, 139, 100, .42);
}

.info-row {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    margin-top: 1rem;
    padding: 1rem;
    background: #ffffff;
}

.info-row > div {
    min-width: 0;
}

.info-row strong,
.info-row span {
    display: block;
}

.info-row span {
    line-height: 1.45;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.info-row strong {
    color: #111111;
    font-weight: 300;
}

#blazor-error-ui {
    color-scheme: light only;
    background: #fff8c5;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: .7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: .75rem;
    top: .5rem;
}

.loading-progress {
    display: block;
    height: 8rem;
    inset: 20vh 0 auto 0;
    margin: 0 auto;
    position: absolute;
    width: 8rem;
}

.loading-progress circle {
    fill: none;
    stroke: rgba(119, 149, 163, .2);
    stroke-width: .6rem;
    transform: rotate(-90deg);
    transform-origin: 50% 50%;
}

.loading-progress circle:last-child {
    stroke: #7795a3;
    stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * .8), 500%;
    transition: stroke-dasharray .05s ease-in-out;
}

.loading-progress-text {
    color: #111111;
    font-weight: 300;
    inset: calc(20vh + 3.25rem) 0 auto .2rem;
    position: absolute;
    text-align: center;
}

.loading-progress-text::after {
    content: var(--blazor-load-percentage-text, "Loading");
}

code {
    color: #9fb7c2;
}

@media (max-width: 640.98px) {
    .beta-gate-form {
        grid-template-columns: 1fr;
    }

    .admin-header,
    .admin-list-header {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-grid,
    .admin-form-grid,
    .admin-chip-card,
    .admin-flow-card,
    .admin-filter-bar {
        grid-template-columns: 1fr;
    }

    .admin-login-form,
    .admin-search,
    .admin-header-actions {
        flex-direction: column;
    }

    .start-hero,
    .start-steps,
    .resin-shop-grid,
    .art-product-grid,
    .viewer-grid-pro,
    .art-checkout-grid,
    .art-detail-layout,
    .art-detail-notes,
    .chip-spec-grid,
    .chip-trust-row,
    .shop-feature-band,
    .shop-steps-section ol,
    .access-panel,
    .access-methods,
    .memory-explainer,
    .flow-panel,
    .use-case-grid {
        grid-template-columns: 1fr;
    }

    .viewer-grid-pro {
        grid-auto-rows: auto;
    }

    .viewer-grid-pro .viewer-card,
    .viewer-grid-pro .viewer-card.is-wide-media,
    .viewer-grid-pro .viewer-card.is-tall-media,
    .viewer-grid-pro .viewer-card.is-feature-text,
    .viewer-grid-pro .viewer-card.is-note-text,
    .viewer-grid-pro .viewer-card.is-audio-media {
        grid-column: auto;
        grid-row: auto;
    }

    .viewer-grid-pro .viewer-preview {
        min-height: 16rem;
    }

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

    .shop-hero,
    .artwork-hero {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, .98) 0%, rgba(255, 255, 255, .9) 58%, rgba(255, 255, 255, .7) 100%),
            url("../images/resin-memory-pendant.png") center bottom / 100% auto no-repeat,
            #f7f9fa;
        min-height: 34rem;
        padding-bottom: 12rem;
    }

    .hero-media {
        justify-content: stretch;
    }

    .hero-video-frame {
        width: 100%;
    }

    .desktop-copy {
        display: none;
    }

    .mobile-copy {
        display: block;
    }

    .access-panel {
        margin-top: 1rem;
    }
    .hero-actions a {
        justify-content: center;
        width: 100%;
    }

    .info-tab-buttons {
        display: grid;
        grid-template-columns: 1fr;
    }

    .info-tab-button {
        border: 1px solid rgba(119, 149, 163, .32);
        border-radius: 8px;
        text-align: left;
    }

    .info-tab-button.active {
        background: rgba(119, 149, 163, .14);
        border-color: rgba(119, 149, 163, .7);
    }

    .flow-panel img {
        max-width: 12rem;
    }

    .memory-header,
    .action-band,
    .shop-band,
    .editor-heading {
        flex-direction: column;
    }

    .upgrade-band {
        grid-template-columns: 1fr;
    }

    .header-actions {
        align-items: stretch;
        justify-content: flex-start;
        width: 100%;
    }

    .header-actions .secondary-button,
    .header-actions .status-pill {
        text-align: center;
        width: 100%;
    }

    .memory-showcase {
        grid-template-columns: 1fr;
        padding-top: 1rem;
    }

    .plan-grid,
    .plan-compare-grid,
    .rich-text-toolbar {
        grid-template-columns: 1fr 1fr;
    }

    .manage-item {
        align-items: start;
        grid-template-columns: auto 4.5rem;
    }

    .manage-preview {
        grid-column: 2;
        width: 4.5rem;
    }

    .manage-copy {
        grid-column: 1 / -1;
    }

    .text-edit-shell {
        grid-template-columns: 1fr;
    }

    .title-editor-form,
    .media-title-form {
        grid-template-columns: 1fr;
    }

    .order-controls {
        grid-column: 1;
        grid-row: 1;
    }

    .manage-item .danger-button {
        grid-column: 1 / -1;
        width: 100%;
    }

    .claim-form {
        grid-template-columns: 1fr;
    }

    .contact-form-grid {
        grid-template-columns: 1fr;
    }

    .plan-grid,
    .plan-compare-grid,
    .rich-text-toolbar {
        grid-template-columns: 1fr;
    }

    .status-pill,
    .primary-action {
        text-align: center;
        width: 100%;
    }

    .file-picker {
        align-items: stretch;
    }

    .file-picker-button,
    .file-picker span {
        text-align: center;
        width: 100%;
    }

    .lightbox-shell {
        gap: .65rem;
        grid-template-columns: 1fr 1fr;
    }

    .lightbox-stage {
        grid-column: 1 / -1;
        order: 2;
    }

    .lightbox-nav-prev,
    .lightbox-nav-next {
        order: 3;
    }

    .lightbox-nav-next {
        justify-self: end;
    }

    .lightbox-caption {
        align-items: flex-start;
        flex-direction: column;
        order: 4;
    }

    .footer-main,
    .footer-brand,
    .language-select {
        align-items: stretch;
        flex-direction: column;
        text-align: center;
    }

    .footer-brand img {
        margin: 0 auto;
    }

    .language-select select {
        width: 100%;
    }
}


