*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#0f1115;color:#e8eaf0}button{font:inherit;padding:.55rem .9rem;border-radius:6px;border:1px solid #2a2f3a;background:#1b1f29;color:#e8eaf0;cursor:pointer}button:hover:not(:disabled){background:#242a37}button:disabled{opacity:.5;cursor:not-allowed}input,select{font:inherit;padding:.55rem .7rem;border-radius:6px;border:1px solid #2a2f3a;background:#11141b;color:#e8eaf0}a{color:#69b8ff;text-decoration:none}.app{min-height:100vh;display:flex;flex-direction:column}.main{padding:1.5rem;max-width:1100px;margin:0 auto;width:100%}.nav{display:flex;gap:1rem;align-items:center;padding:.75rem 1.25rem;background:#151823;border-bottom:1px solid #232838}.nav .brand{font-weight:600}.nav .links{display:flex;gap:1rem;flex:1}.nav .who{display:flex;gap:.75rem;align-items:center}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dot.on{background:#3ad17a}.dot.off{background:#d14a3a}.loading{padding:2rem;text-align:center}.card{background:#151823;border:1px solid #232838;border-radius:10px;padding:1.25rem;margin-bottom:1.25rem}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.banner{padding:.75rem 1rem;background:#1f2a3a;border:1px solid #2a3a52;border-radius:6px;margin-bottom:1rem}.err{color:#ff7d7d;font-size:.9rem}.login{max-width:360px;margin:5rem auto;display:flex;flex-direction:column;gap:.75rem;background:#151823;padding:1.5rem;border-radius:10px;border:1px solid #232838}.login label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.login h1{margin:0 0 .5rem}.dialer{display:grid;gap:1rem}.status{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.5rem;background:#151823;border:1px solid #232838;padding:1rem;border-radius:10px;font-size:.9rem}.dialpad{background:#151823;border:1px solid #232838;padding:1.25rem;border-radius:10px;display:grid;gap:.75rem;max-width:360px}.dialpad .number{font-size:1.4rem;text-align:center}.dialpad .keys{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.dialpad .keys button{font-size:1.4rem;padding:1rem}.dialpad .call{background:#1d6b3a;border-color:#1d6b3a;font-weight:600;font-size:1.1rem;padding:.9rem}.controls{display:flex;gap:.5rem;max-width:360px}.controls .hangup{margin-left:auto;background:#8a2a2a;border-color:#8a2a2a}table{width:100%;border-collapse:collapse}th,td{padding:.6rem .5rem;border-bottom:1px solid #232838;text-align:left;font-size:.9rem}.empty{text-align:center;color:#7a8094;padding:1.5rem}.row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.row input,.row select{flex:1;min-width:140px}.admin .card h2{margin-top:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:50}.modal{background:#151823;border:1px solid #232838;border-radius:10px;padding:1.5rem 2rem;min-width:320px;text-align:center}.modal .actions{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.modal .accept{background:#1d6b3a;border-color:#1d6b3a}.modal .reject{background:#8a2a2a;border-color:#8a2a2a}
