@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');
html { scroll-padding-top: 5rem; }

/* ── Tokens de Design ─────────────────────────────────────── */
:root {
    /* Backgrounds */
    --bg:          #080E1F;
    --bg-card:     #0D1B3E;
    --bg-card-alt: #112244;
    --bg-input:    #060C1A;

    /* Accent — Dourado CRIATIO (sem roxo) */
    --accent:      #F0A500;
    --accent-dark: #C88A00;
    --accent-glow: rgba(240, 165, 0, .15);

    /* Texto */
    --text:        #EEF2FF;
    --text-muted:  #7B8BB2;

    /* Status */
    --success:     #10B981;
    --danger:      #EF4444;
    --warning:     #F59E0B;

    /* Bordas */
    --border:      rgba(255, 255, 255, .07);
    --border-hover: rgba(240, 165, 0, .4);

    /* Sombras */
    --shadow-card: 0 8px 32px rgba(4, 8, 25, .7);
    --shadow-hover: 0 14px 40px rgba(4, 8, 25, .9);
}

/* ── Reset & Base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    background: radial-gradient(ellipse at top, #0F1E4A 0%, var(--bg) 55%, #020918 100%);
    color: var(--text);
    min-height: 100vh;
    font-size: 15px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; transition: opacity .15s; }
a:hover { opacity: .8; text-decoration: underline; }

/* ── Layout ────────────────────────────────────────────────── */
.layout {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ── Header ────────────────────────────────────────────────── */
header {
    padding: .75rem 1.5rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(to right, rgba(8,14,31,.95), rgba(13,27,62,.98));
    backdrop-filter: blur(8px);
    position: sticky;
    top: 0;
    z-index: 100;
}

.brand { display: flex; align-items: center; gap: .7rem; }
.brand-text-main {
    font-weight: 600;
    letter-spacing: .06em;
    font-size: .82rem;
    color: var(--text);
}
.brand-text-sub { font-size: .7rem; color: var(--text-muted); }

nav { display: flex; align-items: center; gap: .25rem; flex-wrap: wrap; }
nav a {
    padding: .3rem .7rem;
    border-radius: 4px;
    font-size: .78rem;
    color: var(--text-muted);
    transition: color .15s, background .15s;
}
nav a:hover, nav a.active {
    color: var(--text);
    background: rgba(240, 165, 0, .12);
    text-decoration: none;
}
nav a.active { color: var(--accent); font-weight: 500; }

/* ── Main Content ──────────────────────────────────────────── */
main {
    flex: 1;
    padding: 1.5rem 1.75rem 2rem;
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
}

h1 { font-size: 1.5rem; font-weight: 700; margin-bottom: .5rem; }
h2 { font-size: 1.05rem; font-weight: 600; margin-bottom: .6rem; }
.subtitle { font-size: .88rem; color: var(--text-muted); margin-bottom: 1.25rem; }

/* ── Flash Messages ────────────────────────────────────────── */
.flash {
    padding: .7rem 1rem;
    border-radius: 6px;
    font-size: .85rem;
    margin-bottom: 1.1rem;
    border-left: 3px solid;
    animation: slideDown .2s ease-out;
}
.flash-success {
    background: rgba(16, 185, 129, .1);
    border-color: var(--success);
    color: var(--success);
}
.flash-error {
    background: rgba(239, 68, 68, .1);
    border-color: var(--danger);
    color: var(--danger);
}
.flash-info {
    background: rgba(240, 165, 0, .08);
    border-color: var(--accent);
    color: var(--accent);
}
@keyframes slideDown {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Cards ─────────────────────────────────────────────────── */
.card {
    background: linear-gradient(135deg, var(--bg-card), var(--bg-card-alt));
    border-radius: 8px;
    padding: 1rem 1.2rem;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-card);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-hover);
    border-color: var(--border-hover);
}
.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: .45rem;
    font-size: .78rem;
    color: var(--text-muted);
    font-weight: 500;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.card-value {
    font-size: 1.45rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    letter-spacing: -.01em;
}
.card-text {
    margin-top: .35rem;
    font-size: .78rem;
    color: var(--text-muted);
}

.grid-cards {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    margin-bottom: 1.5rem;
}

/* ── Badges ─────────────────────────────────────────────────── */
.badge {
    display: inline-flex;
    align-items: center;
    padding: .15rem .45rem;
    border-radius: 4px;
    font-size: .68rem;
    font-weight: 500;
    border: 1px solid var(--border);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.badge-success { border-color: var(--success); color: var(--success); }
.badge-danger  { border-color: var(--danger);  color: var(--danger);  }
.badge-warning { border-color: var(--warning); color: var(--warning); }
.badge-accent  { border-color: var(--accent);  color: var(--accent);  }

/* ── Forms & Inputs ─────────────────────────────────────────── */
label {
    /* display: block; */
    font-size: .82rem;
    font-weight: 500;
    margin-bottom: .35rem;
    color: var(--text-muted);
}
input, select, textarea {
    width: 100%;
    padding: .45rem .6rem;
    border-radius: 5px;
    border: 1px solid rgba(255,255,255,.1);
    background: var(--bg-input);
    color: var(--text);
    font-size: .85rem;
    font-family: inherit;
    transition: border-color .15s;
}
input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px var(--accent-glow);
}
input::placeholder { color: var(--text-muted); }

button, .btn {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .45rem .9rem;
    border-radius: 5px;
    border: none;
    background: var(--accent);
    color: #0A0A0A;
    font-size: .83rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: background .15s, transform .12s;
}
button:hover, .btn:hover {
    background: var(--accent-dark);
    transform: translateY(-1px);
}
button:active, .btn:active { transform: translateY(0); }

.btn-secondary {
    background: rgba(255,255,255,.07);
    color: var(--text);
    border: 1px solid var(--border);
}
.btn-secondary:hover { background: rgba(255,255,255,.12); }

.btn-danger { background: var(--danger); color: #fff; }
.btn-danger:hover { background: #dc2626; }

.btn-sm { padding: .28rem .6rem; font-size: .75rem; }

/* ── Tables ─────────────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; font-size: .8rem; }
/* thead { position: sticky; top: 64px; z-index: 5; } */
th, td { padding: .45rem .55rem; border-bottom: 1px solid var(--border); }
th {
    text-align: left;
    color: var(--text-muted);
    font-weight: 500;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    background: var(--bg-card);
}
tr:hover td { background: rgba(240, 165, 0, .04); }

.table-small { font-size: .78rem; }
.table-small th, .table-small td { padding: .38rem .45rem; }

.tag {
    display: inline-block;
    padding: .08rem .4rem;
    border-radius: 999px;
    font-size: .65rem;
    background: rgba(255,255,255,.07);
    color: var(--text-muted);
}

/* ── Filter Bar ─────────────────────────────────────────────── */
.filter-bar {
    display: flex;
    gap: .6rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-bottom: 1.1rem;
    padding: .75rem 1rem;
    background: var(--bg-card);
    border-radius: 7px;
    border: 1px solid var(--border);
}
.filter-bar label { margin-bottom: .25rem; font-size: .75rem; }
.filter-bar input, .filter-bar select { width: auto; min-width: 120px; }

/* ── Nav Tiles (Dashboard) ──────────────────────────────────── */
.nav-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .8rem;
}
.nav-tile {
    background: var(--bg-card);
    border-radius: 7px;
    padding: .85rem 1rem;
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 76px;
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
    text-decoration: none !important;
}
.nav-tile:hover {
    transform: translateY(-3px);
    border-color: var(--border-hover);
    box-shadow: 0 12px 32px rgba(240,165,0,.15);
    text-decoration: none;
}
.nav-title { font-size: .9rem; font-weight: 600; color: var(--text); margin-bottom: .15rem; }
.nav-desc  { font-size: .74rem; color: var(--text-muted); }

/* ── Separators & Rows ──────────────────────────────────────── */
.row { display: grid; grid-template-columns: minmax(0,1fr); gap: 1rem; }
.nav-section { margin-top: 1.5rem; }

/* ── Footer ──────────────────────────────────────────────────── */
footer {
    padding: .85rem 1.75rem 1.1rem;
    font-size: .72rem;
    color: var(--text-muted);
    border-top: 1px solid var(--border);
    text-align: center;
    background: rgba(4,8,20,.8);
}

/* ── Utilities ───────────────────────────────────────────────── */
.text-success { color: var(--success); }
.text-danger  { color: var(--danger);  }
.text-warning { color: var(--warning); }
.text-accent  { color: var(--accent);  }
.text-muted   { color: var(--text-muted); }
.fw-bold      { font-weight: 700; }
.font-mono    { font-variant-numeric: tabular-nums; }
.mb-1 { margin-bottom: .5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }

/* ── Erro / Erro de Login ────────────────────────────────────── */
.erro, .alert-danger {
    padding: .6rem .8rem;
    border-radius: 5px;
    background: rgba(239,68,68,.1);
    color: var(--danger);
    font-size: .8rem;
    border: 1px solid rgba(239,68,68,.35);
    margin-bottom: .9rem;
}

/* ── Login Card ──────────────────────────────────────────────── */
.card-login {
    width: 100%;
    max-width: 370px;
    background: linear-gradient(135deg, var(--bg-card), var(--bg-card-alt));
    border-radius: 10px;
    padding: 1.75rem 1.6rem 2rem;
    border: 1px solid var(--border);
    box-shadow: 0 24px 64px rgba(4,8,25,.85);
}
.card-login h1 { font-size: 1.3rem; margin-bottom: .3rem; }

/* ── Responsividade ─────────────────────────────────────────── */
@media (max-width: 768px) {
    main { padding: 1rem 1rem 1.5rem; }
    header { padding: .6rem 1rem; }
    .grid-cards { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
    nav a { font-size: .72rem; padding: .25rem .5rem; }
    h1 { font-size: 1.2rem; }
    .filter-bar { gap: .4rem; }
    .filter-bar input, .filter-bar select { min-width: 100px; }
}

@media (max-width: 480px) {
    .grid-cards { grid-template-columns: 1fr 1fr; }
    nav { gap: .15rem; }
    .card-value { font-size: 1.15rem; }
}

/* ── Reduzir animações (acessibilidade) ─────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition: none !important; animation: none !important; }
}


/* ═══════════════════════════════════════════════════════════════
   CLASSES COMPLEMENTARES — páginas do sistema
   ═══════════════════════════════════════════════════════════════ */

/* ── Cards de métricas (entradas, despesas, empresa, pessoal) ── */
.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.2rem;
    margin-bottom: 1.5rem;
}
.cards-grid-recebimentos {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.2rem;
    margin-top: 1rem;
}
@media (max-width: 860px) {
    .cards-grid-recebimentos { grid-template-columns: 1fr; }
}
.card-metric, .card-recebimento-mensal {
    background: linear-gradient(135deg, var(--bg-card), var(--bg-card-alt));
    border-radius: 9px;
    padding: 1.1rem 1.2rem;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-card);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    overflow: hidden;
    min-width: 0;
}
.card-recebimento-mensal {
    display: flex;
    flex-direction: column;
}
.card-recebimento-mensal h2 {
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-muted);
    margin: 0 0 .3rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.card-recebimento-mensal h2 small {
    font-size: .68rem;
    padding: .08rem .4rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    color: var(--text-muted);
}
.card-recebimento-mensal .valor {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 .15rem;
    color: var(--text);
}
.card-recebimento-mensal .descricao {
    font-size: .75rem;
    color: var(--text-muted);
    margin: 0 0 .7rem;
}
.card-recebimento-mensal table {
    font-size: .73rem;
    width: 100%;
    /* overflow-x: auto; */
    /* display: block; */
}
.card-metric:hover, .card-recebimento-mensal:hover {
    transform: translateY(-2px);
    border-color: var(--border-hover);
    box-shadow: var(--shadow-hover);
}
.card-metric h2 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: .85rem;
    margin: 0 0 .5rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text-muted);
    font-weight: 500;
}
.card-metric h2 small {
    font-size: .68rem;
    padding: .1rem .5rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    color: var(--text-muted);
    opacity: .85;
}
.card-metric .valor {
    font-size: 1.7rem;
    font-weight: 700;
    margin: 0 0 .25rem;
    font-variant-numeric: tabular-nums;
    letter-spacing: -.01em;
    color: var(--text);
}
.card-metric .descricao {
    margin: 0;
    font-size: .78rem;
    color: var(--text-muted);
}
.cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.2rem;
}

/* ── KPI cards simples ─────────────────────────────────────── */
.kpi {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: .9rem 1rem;
}

/* ── Grid forms ────────────────────────────────────────────── */
.grid-form {
    display: grid;
    grid-template-columns: 2fr 1.5fr 1fr 1fr auto;
    gap: .75rem;
    align-items: end;
}
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .75rem;
    align-items: end;
}
.form-group { display: flex; flex-direction: column; gap: .3rem; }
.campo      { display: flex; flex-direction: column; gap: .3rem; }

@media (max-width: 900px) {
    .grid-form { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .grid-form { grid-template-columns: 1fr; }
    .form-grid { grid-template-columns: 1fr; }
}

/* ── Filtro linha ──────────────────────────────────────────── */
.filtro-linha {
    display: flex;
    gap: .6rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-bottom: 1.1rem;
    padding: .75rem 1rem;
    background: var(--bg-card);
    border-radius: 7px;
    border: 1px solid var(--border);
}
.filtro-linha label  { margin-bottom: .2rem; font-size: .75rem; }
.filtro-linha input,
.filtro-linha select { width: auto; min-width: 110px; }

/* ── Badges extras ──────────────────────────────────────────── */
.badge-mensal  { border-color: #38bdf8; color: #38bdf8; }
.badge-pontual { border-color: var(--warning); color: var(--warning); }
.badge-ok      { border-color: var(--success); color: var(--success); }
.badge-off     { border-color: var(--text-muted); color: var(--text-muted); opacity: .65; }
.badge-admin   { border-color: var(--accent); color: var(--accent); }
.badge-user    { border-color: var(--text-muted); color: var(--text-muted); }

/* Tags inline ─────────────────────────────────────────────── */
/* Mensal = azul ciano  |  Pontual = laranja  |  Flexível = roxo */
.tag-mensal  { display:inline-block;padding:.1rem .45rem;border-radius:999px;font-size:.65rem;font-weight:600;
               background:rgba(14,165,233,.12);color:#0EA5E9;border:1px solid rgba(14,165,233,.4); }
.tag-pontual { display:inline-block;padding:.1rem .45rem;border-radius:999px;font-size:.65rem;font-weight:600;
               background:rgba(245,158,11,.12);color:#F59E0B;border:1px solid rgba(245,158,11,.4); }
.tag-flexivel{ display:inline-block;padding:.1rem .45rem;border-radius:999px;font-size:.65rem;font-weight:600;
               background:rgba(168,85,247,.12);color:#A855F7;border:1px solid rgba(168,85,247,.4); }

/* ── Table helpers ─────────────────────────────────────────── */
.td-valor  { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.td-data   { white-space: nowrap; color: var(--text-muted); }
.td-acoes  { white-space: nowrap; }
.actions   { display: flex; gap: .3rem; align-items: center; }
.nowrap    { white-space: nowrap; }

/* ── Text helpers ──────────────────────────────────────────── */
.txt-muted  { color: var(--text-muted); }
.muted      { color: var(--text-muted); }
.valor      { font-size: 1.4rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.descricao  { font-size: .8rem; color: var(--text-muted); margin: .2rem 0 0; }

/* ── Button extras ─────────────────────────────────────────── */
.btn-primary {
    background: var(--accent);
    color: #0A0A0A;
    font-weight: 600;
    border: none;
}
.btn-primary:hover { background: var(--accent-dark); }
.btn-back {
    background: rgba(255,255,255,.06);
    color: var(--text);
    border: 1px solid var(--border);
}
.btn-back:hover { background: rgba(255,255,255,.11); }
.btn-small {
    padding: .22rem .55rem;
    font-size: .72rem;
    border-radius: 4px;
}

/* ── Flash messages (ok/erro) ──────────────────────────────── */
.msg-ok {
    padding: .55rem .8rem;
    background: rgba(16,185,129,.1);
    color: var(--success);
    border: 1px solid rgba(16,185,129,.3);
    border-radius: 5px;
    margin-bottom: .9rem;
    font-size: .82rem;
}
.msg-erro {
    padding: .55rem .8rem;
    background: rgba(239,68,68,.1);
    color: var(--danger);
    border: 1px solid rgba(239,68,68,.3);
    border-radius: 5px;
    margin-bottom: .9rem;
    font-size: .82rem;
}

/* ── Subtitle ──────────────────────────────────────────────── */
.subtitle {
    color: var(--text-muted);
    font-size: .88rem;
    margin: -.2rem 0 1.2rem;
}

/* ── Section cards ─────────────────────────────────────────── */
section.card {
    background: var(--bg-card);
    border-radius: 9px;
    padding: 1.1rem 1.2rem;
    border: 1px solid var(--border);
    box-shadow: var(--shadow-card);
    margin-bottom: 1.4rem;
}
section.card h2 {
    font-size: 1rem;
    margin: 0 0 .75rem;
    color: var(--text);
}

/* ── Responsive table wrapper ──────────────────────────────── */
.table-wrapper {
    /* overflow-x: auto; */
    -webkit-overflow-scrolling: touch;
    border-radius: 7px;
    border: 1px solid var(--border);
}

/* ── Skeleton / empty state ────────────────────────────────── */
.empty-state {
    text-align: center;
    padding: 2rem 1rem;
    color: var(--text-muted);
    font-size: .85rem;
}

/* Sticky table header fix to avoid overlapping main header */
.table-wrapper thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--bg-card);
}

/* Ajuste para evitar sobreposição do cabeçalho fixo */
main { scroll-margin-top: 4rem; }
.table-wrapper thead th { top: 3.5rem !important; } /* Ajuste se o header principal tiver ~3.5rem */

/* ── Footer ─────────────────────────────────────────────────── */
.main-footer {
    margin-top: auto;
    padding: 2rem 1.5rem 1rem;
    background: linear-gradient(to top, rgba(8,14,31,1), rgba(13,27,62,0.8));
    border-top: 1px solid var(--border);
    backdrop-filter: blur(10px);
}

.footer-shortcuts {
    display: flex;
    justify-content: center;
    gap: .8rem;
    flex-wrap: wrap;
    max-width: 1200px;
    margin: 0 auto 1.5rem;
}

.footer-tile {
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: .8rem 1.2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    min-width: 110px;
    transition: all .2s ease;
    text-decoration: none !important;
}

.footer-tile:hover {
    background: rgba(240, 165, 0, .08);
    border-color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 4px 15px rgba(0,0,0,.3);
}

.footer-tile .tile-icon {
    font-size: 1.3rem;
}

.footer-tile .tile-label {
    font-size: .72rem;
    font-weight: 500;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: .03em;
}

.footer-tile:hover .tile-label {
    color: var(--accent);
}

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,.05);
    color: var(--text-muted);
    font-size: .68rem;
    letter-spacing: .02em;
}

@media (max-width: 768px) {
    .footer-shortcuts { gap: .5rem; }
    .footer-tile { padding: .6rem; min-width: 90px; }
    .footer-bottom { flex-direction: column; gap: .5rem; text-align: center; }
}

/* ── Header Optimization ────────────────────────────────────── */
header {
    background: rgba(13, 27, 62, 0.85);
    backdrop-filter: blur(12px) saturate(180%);
    -webkit-backdrop-filter: blur(12px) saturate(180%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
}

.brand-text-main {
    background: linear-gradient(135deg, #FFF, #7B8BB2);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: .9rem;
    letter-spacing: .1em;
}

nav a.active {
    background: linear-gradient(135deg, rgba(240, 165, 0, 0.2), rgba(240, 165, 0, 0.05));
    box-shadow: 0 0 15px rgba(240, 165, 0, 0.1);
    border: 1px solid rgba(240, 165, 0, 0.2);
}
