/* ═══════════════════════════ THEME ═══════════════════════════ */
:root {
  --accent: #7c3aed;
  --accent2: #a78bfa;
  --accent-glow: rgba(124,58,237,0.22);
  --green: #10b981;
  --green-dim: rgba(16,185,129,0.13);
  --red: #f43f5e;
  --red-dim: rgba(244,63,94,0.13);
  --yellow: #f59e0b;
  --yellow-dim: rgba(245,158,11,0.13);
  --cyan: #06b6d4;
  --orange: #f97316;
  --radius: 14px;
  --radius-sm: 9px;
  --radius-xs: 6px;
  --sidebar-w: 248px;
  --topbar-h: 56px;
}

[data-theme="dark"] {
  --bg: #0b0b12;
  --surface: #13131e;
  --surface2: #1b1b2a;
  --surface3: #242436;
  --border: rgba(255,255,255,0.07);
  --border2: rgba(255,255,255,0.12);
  --text: #eeeaf8;
  --text2: #9e98ba;
  --text3: #5a5470;
  --shadow: 0 8px 40px rgba(0,0,0,0.55);
  --input-bg: #0b0b12;
}

[data-theme="light"] {
  --bg: #f3f2fc;
  --surface: #ffffff;
  --surface2: #eeecfb;
  --surface3: #e4e1f8;
  --border: rgba(0,0,0,0.07);
  --border2: rgba(0,0,0,0.13);
  --text: #1a1530;
  --text2: #58527a;
  --text3: #9990be;
  --shadow: 0 4px 24px rgba(124,92,252,0.09);
  --input-bg: #f3f2fc;
}

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

html {
  height: 100%;
  height: -webkit-fill-available;
  overflow-x: hidden;
}

body {
  background:var(--bg);
  color:var(--text);
  font-family:'Space Grotesk',sans-serif;
  font-size:14px;
  line-height:1.6;
  height:100dvh;
  overflow:hidden;
  transition:background 0.3s,color 0.3s;
  display:flex;
  flex-direction:column;
}

body::before {
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;opacity:0.25;
}

.glow-orb{position:fixed;border-radius:50%;filter:blur(140px);pointer-events:none;z-index:0;}
.glow-1{width:480px;height:480px;background:var(--accent);top:-180px;left:-180px;opacity:0.07;}
.glow-2{width:360px;height:360px;background:var(--cyan);bottom:-80px;right:-80px;opacity:0.06;}

/* ═══════════════════════════ SCREENS ═══════════════════════════ */
.screen{display:none;position:absolute;top:0;left:0;width:100%;}
.screen.active{display:flex;position:relative;width:100%;flex:1;min-height:0;z-index:1;}

/* ═══════════════════════════ SPLASH / LOADING ═══════════════════════════ */
#screen-loading{align-items:center;justify-content:center;}
.splash-wrap{display:flex;flex-direction:column;align-items:center;gap:28px;}
.splash-logo{width:72px;height:72px;animation:splash-pulse 1.6s ease-in-out infinite;}
@keyframes splash-pulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.06);opacity:0.85;}}
.splash-spinner{width:32px;height:32px;border:3px solid rgba(124,58,237,0.2);border-top-color:var(--accent);border-radius:50%;animation:spin 0.75s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ═══════════════════════════ AUTH ═══════════════════════════ */
#screen-auth,#screen-admin-auth{
  min-height:100vh;align-items:center;justify-content:center;
  position:relative;z-index:1;flex-direction:column;
}

.auth-card{
  background:var(--surface);
  border:1px solid var(--border2);
  border-radius:22px;padding:42px;
  width:100%;max-width:410px;
  box-shadow:var(--shadow);
  animation:cardIn 0.5s cubic-bezier(0.16,1,0.3,1) both;
}

@keyframes cardIn{
  from{opacity:0;transform:translateY(26px) scale(0.97);}
  to{opacity:1;transform:translateY(0) scale(1);}
}

.auth-logo{
  font-family:'Outfit',sans-serif;font-size:38px;font-weight:900;
  background:linear-gradient(135deg,#fff 0%,var(--accent2) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-2px;margin-bottom:4px;
}
[data-theme="light"] .auth-logo{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);-webkit-background-clip:text;}

.auth-tagline{color:var(--text3);font-size:14px;margin-bottom:30px;font-weight:400;text-align:center;}

.auth-tabs{
  display:flex;gap:4px;
  background:var(--bg);border-radius:var(--radius-sm);padding:4px;margin-bottom:24px;
}
.auth-tab{
  flex:1;padding:8px;border:none;border-radius:var(--radius-xs);
  background:transparent;color:var(--text3);
  font-family:'Space Grotesk',sans-serif;font-size:13px;cursor:pointer;transition:all 0.2s;
}
.auth-tab.active{background:var(--surface2);color:var(--text);font-weight:600;}

@media(max-width:700px){
  .auth-card{padding:32px;}
  .auth-logo{font-size:32px;}
  .auth-tagline{margin-bottom:24px;font-size:12px;}
  .auth-tabs{margin-bottom:20px;}
  .auth-tab{padding:7px;font-size:12px;}
}

@media(max-width:480px){
  .auth-card{padding:24px;border-radius:16px;}
  .auth-logo{font-size:28px;}
  .auth-tagline{margin-bottom:20px;font-size:11px;}
  .auth-tabs{padding:3px;margin-bottom:16px;}
  .auth-tab{padding:6px;font-size:11px;}
}

.input-group{margin-bottom:13px;}
.input-group label{
  display:block;font-size:11px;color:var(--text3);
  margin-bottom:5px;text-transform:uppercase;letter-spacing:0.6px;font-weight:600;
}
.input-group input,.input-group select,.input-group textarea{
  width:100%;background:var(--input-bg);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:11px 14px;color:var(--text);
  font-family:'Space Grotesk',sans-serif;font-size:14px;
  transition:border-color 0.2s,box-shadow 0.2s;outline:none;resize:none;
}
.input-group input:focus,.input-group select:focus,.input-group textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);
}
.input-group select option{background:var(--surface);color:var(--text);}

/* ── PASSWORD TOGGLE EYE ── */
.pass-wrapper{position:relative;display:flex;align-items:center;}
.pass-wrapper input{width:100%;padding-right:44px;}
.pass-eye{
  position:absolute;right:0;top:0;bottom:0;
  width:42px;display:flex;align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;color:var(--text3);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  transition:color 0.15s;flex-shrink:0;
}
.pass-eye:hover{color:var(--text);}
.pass-eye svg{width:18px;height:18px;pointer-events:none;}

/* ── REMEMBER ME ── */
.remember-row{
  display:flex;align-items:center;gap:9px;
  cursor:pointer;margin-top:10px;user-select:none;width:fit-content;
}
.remember-check{
  width:16px;height:16px;border-radius:4px;
  accent-color:var(--accent);cursor:pointer;flex-shrink:0;
}
.remember-label{font-size:12.5px;color:var(--text2);font-weight:500;}

@media(max-width:700px){
  .input-group{margin-bottom:11px;}
  .input-group label{font-size:10px;margin-bottom:4px;}
  .input-group input,.input-group select,.input-group textarea{padding:10px 12px;font-size:16px;}
}

@media(max-width:480px){
  .input-group{margin-bottom:10px;}
  .input-group label{font-size:9px;margin-bottom:3px;letter-spacing:0.3px;}
  .input-group input,.input-group select,.input-group textarea{padding:9px 11px;font-size:16px;}
}

/* ═══════════════════════════ BUTTONS ═══════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border:none;border-radius:var(--radius-sm);
  font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:500;
  cursor:pointer;transition:all 0.18s;white-space:nowrap;
}
.btn-primary{background:linear-gradient(135deg,#7c3aed,#06b6d4);color:#fff;box-shadow:0 4px 16px rgba(124,58,237,0.3);justify-content:center;font-weight:600;}
.btn-primary:hover{background:linear-gradient(135deg,#6d28d9,#0891b2);transform:translateY(-2px);box-shadow:0 6px 24px rgba(124,58,237,0.4);}
.btn-primary:active{transform:translateY(0);}
.btn-full{width:100%;padding:13px;font-size:15px;}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border);}
.btn-ghost:hover{border-color:var(--border2);color:var(--text);background:var(--surface2);}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(244,63,94,0.22);}

@media(max-width:700px){
  .btn{padding:9px 16px;font-size:12.5px;}
  .btn-full{padding:11px;font-size:13px;}
  .btn-sm{padding:5px 12px;}
}

@media(max-width:480px){
  .btn{padding:8px 14px;font-size:12px;gap:6px;}
  .btn-full{padding:10px;font-size:12px;}
  .btn-sm{padding:4px 10px;font-size:10px;}
}
.btn-danger:hover{background:rgba(244,63,94,0.22);}
.btn-success-solid{background:var(--green);color:#fff;}
.btn-success-solid:hover{background:#0da872;}
.btn-warning{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(245,158,11,0.22);}
.btn-sm{padding:6px 14px;font-size:12px;border-radius:var(--radius-xs);}
.btn-xs{padding:4px 10px;font-size:11px;}
.btn-icon{padding:8px;border-radius:var(--radius-sm);}

/* ═══════════════════════════ APP LAYOUT ═══════════════════════════ */
#screen-app{flex-direction:row;flex:1;min-height:0;width:100%;position:relative;z-index:1;}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sidebar-w);min-height:100vh;
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface) 95%,rgba(124,92,252,0.05) 100%);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;left:0;top:0;bottom:0;z-index:200;
  transition:transform 0.3s cubic-bezier(0.16,1,0.3,1);
  overflow-y:auto;overflow-x:hidden;
}

.sidebar-logo{padding:20px 16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:12px;}
.logo-text{
  font-family:'Outfit',sans-serif;font-size:26px;font-weight:900;
  background:linear-gradient(135deg,#7c3aed 0%,#a78bfa 50%,#06b6d4 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-1.5px;
}
[data-theme="light"] .logo-text{background:linear-gradient(135deg,#5B21B6 0%,#7c3aed 50%,#06b6d4 100%);-webkit-background-clip:text;}
.logo-sub{font-size:10.5px;color:var(--text3);margin-top:2px;font-weight:500;letter-spacing:0.3px;}

.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:1px;}

.nav-section-label{
  font-size:10px;text-transform:uppercase;letter-spacing:1.2px;
  color:var(--text3);padding:12px 10px 4px;font-weight:700;
}

.nav-btn{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border:none;border-radius:var(--radius-sm);
  background:transparent;color:var(--text2);
  font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:500;
  cursor:pointer;transition:all 0.15s;width:100%;text-align:left;
  position:relative;
}
.nav-btn:hover{background:var(--surface2);color:var(--text);}
.nav-btn.active{background:var(--accent-glow);color:var(--accent2);font-weight:600;}
.nav-btn.active::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:3px;background:var(--accent);border-radius:0 3px 3px 0;
}
.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0;}
.nav-badge{
  margin-left:auto;background:var(--red);color:#fff;
  font-size:10px;font-weight:700;border-radius:20px;padding:1px 6px;line-height:1.5;
}

.sidebar-footer{
  padding:14px 10px;border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:6px;
}

.user-pill{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  border-radius:var(--radius-sm);background:var(--surface2);
  cursor:pointer;transition:all 0.15s;
}
.user-pill:hover{background:var(--surface3);}

.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:#fff;flex-shrink:0;
}

.user-info{flex:1;min-width:0;overflow:hidden;}
.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-email{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.plan-badge{
  padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;flex-shrink:0;
}
.plan-badge.free{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(245,158,11,0.2);}
.plan-badge.pro{background:var(--accent-glow);color:var(--accent2);border:1px solid rgba(124,92,252,0.28);}

/* THEME TOGGLE */
.theme-toggle{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border-radius:var(--radius-sm);background:var(--surface2);
  font-size:12px;font-weight:500;color:var(--text2);cursor:pointer;
  transition:all 0.15s;border:none;width:100%;font-family:inherit;
}
.theme-toggle:hover{background:var(--surface3);}

.toggle-switch{
  width:32px;height:18px;background:var(--border2);border-radius:20px;
  position:relative;transition:background 0.2s;flex-shrink:0;
}
.toggle-switch::after{
  content:'';position:absolute;width:12px;height:12px;background:#fff;
  border-radius:50%;top:3px;left:3px;transition:transform 0.2s;
}
.toggle-switch.on{background:var(--accent);}
.toggle-switch.on::after{transform:translateX(14px);}

/* ── MAIN CONTENT ── */
.main-content{
  margin-left:var(--sidebar-w);
  flex:1;
  min-width:0;
  min-height:0;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  width:calc(100% - var(--sidebar-w));
}

/* TOPBAR */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;height:var(--topbar-h);
  background:var(--surface);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(16px);
  width:100%;
}

.topbar-left{display:flex;align-items:center;gap:12px;}

.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:6px;
  border-radius:var(--radius-xs);transition:background 0.15s;
}
.hamburger:hover{background:var(--surface2);}
.hamburger span{display:block;width:20px;height:2px;background:var(--text2);border-radius:2px;transition:all 0.25s;}

.topbar-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:var(--text);}

.topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;justify-content:flex-end;min-width:0;}

@media(max-width:700px){
  .topbar-right #free-counter{display:none;}
}

/* NOTIFICATION BELL */
.notif-btn{
  position:relative;width:36px;height:36px;border-radius:var(--radius-sm);
  background:transparent;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:16px;transition:all 0.15s;color:var(--text2);
}
.notif-btn:hover{background:var(--surface2);border-color:var(--border2);color:var(--text);}
/* Botão sair mobile — oculto no desktop, visível só no mobile via media query */
.btn-logout-mobile{
  display:none;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:var(--radius-sm);
  background:transparent;border:1px solid var(--border);
  cursor:pointer;color:var(--text2);transition:all 0.15s;flex-shrink:0;
}
.btn-logout-mobile:hover{background:rgba(244,63,94,0.08);border-color:var(--red);color:var(--red);}
.btn-logout-mobile svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.notif-dot{
  position:absolute;top:6px;right:6px;width:8px;height:8px;
  background:var(--red);border-radius:50%;border:2px solid var(--surface);
  display:none;
}
.notif-dot.visible{display:block;}

/* NOTIFICATION DROPDOWN */
.notif-dropdown{
  display:none;position:fixed;top:calc(var(--topbar-h) + 6px);right:28px;
  width:320px;background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--radius);box-shadow:var(--shadow);z-index:500;
  animation:dropIn 0.2s cubic-bezier(0.16,1,0.3,1) both;
  max-height:400px;overflow-y:auto;
}
.notif-dropdown.open{display:block;}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}

.notif-header{
  padding:14px 16px 10px;border-bottom:1px solid var(--border);
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3);
  display:flex;justify-content:space-between;align-items:center;
}
.notif-clear{font-size:11px;color:var(--accent2);cursor:pointer;font-weight:500;}
.notif-clear:hover{text-decoration:underline;}

.notif-item{
  display:flex;align-items:flex-start;gap:10px;padding:12px 16px;
  border-bottom:1px solid var(--border);transition:background 0.12s;cursor:default;
}
.notif-item:last-child{border-bottom:none;}
.notif-item:hover{background:var(--surface2);}
.notif-item.unread{background:rgba(124,92,252,0.05);}
.notif-item-icon{font-size:18px;flex-shrink:0;margin-top:1px;}
.notif-item-body{flex:1;min-width:0;}
.notif-item-title{font-size:13px;font-weight:500;color:var(--text);}
.notif-item-text{font-size:12px;color:var(--text3);margin-top:1px;}
.notif-empty{padding:28px;text-align:center;font-size:13px;color:var(--text3);}

/* ── PAGE CONTENT ── */
.app-content{flex:1;padding:20px 24px;width:100%;min-width:0;}

.page{display:none;}
.page.active{display:block;animation:fadeIn 0.28s ease;}

@keyframes fadeIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

.page-header{margin-bottom:12px;}
.page-header h1{font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;letter-spacing:-0.5px;margin-bottom:2px;}
.page-header p{color:var(--text3);font-size:13px;}

@media(max-width:700px){
  .page-header{margin-bottom:14px;}
  .page-header h1{font-size:18px;}
  .page-header p{font-size:12px;}
}

@media(max-width:480px){
  .page-header{margin-bottom:12px;}
  .page-header h1{font-size:16px;margin-bottom:2px;}
  .page-header p{font-size:11px;}
}

/* ── GRID ── */
.grid{display:grid;gap:10px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
.col-span-2{grid-column:span 2;}

/* ── CARDS ── */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px;transition:all 0.2s;
}
.card:hover{border-color:var(--accent);box-shadow:0 4px 12px rgba(124,92,252,0.15);}

.card-title{
  font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:700;
  color:var(--text3);text-transform:uppercase;letter-spacing:1px;
  margin-bottom:14px;display:flex;align-items:center;gap:8px;
}

/* ── STAT CARDS ── */
.stat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:12px;position:relative;overflow:visible;
  transition:all 0.2s;
}
.stat-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 6px 16px rgba(124,92,252,0.2);}

.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.stat-card.green::before{background:linear-gradient(90deg,#10b981,transparent);}
.stat-card.red::before{background:linear-gradient(90deg,#f43f5e,transparent);}
.stat-card.purple::before{background:linear-gradient(90deg,#7c3aed,transparent);}
.stat-card.yellow::before{background:linear-gradient(90deg,#f59e0b,transparent);}

.stat-icon{
  width:38px;height:38px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:18px;
  margin-bottom:12px;
}
.stat-icon.green{background:var(--green-dim);}
.stat-icon.red{background:var(--red-dim);}
.stat-icon.purple{background:var(--accent-glow);}
.stat-icon.yellow{background:var(--yellow-dim);}

.stat-label{font-size:10px;text-transform:uppercase;letter-spacing:0.6px;color:var(--text3);margin-bottom:4px;font-weight:600;}
.stat-value{font-family:'Outfit',sans-serif;font-size:20px;font-weight:700;letter-spacing:-0.8px;line-height:1;margin-bottom:2px;}
.stat-value.green{color:var(--green);}
.stat-value.red{color:var(--red);}
.stat-value.purple{color:var(--accent2);}
.stat-sub{font-size:11.5px;color:var(--text3);}

/* ARROW INDICATORS */
.stat-arrow{
  position:absolute;top:16px;right:16px;
  font-size:20px;opacity:0.5;
}

/* ── BADGE ── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:20px;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px;
}
.badge-entrada{background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,0.22);}
.badge-saida{background:var(--red-dim);color:var(--red);border:1px solid rgba(244,63,94,0.22);}
.badge-pendente{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(245,158,11,0.22);}
.badge-pago{background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,0.22);}
.badge-atraso{background:var(--red-dim);color:var(--red);border:1px solid rgba(244,63,94,0.28);}

/* ── INSIGHT BANNER ── */
.insight-banner{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 14px;border-radius:var(--radius);margin-bottom:12px;
  animation:fadeIn 0.4s ease;
}
.insight-banner.positive{background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.18);}
.insight-banner.negative{background:rgba(244,63,94,0.08);border:1px solid rgba(244,63,94,0.18);}
.insight-banner.neutral{background:var(--surface2);border:1px solid var(--border);}
.insight-icon{font-size:22px;flex-shrink:0;margin-top:1px;}
.insight-text h4{font-size:14px;font-weight:600;margin-bottom:2px;}
.insight-text p{font-size:12px;color:var(--text2);}

@media(max-width:700px){
  .insight-banner{padding:13px 16px;gap:12px;margin-bottom:16px;}
  .insight-icon{font-size:18px;}
  .insight-text h4{font-size:13px;}
  .insight-text p{font-size:11px;}
  .stat-sub{font-size:10px;}
}

@media(max-width:480px){
  .insight-banner{padding:12px 14px;gap:10px;margin-bottom:14px;}
  .insight-icon{font-size:16px;}
  .insight-text h4{font-size:12px;margin-bottom:1px;}
  .insight-text p{font-size:10px;}
  .stat-sub{font-size:9.5px;}
  .badge{padding:2px 7px;font-size:10px;}
}

/* ── NOVO LANÇAMENTO FORM ── */
.lancamento-form-card{
  background:var(--surface);border:1px solid var(--border2);
  border-radius:18px;padding:14px;margin-bottom:14px;
  box-shadow:0 4px 24px rgba(0,0,0,0.18);
}

.tipo-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px;}
.tipo-btn{
  padding:14px;border-radius:12px;border:2px solid var(--border);
  background:var(--surface2);color:var(--text2);
  font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:500;
  cursor:pointer;transition:all 0.2s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.tipo-btn:hover{border-color:var(--border2);color:var(--text);}
.tipo-btn.selected-entrada{border-color:var(--green);background:var(--green-dim);color:var(--green);}
.tipo-btn.selected-saida{border-color:var(--red);background:var(--red-dim);color:var(--red);}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-actions{display:flex;gap:10px;margin-top:16px;justify-content:flex-end;}

@media(max-width:700px){
  .lancamento-form-card{padding:16px;margin-bottom:16px;border-radius:14px;}
  .tipo-selector{gap:8px;margin-bottom:14px;}
  .tipo-btn{padding:12px;font-size:13px;}
  .form-row{gap:12px;}
  .form-actions{gap:8px;}
  .input-group{margin-bottom:11px;}
}

@media(max-width:480px){
  .lancamento-form-card{padding:14px;margin-bottom:14px;border-radius:12px;}
  .tipo-selector{gap:8px;margin-bottom:12px;}
  .tipo-btn{padding:11px;font-size:12px;}
  .form-row{grid-template-columns:1fr;gap:10px;}
  .form-actions{flex-direction:column-reverse;}
  .form-actions .btn{width:100%;justify-content:center;font-size:13px;}
  .input-group{margin-bottom:10px;}
}

/* ── TX LIST ── */
.tx-list{display:flex;flex-direction:column;gap:5px;}

.tx-item{
  display:flex;align-items:center;gap:12px;
  padding:13px 15px;background:var(--surface2);
  border-radius:var(--radius-sm);border:1px solid transparent;
  transition:all 0.15s;
  flex-wrap:wrap;
}
.tx-item:hover{border-color:var(--border);background:var(--surface3);}

.tx-icon{
  width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.tx-icon.entrada{background:var(--green-dim);}
.tx-icon.saida{background:var(--red-dim);}

.tx-info{flex:1;min-width:0;}
.tx-desc{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tx-meta{font-size:11px;color:var(--text3);margin-top:1px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}

.tx-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}

.tx-valor{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;white-space:nowrap;display:flex;align-items:center;gap:4px;}
.tx-valor.entrada{color:var(--green);}
.tx-valor.saida{color:var(--red);}
.tx-arrow-up::before{content:'↑';font-size:12px;color:var(--green);}
.tx-arrow-down::before{content:'↓';font-size:12px;color:var(--red);}

.tx-actions{display:flex;gap:3px;opacity:0;transition:opacity 0.15s;}
.tx-item:hover .tx-actions{opacity:1;}

.icon-btn{
  width:28px;height:28px;border-radius:6px;
  border:1px solid var(--border);background:var(--surface);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:13px;transition:all 0.12s;color:var(--text2);
}
.icon-btn:hover{background:var(--surface3);border-color:var(--border2);}
.icon-btn.danger:hover{background:var(--red-dim);color:var(--red);border-color:transparent;}
.icon-btn.success:hover{background:var(--green-dim);color:var(--green);border-color:transparent;}

@media(max-width:700px){
  .tx-item{padding:11px 12px;gap:10px;}
  .tx-icon{width:32px;height:32px;font-size:14px;}
  .tx-desc{font-size:12px;}
  .tx-meta{font-size:10px;}
  .tx-valor{font-size:13px;}
  .icon-btn{width:24px;height:24px;font-size:11px;}
  .tx-actions{opacity:1;}
}

@media(max-width:480px){
  .tx-item{padding:10px 10px;gap:8px;}
  .tx-icon{width:28px;height:28px;font-size:12px;}
  .tx-desc{font-size:11px;}
  .tx-meta{font-size:9px;}
  .tx-valor{font-size:12px;}
  .icon-btn{width:22px;height:22px;font-size:10px;padding:2px;}
}

/* ── STATUS DOT ── */
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.status-dot.pendente{background:var(--yellow);}
.status-dot.pago{background:var(--green);}
.status-dot.atraso{background:var(--red);animation:blink 1.4s infinite;}

@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.35;}}

/* ── CALENDAR ── */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.cal-month{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;}
.cal-nav-btn{
  width:32px;height:32px;border-radius:var(--radius-xs);
  background:var(--surface2);border:1px solid var(--border);
  color:var(--text2);cursor:pointer;font-size:14px;
  display:flex;align-items:center;justify-content:center;transition:all 0.15s;
}
.cal-nav-btn:hover{background:var(--surface3);color:var(--text);}

.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;}
.cal-day-name{
  text-align:center;font-size:10px;font-weight:700;
  color:var(--text3);text-transform:uppercase;letter-spacing:0.5px;
  padding:6px 0;
}
.cal-day{
  border-radius:var(--radius-xs);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  padding:6px 3px 4px;
  font-size:12.5px;font-weight:500;cursor:pointer;
  transition:all 0.12s;color:var(--text2);position:relative;
  min-height:48px;
}
.cal-day:hover{background:var(--surface2);color:var(--text);}
.cal-day.today{background:var(--accent-glow);color:var(--accent2);font-weight:700;}
.cal-day.selected{background:var(--accent);color:#fff;font-weight:700;}
.cal-day.other-month{color:var(--text3);opacity:0.4;}
/* day number sits at top */
.cal-day-num{line-height:1;margin-bottom:3px;flex-shrink:0;}
/* mini pill strips inside each day */
.cal-day-pills{display:flex;flex-direction:column;gap:1px;width:100%;align-items:center;}
.cal-pill{
  width:90%;max-width:38px;height:4px;border-radius:2px;
  flex-shrink:0;opacity:0.85;
}
.cal-pill.entrada{background:var(--green);}
.cal-pill.saida{background:var(--red);}
/* legacy dot kept for "other-month" cells that have no pills */
.cal-day.has-event::after{
  content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--accent);
}
.cal-day.has-tx::after{display:none;}/* pills replace the dot when tx exist */
.cal-day.has-event.has-tx::after{display:none;}

/* DAY DETAIL */
.day-detail{
  background:var(--surface2);border-radius:var(--radius-sm);
  padding:14px;margin-top:14px;
}
.day-detail-title{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--text);}
.day-event-item{
  display:flex;align-items:center;gap:10px;padding:8px 10px;
  background:var(--surface);border-radius:var(--radius-xs);
  border:1px solid var(--border);margin-bottom:6px;font-size:13px;
}
.day-event-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}

@media(max-width:700px){
  .cal-grid{gap:2px;}
  .cal-day-name{font-size:9px;padding:4px 0;}
  .cal-day{font-size:11px;min-height:40px;padding:4px 2px 3px;}
  .cal-pill{height:3px;max-width:30px;}
  .day-detail{padding:12px;margin-top:12px;}
  .day-detail-title{font-size:12px;margin-bottom:8px;}
  .day-event-item{padding:7px 8px;gap:8px;margin-bottom:5px;font-size:12px;}
}

@media(max-width:480px){
  .cal-grid{gap:1px;}
  .cal-day-name{font-size:8px;padding:3px 0;letter-spacing:0.2px;}
  .cal-day{font-size:10px;min-height:34px;padding:3px 1px 2px;}
  .cal-pill{height:3px;max-width:22px;}
  .cal-day-pills{gap:1px;}
  .day-detail{padding:10px;margin-top:10px;}
  .day-detail-title{font-size:11px;margin-bottom:6px;}
  .day-event-item{padding:6px 7px;gap:6px;margin-bottom:4px;font-size:11px;}
}

/* ── CHARTS ── */
.chart-wrapper{position:relative;height:210px;}

@media(max-width:700px){
  .chart-wrapper{height:180px;}
}

@media(max-width:480px){
  .chart-wrapper{height:160px;}
}

/* ── FILTER BAR ── */
.filter-bar{
  display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center;
}
.filter-period-btn{
  padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;
  border:1px solid var(--border);background:transparent;color:var(--text3);
  cursor:pointer;transition:all 0.15s;font-family:'Space Grotesk',sans-serif;
}
.filter-period-btn:hover{border-color:var(--border2);color:var(--text2);}
.filter-period-btn.active{background:var(--accent-glow);border-color:var(--accent);color:var(--accent2);}

@media(max-width:700px){
  .filter-bar{gap:6px;margin-bottom:14px;}
  .filter-period-btn{padding:5px 12px;font-size:11px;}
}

@media(max-width:480px){
  .filter-bar{gap:4px;margin-bottom:12px;}
  .filter-period-btn{padding:4px 10px;font-size:10px;}
}

/* ── MODAL ── */
.modal-backdrop{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);
  z-index:1100;align-items:center;justify-content:center;padding:20px;
}
.modal-backdrop.open{display:flex;}
.modal{
  background:var(--surface);border:1px solid var(--border2);
  border-radius:20px;padding:30px;width:100%;max-width:480px;
  box-shadow:var(--shadow);animation:cardIn 0.35s cubic-bezier(0.16,1,0.3,1) both;
  max-height:90vh;overflow-y:auto;
}
.modal h3{font-family:'Outfit',sans-serif;font-size:18px;font-weight:700;margin-bottom:16px;}
.modal-footer{display:flex;gap:10px;margin-top:20px;}
.modal-footer .btn{flex:1;justify-content:center;}

@media(max-width:700px){
  .modal-backdrop{padding:16px;}
  .modal{padding:20px;border-radius:16px;}
  .modal h3{font-size:16px;}
  .modal-footer{gap:8px;}
}

@media(max-width:480px){
  .modal-backdrop{padding:12px;}
  .modal{padding:16px;border-radius:12px;max-width:100%;}
  .modal h3{font-size:14px;margin-bottom:12px;}
  .modal-footer{flex-direction:column;gap:8px;}
  .modal-footer .btn{font-size:13px;padding:10px 16px;}
}

/* SUCCESS ALERT */
.success-alert{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,0.78);backdrop-filter:blur(12px);
  z-index:2000;align-items:center;justify-content:center;
}
.success-alert.open{display:flex;}
.success-alert-box{
  background:var(--surface);border:2px solid var(--green);
  border-radius:22px;padding:38px 46px;text-align:center;max-width:360px;width:90%;
  animation:successPop 0.4s cubic-bezier(0.16,1,0.3,1) both;
  box-shadow:0 0 60px rgba(16,185,129,0.2);
}
@keyframes successPop{from{opacity:0;transform:scale(0.84);}to{opacity:1;transform:scale(1);}}
.success-checkmark{font-size:50px;margin-bottom:14px;animation:checkBounce 0.5s 0.2s cubic-bezier(0.16,1,0.3,1) both;}
@keyframes checkBounce{from{transform:scale(0) rotate(-20deg);}to{transform:scale(1) rotate(0deg);}}
.success-title{font-family:'Space Grotesk',sans-serif;font-size:20px;font-weight:700;color:var(--green);margin-bottom:6px;}
.success-text{font-size:13px;color:var(--text2);margin-bottom:22px;}

/* CONFIRM MODAL */
.confirm-modal{
  background:var(--surface);border:1px solid var(--border2);border-radius:22px;
  padding:28px 28px 22px;max-width:420px;width:92%;
  box-shadow:0 20px 60px rgba(0,0,0,0.25);
  animation:confirmIn 0.32s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes confirmIn{
  from{opacity:0;transform:scale(0.92) translateY(12px);}
  to{opacity:1;transform:scale(1) translateY(0);}
}
.confirm-modal h3{
  font-size:16px;font-weight:700;margin-bottom:6px;color:var(--text);
}
.confirm-what{
  background:var(--surface2);border-radius:var(--radius-sm);
  padding:13px 16px;margin:14px 0 20px;font-size:13px;color:var(--text2);
  border-left:3px solid var(--accent);line-height:1.55;
}
.confirm-modal .modal-footer{
  display:flex;gap:10px;justify-content:flex-end;margin-top:4px;
}
.confirm-modal .btn-ghost{
  border:1px solid var(--border2);color:var(--text2);
}
.confirm-modal .btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  min-width:110px;
}

/* TOAST */
#toast-container{
  position:fixed;bottom:24px;right:24px;z-index:9998;
  display:flex;flex-direction:column;gap:10px;
  pointer-events:none;
}
.toast{
  display:flex;align-items:flex-start;gap:12px;
  padding:13px 16px 13px 14px;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:14px;
  box-shadow:0 8px 30px rgba(0,0,0,0.18),0 2px 8px rgba(0,0,0,0.1);
  font-size:13px;font-weight:500;line-height:1.45;
  animation:toastIn 0.32s cubic-bezier(0.16,1,0.3,1) both;
  max-width:320px;min-width:220px;
  pointer-events:all;
  position:relative;overflow:hidden;
}
.toast::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  border-radius:3px 0 0 3px;
}
.toast .toast-icon{font-size:16px;flex-shrink:0;margin-top:1px;}
.toast .toast-body{flex:1;}
.toast .toast-title{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:0.04em;margin-bottom:2px;opacity:0.7;}
.toast .toast-msg{font-size:13px;}
.toast .toast-close{
  background:none;border:none;cursor:pointer;padding:0;
  font-size:14px;opacity:0.4;color:inherit;flex-shrink:0;
  transition:opacity 0.15s;line-height:1;margin-top:1px;
}
.toast .toast-close:hover{opacity:0.9;}
.toast.error{
  border-color:rgba(244,63,94,0.25);
  background:linear-gradient(135deg,rgba(244,63,94,0.08),rgba(244,63,94,0.04));
  color:var(--red);
}
.toast.error::before{background:var(--red);}
.toast.success{
  border-color:rgba(16,185,129,0.25);
  background:linear-gradient(135deg,rgba(16,185,129,0.08),rgba(16,185,129,0.04));
  color:var(--green);
}
.toast.success::before{background:var(--green);}
.toast.info{
  border-color:rgba(124,92,252,0.25);
  background:linear-gradient(135deg,rgba(124,92,252,0.08),rgba(124,92,252,0.04));
  color:var(--accent2);
}
.toast.info::before{background:var(--accent);}
.toast.warning{
  border-color:rgba(234,179,8,0.25);
  background:linear-gradient(135deg,rgba(234,179,8,0.08),rgba(234,179,8,0.04));
  color:var(--yellow);
}
.toast.warning::before{background:var(--yellow);}
@keyframes toastIn{
  from{opacity:0;transform:translateX(28px) scale(0.96);}
  to{opacity:1;transform:translateX(0) scale(1);}
}
@keyframes toastOut{
  from{opacity:1;transform:translateX(0) scale(1);max-height:100px;}
  to{opacity:0;transform:translateX(28px) scale(0.94);max-height:0;margin:0;padding-top:0;padding-bottom:0;}
}

/* ════════════════════════════════════════
   ADMIN PANEL — NEW LAYOUT
   ════════════════════════════════════════ */
.admin-panel{background:var(--bg);min-height:100vh;position:relative;z-index:1;flex-direction:column;}
.screen.active.admin-panel{display:flex;}

.admin-bar{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:13px 24px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;flex-wrap:wrap;gap:10px;flex-shrink:0;
}
.admin-logo{font-family:'Outfit',sans-serif;font-size:18px;font-weight:800;}
.admin-badge{
  background:rgba(244,63,94,0.13);color:var(--red);
  border:1px solid rgba(244,63,94,0.28);border-radius:20px;
  padding:3px 12px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
}

/* LAYOUT: sidenav + main */
.adm-layout{display:flex;flex:1;min-height:0;height:calc(100vh - 58px);}

/* SIDE NAV */
.adm-sidenav{
  width:220px;flex-shrink:0;
  background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:sticky;top:58px;height:calc(100vh - 58px);overflow-y:auto;
}
.adm-sidenav-header{padding:20px 18px 14px;border-bottom:1px solid var(--border);}
.adm-sidenav-title{font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700;color:var(--text);}
.adm-sidenav-sub{font-size:10.5px;color:var(--text3);margin-top:2px;}
.adm-sidenav-nav{flex:1;padding:10px 10px;display:flex;flex-direction:column;gap:2px;}

.adm-nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border:none;border-radius:var(--radius-sm);
  background:transparent;color:var(--text2);
  font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:500;
  cursor:pointer;transition:all 0.15s;width:100%;text-align:left;
  position:relative;
}
.adm-nav-item svg{width:17px;height:17px;flex-shrink:0;opacity:0.7;}
.adm-nav-item:hover{background:var(--surface2);color:var(--text);}
.adm-nav-item.active{background:var(--accent-glow);color:var(--accent2);font-weight:600;}
.adm-nav-item.active svg{opacity:1;}
.adm-nav-item.active::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:3px;background:var(--accent);border-radius:0 3px 3px 0;
}
.adm-nav-count{
  margin-left:auto;background:var(--surface3);color:var(--text3);
  font-size:10.5px;font-weight:700;border-radius:20px;padding:1px 7px;line-height:1.5;
}
.adm-nav-item.active .adm-nav-count{background:rgba(124,58,237,0.25);color:var(--accent2);}
.adm-nav-badge-new{
  margin-left:auto;background:var(--green-dim);color:var(--green);
  font-size:9px;font-weight:800;border-radius:20px;padding:2px 7px;
  letter-spacing:0.5px;text-transform:uppercase;
}

/* MAIN CONTENT */
.adm-main{flex:1;overflow-y:auto;padding:24px;}

/* TABS */
.adm-tab{display:none;}
.adm-tab.active{display:block;animation:fadeIn 0.25s ease;}

/* TAB HEADER */
.adm-tab-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;margin-bottom:20px;flex-wrap:wrap;
}
.adm-tab-title{font-family:'Outfit',sans-serif;font-size:20px;font-weight:700;letter-spacing:-0.4px;margin-bottom:2px;}
.adm-tab-sub{color:var(--text3);font-size:13px;}
.adm-tab-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.adm-header-time{font-size:12px;color:var(--text3);margin-top:4px;}

/* KPI CARDS */
.adm-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px;}
.adm-kpi{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;display:flex;align-items:center;gap:14px;
  transition:transform 0.18s,border-color 0.18s,box-shadow 0.18s;
  position:relative;overflow:hidden;
}
.adm-kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.adm-kpi.green::before{background:linear-gradient(90deg,var(--green),transparent);}
.adm-kpi.purple::before{background:linear-gradient(90deg,var(--accent),transparent);}
.adm-kpi.yellow::before{background:linear-gradient(90deg,var(--yellow),transparent);}
.adm-kpi.red::before{background:linear-gradient(90deg,var(--red),transparent);}
.adm-kpi:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 4px 20px rgba(0,0,0,0.15);}
.adm-kpi-icon{
  width:42px;height:42px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.adm-kpi.green .adm-kpi-icon{background:var(--green-dim);}
.adm-kpi.green .adm-kpi-icon svg{stroke:var(--green);width:20px;height:20px;}
.adm-kpi.purple .adm-kpi-icon{background:var(--accent-glow);}
.adm-kpi.purple .adm-kpi-icon svg{stroke:var(--accent2);width:20px;height:20px;}
.adm-kpi.yellow .adm-kpi-icon{background:var(--yellow-dim);}
.adm-kpi.yellow .adm-kpi-icon svg{stroke:var(--yellow);width:20px;height:20px;}
.adm-kpi.red .adm-kpi-icon{background:var(--red-dim);}
.adm-kpi.red .adm-kpi-icon svg{stroke:var(--red);width:20px;height:20px;}
.adm-kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:0.7px;color:var(--text3);font-weight:600;margin-bottom:3px;}
.adm-kpi-value{font-family:'Outfit',sans-serif;font-size:26px;font-weight:700;letter-spacing:-1px;line-height:1;}
.adm-kpi.green .adm-kpi-value{color:var(--green);}
.adm-kpi.purple .adm-kpi-value{color:var(--accent2);}
.adm-kpi.yellow .adm-kpi-value{color:var(--yellow);}
.adm-kpi.red .adm-kpi-value{color:var(--red);}

/* QUICK STATS */
.adm-quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px;}
.adm-quick-card{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 16px;
}
.adm-quick-label{font-size:11.5px;color:var(--text3);margin-bottom:5px;font-weight:500;}
.adm-quick-value{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;letter-spacing:-0.5px;}
.adm-quick-value.text-yellow{color:var(--yellow);}
.adm-quick-value.text-green{color:var(--green);}

/* SECTION CARDS */
.adm-section-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:18px;margin-bottom:16px;
}
.adm-section-head{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;
}
.adm-section-title{font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;color:var(--text);}
.adm-link-btn{
  background:transparent;border:none;color:var(--accent2);font-size:12px;
  font-weight:600;cursor:pointer;font-family:'Space Grotesk',sans-serif;
  transition:opacity 0.15s;
}
.adm-link-btn:hover{opacity:0.75;}

/* SUPABASE STATUS BANNER */
.adm-integra-status-bar{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:12px 16px;display:flex;align-items:center;gap:10px;font-size:13px;
  margin-top:4px;
}
.adm-integra-status-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
}
.adm-integra-status-dot.connected{background:var(--green);box-shadow:0 0 6px var(--green);}
.adm-integra-status-dot.disconnected{background:var(--text3);}
.adm-integra-status-dot.error{background:var(--red);box-shadow:0 0 6px var(--red);}

/* SEARCH + FILTERS */
.adm-search-wrap{
  position:relative;display:flex;align-items:center;
}
.adm-search-wrap svg{position:absolute;left:10px;width:15px;height:15px;color:var(--text3);}
.adm-search-input{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px 12px 8px 32px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:13px;
  outline:none;width:220px;transition:border-color 0.2s,box-shadow 0.2s;
}
.adm-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
.adm-filter-select{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:8px 12px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:13px;
  outline:none;cursor:pointer;transition:border-color 0.2s;
}
.adm-filter-select:focus{border-color:var(--accent);}

/* ADMIN ACCOUNT CARD */
.adm-admin-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 20px;display:flex;align-items:center;gap:14px;
  transition:border-color 0.15s;
}
.adm-admin-card:hover{border-color:var(--border2);}
.adm-admin-card.adm-admin-super{
  border-color:rgba(124,58,237,0.3);background:rgba(124,58,237,0.04);
  position:relative;overflow:hidden;
}
.adm-admin-card.adm-admin-super::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
}
.adm-admin-avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--accent-glow);border:2px solid rgba(124,58,237,0.3);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.adm-admin-avatar svg{width:20px;height:20px;stroke:var(--accent2);}
.adm-admin-name{font-size:14px;font-weight:600;color:var(--text);}
.adm-admin-email{font-size:12px;color:var(--text3);margin-top:2px;}
.adm-admin-role{
  margin-left:auto;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;flex-shrink:0;
}
.adm-admin-role.super{background:var(--accent-glow);color:var(--accent2);border:1px solid rgba(124,58,237,0.3);}

/* FEEDBACK STATS */
.adm-fb-stat-row{
  display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:18px;
}
.adm-fb-stat{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px;text-align:center;transition:border-color 0.15s;
}
.adm-fb-stat:hover{border-color:var(--border2);}
.adm-fb-stat.yellow .adm-fb-stat-num{color:var(--yellow);}
.adm-fb-stat.green .adm-fb-stat-num{color:var(--green);}
.adm-fb-stat.red .adm-fb-stat-num{color:var(--red);}
.adm-fb-stat.purple .adm-fb-stat-num{color:var(--accent2);}
.adm-fb-stat.teal .adm-fb-stat-num{color:var(--cyan);}
.adm-fb-stat-num{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;letter-spacing:-0.5px;display:block;margin-bottom:3px;}
.adm-fb-stat-label{font-size:11px;color:var(--text3);font-weight:500;}

/* FEEDBACK FILTERS */
.adm-fb-filter-bar{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;margin-bottom:16px;display:flex;gap:20px;flex-wrap:wrap;
}
.adm-fb-filter-group{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.adm-fb-filter-label{font-size:11.5px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px;white-space:nowrap;}
.adm-fb-chips{display:flex;gap:6px;flex-wrap:wrap;}
.adm-fb-chip{
  padding:5px 13px;border-radius:20px;font-size:12px;font-weight:500;
  border:1px solid var(--border);background:transparent;color:var(--text3);
  cursor:pointer;transition:all 0.15s;font-family:'Space Grotesk',sans-serif;
}
.adm-fb-chip:hover{border-color:var(--border2);color:var(--text2);background:var(--surface);}
.adm-fb-chip.active{background:var(--accent-glow);border-color:rgba(124,58,237,0.35);color:var(--accent2);font-weight:600;}
.adm-fb-chip.active-cat-critica{background:var(--red-dim);border-color:rgba(244,63,94,0.3);color:var(--red);}
.adm-fb-chip.active-cat-ideia{background:var(--yellow-dim);border-color:rgba(245,158,11,0.3);color:var(--yellow);}
.adm-fb-chip.active-cat-elogio{background:var(--green-dim);border-color:rgba(16,185,129,0.3);color:var(--green);}
.adm-fb-chip.active-status-resolvido{background:var(--green-dim);border-color:rgba(16,185,129,0.3);color:var(--green);}
.adm-fb-chip.active-status-pendente{background:var(--yellow-dim);border-color:rgba(245,158,11,0.3);color:var(--yellow);}

/* FEEDBACK ITEMS */
.adm-fb-status-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px;
}
.adm-fb-status-badge.pendente{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(245,158,11,0.22);}
.adm-fb-status-badge.resolvido{background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,0.22);}
.adm-fb-resolve-btn{
  padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;
  background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,0.25);
  cursor:pointer;font-family:'Space Grotesk',sans-serif;transition:all 0.15s;
}
.adm-fb-resolve-btn:hover{background:rgba(16,185,129,0.22);}

/* ─── INTEGRATIONS ─── */
.adm-integra-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;margin-bottom:20px;
}
.adm-integra-header{
  padding:20px 24px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.adm-integra-logo-wrap{display:flex;align-items:center;gap:16px;}
.adm-integra-logo{width:44px;height:44px;flex-shrink:0;}
.adm-integra-name{font-family:'Space Grotesk',sans-serif;font-size:17px;font-weight:700;margin-bottom:3px;}
.adm-integra-desc{font-size:12.5px;color:var(--text3);}
.adm-integra-status-pill{
  display:flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:20px;font-size:12.5px;font-weight:500;
  background:var(--surface2);border:1px solid var(--border);
}
.adm-integra-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.adm-integra-status-dot.connected{background:var(--green);box-shadow:0 0 8px rgba(16,185,129,0.5);animation:pulse 2s infinite;}
.adm-integra-status-dot.disconnected{background:var(--text3);}
.adm-integra-status-dot.testing{background:var(--yellow);animation:pulse 0.8s infinite;}
.adm-integra-status-dot.error{background:var(--red);}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.5;}}

.adm-integra-body{padding:24px;}
.adm-integra-info{
  background:rgba(124,58,237,0.07);border:1px solid rgba(124,58,237,0.2);
  border-radius:var(--radius-sm);padding:12px 16px;
  display:flex;align-items:flex-start;gap:10px;margin-bottom:20px;
  font-size:13px;color:var(--text2);
}
.adm-integra-info svg{stroke:var(--accent2);}

.adm-integra-form{display:flex;flex-direction:column;gap:16px;margin-bottom:20px;}
.adm-field{display:flex;flex-direction:column;gap:6px;}
.adm-field-label{
  font-size:12px;font-weight:600;color:var(--text3);
  text-transform:uppercase;letter-spacing:0.5px;
  display:flex;align-items:center;gap:8px;
}
.adm-field-hint{
  font-size:11px;color:var(--text3);font-weight:400;
  text-transform:none;letter-spacing:0;opacity:0.8;
}
.adm-field-input{
  background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:11px 14px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:13.5px;
  outline:none;transition:border-color 0.2s,box-shadow 0.2s;width:100%;
}
.adm-field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}
.adm-field-pass{position:relative;display:flex;align-items:center;}
.adm-field-pass .adm-field-input{padding-right:44px;}
.adm-field-eye{
  position:absolute;right:12px;background:none;border:none;cursor:pointer;
  color:var(--text3);transition:color 0.15s;padding:4px;
}
.adm-field-eye:hover{color:var(--text2);}
.adm-field-eye svg{width:18px;height:18px;}

.adm-integra-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.adm-integra-btn-test{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border:none;border-radius:var(--radius-sm);
  background:var(--surface2);color:var(--text2);border:1px solid var(--border);
  font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:500;cursor:pointer;
  transition:all 0.18s;
}
.adm-integra-btn-test:hover{border-color:var(--border2);color:var(--text);background:var(--surface3);}
.adm-integra-btn-save{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border:none;border-radius:var(--radius-sm);
  background:var(--accent);color:#fff;box-shadow:0 4px 14px var(--accent-glow);
  font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:500;cursor:pointer;
  transition:all 0.18s;
}
.adm-integra-btn-save:hover{background:var(--accent2);transform:translateY(-1px);}
.adm-integra-btn-clear{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border:1px solid rgba(244,63,94,0.28);border-radius:var(--radius-sm);
  background:var(--red-dim);color:var(--red);
  font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:500;cursor:pointer;
  transition:all 0.18s;margin-left:auto;
}
.adm-integra-btn-clear:hover{background:rgba(244,63,94,0.22);}

.adm-integra-test-result{
  margin-top:14px;padding:12px 16px;border-radius:var(--radius-sm);
  font-size:13px;display:flex;align-items:center;gap:10px;
}
.adm-integra-test-result.success{background:var(--green-dim);border:1px solid rgba(16,185,129,0.25);color:var(--green);}
.adm-integra-test-result.error{background:var(--red-dim);border:1px solid rgba(244,63,94,0.25);color:var(--red);}
.adm-integra-test-result.testing{background:var(--yellow-dim);border:1px solid rgba(245,158,11,0.25);color:var(--yellow);}

/* TABLE SECTION */
.adm-integra-tables-section{
  padding:0 24px 24px;border-top:1px solid var(--border);
  padding-top:20px;
}
.adm-tables-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px;}
.adm-table-item{
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;
}
.adm-table-name{
  display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;
  color:var(--accent2);margin-bottom:5px;font-family:'Space Grotesk',monospace;
}
.adm-table-name svg{stroke:var(--accent2);}
.adm-table-cols{font-size:11.5px;color:var(--text3);font-family:monospace;line-height:1.5;}

/* SQL BLOCK */
.adm-sql-block{
  background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;
}
.adm-sql-header{
  padding:10px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px;
}
.adm-sql-copy{
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:1px solid var(--border);border-radius:var(--radius-xs);
  padding:4px 10px;color:var(--text3);font-size:11.5px;font-weight:500;cursor:pointer;
  font-family:'Space Grotesk',sans-serif;transition:all 0.15s;
}
.adm-sql-copy:hover{border-color:var(--border2);color:var(--text2);background:var(--surface);}
.adm-sql-code{
  padding:16px;font-family:'Courier New',Courier,monospace;font-size:12px;
  color:var(--text2);line-height:1.7;white-space:pre;overflow-x:auto;
  margin:0;
}

/* FUTURE INTEGRATIONS */
.adm-integra-future{margin-top:0;}
.adm-integra-future-title{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;
  color:var(--text3);margin-bottom:12px;
}
.adm-integra-future-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.adm-integra-future-item{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 16px;text-align:center;opacity:0.65;
  transition:opacity 0.2s,border-color 0.2s;
}
.adm-integra-future-item:hover{opacity:0.85;border-color:var(--border2);}
.adm-integra-future-icon{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 10px;
}
.adm-integra-future-icon svg{width:22px;height:22px;}
.adm-integra-future-name{font-size:13.5px;font-weight:600;margin-bottom:4px;}
.adm-integra-future-desc{font-size:11.5px;color:var(--text3);}

/* ADMIN TABLE */
.admin-content{padding:14px;max-width:none;margin:0;}
.admin-table{width:100%;border-collapse:collapse;font-size:13px;}
.admin-table th{
  text-align:left;padding:10px 14px;color:var(--text3);text-transform:uppercase;
  font-size:11px;letter-spacing:0.5px;border-bottom:1px solid var(--border);font-weight:600;
}
.admin-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text2);}
.admin-table tr:last-child td{border-bottom:none;}
.admin-table tr:hover td{background:var(--surface2);}
.view-as-btn{
  display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;
  background:var(--accent-glow);color:var(--accent2);
  border:1px solid rgba(124,92,252,0.28);font-size:11px;font-weight:600;cursor:pointer;
  transition:all 0.15s;font-family:inherit;
}
.view-as-btn:hover{background:rgba(124,58,237,0.2);}

/* RESPONSIVE */
@media(max-width:1100px){
  .adm-kpi-grid{grid-template-columns:repeat(2,1fr);}
  .adm-quick-grid{grid-template-columns:repeat(2,1fr);}
  .adm-fb-stat-row{grid-template-columns:repeat(3,1fr);}
  .adm-integra-future-grid{grid-template-columns:repeat(2,1fr);}
  .adm-tables-grid{grid-template-columns:1fr;}
}
@media(max-width:900px){
  .adm-sidenav{width:60px;}
  .adm-sidenav-header,.adm-sidenav-sub,.adm-nav-item span,.adm-nav-count,.adm-nav-badge-new{display:none;}
  .adm-nav-item{justify-content:center;padding:12px;}
  .adm-nav-item.active::before{display:none;}
  .adm-main{padding:16px;}
  .adm-fb-filter-bar{flex-direction:column;gap:12px;}
  .adm-search-input{width:160px;}
}
@media(max-width:700px){
  .adm-layout{flex-direction:column;height:auto;}
  .adm-sidenav{
    width:100%;height:auto;position:static;
    border-right:none;border-bottom:1px solid var(--border);
    flex-direction:row;overflow-x:auto;
  }
  .adm-sidenav-header{display:none;}
  .adm-sidenav-nav{flex-direction:row;padding:8px;gap:4px;overflow-x:auto;}
  .adm-nav-item{padding:8px 14px;white-space:nowrap;flex-shrink:0;}
  .adm-nav-item span{display:inline;}
  .adm-nav-item.active::before{display:none;} 
  .adm-nav-item.active{border-bottom:2px solid var(--accent);}
  .adm-nav-count,.adm-nav-badge-new{display:none;}
  .adm-kpi-grid{grid-template-columns:repeat(2,1fr);}
  .adm-fb-stat-row{grid-template-columns:repeat(2,1fr);}
  .adm-integra-future-grid{grid-template-columns:repeat(2,1fr);}
  .adm-tab-header{flex-direction:column;}
  .adm-integra-header{flex-direction:column;align-items:flex-start;}
  .adm-integra-actions{flex-direction:column;}
  .adm-integra-btn-clear{margin-left:0;}
  .adm-search-input{width:100%;}
  .admin-bar{padding:12px 16px;}
  .admin-logo{font-size:16px;}
  .admin-badge{padding:2px 10px;font-size:10px;}
  .admin-table{font-size:12px;}
  .admin-table th,.admin-table td{padding:10px 10px;}
  .view-as-btn{padding:4px 10px;font-size:10px;}
  .admin-content{padding:16px;}
}

@media(max-width:480px){
  .admin-bar{padding:10px 12px;font-size:12px;}
  .admin-logo{font-size:14px;}
  .admin-badge{padding:2px 8px;font-size:9px;}
  .admin-table{font-size:11px;}
  .admin-table th,.admin-table td{padding:8px 8px;}
  .view-as-btn{padding:3px 8px;font-size:9px;}
  .admin-content{padding:12px;}
}
.view-as-btn:hover{background:rgba(124,92,252,0.22);}
.readonly-banner{
  background:rgba(244,63,94,0.08);border:1px solid rgba(244,63,94,0.22);
  border-radius:var(--radius-sm);padding:10px 16px;font-size:12px;color:var(--red);
  display:flex;align-items:center;gap:8px;margin-bottom:18px;
}
.view-as-overlay{
  display:none;position:fixed;top:0;left:0;right:0;
  background:rgba(244,63,94,0.1);border-bottom:2px solid var(--red);
  padding:8px 24px;z-index:9990;align-items:center;justify-content:space-between;
  gap:10px;font-size:13px;color:var(--red);font-weight:500;backdrop-filter:blur(8px);
}
.view-as-overlay.active{display:flex;}

/* FEEDBACK */
.feedback-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;}
.feedback-type-btn{
  padding:14px 10px;border-radius:12px;border:2px solid var(--border);background:var(--surface2);
  color:var(--text2);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:500;cursor:pointer;
  transition:all 0.18s;display:flex;flex-direction:column;align-items:center;gap:5px;
}
.feedback-type-btn:hover{border-color:var(--border2);color:var(--text);}
.feedback-type-btn.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent2);}
.feedback-type-btn .fbt-icon{font-size:20px;}
.feedback-item{
  display:flex;align-items:flex-start;gap:12px;padding:14px 16px;
  background:var(--surface2);border-radius:var(--radius-sm);
  border:1px solid transparent;margin-bottom:8px;transition:border-color 0.15s;
}
.feedback-item:hover{border-color:var(--border);}
.feedback-icon{font-size:18px;flex-shrink:0;margin-top:2px;}
.feedback-body{flex:1;}
.feedback-type-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-bottom:2px;font-weight:600;}
.feedback-text{font-size:13px;color:var(--text2);}
.feedback-date{font-size:11px;color:var(--text3);margin-top:4px;}

/* CONFIG SECTION */
.config-section{margin-bottom:24px;}
.config-section-title{font-size:13px;font-weight:700;margin-bottom:12px;color:var(--text);}
.config-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;background:var(--surface2);border-radius:var(--radius-sm);
  border:1px solid var(--border);margin-bottom:8px;
}
.config-row-label{font-size:13px;font-weight:500;}
.config-row-desc{font-size:12px;color:var(--text3);margin-top:2px;}

@media(max-width:700px){
  .feedback-item{padding:12px 14px;gap:10px;margin-bottom:7px;}
  .feedback-icon{font-size:16px;}
  .feedback-type-label{font-size:9px;}
  .feedback-text{font-size:12px;}
  .feedback-date{font-size:10px;}
  .config-section{margin-bottom:18px;}
  .config-section-title{font-size:12px;margin-bottom:10px;}
  .config-row{padding:12px 14px;gap:10px;margin-bottom:7px;}
  .config-row-label{font-size:12px;}
  .config-row-desc{font-size:11px;margin-top:1px;}
}

@media(max-width:480px){
  .feedback-item{padding:10px 12px;gap:8px;margin-bottom:6px;flex-wrap:wrap;}
  .feedback-icon{font-size:14px;margin-top:0;}
  .feedback-type-label{font-size:8px;}
  .feedback-text{font-size:11px;}
  .feedback-date{font-size:9px;}
  .config-section{margin-bottom:16px;}
  .config-section-title{font-size:11px;margin-bottom:8px;}
  .config-row{padding:10px 12px;gap:8px;margin-bottom:6px;flex-wrap:wrap;}
  .config-row-label{font-size:11px;}
  .config-row-desc{font-size:10px;margin-top:1px;}
}

/* SECTION */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.section-title{font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;}

.empty-state{text-align:center;padding:34px 20px;color:var(--text3);font-size:13px;}
.empty-state .empty-icon{font-size:28px;margin-bottom:8px;}

.divider{height:1px;background:var(--border);margin:18px 0;}

/* CODE INPUT */
.code-inputs{display:flex;gap:10px;justify-content:center;margin:20px 0;flex-wrap:wrap;}
.code-input{
  width:44px;height:54px;text-align:center;font-size:22px;font-weight:700;
  font-family:'Space Grotesk',sans-serif;background:var(--input-bg);
  border:2px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);outline:none;transition:all 0.2s;
}
.code-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);}

@media(max-width:700px){
  .empty-state{padding:24px 16px;font-size:12px;}
  .empty-state .empty-icon{font-size:24px;margin-bottom:6px;}
  .divider{margin:14px 0;}
  .code-inputs{gap:8px;margin:16px 0;}
  .code-input{width:40px;height:48px;font-size:18px;}
}

@media(max-width:480px){
  .empty-state{padding:20px 12px;font-size:11px;}
  .empty-state .empty-icon{font-size:20px;}
  .code-inputs{gap:6px;margin:14px 0;}
  .code-input{width:36px;height:44px;font-size:16px;}
}

/* MISC */
.cat-alimentacao{background:rgba(249,115,22,0.13);color:#f97316;}
.cat-transporte{background:rgba(6,182,212,0.13);color:#06b6d4;}
.cat-saude{background:rgba(16,185,129,0.13);color:#10b981;}
.cat-lazer{background:rgba(167,139,250,0.13);color:#a78bfa;}
.cat-educacao{background:rgba(245,158,11,0.13);color:#f59e0b;}
.cat-moradia{background:rgba(99,102,241,0.13);color:#6366f1;}
.cat-renda{background:rgba(16,185,129,0.13);color:#10b981;}
.cat-outros{background:rgba(100,116,139,0.13);color:#64748b;}

.text-green{color:var(--green);}
.text-red{color:var(--red);}
.text-yellow{color:var(--yellow);}
.text-muted{color:var(--text3);}
.flex{display:flex;}.items-center{align-items:center;}.justify-between{justify-content:space-between;}
.gap-8{gap:8px;}.gap-12{gap:12px;}.mt-16{margin-top:16px;}.mb-16{margin-bottom:16px;}

.upgrade-banner{
  background:linear-gradient(135deg,rgba(124,92,252,0.11),rgba(167,139,250,0.06));
  border:1px solid rgba(124,92,252,0.2);border-radius:var(--radius);
  padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-bottom:18px;
}
.upgrade-banner p{font-size:13px;color:var(--text2);}

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

/* ── LOGO STYLES ── */
.auth-logo-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;justify-content:center;text-align:center;}
.auth-logo-img{height:90px;width:auto;object-fit:contain;filter:drop-shadow(0 6px 18px rgba(124,92,252,0.25));}
.auth-logo-svg{width:64px;height:64px;flex-shrink:0;filter:drop-shadow(0 8px 16px rgba(124,92,252,0.5));}
.auth-logo-text{
  font-family:'Outfit',sans-serif;font-size:36px;font-weight:900;
  background:linear-gradient(135deg,#7c3aed 0%,#a78bfa 50%,#06b6d4 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-2px;line-height:1;
}
[data-theme="light"] .auth-logo-text{background:linear-gradient(135deg,#5B21B6 0%,#7c3aed 50%,#06b6d4 100%);-webkit-background-clip:text;}

.sidebar-logo{
  padding:16px 16px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,rgba(124,92,252,0.1),rgba(6,182,212,0.05));
  border-bottom:2px solid rgba(124,92,252,0.2);
}
.sidebar-logo-svg{width:40px;height:40px;flex-shrink:0;filter:drop-shadow(0 4px 12px rgba(124,92,252,0.4));}

/* ── ADM FEEDBACK FILTERS ── */
.adm-fb-filters{
  display:flex;gap:6px;flex-wrap:wrap;align-items:center;
  padding:12px 0 14px;border-bottom:1px solid var(--border);margin-bottom:14px;
}
.adm-fb-filter-label{font-size:11px;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-right:4px;}
.adm-fb-chip{
  padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;
  border:1px solid var(--border);background:transparent;color:var(--text3);
  cursor:pointer;transition:all 0.15s;font-family:'Space Grotesk',sans-serif;
}
.adm-fb-chip:hover{border-color:var(--border2);color:var(--text2);background:var(--surface2);}
.adm-fb-chip.active{background:var(--accent-glow);border-color:rgba(124,92,252,0.35);color:var(--accent2);font-weight:600;}
.adm-fb-chip.active-cat-critica{background:var(--red-dim);border-color:rgba(244,63,94,0.3);color:var(--red);}
.adm-fb-chip.active-cat-ideia{background:var(--yellow-dim);border-color:rgba(245,158,11,0.3);color:var(--yellow);}
.adm-fb-chip.active-cat-elogio{background:var(--green-dim);border-color:rgba(16,185,129,0.3);color:var(--green);}
.adm-fb-chip.active-status-resolvido{background:var(--green-dim);border-color:rgba(16,185,129,0.3);color:var(--green);}
.adm-fb-chip.active-status-pendente{background:var(--yellow-dim);border-color:rgba(245,158,11,0.3);color:var(--yellow);}

.adm-fb-sep{width:1px;height:18px;background:var(--border);margin:0 4px;}

.adm-fb-status-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.3px;margin-left:6px;
}
.adm-fb-status-badge.pendente{background:var(--yellow-dim);color:var(--yellow);border:1px solid rgba(245,158,11,0.22);}
.adm-fb-status-badge.resolvido{background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,0.22);}

.adm-fb-resolve-btn{
  margin-left:auto;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;
  background:var(--green-dim);color:var(--green);border:1px solid rgba(16,185,129,0.25);
  cursor:pointer;font-family:'Space Grotesk',sans-serif;transition:all 0.15s;
}
.adm-fb-resolve-btn:hover{background:rgba(16,185,129,0.22);}
.adm-fb-resolve-btn.done{background:var(--surface2);color:var(--text3);border-color:var(--border);cursor:default;}

/* MOBILE OVERLAY */
.sidebar-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,0.55);
  z-index:199;
}
.sidebar-overlay.active{display:block;}

/* ═══════════════════════════ RESPONSIVE ═══════════════════════════ */
@media(max-width:900px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}
  .col-span-2{grid-column:span 1;}
  .app-content{padding:12px 12px;}
}

@media(max-width:700px){
  :root{--sidebar-w:0px;}
  .sidebar{transform:translateX(-100%);width:248px;z-index:300;will-change:transform;-webkit-transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);-webkit-transform:translateX(0);}
  .hamburger{display:flex;}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .app-content{padding:12px 12px;}
  .topbar{padding:0 12px;}
  .topbar-title{font-size:14px;}
  .notif-dropdown{right:10px;width:calc(100vw - 20px);}
  .admin-content{padding:10px 10px;}
  .page-header h1{font-size:18px;}
  .grid{gap:8px;}
  .stat-card{padding:12px;}
  .card{padding:14px;}
  #page-relatorios .chart-wrapper{height:220px;}
  /* sidebar-overlay: usa .active para mostrar — não precisa de override aqui */
  /* Tabelas: scroll horizontal em vez de quebrar layout */
  .table-wrapper,table{overflow-x:auto;-webkit-overflow-scrolling:touch;display:block;width:100%;}
  /* Modais ocupam mais espaço na tela */
  .modal,.confirm-modal{width:calc(100vw - 32px);max-width:100%;}
  /* Toasts menores */
  #toast-container{bottom:calc(68px + env(safe-area-inset-bottom, 0px));right:12px;left:12px;}
  .toast{max-width:100%;}
  /* Config rows viram coluna em telas pequenas */
  .config-row{flex-wrap:wrap;gap:10px;}
  /* Botões de ação ocupam largura total em formulários */
  .form-actions .btn{flex:1;}
}

@media(max-width:480px){
  .auth-card{padding:24px 20px;margin:0 12px;width:calc(100% - 24px);max-width:100%;}
  .feedback-type-grid{grid-template-columns:1fr;}
  .tipo-selector{grid-template-columns:1fr;}
  .app-content{padding:10px 10px;}
  .topbar{padding:0 10px;height:52px;gap:6px;}
  .topbar-title{font-size:13px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .page-header h1{font-size:16px;margin-bottom:2px;}
  .page-header{margin-bottom:10px;}
  .grid{gap:6px;}
  .stat-card{padding:10px;}
  .card{padding:12px;}
  .stat-icon{width:34px;height:34px;font-size:16px;}
  .stat-value{font-size:20px;}
  .btn-sm{padding:5px 12px;font-size:11px;}
  .notif-btn{width:32px;height:32px;font-size:14px;}
  /* Evita overflow horizontal geral */
  body{overflow-x:hidden;}
  .screen,.main-content{max-width:100vw;overflow-x:hidden;}
  /* Botões primários full-width em contextos de formulário */
  .auth-card .btn-primary{width:100%;justify-content:center;}
  /* Modal fullscreen quase */
  .modal,.confirm-modal{width:calc(100vw - 24px);border-radius:16px;}
  /* Config rows viram coluna */
  .config-row{flex-direction:column;align-items:flex-start;gap:8px;}
  .config-row > *:last-child{align-self:stretch;}
  /* Toasts full width acima da bottom nav */
  #toast-container{bottom:calc(68px + env(safe-area-inset-bottom, 0px));right:8px;left:8px;}
  .toast{max-width:100%;min-width:0;}
}

/* ══════════════════════════════════════════════════════════
   CALENDÁRIO — MELHORIAS VISUAIS & COMPROMISSOS
══════════════════════════════════════════════════════════ */

/* Navegação do calendário */
.cal-nav { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; gap:8px; }
.cal-nav-center { flex:1; text-align:center; }
.cal-month-summary {
  font-size:11px; color:var(--accent2); font-weight:600;
  margin-top:2px; min-height:14px; letter-spacing:0.3px;
}
.cal-today-btn {
  background:var(--accent-glow); color:var(--accent2); border:1.5px solid var(--accent);
  border-radius:20px; font-size:11px; font-weight:700; padding:3px 10px;
  cursor:pointer; transition:all 0.15s; white-space:nowrap;
}
.cal-today-btn:hover { background:var(--accent); color:#fff; }

/* Legenda de categorias */
.cal-legend {
  display:flex; flex-wrap:wrap; gap:6px 14px;
  margin-bottom:10px; padding:8px 10px;
  background:var(--surface2); border-radius:var(--radius-sm);
}
.cal-legend-item { display:flex; align-items:center; gap:5px; font-size:11px; color:var(--text3); }
.cal-legend-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* Dias do calendário — indicadores */
.cal-appt-dot {
  width:6px; height:6px; border-radius:50%;
  margin-top:1px; flex-shrink:0; transition:transform 0.15s;
}
.cal-day:hover .cal-appt-dot { transform:scale(1.3); }
.cal-appt-count {
  font-size:9px; font-weight:800; color:#fff;
  background:var(--accent); border-radius:20px;
  padding:0 4px; line-height:14px; min-width:14px;
  text-align:center; margin-top:1px;
}
.cal-day.has-appt { position:relative; }

/* Destaque suave no hover do dia */
.cal-day { transition:background 0.12s, transform 0.1s; }
.cal-day:hover { transform:scale(1.04); }
.cal-day.selected { transform:scale(1.04); }

/* ── PAINEL DETALHE DO DIA ── */
.day-detail { background:var(--surface2); border-radius:var(--radius-sm); padding:14px; margin-top:12px; }
.day-detail-title { font-size:13px; font-weight:700; margin-bottom:12px; color:var(--text); }

/* Seção de compromissos */
.appt-section { }
.appt-section-header { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.appt-section-title { font-size:11.5px; font-weight:700; color:var(--text2); text-transform:uppercase; letter-spacing:0.5px; }
.appt-count-badge {
  background:var(--accent); color:#fff; font-size:10px; font-weight:700;
  border-radius:20px; padding:1px 7px; min-width:18px; text-align:center;
}
.appt-list { display:flex; flex-direction:column; gap:5px; margin-bottom:10px; }
.appt-empty { font-size:12px; color:var(--text3); padding:4px 0 6px; font-style:italic; }

/* Item de compromisso */
.appt-item {
  display:flex; align-items:center; gap:7px;
  padding:8px 10px;
  background:var(--surface3); border-radius:var(--radius-sm);
  border:1px solid var(--border); font-size:13px;
  animation:appt-in 0.18s ease;
  transition:border-color 0.15s;
}
.appt-item:hover { border-color:var(--border2); }
@keyframes appt-in { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:none; } }
.appt-cat-dot { font-size:15px; flex-shrink:0; line-height:1; }
.appt-time-badge {
  font-size:11px; font-weight:700; padding:2px 7px;
  border-radius:20px; white-space:nowrap; flex-shrink:0;
}
.appt-desc { flex:1; color:var(--text); word-break:break-word; line-height:1.3; }
.appt-edit-btn {
  background:none; border:none; color:var(--text3); font-size:13px;
  cursor:pointer; padding:2px 4px; flex-shrink:0;
  opacity:0; transition:opacity 0.15s;
}
.appt-item:hover .appt-edit-btn { opacity:1; }
.appt-remove {
  background:none; border:none; color:var(--text3);
  font-size:18px; line-height:1; cursor:pointer; padding:0 2px; flex-shrink:0;
  opacity:0; transition:color 0.15s, opacity 0.15s;
}
.appt-item:hover .appt-remove { opacity:1; }
.appt-remove:hover { color:var(--red); }

/* Edição inline */
.appt-editing {
  background:var(--surface); border-color:var(--accent);
  flex-wrap:wrap; gap:5px;
}
.appt-edit-cat, .appt-edit-time, .appt-edit-desc {
  background:var(--surface3); border:1.5px solid var(--border); border-radius:var(--radius-xs);
  color:var(--text); font-size:12px; padding:5px 8px; outline:none;
  transition:border-color 0.2s;
}
.appt-edit-cat:focus, .appt-edit-time:focus, .appt-edit-desc:focus { border-color:var(--accent); }
.appt-edit-cat { width:120px; flex-shrink:0; }
.appt-edit-time { width:95px; flex-shrink:0; }
.appt-edit-desc { flex:1; min-width:120px; }
.appt-edit-save {
  background:var(--green); color:#fff; border:none; border-radius:var(--radius-xs);
  font-size:14px; font-weight:700; padding:5px 10px; cursor:pointer; flex-shrink:0;
  transition:opacity 0.15s;
}
.appt-edit-save:hover { opacity:0.85; }

/* Formulário de adição */
.appt-form { margin-top:4px; }
.appt-form-row { display:flex; gap:6px; align-items:center; flex-wrap:wrap; }
.appt-input-cat {
  background:var(--surface3); border:1.5px solid var(--border); border-radius:var(--radius-sm);
  color:var(--text); font-size:12px; padding:7px 8px; flex-shrink:0; outline:none;
  transition:border-color 0.2s; width:130px;
}
.appt-input-cat:focus { border-color:var(--accent); }
.appt-input-time {
  background:var(--surface3); border:1.5px solid var(--border); border-radius:var(--radius-sm);
  color:var(--text); font-size:13px; padding:7px 10px; width:105px; flex-shrink:0; outline:none;
  transition:border-color 0.2s;
}
.appt-input-time:focus { border-color:var(--accent); }
.appt-input-desc {
  background:var(--surface3); border:1.5px solid var(--border); border-radius:var(--radius-sm);
  color:var(--text); font-size:13px; padding:7px 10px; flex:1; min-width:140px; outline:none;
  transition:border-color 0.2s;
}
.appt-input-desc:focus { border-color:var(--accent); }
.appt-input-desc::placeholder { color:var(--text3); }
.appt-add-btn {
  background:var(--accent); color:#fff; border:none; border-radius:var(--radius-sm);
  font-size:18px; font-weight:600; width:36px; height:36px; flex-shrink:0;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:opacity 0.15s, transform 0.1s;
}
.appt-add-btn:hover { opacity:0.85; transform:scale(1.08); }

/* ── PAINEL LATERAL — PRÓXIMOS ── */
.proximos-section-title {
  font-size:11px; font-weight:700; color:var(--text3);
  text-transform:uppercase; letter-spacing:0.5px;
  margin-bottom:8px;
}
.proximos-appt-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 10px; margin-bottom:5px;
  background:var(--surface2); border-radius:var(--radius-sm);
  border:1px solid var(--border); cursor:pointer;
  transition:border-color 0.15s, background 0.15s;
}
.proximos-appt-item:hover { border-color:var(--accent); background:var(--surface3); }
.proximos-appt-icon {
  width:32px; height:32px; border-radius:var(--radius-xs);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; flex-shrink:0;
}
.proximos-appt-body { flex:1; min-width:0; }
.proximos-appt-desc { font-size:13px; color:var(--text); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.proximos-appt-meta { display:flex; align-items:center; gap:6px; margin-top:2px; }
.proximos-appt-date { font-size:11px; color:var(--text3); }

/* ── RESPONSIVO ── */
@media(max-width:600px) {
  .cal-legend { gap:4px 10px; }
  .appt-form-row { flex-direction:column; align-items:stretch; }
  .appt-input-cat, .appt-input-time, .appt-input-desc, .appt-add-btn { width:100%; }
  .appt-add-btn { height:38px; font-size:15px; }
  .appt-edit-btn, .appt-remove { opacity:1; }
}

/* Painel fixo de adição de compromisso */
.appt-add-panel {
  margin-top:12px;
  border-top:1px solid var(--border);
  padding-top:12px;
}
.appt-add-panel-hint {
  font-size:12px; color:var(--text3); text-align:center;
  padding:8px 0; font-style:italic;
}
.appt-add-panel-form {}
.appt-add-panel-label {
  font-size:12px; font-weight:600; color:var(--accent2);
  margin-bottom:8px;
}

/* ══════════════════════════════════════════════════════════
   MOBILE — Previne zoom automático no iOS ao focar inputs
══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  input, select, textarea,
  .input-group input,
  .input-group select,
  .input-group textarea,
  .adm-field-input,
  .adm-search-input,
  .code-input {
    font-size: 16px !important;
  }
}


/* ══════════════════════════════════════════════════════════
   MOBILE — Bottom Tab Bar
══════════════════════════════════════════════════════════ */

.mobile-bottom-nav {
  display: none;
}

/* Oculta barra inferior nas telas de autenticação (login/registro) */
.mobile-bottom-nav.nav-hidden {
  display: none !important;
}
@media (max-width: 700px) {

  /* ── Show bottom bar ── */
  .mobile-bottom-nav {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 60px;
    background: var(--surface);
    border-top: 1px solid var(--border);
    z-index: 1000;
    align-items: stretch;
    padding-bottom: env(safe-area-inset-bottom, 0px);
    /* Força renderização acima de qualquer conteúdo */
    transform: translateZ(0);
    -webkit-transform: translateZ(0);
    will-change: transform;
  }

  .mob-tab {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text3);
    font-family: 'Space Grotesk', sans-serif;
    font-size: 10px;
    font-weight: 500;
    padding: 8px 4px;
    transition: color 0.15s;
    -webkit-tap-highlight-color: transparent;
    position: relative;
  }

  .mob-tab svg {
    width: 22px;
    height: 22px;
    stroke-width: 1.8;
    transition: transform 0.18s cubic-bezier(0.16, 1, 0.3, 1);
    flex-shrink: 0;
  }

  .mob-tab span {
    line-height: 1;
  }

  .mob-tab.active {
    color: var(--accent2);
  }

  .mob-tab.active svg {
    transform: translateY(-2px) scale(1.1);
    stroke-width: 2.2;
  }

  /* Indicador pontinho embaixo do ativo */
  .mob-tab.active::after {
    content: '';
    position: absolute;
    bottom: 6px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--accent2);
  }

  /* ── Layout adjustments ── */
  .hamburger { display: none !important; }
  .topbar-right .btn-ghost { display: none; }
  /* Botão sair mobile: ícone discreto ao lado do sino */
  .topbar-right .btn-logout-mobile { display: flex; }
  /* Garante que o conteúdo nunca fique atrás da bottom nav */
  .main-content {
    margin-left: 0;
    width: 100%;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
  }
  .app-content {
    padding-bottom: calc(80px + env(safe-area-inset-bottom, 0px));
  }

  /* ── Topbar limpa ── */
  .topbar { padding: 0 16px; }
  .topbar-right #free-counter { display: none; }

  /* ── Auth card ── */
  #screen-auth, #screen-admin-auth {
    padding: 20px 16px;
    align-items: flex-start;
    padding-top: 10vh;
  }
  .auth-card {
    padding: 28px 22px;
    border-radius: 20px;
    max-width: 100%;
  }

  /* ── Grids ── */
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  #page-dashboard .grid-4 { grid-template-columns: repeat(2, 1fr); }
  #page-relatorios .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .form-row { grid-template-columns: 1fr; }
  .grid { gap: 8px; }

  /* ── Cards ── */
  .card { padding: 14px 12px; }
  .stat-card { padding: 14px 12px; }
  .stat-value { font-size: 20px; }

  /* ── Lançamentos: esconde botão do header, usa + no topbar ── */
  #btn-novo-lancamento { display: none; }

  /* ── Tx items: ações sempre visíveis no mobile ── */
  .tx-actions { opacity: 1; }
  .tx-item { padding: 13px 10px; min-height: 60px; }
  .icon-btn { width: 32px; height: 32px; font-size: 14px; }

  /* ── Modais: surgem de baixo ── */
  .modal-backdrop {
    align-items: flex-end;
    padding: 0;
  }
  .modal, .confirm-modal {
    border-radius: 22px 22px 0 0;
    max-width: 100%;
    width: 100%;
    padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px));
    animation: slideUpModal 0.32s cubic-bezier(0.16, 1, 0.3, 1) both;
  }
  @keyframes slideUpModal {
    from { transform: translateY(100%); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
  }

  /* ── Toasts acima da bottom bar ── */
  #toast-container {
    bottom: calc(68px + env(safe-area-inset-bottom, 0px));
    right: 12px;
    left: 12px;
  }
  .toast { max-width: 100%; min-width: 0; }

  /* ── Agenda: coluna única ── */
  #page-agenda .grid { grid-template-columns: 1fr; }

  /* ── Feedback ── */
  .feedback-type-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .feedback-type-btn { padding: 12px 6px; font-size: 11px; }

  /* ── Config rows ── */
  .config-row { flex-wrap: wrap; gap: 10px; }

  /* ── Admin: abas horizontais ── */
  .adm-sidenav {
    width: 100% !important;
    height: auto !important;
    position: sticky !important;
    top: 58px;
    flex-direction: row !important;
    border-right: none !important;
    border-bottom: 1px solid var(--border) !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    z-index: 90;
  }
  .adm-sidenav::-webkit-scrollbar { display: none; }
  .adm-sidenav-header { display: none; }
  .adm-sidenav-nav {
    flex-direction: row !important;
    padding: 6px 8px;
    gap: 4px;
    width: 100%;
  }
  .adm-nav-item { padding: 8px 14px; white-space: nowrap; flex-shrink: 0; font-size: 12px; }
  .adm-nav-item svg { display: none; }
  .adm-nav-item span { display: inline !important; }
  .adm-nav-item.active::before { display: none; }
  .adm-nav-item.active { border-bottom: 2px solid var(--accent); }
  .adm-nav-count { display: inline; font-size: 10px; }
  .adm-layout { flex-direction: column; height: auto; }
  .adm-main { padding: 12px; height: auto; overflow-y: visible; }
  .adm-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .adm-quick-grid { grid-template-columns: repeat(2, 1fr); }
  .adm-fb-stat-row { grid-template-columns: repeat(3, 1fr); }
  .adm-tab-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .adm-tab-actions { width: 100%; }
  .adm-search-input { width: 100%; }

  /* ── Tap sem brilho azul ── */
  * { -webkit-tap-highlight-color: transparent; }
  .stat-card:active { transform: scale(0.97); }
  .tx-item:active { background: var(--surface3); }
  .mob-tab:active svg { transform: scale(0.92); }

  /* ── Overflow global ── */
  body { overflow-x: hidden; }
  .screen, .main-content { max-width: 100vw; overflow-x: hidden; }

  /* ── Botão + no topbar para lançamentos ── */
  .topbar-add-btn {
    display: flex;
    width: 34px; height: 34px;
    align-items: center; justify-content: center;
    background: linear-gradient(135deg, #7c3aed, #06b6d4);
    border: none; border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 3px 12px rgba(124,58,237,0.4);
    transition: transform 0.15s;
    flex-shrink: 0;
  }
  .topbar-add-btn:active { transform: scale(0.9); }
  .topbar-add-btn svg { width: 18px; height: 18px; stroke: #fff; stroke-width: 2.5; }
}

@media (max-width: 380px) {
  .mob-tab span { display: none; }
  .mob-tab { padding: 12px 4px; }
  .mob-tab.active::after { bottom: 4px; }
  .auth-card { padding: 22px 16px; }
}

/* ── STAT CARD BLUE (Saldo Futuro) ── */
.stat-card.blue::before{background:linear-gradient(90deg,var(--cyan),transparent);}

/* ── TOOLTIP RELATÓRIO ── */
.rel-tooltip-wrap{position:relative;display:inline-flex;align-items:center;cursor:help;z-index:10;}
.rel-tooltip-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--cyan);color:#fff;font-size:10px;font-weight:700;line-height:1;flex-shrink:0;transition:background 0.2s;}
.rel-tooltip-wrap:hover .rel-tooltip-badge{background:var(--accent);}
.rel-tooltip-icon{color:var(--text3);flex-shrink:0;transition:color 0.2s;}
.rel-tooltip-wrap:hover .rel-tooltip-icon{color:var(--cyan);}
.rel-tooltip-box{
  position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--surface3);border:1px solid var(--border2);border-radius:var(--radius-sm);
  padding:9px 12px;font-size:11.5px;line-height:1.5;color:var(--text2);
  white-space:normal;width:220px;z-index:999;pointer-events:none;
  opacity:0;transition:opacity 0.18s;box-shadow:0 6px 20px rgba(0,0,0,0.35);
  font-weight:400;text-transform:none;letter-spacing:0;
}
.rel-tooltip-box::after{
  content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--surface3);
}
.rel-tooltip-wrap:hover .rel-tooltip-box{opacity:1;}

/* ── CHART WRAPPER TALLER FOR REPORTS ── */
#page-relatorios .chart-wrapper{height:260px;}

/* ══════════════════════════════════════════════════════════
   FAB — Botão flutuante mobile (Novo Lançamento)
══════════════════════════════════════════════════════════ */

.mob-fab {
  display: none !important; /* escondido por padrão; só aparece no mobile via media query */
}

@media (max-width: 700px) {
  /* No mobile, permite mostrar (a menos que nav-hidden esteja presente) */
  .mob-fab {
    display: flex !important;
    align-items: center;
    justify-content: center;
    position: fixed;
    right: 18px;
    bottom: calc(60px + 16px + env(safe-area-inset-bottom, 0px));
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent), var(--accent2));
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(124, 92, 252, 0.5);
    z-index: 990;
    transition: transform 0.18s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.18s;
    -webkit-tap-highlight-color: transparent;
  }

  .mob-fab svg {
    width: 26px;
    height: 26px;
    stroke: #fff;
    flex-shrink: 0;
  }

  .mob-fab:active {
    transform: scale(0.92);
    box-shadow: 0 2px 10px rgba(124, 92, 252, 0.4);
  }

  /* Escondido nas telas de auth (reutiliza classe nav-hidden) */
  .mob-fab.nav-hidden {
    display: none !important;
  }

  /* Drag handle do modal mobile */
  .mob-modal-drag-handle {
    width: 36px;
    height: 4px;
    background: var(--border2);
    border-radius: 2px;
    margin: -8px auto 16px;
  }

  /* Botão de exportar CSV visível no mobile dentro da página */
  #page-relatorios .page-header .btn-ghost {
    display: flex !important;
  }

  /* Agenda: formulário de novo compromisso em coluna */
  .appt-add-panel-form .appt-form-row {
    flex-direction: column;
    gap: 8px;
  }

  .appt-input-desc {
    width: 100%;
    min-width: 0;
  }

  .appt-add-btn {
    width: 100%;
  }

  /* Página de configurações: seções com espaçamento adequado */
  .config-section-title {
    font-size: 12px;
  }

  /* ── Page header com flex (Lançamentos / Relatórios) ── */
  .page-header .flex.items-center.justify-between {
    flex-wrap: wrap;
    gap: 8px;
  }

  /* ── view-as-overlay no mobile ── */
  .view-as-overlay {
    padding: 6px 12px;
    font-size: 11px;
    flex-wrap: wrap;
    gap: 6px;
  }
  .view-as-overlay strong { font-size: 11px; }

  /* ── readonly-banner no mobile ── */
  .readonly-banner {
    font-size: 11px;
    padding: 8px 12px;
    margin-bottom: 12px;
  }

  /* ── notif-dropdown: fullwidth no mobile ── */
  .notif-dropdown {
    right: 8px;
    left: 8px;
    width: auto;
  }

  /* ── admin-bar: texto truncado ── */
  #admin-logged-as {
    display: none;
  }

  /* ── adm-quick-grid: 2 colunas no mobile ── */
  .adm-quick-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* ── Filtro de período no relatório: wrap correto ── */
  #rp-custom-range {
    width: 100%;
    flex-wrap: wrap;
  }
  #rp-from, #rp-to {
    flex: 1;
    min-width: 120px;
  }

  /* ── Lançamentos: form-row garante 1 coluna ── */
  .form-row {
    grid-template-columns: 1fr !important;
  }

  /* ── Modal de lançamento mobile: drag handle visível ── */
  .mob-modal-drag-handle {
    display: block;
  }

  /* ── Topbar: botão "Sair" oculto — já está na bottom nav via perfil ── */
  /* (já coberto por .topbar-right .btn-ghost { display: none; }) */

  /* ── Agenda: formulário de edição inline em coluna no mobile ── */
  .appt-editing {
    flex-direction: column;
  }
  .appt-edit-cat, .appt-edit-time, .appt-edit-desc {
    width: 100%;
  }

  /* ── Upgrade banner: quebra em coluna ── */
  .upgrade-banner {
    flex-direction: column;
    align-items: flex-start;
  }

  /* ── Page header relatórios: alinha botão CSV corretamente ── */
  #page-relatorios .page-header > div {
    flex-wrap: wrap;
    gap: 8px;
  }

  /* ── Stat card blue (saldo futuro) ── */
  .stat-card.blue::before { background: linear-gradient(90deg, var(--cyan), transparent); }
}

/* ═══════════════════════════════════════════
   CORREÇÕES ADICIONAIS MOBILE (max-width: 480px)
═══════════════════════════════════════════ */
@media (max-width: 480px) {

  /* ── Auth card: margem lateral ── */
  .auth-logo-wrap {
    gap: 10px;
    margin-bottom: 24px;
  }
  .auth-logo-img {
    height: 72px;
  }

  /* ── Code inputs (2FA): ajuste para caber em tela estreita ── */
  .code-inputs {
    gap: 5px;
  }
  .code-input {
    width: 34px;
    height: 42px;
    font-size: 15px;
  }

  /* ── Admin sidenav horizontal: ícones menores ── */
  .adm-nav-item {
    padding: 7px 10px;
    font-size: 11px;
  }

  /* ── adm-fb-stat-row: 2 colunas em 480px ── */
  .adm-fb-stat-row {
    grid-template-columns: repeat(2, 1fr);
  }

  /* ── Filtros de feedback: empilha em coluna ── */
  .adm-fb-filter-bar {
    flex-direction: column;
    gap: 10px;
  }

  /* ── Tabela admin: mínimo de colunas visíveis ── */
  .admin-table th:nth-child(4),
  .admin-table td:nth-child(4) {
    display: none;
  }

  /* ── Modal de confirmação: footer em coluna ── */
  .confirm-modal .modal-footer {
    flex-direction: column;
    gap: 8px;
  }
  .confirm-modal .modal-footer .btn {
    width: 100%;
    justify-content: center;
  }

  /* ── Tipo selector no modal mobile: 2 colunas mantidas ── */
  #modal-mob-lancamento-inner .tipo-selector {
    grid-template-columns: 1fr 1fr;
  }

  /* ── Form row dentro de modal mobile: 1 coluna ── */
  #modal-mob-lancamento-inner .form-row {
    grid-template-columns: 1fr;
  }

  /* ── Relative tooltip: posiciona à esquerda em telas estreitas ── */
  .rel-tooltip-box {
    left: auto;
    right: 0;
    transform: none;
    width: 180px;
  }
  .rel-tooltip-box::after {
    left: auto;
    right: 12px;
    transform: none;
  }

  /* ── Insight banner: compacto ── */
  .insight-banner {
    padding: 10px 12px;
  }

  /* ── Charts de relatório: altura mínima para caber gráfico + legenda ── */
  #page-relatorios .chart-wrapper { height: 200px; }
}

/* ═══════════════════════════════════════════
   CORREÇÃO: closeSidebar — pointer-events
═══════════════════════════════════════════ */
.sidebar-overlay {
  pointer-events: none;
}
.sidebar-overlay.active {
  display: block;
  pointer-events: auto;
}

/* ═══════════════════════════════════════════
   MOBILE SAFE AREA — PWA / iPhone notch
═══════════════════════════════════════════ */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  @media (max-width: 700px) {
    .mobile-bottom-nav {
      height: calc(60px + env(safe-area-inset-bottom, 0px));
      padding-bottom: env(safe-area-inset-bottom, 0px);
    }
    .app-content {
      padding-bottom: calc(80px + env(safe-area-inset-bottom, 0px));
    }
    #toast-container {
      bottom: calc(72px + env(safe-area-inset-bottom, 0px));
    }
    /* FAB reposicionado considerando altura real do nav */
    .mob-fab {
      bottom: calc(60px + env(safe-area-inset-bottom, 0px) + 16px);
    }
  }
}

/* ═══════════════════════════════════════════
   ETAPA 1 — Auth: recuperação de senha & confirmação de e-mail
═══════════════════════════════════════════ */

/* Tela de esqueci senha / redefinir / confirmar e-mail reutilizam .auth-card */
/* Animação de entrada suave para as novas sub-telas */
#auth-forgot,
#auth-reset,
#auth-confirm-email {
  animation: cardIn 0.3s cubic-bezier(0.16,1,0.3,1) both;
}

/* Link "Esqueci minha senha" — tap area confortável no mobile */
#auth-login > div:last-child span {
  display: inline-block;
  padding: 4px 0;
  min-height: 32px;
  line-height: 32px;
}

/* Ícone grande nas telas de confirmação */
#auth-forgot .auth-big-icon,
#auth-confirm-email .auth-big-icon {
  font-size: 44px;
  margin-bottom: 12px;
  display: block;
}

/* Caixa de aviso de spam */
.auth-info-box {
  background: var(--surface2);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--text3);
  line-height: 1.6;
  margin-bottom: 16px;
}

/* Campos de senha no reset — garante padding-right para o olhinho */
#reset-pass,
#reset-pass-confirm {
  padding-right: 44px;
}

/* Fortaleza da senha (futuro) */
.pass-strength-bar {
  height: 3px;
  border-radius: 2px;
  margin-top: 6px;
  background: var(--border2);
  overflow: hidden;
  transition: all 0.2s;
}
.pass-strength-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.3s, background 0.3s;
}
.pass-strength-fill.weak   { width: 33%; background: var(--red); }
.pass-strength-fill.medium { width: 66%; background: var(--yellow); }
.pass-strength-fill.strong { width: 100%; background: var(--green); }

@media (max-width: 700px) {
  #auth-forgot,
  #auth-reset,
  #auth-confirm-email {
    padding-top: 4px;
  }
}

@media (max-width: 480px) {
  /* Ícone menor em telas muito pequenas */
  #auth-confirm-email > div > div:first-child,
  #auth-forgot > div > div:first-child {
    font-size: 36px;
    margin-bottom: 10px;
  }
}

/* ═══════════════════════════════════════════
   ETAPA 2 — Paginação de lançamentos (B3)
═══════════════════════════════════════════ */

/* ── Filtro de Período ── */
.filter-period-bar {
  margin-bottom: 12px;
}
.filter-period-btns {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.filter-period-btns .btn.active {
  background: var(--accent-glow);
  border-color: var(--accent);
  color: var(--accent2);
  font-weight: 700;
}
#filter-period-custom-row {
  display: none;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}
#filter-period-custom-row input[type="date"] {
  padding: 5px 10px;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  background: var(--surface2);
  color: var(--text1);
  font-size: 13px;
  font-family: inherit;
}
#filter-period-custom-row input[type="date"]:focus {
  outline: none;
  border-color: var(--purple);
}

/* ── Paginação ── */
.tx-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px 4px 4px;
  margin-top: 4px;
  border-top: 1px solid var(--border);
}
.tx-pag-left {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.tx-pag-right {
  display: flex;
  align-items: center;
  gap: 4px;
}
.tx-pag-size-label {
  font-size: 12px;
  color: var(--text3);
  white-space: nowrap;
}
.tx-pag-size-select {
  padding: 4px 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface2);
  color: var(--text2);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: border-color 0.15s;
}
.tx-pag-size-select:focus {
  outline: none;
  border-color: var(--purple);
}

.tx-pag-btn {
  width: 32px; height: 32px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--text2);
  font-size: 16px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
  flex-shrink: 0;
  font-family: inherit;
}
.tx-pag-btn:hover:not(:disabled) {
  background: var(--surface3);
  border-color: var(--border2);
  color: var(--text);
}
.tx-pag-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.tx-pag-btn:active:not(:disabled) {
  transform: scale(0.94);
}
.tx-pag-pages {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  padding: 0 6px;
  white-space: nowrap;
}
.tx-pag-total {
  font-size: 11px;
  color: var(--text3);
  white-space: nowrap;
}

.tx-pagination-simple {
  padding: 10px 4px 2px;
  font-size: 12px;
  color: var(--text3);
  text-align: center;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}

@media (max-width: 700px) {
  .tx-pagination { padding: 12px 2px 2px; flex-direction: column; align-items: flex-start; }
  .tx-pag-btn { width: 38px; height: 38px; font-size: 18px; }
  .tx-pag-pages { font-size: 12px; }
  .tx-pag-total { font-size: 10px; }
  .filter-period-btns { gap: 4px; }
  .filter-period-btns .btn { font-size: 12px; padding: 5px 10px; }
}

/* ═══════════════════════════════════════════
   ETAPA 2 — FAB em todas as páginas (B1)
   Tooltip contextual no FAB
═══════════════════════════════════════════ */

/* FAB tooltip — aparece acima do botão */
.mob-fab::before {
  content: attr(aria-label);
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  background: var(--surface3);
  color: var(--text);
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  padding: 5px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border2);
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.18s, transform 0.18s;
}

/* Mostra tooltip ao segurar (long-press via :active em mobile ou hover desktop) */
@media (hover: hover) {
  .mob-fab:hover::before {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ═══════════════════════════════════════════
   ETAPA 3 — C2: Widget de Saldo
═══════════════════════════════════════════ */

.saldo-widget {
  border-radius: var(--radius);
  padding: 22px 24px 18px;
  margin-bottom: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  position: relative;
  overflow: hidden;
  transition: border-color 0.3s, box-shadow 0.3s;
}

/* Barra de cor no topo — muda conforme o estado */
.saldo-widget::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 3px 3px 0 0;
  background: var(--border2);
  transition: background 0.4s;
}
.saldo-widget.saldo-positivo::before { background: linear-gradient(90deg, var(--green), transparent); }
.saldo-widget.saldo-negativo::before { background: linear-gradient(90deg, var(--red), transparent); }
.saldo-widget.saldo-neutro::before   { background: linear-gradient(90deg, var(--accent), transparent); }

.saldo-widget.saldo-positivo { border-color: rgba(16,185,129,0.25); }
.saldo-widget.saldo-negativo { border-color: rgba(244,63,94,0.25); }

.saldo-widget-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text3);
  margin-bottom: 4px;
}

.saldo-widget-value {
  font-family: 'Outfit', sans-serif;
  font-size: 42px;
  font-weight: 700;
  letter-spacing: -2px;
  line-height: 1;
  margin-bottom: 4px;
  transition: color 0.3s;
  color: var(--text);
}
.saldo-widget.saldo-positivo .saldo-widget-value { color: var(--green); }
.saldo-widget.saldo-negativo .saldo-widget-value { color: var(--red); }

.saldo-widget-sub {
  font-size: 12px;
  color: var(--text3);
  margin-bottom: 16px;
}

.saldo-widget-bars {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--surface2);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  border: 1px solid var(--border);
}

.saldo-bar-item {
  display: flex;
  align-items: center;
  gap: 7px;
  flex: 1;
}

.saldo-bar-divider {
  width: 1px;
  height: 28px;
  background: var(--border);
  margin: 0 14px;
  flex-shrink: 0;
}

.saldo-bar-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.saldo-bar-dot.entrada { background: var(--green); }
.saldo-bar-dot.saida   { background: var(--red); }

.saldo-bar-lbl {
  font-size: 11px;
  color: var(--text3);
  font-weight: 500;
}

.saldo-bar-val {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin-left: auto;
}

@media (max-width: 700px) {
  .saldo-widget { padding: 18px 16px 14px; margin-bottom: 12px; }
  .saldo-widget-value { font-size: 34px; letter-spacing: -1.5px; }
  .saldo-widget-sub { font-size: 11px; margin-bottom: 12px; }
  .saldo-widget-bars { padding: 8px 12px; }
  .saldo-bar-lbl { font-size: 10px; }
  .saldo-bar-val { font-size: 12px; }
  .saldo-bar-divider { margin: 0 10px; }
}

@media (max-width: 480px) {
  .saldo-widget { padding: 14px 14px 12px; }
  .saldo-widget-value { font-size: 28px; letter-spacing: -1px; }
  .saldo-widget-sub { margin-bottom: 10px; }
  .saldo-bar-val { font-size: 11px; }
}

/* ═══════════════════════════════════════════
   ETAPA 3 — C3: Empty states dos gráficos
═══════════════════════════════════════════ */

/* O wrapper do gráfico precisa de position:relative para o overlay */
.chart-wrapper { position: relative; }

.chart-empty-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  pointer-events: none;
  z-index: 2;
  padding: 16px;
}

/* Apenas o botão dentro do overlay é clicável */
.chart-empty-overlay button { pointer-events: auto; }

.chart-empty-icon {
  font-size: 28px;
  opacity: 0.5;
}

.chart-empty-msg {
  font-size: 12px;
  color: var(--text3);
  text-align: center;
  font-weight: 500;
  max-width: 180px;
  line-height: 1.4;
}

@media (max-width: 700px) {
  .chart-empty-icon  { font-size: 22px; }
  .chart-empty-msg   { font-size: 11px; }
}

/* ── Recorrência ───────────────────────────────────────── */
.recorr-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  background: var(--surface2);
  color: var(--text2);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
  white-space: nowrap;
}
.recorr-btn:hover { border-color: var(--purple); color: var(--purple); }
.recorr-btn.active {
  border-color: var(--purple);
  background: rgba(124,92,252,0.12);
  color: var(--purple);
  font-weight: 700;
}
.badge-recorr {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 5px;
  background: rgba(124,92,252,0.13);
  color: var(--purple);
  font-weight: 600;
  white-space: nowrap;
}

/* ── Forma de pagamento ─────────────────────────────────── */
.forma-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 11px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  background: var(--surface2);
  color: var(--text2);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
  white-space: nowrap;
}
.forma-btn:hover { border-color: var(--cyan); color: var(--cyan); }
.forma-btn.active {
  border-color: var(--cyan);
  background: rgba(6,182,212,0.12);
  color: var(--cyan);
  font-weight: 700;
}
.badge-forma {
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 5px;
  background: rgba(6,182,212,0.12);
  color: var(--cyan);
  font-weight: 600;
  white-space: nowrap;
}

/* ══════════════════════════════════════════════════════════
   ONBOARDING
══════════════════════════════════════════════════════════ */
.onboard-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
  transition: background 0.2s, transform 0.2s;
}
.onboard-dot.active {
  background: var(--accent);
  transform: scale(1.3);
}
.onboard-step {
  animation: onboardIn 0.25s cubic-bezier(0.16,1,0.3,1);
}
@keyframes onboardIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════════════════════════════
   METAS FINANCEIRAS
══════════════════════════════════════════════════════════ */
.goals-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.goals-pro-teaser {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  padding: 4px 0;
  transition: opacity 0.15s;
}
.goals-pro-teaser:hover { opacity: 0.8; }

.goals-empty {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  padding: 8px 0;
  color: var(--text2);
}
.goal-row { margin-bottom: 14px; }
.goal-row:last-child { margin-bottom: 0; }
.goal-row-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.goal-cat {
  font-size: 13px;
  font-weight: 600;
  color: var(--text1);
}
.goal-values {
  font-size: 12px;
  font-weight: 700;
  color: var(--green);
}
.goal-values.over { color: var(--red); }
.goal-bar-track {
  height: 7px;
  background: var(--surface2);
  border-radius: 99px;
  overflow: hidden;
}
.goal-bar-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.5s cubic-bezier(0.16,1,0.3,1);
}
.goal-over-msg {
  font-size: 11px;
  color: var(--red);
  margin-top: 4px;
  font-weight: 600;
}
.goal-edit-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.goal-edit-row:last-child { border-bottom: none; }
.goal-edit-label {
  font-size: 13px;
  color: var(--text1);
  font-weight: 500;
}

/* ══════════════════════════════════════════════════════════
   IMPORTAR CSV
══════════════════════════════════════════════════════════ */
.import-dropzone {
  border: 2px dashed var(--border);
  border-radius: var(--radius);
  padding: 32px 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  background: var(--surface2);
}
.import-dropzone:hover,
.import-dropzone.drag {
  border-color: var(--accent);
  background: rgba(124,92,252,0.06);
}

/* ══════════════════════════════════════════════════════════
   PRIVACY MODE — Ocultar valores (R$)
══════════════════════════════════════════════════════════ */
.btn-eye {
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text3);
  cursor: pointer;
  padding: 6px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  flex-shrink: 0;
}
.btn-eye:hover  { color: var(--text); border-color: var(--border2); }
.btn-eye.active { color: var(--accent2); border-color: var(--accent2); background: var(--accent-glow); }

/* Oculta só os valores das páginas com privacy ativo */
#page-dashboard.privacy-on  .stat-value,
#page-dashboard.privacy-on  #recent-list .tx-valor,
#page-dashboard.privacy-on  #pending-list .tx-valor { filter: blur(8px); user-select: none; pointer-events: none; transition: filter 0.25s; }

/* Oculta o banner de situação financeira (positivo/negativo) quando privacy está ativo */
#page-dashboard.privacy-on  #dash-insight .insight-text p { filter: blur(8px); user-select: none; pointer-events: none; transition: filter 0.25s; }

#page-lancamentos.privacy-on .tx-valor { filter: blur(8px); user-select: none; pointer-events: none; transition: filter 0.25s; }

#page-relatorios.privacy-on  .stat-value,
#page-relatorios.privacy-on  .tx-valor  { filter: blur(8px); user-select: none; pointer-events: none; transition: filter 0.25s; }

/* Transição suave ao revelar */
.stat-value, .tx-valor, #dash-insight .insight-text p { transition: filter 0.25s; }
