:root{
  --exp-bg-deep:#041016;
  --exp-bg-mid:#0a2532;
  --exp-card:#0d1d28c9;
  --exp-card-strong:#102736;
  --exp-border:rgba(148, 210, 255, 0.2);
  --exp-title:#e6f8ff;
  --exp-text:#bfd8e8;
  --exp-muted:#89a6ba;
  --exp-accent:#2bd38d;
  --exp-accent-2:#1fb87a;
  --exp-danger:#ff7f8d;
  --exp-pill:#0f3144;
  --exp-shadow:0 16px 42px rgba(0,0,0,0.24);
}

body[data-theme="light"]{
  --exp-bg-deep:#ecf5fb;
  --exp-bg-mid:#d9ecf8;
  --exp-card:rgba(255,255,255,0.88);
  --exp-card-strong:#ffffff;
  --exp-border:rgba(63,120,155,0.18);
  --exp-title:#123348;
  --exp-text:#2a4f65;
  --exp-muted:#577486;
  --exp-accent:#0fae73;
  --exp-accent-2:#22bf85;
  --exp-danger:#b93149;
  --exp-pill:#e4f2fa;
  --exp-shadow:0 14px 30px rgba(27,77,109,0.14);
}

*{box-sizing:border-box}

body{
  margin:0;
  padding-top:4.5rem;
  font-family:"Manrope","Segoe UI",sans-serif;
  color:var(--exp-text);
  background:
    radial-gradient(circle at 8% 3%, rgba(40,207,148,0.2), transparent 32%),
    radial-gradient(circle at 94% 14%, rgba(74,172,255,0.16), transparent 28%),
    linear-gradient(160deg, var(--exp-bg-mid) 0%, var(--exp-bg-deep) 65%);
}

.app{
  width:min(1160px, calc(100% - 2rem));
  margin:0 auto;
  padding:1.2rem 0 1.8rem;
}

.page-intro{
  margin-bottom:1rem;
  animation:fadeRise .45s ease both;
}

.intro-topbar{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:0.8rem;
  flex-wrap:wrap;
}

.intro-actions{
  display:flex;
  align-items:center;
  gap:0.5rem;
  flex-wrap:wrap;
  justify-content:flex-end;
  margin-left:auto;
}

.intro-actions > *{
  flex:0 0 auto;
}

.go-incomes{
  text-decoration:none;
  color:var(--exp-title);
  border:1px solid var(--exp-border);
  background:var(--exp-pill);
  border-radius:999px;
  min-height:40px;
  padding:0.55rem 0.85rem;
  font-weight:700;
  font-size:0.9rem;
}

.manage-accounts-btn{
  border:1px solid var(--exp-border);
  background:var(--exp-pill);
  color:var(--exp-title);
  border-radius:999px;
  min-height:40px;
  padding:0.55rem 0.85rem;
  font-weight:700;
  font-size:0.9rem;
  cursor:pointer;
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:0.45rem;
}

.manage-accounts-btn:hover{filter:brightness(1.04)}

.badge{
  min-width:20px;
  height:20px;
  border-radius:999px;
  padding:0 0.35rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:0.72rem;
  font-weight:800;
  color:#fff;
  background:#ff5a76;
}

.eyebrow{
  margin:0;
  font-size:0.78rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--exp-accent);
  font-weight:800;
}

.page-intro h1{
  margin:0.35rem 0;
  color:var(--exp-title);
  font-family:"Sora","Manrope",sans-serif;
  font-size:1.68rem;
}

.page-subtitle{
  margin:0;
  max-width:72ch;
  color:var(--exp-muted);
  font-size:0.96rem;
}

.theme-toggle{
  margin-top:0.12rem;
  border:1px solid var(--exp-border);
  background:var(--exp-pill);
  color:var(--exp-title);
  border-radius:999px;
  min-height:40px;
  min-width:96px;
  padding:0 0.75rem;
  display:inline-flex;
  gap:0.45rem;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-weight:700;
}

.privacy-toggle{
  margin-top:0.12rem;
  border:1px solid var(--exp-border);
  background:var(--exp-pill);
  color:var(--exp-title);
  border-radius:999px;
  min-height:40px;
  min-width:132px;
  padding:0 0.75rem;
  display:inline-flex;
  gap:0.45rem;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-weight:700;
}

.privacy-toggle:hover{filter:brightness(1.04)}

.theme-toggle:hover{filter:brightness(1.04)}

.theme-icon{
  color:var(--exp-accent);
  font-size:1rem;
}

.metrics-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0.75rem;
  margin-bottom:1rem;
}

.metric-card{
  background:linear-gradient(165deg, var(--exp-card-strong), var(--exp-card));
  border:1px solid var(--exp-border);
  border-radius:16px;
  padding:0.86rem 0.95rem;
  box-shadow:var(--exp-shadow);
  animation:fadeRise .45s ease both;
}

.metric-card:nth-child(2){animation-delay:.06s}
.metric-card:nth-child(3){animation-delay:.12s}
.metric-card:nth-child(4){animation-delay:.18s}

.metric-label{
  margin:0;
  color:var(--exp-muted);
  font-size:0.78rem;
  letter-spacing:0.04em;
  text-transform:uppercase;
  font-weight:700;
}

.metric-value{
  margin:0.28rem 0;
  color:var(--exp-title);
  font-size:1.25rem;
  font-weight:800;
  font-family:"Sora","Manrope",sans-serif;
}

.metric-value--sm{
  font-size:1rem;
  line-height:1.35;
}

.metric-foot{
  margin:0;
  color:var(--exp-muted);
  font-size:0.84rem;
}

.metric-foot--alert{
  color:var(--exp-danger);
  font-weight:700;
}

.dashboard-grid{
  display:grid;
  gap:1rem;
}

.content-stack{
  display:grid;
  gap:1rem;
}

.card{
  background:linear-gradient(165deg, var(--exp-card-strong), var(--exp-card));
  border:1px solid var(--exp-border);
  border-radius:18px;
  padding:1.05rem;
  backdrop-filter:blur(7px);
  box-shadow:var(--exp-shadow);
  animation:fadeRise .45s ease both;
}

.card h2,
.card h3{
  margin:0 0 0.85rem;
  color:var(--exp-title);
  font-family:"Sora","Manrope",sans-serif;
  font-size:1.23rem;
}

.auth-provider{
  margin:0 0 0.7rem;
  display:inline-flex;
  align-items:center;
  padding:0.26rem 0.62rem;
  border-radius:999px;
  border:1px solid rgba(168,206,232,0.24);
  background:var(--exp-pill);
  color:var(--exp-muted);
  font-size:0.78rem;
  font-weight:700;
}

.target-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:0.7rem;
  margin:0 0 0.55rem;
}

.target-header p{
  margin:0;
  color:var(--exp-title);
  font-weight:800;
  font-size:0.9rem;
}

.target-header small{
  color:var(--exp-muted);
  font-size:0.78rem;
}

.target-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:0.5rem;
  margin-bottom:0.78rem;
}

.target-tab{
  border:1px solid rgba(168,206,232,0.24);
  background:var(--exp-pill);
  color:var(--exp-title);
  border-radius:999px;
  padding:0.45rem 0.78rem;
  font-size:0.83rem;
  font-weight:700;
  cursor:pointer;
  transition:all .16s ease;
}

.target-tab:hover{
  border-color:rgba(121,248,194,0.8);
}

.target-tab.is-active{
  color:#042015;
  border-color:transparent;
  background:linear-gradient(120deg, #7df5c3, #27cf8d);
}

.target-tab.disabled{
  cursor:not-allowed;
  opacity:0.7;
}

.field{
  display:flex;
  flex-direction:column;
  gap:0.42rem;
  margin-bottom:0.75rem;
}

.field label{
  font-size:0.77rem;
  color:var(--exp-muted);
  font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

.field input,
.field select{
  width:100%;
  min-height:46px;
  padding:0.78rem 0.85rem;
  border-radius:11px;
  border:1px solid rgba(156,214,255,0.18);
  background:rgba(7,21,32,0.6);
  color:var(--exp-title);
  font-size:0.96rem;
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.field-inline{
  display:flex;
  align-items:center;
  gap:0.6rem;
  margin-bottom:0.7rem;
}

.field-inline input{
  width:18px;
  height:18px;
  accent-color:var(--exp-accent-2);
}

.field-inline label{
  color:var(--exp-title);
  font-size:0.92rem;
  font-weight:700;
}

body[data-theme="light"] .field input,
body[data-theme="light"] .field select{
  background:rgba(255,255,255,0.78);
}

.field input::placeholder{color:#88a6bb}

.field input:focus,
.field select:focus{
  outline:none;
  border-color:rgba(96,243,179,0.9);
  box-shadow:0 0 0 3px rgba(43,211,141,0.2);
}

.action-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0.65rem;
}

.action-single .btn{width:100%}

.btn{
  min-height:44px;
  border-radius:11px;
  font-weight:800;
}

.btn.btn-ghost{
  border:1px solid rgba(168,206,232,0.24);
  color:var(--exp-title);
  background:rgba(7,24,34,0.45);
}

body[data-theme="light"] .btn.btn-ghost{
  background:#f2f9fd;
}

.btn.btn-primary{
  border:0;
  color:#062818;
  background:linear-gradient(130deg, #87f5c8, #1fc784);
}

.big-btn{
  width:100%;
  margin-top:0.3rem;
  border:0;
  border-radius:12px;
  padding:0.86rem 1rem;
  font-weight:800;
  font-size:0.97rem;
  color:#022517;
  cursor:pointer;
  background:linear-gradient(138deg, var(--exp-accent) 0%, var(--exp-accent-2) 100%);
  box-shadow:0 12px 22px rgba(20,130,87,0.35);
  transition:transform .14s ease, filter .14s ease;
}

.big-btn:hover{
  filter:brightness(1.04);
  transform:translateY(-1px);
}

.big-btn-secondary{
  background:var(--exp-pill);
  color:var(--exp-title);
  border:1px solid var(--exp-border);
  box-shadow:none;
}

#msg{
  margin-top:0.6rem;
  min-height:1.2rem;
  font-size:0.92rem;
  font-weight:700;
}

.filters{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0.55rem;
  margin:0.4rem 0 0.8rem;
}

.filters button{
  border:1px solid rgba(168,206,232,0.2);
  border-radius:999px;
  padding:0.48rem 0.65rem;
  font-weight:700;
  font-size:0.86rem;
  color:var(--exp-muted);
  background:var(--exp-pill);
  cursor:pointer;
  transition:all .16s ease;
}

.filters button.is-active,
.filters button:hover{
  color:#042015;
  background:linear-gradient(120deg, #7df5c3, #27cf8d);
  border-color:transparent;
}

.list{
  display:grid;
  gap:0.5rem;
}

.item{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:0.5rem;
  padding:0.66rem 0.72rem;
  border-radius:12px;
  border:1px solid rgba(176,219,244,0.12);
  background:rgba(4,18,28,0.44);
  color:var(--exp-title);
}

body[data-theme="light"] .item{
  background:#f8fcff;
}

.item-right{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:0.35rem;
}

.item-amount{
  font-weight:800;
}

.item-actions{
  display:flex;
  gap:0.35rem;
}

.item-btn{
  border:1px solid var(--exp-border);
  background:var(--exp-pill);
  color:var(--exp-title);
  border-radius:999px;
  padding:0.3rem 0.65rem;
  font-size:0.72rem;
  font-weight:800;
  cursor:pointer;
  transition:transform 140ms ease, box-shadow 140ms ease, background 140ms ease, border-color 140ms ease;
}

.item-btn-danger{
  border-color:rgba(255,127,141,0.45);
  color:var(--exp-danger);
  background:rgba(255,127,141,0.12);
}

.item-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 14px rgba(7,20,34,0.24);
}

.item-btn-danger:hover{
  background:rgba(255,127,141,0.22);
  border-color:rgba(255,127,141,0.75);
}

.item-btn:disabled{
  opacity:0.6;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}

.item-empty{
  grid-template-columns:1fr;
  color:var(--exp-muted);
}

.total{
  margin-top:0.75rem;
  text-align:right;
  color:var(--exp-accent);
  font-weight:800;
  letter-spacing:0.01em;
}

.ai-card h3{
  margin:0 0 0.4rem;
  font-size:1.05rem;
  color:var(--exp-title);
}

.ai-subtitle{
  margin:0 0 0.7rem;
  color:var(--exp-muted);
  font-size:0.88rem;
}

#ai_expense_msg{
  margin-top:0.55rem;
  min-height:1.1rem;
  font-size:0.88rem;
  font-weight:700;
}

.ai-result{
  margin-top:0.85rem;
  padding-top:0.75rem;
  border-top:1px solid rgba(148,210,255,0.15);
}

.ai-score{
  display:grid;
  gap:0.6rem;
}

.ai-score-label{
  margin:0;
  font-size:0.78rem;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--exp-muted);
  font-weight:700;
}

.ai-score-value{
  margin:0.2rem 0;
  font-size:1.5rem;
  font-weight:800;
  color:var(--exp-title);
}

.ai-score-note{
  margin:0;
  font-size:0.85rem;
  color:var(--exp-muted);
}

.ai-score-bar{
  position:relative;
  height:10px;
  border-radius:999px;
  background:rgba(14,35,48,0.45);
  overflow:hidden;
}

.ai-score-bar span{
  position:absolute;
  inset:0;
  width:0%;
  background:linear-gradient(120deg, #7df5c3, #27cf8d);
  transition:width 280ms ease;
}

.ai-score-bar span[data-level="critico"]{
  background:linear-gradient(120deg, #ff9aa7, #ff6a7f);
}

.ai-score-bar span[data-level="atencao"]{
  background:linear-gradient(120deg, #ffd66b, #ff9f43);
}

.ai-metrics{
  display:grid;
  gap:0.45rem;
  margin:0.85rem 0;
}

.ai-metric{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:0.6rem;
  padding:0.5rem 0.7rem;
  border-radius:10px;
  border:1px solid rgba(148,210,255,0.12);
  background:rgba(6,19,30,0.35);
  font-size:0.86rem;
}

body[data-theme="light"] .ai-score-bar{
  background:#e1edf5;
}

body[data-theme="light"] .ai-metric{
  background:#f6fbff;
}

.ai-summary{
  margin:0.6rem 0 0.85rem;
  color:var(--exp-text);
  line-height:1.5;
}

.ai-grid{
  display:grid;
  gap:0.8rem;
}

.ai-grid h4{
  margin:0 0 0.4rem;
  color:var(--exp-title);
  font-size:0.92rem;
}

.ai-list{
  margin:0;
  padding-left:1.1rem;
  color:var(--exp-text);
  font-size:0.86rem;
}

.ai-actions{
  display:grid;
  gap:0.55rem;
}

.ai-action{
  border:1px solid rgba(148,210,255,0.14);
  border-radius:12px;
  padding:0.6rem 0.75rem;
  background:rgba(7,22,32,0.4);
}

body[data-theme="light"] .ai-action{
  background:#f6fbff;
}

.ai-action p{
  margin:0.35rem 0 0.55rem;
  color:var(--exp-muted);
  font-size:0.84rem;
}

.ai-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:0.2rem 0.6rem;
  font-size:0.72rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.04em;
  background:rgba(125,245,195,0.16);
  color:var(--exp-accent);
}

.ai-budgets{
  display:grid;
  gap:0.45rem;
}

.ai-budget{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:0.6rem;
  padding:0.55rem 0.7rem;
  border-radius:10px;
  border:1px dashed rgba(148,210,255,0.2);
  background:rgba(6,19,30,0.3);
  font-size:0.85rem;
}

body[data-theme="light"] .ai-budget{
  background:#f6fbff;
}

.ai-budget small{
  color:var(--exp-muted);
}

.ai-empty{
  color:var(--exp-muted);
  font-size:0.85rem;
}

@media (min-width:920px){
  .ai-grid{
    grid-template-columns:repeat(2, 1fr);
    align-items:start;
  }
}

.invite-link{
  margin-top:0.45rem;
  word-break:break-word;
  font-size:0.86rem;
}

.invite-actions{
  margin-top:0.5rem;
  display:flex;
  flex-wrap:wrap;
  gap:0.45rem;
}

.split-hint{
  margin:0.15rem 0 0;
  font-size:0.82rem;
  color:var(--exp-muted);
}

.notify-box{
  margin-top:0.75rem;
  border-top:1px solid rgba(168,206,232,0.18);
  padding-top:0.65rem;
}

.notify-box h4{
  margin:0 0 0.45rem;
  color:var(--exp-title);
  font-size:0.86rem;
}

.notifications-list{
  display:grid;
  gap:0.42rem;
  color:var(--exp-muted);
  font-size:0.82rem;
}

.notification-item{
  border:1px solid rgba(176,219,244,0.12);
  border-radius:10px;
  padding:0.45rem 0.52rem;
  background:rgba(4,18,28,0.35);
}

.notification-item.unread{
  border-color:rgba(125,245,195,0.45);
}

.notification-item strong{
  display:block;
  color:var(--exp-title);
  font-size:0.8rem;
}

.notification-item p{
  margin:0.2rem 0 0;
}

.notification-actions{
  margin-top:0.35rem;
}

.mini-action{
  border:1px solid rgba(168,206,232,0.25);
  border-radius:999px;
  padding:0.24rem 0.62rem;
  font-size:0.74rem;
  font-weight:700;
  color:var(--exp-title);
  background:var(--exp-pill);
  cursor:pointer;
}

.mini-action:hover{
  filter:brightness(1.06);
}

.beta-fab{
  position:fixed;
  right:1rem;
  bottom:1rem;
  z-index:120;
  border:0;
  border-radius:999px;
  padding:0.7rem 1rem;
  font-weight:800;
  color:#052414;
  background:linear-gradient(130deg, #87f5c8, #20c987);
  box-shadow:0 14px 28px rgba(19,112,76,0.34);
  cursor:pointer;
}

.privacy-fab{
  position:fixed;
  left:1rem;
  bottom:1rem;
  z-index:121;
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid var(--exp-border);
  background:var(--exp-pill);
  color:var(--exp-title);
  font-size:1.1rem;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(10,35,52,0.3);
}

.beta-modal{
  position:fixed;
  inset:0;
  z-index:130;
  background:rgba(2,9,14,0.6);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
}

.beta-modal[hidden]{
  display:none !important;
}

.beta-modal-card{
  width:min(560px, 100%);
  border-radius:16px;
  border:1px solid var(--exp-border);
  background:linear-gradient(165deg, var(--exp-card-strong), var(--exp-card));
  padding:1rem;
}

.beta-modal-card h3{
  margin:0;
  color:var(--exp-title);
  font-family:"Sora","Manrope",sans-serif;
}

.beta-modal-card p{
  margin:0.38rem 0 0.75rem;
  color:var(--exp-muted);
}

.beta-modal-card textarea{
  width:100%;
  min-height:110px;
  border-radius:11px;
  border:1px solid rgba(156,214,255,0.18);
  background:rgba(7,21,32,0.6);
  color:var(--exp-title);
  padding:0.72rem 0.82rem;
  resize:vertical;
}

body[data-theme="light"] .beta-modal-card textarea{
  background:rgba(255,255,255,0.78);
}

.beta-actions{
  margin-top:0.25rem;
  display:flex;
  justify-content:flex-end;
  gap:0.5rem;
}

.beta-msg{
  min-height:1rem;
  margin-top:0.5rem;
  font-size:0.85rem;
  font-weight:700;
}

/* Plan lock (upgrade prompt) */
.plan-lock{
  display:flex;
  flex-direction:column;
  gap:.5rem;
  padding:.85rem;
  border-radius:10px;
  border:1px solid rgba(94,198,255,0.2);
  background:linear-gradient(180deg,rgba(12,20,34,0.85),rgba(6,12,20,0.95));
  color:var(--exp-text);
  margin:.6rem 0 .75rem;
}
.plan-lock p{margin:0;color:var(--exp-muted)}

.danger-zone{
  margin-top:0.85rem;
  border:1px solid rgba(255,127,141,0.35);
  border-radius:12px;
  padding:0.8rem;
  background:rgba(78, 16, 28, 0.24);
}

body[data-theme="light"] .danger-zone{
  background:rgba(255, 233, 237, 0.9);
}

.danger-zone h4{
  margin:0;
  color:var(--exp-title);
  font-size:0.88rem;
}

.danger-zone p{
  margin:0.35rem 0 0.65rem;
  color:var(--exp-muted);
  font-size:0.82rem;
}

.btn.btn-danger{
  border:1px solid rgba(255,127,141,0.6);
  background:linear-gradient(120deg, #ff8fa0, #ff6f86);
  color:#2b0911;
  cursor:pointer;
}

#delete_account_msg{
  margin-top:0.45rem;
  min-height:1.1rem;
  font-size:0.83rem;
  font-weight:700;
}

.onboarding-modal{
  position:fixed;
  inset:0;
  z-index:145;
  background:rgba(2,9,14,0.68);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
}

.onboarding-modal[hidden]{
  display:none !important;
}

.onboarding-card{
  width:min(560px, 100%);
  border-radius:16px;
  border:1px solid var(--exp-border);
  background:linear-gradient(165deg, var(--exp-card-strong), var(--exp-card));
  padding:1rem;
  box-shadow:var(--exp-shadow);
}

.onboarding-card h3{
  margin:0;
  color:var(--exp-title);
  font-family:"Sora","Manrope",sans-serif;
}

.onboarding-step p{
  margin:0.75rem 0 0;
  color:var(--exp-muted);
  line-height:1.5;
}

.onboarding-actions{
  margin-top:0.9rem;
  display:flex;
  justify-content:flex-end;
  gap:0.5rem;
}

.invite-link a{color:#5ec6ff}

@media (min-width:760px){
  .metrics-grid{
    grid-template-columns:repeat(2, 1fr);
  }
}

@media (min-width:920px){
  .app{padding-top:1.45rem}
  .dashboard-grid.has-account-panel{
    grid-template-columns:360px 1fr;
    align-items:start;
  }
}

@media (min-width:1100px){
  .metrics-grid{
    grid-template-columns:repeat(4, 1fr);
  }
}

@media (max-width:560px){
  .app{
    width:min(1160px, calc(100% - 1.15rem));
  }
  .page-intro h1{font-size:1.38rem}
  .action-row{grid-template-columns:1fr}
  .intro-topbar{
    flex-direction:column;
    align-items:flex-start;
  }

  .intro-actions{
    width:100%;
    justify-content:flex-start;
  }

  .target-header{
    flex-direction:column;
    align-items:flex-start;
  }
}

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