/* ===== RESET & BASE ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
:root {
    --bg: #0f1117; --bg2: #1a1d27; --bg3: #242833;
    --surface: #1e2130; --surface2: #282c3e;
    --border: #2e3348; --border2: #3a3f55;
    --text: #e8eaf0; --text2: #9ca3b8; --text3: #6b7280;
    --green: #00d4aa; --green-bg: rgba(0,212,170,.12);
    --red: #f43f5e; --red-bg: rgba(244,63,94,.12);
    --blue: #3b82f6; --blue-bg: rgba(59,130,246,.12);
    --purple: #8b5cf6; --purple-bg: rgba(139,92,246,.12);
    --orange: #f59e0b; --orange-bg: rgba(245,158,11,.12);
    --cyan: #06b6d4; --cyan-bg: rgba(6,182,212,.12);
    --pink: #ec4899; --pink-bg: rgba(236,72,153,.12);
    --amber: #f59e0b; --teal: #14b8a6; --teal-bg: rgba(20,184,166,.12);
    --sidebar-w: 260px;
    --radius: 12px; --radius-sm: 8px;
    --shadow: 0 4px 24px rgba(0,0,0,.3);
    --transition: .25s cubic-bezier(.4,0,.2,1);
}
html { font-size: 14px; }
body { font-family:'Inter',sans-serif; background:var(--bg); color:var(--text); display:flex; min-height:100vh; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
input, select, button { font-family:inherit; font-size:.9rem; }
.mt-20 { margin-top: 20px; }

/* ===== SIDEBAR ===== */
.sidebar {
    width:var(--sidebar-w); background:var(--bg2); border-right:1px solid var(--border);
    display:flex; flex-direction:column; position:fixed; top:0; left:0; bottom:0; z-index:100;
    transition: transform var(--transition);
}
.sidebar-header { padding:24px 20px; border-bottom:1px solid var(--border); }
.logo { display:flex; align-items:center; gap:12px; font-size:1.2rem; font-weight:700; }
.logo i { font-size:1.5rem; color:var(--green); }
.nav-links { list-style:none; flex:1; padding:12px 10px; overflow-y:auto; }
.nav-link {
    display:flex; align-items:center; gap:12px; padding:12px 16px; border-radius:var(--radius-sm);
    color:var(--text2); font-weight:500; transition: all var(--transition); margin-bottom:2px;
}
.nav-link:hover { background:var(--bg3); color:var(--text); }
.nav-link.active { background:linear-gradient(135deg,rgba(0,212,170,.15),rgba(59,130,246,.1)); color:var(--green); }
.nav-link i { width:20px; text-align:center; font-size:1rem; }
.sidebar-footer { padding:16px 20px; border-top:1px solid var(--border); }
.month-selector label { display:block; font-size:.75rem; color:var(--text3); margin-bottom:6px; text-transform:uppercase; letter-spacing:1px; }
.month-selector input[type="month"] {
    width:100%; padding:10px 12px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm);
    color:var(--text); outline:none;
}
.month-selector input[type="month"]:focus { border-color:var(--green); }

/* ===== MAIN ===== */
.main-content { margin-left:var(--sidebar-w); flex:1; padding:0; min-height:100vh; }
.topbar {
    display:flex; align-items:center; gap:16px; padding:16px 32px;
    background:var(--bg2); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:50;
    backdrop-filter:blur(12px);
}
.topbar h1 { flex:1; font-size:1.3rem; font-weight:700; }
.menu-toggle { display:none; background:none; border:none; color:var(--text); font-size:1.3rem; cursor:pointer; }
.topbar-actions { display:flex; gap:8px; }

/* ===== MONTH DISPLAY BAR ===== */
.month-display-bar {
    display:flex; align-items:center; justify-content:center; gap:20px;
    padding:18px 32px;
    background:linear-gradient(135deg, rgba(0,212,170,.06) 0%, rgba(59,130,246,.04) 100%);
    border-bottom:1px solid var(--border);
    position:sticky; top:57px; z-index:49;
    backdrop-filter:blur(12px);
}
.month-display-text {
    font-size:2rem; font-weight:800; letter-spacing:1px;
    background:linear-gradient(135deg, var(--green), var(--blue));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text; text-transform:capitalize;
    text-align:center; min-width:280px;
    user-select:none;
}
.month-nav-btn {
    background:var(--bg3); border:1px solid var(--border); color:var(--text2);
    width:40px; height:40px; border-radius:50%; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    font-size:1rem; transition:all var(--transition);
}
.month-nav-btn:hover {
    background:var(--green-bg); border-color:var(--green); color:var(--green);
    transform:scale(1.1);
}

/* ===== BUTTONS ===== */
.btn {
    display:inline-flex; align-items:center; gap:8px; padding:10px 20px;
    border:none; border-radius:var(--radius-sm); font-weight:600; cursor:pointer;
    transition: all var(--transition);
}
.btn-primary { background:linear-gradient(135deg,var(--green),#00b894); color:#0f1117; }
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 4px 16px rgba(0,212,170,.3); }
.btn-outline { background:transparent; border:1px solid var(--border); color:var(--text2); }
.btn-outline:hover { border-color:var(--green); color:var(--green); }
.btn-sm { padding:6px 12px; font-size:.8rem; }
.btn-danger { background:var(--red-bg); color:var(--red); border:1px solid transparent; }
.btn-danger:hover { border-color:var(--red); }

/* ===== SECTIONS ===== */
.content-section { display:none; padding:24px 32px; animation:fadeIn .3s ease; }
.content-section.active { display:block; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ===== CARDS ===== */
.cards-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:16px; }
.card {
    background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
    padding:20px; display:flex; align-items:center; gap:16px;
    transition: all var(--transition);
}
.card:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.card-icon {
    width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center;
    font-size:1.2rem;
}
.card-green .card-icon { background:var(--green-bg); color:var(--green); }
.card-blue .card-icon { background:var(--blue-bg); color:var(--blue); }
.card-purple .card-icon { background:var(--purple-bg); color:var(--purple); }
.card-orange .card-icon { background:var(--orange-bg); color:var(--orange); }
.card-cyan .card-icon { background:var(--cyan-bg); color:var(--cyan); }
.card-amber .card-icon { background:var(--orange-bg); color:var(--amber); }
.card-pink .card-icon { background:var(--pink-bg); color:var(--pink); }
.card-teal .card-icon { background:var(--teal-bg); color:var(--teal); }
.card-label { display:block; font-size:.8rem; color:var(--text3); margin-bottom:4px; }
.card-value { display:block; font-size:1.25rem; font-weight:700; }
.card-sub { display:block; font-size:.7rem; color:var(--pink); margin-top:2px; font-style:italic; }

/* ===== PANELS ===== */
.panel {
    background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
    padding:24px; transition: all var(--transition);
}
.panel:hover { border-color:var(--border2); }
.panel h3 { font-size:1rem; font-weight:600; margin-bottom:16px; display:flex; align-items:center; gap:10px; }
.panel h3 i { color:var(--green); }
.panel-header { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:12px; margin-bottom:16px; }
.panel-header h3 { margin-bottom:0; }
.big-value { font-size:2rem; font-weight:800; text-align:center; padding:16px; }

/* ===== FORMS ===== */
.form-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; align-items:end; }
.form-inline { display:flex; gap:14px; align-items:end; flex-wrap:wrap; }
.form-group label { display:block; font-size:.75rem; color:var(--text3); margin-bottom:6px; text-transform:uppercase; letter-spacing:.5px; font-weight:600; }
.form-group input, .form-group select {
    width:100%; padding:10px 14px; background:var(--bg3); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text); outline:none; transition: border var(--transition);
}
.form-group input:focus, .form-group select:focus { border-color:var(--green); }
.form-group input[readonly] { opacity:.6; cursor:default; }
.form-actions { display:flex; align-items:flex-end; }
.btn-inline-add {
    display:inline-flex; align-items:center; justify-content:center;
    width:20px; height:20px; border-radius:50%; border:1px solid var(--green);
    background:var(--green-bg); color:var(--green); font-size:.85rem; font-weight:700;
    cursor:pointer; margin-left:6px; padding:0; line-height:1; vertical-align:middle;
    transition:all var(--transition);
}
.btn-inline-add:hover { background:var(--green); color:#0f1117; }

/* ===== BADGES ===== */
.summary-badges { display:flex; gap:8px; flex-wrap:wrap; }
.badge {
    padding:6px 14px; border-radius:20px; font-size:.8rem; font-weight:500;
}
.badge-green { background:var(--green-bg); color:var(--green); }
.badge-red { background:var(--red-bg); color:var(--red); }
.badge-blue { background:var(--blue-bg); color:var(--blue); }
.badge-purple { background:var(--purple-bg); color:var(--purple); }
.badge-orange { background:var(--orange-bg); color:var(--orange); }
.badge-pink { background:var(--pink-bg); color:var(--pink); }

/* ===== TABLES ===== */
.table-wrap { overflow-x:auto; }
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
    text-align:left; padding:12px 14px; font-size:.75rem; text-transform:uppercase;
    letter-spacing:.5px; color:var(--text3); border-bottom:1px solid var(--border); font-weight:600;
}
.data-table td { padding:10px 14px; border-bottom:1px solid var(--border); font-size:.85rem; }
.data-table tbody tr { transition: background var(--transition); }
.data-table tbody tr:hover { background:var(--bg3); }
.data-table .tipo-entrada { color:var(--green); font-weight:600; }
.data-table .tipo-saida { color:var(--red); font-weight:600; }
.data-table .tipo-debito { color:var(--red); font-weight:600; }
.data-table .tipo-credito { color:var(--green); font-weight:600; }
.status-pendente { color:var(--orange); }
.status-compensado { color:var(--green); }
.status-devolvido { color:var(--red); }
.status-retirado { color:var(--blue); }

/* ===== DISTRIBUTION ===== */
.distrib-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; }
.distrib-item {
    text-align:center; padding:24px 16px; background:var(--bg3); border-radius:var(--radius);
    border:1px solid var(--border);
}
.distrib-item p { color:var(--text2); margin-bottom:8px; font-weight:500; }
.distrib-item h2 { font-size:1.4rem; font-weight:800; }
.distrib-bar {
    width:var(--pct); max-width:100%; height:8px; background:var(--clr); border-radius:4px;
    margin:0 auto 12px; position:relative;
}
.distrib-bar span {
    position:absolute; top:-22px; right:0; font-size:.7rem; font-weight:700; color:var(--clr);
}
.calc-summary { font-size:.9rem; line-height:2; color:var(--text2); }
.calc-summary .line { display:flex; justify-content:space-between; padding:4px 0; border-bottom:1px solid var(--border); }
.calc-summary .line b { color:var(--text); }
.calc-summary .line.total { font-weight:700; color:var(--green); font-size:1rem; border-top:2px solid var(--green); border-bottom:none; margin-top:8px; padding-top:8px; }
.calc-summary .line.comissao { color:var(--pink); font-weight:600; }
.calc-summary .line.comissao b { color:var(--pink); }
.calc-summary .section-label { color:var(--text3); font-size:.75rem; text-transform:uppercase; letter-spacing:1px; margin-top:12px; padding-top:8px; border-top:1px dashed var(--border); display:block; }

/* ===== COLLABORATORS ===== */
.colab-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:12px; }
.colab-card {
    background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius);
    padding:20px; display:flex; align-items:center; gap:14px;
}
.colab-card .avatar {
    width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--green),var(--blue));
    display:flex; align-items:center; justify-content:center; font-weight:700; color:#0f1117; font-size:1rem;
    flex-shrink:0;
}
.colab-card .colab-info { flex:1; }
.colab-card .colab-info .name { font-weight:600; }
.colab-card .colab-info .pct { color:var(--text3); font-size:.8rem; }
.colab-card .colab-info .commission { color:var(--green); font-weight:700; font-size:1.1rem; }
.colab-card .btn-remove { background:none; border:none; color:var(--text3); cursor:pointer; font-size:1rem; transition:color var(--transition); }
.colab-card .btn-remove:hover { color:var(--red); }

/* ===== CONFIG ===== */
.config-desc { color:var(--text3); font-size:.85rem; line-height:1.6; padding:8px 0; }
.config-alert { margin-top:12px; font-size:.85rem; font-weight:600; }
.config-alert.ok { color:var(--green); }
.config-alert.warn { color:var(--orange); }
.config-alert.error { color:var(--red); }

/* Tags (categories) */
.tags-list { display:flex; flex-wrap:wrap; gap:8px; }
.tag-item {
    display:inline-flex; align-items:center; gap:8px;
    background:var(--bg3); border:1px solid var(--border); border-radius:20px;
    padding:8px 14px; font-size:.85rem; font-weight:500; transition: all var(--transition);
}
.tag-item:hover { border-color:var(--green); }
.tag-item .tag-remove {
    background:none; border:none; color:var(--text3); cursor:pointer; font-size:.8rem;
    transition:color var(--transition); padding:0; line-height:1;
}
.tag-item .tag-remove:hover { color:var(--red); }

/* ===== CONTAS A PAGAR ===== */
.row-boleto-pendente { background:rgba(245,158,11,.15) !important; }
.row-boleto-pendente td { color:var(--orange) !important; }
.row-pago { opacity:.65; }
.row-pago td { text-decoration:line-through; color:var(--text3) !important; }
.row-pago td:last-child { text-decoration:none; }
.inline-select {
    padding:4px 8px; background:var(--bg3); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text); font-size:.8rem; cursor:pointer;
}
.inline-select:focus { border-color:var(--green); outline:none; }
.inline-toggle {
    padding:4px 12px; border-radius:4px; border:1px solid var(--border);
    background:var(--bg3); color:var(--text); cursor:pointer; font-size:.8rem; font-weight:600;
}
.inline-toggle.is-yes { background:var(--green-bg); color:var(--green); border-color:var(--green); }
.inline-toggle.is-no { background:var(--orange-bg); color:var(--orange); border-color:var(--orange); }

/* ===== FILTER BAR ===== */
.filter-bar {
    display:flex; align-items:center; gap:12px; margin-bottom:16px; padding:10px 14px;
    background:var(--bg3); border-radius:var(--radius-sm); font-size:.85rem; color:var(--text2);
}
.filter-bar select {
    padding:6px 12px; background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text); font-size:.85rem;
}

/* ===== CHART BARS ===== */
.chart-container { padding:8px 0; }
.chart-bar-row { display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.chart-bar-label { width:120px; font-size:.85rem; font-weight:500; text-align:right; color:var(--text2); }
.chart-bar-track { flex:1; height:28px; background:var(--bg3); border-radius:6px; overflow:hidden; position:relative; }
.chart-bar-fill {
    height:100%; border-radius:6px; display:flex; align-items:center; padding-left:10px;
    font-size:.75rem; font-weight:700; color:#fff; min-width:40px;
    transition: width .6s cubic-bezier(.4,0,.2,1);
}
.chart-bar-value { font-size:.85rem; font-weight:600; width:100px; text-align:right; }

/* ===== TOAST ===== */
.toast-container { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:8px; }
.toast {
    padding:12px 20px; border-radius:var(--radius-sm); font-size:.85rem; font-weight:500;
    animation:toastIn .3s ease; min-width:260px; display:flex; align-items:center; gap:10px;
    box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.toast-success { background:#065f46; color:#6ee7b7; border:1px solid #10b981; }
.toast-error { background:#7f1d1d; color:#fca5a5; border:1px solid #ef4444; }
.toast-info { background:#1e3a5f; color:#93c5fd; border:1px solid #3b82f6; }
@keyframes toastIn { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }

/* ===== LOGIN ===== */
.login-overlay {
    position:fixed; top:0; left:0; right:0; bottom:0; z-index:10000;
    background:linear-gradient(135deg,#0f1117 0%,#1a1d27 50%,#0f1117 100%);
    display:flex; align-items:center; justify-content:center;
}
.login-card {
    background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
    padding:40px; width:380px; max-width:95vw; box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.login-logo { text-align:center; margin-bottom:32px; }
.login-logo i { font-size:2.5rem; color:var(--green); display:block; margin-bottom:12px; }
.login-logo h2 { font-size:1.4rem; font-weight:700; color:var(--text); }
.login-card .form-group { margin-bottom:16px; }
.login-card .form-group input { width:100%; padding:12px 16px; }
.login-erro { color:var(--red); font-size:.85rem; margin-bottom:12px; text-align:center; }

/* ===== USER MANAGEMENT ===== */
.perms-grid {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:8px;
    padding:12px 0;
}
.perm-item {
    display:flex; align-items:center; gap:10px; padding:10px 14px;
    background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius-sm);
    cursor:pointer; transition:all var(--transition); font-size:.85rem;
}
.perm-item:hover { border-color:var(--green); }
.perm-item input[type="checkbox"] { accent-color:var(--green); width:16px; height:16px; cursor:pointer; }
.perm-item.checked { background:var(--green-bg); border-color:var(--green); }
.perm-item i { color:var(--text3); width:18px; text-align:center; }
.perm-item.checked i { color:var(--green); }
.user-badge { display:inline-block; padding:2px 10px; border-radius:12px; font-size:.7rem; font-weight:700; text-transform:uppercase; }
.user-badge.admin { background:var(--green-bg); color:var(--green); }
.user-badge.user { background:var(--blue-bg); color:var(--blue); }
.user-perms-tags { display:flex; flex-wrap:wrap; gap:4px; }
.user-perms-tags span { padding:2px 8px; border-radius:10px; font-size:.65rem; background:var(--bg3); color:var(--text3); }
.topbar-user { display:flex; align-items:center; gap:8px; font-size:.85rem; color:var(--text2); }
.topbar-user i { color:var(--green); }
.btn-logout { background:none; border:1px solid var(--border); color:var(--text3); padding:6px 12px; border-radius:var(--radius-sm); cursor:pointer; font-size:.8rem; transition:all var(--transition); }
.btn-logout:hover { border-color:var(--red); color:var(--red); }

/* ===== MODAL CHEQUE PAGAMENTO ===== */
.modal-overlay {
    position:fixed; top:0; left:0; right:0; bottom:0; z-index:9000;
    background:rgba(0,0,0,.65); backdrop-filter:blur(6px);
    display:flex; align-items:center; justify-content:center;
    animation:fadeIn .2s ease;
}
.modal-card {
    background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
    width:520px; max-width:95vw; max-height:90vh; overflow-y:auto;
    box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.modal-header {
    display:flex; justify-content:space-between; align-items:center;
    padding:20px 24px; border-bottom:1px solid var(--border);
}
.modal-header h3 { margin:0; display:flex; align-items:center; gap:10px; font-size:1.1rem; }
.modal-header h3 i { color:var(--purple); }
.modal-close {
    background:none; border:none; color:var(--text3); font-size:1.1rem; cursor:pointer;
    transition:color var(--transition);
}
.modal-close:hover { color:var(--red); }
.modal-footer {
    display:flex; gap:10px; justify-content:flex-end;
    padding:16px 24px; border-top:1px solid var(--border);
}
.cpag-info-box { padding:16px 24px; }
.cpag-info-line {
    display:flex; justify-content:space-between; align-items:center;
    padding:8px 0; border-bottom:1px solid var(--border); font-size:.9rem;
}
.cpag-info-line:last-child { border-bottom:none; }
.cpag-info-line span { color:var(--text3); }
.cpag-info-line b { color:var(--text); }
.cpag-calc-box {
    margin:12px 24px 16px; padding:16px; background:var(--bg3);
    border-radius:var(--radius-sm); border:1px solid var(--border);
}
.cpag-calc-line {
    display:flex; justify-content:space-between; padding:6px 0;
    font-size:.9rem; color:var(--text2);
}
.cpag-calc-line.result {
    border-top:2px solid var(--border2); margin-top:8px; padding-top:10px;
    font-size:1.05rem; font-weight:700;
}
.btn-cheque-pay {
    padding:4px 10px; font-size:.75rem; font-weight:600; border:1px solid var(--purple);
    background:var(--purple-bg); color:var(--purple); border-radius:var(--radius-sm);
    cursor:pointer; transition:all var(--transition); display:inline-flex; align-items:center; gap:4px;
}
.btn-cheque-pay:hover { background:var(--purple); color:#fff; }

/* ===== INLINE EDITING ===== */
.row-editing { background:rgba(0,212,170,.06) !important; }
.row-editing td { border-bottom-color:var(--green) !important; }
.edit-input {
    width:100%; padding:4px 8px; background:var(--bg3); border:1px solid var(--green);
    border-radius:4px; color:var(--text); font-size:.82rem; outline:none;
}
.edit-input:focus { box-shadow:0 0 0 2px rgba(0,212,170,.2); }
.edit-input[type="number"] { width:90px; }
.edit-input[type="date"] { width:130px; }
.btn-edit {
    padding:4px 8px; font-size:.75rem; background:var(--blue-bg); color:var(--blue);
    border:1px solid var(--blue); border-radius:var(--radius-sm); cursor:pointer;
    transition:all var(--transition); display:inline-flex; align-items:center; gap:4px;
}
.btn-edit:hover { background:var(--blue); color:#fff; }
.btn-save {
    padding:4px 8px; font-size:.75rem; background:var(--green-bg); color:var(--green);
    border:1px solid var(--green); border-radius:var(--radius-sm); cursor:pointer;
    transition:all var(--transition); display:inline-flex; align-items:center; gap:4px;
}
.btn-save:hover { background:var(--green); color:#0f1117; }
.btn-cancel {
    padding:4px 8px; font-size:.75rem; background:var(--bg3); color:var(--text3);
    border:1px solid var(--border); border-radius:var(--radius-sm); cursor:pointer;
    transition:all var(--transition); display:inline-flex; align-items:center; gap:4px;
}
.btn-cancel:hover { border-color:var(--red); color:var(--red); }

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
    .sidebar { transform:translateX(-100%); }
    .sidebar.open { transform:translateX(0); }
    .main-content { margin-left:0; }
    .menu-toggle { display:block; }
    .content-section { padding:16px; }
    .topbar { padding:12px 16px; }
    .month-display-bar { padding:12px 16px; top:49px; }
    .month-display-text { font-size:1.4rem; min-width:200px; }
    .month-nav-btn { width:34px; height:34px; font-size:.85rem; }
    .form-grid { grid-template-columns:1fr; }
    .cards-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:480px){
    .cards-grid { grid-template-columns:1fr; }

}

/* LEMBRETES MODERNOS */
.lembretes-wrapper { background: var(--surface); border-bottom: 1px solid var(--border); padding: 16px 20px; box-shadow: inset 0 -4px 15px rgba(0,0,0,0.1); z-index: 90; position: relative; }
.lembretes-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.lembretes-header span { font-size: 15px; font-weight: 700; display: flex; align-items: center; gap: 8px; color: var(--text); }
.lembretes-container { display: flex; gap: 16px; overflow-x: auto; padding: 5px 5px 20px 5px; scroll-behavior: smooth; }
.lembretes-container::-webkit-scrollbar { height: 6px; }
.lembretes-container::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 10px; }
.lembrete-card { min-width: 240px; max-width: 300px; background: linear-gradient(135deg, #fff9c4 0%, #fff176 100%); color: #1a1a1a; padding: 16px; border-radius: 12px; box-shadow: 0 4px 15px rgba(0,0,0,0.3), 0 1px 3px rgba(0,0,0,0.2); border: 1px solid #f9a825; border-left: 4px solid #f9a825; display: flex; flex-direction: column; justify-content: space-between; transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); position: relative; overflow: hidden; }
.lembrete-card::before { content: ''; position: absolute; top: 0; right: 0; width: 60px; height: 60px; background: radial-gradient(circle, rgba(249,168,37,0.2) 0%, transparent 70%); border-radius: 50%; transform: translate(20px, -20px); }
.lembrete-card:hover { transform: translateY(-4px); box-shadow: 0 12px 25px rgba(0,0,0,0.4), 0 5px 10px rgba(0,0,0,0.2); border-color: #f57f17; }
.lembrete-card.concluido { opacity: 0.5; border-left-color: var(--green); background: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%); }
.lembrete-card.concluido::before { background: radial-gradient(circle, rgba(0,212,170,0.15) 0%, transparent 70%); }
.lembrete-card.concluido .lembrete-texto { text-decoration: line-through; color: #666; }
.lembrete-texto { font-size: 14px; line-height: 1.5; word-wrap: break-word; white-space: pre-wrap; margin-bottom: 16px; font-weight: 500; z-index: 1; color: #1a1a1a; }
.lembrete-actions { display: flex; justify-content: flex-end; gap: 8px; border-top: 1px solid rgba(0,0,0,0.1); padding-top: 12px; z-index: 1; }
.lembrete-card button { background: rgba(0,0,0,0.08); border: 1px solid rgba(0,0,0,0.15); color: #555; cursor: pointer; font-size: 12px; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: all 0.2s; box-shadow: 0 2px 5px rgba(0,0,0,0.1); }
.lembrete-card button:hover { color: #fff; transform: scale(1.1); box-shadow: 0 4px 8px rgba(0,0,0,0.3); }
.lembrete-card button.btn-concluir:hover { background: var(--green); border-color: var(--green); color: #fff; }
.lembrete-card button.btn-excluir:hover { background: var(--red); border-color: var(--red); }
.lembrete-card button.btn-desmarcar:hover { background: var(--amber); border-color: var(--amber); color: #000; }
