/* =========================================================================
   ForceLatinRadio — sistema de diseño accesible
   Paleta: negro profundo + naranja vibrante (consistente con el logo).
   Objetivos:
   - WCAG 2.1 AA: contraste ≥ 4.5:1 texto normal, ≥ 3:1 UI
   - Foco visible siempre (no quitar outline)
   - Tipografía legible (18px base) y line-height 1.6
   - Touch targets ≥ 44x44px
   - Soporte de prefers-reduced-motion y prefers-contrast
   ========================================================================= */

/* ---------- Tokens ---------- */
:root {
    /* Colores */
    --color-bg:           #0d0d0d;
    --color-bg-elevated:  #1a1a1a;
    --color-bg-card:      #161616;
    --color-bg-input:     #121212;
    --color-border:       #2a2a2a;
    --color-border-strong:#3d3d3d;

    --color-text:         #f7f7f7;
    --color-text-soft:    #c8c8c8;
    --color-text-muted:   #8a8a8a;
    --color-text-on-accent:#1a0a00;

    --color-accent:       #f47c2c;
    --color-accent-hover: #ff9347;
    --color-accent-soft:  rgba(244, 124, 44, 0.15);

    --color-success:      #4ade80;
    --color-success-bg:   rgba(74, 222, 128, 0.12);
    --color-warning:      #fbbf24;
    --color-warning-bg:   rgba(251, 191, 36, 0.12);
    --color-error:        #f87171;
    --color-error-bg:     rgba(248, 113, 113, 0.12);
    --color-info:         #60a5fa;
    --color-info-bg:      rgba(96, 165, 250, 0.12);

    --color-focus:        #ffaa55;

    /* Tipografía */
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                 "Helvetica Neue", Arial, "Noto Sans", sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas,
                 "Liberation Mono", monospace;

    --fs-base:   1.125rem;  /* 18px */
    --fs-sm:     1rem;
    --fs-xs:     0.875rem;
    --fs-lg:     1.25rem;
    --fs-xl:     1.5rem;
    --fs-2xl:    2rem;
    --fs-3xl:    2.5rem;
    --fs-4xl:    3.25rem;

    --lh-tight:  1.25;
    --lh-normal: 1.6;

    /* Espaciado */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --space-7: 3rem;
    --space-8: 4rem;
    --space-9: 6rem;

    /* Bordes y sombras */
    --radius-sm: 4px;
    --radius:    8px;
    --radius-lg: 14px;
    --radius-pill: 999px;

    --shadow-sm: 0 1px 2px rgba(0,0,0,0.4);
    --shadow:    0 4px 16px rgba(0,0,0,0.5);
    --shadow-lg: 0 12px 40px rgba(0,0,0,0.6);

    /* Layout */
    --container-width: 1200px;

    /* Transiciones (respetando reduced motion) */
    --t-fast: 120ms;
    --t-med:  220ms;
}

/* ---------- Modo alto contraste opcional (usuario lo activa en preferencias) ---------- */
body.high-contrast {
    --color-bg: #000;
    --color-bg-elevated: #0a0a0a;
    --color-bg-card: #0a0a0a;
    --color-bg-input: #000;
    --color-text: #fff;
    --color-text-soft: #fff;
    --color-text-muted: #d0d0d0;
    --color-accent: #ffaa55;
    --color-accent-hover: #ffcc88;
    --color-border: #fff;
    --color-border-strong: #fff;
}

/* ---------- Reset mínimo ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.reduced-motion, body.reduced-motion * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--fs-base);
    line-height: var(--lh-normal);
    color: var(--color-text);
    background: var(--color-bg);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; display: block; }
svg { display: block; }

/* Tipografía base */
h1, h2, h3, h4, h5, h6 {
    margin: 0 0 var(--space-4);
    line-height: var(--lh-tight);
    color: var(--color-text);
    font-weight: 700;
    letter-spacing: -0.01em;
}
h1 { font-size: var(--fs-3xl); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-lg); }

p { margin: 0 0 var(--space-4); }
p:last-child { margin-bottom: 0; }

a {
    color: var(--color-accent);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    transition: color var(--t-fast);
}
a:hover { color: var(--color-accent-hover); }
a:visited { color: var(--color-accent); }

ul, ol { padding-left: 1.5em; margin: 0 0 var(--space-4); }
li { margin-bottom: var(--space-2); }

/* ---------- Foco visible — clave para accesibilidad por teclado ---------- */
:focus { outline: none; }
:focus-visible {
    outline: 3px solid var(--color-focus);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ---------- Utilidades ---------- */
.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}

.container {
    width: 100%;
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 var(--space-5);
}

/* ---------- Skip link ---------- */
.skip-link {
    position: absolute;
    top: -100px;
    left: var(--space-3);
    background: var(--color-accent);
    color: var(--color-text-on-accent);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius);
    font-weight: 600;
    z-index: 9999;
    text-decoration: none;
    transition: top var(--t-fast);
}
.skip-link:focus { top: var(--space-3); }

/* ---------- Header ---------- */
.site-header {
    background: linear-gradient(180deg, #161616 0%, var(--color-bg) 100%);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(8px);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-5);
    min-height: 72px;
    padding-top: var(--space-3);
    padding-bottom: var(--space-3);
    flex-wrap: wrap;
}

.site-brand {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    color: var(--color-text);
}
.site-brand:hover { color: var(--color-text); }
.site-brand__logo { width: 56px; height: 56px; border-radius: 50%; }
.site-brand__text { display: flex; flex-direction: column; line-height: 1.2; }
.site-brand__name { font-weight: 800; font-size: var(--fs-lg); letter-spacing: 0.02em; }
.site-brand__tagline { font-size: var(--fs-xs); color: var(--color-text-muted); }

/* Nav */
.site-nav__list {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.site-nav__list li { margin: 0; }
.site-nav__list a {
    display: inline-block;
    padding: var(--space-3) var(--space-4);
    color: var(--color-text);
    text-decoration: none;
    border-radius: var(--radius);
    font-weight: 500;
    min-height: 44px;
}
.site-nav__list a:hover,
.site-nav__list a[aria-current="page"] { background: var(--color-bg-elevated); color: var(--color-accent); }
.site-nav__form { display: inline; margin: 0; }

.nav-toggle {
    display: none;
    width: 48px; height: 48px;
    border: 2px solid var(--color-border-strong);
    background: var(--color-bg-elevated);
    color: var(--color-text);
    border-radius: var(--radius);
    cursor: pointer;
    align-items: center; justify-content: center;
    padding: 0;
    transition: border-color var(--t-fast), background var(--t-fast);
}
.nav-toggle:hover { border-color: var(--color-accent); color: var(--color-accent); }
.nav-toggle__icon {
    display: inline-flex; flex-direction: column;
    width: 22px; height: 16px; position: relative;
}
.nav-toggle__icon span {
    display: block; position: absolute; left: 0; right: 0;
    height: 2px; background: currentColor; border-radius: 2px;
    transition: transform var(--t-med), top var(--t-fast), opacity var(--t-fast);
}
.nav-toggle__icon span:nth-child(1) { top: 0; }
.nav-toggle__icon span:nth-child(2) { top: 7px; }
.nav-toggle__icon span:nth-child(3) { top: 14px; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon span:nth-child(1) { top: 7px; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon span:nth-child(3) { top: 7px; transform: rotate(-45deg); }

@media (max-width: 860px) {
    .site-header__inner { flex-wrap: nowrap; }
    .nav-toggle { display: inline-flex; flex-shrink: 0; }

    .site-nav {
        position: absolute;
        top: 100%; left: 0; right: 0;
        background: var(--color-bg-elevated);
        border-bottom: 1px solid var(--color-border);
        box-shadow: var(--shadow);
        max-height: 0;
        overflow: hidden;
        visibility: hidden;
        transition: max-height var(--t-med) ease-out, visibility 0s linear var(--t-med);
    }
    .site-nav[data-open="true"] {
        max-height: 80vh;
        visibility: visible;
        overflow-y: auto;
        transition: max-height var(--t-med) ease-out, visibility 0s linear 0s;
    }
    .site-header { position: relative; }
    .site-nav__list {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: var(--space-3) var(--space-5);
    }
    .site-nav__list li { border-bottom: 1px solid var(--color-border); }
    .site-nav__list li:last-child { border-bottom: 0; }
    .site-nav__list a {
        display: block;
        padding: var(--space-4) var(--space-3);
        border-radius: 0;
        min-height: 52px;
        font-size: var(--fs-base);
    }
    .site-nav__list .btn { margin: var(--space-3) 0; }
}

/* ---------- Footer ---------- */
.site-footer {
    margin-top: auto;
    background: #0a0a0a;
    border-top: 1px solid var(--color-border);
    color: var(--color-text-soft);
    padding: var(--space-7) 0 var(--space-5);
}
.site-footer__inner {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-6);
}
.site-footer__name { font-weight: 800; font-size: var(--fs-lg); color: var(--color-text); margin-bottom: var(--space-1); }
.site-footer__tagline { color: var(--color-accent); font-style: italic; }
.site-footer__heading { font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); margin-bottom: var(--space-3); }
.site-footer__nav ul { list-style: none; padding: 0; margin: 0; }
.site-footer__nav li { margin-bottom: var(--space-2); }
.site-footer__nav a { color: var(--color-text-soft); text-decoration: none; }
.site-footer__nav a:hover { color: var(--color-accent); text-decoration: underline; }
.site-footer__bottom { border-top: 1px solid var(--color-border); margin-top: var(--space-6); padding-top: var(--space-4); font-size: var(--fs-sm); color: var(--color-text-muted); text-align: center; }
.site-footer__desc { font-size: var(--fs-sm); color: var(--color-text-muted); margin-top: var(--space-2); }
.site-footer__hours { font-size: var(--fs-sm); color: var(--color-text-muted); }
.site-footer__social { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--space-2); }
.site-footer__social li { margin: 0; }
.site-footer__social a {
    display: inline-flex; align-items: center; gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--color-bg-elevated); border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    color: var(--color-text-soft); text-decoration: none;
    font-size: var(--fs-sm); min-height: 36px;
}
.site-footer__social a:hover { color: var(--color-accent); border-color: var(--color-accent); }
.social-icon {
    width: 18px; height: 18px; border-radius: 4px;
    background: var(--color-accent); flex-shrink: 0;
    display: inline-block;
}
.social-icon--facebook { background: #1877F2; }
.social-icon--instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.social-icon--twitter { background: #000; }
.social-icon--youtube { background: #FF0000; }
.social-icon--tiktok { background: #000; }
.social-icon--whatsapp { background: #25D366; }
.social-icon--telegram { background: #229ED9; }
.social-icon--discord { background: #5865F2; }

.article {
    max-width: 760px; margin: 0 auto;
}
.article__header { margin-bottom: var(--space-6); }
.article__title { font-size: var(--fs-3xl); margin-bottom: var(--space-3); }
.article__meta { color: var(--color-text-muted); font-size: var(--fs-sm); }
.article__meta time { color: var(--color-accent); }
.article__cover { border-radius: var(--radius); margin-bottom: var(--space-5); }
.article__body { line-height: 1.75; }
.article__body p { margin-bottom: var(--space-4); }
.article__body h2, .article__body h3 { margin-top: var(--space-6); }

.article-card {
    display: flex; flex-direction: column;
}
.article-card__title { margin-top: var(--space-2); margin-bottom: var(--space-2); }
.article-card__title a { color: var(--color-text); text-decoration: none; }
.article-card__title a:hover { color: var(--color-accent); }
.article-card__meta { font-size: var(--fs-sm); color: var(--color-text-muted); margin-bottom: var(--space-3); }
.article-card__summary { color: var(--color-text-soft); margin-bottom: var(--space-3); flex: 1; }
.article-card__badge { display: inline-block; background: var(--color-accent); color: var(--color-text-on-accent); padding: 2px var(--space-2); border-radius: var(--radius-sm); font-size: var(--fs-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }

.radio-player {
    max-width: 720px; margin: 0 auto;
    padding: var(--space-7) var(--space-6);
    background:
        radial-gradient(circle at top right, rgba(244,124,44,0.18), transparent 60%),
        linear-gradient(180deg, var(--color-bg-card) 0%, var(--color-bg-elevated) 100%);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.radio-player__live {
    display: inline-flex; align-items: center; gap: var(--space-2);
    padding: var(--space-1) var(--space-3);
    background: var(--color-error-bg);
    color: var(--color-error);
    border: 1px solid var(--color-error);
    border-radius: var(--radius-pill);
    font-size: var(--fs-xs); font-weight: 700;
    letter-spacing: 0.12em;
    margin-bottom: var(--space-4);
}
.radio-player__dot {
    display: inline-block; width: 10px; height: 10px;
    background: var(--color-error); border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(248,113,113,0.6);
    animation: flrPulse 1.6s infinite;
}
@keyframes flrPulse {
    0% { box-shadow: 0 0 0 0 rgba(248,113,113,0.6); }
    70% { box-shadow: 0 0 0 12px rgba(248,113,113,0); }
    100% { box-shadow: 0 0 0 0 rgba(248,113,113,0); }
}
body.reduced-motion .radio-player__dot { animation: none; }
@media (prefers-reduced-motion: reduce) { .radio-player__dot { animation: none; } }

.radio-player__title { font-size: var(--fs-2xl); margin-bottom: var(--space-2); }
.radio-player__tagline { color: var(--color-text-soft); margin-bottom: var(--space-5); }

.radio-player__now {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--space-3) var(--space-4);
    margin: 0 auto var(--space-5);
    max-width: 480px;
}
.radio-player__now-label {
    font-size: var(--fs-xs); color: var(--color-accent);
    font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
    margin-bottom: var(--space-1);
}
.radio-player__now-title { font-weight: 700; font-size: var(--fs-lg); margin: 0; }
.radio-player__now-artist { color: var(--color-text-soft); font-size: var(--fs-sm); margin: 0; }

.radio-player__controls {
    display: flex; align-items: center; justify-content: center;
    gap: var(--space-5);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
}

.radio-player__play {
    display: inline-flex; align-items: center; gap: var(--space-3);
    padding: var(--space-3) var(--space-5);
    min-height: 56px;
    border: 0; border-radius: var(--radius-pill);
    background: var(--color-accent); color: var(--color-text-on-accent);
    font-size: var(--fs-lg); font-weight: 700;
    cursor: pointer; font-family: inherit;
    transition: background var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    box-shadow: 0 6px 20px rgba(244,124,44,0.35);
}
.radio-player__play:hover { background: var(--color-accent-hover); transform: translateY(-1px); }
.radio-player__play:active { transform: translateY(0); }
.radio-player__play-icon { display: inline-flex; }

.radio-player.is-playing .radio-player__play { background: var(--color-bg-input); color: var(--color-text); box-shadow: none; border: 2px solid var(--color-accent); }
.radio-player.is-playing .radio-player__play:hover { background: var(--color-bg-elevated); }

.radio-player__volume {
    display: inline-flex; align-items: center; gap: var(--space-2);
    background: var(--color-bg-input);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-pill);
    padding: var(--space-2) var(--space-4);
    min-height: 44px;
}
.radio-player__volume-label { display: inline-flex; color: var(--color-text-soft); }
.radio-player__volume-input {
    appearance: none; -webkit-appearance: none;
    width: 140px; height: 4px;
    background: var(--color-border-strong); border-radius: 2px;
    margin: 0;
}
.radio-player__volume-input::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--color-accent); cursor: pointer;
    border: 0;
}
.radio-player__volume-input::-moz-range-thumb {
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--color-accent); cursor: pointer;
    border: 0;
}
.radio-player__volume-input:focus-visible { outline: 3px solid var(--color-focus); outline-offset: 4px; }

.radio-player__status {
    margin: 0; min-height: 1.5em;
    font-size: var(--fs-sm); color: var(--color-text-muted);
}

@media (max-width: 560px) {
    .radio-player { padding: var(--space-6) var(--space-4); }
    .radio-player__controls { gap: var(--space-3); flex-direction: column; }
    .radio-player__volume-input { width: 180px; }
}

/* ---------- Main ---------- */
.main { flex: 1; padding: var(--space-6) 0; }
.main:focus { outline: none; }

/* ---------- Botones ---------- */
.btn {
    display: inline-flex;
    align-items: center; justify-content: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    min-height: 44px;
    border: 2px solid transparent;
    border-radius: var(--radius);
    font-size: var(--fs-base);
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
    line-height: 1.2;
    font-family: inherit;
}
.btn:active { transform: translateY(1px); }
.btn--primary {
    background: var(--color-accent);
    color: var(--color-text-on-accent);
    border-color: var(--color-accent);
}
.btn--primary:hover { background: var(--color-accent-hover); border-color: var(--color-accent-hover); color: var(--color-text-on-accent); }
.btn--ghost {
    background: transparent;
    color: var(--color-text);
    border-color: var(--color-border-strong);
}
.btn--ghost:hover { background: var(--color-bg-elevated); color: var(--color-accent); border-color: var(--color-accent); }
.btn--lg { padding: var(--space-4) var(--space-6); font-size: var(--fs-lg); }
.btn--sm { padding: var(--space-2) var(--space-3); font-size: var(--fs-sm); min-height: 36px; }
.btn--block { display: flex; width: 100%; }
.btn:disabled, .btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; }

/* ---------- Formularios ---------- */
.form { max-width: 560px; margin: 0 auto; }
.form--wide { max-width: 720px; }

.field { margin-bottom: var(--space-5); }
.field__label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--space-2);
    color: var(--color-text);
}
.field__required { color: var(--color-accent); margin-left: 2px; }

.field__input {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    font-size: var(--fs-base);
    font-family: inherit;
    background: var(--color-bg-input);
    color: var(--color-text);
    border: 2px solid var(--color-border-strong);
    border-radius: var(--radius);
    min-height: 48px;
    transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.field__input:hover { border-color: var(--color-accent); }
.field__input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-soft); }
.field__input::placeholder { color: var(--color-text-muted); opacity: 0.7; }

select.field__input,
textarea.field__input { width: 100%; }
textarea.field__input { min-height: 120px; resize: vertical; }

.field--error .field__input { border-color: var(--color-error); }
.field--error .field__input:focus { box-shadow: 0 0 0 3px rgba(248,113,113,0.25); }

.field__help { margin-top: var(--space-2); margin-bottom: 0; font-size: var(--fs-sm); color: var(--color-text-muted); }
.field__errors {
    margin-top: var(--space-2); padding: 0; list-style: none;
    color: var(--color-error); font-size: var(--fs-sm); font-weight: 500;
}
.field__errors li { margin-bottom: 0; }

.field--checkbox { display: flex; }
.field__checkbox-label {
    display: flex; align-items: flex-start; gap: var(--space-3);
    cursor: pointer; padding: var(--space-2) 0; line-height: 1.5;
}
.field__input--checkbox {
    width: 22px; height: 22px;
    accent-color: var(--color-accent);
    flex-shrink: 0; margin-top: 2px;
}
.field__label-text { color: var(--color-text); }

.form-actions {
    display: flex; gap: var(--space-3); flex-wrap: wrap;
    margin-top: var(--space-6); padding-top: var(--space-5);
    border-top: 1px solid var(--color-border);
}

/* Non-field errors */
.form__errors {
    background: var(--color-error-bg);
    border: 1px solid var(--color-error);
    border-radius: var(--radius);
    padding: var(--space-4);
    margin-bottom: var(--space-5);
    color: var(--color-text);
}
.form__errors ul { margin: 0; padding-left: 1.5em; }

/* ---------- Mensajes Django ---------- */
.messages { padding: var(--space-3) 0; }
.messages__list { list-style: none; padding: 0; margin: 0; }
.message {
    display: flex; align-items: flex-start; gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius);
    border-left: 4px solid;
    margin-bottom: var(--space-3);
}
.message__icon {
    flex-shrink: 0; width: 24px; height: 24px;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 700; border-radius: 50%;
}
.message--success { background: var(--color-success-bg); border-color: var(--color-success); }
.message--success .message__icon { background: var(--color-success); color: #0a2914; }
.message--error, .message--danger { background: var(--color-error-bg); border-color: var(--color-error); }
.message--error .message__icon, .message--danger .message__icon { background: var(--color-error); color: #2b0707; }
.message--warning { background: var(--color-warning-bg); border-color: var(--color-warning); }
.message--warning .message__icon { background: var(--color-warning); color: #2b1f00; }
.message--info, .message--debug { background: var(--color-info-bg); border-color: var(--color-info); }
.message--info .message__icon, .message--debug .message__icon { background: var(--color-info); color: #0a1a2b; }

/* ---------- Cards / paneles ---------- */
.card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
}
.card--highlighted {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 1px var(--color-accent), var(--shadow);
}

/* ---------- Layout helpers ---------- */
.stack > * + * { margin-top: var(--space-4); }
.stack--lg > * + * { margin-top: var(--space-6); }

.grid { display: grid; gap: var(--space-5); }
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--3 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

.section { padding: var(--space-7) 0; }
.section + .section { border-top: 1px solid var(--color-border); }

/* ---------- Hero (landing) ---------- */
.hero {
    padding: var(--space-9) 0 var(--space-8);
    background:
        radial-gradient(ellipse at top right, rgba(244,124,44,0.15), transparent 50%),
        radial-gradient(ellipse at bottom left, rgba(244,124,44,0.08), transparent 50%),
        var(--color-bg);
    text-align: center;
}
.hero__logo { width: 140px; height: 140px; margin: 0 auto var(--space-5); border-radius: 50%; }
.hero__eyebrow {
    display: inline-block;
    color: var(--color-accent);
    font-size: var(--fs-sm);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-weight: 700;
    margin: 0 0 var(--space-3);
    padding: var(--space-1) var(--space-3);
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-pill);
}
.hero__title {
    font-size: var(--fs-4xl);
    margin-bottom: var(--space-4);
    letter-spacing: -0.01em;
    max-width: 880px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.15;
}
.hero__tagline {
    font-size: var(--fs-lg); color: var(--color-text-soft);
    max-width: 720px; margin: 0 auto var(--space-6);
}
.hero__cta { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }

/* ---------- Feature list (landing) ---------- */
.feature { padding: var(--space-5); }
.feature__icon {
    width: 56px; height: 56px;
    background: var(--color-accent-soft); color: var(--color-accent);
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: var(--fs-xl); margin-bottom: var(--space-4);
    font-weight: 700;
}
.feature__title { margin-bottom: var(--space-2); }

/* ---------- Plan cards (pricing) ---------- */
.plan {
    position: relative;
    display: flex; flex-direction: column;
}
.plan__badge {
    position: absolute; top: -14px; right: var(--space-5);
    background: var(--color-accent); color: var(--color-text-on-accent);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-pill);
    font-size: var(--fs-xs); font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em;
}
.plan__name { font-size: var(--fs-xl); margin-bottom: var(--space-2); }
.plan__price { font-size: var(--fs-3xl); font-weight: 800; color: var(--color-accent); margin-bottom: var(--space-2); line-height: 1; }
.plan__price-period { font-size: var(--fs-base); color: var(--color-text-muted); font-weight: 500; }
.plan__price--secondary { font-size: var(--fs-xl); color: var(--color-text); }
.plan__price--secondary .plan__price-period { font-size: var(--fs-sm); }
.plan__discount-tag {
    display: inline-block; background: var(--color-success-bg); color: var(--color-success);
    padding: 2px var(--space-2); border-radius: var(--radius-sm);
    font-size: var(--fs-xs); font-weight: 700; margin-left: var(--space-2);
}

.interval-choice { border: 0; padding: 0; margin: 0 0 var(--space-5); display: grid; gap: var(--space-3); grid-template-columns: 1fr 1fr; }
.interval-choice__option {
    display: flex; flex-direction: column; gap: var(--space-1);
    padding: var(--space-4);
    border: 2px solid var(--color-border-strong);
    border-radius: var(--radius);
    background: var(--color-bg-input);
    text-decoration: none; color: var(--color-text);
    transition: border-color var(--t-fast), background var(--t-fast);
}
.interval-choice__option:hover { border-color: var(--color-accent); }
.interval-choice__option.is-selected {
    border-color: var(--color-accent); background: var(--color-accent-soft);
}
.interval-choice__label { font-weight: 700; font-size: var(--fs-lg); }
.interval-choice__price { font-size: var(--fs-xl); color: var(--color-accent); font-weight: 800; }
.interval-choice__period { font-size: var(--fs-sm); color: var(--color-text-muted); }
.interval-choice__savings { font-size: var(--fs-sm); color: var(--color-success); margin-top: var(--space-1); }

.client-body { background: var(--color-bg); }

.client-topbar {
    background: linear-gradient(180deg, #161616 0%, #0a0a0a 100%);
    border-bottom: 1px solid var(--color-border);
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(8px);
}
.client-topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    max-width: var(--container-width);
    margin: 0 auto;
    padding: var(--space-3) var(--space-5);
    min-height: 64px;
    flex-wrap: wrap;
}
.client-topbar__brand {
    display: flex; align-items: center; gap: var(--space-3);
    text-decoration: none; color: var(--color-text);
    font-weight: 700;
}
.client-topbar__brand:hover { color: var(--color-accent); }
.client-topbar__logo { width: 40px; height: 40px; border-radius: 50%; }
.client-topbar__name { font-size: var(--fs-lg); letter-spacing: 0.02em; }

.client-topbar__user {
    display: flex; align-items: center; gap: var(--space-3);
    flex-wrap: wrap;
}
.client-topbar__id {
    background: var(--color-accent-soft);
    color: var(--color-accent);
    font-family: var(--font-mono);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-pill);
    font-size: var(--fs-sm);
    font-weight: 700;
}
.client-topbar__email {
    color: var(--color-text-muted);
    font-size: var(--fs-sm);
}
@media (max-width: 600px) {
    .client-topbar__email { display: none; }
}
.client-topbar__logout { margin: 0; }

.main--client { padding: 0; flex: 1; }

.client-footer {
    margin-top: auto;
    background: #0a0a0a;
    border-top: 1px solid var(--color-border);
    color: var(--color-text-muted);
    padding: var(--space-5) 0;
    font-size: var(--fs-sm);
    text-align: center;
}
.client-footer a { color: var(--color-text-soft); text-decoration: none; }
.client-footer a:hover { color: var(--color-accent); text-decoration: underline; }
.client-footer p { margin: 0 0 var(--space-1); }

.panel-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--space-5);
    align-items: stretch;
    max-width: var(--container-width);
    margin: 0 auto;
    padding: var(--space-5);
}
@media (max-width: 960px) {
    .panel-layout { grid-template-columns: 1fr; padding: var(--space-3); gap: var(--space-3); }
}

.panel-sidebar {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-3);
    height: fit-content;
    position: sticky;
    top: 100px;
}
@media (max-width: 960px) {
    .panel-sidebar { position: static; padding: var(--space-4) var(--space-3); }
}

.panel-sidebar__user {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 0 var(--space-3) var(--space-4);
    margin-bottom: var(--space-3);
    border-bottom: 1px solid var(--color-border);
}
.panel-sidebar__avatar {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: var(--color-accent);
    color: var(--color-text-on-accent);
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: var(--fs-xl);
    flex-shrink: 0;
}
.panel-sidebar__userinfo { min-width: 0; }
.panel-sidebar__name {
    margin: 0; font-weight: 700; color: var(--color-text);
    font-size: var(--fs-sm);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.panel-sidebar__id {
    margin: 0; font-family: var(--font-mono);
    font-size: var(--fs-xs); color: var(--color-accent);
}

.panel-sidebar__nav ul {
    list-style: none; padding: 0; margin: 0;
}
.panel-sidebar__nav li { margin: 0; }
.panel-sidebar__nav li.panel-sidebar__sep {
    border-top: 1px solid var(--color-border);
    margin: var(--space-3) 0;
}
.panel-sidebar__nav a,
.panel-sidebar__nav button {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius);
    color: var(--color-text-soft);
    text-decoration: none;
    font-size: var(--fs-sm); font-weight: 500;
    transition: background var(--t-fast), color var(--t-fast);
    width: 100%;
    background: none; border: 0; cursor: pointer;
    font-family: inherit; text-align: left;
    min-height: 44px;
}
.panel-sidebar__nav a:hover,
.panel-sidebar__nav button:hover {
    background: var(--color-bg-elevated);
    color: var(--color-text);
}
.panel-sidebar__nav a[aria-current="page"] {
    background: var(--color-accent-soft);
    color: var(--color-accent);
    font-weight: 700;
}
.panel-sidebar__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 24px; height: 24px;
    font-size: var(--fs-base);
    flex-shrink: 0;
}
.panel-sidebar__logout-form { margin: 0; }

.panel-main {
    min-width: 0;
}

.panel-header {
    display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
    flex-wrap: wrap;
}
.panel-header__title { margin: 0 0 var(--space-1); }
.panel-header__subtitle { margin: 0; color: var(--color-text-soft); }

.panel-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--space-4);
    margin-bottom: var(--space-5);
}
.panel-stat {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--space-4) var(--space-5);
}
.panel-stat__label {
    margin: 0 0 var(--space-2); font-size: var(--fs-xs);
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--color-text-muted); font-weight: 700;
}
.panel-stat__value {
    margin: 0; font-size: var(--fs-3xl); font-weight: 800;
    color: var(--color-text); line-height: 1;
}
.panel-stat__value--accent { color: var(--color-accent); }

.panel-section { margin-bottom: var(--space-7); }
.panel-section__head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: var(--space-3); margin-bottom: var(--space-4);
}
.panel-section__head h2 { margin: 0; font-size: var(--fs-xl); }

.panel-empty {
    background: var(--color-bg-card);
    border: 1px dashed var(--color-border-strong);
    border-radius: var(--radius);
    padding: var(--space-6);
    text-align: center;
    color: var(--color-text-soft);
}
.panel-empty p:last-child { margin-bottom: 0; }

.service-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
}
.service-card__head {
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--space-3); margin-bottom: var(--space-3);
}
.service-card__name { margin: 0; font-size: var(--fs-lg); }
.service-card__status {
    display: inline-block; font-size: var(--fs-xs); font-weight: 700;
    padding: 2px var(--space-2); border-radius: var(--radius-pill);
    text-transform: uppercase; letter-spacing: 0.06em;
}
.service-card__status--active { background: var(--color-success-bg); color: var(--color-success); }
.service-card__status--pending { background: var(--color-warning-bg); color: var(--color-warning); }
.service-card__status--failed { background: var(--color-error-bg); color: var(--color-error); }
.service-card__status--draft { background: var(--color-info-bg); color: var(--color-info); }

.wizard-steps { margin-bottom: var(--space-6); }
.wizard-steps ol {
    list-style: none; padding: 0; margin: 0;
    display: flex; gap: var(--space-2);
    overflow-x: auto;
}
.wizard-steps li {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    background: var(--color-bg-card);
    border: 2px solid var(--color-border-strong);
    border-radius: var(--radius);
    color: var(--color-text-muted);
    flex: 1; min-width: 180px;
    margin: 0;
}
.wizard-steps li.is-current { border-color: var(--color-accent); color: var(--color-text); background: var(--color-accent-soft); }
.wizard-steps li.is-done { border-color: var(--color-success); color: var(--color-text-soft); }
.wizard-steps__num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--color-border-strong); color: var(--color-text);
    font-weight: 700; font-size: var(--fs-sm);
    flex-shrink: 0;
}
.wizard-steps li.is-current .wizard-steps__num { background: var(--color-accent); color: var(--color-text-on-accent); }
.wizard-steps li.is-done .wizard-steps__num { background: var(--color-success); color: #0a2914; }
.wizard-steps__label { font-size: var(--fs-sm); font-weight: 500; }

@media (max-width: 720px) {
    .wizard-steps ol { flex-direction: column; }
    .wizard-steps li { min-width: 0; }
}

.customer-badge {
    display: inline-block;
    background: var(--color-accent-soft);
    color: var(--color-accent);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-pill);
    font-family: var(--font-mono);
    font-weight: 700;
    letter-spacing: 0.05em;
}

.profile-data { display: grid; grid-template-columns: 200px 1fr; gap: var(--space-2) var(--space-5); margin: 0 0 var(--space-5); }
.profile-data dt { margin: 0; }
.profile-data dd { margin: 0; }
@media (max-width: 540px) {
    .profile-data { grid-template-columns: 1fr; gap: 0 0; }
    .profile-data dd { margin-bottom: var(--space-3); }
}

@media (max-width: 540px) {
    .interval-choice { grid-template-columns: 1fr; }
}
.plan__features { list-style: none; padding: 0; margin: var(--space-5) 0; flex: 1; }
.plan__features li {
    padding: var(--space-2) 0 var(--space-2) var(--space-5);
    position: relative;
    border-bottom: 1px solid var(--color-border);
    margin: 0;
}
.plan__features li:last-child { border-bottom: 0; }
.plan__features li::before {
    content: "✓"; color: var(--color-accent); font-weight: 700;
    position: absolute; left: 0;
}

/* ---------- Tablas accesibles ---------- */
.table-wrap { overflow-x: auto; margin-bottom: var(--space-5); }
.table {
    width: 100%; border-collapse: collapse;
    background: var(--color-bg-card); border-radius: var(--radius);
    overflow: hidden;
}
.table th, .table td { padding: var(--space-3) var(--space-4); text-align: left; border-bottom: 1px solid var(--color-border); }
.table th { background: var(--color-bg-elevated); font-weight: 700; color: var(--color-text); }
.table tr:last-child td { border-bottom: 0; }

/* ---------- Page header ---------- */
.page-header { padding: var(--space-6) 0; text-align: center; border-bottom: 1px solid var(--color-border); margin-bottom: var(--space-6); }
.page-header__title { margin-bottom: var(--space-2); }
.page-header__subtitle { color: var(--color-text-soft); font-size: var(--fs-lg); max-width: 720px; margin: 0 auto; }

/* ---------- Auth pages ---------- */
.auth-page { padding: var(--space-6) 0; }
.auth-page__panel {
    max-width: 480px; margin: 0 auto;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
}
.auth-page__panel--wide { max-width: 640px; }
.auth-page__title { text-align: center; margin-bottom: var(--space-2); }
.auth-page__intro { text-align: center; color: var(--color-text-soft); margin-bottom: var(--space-6); }
.auth-page__links { margin-top: var(--space-5); text-align: center; font-size: var(--fs-sm); }
.auth-page__links p { margin-bottom: var(--space-2); }

/* ---------- Responsivo extra ---------- */
@media (max-width: 600px) {
    :root { --fs-base: 1rem; --fs-3xl: 2rem; --fs-4xl: 2.5rem; }
    .hero { padding: var(--space-7) 0 var(--space-6); }
    .hero__logo { width: 100px; height: 100px; }
    .site-brand__tagline { display: none; }
}

/* ---------- Print ---------- */
@media print {
    .site-header, .site-footer, .nav-toggle, .skip-link, .messages { display: none; }
    body { background: white; color: black; }
    a { color: black; text-decoration: underline; }
}
