:root{--bg: #0f1419;--surface: #1a212b;--surface-2: #232d3a;--border: #2c3848;--text: #e6edf3;--muted: #8b97a7;--primary: #2f81f7;--primary-hover: #4c95ff;--green: #2ea043;--yellow: #d29922;--red: #f85149;--radius: 10px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5}a{color:var(--primary);text-decoration:none}.muted{color:var(--muted);font-size:.9em}.center{text-align:center}.center-screen{display:grid;place-items:center;height:100%;color:var(--muted)}.btn{border:1px solid transparent;border-radius:8px;padding:.5rem .9rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:default}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface-2)}.btn-danger{background:transparent;border-color:var(--red);color:var(--red)}.btn-danger:hover:not(:disabled){background:#f851491f}label{display:flex;flex-direction:column;gap:.35rem;font-size:.88rem;color:var(--muted)}input,select{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.6rem .7rem;color:var(--text);font-size:.95rem}input:focus,select:focus{outline:none;border-color:var(--primary)}.auth-screen{display:grid;place-items:center;min-height:100%;padding:1rem}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;display:flex;flex-direction:column;gap:1rem}.auth-card h1{margin:0;font-size:1.5rem}.field-hint{margin:-.4rem 0 0;font-size:.8rem;line-height:1.4}.form-error{background:#f851491f;border:1px solid var(--red);color:var(--red);padding:.55rem .7rem;border-radius:8px;font-size:.88rem}.topbar{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.topbar-inner,.container{max-width:1100px;margin:0 auto;padding:0 1rem}.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:56px}.brand{font-weight:700;display:flex;align-items:center;gap:.5rem}.brand-dot{width:10px;height:10px;border-radius:50%;background:var(--green)}.topbar-right{display:flex;align-items:center;gap:.75rem}.user-email{color:var(--muted);font-size:.85rem;max-width:40vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container{padding-top:1.25rem;padding-bottom:3rem;display:flex;flex-direction:column;gap:1.25rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.card-head h2{margin:0;font-size:1.15rem}.metrics-grid{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:1rem}.gauge,.stat-cards{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.gauge-top{display:flex;justify-content:space-between;margin-bottom:.5rem}.gauge-bar{height:8px;background:var(--surface-2);border-radius:5px;overflow:hidden}.gauge-fill{height:100%;transition:width .4s}.gauge-green{background:var(--green)}.gauge-yellow{background:var(--yellow)}.gauge-red{background:var(--red)}.gauge-sub{display:block;margin-top:.4rem}.stat-cards{display:flex;justify-content:space-around;gap:.5rem}.stat{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-num{font-size:1.5rem;font-weight:700}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);overflow-x:auto}.tab{background:none;border:none;color:var(--muted);padding:.7rem 1rem;cursor:pointer;font-size:.95rem;border-bottom:2px solid transparent;display:flex;align-items:center;gap:.4rem;white-space:nowrap}.tab-active{color:var(--text);border-bottom-color:var(--primary)}.tab-badge{background:var(--red);color:#fff;font-size:.7rem;border-radius:10px;padding:0 .4rem;min-width:18px;text-align:center}.badge{display:inline-block;padding:.15rem .55rem;border-radius:20px;font-size:.78rem;font-weight:500}.badge-green{background:#2ea04326;color:var(--green)}.badge-yellow{background:#d2992226;color:var(--yellow)}.badge-red{background:#f8514926;color:var(--red)}.badge-gray{background:var(--surface-2);color:var(--muted)}.table-wrap{overflow-x:auto}.rtable{width:100%;border-collapse:collapse;font-size:.9rem}.rtable th,.rtable td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--border);vertical-align:middle}.rtable th{color:var(--muted);font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}.row-actions .btn{padding:.35rem .6rem;font-size:.82rem}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.4rem}.dot-on{background:var(--green)}.dot-off{background:var(--muted)}.exp-red{color:var(--red)}.exp-soon{color:var(--yellow)}.profile-list,.req-list,.audit-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.profile-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface-2);border-radius:8px}.profile-main{display:flex;align-items:center;gap:.6rem}.profile-name{font-weight:600}.profile-actions{display:flex;gap:.4rem}.req-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;background:var(--surface-2);border-radius:8px;flex-wrap:wrap}.req-admin{justify-content:space-between}.req-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.req-kind{font-weight:600}.audit-item{display:flex;gap:.75rem;padding:.45rem 0;border-bottom:1px solid var(--border);font-size:.88rem;flex-wrap:wrap}.audit-action{font-weight:500}.audit-target{color:var(--muted);font-family:monospace}.audit-actor{margin-left:auto}.guide{display:flex;flex-direction:column;gap:1rem}.guide-steps{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.4rem}.callout{background:#d299221a;border:1px solid rgba(210,153,34,.4);border-radius:8px;padding:.7rem .9rem;font-size:.9rem}.callout-info{background:#2f81f71a;border-color:#2f81f766}.platforms{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.platform{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:.85rem}.platform-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.platform-head h3{margin:0;font-size:1rem}.platform-icon{font-size:1.2rem}.platform-links{list-style:none;margin:0 0 .5rem;padding:0;display:flex;flex-direction:column;gap:.35rem}.platform-links a{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem}.src-primary{font-weight:600}.src-tag{background:#2ea04326;color:var(--green);font-size:.7rem;padding:.05rem .4rem;border-radius:10px}.platform-note{font-size:.8rem;margin:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;padding:1rem;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:1.25rem}.modal-sm{max-width:400px;display:flex;flex-direction:column;gap:.9rem}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.modal-head h2{margin:0;font-size:1.2rem}.modal-close{background:none;border:none;color:var(--muted);font-size:1.6rem;line-height:1;cursor:pointer}.modal-actions{display:flex;gap:.6rem;margin-top:1rem}.config-body{display:flex;flex-direction:column;gap:1rem}.qr-wrap{display:flex;flex-direction:column;align-items:center;gap:.4rem}.qr{width:220px;height:220px;background:#fff;border-radius:8px;padding:8px}.hint{margin:0;font-size:.82rem}.conf-text{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.75rem;font-size:.78rem;overflow-x:auto;white-space:pre;margin:0}@media(max-width:860px){.metrics-grid{grid-template-columns:1fr}}@media(max-width:680px){.rtable thead{display:none}.rtable,.rtable tbody,.rtable tr,.rtable td{display:block;width:100%}.rtable tr{border:1px solid var(--border);border-radius:8px;margin-bottom:.75rem;padding:.5rem}.rtable td{border:none;display:flex;justify-content:space-between;gap:1rem;padding:.35rem .4rem}.rtable td:before{content:attr(data-label);color:var(--muted);font-size:.8rem;font-weight:500}.row-actions{justify-content:flex-end}.profile-item{grid-template-columns:1fr}.profile-actions{justify-content:flex-start}.audit-actor{margin-left:0}}
