.login-page{
    align-items:center;
    background:
        linear-gradient(90deg, rgba(255,213,0,.08), transparent 34%),
        var(--bg);
    display:flex;
    justify-content:center;
    min-height:100vh;
    padding:24px;
}

.login-panel{
    background:var(--panel);
    border:1px solid var(--border);
    border-radius:8px;
    max-width:420px;
    overflow:hidden;
    width:100%;
}

.login-brand{
    background:#0b0b0b;
    border-bottom:1px solid var(--border-soft);
    padding:28px;
}

.login-brand span{
    color:#fff;
    display:block;
    font-size:28px;
    font-weight:600;
    line-height:1;
    text-align:center;
}

.login-brand strong{
    color:var(--yellow);
}

.login-brand p{
    color:var(--muted);
    font-size:13px;
    margin-top:10px;
    text-transform:uppercase;
}

.login-form{
    display:grid;
    gap:16px;
    padding:28px;
}

.login-form label span{
    color:var(--muted);
    display:block;
    font-size:12px;
    margin-bottom:8px;
    text-transform:uppercase;
}

.login-form input{
    background:#050505;
    border:1px solid #252525;
    border-radius:6px;
    color:var(--text);
    height:42px;
    outline:0;
    padding:0 12px;
    width:100%;
}

.login-form input:focus{
    border-color:var(--yellow);
}

.login-form input:disabled{
    cursor:not-allowed;
    opacity:.55;
}

.login-form button{
    background:var(--yellow);
    border:0;
    border-radius:6px;
    color:#000;
    cursor:pointer;
    font-weight:600;
    height:42px;
}

.login-form button:disabled{
    background:#2a2a2a;
    color:#777;
    cursor:not-allowed;
}

.login-error{
    align-items:center;
    border-radius:6px;
    display:flex;
    gap:12px;
    justify-content:space-between;
    font-size:12px;
    line-height:1.5;
    padding:10px 12px;
}

.login-error{
    background:rgba(255,92,92,.12);
    border:1px solid rgba(255,92,92,.35);
    color:#ffb0b0;
}

.login-error span{
    min-width:0;
}

.login-error button{
    background:#2a1010;
    border:1px solid rgba(255,92,92,.45);
    border-radius:5px;
    color:#ffd0d0;
    cursor:pointer;
    flex:0 0 auto;
    font-size:12px;
    height:28px;
    padding:0 10px;
}

.login-error button:hover{
    background:#3a1515;
    color:#fff;
}

.rfid-password{
    background:#050505;
    border:1px solid #252525;
    border-radius:6px;
    cursor:text;
    height:72px;
    overflow:hidden;
    padding:12px 16px;
}

.rfid-password:focus-within,
.rfid-password.active{
    border-color:var(--yellow);
}

.rfid-hidden-input{
    height:1px !important;
    opacity:0;
    padding:0 !important;
    pointer-events:none;
    position:absolute;
    width:1px !important;
}

.rfid-circuit{
    align-items:center;
    display:grid;
    grid-template-columns:42px minmax(62px,1fr) 78px minmax(62px,1fr) 42px;
    gap:0;
    height:100%;
    position:relative;
}

.rfid-block{
    background:#232323;
    border:1px solid #303030;
    border-radius:5px;
    display:block;
    height:42px;
    position:relative;
    width:42px;
}

.rfid-block::before,
.rfid-block::after{
    background:#232323;
    content:"";
    height:7px;
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    transition:background .16s ease, box-shadow .16s ease;
    display:none;
    width:0;
}

.rfid-block:first-child::after{
    right:-12px;
}

.rfid-block:last-child::before{
    left:-12px;
}

.rfid-coils{
    align-items:center;
    display:flex;
    height:42px;
    min-width:0;
    overflow:hidden;
    position:relative;
}

.rfid-coils svg{
    display:block;
    height:42px;
    width:100%;
}

.rfid-coils path{
    fill:none;
    stroke:#232323;
    stroke-linecap:round;
    stroke-linejoin:round;
    stroke-width:7;
    transition:stroke .16s ease, filter .16s ease;
}

.rfid-chip{
    align-items:center;
    background:#232323;
    border:4px solid #232323;
    border-radius:7px;
    display:flex;
    flex-direction:column;
    height:24px;
    justify-content:center;
    position:relative;
    width:78px;
}

.rfid-chip::before,
.rfid-chip::after{
    background:transparent;
    content:"";
    height:4px;
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:16px;
}

.rfid-chip::before{
    left:-18px;
}

.rfid-chip::after{
    right:-18px;
}

.rfid-block.active{
    border-color:var(--yellow);
    background:var(--yellow);
    box-shadow:0 0 10px rgba(255,213,0,.42);
}

.rfid-block.active::before,
.rfid-block.active::after,
.rfid-chip.active::before,
.rfid-chip.active::after{
    background:var(--yellow);
    box-shadow:0 0 10px rgba(255,213,0,.42);
}

.rfid-chip.active{
    background:var(--yellow);
    border-color:var(--yellow);
    box-shadow:0 0 10px rgba(255,213,0,.42);
}

.rfid-coils.active path{
    filter:drop-shadow(0 0 6px rgba(255,213,0,.55));
    stroke:var(--yellow);
}

.rfid-password.invalid{
    border-color:#ff5c5c;
}

.rfid-password.invalid .rfid-block,
.rfid-password.invalid .rfid-chip{
    background:#ff5c5c;
    border-color:#ff5c5c;
    box-shadow:0 0 10px rgba(255,92,92,.48);
}

.rfid-password.invalid .rfid-block::before,
.rfid-password.invalid .rfid-block::after,
.rfid-password.invalid .rfid-chip::before,
.rfid-password.invalid .rfid-chip::after{
    background:#ff5c5c;
    box-shadow:0 0 10px rgba(255,92,92,.48);
}

.rfid-password.invalid .rfid-coils path{
    filter:drop-shadow(0 0 6px rgba(255,92,92,.55));
    stroke:#ff5c5c;
}
