/* TarotAstrolabe UI refresh layer */
:root {
    --ui-bg: #070813;
    --ui-bg-2: #101426;
    --ui-panel: rgba(13, 17, 31, 0.72);
    --ui-panel-strong: rgba(18, 23, 41, 0.88);
    --ui-line: rgba(255, 255, 255, 0.1);
    --ui-line-gold: rgba(217, 184, 107, 0.32);
    --ui-text: #f7f3ea;
    --ui-muted: #a9b0c3;
    --ui-dim: #747d96;
    --ui-gold: #d9b86b;
    --ui-gold-soft: #f4d58b;
    --ui-blue: #92a8ff;
    --ui-green: #8bd6c7;
    --ui-radius: 8px;
    --ui-radius-lg: 12px;
    --ui-shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
}

/* 25. Drawing Flow Reference Redesign v1 */
#app-main:has(#scene-meditation.active) #main-nav {
    display: none !important;
}

#scene-meditation.ta-drawing-flow {
    padding: clamp(0.9rem, 2vw, 1.35rem) !important;
    justify-content: center !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 64% 64%, rgba(217, 184, 107, 0.1), transparent 28%),
        linear-gradient(180deg, rgba(1, 2, 8, 0.35), rgba(1, 2, 8, 0.78)),
        #03050c !important;
}

.ta-flow-frame {
    position: relative;
    width: min(1360px, 100%);
    height: min(820px, calc(100dvh - clamp(1.8rem, 4vw, 2.7rem)));
    min-height: 620px;
    display: grid;
    grid-template-rows: 66px 1fr 78px;
    overflow: hidden;
    border: 1px solid rgba(218, 191, 138, 0.18);
    border-radius: 16px;
    background:
        linear-gradient(90deg, rgba(5, 7, 17, 0.92) 0 32%, rgba(5, 7, 17, 0.66) 54%, rgba(5, 7, 17, 0.25) 100%),
        linear-gradient(180deg, rgba(5, 7, 17, 0.12), rgba(5, 7, 17, 0.74)),
        url("images/ui/draw-flow-fan-v1.webp") center / cover no-repeat;
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255,255,255,0.045);
}

.ta-flow-frame::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 67% 62%, transparent 0 20%, rgba(4, 7, 16, 0.1) 36%, rgba(4, 7, 16, 0.68) 76%),
        linear-gradient(180deg, transparent 0 70%, rgba(3,5,12,0.76) 100%);
}

.ta-flow-header,
.ta-flow-body,
.ta-flow-footer,
.ta-flow-mobile-progress {
    position: relative;
    z-index: 1;
}

.ta-flow-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 clamp(1.25rem, 2.8vw, 2rem);
    border-bottom: 1px solid rgba(218, 191, 138, 0.13);
    background: rgba(4, 7, 16, 0.55);
}

.ta-flow-brand {
    color: rgba(247, 232, 202, 0.92);
    font-family: var(--font-heading);
    font-size: clamp(1rem, 1.4vw, 1.28rem);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
}

.ta-flow-exit,
.ta-flow-save,
.ta-flow-next {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    border-radius: 8px;
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.ta-flow-exit {
    padding: 0 1.15rem;
    border: 1px solid rgba(218, 191, 138, 0.2);
    background: rgba(255,255,255,0.035);
    color: rgba(244, 213, 139, 0.9);
    font-size: 0.95rem;
}

.ta-flow-body {
    min-height: 0;
    display: grid;
    grid-template-columns: 232px minmax(0, 1fr);
}

.ta-flow-rail {
    display: grid;
    align-content: start;
    gap: 2.45rem;
    padding: clamp(2rem, 4vw, 3.2rem) 1.45rem 1rem 1.8rem;
    border-right: 1px solid rgba(218, 191, 138, 0.13);
    background: linear-gradient(180deg, rgba(5, 7, 17, 0.72), rgba(5, 7, 17, 0.36));
}

.ta-flow-rail-item {
    position: relative;
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 0.85rem;
    color: rgba(217, 219, 227, 0.7);
}

.ta-flow-rail-item:not(:last-child)::after {
    content: "";
    position: absolute;
    left: 20px;
    top: 48px;
    width: 1px;
    height: 2rem;
    background: linear-gradient(180deg, rgba(218, 191, 138, 0.38), rgba(218, 191, 138, 0.08));
}

.ta-flow-rail-item > span,
.ta-flow-mobile-progress > span {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(218, 191, 138, 0.25);
    border-radius: 50%;
    background: rgba(4, 7, 16, 0.64);
    color: rgba(217, 219, 227, 0.74);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-weight: 700;
}

.ta-flow-rail-item.active > span,
.ta-flow-mobile-progress > span.active {
    background: linear-gradient(180deg, #ffe29b, #d6a84b);
    color: #110d08;
    box-shadow: 0 0 0 4px rgba(217, 184, 107, 0.12);
}

.ta-flow-rail-item strong {
    display: block;
    margin-top: 0.28rem;
    color: rgba(247, 232, 202, 0.92);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: 1rem;
    letter-spacing: 0.04em;
}

.ta-flow-rail-item small {
    display: block;
    max-width: 8.4rem;
    margin-top: 0.35rem;
    color: rgba(217, 219, 227, 0.62);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: 0.88rem;
    line-height: 1.35;
}

.ta-flow-mobile-progress {
    display: none;
}

#scene-meditation.ta-drawing-flow .ta-flow-content {
    width: min(100%, 980px) !important;
    max-width: none !important;
    height: 100%;
    margin: 0 !important;
    padding: clamp(1.35rem, 3vw, 2rem) clamp(1.35rem, 3vw, 2.4rem) 1.15rem !important;
    display: grid !important;
    grid-template-columns: minmax(340px, 0.72fr) minmax(300px, 0.9fr);
    grid-template-rows: auto auto 1fr;
    grid-template-areas:
        "question deck"
        "spread deck"
        "persona ready";
    gap: clamp(1rem, 2vw, 1.35rem);
    overflow: auto;
}

#scene-meditation.ta-drawing-flow .ta-flow-content::after {
    content: "Your cards are waiting.\\A Complete the steps on the left to begin your draw.";
    white-space: pre-line;
    grid-area: deck;
    align-self: center;
    justify-self: end;
    width: min(33vw, 390px);
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    padding-top: 8rem;
    color: rgba(247, 232, 202, 0.9);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1.05rem, 1.3vw, 1.25rem);
    line-height: 1.45;
    text-align: center;
    text-shadow: 0 12px 34px rgba(0,0,0,0.72);
    pointer-events: none;
}

#scene-meditation.ta-drawing-flow .ritual-step,
#scene-meditation.ta-drawing-flow .draw-ready-panel {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

#scene-meditation.ta-drawing-flow .ritual-step:nth-of-type(1) { grid-area: question; }
#scene-meditation.ta-drawing-flow .ritual-step:nth-of-type(2) { grid-area: spread; }
#scene-meditation.ta-drawing-flow .ritual-step:nth-of-type(3) { grid-area: persona; }
#scene-meditation.ta-drawing-flow .draw-ready-panel { grid-area: ready; align-self: end; }

#scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child {
    margin-bottom: 0.95rem !important;
}

#scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child span {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(218, 191, 138, 0.34);
    border-radius: 50%;
    background: rgba(4, 7, 16, 0.58);
    color: rgba(244, 213, 139, 0.92) !important;
    font-family: Cormorant Garamond, Noto Serif TC, serif;
}

#scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child label,
#scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child h2 {
    color: rgba(247, 232, 202, 0.92) !important;
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1.05rem, 1.6vw, 1.32rem) !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

#scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child .h-px {
    display: none;
}

#scene-meditation.ta-drawing-flow #user-query {
    min-height: 164px !important;
    padding: 1.05rem !important;
    border: 1px solid rgba(218, 191, 138, 0.16) !important;
    border-radius: 10px !important;
    background: rgba(4, 7, 16, 0.66) !important;
    color: rgba(247, 243, 234, 0.92) !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    text-align: left !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

#scene-meditation.ta-drawing-flow .spread-panel {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.85rem !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
}

#scene-meditation.ta-drawing-flow #spread-select {
    min-height: 52px;
    border-color: rgba(218, 191, 138, 0.18) !important;
    border-radius: 10px !important;
    background: rgba(4, 7, 16, 0.72) !important;
    color: rgba(247, 232, 202, 0.9) !important;
}

#scene-meditation.ta-drawing-flow .spread-question-chips {
    display: flex;
    gap: 0.45rem;
    overflow-x: auto;
    padding-bottom: 0.1rem;
}

#scene-meditation.ta-drawing-flow .spread-chip {
    white-space: nowrap;
    border-radius: 999px;
    border: 1px solid rgba(218, 191, 138, 0.16);
    background: rgba(255,255,255,0.035);
    color: rgba(217, 219, 227, 0.72);
    padding: 0.5rem 0.75rem;
    font-size: 0.78rem;
}

#scene-meditation.ta-drawing-flow .spread-chip.active {
    background: rgba(217, 184, 107, 0.16);
    color: rgba(244, 213, 139, 0.96);
}

#scene-meditation.ta-drawing-flow .spread-card-grid {
    display: flex;
    gap: 0.7rem;
    overflow-x: auto;
    padding: 0.15rem 0 0.35rem;
    scroll-snap-type: x proximity;
}

#scene-meditation.ta-drawing-flow .spread-choice-card {
    flex: 0 0 178px;
    min-height: 122px;
    scroll-snap-align: start;
    border-radius: 10px;
    border: 1px solid rgba(218, 191, 138, 0.14);
    background: rgba(4, 7, 16, 0.66);
}

#scene-meditation.ta-drawing-flow .spread-choice-card.active {
    border-color: rgba(244, 213, 139, 0.76);
    box-shadow: 0 0 0 1px rgba(244, 213, 139, 0.16), 0 16px 36px rgba(0,0,0,0.26);
}

#scene-meditation.ta-drawing-flow .spread-current {
    padding: 0.95rem !important;
    border: 1px solid rgba(218, 191, 138, 0.12) !important;
    border-radius: 10px;
    background: rgba(4, 7, 16, 0.5);
}

#scene-meditation.ta-drawing-flow #persona-selection {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 0.7rem !important;
}

#scene-meditation.ta-drawing-flow .persona-card {
    min-height: auto;
    padding: 0.95rem !important;
    border-color: rgba(218, 191, 138, 0.14) !important;
    border-radius: 10px !important;
    background: rgba(4, 7, 16, 0.56) !important;
}

#scene-meditation.ta-drawing-flow .persona-card p {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

#scene-meditation.ta-drawing-flow .draw-ready-panel {
    display: grid;
    justify-items: center;
    gap: 0.8rem;
    padding: 1rem !important;
    border: 1px solid rgba(218, 191, 138, 0.12) !important;
    border-radius: 12px;
    background: rgba(4, 7, 16, 0.5) !important;
    text-align: center;
}

#scene-meditation.ta-drawing-flow .draw-ready-panel .flex {
    margin: 0 !important;
}

#scene-meditation.ta-drawing-flow .draw-ready-copy {
    margin: 0 !important;
    max-width: 22rem;
}

#scene-meditation.ta-drawing-flow .draw-ready-deck {
    display: none;
}

#scene-meditation.ta-drawing-flow #btn_confirm_meditation {
    display: none;
}

.ta-flow-footer {
    display: grid;
    grid-template-columns: 170px 1fr 260px;
    align-items: center;
    gap: 1rem;
    padding: 0 clamp(1.25rem, 2.8vw, 2rem);
    border-top: 1px solid rgba(218, 191, 138, 0.13);
    background: rgba(4, 7, 16, 0.78);
}

.ta-flow-save {
    border: 1px solid rgba(218, 191, 138, 0.16);
    background: rgba(255,255,255,0.035);
    color: rgba(217, 219, 227, 0.74);
}

.ta-flow-footer p {
    margin: 0;
    color: rgba(217, 219, 227, 0.72);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: 0.95rem;
    text-align: center;
}

.ta-flow-footer p span {
    color: rgba(244, 213, 139, 0.86);
    margin-right: 0.55rem;
}

.ta-flow-next {
    min-height: 52px;
    border: 1px solid rgba(255, 236, 184, 0.42);
    background: linear-gradient(180deg, #ffe29b 0%, #d6a84b 54%, #b87f2f 100%);
    color: #120f0a;
    font-size: 1.05rem;
    font-weight: 700;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.36), 0 14px 34px rgba(0,0,0,0.3);
}

@media (max-width: 980px) {
    #scene-meditation.ta-drawing-flow {
        padding: 0 !important;
    }

    .ta-flow-frame {
        width: 100%;
        height: 100dvh;
        min-height: 0;
        grid-template-rows: 58px 46px 1fr 72px;
        border: 0;
        border-radius: 0;
        background:
            linear-gradient(180deg, rgba(5, 7, 17, 0.88) 0 48%, rgba(5, 7, 17, 0.3) 72%, rgba(5, 7, 17, 0.88) 100%),
            url("images/ui/draw-flow-fan-v1.webp") center bottom / auto 58% no-repeat,
            #03050c;
    }

    .ta-flow-header {
        padding: 0 1rem;
    }

    .ta-flow-brand {
        font-size: 0.82rem;
    }

    .ta-flow-exit {
        width: 42px;
        min-width: 42px;
        padding: 0;
        font-size: 0;
    }

    .ta-flow-exit span {
        font-size: 1.2rem;
    }

    .ta-flow-mobile-progress {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.42rem;
        padding-inline: 1rem;
        border-bottom: 1px solid rgba(218, 191, 138, 0.1);
        background: rgba(4, 7, 16, 0.56);
    }

    .ta-flow-mobile-progress > span {
        width: 28px;
        height: 28px;
        font-size: 0.86rem;
    }

    .ta-flow-mobile-progress i {
        width: clamp(22px, 10vw, 42px);
        height: 1px;
        background: rgba(218, 191, 138, 0.22);
    }

    .ta-flow-body {
        display: block;
        overflow: hidden;
    }

    .ta-flow-rail {
        display: none;
    }

    #scene-meditation.ta-drawing-flow .ta-flow-content {
        width: 100% !important;
        height: 100%;
        padding: 1.15rem 1rem 2rem !important;
        display: block !important;
        overflow-y: auto;
    }

    #scene-meditation.ta-drawing-flow .ta-flow-content::after {
        display: block;
        width: min(76vw, 300px);
        aspect-ratio: 1.25;
        margin: 1.1rem auto 0;
        padding-top: 4.8rem;
        font-size: 1.08rem;
    }

    #scene-meditation.ta-drawing-flow .ritual-step,
    #scene-meditation.ta-drawing-flow .draw-ready-panel {
        margin-bottom: 1rem !important;
    }

    #scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child {
        align-items: flex-start;
        gap: 0.75rem !important;
    }

    #scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child label,
    #scene-meditation.ta-drawing-flow .ritual-step > .flex:first-child h2 {
        font-size: clamp(1.12rem, 6vw, 1.42rem) !important;
        line-height: 1.12;
    }

    #scene-meditation.ta-drawing-flow #user-query {
        min-height: 132px !important;
    }

    #scene-meditation.ta-drawing-flow .spread-panel {
        max-width: none !important;
    }

    #scene-meditation.ta-drawing-flow .spread-choice-card {
        flex-basis: min(68vw, 210px);
    }

    #scene-meditation.ta-drawing-flow .spread-current {
        font-size: 0.9rem;
    }

    .ta-flow-footer {
        grid-template-columns: 1fr;
        padding: 0.6rem 1rem max(0.6rem, env(safe-area-inset-bottom));
    }

    .ta-flow-save,
    .ta-flow-footer p {
        display: none;
    }

    .ta-flow-next {
        width: 100%;
        min-height: 50px;
        border-radius: 8px;
    }
}

html {
    background: var(--ui-bg);
}

body {
    color: var(--ui-text);
    background:
        radial-gradient(circle at 24% 8%, rgba(146, 168, 255, 0.15), transparent 30rem),
        radial-gradient(circle at 80% 20%, rgba(217, 184, 107, 0.11), transparent 28rem),
        linear-gradient(180deg, #070813 0%, #0b0d18 52%, #070813 100%);
}

body:not(.theme-mode-dark) {
    overflow-x: hidden;
    overflow-y: auto;
    min-height: 100vh;
    height: auto;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,0.7), transparent 72%);
}

body > * {
    position: relative;
}

.ta-entry-gate {
    isolation: isolate;
    min-height: 100dvh;
    display: grid;
    grid-template-columns: minmax(1.25rem, 1fr) minmax(0, 1180px) minmax(1.25rem, 1fr);
    align-items: center;
    overflow: hidden;
    color: var(--ui-text);
    background:
        linear-gradient(90deg, rgba(5,5,16,0.96) 0%, rgba(5,5,16,0.78) 42%, rgba(5,5,16,0.3) 72%, rgba(5,5,16,0.62) 100%),
        linear-gradient(180deg, rgba(5,5,16,0.22), rgba(5,5,16,0.82)),
        url("images/ui/hero-astrolabe-v1.webp") center right / cover no-repeat;
}

.ta-entry-gate::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(5,5,16,0.58), transparent 38%, rgba(5,5,16,0.78)),
        linear-gradient(90deg, rgba(5,5,16,0.34), transparent 48%, rgba(5,5,16,0.18));
}

.ta-entry-brand {
    position: absolute;
    top: max(1.4rem, env(safe-area-inset-top));
    left: clamp(1rem, 4vw, 3rem);
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 0.72rem;
    color: rgba(247, 243, 234, 0.9);
    font-family: var(--font-heading);
    font-size: clamp(0.9rem, 1.3vw, 1.1rem);
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.ta-entry-mark {
    width: 1.6rem;
    height: 1.6rem;
    border: 1px solid rgba(217, 184, 107, 0.58);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(244,213,139,0.8) 0 2px, transparent 3px),
        conic-gradient(from 0deg, transparent, rgba(217,184,107,0.42), transparent 34%);
    box-shadow: 0 0 24px rgba(217,184,107,0.12);
}

.ta-entry-copy {
    grid-column: 2;
    width: min(100%, 620px);
    padding-top: clamp(3rem, 6vh, 5rem);
    text-align: left;
}

.ta-entry-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    margin: 0 0 1rem;
    color: rgba(244, 213, 139, 0.88);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.ta-entry-kicker::before {
    content: "";
    width: 2.2rem;
    height: 1px;
    background: linear-gradient(90deg, rgba(244,213,139,0.9), transparent);
}

.ta-entry-copy h1 {
    max-width: 11.5em;
    margin: 0;
    color: rgba(247, 243, 234, 0.98);
    font-family: var(--font-heading);
    font-size: clamp(2.65rem, 6vw, 5.7rem);
    line-height: 1.04;
    letter-spacing: 0;
    text-wrap: balance;
    text-shadow: 0 22px 60px rgba(0,0,0,0.58);
}

.ta-entry-lede {
    max-width: 39rem;
    margin: 1.25rem 0 0;
    color: rgba(210, 217, 232, 0.82);
    font-family: Noto Serif TC, Cormorant Garamond, serif;
    font-size: clamp(1rem, 1.45vw, 1.18rem);
    line-height: 1.9;
}

.ta-entry-actions {
    display: flex;
    align-items: stretch;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 2rem;
}

.ta-entry-actions.gate-buttons {
    animation-delay: 0.24s;
}

.ta-entry-actions button {
    min-width: min(100%, 13.5rem);
    min-height: 4rem;
    display: grid;
    gap: 0.22rem;
    align-content: center;
    text-align: left;
    border-radius: 8px;
    padding: 0.72rem 1rem;
    font-family: Lato, system-ui, sans-serif;
}

.ta-entry-actions button span {
    display: block;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    opacity: 0.78;
}

.ta-entry-actions button strong {
    display: block;
    font-family: var(--font-heading);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.ta-entry-actions .gate-btn-primary {
    border: 1px solid rgba(244, 213, 139, 0.48);
    background: linear-gradient(135deg, #f6df9d, #c69b45 54%, #f4d58b);
    color: #10131d;
    box-shadow: 0 18px 42px rgba(217, 184, 107, 0.16);
}

.ta-entry-actions .gate-btn-secondary {
    border: 1px solid rgba(255,255,255,0.16);
    background: rgba(255,255,255,0.045);
    color: rgba(247, 243, 234, 0.88);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.ta-entry-actions .gate-btn-primary:hover,
.ta-entry-actions .gate-btn-secondary:hover {
    transform: translateY(-2px);
}

.ta-entry-note {
    max-width: 36rem;
    margin: 1rem 0 0;
    color: rgba(169, 176, 195, 0.72);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.82rem;
    line-height: 1.75;
}

.ta-entry-status {
    position: absolute;
    left: clamp(1rem, 4vw, 3rem);
    bottom: max(1.15rem, env(safe-area-inset-bottom));
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 0.72rem;
    color: rgba(169,176,195,0.7);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ta-entry-status span {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: rgba(139, 214, 199, 0.9);
    box-shadow: 0 0 18px rgba(139,214,199,0.48);
}

#main-nav {
    position: fixed;
    top: max(16px, env(safe-area-inset-top));
    left: 50%;
    transform: translateX(-50%);
    z-index: 70;
    width: min(1120px, calc(100vw - 32px));
    min-height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 10px 14px 10px 20px;
    background: linear-gradient(135deg, rgba(15, 18, 31, 0.84), rgba(16, 21, 38, 0.7));
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--ui-radius);
    box-shadow: 0 18px 60px rgba(0, 0, 0, 0.34);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

#main-nav a:first-child,
#main-nav > a {
    font-family: var(--font-heading);
    color: var(--ui-text);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    text-decoration: none;
}

#main-nav a,
#main-nav button {
    transition: color 180ms ease, background 180ms ease, border-color 180ms ease, transform 180ms ease;
}

#main-nav a:hover,
#main-nav button:hover {
    color: var(--ui-gold-soft);
}

.lang-switch,
#main-nav .lang-switch {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 3px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 7px;
    background: rgba(255,255,255,0.045);
}

.lang-switch button,
#main-nav button[data-lang-btn] {
    min-width: 38px;
    min-height: 34px;
    padding: 0 10px;
    border-radius: 5px;
    color: var(--ui-muted);
    font-family: Lato, system-ui, sans-serif;
    font-size: 12px;
    letter-spacing: 0.08em;
}

#main-nav button.text-amber-400,
#main-nav button[data-lang-btn].text-amber-400 {
    background: rgba(217, 184, 107, 0.16);
    color: var(--ui-gold-soft);
}

#mobile-menu-btn,
#menu_btn {
    width: 44px;
    height: 44px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    border: 1px solid rgba(217, 184, 107, 0.2);
    border-radius: 999px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02)),
        rgba(7, 10, 24, 0.72);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 10px 26px rgba(0,0,0,0.24);
    color: rgba(244, 213, 139, 0.9);
}

#mobile-menu-btn svg,
#menu_btn svg {
    width: 22px;
    height: 22px;
}

#mobile-menu-btn span,
#menu_btn span {
    width: 18px !important;
    height: 1px !important;
    margin: 0 !important;
    border-radius: 999px;
}

#mobile-menu,
#mobile_menu {
    position: fixed;
    inset: 0;
    z-index: 90;
    padding: max(4.35rem, calc(env(safe-area-inset-top) + 3.85rem)) 1.25rem max(1.2rem, calc(env(safe-area-inset-bottom) + 0.9rem));
    background:
        radial-gradient(circle at 18% 16%, rgba(217, 184, 107, 0.14), transparent 34%),
        radial-gradient(circle at 82% 88%, rgba(87, 120, 180, 0.16), transparent 38%),
        rgba(5, 7, 18, 0.97);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

#mobile-menu::before,
#mobile_menu::before {
    content: "TarotAstrolabe";
    position: absolute;
    top: max(1.6rem, calc(env(safe-area-inset-top) + 1.1rem));
    left: 1.35rem;
    color: rgba(255, 247, 224, 0.84);
    font-family: var(--font-heading);
    font-size: 0.82rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

#mobile-menu::after,
#mobile_menu::after {
    content: "";
    position: absolute;
    inset: auto 1.25rem 1.25rem;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(217, 184, 107, 0.36), transparent);
}

#close_menu_btn {
    top: max(1rem, calc(env(safe-area-inset-top) + 0.75rem)) !important;
    right: 1rem !important;
    width: 44px;
    height: 44px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(217, 184, 107, 0.24);
    border-radius: 999px;
    background: rgba(255,255,255,0.045);
    color: rgba(244, 213, 139, 0.9) !important;
    font-size: 1.85rem !important;
    line-height: 1;
}

:where(a, button, textarea, select):focus-visible {
    outline: 2px solid rgba(244, 213, 139, 0.85);
    outline-offset: 3px;
}

body.menu-open {
    overflow: hidden;
}

#mobile-menu nav,
#mobile_menu nav {
    width: min(21rem, 100%);
    padding-top: 0;
    display: grid !important;
    gap: 0.45rem !important;
    margin: 0;
}

#mobile_menu > a,
#mobile-menu > a,
#mobile_menu nav > a,
#mobile-menu nav > a {
    width: min(21rem, 100%);
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.58rem 0.9rem;
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: 12px;
    background: rgba(255,255,255,0.04);
    color: rgba(226, 232, 240, 0.86);
    font-family: var(--font-serif);
    font-size: 0.98rem !important;
    letter-spacing: 0.06em;
    line-height: 1.2;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
}

#mobile_menu > a::after,
#mobile-menu > a::after,
#mobile_menu nav > a::after,
#mobile-menu nav > a::after {
    content: "";
    width: 6px;
    height: 6px;
    border-top: 1px solid currentColor;
    border-right: 1px solid currentColor;
    opacity: 0.5;
    transform: rotate(45deg);
}

#mobile_menu > a:hover,
#mobile-menu > a:hover,
#mobile_menu nav > a:hover,
#mobile-menu nav > a:hover,
#mobile_menu > a.active,
#mobile-menu > a.active,
#mobile_menu nav > a.active,
#mobile-menu nav > a.active {
    transform: translateY(-1px);
    border-color: rgba(217, 184, 107, 0.42);
    background: rgba(217, 184, 107, 0.1);
    color: rgba(244, 213, 139, 0.96);
}

#mobile_menu nav .w-12 {
    width: 100% !important;
    margin: 0.2rem 0 !important;
}

#mobile_menu [data-lang-btn],
#mobile-menu [data-lang-btn] {
    min-width: 0;
    min-height: 34px;
    padding: 0 0.65rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.035);
}

@media (max-height: 680px) {
    #mobile-menu,
    #mobile_menu {
        padding-top: max(4.25rem, calc(env(safe-area-inset-top) + 3.75rem));
        padding-bottom: max(1rem, calc(env(safe-area-inset-bottom) + 0.8rem));
    }

    #mobile-menu nav,
    #mobile_menu nav {
        gap: 0.45rem !important;
        margin: 0;
    }

    #mobile_menu > a,
    #mobile-menu > a,
    #mobile_menu nav > a,
    #mobile-menu nav > a {
        min-height: 40px;
        padding: 0.55rem 0.9rem;
        font-size: 0.98rem !important;
    }

    #mobile_menu nav .w-12 {
        margin: 0.2rem 0 !important;
    }

    #mobile_menu [data-lang-btn],
    #mobile-menu [data-lang-btn] {
        min-height: 34px;
        padding-inline: 0.65rem;
    }
}

/* 23. Reference Home Hero v1 */
#app-main:has(#scene-init.ta-reference-hero.active) #main-nav {
    top: max(18px, env(safe-area-inset-top));
    width: min(1320px, calc(100vw - 32px));
    min-height: 58px;
    padding: 0 36px;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .brand-title {
    font-size: clamp(1rem, 1.35vw, 1.22rem);
    letter-spacing: 0.09em;
    text-transform: uppercase;
    color: rgba(247, 232, 202, 0.92);
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .hidden.md\:flex {
    gap: clamp(1.8rem, 4vw, 4.4rem);
    letter-spacing: 0;
    text-transform: none;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .hidden.md\:flex > a {
    position: relative;
    border: 0 !important;
    padding: 0.35rem 0 0.55rem;
    color: rgba(247, 243, 234, 0.82);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(0.96rem, 1.2vw, 1.08rem);
    letter-spacing: 0;
    text-transform: none;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .hidden.md\:flex > a::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 0;
    height: 1px;
    background: rgba(244, 213, 139, 0.9);
    transform: translateX(-50%);
    transition: width 180ms ease;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .hidden.md\:flex > a:hover::after,
#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .hidden.md\:flex > a.text-amber-400::after {
    width: 100%;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .lang-switch {
    margin-left: clamp(0.8rem, 1.4vw, 1.5rem);
    border-color: rgba(244, 213, 139, 0.22);
    border-radius: 999px;
    background: rgba(5, 6, 14, 0.28);
}

#scene-init.ta-reference-hero,
#scene-init.ta-reference-hero.ta-home-hero {
    min-height: 100%;
    padding: 18px !important;
    background:
        radial-gradient(circle at 50% 42%, rgba(244, 213, 139, 0.08), transparent 26%),
        linear-gradient(180deg, rgba(1, 2, 8, 0.18), rgba(1, 2, 8, 0.62)),
        #03050c;
}

#scene-init.ta-reference-hero::after {
    background:
        linear-gradient(180deg, rgba(1, 2, 8, 0.32), transparent 32%, rgba(1, 2, 8, 0.28) 76%, rgba(1, 2, 8, 0.78)),
        radial-gradient(ellipse at 50% 44%, transparent 0 37%, rgba(1, 2, 8, 0.14) 56%, rgba(1, 2, 8, 0.58) 100%);
}

.ta-reference-frame {
    position: relative;
    z-index: 1;
    width: min(1320px, 100%);
    height: min(840px, calc(100dvh - 36px));
    min-height: 620px;
    display: grid;
    grid-template-rows: 1fr auto;
    overflow: hidden;
    border: 1px solid rgba(218, 191, 138, 0.2);
    background:
        linear-gradient(180deg, rgba(5, 7, 17, 0.08), rgba(5, 7, 17, 0.5) 72%, rgba(5, 7, 17, 0.92)),
        url("images/ui/home-reference-hero-v1.webp") center / cover no-repeat;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.055),
        inset 0 -1px 0 rgba(244, 213, 139, 0.12),
        0 28px 90px rgba(0, 0, 0, 0.42);
}

.ta-reference-frame::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(1,2,8,0.16), transparent 18%, transparent 82%, rgba(1,2,8,0.22)),
        radial-gradient(ellipse at center, transparent 0 35%, rgba(1,2,8,0.18) 58%, rgba(1,2,8,0.44) 100%);
}

.ta-reference-frame .ta-hero-shell {
    z-index: 1;
    width: 100%;
    min-height: 0;
    grid-template-columns: 1fr;
    place-items: center;
    padding: clamp(5.8rem, 13vh, 8.2rem) clamp(1.2rem, 4vw, 4rem) clamp(2rem, 6vh, 4.2rem);
}

.ta-reference-frame .ta-hero-copy {
    max-width: 760px;
    margin-inline: auto;
    text-align: center;
}

.ta-reference-frame .ta-hero-kicker {
    width: clamp(54px, 6vw, 80px);
    height: clamp(54px, 6vw, 80px);
    display: inline-grid;
    place-items: center;
    margin: 0 0 clamp(1.4rem, 3.2vh, 2.35rem);
    color: rgba(244, 213, 139, 0.92);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(2rem, 3.2vw, 3.1rem);
    line-height: 1;
    letter-spacing: 0;
    text-shadow: 0 0 30px rgba(244, 213, 139, 0.36);
}

.ta-reference-frame .ta-hero-kicker::before,
.ta-reference-frame .ta-hero-kicker::after {
    content: "";
    position: absolute;
    width: clamp(90px, 12vw, 160px);
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(218, 191, 138, 0.48), transparent);
}

.ta-reference-frame .ta-hero-kicker::before {
    transform: translateX(calc(-50% - clamp(72px, 10vw, 125px)));
}

.ta-reference-frame .ta-hero-kicker::after {
    transform: translateX(calc(50% + clamp(72px, 10vw, 125px)));
}

.ta-reference-frame .ta-hero-title {
    color: rgba(247, 232, 202, 0.98);
    font-size: clamp(3.25rem, 6.9vw, 6.15rem);
    line-height: 0.92;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-shadow: 0 20px 58px rgba(0, 0, 0, 0.66), 0 0 28px rgba(244, 213, 139, 0.12);
}

.ta-reference-frame .ta-hero-subtitle {
    max-width: 35rem;
    margin: clamp(1.4rem, 3vh, 2.1rem) auto 0;
    color: rgba(247, 243, 234, 0.78);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1.22rem, 2.05vw, 1.72rem);
    line-height: 1.36;
}

.ta-reference-frame .ta-hero-actions {
    justify-content: center;
    margin-top: clamp(1.8rem, 4vh, 2.7rem);
}

.ta-reference-frame .cta-btn-gold {
    position: relative;
    min-width: clamp(13.5rem, 21vw, 17.2rem);
    min-height: clamp(3.25rem, 5.6vw, 4.1rem);
    padding: 0 2.1rem 0 4.05rem;
    border: 1px solid rgba(255, 236, 184, 0.5);
    border-radius: 8px;
    background: linear-gradient(180deg, #ffe29b 0%, #d6a84b 54%, #b87f2f 100%);
    color: #120f0a;
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1.12rem, 1.75vw, 1.42rem);
    font-weight: 600;
    letter-spacing: 0.01em;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.42), 0 18px 44px rgba(0,0,0,0.34), 0 0 32px rgba(217, 184, 107, 0.18);
}

.ta-reference-frame .cta-btn-gold::before {
    content: "✶";
    position: absolute;
    left: 1.55rem;
    top: 50%;
    color: rgba(18, 15, 10, 0.86);
    font-size: 1.35rem;
    transform: translateY(-50%);
}

.ta-reference-frame .ta-secondary-link {
    width: 100%;
    min-height: auto;
    margin-top: 0.6rem;
    padding: 0.15rem 0;
    border: 0;
    background: transparent;
    color: rgba(244, 213, 139, 0.94);
    box-shadow: none;
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1rem, 1.45vw, 1.22rem);
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
}

.ta-reference-frame .ta-secondary-link::after {
    content: "›";
    margin-left: 0.65rem;
    font-size: 1.5em;
    line-height: 0;
}

.ta-reference-frame .ta-astrolabe-visual,
.ta-reference-frame .ta-hero-note,
.ta-reference-hero .ta-next-preview {
    display: none !important;
}

.ta-reference-bottom {
    position: relative;
    z-index: 1;
    min-height: clamp(124px, 16vh, 178px);
    display: grid;
    grid-template-columns: minmax(220px, 0.9fr) minmax(340px, 1.35fr) minmax(220px, 0.9fr);
    align-items: center;
    gap: clamp(1.2rem, 3vw, 2.6rem);
    padding: clamp(1rem, 2.6vh, 1.65rem) clamp(2rem, 6vw, 5rem);
    border-top: 1px solid rgba(218, 191, 138, 0.2);
    background: rgba(4, 7, 16, 0.78);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.ta-ref-feature {
    min-width: 0;
    display: grid;
    grid-template-columns: clamp(58px, 6vw, 82px) 1fr;
    align-items: center;
    gap: clamp(0.8rem, 2vw, 1.25rem);
    text-align: left;
}

.ta-ref-feature:last-child {
    justify-self: end;
}

.ta-ref-icon {
    position: relative;
    width: clamp(58px, 6vw, 82px);
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    border: 1px solid rgba(218, 191, 138, 0.18);
    border-radius: 50%;
    background: rgba(255,255,255,0.035);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
}

.ta-ref-icon-star::before {
    content: "✶";
    color: rgba(244, 213, 139, 0.9);
    font-size: clamp(1.8rem, 3vw, 2.7rem);
}

.ta-ref-icon-eye::before {
    content: "";
    width: 2.35rem;
    height: 1.25rem;
    border: 2px solid rgba(244, 213, 139, 0.82);
    border-radius: 50%;
}

.ta-ref-icon-eye::after {
    content: "";
    position: absolute;
    width: 0.58rem;
    height: 0.58rem;
    border-radius: 50%;
    background: rgba(244, 213, 139, 0.86);
}

.ta-ref-feature strong {
    display: block;
    color: rgba(247, 232, 202, 0.94);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1rem, 1.4vw, 1.2rem);
    font-weight: 600;
}

.ta-ref-feature p,
.ta-ref-statement p {
    margin: 0.25rem 0 0;
    color: rgba(217, 219, 227, 0.68);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(0.84rem, 1.15vw, 1.02rem);
    line-height: 1.46;
}

.ta-ref-statement {
    position: relative;
    padding-inline: clamp(1rem, 3vw, 2.5rem);
    text-align: center;
}

.ta-ref-statement::before,
.ta-ref-statement::after {
    content: "";
    position: absolute;
    top: 8%;
    bottom: 8%;
    width: 1px;
    background: linear-gradient(180deg, transparent, rgba(218, 191, 138, 0.2), transparent);
}

.ta-ref-statement::before {
    left: 0;
}

.ta-ref-statement::after {
    right: 0;
}

.ta-ref-statement span {
    color: rgba(217, 184, 107, 0.94);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.68rem;
    letter-spacing: 0.28em;
}

.ta-ref-statement h2 {
    margin: 0.6rem 0 0;
    color: rgba(247, 232, 202, 0.96);
    font-family: Cormorant Garamond, Noto Serif TC, serif;
    font-size: clamp(1.85rem, 3vw, 2.75rem);
    font-weight: 500;
    line-height: 1.05;
}

@media (max-width: 980px) {
    .ta-reference-bottom {
        grid-template-columns: 1fr;
        gap: 1rem;
        padding: 1.2rem;
    }

    .ta-ref-feature,
    .ta-ref-feature:last-child {
        justify-self: stretch;
    }

    .ta-ref-statement {
        order: -1;
        padding-inline: 0;
    }

    .ta-ref-statement::before,
    .ta-ref-statement::after {
        display: none;
    }
}

@media (max-width: 767px) {
    #app-main:has(#scene-init.ta-reference-hero.active) #main-nav {
        top: max(12px, env(safe-area-inset-top));
        width: calc(100vw - 28px);
        min-height: 56px;
        padding: 0 0 0 0.8rem;
        border: 1px solid rgba(218, 191, 138, 0.2);
        border-bottom: 0;
        border-radius: 16px 16px 0 0;
        background: rgba(3, 5, 12, 0.2);
    }

    #app-main:has(#scene-init.ta-reference-hero.active) #main-nav .brand-title {
        max-width: 58vw;
        font-size: 0.82rem;
        letter-spacing: 0.08em;
    }

    #app-main:has(#scene-init.ta-reference-hero.active) #menu_btn {
        margin-right: 0.3rem;
        border-color: rgba(218, 191, 138, 0.24);
        border-radius: 999px;
        background: rgba(5, 6, 14, 0.42);
        color: rgba(244, 213, 139, 0.92);
    }

    #scene-init.ta-reference-hero,
    #scene-init.ta-reference-hero.ta-home-hero {
        padding: max(12px, env(safe-area-inset-top)) 14px max(14px, env(safe-area-inset-bottom)) !important;
        overflow: hidden !important;
    }

    .ta-reference-frame {
        width: 100%;
        height: 100%;
        min-height: min(690px, calc(100dvh - 28px));
        border-radius: 18px;
        background:
            linear-gradient(180deg, rgba(5, 7, 17, 0.08), rgba(5, 7, 17, 0.2) 52%, rgba(5, 7, 17, 0.92)),
            url("images/ui/home-reference-hero-v1.webp") center top / auto 70% no-repeat,
            #03050c;
    }

    .ta-reference-frame .ta-hero-shell {
        padding: clamp(5.3rem, 16vh, 7.4rem) 1.05rem 1rem;
        align-content: start;
    }

    .ta-reference-frame .ta-hero-kicker {
        width: 50px;
        height: 50px;
        margin-bottom: 1.2rem;
        font-size: 2rem;
    }

    .ta-reference-frame .ta-hero-kicker::before,
    .ta-reference-frame .ta-hero-kicker::after {
        display: none;
    }

    .ta-reference-frame .ta-hero-title {
        font-size: clamp(2.05rem, 9.6vw, 3.05rem);
        line-height: 1.04;
        letter-spacing: 0.08em;
        overflow-wrap: anywhere;
    }

    .ta-reference-frame .ta-hero-subtitle {
        max-width: 17rem;
        margin-top: 1rem;
        font-size: clamp(0.98rem, 4.6vw, 1.16rem);
        line-height: 1.48;
    }

    .ta-reference-frame .ta-hero-actions {
        display: grid;
        justify-items: center;
        gap: 0.75rem;
        margin-top: 1.45rem;
    }

    .ta-reference-frame .cta-btn-gold {
        width: min(100%, 11.8rem);
        min-width: 0;
        min-height: 2.9rem;
        padding-left: 2.9rem;
        padding-right: 1.2rem;
        font-size: 1rem;
    }

    .ta-reference-frame .cta-btn-gold::before {
        left: 1.05rem;
        font-size: 1.05rem;
    }

    .ta-reference-frame .ta-secondary-link {
        width: auto;
        margin-top: 0;
        font-size: 0.92rem;
    }

    .ta-reference-bottom {
        min-height: auto;
        padding: 0.9rem 1rem 1.1rem;
        background: linear-gradient(180deg, rgba(4,7,16,0.48), rgba(4,7,16,0.88));
    }

    .ta-ref-feature {
        display: none;
    }

    .ta-ref-statement span {
        font-size: 0.56rem;
        letter-spacing: 0.2em;
    }

    .ta-ref-statement h2 {
        margin-top: 0.38rem;
        font-size: clamp(1.22rem, 6vw, 1.7rem);
    }

    .ta-ref-statement p {
        max-width: 18rem;
        margin: 0.45rem auto 0;
        font-size: 0.82rem;
        line-height: 1.45;
    }

    #mobile_menu {
        background:
            linear-gradient(180deg, rgba(4, 6, 14, 0.94), rgba(4, 6, 14, 0.985)),
            url("images/ui/home-reference-hero-v1.webp") center top / auto 45% no-repeat;
    }

    #mobile_menu nav > a,
    #mobile_menu nav .w-12 + div {
        border-radius: 8px;
        background: rgba(255,255,255,0.035);
        border-color: rgba(218, 191, 138, 0.12);
    }
}

body:not(.theme-mode-dark) main {
    position: relative;
    z-index: 1;
}

.text-page-container,
body:not(.theme-mode-dark) main {
    width: min(100%, 1120px);
    margin: 0 auto;
    padding-top: clamp(9.5rem, 15vh, 11.5rem);
    padding-bottom: 5rem;
    scroll-margin-top: 7rem;
}

.text-page-container {
    padding-left: 24px;
    padding-right: 24px;
}

.glass-panel,
.content-card,
.guide-box,
.timeline-card,
.spread-card,
.theory-box,
.process-step,
.policy-section,
.terms-section {
    border-radius: var(--ui-radius-lg);
    border: 1px solid var(--ui-line);
    background:
        linear-gradient(145deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015)),
        var(--ui-panel);
    box-shadow: 0 18px 60px rgba(0,0,0,0.22);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.glass-panel,
.content-card {
    padding: clamp(1.5rem, 4vw, 3rem);
}

.timeline-card,
.theory-box,
.process-step {
    padding: 1.25rem;
}

.policy-section,
.terms-section {
    padding: 1.15rem 1.25rem;
    margin-bottom: 1rem;
}

body:not(.theme-mode-dark) h1 {
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
    color: var(--ui-text);
    line-height: 1.08;
    letter-spacing: 0.02em;
    text-wrap: balance;
}

body:not(.theme-mode-dark) header > p,
body:not(.theme-mode-dark) .text-slate-400.tracking-\[0\.3em\] {
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
    color: var(--ui-muted);
    letter-spacing: 0.14em;
    line-height: 1.9;
    text-wrap: balance;
}

.theory-page #content-zh > header,
.theory-page #content-en > header {
    display: none;
}

body:not(.theme-mode-dark) h2 {
    color: var(--ui-gold-soft);
    letter-spacing: 0.01em;
    line-height: 1.25;
}

body:not(.theme-mode-dark) h3 {
    color: var(--ui-text);
    line-height: 1.35;
}

body:not(.theme-mode-dark) p,
body:not(.theme-mode-dark) li {
    color: var(--ui-muted);
    line-height: 1.85;
}

.policy-h2,
.terms-h2,
.content-card h2 {
    font-size: clamp(1.25rem, 2.5vw, 1.75rem);
    margin-bottom: 0.9rem;
}

.policy-p,
.terms-p {
    color: var(--ui-muted);
    line-height: 1.9;
}

.highlight,
.text-link {
    color: var(--ui-gold-soft);
}

#stage-container {
    min-height: 0;
}

.scene {
    padding-inline: clamp(1rem, 4vw, 3rem);
}

.hero-content {
    width: min(100%, 920px);
}

.ritual-form {
    width: min(100%, 1180px);
    margin: 0 auto;
}

.ritual-step,
.spread-panel,
.draw-ready-panel,
.glass-panel-control {
    border-radius: var(--ui-radius-lg);
}

.ritual-step {
    background: rgba(8, 11, 22, 0.36);
}

.spread-panel {
    background: linear-gradient(145deg, rgba(20, 26, 45, 0.76), rgba(9, 12, 24, 0.68));
    border-color: rgba(217, 184, 107, 0.14);
}

.spread-option,
.persona-option,
.category-pill {
    border-radius: 8px;
}

.cta-btn-gold,
.btn-outline,
.gate-btn-primary,
.gate-btn-secondary {
    border-radius: 7px;
    min-height: 44px;
}

.cta-btn-gold {
    background: linear-gradient(135deg, #f6df9d, #c69b45 54%, #f4d58b);
    color: #11131d;
    box-shadow: 0 16px 42px rgba(217, 184, 107, 0.16);
}

.btn-outline {
    border: 1px solid rgba(255,255,255,0.16);
    color: var(--ui-text);
    background: rgba(255,255,255,0.045);
}

.card-face {
    border-radius: 10px;
}

.spread-card {
    overflow: hidden;
}

.mini-map {
    border-radius: 10px;
}

#scene-init.ta-home-hero,
#scene-init {
    align-items: center !important;
    justify-content: center !important;
    padding: clamp(6.8rem, 12vh, 8.4rem) clamp(1rem, 4vw, 3rem) 3.25rem !important;
    overflow: hidden;
}

#scene-init.ta-home-hero {
    isolation: isolate;
    background:
        linear-gradient(90deg, rgba(7,8,19,0.96) 0%, rgba(7,8,19,0.82) 38%, rgba(7,8,19,0.32) 70%, rgba(7,8,19,0.62) 100%),
        linear-gradient(180deg, rgba(7,8,19,0.34), rgba(7,8,19,0.86)),
        url("images/ui/hero-astrolabe-v1.webp") center right / cover no-repeat;
}

#scene-init.ta-home-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(7,8,19,0.4), transparent 34%, rgba(7,8,19,0.76) 100%),
        radial-gradient(ellipse at 20% 50%, rgba(7,8,19,0.45), transparent 46%);
}

.ta-hero-shell {
    position: relative;
    z-index: 1;
    width: min(1180px, 100%);
    min-height: min(700px, calc(100dvh - 156px));
    display: grid;
    grid-template-columns: minmax(0, 0.94fr) minmax(360px, 1.06fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 5.25rem);
}

.ta-hero-copy {
    text-align: left;
    max-width: 660px;
}

.ta-hero-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.15rem;
    color: var(--ui-gold-soft);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.ta-hero-kicker::before {
    content: "";
    width: 2.35rem;
    height: 1px;
    background: linear-gradient(90deg, var(--ui-gold), transparent);
}

.ta-hero-title {
    margin: 0;
    color: var(--ui-text);
    font-family: var(--font-heading);
    font-size: clamp(3.2rem, 7.8vw, 7.2rem);
    line-height: 0.94;
    letter-spacing: 0;
    text-wrap: balance;
    text-shadow: 0 20px 56px rgba(0, 0, 0, 0.45);
}

.ta-hero-subtitle {
    max-width: 38rem;
    margin: 1.25rem 0 0;
    color: rgba(247, 243, 234, 0.78);
    font-family: Noto Serif TC, Cormorant Garamond, serif;
    font-size: clamp(1.06rem, 1.65vw, 1.38rem);
    line-height: 1.85;
}

.ta-hero-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.9rem;
    margin-top: 2rem;
}

.ta-hero-actions .cta-btn-gold {
    min-width: 12rem;
    min-height: 3.25rem;
    padding-inline: 1.85rem;
    border-radius: 8px;
}

.ta-secondary-link {
    min-height: 3.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 1.1rem;
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 8px;
    background: rgba(255,255,255,0.035);
    color: rgba(247, 243, 234, 0.82);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.ta-secondary-link:hover {
    border-color: rgba(217, 184, 107, 0.48);
    color: var(--ui-gold-soft);
    transform: translateY(-1px);
}

.ta-hero-note {
    max-width: 34rem;
    margin-top: 1.15rem;
    color: rgba(169, 176, 195, 0.76);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.86rem;
    line-height: 1.75;
}

.ta-astrolabe-visual {
    position: relative;
    width: min(46vw, 560px);
    aspect-ratio: 1;
    justify-self: center;
    display: grid;
    place-items: center;
    filter: drop-shadow(0 34px 84px rgba(0,0,0,0.34));
    opacity: 0;
    visibility: hidden;
}

.ta-astrolabe-visual::before {
    content: "";
    position: absolute;
    inset: 14%;
    background: conic-gradient(from 42deg, rgba(217,184,107,0.08), rgba(146,168,255,0.16), rgba(139,214,199,0.08), rgba(217,184,107,0.12));
    border-radius: 50%;
    filter: blur(20px);
}

.ta-ring,
.ta-axis {
    position: absolute;
    pointer-events: none;
}

.ta-ring {
    inset: 0;
    border: 1px solid rgba(217, 184, 107, 0.34);
    border-radius: 50%;
    box-shadow: inset 0 0 44px rgba(217, 184, 107, 0.045), 0 0 42px rgba(146, 168, 255, 0.08);
}

.ta-ring-outer {
    background:
        repeating-conic-gradient(from 0deg, rgba(244,213,139,0.42) 0deg 1deg, transparent 1deg 8deg),
        radial-gradient(circle, transparent 66%, rgba(255,255,255,0.045) 67%, transparent 69%);
    animation: ta-slow-spin 54s linear infinite;
}

.ta-ring-mid {
    inset: 13%;
    border-color: rgba(146, 168, 255, 0.28);
    transform: rotate(16deg);
}

.ta-ring-inner {
    inset: 29%;
    border-color: rgba(139, 214, 199, 0.28);
    background: radial-gradient(circle, rgba(247,243,234,0.1) 0 1px, transparent 2px);
}

.ta-axis {
    width: 78%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(244, 213, 139, 0.55), transparent);
    transform-origin: center;
}

.ta-axis-a {
    transform: rotate(28deg);
}

.ta-axis-b {
    transform: rotate(118deg);
}

.ta-card-orbit {
    position: absolute;
    inset: 0;
}

.ta-card-orbit span {
    position: absolute;
    left: 50%;
    bottom: 2%;
    width: clamp(46px, 6vw, 72px);
    aspect-ratio: 0.68;
    border: 1px solid rgba(217, 184, 107, 0.46);
    border-radius: 7px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.02)),
        linear-gradient(180deg, rgba(29, 34, 57, 0.92), rgba(10, 12, 25, 0.94));
    box-shadow: 0 18px 36px rgba(0,0,0,0.28), inset 0 0 0 1px rgba(255,255,255,0.04);
    transform-origin: 50% -260%;
}

.ta-card-orbit span::after {
    content: "";
    position: absolute;
    inset: 14%;
    border: 1px solid rgba(244, 213, 139, 0.22);
    border-radius: 5px;
    background:
        linear-gradient(90deg, transparent 48%, rgba(244,213,139,0.18) 49% 51%, transparent 52%),
        linear-gradient(0deg, transparent 48%, rgba(244,213,139,0.14) 49% 51%, transparent 52%);
}

.ta-card-orbit span:nth-child(1) { transform: translateX(-50%) rotate(-34deg); }
.ta-card-orbit span:nth-child(2) { transform: translateX(-50%) rotate(-17deg); }
.ta-card-orbit span:nth-child(3) { transform: translateX(-50%) rotate(0deg); }
.ta-card-orbit span:nth-child(4) { transform: translateX(-50%) rotate(17deg); }
.ta-card-orbit span:nth-child(5) { transform: translateX(-50%) rotate(34deg); }

.ta-next-preview {
    position: absolute;
    left: 50%;
    bottom: max(1rem, env(safe-area-inset-bottom));
    transform: translateX(-50%);
    z-index: 2;
    width: min(520px, calc(100% - 2rem));
    min-height: 3.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0.95rem 0.75rem 1.1rem;
    border-top: 1px solid rgba(255,255,255,0.12);
    color: rgba(247, 243, 234, 0.76);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.76rem;
    letter-spacing: 0.08em;
    text-align: left;
}

.ta-next-preview span {
    color: var(--ui-gold-soft);
    text-transform: uppercase;
    white-space: nowrap;
}

.ta-next-preview strong {
    min-width: 0;
    color: rgba(247, 243, 234, 0.88);
    font-weight: 500;
    letter-spacing: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

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

@media (max-width: 767px) {
    .ta-entry-gate {
        grid-template-columns: 1rem minmax(0, 1fr) 1rem;
        align-items: end;
        padding-bottom: max(5.2rem, calc(env(safe-area-inset-bottom) + 4.5rem));
        background:
            linear-gradient(180deg, rgba(5,5,16,0.28), rgba(5,5,16,0.82) 42%, rgba(5,5,16,0.96) 100%),
            url("images/ui/hero-astrolabe-v1.webp") 63% top / auto 58% no-repeat,
            #050510;
    }

    .ta-entry-brand {
        left: 1rem;
        font-size: 0.75rem;
        letter-spacing: 0.12em;
    }

    .ta-entry-mark {
        width: 1.35rem;
        height: 1.35rem;
    }

    .ta-entry-copy {
        width: 100%;
        padding-top: 0;
    }

    .ta-entry-kicker {
        font-size: 0.64rem;
        letter-spacing: 0.12em;
    }

    .ta-entry-copy h1 {
        max-width: 9.8em;
        font-size: clamp(2.25rem, 12vw, 3.6rem);
    }

    .ta-entry-lede {
        font-size: 0.95rem;
        line-height: 1.72;
    }

    .ta-entry-actions {
        display: grid;
        grid-template-columns: 1fr;
        margin-top: 1.35rem;
    }

    .ta-entry-actions button {
        width: 100%;
        min-height: 3.6rem;
        text-align: center;
        justify-items: center;
    }

    .ta-entry-note {
        font-size: 0.75rem;
    }

    .ta-entry-status {
        left: 1rem;
        right: 1rem;
        justify-content: center;
        font-size: 0.62rem;
        text-align: center;
    }

    #main-nav {
        width: calc(100vw - 20px);
        min-height: 58px;
        padding: 8px 10px 8px 14px;
        gap: 10px;
    }

    #main-nav a:first-child,
    #main-nav > a {
        font-size: 0.76rem;
        letter-spacing: 0.12em;
        max-width: 48vw;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .lang-switch button,
    #main-nav button[data-lang-btn] {
        min-width: 34px;
        min-height: 32px;
        padding: 0 8px;
        font-size: 11px;
    }

    #mobile-menu-btn,
    #menu_btn {
        width: 40px;
        height: 40px;
    }

    .text-page-container,
    body:not(.theme-mode-dark) main {
        padding-top: 8.5rem;
        padding-left: 16px;
        padding-right: 16px;
    }

    body:not(.theme-mode-dark) h1 {
        font-size: clamp(2rem, 11vw, 3rem);
        letter-spacing: 0.01em;
    }

    body:not(.theme-mode-dark) header > p,
    body:not(.theme-mode-dark) .text-slate-400.tracking-\[0\.3em\] {
        letter-spacing: 0.08em;
        font-size: 0.72rem;
    }

    .glass-panel,
    .content-card,
    .guide-box {
        padding: 1.15rem;
    }

    .scene {
        padding-inline: 1rem;
    }

    #scene-init.ta-home-hero,
    #scene-init {
        justify-content: flex-start !important;
        padding-top: 6rem !important;
        padding-bottom: 4.6rem !important;
        overflow-y: auto;
    }

    .ta-hero-shell {
        min-height: auto;
        grid-template-columns: 1fr;
        gap: 1.65rem;
        align-content: start;
    }

    .ta-hero-copy {
        max-width: none;
        text-align: center;
    }

    .ta-hero-kicker {
        justify-content: center;
        margin-bottom: 0.8rem;
        font-size: 0.66rem;
        letter-spacing: 0.13em;
    }

    .ta-hero-kicker::before {
        width: 1.35rem;
    }

    .ta-hero-title {
        font-size: clamp(2.55rem, 15vw, 4rem);
        line-height: 1;
        overflow-wrap: anywhere;
    }

    .ta-hero-subtitle {
        margin-top: 0.9rem;
        font-size: 1rem;
        line-height: 1.72;
    }

    .ta-hero-actions {
        justify-content: center;
        margin-top: 1.35rem;
    }

    .ta-hero-actions .cta-btn-gold,
    .ta-secondary-link {
        width: min(100%, 17rem);
    }

    .ta-hero-note {
        margin-inline: auto;
        font-size: 0.78rem;
    }

    .ta-astrolabe-visual {
        display: none;
    }

    .ta-card-orbit span {
        width: clamp(34px, 10vw, 48px);
    }

    .ta-next-preview {
        width: calc(100% - 2rem);
        min-height: 2.8rem;
        font-size: 0.66rem;
        bottom: max(0.7rem, env(safe-area-inset-bottom));
    }

    #scene-input {
        align-items: flex-start;
        overflow-y: auto;
        padding-top: 5.5rem;
        padding-bottom: 2rem;
    }

    #scene-meditation {
        align-items: stretch !important;
        justify-content: flex-start !important;
        padding-top: 5.25rem !important;
        padding-bottom: 2rem !important;
        overflow-y: auto !important;
        scroll-padding-top: 5.25rem;
    }

    #scene-meditation .content-wrapper {
        width: 100% !important;
        max-width: none !important;
        gap: 1rem !important;
    }

    .ritual-form {
        gap: 1rem;
    }

    .spread-panel {
        padding: 1rem;
    }

    .spread-question-chips {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: 0.25rem;
        scrollbar-width: none;
    }

    .spread-question-chips::-webkit-scrollbar {
        display: none;
    }

    .spread-chip {
        flex: 0 0 auto;
    }

    .spread-card-grid {
        max-height: none !important;
        overflow-y: visible !important;
        padding-right: 0;
    }

    .spread-choice-card {
        grid-template-columns: 32px minmax(0, 1fr) 34px;
        padding: 0.75rem;
    }

    .spread-choice-copy strong {
        white-space: normal;
    }

    #scene-meditation #user-query {
        min-height: 72px;
        font-size: 1.25rem !important;
        line-height: 1.55 !important;
    }

    #persona-selection {
        gap: 0.75rem !important;
    }

    .persona-card {
        min-height: auto !important;
        padding: 0.9rem !important;
    }

    .draw-ready-panel {
        margin-top: 0.75rem !important;
        padding-top: 1.25rem !important;
    }

    #altar-container {
        gap: 0.75rem;
        min-height: 220px;
        padding-block: 1rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* =========================================
   19. Entry Gate Responsive Hardening v1
   ========================================= */
.ta-entry-gate {
    height: 100dvh;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.ta-entry-brand {
    font-size: 1rem;
}

.ta-entry-copy h1 {
    font-size: 4.85rem;
}

.ta-entry-lede {
    font-size: 1.08rem;
}

@media (max-width: 1180px) {
    .ta-entry-gate {
        grid-template-columns: 2rem minmax(0, 1fr) 2rem;
        background-position: 66% center;
    }

    .ta-entry-copy {
        width: min(100%, 560px);
    }

    .ta-entry-copy h1 {
        font-size: 4.1rem;
    }
}

@media (max-width: 920px) {
    .ta-entry-gate {
        align-items: end;
        padding-bottom: max(4.75rem, calc(env(safe-area-inset-bottom) + 4rem));
        background:
            linear-gradient(180deg, rgba(5,5,16,0.2), rgba(5,5,16,0.72) 42%, rgba(5,5,16,0.98) 100%),
            linear-gradient(90deg, rgba(5,5,16,0.68), rgba(5,5,16,0.18), rgba(5,5,16,0.68)),
            url("images/ui/hero-astrolabe-v1.webp") center top / auto 60% no-repeat,
            #050510;
    }

    .ta-entry-copy {
        width: min(100%, 640px);
        padding-top: 0;
    }

    .ta-entry-copy h1 {
        max-width: 12em;
        font-size: 3.45rem;
    }

    .ta-entry-lede {
        max-width: 38rem;
    }
}

@media (max-width: 767px) {
    .ta-entry-gate {
        grid-template-columns: 1rem minmax(0, 1fr) 1rem;
        padding-top: max(4.2rem, calc(env(safe-area-inset-top) + 3.4rem));
        padding-bottom: max(4.25rem, calc(env(safe-area-inset-bottom) + 3.4rem));
        background:
            linear-gradient(180deg, rgba(5,5,16,0.1), rgba(5,5,16,0.78) 40%, rgba(5,5,16,0.98) 100%),
            url("images/ui/hero-astrolabe-v1.webp") 58% top / auto 48% no-repeat,
            #050510;
    }

    .ta-entry-brand {
        top: max(0.95rem, env(safe-area-inset-top));
        left: 1rem;
        max-width: calc(100vw - 2rem);
        font-size: 0.75rem;
        letter-spacing: 0.11em;
    }

    .ta-entry-copy {
        align-self: end;
        padding-top: 16rem;
    }

    .ta-entry-copy h1 {
        max-width: 9.8em;
        font-size: 2.72rem;
        line-height: 1.06;
    }

    .ta-entry-lede {
        margin-top: 0.85rem;
        font-size: 0.95rem;
        line-height: 1.72;
    }

    .ta-entry-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.7rem;
        margin-top: 1.15rem;
    }

    .ta-entry-actions button {
        width: 100%;
        min-height: 3.55rem;
        padding: 0.65rem 0.9rem;
        text-align: center;
        justify-items: center;
    }

    .ta-entry-note {
        margin-top: 0.78rem;
        font-size: 0.75rem;
        line-height: 1.58;
    }

    .ta-entry-status {
        left: 1rem;
        right: 1rem;
        justify-content: center;
        font-size: 0.62rem;
        text-align: center;
    }
}

@media (max-width: 420px) {
    .ta-entry-copy h1 {
        font-size: 2.38rem;
    }

    .ta-entry-lede {
        font-size: 0.9rem;
    }
}

@media (max-width: 767px) and (max-height: 720px) {
    .ta-entry-gate {
        align-items: start;
        padding-top: max(3.7rem, calc(env(safe-area-inset-top) + 3rem));
        padding-bottom: 1rem;
        background:
            linear-gradient(180deg, rgba(5,5,16,0.42), rgba(5,5,16,0.92)),
            url("images/ui/hero-astrolabe-v1.webp") right top / auto 42% no-repeat,
            #050510;
    }

    .ta-entry-copy {
        align-self: start;
        padding-top: 10rem;
    }

    .ta-entry-copy h1 {
        font-size: 2.12rem;
    }

    .ta-entry-lede {
        font-size: 0.84rem;
        line-height: 1.56;
    }

    .ta-entry-actions button {
        min-height: 3.15rem;
    }

    .ta-entry-note {
        font-size: 0.68rem;
    }

    .ta-entry-status {
        display: none;
    }
}

@media (max-height: 540px) and (orientation: landscape) {
    .ta-entry-gate {
        align-items: center;
        padding-top: max(3.25rem, env(safe-area-inset-top));
        padding-bottom: 1rem;
        background:
            linear-gradient(90deg, rgba(5,5,16,0.94), rgba(5,5,16,0.72) 48%, rgba(5,5,16,0.36)),
            url("images/ui/hero-astrolabe-v1.webp") right center / auto 100% no-repeat,
            #050510;
    }

    .ta-entry-copy {
        width: min(56vw, 620px);
        padding-top: 0;
    }

    .ta-entry-copy h1 {
        font-size: 2.35rem;
    }

    .ta-entry-lede {
        font-size: 0.84rem;
        line-height: 1.52;
    }

    .ta-entry-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ta-entry-note,
    .ta-entry-status {
        display: none;
    }
}

/* =========================================
   20. Entry Ritual Gate v1
   ========================================= */
.ta-entry-ritual {
    min-height: 100dvh;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    place-items: center;
    grid-template-rows: 1fr auto auto auto 1fr;
    gap: clamp(1rem, 2.8vh, 1.6rem);
    padding: max(1.2rem, env(safe-area-inset-top)) 1.25rem max(1.2rem, env(safe-area-inset-bottom));
    overflow: hidden;
    color: var(--ui-text);
    background:
        radial-gradient(circle at 50% 44%, rgba(217,184,107,0.12), transparent 18rem),
        radial-gradient(circle at 50% 52%, rgba(139,214,199,0.08), transparent 28rem),
        linear-gradient(180deg, #050510 0%, #090b18 48%, #050510 100%);
}

.ta-entry-ritual > * {
    grid-column: 1;
}

.ta-entry-ritual::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.018) 1px, transparent 1px);
    background-size: 54px 54px;
    mask-image: radial-gradient(circle at 50% 48%, rgba(0,0,0,0.72), transparent 62%);
}

.ta-entry-ritual::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(5,5,16,0.24), transparent 42%, rgba(5,5,16,0.72)),
        url("images/ui/ritual-workbench-v1.webp") center / cover no-repeat;
    opacity: 0.28;
    filter: saturate(0.84);
}

.ta-ritual-plate {
    grid-row: 2;
    position: relative;
    width: clamp(12rem, 30vw, 20rem);
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    filter: drop-shadow(0 28px 70px rgba(0,0,0,0.42));
}

.ta-ritual-ring,
.ta-ritual-axis,
.ta-ritual-core {
    position: absolute;
    pointer-events: none;
}

.ta-ritual-ring {
    inset: 0;
    border: 1px solid rgba(217,184,107,0.34);
    border-radius: 50%;
}

.ta-ritual-ring-a {
    background:
        repeating-conic-gradient(from 0deg, rgba(244,213,139,0.45) 0deg 1deg, transparent 1deg 9deg),
        radial-gradient(circle, transparent 62%, rgba(244,213,139,0.08) 64%, transparent 66%);
    animation: ta-slow-spin 44s linear infinite;
}

.ta-ritual-ring-b {
    inset: 16%;
    border-color: rgba(139,214,199,0.28);
    animation: spin-reverse 30s linear infinite;
}

.ta-ritual-ring-c {
    inset: 33%;
    border-color: rgba(247,243,234,0.26);
    box-shadow: inset 0 0 34px rgba(217,184,107,0.06);
}

.ta-ritual-axis {
    width: 82%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(244,213,139,0.58), transparent);
}

.ta-ritual-axis-a {
    transform: rotate(32deg);
}

.ta-ritual-axis-b {
    transform: rotate(122deg);
}

.ta-ritual-core {
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 50%;
    background: rgba(244,213,139,0.92);
    box-shadow: 0 0 34px rgba(244,213,139,0.44);
    animation: pulse 2.8s ease-in-out infinite;
}

.ta-ritual-copy {
    grid-row: 3;
    max-width: 34rem;
    text-align: center;
}

.ta-ritual-kicker {
    margin: 0 0 0.65rem;
    color: rgba(244,213,139,0.9);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.ta-ritual-copy h1 {
    margin: 0;
    color: rgba(247,243,234,0.96);
    font-family: var(--font-heading);
    font-size: clamp(2rem, 5vw, 4.1rem);
    line-height: 1.04;
    letter-spacing: 0;
}

.ta-ritual-copy p:not(.ta-ritual-kicker) {
    margin: 0.7rem auto 0;
    color: rgba(169,176,195,0.82);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.92rem;
    line-height: 1.65;
}

.ta-ritual-actions {
    grid-row: 4;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.ta-ritual-actions.gate-buttons {
    animation-delay: 0.36s;
}

.ta-ritual-actions button {
    min-width: 9.5rem;
    min-height: 2.9rem;
    border-radius: 999px;
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.ta-ritual-actions .gate-btn-primary {
    border: 1px solid rgba(244,213,139,0.62);
    background: linear-gradient(135deg, #f6df9d, #c69b45 54%, #f4d58b);
    color: #10131d;
}

.ta-ritual-actions .gate-btn-secondary {
    border: 1px solid rgba(255,255,255,0.16);
    background: rgba(255,255,255,0.045);
    color: rgba(247,243,234,0.86);
}

.ta-ritual-footnote {
    grid-row: 5;
    align-self: end;
    margin: 0;
    color: rgba(169,176,195,0.55);
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-align: center;
    text-transform: uppercase;
}

@media (max-width: 767px) {
    .ta-entry-ritual {
        grid-template-rows: 1fr auto auto auto 0.7fr;
        gap: 0.9rem;
        padding-inline: 1rem;
    }

    .ta-ritual-plate {
        width: clamp(11rem, 62vw, 15rem);
    }

    .ta-ritual-kicker {
        font-size: 0.62rem;
        letter-spacing: 0.16em;
    }

    .ta-ritual-copy h1 {
        font-size: clamp(2rem, 10vw, 3rem);
    }

    .ta-ritual-copy p:not(.ta-ritual-kicker) {
        font-size: 0.84rem;
    }

    .ta-ritual-actions {
        width: min(100%, 21rem);
        display: grid;
        grid-template-columns: 1fr;
    }

    .ta-ritual-actions button {
        width: 100%;
    }
}

@media (max-height: 650px) {
    .ta-entry-ritual {
        grid-template-rows: auto auto auto auto;
        justify-items: center;
        gap: 0.7rem;
        padding-block: 0.9rem;
    }

    .ta-ritual-plate {
        width: clamp(8.5rem, 26vh, 11rem);
    }

    .ta-ritual-copy h1 {
        font-size: clamp(1.75rem, 6vh, 2.5rem);
    }

    .ta-ritual-copy p:not(.ta-ritual-kicker),
    .ta-ritual-footnote {
        display: none;
    }
}

/* =========================================
   21. Imagegen Draw Flow Stage v1
   ========================================= */
.ta-draw-stage {
    isolation: isolate;
    background:
        linear-gradient(180deg, rgba(5, 6, 16, 0.44), rgba(5, 6, 16, 0.78)),
        url("images/ui/draw-stage-v2.webp") center / cover no-repeat !important;
}

.ta-draw-stage::before {
    inset: max(5.9rem, calc(env(safe-area-inset-top) + 5.2rem)) clamp(0.75rem, 3vw, 2rem) max(1rem, calc(env(safe-area-inset-bottom) + 0.85rem)) !important;
    border: 1px solid rgba(217, 184, 107, 0.16) !important;
    border-radius: 18px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.006)),
        linear-gradient(90deg, rgba(5,6,16,0.2), transparent 50%, rgba(5,6,16,0.18)) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.05),
        inset 0 -90px 120px rgba(0,0,0,0.22),
        0 24px 80px rgba(0,0,0,0.24);
}

.ta-draw-stage::after {
    left: clamp(1.25rem, 7vw, 7rem) !important;
    right: clamp(1.25rem, 7vw, 7rem) !important;
    bottom: max(1.5rem, env(safe-area-inset-bottom)) !important;
    background: linear-gradient(90deg, transparent, rgba(244,213,139,0.45), rgba(139,214,199,0.28), transparent) !important;
}

.ta-draw-stage #card-stream-track {
    z-index: 3 !important;
    filter: drop-shadow(0 18px 34px rgba(0,0,0,0.38));
}

.ta-draw-stage #draw-prompt {
    top: max(6.35rem, calc(env(safe-area-inset-top) + 5.5rem)) !important;
    width: min(24rem, calc(100vw - 2rem));
    padding: 0.7rem 1rem !important;
    border: 1px solid rgba(217,184,107,0.22) !important;
    border-radius: 999px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.018)),
        rgba(5, 7, 18, 0.74) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.06),
        0 18px 52px rgba(0,0,0,0.36);
}

.ta-draw-stage #draw-prompt p {
    color: rgba(244,213,139,0.88) !important;
}

.ta-draw-stage .stream-card {
    border-radius: 10px;
    outline: 1px solid rgba(244,213,139,0.24);
    outline-offset: -1px;
    box-shadow:
        0 18px 38px rgba(0,0,0,0.46),
        0 0 0 1px rgba(255,255,255,0.04);
}

@media (hover: hover) {
    .ta-draw-stage .stream-card:hover {
        filter: brightness(1.12) saturate(1.04);
        box-shadow:
            0 22px 48px rgba(0,0,0,0.5),
            0 0 32px rgba(217,184,107,0.28);
    }
}

.ta-revelation-stage {
    background:
        linear-gradient(180deg, rgba(5, 6, 16, 0.42), rgba(5, 6, 16, 0.9)),
        url("images/ui/revelation-altar-v2.webp") center / cover no-repeat;
}

.ta-revelation-stage .content-wrapper {
    position: relative;
    z-index: 1;
    max-width: min(1180px, calc(100vw - 2rem)) !important;
}

.ta-revelation-stage #altar-container {
    width: min(100%, 1060px);
    min-height: clamp(300px, 46vh, 470px) !important;
    padding: clamp(2.4rem, 7vh, 4.5rem) 1rem clamp(1.2rem, 3vh, 2rem) !important;
    align-items: center;
    align-content: center;
    border: 1px solid rgba(217,184,107,0.1);
    border-radius: 18px;
    background:
        radial-gradient(ellipse at 50% 46%, rgba(217,184,107,0.08), transparent 56%),
        rgba(5,7,18,0.18);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 26px 90px rgba(0,0,0,0.16);
}

.ta-revelation-stage .card-item {
    filter: drop-shadow(0 24px 34px rgba(0,0,0,0.46));
}

.ta-revelation-stage .card-front,
.ta-revelation-stage .card-back {
    border: 1px solid rgba(244,213,139,0.18);
    border-radius: 12px !important;
}

.ta-revelation-stage #action-area {
    margin-top: clamp(0.4rem, 2vh, 1.2rem) !important;
    margin-bottom: clamp(1.2rem, 4vh, 2.4rem) !important;
}

.ta-revelation-stage .glass-panel-control {
    border: 1px solid rgba(217,184,107,0.18) !important;
    border-radius: 14px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.018)),
        rgba(5,7,18,0.78) !important;
    box-shadow: 0 22px 56px rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.06);
}

.ta-revelation-stage #interpret_section {
    position: relative;
    z-index: 2;
}

@media (max-width: 767px) {
    .ta-draw-stage {
        background:
            linear-gradient(180deg, rgba(5, 6, 16, 0.32), rgba(5, 6, 16, 0.86)),
            url("images/ui/draw-stage-v2.webp") center / auto 100% no-repeat !important;
    }

    .ta-draw-stage::before {
        inset: max(5.25rem, calc(env(safe-area-inset-top) + 4.6rem)) 0.55rem max(0.7rem, calc(env(safe-area-inset-bottom) + 0.55rem)) !important;
        border-radius: 12px !important;
    }

    .ta-draw-stage #draw-prompt {
        top: max(5.55rem, calc(env(safe-area-inset-top) + 4.85rem)) !important;
        width: min(19rem, calc(100vw - 1.4rem));
        padding: 0.62rem 0.85rem !important;
    }

    .ta-revelation-stage {
        background:
            linear-gradient(180deg, rgba(5, 6, 16, 0.34), rgba(5, 6, 16, 0.92)),
            url("images/ui/revelation-altar-v2.webp") center / auto 100% no-repeat;
    }

    .ta-revelation-stage #altar-container {
        min-height: clamp(320px, 50vh, 430px) !important;
        padding: 3rem 0.5rem 1.25rem !important;
        gap: 0.85rem !important;
    }

    .ta-revelation-stage .glass-panel-control {
        width: min(100%, 22rem);
        padding: 0.75rem !important;
    }
}

/* =========================================
   17. Ritual Workbench Redesign v1
   ========================================= */
.ta-ritual-workbench {
    padding-top: max(7.25rem, calc(env(safe-area-inset-top) + 6.4rem)) !important;
    padding-bottom: max(2.2rem, calc(env(safe-area-inset-bottom) + 1.7rem)) !important;
    background:
        linear-gradient(180deg, rgba(7, 8, 19, 0.42), rgba(7, 8, 19, 0.88)),
        linear-gradient(90deg, rgba(7, 8, 19, 0.78), rgba(7, 8, 19, 0.26), rgba(7, 8, 19, 0.78)),
        url("images/ui/ritual-workbench-v1.webp") center / cover no-repeat;
}

.ta-ritual-grid {
    max-width: min(1180px, calc(100vw - 2rem)) !important;
    display: grid !important;
    grid-template-columns: minmax(300px, 0.86fr) minmax(360px, 1.14fr);
    grid-template-areas:
        "query spread"
        "persona spread"
        "ready ready";
    gap: 1rem !important;
    align-items: stretch;
}

.ta-ritual-grid > .ritual-step:nth-of-type(1) {
    grid-area: query;
}

.ta-ritual-grid > .ritual-step:nth-of-type(2) {
    grid-area: spread;
}

.ta-ritual-grid > .ritual-step:nth-of-type(3) {
    grid-area: persona;
}

.ta-ritual-grid > .draw-ready-panel {
    grid-area: ready;
}

.ta-ritual-workbench .ritual-step,
.ta-ritual-workbench .draw-ready-panel {
    margin: 0 !important;
    padding: clamp(1rem, 2vw, 1.35rem) !important;
    border: 1px solid rgba(255,255,255,0.1) !important;
    border-radius: 12px !important;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.055), rgba(255,255,255,0.016)),
        rgba(9, 12, 25, 0.72) !important;
    box-shadow: 0 20px 58px rgba(0,0,0,0.24);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.ta-ritual-workbench .ritual-step > .flex:first-child {
    justify-content: flex-start !important;
    gap: 0.72rem !important;
    margin-bottom: 0.9rem !important;
}

.ta-ritual-workbench .ritual-step > .flex:first-child .h-px {
    display: block !important;
    min-width: 1.6rem;
    opacity: 0.72;
}

.ta-ritual-workbench .ritual-step > .flex:first-child span {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(217, 184, 107, 0.28);
    border-radius: 8px;
    background: rgba(217, 184, 107, 0.08);
    font-size: 0.86rem !important;
    line-height: 1;
}

.ta-ritual-workbench .ritual-step > .flex:first-child label,
.ta-ritual-workbench .ritual-step > .flex:first-child h2 {
    color: rgba(247, 243, 234, 0.9) !important;
    font-family: Lato, system-ui, sans-serif;
    font-size: 0.77rem !important;
    font-weight: 700;
    letter-spacing: 0.1em !important;
    text-transform: uppercase;
}

.ta-ritual-workbench #user-query {
    min-height: 178px !important;
    padding: 1rem !important;
    border: 1px solid rgba(255,255,255,0.1) !important;
    border-radius: 10px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.01)),
        rgba(3, 5, 15, 0.54) !important;
    color: rgba(247, 243, 234, 0.94) !important;
    font-size: 1rem !important;
    line-height: 1.7 !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.045);
}

.ta-ritual-workbench #user-query:focus {
    border-color: rgba(217, 184, 107, 0.52) !important;
    box-shadow: 0 0 0 3px rgba(217, 184, 107, 0.08), inset 0 1px 0 rgba(255,255,255,0.06);
}

.ta-ritual-workbench .spread-guidance {
    height: 100%;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem !important;
}

.ta-ritual-workbench .spread-question-chips {
    gap: 0.5rem;
}

.ta-ritual-workbench .spread-chip {
    min-height: 2rem;
    padding: 0.42rem 0.66rem;
    border-radius: 999px;
    font-size: 0.72rem;
}

.ta-ritual-workbench .spread-card-grid {
    max-height: 248px;
    padding-right: 0.2rem;
}

.ta-ritual-workbench .spread-choice-card {
    grid-template-columns: 38px minmax(0, 1fr) 40px;
    min-height: 4.25rem;
    padding: 0.72rem;
    background: rgba(255,255,255,0.035);
}

.ta-ritual-workbench .spread-choice-card.active {
    border-color: rgba(244, 213, 139, 0.54);
    background: rgba(217, 184, 107, 0.1);
}

.ta-ritual-workbench .spread-current {
    margin-top: 0.15rem;
    padding-top: 0.78rem !important;
}

.ta-ritual-workbench .spread-current h3 {
    font-size: 1.05rem !important;
}

.ta-ritual-workbench .spread-current p {
    font-size: 0.82rem !important;
    line-height: 1.65 !important;
}

.ta-ritual-workbench #persona-selection {
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 0.68rem !important;
}

.ta-ritual-workbench .persona-card {
    min-height: 4.6rem !important;
    padding: 0.78rem !important;
    border-radius: 10px !important;
    background: rgba(255,255,255,0.034);
}

.ta-ritual-workbench .persona-card .w-12 {
    flex: 0 0 42px;
}

.ta-ritual-workbench .draw-ready-panel {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) auto minmax(180px, 0.7fr);
    align-items: center;
    gap: clamp(1rem, 3vw, 2.25rem);
    text-align: left !important;
    padding: 1.15rem 1.35rem !important;
}

.ta-ritual-workbench .draw-ready-panel .flex {
    justify-content: flex-start !important;
    margin: 0 !important;
}

.ta-ritual-workbench .draw-ready-copy {
    max-width: none !important;
    margin: 0 !important;
}

.ta-ritual-workbench .draw-ready-deck {
    width: 230px;
    height: 96px;
    margin: 0 !important;
}

.ta-ritual-workbench #btn_confirm_meditation {
    width: min(100%, 220px);
    justify-self: end;
}

.ta-draw-stage::before {
    inset: max(6.2rem, calc(env(safe-area-inset-top) + 5.5rem)) clamp(0.75rem, 3vw, 2rem) max(1.3rem, calc(env(safe-area-inset-bottom) + 1rem)) !important;
    border-radius: 14px !important;
    background:
        linear-gradient(180deg, rgba(7, 8, 19, 0.28), rgba(7, 8, 19, 0.72)),
        url("images/ui/ritual-workbench-v1.webp") center / cover no-repeat !important;
    box-shadow: inset 0 0 0 1px rgba(217, 184, 107, 0.12), inset 0 -80px 120px rgba(0,0,0,0.34);
}

.ta-draw-stage #draw-prompt {
    top: max(6.75rem, calc(env(safe-area-inset-top) + 5.9rem)) !important;
}

.ta-revelation-stage #altar-container {
    width: min(100%, 1120px);
    min-height: clamp(280px, 42vh, 430px) !important;
    align-items: center;
}

.ta-revelation-stage .glass-panel-control {
    border-radius: 12px !important;
}

@media (max-width: 1023px) {
    .ta-ritual-grid {
        grid-template-columns: 1fr;
        grid-template-areas:
            "query"
            "spread"
            "persona"
            "ready";
        max-width: min(720px, calc(100vw - 1.5rem)) !important;
    }

    .ta-ritual-workbench .spread-card-grid {
        max-height: none;
    }

    .ta-ritual-workbench .draw-ready-panel {
        grid-template-columns: 1fr;
        text-align: center !important;
        justify-items: center;
    }

    .ta-ritual-workbench .draw-ready-panel .flex {
        justify-content: center !important;
    }

    .ta-ritual-workbench #btn_confirm_meditation {
        justify-self: center;
    }
}

@media (max-width: 767px) {
    .ta-ritual-workbench {
        padding-top: max(5.7rem, calc(env(safe-area-inset-top) + 5.1rem)) !important;
        padding-inline: 0.75rem !important;
    }

    .ta-ritual-grid {
        max-width: none !important;
        gap: 0.85rem !important;
    }

    .ta-ritual-workbench .ritual-step,
    .ta-ritual-workbench .draw-ready-panel {
        padding: 0.95rem !important;
    }

    .ta-ritual-workbench #user-query {
        min-height: 126px !important;
    }

    .ta-ritual-workbench .spread-choice-card {
        grid-template-columns: 34px minmax(0, 1fr) 36px;
        min-height: 4rem;
    }

    .ta-ritual-workbench .draw-ready-deck {
        width: 210px;
        height: 88px;
    }

    .ta-draw-stage::before {
        inset: max(5.35rem, calc(env(safe-area-inset-top) + 4.7rem)) 0.65rem max(0.8rem, calc(env(safe-area-inset-bottom) + 0.7rem)) !important;
    }

    .ta-draw-stage #draw-prompt {
        top: max(5.7rem, calc(env(safe-area-inset-top) + 5rem)) !important;
        width: min(300px, calc(100vw - 1.5rem));
    }
}

/* =========================================
   18. Editorial Page System v1
   ========================================= */
body:not(.theme-mode-dark) main.text-page-container,
body:not(.theme-mode-dark) main.pt-28 {
    width: min(100%, 1120px) !important;
    padding-top: max(9rem, calc(env(safe-area-inset-top) + 8rem)) !important;
    padding-bottom: max(5rem, calc(env(safe-area-inset-bottom) + 4rem)) !important;
}

body:not(.theme-mode-dark) main > section.max-w-4xl,
body:not(.theme-mode-dark) main > .max-w-5xl,
body:not(.theme-mode-dark) main.text-page-container > article,
body:not(.theme-mode-dark) main.text-page-container > div {
    width: min(100%, 920px);
    margin-left: auto;
    margin-right: auto;
}

body:not(.theme-mode-dark) .glass-panel,
body:not(.theme-mode-dark) .content-card,
body:not(.theme-mode-dark) .policy-section,
body:not(.theme-mode-dark) .terms-section {
    border-radius: 12px !important;
    border-color: rgba(255,255,255,0.1) !important;
    background:
        linear-gradient(145deg, rgba(255,255,255,0.058), rgba(255,255,255,0.014)),
        rgba(9, 12, 25, 0.74) !important;
}

body:not(.theme-mode-dark) .glass-panel {
    padding: clamp(1.25rem, 5vw, 3.3rem) !important;
}

body:not(.theme-mode-dark) article header,
body:not(.theme-mode-dark) #content-zh > header,
body:not(.theme-mode-dark) #content-en > header {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 3.4rem) !important;
    padding-bottom: clamp(1.25rem, 3vw, 1.8rem);
    text-align: left !important;
}

body:not(.theme-mode-dark) article header::after,
body:not(.theme-mode-dark) #content-zh > header::after,
body:not(.theme-mode-dark) #content-en > header::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: min(100%, 34rem);
    height: 1px;
    background: linear-gradient(90deg, rgba(217,184,107,0.5), rgba(255,255,255,0.1), transparent);
}

body:not(.theme-mode-dark) article header .h-1,
body:not(.theme-mode-dark) #content-zh > header .h-1,
body:not(.theme-mode-dark) #content-en > header .h-1 {
    display: none;
}

body:not(.theme-mode-dark) article header h1,
body:not(.theme-mode-dark) #content-zh > header h1,
body:not(.theme-mode-dark) #content-en > header h1 {
    margin-left: 0;
    margin-right: 0;
    font-size: clamp(2.35rem, 6vw, 4.4rem) !important;
    line-height: 1.03 !important;
    letter-spacing: 0 !important;
}

body:not(.theme-mode-dark) article header p,
body:not(.theme-mode-dark) #content-zh > header p,
body:not(.theme-mode-dark) #content-en > header p {
    max-width: 42rem;
    margin-left: 0;
    margin-right: 0;
    color: rgba(169, 176, 195, 0.82) !important;
    font-size: 0.76rem !important;
    letter-spacing: 0.12em !important;
}

body:not(.theme-mode-dark) article section,
body:not(.theme-mode-dark) .content-card section {
    position: relative;
}

body:not(.theme-mode-dark) article section + section,
body:not(.theme-mode-dark) .content-card section + section {
    margin-top: clamp(1.65rem, 4vw, 2.4rem) !important;
    padding-top: clamp(1.4rem, 3vw, 2rem) !important;
    border-top: 1px solid rgba(255,255,255,0.08);
}

body:not(.theme-mode-dark) article section h2,
body:not(.theme-mode-dark) .content-card h2,
body:not(.theme-mode-dark) .policy-h2,
body:not(.theme-mode-dark) .terms-h2 {
    display: flex;
    align-items: center;
    gap: 0.72rem;
    border-bottom: 0 !important;
    padding-bottom: 0 !important;
    color: rgba(244, 213, 139, 0.96) !important;
    font-size: clamp(1.15rem, 2.3vw, 1.52rem) !important;
    letter-spacing: 0 !important;
}

body:not(.theme-mode-dark) article section h2::before,
body:not(.theme-mode-dark) .content-card h2::before,
body:not(.theme-mode-dark) .policy-h2::before,
body:not(.theme-mode-dark) .terms-h2::before {
    content: "";
    flex: 0 0 0.55rem;
    width: 0.55rem;
    height: 0.55rem;
    border: 1px solid rgba(217, 184, 107, 0.62);
    border-radius: 50%;
    box-shadow: 0 0 0 0.35rem rgba(217, 184, 107, 0.08);
}

body:not(.theme-mode-dark) article p,
body:not(.theme-mode-dark) article li,
body:not(.theme-mode-dark) .policy-p,
body:not(.theme-mode-dark) .terms-p {
    color: rgba(210, 217, 232, 0.78) !important;
    font-size: clamp(0.98rem, 1.3vw, 1.04rem);
    line-height: 1.9 !important;
}

body:not(.theme-mode-dark) article ul,
body:not(.theme-mode-dark) .content-card ul {
    display: grid;
    gap: 0.72rem;
    padding-left: 0;
    list-style: none;
}

body:not(.theme-mode-dark) article li,
body:not(.theme-mode-dark) .content-card li {
    position: relative;
    padding-left: 1.35rem;
}

body:not(.theme-mode-dark) article li::before,
body:not(.theme-mode-dark) .content-card li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.82em;
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 50%;
    background: rgba(217, 184, 107, 0.72);
}

body:not(.theme-mode-dark) article strong,
body:not(.theme-mode-dark) .content-card strong {
    color: rgba(244, 213, 139, 0.94) !important;
    font-weight: 600;
}

body:not(.theme-mode-dark) article section.border-t,
body:not(.theme-mode-dark) .content-card section.border-t {
    border-top-color: rgba(217, 184, 107, 0.2) !important;
}

body:not(.theme-mode-dark) article section.border-t p,
body:not(.theme-mode-dark) .content-card section.border-t p {
    color: rgba(247, 243, 234, 0.86) !important;
    font-size: clamp(1.05rem, 2vw, 1.25rem);
}

.spreads-page-shell .guide-box {
    overflow: hidden;
}

.spreads-guide-visual {
    width: 100%;
    aspect-ratio: 2.35 / 1;
    margin-bottom: 1.4rem;
    border: 1px solid rgba(217, 184, 107, 0.18);
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(7,8,19,0.08), rgba(7,8,19,0.34)),
        url("images/ui/spreads-guide-v1.webp") center / cover no-repeat;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 18px 44px rgba(0,0,0,0.22);
}

.editorial-visual-panel {
    position: relative;
    width: 100%;
    aspect-ratio: 2.22 / 1;
    margin: 0 0 clamp(1.7rem, 4vw, 2.5rem);
    overflow: hidden;
    border: 1px solid rgba(217, 184, 107, 0.18);
    border-radius: 12px;
    background-color: rgba(7, 8, 19, 0.86);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.07),
        inset 0 -72px 110px rgba(0,0,0,0.28),
        0 22px 62px rgba(0,0,0,0.28);
}

.editorial-visual-panel::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(7,8,19,0.03), rgba(7,8,19,0.2) 64%, rgba(7,8,19,0.52)),
        linear-gradient(90deg, rgba(7,8,19,0.26), transparent 34%, rgba(7,8,19,0.18));
}

.visual-about-flow {
    background-image: url("images/ui/about-flow-v1.webp");
}

.visual-theory-matrix {
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
    background-image: url("images/ui/theory-matrix-v1.webp");
}

.visual-origins-timeline {
    background-image: url("images/ui/origins-timeline-v1.webp");
}

.page-about,
.page-origins,
.theory-page {
    background-attachment: fixed;
}

.page-about::after,
.page-origins::after,
.theory-page::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    opacity: 0.42;
    background-repeat: no-repeat;
    background-size: min(960px, 82vw) auto;
    filter: saturate(0.84);
    mask-image: linear-gradient(to bottom, transparent, rgba(0,0,0,0.62) 18%, rgba(0,0,0,0.46) 72%, transparent);
}

.page-about::after {
    background-image: url("images/ui/about-flow-v1.webp");
    background-position: right 8vw top 9rem;
}

.page-origins::after {
    background-image: url("images/ui/origins-timeline-v1.webp");
    background-position: left 5vw top 9rem;
}

.theory-page::after {
    background-image: url("images/ui/theory-matrix-v1.webp");
    background-position: right 4vw top 9rem;
}

body:not(.theme-mode-dark) .timeline-card {
    position: relative;
    overflow: hidden;
}

body:not(.theme-mode-dark) .timeline-card::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(180deg, rgba(244,213,139,0.8), rgba(139,214,199,0.24));
    opacity: 0.74;
}

@media (max-width: 767px) {
    body:not(.theme-mode-dark) main.text-page-container,
    body:not(.theme-mode-dark) main.pt-28 {
        padding-top: max(6.8rem, calc(env(safe-area-inset-top) + 6rem)) !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    body:not(.theme-mode-dark) .glass-panel {
        padding: 1.15rem !important;
    }

    body:not(.theme-mode-dark) article header,
    body:not(.theme-mode-dark) #content-zh > header,
    body:not(.theme-mode-dark) #content-en > header {
        text-align: left !important;
    }

    .spreads-guide-visual {
        aspect-ratio: 1.45 / 1;
        background-position: center;
    }

    .editorial-visual-panel {
        aspect-ratio: 1.45 / 1;
        margin-bottom: 1.35rem;
        border-radius: 10px;
    }

    .visual-about-flow {
        background-position: center;
    }

    .visual-theory-matrix {
        background-position: center;
    }

    .visual-origins-timeline {
        background-position: center;
    }

    .page-about::after,
    .page-origins::after,
    .theory-page::after {
        opacity: 0.18;
        background-size: 160vw auto;
        background-position: center top 7rem;
    }
}

/* 24. Reference Home Hero Priority Layer */
#app-main:has(#scene-init.ta-reference-hero.active) #main-nav {
    top: max(18px, env(safe-area-inset-top)) !important;
    width: min(1320px, calc(100vw - 32px)) !important;
    min-height: 58px !important;
    padding: 0 36px !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

#scene-init.ta-reference-hero,
#scene-init.ta-reference-hero.ta-home-hero {
    justify-content: center !important;
    padding: 18px !important;
    overflow: hidden !important;
    background:
        radial-gradient(circle at 50% 42%, rgba(244, 213, 139, 0.08), transparent 26%),
        linear-gradient(180deg, rgba(1, 2, 8, 0.18), rgba(1, 2, 8, 0.62)),
        #03050c !important;
}

#scene-init.ta-reference-hero::after {
    background:
        linear-gradient(180deg, rgba(1, 2, 8, 0.32), transparent 32%, rgba(1, 2, 8, 0.28) 76%, rgba(1, 2, 8, 0.78)),
        radial-gradient(ellipse at 50% 44%, transparent 0 37%, rgba(1,2,8,0.18) 58%, rgba(1,2,8,0.58) 100%) !important;
}

#scene-init.ta-reference-hero .ta-reference-frame {
    width: min(1320px, 100%) !important;
    height: min(840px, calc(100dvh - 36px)) !important;
    min-height: 620px !important;
    display: grid !important;
    grid-template-rows: 1fr auto !important;
    overflow: hidden !important;
    border: 1px solid rgba(218, 191, 138, 0.2) !important;
    border-radius: 0 !important;
    background:
        linear-gradient(180deg, rgba(5, 7, 17, 0.08), rgba(5, 7, 17, 0.5) 72%, rgba(5, 7, 17, 0.92)),
        url("images/ui/home-reference-hero-v1.webp") center / cover no-repeat !important;
}

#scene-init.ta-reference-hero .ta-hero-shell {
    width: 100% !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    place-items: center !important;
    padding: clamp(5.8rem, 13vh, 8.2rem) clamp(1.2rem, 4vw, 4rem) clamp(2rem, 6vh, 4.2rem) !important;
}

#scene-init.ta-reference-hero .ta-hero-copy {
    max-width: 760px !important;
    margin-inline: auto !important;
    text-align: center !important;
}

#scene-init.ta-reference-hero .ta-hero-title {
    font-size: clamp(3.25rem, 6.9vw, 6.15rem) !important;
    line-height: 0.92 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

#scene-init.ta-reference-hero .ta-reference-bottom {
    display: grid !important;
}

#scene-init.ta-reference-hero .ta-astrolabe-visual,
#scene-init.ta-reference-hero .ta-hero-note,
#scene-init.ta-reference-hero .ta-next-preview {
    display: none !important;
}

@media (max-width: 767px) {
    #app-main:has(#scene-init.ta-reference-hero.active) #main-nav {
        top: max(12px, env(safe-area-inset-top)) !important;
        width: calc(100vw - 28px) !important;
        min-height: 56px !important;
        padding: 0 0 0 0.8rem !important;
        border: 1px solid rgba(218, 191, 138, 0.2) !important;
        border-bottom: 0 !important;
        border-radius: 16px 16px 0 0 !important;
        background: rgba(3, 5, 12, 0.2) !important;
    }

    #scene-init.ta-reference-hero,
    #scene-init.ta-reference-hero.ta-home-hero {
        padding: max(12px, env(safe-area-inset-top)) 14px max(14px, env(safe-area-inset-bottom)) !important;
    }

    #scene-init.ta-reference-hero .ta-reference-frame {
        width: 100% !important;
        height: 100% !important;
        min-height: min(690px, calc(100dvh - 28px)) !important;
        border-radius: 18px !important;
        background:
            linear-gradient(180deg, rgba(5, 7, 17, 0.08), rgba(5, 7, 17, 0.2) 52%, rgba(5, 7, 17, 0.92)),
            url("images/ui/home-reference-hero-v1.webp") center top / auto 70% no-repeat,
            #03050c !important;
    }

    #scene-init.ta-reference-hero .ta-hero-shell {
        padding: clamp(5.3rem, 16vh, 7.4rem) 1.05rem 1rem !important;
        align-content: start !important;
    }

    #scene-init.ta-reference-hero .ta-hero-title {
        font-size: clamp(2.05rem, 9.6vw, 3.05rem) !important;
        line-height: 1.04 !important;
        letter-spacing: 0.08em !important;
    }

    #scene-init.ta-reference-hero .ta-reference-bottom {
        min-height: 112px !important;
        padding: 0.72rem 0.9rem 0.86rem !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement p {
        max-width: 16rem !important;
        font-size: 0.76rem !important;
        line-height: 1.32 !important;
    }
}

@media (max-width: 767px) and (max-height: 740px) {
    #scene-init.ta-reference-hero .ta-reference-frame {
        grid-template-rows: minmax(0, 1fr) auto !important;
    }

    #scene-init.ta-reference-hero .ta-hero-shell {
        padding: 4.1rem 0.9rem 0.55rem !important;
    }

    #scene-init.ta-reference-hero .ta-hero-kicker {
        width: 34px !important;
        height: 34px !important;
        margin-bottom: 0.58rem !important;
        font-size: 1.45rem !important;
    }

    #scene-init.ta-reference-hero .ta-hero-title {
        font-size: clamp(1.55rem, 8.2vw, 2.35rem) !important;
        line-height: 1 !important;
    }

    #scene-init.ta-reference-hero .ta-hero-subtitle {
        max-width: 15.5rem !important;
        margin-top: 0.6rem !important;
        font-size: 0.88rem !important;
        line-height: 1.32 !important;
    }

    #scene-init.ta-reference-hero .ta-hero-actions {
        margin-top: 0.85rem !important;
        gap: 0.42rem !important;
    }

    #scene-init.ta-reference-hero .cta-btn-gold {
        width: min(100%, 10.7rem) !important;
        min-height: 2.55rem !important;
        font-size: 0.94rem !important;
    }

    #scene-init.ta-reference-hero .ta-secondary-link {
        font-size: 0.82rem !important;
    }

    #scene-init.ta-reference-hero .ta-reference-bottom {
        min-height: 86px !important;
        padding: 0.55rem 0.8rem 0.68rem !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement span {
        font-size: 0.5rem !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement h2 {
        font-size: 1.06rem !important;
        line-height: 1.08 !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement p {
        display: none !important;
    }
}

/* 26. Home Entry Layout Stabilization v1 */
#gate-screen.ta-entry-ritual {
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) auto auto auto minmax(0, 1fr) !important;
    justify-items: center !important;
    align-items: center !important;
    width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    padding: max(1rem, env(safe-area-inset-top)) clamp(1rem, 4vw, 2rem) max(1rem, env(safe-area-inset-bottom)) !important;
}

#gate-screen.ta-entry-ritual > * {
    grid-column: 1 !important;
}

#gate-screen .ta-ritual-actions,
#gate-screen .ta-ritual-actions button {
    position: relative;
    z-index: 3;
    pointer-events: auto;
}

#app-main:has(#scene-init.ta-reference-hero.active) {
    height: 100dvh !important;
    min-height: 100dvh !important;
    overflow: hidden !important;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav {
    position: fixed !important;
    top: max(18px, env(safe-area-inset-top)) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 80 !important;
    width: min(1320px, calc(100vw - 32px)) !important;
    min-height: 58px !important;
    padding: 0 36px !important;
    pointer-events: none !important;
}

#app-main:has(#scene-init.ta-reference-hero.active) #main-nav > *,
#app-main:has(#scene-init.ta-reference-hero.active) #main-nav a,
#app-main:has(#scene-init.ta-reference-hero.active) #main-nav button,
#app-main:has(#scene-init.ta-reference-hero.active) #main-nav .lang-switch {
    pointer-events: auto !important;
}

#scene-init.ta-reference-hero,
#scene-init.ta-reference-hero.ta-home-hero {
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    display: grid !important;
    place-items: center !important;
    padding: max(18px, env(safe-area-inset-top)) 18px max(18px, env(safe-area-inset-bottom)) !important;
    overflow: hidden !important;
}

#scene-init.ta-reference-hero::after {
    pointer-events: none !important;
}

#scene-init.ta-reference-hero .ta-reference-frame {
    width: min(1320px, 100%) !important;
    height: min(840px, calc(100dvh - max(36px, calc(env(safe-area-inset-top) + env(safe-area-inset-bottom) + 36px)))) !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    border-radius: 0 !important;
    overflow: hidden !important;
}

#scene-init.ta-reference-hero .ta-hero-shell {
    min-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: clamp(5.4rem, 12vh, 7.7rem) clamp(1rem, 5vw, 4.25rem) clamp(1.2rem, 3.2vh, 2.8rem) !important;
}

#scene-init.ta-reference-hero .ta-hero-copy {
    width: min(100%, 760px) !important;
    display: grid !important;
    justify-items: center !important;
    text-align: center !important;
}

#scene-init.ta-reference-hero .ta-hero-actions {
    position: relative !important;
    z-index: 8 !important;
    display: grid !important;
    justify-items: center !important;
    gap: 0.62rem !important;
    pointer-events: auto !important;
}

#scene-init.ta-reference-hero #btn_start,
#scene-init.ta-reference-hero .cta-btn-gold,
#scene-init.ta-reference-hero .ta-secondary-link {
    position: relative !important;
    z-index: 9 !important;
    pointer-events: auto !important;
    touch-action: manipulation;
}

#scene-init.ta-reference-hero .ta-reference-bottom {
    position: relative !important;
    z-index: 2 !important;
    pointer-events: none !important;
}

@media (max-width: 767px) {
    #gate-screen.ta-entry-ritual {
        gap: clamp(0.65rem, 2.2vh, 1rem) !important;
    }

    #gate-screen .ta-ritual-plate {
        width: clamp(8.8rem, 46vh, 13.6rem) !important;
        max-width: 68vw !important;
    }

    #gate-screen .ta-ritual-copy h1 {
        font-size: clamp(1.8rem, 9vw, 2.72rem) !important;
        line-height: 1.05 !important;
    }

    #gate-screen .ta-ritual-copy p:not(.ta-ritual-kicker) {
        max-width: 18rem;
        font-size: 0.84rem !important;
        line-height: 1.52 !important;
    }

    #gate-screen .ta-ritual-actions {
        width: min(100%, 20rem) !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0.62rem !important;
    }

    #gate-screen .ta-ritual-actions button {
        width: 100% !important;
        min-height: 2.8rem !important;
    }

    #app-main:has(#scene-init.ta-reference-hero.active) #main-nav {
        top: max(12px, env(safe-area-inset-top)) !important;
        width: calc(100vw - 28px) !important;
        min-height: 56px !important;
        padding: 0 0.5rem 0 0.86rem !important;
        border: 1px solid rgba(218, 191, 138, 0.22) !important;
        border-bottom: 0 !important;
        border-radius: 16px 16px 0 0 !important;
        background: rgba(3, 5, 12, 0.28) !important;
    }

    #app-main:has(#scene-init.ta-reference-hero.active) #main-nav .brand-title {
        max-width: calc(100vw - 112px) !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        font-size: 0.78rem !important;
        letter-spacing: 0.08em !important;
    }

    #scene-init.ta-reference-hero,
    #scene-init.ta-reference-hero.ta-home-hero {
        padding: max(12px, env(safe-area-inset-top)) 14px max(14px, env(safe-area-inset-bottom)) !important;
    }

    #scene-init.ta-reference-hero .ta-reference-frame {
        width: 100% !important;
        height: calc(100dvh - max(26px, calc(env(safe-area-inset-top) + env(safe-area-inset-bottom) + 26px))) !important;
        min-height: 0 !important;
        border-radius: 18px !important;
        grid-template-rows: minmax(0, 1fr) auto !important;
        background:
            linear-gradient(180deg, rgba(5, 7, 17, 0.04), rgba(5, 7, 17, 0.18) 48%, rgba(5, 7, 17, 0.92)),
            url("images/ui/home-reference-hero-v1.webp") center top / auto 63% no-repeat,
            #03050c !important;
    }

    #scene-init.ta-reference-hero .ta-hero-shell {
        justify-content: center !important;
        padding: max(4.45rem, calc(env(safe-area-inset-top) + 4rem)) 1rem 0.7rem !important;
    }

    #scene-init.ta-reference-hero .ta-hero-kicker {
        width: 38px !important;
        height: 38px !important;
        margin-bottom: clamp(0.58rem, 2vh, 0.95rem) !important;
        font-size: 1.55rem !important;
    }

    #scene-init.ta-reference-hero .ta-hero-title {
        max-width: 100% !important;
        font-size: clamp(1.78rem, 8.6vw, 2.75rem) !important;
        line-height: 1.02 !important;
        letter-spacing: 0.075em !important;
        overflow-wrap: normal !important;
        word-break: normal !important;
    }

    #scene-init.ta-reference-hero .ta-hero-subtitle {
        max-width: 18rem !important;
        margin-top: clamp(0.64rem, 2.4vh, 1rem) !important;
        font-size: clamp(0.88rem, 4.1vw, 1.08rem) !important;
        line-height: 1.38 !important;
    }

    #scene-init.ta-reference-hero .ta-hero-actions {
        margin-top: clamp(0.9rem, 3vh, 1.32rem) !important;
    }

    #scene-init.ta-reference-hero .cta-btn-gold {
        width: min(100%, 12.6rem) !important;
        min-width: 0 !important;
        min-height: 2.85rem !important;
        padding: 0 1.2rem 0 2.95rem !important;
        font-size: 1rem !important;
    }

    #scene-init.ta-reference-hero .ta-secondary-link {
        width: auto !important;
        margin-top: 0 !important;
        font-size: 0.9rem !important;
    }

    #scene-init.ta-reference-hero .ta-reference-bottom {
        min-height: auto !important;
        padding: 0.72rem 0.9rem 0.82rem !important;
    }

    #scene-init.ta-reference-hero .ta-ref-feature {
        display: none !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement h2 {
        margin-top: 0.28rem !important;
        font-size: clamp(1.08rem, 5.1vw, 1.48rem) !important;
        line-height: 1.08 !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement p {
        max-width: 17rem !important;
        margin-top: 0.34rem !important;
        font-size: 0.74rem !important;
        line-height: 1.32 !important;
    }
}

@media (max-width: 767px) and (max-height: 700px) {
    #gate-screen .ta-ritual-footnote,
    #scene-init.ta-reference-hero .ta-ref-statement p {
        display: none !important;
    }

    #gate-screen .ta-ritual-plate {
        width: clamp(7.6rem, 34vh, 10.5rem) !important;
    }

    #scene-init.ta-reference-hero .ta-reference-frame {
        grid-template-rows: minmax(0, 1fr) auto !important;
    }

    #scene-init.ta-reference-hero .ta-hero-shell {
        padding-top: 3.75rem !important;
        padding-bottom: 0.35rem !important;
    }

    #scene-init.ta-reference-hero .ta-hero-kicker {
        display: none !important;
    }

    #scene-init.ta-reference-hero .ta-hero-title {
        font-size: clamp(1.52rem, 7.6vw, 2.18rem) !important;
    }

    #scene-init.ta-reference-hero .ta-hero-subtitle {
        margin-top: 0.5rem !important;
        font-size: 0.82rem !important;
    }

    #scene-init.ta-reference-hero .ta-hero-actions {
        margin-top: 0.7rem !important;
    }

    #scene-init.ta-reference-hero .cta-btn-gold {
        min-height: 2.55rem !important;
        font-size: 0.92rem !important;
    }

    #scene-init.ta-reference-hero .ta-reference-bottom {
        padding-block: 0.52rem 0.62rem !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement span {
        font-size: 0.48rem !important;
    }

    #scene-init.ta-reference-hero .ta-ref-statement h2 {
        font-size: 1rem !important;
    }
}

/* 27. Chinese Interface Rhythm v1 */
body[data-lang="zh-TW"] #main-nav a:not(.brand-title),
body[data-lang="zh-TW"] #mobile_menu a,
body[data-lang="zh-TW"] .ta-flow-rail-item strong,
body[data-lang="zh-TW"] .about-section-label,
body[data-lang="zh-TW"] .about-info-card h2,
body[data-lang="zh-TW"] .origins-kicker,
body[data-lang="zh-TW"] .theory-kicker,
body[data-lang="zh-TW"] .theory-toc-title,
body[data-lang="zh-TW"] .theory-stage-label,
body[data-lang="zh-TW"] .spread-board-head,
body[data-lang="zh-TW"] .terms-h2,
body[data-lang="zh-TW"] .policy-h2 {
    letter-spacing: 0.12em !important;
    text-transform: none !important;
}

body[data-lang="zh-TW"] .about-kicker {
    text-transform: none !important;
}

body[data-lang="zh-TW"] #main-nav .hidden.md\:flex {
    text-transform: none !important;
    letter-spacing: 0.12em !important;
}

body[data-lang="zh-TW"] #main-nav .hidden.md\:flex > a:not(.about-start-link) {
    min-width: 2.35em;
    text-align: center;
}

body[data-lang="zh-TW"] .font-cinzel,
body[data-lang="zh-TW"] .policy-h2,
body[data-lang="zh-TW"] .terms-h2 {
    font-family: "Noto Serif TC", "Cormorant Garamond", serif !important;
}

body[data-lang="zh-TW"] #scene-meditation.ta-drawing-flow .ta-flow-content::after {
    content: "牌卡正在等待。\A完成左側步驟後即可開始抽牌。";
}

@media (max-width: 767px) {
    body[data-lang="zh-TW"] #scene-meditation.ta-drawing-flow .ta-flow-content::after {
        content: "牌卡正在等待。\A完成上方步驟後即可開始抽牌。";
    }

    body[data-lang="zh-TW"] #mobile_menu a {
        font-size: clamp(1.45rem, 7vw, 2rem) !important;
    }
}

/* =========================================
   28. Astrolabe Draw Arc v1
   ========================================= */
.ta-draw-stage {
    --draw-frame-top: max(6.05rem, calc(env(safe-area-inset-top) + 5.25rem));
    --draw-frame-bottom: max(1rem, calc(env(safe-area-inset-bottom) + 0.8rem));
    --draw-gold: #d8ad5d;
    --draw-gold-soft: rgba(216, 173, 93, 0.68);
    --draw-cyan: rgba(120, 206, 210, 0.34);
    isolation: isolate;
    background:
        radial-gradient(circle at 50% 34%, rgba(216, 173, 93, 0.11), transparent 24rem),
        linear-gradient(180deg, rgba(3, 5, 14, 0.36), rgba(3, 5, 14, 0.78)),
        url("images/ui/draw-stage-v2.webp") center / cover no-repeat !important;
}

.ta-draw-stage::before {
    content: "" !important;
    position: absolute !important;
    inset: var(--draw-frame-top) clamp(0.85rem, 2.8vw, 2.25rem) var(--draw-frame-bottom) !important;
    border: 1px solid rgba(216, 173, 93, 0.22) !important;
    border-radius: 18px !important;
    pointer-events: none !important;
    z-index: 1 !important;
    background:
        radial-gradient(circle at 50% 33%, rgba(216, 173, 93, 0.12), transparent 15rem),
        radial-gradient(circle at 50% 88%, rgba(120, 206, 210, 0.08), transparent 22rem),
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.006)) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.06),
        inset 0 -9rem 12rem rgba(0,0,0,0.32),
        0 1.5rem 5rem rgba(0,0,0,0.28) !important;
}

.ta-draw-stage::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    bottom: max(-6.6rem, calc(env(safe-area-inset-bottom) - 7.2rem)) !important;
    width: min(70rem, 105vw) !important;
    height: min(35rem, 52vw) !important;
    transform: translateX(-50%) !important;
    border: 1px solid rgba(216, 173, 93, 0.24) !important;
    border-bottom: 0 !important;
    border-radius: 50% 50% 0 0 / 100% 100% 0 0 !important;
    pointer-events: none !important;
    z-index: 2 !important;
    background:
        repeating-radial-gradient(ellipse at 50% 100%, transparent 0 3.15rem, rgba(216, 173, 93, 0.11) 3.22rem 3.28rem),
        conic-gradient(from 270deg at 50% 100%, transparent 0deg, rgba(216, 173, 93, 0.22) 35deg, transparent 72deg, transparent 288deg, rgba(216, 173, 93, 0.22) 325deg, transparent 360deg) !important;
    opacity: 0.86 !important;
    filter: drop-shadow(0 -1.4rem 2.6rem rgba(216, 173, 93, 0.08));
}

.ta-draw-stage #card-stream-track {
    inset: 0 !important;
    z-index: 4 !important;
    cursor: grab;
    touch-action: none;
    filter: drop-shadow(0 1.25rem 2.4rem rgba(0,0,0,0.46));
}

.ta-draw-stage #card-stream-track.is-dragging {
    cursor: grabbing;
}

.ta-draw-stage-copy {
    position: absolute;
    top: max(7.15rem, calc(env(safe-area-inset-top) + 6.3rem));
    left: clamp(1.35rem, 5vw, 5.5rem);
    z-index: 8;
    display: grid;
    gap: 0.32rem;
    max-width: min(27rem, 48vw);
    pointer-events: none;
    text-shadow: 0 0.75rem 1.9rem rgba(0,0,0,0.66);
}

.ta-draw-stage-copy span {
    color: var(--draw-gold);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.18em;
}

.ta-draw-stage-copy strong {
    color: rgba(255, 247, 226, 0.96);
    font-family: "Noto Serif TC", "Cormorant Garamond", serif;
    font-size: clamp(1.42rem, 2.4vw, 2.35rem);
    font-weight: 600;
    line-height: 1.16;
    letter-spacing: 0.04em;
}

.ta-draw-stage-copy small {
    max-width: 22rem;
    color: rgba(226, 232, 240, 0.76);
    font-size: clamp(0.82rem, 1.2vw, 0.98rem);
    line-height: 1.7;
    letter-spacing: 0.04em;
}

.ta-draw-aperture {
    position: absolute;
    top: clamp(20rem, 42vh, 26.25rem);
    left: 50%;
    z-index: 7;
    width: clamp(7.5rem, 15vw, 12rem);
    aspect-ratio: 1;
    transform: translate(-50%, -50%);
    border: 1px solid rgba(216, 173, 93, 0.2);
    border-radius: 50%;
    pointer-events: none;
    background:
        radial-gradient(circle, rgba(216, 173, 93, 0.11), transparent 40%),
        conic-gradient(from 0deg, transparent, rgba(216, 173, 93, 0.18), transparent 24%, transparent 76%, rgba(120, 206, 210, 0.15), transparent);
    box-shadow:
        inset 0 0 2rem rgba(216, 173, 93, 0.12),
        0 0 3.2rem rgba(216, 173, 93, 0.13);
}

.ta-draw-aperture::before,
.ta-draw-aperture::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(180deg, transparent, rgba(216, 173, 93, 0.86), transparent);
}

.ta-draw-aperture::before {
    top: -2.7rem;
    width: 1px;
    height: 2.25rem;
}

.ta-draw-aperture::after {
    bottom: -2.7rem;
    width: 1px;
    height: 2.25rem;
}

.ta-draw-aperture span {
    position: absolute;
    inset: 50% auto auto 50%;
    width: 0.72rem;
    aspect-ratio: 1;
    transform: translate(-50%, -50%) rotate(45deg);
    border: 1px solid rgba(255, 224, 153, 0.78);
    background: rgba(216, 173, 93, 0.18);
    box-shadow: 0 0 1.6rem rgba(216, 173, 93, 0.42);
}

.ta-draw-rotate-controls {
    position: absolute;
    top: clamp(19.5rem, 42vh, 25.7rem);
    left: 50%;
    z-index: 11;
    width: min(32rem, calc(100vw - 2rem));
    transform: translate(-50%, -50%);
    display: flex;
    justify-content: space-between;
    pointer-events: none;
}

.ta-draw-rotate {
    pointer-events: auto;
    display: grid;
    place-items: center;
    width: 3.05rem;
    aspect-ratio: 1;
    border: 1px solid rgba(216, 173, 93, 0.28);
    border-radius: 50%;
    color: rgba(255, 231, 174, 0.92);
    background:
        linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02)),
        rgba(4, 7, 18, 0.78);
    box-shadow: 0 0.9rem 2.2rem rgba(0,0,0,0.34), inset 0 1px 0 rgba(255,255,255,0.07);
    font-family: "Cormorant Garamond", "Noto Serif TC", serif;
    font-size: 2.15rem;
    line-height: 1;
    transition: border-color 160ms ease, color 160ms ease, transform 160ms ease, background 160ms ease;
}

.ta-draw-rotate:hover,
.ta-draw-rotate:focus-visible {
    border-color: rgba(255, 224, 153, 0.68);
    color: rgba(255, 247, 226, 1);
    background:
        linear-gradient(180deg, rgba(216,173,93,0.16), rgba(255,255,255,0.03)),
        rgba(4, 7, 18, 0.86);
    transform: translateY(-1px);
}

.ta-draw-stage #draw-prompt {
    top: max(7.1rem, calc(env(safe-area-inset-top) + 6.25rem)) !important;
    right: clamp(1.35rem, 5vw, 5.5rem) !important;
    left: auto !important;
    transform: none !important;
    z-index: 10 !important;
    width: auto;
    min-width: 8.4rem;
    padding: 0.62rem 0.95rem !important;
    border: 1px solid rgba(216,173,93,0.28) !important;
    border-radius: 999px !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02)),
        rgba(4, 7, 18, 0.78) !important;
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.07),
        0 1rem 3rem rgba(0,0,0,0.38) !important;
}

.ta-draw-stage #draw-prompt p {
    margin-bottom: 0.1rem !important;
    color: rgba(216, 173, 93, 0.86) !important;
    font-size: 0.62rem !important;
    letter-spacing: 0.15em !important;
    text-transform: none !important;
}

.ta-draw-stage #count-drawn {
    font-size: clamp(1.8rem, 3vw, 2.55rem) !important;
    color: rgba(255, 247, 226, 0.98) !important;
}

.ta-draw-stage #count-total {
    font-size: clamp(1.05rem, 1.5vw, 1.35rem) !important;
}

.ta-draw-slots {
    position: absolute;
    left: 50%;
    bottom: max(1.35rem, calc(env(safe-area-inset-bottom) + 1rem));
    z-index: 9;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.55rem;
    width: min(68rem, calc(100vw - 3rem));
    transform: translateX(-50%);
    pointer-events: none;
}

.ta-draw-slots.is-single {
    justify-content: center;
}

.ta-draw-slot {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.55rem;
    min-width: min(13rem, 22vw);
    max-width: 16rem;
    padding: 0.58rem 0.72rem;
    border: 1px solid rgba(216, 173, 93, 0.18);
    border-radius: 0.82rem;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.018)),
        rgba(4, 7, 18, 0.72);
    box-shadow: 0 0.9rem 2rem rgba(0,0,0,0.28);
    transition: border-color 180ms ease, background 180ms ease, transform 180ms ease;
}

.ta-draw-slot-index,
.ta-draw-slot-status {
    color: rgba(216, 173, 93, 0.86);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    white-space: nowrap;
}

.ta-draw-slot-label {
    overflow: hidden;
    color: rgba(226, 232, 240, 0.82);
    font-size: 0.82rem;
    line-height: 1.25;
    letter-spacing: 0.04em;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ta-draw-slot.is-current {
    border-color: rgba(216, 173, 93, 0.48);
    background:
        linear-gradient(180deg, rgba(216,173,93,0.13), rgba(216,173,93,0.035)),
        rgba(4, 7, 18, 0.78);
    transform: translateY(-0.12rem);
}

.ta-draw-slot.is-filled {
    border-color: rgba(120, 206, 210, 0.32);
    background:
        linear-gradient(180deg, rgba(120,206,210,0.12), rgba(255,255,255,0.02)),
        rgba(4, 7, 18, 0.72);
}

.ta-draw-slot.is-filled .ta-draw-slot-status {
    color: rgba(138, 230, 208, 0.88);
}

.ta-draw-stage .stream-card {
    appearance: none;
    padding: 0;
    border: 0;
    border-radius: 10px;
    outline: 1px solid rgba(216, 173, 93, 0.28);
    outline-offset: -1px;
    transform-origin: 50% 100%;
    transition: filter 180ms ease, opacity 180ms ease, box-shadow 180ms ease, outline-color 180ms ease;
    box-shadow:
        0 1.2rem 2.4rem rgba(0,0,0,0.54),
        0 0 0 1px rgba(255,255,255,0.04);
}

.ta-draw-stage .stream-card.near-focus {
    filter: brightness(1.08) saturate(1.04);
}

.ta-draw-stage .stream-card.is-focus {
    outline-color: rgba(255, 224, 153, 0.82);
    filter: brightness(1.2) saturate(1.08);
    box-shadow:
        0 1.6rem 3.4rem rgba(0,0,0,0.58),
        0 0 2rem rgba(216,173,93,0.42),
        0 0 0 1px rgba(255,239,196,0.28);
}

.ta-draw-stage .stream-card.is-picked {
    opacity: 0 !important;
    transform: scale(0.7) !important;
}

@media (max-width: 1023px) {
    .ta-draw-stage-copy {
        max-width: min(26rem, 55vw);
    }

    .ta-draw-slot {
        min-width: min(12rem, 30vw);
    }
}

@media (max-width: 767px) {
    .ta-draw-stage {
        --draw-frame-top: max(5.35rem, calc(env(safe-area-inset-top) + 4.8rem));
        --draw-frame-bottom: max(0.55rem, calc(env(safe-area-inset-bottom) + 0.45rem));
        background:
            radial-gradient(circle at 50% 42%, rgba(216, 173, 93, 0.1), transparent 17rem),
            linear-gradient(180deg, rgba(3, 5, 14, 0.26), rgba(3, 5, 14, 0.86)),
            url("images/ui/draw-stage-v2.webp") center / auto 100% no-repeat !important;
    }

    .ta-draw-stage::before {
        inset: var(--draw-frame-top) 0.62rem var(--draw-frame-bottom) !important;
        border-radius: 12px !important;
    }

    .ta-draw-stage::after {
        bottom: max(-3.2rem, calc(env(safe-area-inset-bottom) - 3.8rem)) !important;
        width: 126vw !important;
        height: 58vw !important;
    }

    .ta-draw-stage-copy {
        top: max(5.95rem, calc(env(safe-area-inset-top) + 5.25rem));
        left: 1rem;
        max-width: 6rem;
        gap: 0.2rem;
    }

    .ta-draw-stage-copy::after {
        content: "拖曳牌弧";
        color: rgba(226, 232, 240, 0.78);
        font-size: 0.72rem;
        line-height: 1.35;
        letter-spacing: 0.08em;
    }

    .ta-draw-stage-copy span {
        font-size: 0.58rem;
        letter-spacing: 0.14em;
    }

    .ta-draw-stage-copy strong {
        display: none;
    }

    .ta-draw-stage-copy small {
        display: none;
    }

    .ta-draw-stage #draw-prompt {
        top: max(5.75rem, calc(env(safe-area-inset-top) + 5rem)) !important;
        right: 0.85rem !important;
        min-width: 4.75rem;
        width: 4.75rem;
        padding: 0.42rem 0.5rem !important;
    }

    .ta-draw-stage #draw-prompt p {
        display: none;
    }

    .ta-draw-stage #draw-prompt .flex {
        gap: 0.18rem !important;
    }

    .ta-draw-stage #count-drawn {
        font-size: 1.5rem !important;
    }

    .ta-draw-stage #count-total {
        font-size: 0.92rem !important;
    }

    .ta-draw-aperture {
        top: clamp(15rem, 40vh, 19.4rem);
        width: clamp(5.7rem, 25vw, 7rem);
    }

    .ta-draw-rotate-controls {
        top: clamp(15rem, 40vh, 19.4rem);
        width: calc(100vw - 1.8rem);
    }

    .ta-draw-rotate {
        width: 2.6rem;
        font-size: 1.75rem;
        background:
            linear-gradient(180deg, rgba(255,255,255,0.065), rgba(255,255,255,0.018)),
            rgba(4, 7, 18, 0.68);
    }

    .ta-draw-aperture::before {
        top: -1.8rem;
        height: 1.45rem;
    }

    .ta-draw-aperture::after {
        bottom: -1.8rem;
        height: 1.45rem;
    }

    .ta-draw-slots {
        bottom: max(0.9rem, calc(env(safe-area-inset-bottom) + 0.7rem));
        gap: 0.4rem;
        width: calc(100vw - 1.2rem);
        flex-wrap: nowrap;
        justify-content: flex-start;
        overflow-x: auto;
        padding: 0.1rem 0.2rem 0.25rem;
        pointer-events: auto;
        scrollbar-width: none;
    }

    .ta-draw-slots::-webkit-scrollbar {
        display: none;
    }

    .ta-draw-slots.is-single {
        justify-content: center;
        overflow: hidden;
        pointer-events: none;
    }

    .ta-draw-slot {
        grid-template-columns: auto minmax(0, 1fr);
        flex: 0 0 min(9.5rem, 45vw);
        min-width: min(9.5rem, 45vw);
        max-width: min(9.5rem, 45vw);
        padding: 0.48rem 0.5rem;
        border-radius: 0.68rem;
        scroll-snap-align: center;
    }

    .ta-draw-slots.is-single .ta-draw-slot {
        flex-basis: min(10rem, 64vw);
        min-width: min(10rem, 64vw);
        max-width: min(10rem, 64vw);
    }

    .ta-draw-slot-status {
        display: none;
    }

    .ta-draw-slot-index {
        font-size: 0.58rem;
    }

    .ta-draw-slot-label {
        font-size: 0.72rem;
    }
}

@media (max-width: 390px) {
    .ta-draw-stage-copy {
        max-width: 5.5rem;
    }

    .ta-draw-slot {
        flex-basis: min(8.8rem, 46vw);
        min-width: min(8.8rem, 46vw);
        max-width: min(8.8rem, 46vw);
    }
}

@media (prefers-reduced-motion: reduce) {
    .ta-draw-stage .stream-card,
    .ta-draw-slot {
        transition: none !important;
    }
}

/* 30. Full Deck Atlas Draw Interface */
#scene-draw.ta-draw-stage {
    --atlas-top: clamp(9.4rem, 16vh, 12.4rem);
    --atlas-bottom: max(6.8rem, calc(env(safe-area-inset-bottom) + 5.8rem));
    touch-action: pan-y !important;
}

.ta-draw-stage #card-stream-track.ta-deck-atlas-track {
    position: absolute !important;
    inset: var(--atlas-top) clamp(1.1rem, 4vw, 4.5rem) var(--atlas-bottom) !important;
    z-index: 5 !important;
    display: grid !important;
    grid-template-columns: repeat(13, auto);
    align-content: center;
    justify-content: center;
    gap: clamp(0.28rem, min(0.58vw, 0.72vh), 0.62rem);
    padding: clamp(0.65rem, 1.6vw, 1.35rem);
    overflow: hidden;
    border: 1px solid rgba(216, 173, 93, 0.18);
    border-radius: 18px;
    background:
        radial-gradient(circle at 50% 48%, rgba(216, 173, 93, 0.12), transparent 19rem),
        linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.012)),
        rgba(3, 6, 16, 0.58);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.055),
        inset 0 -5rem 8rem rgba(0,0,0,0.24),
        0 1.4rem 4rem rgba(0,0,0,0.28);
    cursor: default;
    filter: none !important;
    touch-action: pan-y !important;
}

.ta-draw-stage #card-stream-track.ta-deck-atlas-track:focus-visible {
    outline: 1px solid rgba(255, 224, 153, 0.5);
    outline-offset: 4px;
}

.ta-draw-stage .stream-card.deck-atlas-card {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: clamp(2.05rem, min(4.35vw, 6.1vh), 4.75rem) !important;
    height: auto !important;
    aspect-ratio: 70 / 120;
    display: grid;
    place-items: end center;
    padding: 0 !important;
    overflow: hidden;
    border: 1px solid rgba(216, 173, 93, 0.2) !important;
    border-radius: clamp(0.3rem, 0.75vw, 0.62rem) !important;
    outline: 0 !important;
    background-size: cover !important;
    background-position: center !important;
    box-shadow:
        0 0.75rem 1.4rem rgba(0,0,0,0.42),
        0 0 0 1px rgba(255,255,255,0.035);
    cursor: pointer;
    opacity: 0.78 !important;
    pointer-events: auto !important;
    transform: translateZ(0) !important;
    transform-origin: center !important;
    transition:
        transform 150ms ease,
        opacity 150ms ease,
        filter 150ms ease,
        border-color 150ms ease,
        box-shadow 150ms ease !important;
    will-change: auto !important;
}

.ta-draw-stage .stream-card.deck-atlas-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 50% 38%, transparent 0 34%, rgba(255,255,255,0.05) 56%, transparent 72%),
        linear-gradient(180deg, rgba(255,255,255,0.08), transparent 42%, rgba(0,0,0,0.18));
    opacity: 0.55;
    pointer-events: none;
}

.deck-card-number {
    position: absolute;
    top: 0.26rem;
    left: 0.3rem;
    color: rgba(244, 213, 139, 0.62);
    font-size: clamp(0.46rem, 0.72vw, 0.64rem);
    font-weight: 700;
    letter-spacing: 0.04em;
    text-shadow: 0 0.35rem 0.75rem rgba(0,0,0,0.7);
}

.stream-card-focus-label {
    position: relative;
    z-index: 1;
    width: 100%;
    padding: 0.24rem 0.12rem 0.28rem;
    color: rgba(21, 17, 11, 0.96);
    background: linear-gradient(135deg, #f7dfa0, #c99b45);
    font-size: clamp(0.48rem, 0.72vw, 0.68rem);
    font-weight: 800;
    letter-spacing: 0.12em;
    text-align: center;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 150ms ease, transform 150ms ease;
}

.ta-draw-stage .stream-card.deck-atlas-card:hover,
.ta-draw-stage .stream-card.deck-atlas-card:focus-visible {
    opacity: 0.92 !important;
    filter: brightness(1.08) saturate(1.05);
}

.ta-draw-stage .stream-card.deck-atlas-card.is-focus {
    z-index: 30 !important;
    border-color: rgba(255, 224, 153, 0.9) !important;
    opacity: 1 !important;
    filter: brightness(1.22) saturate(1.12);
    transform: translateY(-0.32rem) scale(1.18) translateZ(0) !important;
    box-shadow:
        0 1.2rem 2.4rem rgba(0,0,0,0.56),
        0 0 2.3rem rgba(216,173,93,0.42),
        0 0 0 1px rgba(255,239,196,0.34);
}

.ta-draw-stage .stream-card.deck-atlas-card.is-focus .stream-card-focus-label {
    opacity: 1;
    transform: translateY(0);
}

.ta-draw-stage .stream-card.deck-atlas-card.is-picked {
    opacity: 0.22 !important;
    filter: saturate(0.25) brightness(0.72);
    pointer-events: none !important;
    transform: scale(0.92) translateZ(0) !important;
}

.ta-draw-stage .stream-card.deck-atlas-card.is-picked::after {
    content: "✓";
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: rgba(138, 230, 208, 0.9);
    background: rgba(2, 6, 14, 0.35);
    font-size: clamp(1rem, 2vw, 1.55rem);
    font-weight: 700;
}

.ta-draw-stage .ta-draw-aperture {
    top: calc(var(--atlas-top) + ((100dvh - var(--atlas-top) - var(--atlas-bottom)) / 2)) !important;
    width: clamp(8rem, 16vw, 13rem) !important;
    opacity: 0.5;
    z-index: 4;
}

.ta-draw-focus-hint {
    position: absolute;
    top: max(7.05rem, calc(env(safe-area-inset-top) + 6.15rem));
    left: 50%;
    z-index: 13;
    min-width: min(16rem, 54vw);
    display: grid;
    gap: 0.08rem;
    padding: 0.56rem 1.1rem 0.62rem 3.15rem;
    transform: translateX(-50%);
    border: 1px solid rgba(216, 173, 93, 0.28);
    border-radius: 999px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.018)),
        rgba(4, 7, 18, 0.82);
    box-shadow:
        inset 0 1px 0 rgba(255,255,255,0.07),
        0 1rem 3rem rgba(0,0,0,0.34);
    pointer-events: none;
}

.ta-draw-focus-hint::before {
    content: attr(data-focus-index);
    position: absolute;
    top: 50%;
    left: 0.62rem;
    width: 2.08rem;
    aspect-ratio: 1;
    display: grid;
    place-items: center;
    transform: translateY(-50%);
    border: 1px solid rgba(255, 224, 153, 0.48);
    border-radius: 50%;
    color: rgba(255, 239, 196, 0.94);
    background: rgba(216, 173, 93, 0.12);
    font-size: 0.68rem;
    font-weight: 800;
}

.ta-draw-focus-hint span {
    color: rgba(216, 173, 93, 0.86);
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.14em;
}

.ta-draw-focus-hint strong {
    color: rgba(255, 247, 226, 0.98);
    font-family: "Noto Serif TC", "Cormorant Garamond", serif;
    font-size: clamp(0.95rem, 1.25vw, 1.18rem);
    line-height: 1.12;
    letter-spacing: 0.04em;
}

.ta-draw-focus-hint small {
    color: rgba(226, 232, 240, 0.68);
    font-size: 0.68rem;
    line-height: 1.2;
    letter-spacing: 0.04em;
}

.ta-draw-stage .ta-draw-rotate-controls {
    top: max(7.95rem, calc(env(safe-area-inset-top) + 7rem)) !important;
    width: min(28rem, calc(100vw - 2rem)) !important;
    z-index: 14;
}

.ta-draw-stage .ta-draw-rotate {
    width: 2.55rem;
}

@media (max-width: 767px) {
    #scene-draw.ta-draw-stage {
        --atlas-top: max(10.15rem, calc(env(safe-area-inset-top) + 9.4rem));
        --atlas-bottom: max(8.25rem, calc(env(safe-area-inset-bottom) + 7.35rem));
    }

    .ta-draw-stage #card-stream-track.ta-deck-atlas-track {
        inset: var(--atlas-top) 0.72rem var(--atlas-bottom) !important;
        grid-template-columns: repeat(6, minmax(0, 1fr));
        align-content: start;
        justify-content: stretch;
        gap: 0.42rem;
        padding: 0.72rem;
        overflow-y: auto;
        overscroll-behavior: contain;
        scrollbar-width: none;
    }

    .ta-draw-stage #card-stream-track.ta-deck-atlas-track::-webkit-scrollbar {
        display: none;
    }

    .ta-draw-stage .stream-card.deck-atlas-card {
        justify-self: center;
        width: min(100%, 3.28rem) !important;
        border-radius: 0.42rem !important;
    }

    .deck-card-number {
        font-size: 0.48rem;
    }

    .stream-card-focus-label {
        padding-block: 0.18rem 0.2rem;
        font-size: 0.48rem;
        letter-spacing: 0.06em;
    }

    .ta-draw-stage .stream-card.deck-atlas-card.is-focus {
        transform: translateY(-0.22rem) scale(1.12) translateZ(0) !important;
    }

    .ta-draw-focus-hint {
        top: max(5.7rem, calc(env(safe-area-inset-top) + 5rem));
        min-width: min(12.1rem, 54vw);
        padding: 0.48rem 0.75rem 0.52rem 2.72rem;
    }

    .ta-draw-focus-hint::before {
        left: 0.5rem;
        width: 1.72rem;
        font-size: 0.58rem;
    }

    .ta-draw-focus-hint span {
        font-size: 0.54rem;
    }

    .ta-draw-focus-hint strong {
        font-size: 0.86rem;
    }

    .ta-draw-focus-hint small {
        display: none;
    }

    .ta-draw-stage-copy::after {
        content: "全牌星圖";
    }

    .ta-draw-stage .ta-draw-aperture {
        display: none;
    }

    .ta-draw-stage .ta-draw-rotate-controls {
        top: auto !important;
        bottom: max(4.7rem, calc(env(safe-area-inset-bottom) + 3.95rem)) !important;
        width: calc(100vw - 1.45rem) !important;
    }
}

/* 29. Shared Mobile Menu Reliability */
#mobile_menu.hidden {
    display: none !important;
}

#mobile_menu.is-open {
    display: flex !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

#mobile_menu:not(.is-open) {
    pointer-events: none;
}

body.menu-open {
    overflow: hidden !important;
}

@media (min-width: 768px) {
    #main-nav #menu_btn,
    #main-nav #mobile-menu-btn {
        display: none !important;
    }
}

@media (max-width: 767px) {
    #main-nav #menu_btn,
    #main-nav #mobile-menu-btn {
        display: inline-flex !important;
    }
}

/* 31. Focus Magnifier Fan Draw Interface */
#scene-draw.ta-draw-stage {
    --fan-top: clamp(12.6rem, 23vh, 16.4rem);
    --fan-bottom: max(6.2rem, calc(env(safe-area-inset-bottom) + 5.25rem));
    --fan-gold: #d8ad5d;
    --fan-gold-hot: #ffe7a6;
    --fan-ink: rgba(3, 6, 16, 0.82);
    touch-action: none !important;
}

.ta-draw-stage #card-stream-track.ta-draw-fan-track {
    position: absolute !important;
    inset: var(--fan-top) clamp(0.6rem, 2.2vw, 2.6rem) var(--fan-bottom) !important;
    z-index: 6 !important;
    overflow: hidden;
    border: 0;
    border-radius: 18px;
    background:
        radial-gradient(ellipse at 50% 38%, rgba(255, 231, 174, 0.1), transparent 18rem),
        radial-gradient(ellipse at 50% 88%, rgba(120, 206, 210, 0.06), transparent 24rem);
    cursor: grab;
    filter: none !important;
    touch-action: none !important;
    user-select: none;
}

.ta-draw-stage #card-stream-track.ta-draw-fan-track::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: clamp(-5.2rem, -9vw, -2.8rem);
    width: min(76rem, 116vw);
    height: min(34rem, 43vw);
    transform: translateX(-50%);
    border: 1px solid rgba(216, 173, 93, 0.18);
    border-bottom: 0;
    border-radius: 50% 50% 0 0 / 100% 100% 0 0;
    background:
        repeating-radial-gradient(ellipse at 50% 100%, transparent 0 3.1rem, rgba(216, 173, 93, 0.095) 3.16rem 3.22rem),
        linear-gradient(180deg, transparent, rgba(216, 173, 93, 0.05));
    opacity: 0.92;
    pointer-events: none;
}

.ta-draw-stage #card-stream-track.ta-draw-fan-track::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0.72rem;
    width: min(26rem, 68vw);
    height: 2px;
    transform: translateX(-50%);
    border-radius: 999px;
    background:
        linear-gradient(90deg, rgba(255, 231, 174, 0.78) 0 var(--focus-progress), rgba(216, 173, 93, 0.15) var(--focus-progress) 100%);
    box-shadow: 0 0 1.1rem rgba(216, 173, 93, 0.24);
    pointer-events: none;
}

.ta-draw-stage #card-stream-track.ta-draw-fan-track:focus-visible {
    outline: 1px solid rgba(255, 224, 153, 0.48);
    outline-offset: 4px;
}

.ta-draw-stage #card-stream-track.ta-draw-fan-track.is-dragging {
    cursor: grabbing;
}

.ta-draw-stage .stream-card.deck-fan-card {
    --drag-x: 0px;
    --drag-y: 0px;
    --drag-progress: 0;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: var(--card-w, 3.2rem) !important;
    height: auto !important;
    aspect-ratio: 70 / 120;
    display: grid;
    place-items: end center;
    overflow: hidden;
    padding: 0 !important;
    border: 1px solid rgba(216, 173, 93, 0.16) !important;
    border-radius: clamp(0.32rem, 0.72vw, 0.58rem) !important;
    outline: 0 !important;
    background-size: cover !important;
    background-position: center !important;
    opacity: 0.48 !important;
    filter: brightness(0.68) saturate(0.58) contrast(0.82);
    cursor: grab;
    pointer-events: auto !important;
    transform:
        translate3d(calc(var(--card-x, 0px) + var(--drag-x)), calc(var(--card-y, 0px) + var(--drag-y)), 0)
        rotate(var(--card-rotate, 0deg))
        scale(var(--card-scale, 1)) !important;
    transform-origin: 50% 88%;
    box-shadow:
        0 0.72rem 1.25rem rgba(0,0,0,0.38),
        0 0 0 1px rgba(255,255,255,0.025);
    transition:
        transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1),
        opacity 180ms ease,
        filter 180ms ease,
        border-color 180ms ease,
        box-shadow 180ms ease !important;
    will-change: transform;
}

.ta-draw-stage .stream-card.deck-fan-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), transparent 40%, rgba(0,0,0,0.34)),
        rgba(2, 6, 14, 0.22);
    opacity: 0.92;
    pointer-events: none;
    transition: opacity 180ms ease, background 180ms ease;
}

.ta-draw-stage .stream-card.deck-fan-card:hover,
.ta-draw-stage .stream-card.deck-fan-card:focus-visible {
    opacity: 0.72 !important;
    filter: brightness(0.86) saturate(0.72) contrast(0.92);
}

.ta-draw-stage .stream-card.deck-fan-card.is-soft-focus {
    opacity: 0.62 !important;
    filter: brightness(0.78) saturate(0.66) contrast(0.88);
}

.ta-draw-stage .stream-card.deck-fan-card.is-near-focus {
    opacity: 0.82 !important;
    filter: brightness(0.96) saturate(0.82) contrast(0.98);
}

.ta-draw-stage .stream-card.deck-fan-card.is-focus {
    border-color: rgba(255, 231, 174, 0.92) !important;
    opacity: 1 !important;
    filter: brightness(1.24) saturate(1.08) contrast(1.04);
    cursor: grab;
    box-shadow:
        0 1.35rem 2.9rem rgba(0,0,0,0.58),
        0 0 2.3rem rgba(216,173,93,0.48),
        0 0 0 1px rgba(255,239,196,0.32);
}

.ta-draw-stage .stream-card.deck-fan-card.is-focus::before {
    opacity: 0.24;
    background:
        radial-gradient(circle at 50% 34%, rgba(255, 231, 174, 0.16), transparent 48%),
        linear-gradient(180deg, rgba(255,255,255,0.1), transparent 48%, rgba(0,0,0,0.16));
}

.ta-draw-stage #card-stream-track.ta-draw-fan-track.is-dragging .stream-card.deck-fan-card:not(.is-focus) {
    opacity: 0.28 !important;
    filter: brightness(0.48) saturate(0.42) contrast(0.76);
}

.ta-draw-stage .stream-card.deck-fan-card.is-dragging-out {
    cursor: grabbing;
    transition: none !important;
    filter:
        brightness(calc(1.08 + (var(--drag-progress) * 0.28)))
        saturate(1.08)
        contrast(1.04);
    box-shadow:
        0 1.7rem 3.4rem rgba(0,0,0,0.62),
        0 0 calc(1.4rem + (var(--drag-progress) * 1.8rem)) rgba(255, 231, 174, 0.52),
        0 0 0 1px rgba(255,239,196,0.38);
}

.ta-draw-stage .stream-card.deck-fan-card.is-dragging-out::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 100%;
    width: 1px;
    height: calc(2rem + (var(--drag-progress) * 4.5rem));
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(255, 231, 174, 0.82), transparent);
    opacity: 0.78;
    pointer-events: none;
}

.ta-draw-stage .stream-card.deck-fan-card.is-confirming-draw {
    opacity: 0.12 !important;
    filter: brightness(1.5) saturate(1.2);
    transform:
        translate3d(calc(var(--card-x, 0px) + var(--drag-x)), calc(var(--card-y, 0px) + var(--drag-y, -8rem)), 0)
        rotate(0deg)
        scale(1.08) !important;
}

.ta-draw-stage .stream-card.deck-fan-card.is-picked {
    opacity: 0.16 !important;
    filter: brightness(0.45) saturate(0.2) contrast(0.72);
    pointer-events: none !important;
    box-shadow: none;
}

.ta-draw-stage .stream-card.deck-fan-card.is-picked::after {
    content: "\2713";
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: rgba(138, 230, 208, 0.9);
    background: rgba(2, 6, 14, 0.52);
    font-size: clamp(1rem, 2vw, 1.55rem);
    font-weight: 700;
}

.ta-draw-stage .stream-card.deck-fan-card.is-out-of-range {
    opacity: 0 !important;
}

.ta-draw-stage .stream-card.deck-fan-card .deck-card-number {
    z-index: 1;
    color: rgba(244, 213, 139, 0.38);
    text-shadow: 0 0.35rem 0.75rem rgba(0,0,0,0.82);
}

.ta-draw-stage .stream-card.deck-fan-card.is-focus .deck-card-number,
.ta-draw-stage .stream-card.deck-fan-card.is-near-focus .deck-card-number {
    color: rgba(255, 231, 174, 0.82);
}

.ta-draw-stage .stream-card.deck-fan-card .stream-card-focus-label {
    z-index: 2;
    color: rgba(23, 17, 8, 0.98);
    background: linear-gradient(135deg, #ffe7a6, #c7953f);
    letter-spacing: 0.16em;
}

.ta-draw-stage .stream-card.deck-fan-card.is-focus .stream-card-focus-label {
    opacity: 1;
    transform: translateY(0);
}

.ta-draw-stage .ta-draw-aperture {
    top: clamp(15rem, 35vh, 20.6rem) !important;
    width: clamp(6.4rem, 10vw, 8.6rem) !important;
    z-index: 12 !important;
    opacity: 1 !important;
    display: grid !important;
    place-items: center;
    border-color: rgba(216, 173, 93, 0.34);
    background:
        radial-gradient(circle, rgba(216, 173, 93, 0.18), transparent 45%),
        conic-gradient(from 0deg, transparent, rgba(216, 173, 93, 0.22), transparent 24%, transparent 76%, rgba(120, 206, 210, 0.18), transparent);
    box-shadow:
        inset 0 0 2.1rem rgba(216, 173, 93, 0.15),
        0 0 3.2rem rgba(216, 173, 93, 0.18);
    transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.ta-draw-stage .ta-draw-aperture.is-draw-target {
    border-color: rgba(255, 231, 174, 0.56);
    box-shadow:
        inset 0 0 2.6rem rgba(216, 173, 93, 0.22),
        0 0 4rem rgba(216, 173, 93, 0.26);
}

.ta-draw-stage .ta-draw-aperture.is-ready-to-draw {
    transform: translate(-50%, -50%) scale(1.04);
    border-color: rgba(255, 231, 174, 0.9);
    box-shadow:
        inset 0 0 2.9rem rgba(255, 231, 174, 0.28),
        0 0 4.8rem rgba(255, 231, 174, 0.36);
}

.ta-focus-preview-card {
    position: relative;
    z-index: 2;
    width: clamp(2.55rem, 4.4vw, 3.65rem);
    aspect-ratio: 70 / 120;
    border: 1px solid rgba(255, 231, 174, 0.7);
    border-radius: 0.46rem;
    background-size: cover;
    background-position: center;
    box-shadow:
        0 0.95rem 2rem rgba(0,0,0,0.46),
        0 0 1.8rem rgba(216, 173, 93, 0.38);
}

.ta-focus-preview-card::after {
    content: attr(data-card-number);
    position: absolute;
    left: 50%;
    bottom: -1.25rem;
    transform: translateX(-50%);
    color: rgba(255, 231, 174, 0.86);
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-shadow: 0 0.6rem 1.1rem rgba(0,0,0,0.8);
}

.ta-draw-stage .ta-draw-aperture > span {
    display: none;
}

.ta-draw-stage-copy {
    top: max(7.05rem, calc(env(safe-area-inset-top) + 6.1rem)) !important;
    left: 50% !important;
    max-width: min(36rem, 62vw) !important;
    transform: translateX(-50%);
    text-align: center;
}

.ta-draw-stage-copy span {
    color: rgba(216, 173, 93, 0.86);
}

.ta-draw-stage-copy strong {
    font-size: clamp(1.36rem, 2vw, 2.05rem);
}

.ta-draw-stage-copy small {
    max-width: none;
}

.ta-draw-focus-hint {
    top: clamp(20.6rem, 45vh, 25.6rem) !important;
    min-width: min(18rem, 62vw);
    z-index: 14;
}

.ta-draw-stage .ta-draw-rotate-controls {
    top: clamp(18.5rem, 45vh, 24rem) !important;
    width: min(70rem, calc(100vw - 2rem)) !important;
}

.ta-draw-stage #draw-prompt {
    top: auto !important;
    right: clamp(1.2rem, 3.6vw, 3rem) !important;
    bottom: max(1.2rem, calc(env(safe-area-inset-bottom) + 0.92rem)) !important;
    min-width: 8rem;
    border-radius: 0.9rem !important;
}

.ta-draw-slots {
    width: min(52rem, calc(100vw - 15rem));
    bottom: max(1.18rem, calc(env(safe-area-inset-bottom) + 0.9rem));
}

@media (max-width: 1023px) {
    #scene-draw.ta-draw-stage {
        --fan-top: clamp(12rem, 23vh, 15rem);
    }

    .ta-draw-stage-copy {
        max-width: min(30rem, 66vw) !important;
    }

    .ta-draw-stage .ta-draw-rotate-controls {
        width: calc(100vw - 1.6rem) !important;
    }
}

@media (max-width: 767px) {
    #scene-draw.ta-draw-stage {
        --fan-top: max(10.2rem, calc(env(safe-area-inset-top) + 9.25rem));
        --fan-bottom: max(8.85rem, calc(env(safe-area-inset-bottom) + 7.7rem));
        background:
            radial-gradient(circle at 50% 39%, rgba(216, 173, 93, 0.11), transparent 16rem),
            linear-gradient(180deg, rgba(3, 5, 14, 0.22), rgba(3, 5, 14, 0.88)),
            url("images/ui/draw-stage-v2.webp") center / auto 100% no-repeat !important;
    }

    .ta-draw-stage #card-stream-track.ta-draw-fan-track {
        inset: var(--fan-top) 0.45rem var(--fan-bottom) !important;
        border-radius: 12px;
    }

    .ta-draw-stage #card-stream-track.ta-draw-fan-track::before {
        bottom: -2.1rem;
        width: 132vw;
        height: 58vw;
    }

    .ta-draw-stage #card-stream-track.ta-draw-fan-track::after {
        bottom: 0.38rem;
        width: min(18rem, 72vw);
    }

    .ta-draw-stage-copy {
        top: max(5.7rem, calc(env(safe-area-inset-top) + 5rem)) !important;
        left: 50% !important;
        max-width: min(14rem, 56vw) !important;
        gap: 0.16rem;
        text-align: center;
    }

    .ta-draw-stage-copy::after {
        content: "\5411\4e0a\6ed1\51fa\6b64\724c";
        color: rgba(226, 232, 240, 0.76);
        font-size: 0.68rem;
        line-height: 1.35;
        letter-spacing: 0.08em;
    }

    .ta-draw-stage-copy span {
        font-size: 0.54rem;
    }

    .ta-draw-stage-copy strong {
        display: block;
        font-size: clamp(0.92rem, 3.8vw, 1.12rem);
        line-height: 1.22;
    }

    .ta-draw-stage-copy small {
        display: none;
    }

    .ta-draw-stage .ta-draw-aperture {
        top: max(12.75rem, calc(env(safe-area-inset-top) + 11.8rem)) !important;
        width: clamp(5.5rem, 25vw, 6.5rem) !important;
    }

    .ta-focus-preview-card {
        width: clamp(2.25rem, 11vw, 2.8rem);
        border-radius: 0.38rem;
    }

    .ta-focus-preview-card::after {
        bottom: -1.05rem;
        font-size: 0.56rem;
    }

    .ta-draw-focus-hint {
        top: auto !important;
        bottom: max(4.55rem, calc(env(safe-area-inset-bottom) + 4.1rem));
        left: 50%;
        width: calc(100vw - 1.4rem);
        min-width: 0;
        padding: 0.62rem 0.86rem 0.66rem 3rem;
        border-radius: 0.9rem;
        text-align: left;
        pointer-events: none;
    }

    .ta-draw-focus-hint::before {
        left: 0.66rem;
        width: 1.84rem;
        font-size: 0.58rem;
    }

    .ta-draw-focus-hint span {
        font-size: 0.54rem;
    }

    .ta-draw-focus-hint strong {
        font-size: 0.92rem;
    }

    .ta-draw-focus-hint small {
        display: block;
        font-size: 0.62rem;
        line-height: 1.25;
    }

    .ta-draw-stage .ta-draw-rotate-controls {
        top: clamp(18.5rem, 51vh, 24rem) !important;
        left: 50% !important;
        right: auto !important;
        bottom: auto !important;
        width: min(18rem, calc(100% - 1rem)) !important;
        transform: translate(-50%, -50%) !important;
    }

    .ta-draw-stage .ta-draw-rotate {
        width: 2.45rem;
        background:
            linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.018)),
            rgba(4, 7, 18, 0.74);
    }

    .ta-draw-stage #draw-prompt {
        display: none !important;
    }

    .ta-draw-slots {
        bottom: max(0.72rem, calc(env(safe-area-inset-bottom) + 0.52rem));
        width: calc(100vw - 1.2rem);
    }
}

@media (prefers-reduced-motion: reduce) {
    .ta-draw-stage .stream-card.deck-fan-card,
    .ta-draw-stage .ta-draw-aperture {
        transition: none !important;
    }
}

/* =========================================
   32. Global UI/UX Responsive Pass
   ========================================= */
:root {
    --ta-mobile-gutter: clamp(1rem, 4.2vw, 1.35rem);
}

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

@supports not (overflow-x: clip) {
    html,
    body {
        overflow-x: hidden;
    }
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

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

body:not(.theme-mode-dark) #main-nav a,
body:not(.theme-mode-dark) #main-nav button,
body:not(.theme-mode-dark) .spread-filter-tabs button {
    min-width: 0;
}

body:not(.theme-mode-dark) .spread-guide-ref-shell > .spread-filter-tabs,
body:not(.theme-mode-dark) .spread-guide-ref-shell > .spread-selection-board,
body:not(.theme-mode-dark) .spread-guide-ref-shell > .spread-guide-tip {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

body:not(.theme-mode-dark) main.text-page-container.spread-guide-ref-shell {
    width: min(1440px, calc(100% - 24px)) !important;
    max-width: none !important;
}

@media (min-width: 768px) {
    body:not(.theme-mode-dark) #main-nav {
        left: 50% !important;
        right: auto !important;
        width: min(1180px, calc(100% - 2rem)) !important;
        transform: translateX(-50%) !important;
        padding: 0.88rem 1.2rem !important;
        border: 1px solid rgba(218, 191, 138, 0.16) !important;
        border-radius: 14px !important;
        background:
            linear-gradient(180deg, rgba(255,255,255,0.058), rgba(255,255,255,0.015)),
            rgba(6, 8, 18, 0.7) !important;
        box-shadow: 0 18px 48px rgba(0,0,0,0.28) !important;
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
    }

    body:not(.theme-mode-dark) #main-nav .hidden.md\:flex {
        gap: clamp(1rem, 1.7vw, 1.55rem) !important;
        align-items: center;
    }

    body:not(.theme-mode-dark) #main-nav .brand-title,
    body:not(.theme-mode-dark) #main-nav > a:first-child {
        font-size: 1rem !important;
        letter-spacing: 0.16em !important;
    }

    body:not(.theme-mode-dark) #main-nav .hidden.md\:flex > a {
        font-size: 0.78rem !important;
        line-height: 1.2 !important;
    }
}

@media (max-width: 767px) {
    body:not(.theme-mode-dark) #main-nav {
        position: fixed !important;
        top: max(0.75rem, env(safe-area-inset-top)) !important;
        left: 50% !important;
        right: auto !important;
        width: calc(100vw - 2rem) !important;
        max-width: calc(100vw - 2rem) !important;
        min-width: 0 !important;
        min-height: 3.38rem !important;
        padding: 0.58rem 0.62rem 0.58rem 0.86rem !important;
        gap: 0.55rem !important;
        justify-content: space-between !important;
        border: 1px solid rgba(218, 191, 138, 0.16) !important;
        border-radius: 12px !important;
        background:
            linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.012)),
            rgba(5, 7, 17, 0.76) !important;
        box-shadow: 0 16px 42px rgba(0,0,0,0.34) !important;
        transform: translateX(-50%) !important;
        backdrop-filter: blur(18px) saturate(1.15);
        -webkit-backdrop-filter: blur(18px) saturate(1.15);
    }

    body:not(.theme-mode-dark) #main-nav .hidden.md\:flex {
        display: none !important;
    }

    body:not(.theme-mode-dark) #main-nav .brand-title,
    body:not(.theme-mode-dark) #main-nav > a:first-child {
        flex: 1 1 auto !important;
        max-width: min(12.5rem, 52vw) !important;
        overflow: hidden !important;
        color: rgba(247, 232, 202, 0.94) !important;
        font-size: clamp(0.76rem, 3.15vw, 0.9rem) !important;
        line-height: 1.1 !important;
        letter-spacing: 0.12em !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    body:not(.theme-mode-dark) #main-nav .nav-controls,
    body:not(.theme-mode-dark) #main-nav > div:not(#mobile_menu):not(#mobile-menu):not(.hidden) {
        flex: 0 0 auto;
        display: flex !important;
        align-items: center !important;
        gap: 0.4rem !important;
        margin-left: auto;
    }

    body:not(.theme-mode-dark) #main-nav .lang-switch {
        display: none !important;
    }

    body:not(.theme-mode-dark) #main-nav .lang-switch span {
        display: none !important;
    }

    body:not(.theme-mode-dark) #main-nav .lang-switch button,
    body:not(.theme-mode-dark) #main-nav button[data-lang-btn] {
        min-width: 2.1rem !important;
        min-height: 1.9rem !important;
        padding: 0 0.42rem !important;
        border-radius: 999px !important;
        font-size: 0.66rem !important;
        letter-spacing: 0.03em !important;
    }

    body:not(.theme-mode-dark) #menu_btn,
    body:not(.theme-mode-dark) #mobile-menu-btn {
        flex: 0 0 auto !important;
        width: 2.3rem !important;
        height: 2.3rem !important;
        display: grid !important;
        place-items: center !important;
        padding: 0 !important;
        border: 1px solid rgba(218, 191, 138, 0.16) !important;
        border-radius: 999px !important;
        background: rgba(255,255,255,0.035) !important;
    }

    body:not(.theme-mode-dark) #mobile_menu {
        background:
            radial-gradient(circle at 50% 18%, rgba(217,184,107,0.11), transparent 16rem),
            rgba(3, 5, 12, 0.96) !important;
        backdrop-filter: blur(22px);
        -webkit-backdrop-filter: blur(22px);
    }

    body:not(.theme-mode-dark) #mobile_menu a {
        max-width: calc(100vw - 3rem);
        font-size: clamp(1.55rem, 7vw, 2.05rem) !important;
        line-height: 1.18 !important;
        letter-spacing: 0.1em !important;
        text-align: center;
        overflow-wrap: anywhere;
    }

    body:not(.theme-mode-dark) main.text-page-container:not(.spread-guide-ref-shell) {
        width: 100% !important;
        max-width: none !important;
        overflow-x: hidden !important;
        padding: max(6.45rem, calc(env(safe-area-inset-top) + 5.75rem)) var(--ta-mobile-gutter) max(4rem, calc(env(safe-area-inset-bottom) + 3rem)) !important;
    }

    body:not(.theme-mode-dark) main.text-page-container > article,
    body:not(.theme-mode-dark) main.text-page-container > div {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        overflow-x: hidden !important;
    }

    body:not(.theme-mode-dark) main.text-page-container header,
    body:not(.theme-mode-dark) #content-zh > header,
    body:not(.theme-mode-dark) #content-en > header {
        margin-bottom: 1.45rem !important;
        padding-bottom: 1rem !important;
        text-align: left !important;
    }

    body:not(.theme-mode-dark) main.text-page-container header h1,
    body:not(.theme-mode-dark) #content-zh > header h1,
    body:not(.theme-mode-dark) #content-en > header h1,
    body:not(.theme-mode-dark) #terms-page-title {
        max-width: 100% !important;
        font-size: clamp(2.05rem, 9vw, 2.62rem) !important;
        line-height: 1.08 !important;
        letter-spacing: 0 !important;
        overflow-wrap: anywhere !important;
        text-wrap: balance;
    }

    body:not(.theme-mode-dark) main.text-page-container header p,
    body:not(.theme-mode-dark) #content-zh > header p,
    body:not(.theme-mode-dark) #content-en > header p {
        max-width: 100% !important;
        font-size: 0.72rem !important;
        line-height: 1.55 !important;
        letter-spacing: 0.08em !important;
    }

    body:not(.theme-mode-dark) .glass-panel {
        width: min(100%, calc(100vw - 2rem)) !important;
        max-width: calc(100vw - 2rem) !important;
        padding: 1.08rem !important;
        margin-left: auto !important;
        margin-right: auto !important;
        overflow-x: hidden !important;
        border-radius: 0.88rem !important;
    }

    body:not(.theme-mode-dark) .glass-panel > * {
        max-width: 100% !important;
        min-width: 0 !important;
    }

    body:not(.theme-mode-dark) .policy-section,
    body:not(.theme-mode-dark) .terms-section {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 1rem 0 !important;
        border-top: 1px solid rgba(218, 191, 138, 0.1);
    }

    body:not(.theme-mode-dark) .policy-section:first-child,
    body:not(.theme-mode-dark) .terms-section:first-child {
        padding-top: 0 !important;
        border-top: 0 !important;
    }

    body:not(.theme-mode-dark) .policy-h2,
    body:not(.theme-mode-dark) .terms-h2 {
        align-items: flex-start !important;
        gap: 0.62rem !important;
        margin-bottom: 0.55rem !important;
        padding-left: 0 !important;
        border-left: 0 !important;
        font-size: clamp(1.02rem, 4.7vw, 1.18rem) !important;
        line-height: 1.42 !important;
        letter-spacing: 0.01em !important;
        overflow-wrap: anywhere !important;
        word-break: normal !important;
    }

    body:not(.theme-mode-dark) .policy-h2::before,
    body:not(.theme-mode-dark) .terms-h2::before {
        margin-top: 0.42em;
    }

    body:not(.theme-mode-dark) .policy-p,
    body:not(.theme-mode-dark) .terms-p,
    body:not(.theme-mode-dark) .policy-list,
    body:not(.theme-mode-dark) article p,
    body:not(.theme-mode-dark) article li {
        max-width: 100% !important;
        color: rgba(218, 225, 238, 0.78) !important;
        font-size: 0.92rem !important;
        line-height: 1.82 !important;
        letter-spacing: 0 !important;
        text-align: left !important;
        word-break: normal !important;
        overflow-wrap: anywhere !important;
    }

    body:not(.theme-mode-dark) .policy-list {
        padding-left: 1.1rem !important;
    }

    .about-ref-shell {
        width: 100% !important;
        min-height: 100dvh !important;
        padding: max(5.95rem, calc(env(safe-area-inset-top) + 5.2rem)) var(--ta-mobile-gutter) 1.35rem !important;
        overflow-x: hidden !important;
    }

    .about-hero-copy {
        max-width: 100% !important;
        padding-left: 0 !important;
    }

    .about-hero-copy h1 {
        max-width: 11.5em !important;
        font-size: clamp(2rem, 8.7vw, 2.46rem) !important;
        line-height: 1.1 !important;
        letter-spacing: 0 !important;
        text-wrap: balance;
    }

    .about-hero-copy p:not(.about-kicker) {
        max-width: 100% !important;
        font-size: 0.94rem !important;
        line-height: 1.76 !important;
    }

    .about-ai-note {
        width: 100% !important;
        padding: 0.82rem 0.9rem !important;
        border-radius: 0.82rem !important;
        font-size: 0.88rem !important;
        line-height: 1.55 !important;
    }

    .about-process-panel,
    .about-info-card,
    .about-limit-band {
        border-radius: 0.9rem !important;
    }

    .about-step {
        grid-template-columns: 56px minmax(0, 1fr) !important;
        gap: 0.8rem !important;
        padding: 0.82rem !important;
    }

    .about-step-visual {
        width: 48px !important;
        height: 48px !important;
    }

    .spread-guide-ref-shell {
        width: 100% !important;
        min-height: 100dvh !important;
        padding: max(5.65rem, calc(env(safe-area-inset-top) + 5rem)) var(--ta-mobile-gutter) max(1.35rem, calc(env(safe-area-inset-bottom) + 1rem)) !important;
        overflow-x: hidden !important;
        background:
            radial-gradient(circle at 90% 9%, rgba(217,184,107,.12), transparent 9.5rem),
            linear-gradient(180deg, rgba(5,7,17,.78), rgba(5,7,17,.97)),
            url("images/ui/spreads-guide-v1.webp") right top / auto 252px no-repeat,
            #03050c !important;
    }

    .spread-guide-ref-shell header {
        margin-bottom: 1rem !important;
        padding-right: min(18vw, 4.5rem);
        text-align: left !important;
    }

    .spread-guide-ref-shell #page-title {
        max-width: 9em !important;
        font-size: clamp(2.05rem, 8.9vw, 2.55rem) !important;
        line-height: 1.08 !important;
        letter-spacing: 0 !important;
        overflow-wrap: anywhere !important;
        text-wrap: balance;
    }

    .spread-guide-ref-shell #page-subtitle {
        max-width: 25rem !important;
        margin-left: 0 !important;
        font-size: 0.92rem !important;
        line-height: 1.72 !important;
        letter-spacing: 0 !important;
        text-transform: none !important;
    }

    .spread-filter-tabs {
        gap: 0.3rem !important;
        margin: 0 -0.2rem 0.9rem !important;
        padding: 0.28rem !important;
        border-radius: 0.78rem !important;
        scrollbar-width: none;
    }

    .spread-filter-tabs::-webkit-scrollbar {
        display: none;
    }

    .spread-filter-tabs button {
        flex: 0 0 auto !important;
        min-width: 4.7rem !important;
        min-height: 2.78rem !important;
        flex-direction: row !important;
        gap: 0.32rem !important;
        padding: 0.42rem 0.66rem !important;
        border: 1px solid rgba(218, 191, 138, 0.12) !important;
        border-radius: 0.62rem !important;
        font-size: 0.82rem !important;
        line-height: 1.15 !important;
        white-space: nowrap !important;
    }

    .spread-selection-board {
        gap: 0.58rem !important;
    }

    .spread-board-row {
        grid-template-columns: 4.2rem minmax(0, 1fr) 1.1rem !important;
        gap: 0.72rem !important;
        padding: 0.76rem !important;
        border-radius: 0.82rem !important;
    }

    .spread-board-map {
        width: 4.2rem !important;
        height: 3.85rem !important;
        overflow: hidden;
    }

    .spread-board-map .mini-card {
        width: 16px !important;
        height: 24px !important;
        border-radius: 4px !important;
        font-size: 8px !important;
    }

    .spread-board-title h3 {
        font-size: 1.12rem !important;
        line-height: 1.22 !important;
        overflow-wrap: anywhere !important;
    }

    .spread-board-title p,
    .spread-board-title::after {
        font-size: 0.78rem !important;
        line-height: 1.42 !important;
    }

    .spread-board-row > .spread-board-cell.depth-dots {
        display: none !important;
    }

    .spread-board-title .mobile-depth.depth-dots {
        display: flex !important;
        gap: 0.32rem !important;
        margin-top: 0.38rem !important;
    }

    .spread-board-title .mobile-depth.depth-dots i {
        width: 0.42rem !important;
        height: 0.42rem !important;
    }

    .spread-board-row::after {
        align-self: center;
        font-size: 1rem !important;
    }

    .spread-guide-tip {
        display: block !important;
        padding: 0.9rem !important;
        border-radius: 0.82rem !important;
        font-size: 0.86rem !important;
        line-height: 1.65 !important;
    }

    .spread-guide-tip a {
        display: inline-flex;
        margin-top: 0.5rem;
    }

    .origins-ref-shell,
    .theory-ref-shell {
        overflow-x: hidden !important;
    }

    .origins-hero h1,
    .theory-hero h1 {
        font-size: clamp(2.12rem, 10vw, 2.82rem) !important;
        line-height: 1.05 !important;
        letter-spacing: 0 !important;
        overflow-wrap: anywhere !important;
        text-wrap: balance;
    }

    .origins-hero p,
    .origins-hero h2,
    .theory-hero p,
    .theory-hero .theory-subtitle,
    .theory-hero .theory-lead {
        max-width: 100% !important;
        line-height: 1.72 !important;
    }
}

@media (min-width: 768px) {
    body:not(.theme-mode-dark) #main-nav #menu_btn,
    body:not(.theme-mode-dark) #main-nav #mobile-menu-btn {
        display: none !important;
    }
}

/* =========================================
   33. Draw Scene Overlap Guard
   ========================================= */
#scene-draw.ta-draw-stage #card-stream-track.ta-draw-fan-track {
    inset: var(--fan-top) clamp(0.6rem, 2.2vw, 2.6rem) var(--fan-bottom) !important;
    width: auto !important;
    height: auto !important;
    max-width: none !important;
    max-height: none !important;
}

@media (max-width: 1023px) {
    #scene-draw.ta-draw-stage #card-stream-track.ta-draw-fan-track {
        inset: var(--fan-top) clamp(0.5rem, 1.8vw, 1rem) var(--fan-bottom) !important;
    }

    .ta-draw-stage #draw-prompt {
        display: none !important;
    }
}

@media (min-width: 768px) and (max-width: 1023px) {
    #scene-draw.ta-draw-stage {
        --fan-top: clamp(14rem, 24vh, 16.4rem);
        --fan-bottom: max(8rem, calc(env(safe-area-inset-bottom) + 6.8rem));
    }

    .ta-draw-slots {
        width: min(34rem, calc(100vw - 2rem)) !important;
        bottom: max(1rem, calc(env(safe-area-inset-bottom) + 0.75rem)) !important;
    }
}

@media (min-width: 1024px) {
    .ta-draw-focus-hint {
        left: calc(50% + clamp(12rem, 18vw, 16rem)) !important;
        max-width: min(18rem, 28vw);
        transform: translateX(-50%) !important;
    }
}

@media (max-width: 767px) {
    #scene-draw.ta-draw-stage #card-stream-track.ta-draw-fan-track {
        inset: var(--fan-top) 0.45rem var(--fan-bottom) !important;
    }

    .ta-draw-focus-hint {
        bottom: max(4.65rem, calc(env(safe-area-inset-bottom) + 4.15rem)) !important;
    }

    .ta-draw-slots {
        bottom: max(0.72rem, calc(env(safe-area-inset-bottom) + 0.52rem)) !important;
    }
}

/* =========================================
   34. Draw Scene Minimal Guidance
   ========================================= */
#scene-draw.ta-draw-stage {
    --fan-top: clamp(10.8rem, 21vh, 13.8rem);
    --fan-bottom: max(5.2rem, calc(env(safe-area-inset-bottom) + 4.45rem));
}

.ta-draw-stage .stream-card.deck-fan-card .deck-card-number,
.ta-draw-stage .stream-card.deck-atlas-card .deck-card-number,
.deck-card-number {
    display: none !important;
}

.ta-focus-preview-card::after {
    content: none !important;
    display: none !important;
}

.ta-draw-focus-hint {
    display: none !important;
}

.ta-draw-stage-copy {
    top: max(6.38rem, calc(env(safe-area-inset-top) + 5.48rem)) !important;
    gap: 0.08rem !important;
}

.ta-draw-stage-copy span {
    font-size: 0.6rem !important;
    letter-spacing: 0.16em !important;
}

.ta-draw-stage-copy strong {
    font-size: clamp(1.08rem, 1.65vw, 1.52rem) !important;
    line-height: 1.18 !important;
}

.ta-draw-stage-copy small {
    display: none !important;
}

.ta-draw-stage .ta-draw-aperture {
    top: clamp(12.9rem, 31vh, 18.2rem) !important;
    width: clamp(5.7rem, 8.4vw, 7.4rem) !important;
}

.ta-focus-preview-card {
    width: clamp(2.18rem, 3.5vw, 3rem) !important;
}

#scene-draw.ta-draw-stage #card-stream-track.ta-draw-fan-track {
    inset: var(--fan-top) clamp(0.6rem, 2.2vw, 2.6rem) var(--fan-bottom) !important;
}

.ta-draw-slots {
    bottom: max(0.82rem, calc(env(safe-area-inset-bottom) + 0.58rem)) !important;
}

.ta-draw-slot {
    min-height: 2.15rem;
    padding-top: 0.42rem !important;
    padding-bottom: 0.42rem !important;
}

@media (min-width: 1024px) {
    .ta-draw-stage #draw-prompt {
        bottom: max(0.82rem, calc(env(safe-area-inset-bottom) + 0.58rem)) !important;
        padding: 0.42rem 0.74rem !important;
        min-width: 6.6rem !important;
    }

    .ta-draw-stage #draw-prompt p {
        display: none !important;
    }

    .ta-draw-stage #count-drawn {
        font-size: clamp(1.42rem, 2.2vw, 2rem) !important;
    }

    .ta-draw-stage #count-total {
        font-size: 0.95rem !important;
    }
}

@media (min-width: 768px) and (max-width: 1023px) {
    #scene-draw.ta-draw-stage {
        --fan-top: clamp(12.8rem, 22vh, 14.8rem);
        --fan-bottom: max(5.8rem, calc(env(safe-area-inset-bottom) + 5rem));
    }

    .ta-draw-stage .ta-draw-aperture {
        top: clamp(12.9rem, 30vh, 17.6rem) !important;
    }
}

@media (max-width: 767px) {
    #scene-draw.ta-draw-stage {
        --fan-top: max(8.9rem, calc(env(safe-area-inset-top) + 7.95rem));
        --fan-bottom: max(5.35rem, calc(env(safe-area-inset-bottom) + 4.78rem));
    }

    .ta-draw-stage-copy {
        top: max(5.08rem, calc(env(safe-area-inset-top) + 4.42rem)) !important;
        max-width: min(16rem, 72vw) !important;
    }

    .ta-draw-stage-copy::after {
        content: none !important;
        display: none !important;
    }

    .ta-draw-stage-copy span {
        display: none !important;
    }

    .ta-draw-stage-copy strong {
        font-size: clamp(0.86rem, 3.45vw, 1.02rem) !important;
    }

    .ta-draw-stage .ta-draw-aperture {
        top: max(10.85rem, calc(env(safe-area-inset-top) + 9.9rem)) !important;
        width: clamp(4.9rem, 21vw, 5.55rem) !important;
    }

    .ta-focus-preview-card {
        width: clamp(1.92rem, 9.2vw, 2.35rem) !important;
    }

    #scene-draw.ta-draw-stage #card-stream-track.ta-draw-fan-track {
        inset: var(--fan-top) 0.45rem var(--fan-bottom) !important;
    }

    .ta-draw-stage .ta-draw-rotate-controls {
        top: clamp(17rem, 50vh, 23rem) !important;
    }

    .ta-draw-slot {
        min-height: 2rem;
        padding: 0.34rem 0.5rem !important;
    }
}

/* =========================================
   35. Remove Duplicate Draw Preview
   ========================================= */
.ta-draw-stage .ta-focus-preview-card {
    display: none !important;
}

.ta-draw-stage .ta-draw-aperture {
    opacity: 0.46 !important;
    background:
        radial-gradient(circle, rgba(216, 173, 93, 0.12), transparent 52%),
        conic-gradient(from 0deg, transparent, rgba(216, 173, 93, 0.18), transparent 22%, transparent 78%, rgba(120, 206, 210, 0.1), transparent) !important;
    box-shadow:
        inset 0 0 1.7rem rgba(216, 173, 93, 0.12),
        0 0 2.4rem rgba(216, 173, 93, 0.14) !important;
}

.ta-draw-stage .ta-draw-aperture.is-draw-target,
.ta-draw-stage .ta-draw-aperture.is-ready-to-draw {
    opacity: 1 !important;
}

/* =========================================
   36. Draw Stage UX Polish
   ========================================= */
.ta-draw-stage-copy {
    display: none !important;
}

.ta-draw-stage .ta-draw-aperture {
    pointer-events: none;
}

/* =========================================
   37. Mobile PC-Style Draw Fan
   ========================================= */
@media (max-width: 767px) {
    #scene-draw.ta-draw-stage #card-stream-track.ta-draw-fan-track[data-layout="mobile-fan"] {
        perspective: 820px;
    }

    .ta-draw-stage #card-stream-track.ta-draw-fan-track[data-layout="mobile-fan"] .stream-card.deck-fan-card {
        transition:
            transform 280ms cubic-bezier(0.16, 0.84, 0.24, 1),
            opacity 190ms ease,
            filter 190ms ease,
            border-color 190ms ease,
            box-shadow 190ms ease !important;
    }

    .ta-draw-stage #card-stream-track.ta-draw-fan-track[data-layout="mobile-fan"] .stream-card.deck-fan-card.is-focus {
        box-shadow:
            0 1.25rem 2.4rem rgba(0,0,0,0.58),
            0 0 2.15rem rgba(216,173,93,0.52),
            0 0 0 1px rgba(255,239,196,0.36);
    }

    .ta-draw-stage #card-stream-track.ta-draw-fan-track[data-layout="mobile-fan"]::after {
        bottom: 0.82rem;
        width: min(20rem, 74vw);
    }
}
