/* Legal pages (terms.php / privacy.php) — dark professional design */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    background: #111;
    color: #d0d0d0;
    font-family: 'Segoe UI', system-ui, sans-serif;
    min-height: 100vh;
}

.legal-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ── Top bar ─────────────────────────────────────────────────────── */
.legal-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 32px;
    height: 64px;
    background: rgba(20,20,20,.98);
    border-bottom: 1px solid rgba(255,255,255,.08);
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(8px);
}

.legal-back {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #aaa;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: color .2s;
    min-width: 120px;
}
.legal-back:hover { color: #e15829; }

.legal-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    letter-spacing: .5px;
}
.legal-logo img {
    height: 36px;
    width: auto;
}

.legal-topbar-right {
    min-width: 120px;
    text-align: right;
}
.legal-nav-link {
    color: #888;
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    transition: color .2s;
}
.legal-nav-link:hover { color: #e15829; }

/* ── Hero ────────────────────────────────────────────────────────── */
.legal-hero {
    background: linear-gradient(160deg, #1c1c1c 0%, #141414 60%, rgba(225,88,41,.06) 100%);
    border-bottom: 1px solid rgba(255,255,255,.07);
    padding: 64px 32px 52px;
    text-align: center;
}

.legal-hero-icon {
    width: 72px;
    height: 72px;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(225,88,41,.2), rgba(255,107,61,.1));
    border: 1px solid rgba(225,88,41,.35);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    color: #e15829;
    margin: 0 auto 24px;
    box-shadow: 0 8px 30px rgba(225,88,41,.18);
}
.legal-hero-icon.privacy {
    background: linear-gradient(135deg, rgba(76,175,80,.2), rgba(56,142,60,.1));
    border-color: rgba(76,175,80,.35);
    color: #4CAF50;
    box-shadow: 0 8px 30px rgba(76,175,80,.15);
}

.legal-hero h1 {
    font-size: 36px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 10px;
    letter-spacing: -.3px;
}

.legal-hero p {
    font-size: 16px;
    color: #888;
    max-width: 480px;
    margin: 0 auto;
}

/* ── Content container ───────────────────────────────────────────── */
.legal-container {
    max-width: 860px;
    margin: 0 auto;
    padding: 48px 24px;
    width: 100%;
    flex: 1;
}

.legal-card {
    background: rgba(28,28,28,.9);
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 20px;
    padding: 44px 48px;
    box-shadow: 0 12px 50px rgba(0,0,0,.35);
}

/* ── Body content (user-supplied HTML) ───────────────────────────── */
.legal-body h1,
.legal-body h2,
.legal-body h3 {
    color: #fff;
    margin: 1.8em 0 .7em;
    font-weight: 700;
    line-height: 1.3;
}
.legal-body h1 { font-size: 26px; }
.legal-body h2 {
    font-size: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.legal-body h3 { font-size: 17px; color: #e0e0e0; }

.legal-body p {
    margin: 0 0 16px;
    line-height: 1.75;
    color: #c0c0c0;
}

.legal-body ul,
.legal-body ol {
    margin: 0 0 18px;
    padding-left: 28px;
    color: #c0c0c0;
}
.legal-body li {
    margin-bottom: 8px;
    line-height: 1.65;
}

.legal-body strong { color: #fff; }
.legal-body em { color: #bbb; font-style: italic; }

.legal-body a {
    color: #e15829;
    text-decoration: none;
    border-bottom: 1px solid rgba(225,88,41,.3);
    transition: border-color .2s, color .2s;
}
.legal-body a:hover { color: #ff7a45; border-bottom-color: #ff7a45; }

.legal-body hr {
    border: none;
    border-top: 1px solid rgba(255,255,255,.1);
    margin: 28px 0;
}

.legal-body blockquote {
    border-left: 3px solid #e15829;
    margin: 20px 0;
    padding: 14px 20px;
    background: rgba(225,88,41,.07);
    border-radius: 0 10px 10px 0;
    color: #bbb;
    font-style: italic;
}

.legal-body table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    font-size: 14px;
}
.legal-body th,
.legal-body td {
    padding: 10px 14px;
    border: 1px solid rgba(255,255,255,.1);
    text-align: left;
}
.legal-body th { background: rgba(255,255,255,.06); color: #fff; font-weight: 700; }

/* Empty state */
.legal-empty {
    text-align: center;
    padding: 60px 20px;
    color: #555;
}
.legal-empty i {
    font-size: 48px;
    margin-bottom: 18px;
    display: block;
    color: #333;
}
.legal-empty p { font-size: 16px; margin-bottom: 8px; }
.legal-empty-sub { font-size: 13px; color: #444; }

/* ── Footer ──────────────────────────────────────────────────────── */
.legal-footer {
    background: rgba(15,15,15,.98);
    border-top: 1px solid rgba(255,255,255,.07);
    padding: 24px 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.legal-footer p {
    font-size: 13px;
    color: #555;
}
.legal-footer-links {
    display: flex;
    gap: 20px;
}
.legal-footer-links a {
    font-size: 13px;
    color: #666;
    text-decoration: none;
    transition: color .2s;
}
.legal-footer-links a:hover { color: #e15829; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .legal-topbar { padding: 0 16px; }
    .legal-topbar-right { display: none; }
    .legal-hero { padding: 48px 20px 40px; }
    .legal-hero h1 { font-size: 26px; }
    .legal-card { padding: 28px 22px; }
    .legal-container { padding: 32px 16px; }
    .legal-footer { flex-direction: column; align-items: flex-start; }
}
