:root{--bg:#080a12;--card:#0f1320;--bd:#1f2740;--bd2:#2e3a5e;
--txt:#F5F5F7;--dim:#9CA3AF;--pri:#4D5FFF;--sec:#00E0FF;--ok:#3DDC97;--dng:#FF4F64;--warn:#F4B740}
*{box-sizing:border-box;margin:0;padding:0;font-family:'Inter',system-ui,sans-serif}
body{background:radial-gradient(circle at 50% 0%,#10142a,#080a12);color:var(--txt);min-height:100vh}
.boot{display:grid;place-items:center;height:100vh;color:var(--dim)}
.wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.card{width:100%;max-width:440px;background:rgba(15,19,32,.92);border:1px solid var(--bd2);
border-radius:18px;padding:30px 26px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.brand{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:800;margin-bottom:4px}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--sec);box-shadow:0 0 10px var(--sec)}
.sub{color:var(--dim);font-size:14px;margin-bottom:22px}
label{display:block;font-size:13px;color:var(--dim);margin:14px 0 6px}
input{width:100%;height:52px;padding:0 16px;background:rgba(255,255,255,.04);
border:1px solid var(--bd);border-radius:12px;color:var(--txt);font-size:18px;outline:none}
input:focus{border-color:var(--pri);box-shadow:0 0 0 4px rgba(77,95,255,.15)}
button{appearance:none;border:none;cursor:pointer;font-family:inherit;font-weight:700;
border-radius:12px;transition:transform .08s,background .12s}
button:active{transform:scale(.98)}
.btn{width:100%;height:54px;font-size:17px;color:#fff;margin-top:18px;
background:linear-gradient(135deg,var(--pri),#6B7DFF)}
.btn[disabled]{opacity:.6;cursor:default}
.msg{margin-top:14px;padding:11px 14px;border-radius:10px;font-size:14px;border-left:3px solid}
.msg.err{background:rgba(255,79,100,.1);color:#FFD0D6;border-color:var(--dng)}
.msg.ok{background:rgba(61,220,151,.1);color:#BEFFE0;border-color:var(--ok)}
.msg.info{background:rgba(0,224,255,.08);color:#CFF;border-color:var(--sec)}
/* Kiosko */
.kwrap{min-height:100vh;display:flex;flex-direction:column}
.khead{display:flex;justify-content:space-between;align-items:center;padding:18px 26px;
border-bottom:1px solid var(--bd)}
.kbody{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px}
.kgrid{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;max-width:1000px}
.tile{width:180px;background:var(--card);border:1px solid var(--bd);border-radius:16px;
padding:18px;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:all .12s}
.tile:hover{border-color:var(--bd2);transform:translateY(-2px)}
.av{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;
font-size:22px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--pri),var(--sec));margin-bottom:10px}
.tn{font-weight:700}.tr{font-size:12px;color:var(--dim);margin-top:3px}
.pin-dots{display:flex;gap:12px;justify-content:center;margin:18px 0}
.pd{width:16px;height:16px;border-radius:50%;border:2px solid var(--bd2)}
.pd.on{background:var(--pri);border-color:var(--pri);box-shadow:0 0 10px var(--pri)}
.keypad{display:grid;grid-template-columns:repeat(3,84px);gap:12px;justify-content:center}
.key{height:74px;border-radius:14px;background:var(--card);border:1px solid var(--bd);
color:var(--txt);font-size:26px;font-weight:700}
.key:hover{background:#172036}.key.ko{background:linear-gradient(135deg,var(--ok),#5DFFB1);color:#052819;border:none}
.key.kb{background:rgba(255,90,108,.1);color:var(--dng)}
.muted{color:var(--dim);font-size:13px}
.link{background:none;color:var(--sec);font-size:13px;width:auto;height:auto;margin-top:14px;text-decoration:underline}
