﻿

.gzd-login-ritual {
    position: fixed;
    inset: 0;
    z-index: 12000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right))
        max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
    pointer-events: none;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.28s ease, visibility 0.28s ease;
}

.gzd-login-ritual.is-active {
    pointer-events: auto;
    opacity: 1;
    visibility: visible;
}

.gzd-login-ritual__veil {
    position: absolute;
    inset: 0;
    background: rgba(26, 15, 8, 0.28);
    backdrop-filter: blur(2px);
}

.gzd-login-ritual--compact .gzd-login-ritual__veil {
    background: rgba(26, 15, 8, 0.22);
}

.gzd-login-ritual__stage {
    position: relative;
    z-index: 1;
    width: min(22rem, 92vw);
    transform: translateY(1.25rem) scale(0.94);
    opacity: 0;
}

.gzd-login-ritual--compact .gzd-login-ritual__stage {
    width: min(17.5rem, 90vw);
    transform: translateY(0.75rem) scale(0.96);
}

.gzd-login-ritual.is-active .gzd-login-ritual__stage {
    animation: gzd-login-ritual-rise 0.55s cubic-bezier(0.34, 1.45, 0.64, 1) forwards;
}

@keyframes gzd-login-ritual-rise {
    to {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
}

.gzd-login-ritual__scroll {
    position: relative;
    padding: 1.35rem 1.25rem 1.15rem;
    background:
        linear-gradient(180deg, #FFFDF6 0%, #F7EBD0 42%, #EDD9B8 100%);
    border: 2px solid rgba(166, 133, 37, 0.55);
    border-radius: 0.35rem 0.35rem 0.65rem 0.65rem;
    box-shadow:
        0 18px 40px rgba(61, 36, 14, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.65);
    overflow: hidden;
}

.gzd-login-ritual--compact .gzd-login-ritual__scroll {
    padding: 1.1rem 1rem 0.95rem;
    box-shadow:
        0 12px 28px rgba(61, 36, 14, 0.22),
        inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.gzd-login-ritual--fail.gzd-login-ritual--compact .gzd-login-ritual__scroll {
    border-color: rgba(139, 26, 18, 0.42);
    background: linear-gradient(180deg, #FFFCFA 0%, #F8E8E2 45%, #EDD5CC 100%);
}

.gzd-login-ritual--success.gzd-login-ritual--compact .gzd-login-ritual__scroll {
    border-color: rgba(74, 124, 89, 0.45);
    background: linear-gradient(180deg, #FCFFFD 0%, #E8F3EB 45%, #D4E8DA 100%);
}

.gzd-login-ritual__scroll::before,
.gzd-login-ritual__scroll::after {
    content: "";
    position: absolute;
    left: 0.65rem;
    right: 0.65rem;
    height: 0.45rem;
    border-radius: 999px;
    background: linear-gradient(90deg, #8B6914, #DAB030, #8B6914);
    opacity: 0.85;
}

.gzd-login-ritual__scroll::before { top: -0.18rem; }
.gzd-login-ritual__scroll::after { bottom: -0.18rem; }

.gzd-login-ritual__mount {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3.5rem;
    opacity: 0.14;
    background:
        linear-gradient(180deg, transparent, rgba(74, 124, 89, 0.35)),
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 48' preserveAspectRatio='none'%3E%3Cpath fill='%234A7C59' d='M0 48 L0 28 Q30 8 60 24 T120 20 T180 26 T240 18 L240 48 Z'/%3E%3C/svg%3E") center bottom / 100% 100% no-repeat;
    pointer-events: none;
}

.gzd-login-ritual__seal-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 0.85rem;
    min-height: 4.5rem;
}

.gzd-login-ritual__seal {
    width: 4.25rem;
    height: 4.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "STKaiti", "KaiTi", "Noto Serif SC", serif;
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #8B1A12;
    border: 3px solid rgba(139, 26, 18, 0.85);
    border-radius: 0.35rem;
    transform: rotate(-8deg) scale(1.8);
    opacity: 0;
    box-shadow: inset 0 0 0 2px rgba(255, 220, 210, 0.35);
}

.gzd-login-ritual--fail .gzd-login-ritual__seal {
    animation: gzd-login-seal-stamp 0.72s cubic-bezier(0.22, 1.15, 0.36, 1) 0.12s forwards;
}

.gzd-login-ritual--success .gzd-login-ritual__seal {
    color: #2D5A3A;
    border-color: rgba(45, 90, 58, 0.88);
    box-shadow: inset 0 0 0 2px rgba(210, 240, 220, 0.45);
    animation: gzd-login-seal-pass 0.85s cubic-bezier(0.22, 1.1, 0.36, 1) 0.08s forwards;
}

@keyframes gzd-login-seal-stamp {
    0% { transform: rotate(-8deg) scale(2.2); opacity: 0; }
    55% { transform: rotate(-6deg) scale(0.92); opacity: 1; }
    72% { transform: rotate(-7deg) scale(1.06); opacity: 1; }
    100% { transform: rotate(-7deg) scale(1); opacity: 0.96; }
}

@keyframes gzd-login-seal-pass {
    0% { transform: rotate(-8deg) scale(0.4); opacity: 0; }
    60% { transform: rotate(-5deg) scale(1.08); opacity: 1; }
    100% { transform: rotate(-5deg) scale(1); opacity: 1; }
}

.gzd-login-ritual__title {
    margin: 0 0 0.45rem;
    text-align: center;
    font-family: "STKaiti", "KaiTi", "Noto Serif SC", serif;
    font-size: 1.125rem;
    letter-spacing: 0.22em;
    color: #5D3A1A;
}

.gzd-login-ritual__text {
    margin: 0;
    text-align: center;
    font-family: "Microsoft YaHei", sans-serif;
    font-size: 0.875rem;
    line-height: 1.65;
    color: #6B4423;
}

.gzd-login-ritual__ink {
    position: absolute;
    width: 6rem;
    height: 6rem;
    border-radius: 50%;
    pointer-events: none;
    opacity: 0;
}

.gzd-login-ritual__ink--1 {
    top: 12%;
    left: -8%;
    background: radial-gradient(circle, rgba(139, 26, 18, 0.18), transparent 68%);
}

.gzd-login-ritual__ink--2 {
    bottom: 8%;
    right: -10%;
    background: radial-gradient(circle, rgba(122, 62, 26, 0.14), transparent 70%);
}

.gzd-login-ritual--fail.is-active .gzd-login-ritual__ink {
    animation: gzd-login-ink-spread 1.1s ease-out 0.2s forwards;
}

.gzd-login-ritual--compact.gzd-login-ritual--fail .gzd-login-ritual__petals,
.gzd-login-ritual--compact.gzd-login-ritual--fail .gzd-login-ritual__mount {
    display: none;
}

.gzd-login-ritual--compact .gzd-login-ritual__seal-wrap {
    margin-bottom: 0.65rem;
    min-height: 3.75rem;
}

.gzd-login-ritual--compact .gzd-login-ritual__seal {
    width: 3.5rem;
    height: 3.5rem;
    font-size: 1.15rem;
}

.gzd-login-ritual--compact .gzd-login-ritual__title {
    font-size: 1.05rem;
    letter-spacing: 0.16em;
}

.gzd-login-ritual--compact .gzd-login-ritual__text {
    font-size: 0.8125rem;
    line-height: 1.55;
    max-width: 14rem;
    margin-left: auto;
    margin-right: auto;
}

.gzd-login-ritual--success.is-active .gzd-login-ritual__ink--1 {
    background: radial-gradient(circle, rgba(74, 124, 89, 0.2), transparent 68%);
    animation: gzd-login-ink-spread 1.2s ease-out 0.15s forwards;
}

@keyframes gzd-login-ink-spread {
    from { opacity: 0; transform: scale(0.6); }
    to { opacity: 1; transform: scale(1.15); }
}

.gzd-login-ritual__petals {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}

.gzd-login-ritual__petal {
    position: absolute;
    width: 0.45rem;
    height: 0.75rem;
    background: linear-gradient(180deg, #FFE370, #DAB030);
    border-radius: 50% 50% 50% 0;
    opacity: 0;
}

.gzd-login-ritual--success.is-active .gzd-login-ritual__petal {
    animation: gzd-login-petal-fall 1.6s ease-out forwards;
}

.gzd-login-ritual__petal:nth-child(1) { left: 18%; top: -5%; animation-delay: 0.2s; }
.gzd-login-ritual__petal:nth-child(2) { left: 42%; top: -8%; animation-delay: 0.35s; }
.gzd-login-ritual__petal:nth-child(3) { left: 68%; top: -6%; animation-delay: 0.5s; }
.gzd-login-ritual__petal:nth-child(4) { left: 82%; top: -4%; animation-delay: 0.65s; }

@keyframes gzd-login-petal-fall {
    0% { opacity: 0; transform: translateY(0) rotate(0deg); }
    15% { opacity: 0.85; }
    100% { opacity: 0; transform: translateY(5rem) rotate(140deg); }
}

.gzd-login-ritual__close {
    display: block;
    width: 100%;
    margin-top: 1rem;
    padding: 0.55rem 1rem;
    font-family: "Microsoft YaHei", sans-serif;
    font-size: 0.8125rem;
    color: #7A3E1A;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(122, 62, 26, 0.25);
    border-radius: 999px;
    cursor: pointer;
}

.gzd-login-ritual--fail .gzd-login-ritual__close {
    color: #8b2618;
    border-color: rgba(139, 26, 18, 0.28);
    background: rgba(255, 252, 250, 0.75);
}

.gzd-login-ritual--success .gzd-login-ritual__close {
    color: #2d5a3a;
    border-color: rgba(74, 124, 89, 0.35);
    background: rgba(252, 255, 253, 0.85);
}

.gzd-login-ritual__close:hover {
    background: rgba(255, 255, 255, 0.85);
}

.gzd-login-ritual__close:focus-visible {
    outline: 2px solid #DAB030;
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .gzd-login-ritual__stage,
    .gzd-login-ritual__seal,
    .gzd-login-ritual__ink,
    .gzd-login-ritual__petal {
        animation: none !important;
    }

    .gzd-login-ritual.is-active .gzd-login-ritual__stage {
        transform: none;
        opacity: 1;
    }

    .gzd-login-ritual__seal {
        transform: rotate(-6deg) scale(1);
        opacity: 1;
    }
}


.portal-access-notice.is-ritual-enter {
    animation: portal-access-ritual-in 0.85s cubic-bezier(0.34, 1.35, 0.64, 1) both;
}

.portal-access-notice.is-ritual-enter .portal-access-notice__mark {
    animation: portal-access-seal-pop 0.7s cubic-bezier(0.34, 1.4, 0.64, 1) 0.15s both;
}

@keyframes portal-access-ritual-in {
    0% {
        opacity: 0;
        transform: translateY(-0.5rem) scale(0.92);
        filter: blur(2px);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
        filter: none;
    }
}

@keyframes portal-access-seal-pop {
    0% { transform: scale(0.4) rotate(-12deg); opacity: 0; }
    70% { transform: scale(1.12) rotate(4deg); opacity: 1; }
    100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
