*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Variáveis — Modo Claro ─────────────────────────────────────────── */
:root {
    --cor-primaria: #1D9E75;
    --cor-primaria-hover: #0F6E56;
    --cor-bg: #f7f7f5;
    --cor-card: #ffffff;
    --cor-borda: rgba(0,0,0,0.1);
    --cor-borda-hover: rgba(0,0,0,0.2);
    --cor-texto-pri: #1a1a18;
    --cor-texto: #1a1a18;
    --cor-texto-sec: #6b6b67;
    --cor-texto-ter: #9e9e9a;
    --cor-danger: #E24B4A;
    --cor-warning-bg: #FAEEDA;
    --cor-warning-txt: #633806;
    --cor-warning-borda: #EF9F27;
    --raio-md: 8px;
    --raio-lg: 12px;
    --sombra: 0 1px 3px rgba(0,0,0,0.07);
}

/* ── Variáveis — Modo Escuro ────────────────────────────────────────── */
[data-tema="escuro"] {
    --cor-bg: #141413;
    --cor-card: #1e1e1c;
    --cor-borda: rgba(255,255,255,0.08);
    --cor-borda-hover: rgba(255,255,255,0.16);
    --cor-texto-pri: #f0f0ee;
    --cor-texto: #f0f0ee;
    --cor-texto-sec: #9e9e9a;
    --cor-texto-ter: #6b6b67;
    --cor-warning-bg: #2a1f0a;
    --cor-warning-txt: #f0b860;
    --cor-warning-borda: #7a5010;
    --sombra: 0 1px 3px rgba(0,0,0,0.3);
}
[data-tema="escuro"] .badge-teal   { background: #0d3327; color: #4dd4a0; }
[data-tema="escuro"] .badge-purple { background: #1e1a40; color: #a09af0; }
[data-tema="escuro"] .badge-blue   { background: #0d1e30; color: #60a8e0; }
[data-tema="escuro"] .badge-coral  { background: #2e120a; color: #e8896a; }
[data-tema="escuro"] .alerta-erro  { background: #2e0f0f; color: #f09090; border-color: #7a2020; }
[data-tema="escuro"] .alerta-sucesso { background: #112008; color: #80c050; border-color: #2a5010; }
[data-tema="escuro"] .login-box    { border-color: var(--cor-borda); }
[data-tema="escuro"] input, [data-tema="escuro"] select, [data-tema="escuro"] textarea {
    background: #2a2a28 !important;
    color: var(--cor-texto) !important;
    border-color: var(--cor-borda-hover) !important;
}
[data-tema="escuro"] .ql-toolbar  { background: #2a2a28; border-color: var(--cor-borda-hover) !important; }
[data-tema="escuro"] .ql-container { background: #2a2a28; border-color: var(--cor-borda-hover) !important; }
[data-tema="escuro"] .ql-editor   { color: var(--cor-texto); }

/* ── Base ────────────────────────────────────────────────────────────── */
body {
    font-family: system-ui, -apple-system, sans-serif;
    background: var(--cor-bg);
    color: var(--cor-texto);
    font-size: 15px;
    line-height: 1.5;
    transition: background .2s, color .2s;
}

/* ── Topbar ──────────────────────────────────────────────────────────── */
.topbar {
    background: var(--cor-card);
    border-bottom: 0.5px solid var(--cor-borda);
    padding: 0 20px;
    height: 52px;
    display: flex;
    align-items: center;
    gap: 16px;
    position: sticky;
    top: 0;
    z-index: 100;
}
.topbar-logo { display: flex; align-items: center; gap: 6px; text-decoration: none; }
.logo-v { width: 28px; height: 28px; background: var(--cor-primaria); color: #fff; border-radius: 7px; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 15px; flex-shrink: 0; }
.logo-nome { font-weight: 500; font-size: 15px; color: var(--cor-texto); }
.topbar-nav { display: flex; gap: 2px; flex: 1; overflow-x: auto; }
.topbar-nav a { font-size: 13px; padding: 6px 10px; border-radius: var(--raio-md); color: var(--cor-texto-sec); text-decoration: none; transition: background .15s; white-space: nowrap; }
.topbar-nav a:hover { background: var(--cor-bg); color: var(--cor-texto); }
.topbar-nav a.ativo { background: var(--cor-bg); color: var(--cor-texto); font-weight: 500; }
.topbar-user { display: flex; align-items: center; gap: 8px; font-size: 13px; flex-shrink: 0; }
.topbar-user-link { color: var(--cor-texto-sec); text-decoration: none; font-size: 13px; padding: 2px 4px; border-radius: 4px; transition: color .15s; white-space: nowrap; }
.topbar-user-link:hover { color: var(--cor-primaria); text-decoration: underline; }
.btn-logout { font-size: 13px; color: var(--cor-texto-sec); text-decoration: none; padding: 4px 10px; border: 0.5px solid var(--cor-borda); border-radius: var(--raio-md); transition: all .15s; white-space: nowrap; }
.btn-logout:hover { border-color: var(--cor-borda-hover); color: var(--cor-texto); }

/* ── Botão modo escuro ───────────────────────────────────────────────── */
.btn-tema {
    background: none;
    border: 0.5px solid var(--cor-borda);
    border-radius: var(--raio-md);
    padding: 4px 8px;
    cursor: pointer;
    font-size: 15px;
    line-height: 1;
    color: var(--cor-texto-sec);
    transition: all .15s;
    flex-shrink: 0;
}
.btn-tema:hover { border-color: var(--cor-borda-hover); color: var(--cor-texto); }

/* ── Container ───────────────────────────────────────────────────────── */
.container { max-width: 760px; margin: 0 auto; padding: 20px 16px 60px; }

/* ── Lembretes ───────────────────────────────────────────────────────── */
.lembretes-container { margin-bottom: 20px; }
.lembrete-banner { background: var(--cor-warning-bg); border: 0.5px solid var(--cor-warning-borda); border-radius: var(--raio-md); padding: 10px 14px; display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-size: 14px; color: var(--cor-warning-txt); }
.lembrete-icone { width: 22px; height: 22px; background: #EF9F27; color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.lembrete-hora { font-size: 12px; font-weight: 600; color: #9E5C1D; background: #FDF0E0; border-radius: 4px; padding: 1px 6px; margin: 0 4px; }
[data-tema="escuro"] .lembrete-hora { color: #f0b860; background: #3a2a0a; }

/* ── Stats ───────────────────────────────────────────────────────────── */
.painel-header { display: flex; flex-direction: column; gap: 14px; margin-bottom: 24px; }
.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.stat-card { background: var(--cor-card); border: 0.5px solid var(--cor-borda); border-radius: var(--raio-md); padding: 12px 14px; }
.stat-label { font-size: 12px; color: var(--cor-texto-sec); margin-bottom: 4px; }
.stat-value { font-size: 22px; font-weight: 500; }

/* ── Filtros ─────────────────────────────────────────────────────────── */
.filtros { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.filtros form { display: flex; gap: 8px; flex: 1; flex-wrap: wrap; }
.filtros select, .filtros input[type=text] { font-size: 13px; padding: 7px 10px; border: 0.5px solid var(--cor-borda); border-radius: var(--raio-md); background: var(--cor-card); color: var(--cor-texto); cursor: pointer; }

/* ── Botões ──────────────────────────────────────────────────────────── */
.btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border: 0.5px solid var(--cor-borda-hover); border-radius: var(--raio-md); background: transparent; font-size: 14px; color: var(--cor-texto); cursor: pointer; transition: all .15s; text-decoration: none; }
.btn:hover { background: var(--cor-bg); }
.btn-primary { background: var(--cor-primaria); color: #fff !important; border-color: var(--cor-primaria); }
.btn-primary:hover { background: var(--cor-primaria-hover); border-color: var(--cor-primaria-hover); }
.btn-full { width: 100%; justify-content: center; padding: 10px; }
.btn-sm { padding: 4px 10px; font-size: 12px; }

/* ── Cards de tarefa ─────────────────────────────────────────────────── */
.grupo-tarefas { margin-bottom: 24px; }
.grupo-titulo { font-size: 11px; font-weight: 600; color: var(--cor-texto-sec); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 8px; }

.task-card { background: var(--cor-card); border: 0.5px solid var(--cor-borda); border-radius: var(--raio-lg); padding: 11px 12px; margin-bottom: 7px; display: flex; gap: 10px; align-items: flex-start; transition: border-color .15s, box-shadow .15s; }
.task-card:hover { border-color: var(--cor-borda-hover); box-shadow: var(--sombra); }
.task-card.done { opacity: .5; }
.task-card.done .task-titulo { text-decoration: line-through; }

.check-btn { width: 20px; height: 20px; border-radius: 50%; border: 1.5px solid var(--cor-borda-hover); background: transparent; cursor: pointer; flex-shrink: 0; margin-top: 1px; display: flex; align-items: center; justify-content: center; transition: all .15s; color: #fff; }
.check-btn:hover { border-color: var(--cor-primaria); }
.check-btn.checked { background: var(--cor-primaria); border-color: var(--cor-primaria); }

.task-body { flex: 1; min-width: 0; }
.task-titulo { font-size: 14px; font-weight: 500; margin-bottom: 3px; }
.task-desc { font-size: 13px; color: var(--cor-texto-sec); margin-bottom: 4px; }
.task-desc-html { font-size: 13px; color: var(--cor-texto-sec); margin-bottom: 4px; line-height: 1.6; }
.task-desc-html p { margin: 0 0 4px; }
.task-desc-html ul, .task-desc-html ol { margin: 0 0 4px 18px; }
.task-desc-html strong { font-weight: 600; color: var(--cor-texto); }
.task-desc-html em { font-style: italic; }
.task-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 4px; }
.task-lembrete { font-size: 12px; color: var(--cor-texto-ter); }

/* ── Subtarefas no card ──────────────────────────────────────────────── */
.subtarefas-wrap { margin-top: 8px; border-top: 0.5px solid var(--cor-borda); padding-top: 8px; }
.subtarefa-item { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.subtarefa-check { width: 16px; height: 16px; border-radius: 4px; border: 1.5px solid var(--cor-borda-hover); background: transparent; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: all .15s; color: #fff; }
.subtarefa-check:hover { border-color: var(--cor-primaria); }
.subtarefa-check.checked { background: var(--cor-primaria); border-color: var(--cor-primaria); }
.subtarefa-titulo { font-size: 13px; flex: 1; color: var(--cor-texto); }
.subtarefa-titulo.done { text-decoration: line-through; color: var(--cor-texto-ter); }
.subtarefa-del { background: none; border: none; color: var(--cor-texto-ter); cursor: pointer; font-size: 12px; padding: 2px 4px; border-radius: 3px; opacity: 0; transition: opacity .15s, color .15s; }
.subtarefa-item:hover .subtarefa-del { opacity: 1; }
.subtarefa-del:hover { color: var(--cor-danger); }
.subtarefa-progresso { font-size: 11px; color: var(--cor-texto-ter); margin-bottom: 6px; }
.subtarefa-progresso-bar { height: 3px; background: var(--cor-borda); border-radius: 2px; margin-bottom: 6px; overflow: hidden; }
.subtarefa-progresso-fill { height: 100%; background: var(--cor-primaria); border-radius: 2px; transition: width .3s; }
.subtarefa-add { display: flex; gap: 6px; margin-top: 6px; }
.subtarefa-add input { flex: 1; font-size: 12px; padding: 5px 8px; border: 0.5px solid var(--cor-borda); border-radius: var(--raio-md); background: var(--cor-bg); color: var(--cor-texto); }
.subtarefa-add input::placeholder { color: var(--cor-texto-ter); }
.subtarefa-toggle-btn { font-size: 12px; color: var(--cor-texto-ter); background: none; border: none; cursor: pointer; padding: 2px 0; display: flex; align-items: center; gap: 4px; margin-top: 4px; transition: color .15s; }
.subtarefa-toggle-btn:hover { color: var(--cor-primaria); }

/* ── Badges ──────────────────────────────────────────────────────────── */
.badge { font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 500; }
.badge-teal   { background: #E1F5EE; color: #085041; }
.badge-purple { background: #EEEDFE; color: #3C3489; }
.badge-blue   { background: #E6F1FB; color: #0C447C; }
.badge-coral  { background: #FAECE7; color: #712B13; }

/* ── Botões de ação no card ──────────────────────────────────────────── */
.task-actions { display: flex; gap: 2px; flex-shrink: 0; }
.btn-editar  { background: none; border: none; color: var(--cor-texto-ter); cursor: pointer; font-size: 15px; padding: 3px 6px; border-radius: 4px; transition: color .15s; }
.btn-editar:hover  { color: var(--cor-primaria); }
.btn-excluir { background: none; border: none; color: var(--cor-texto-ter); cursor: pointer; font-size: 14px; padding: 3px 6px; border-radius: 4px; transition: color .15s; }
.btn-excluir:hover { color: var(--cor-danger); }

/* ── Vazio ───────────────────────────────────────────────────────────── */
.vazio { text-align: center; color: var(--cor-texto-sec); font-size: 14px; padding: 40px 0; }

/* ── Modais ──────────────────────────────────────────────────────────── */
.modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 200; align-items: center; justify-content: center; padding: 16px; }
.modal-overlay.aberto { display: flex; }
.modal-box { background: var(--cor-card); border-radius: var(--raio-lg); padding: 22px; width: 100%; max-width: 500px; max-height: 92vh; overflow-y: auto; }
.modal-box h3 { font-size: 16px; font-weight: 500; margin-bottom: 18px; }
.modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 18px; }

/* ── Campos de formulário ────────────────────────────────────────────── */
.campo { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.campo label { font-size: 13px; color: var(--cor-texto-sec); }
.campo input[type=text],
.campo input[type=email],
.campo input[type=password],
.campo input[type=date],
.campo input[type=time],
.campo select,
.campo textarea {
    padding: 8px 10px;
    border: 0.5px solid var(--cor-borda-hover);
    border-radius: var(--raio-md);
    font-size: 14px;
    color: var(--cor-texto);
    background: var(--cor-card);
    width: 100%;
}
.campo textarea { resize: vertical; min-height: 60px; }
.campo-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.campo-check { justify-content: flex-end; }
.campo-check label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--cor-texto-sec); cursor: pointer; }
input[type="time"]:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Editor Quill ────────────────────────────────────────────────────── */
.editor-toggle { font-size: 12px; color: var(--cor-primaria); background: none; border: none; cursor: pointer; padding: 2px 0; margin-bottom: 6px; text-decoration: underline; }
.editor-toggle:hover { color: var(--cor-primaria-hover); }
.editor-wrap { display: none; }
.editor-wrap.visivel { display: block; }
.ql-toolbar { border-radius: var(--raio-md) var(--raio-md) 0 0 !important; border-color: var(--cor-borda-hover) !important; }
.ql-container { border-radius: 0 0 var(--raio-md) var(--raio-md) !important; border-color: var(--cor-borda-hover) !important; font-size: 14px !important; }
.ql-editor { min-height: 80px; color: var(--cor-texto); }

/* ── Alertas ─────────────────────────────────────────────────────────── */
.alerta { padding: 10px 14px; border-radius: var(--raio-md); font-size: 14px; margin-bottom: 16px; }
.alerta-erro    { background: #FCEBEB; color: #791F1F; border: 0.5px solid #F09595; }
.alerta-sucesso { background: #EAF3DE; color: #27500A; border: 0.5px solid #97C459; }

/* ── Login ───────────────────────────────────────────────────────────── */
.login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: var(--cor-bg); }
.login-box { background: var(--cor-card); border: 0.5px solid var(--cor-borda); border-radius: var(--raio-lg); padding: 32px; width: 100%; max-width: 380px; }
.login-logo { display: flex; align-items: center; gap: 8px; margin-bottom: 20px; }
.login-box h1 { font-size: 18px; font-weight: 500; margin-bottom: 20px; color: var(--cor-texto-sec); }
.login-hint { font-size: 12px; color: var(--cor-texto-ter); margin-top: 14px; text-align: center; }
.login-hint code { background: var(--cor-bg); padding: 1px 5px; border-radius: 4px; }

/* ── Placeholders ────────────────────────────────────────────────────── */
input::placeholder, textarea::placeholder { color: var(--cor-texto-ter); }

/* ── Print ───────────────────────────────────────────────────────────── */
@media print { .btn-imprimir { display: none !important; } }

/* ── Responsividade Mobile ───────────────────────────────────────────── */
@media (max-width: 600px) {
    .topbar { padding: 0 12px; gap: 8px; }
    .logo-nome { display: none; }
    .topbar-nav a { padding: 5px 8px; font-size: 12px; }
    .topbar-nav a[href="exportar.php"] { display: none; }
    .topbar-user-link { display: none; }

    .container { padding: 14px 12px 80px; }

    .stats-grid { grid-template-columns: repeat(3,1fr); gap: 8px; }
    .stat-card { padding: 10px 10px; }
    .stat-value { font-size: 18px; }

    .filtros { gap: 6px; }
    .filtros form { flex-direction: column; }
    .filtros select, .filtros input[type=text] { width: 100%; }
    .btn.btn-primary { width: 100%; justify-content: center; }

    .task-card { padding: 10px 10px; }
    .task-titulo { font-size: 13px; }

    .campo-row { grid-template-columns: 1fr; }

    .modal-box { padding: 18px 16px; }
    .modal-overlay { padding: 10px; align-items: flex-end; }
    .modal-box { border-radius: var(--raio-lg) var(--raio-lg) 0 0; max-height: 95vh; }

    /* Botão flutuante nova tarefa no mobile */
    .btn-nova-tarefa-mobile {
        position: fixed;
        bottom: 20px;
        right: 16px;
        width: 52px;
        height: 52px;
        border-radius: 50%;
        background: var(--cor-primaria);
        color: #fff;
        font-size: 26px;
        border: none;
        cursor: pointer;
        box-shadow: 0 4px 12px rgba(29,158,117,0.4);
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 150;
        transition: background .15s, transform .15s;
    }
    .btn-nova-tarefa-mobile:hover { background: var(--cor-primaria-hover); transform: scale(1.05); }
    .btn-nova-tarefa-desktop { display: none; }
}
@media (min-width: 601px) {
    .btn-nova-tarefa-mobile { display: none; }
}

/* ── Tags ────────────────────────────────────────────────────────────── */
.tags-checkboxes { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-check { display: flex; align-items: center; cursor: pointer; }
.tag-check input { display: none; }
.tag-check input:checked + .badge { outline: 2px solid var(--cor-primaria); outline-offset: 2px; }
.tag-check .badge { cursor: pointer; transition: outline .1s; }
.badge-tag { font-size: 11px; }

/* ── Acompanhamento no card ──────────────────────────────────────────── */
.badge-acomp { font-size: 10px; padding: 1px 6px; vertical-align: middle; margin-left: 4px; }
.task-card.acomp-em_andamento { border-left: 3px solid #60a8e0; }
.task-card.acomp-aguardando   { border-left: 3px solid #e8896a; }
[data-tema="escuro"] .task-card.acomp-em_andamento { border-left-color: #3a7ab0; }
[data-tema="escuro"] .task-card.acomp-aguardando   { border-left-color: #b05030; }

/* ── Recorrência no card ─────────────────────────────────────────────── */
.badge-recorrencia { font-size: 11px; color: var(--cor-texto-ter); margin-left: 4px; }

/* ── Dashboard ───────────────────────────────────────────────────────── */
.dash-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 20px; }
.kpi-card { background: var(--cor-card); border: 0.5px solid var(--cor-borda); border-radius: var(--raio-lg); padding: 16px; text-align: center; }
.kpi-valor { font-size: 28px; font-weight: 600; color: var(--cor-primaria); }
.kpi-label { font-size: 12px; color: var(--cor-texto-sec); margin-top: 4px; }
.dash-graficos { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.dash-card { background: var(--cor-card); border: 0.5px solid var(--cor-borda); border-radius: var(--raio-lg); padding: 18px; }
.dash-titulo { font-size: 13px; font-weight: 500; color: var(--cor-texto-sec); margin-bottom: 14px; }
.dash-projetos { display: flex; flex-direction: column; gap: 12px; }
.dash-projeto-item { }

@media (max-width: 600px) {
    .dash-kpis { grid-template-columns: repeat(2,1fr); }
    .dash-graficos { grid-template-columns: 1fr; }
}
