/* Natal chart page specific styles */

.natal-chart-unknown-banner {
    margin: 8px 0 16px;
    padding: 10px 14px;
    border-radius: 10px;
    border: 1px solid rgba(196, 181, 255, 0.28);
    background: rgba(62, 42, 105, 0.22);
    line-height: 1.45;
}

.natal-result { margin-top:24px; text-align:left; animation:fadeIn 0.6s; }
.natal-error { margin-top:12px; }
.natal-guest-deepseek-notice {
    margin: 10px 0 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: #a898c8;
    text-align: center;
}
.natal-guest-deepseek-notice[hidden] { display: none !important; }
.natal-guest-deepseek-notice a {
    color: #c4b5fd;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.natal-guest-deepseek-notice a:hover { color: #ddd6fe; }
button.natal-chart-submit {
    appearance: none;
    position: relative;
    display: block;
    width: 100%;
    margin-top: 16px !important;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(196, 181, 255, 0.5);
    border-radius: 999px;
    background: linear-gradient(
        135deg,
        rgba(62, 42, 105, 0.78) 0%,
        rgba(48, 32, 88, 0.88) 45%,
        rgba(72, 50, 118, 0.74) 100%
    );
    color: #ece6ff;
    font-size: 1.05rem;
    font-weight: 600;
    line-height: 1.3;
    padding: 16px 22px;
    cursor: pointer;
    letter-spacing: 0.05em;
    text-shadow: 0 0 16px rgba(212, 196, 255, 0.45);
    box-shadow:
        0 0 22px rgba(139, 92, 246, 0.32),
        0 0 44px rgba(167, 139, 250, 0.14),
        inset 0 1px 0 rgba(230, 220, 255, 0.12);
    transition: border-color 0.3s ease, transform 0.2s ease, color 0.3s ease;
    animation: natalSubmitGlow 3.8s ease-in-out infinite;
}
button.natal-chart-submit::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(
        105deg,
        transparent 38%,
        rgba(228, 220, 255, 0.2) 50%,
        transparent 62%
    );
    transform: translateX(-120%);
    animation: natalSubmitShimmer 5.5s ease-in-out infinite;
}
button.natal-chart-submit:hover:not(:disabled) {
    border-color: rgba(220, 210, 255, 0.68);
    color: #f8f4ff;
    animation: none;
    box-shadow:
        0 0 30px rgba(167, 139, 250, 0.48),
        0 0 56px rgba(139, 92, 246, 0.22),
        inset 0 1px 0 rgba(240, 235, 255, 0.16);
    transform: translateY(-1px);
}
button.natal-chart-submit:active:not(:disabled) {
    transform: scale(0.98);
}
button.natal-chart-submit:disabled {
    opacity: 0.6;
    cursor: wait;
    transform: none;
    animation: none;
}
button.natal-chart-submit:disabled::before {
    animation: none;
}
@keyframes natalSubmitGlow {
    0%, 100% {
        box-shadow:
            0 0 20px rgba(139, 92, 246, 0.26),
            0 0 40px rgba(167, 139, 250, 0.12),
            inset 0 1px 0 rgba(230, 220, 255, 0.1);
    }
    50% {
        box-shadow:
            0 0 28px rgba(167, 139, 250, 0.4),
            0 0 52px rgba(139, 92, 246, 0.18),
            inset 0 1px 0 rgba(240, 235, 255, 0.14);
    }
}
@keyframes natalSubmitShimmer {
    0%, 72%, 100% { transform: translateX(-120%); }
    88% { transform: translateX(120%); }
}
.natal-title {
    color: #f0d9ff;
    margin-bottom: 12px;
    font-size: 1.2rem;
    text-align: center;
    scroll-margin-top: 24px;
}
.natal-warning {
    color:#ffd89b;
    background:rgba(255,180,80,0.12);
    border:1px solid rgba(255,200,120,0.35);
    border-radius:16px;
    padding:12px 16px;
    margin-bottom:16px;
    font-size:0.9rem;
    line-height:1.5;
}
.natal-chart-visual { text-align:center; margin-bottom:16px; width:100%; }
.natal-chart-visual__chart-wrap {
    position:relative;
    width:100%;
    max-width:min(100%, 530px);
    margin:0 auto;
}
.natal-chart-visual__preview {
    display:block;
    width:100%;
    max-width:min(100%, 530px);
    margin:0 auto;
}
.natal-chart-settings-toggle {
    display:none;
}
.natal-chart-settings__mobile-title {
    display:none;
}
.natal-chart-settings {
    display:flex;
    flex-wrap:wrap;
    gap:10px 14px;
    align-items:flex-end;
    justify-content:center;
    margin-top:14px;
    margin-bottom:0;
    padding:12px 14px;
    border-radius:16px;
    background:rgba(30,20,60,0.55);
    border:1px solid rgba(200,180,255,0.22);
    text-align:left;
}
.natal-chart-settings__intro {
    flex:1 1 100%;
    margin:0 0 2px;
    color:#e8dcff;
    font-size:0.88rem;
    line-height:1.35;
    text-align:center;
}
.natal-chart-settings__row {
    flex:1 1 140px;
    min-width:120px;
    max-width:200px;
}
.natal-chart-settings__field {
    display:block;
    margin-bottom:4px;
    color:#cbb2ff;
    font-size:0.78rem;
    letter-spacing:0.5px;
}
.natal-chart-settings__control {
    width:100%;
    padding:10px 12px;
    border-radius:20px;
    font-size:0.9rem;
}
.natal-chart-settings__check {
    display:flex;
    align-items:center;
    gap:8px;
    flex:1 1 100%;
    justify-content:center;
    color:#cbb2ff;
    font-size:0.85rem;
    cursor:pointer;
    margin:0;
}
.natal-chart-settings__check input[type="checkbox"] {
    width:auto;
    margin:0;
    accent-color:#8b5cf6;
}
.natal-chart-settings__check input[type="checkbox"]:disabled {
    opacity:0.45;
    cursor:not-allowed;
}
.natal-chart-settings__apply {
    flex:1 1 100%;
    width:auto;
    max-width:220px;
    margin:4px auto 0;
    padding:10px 20px;
    font-size:0.9rem;
    letter-spacing:0.5px;
}
.natal-chart-frame {
    position:relative;
    display:block;
    width:100%;
}
.natal-chart-frame__overlay {
    position:absolute;
    inset:0;
    z-index:2;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(2,1,17,0.55);
    border-radius:12px;
}
.natal-chart-frame__overlay[hidden] {
    display:none !important;
}
.natal-chart-frame__spinner {
    width:44px;
    height:44px;
    border-width:3px;
}
.natal-chart-svg {
    width:100%;
    max-width:100%;
    height:auto;
    display:block;
    margin:0 auto;
    aspect-ratio:1 / 1;
    object-fit:contain;
}
.natal-chart-actions {
    margin-top:12px;
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    justify-content:center;
}
.natal-chart-action-btn {
    appearance: none;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    border: 1px solid rgba(160, 196, 255, 0.35);
    border-radius: 10px;
    background: rgba(55, 75, 130, 0.7);
    color: #e8f0ff;
    font-size: 0.88rem;
    font-weight: 600;
    line-height: 1.2;
    padding: 9px 14px;
    cursor: pointer;
    box-shadow: 0 0 18px rgba(100, 140, 255, 0.2);
    transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
.natal-chart-action-btn:hover:not(:disabled) {
    background: rgba(70, 95, 160, 0.85);
    border-color: rgba(186, 210, 255, 0.5);
    box-shadow: 0 0 24px rgba(120, 160, 255, 0.32);
}
.natal-chart-action-btn:active:not(:disabled) { transform: scale(0.98); }
.natal-chart-action-btn__icon {
    display:none;
    flex-shrink:0;
}
.natal-chart-action-icon {
    width: 18px;
    height: 18px;
    display: block;
}
.natal-chart-action-btn.is-loading {
    opacity:0.7;
    cursor:wait;
}
.natal-chart-actions .natal-chart-action-btn {
    width:auto;
    flex:1 1 160px;
    max-width:100%;
    margin-top:0;
}
.btn-pdf-report {
    font-size: 0.85rem;
    padding: 8px 12px;
    line-height: 1;
    white-space: nowrap;
}
.btn-pdf-report:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}
.interpretation-result {
    margin-top: 16px;
}
.interpretation-result[hidden] {
    display: none !important;
}
.interpretation-result__header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 10px;
}
.interpretation-result__header[hidden] {
    display: none !important;
}
.interpretation-result__toolbar {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    align-self: stretch;
}
.interpretation-result__toolbar .interpretation-result__pdf-chip {
    flex: 0 0 auto;
}
.interpretation-result__footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid rgba(200, 180, 255, 0.14);
}
.interpretation-result__footer[hidden] {
    display: none !important;
}
.interpretation-result__like-btn {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 40px;
    padding: 8px 16px;
    border: 1px solid rgba(244, 114, 182, 0.28);
    border-radius: 999px;
    background: rgba(55, 35, 70, 0.42);
    color: #e8b4d4;
    font: inherit;
    font-size: 0.88rem;
    line-height: 1.2;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
}
.interpretation-result__like-btn:hover:not(:disabled) {
    background: rgba(244, 114, 182, 0.14);
    border-color: rgba(244, 114, 182, 0.45);
    color: #fbcfe8;
}
.interpretation-result__like-btn:active:not(:disabled) {
    transform: scale(0.98);
}
.interpretation-result__like-btn:disabled,
.interpretation-result__like-btn.is-loading {
    opacity: 0.65;
    cursor: wait;
}
.interpretation-result__like-btn.is-liked {
    color: #f472b6;
    border-color: rgba(244, 114, 182, 0.5);
    background: rgba(244, 114, 182, 0.14);
}
.interpretation-result__like-icon {
    position: relative;
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
}
.interpretation-result__heart {
    position: absolute;
    inset: 0;
    width: 18px;
    height: 18px;
    display: block;
}
.interpretation-result__heart--filled {
    display: none;
}
.interpretation-result__like-btn.is-liked .interpretation-result__heart--outline {
    display: none;
}
.interpretation-result__like-btn.is-liked .interpretation-result__heart--filled {
    display: block;
}
.interpretation-result__like-label {
    white-space: nowrap;
}
.interpretation-result__pdf-chip {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: 40px;
    padding: 8px 14px;
    border: 1px solid rgba(200, 180, 255, 0.24);
    border-radius: 999px;
    background: rgba(45, 35, 85, 0.5);
    color: #d8c8ff;
    font: inherit;
    font-size: 0.84rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    line-height: 1;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
}
.interpretation-result__pdf-chip:hover:not(:disabled) {
    background: rgba(65, 50, 110, 0.78);
    border-color: rgba(212, 181, 255, 0.42);
    color: #f3e8ff;
}
.interpretation-result__pdf-chip:active:not(:disabled) {
    transform: scale(0.98);
}
.interpretation-result__pdf-chip:disabled,
.interpretation-result__pdf-chip.is-loading {
    opacity: 0.45;
    cursor: not-allowed;
}
.interpretation-result__pdf-chip-icon {
    width: 16px;
    height: 16px;
    display: block;
    flex: 0 0 16px;
}
.interpretation-result__pdf-chip-label {
    white-space: nowrap;
}
.interpretation-result__toolbar[hidden] {
    display: none !important;
}
.interpretation-back-actions {
    margin-top: 18px;
    text-align: center;
}
.interpretation-back-actions[hidden] { display: none !important; }
.interpretation-back-btn {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: auto !important;
    min-height: 42px;
    padding: 10px 18px;
    border: 1px solid rgba(200, 180, 255, 0.22);
    border-radius: 999px;
    background: rgba(35, 28, 62, 0.45);
    color: #c9b8f0;
    font: inherit;
    font-size: 0.88rem;
    line-height: 1.2;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.15s ease;
}
.interpretation-back-btn:hover {
    background: rgba(55, 42, 95, 0.62);
    border-color: rgba(212, 181, 255, 0.38);
    color: #ebe2ff;
}
.interpretation-back-btn:active {
    transform: scale(0.98);
}
.interpretation-back-btn__icon {
    width: 16px;
    height: 16px;
    display: block;
    flex: 0 0 16px;
    opacity: 0.9;
}
@media (max-width: 767px) {
    .natal-chart-visual__chart-wrap {
        overflow:visible;
    }
    .natal-chart-settings-toggle {
        display:flex;
        align-items:center;
        justify-content:center;
        position:absolute;
        top:-6px;
        right:-8px;
        z-index:4;
        width:40px;
        height:40px;
        margin:0;
        padding:0;
        border-radius:50%;
        border:1px solid rgba(200,180,255,0.35);
        background:rgba(30,20,60,0.88);
        color:#f0e6ff;
        font-size:0;
        line-height:0;
        cursor:pointer;
        box-shadow:0 4px 14px rgba(0,0,0,0.28);
    }
    .natal-chart-settings-toggle:hover,
    .natal-chart-settings-toggle:focus-visible {
        background:rgba(139,92,246,0.45);
        border-color:rgba(200,180,255,0.55);
        outline:none;
    }
    .natal-chart-settings-toggle.is-active {
        background:rgba(139,92,246,0.55);
        border-color:rgba(220,200,255,0.65);
    }
    .natal-chart-settings-toggle__icon {
        display:flex;
        align-items:center;
        justify-content:center;
        width:100%;
        height:100%;
        font-size:1.5rem;
        line-height:1;
    }
    .natal-chart-settings {
        display:none;
        margin-top:10px;
    }
    .natal-chart-settings.is-open {
        display:flex;
    }
    .natal-chart-settings__mobile-title {
        display:block;
        flex:1 1 100%;
        margin:0 0 6px;
        color:#e8dcff;
        font-size:0.92rem;
        font-weight:600;
        line-height:1.35;
        text-align:center;
    }
    .natal-chart-settings__intro {
        display:none;
    }
    .natal-chart-actions {
        gap:8px;
    }
    .natal-chart-actions .natal-chart-action-btn {
        flex:0 0 40px;
        width:40px;
        min-width:40px;
        height:40px;
        padding:0;
        font-size:0;
        line-height:0;
    }
    .natal-chart-action-btn__icon {
        display:block;
    }
    .natal-chart-action-btn__label {
        display:none;
    }
}
@media (min-width: 768px) {
    .natal-chart-settings {
        display:flex !important;
    }
}
.natal-chart-visual--clickable { cursor:pointer; }
.natal-chart-visual--clickable .natal-chart-svg { pointer-events:none; }
.natal-chart-settings,
.natal-chart-settings * {
    cursor:default;
}
.natal-chart-settings__apply { cursor:pointer; }

.chart-lightbox {
    position:fixed; inset:0; z-index:2000;
    display:flex; align-items:center; justify-content:center;
    padding:16px;
}
.chart-lightbox[hidden] { display:none !important; }
.chart-lightbox__backdrop {
    position:absolute; inset:0;
    background:rgba(2,1,17,0.88);
    cursor:pointer;
}
.chart-lightbox__panel {
    position:relative; z-index:1;
    width:min(98vw, 1340px);
    max-height:92vh;
    display:flex; flex-direction:column;
    background:rgba(20,15,50,0.95);
    border:1px solid rgba(200,180,255,0.35);
    border-radius:20px;
    padding:20px 16px 16px;
    box-shadow:0 0 80px rgba(120,80,200,0.45);
}
.chart-lightbox__title {
    margin:0 40px 12px 0;
    font-size:1.1rem;
    color:#f0d9ff;
    text-align:left;
}
.chart-lightbox__close {
    position:absolute; top:10px; right:10px;
    width:40px; height:40px; min-width:40px;
    margin:0; padding:0;
    border-radius:50%;
    background:rgba(50,30,80,0.9);
    border:1px solid #7b5e9c;
    color:#f0e6ff;
    font-size:1.6rem; line-height:1;
    cursor:pointer;
    box-shadow:none;
    letter-spacing:0;
}
.chart-lightbox__close:hover {
    transform:none;
    background:rgba(139,92,246,0.35);
    box-shadow:0 0 20px rgba(139,92,246,0.4);
}
.chart-lightbox__status,
.chart-lightbox__error {
    text-align:center;
    color:#cbb2ff;
    margin:8px 0 12px;
    font-size:0.95rem;
}
.chart-lightbox__error {
    color:#ffb4b4;
    background:rgba(255,80,80,0.12);
    border:1px solid rgba(255,120,120,0.35);
    border-radius:12px;
    padding:10px 14px;
}
/* Table of aspects width equals main container. */
.chart-lightbox__panel--aspects {
    width: min(90vw, 650px);
    max-width: 650px;
}
.chart-lightbox__panel--aspects .chart-lightbox__scroll--aspects {
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.chart-lightbox__panel--aspects .chart-lightbox__img--aspects {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
    height: auto;
    display: block;
    margin: 0 auto;
}
.natal-chart-visual--minimal {
    margin-bottom: 12px;
}
@media (max-width: 767px), (max-device-width: 767px) {
    .natal-chart-visual--minimal .natal-chart-svg {
        max-width: min(100%, 360px);
    }
}
.chart-lightbox__scroll {
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    flex:1 1 auto;
    min-height:0;
    text-align:center;
}
.chart-lightbox__img {
    display:block;
    width:1305px;
    max-width:none;
    height:auto;
    margin:0 auto;
}
@media (max-width:1320px) {
    .chart-lightbox__img {
        width:100%;
        max-width:1305px;
    }
}
.natal-key-positions {
    margin-top:12px;
    padding-top:10px;
    border-top:1px solid rgba(123,94,156,0.45);
    color:#d1c4e9;
    line-height:1.7;
}
.natal-key-positions__row { margin:6px 0; }
.natal-advanced {
    margin-top:16px;
    color:#cbb2ff;
}
.natal-advanced__summary {
    cursor:pointer;
    padding:8px 0;
    font-weight:600;
    color:#e8d5ff;
}
.natal-advanced__body {
    margin-top:8px;
    padding:12px 0 4px;
}
.natal-advanced__section { margin-bottom:18px; }
.natal-advanced__section:last-child { margin-bottom:0; }
.natal-advanced__heading {
    margin:0 0 8px;
    font-size:0.95rem;
    color:#f0d9ff;
}
.natal-advanced__table { margin-top:0; }

.planet-ruler-mode {
    margin: 0 0 10px;
    padding: 0;
    border: 0;
}
.planet-ruler-mode__legend {
    margin: 0 0 6px;
    padding: 0;
    font-size: 0.82rem;
    font-weight: 600;
    color: #c9b0e8;
}
.planet-ruler-mode__options {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
}
label.planet-ruler-mode__option {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid rgba(123, 94, 156, 0.55);
    background: rgba(48, 34, 88, 0.35);
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
}
label.planet-ruler-mode__option:has(.planet-ruler-mode__input:checked) {
    border-color: rgba(196, 168, 255, 0.75);
    background: rgba(88, 62, 140, 0.55);
}
.planet-ruler-mode__input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.planet-ruler-mode__label {
    font-size: 0.82rem;
    color: #e8d5ff;
    line-height: 1.2;
}
.planet-dignity-legend {
    margin: 10px 0 0;
    font-size: 0.78rem;
    line-height: 1.5;
    color: #b8a0d8;
}
.planet-dignity-legend__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 5px;
}
.planet-dignity-legend__item {
    margin: 0;
    color: inherit;
}
.score-table.natal-advanced__table--planets tbody tr.planet-row--strong,
.score-table.natal-advanced__table--planets tbody tr.planet-row--strong:nth-child(even) {
    background: rgba(76, 175, 80, 0.12);
}
.score-table.natal-advanced__table--planets tbody tr.planet-row--weak,
.score-table.natal-advanced__table--planets tbody tr.planet-row--weak:nth-child(even) {
    background: rgba(244, 67, 54, 0.10);
}
.score-table.natal-advanced__table--planets tbody tr.planet-row--strong:hover {
    background: rgba(76, 175, 80, 0.18);
}
.score-table.natal-advanced__table--planets tbody tr.planet-row--weak:hover {
    background: rgba(244, 67, 54, 0.16);
}
.planet-row__sign {
    font-weight: 600;
    border-left: 3px solid transparent;
}
.planet-row__sign--strong {
    border-left-color: rgba(129, 199, 132, 0.95);
}
.planet-row__sign--weak {
    border-left-color: rgba(239, 154, 154, 0.95);
}
.planet-dignity-badge {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1.35;
    white-space: nowrap;
}
.planet-dignity-badge--strong {
    color: #c8f7c5;
    background: rgba(76, 175, 80, 0.22);
    border: 1px solid rgba(129, 199, 132, 0.45);
}
.planet-dignity-badge--weak {
    color: #ffcdd2;
    background: rgba(244, 67, 54, 0.18);
    border: 1px solid rgba(239, 154, 154, 0.4);
}

/* Natal interpretation preview (guest teaser) */
.interpretation-preview {
    margin-top: 28px;
    padding: 20px 18px;
    border-radius: 18px;
    border: 1px solid rgba(196, 181, 255, 0.28);
    background: linear-gradient(
        160deg,
        rgba(48, 34, 88, 0.55) 0%,
        rgba(32, 24, 68, 0.72) 100%
    );
    text-align: left;
    animation: fadeIn 0.6s;
}
.interpretation-preview[hidden] { display: none !important; }
.interpretation-preview__title {
    margin: 0 0 14px;
    font-size: 1.15rem;
    line-height: 1.35;
    color: #f0d9ff;
}
.interpretation-preview__loading[hidden],
.interpretation-preview__text[hidden],
.interpretation-preview__cta[hidden] { display: none !important; }
.interpretation-preview__skeleton {
    height: 14px;
    margin-bottom: 10px;
    border-radius: 8px;
    background: linear-gradient(
        90deg,
        rgba(180, 160, 255, 0.12) 0%,
        rgba(220, 200, 255, 0.22) 50%,
        rgba(180, 160, 255, 0.12) 100%
    );
    background-size: 200% 100%;
    animation: interpretationPreviewShimmer 1.4s ease-in-out infinite;
}
.interpretation-preview__skeleton--short { width: 72%; }
.interpretation-preview__loading-text {
    margin: 12px 0 0;
    font-size: 0.9rem;
    color: #b8a8d8;
}
.interpretation-preview__text {
    margin: 0 0 16px;
    font-size: 1rem;
    line-height: 1.65;
    color: #e8dcff;
}
.interpretation-preview__cta {
    margin-top: 4px;
    text-align: center;
}
.interpretation-preview__register-btn {
    display: inline-block;
    width: 100%;
    max-width: 420px;
    padding: 14px 18px;
    border-radius: 14px;
    border: 1px solid rgba(196, 181, 255, 0.45);
    background: linear-gradient(
        145deg,
        rgba(124, 92, 255, 0.85) 0%,
        rgba(88, 56, 200, 0.95) 100%
    );
    color: #fff;
    font-size: 0.95rem;
    line-height: 1.4;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    box-shadow: 0 0 20px rgba(139, 92, 246, 0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.interpretation-preview__register-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 0 26px rgba(139, 92, 246, 0.35);
}
.interpretation-preview__login-hint {
    margin: 12px 0 0;
    font-size: 0.88rem;
    color: #b0a0d0;
}
.interpretation-preview__login-hint a {
    color: #a0c4ff;
    text-decoration: none;
}
.interpretation-preview__login-hint a:hover { text-decoration: underline; }
@keyframes interpretationPreviewShimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Natal interpretation actions and states */
.interpretation-section {
    margin-top: 28px;
    text-align: left;
    animation: fadeIn 0.6s;
    scroll-margin-top: 24px;
    scroll-margin-bottom: 24px;
}
.interpretation-section[hidden] { display: none !important; }
.interpretation-how-it-works {
    margin: 20px 0 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(200, 180, 255, 0.2);
    text-align: center;
    color: #d4c0ff;
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.55;
}
.interpretation-how-it-works[hidden] { display: none !important; }
.natal-onboarding-checklist {
    margin: 0 0 24px;
    text-align: left;
}
.natal-onboarding-checklist[hidden] { display: none !important; }
.natal-onboarding-checklist__steps {
    margin-bottom: 0;
}
.natal-onboarding-checklist__steps [data-step].natal-onboarding-checklist__step--current {
    color: #f0e6ff;
    font-weight: 600;
}
.natal-onboarding-checklist__steps [data-step].natal-onboarding-checklist__step--done {
    color: #9a8fc0;
}
.interpret-btn--onboarding-target {
    outline: 2px solid rgba(192, 160, 255, 0.9);
    outline-offset: 2px;
    box-shadow:
        0 0 0 4px rgba(139, 92, 246, 0.22),
        0 0 22px rgba(167, 139, 250, 0.35);
    animation: onboardingTargetPulse 2.2s ease-in-out infinite;
}
@keyframes onboardingTargetPulse {
    0%, 100% {
        box-shadow:
            0 0 0 4px rgba(139, 92, 246, 0.18),
            0 0 16px rgba(167, 139, 250, 0.28);
    }
    50% {
        box-shadow:
            0 0 0 6px rgba(139, 92, 246, 0.32),
            0 0 28px rgba(167, 139, 250, 0.42);
    }
}
@media (prefers-reduced-motion: reduce) {
    .interpret-btn--onboarding-target {
        animation: none;
    }
}
.interpretation-section > .btn-secondary {
    margin-top: 0;
}
.interpretation-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 0;
    scroll-margin-top: 24px;
    overflow: visible;
}
.interpretation-actions[hidden] { display: none !important; }
.interpret-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 4px;
    overflow: visible;
}
.interpret-section-heading {
    margin: 12px 0 0;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #b8a8e0;
    line-height: 1.4;
}
.interpret-section--vip .interpret-section-heading {
    color: #e8c97a;
}
.interpret-section-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: visible;
    padding-top: 6px;
}
.interpret-section-list--nested {
    margin-top: 4px;
}
.interpret-topics-more {
    border: none;
    padding: 0;
    margin: 0;
}
.interpret-topics-more__summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 16px;
    min-height: 44px;
    border-radius: 12px;
    border: 1px dashed rgba(196, 181, 255, 0.35);
    background: rgba(32, 24, 58, 0.45);
    font-size: 0.92rem;
    font-weight: 600;
    color: #d8cff5;
    transition: border-color 0.2s ease, background 0.2s ease;
}
.interpret-topics-more__summary::-webkit-details-marker { display: none; }
.interpret-topics-more__summary::after {
    content: '▼';
    font-size: 0.7rem;
    color: #b8a8e0;
    transition: transform 0.2s ease;
}
.interpret-topics-more[open] .interpret-topics-more__summary::after {
    transform: rotate(180deg);
}
.interpret-topics-more__summary:hover {
    border-color: rgba(220, 210, 255, 0.5);
    background: rgba(42, 32, 72, 0.55);
}
.interpret-vip-toc {
    border: none;
    padding: 0;
    margin: 0 0 4px;
}
.interpret-vip-toc__summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 16px;
    min-height: 44px;
    border-radius: 12px;
    border: 1px dashed rgba(232, 201, 122, 0.38);
    background: rgba(48, 36, 24, 0.4);
    font-size: 0.9rem;
    font-weight: 600;
    color: #f0e0c0;
    transition: border-color 0.2s ease, background 0.2s ease;
}
.interpret-vip-toc__summary::-webkit-details-marker { display: none; }
.interpret-vip-toc__summary::after {
    content: '▼';
    font-size: 0.7rem;
    color: #d4b878;
    transition: transform 0.2s ease;
}
.interpret-vip-toc[open] .interpret-vip-toc__summary::after {
    transform: rotate(180deg);
}
.interpret-vip-toc__summary:hover {
    border-color: rgba(255, 224, 138, 0.55);
    background: rgba(58, 42, 28, 0.5);
}
.interpret-vip-toc__body {
    margin-top: 8px;
    padding: 12px 14px 10px;
    border-radius: 12px;
    border: 1px solid rgba(232, 201, 122, 0.22);
    background: rgba(28, 22, 48, 0.45);
}
.interpret-vip-toc__list {
    margin: 0;
    padding: 0 0 0 1.15rem;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.interpret-vip-toc__item {
    padding: 0;
    line-height: 1.4;
}
.interpret-vip-toc__item-title {
    display: block;
    font-size: 0.88rem;
    font-weight: 600;
    color: #f2ebff;
}
.interpret-vip-toc__item-hint {
    display: block;
    margin-top: 2px;
    font-size: 0.8rem;
    font-weight: 500;
    color: #b8a8e0;
}
.interpret-vip-toc__note {
    margin: 12px 0 0;
    font-size: 0.8rem;
    line-height: 1.45;
    color: #c4b5a8;
}
.interpret-vip-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow: visible;
    padding-top: 6px;
}
.interpret-vip-card {
    appearance: none;
    position: relative;
    overflow: visible;
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    text-align: left;
    padding: 14px 16px;
    min-height: 72px;
    border-radius: 16px;
    border: 1px solid rgba(232, 201, 122, 0.42);
    background: linear-gradient(
        145deg,
        rgba(72, 52, 28, 0.55) 0%,
        rgba(48, 32, 72, 0.88) 55%,
        rgba(36, 28, 68, 0.92) 100%
    );
    cursor: pointer;
    box-shadow:
        0 0 22px rgba(232, 201, 122, 0.12),
        inset 0 1px 0 rgba(255, 240, 200, 0.1);
    transition:
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.2s ease;
}
.interpret-vip-card:hover:not(:disabled) {
    border-color: rgba(255, 224, 138, 0.62);
    box-shadow:
        0 0 28px rgba(232, 201, 122, 0.22),
        inset 0 1px 0 rgba(255, 245, 220, 0.14);
    transform: translateY(-2px);
}
.interpret-vip-card:active:not(:disabled) {
    transform: scale(0.99);
}
.interpret-vip-card__main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.interpret-vip-card__title {
    font-size: 1rem;
    font-weight: 700;
    color: #fff4dc;
    letter-spacing: 0.02em;
    line-height: 1.3;
}
.interpret-vip-card__meta {
    font-size: 0.8rem;
    font-weight: 500;
    color: #d4c4a0;
    line-height: 1.4;
}
.interpret-vip-card .interpret-btn__price {
    margin-top: 2px;
    border-color: rgba(232, 201, 122, 0.45);
    background: rgba(28, 20, 12, 0.45);
}
.interpret-vip-card:disabled,
.interpret-vip-card--locked {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}
.interpret-vip-card--locked .interpret-vip-card__title,
.interpret-vip-card--locked .interpret-vip-card__meta,
.interpret-vip-card--locked .interpret-btn__price-count {
    color: var(--text-muted, #9a8fc0);
}
.interpret-promo-badge {
    position: absolute;
    top: 0;
    left: 14px;
    z-index: 2;
    transform: translateY(-50%);
    padding: 3px 9px;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    line-height: 1.2;
    text-transform: uppercase;
    white-space: nowrap;
    pointer-events: none;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
}
.interpret-promo-badge--hit {
    color: #fff8f8;
    background: linear-gradient(135deg, #e85d7a 0%, #d43d5c 100%);
    border: 1px solid rgba(255, 200, 210, 0.55);
}
.interpret-promo-badge--recommended {
    color: #3d2a08;
    background: linear-gradient(135deg, #fff4d6 0%, #f0d48a 55%, #e8c06a 100%);
    border: 1px solid rgba(255, 240, 200, 0.85);
    text-transform: none;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.interpret-promo-badge--inline {
    position: static;
    transform: none;
    display: inline-block;
    vertical-align: middle;
    margin-left: 2px;
    padding: 2px 8px;
    font-size: 0.62rem;
    line-height: 1.25;
    box-shadow: none;
}
.interpret-btn--hit .interpret-btn__label {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}
.interpret-btn--hit {
    border-width: 2px;
    border-color: rgba(232, 120, 150, 0.55);
    box-shadow:
        0 0 20px rgba(232, 100, 130, 0.2),
        inset 0 1px 0 rgba(255, 220, 230, 0.1);
}
.interpret-btn--hit:hover:not(:disabled) {
    border-color: rgba(255, 160, 185, 0.72);
    box-shadow:
        0 0 28px rgba(232, 100, 130, 0.32),
        inset 0 1px 0 rgba(255, 230, 240, 0.14);
}
.interpret-btn--hit.interpret-btn--locked {
    border-color: rgba(232, 120, 150, 0.22) !important;
}
.interpret-vip-card--recommended {
    margin-top: 10px;
    border-width: 2px;
    border-color: rgba(255, 224, 138, 0.72);
    box-shadow:
        0 0 26px rgba(232, 201, 122, 0.24),
        inset 0 1px 0 rgba(255, 248, 230, 0.16);
}
.interpret-vip-card--recommended:hover:not(:disabled) {
    border-color: rgba(255, 236, 170, 0.88);
    box-shadow:
        0 0 32px rgba(232, 201, 122, 0.34),
        inset 0 1px 0 rgba(255, 252, 240, 0.2);
}
.interpret-vip-card--recommended.interpret-vip-card--locked {
    border-color: rgba(232, 201, 122, 0.22) !important;
}
.interpret-btn {
    appearance: none;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    margin-top: 0;
    width: 100%;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    text-align: left;
    padding: 12px 16px;
    min-height: 52px;
    border-radius: 14px;
    border: 1px solid rgba(196, 181, 255, 0.38);
    background: linear-gradient(
        145deg,
        rgba(52, 38, 92, 0.78) 0%,
        rgba(40, 28, 78, 0.88) 100%
    );
    cursor: pointer;
    box-shadow:
        0 0 18px rgba(139, 92, 246, 0.16),
        inset 0 1px 0 rgba(230, 220, 255, 0.08);
    transition:
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.2s ease,
        background 0.25s ease;
}
.interpret-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(
        120deg,
        transparent 35%,
        rgba(228, 220, 255, 0.1) 50%,
        transparent 65%
    );
    transform: translateX(-130%);
    transition: transform 0.6s ease;
}
.interpret-btn:hover:not(:disabled) {
    border-color: rgba(220, 210, 255, 0.55);
    background: linear-gradient(
        145deg,
        rgba(62, 46, 108, 0.88) 0%,
        rgba(48, 34, 90, 0.92) 100%
    );
    box-shadow:
        0 0 26px rgba(167, 139, 250, 0.3),
        inset 0 1px 0 rgba(240, 235, 255, 0.12);
    transform: translateY(-2px);
}
.interpret-btn:hover:not(:disabled)::before {
    transform: translateX(130%);
}
.interpret-btn:active:not(:disabled) {
    transform: scale(0.98);
}
.interpret-btn--free {
    border-color: rgba(134, 239, 172, 0.4);
    background: linear-gradient(
        145deg,
        rgba(34, 72, 62, 0.72) 0%,
        rgba(42, 38, 88, 0.82) 100%
    );
    box-shadow:
        0 0 18px rgba(74, 222, 128, 0.14),
        0 0 24px rgba(139, 92, 246, 0.1),
        inset 0 1px 0 rgba(220, 255, 240, 0.1);
}
.interpret-btn--free:hover:not(:disabled) {
    border-color: rgba(167, 243, 208, 0.55);
    box-shadow:
        0 0 26px rgba(74, 222, 128, 0.22),
        0 0 32px rgba(167, 139, 250, 0.18);
}
.interpret-btn__label {
    flex: 1;
    min-width: 0;
    font-size: 0.98rem;
    font-weight: 600;
    color: #f2ebff;
    letter-spacing: 0.02em;
    line-height: 1.35;
}
.interpret-btn__price {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid rgba(196, 181, 255, 0.3);
    background: rgba(20, 14, 40, 0.45);
    line-height: 1;
}
.interpret-btn__price-count {
    font-weight: 700;
    font-size: 0.95rem;
    font-variant-numeric: tabular-nums;
    color: #e0d7ff;
}
.interpret-btn__price--gold .interpret-btn__price-count {
    color: #ffe08a;
}
.interpret-btn__meta {
    flex-shrink: 0;
    font-size: 0.82rem;
    font-weight: 600;
    color: #b8a8e0;
}
.interpret-btn--free .interpret-btn__meta {
    color: #a8f0d0;
}
.interpret-btn__free-tag {
    font-weight: 600;
    color: #a8f0d0;
}
.interpret-btn__price--silver .interpret-btn__price-count {
    color: #e8f0ff;
}
.interpret-btn__hint {
    font-size: 0.78rem;
    color: #c9a0a0;
    line-height: 1.35;
    margin-top: 2px;
}
.interpret-btn__hint[hidden] { display: none !important; }
.interpret-btn:disabled {
    cursor: not-allowed;
    box-shadow: none !important;
    transform: none !important;
}
.interpret-btn--locked {
    opacity: 0.45;
    filter: saturate(0.5);
    border-color: rgba(196, 181, 255, 0.2) !important;
    background: linear-gradient(
        145deg,
        rgba(40, 32, 68, 0.55) 0%,
        rgba(32, 26, 58, 0.65) 100%
    ) !important;
}
.interpret-btn--locked .interpret-btn__label {
    color: #b0a0cc;
}
.interpret-btn--locked .interpret-btn__price {
    opacity: 0.75;
}
.interpret-btn--locked .interpret-btn__price-count,
.interpret-btn--locked .interpret-btn__meta,
.interpret-btn--locked .interpret-btn__free-tag {
    color: #8a7aa8;
}
.interpret-btn--free.interpret-btn--locked {
    border-color: rgba(134, 239, 172, 0.15) !important;
}
.interpretation-credits-note {
    margin: 14px 0 0;
    line-height: 1.5;
    text-align: left;
}
.interpretation-credits-note[hidden] { display: none !important; }
.interpretation-chart-required-note {
    margin: 14px 0 0;
    padding: 12px 14px;
    scroll-margin-top: 24px;
    border-radius: 14px;
    border: 1px solid rgba(196, 181, 255, 0.34);
    background: rgba(90, 70, 150, 0.16);
    color: #efe7ff;
    font-size: 1.04rem;
    font-weight: 600;
    line-height: 1.55;
    letter-spacing: 0.01em;
}
.interpretation-credits-note a {
    color: #a0c4ff;
    text-decoration: none;
    border-bottom: 1px solid rgba(160, 196, 255, 0.35);
}
.interpretation-credits-note a:hover {
    color: #d4b5ff;
    border-bottom-color: rgba(212, 181, 255, 0.6);
}
.interpret-confirm-modal {
    border: 1px solid rgba(200, 180, 255, 0.35);
    border-radius: 18px;
    padding: 0;
    max-width: min(480px, calc(100vw - 32px));
    background: linear-gradient(145deg, #1a1235 0%, #2a1f4a 100%);
    color: #e8dcff;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.55);
    margin: auto;
}
.interpret-confirm-modal[open] {
    position: fixed;
    inset: 0;
    margin: auto;
}
.interpret-confirm-modal::backdrop {
    background: rgba(10, 6, 22, 0.72);
    backdrop-filter: blur(4px);
}
.interpret-confirm-form {
    padding: 18px 20px 16px;
    margin: 0;
}
.interpret-confirm-title {
    margin: 0 0 8px;
    font-size: 1.05rem;
    color: #f0e6ff;
}
.interpret-confirm-text {
    margin: 0 0 14px;
    font-size: 0.88rem;
    line-height: 1.45;
    color: #cbb2ff;
}
/* Scoped under .interpret-confirm-form to override global `label { display:block }` */
.interpret-confirm-form .interpret-language-mode {
    margin: 0 0 14px;
    padding: 0;
    border: none;
    min-width: 0;
}
.interpret-confirm-form .interpret-language-mode__legend {
    margin: 0 0 6px;
    padding: 0;
    font-size: 0.82rem;
    font-weight: 600;
    color: #d8c8f8;
    letter-spacing: 0.01em;
}
.interpret-confirm-form .interpret-language-mode__options {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 8px;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.18);
    border: 1px solid rgba(200, 180, 255, 0.12);
}
.interpret-confirm-form label.interpret-language-mode__option {
    display: flex !important;
    flex-direction: row;
    align-items: flex-start;
    gap: 8px;
    margin: 0 !important;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: rgba(255, 255, 255, 0.04);
    cursor: pointer;
    letter-spacing: normal !important;
    width: 100%;
    box-sizing: border-box;
    transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}
@media (prefers-reduced-motion: reduce) {
    .interpret-confirm-form label.interpret-language-mode__option {
        transition: none;
    }
}
.interpret-confirm-form label.interpret-language-mode__option:has(.interpret-language-mode__input:checked) {
    border-color: rgba(200, 180, 255, 0.45);
    background: rgba(200, 180, 255, 0.12);
    box-shadow: 0 0 0 1px rgba(200, 180, 255, 0.08);
}
.interpret-confirm-form .interpret-language-mode__input {
    margin: 2px 0 0 !important;
    flex: 0 0 auto;
    width: 1rem;
    height: 1rem;
    accent-color: #c8b4ff;
    cursor: pointer;
}
.interpret-confirm-form .interpret-language-mode__text {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    gap: 1px;
    min-width: 0;
}
.interpret-confirm-form .interpret-language-mode__label {
    display: block;
    font-size: 0.84rem;
    font-weight: 600;
    color: #f0e6ff;
    line-height: 1.3;
    letter-spacing: normal;
}
.interpret-confirm-form .interpret-language-mode__badge {
    font-size: 0.68rem;
    font-weight: 500;
    color: #b8a0e8;
    text-transform: lowercase;
    letter-spacing: normal;
}
.interpret-confirm-form .interpret-language-mode__desc {
    display: block;
    font-size: 0.74rem;
    line-height: 1.35;
    color: #a894d4;
    letter-spacing: normal;
    overflow-wrap: anywhere;
}
.interpret-confirm-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: stretch;
}
.interpret-confirm-actions .btn-secondary {
    margin-top: 0 !important;
    flex: 1 1 8rem;
    display: inline-block !important;
    padding: 9px 16px !important;
    font-size: 0.88rem !important;
}
.interpret-confirm-yes {
    border: 1.5px solid #6ee7b7 !important;
    background: linear-gradient(180deg, #34d399 0%, #059669 100%) !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em !important;
    text-shadow: 0 1px 2px rgba(0, 40, 24, 0.35) !important;
    box-shadow:
        0 2px 8px rgba(0, 0, 0, 0.35),
        0 0 20px rgba(52, 211, 153, 0.45) !important;
}
.interpret-confirm-yes:hover {
    border-color: #a7f3d0 !important;
    background: linear-gradient(180deg, #4ade80 0%, #10b981 100%) !important;
    color: #ffffff !important;
    box-shadow:
        0 4px 12px rgba(0, 0, 0, 0.4),
        0 0 28px rgba(74, 222, 128, 0.55) !important;
    transform: translateY(-1px);
}
.interpret-confirm-no {
    border-color: rgba(200, 180, 255, 0.35) !important;
    background: rgba(40, 30, 70, 0.85) !important;
    color: #e8dcff !important;
    font-weight: 600 !important;
}
.interpret-confirm-no:hover {
    border-color: rgba(220, 210, 255, 0.5) !important;
    background: rgba(55, 42, 95, 0.95) !important;
    color: #f5f0ff !important;
}

.interpretation-status {
    margin: 20px 0 8px;
    padding: 18px 4px 8px;
    opacity: 0;
    transform: translateY(8px);
}
.interpretation-status[hidden] { display: none !important; }
.interpretation-status--visible {
    opacity: 1;
    transform: translateY(0);
}
.interpretation-status__track {
    height: 3px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}
.interpretation-status__track[hidden] { display: none !important; }
.interpretation-status__bar {
    width: 0%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #5ec8ff 0%, #9b7bff 55%, #c77dff 100%);
    box-shadow: 0 0 12px rgba(126, 200, 255, 0.45);
}
@media (prefers-reduced-motion: no-preference) {
    .interpretation-status {
        transition: opacity 0.35s ease, transform 0.35s ease;
    }
    .interpretation-status__bar {
        transition: width 0.12s linear;
    }
    .interpretation-status--done .interpretation-status__bar {
        transition: width 0.2s ease-out;
    }
}
.interpretation-status__text {
    margin: 0 0 12px;
    font-size: 0.92rem;
    letter-spacing: 0.3px;
    text-align: center;
    line-height: 1.5;
    color: #b8a8d8;
}
.interpretation-status__notice {
    margin: 14px 0 0;
    padding: 12px 14px;
    font-size: 0.86rem;
    line-height: 1.55;
    text-align: left;
    color: #a89cc4;
    border-radius: 14px;
    background: rgba(126, 200, 255, 0.06);
    border: 1px solid rgba(155, 123, 255, 0.22);
}
.interpretation-status__notice[hidden] { display: none !important; }
.interpretation-status--error .interpretation-status__notice {
    display: none !important;
}
.interpretation-status--done .interpretation-status__text {
    color: #d4f0ff;
}
.interpretation-status--error .interpretation-status__text {
    color: #ffb4b4;
    text-align: left;
    padding: 10px 14px;
    border-radius: 14px;
    background: rgba(255, 80, 80, 0.12);
    border: 1px solid rgba(255, 138, 138, 0.35);
}
.interpretation-status--error .interpretation-status__text a {
    color: #a0c4ff;
    text-decoration: none;
    border-bottom: 1px solid rgba(160, 196, 255, 0.35);
}
.interpretation-status--error .interpretation-status__text a:hover {
    color: #d4b5ff;
}
.interpretation-status--error .interpretation-status__text .link-button {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    color: #a0c4ff;
    cursor: pointer;
    text-decoration: underline;
}
.interpretation-success-banner {
    margin: 18px 0 20px;
    text-align: center;
    scroll-margin-top: 24px;
    animation: fadeIn 0.5s;
}
.interpretation-success-banner[hidden] { display: none !important; }
.interpretation-success-banner__badge {
    margin-bottom: 2px;
}
.interpretation-success-banner__text,
.interpretation-success-banner__hint {
    margin: 0 0 10px;
    color: #cbb2ff;
    line-height: 1.55;
    font-size: 0.95rem;
    text-align: left;
}
.interpretation-success-banner__hint[hidden] {
    display: none !important;
}
.interpretation-success-banner__text a,
.interpretation-success-banner__hint a {
    color: #a0c4ff;
    text-decoration: none;
    border-bottom: 1px solid rgba(160, 196, 255, 0.35);
}
.interpretation-success-banner__text a:hover,
.interpretation-success-banner__hint a:hover {
    color: #d4b5ff;
    border-bottom-color: rgba(212, 181, 255, 0.6);
}
.interpretation-success-banner__dismiss {
    margin-top: 6px !important;
    width: auto !important;
    display: inline-block !important;
}
@media (prefers-reduced-motion: reduce) {
    .interpretation-success-banner {
        animation: none;
    }
}

.natal-page {
    text-align: left;
}
.natal-page h1,
.natal-page .subtitle,
.natal-page .page-nav {
    text-align: center;
}
.natal-page > .lessons-intro {
    margin-top: 2rem;
}
.natal-page .subtitle__short {
    display: none;
}

/* Keep theme switch smooth without reflow "jumps" on native controls. */
.natal-page input,
.natal-page select {
    transition:
        background-color 0.25s ease,
        border-color 0.25s ease,
        color 0.25s ease,
        box-shadow 0.25s ease;
}
.natal-page input[type="radio"],
.natal-page input[type="checkbox"] {
    transition: none;
}
@media (max-width: 767px) {
    .natal-page .subtitle__long {
        display: none;
    }
    .natal-page .subtitle__short {
        display: inline;
    }
}

[data-theme="light"] button.natal-chart-submit {
    border-color: rgba(139, 94, 60, 0.35);
    background: linear-gradient(135deg, rgba(245, 235, 218, 0.95) 0%, rgba(232, 218, 195, 0.98) 100%);
    color: var(--text-heading);
    text-shadow: none;
    box-shadow: 0 4px 16px rgba(62, 44, 35, 0.1);
    animation: none;
}
[data-theme="light"] button.natal-chart-submit::before { display: none; }
[data-theme="light"] button.natal-chart-submit:hover:not(:disabled) {
    border-color: rgba(139, 94, 60, 0.5);
    color: var(--text-heading);
    box-shadow: 0 6px 20px rgba(62, 44, 35, 0.14);
}
[data-theme="light"] .natal-title,
[data-theme="light"] .natal-chart-settings__intro,
[data-theme="light"] .natal-chart-settings__mobile-title { color: var(--text-heading); }
[data-theme="light"] .natal-chart-settings-toggle {
    background: var(--bg-elevated);
    border-color: var(--border);
    color: var(--text-heading);
    box-shadow: 0 4px 14px rgba(62, 44, 35, 0.12);
}
[data-theme="light"] .natal-chart-settings-toggle:hover,
[data-theme="light"] .natal-chart-settings-toggle:focus-visible,
[data-theme="light"] .natal-chart-settings-toggle.is-active {
    background: rgba(139, 94, 60, 0.12);
    border-color: rgba(139, 94, 60, 0.35);
}
[data-theme="light"] .natal-warning {
    color: var(--warning);
    background: rgba(154, 107, 46, 0.1);
    border-color: rgba(154, 107, 46, 0.28);
}
[data-theme="light"] .natal-chart-settings__field,
[data-theme="light"] .natal-chart-settings__check { color: var(--text-label); }
[data-theme="light"] .natal-chart-settings {
    background: linear-gradient(
        145deg,
        rgba(245, 235, 218, 0.92) 0%,
        rgba(239, 227, 207, 0.95) 100%
    );
    border-color: rgba(139, 94, 60, 0.28);
    box-shadow: 0 4px 14px rgba(62, 44, 35, 0.08);
}
[data-theme="light"] .natal-chart-settings__intro {
    color: var(--text-heading);
    font-weight: 600;
}

[data-theme="light"] .interpret-btn {
    border: 1px solid rgba(107, 74, 138, 0.32);
    background: linear-gradient(
        165deg,
        #fffdf8 0%,
        #fff8ee 48%,
        #f7efe3 100%
    );
    box-shadow:
        0 2px 10px rgba(62, 44, 35, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}
[data-theme="light"] .interpret-btn:hover:not(:disabled) {
    border-color: rgba(107, 74, 138, 0.48);
    background: linear-gradient(
        165deg,
        #ffffff 0%,
        #fffaf2 50%,
        #f5ebe0 100%
    );
    box-shadow:
        0 6px 18px rgba(62, 44, 35, 0.14),
        0 0 0 1px rgba(107, 74, 138, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 1);
    transform: translateY(-2px);
}
[data-theme="light"] .interpret-btn--free {
    border-color: rgba(56, 118, 78, 0.42);
    background: linear-gradient(
        165deg,
        #f6fcf8 0%,
        #f0f8f2 45%,
        #f7efe3 100%
    );
    box-shadow:
        0 2px 10px rgba(56, 118, 78, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}
[data-theme="light"] .interpret-btn--free:hover:not(:disabled) {
    border-color: rgba(56, 118, 78, 0.58);
    background: linear-gradient(
        165deg,
        #fafffc 0%,
        #f2faf5 50%,
        #f5ebe0 100%
    );
    box-shadow:
        0 6px 18px rgba(56, 118, 78, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 1);
}
[data-theme="light"] .interpret-btn__label {
    color: var(--text-heading);
    font-weight: 700;
}
[data-theme="light"] .interpret-btn__price {
    background: rgba(107, 74, 138, 0.1);
    border-color: rgba(107, 74, 138, 0.22);
}
[data-theme="light"] .interpret-btn__price-count { color: var(--text-heading); font-weight: 800; }
[data-theme="light"] .interpret-btn__price--gold .interpret-btn__price-count { color: #9a6b2e; }
[data-theme="light"] .interpret-btn__meta { color: var(--text-muted); font-weight: 600; }
[data-theme="light"] .interpret-btn--free .interpret-btn__meta,
[data-theme="light"] .interpret-btn__free-tag { color: #2f6b45; font-weight: 700; }
[data-theme="light"] .interpret-btn__price--silver .interpret-btn__price-count { color: #5c4030; }
[data-theme="light"] .interpret-btn--hit {
    border-color: rgba(196, 72, 98, 0.48);
    box-shadow:
        0 4px 16px rgba(196, 72, 98, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.95);
}
[data-theme="light"] .interpret-btn--hit:hover:not(:disabled) {
    border-color: rgba(196, 72, 98, 0.62);
    box-shadow:
        0 6px 20px rgba(196, 72, 98, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 1);
}
[data-theme="light"] .interpret-promo-badge--hit {
    color: #fff;
    background: linear-gradient(135deg, #e85d7a 0%, #c93d58 100%);
    border-color: rgba(255, 220, 228, 0.7);
}
[data-theme="light"] .interpret-vip-card--recommended {
    border-color: rgba(168, 118, 28, 0.72);
    box-shadow:
        0 6px 22px rgba(180, 130, 40, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.55);
}
[data-theme="light"] .interpret-vip-card--recommended:hover:not(:disabled) {
    border-color: rgba(140, 96, 20, 0.82);
    box-shadow:
        0 8px 28px rgba(180, 130, 40, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
[data-theme="light"] .interpret-promo-badge--recommended {
    color: #5c3d12;
    background: linear-gradient(135deg, #fff8e8 0%, #f5dfa0 100%);
    border-color: rgba(168, 118, 28, 0.35);
}
[data-theme="light"] .interpret-btn--locked {
    opacity: 0.52;
    border-color: rgba(107, 74, 138, 0.16) !important;
    background: linear-gradient(165deg, #f3ece2 0%, #ebe3d6 100%) !important;
    box-shadow: none !important;
}
[data-theme="light"] .interpret-btn--locked .interpret-btn__label,
[data-theme="light"] .interpret-btn--locked .interpret-btn__price-count,
[data-theme="light"] .interpret-btn--locked .interpret-btn__meta,
[data-theme="light"] .interpret-btn--locked .interpret-btn__free-tag { color: var(--text-muted); }
[data-theme="light"] .interpret-section-heading {
    color: var(--text-muted);
    font-weight: 700;
}
[data-theme="light"] .interpret-section--vip .interpret-section-heading {
    color: #8a5f18;
    letter-spacing: 0.08em;
}
[data-theme="light"] .interpretation-how-it-works {
    color: var(--text-body);
    font-weight: 500;
    border-top-color: rgba(120, 100, 160, 0.15);
}
[data-theme="light"] .natal-onboarding-checklist__steps [data-step].natal-onboarding-checklist__step--current {
    color: var(--text-heading);
}
[data-theme="light"] .natal-onboarding-checklist__steps [data-step].natal-onboarding-checklist__step--done {
    color: var(--text-muted);
}
[data-theme="light"] .interpret-btn--onboarding-target {
    outline-color: rgba(139, 94, 60, 0.75);
    box-shadow:
        0 0 0 4px rgba(139, 94, 60, 0.14),
        0 0 18px rgba(168, 118, 28, 0.22);
}
[data-theme="light"] .interpret-vip-toc__summary {
    border: 1px dashed rgba(168, 118, 28, 0.38);
    background: rgba(255, 248, 232, 0.9);
    color: #6b4510;
    box-shadow: 0 1px 6px rgba(180, 130, 40, 0.08);
}
[data-theme="light"] .interpret-vip-toc__summary::after { color: #9a6b2e; }
[data-theme="light"] .interpret-vip-toc__summary:hover {
    border-color: rgba(168, 118, 28, 0.55);
    background: #fffbf0;
}
[data-theme="light"] .interpret-vip-toc__body {
    border-color: rgba(168, 118, 28, 0.22);
    background: rgba(255, 248, 232, 0.75);
}
[data-theme="light"] .interpret-vip-toc__item-title { color: var(--text-heading); }
[data-theme="light"] .interpret-vip-toc__item-hint { color: var(--text-muted); }
[data-theme="light"] .interpret-vip-toc__note { color: var(--text-muted); }
[data-theme="light"] .interpret-topics-more__summary {
    border: 1px dashed rgba(107, 74, 138, 0.32);
    background: rgba(255, 250, 242, 0.92);
    color: var(--text-heading);
    box-shadow: 0 1px 6px rgba(62, 44, 35, 0.06);
}
[data-theme="light"] .interpret-topics-more__summary:hover {
    border-color: rgba(107, 74, 138, 0.45);
    background: #fffdf8;
}
[data-theme="light"] .interpret-topics-more__summary::after { color: var(--text-muted); }
[data-theme="light"] .interpret-vip-card {
    border: 1px solid rgba(196, 145, 45, 0.52);
    background: linear-gradient(
        145deg,
        #fff9eb 0%,
        #f8e8c4 38%,
        #edd39a 72%,
        #e4c47e 100%
    );
    box-shadow:
        0 4px 20px rgba(180, 130, 40, 0.18),
        0 0 0 1px rgba(255, 248, 230, 0.65) inset,
        inset 0 1px 0 rgba(255, 255, 255, 0.55);
}
[data-theme="light"] .interpret-vip-card:hover:not(:disabled) {
    border-color: rgba(168, 118, 28, 0.68);
    background: linear-gradient(
        145deg,
        #fffbf0 0%,
        #faecc8 40%,
        #f0d492 75%,
        #e8c878 100%
    );
    box-shadow:
        0 8px 26px rgba(180, 130, 40, 0.26),
        0 0 0 1px rgba(255, 252, 240, 0.8) inset,
        inset 0 1px 0 rgba(255, 255, 255, 0.7);
    transform: translateY(-2px);
}
[data-theme="light"] .interpret-vip-card__title {
    color: #5c3d12;
    font-weight: 800;
}
[data-theme="light"] .interpret-vip-card__meta { color: #7a5a28; }
[data-theme="light"] .interpret-vip-card .interpret-btn__price {
    background: rgba(92, 61, 18, 0.12);
    border-color: rgba(168, 118, 28, 0.35);
}
[data-theme="light"] .interpret-vip-card .interpret-btn__price-count {
    color: #6b4510;
    font-weight: 800;
}
[data-theme="light"] .interpret-vip-card--locked {
    opacity: 0.55;
    border-color: rgba(196, 145, 45, 0.22) !important;
    background: linear-gradient(145deg, #f3e8d4 0%, #e8dcc4 100%) !important;
    box-shadow: none !important;
}
[data-theme="light"] .interpret-vip-card--locked .interpret-vip-card__title,
[data-theme="light"] .interpret-vip-card--locked .interpret-vip-card__meta,
[data-theme="light"] .interpret-vip-card--locked .interpret-btn__price-count { color: var(--text-muted); }
[data-theme="light"] .interpretation-credits-note a {
    color: var(--link);
    border-bottom-color: rgba(107, 74, 138, 0.35);
}
[data-theme="light"] .interpretation-chart-required-note {
    border-color: rgba(107, 74, 138, 0.28);
    background: rgba(107, 74, 138, 0.1);
    color: var(--text-heading);
}
[data-theme="light"] .interpretation-credits-note a:hover {
    color: var(--link-hover);
    border-bottom-color: rgba(107, 74, 138, 0.55);
}
[data-theme="light"] .interpret-confirm-modal {
    background: linear-gradient(145deg, #faf3e6 0%, #f5ebda 100%);
    color: var(--text-primary);
    border-color: var(--border);
    box-shadow: 0 16px 48px rgba(62, 44, 35, 0.18);
}
[data-theme="light"] .interpret-confirm-modal::backdrop {
    background: var(--bg-overlay);
}
[data-theme="light"] .interpret-confirm-title { color: var(--text-heading); }
[data-theme="light"] .interpret-confirm-text { color: var(--text-body); }
[data-theme="light"] .interpret-confirm-form .interpret-language-mode__legend {
    color: var(--text-muted);
}
[data-theme="light"] .interpret-confirm-form .interpret-language-mode__options {
    background: rgba(255, 255, 255, 0.65);
    border-color: var(--border);
}
[data-theme="light"] .interpret-confirm-form label.interpret-language-mode__option {
    background: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .interpret-confirm-form label.interpret-language-mode__option:has(.interpret-language-mode__input:checked) {
    border-color: rgba(107, 74, 138, 0.4);
    background: rgba(107, 74, 138, 0.07);
    box-shadow: 0 0 0 1px rgba(107, 74, 138, 0.06);
}
[data-theme="light"] .interpret-confirm-form .interpret-language-mode__label {
    color: var(--text-heading);
}
[data-theme="light"] .interpret-confirm-form .interpret-language-mode__badge,
[data-theme="light"] .interpret-confirm-form .interpret-language-mode__desc {
    color: var(--text-muted);
}
[data-theme="light"] .interpret-confirm-no {
    border-color: var(--border) !important;
    background: #efe3cf !important;
    color: var(--text-primary) !important;
}
[data-theme="light"] .interpretation-status__text { color: var(--text-muted); }
[data-theme="light"] .interpretation-status__notice {
    color: var(--text-muted);
    background: rgba(107, 74, 138, 0.06);
    border-color: rgba(107, 74, 138, 0.18);
}
[data-theme="light"] .interpretation-status--done .interpretation-status__text { color: var(--text-heading); }
[data-theme="light"] .interpretation-status--error .interpretation-status__text {
    color: var(--error);
    background: var(--error-bg);
    border-color: var(--error-border);
}
[data-theme="light"] .interpretation-status--error .interpretation-status__text a,
[data-theme="light"] .interpret-btn__hint a.interpret-btn__topup {
    color: var(--text-link);
}
[data-theme="light"] .interpretation-success-banner__text,
[data-theme="light"] .interpretation-success-banner__hint { color: var(--text-muted); }
[data-theme="light"] .interpretation-success-banner__text a,
[data-theme="light"] .interpretation-success-banner__hint a {
    color: var(--link);
    border-bottom-color: rgba(107, 74, 138, 0.35);
}
[data-theme="light"] .interpretation-success-banner__text a:hover,
[data-theme="light"] .interpretation-success-banner__hint a:hover {
    color: var(--link-hover);
    border-bottom-color: rgba(107, 74, 138, 0.55);
}
[data-theme="light"] .chart-lightbox__backdrop { background: var(--bg-overlay); }
[data-theme="light"] .chart-lightbox__panel {
    background: var(--bg-modal);
    border-color: var(--border);
    box-shadow: 0 12px 40px rgba(62, 44, 35, 0.18);
}
[data-theme="light"] .chart-lightbox__title { color: var(--text-heading); }
[data-theme="light"] .chart-lightbox__close {
    background: var(--bg-card);
    border-color: var(--border-strong);
    color: var(--text-primary);
    box-shadow: none;
}
[data-theme="light"] .chart-lightbox__close:hover {
    background: rgba(139, 94, 60, 0.12);
    box-shadow: none;
}
[data-theme="light"] .chart-lightbox__status,
[data-theme="light"] .chart-lightbox__error,
[data-theme="light"] .natal-advanced,
[data-theme="light"] .natal-advanced__summary,
[data-theme="light"] .natal-advanced__heading { color: var(--text-label); }
[data-theme="light"] .natal-key-positions {
    border-top-color: var(--border);
    color: var(--text-body);
}
[data-theme="light"] .chart-lightbox__error { color: var(--error); }
[data-theme="light"] .natal-chart-frame__overlay { background: rgba(217, 210, 197, 0.55); }
[data-theme="light"] .natal-advanced {
    margin-top: 18px;
    padding: 10px 12px 6px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: rgba(249, 241, 227, 0.82);
}
[data-theme="light"] .natal-advanced__summary {
    color: var(--text-heading);
    font-weight: 700;
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(196, 168, 130, 0.16);
}
[data-theme="light"] .natal-advanced__heading {
    color: var(--text-heading);
    font-weight: 700;
}
[data-theme="light"] .natal-advanced__table th {
    color: var(--text-heading);
    background: rgba(196, 168, 130, 0.24);
}
[data-theme="light"] .natal-advanced__table td {
    color: var(--text-body);
}
[data-theme="light"] .planet-ruler-mode__legend {
    color: var(--text-muted);
}
[data-theme="light"] label.planet-ruler-mode__option {
    border-color: var(--border-strong);
    background: rgba(255, 255, 255, 0.72);
}
[data-theme="light"] label.planet-ruler-mode__option:has(.planet-ruler-mode__input:checked) {
    border-color: rgba(139, 94, 60, 0.55);
    background: rgba(196, 168, 130, 0.28);
}
[data-theme="light"] .planet-ruler-mode__label {
    color: var(--text-body);
}
[data-theme="light"] .planet-dignity-legend,
[data-theme="light"] .planet-dignity-legend__item {
    color: var(--text-muted);
}
[data-theme="light"] .score-table.natal-advanced__table--planets tbody tr.planet-row--strong,
[data-theme="light"] .score-table.natal-advanced__table--planets tbody tr.planet-row--strong:nth-child(even) {
    background: rgba(76, 175, 80, 0.14);
}
[data-theme="light"] .score-table.natal-advanced__table--planets tbody tr.planet-row--weak,
[data-theme="light"] .score-table.natal-advanced__table--planets tbody tr.planet-row--weak:nth-child(even) {
    background: rgba(244, 67, 54, 0.08);
}
[data-theme="light"] .score-table.natal-advanced__table--planets tbody tr.planet-row--strong:hover {
    background: rgba(76, 175, 80, 0.2);
}
[data-theme="light"] .score-table.natal-advanced__table--planets tbody tr.planet-row--weak:hover {
    background: rgba(244, 67, 54, 0.12);
}
[data-theme="light"] .planet-dignity-badge--strong {
    color: #2e7d32;
    background: rgba(76, 175, 80, 0.16);
    border-color: rgba(76, 175, 80, 0.35);
}
[data-theme="light"] .planet-dignity-badge--weak {
    color: #c62828;
    background: rgba(244, 67, 54, 0.12);
    border-color: rgba(244, 67, 54, 0.28);
}

/* Guest interpretation preview — light theme */
[data-theme="light"] .interpretation-preview {
    border: 1px solid var(--border-strong);
    background: var(--bg-card);
    box-shadow: var(--shadow-surface);
}
[data-theme="light"] .interpretation-preview__title {
    color: var(--text-heading);
    font-size: 1.05rem;
    font-weight: 700;
}
[data-theme="light"] .natal-guest-deepseek-notice {
    color: var(--text-muted);
}
[data-theme="light"] .natal-guest-deepseek-notice a {
    color: var(--text-link);
}
[data-theme="light"] .natal-guest-deepseek-notice a:hover {
    color: var(--text-link-hover);
}
[data-theme="light"] .interpretation-preview__loading-text {
    color: var(--text-muted);
}
[data-theme="light"] .interpretation-preview__skeleton {
    background: linear-gradient(
        90deg,
        rgba(196, 168, 130, 0.18) 0%,
        rgba(196, 168, 130, 0.32) 50%,
        rgba(196, 168, 130, 0.18) 100%
    );
    background-size: 200% 100%;
}
[data-theme="light"] .interpretation-preview__text {
    color: var(--text-body);
    font-size: 1.02rem;
}
[data-theme="light"] .interpretation-preview__register-btn {
    max-width: 100%;
    border-color: rgba(107, 68, 35, 0.35);
    background: linear-gradient(
        145deg,
        var(--btn-gradient-start) 0%,
        var(--btn-gradient-end) 100%
    );
    color: #fffaf2;
    box-shadow: 0 4px 16px var(--btn-shadow);
}
[data-theme="light"] .interpretation-preview__register-btn:hover {
    box-shadow: 0 6px 20px var(--btn-hover-shadow);
}
[data-theme="light"] .interpretation-preview__login-hint {
    color: var(--text-muted);
}
[data-theme="light"] .interpretation-preview__login-hint a {
    color: var(--text-link);
}
[data-theme="light"] .interpretation-preview__login-hint a:hover {
    color: var(--text-link-hover);
}

[data-theme="light"] .interpretation-result__footer {
    border-top-color: rgba(92, 61, 46, 0.14);
}
[data-theme="light"] .interpretation-result__like-btn {
    color: #7a3056;
    background: #fde8f0;
    border-color: rgba(122, 48, 86, 0.32);
}
[data-theme="light"] .interpretation-result__like-btn:hover:not(:disabled) {
    color: #6b2448;
    background: #fcd9e7;
    border-color: rgba(107, 36, 72, 0.42);
}
[data-theme="light"] .interpretation-result__like-btn.is-liked {
    color: #9d174d;
    background: #fce7f3;
    border-color: rgba(157, 23, 77, 0.38);
}
[data-theme="light"] .interpretation-result__pdf-chip {
    color: var(--text-heading);
    background: #fff9f2;
    border-color: rgba(92, 61, 46, 0.24);
}
[data-theme="light"] .interpretation-result__pdf-chip:hover:not(:disabled) {
    color: var(--text-on-surface);
    background: #f5ebe0;
    border-color: rgba(92, 61, 46, 0.34);
}
[data-theme="light"] .interpretation-back-btn {
    color: var(--text-heading);
    background: #fff9f2;
    border-color: rgba(92, 61, 46, 0.22);
}
[data-theme="light"] .interpretation-back-btn:hover {
    color: var(--text-on-surface);
    background: #f5ebe0;
    border-color: rgba(92, 61, 46, 0.32);
}
