.legal-container {
    max-width: 900px;
    margin: 4rem auto;
    padding: 0 1rem;
}

.legal-nav {
    background-color: var(--bg-light);
    border-radius: 8px 8px 0 0;
    border: 1px solid var(--border-color);
    border-bottom: none;
    padding: 0;
    margin-bottom: 0;
    display: flex;
}

.legal-nav-button {
    padding: 15px 25px;
    font-size: 1rem;
    font-weight: 500;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    border-bottom: 3px solid transparent;
    transition: all 0.2s ease;
}

.legal-nav-button.active {
    border-bottom-color: var(--red-gradient-start);
    color: var(--text-color);
}

.legal-content {
    padding: 2rem 2.5rem;
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 0 0 8px 8px;
    margin-top: 0;
}

.legal-section {
    display: none;
}

.legal-section.active {
    display: block;
}

.legal-content h1 {
    color: var(--text-color);
    font-size: 1.8rem;
    margin-top: 0;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--border-color);
}

.legal-content h2 {
    color: var(--text-color);
    font-size: 1.4rem;
    margin-top: 35px;
    margin-bottom: 15px;
}

.legal-content p, .legal-content ul, .legal-content ol {
    color: var(--text-secondary);
    line-height: 1.7;
    margin-bottom: 15px;
}

.legal-content ul, .legal-content ol {
    padding-left: 25px;
}

.legal-content li {
    margin-bottom: 8px;
}

/* Layout shell */
.legal-wrapper {
    --side-width: 250px;
    max-width: 1250px;
    margin: clamp(2.5rem,5vh,4rem) auto;
    display: grid;
    grid-template-columns: var(--side-width) 1fr;
    gap: 2.2rem;
    padding: 0 1.25rem;
}

.legal-side {
    position: sticky;
    top: 90px;
    align-self: start;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.legal-brand h1 {
    font-size: 1.3rem;
    margin: 0 0 .2rem;
}
.legal-version {
    font-size: .7rem;
    letter-spacing:.5px;
    text-transform:uppercase;
    color: var(--text-secondary);
}

.legal-tabs {
    display:flex;
    flex-direction:column;
    background: var(--bg-light);
    border:1px solid var(--border-color);
    border-radius:10px;
    overflow:hidden;
}

.legal-tab-button {
    background:none;
    border:0;
    padding:.9rem 1rem;
    text-align:left;
    color: var(--text-secondary);
    font-weight:500;
    font-size:.85rem;
    cursor:pointer;
    position:relative;
    transition:background .2s,color .2s;
}
.legal-tab-button:hover { background:#1f1f1f; color:var(--text-color); }
.legal-tab-button.active {
    background:linear-gradient(90deg,#1f1f1f,#252525);
    color:var(--text-color);
}
.legal-tab-button.active::after {
    content:"";
    position:absolute;
    right:0; top:10%; bottom:10%;
    width:3px;
    background: var(--red-gradient-start);
    border-radius:2px;
}

.legal-tools { display:flex; flex-direction:column; gap:.6rem; }
.legal-mini-btn {
    background:#222;
    border:1px solid var(--border-color);
    color: var(--text-secondary);
    padding:.55rem .75rem;
    font-size:.65rem;
    letter-spacing:.5px;
    text-transform:uppercase;
    border-radius:6px;
    cursor:pointer;
    transition:background .25s,color .25s,border-color .25s;
}
.legal-mini-btn:hover { background:#2a2a2a; color: var(--text-color); }

.legal-main {
    background: rgba(29,29,29,0.9);
    border:1px solid var(--border-color);
    border-radius:18px;
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    padding:2.2rem 2.6rem 2.8rem;
    min-height:900px; /* fallback; JS will raise if needed */
    position:relative;
}

/* Stabilize .legal-main width regardless of tab content */
.legal-main {
    width:100%;
    box-sizing:border-box;
}

/* Constrain readable line length (optional but keeps it identical per tab) */
.legal-main .legal-doc {
    max-width: 820px;
    margin: 0 auto;
}

/* Keep layout from recomputing a narrower intrinsic width */
.legal-wrapper { width:100%; }

/* If any long unbroken strings appear, allow wrapping so they don't force expansion */
.legal-main, .legal-main * { overflow-wrap: anywhere; }

.legal-doc { display:none; animation: fadeIn .35s ease; }
.legal-doc.active { display:block; }

@keyframes fadeIn { from {opacity:0; transform:translateY(6px);} to {opacity:1; transform:translateY(0);} }

.legal-doc header h2 { font-size:1.65rem; margin:0 0 .4rem; }
.update-date {
    font-size:.75rem;
    letter-spacing:.6px;
    text-transform:uppercase;
    color: var(--text-secondary);
    margin:0 0 1.2rem;
}

.legal-doc section { margin:1.8rem 0; }
.legal-doc section:first-of-type { margin-top:0; }

.legal-doc h3 {
    font-size:1.05rem;
    margin:0 0 .75rem;
    position:relative;
}
.legal-doc h3::before {
    content:"#";
    color: var(--red-gradient-start);
    margin-right:.45rem;
    font-weight:600;
}
.legal-doc h4 { font-size:.9rem; margin:1.2rem 0 .5rem; color: var(--text-color); }

.legal-doc p,
.legal-doc li {
    color: var(--text-secondary);
    line-height:1.55;
    font-size:.87rem;
}
.legal-doc ul,
.legal-doc ol {
    padding-left:1.3rem;
    margin:.6rem 0 1rem;
}
.legal-doc li { margin:.35rem 0; }

.contact-box {
    background:#181818;
    border:1px solid var(--border-color);
    padding:1rem 1.15rem 1.1rem;
    border-radius:8px;
    font-size:.8rem;
    line-height:1.5;
    margin:1.2rem 0 0;
}
.contact-box strong { color: var(--text-color); font-weight:600; }

.placeholder {
    background:rgba(255,235,59,0.18);
    padding:1px 5px;
    border-radius:4px;
    font-family:monospace;
    font-size:.75rem;
    color:#fff;
}

@media (max-width: 980px) {
    .legal-wrapper { grid-template-columns:1fr; gap:1.6rem; }
    .legal-side {
        position:static;
        top:auto;
        flex-direction:row;
        flex-wrap:wrap;
        align-items:flex-start;
        background:#1b1b1b;
        padding:1rem 1rem .9rem;
        border:1px solid var(--border-color);
        border-radius:14px;
    }
    .legal-brand { flex:1 1 120px; }
    .legal-tabs { flex:1 1 220px; flex-direction:row; }
    .legal-tab-button { flex:1; text-align:center; }
    .legal-tools { flex:1 1 160px; }
}

@media (max-width:640px) {
    .legal-main { padding:1.5rem 1.3rem 1.9rem; border-radius:14px; }
    .legal-doc header h2 { font-size:1.35rem; }
    .legal-doc h3 { font-size:.95rem; }
}