:root{--bg: #0f1720;--surface: #17222e;--surface-2: #1e2c3a;--text: #e8eef4;--muted: #9fb0c0;--primary: #2f80ed;--open: #27ae60;--block: #e2b93b;--close: #eb5757;--danger: #c0392b;--radius: 12px;--border: #2a3a4a}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.4}.muted{color:var(--muted)}.mono{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.85em}.ellipsis{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.center{min-height:100%;display:flex;align-items:center;justify-content:center;padding:1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.login-card{width:100%;max-width:360px;text-align:center}.login-card h1{margin:0 0 .25rem}.brand-logo{width:190px;max-width:70%;height:auto;margin:0 auto .35rem;display:block}.brand-dinova{width:110px;max-width:45%;height:auto;margin:0 auto .75rem;display:block;opacity:.9}.btn-google{display:inline-flex;align-items:center;justify-content:center;gap:.6rem}.btn-google .gicon{width:18px;height:18px;background:#fff;border-radius:50%;padding:2px;box-sizing:content-box;flex:0 0 auto}.topbar-logo{height:30px;width:auto;display:block}.topbar-brand{display:flex;align-items:center;gap:.5rem}.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.clickable:hover{text-decoration:underline}.nowrap{white-space:nowrap}.stack{display:flex;flex-direction:column;gap:.85rem}.row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}label{display:flex;flex-direction:column;gap:.3rem;text-align:left;font-size:.9rem}label.checkbox{flex-direction:row;align-items:center;gap:.5rem}input,select,textarea{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:.6rem .7rem;font-size:1rem;width:100%}textarea{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;resize:vertical}input[readonly]{opacity:.75;cursor:default}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);border-color:transparent}.badge{font-size:.8rem;padding:.2rem .55rem;border-radius:999px;border:1px solid var(--border)}.badge.ok{color:var(--open);border-color:var(--open)}.badge.warn{color:#e0b341;border-color:#e0b341}.btn{border:none;border-radius:10px;padding:.7rem 1rem;font-size:1rem;font-weight:600;cursor:pointer;color:#fff;background:var(--surface-2);transition:filter .15s ease}.btn:hover:not(:disabled){filter:brightness(1.12)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-block{width:100%}.btn-primary{background:var(--primary)}.btn-open{background:var(--open);font-size:1.15rem;padding:.9rem;width:100%}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-danger{background:var(--danger)}.btn-gate-block{background:var(--block);color:#1a1a1a}.btn-gate-close{background:var(--close)}.linklike{background:none;border:none;color:var(--muted);cursor:pointer;text-decoration:underline;margin-top:.6rem;font-size:.9rem}.error{background:#3a1d1d;border:1px solid var(--close);color:#ffd9d9;padding:.6rem .75rem;border-radius:8px;font-size:.9rem}.small{font-size:.8rem}.qr-wrap{display:flex;justify-content:center;margin:.75rem 0}.qr{width:200px;height:200px;background:#fff;padding:8px;border-radius:8px}.totp-secret{display:block;margin:.25rem 0 .75rem;padding:.5rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.08em;word-break:break-all;-webkit-user-select:all;user-select:all}.page{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.topbar-right{display:flex;align-items:center;gap:.6rem}.content{padding:1rem;max-width:1100px;width:100%;margin:0 auto}.gate-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.gate-card{display:flex;flex-direction:column;gap:.75rem}.gate-head{display:flex;align-items:center;gap:.6rem}.gate-head h2{font-size:1.1rem;margin:0}.gate-pos{flex:0 0 auto;width:2rem;height:2rem;border-radius:50%;background:var(--surface-2);display:grid;place-items:center;font-weight:700}.gate-actions{display:flex;gap:.5rem}.gate-actions .btn{flex:1}.gate-ok{color:var(--open);font-weight:600}.gate-err{color:var(--close);font-weight:600;font-size:.9rem}.tabs{display:flex;gap:.25rem;padding:0 1rem;background:var(--surface);border-bottom:1px solid var(--border)}.tab{background:none;border:none;color:var(--muted);padding:.75rem 1rem;cursor:pointer;border-bottom:2px solid transparent;font-size:1rem}.tab.active{color:var(--text);border-bottom-color:var(--primary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:1rem}.form-grid .wide{grid-column:1 / -1}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--border);font-size:.92rem}th{color:var(--muted);font-weight:600}.role-block{border-top:1px solid var(--border);padding-top:.75rem;margin-top:.75rem}.role-block ul{margin:.3rem 0 0;padding-left:1.1rem}@media(max-width:640px){.form-grid{grid-template-columns:1fr}.hide-sm{display:none}.topbar strong{font-size:.95rem}.content{padding:.75rem}}
