:root{--bg: #f7f9fb;--surface: #ffffff;--surface2: #f0f4f8;--border: #dde3ea;--border-strong: #c4ccd6;--accent: #2ea3f2;--accent-hover: #1d8dd8;--accent-soft: rgba(46,163,242,.1);--secondary: #2b987b;--secondary-hover: #237a63;--text: #2c3e50;--text2: #6b7785;--text3: #9ba6b3;--success: #2b987b;--warning: #ff6900;--danger: #dc3232;--radius: 8px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow: 0 2px 8px rgba(0,0,0,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}h1,h2,h3,h4{font-weight:600;color:var(--text)}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.05rem}button{cursor:pointer;border:none;border-radius:var(--radius);padding:9px 18px;font-family:inherit;font-size:.875rem;font-weight:500;letter-spacing:.01em;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(.92)}input,select,textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:9px 12px;color:var(--text);font-family:inherit;font-size:.875rem;width:100%;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}label{display:block;font-size:.8rem;color:var(--text2);margin-bottom:6px;font-weight:500}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 12px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text2);border-bottom:2px solid var(--border);background:var(--surface2)}td{padding:12px;border-bottom:1px solid var(--border)}tr:hover td{background:var(--surface2)}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:500;background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.badge-success{background:#2b987b1a;color:var(--secondary);border-color:#2b987b40}.badge-danger{background:#dc32321a;color:var(--danger);border-color:#dc323240}.badge-accent{background:var(--accent-soft);color:var(--accent);border-color:#2ea3f240}.error-banner{background:#dc323214;border:1px solid rgba(220,50,50,.3);color:var(--danger);padding:10px 14px;border-radius:var(--radius);font-size:.875rem;margin-bottom:12px}.info-banner{background:var(--accent-soft);border:1px solid rgba(46,163,242,.3);color:var(--accent-hover);padding:10px 14px;border-radius:var(--radius);font-size:.875rem;margin-bottom:12px}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.sidebar h1{font-size:1.5rem;font-weight:700;color:var(--accent);padding:8px 12px 18px;border-bottom:1px solid var(--border);margin-bottom:12px;letter-spacing:-.01em}.sidebar a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);color:var(--text2);font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.sidebar a:hover{background:var(--surface2);color:var(--text)}.sidebar a.active{background:var(--accent-soft);color:var(--accent)}.sidebar-footer{margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.sidebar-footer .user{font-size:.85rem;color:var(--text);padding:6px 12px;font-weight:500}.sidebar-footer .user-mail{font-size:.72rem;color:var(--text2);padding:0 12px 8px}.main{flex:1;padding:16px 20px;min-width:0}.page-title{font-size:1.4rem;font-weight:600;margin-bottom:14px;color:var(--text)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,var(--bg) 0%,var(--surface2) 100%)}.login-card{width:100%;max-width:400px;box-shadow:var(--shadow)}.login-card h1{color:var(--accent);margin-bottom:4px;font-weight:700}.login-card p.sub{color:var(--text2);font-size:.875rem;margin-bottom:24px}.login-card form>*+*{margin-top:14px}.matrix-table th,.matrix-table td{text-align:center}.matrix-table th:first-child,.matrix-table td:first-child{text-align:left}.matrix-table input[type=checkbox]{width:auto;cursor:pointer}.matrix-cat{background:var(--surface2);font-weight:600;color:var(--accent);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}.totp-qr{background:#fff;padding:16px;border-radius:var(--radius);display:inline-block;border:1px solid var(--border)}.totp-qr img{display:block;max-width:240px;height:auto}
