/**
 * GAISHA legal pages — Privacy, PDPA, Terms.
 */

.gaisha-page--legal {
    --gaisha-legal-max: 900px;
}

.gaisha-page-hero--legal .gaisha-page-hero__subtitle {
    max-width: 42rem;
}

.gaisha-legal-body {
    position: relative;
    padding: 0 0 clamp(3rem, 6vw, 4.5rem);
}

.gaisha-legal-body::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 12% 18%, rgba(56, 237, 255, 0.08), transparent 34%),
        radial-gradient(circle at 88% 72%, rgba(163, 134, 255, 0.08), transparent 38%);
}

.gaisha-legal-shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: clamp(20px, 3vw, 32px);
    align-items: start;
    width: min(100%, calc(var(--gaisha-legal-max) + 220px + 32px));
    margin: 0 auto;
}

.gaisha-legal-nav {
    position: sticky;
    top: 96px;
    padding: 18px 16px;
    border-radius: var(--gaisha-radius-card, 18px);
    border: 1px solid rgba(166, 201, 255, 0.12);
    background: rgba(8, 14, 32, 0.72);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.gaisha-legal-nav__label {
    margin: 0 0 12px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(48, 222, 220, 0.88);
}

.gaisha-legal-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 8px;
}

.gaisha-legal-nav__list a {
    display: block;
    padding: 0.35rem 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: rgba(206, 222, 244, 0.78);
    text-decoration: none;
    transition: color 0.2s ease;
}

.gaisha-legal-nav__list a:hover,
.gaisha-legal-nav__list a:focus-visible {
    color: rgba(223, 252, 255, 0.96);
}

.gaisha-legal-content {
    display: grid;
    gap: 16px;
    max-width: var(--gaisha-legal-max);
}

.gaisha-legal-meta,
.gaisha-legal-section {
    padding: clamp(20px, 3vw, 28px);
}

.gaisha-legal-meta__company {
    margin: 0 0 6px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(48, 222, 220, 0.88);
}

.gaisha-legal-meta__updated {
    margin: 0 0 14px;
    font-size: 0.8125rem;
    color: rgba(186, 210, 240, 0.72);
}

.gaisha-legal-meta__text,
.gaisha-legal-section p {
    margin: 0 0 14px;
    font-size: 1rem;
    line-height: 1.75;
    color: rgba(206, 222, 244, 0.86);
}

.gaisha-legal-meta__text:last-child,
.gaisha-legal-section p:last-child {
    margin-bottom: 0;
}

.gaisha-legal-section__title {
    margin: 0 0 14px;
    font-size: clamp(1.15rem, 2.2vw, 1.35rem);
    line-height: 1.3;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--gaisha-text, #f4f9ff);
}

.gaisha-legal-section__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
}

.gaisha-legal-section__list li {
    position: relative;
    padding-left: 1rem;
    font-size: 0.9375rem;
    line-height: 1.65;
    color: rgba(206, 222, 244, 0.84);
}

.gaisha-legal-section__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.62em;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: linear-gradient(135deg, #30dedc, #8b35ff);
    box-shadow: 0 0 10px rgba(56, 237, 255, 0.24);
}

.gaisha-legal-contact__card {
    margin-top: 8px;
    padding: 16px 18px;
    border-radius: 14px;
    border: 1px solid rgba(48, 222, 220, 0.16);
    background:
        radial-gradient(circle at top right, rgba(56, 237, 255, 0.08), transparent 42%),
        rgba(4, 10, 24, 0.55);
}

.gaisha-legal-contact__company {
    margin: 0 0 8px;
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--gaisha-text, #f4f9ff);
}

.gaisha-legal-contact__email {
    display: inline-block;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: rgba(48, 222, 220, 0.92);
    text-decoration: none;
}

.gaisha-legal-contact__email:hover,
.gaisha-legal-contact__email:focus-visible {
    color: #dffcff;
}

.gaisha-legal-contact__line {
    margin: 8px 0 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: rgba(206, 222, 244, 0.84);
}

.gaisha-legal-related {
    padding-top: 8px;
}

.gaisha-legal-related__label {
    margin: 0 0 10px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(186, 210, 240, 0.72);
}

.gaisha-legal-related__links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.gaisha-legal-related__links a {
    display: inline-flex;
    align-items: center;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    border: 1px solid rgba(166, 201, 255, 0.16);
    background: rgba(8, 14, 32, 0.72);
    font-size: 0.8125rem;
    font-weight: 600;
    color: rgba(223, 252, 255, 0.9);
    text-decoration: none;
    transition:
        border-color 0.2s ease,
        background 0.2s ease,
        transform 0.2s ease;
}

.gaisha-legal-related__links a:hover,
.gaisha-legal-related__links a:focus-visible {
    border-color: rgba(48, 222, 220, 0.42);
    background: rgba(8, 14, 32, 0.92);
    transform: translateY(-1px);
}

@media (max-width: 960px) {
    .gaisha-legal-shell {
        grid-template-columns: 1fr;
        width: min(100%, var(--gaisha-legal-max));
    }

    .gaisha-legal-nav {
        position: static;
    }

    .gaisha-legal-nav__list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px 12px;
    }
}

@media (max-width: 640px) {
    .gaisha-legal-nav__list {
        grid-template-columns: 1fr;
    }

    .gaisha-legal-meta,
    .gaisha-legal-section {
        padding: 18px 16px;
    }

    .gaisha-legal-meta__text,
    .gaisha-legal-section p {
        font-size: 0.9375rem;
    }
}
