/* ===== LEGAL PAGES COMMON ===== */
.legal-page { max-width: 860px; margin: 0 auto; }
.legal-page h2 { font-size: var(--font-size-2xl); font-weight: 700; color: var(--color-title); margin: var(--space-10) 0 var(--space-4); padding-bottom: var(--space-3); border-bottom: 2px solid var(--color-border); }
.legal-page h3 { font-size: var(--font-size-lg); font-weight: 700; color: var(--color-title); margin: var(--space-6) 0 var(--space-3); }
.legal-page h4 { font-size: var(--font-size-base); font-weight: 700; color: var(--color-title); margin: var(--space-4) 0 var(--space-2); }
.legal-page p { color: var(--color-body); line-height: var(--line-height-relaxed); margin-bottom: var(--space-4); }
.legal-page ol, .legal-page ul { color: var(--color-body); line-height: var(--line-height-relaxed); margin-bottom: var(--space-4); padding-left: var(--space-6); }
.legal-page li { margin-bottom: var(--space-2); }
.legal-page .legal-meta { background: var(--color-bg-light); border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6); margin-bottom: var(--space-8); display: flex; flex-wrap: wrap; gap: var(--space-6); font-size: var(--font-size-sm); color: var(--color-muted); }
.legal-page .legal-meta span { display: flex; align-items: center; gap: var(--space-2); }
.legal-page .legal-highlight { background: rgba(196,30,58,0.06); border-left: 3px solid var(--color-primary); border-radius: 0 var(--radius-md) var(--radius-md) 0; padding: var(--space-4) var(--space-5); margin: var(--space-4) 0; }
.legal-page .legal-highlight p { margin-bottom: 0; color: var(--color-title); font-weight: 500; }
.legal-page .legal-table { width: 100%; border-collapse: collapse; margin: var(--space-4) 0 var(--space-6); font-size: var(--font-size-sm); }
.legal-page .legal-table th { background: var(--color-bg-light); padding: var(--space-3) var(--space-4); text-align: left; font-weight: 700; color: var(--color-title); border: 1px solid var(--color-border); }
.legal-page .legal-table td { padding: var(--space-3) var(--space-4); border: 1px solid var(--color-border); color: var(--color-body); vertical-align: top; }
.legal-page .legal-table tr:nth-child(even) td { background: var(--color-bg-light); }
.legal-toc { background: var(--color-bg-light); border-radius: var(--radius-xl); padding: var(--space-6); margin-bottom: var(--space-8); }
.legal-toc-title { font-weight: 700; color: var(--color-title); margin-bottom: var(--space-4); font-size: var(--font-size-base); }
.legal-toc ol { margin-bottom: 0; }
.legal-toc li { margin-bottom: var(--space-1); }
.legal-toc a { color: var(--color-primary); font-size: var(--font-size-sm); }
.legal-toc a:hover { text-decoration: underline; }
.legal-contact-box { background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark)); border-radius: var(--radius-xl); padding: var(--space-8); color: white; margin-top: var(--space-10); }
.legal-contact-box h3 { color: white; margin-top: 0; border: none; }
.legal-contact-box p { color: rgba(255,255,255,0.85); margin-bottom: var(--space-2); }
.legal-contact-box a { color: white; font-weight: 600; }
.complaint-channel { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-4); margin: var(--space-6) 0; }
.complaint-channel-card { background: white; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: var(--space-6); text-align: center; }
.complaint-channel-card .icon { font-size: 36px; margin-bottom: var(--space-3); }
.complaint-channel-card .name { font-weight: 700; color: var(--color-title); margin-bottom: var(--space-2); }
.complaint-channel-card .number { font-size: var(--font-size-2xl); font-weight: 900; color: var(--color-primary); margin-bottom: var(--space-2); }
.complaint-channel-card .desc { font-size: var(--font-size-xs); color: var(--color-muted); }
.qualification-card { background: white; border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: var(--space-6); margin: var(--space-6) 0; }
.qualification-card-title { font-size: var(--font-size-lg); font-weight: 700; color: var(--color-title); margin-bottom: var(--space-5); display: flex; align-items: center; gap: var(--space-3); }
.qualification-card-title i { color: var(--color-primary); }
.qualification-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-4); }
.qualification-item { display: flex; flex-direction: column; gap: 4px; }
.qualification-label { font-size: var(--font-size-xs); color: var(--color-muted); }
.qualification-value { font-size: var(--font-size-sm); color: var(--color-title); font-weight: 600; }
.report-btn { display: inline-flex; align-items: center; gap: var(--space-2); padding: 6px 14px; border: 1px solid var(--color-primary); border-radius: var(--radius-md); color: var(--color-primary); font-size: var(--font-size-sm); font-weight: 600; transition: all var(--transition-fast); background: transparent; cursor: pointer; }
.report-btn:hover { background: var(--color-primary); color: white; }
.agreement-check { display: flex; align-items: flex-start; gap: var(--space-3); font-size: var(--font-size-sm); color: var(--color-body); cursor: pointer; line-height: 1.6; }
.agreement-check input[type="checkbox"] { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; accent-color: var(--color-primary); cursor: pointer; }
.agreement-check a { color: var(--color-primary); }
.agreement-check a:hover { text-decoration: underline; }
.post-notice { background: #FFF8F8; border: 1px solid #FECACA; border-radius: var(--radius-xl); padding: var(--space-5) var(--space-6); margin-bottom: var(--space-6); }
.post-notice-title { font-weight: 700; color: var(--color-title); margin-bottom: var(--space-3); display: flex; align-items: center; gap: var(--space-2); }
.post-notice-title i { color: var(--color-primary); }
.post-notice ul { margin-bottom: 0; padding-left: var(--space-5); }
.post-notice li { font-size: var(--font-size-sm); color: var(--color-body); margin-bottom: var(--space-1); }
.post-notice .notice-warning { font-size: var(--font-size-sm); color: var(--color-primary); font-weight: 600; margin-top: var(--space-3); margin-bottom: 0; }
