.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-password.compact{
    height:54px;
    padding:8px 10px;
}

.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-password.compact .rfid-circuit{
    grid-template-columns:34px minmax(44px,1fr) 58px minmax(44px,1fr) 34px;
}

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

.rfid-password .rfid-block,
.rfid-password .rfid-coils,
.rfid-password .rfid-chip{
    color:inherit;
    margin-bottom:0;
    text-transform:none;
}

.rfid-password.compact .rfid-block{
    height:34px;
    width:34px;
}

.rfid-block::before,
.rfid-block::after{
    background:#232323;
    content:"";
    display:none;
    height:7px;
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    transition:background .16s ease, box-shadow .16s ease;
    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-password .rfid-coils{
    display:flex;
}

.rfid-password.compact .rfid-coils{
    height:34px;
}

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

.rfid-password.compact .rfid-coils svg{
    height:34px;
}

.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-password .rfid-chip{
    display:flex;
}

.rfid-password.compact .rfid-chip{
    border-width:3px;
    height:20px;
    width:58px;
}

.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{
    background:var(--yellow);
    border-color: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;
}
