*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:Inter,sans-serif;
}

:root{
--preto:#050505;
--preto-card:#111111;
--branco:#ffffff;
--cinza:#a1a1a1;
--dourado:#c08b42;
--dourado-claro:#e3b760;
--borda:rgba(192,139,66,.28);
}

body{
background:var(--preto);
min-height:100vh;
display:flex;
justify-content:center;
align-items:center;
overflow:hidden;
}

.bg{
position:fixed;
width:100%;
height:100%;
background:
radial-gradient(circle at 50% 0%,rgba(192,139,66,.23),transparent 38%),
linear-gradient(135deg,#030303,#101010 55%,#050505);
}

.bg::before{
content:"";
position:absolute;
inset:0;
background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
background-size:42px 42px;
mask-image:radial-gradient(circle at center,black,transparent 72%);
}

.login-box{
position:relative;
width:440px;
background:rgba(17,17,17,.92);
border:1px solid var(--borda);
border-radius:28px;
padding:46px;
box-shadow:0 35px 100px rgba(0,0,0,.7);
z-index:2;
animation:subir .55s ease;
}

@keyframes subir{
from{
opacity:0;
transform:translateY(30px);
}
to{
opacity:1;
transform:translateY(0);
}
}

.logo{
text-align:center;
margin-bottom:34px;
}

.logo img{
width:165px;
margin-bottom:22px;
filter:drop-shadow(0 12px 30px rgba(0,0,0,.55));
}

.logo h2{
color:var(--branco);
font-size:28px;
font-weight:900;
letter-spacing:-.5px;
}

.logo p{
margin-top:8px;
color:var(--cinza);
}

.campo{
margin-bottom:20px;
}

label{
display:block;
margin-bottom:8px;
color:#eeeeee;
font-size:14px;
font-weight:700;
}

input{
width:100%;
padding:15px;
border-radius:14px;
border:1px solid #2c2c2c;
background:#0d0d0d;
color:white;
font-size:15px;
outline:none;
transition:.25s;
}

input:focus{
border-color:var(--dourado);
box-shadow:0 0 0 3px rgba(192,139,66,.16);
}

button{
width:100%;
padding:16px;
background:linear-gradient(135deg,var(--dourado),var(--dourado-claro));
border:none;
border-radius:14px;
color:#080808;
font-size:16px;
font-weight:900;
cursor:pointer;
transition:.25s;
}

button:hover{
transform:translateY(-2px);
filter:brightness(1.08);
box-shadow:0 15px 40px rgba(192,139,66,.18);
}

#erro{
margin-bottom:18px;
text-align:center;
color:#ff8b8b;
font-size:14px;
}

@media(max-width:520px){
.login-box{
width:92%;
padding:32px 22px;
}

.logo h2{
font-size:23px;
}
}
.modal-bg{
    align-items:flex-start!important;
    padding:35px 20px!important;
    overflow-y:auto!important;
}

.modal{
    max-height:none!important;
    margin-bottom:40px!important;
}

.upload-ref{
    position:relative;
    border:1px dashed rgba(192,139,66,.45);
    background:#0b0b0b;
    border-radius:16px;
    padding:18px;
    display:flex;
    align-items:center;
    gap:15px;
    cursor:pointer;
    margin-bottom:20px;
}

.upload-ref i{
    font-size:32px;
    color:#c08b42;
}

.upload-ref strong{
    color:#fff;
    display:block;
    margin-bottom:4px;
}

.upload-ref p{
    color:#aaa;
    font-size:13px;
    margin-bottom:6px;
}

.upload-ref span{
    color:#e3b760;
    font-weight:700;
    font-size:13px;
}

.upload-ref input{
    position:absolute;
    inset:0;
    opacity:0;
    cursor:pointer;
}