/* ============================================================
   FFACILITES Admin - Premium Polish (carregado por ÚLTIMO)
   Refinamentos visuais finais sem quebrar funcionalidade.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
    --adm-gold: #f5c518;
    --adm-gold-d: #d4a017;
    --adm-green: #10b981;
    --adm-red: #ef4444;
    --adm-purple: #a855f7;
    --adm-blue: #3b82f6;
    --adm-glow: rgba(245,197,24,0.3);
}

/* ── Body background mais rico ── */
body {
    background: #06060d !important;
    font-family: 'Inter', 'Segoe UI', system-ui, sans-serif !important;
    -webkit-font-smoothing: antialiased !important;
}

/* Textura de fundo */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image:
        linear-gradient(rgba(245,197,24,0.018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(245,197,24,0.018) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
    z-index: 0;
    mask-image: radial-gradient(ellipse 90% 80% at 50% 0%, #000 20%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 90% 80% at 50% 0%, #000 20%, transparent 80%);
}

/* ── Sidebar premium ── */
.sidebar {
    background: linear-gradient(180deg, rgba(12,12,20,0.98), rgba(7,7,12,0.96)) !important;
    border-right: 1px solid rgba(245,197,24,0.1) !important;
    box-shadow: 4px 0 30px rgba(0,0,0,0.5) !important;
}

.logo-area img {
    filter: drop-shadow(0 0 12px rgba(245,197,24,0.25));
    transition: filter 0.3s;
}
.logo-area:hover img {
    filter: drop-shadow(0 0 20px rgba(245,197,24,0.45));
}

/* Botões de nav com micro-interação */
.btn-nav {
    font-size: 12.5px !important;
    letter-spacing: 0.2px !important;
}
.btn-nav:hover {
    background: rgba(245,197,24,0.06) !important;
    color: var(--adm-gold) !important;
}
.btn-nav.active {
    background: linear-gradient(90deg, rgba(245,197,24,0.16), transparent) !important;
    color: var(--adm-gold) !important;
    font-weight: 700 !important;
}
.btn-nav.active::before {
    background: var(--adm-gold) !important;
    box-shadow: 0 0 8px var(--adm-glow) !important;
}

/* ── Content area ── */
.content {
    background: transparent !important;
}

/* ── Page title com gradiente ── */
.page-title {
    font-size: 24px !important;
    font-weight: 900 !important;
    letter-spacing: -0.8px !important;
    background: linear-gradient(135deg, #fff 30%, var(--adm-gold) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1.1 !important;
}

/* ── Stats cards redesenhados ── */
.stat-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.025), rgba(255,255,255,0.005)),
                rgba(12,12,20,0.8) !important;
    border: 1px solid rgba(255,255,255,0.055) !important;
    border-radius: 16px !important;
    backdrop-filter: blur(12px);
    transition: all 0.28s cubic-bezier(0.4,0,0.2,1) !important;
    border-left: none !important;
}
.stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    border-radius: 16px 16px 0 0;
    opacity: 0;
    transition: opacity 0.3s;
}
.stat-card:hover::before { opacity: 1; }
.stat-card:hover {
    transform: translateY(-4px) !important;
    border-color: rgba(255,255,255,0.1) !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.5) !important;
}
.stat-card.verde::before    { background: linear-gradient(90deg, transparent, #10b981, transparent); }
.stat-card.vermelho::before { background: linear-gradient(90deg, transparent, #ef4444, transparent); }
.stat-card.amarelo::before  { background: linear-gradient(90deg, transparent, #f5c518, transparent); }
.stat-card.roxo::before     { background: linear-gradient(90deg, transparent, #a855f7, transparent); }
.stat-card.azul::before     { background: linear-gradient(90deg, transparent, #3b82f6, transparent); }

.stat-card-value {
    font-size: 28px !important;
    letter-spacing: -1px !important;
}
.stat-card-label {
    font-size: 9.5px !important;
    letter-spacing: 1.5px !important;
}
.stat-card-icon {
    width: 40px !important;
    height: 40px !important;
    border-radius: 12px !important;
    transition: transform 0.3s, box-shadow 0.3s !important;
}
.stat-card:hover .stat-card-icon {
    transform: scale(1.1) rotate(-6deg);
    box-shadow: 0 6px 18px rgba(0,0,0,0.3) !important;
}

/* ── Blocos premium ── */
.bloco {
    background: linear-gradient(135deg, rgba(255,255,255,0.02), rgba(255,255,255,0.004)),
                rgba(12,12,20,0.85) !important;
    border: 1px solid rgba(255,255,255,0.055) !important;
    border-radius: 16px !important;
    backdrop-filter: blur(10px);
    transition: border-color 0.25s, box-shadow 0.25s !important;
    overflow: hidden !important;
}
.bloco:hover {
    border-color: rgba(245,197,24,0.18) !important;
}

.bloco-titulo {
    color: var(--adm-gold) !important;
    -webkit-text-fill-color: var(--adm-gold) !important;
    font-size: 11.5px !important;
    letter-spacing: 1.4px !important;
}
.bloco-titulo::before {
    box-shadow: 0 0 8px var(--adm-glow) !important;
}

/* ── Tabela premium ── */
.tabela-admin thead th {
    background: rgba(245,197,24,0.05) !important;
    border-bottom: 1px solid rgba(245,197,24,0.14) !important;
    color: rgba(245,197,24,0.85) !important;
    font-size: 9.5px !important;
    letter-spacing: 1.4px !important;
    padding: 12px 14px !important;
}
.tabela-admin tbody tr {
    transition: background 0.15s !important;
}
.tabela-admin tbody tr:hover td {
    background: rgba(245,197,24,0.04) !important;
}

/* ── Badges refinados ── */
.badge {
    font-size: 10.5px !important;
    letter-spacing: 0.5px !important;
    padding: 3px 10px !important;
}
.badge-ativo {
    background: rgba(16,185,129,0.12) !important;
    color: #34d399 !important;
    border: 1px solid rgba(16,185,129,0.3) !important;
    box-shadow: 0 0 10px rgba(16,185,129,0.15) !important;
}
.badge-expirado {
    background: rgba(239,68,68,0.12) !important;
    color: #f87171 !important;
    border: 1px solid rgba(239,68,68,0.3) !important;
    box-shadow: 0 0 10px rgba(239,68,68,0.15) !important;
}
.badge-pendente {
    background: rgba(245,197,24,0.12) !important;
    color: var(--adm-gold) !important;
    border: 1px solid rgba(245,197,24,0.3) !important;
    box-shadow: 0 0 10px rgba(245,197,24,0.15) !important;
    animation: pendentePulse 2.5s ease-in-out infinite;
}
@keyframes pendentePulse {
    0%, 100% { box-shadow: 0 0 10px rgba(245,197,24,0.15); }
    50% { box-shadow: 0 0 18px rgba(245,197,24,0.35); }
}
.badge-trial {
    background: rgba(99,102,241,0.12) !important;
    color: #a5b4fc !important;
    border: 1px solid rgba(99,102,241,0.3) !important;
}

/* ── Botões premium ── */
.btn-primary {
    background: linear-gradient(135deg, var(--adm-gold-d), var(--adm-gold)) !important;
    color: #000 !important;
    box-shadow: 0 4px 14px rgba(245,197,24,0.3), inset 0 1px 0 rgba(255,255,255,0.3) !important;
    font-weight: 800 !important;
    border-radius: 10px !important;
    transition: all 0.22s cubic-bezier(0.4,0,0.2,1) !important;
}
.btn-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(245,197,24,0.45) !important;
    filter: brightness(1.05);
}
.btn-success {
    background: linear-gradient(135deg, #059669, #10b981) !important;
    box-shadow: 0 4px 14px rgba(16,185,129,0.28) !important;
}
.btn-success:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 22px rgba(16,185,129,0.45) !important;
}
.btn-danger {
    border-color: rgba(239,68,68,0.35) !important;
    color: #f87171 !important;
}
.btn-danger:hover {
    background: linear-gradient(135deg, #b91c1c, #ef4444) !important;
    color: #fff !important;
    box-shadow: 0 6px 18px rgba(239,68,68,0.35) !important;
}

/* ── Modal premium ── */
.modal {
    background: linear-gradient(135deg, rgba(255,255,255,0.025), rgba(255,255,255,0.005)),
                rgba(10,10,18,0.96) !important;
    border: 1px solid rgba(245,197,24,0.2) !important;
    border-radius: 20px !important;
    box-shadow: 0 30px 80px rgba(0,0,0,0.7), 0 0 60px rgba(245,197,24,0.06) !important;
    backdrop-filter: blur(20px) !important;
}
.modal::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--adm-gold), var(--adm-purple), transparent);
    border-radius: 20px 20px 0 0;
}
.modal-titulo {
    background: linear-gradient(135deg, #fff, var(--adm-gold));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-size: 19px !important;
}

/* ── Toast premium ── */
.toast {
    backdrop-filter: blur(20px) !important;
    border-radius: 14px !important;
    box-shadow: 0 16px 48px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.05) !important;
    font-size: 13.5px !important;
}
.toast.success {
    background: linear-gradient(135deg, rgba(5,150,105,0.95), rgba(16,185,129,0.9)) !important;
    border-left: 3px solid #34d399 !important;
}
.toast.error {
    background: linear-gradient(135deg, rgba(185,28,28,0.95), rgba(239,68,68,0.9)) !important;
    border-left: 3px solid #f87171 !important;
}
.toast.info {
    background: linear-gradient(135deg, rgba(184,134,11,0.95), rgba(212,160,23,0.9)) !important;
    border-left: 3px solid #f5c518 !important;
}

/* ── Inputs ── */
input, select, textarea {
    background: rgba(8,8,15,0.7) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: 10px !important;
    font-family: 'Inter', sans-serif !important;
    transition: all 0.22s !important;
}
input:focus, select:focus, textarea:focus {
    border-color: var(--adm-gold) !important;
    box-shadow: 0 0 0 3px rgba(245,197,24,0.14) !important;
    background: rgba(8,8,15,0.9) !important;
    outline: none !important;
}

/* ── Aceitacao cards ── */
.aceitacao-card {
    background: linear-gradient(135deg, rgba(245,197,24,0.05), rgba(245,197,24,0.01)) !important;
    border: 1px solid rgba(245,197,24,0.2) !important;
    transition: all 0.25s cubic-bezier(0.4,0,0.2,1) !important;
}
.aceitacao-card:hover {
    border-color: rgba(245,197,24,0.45) !important;
    box-shadow: 0 8px 28px rgba(245,197,24,0.1) !important;
    transform: translateX(3px) !important;
}

/* ── QR Codes table ── */
.badge-ativo, .badge.badge-ativo { background: rgba(16,185,129,0.12) !important; }

/* ── Charts melhorados ── */
.chart-bar {
    border-radius: 6px 6px 0 0 !important;
    transition: opacity 0.2s, transform 0.2s !important;
}
.chart-bar:hover {
    opacity: 0.85 !important;
    transform: scaleY(1.02) !important;
    transform-origin: bottom !important;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: rgba(0,0,0,0.2); }
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(245,197,24,0.3), rgba(245,197,24,0.12));
    border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(245,197,24,0.5), rgba(245,197,24,0.25));
}

/* ── Seleção ── */
::selection { background: rgba(245,197,24,0.3); color: #fff; }

/* ── Config pix modal ── */
#modal-config-pix .modal, #modal-config-mp .modal {
    max-width: 440px !important;
}

/* ── Botão de nav badge com pulse vermelho ── */
.nav-badge:not(.hidden) {
    animation: navBadgePulse 2.5s ease-in-out infinite;
}
@keyframes navBadgePulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.12); }
}

/* ── Animacoes de entrada ── */
@keyframes admFadeUp {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}
.aba-content { animation: admFadeUp 0.35s cubic-bezier(0.4,0,0.2,1); }
.stat-card {
    animation: admFadeUp 0.4s cubic-bezier(0.4,0,0.2,1) backwards;
}

/* ── Topbar mobile premium ── */
.admin-topbar {
    background: linear-gradient(180deg, rgba(12,12,20,0.97), rgba(8,8,14,0.95)) !important;
    border-bottom: 1px solid rgba(245,197,24,0.14) !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4) !important;
}
.topbar-title {
    background: linear-gradient(135deg, var(--adm-gold), var(--adm-gold-d));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: 800 !important;
}

/* ── Quick Toolbar ── */
.quick-toolbar {
    background: linear-gradient(135deg, rgba(255,255,255,0.025), rgba(255,255,255,0.005)),
                rgba(10,10,18,0.9) !important;
    border: 1px solid rgba(245,197,24,0.16) !important;
    box-shadow: 0 8px 28px rgba(0,0,0,0.4) !important;
    position: relative !important;
    overflow: hidden !important;
}
.quick-toolbar::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--adm-gold), transparent);
    opacity: 0.6;
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
    .stat-card, .aba-content, body::after { animation: none !important; }
    .stat-card:hover { transform: none !important; }
}
