:root {
    --legal-text: #3f3f46;
    --legal-muted: #71717a;
    --legal-accent: #9d174d;
    --legal-accent-hover: #db2777;
    --legal-soft: #fdf2f8;
    --legal-border: #f9a8d4;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: "Malgun Gothic", "Apple SD Gothic Neo", sans-serif;
    font-size: 15px;
    line-height: 1.75;
    color: var(--legal-text);
    background: #fff;
}

.legal-wrap {
    max-width: 720px;
    margin: 0 auto;
    padding: 28px 18px 48px;
}

.legal-wrap h1 {
    font-size: 1.45rem;
    font-weight: 700;
    color: var(--legal-accent);
    margin-bottom: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--legal-border);
}

.legal-wrap h2 {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--legal-accent);
    margin-top: 1.65rem;
    margin-bottom: 0.6rem;
}

.legal-wrap p {
    margin-bottom: 0.9rem;
}

.legal-wrap .intro {
    margin-bottom: 1.25rem;
}

.legal-dl {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.35rem 1rem;
    align-items: baseline;
    margin-bottom: 1rem;
}

.legal-dl dt {
    font-weight: 600;
    color: var(--legal-text);
}

.legal-dl dd {
    margin: 0;
}

.legal-list {
    margin: 0.5rem 0 1rem 1.15rem;
    padding: 0;
}

.legal-list li {
    margin-bottom: 0.45rem;
}

.legal-list li::marker {
    color: var(--legal-accent);
}

.legal-address {
    font-style: normal;
    line-height: 1.65;
}

.legal-card p {
    margin-bottom: 0.35rem;
}

.legal-card p:last-child {
    margin-bottom: 0;
}

.legal-company-name {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--legal-accent);
    margin-bottom: 0.35rem;
}

.legal-card h2.legal-card-heading {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
    font-size: 0.95rem;
}

.legal-note {
    font-size: 0.8125rem;
    color: var(--legal-muted);
    line-height: 1.65;
    margin-top: 0.5rem;
}

.site-footer-legal {
    margin-top: 2.25rem;
    padding-top: 1.35rem;
    border-top: 1px solid var(--legal-border);
    font-size: 0.8125rem;
    text-align: center;
}

.site-footer-legal nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 4px 0;
    margin-bottom: 0.65rem;
}

.site-footer-legal a {
    color: var(--legal-accent);
    text-decoration: none;
    padding: 4px 8px;
    border-radius: 4px;
}

.site-footer-legal a:hover {
    color: var(--legal-accent-hover);
    background: rgba(236, 72, 153, 0.08);
}

.site-footer-legal .sep {
    color: #d4a5c4;
    user-select: none;
    padding: 0 2px;
}

.site-footer-legal .company-line {
    color: var(--legal-muted);
    margin-bottom: 0.75rem;
}

.back-top {
    display: inline-block;
    margin-bottom: 1rem;
    font-size: 0.875rem;
    color: var(--legal-accent);
    text-decoration: none;
}

.back-top:hover {
    text-decoration: underline;
}
