/* =========================================
   JournalByTTS — components/buttons.css
   .btn, .button, .btn-*, download buttons
   ========================================= */

/* ─── BOTONES ─── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    background: rgba(255,255,255,0.07);
    color: var(--ink-3);
    border: 1px solid var(--border);
    border-radius: 10px;
    cursor: pointer;
    font-family: var(--font-sans);
    font-size: 0.83rem;
    font-weight: 500;
    letter-spacing: 0.03em;
    text-decoration: none;
    transition: background 0.18s, color 0.18s, transform 0.1s, box-shadow 0.18s;
    white-space: nowrap;
}
.btn:hover {
    background: rgba(255,255,255,0.12);
    color: var(--text);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.btn:active { transform: translateY(0); }

.btn-secondary {
    background: rgba(120,144,176,0.08);
    color: var(--ink-3);
    border-color: rgba(120,144,176,0.18);
    box-shadow: none;
}
.btn-secondary:hover { background: rgba(120,144,176,0.15); color: var(--text); }

.btn-success {
    background: rgba(18,184,120,0.15);
    color: #34d399;
    border-color: rgba(18,184,120,0.25);
    box-shadow: none;
}
.btn-success:hover { background: rgba(18,184,120,0.25); }

.btn-danger {
    background: rgba(232,92,74,0.15);
    color: #f87171;
    border-color: rgba(232,92,74,0.25);
    box-shadow: none;
}
.btn-danger:hover { background: rgba(232,92,74,0.25); }

.btn-outline {
    background: transparent;
    color: var(--ink-3);
    border: 1px solid var(--border-dark);
    box-shadow: none;
}
.btn-outline:hover { background: color-mix(in oklch, var(--ink) 8%, transparent); color: var(--ink); box-shadow: none; }

.btn-sm { padding: 6px 12px; font-size: 0.78rem; }
.btn-xs { padding: 4px 8px; font-size: 0.72rem; }

/* Modern rounded overrides */
.btn {
    border-radius: 8px !important;
    font-weight: 500;
    letter-spacing: 0.01em;
    transition: background 0.18s, color 0.18s, box-shadow 0.18s, transform 0.1s !important;
}
.btn:hover { box-shadow: 0 3px 10px var(--shadow); }
.btn:active { transform: translateY(1px) !important; }
.btn-primary {
    background: var(--accent);
    color: var(--accent-fg);
    border: none;
}
.btn-primary:hover {
    background: var(--accent-hover);
    color: var(--accent-fg);
    transform: translateY(-1px);
}
.btn-outline { border-radius: 8px !important; }
.btn-sm { border-radius: 7px !important; padding: 5px 12px; font-size: 0.75rem; }

.btn-block { width: 100%; justify-content: center; margin-bottom: 10px; }

/* components.css btn override */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 8px 14px;
    border-radius: var(--r-md);
    font-size: var(--text-sm);
    font-weight: 500;
    letter-spacing: -0.005em;
    transition: all var(--t-fast) var(--ease-out);
    white-space: nowrap;
    border: 1px solid transparent;
}
.btn-ghost { color: var(--ink-2); }
.btn-ghost:hover { background: var(--bg-hover); color: var(--ink); }
.btn-icon { width: 32px; height: 32px; padding: 0; }

/* ─── BOTÓN DE DESCARGA EA ─── */
.btn-download-ea {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--bg-elev);
    color: var(--ink-2);
    border: 1px solid var(--border);
    border-radius: 10px;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-decoration: none;
    transition: background 0.18s, border-color 0.18s, color 0.18s;
    cursor: pointer;
    white-space: nowrap;
}
.btn-download-ea:hover {
    background: var(--accent-hover);
    border-color: var(--accent-hover);
    color: #fff;
}
.btn-download-ea i {
    font-size: 0.8rem;
    color: var(--jade);
}
.btn-download-ea:hover i {
    color: #fff;
}

/* ─── PAGE ACTIONS ─── */
.page-actions { display: flex; gap: 8px; }
.page-head { padding: 32px 32px 0; display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; }

/* ─── LIGHT THEME ─── */
html[data-theme="light"] .btn {
    background: rgba(0,0,0,0.04);
    border-color: rgba(30,60,100,0.15);
    color: var(--ink-3);
}
html[data-theme="light"] .btn:hover { background: rgba(0,0,0,0.07); color: var(--text); }

/* ─── DARK THEME — .btn-primary pop ───
   En dark mode, --accent-fg es casi negro (#0B0C0E): el texto sobre el
   naranja queda con poco contraste y los botones "desaparecen". Forzamos
   texto blanco + un anillo/glow sutil para que destaquen sobre el coal. */
html[data-theme="dark"] .btn-primary,
html[data-theme="dark"] .jb .btn-primary {
    background: var(--accent);
    color: #fff;
    border: 1px solid color-mix(in oklch, var(--accent) 70%, white);
    box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset,
                0 4px 14px rgba(232, 85, 43, 0.28);
}
html[data-theme="dark"] .btn-primary:hover,
html[data-theme="dark"] .jb .btn-primary:hover {
    background: var(--accent-hover);
    color: #fff;
    border-color: color-mix(in oklch, var(--accent-hover) 60%, white);
    box-shadow: 0 1px 0 rgba(255,255,255,0.12) inset,
                0 6px 18px rgba(232, 85, 43, 0.42);
}
html[data-theme="dark"] .btn-primary i,
html[data-theme="dark"] .btn-primary svg,
html[data-theme="dark"] .jb .btn-primary i,
html[data-theme="dark"] .jb .btn-primary svg {
    color: #fff;
}
