
/* ══════════════════════════════════════════════════════════════
   FINCONTROL · MASTERPIECE EDITION (V79 Visual Parity with V70)
   Single-pass, clean architecture, premium design
   ══════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ── */
:root{
  --bg:#04060B; --bg2:#07090F; --surface:#0C111B;
  --card:#101724; --card2:#161F33; --card3:#1D2842;

  --border:rgba(255,255,255,.06); --border2:rgba(255,255,255,.10); --border3:rgba(255,255,255,.14);

  --gold:#D9AC44; --gold-light:#F2CD68; --gold-dark:#9F7A20;
  --gold-dim:rgba(217,172,68,.10); --gold-border:rgba(217,172,68,.22);

  --income:#2FD8A0; --income-light:#4FE8B5;
  --income-dim:rgba(47,216,160,.09); --income-border:rgba(47,216,160,.22);

  --expense:#F4708B; --expense-light:#FF8FA8;
  --expense-dim:rgba(244,112,139,.09); --expense-border:rgba(244,112,139,.22);

  --purple:#A78BFA; --purple-light:#C4B0FC;
  --purple-dim:rgba(167,139,250,.10);

  --text:#EFF2FF; --text2:#8B95B5; --text3:#5A6585;

  --radius:20px; --radius-sm:14px; --radius-xs:10px;
  --nav-h:74px; --header-h:60px;

  --shadow-1:0 1px 3px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.025);
  --shadow-2:0 4px 14px rgba(0,0,0,.5),0 1px 3px rgba(0,0,0,.3);
  --shadow-3:0 10px 32px rgba(0,0,0,.6),0 3px 10px rgba(0,0,0,.35);
  --shadow-4:0 24px 70px rgba(0,0,0,.75);
  --glow-gold:0 0 24px rgba(217,172,68,.12),0 0 0 1px rgba(217,172,68,.14);
}

/* ── RESET ── */
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;height:100%;font-family:'Outfit',-apple-system,sans-serif;font-size:14px;color:var(--text);background:var(--bg);overflow-x:hidden}
button,input,select,textarea{font-family:inherit;color:inherit}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}
.numeric{font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1,"lnum" 1}

/* ── LAYOUT ── */
#app{position:relative;min-height:100vh;background:var(--bg);overflow:hidden}
#app::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 90% 55% at 50% -8%,rgba(167,139,250,.08) 0%,transparent 60%),
    radial-gradient(ellipse 80% 50% at 100% 105%,rgba(217,172,68,.06) 0%,transparent 55%);
}
#app::after{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.32;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' 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.4'/%3E%3C/svg%3E");
  background-size:180px;
}

#header{
  position:sticky;top:0;height:var(--header-h);z-index:50;
  background:rgba(4,6,11,.85);backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  border-bottom:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 18px;padding-top:env(safe-area-inset-top,0)
}
#header::after{content:'';position:absolute;inset:auto 0 -1px 0;height:1px;background:linear-gradient(90deg,transparent,rgba(217,172,68,.4) 30%,rgba(217,172,68,.4) 70%,transparent)}
.brand{
  font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;letter-spacing:2.5px;
  background:linear-gradient(120deg,#F2CD68,#D9AC44 50%,#9F7A20);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 0 10px rgba(217,172,68,.25))
}
.month-pill{
  display:flex;align-items:center;gap:8px;background:var(--card2);
  border:1px solid var(--border2);border-radius:30px;padding:6px 12px;
  font-size:12px;font-weight:700;color:var(--text2);transition:all .2s
}
.month-pill:active{transform:scale(.96)}
.month-pill .arrow{padding:0 4px;color:var(--gold)}

#main{position:relative;z-index:1;padding:14px 14px calc(var(--nav-h) + 14px + env(safe-area-inset-bottom,0))}
.screen{display:none;animation:fcIn .32s cubic-bezier(.16,1,.3,1)}
.screen.active{display:block}
@keyframes fcIn{from{opacity:0;transform:translateY(10px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── BOTTOM NAV ── */
#nav{
  position:fixed;left:0;right:0;bottom:0;height:calc(var(--nav-h) + env(safe-area-inset-bottom,0));
  padding-bottom:env(safe-area-inset-bottom,0);z-index:50;
  background:rgba(4,6,11,.92);backdrop-filter:blur(40px) saturate(220%);
  -webkit-backdrop-filter:blur(40px) saturate(220%);
  border-top:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;justify-content:space-around;
  box-shadow:0 -12px 40px rgba(0,0,0,.5)
}
.nav-btn{
  position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:9px 2px 7px;border-radius:14px;color:var(--text3);
  transition:all .2s cubic-bezier(.4,0,.2,1);flex:1
}
.nav-btn:active{transform:scale(.92)}
.nav-icon{font-size:21px;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.nav-label{font-size:8px;font-weight:800;letter-spacing:.4px;text-transform:uppercase}
.nav-btn.active{color:var(--gold-light)}
.nav-btn.active .nav-icon{transform:translateY(-3px) scale(1.12);filter:drop-shadow(0 0 8px rgba(217,172,68,.5))}
.nav-btn.active::after{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:28px;height:3px;border-radius:0 0 4px 4px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  box-shadow:0 0 12px rgba(217,172,68,.7)
}

/* ── HERO SALDO ── */
.saldo-card{
  background:
    radial-gradient(ellipse 60% 80% at 0% 0%,rgba(217,172,68,.06),transparent 60%),
    linear-gradient(165deg,rgba(22,31,51,.98),rgba(15,22,35,.99));
  border:1px solid rgba(217,172,68,.18);border-radius:24px;padding:22px;
  box-shadow:var(--glow-gold),var(--shadow-3);position:relative;overflow:hidden;margin-bottom:14px
}
.saldo-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 10%,rgba(217,172,68,.5) 50%,transparent 90%)
}
.saldo-label{font-size:11px;font-weight:800;letter-spacing:1.4px;color:var(--text3);text-transform:uppercase;margin-bottom:6px}
.saldo-value{font-size:36px;font-weight:900;letter-spacing:-1.8px;line-height:1;font-family:'JetBrains Mono',monospace}
.saldo-value.positive{background:linear-gradient(135deg,#4FE8B5,#2FD8A0 50%,#1FAA80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 8px rgba(47,216,160,.3))}
.saldo-value.negative{background:linear-gradient(135deg,#FF8FA8,#F4708B 50%,#C8405A);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.saldo-meta{display:flex;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.05)}
.saldo-meta-item{font-size:10px;font-weight:700;color:var(--text3);letter-spacing:.6px}
.saldo-meta-item strong{display:block;font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:800;margin-top:3px;letter-spacing:-.2px}

/* ── STAT CARDS ── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.stat-card{
  position:relative;background:linear-gradient(155deg,var(--card),var(--card2));
  border:1px solid var(--border2);border-radius:18px;padding:14px;
  box-shadow:var(--shadow-2);cursor:pointer;overflow:hidden;
  transition:all .2s cubic-bezier(.4,0,.2,1)
}
.stat-card::after{content:'';position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)}
.stat-card:active{transform:scale(.98)}
.stat-card.income{border-color:rgba(47,216,160,.18)}
.stat-card.expense{border-color:rgba(244,112,139,.15)}
.stat-card.active{box-shadow:var(--glow-gold),var(--shadow-2);transform:scale(1.025);border-color:var(--gold)}
.stat-icon{font-size:22px;margin-bottom:6px}
.stat-label{font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text3);margin-bottom:4px}
.stat-value{font-size:18px;font-weight:800;letter-spacing:-.3px;font-family:'JetBrains Mono',monospace}
.stat-card.income .stat-value{color:var(--income)}
.stat-card.expense .stat-value{color:var(--expense)}

/* ── CARD-LIKE BLOCKS (acordeons) ── */
.block{
  background:linear-gradient(155deg,var(--card),var(--card2));
  border:1px solid var(--border2);border-radius:18px;
  box-shadow:var(--shadow-2);margin-bottom:9px;overflow:hidden
}
.block-head{
  padding:14px 15px;display:flex;align-items:center;gap:12px;cursor:pointer;
  transition:all .15s
}
.block-head:active{background:rgba(255,255,255,.025)}
.block-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0;box-shadow:0 0 14px currentColor}
.block-info{flex:1;min-width:0}
.block-name{font-size:14.5px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.block-meta{font-size:11px;color:var(--text3);margin-top:2px;font-weight:600}
.block-meta strong{color:var(--gold-light);font-family:'JetBrains Mono',monospace;font-weight:900;font-size:13px;letter-spacing:-.2px}
.block-chev{font-size:11px;color:var(--text3);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.block.open .block-chev{transform:rotate(180deg)}
.block-body{display:none;padding:0 12px 12px;animation:fcExpand .25s cubic-bezier(.16,1,.3,1)}
.block.open .block-body{display:block}
@keyframes fcExpand{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* ── SUB-ITEM (transação dentro de bloco) ── */
.sub-item{
  background:rgba(255,255,255,.018);border:1px solid var(--border);
  border-radius:13px;padding:11px 12px;margin-bottom:6px;
  display:flex;align-items:center;gap:10px;transition:all .15s;cursor:pointer
}
.sub-item:active{background:rgba(255,255,255,.05);transform:scale(.985);border-color:var(--gold-border)}
.sub-item-info{flex:1;min-width:0}
.sub-item-desc{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-item-meta{font-size:10px;color:var(--text3);margin-top:2px;font-weight:500}
.sub-item-amt{font-family:'JetBrains Mono',monospace;font-weight:900;font-size:13px;letter-spacing:-.3px;white-space:nowrap}
.sub-item-amt.pos{color:var(--income)}
.sub-item-amt.neg{color:var(--expense)}
.sub-item-actions{display:flex;gap:5px;flex-shrink:0}
.sub-item-btn{
  background:var(--card3);border:1px solid var(--border);border-radius:8px;
  padding:4px 7px;font-size:11px;font-weight:700;color:var(--text2);cursor:pointer;transition:all .15s
}
.sub-item-btn:active{transform:scale(.92)}
.sub-item-btn.confirmed{background:var(--income-dim);border-color:var(--income-border);color:var(--income)}

/* ── FORMS ── */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--text3);margin-bottom:7px}
.form-input,.form-select{
  width:100%;background:rgba(15,22,35,.85);border:1.5px solid var(--border2);
  border-radius:14px;padding:13px 15px;color:var(--text);font-size:15px;font-weight:500;
  box-shadow:inset 0 2px 4px rgba(0,0,0,.3);transition:all .2s;outline:none
}
.form-input::placeholder{color:var(--text3)}
.form-input:focus,.form-select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim),inset 0 2px 4px rgba(0,0,0,.25)}
.form-input.numeric-readonly{cursor:pointer;background:rgba(15,22,35,.7)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:14px 18px;border-radius:14px;font-size:14px;font-weight:800;letter-spacing:.3px;
  cursor:pointer;transition:all .18s cubic-bezier(.4,0,.2,1);width:100%;position:relative;overflow:hidden
}
.btn:active{transform:scale(.97)}
.btn::after{content:'';position:absolute;inset:0 0 auto 0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.15),transparent);pointer-events:none;opacity:.7}
.btn-primary{background:linear-gradient(135deg,#B88420,#E8B84A 35%,#F2CD68 50%,#D9AC44 70%,#9F7A20);color:#0A0500;box-shadow:0 6px 24px rgba(217,172,68,.32),inset 0 1px 0 rgba(255,255,255,.3)}
.btn-blue{background:linear-gradient(135deg,#2A4FBF,#6080F0 50%,#4F6FCC);color:#fff;box-shadow:0 6px 24px rgba(96,128,240,.30),inset 0 1px 0 rgba(255,255,255,.2)}
.btn-orange{background:linear-gradient(135deg,#B86018,#E89030 50%,#C07520);color:#fff;box-shadow:0 6px 24px rgba(232,144,48,.28),inset 0 1px 0 rgba(255,255,255,.2)}
.btn-green{background:linear-gradient(135deg,#0E7858,#2FD8A0 50%,#229078);color:#fff;box-shadow:0 6px 24px rgba(47,216,160,.28),inset 0 1px 0 rgba(255,255,255,.25)}
.btn-pink{background:linear-gradient(135deg,#7E1240,#E04880 50%,#A02858);color:#fff;box-shadow:0 6px 24px rgba(224,72,128,.28),inset 0 1px 0 rgba(255,255,255,.22)}
.btn-purple{background:linear-gradient(135deg,#6644BB,#A78BFA 50%,#7B5EE0);color:#fff;box-shadow:0 6px 24px rgba(167,139,250,.30),inset 0 1px 0 rgba(255,255,255,.2)}
.btn-ghost{background:linear-gradient(155deg,var(--card2),var(--card));border:1px solid var(--border2);color:var(--text);box-shadow:var(--shadow-1)}
.btn-ghost:active{background:var(--card3)}
.btn-danger{background:var(--expense-dim);border:1px solid var(--expense-border);color:var(--expense)}

/* ── CHIPS ── */
.chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.chip{
  padding:7px 14px;border-radius:30px;font-size:12px;font-weight:700;
  border:1.5px solid var(--border2);background:rgba(15,22,35,.6);color:var(--text2);
  transition:all .15s;cursor:pointer;letter-spacing:.1px
}
.chip:active{transform:scale(.95)}
.chip.active{
  background:linear-gradient(135deg,rgba(217,172,68,.22),rgba(217,172,68,.10));
  border-color:var(--gold);color:var(--gold-light);
  box-shadow:0 0 14px rgba(217,172,68,.18)
}

/* ── SECTION ── */
.section-title{font-size:11px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--text3);margin:20px 0 10px;padding:0 4px}

/* ── TYPE TABS (lançar) ── */
.type-tabs{
  display:flex;background:rgba(15,22,35,.85);border:1px solid var(--border2);
  border-radius:16px;padding:4px;margin-bottom:14px;
  box-shadow:inset 0 1px 3px rgba(0,0,0,.3)
}
.type-tab{
  flex:1;padding:11px 4px;border-radius:12px;font-size:11.5px;font-weight:800;
  color:var(--text2);text-align:center;transition:all .18s;letter-spacing:.3px
}
.type-tab.active{background:linear-gradient(155deg,var(--card3),var(--card2));color:var(--gold-light);box-shadow:0 2px 10px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05)}

/* ── TAGS (Mobills style) ── */
.tag-card{
  background:linear-gradient(155deg,var(--card),var(--card2));
  border:1px solid var(--border2);border-radius:20px;margin-bottom:10px;
  box-shadow:var(--shadow-2);overflow:hidden
}
.tag-head{display:flex;align-items:center;gap:14px;padding:14px 16px}
.tag-circle{
  width:50px;height:50px;border-radius:18px;display:flex;align-items:center;justify-content:center;
  font-size:23px;flex-shrink:0;box-shadow:0 6px 18px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.15);
  cursor:pointer
}
.tag-info{flex:1;min-width:0}
.tag-name{font-size:15.5px;font-weight:800;color:var(--text);letter-spacing:-.2px}
.tag-sub{font-size:10.5px;color:var(--text3);margin-top:3px;font-weight:600}
.tag-add-btn{
  width:38px;height:38px;border-radius:50%;background:var(--card3);
  border:1.5px solid var(--border2);color:var(--text2);font-size:20px;font-weight:600;
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s
}
.tag-add-btn:active{background:var(--gold-dim);border-color:var(--gold);color:var(--gold-light)}
.tag-menu-btn{background:none;border:none;color:var(--text3);font-size:19px;padding:0 6px;cursor:pointer;letter-spacing:-.5px}
.tag-subtags{display:none;background:var(--card2);border-top:1px solid var(--border)}
.tag-card.expanded .tag-subtags{display:block}
.subtag-row{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--border);font-size:13px}
.subtag-row:last-child{border-bottom:none}
.subtag-name{flex:1;font-weight:600;color:var(--text2)}
.subtag-add-row{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--border);background:var(--card2)}
.subtag-add-row .form-input{font-size:13px;padding:9px 12px}

/* ── EMPTY STATE ── */
.empty{padding:50px 16px;text-align:center;color:var(--text3)}
.empty-icon{font-size:42px;margin-bottom:12px;opacity:.55;animation:fcFloat 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(217,172,68,.15))}
@keyframes fcFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.empty p{font-size:13px;line-height:1.5;font-weight:500;margin:0}

/* ── MODAL (bottom-sheet) ── */
.modal-overlay{
  position:fixed;inset:0;z-index:200;display:none;
  background:rgba(0,0,0,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)
}
.modal-overlay.active{display:flex;align-items:flex-end;animation:fcFade .2s}
@keyframes fcFade{from{opacity:0}to{opacity:1}}
.modal-sheet{
  width:100%;max-height:90vh;overflow-y:auto;
  background:rgba(12,17,28,.97);backdrop-filter:blur(40px) saturate(200%);
  -webkit-backdrop-filter:blur(40px) saturate(200%);
  border-radius:28px 28px 0 0;border-top:1px solid rgba(255,255,255,.08);
  box-shadow:0 -32px 100px rgba(0,0,0,.8);
  padding:14px 18px 24px;animation:fcSlide .3s cubic-bezier(.16,1,.3,1);position:relative
}
.modal-sheet::before{content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);width:40px;height:4px;background:rgba(255,255,255,.15);border-radius:4px}
@keyframes fcSlide{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-title{font-size:18px;font-weight:800;color:var(--text);margin:14px 0 14px;text-align:center;letter-spacing:-.3px}
.modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:var(--card2);border:1px solid var(--border2);color:var(--text);font-size:14px;display:flex;align-items:center;justify-content:center}

/* ── NUMPAD ── */
#numpad{position:fixed;inset:auto 0 0 0;z-index:300;display:none;background:rgba(12,17,28,.98);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-top:1px solid rgba(255,255,255,.08);padding:14px 12px calc(20px + env(safe-area-inset-bottom,0));animation:fcSlide .25s cubic-bezier(.16,1,.3,1)}
#numpad.active{display:block}
.np-display{background:var(--card2);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:12px;text-align:right}
.np-display .np-label{font-size:10px;font-weight:800;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;text-align:left}
.np-display .np-value{font-family:'JetBrains Mono',monospace;font-size:28px;font-weight:800;color:var(--text);letter-spacing:-1px}
.np-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.np-btn{padding:18px 0;border-radius:14px;background:var(--card2);border:1px solid var(--border);font-size:20px;font-weight:800;color:var(--text);transition:all .12s}
.np-btn:active{background:var(--card3);transform:scale(.94)}
.np-btn.del{color:var(--expense);background:var(--expense-dim)}
.np-btn.ok{grid-column:span 3;background:linear-gradient(135deg,#B88420,#E8B84A 35%,#F2CD68 50%,#D9AC44 70%,#9F7A20);color:#0A0500;font-size:16px}
.np-btn.zero{grid-column:span 2}

/* ── TOAST ── */
#toast{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);
  z-index:400;background:rgba(20,28,46,.97);backdrop-filter:blur(28px);
  border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px 22px;
  font-size:14px;font-weight:600;color:var(--text);
  box-shadow:0 16px 40px rgba(0,0,0,.5);display:none;animation:fcToast .25s
}
@keyframes fcToast{from{opacity:0;transform:translate(-50%,-40%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}

/* ── EXTRATO MODAL ── */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;background:var(--card2);border:1px solid var(--border);border-radius:14px;padding:10px}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .15s}
.cal-day.selected{background:var(--gold);color:#0A0500;font-weight:800}
.cal-day:active{transform:scale(.9)}
.cal-dow{text-align:center;font-size:10px;color:var(--text3);font-weight:800;padding:4px 0}

/* ── UTILITIES ── */
.row{display:flex;align-items:center;gap:10px}
.col{display:flex;flex-direction:column;gap:10px}
.gap-sm{gap:6px}
.flex-1{flex:1}
.text-r{text-align:right}
.text-c{text-align:center}
.mt-1{margin-top:4px} .mt-2{margin-top:8px} .mt-3{margin-top:12px}
.mb-1{margin-bottom:4px} .mb-2{margin-bottom:8px} .mb-3{margin-bottom:12px}
.hidden{display:none !important}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(217,172,68,.18);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(217,172,68,.35)}


/* ── V79 · extensões comerciais preservando o design base ── */
.fc-card-btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.fc-card-btn-row .btn{padding:10px 12px;font-size:12px;flex:1;min-width:130px}
.fc-mini-note{font-size:11px;color:var(--text3);line-height:1.45;margin-top:6px}
.fc-status-pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 9px;font-size:10px;font-weight:900;letter-spacing:.4px;text-transform:uppercase;border:1px solid var(--border2);background:var(--card2);color:var(--text2)}
.fc-status-pill.ok{background:var(--income-dim);border-color:var(--income-border);color:var(--income)}
.fc-status-pill.warn{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold-light)}
.fc-status-pill.bad{background:var(--expense-dim);border-color:var(--expense-border);color:var(--expense)}
.fc-chart-grid{display:grid;grid-template-columns:1fr;gap:12px}
.fc-chart-card{background:linear-gradient(155deg,var(--card),var(--card2));border:1px solid var(--border2);border-radius:18px;padding:14px;box-shadow:var(--shadow-2);min-height:260px}
.fc-chart-card canvas{width:100%!important;max-height:300px}
.fc-detect-item{background:rgba(255,255,255,.018);border:1px solid var(--border);border-radius:14px;padding:12px;margin-bottom:8px}
.fc-detect-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.fc-detect-top input{width:18px;height:18px;accent-color:var(--gold)}
.fc-inline-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.fc-inline-grid.three{grid-template-columns:1fr 1fr 1fr}
.fc-segment{display:flex;gap:6px;background:rgba(15,22,35,.85);border:1px solid var(--border2);border-radius:14px;padding:4px;margin-bottom:10px}
.fc-segment button{flex:1;padding:9px 8px;border-radius:11px;font-size:11px;font-weight:900;color:var(--text2)}
.fc-segment button.active{background:var(--card3);color:var(--gold-light);box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.fc-year-grid,.fc-month-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:10px 0}
.fc-year-grid button,.fc-month-grid button{background:var(--card2);border:1px solid var(--border);border-radius:12px;padding:10px 6px;font-weight:800;color:var(--text2)}
.fc-year-grid button.selected,.fc-month-grid button.selected{background:var(--gold-dim);border-color:var(--gold);color:var(--gold-light)}
.fc-hidden{display:none!important}
@media (min-width:700px){.fc-chart-grid{grid-template-columns:1fr 1fr}.modal-sheet{max-width:520px;margin:0 auto}}


.fc-invoice-box{
  background:linear-gradient(155deg,rgba(201,168,76,.08),rgba(255,255,255,.02));
  border:1px solid var(--gold-border);
  border-radius:16px;
  padding:12px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.fc-invoice-preview{
  background:rgba(0,0,0,.18);
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  font-size:12px;
  line-height:1.45;
  color:var(--text2);
  margin-bottom:10px;
}
.fc-invoice-preview strong{color:var(--gold-light);font-size:13px}
.fc-check-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);font-weight:700}
.fc-check-row input{width:18px;height:18px;accent-color:var(--gold)}



/* V79 SERVICE-ORIENTED — layout safeguards */
.app-modal, #modal-sheet { max-width: 430px; margin-left:auto; margin-right:auto; }
.screen { overscroll-behavior-y: contain; }
.wheel-list, .picker-list, .scroll-list, .tx-list, .fc-list { overscroll-behavior: contain; -webkit-overflow-scrolling: touch; }
.list-viewport { max-height: min(38vh, 320px); overflow:auto; overscroll-behavior: contain; -webkit-overflow-scrolling: touch; }
button, .btn, .chip, .block-head { touch-action: manipulation; }

/* ══════════════════════════════════════════════════════════════
   FINCONTROL V85 · VISUAL V61 LOCK + PREMIUM REFINEMENTS
   ══════════════════════════════════════════════════════════════ */
:root{--app-w:430px;--wheel-h:258px;--wheel-row:82px;}
html{background:#05070d;}
body{min-height:100%;display:flex;justify-content:center;background:#05070d;}
#app{width:100%;max-width:var(--app-w);min-height:100dvh;margin:0 auto;box-shadow:0 0 0 1px rgba(255,255,255,.035),0 30px 100px rgba(0,0,0,.55);}
#header,#nav{left:50%;right:auto;transform:translateX(-50%);width:100%;max-width:var(--app-w)}
#main{max-width:var(--app-w);margin:0 auto;overflow-x:hidden;}
.modal-overlay{padding:16px;}
.modal-sheet{width:100%;max-width:calc(var(--app-w) - 20px);max-height:88dvh;overflow-y:auto;overscroll-behavior:contain;}
body.fc-modal-open{overflow:hidden;}
button,.block-head,.chip,.sub-item{touch-action:manipulation;}
.fc-app-shell-note{font-size:10px;color:var(--text3);font-weight:700;letter-spacing:.35px;}
.fc-premium-panel{background:linear-gradient(155deg,rgba(20,28,48,.98),rgba(12,17,29,.99));border:1px solid rgba(255,255,255,.09);box-shadow:var(--shadow-2);border-radius:22px;padding:15px;margin-bottom:12px;}
.fc-premium-panel.gold{border-color:var(--gold-border);box-shadow:var(--glow-gold),var(--shadow-2)}
.fc-row-line{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.055);font-size:13px;color:var(--text2)}
.fc-row-line:last-child{border-bottom:0}
.fc-row-line strong{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--text);white-space:nowrap}
.fc-wheel-list{position:relative;max-height:var(--wheel-h);overflow-y:auto;overscroll-behavior:contain;scroll-snap-type:y proximity;padding:6px 4px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01));border:1px solid rgba(255,255,255,.055);-webkit-overflow-scrolling:touch;}
.fc-wheel-list::before,.fc-wheel-list::after{content:'';position:sticky;left:0;right:0;display:block;height:15px;z-index:2;pointer-events:none;}
.fc-wheel-list::before{top:0;background:linear-gradient(180deg,rgba(12,17,29,.98),transparent)}
.fc-wheel-list::after{bottom:0;background:linear-gradient(0deg,rgba(12,17,29,.98),transparent)}
.fc-wheel-list .sub-item,.fc-wheel-list .block,.fc-wheel-list .tag-card{scroll-snap-align:center;min-height:68px;}
.fc-scroll-hint{text-align:center;font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--text3);font-weight:900;margin:5px 0 8px;opacity:.75}
.fc-accordion-collapsed .block-body{display:none!important;}
.block.open>.block-body{display:block!important;}
.fc-detail-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px;}
.fc-detail-actions .btn{padding:10px 9px;font-size:12px;border-radius:12px;}
.fc-menu-grid{display:grid;gap:8px}.fc-menu-grid .btn{justify-content:flex-start}
.tag-card{background:linear-gradient(155deg,#151923,#252735);border-radius:28px;border:0;box-shadow:none;margin-bottom:10px;overflow:visible;}
.tag-head{padding:15px 14px;display:flex;align-items:center;gap:14px;}
.tag-circle{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:22px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1)}
.tag-name{font-size:17px;font-weight:750;letter-spacing:-.2px}.tag-sub{font-size:10px;color:rgba(255,255,255,.42);font-weight:600;margin-top:1px}
.tag-add-btn,.tag-menu-btn{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.08);font-weight:900;font-size:18px;flex-shrink:0;color:rgba(255,255,255,.75)}
.tag-menu-btn{background:transparent;border-color:transparent;font-size:20px;color:rgba(255,255,255,.55)}
.tag-subtags{display:none;padding:0 14px 14px}.tag-card.expanded .tag-subtags{display:block}.subtag-row{display:flex;align-items:center;justify-content:space-between;background:rgba(0,0,0,.16);border-radius:14px;padding:9px 10px;margin:6px 0}.subtag-name{font-size:12px;font-weight:700;color:var(--text2)}.subtag-add-row{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:8px}
.fc-filter-chip{position:relative}.fc-filter-chip.relevant{box-shadow:0 0 0 1px rgba(217,172,68,.24),0 0 14px rgba(217,172,68,.12)}.fc-filter-chip .tick{font-weight:900;margin-right:4px;color:var(--income)}
.fc-extract-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:8px}.fc-extract-toolbar .btn{padding:10px;font-size:12px}.fc-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.fc-day-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.fc-day-grid .cal-day{height:34px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);font-size:12px;font-weight:800}.fc-day-grid .cal-day.selected{background:var(--gold-dim);border-color:var(--gold);color:var(--gold-light)}.fc-day-grid .cal-day.in-range{background:rgba(217,172,68,.12)}
.fc-loan-person-card{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:10px;margin-bottom:8px}.fc-loan-person-card .form-row{grid-template-columns:1.2fr .8fr}.fc-preview-table{background:rgba(255,255,255,.035);border:1px solid var(--gold-border);border-radius:16px;padding:12px;margin:10px 0}.fc-preview-row{display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid rgba(255,255,255,.055);padding:7px 0;font-size:12px}.fc-preview-row:last-child{border-bottom:0}.fc-preview-row strong{font-family:'JetBrains Mono',monospace;color:var(--gold-light)}
@media(min-width:560px){body{padding:0;background:radial-gradient(circle at top,#0d1422,#05070d 55%)}#app{border-left:1px solid rgba(255,255,255,.035);border-right:1px solid rgba(255,255,255,.035)}}
@media(max-width:380px){.brand{font-size:20px;letter-spacing:1.7px}.month-pill{padding:5px 9px}.stat-value{font-size:15px}.saldo-value{font-size:31px}.fc-detail-actions{grid-template-columns:1fr}}
.fc-badge{display:inline-flex;align-items:center;gap:3px;background:var(--gold-dim);border:1px solid var(--gold-border);border-radius:999px;padding:1px 7px;color:var(--gold-light);font-size:9px;font-weight:900;vertical-align:middle}.fc-badge.purple{background:var(--purple-dim);border-color:rgba(167,139,250,.25);color:var(--purple-light)}
.sub-item-btn[disabled],.btn[disabled]{pointer-events:none;filter:grayscale(.2)}

/* FINCONTROL V88 · Reset mantendo cadastros */
.fc-reset-choice{display:grid;gap:10px}
.fc-reset-option{width:100%;text-align:left;border-radius:20px;padding:14px;border:1px solid rgba(255,255,255,.09);background:linear-gradient(155deg,rgba(255,255,255,.055),rgba(255,255,255,.018));color:var(--text);display:grid;grid-template-columns:auto 1fr;gap:8px 12px;align-items:center;box-shadow:var(--shadow-1)}
.fc-reset-option strong{font-size:14px;font-weight:900;letter-spacing:-.15px}.fc-reset-option small{grid-column:2;color:var(--text3);font-size:11px;line-height:1.45;font-weight:650}.fc-reset-option-icon{font-size:24px;grid-row:span 2}.fc-reset-option.keep{border-color:var(--gold-border);background:linear-gradient(155deg,rgba(217,172,68,.12),rgba(255,255,255,.025))}.fc-reset-option.danger{border-color:var(--expense-border);background:linear-gradient(155deg,rgba(244,112,139,.10),rgba(255,255,255,.018))}
.fc-reset-snapshot-note,.fc-reset-delete-list{font-size:11px;line-height:1.45;color:var(--text2);font-weight:650;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:10px}
.fc-reset-banner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;background:linear-gradient(155deg,rgba(167,139,250,.17),rgba(217,172,68,.08));border:1px solid rgba(217,172,68,.22);border-radius:20px;padding:12px;margin-bottom:12px;box-shadow:var(--shadow-1)}
.fc-reset-banner-icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:rgba(0,0,0,.18);font-size:20px}.fc-reset-banner-copy{min-width:0}.fc-reset-banner-copy strong{display:block;color:var(--text);font-size:13px;font-weight:900}.fc-reset-banner-copy span{display:block;color:var(--text3);font-size:10.5px;font-weight:700;line-height:1.35}.fc-reset-banner .btn{width:auto;padding:10px 12px;font-size:11px;border-radius:12px}
.fc-reset-pending-card{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:linear-gradient(155deg,rgba(167,139,250,.12),rgba(255,255,255,.025));border:1px solid rgba(167,139,250,.24);border-radius:16px;padding:11px;margin:8px 0 12px}.fc-reset-pending-card strong{display:block;font-size:12px;color:var(--text);font-weight:900}.fc-reset-pending-card span{display:block;font-size:10px;color:var(--text3);font-weight:700;margin-top:2px}.fc-reset-pending-card .btn{width:auto;padding:9px 11px;font-size:11px;border-radius:12px}
.fc-reset-confirm-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.035);border-radius:15px;padding:10px;margin-bottom:7px}.fc-reset-confirm-row input{width:20px;height:20px;accent-color:var(--gold)}.fc-reset-confirm-info{min-width:0}.fc-reset-confirm-info strong{display:block;font-size:12.5px;color:var(--text);font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-reset-confirm-info small{display:block;font-size:10px;color:var(--text3);font-weight:700;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:380px){.fc-reset-banner{grid-template-columns:auto 1fr}.fc-reset-banner .btn{grid-column:1/3;width:100%}.fc-reset-pending-card{grid-template-columns:1fr}.fc-reset-pending-card .btn{width:100%}}
