:root { color-scheme: light; font-family: "Plus Jakarta Sans", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: #f4f7f6; color: #17211d; }
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; background: #f4f7f6; }
a { color: inherit; }
.legal-header { position: sticky; top: 0; z-index: 20; border-bottom: 1px solid #dbe5e0; background: rgba(255,255,255,.96); backdrop-filter: blur(12px); }
.legal-header__inner { width: min(1180px, calc(100% - 40px)); min-height: 68px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.legal-brand { display: inline-flex; align-items: center; gap: 10px; color: #087f5b; font-size: 1.15rem; font-weight: 800; text-decoration: none; }
.legal-brand__mark { width: 13px; height: 13px; border-radius: 50%; background: #18b889; box-shadow: 0 0 0 5px #dff7ef; }
.legal-header__links { display: flex; align-items: center; gap: 18px; color: #52615a; font-size: .86rem; font-weight: 700; }
.legal-header__links a { text-decoration: none; }
.legal-header__links a:hover, .legal-header__links a:focus-visible { color: #087f5b; }
.legal-layout { width: min(1180px, calc(100% - 40px)); margin: 0 auto; padding: 56px 0 72px; display: grid; grid-template-columns: 250px minmax(0,760px); justify-content: center; gap: 56px; }
.legal-aside { align-self: start; position: sticky; top: 100px; }
.legal-aside__label { margin: 0 0 14px; color: #087f5b; font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.legal-toc { display: grid; gap: 3px; max-height: calc(100vh - 145px); overflow: auto; padding-right: 8px; }
.legal-toc a { padding: 7px 10px; border-left: 2px solid #dbe5e0; color: #607069; font-size: .78rem; line-height: 1.35; text-decoration: none; }
.legal-toc a:hover, .legal-toc a:focus-visible { border-color: #18a778; color: #087f5b; background: #ebf8f3; }
.legal-article { min-width: 0; padding: 44px 52px 56px; border: 1px solid #dbe5e0; border-radius: 8px; background: #fff; box-shadow: 0 18px 48px rgba(38,70,57,.08); }
.legal-eyebrow { margin: 0 0 12px; color: #087f5b; font-size: .75rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.legal-title { max-width: 680px; margin: 0; color: #10281f; font-size: 3rem; line-height: 1.08; letter-spacing: 0; }
.legal-updated { display: inline-flex; margin: 18px 0 0; padding: 7px 10px; border: 1px solid #cfe7dd; border-radius: 6px; background: #f1faf6; color: #38705b; font-size: .78rem; font-weight: 700; }
.legal-divider { height: 1px; margin: 34px 0 30px; background: #e2ebe7; }
.legal-content { color: #35443e; font-family: Georgia, "Times New Roman", serif; font-size: 1rem; line-height: 1.78; }
.legal-content h2 { margin: 42px 0 14px; scroll-margin-top: 96px; color: #123c2d; font-family: "Plus Jakarta Sans", Inter, system-ui, sans-serif; font-size: 1.2rem; line-height: 1.35; letter-spacing: 0; }
.legal-content h2:first-child { margin-top: 0; }
.legal-content p { margin: 0 0 15px; }
.legal-content .legal-clause { padding-left: 18px; border-left: 2px solid #e1eee8; }
.legal-status { min-height: 120px; display: grid; place-items: center; color: #68766f; font-size: .9rem; text-align: center; }
.legal-status.is-error { color: #a33a3a; }
.legal-footer { border-top: 1px solid #dbe5e0; background: #fff; }
.legal-footer__inner { width: min(1180px, calc(100% - 40px)); min-height: 94px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 24px; color: #68766f; font-size: .78rem; }
.legal-footer__links { display: flex; gap: 16px; }
.legal-footer__links a:hover, .legal-footer__links a:focus-visible { color: #087f5b; }
@media (max-width: 900px) { .legal-layout { grid-template-columns: minmax(0,760px); padding-top: 32px; } .legal-aside { position: static; } .legal-toc { grid-auto-flow: column; grid-auto-columns: minmax(190px,260px); overflow-x: auto; max-height: none; padding: 0 0 10px; } }
@media (max-width: 640px) { .legal-header__inner, .legal-layout, .legal-footer__inner { width: min(100% - 28px,760px); } .legal-header__inner { min-height: 62px; } .legal-header__links a:not(.is-current) { display: none; } .legal-layout { gap: 24px; padding: 24px 0 48px; } .legal-article { padding: 30px 22px 38px; } .legal-title { font-size: 2rem; } .legal-content { font-size: .96rem; line-height: 1.72; } .legal-footer__inner { padding: 24px 0; align-items: flex-start; flex-direction: column; } }
