:root{--bg-app:#f0f4f8;--bg-card:#ffffff;--bg-sidebar:#0f172a;--bg-sidebar-hover:#1e293b;--primary:#0d9488;--primary-hover:#0f766e;--primary-soft:#ccfbf1;--text:#0f172a;--text-muted:#64748b;--border:#e2e8f0;--receita:#059669;--receita-bg:#ecfdf5;--despesa:#dc2626;--despesa-bg:#fef2f2;--shadow-sm:0 1px 2px rgba(15, 23, 42, 0.06);--shadow-md:0 4px 16px rgba(15, 23, 42, 0.08);--radius:12px;--radius-sm:8px;--sidebar-width:252px}*{-webkit-box-sizing:border-box;box-sizing:border-box}body{margin:0;font-family:'DM Sans','Segoe UI',system-ui,sans-serif;background:var(--bg-app);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none;font-weight:500}a:hover{color:var(--primary-hover)}h1,h2,h3{margin:0 0 .5rem;font-weight:700;letter-spacing:-.02em}h1{font-size:1.75rem}h2{font-size:1.35rem}h3{font-size:1rem;color:var(--text-muted);font-weight:600}.btn,button{cursor:pointer;border:none;border-radius:var(--radius-sm);padding:10px 16px;font-size:14px;font-weight:600;font-family:inherit;-webkit-transition:background .15s,-webkit-transform .1s,-webkit-box-shadow .15s;transition:background .15s,transform .1s,box-shadow .15s,-webkit-transform .1s,-webkit-box-shadow .15s}.btn:active,button:active{-webkit-transform:scale(.98);transform:scale(.98)}.btn-primary{background:var(--primary);color:#fff;-webkit-box-shadow:0 2px 8px rgba(13,148,136,.35);box-shadow:0 2px 8px rgba(13,148,136,.35)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--despesa);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-secondary{background:#f1f5f9;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:#e2e8f0}.btn-ghost{background:0 0;color:var(--text-muted);border:1px solid transparent}.btn-ghost:hover{background:#f1f5f9;color:var(--text)}.btn-sm{padding:6px 12px;font-size:13px}.btn-block{width:100%}.btn-group{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:8px;margin-top:16px}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;color:var(--text);-webkit-transition:border-color .15s,-webkit-box-shadow .15s;transition:border-color .15s,box-shadow .15s,-webkit-box-shadow .15s}input:focus,select:focus,textarea:focus{outline:0;border-color:var(--primary);-webkit-box-shadow:0 0 0 3px rgba(13,148,136,.15);box-shadow:0 0 0 3px rgba(13,148,136,.15)}.card{background:var(--bg-card);border-radius:var(--radius);padding:20px 22px;-webkit-box-shadow:var(--shadow-sm);box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:20px}.card-title{margin:0 0 16px;font-size:1rem;font-weight:600;color:var(--text)}.page-header{margin-bottom:24px}.page-header p{margin:6px 0 0;color:var(--text-muted);font-size:15px}.layout{display:-webkit-box;display:-ms-flexbox;display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:-webkit-gradient(linear,left top,left bottom,from(#0f172a),color-stop(120%,#134e4a));background:linear-gradient(180deg,#0f172a 0,#134e4a 120%);color:#fff;padding:24px 16px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-ms-flex-negative:0;flex-shrink:0}.sidebar-brand{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:12px;padding:0 8px 24px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:20px}.sidebar-logo{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.15);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;font-size:20px}.sidebar-brand h2{margin:0;font-size:1.05rem;color:#fff;font-weight:700}.sidebar-brand span{display:block;font-size:11px;color:rgba(255,255,255,.55);font-weight:500;margin-top:2px}.sidebar-user{padding:12px;margin-bottom:16px;background:rgba(255,255,255,.08);border-radius:var(--radius-sm);font-size:13px}.sidebar-user strong{display:block;font-size:14px;margin-bottom:2px}.sidebar-user span{color:rgba(255,255,255,.6);font-size:12px;word-break:break-all}.sidebar-nav{-webkit-box-flex:1;-ms-flex:1;flex:1}.sidebar a{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:10px;color:rgba(255,255,255,.75);padding:11px 12px;border-radius:var(--radius-sm);margin-bottom:4px;font-weight:500;font-size:14px}.sidebar a:hover{background:rgba(255,255,255,.1);color:#fff}.sidebar a.active{background:rgba(255,255,255,.18);color:#fff}.sidebar-icon{width:20px;text-align:center;opacity:.9}.sidebar-footer{padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-footer .btn-secondary{width:100%;background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15);color:#fff}.sidebar-footer .btn-secondary:hover{background:rgba(255,255,255,.18)}.content{-webkit-box-flex:1;-ms-flex:1;flex:1;padding:28px 32px 40px;max-width:1200px;width:100%}.stats-grid{display:-ms-grid;display:grid;-ms-grid-columns:(minmax(200px,1fr)) [auto-fit];grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:18px 20px;border:1px solid var(--border);-webkit-box-shadow:var(--shadow-sm);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.stat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary)}.stat-card--receita::before{background:var(--receita)}.stat-card--despesa::before{background:var(--despesa)}.stat-card--mes::before{background:#6366f1}.stat-label{color:var(--text-muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.stat-value{font-size:1.65rem;font-weight:700;letter-spacing:-.02em}.stat-value.receita{color:var(--receita)}.stat-value.despesa{color:var(--despesa)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}thead th{text-align:left;padding:12px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#f8fafc;border-bottom:1px solid var(--border)}tbody td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle}tbody tr:hover{background:#f8fafc}tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-receita{background:var(--receita-bg);color:var(--receita)}.badge-despesa{background:var(--despesa-bg);color:var(--despesa)}.valor-cell{font-weight:600;font-variant-numeric:tabular-nums}.receita{color:var(--receita)}.despesa{color:var(--despesa)}.error{color:var(--despesa);font-size:13px;margin:8px 0 0;padding:10px 12px;background:var(--despesa-bg);border-radius:var(--radius-sm)}.form-row{margin-bottom:14px}.form-row label{display:block;margin-bottom:6px;font-size:13px;font-weight:600;color:var(--text)}.form-grid{display:-ms-grid;display:grid;-ms-grid-columns:(minmax(160px,1fr)) [auto-fit];grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;-webkit-box-align:end;-ms-flex-align:end;align-items:end}.form-grid .form-row{margin-bottom:0}.filter-bar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:14px;-webkit-box-align:end;-ms-flex-align:end;align-items:flex-end}.filter-bar .form-row{-webkit-box-flex:1;-ms-flex:1;flex:1;min-width:140px;margin-bottom:0}.color-swatch{display:inline-block;width:24px;height:24px;border-radius:6px;border:2px solid var(--border);vertical-align:middle}.empty-state{text-align:center;padding:32px 16px;color:var(--text-muted)}.empty-state p{margin:0}.auth-page{min-height:100vh;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#0f172a 0,#134e4a 50%,#0d9488 100%)}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border-radius:16px;padding:36px 32px;-webkit-box-shadow:var(--shadow-md);box-shadow:var(--shadow-md);border:1px solid var(--border)}.auth-card h2{margin-bottom:8px;color:var(--text)}.auth-subtitle{color:var(--text-muted);font-size:14px;margin:0 0 24px}.auth-footer{margin-top:20px;text-align:center;font-size:14px;color:var(--text-muted)}.actions-cell{white-space:nowrap}.actions-cell .btn{margin-right:6px}.actions-cell .btn:last-child{margin-right:0}.page-tabs{display:-webkit-box;display:-ms-flexbox;display:flex;gap:8px;margin-bottom:20px;-ms-flex-wrap:wrap;flex-wrap:wrap}.page-tab{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);padding:10px 18px;border-radius:var(--radius-sm);font-weight:600}.page-tab.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary-hover)}.text-muted{color:var(--text-muted);font-size:14px}.card-hint{margin:0 0 16px}.badge-parcela{display:inline-block;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:700;border-radius:999px;background:var(--primary-soft);color:var(--primary-hover)}.parcela-list{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:16px}.parcela-item{padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fafbfc}.parcela-item__head{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:baseline;-ms-flex-align:baseline;align-items:baseline;gap:12px;-ms-flex-wrap:wrap;flex-wrap:wrap;margin-bottom:8px}.parcela-item__meta{font-size:13px;color:var(--text-muted);margin:8px 0 12px}.progress-bar{height:8px;background:var(--border);border-radius:999px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--primary);border-radius:999px;-webkit-transition:width .2s;transition:width .2s}.anuario-layout{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;gap:16px}.month-tabs{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:6px}.month-tab{min-width:52px;padding:8px 10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:600;font-size:13px;color:var(--text-muted)}.month-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.anuario-meta{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.anuario-meta p{margin:0 0 8px}.anuario-totais{margin-bottom:20px}.destaques-list{margin:0;padding-left:20px;color:var(--text)}.destaques-list li{margin-bottom:8px}.year-grid{display:-ms-grid;display:grid;-ms-grid-columns:(1fr)[6];grid-template-columns:repeat(6,1fr);gap:10px}@media (max-width:900px){.year-grid{-ms-grid-columns:(1fr)[4];grid-template-columns:repeat(4,1fr)}}@media (max-width:520px){.year-grid{-ms-grid-columns:(1fr)[3];grid-template-columns:repeat(3,1fr)}}.year-cell{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:4px;padding:12px 8px;border-radius:var(--radius-sm);border:2px solid transparent;background:#f8fafc;font-family:inherit;cursor:pointer;-webkit-transition:border-color .15s,-webkit-transform .1s;transition:border-color .15s,transform .1s,-webkit-transform .1s}.year-cell:hover{-webkit-transform:translateY(-1px);transform:translateY(-1px)}.year-cell.active{border-color:var(--primary);-webkit-box-shadow:var(--shadow-sm);box-shadow:var(--shadow-sm)}.year-cell--positivo{background:var(--receita-bg)}.year-cell--negativo{background:var(--despesa-bg)}.year-cell--vazio{background:#f1f5f9;opacity:.85}.year-cell--neutro{background:#f8fafc}.year-cell__mes{font-size:12px;font-weight:700;text-transform:uppercase;color:var(--text-muted)}.year-cell__valor{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}.chart-bars{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:end;-ms-flex-align:end;align-items:flex-end;gap:8px;min-height:160px;padding:8px 0 4px}.chart-bars__item{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:6px;cursor:pointer;min-width:0}.chart-bars__item.active .chart-bars__label{color:var(--primary);font-weight:700}.chart-bars__track{width:100%;max-width:36px;height:120px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:end;-ms-flex-align:end;align-items:flex-end;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.chart-bar{width:100%;min-height:4px;border-radius:4px 4px 0 0;-webkit-transition:height .2s;transition:height .2s}.chart-bar--positivo{background:var(--receita)}.chart-bar--negativo{background:var(--despesa)}.chart-bars__label{font-size:11px;color:var(--text-muted);font-weight:600}@media (max-width:768px){.layout{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.sidebar{width:100%;padding:16px}.sidebar-nav{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:4px}.sidebar a{-webkit-box-flex:1;-ms-flex:1;flex:1;min-width:120px;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.content{padding:20px 16px}.stats-grid{-ms-grid-columns:1fr;grid-template-columns:1fr}}