*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f5f5;color:#333}button,input,select{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh}.topbar{background:#363636;color:#fff;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:100}.topbar h1{margin:0;font-size:1.15rem}.topbar-actions{display:flex;align-items:center;gap:12px}.muted{color:#999;font-size:.85rem}.page{max-width:1200px;margin:0 auto;padding:24px}.card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014;padding:20px;margin-bottom:20px}.card h2{margin:0 0 16px;font-size:1.05rem}.card-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px 20px;margin-bottom:16px}.card-toolbar h2{margin:0}.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.section-header h2{margin:0;font-size:1.05rem}.section-header__toggle{flex-shrink:0}.section-body{display:block}.card-toolbar__row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.filter-toggle{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#363636;color:#fff;font-size:.75rem;font-weight:700}.filter-toggle__chevron{display:inline-block;transition:transform .2s ease;font-size:.85rem;line-height:1}.filter-toggle__chevron.is-open{transform:rotate(180deg)}.filter-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px 14px}.filter-control{display:flex;align-items:center;gap:10px}.filter-control label{font-size:.85rem;font-weight:600;color:#666;white-space:nowrap}.filter-control select{min-width:168px;border:1px solid #ddd;border-radius:8px;padding:8px 12px;background:#fff;color:#333}.filter-control select:focus{outline:none;border-color:#363636;box-shadow:0 0 0 2px #3636361f}.page-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:20px}.tabs-scroll{flex:1;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs{display:flex;flex-wrap:wrap;gap:8px}.page-toolbar__refresh{flex-shrink:0}.topbar-email{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab{border:none;background:#e8e8e8;color:#333;padding:10px 16px;border-radius:8px}.tab.active{background:#363636;color:#fff}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:12px}.field label{display:block;font-size:.85rem;margin-bottom:6px;color:#555}.field input,.field select{width:100%;border:1px solid #ddd;border-radius:8px;padding:10px 12px}.btn{border:none;border-radius:8px;padding:10px 14px;font-weight:600}.btn-primary{background:#363636;color:#fff}.btn-secondary{background:#eee;color:#333}.btn-danger{background:#c0392b;color:#fff}.btn-success{background:#27ae60;color:#fff}.btn:disabled{opacity:.6;cursor:not-allowed}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid #eee;vertical-align:top}th{color:#666;font-weight:600}.badge{display:inline-block;padding:3px 8px;border-radius:999px;font-size:.75rem;font-weight:600}.badge-pending{background:#fff3cd;color:#856404}.badge-approved{background:#d4edda;color:#155724}.badge-banned,.badge-rejected{background:#f8d7da;color:#721c24}.badge-unbound{background:#e2e3e5;color:#383d41}.badge-active{background:#d4edda;color:#155724}.badge-disabled{background:#f8d7da;color:#721c24}.badge-expired{background:#fff3cd;color:#856404}.badge-revoked{background:#e2e3e5;color:#383d41}.actions{display:flex;flex-wrap:wrap;gap:6px}.expiry-cell{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.btn-compact{padding:4px 8px;font-size:.75rem}.actions .btn{padding:6px 10px;font-size:.8rem}.error-text{color:#c0392b;margin:8px 0 0;font-size:.9rem}.success-text{color:#27ae60;margin:8px 0 0;font-size:.9rem}.feedback-banner{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:10px;margin-top:16px;border:1px solid transparent}.feedback-banner--success{background:#edf7ed;border-color:#b7dfb9;color:#1b5e20}.feedback-banner--error{background:#fdecea;border-color:#f5c6c0;color:#922b21}.feedback-banner__icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.feedback-banner--success .feedback-banner__icon{background:#2e7d32;color:#fff}.feedback-banner--error .feedback-banner__icon{background:#c0392b;color:#fff}.feedback-banner__body{flex:1;min-width:0}.feedback-banner__title{display:block;font-size:.95rem;margin-bottom:4px}.feedback-banner__message{margin:0;font-size:.88rem;line-height:1.45;opacity:.92}.feedback-banner__close{border:none;background:transparent;color:inherit;font-size:1.35rem;line-height:1;padding:0 4px;opacity:.6;flex-shrink:0}.feedback-banner__close:hover{opacity:1}.banner-fade-enter-active,.banner-fade-leave-active{transition:opacity .2s ease,transform .2s ease}.banner-fade-enter-from,.banner-fade-leave-to{opacity:0;transform:translateY(-6px)}.action-toast{position:fixed;right:24px;bottom:24px;z-index:1000;width:min(420px,calc(100vw - 48px));display:flex;align-items:flex-start;gap:12px;padding:16px 18px;border-radius:12px;border:1px solid transparent;box-shadow:0 10px 30px #00000024}.action-toast--success{background:#edf7ed;border-color:#b7dfb9;color:#1b5e20}.action-toast--error{background:#fdecea;border-color:#f5c6c0;color:#922b21}.action-toast__icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.action-toast--success .action-toast__icon{background:#2e7d32;color:#fff}.action-toast--error .action-toast__icon{background:#c0392b;color:#fff}.action-toast__body{flex:1;min-width:0}.action-toast__title{display:block;font-size:.96rem;margin-bottom:4px}.action-toast__message{margin:0;font-size:.88rem;line-height:1.45;opacity:.92}.action-toast__close{border:none;background:transparent;color:inherit;font-size:1.4rem;line-height:1;padding:0 4px;opacity:.6;flex-shrink:0}.action-toast__close:hover{opacity:1}.toast-slide-enter-active,.toast-slide-leave-active{transition:opacity .22s ease,transform .22s ease}.toast-slide-enter-from,.toast-slide-leave-to{opacity:0;transform:translateY(12px)}.confirm-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:24px;background:#00000073}.confirm-dialog{width:min(460px,100%);background:#fff;border-radius:12px;box-shadow:0 16px 40px #0003;padding:22px 24px}.confirm-dialog__title{margin:0 0 10px;font-size:1.05rem}.confirm-dialog__message{margin:0 0 16px;color:#555;font-size:.92rem;line-height:1.5}.confirm-dialog__field{margin-bottom:18px}.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:10px}.dialog-fade-enter-active,.dialog-fade-leave-active{transition:opacity .2s ease}.dialog-fade-enter-active .confirm-dialog,.dialog-fade-leave-active .confirm-dialog{transition:transform .2s ease,opacity .2s ease}.dialog-fade-enter-from,.dialog-fade-leave-to{opacity:0}.dialog-fade-enter-from .confirm-dialog,.dialog-fade-leave-to .confirm-dialog{opacity:0;transform:translateY(10px) scale(.98)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:420px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.8rem;word-break:break-all}.empty{color:#888;padding:12px 0}.audit-changes,.audit-context{list-style:none;margin:0;padding:0}.audit-cell__content{display:flex;flex-direction:column;gap:4px}.audit-changes li{display:block;padding:0;line-height:1.45}.audit-context li{display:block;padding:0;line-height:1.4;font-size:.85rem}.audit-change__label{color:#666;font-size:.85rem;margin-right:4px}.audit-change__values{display:inline}.audit-change__from{color:#a94442;text-decoration:line-through;text-decoration-color:#a9444273}.audit-change__arrow{color:#999;font-size:.85rem;margin:0 4px}.audit-change__to{color:#1f7a1f;font-weight:600}.audit-context:not(:first-child){margin-top:4px;padding-top:4px;border-top:1px dashed #eee}@media (max-width: 768px){.topbar{flex-wrap:wrap;padding:max(12px,env(safe-area-inset-top)) 16px 12px;gap:10px}.topbar__title{font-size:1rem;line-height:1.3;flex:1 1 100%}.topbar-actions{width:100%;justify-content:space-between;gap:10px}.topbar-email{max-width:none;flex:1;min-width:0;color:#ccc;font-size:.82rem}.topbar-actions .btn{flex-shrink:0;min-height:40px;padding:8px 14px}.page{padding:16px;padding-bottom:calc(88px + env(safe-area-inset-bottom))}.page-toolbar{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:16px}.tabs-scroll{margin:0;padding:2px 0;scrollbar-width:none}.tabs-scroll::-webkit-scrollbar{display:none}.tabs{flex-wrap:nowrap;width:max-content;gap:6px}.tab{flex-shrink:0;min-height:44px;padding:10px 16px;font-size:.9rem}.page-toolbar__refresh{width:100%;min-height:44px}.card{padding:16px;border-radius:12px;margin-bottom:14px}.card h2,.section-header h2,.card-toolbar h2{font-size:1rem}.section-header{margin-bottom:0}.section-header__toggle,.filter-toggle{min-height:40px}.section-body{margin-top:14px}.card-toolbar{flex-direction:column;align-items:stretch;gap:12px}.card-toolbar--stack .card-toolbar__row{flex-wrap:wrap}.card-toolbar--stack .filter-toggle{width:100%;justify-content:center}.filter-toolbar{width:100%;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:12px;padding:12px;border:1px solid #ececec;border-radius:10px;background:#f9f9f9}.filter-control{width:100%;flex-direction:column;align-items:stretch;gap:6px}.filter-control select,.field input,.field select,.confirm-dialog__field input{min-width:0;width:100%;min-height:44px;font-size:16px}.form-grid{grid-template-columns:1fr;gap:14px}.btn-block-mobile{width:100%;min-height:44px}.table-cards{overflow:visible}.table-cards table{font-size:.88rem}.table-cards thead{display:none}.table-cards tbody tr{display:flex;flex-direction:column;padding:0;margin-bottom:12px;border:1px solid #e3e3e3;border-radius:12px;background:#fff;box-shadow:0 1px 4px #0000000a;overflow:hidden}.table-cards tbody tr:last-child{margin-bottom:0}.table-cards td{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:10px 14px;border-bottom:1px solid #f0f0f0}.table-cards td:last-child{border-bottom:none;background:#fafafa}.table-cards td:before{content:attr(data-label);font-size:.72rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#888;line-height:1.3}.table-cards td[data-label=Benutzer],.table-cards td[data-label=Zeit]{padding:14px;background:#f7f7f7;border-bottom:1px solid #ececec}.table-cards td[data-label=Benutzer]:before,.table-cards td[data-label=Zeit]:before{display:none}.table-cards td[data-label=Benutzer] strong{font-size:1rem}.table-cards td[data-label=Aktionen]{gap:8px;padding-top:12px;padding-bottom:12px}.table-cards .actions{width:100%;flex-direction:column;gap:8px}.table-cards .actions .btn,.table-cards td[data-label=Aktionen]>.btn{width:100%;flex:none;min-height:44px;padding:11px 14px;font-size:.9rem}.table-cards td[data-label=Details]{word-break:break-word}.action-toast{right:16px;left:16px;bottom:calc(16px + env(safe-area-inset-bottom));width:auto}.confirm-dialog-backdrop{padding:0;align-items:flex-end}.confirm-dialog{width:100%;max-height:90vh;overflow-y:auto;padding:20px 16px calc(16px + env(safe-area-inset-bottom));border-radius:16px 16px 0 0}.confirm-dialog__actions{flex-direction:column-reverse;gap:8px}.confirm-dialog__actions .btn{width:100%;min-height:48px}.login-page{padding:16px;padding-top:calc(12vh + env(safe-area-inset-top));padding-bottom:calc(16px + env(safe-area-inset-bottom));align-items:flex-start}.login-card .field input{min-height:48px;font-size:16px}.login-card .btn{min-height:48px}}@media (max-width: 480px){.topbar__title{font-size:.92rem}.page{padding:12px;padding-bottom:calc(88px + env(safe-area-inset-bottom))}.card{padding:14px}.tab{padding:10px 12px;font-size:.85rem}}
