*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0b0f1a;--bg2:#111827;--bg3:#1a2236;--bg4:#212d44;
  --border:#1e2d45;--border2:#2e4268;
  --text:#e2eaf8;--text2:#7e95c4;--text3:#4a5f85;
  --green:#1fcb72;--green2:#13a358;--green-bg:#0a2218;
  --red:#f04f4f;--red2:#c23030;--red-bg:#280d0d;
  --blue:#3d8ef0;--blue2:#1e6fd4;--blue-bg:#0a1b38;
  --amber:#f0a020;--amber-bg:#251800;
  --purple:#9b7ff0;--purple-bg:#160f2e;
  --teal:#1ec8b0;--teal-bg:#092320;
  --accent:#1fcb72;
  --radius:10px;--radius-lg:16px;
  --font:'Sora',sans-serif;--mono:'JetBrains Mono',monospace;
}
body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;font-size:14px}

/* AUTH SCREEN */
#authScreen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}
#authScreen::before{content:'';position:absolute;top:-200px;left:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,#1fcb7210 0%,transparent 70%);pointer-events:none}
#authScreen::after{content:'';position:absolute;bottom:-150px;right:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,#3d8ef010 0%,transparent 70%);pointer-events:none}
.auth-box{background:var(--bg2);border:1px solid var(--border2);border-radius:24px;padding:40px;width:420px;max-width:95vw;position:relative;z-index:1}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-logo-text{font-size:32px;font-weight:700;color:var(--green);letter-spacing:-1px}
.auth-logo-icon{font-size:40px;margin-bottom:8px}
.auth-logo-sub{font-size:13px;color:var(--text3);margin-top:4px}
.auth-tabs{display:flex;background:var(--bg3);border-radius:10px;padding:3px;margin-bottom:24px;border:1px solid var(--border)}
.auth-tab{flex:1;padding:9px;border-radius:8px;text-align:center;cursor:pointer;font-size:13px;font-weight:500;color:var(--text3);transition:all .2s}
.auth-tab.active{background:var(--bg2);color:var(--text);box-shadow:0 2px 8px #00000050}
.auth-error{background:var(--red-bg);border:1px solid var(--red)30;border-radius:8px;padding:10px 14px;font-size:13px;color:var(--red);margin-bottom:14px;display:none}
.auth-success{background:var(--green-bg);border:1px solid var(--green)30;border-radius:8px;padding:10px 14px;font-size:13px;color:var(--green);margin-bottom:14px;display:none}
.auth-divider{text-align:center;font-size:12px;color:var(--text3);margin:16px 0;position:relative}
.auth-divider::before,.auth-divider::after{content:'';position:absolute;top:50%;width:40%;height:1px;background:var(--border)}
.auth-divider::before{left:0}.auth-divider::after{right:0}
.demo-btn{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:11px;font-family:var(--font);font-size:13px;color:var(--text2);cursor:pointer;transition:all .15s;font-weight:500}
.demo-btn:hover{border-color:var(--green)50;color:var(--green)}
.supabase-note{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:16px;font-size:11px;color:var(--text3)}
.supabase-note strong{color:var(--amber);display:block;margin-bottom:4px}
.supabase-note code{background:var(--bg4);border-radius:4px;padding:1px 5px;font-family:var(--mono);color:var(--blue)}

/* APP */
#appScreen{display:none}
.app{display:flex;min-height:100vh}
.sidebar{width:224px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:100}
.main{margin-left:224px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.content{padding:28px;flex:1}

/* SIDEBAR */
.logo{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.logo-icon{font-size:24px}
.logo-text{font-size:20px;font-weight:700;color:var(--green);letter-spacing:-0.5px}
.logo-sub{font-size:10px;color:var(--text3)}
.nav-section{padding:14px 12px 6px}
.nav-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:1px;padding:0 8px;margin-bottom:6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;transition:all .15s;margin-bottom:2px;border:1px solid transparent}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:var(--green-bg);color:var(--green);border-color:#1fcb7220}
.nav-icon{font-size:15px;width:18px;text-align:center}
.user-area{padding:14px;border-top:1px solid var(--border);margin-top:auto}
.user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--green-bg);border:1px solid var(--green)40;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--green)}
.user-name{font-size:12px;font-weight:600;color:var(--text)}
.user-email{font-size:10px;color:var(--text3)}
.year-ctrl{display:flex;align-items:center;gap:6px;justify-content:center;background:var(--bg3);border-radius:8px;padding:6px;border:1px solid var(--border)}
.year-btn{background:transparent;border:none;color:var(--text2);border-radius:5px;width:24px;height:24px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.year-btn:hover{color:var(--green)}
.year-display{font-size:15px;font-weight:700;color:var(--text);font-family:var(--mono);flex:1;text-align:center}

/* TOPBAR */
.page-title{font-size:15px;font-weight:600;color:var(--text)}
.page-sub{font-size:11px;color:var(--text3);margin-top:1px}
.topbar-actions{display:flex;gap:8px;align-items:center}
.btn{padding:8px 16px;border-radius:8px;border:1px solid transparent;font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--green2);color:#fff;border-color:var(--green2)}
.btn-primary:hover{background:var(--green);color:#000}
.btn-ghost{background:var(--bg3);color:var(--text2);border-color:var(--border)}
.btn-ghost:hover{border-color:var(--border2);color:var(--text)}
.btn-danger{background:var(--red-bg);color:var(--red);border-color:var(--red2)40}
.btn-danger:hover{background:var(--red2);color:#fff;border-color:var(--red2)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-logout{background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:7px;padding:5px 10px;font-size:12px;cursor:pointer;transition:all .15s}
.btn-logout:hover{border-color:var(--red)40;color:var(--red)}

/* MONTHS TABS */
.months-tabs{display:flex;gap:3px;margin-bottom:22px;overflow-x:auto;padding-bottom:4px}
.months-tabs::-webkit-scrollbar{height:3px}
.months-tabs::-webkit-scrollbar-thumb{background:var(--border)}
.month-tab{padding:7px 13px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text3);background:var(--bg2);border:1px solid var(--border);white-space:nowrap;transition:all .15s}
.month-tab:hover{color:var(--text2);border-color:var(--border2)}
.month-tab.active{background:var(--blue-bg);color:var(--blue);border-color:#3d8ef030}

/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-size:14px;font-weight:600;color:var(--text)}
.card-sub{font-size:11px;color:var(--text3);margin-top:2px}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;margin-bottom:20px}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.stat-label{font-size:10px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.stat-value{font-size:20px;font-weight:700;font-family:var(--mono);margin-top:5px}
.stat-value.green{color:var(--green)}
.stat-value.red{color:var(--red)}
.stat-value.blue{color:var(--blue)}
.stat-value.amber{color:var(--amber)}
.stat-delta{font-size:10px;margin-top:3px;color:var(--text3)}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}

/* TABLE */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;padding:9px 10px;text-align:left;border-bottom:1px solid var(--border)}
td{padding:10px 10px;border-bottom:1px solid #1e2d4520;font-size:13px;color:var(--text2)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg3)60;color:var(--text)}
.td-amount{font-family:var(--mono);font-weight:500;text-align:right;white-space:nowrap}
.td-amount.green{color:var(--green)}
.td-amount.red{color:var(--red)}
.td-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:600;white-space:nowrap}
.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-amber{background:var(--amber-bg);color:var(--amber)}
.badge-purple{background:var(--purple-bg);color:var(--purple)}
.badge-teal{background:var(--teal-bg);color:var(--teal)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:#00000095;backdrop-filter:blur(6px);z-index:1000;display:none;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:28px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto}
.modal-title{font-size:15px;font-weight:700;margin-bottom:18px;color:var(--text)}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}

/* CONFIRM MODAL */
.confirm-box{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:28px;width:380px;max-width:95vw;text-align:center}
.confirm-icon{font-size:40px;margin-bottom:12px}
.confirm-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px}
.confirm-desc{font-size:13px;color:var(--text2);margin-bottom:20px;line-height:1.6}
.confirm-actions{display:flex;gap:10px;justify-content:center}

/* FORM */
.form-group{margin-bottom:13px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
label{display:block;font-size:11px;font-weight:600;color:var(--text3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
input,select,textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 11px;color:var(--text);font-family:var(--font);font-size:13px;outline:none;transition:border .15s}
input:focus,select:focus,textarea:focus{border-color:var(--blue)}
input[type="date"]{color-scheme:dark}
select option{background:var(--bg3)}

/* CHART */
.chart-container{position:relative;width:100%}
.chart-area{display:flex;gap:0;align-items:flex-end;padding:0 0 0 48px;position:relative}
.chart-y-axis{position:absolute;left:0;top:0;bottom:24px;width:44px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}
.chart-y-label{font-size:9px;color:var(--text3);font-family:var(--mono);text-align:right;padding-right:6px;line-height:1}
.chart-grid{position:absolute;left:44px;right:0;top:0;bottom:24px;pointer-events:none}
.chart-grid-line{position:absolute;left:0;right:0;height:1px;background:var(--border)50}
.chart-bars{display:flex;flex:1;gap:6px;align-items:flex-end;height:180px;padding-bottom:0;position:relative;z-index:1}
.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0}
.chart-bar-group{display:flex;gap:2px;align-items:flex-end;width:100%;justify-content:center}
.chart-bar{border-radius:3px 3px 0 0;min-height:2px;transition:height .4s ease;cursor:pointer;position:relative;flex:1;max-width:16px}
.chart-bar:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);background:var(--bg4);border:1px solid var(--border2);border-radius:6px;padding:3px 7px;font-size:10px;color:var(--text);white-space:nowrap;z-index:10;font-family:var(--mono)}
.chart-x-labels{display:flex;gap:6px;padding-left:0;margin-top:6px}
.chart-x-label{flex:1;text-align:center;font-size:9px;color:var(--text3);font-family:var(--mono)}

/* PROGRESS */
.progress-bar{height:5px;background:var(--bg4);border-radius:3px;overflow:hidden;margin-top:5px}
.progress-fill{height:100%;border-radius:3px;transition:width .4s}

/* EMPTY */
.empty{text-align:center;padding:40px 24px;color:var(--text3)}
.empty-icon{font-size:32px;margin-bottom:10px;opacity:.35}
.empty-text{font-size:13px;margin-bottom:6px;color:var(--text2)}

/* ACCOUNT CARD */
.account-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:15px;transition:all .15s}
.account-card:hover{border-color:var(--border2)}
.account-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}
.account-bal{font-size:19px;font-weight:700;font-family:var(--mono);margin:8px 0}
.account-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.icon-btn{background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text3);padding:4px 8px;cursor:pointer;font-size:12px;transition:all .15s;font-family:var(--font)}
.icon-btn:hover{border-color:var(--border2);color:var(--text)}

/* CARTAO COLLAPSIBLE */
.cartao-wrap{margin-bottom:14px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s}
.cartao-wrap.expanded{border-color:var(--border2)}
.cartao-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;background:var(--bg2);transition:background .15s;user-select:none}
.cartao-header:hover{background:var(--bg3)}
.cartao-header-left{display:flex;align-items:center;gap:12px}
.cartao-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.cartao-header-info{flex:1}
.cartao-header-name{font-size:14px;font-weight:600;color:var(--text)}
.cartao-header-sub{font-size:11px;color:var(--text3);margin-top:2px}
.cartao-header-right{display:flex;align-items:center;gap:12px}
.cartao-fatura-val{font-size:18px;font-weight:700;font-family:var(--mono);color:var(--red)}
.cartao-chevron{font-size:12px;color:var(--text3);transition:transform .25s}
.cartao-wrap.expanded .cartao-chevron{transform:rotate(180deg)}
.cartao-body{display:none;border-top:1px solid var(--border);background:var(--bg2)}
.cartao-wrap.expanded .cartao-body{display:block}
.cartao-body-inner{padding:16px 20px}

/* FATURA STATUS BTN */
.fatura-status-btn{display:flex;align-items:center;gap:7px;padding:6px 12px;border-radius:8px;border:1px solid;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s}
.fatura-status-btn.pendente{background:var(--red-bg);border-color:var(--red)40;color:var(--red)}
.fatura-status-btn.pendente:hover{background:var(--red2)20}
.fatura-status-btn.pago{background:var(--green-bg);border-color:var(--green)40;color:var(--green)}
.fatura-status-btn.pago:hover{background:var(--green2)20}
.fatura-dot{width:7px;height:7px;border-radius:50%;background:currentColor}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* LOADING */
.loading-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;flex-direction:column;gap:16px}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ANIMATIONS */
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .18s ease}

/* SUPABASE SETUP BANNER */
.setup-banner{background:var(--amber-bg);border:1px solid var(--amber)30;border-radius:10px;padding:14px 18px;margin-bottom:20px;font-size:12px;color:var(--amber);display:flex;align-items:flex-start;gap:10px}
.setup-banner strong{font-size:13px;display:block;margin-bottom:4px}
.setup-banner code{background:#ffffff15;border-radius:4px;padding:1px 5px;font-family:var(--mono);font-size:11px}

/* WELCOME OVERLAY */
.welcome-overlay{position:fixed;inset:0;background:#00000098;backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.welcome-overlay--show{opacity:1}
.welcome-box{background:var(--bg2);border:1px solid var(--border2);border-radius:24px;padding:36px;width:520px;max-width:95vw;max-height:92vh;overflow-y:auto;transform:translateY(12px);transition:transform .3s}
.welcome-overlay--show .welcome-box{transform:translateY(0)}
.welcome-header{text-align:center;margin-bottom:28px}
.welcome-logo{font-size:48px;margin-bottom:12px}
.welcome-title{font-size:22px;font-weight:700;color:var(--green);letter-spacing:-.5px;margin-bottom:8px}
.welcome-sub{font-size:13px;color:var(--text2);line-height:1.6}
.welcome-steps{display:flex;flex-direction:column;gap:0;margin-bottom:20px}
.welcome-step{display:flex;align-items:flex-start;gap:14px;background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:16px}
.welcome-step-divider{text-align:center;color:var(--text3);font-size:16px;padding:4px 0;line-height:1}
.welcome-step-num{width:22px;height:22px;border-radius:50%;background:var(--green);color:#000;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.welcome-step-icon{font-size:24px;flex-shrink:0}
.welcome-step-info{flex:1}
.welcome-step-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.welcome-step-desc{font-size:12px;color:var(--text3);line-height:1.5}
.welcome-tip{background:var(--blue-bg);border:1px solid var(--blue)20;border-radius:10px;padding:12px 14px;font-size:12px;color:var(--text2);line-height:1.6;margin-bottom:20px}
.welcome-tip strong{color:var(--text)}
.welcome-actions{display:flex;flex-direction:column;gap:8px}

/* SUGESTÕES DE CATEGORIAS */
.sugestoes-grid{display:flex;flex-wrap:wrap;gap:6px}
.sugestao-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:20px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;font-family:var(--font)}
.sugestao-chip:hover:not(:disabled){border-color:var(--blue);color:var(--text);background:var(--blue-bg)}
.sugestao-chip--added{background:var(--green-bg)!important;border-color:var(--green)30!important;color:var(--green)!important;cursor:default;opacity:.7}
.sugestao-check{font-size:10px;font-weight:700}

/* EMOJI PICKER */
.emoji-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:3px;max-height:160px;overflow-y:auto;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px}
.emoji-btn{background:transparent;border:1px solid transparent;border-radius:6px;font-size:18px;padding:4px;cursor:pointer;transition:all .1s;line-height:1;aspect-ratio:1}
.emoji-btn:hover{background:var(--bg4);border-color:var(--border2)}
.emoji-btn--active{background:var(--blue-bg);border-color:var(--blue)!important}

/* SETTINGS BUTTON */
.btn-settings{background:transparent;border:1px solid var(--border);border-radius:7px;color:var(--text3);padding:5px 8px;font-size:14px;cursor:pointer;transition:all .15s;line-height:1}
.btn-settings:hover{border-color:var(--border2);color:var(--text);transform:rotate(30deg)}

/* SETTINGS MODAL */
.settings-section{margin-bottom:20px}
.settings-section:last-child{margin-bottom:0}
.settings-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.settings-section-title.danger{color:var(--amber)}
.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0}
.settings-row-label{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}
.settings-row-sub{font-size:11px;color:var(--text3);line-height:1.5}
.danger-zone{background:var(--red-bg);border:1px solid var(--red)20;border-radius:var(--radius);padding:14px}
.danger-zone .settings-section-title{border-color:var(--red)20}

/* CLEAR DATA */
.clear-data-warning{background:var(--amber-bg);border:1px solid var(--amber)30;border-radius:10px;padding:16px;display:flex;gap:12px;align-items:flex-start}
.clear-data-icon{font-size:24px;flex-shrink:0;margin-top:1px}
.clear-data-text{font-size:13px;color:var(--amber);line-height:1.6}
.clear-data-text strong{font-weight:700}
.clear-data-error{background:var(--red-bg);border:1px solid var(--red)30;border-radius:8px;padding:9px 12px;font-size:12px;color:var(--red);margin-top:10px}

/* TOAST */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--bg3);border:1px solid var(--green)40;border-radius:10px;padding:11px 20px;font-size:13px;color:var(--green);z-index:9999;opacity:0;transition:all .25s;white-space:nowrap;pointer-events:none}
.toast.toast-show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:768px){
  .sidebar{width:56px}
  .logo-text,.logo-sub,.nav-item span,.nav-label,.user-name,.user-email,.year-display{display:none}
  .main{margin-left:56px}
  .grid2{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
}
