.legal-page { max-width: 860px; margin: 0 auto; padding: 6rem 3rem 8rem; }

.legal-breadcrumb { font-size: 13px; color: var(--gray-mid); margin-bottom: 3rem; display: flex; align-items: center; gap: 8px; }
.legal-breadcrumb a { text-decoration: none; color: var(--gray-mid); transition: color 0.15s; }
.legal-breadcrumb a:hover { color: var(--black); }
.legal-breadcrumb svg { width: 14px; height: 14px; flex-shrink: 0; opacity: 0.4; }

.legal-tag { display: inline-flex; align-items: center; gap: 7px; padding: 6px 16px; border: 1px solid #C8BDB0; border-radius: 999px; font-size: 11px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-mid); margin-bottom: 1.5rem; }

.legal-hero-title { font-family: var(--font-display); font-size: clamp(2.4rem, 5vw, 3.8rem); font-weight: 800; letter-spacing: -0.03em; line-height: 1.06; color: var(--black); margin-bottom: 1.5rem; }

.legal-hero-desc { font-size: 17px; line-height: 1.65; color: var(--gray-mid); max-width: 56ch; margin-bottom: 4rem; padding-bottom: 4rem; border-bottom: 1px solid #DDD5C8; }

.legal-section { margin-bottom: 3.5rem; }

.legal-section-title { font-family: var(--font-display); font-size: 1.25rem; font-weight: 700; color: var(--black); letter-spacing: -0.02em; margin-bottom: 1rem; }

.legal-section p { font-size: 15px; line-height: 1.8; color: var(--gray-mid); margin-bottom: 0.75rem; }
.legal-section p:last-child { margin-bottom: 0; }

.legal-section ul { list-style: none; padding: 0; margin: 0.5rem 0 0; }
.legal-section ul li { font-size: 15px; line-height: 1.8; color: var(--gray-mid); padding-left: 1.25rem; position: relative; }
.legal-section ul li::before { content: '·'; position: absolute; left: 0; color: var(--accent); font-weight: 700; }

.legal-section a { color: var(--black); text-underline-offset: 3px; }

.legal-divider { border: none; border-top: 1px solid #DDD5C8; margin: 3.5rem 0; }

.legal-contact-block { background: var(--gray-light); border-radius: 16px; padding: 2rem 2.25rem; display: flex; flex-direction: column; gap: 0.4rem; margin-top: 1rem; }
.legal-contact-block strong { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--black); display: block; margin-bottom: 0.5rem; }
.legal-contact-block span, .legal-contact-block a { font-size: 15px; color: var(--gray-mid); line-height: 1.7; text-decoration: none; }
.legal-contact-block a:hover { color: var(--black); }

.legal-sub-title { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--black); letter-spacing: -0.01em; margin-bottom: 0.6rem; margin-top: 1.75rem; }
.legal-sub-title:first-child { margin-top: 0; }

.rights-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin-top: 0.5rem; }
.rights-item { background: var(--gray-light); border-radius: 10px; padding: 1rem 1.25rem; }
.rights-item strong { font-size: 13px; font-weight: 600; color: var(--black); display: block; margin-bottom: 3px; }
.rights-item span { font-size: 12px; color: var(--gray-mid); }

.legal-link-banner { background: #2C1F14; border-radius: 16px; padding: 2rem 2.25rem; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; margin-top: 4rem; text-decoration: none; transition: opacity 0.15s; }
.legal-link-banner:hover { opacity: 0.9; }
.legal-link-banner-text { display: flex; flex-direction: column; gap: 0.25rem; }
.legal-link-banner span:first-child { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(253,250,246,0.4); }
.legal-link-banner span:last-child { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: #FDFAF6; }
.legal-link-banner svg { width: 22px; height: 22px; stroke: rgba(253,250,246,0.6); fill: none; stroke-width: 1.5; stroke-linecap: round; flex-shrink: 0; }

@media (max-width: 860px) {
  .legal-page { padding: 3.5rem 1.5rem 5rem; }
  .rights-grid { grid-template-columns: 1fr; }
  .legal-link-banner { flex-direction: column; align-items: flex-start; }
}
