/* ============================
   PALETA NUN-PTAH
   ============================ */
:root {
    --bg-body: #020315;
    --bg-alt: #070b1e;
    --bg-card: #0a0f25;
    --fg-main: #f5f5f8;
    --fg-muted: #c3c3d4;
    --accent-gold: #d8b16a;
    --accent-gold-soft: #f0d892;
    --accent-emerald: #009178;
    --danger: #ff6b6b;
    --border-soft: rgba(255, 255, 255, 0.12);
    --shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.65);
}

/* Reset básico */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    font-family: "Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: radial-gradient(circle at top, #111631 0, #020315 52%, #01010b 100%);
    color: var(--fg-main);
}

/* ============================
   CONTENEDOR GENERAL
   ============================ */

.terms-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    padding: 1.5rem 1.25rem 2rem;
}

/* ============================
   HEADER
   ============================ */

.terms-header {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 1rem;
}

.terms-logo {
    max-width: 210px;
    width: 100%;
    filter: drop-shadow(0 0 18px rgba(0, 0, 0, 0.8));
}

/* ============================
   MAIN / CARD
   ============================ */

.terms-main {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: stretch;
}

.terms-card {
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
    padding: 2rem 1.5rem 2.5rem;
    background: linear-gradient(135deg, rgba(10, 15, 37, 0.98), rgba(7, 11, 30, 0.96));
    border-radius: 1.5rem;
    border: 1px solid var(--border-soft);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(18px);
    overflow: hidden;
}

/* Scroll interno para textos largos en pantallas bajas */
@media (min-height: 600px) {
    .terms-card {
        max-height: calc(100vh - 7.5rem);
        overflow-y: auto;
        scrollbar-width: thin;
        scrollbar-color: rgba(216, 177, 106, 0.8) transparent;
    }

    .terms-card::-webkit-scrollbar {
        width: 8px;
    }

    .terms-card::-webkit-scrollbar-track {
        background: transparent;
    }

    .terms-card::-webkit-scrollbar-thumb {
        background: linear-gradient(180deg, var(--accent-gold), var(--accent-emerald));
        border-radius: 999px;
    }
}

/* ============================
   TIPOGRAFÍA
   ============================ */

.terms-card h1 {
    font-size: 1.7rem;
    letter-spacing: 0.08em;
    text-align: center;
    margin-bottom: 1.5rem;
    color: var(--accent-gold-soft);
    text-shadow: 0 0 18px rgba(240, 216, 146, 0.4);
    text-transform: uppercase;
}

.terms-card h3 {
    font-size: 1.02rem;
    margin-top: 1.5rem;
    margin-bottom: 0.4rem;
    color: var(--accent-gold);
    letter-spacing: 0.04em;
}

.terms-card p {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--fg-muted);
    margin-bottom: 0.85rem;
}

/* Listas */

.terms-card ul {
    padding-left: 1.25rem;
    margin-bottom: 0.9rem;
}

.terms-card li {
    font-size: 0.92rem;
    line-height: 1.65;
    color: var(--fg-muted);
    margin-bottom: 0.45rem;
    list-style: none; /* mantienes el número dentro del texto */
}

/* ============================
   BOTONES ACEPTAR / RECHAZAR
   ============================ */

.botones {
    margin-top: 2rem;
    display: flex;
    justify-content: center;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.aceptar,
.rechazar {
    min-width: 150px;
    padding: 0.55rem 1.5rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.06em;
    text-decoration: none;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease, color 0.22s ease, border-color 0.22s ease;
    border: 1px solid transparent;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.8);
}

/* Botón ACEPTAR: verde esmeralda, positivo */
.aceptar {
    background: radial-gradient(circle at 0% 0%, rgba(157, 216, 182, 0.26), transparent 60%),
                linear-gradient(135deg, rgba(0, 145, 120, 0.9), rgba(0, 104, 90, 1));
    color: #f5fff9;
    border-color: rgba(0, 184, 140, 0.7);
}

.aceptar:hover {
    transform: translateY(-2px);
    background: radial-gradient(circle at 0% 0%, rgba(157, 216, 182, 0.4), transparent 65%),
                linear-gradient(135deg, rgba(0, 184, 140, 1), rgba(0, 120, 102, 1));
    box-shadow: 0 0 18px rgba(0, 184, 140, 0.7), 0 14px 36px rgba(0, 0, 0, 0.9);
}

/* Botón RECHAZAR: tono más sobrio pero claro */
.rechazar {
    background: radial-gradient(circle at 0% 0%, rgba(255, 107, 107, 0.2), transparent 60%),
                linear-gradient(135deg, rgba(61, 20, 50, 0.95), rgba(50, 10, 36, 1));
    color: #ffe7ec;
    border-color: rgba(255, 107, 107, 0.55);
}

.rechazar:hover {
    transform: translateY(-2px);
    background: radial-gradient(circle at 0% 0%, rgba(255, 107, 107, 0.33), transparent 65%),
                linear-gradient(135deg, rgba(139, 17, 60, 1), rgba(86, 7, 35, 1));
    box-shadow: 0 0 18px rgba(255, 107, 107, 0.65), 0 14px 36px rgba(0, 0, 0, 0.92);
}

/* ============================
   RESPONSIVE
   ============================ */

@media (max-width: 768px) {
    .terms-shell {
        padding: 1.25rem 0.75rem 1.75rem;
    }

    .terms-logo {
        max-width: 170px;
    }

    .terms-card {
        padding: 1.4rem 1.1rem 2rem;
        border-radius: 1.1rem;
    }

    .terms-card h1 {
        font-size: 1.4rem;
        margin-bottom: 1.1rem;
    }

    .terms-card h3 {
        font-size: 0.98rem;
    }

    .terms-card p,
    .terms-card li {
        font-size: 0.9rem;
    }

    .aceptar,
    .rechazar {
        min-width: 140px;
        font-size: 0.9rem;
        padding: 0.5rem 1.3rem;
    }
}

@media (min-width: 1200px) {
    .terms-card {
        padding: 2.3rem 2.25rem 2.5rem;
    }

    .terms-card p,
    .terms-card li {
        font-size: 0.97rem;
    }
}










