/* TarotAstrolabe card meaning pages */

html:has(body.page-card-library),
html:has(body.page-card-meaning) {
    height: 100% !important;
    min-height: 100%;
    overflow-x: hidden !important;
    overflow-y: hidden !important;
}

body.page-card-library,
body.page-card-meaning {
    height: 100dvh !important;
    min-height: 100dvh;
    overflow-x: hidden !important;
    overflow-y: hidden !important;
    color: rgba(238, 232, 219, .92);
    background:
        radial-gradient(circle at 12% 12%, rgba(217, 184, 107, .13), transparent 22rem),
        radial-gradient(circle at 86% 18%, rgba(96, 132, 190, .12), transparent 20rem),
        linear-gradient(180deg, #03050c, #070913 58%, #03050c);
}

body.page-card-library.menu-open,
body.page-card-meaning.menu-open {
    overflow: hidden !important;
}

.cards-page-shell {
    width: min(1280px, calc(100% - 28px));
    height: 100dvh;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    margin: 0 auto;
    padding: clamp(86px, 9vw, 112px) 0 56px;
}

.cards-page-shell:focus {
    outline: none;
}

.cards-page-shell:focus-visible {
    outline: 1px solid rgba(244, 213, 139, .28);
    outline-offset: -2px;
}

body.page-card-library.menu-open .cards-page-shell,
body.page-card-meaning.menu-open .cards-page-shell {
    overflow: hidden;
}

.cards-hero,
.card-detail-hero {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(218, 191, 138, .2);
    border-radius: 14px;
    background:
        linear-gradient(135deg, rgba(8, 10, 24, .88), rgba(8, 10, 24, .58)),
        radial-gradient(circle at 72% 18%, rgba(217, 184, 107, .16), transparent 18rem);
    box-shadow: 0 28px 90px rgba(0, 0, 0, .42), inset 0 1px 0 rgba(255, 255, 255, .05);
}

.cards-hero {
    min-height: clamp(290px, 34vw, 360px);
    display: grid;
    align-items: end;
    padding: clamp(28px, 5vw, 56px);
    background:
        linear-gradient(120deg, rgba(5, 7, 17, .94), rgba(5, 7, 17, .72) 55%, rgba(5, 7, 17, .46)),
        url("images/ui/cards-knowledge-hero-v1.webp") right top / min(720px, 62vw) auto no-repeat,
        radial-gradient(circle at 72% 18%, rgba(217, 184, 107, .16), transparent 18rem),
        #050711;
}

.cards-kicker {
    margin: 0 0 .8rem;
    color: rgba(244, 213, 139, .9);
    font: 700 .74rem Lato, sans-serif;
    letter-spacing: .16em;
}

.cards-hero h1,
.card-detail-title {
    margin: 0;
    color: rgba(247, 232, 202, .98);
    font-family: Cormorant Garamond, "Noto Serif TC", serif;
    font-size: clamp(2.6rem, 7vw, 5.8rem);
    line-height: .96;
    letter-spacing: 0;
    text-shadow: 0 24px 56px rgba(0, 0, 0, .55);
}

.cards-hero p,
.card-detail-lead {
    max-width: 46rem;
    margin: 1.1rem 0 0;
    color: rgba(230, 226, 214, .78);
    font-size: clamp(1rem, 1.7vw, 1.24rem);
    line-height: 1.78;
}

.cards-library-jump {
    position: sticky;
    top: 94px;
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin-top: 16px;
    padding: 10px;
    border: 1px solid rgba(218, 191, 138, .14);
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018)),
        rgba(4, 7, 17, .82);
    box-shadow: 0 18px 54px rgba(0, 0, 0, .28);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.cards-library-jump a {
    display: grid;
    gap: .18rem;
    min-width: 0;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 8px;
    padding: .74rem .85rem;
    color: inherit;
    text-decoration: none;
    background:
        radial-gradient(circle at 100% 0%, rgba(244, 213, 139, .08), transparent 7rem),
        rgba(255, 255, 255, .032);
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.cards-library-jump a:hover,
.cards-library-jump a:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(244, 213, 139, .42);
    background: rgba(217, 184, 107, .085);
    outline: none;
}

.cards-library-jump strong {
    color: rgba(247, 232, 202, .96);
    font-size: .92rem;
    line-height: 1.2;
}

.cards-library-jump span {
    overflow: hidden;
    color: rgba(230, 226, 214, .58);
    font: 400 .72rem Lato, "Noto Serif TC", sans-serif;
    line-height: 1.35;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cards-section {
    scroll-margin-top: 176px;
    margin-top: clamp(30px, 5vw, 52px);
}

.cards-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(218, 191, 138, .16);
    padding-bottom: .9rem;
}

.cards-section-head h2 {
    margin: 0;
    color: rgba(247, 232, 202, .96);
    font-family: Cormorant Garamond, "Noto Serif TC", serif;
    font-size: clamp(1.7rem, 3vw, 2.6rem);
    line-height: 1.05;
}

.cards-section-head span {
    color: rgba(244, 213, 139, .76);
    font-size: .9rem;
}

.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(154px, 1fr));
    gap: 16px;
}

.tarot-card-link {
    min-height: 100%;
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
    border: 1px solid rgba(218, 191, 138, .16);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.012)),
        rgba(5, 7, 17, .72);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 18px 44px rgba(0, 0, 0, .18);
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.tarot-card-link:hover,
.tarot-card-link:focus-visible {
    transform: translateY(-4px);
    border-color: rgba(244, 213, 139, .46);
    background: rgba(217, 184, 107, .08);
    box-shadow: 0 24px 58px rgba(0, 0, 0, .28);
    outline: none;
}

.tarot-card-link img {
    display: block;
    width: 100%;
    aspect-ratio: 2 / 3.42;
    object-fit: cover;
    background:
        radial-gradient(circle at 50% 18%, rgba(244, 213, 139, .18), transparent 42%),
        linear-gradient(180deg, rgba(11, 15, 30, .98), rgba(4, 6, 14, .98));
}

.tarot-card-link strong {
    display: block;
    align-self: end;
    padding: .82rem .82rem .18rem;
    color: rgba(247, 232, 202, .98);
    font-size: 1rem;
    line-height: 1.35;
}

.tarot-card-link span {
    display: block;
    min-height: 3.4em;
    padding: 0 .82rem .88rem;
    color: rgba(230, 226, 214, .62);
    font-size: .78rem;
    line-height: 1.55;
}

.card-detail-hero {
    display: grid;
    grid-template-columns: minmax(210px, 300px) minmax(0, 1fr);
    align-items: start;
    gap: clamp(22px, 4vw, 48px);
    padding: clamp(24px, 4vw, 44px);
}

.card-detail-cover {
    position: relative;
    align-self: start;
    overflow: hidden;
    border: 1px solid rgba(244, 213, 139, .3);
    border-radius: 10px;
    background: rgba(4, 6, 14, .8);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .42);
}

.card-detail-cover img {
    display: block;
    width: 100%;
    aspect-ratio: 2 / 3.42;
    object-fit: cover;
}

.card-detail-cover figcaption {
    position: absolute;
    inset-inline: 10px;
    bottom: 10px;
    border: 1px solid rgba(244, 213, 139, .2);
    border-radius: 999px;
    padding: .38rem .7rem;
    color: rgba(247, 232, 202, .94);
    background: rgba(4, 6, 14, .72);
    font: 700 .72rem Lato, "Noto Serif TC", sans-serif;
    letter-spacing: .08em;
    text-align: center;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.card-detail-copy {
    min-width: 0;
    display: grid;
    align-content: start;
}

.card-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1rem;
}

.card-chip {
    border: 1px solid rgba(218, 191, 138, .24);
    border-radius: 999px;
    padding: .38rem .68rem;
    color: rgba(244, 213, 139, .92);
    background: rgba(217, 184, 107, .08);
    font-size: .78rem;
}

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

.card-insight-item {
    min-width: 0;
    border: 1px solid rgba(218, 191, 138, .14);
    border-radius: 10px;
    padding: .9rem .95rem;
    background:
        radial-gradient(circle at 100% 0%, rgba(244, 213, 139, .09), transparent 8rem),
        rgba(255, 255, 255, .035);
}

.card-insight-item span {
    display: block;
    margin-bottom: .42rem;
    color: rgba(244, 213, 139, .82);
    font: 700 .72rem Lato, "Noto Serif TC", sans-serif;
    letter-spacing: .1em;
}

.card-insight-item strong {
    display: block;
    color: rgba(247, 232, 202, .96);
    font-size: .95rem;
    line-height: 1.62;
    overflow-wrap: anywhere;
}

.card-reading-nav {
    position: sticky;
    top: 94px;
    z-index: 28;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-top: 16px;
    padding: 10px;
    border: 1px solid rgba(218, 191, 138, .14);
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018)),
        rgba(4, 7, 17, .84);
    box-shadow: 0 18px 54px rgba(0, 0, 0, .28);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.card-reading-nav a {
    flex: 1 1 8.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 8px;
    padding: .55rem .75rem;
    color: rgba(238, 232, 219, .82);
    background: rgba(255, 255, 255, .032);
    font-size: .82rem;
    line-height: 1.2;
    text-decoration: none;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
    white-space: nowrap;
}

.card-reading-nav a:hover,
.card-reading-nav a:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(244, 213, 139, .38);
    color: rgba(247, 232, 202, .98);
    background: rgba(217, 184, 107, .08);
    outline: none;
}

.card-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 24px;
    margin-top: 22px;
    align-items: start;
}

.card-meaning-panel,
.card-side-panel,
.cards-cta-panel {
    border: 1px solid rgba(218, 191, 138, .16);
    border-radius: 12px;
    background: rgba(5, 7, 17, .62);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
}

.card-meaning-panel {
    max-width: 880px;
    padding: clamp(24px, 3vw, 38px);
}

.card-key-panel {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .8rem;
    margin-bottom: 2rem;
}

.card-key-item {
    border: 1px solid rgba(218, 191, 138, .14);
    border-radius: 10px;
    padding: .95rem;
    background:
        radial-gradient(circle at 100% 0%, rgba(244, 213, 139, .1), transparent 9rem),
        rgba(255, 255, 255, .035);
}

.card-key-item span {
    display: block;
    margin-bottom: .42rem;
    color: rgba(244, 213, 139, .82);
    font: 700 .72rem Lato, sans-serif;
    letter-spacing: .12em;
}

.card-key-item strong {
    display: block;
    color: rgba(247, 232, 202, .96);
    font-size: .96rem;
    line-height: 1.65;
}

.card-meaning-section + .card-meaning-section {
    margin-top: 2rem;
    padding-top: 1.8rem;
    border-top: 1px solid rgba(218, 191, 138, .12);
}

.card-meaning-section {
    scroll-margin-top: 170px;
}

.card-meaning-section h2 {
    margin: 0 0 .72rem;
    color: rgba(247, 232, 202, .96);
    font-family: Cormorant Garamond, "Noto Serif TC", serif;
    font-size: clamp(1.45rem, 2.3vw, 2.05rem);
    line-height: 1.15;
}

.card-meaning-section p {
    margin: 0;
    color: rgba(230, 226, 214, .8);
    font-size: 1rem;
    line-height: 1.9;
}

.card-meaning-section p + p {
    margin-top: .85rem;
}

.card-insight-list {
    display: grid;
    gap: .7rem;
    margin: 1rem 0 0;
    padding: 0;
    list-style: none;
}

.card-insight-list li {
    position: relative;
    border: 1px solid rgba(218, 191, 138, .12);
    border-radius: 10px;
    padding: .86rem .95rem .86rem 1.65rem;
    color: rgba(230, 226, 214, .78);
    background: rgba(255, 255, 255, .03);
    line-height: 1.75;
}

.card-insight-list li::before {
    content: "";
    position: absolute;
    left: .85rem;
    top: 1.55rem;
    width: .36rem;
    height: .36rem;
    border-radius: 999px;
    background: rgba(244, 213, 139, .82);
    box-shadow: 0 0 16px rgba(244, 213, 139, .34);
}

.card-side-panel {
    position: sticky;
    top: 96px;
    align-self: start;
    padding: 18px;
}

.card-side-panel h2 {
    margin: 0 0 .8rem;
    color: rgba(244, 213, 139, .94);
    font-size: .86rem;
    letter-spacing: .12em;
}

.card-side-list {
    display: grid;
    gap: .6rem;
}

.card-side-list a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .75rem;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 8px;
    padding: .75rem .82rem;
    color: rgba(238, 232, 219, .82);
    background: rgba(255, 255, 255, .035);
    text-decoration: none;
}

.card-side-list a:hover {
    border-color: rgba(244, 213, 139, .34);
    color: rgba(247, 232, 202, .98);
}

.card-side-card {
    display: grid !important;
    grid-template-columns: 46px minmax(0, 1fr);
    justify-content: start;
    align-items: center;
}

.card-side-card img {
    width: 46px;
    aspect-ratio: 2 / 3.42;
    object-fit: cover;
    border: 1px solid rgba(244, 213, 139, .2);
    border-radius: 5px;
    background: rgba(4, 6, 14, .8);
}

.card-side-card span {
    min-width: 0;
    display: grid;
    gap: .15rem;
}

.card-side-card em {
    color: rgba(244, 213, 139, .72);
    font-size: .72rem;
    font-style: normal;
}

.card-side-card strong {
    overflow: hidden;
    color: rgba(247, 232, 202, .96);
    font-size: .92rem;
    line-height: 1.28;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cards-cta-panel {
    margin-top: 22px;
    padding: clamp(20px, 3vw, 32px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.cards-cta-panel p {
    margin: 0;
    color: rgba(230, 226, 214, .78);
    line-height: 1.7;
}

.cards-button {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border: 1px solid rgba(244, 213, 139, .4);
    border-radius: 999px;
    padding: 0 1.15rem;
    color: #160f05;
    background: linear-gradient(180deg, #ffe7aa, #d8aa4b);
    font-weight: 700;
    text-decoration: none;
}

.card-faq details {
    border: 1px solid rgba(218, 191, 138, .12);
    border-radius: 10px;
    padding: 1rem;
    background: rgba(255, 255, 255, .03);
}

.card-faq details + details {
    margin-top: .75rem;
}

.card-faq summary {
    cursor: pointer;
    color: rgba(247, 232, 202, .95);
    font-weight: 700;
}

.card-faq p {
    margin-top: .7rem;
}

@media (max-width: 1020px) {
    .cards-grid {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }

    .cards-library-jump {
        position: static;
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

    .card-side-panel {
        position: static;
    }

    .card-side-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    body.page-card-library,
    body.page-card-meaning {
        background:
            radial-gradient(circle at 50% 0%, rgba(217, 184, 107, .1), transparent 18rem),
            linear-gradient(180deg, #03050c, #070913 58%, #03050c);
    }

    .cards-page-shell {
        width: min(100%, calc(100% - 20px));
        padding-top: max(92px, calc(env(safe-area-inset-top) + 82px));
        padding-bottom: 42px;
    }

    .cards-hero {
        min-height: 255px;
        padding: 22px;
        background:
            linear-gradient(180deg, rgba(5, 7, 17, .72), rgba(5, 7, 17, .96)),
            url("images/ui/cards-knowledge-hero-v1.webp") right top / auto 245px no-repeat,
            #050711;
    }

    .cards-hero h1,
    .card-detail-title {
        font-size: clamp(2.05rem, 10.5vw, 2.75rem);
        line-height: 1.03;
    }

    .cards-hero p,
    .card-detail-lead {
        margin-top: .85rem;
        font-size: .95rem;
        line-height: 1.72;
    }

    .cards-kicker {
        margin-bottom: .55rem;
        font-size: .68rem;
        letter-spacing: .12em;
    }

    .cards-library-jump {
        grid-template-columns: 1fr;
        gap: 8px;
        margin-top: 12px;
        padding: 8px;
    }

    .cards-library-jump a {
        grid-template-columns: minmax(5.8rem, auto) 1fr;
        align-items: center;
        min-height: 48px;
        padding: .66rem .72rem;
    }

    .cards-library-jump span {
        text-align: right;
        white-space: normal;
    }

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

    .tarot-card-link strong {
        padding-inline: .68rem;
        font-size: .92rem;
    }

    .tarot-card-link span {
        min-height: 3.2em;
        padding-inline: .68rem;
        font-size: .72rem;
    }

    .cards-section {
        scroll-margin-top: 92px;
        margin-top: 30px;
    }

    .cards-section-head {
        align-items: center;
        margin-bottom: .85rem;
    }

    .cards-section-head h2 {
        font-size: clamp(1.55rem, 8vw, 2rem);
    }

    .cards-section-head span {
        flex: 0 0 auto;
        font-size: .76rem;
    }

    .card-detail-hero {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 18px;
    }

    .card-detail-cover {
        width: min(196px, 56vw);
        margin-inline: auto;
    }

    .card-detail-cover figcaption {
        inset-inline: 8px;
        bottom: 8px;
        padding: .34rem .6rem;
        font-size: .66rem;
    }

    .card-detail-meta {
        gap: .45rem;
        margin-top: .85rem;
    }

    .card-chip {
        padding: .34rem .56rem;
        font-size: .72rem;
    }

    .card-insight-panel,
    .card-key-panel {
        grid-template-columns: 1fr;
    }

    .card-insight-panel {
        gap: .65rem;
        margin-top: 1rem;
    }

    .card-insight-item {
        padding: .78rem .85rem;
    }

    .card-insight-item strong {
        font-size: .9rem;
        line-height: 1.58;
    }

    .card-reading-nav {
        position: static;
        flex-wrap: nowrap;
        overflow-x: auto;
        margin-top: 12px;
        padding: 7px;
        scroll-snap-type: x proximity;
        scrollbar-width: none;
    }

    .card-reading-nav::-webkit-scrollbar {
        display: none;
    }

    .card-reading-nav a {
        flex: 0 0 auto;
        min-width: 5.8rem;
        min-height: 38px;
        padding: .5rem .68rem;
        font-size: .76rem;
        scroll-snap-align: start;
    }

    .card-detail-layout {
        gap: 16px;
        margin-top: 16px;
    }

    .card-meaning-panel,
    .card-side-panel,
    .cards-cta-panel {
        border-radius: 10px;
    }

    .card-meaning-panel {
        padding: 20px;
    }

    .card-meaning-section {
        scroll-margin-top: 94px;
    }

    .card-meaning-section + .card-meaning-section {
        margin-top: 1.65rem;
        padding-top: 1.45rem;
    }

    .card-meaning-section h2 {
        font-size: clamp(1.32rem, 6.6vw, 1.72rem);
        line-height: 1.22;
    }

    .card-meaning-section p,
    .card-insight-list li {
        font-size: .95rem;
        line-height: 1.78;
    }

    .card-side-list {
        grid-template-columns: 1fr;
    }

    .card-side-panel {
        padding: 16px;
    }

    .cards-cta-panel {
        align-items: stretch;
        flex-direction: column;
        margin-top: 16px;
        padding: 18px;
    }

    .cards-button {
        width: 100%;
    }
}
