.legal-hero { background: #0f1a0f; padding: 52px 24px 44px; text-align: center; }
.legal-hero h1 { font-size: clamp(26px,4vw,40px); font-weight: 800; letter-spacing: -1px; color: #fff; margin-bottom: 10px; }
.legal-hero p { font-size: 14px; color: rgba(255,255,255,.45); }
.legal-wrap { max-width: 760px; margin: 0 auto; padding: 48px 24px 80px; }
.legal-toc { background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 14px; padding: 20px 24px; margin-bottom: 48px; }
.legal-toc-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #166534; margin-bottom: 12px; }
.legal-toc ol { padding-left: 18px; display: flex; flex-direction: column; gap: 6px; }
.legal-toc li a { font-size: 14px; color: #166534; text-decoration: none; font-weight: 500; }
.legal-toc li a:hover { text-decoration: underline; }
.legal-section { margin-bottom: 44px; scroll-margin-top: 80px; }
.legal-section h2 { font-size: 20px; font-weight: 700; letter-spacing: -.3px; margin-bottom: 14px; color: #0f1a0f; padding-bottom: 10px; border-bottom: 2px solid #f0fdf4; }
.legal-section p { font-size: 15px; color: #52525b; line-height: 1.8; margin-bottom: 12px; }
.legal-section p:last-child { margin-bottom: 0; }
.legal-section ul { padding-left: 20px; display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.legal-section li { font-size: 15px; color: #52525b; line-height: 1.7; }
.legal-section a { color: #16a34a; text-decoration: underline; }
.legal-section strong { color: #0f1a0f; font-weight: 600; }
.legal-highlight { background: #fffbeb; border-left: 3px solid #f59e0b; border-radius: 0 10px 10px 0; padding: 14px 18px; margin-bottom: 16px; }
.legal-highlight p { font-size: 14px; color: #92400e; margin: 0; line-height: 1.7; }
.legal-updated { font-size: 13px; color: #a1a1aa; margin-bottom: 40px; padding-bottom: 24px; border-bottom: 1px solid #e5e7eb; }
.legal-contact-box { background: #0f1a0f; border-radius: 14px; padding: 28px; color: #fff; }
.legal-contact-box h3 { font-size: 17px; font-weight: 700; margin-bottom: 8px; }
.legal-contact-box p { font-size: 14px; color: rgba(255,255,255,.6); line-height: 1.7; }
.legal-contact-box a { color: #4ade80; }
