/* =========================================================
   BLOCO 1 — MODAL GLOBAL
========================================================= */

.app-fin-modal{
  position:fixed;
  inset:0;
  z-index:999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
}

.app-fin-modal[aria-hidden="true"]{
  display:none;
}

.app-fin-modal__overlay{
  position:absolute;
  inset:0;
  background:rgba(15, 23, 42, .56);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
}

.app-fin-modal__dialog{
  position:relative;
  z-index:2;
  width:100%;
  max-width:560px;
  max-height:calc(100vh - 40px);
  overflow:hidden;
  background:linear-gradient(180deg, #FCFCFD, #F8FAFC);
  border:1px solid rgba(17,24,39,.08);
  border-radius:24px;
  box-shadow:0 28px 80px rgba(2, 6, 23, .26);
}

.app-fin-modal__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:18px 18px 12px;
  border-bottom:1px solid rgba(17,24,39,.06);
  background:rgba(255,255,255,.72);
}

.app-fin-modal__headings{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.app-fin-modal__eyebrow{
  display:none;
  font-size:11px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#0F766E;
}

.app-fin-modal__title{
  margin:0;
  font-size:22px;
  line-height:1.1;
  font-weight:700;
  letter-spacing:-.02em;
  color:#111827;
}

.app-fin-modal__subtitle{
  display:none;
  font-size:13px;
  line-height:1.4;
  font-weight:500;
  color:#6B7280;
}

.app-fin-modal__close{
  height:40px;
  width:40px;
  min-width:40px;
  border:none;
  border-radius:14px;
  background:#F3F4F6;
  color:#111827;
  font-size:24px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:none;
  transition:none !important;
  transform:none !important;
}

.app-fin-modal__close:hover,
.app-fin-modal__close:focus,
.app-fin-modal__close:focus-visible,
.app-fin-modal__close:active{
  background:#E5E7EB;
  outline:none;
  box-shadow:none !important;
  transform:none !important;
}

.app-fin-modal__body{
  padding:16px 18px 18px;
  overflow:auto;
  max-height:calc(100vh - 140px);
}

.app-fin-modal__body.is-loading{
  overflow:hidden;
}

.app-fin-modal__loading{
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(17,24,39,.06);
  background:#F8FAFC;
  color:#374151;
  font-size:14px;
  font-weight:600;
}

.app-fin-modal__content{
  min-height:40px;
}

/* =========================================================
   BLOCO 2 — VARIANTES
========================================================= */

.app-fin-modal.is-default-modal .app-fin-modal__dialog{
  max-width:560px;
}

.app-fin-modal.is-entry-modal .app-fin-modal__dialog{
  max-width:520px;
}

.app-fin-modal.is-expense-modal .app-fin-modal__dialog{
  max-width:560px;
}

.app-fin-modal.is-card-expense-modal{
  align-items:flex-start;
  padding-top:24px;
  padding-bottom:16px;
}

.app-fin-modal.is-card-expense-modal .app-fin-modal__dialog{
  max-width:520px;
}

/* =========================================================
   BLOCO 3 — SHELL DE FORMULÁRIO
========================================================= */

.app-fin-modal-form{
  display:block;
}

.app-fin-modal-panel{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.app-fin-form-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.app-fin-form-grid--2{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.app-fin-form-field{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}

.app-fin-form-field.is-full{
  grid-column:1 / -1;
}

.app-fin-form-field label{
  font-size:12px;
  line-height:1.25;
  font-weight:700;
  color:#374151;
  letter-spacing:-.01em;
}

.app-fin-input-wrap{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:40px;
  padding:0 10px;
  border:1px solid rgba(17,24,39,.08);
  border-radius:14px;
  background:rgba(255,255,255,.92);
  box-shadow:none;
  transition:none !important;
}

.app-fin-input-wrap:hover{
  outline:1px solid rgba(17,24,39,.08);
}

.app-fin-input-wrap:focus-within{
  outline:1px solid rgba(17,24,39,.18);
  box-shadow:0 0 0 3px rgba(17,24,39,.05);
}

.app-fin-input-wrap__icon{
  width:18px;
  height:18px;
  min-width:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#9CA3AF;
}

.app-fin-input-wrap__icon svg{
  width:18px;
  height:18px;
  display:block;
}

.app-fin-form-field input,
.app-fin-form-field select,
.app-fin-form-field textarea{
  width:100%;
  border:none;
  outline:none;
  background:transparent;
  box-shadow:none;
  color:#111827;
  font-size:14px;
  line-height:1.2;
  font-weight:500;
  padding:0;
  appearance:none;
}

.app-fin-form-field input{
  min-height:40px;
  height:40px;
}

.app-fin-form-field select{
  min-height:40px;
  height:40px;
  cursor:pointer;
}

.app-fin-form-field textarea{
  min-height:92px;
  padding:10px 0;
  resize:vertical;
}

.app-fin-form-field input::placeholder,
.app-fin-form-field textarea::placeholder{
  color:#9CA3AF;
  opacity:1;
  font-weight:400;
}

.app-fin-form-field input:disabled,
.app-fin-form-field select:disabled,
.app-fin-form-field textarea:disabled{
  cursor:not-allowed;
}

.app-fin-form-field.is-inactive{
  opacity:1;
}

.app-fin-form-field.is-inactive label{
  color:#9CA3AF;
}

.app-fin-form-field.is-inactive .app-fin-input-wrap{
  background:rgba(243,244,246,.75);
  border-color:rgba(229,231,235,.9);
}

.app-fin-form-field.is-inactive .app-fin-input-wrap__icon,
.app-fin-form-field.is-inactive input,
.app-fin-form-field.is-inactive select,
.app-fin-form-field.is-inactive textarea{
  color:#9CA3AF;
  -webkit-text-fill-color:#9CA3AF;
}

/* =========================================================
   BLOCO 4 — AÇÕES / FEEDBACK
========================================================= */

.app-fin-form-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  margin-top:4px;
}

.app-fin-btn-primary{
  min-height:42px;
  padding:0 14px;
  border:none;
  border-radius:14px;
  background:#111827;
  color:#fff;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  box-shadow:none;
  transition:none !important;
  transform:none !important;
}

.app-fin-btn-primary:hover,
.app-fin-btn-primary:focus,
.app-fin-btn-primary:focus-visible,
.app-fin-btn-primary:active{
  background:#111827;
  box-shadow:none;
  outline:none;
  transform:none !important;
}

.app-fin-btn-primary:disabled,
.app-fin-btn-primary.is-loading{
  opacity:.65;
  cursor:not-allowed;
}

.app-fin-btn-secondary{
  min-height:42px;
  padding:0 14px;
  border:1px solid rgba(17,24,39,.08);
  border-radius:14px;
  background:#fff;
  color:#111827;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  box-shadow:none;
  transition:none !important;
  transform:none !important;
}

.app-fin-btn-secondary:hover,
.app-fin-btn-secondary:focus,
.app-fin-btn-secondary:focus-visible,
.app-fin-btn-secondary:active{
  border-color:rgba(17,24,39,.12);
  background:#F9FAFB;
  box-shadow:none;
  outline:none;
  transform:none !important;
}

.app-fin-form-feedback{
  margin-top:10px;
}

.app-fin-form-notice{
  padding:12px 14px;
  border-radius:14px;
  font-size:13px;
  line-height:1.45;
  font-weight:600;
}

.app-fin-form-notice.is-error{
  background:#FEF2F2;
  color:#991B1B;
  border:1px solid rgba(220,38,38,.12);
}

.app-fin-form-notice.is-success{
  background:#ECFDF5;
  color:#065F46;
  border:1px solid rgba(5,150,105,.12);
}

/* =========================================================
   BLOCO 5 — SWITCH
========================================================= */

.app-fin-switch-field{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:40px;
  width:100%;
  cursor:pointer;
}

.app-fin-switch-field input[type="checkbox"]{
  display:none;
}

.app-fin-switch-ui{
  position:relative;
  width:38px;
  height:22px;
  border-radius:999px;
  background:#D1D5DB;
  flex:0 0 38px;
}

.app-fin-switch-ui::after{
  content:"";
  position:absolute;
  top:3px;
  left:3px;
  width:16px;
  height:16px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.12);
}

.app-fin-switch-field input[type="checkbox"]:checked + .app-fin-switch-ui{
  background:#111827;
}

.app-fin-switch-field input[type="checkbox"]:checked + .app-fin-switch-ui::after{
  left:19px;
}

.app-fin-switch-text{
  font-size:13px;
  line-height:1.3;
  font-weight:600;
  color:#111827;
}

/* =========================================================
   BLOCO 6 — BLOCO CONDICIONAL
========================================================= */

.app-fin-conditional{
  display:none;
  margin-top:2px;
  padding:12px;
  border:1px solid rgba(17,24,39,.08);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(248,250,252,.96), rgba(255,255,255,.96));
}

.app-fin-conditional.is-open{
  display:block;
}

.app-fin-conditional__head{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-bottom:10px;
}

.app-fin-conditional__title{
  font-size:12px;
  line-height:1.25;
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:#111827;
}

.app-fin-conditional__text{
  font-size:12px;
  line-height:1.45;
  font-weight:500;
  color:#6B7280;
}

/* =========================================================
   BLOCO 7 — MOBILE
========================================================= */

@media (max-width: 767px){
  .app-fin-modal{
    padding:10px;
    align-items:flex-end;
  }

  .app-fin-modal__dialog{
    max-width:none;
    max-height:calc(100vh - 20px);
    border-radius:22px 22px 0 0;
  }

  .app-fin-modal__header{
    padding:16px 16px 10px;
  }

  .app-fin-modal__title{
    font-size:20px;
  }

  .app-fin-modal__body{
    padding:14px 16px 16px;
    max-height:calc(100vh - 110px);
  }

  .app-fin-modal.is-card-expense-modal{
    align-items:flex-end;
    padding-top:10px;
  }

  .app-fin-form-grid--2{
    grid-template-columns:1fr;
  }

  .app-fin-form-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .app-fin-btn-primary,
  .app-fin-btn-secondary{
    width:100%;
  }
}

/* =========================================================
   BLOCO 8 — TRAVA DE SCROLL
========================================================= */

html.app-fin-modal-lock,
body.app-fin-modal-lock{
  overflow:hidden !important;
}