*{
margin:0;
padding:0;
box-sizing:border-box;
}

/* LOGIN */
.login-body{
font-family:Arial,sans-serif;
background:url("https://www.sigemsistemas.com.br/appmobile/imagem-fundo.jpeg") no-repeat center center;
background-size:cover;
min-height:100svh;
display:flex;
justify-content:center;
align-items:center;
padding:16px;
}

.layout-login{
width:100%;
display:flex;
flex-direction:column;
align-items:center;
}

.logo-topo{
width:160px;
height:160px;
object-fit:cover;
border-radius:50%;
margin-bottom:18px;
border:4px solid #ffffff;
box-shadow:0 4px 12px rgba(0,0,0,0.20);
opacity: 0.7;
}

.card{
background:rgba(255,255,255,0.92);
border-radius:20px;
box-shadow:0 4px 12px rgba(0,0,0,0.20);
width:100%;
text-align:center;
}

.login-card{
max-width:500px;
padding:28px 24px 24px 24px;
}

.card h2{
margin-bottom:22px;
color:#333;
font-size:26px;
font-weight:700;
}

.card input{
width:100%;
padding:14px;
margin:10px 0;
border:1px solid #ccc;
border-radius:8px;
font-size:16px;
font-family:Arial,sans-serif;
}

.card button{
width:100%;
padding:14px;
background:#1976d2;
color:#fff;
border:none;
border-radius:8px;
font-size:18px;
font-family:Arial,sans-serif;
cursor:pointer;
}

.msg-erro{
color:#e00000;
margin-top:12px;
font-weight:700;
font-size:18px;
line-height:1.4;
}

.area-voltar{
width:100%;
display:flex;
justify-content:center;
align-items:center;
margin-top:30px;
}

.btn-voltar-simples{
display:inline-flex;
align-items:center;
justify-content:center;
text-decoration:none;
background:transparent;
border:none;
cursor:pointer;
width:72px;
height:52px;
}

.btn-voltar-seta{
font-size:52px;
line-height:1;
font-weight:700;
color:#24364a;
display:inline-block;
}

/* PORTAL */
.portal-body{
margin:0;
padding:0;
min-height:100svh;
font-family:Arial,sans-serif;
background:#1b2836;
color:#fff;
overflow-x:hidden;
}

.portal-body.menu-aberto{
overflow:hidden;
}

.topbar{
position:fixed;
top:0;
left:0;
right:0;
height:64px;
background:#152332;
display:flex;
align-items:center;
padding:0 16px;
box-shadow:0 2px 10px rgba(0,0,0,0.25);
z-index:1200;
}

.topbar-left{
display:flex;
align-items:center;
gap:14px;
width:100%;
min-width:0;
}

.topbar-title{
font-size:20px;
font-weight:700;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
min-width:0;
}

.menu-btn{
width:44px;
height:44px;
border:none;
background:transparent;
display:flex;
flex-direction:column;
justify-content:center;
align-items:center;
gap:5px;
cursor:pointer;
flex-shrink:0;
}

.menu-btn span{
display:block;
width:24px;
height:3px;
border-radius:3px;
background:#ffffff;
}

.menu-overlay{
position:fixed;
inset:0;
background:rgba(0,0,0,0.45);
opacity:0;
visibility:hidden;
transition:all .25s ease;
z-index:1090;
}

.menu-overlay.ativo{
opacity:1;
visibility:visible;
}

.sidebar{
position:fixed;
top:0;
bottom:0;
left:0;
width:min(86vw, 360px);
background:#1d2b3a;
transform:translateX(-100%);
transition:transform .28s ease;
z-index:1100;
box-shadow:4px 0 20px rgba(0,0,0,0.35);
overflow:hidden;
}

.sidebar.ativo{
transform:translateX(0);
}

.sidebar-header{
position:absolute;
top:0;
left:0;
right:0;
height:84px;
padding:18px;
display:flex;
justify-content:space-between;
align-items:center;
background:#152332;
z-index:2;
}

.sidebar-title{
font-size:20px;
font-weight:600;
color:#ffffff;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
max-width:75%;
}

.close-btn{
border:none;
background:transparent;
color:#ffffff;
font-size:30px;
cursor:pointer;
line-height:1;
}

.sidebar-scroll{
position:absolute;
top:84px;
bottom:210px;
left:0;
right:0;
overflow-y:auto;
-webkit-overflow-scrolling:touch;
}

.sidebar-content{
padding:18px;
display:flex;
flex-direction:column;
gap:18px;
}

.sidebar-footer{
position:absolute;
left:0;
right:0;
bottom:0;
padding:18px;
background:#1d2b3a;
border-top:1px solid rgba(255,255,255,0.08);
z-index:2;
}

.menu-card{
background:#3b4b5c;
border-radius:20px;
padding:16px;
display:flex;
align-items:center;
gap:14px;
}

.menu-card-icone,
.menu-item-icone{
width:44px;
height:44px;
background:#223244;
border-radius:12px;
display:flex;
align-items:center;
justify-content:center;
flex-shrink:0;
color:#fff;
}

.menu-card-icone svg,
.menu-item-icone svg,
.logout-icone svg,
.home-card-icon svg,
.icone-acao svg{
width:22px;
height:22px;
fill:currentColor;
display:block;
}

.menu-card-texto{
font-size:18px;
font-weight:600;
}

.menu-item{
display:flex;
align-items:center;
gap:14px;
padding:12px;
border-radius:12px;
text-decoration:none;
color:#fff;
}

.menu-item:hover{
background:rgba(255,255,255,0.06);
}

.menu-item-titulo{
font-size:20px;
font-weight:600;
}

.divisor{
height:1px;
background:rgba(255,255,255,0.10);
margin:10px 8px;
}

.usuario-box{
background:#2a3948;
border-radius:20px;
padding:16px;
margin-bottom:10px;
}

.usuario-nome{
font-size:20px;
font-weight:600;
margin-bottom:6px;
}

.usuario-email{
font-size:14px;
color:#2fa043;
word-break:break-word;
line-height:1.35;
}

.logout-link{
display:flex;
align-items:center;
gap:10px;
color:#fff;
text-decoration:none;
font-size:18px;
font-weight:600;
}

.logout-icone{
display:flex;
align-items:center;
justify-content:center;
color:#fff;
}

.main{
padding:90px 16px 24px 16px;
min-height:100svh;
}

.dashboard-cards{
max-width:920px;
margin:0 auto;
display:flex;
flex-direction:column;
gap:22px;
}

.loading-box{
max-width:920px;
margin:0 auto 6px auto;
background:rgba(255,255,255,0.10);
border:1px solid rgba(255,255,255,0.10);
border-radius:18px;
padding:14px 16px;
display:flex;
align-items:center;
gap:12px;
}

.loading-spinner{
width:18px;
height:18px;
border:3px solid rgba(255,255,255,0.25);
border-top-color:#ffffff;
border-radius:50%;
animation:giroLoading 1s linear infinite;
flex-shrink:0;
}

.loading-texto{
font-size:15px;
line-height:1.4;
color:#ffffff;
}

.erro-box{
max-width:920px;
margin:0 auto 8px auto;
background:rgba(224,0,0,0.16);
border:1px solid rgba(255,255,255,0.08);
border-radius:18px;
padding:14px 16px;
font-size:15px;
color:#ffffff;
}

@keyframes giroLoading{
from{transform:rotate(0deg);}
to{transform:rotate(360deg);}
}

.home-card{
background:#f3f3f3;
color:#1f1f1f;
border-radius:24px;
padding:22px 24px;
box-shadow:0 6px 14px rgba(0,0,0,0.18);
}

.home-card-header{
display:flex;
align-items:flex-start;
gap:18px;
}

.home-card-icon{
width:44px;
height:44px;
flex-shrink:0;
display:flex;
align-items:center;
justify-content:center;
color:#1f1f1f;
}

.saldo-textos,
.repasse-textos{
flex:1;
min-width:0;
}

.saldo-linha{
display:flex;
align-items:center;
gap:14px;
flex-wrap:wrap;
margin-bottom:8px;
}

.saldo-label{
font-size:24px;
font-weight:500;
color:#1f1f1f;
}

.saldo-valor{
font-size:24px;
font-weight:500;
}

.saldo-negativo{
color:#8d39c9;
}

.saldo-positivo{
color:#1f1f1f;
}

.home-card-title{
font-size:22px;
font-weight:500;
line-height:1.2;
margin-bottom:8px;
}

.home-card-desc{
font-size:16px;
line-height:1.45;
color:#5e5e5e;
max-width:560px;
}

.icone-acao{
width:36px;
height:36px;
border:none;
background:transparent;
display:flex;
align-items:center;
justify-content:center;
cursor:pointer;
flex-shrink:0;
margin-top:2px;
color:#1f1f1f;
}

.home-card-footer{
margin-top:18px;
display:flex;
}

.home-card-footer-right{
justify-content:flex-end;
}

.link-destaque{
text-decoration:none;
font-size:20px;
font-weight:700;
color:#6d52b7;
}

.repasse-tabela{
margin-top:20px;
}

.repasse-head{
display:grid;
grid-template-columns:1fr 1fr 1.2fr;
border:2px solid #9b9b9b;
border-radius:12px;
padding:8px 16px;
font-size:18px;
font-weight:500;
text-align:center;
color:#1f1f1f;
background:rgba(255,255,255,0.65);
}

.repasse-row{
display:grid;
grid-template-columns:1fr 1fr 1.2fr;
padding:10px 16px 0 16px;
font-size:18px;
text-align:center;
color:#1f1f1f;
}

.repasse-vazio{
padding:18px 6px 6px 6px;
font-size:16px;
color:#5e5e5e;
text-align:center;
}

.lista-card{
max-width:1100px;
margin:0 auto;
background:#f3f3f3;
color:#1f1f1f;
border-radius:24px;
padding:22px 24px;
box-shadow:0 6px 14px rgba(0,0,0,0.18);
}

.lista-card-titulo{
font-size:24px;
font-weight:700;
margin-bottom:18px;
}

.lista-tabela{
width:100%;
overflow-x:auto;
}

.lista-head,
.lista-row{
display:grid;
gap:12px;
align-items:center;
}

.lista-head{
font-weight:700;
padding:12px 10px;
border-bottom:2px solid #d0d0d0;
min-width:720px;
}

.lista-row{
padding:12px 10px;
border-bottom:1px solid #e0e0e0;
min-width:720px;
}

.lista-extrato-grid{
grid-template-columns:1fr 1.2fr 1.2fr 1.2fr 1.2fr;
}

.lista-informe-grid{
grid-template-columns:.8fr 1.2fr 1.2fr 1.2fr 1.2fr;
}

.lista-vazia{
font-size:16px;
color:#5e5e5e;
padding:8px 0 4px 0;
}

@media(max-width:768px){

.login-card{
width:calc(100vw - 40px);
max-width:none;
padding:24px 18px 22px 18px;
}

.logo-topo{
width:140px;
height:140px;
}

.card h2{
font-size:24px;
}

.topbar-title{
font-size:16px;
}

.sidebar{
width:min(88vw, 340px);
}

.sidebar-scroll{
bottom:200px;
}

.dashboard-cards{
gap:18px;
}

.home-card{
padding:18px 18px;
border-radius:22px;
}

.home-card-header{
gap:14px;
}

.saldo-label,
.saldo-valor,
.home-card-title{
font-size:18px;
}

.home-card-desc{
font-size:14px;
}

.link-destaque{
font-size:18px;
}

.repasse-head,
.repasse-row{
font-size:16px;
padding-left:10px;
padding-right:10px;
}

.lista-card{
padding:18px 18px;
border-radius:22px;
}

.lista-card-titulo{
font-size:20px;
}
}

@media(max-width:420px){

.saldo-linha{
align-items:flex-start;
flex-direction:column;
gap:4px;
}

.home-card-footer-right{
justify-content:flex-start;
}

.repasse-head,
.repasse-row{
grid-template-columns:1fr 1fr 1fr;
font-size:14px;
}

.topbar-title{
font-size:15px;
}
}

/* EXTRATO EM CARDS - ISOLADO */
.extrato-main-card{
background:#1b2836;
padding-top:90px;
}

.extrato-page-title{
color:#ffffff;
font-size:20px;
font-weight:700;
text-align:center;
margin:0 0 22px 0;
}

.extrato-cards-lista{
max-width:920px;
margin:0 auto;
display:flex;
flex-direction:column;
gap:18px;
}

.extrato-card-mes{
background:#f3f3f3;
color:#222;
border-radius:20px;
box-shadow:0 3px 9px rgba(0,0,0,0.22);
display:flex;
overflow:hidden;
}

.extrato-card-barra{
width:24px;
flex-shrink:0;
}

.extrato-card-barra.negativo{
background:#a620bf;
}

.extrato-card-barra.positivo{
background:#38a947;
}

.extrato-card-conteudo{
width:100%;
padding:20px 22px 18px 22px;
}

.extrato-card-conteudo h2{
font-size:24px;
font-weight:700;
text-align:center;
color:#000;
margin:0 0 20px 0;
}

.extrato-card-subtitulo{
font-size:22px;
color:#666;
margin-bottom:14px;
}

.extrato-card-linha{
display:grid;
grid-template-columns:160px 1fr;
gap:10px;
font-size:16px;
line-height:1.35;
color:#555;
}

.extrato-card-linha strong{
font-weight:400;
color:#222;
}

.extrato-card-link-area{
display:flex;
justify-content:flex-end;
margin-top:22px;
}

.extrato-card-link{
font-size:17px;
font-weight:700;
color:#0066c9;
text-decoration:none;
}

@media(max-width:420px){
.extrato-page-title{
font-size:19px;
margin-bottom:18px;
}

.extrato-cards-lista{
gap:16px;
}

.extrato-card-mes{
border-radius:18px;
}

.extrato-card-barra{
width:26px;
}

.extrato-card-conteudo{
padding:18px 18px 16px 18px;
}

.extrato-card-conteudo h2{
font-size:22px;
margin-bottom:18px;
}

.extrato-card-subtitulo{
font-size:20px;
}

.extrato-card-linha{
grid-template-columns:145px 1fr;
font-size:15px;
}

.extrato-card-link{
font-size:16px;
}
}


/* INFORME EM CARDS - ISOLADO */
.informe-main-card{
background:#1b2836;
padding-top:90px;
}

.informe-page-title{
color:#ffffff;
font-size:20px;
font-weight:700;
text-align:center;
margin:0 0 22px 0;
}

.informe-cards-lista{
max-width:920px;
margin:0 auto;
display:flex;
flex-direction:column;
gap:18px;
}

.informe-card-ano{
background:#f3f3f3;
color:#222;
border-radius:20px;
box-shadow:0 3px 9px rgba(0,0,0,0.22);
overflow:hidden;
padding:20px 24px 18px 24px;
}

.informe-card-ano h2{
font-size:24px;
font-weight:700;
text-align:center;
color:#000;
margin:0 0 20px 0;
}

.informe-card-subtitulo{
font-size:22px;
color:#666;
margin-bottom:14px;
}

.informe-card-linha{
display:grid;
grid-template-columns:190px 1fr;
gap:10px;
font-size:16px;
line-height:1.35;
color:#555;
}

.informe-card-linha strong{
font-weight:400;
color:#222;
}

.informe-card-link-area{
display:flex;
justify-content:flex-end;
margin-top:22px;
}

.informe-card-link{
font-size:17px;
font-weight:700;
color:#0066c9;
text-decoration:none;
}

@media(max-width:420px){
.informe-page-title{
font-size:19px;
margin-bottom:18px;
}

.informe-cards-lista{
gap:16px;
}

.informe-card-ano{
border-radius:18px;
padding:18px 18px 16px 18px;
}

.informe-card-ano h2{
font-size:22px;
margin-bottom:18px;
}

.informe-card-subtitulo{
font-size:20px;
}

.informe-card-linha{
grid-template-columns:155px 1fr;
font-size:15px;
}

.informe-card-link{
font-size:16px;
}
}


/* BOLETOS - INQUILINO */
.boleto-main-card{background:#1b2836;padding-top:90px;}
.boleto-page-title{color:#ffffff;font-size:20px;font-weight:700;text-align:center;margin:0 0 22px 0;}
.boleto-cards-lista{max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:18px;}
.boleto-card{background:#f3f3f3;color:#222;border-radius:20px;box-shadow:0 3px 9px rgba(0,0,0,0.22);display:flex;overflow:hidden;}
.boleto-card-barra{width:24px;flex-shrink:0;background:#ff9400;}
.boleto-card-conteudo{width:100%;padding:22px 22px 18px 22px;}
.boleto-card-linha{display:flex;gap:10px;font-size:22px;line-height:1.55;color:#222;align-items:center;}
.boleto-card-linha strong{font-weight:400;}
.boleto-card-link-area{display:flex;justify-content:flex-end;margin-top:20px;}
.boleto-card-link{font-size:17px;font-weight:700;color:#6d52b7;text-decoration:none;}
.boleto-laranja{color:#ff9400 !important;}
.boleto-atual-box{font-size:18px;line-height:1.5;color:#1f1f1f;margin-top:14px;}
.boleto-atual-linha{margin-bottom:8px;}
.boleto-atual-linha strong{font-weight:400;}
.boleto-linha-digitavel-wrap strong{color:#777;word-break:break-word;}
.btn-copiar-boleto{margin-top:8px;background:#f5effc;color:#6d52b7;border:none;border-radius:18px;padding:10px 14px;font-size:15px;font-weight:700;cursor:pointer;}
@media(max-width:420px){.boleto-page-title{font-size:19px;margin-bottom:18px;}.boleto-card{border-radius:18px;}.boleto-card-barra{width:26px;}.boleto-card-conteudo{padding:18px 18px 16px 18px;}.boleto-card-linha{font-size:18px;line-height:1.5;}.boleto-card-link{font-size:16px;}.boleto-atual-box{font-size:16px;}}


/* QUITAÇÃO ANUAL - INQUILINO */
.quitacao-card{
background:#f3f3f3;
}

.quitacao-textos{
flex:1;
min-width:0;
}

.quitacao-mensagem{
font-size:18px;
line-height:1.45;
color:#333;
margin-top:18px;
}

.quitacao-footer{
margin-top:18px;
justify-content:center;
}

.btn-quitacao{
display:inline-flex;
align-items:center;
justify-content:center;
text-align:center;
background:#f5effc;
color:#6d52b7;
border-radius:24px;
padding:12px 20px;
font-size:18px;
font-weight:700;
text-decoration:none;
min-width:220px;
}

.btn-quitacao:before{
content:"✓";
font-size:20px;
margin-right:10px;
}

.btn-quitacao.desabilitado{
opacity:.55;
cursor:default;
}

@media(max-width:420px){
.quitacao-mensagem{
font-size:16px;
}
.btn-quitacao{
font-size:16px;
width:100%;
}
}



/* BALANCETES - CONDOMÍNIO */
.balancete-main-card{
background:#1b2836;
padding-top:90px;
}

.balancete-page-title{
color:#ffffff;
font-size:20px;
font-weight:700;
text-align:center;
margin:0 0 22px 0;
}

.balancete-cards-lista{
max-width:920px;
margin:0 auto;
display:flex;
flex-direction:column;
gap:18px;
}

.balancete-card-mes{
background:#f3f3f3;
color:#222;
border-radius:20px;
box-shadow:0 3px 9px rgba(0,0,0,0.22);
display:flex;
overflow:hidden;
}

.balancete-card-barra{
width:24px;
flex-shrink:0;
}

.balancete-card-barra.negativo{
background:#a620bf;
}

.balancete-card-barra.positivo{
background:#38a947;
}

.balancete-card-conteudo{
width:100%;
padding:20px 22px 18px 22px;
}

.balancete-card-conteudo h2{
font-size:24px;
font-weight:700;
text-align:center;
color:#000;
margin:0 0 20px 0;
}

.balancete-card-subtitulo{
font-size:22px;
color:#666;
margin-bottom:14px;
}

.balancete-card-linha{
display:grid;
grid-template-columns:160px 1fr;
gap:10px;
font-size:16px;
line-height:1.35;
color:#555;
}

.balancete-card-linha strong{
font-weight:400;
color:#222;
}

.balancete-card-link-area{
display:flex;
justify-content:flex-end;
margin-top:22px;
}

.balancete-card-link{
font-size:17px;
font-weight:700;
color:#0066c9;
text-decoration:none;
}

.boleto-atraso-titulo{
color:#8d39c9 !important;
font-weight:700;
}

@media(max-width:420px){
.balancete-page-title{
font-size:19px;
margin-bottom:18px;
}

.balancete-cards-lista{
gap:16px;
}

.balancete-card-mes{
border-radius:18px;
}

.balancete-card-barra{
width:26px;
}

.balancete-card-conteudo{
padding:18px 18px 16px 18px;
}

.balancete-card-conteudo h2{
font-size:22px;
margin-bottom:18px;
}

.balancete-card-subtitulo{
font-size:20px;
}

.balancete-card-linha{
grid-template-columns:145px 1fr;
font-size:15px;
}

.balancete-card-link{
font-size:16px;
}
}



/* RECUPERAR SENHA NA INDEX */
.frase-recuperar{
text-align:center;
margin-top:18px;
font-size:14px;
color:#ffffff;
text-shadow:0 1px 3px rgba(0,0,0,0.45);
}

.frase-recuperar a{
color:#ffffff;
font-weight:700;
text-decoration:underline;
}

.frase-recuperar a:hover{
text-decoration:none;
}

.modal-recuperar{
position:fixed;
top:0;
left:0;
right:0;
bottom:0;
background:rgba(0,0,0,0.55);
display:none;
align-items:center;
justify-content:center;
z-index:9999;
padding:18px;
}

.modal-box{
background:#ffffff;
padding:24px 22px;
border-radius:18px;
width:100%;
max-width:380px;
text-align:center;
box-shadow:0 6px 18px rgba(0,0,0,0.28);
}

.modal-box h3{
font-size:22px;
color:#333333;
margin-bottom:14px;
}

.modal-box input{
width:100%;
padding:14px;
margin-top:10px;
border:1px solid #cccccc;
border-radius:8px;
font-size:16px;
font-family:Arial,sans-serif;
}

.modal-box button{
width:100%;
padding:14px;
margin-top:14px;
background:#1976d2;
color:#ffffff;
border:none;
border-radius:8px;
font-size:17px;
font-family:Arial,sans-serif;
font-weight:700;
cursor:pointer;
}

.modal-box button:disabled{
opacity:.65;
cursor:default;
}

.fechar-modal{
margin-top:14px;
color:#666666;
font-size:15px;
cursor:pointer;
}

.msg-recuperar{
margin-top:12px;
font-size:14px;
line-height:1.35;
min-height:18px;
}

.msg-recuperar.sucesso{
color:#177a2f;
font-weight:700;
}

.msg-recuperar.erro{
color:#d00000;
font-weight:700;
}

/* TOAST / MENSAGENS RÁPIDAS */
.toast-mensagem{
position:fixed;
left:50%;
bottom:28px;
transform:translateX(-50%);
background:#111;
color:#fff;
padding:12px 18px;
border-radius:10px;
font-size:15px;
font-family:Arial,sans-serif;
z-index:9999;
box-shadow:0 4px 12px rgba(0,0,0,0.28);
text-align:center;
max-width:90vw;
}

.desabilitado{
opacity:0.55;
pointer-events:none;
}


/* AJUSTE FONTE TOPO PORTAL */
.topbar-title{
font-size:20px;
}

@media(max-width:768px){
.topbar-title{
font-size:18px;
}
}

@media(max-width:420px){
.topbar-title{
font-size:17px;
}
}
