:root{--color-bg: #0f1419;--color-surface: #1a2332;--color-surface-hover: #243044;--color-border: #2d3a4f;--color-text: #e8edf4;--color-text-muted: #8b9cb3;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-keys: #f59e0b;--color-keys-bg: rgba(245, 158, 11, .12);--color-warehouse: #10b981;--color-warehouse-bg: rgba(16, 185, 129, .12);--color-admin: #a78bfa;--color-admin-bg: rgba(167, 139, 250, .12);--color-error: #ef4444;--color-success: #22c55e;--radius: 12px;--shadow: 0 8px 32px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}#root,.page{min-height:100vh}.login-page{display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(ellipse at 20% 50%,rgba(59,130,246,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(245,158,11,.08) 0%,transparent 40%),var(--color-bg)}.login-card{width:100%;max-width:420px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:block;width:100%;max-width:280px;height:auto;margin:0 auto 1.25rem;object-fit:contain}.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,var(--color-primary),#6366f1);border-radius:14px;font-weight:700;font-size:1rem;letter-spacing:.05em;margin-bottom:1rem}.logo-mark--sm{width:36px;height:36px;font-size:.7rem;border-radius:8px;margin-bottom:0}.login-header h1{font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.subtitle{color:var(--color-text-muted);font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-muted)}.form-group input{padding:.75rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:1rem;font-family:inherit;transition:border-color .15s}.form-group input:focus{outline:none;border-color:var(--color-primary)}.form-group input::placeholder{color:var(--color-text-muted);opacity:.6}.error-message{color:var(--color-error);font-size:.875rem;text-align:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-full{width:100%;padding:.875rem;font-size:1rem}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-back{border:none;padding-left:0}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.top-bar__brand{display:flex;align-items:center;gap:.75rem;font-weight:600}.top-bar-logo{display:block;height:36px;width:auto;object-fit:contain}.top-bar__user{display:flex;align-items:center;gap:1rem}.user-greeting{color:var(--color-text-muted);font-size:.875rem}.module-select-page{background:radial-gradient(ellipse at 50% 0%,rgba(59,130,246,.1) 0%,transparent 60%),var(--color-bg)}.module-select-main{max-width:900px;margin:0 auto;padding:3rem 2rem}.module-select-intro{text-align:center;margin-bottom:3rem}.module-select-intro h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.module-select-intro p{color:var(--color-text-muted);font-size:1.0625rem}.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.module-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s;font-family:inherit;color:inherit}.module-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.module-card--keys:hover{border-color:var(--color-keys)}.module-card--warehouse:hover{border-color:var(--color-warehouse)}.module-card--admin:hover{border-color:var(--color-admin)}.module-card__icon{font-size:2.5rem;margin-bottom:1rem}.module-card h2{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.module-card p{color:var(--color-text-muted);font-size:.9375rem;line-height:1.6;flex:1}.module-card__arrow{margin-top:1.25rem;font-size:1.25rem;color:var(--color-text-muted);transition:transform .15s}.module-card:hover .module-card__arrow{transform:translate(4px)}.module-card--keys:hover .module-card__arrow{color:var(--color-keys)}.module-card--warehouse:hover .module-card__arrow{color:var(--color-warehouse)}.module-card--admin:hover .module-card__arrow{color:var(--color-admin)}.admin-tag{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:var(--color-admin-bg);color:var(--color-admin);border-radius:4px;font-size:.75rem;font-weight:600}.no-access-message{text-align:center;color:var(--color-text-muted);padding:2rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.app-page{background:var(--color-bg)}.app-main{max-width:1000px;margin:0 auto;padding:2.5rem 2rem}.app-main--wide{max-width:1200px}.page-header{margin-bottom:1.5rem}.app-main h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.lead{color:var(--color-text-muted);font-size:1.0625rem;margin-bottom:2.5rem;max-width:600px}.module-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600}.module-badge--keys{background:var(--color-keys-bg);color:var(--color-keys)}.module-badge--warehouse{background:var(--color-warehouse-bg);color:var(--color-warehouse)}.module-badge--admin{background:var(--color-admin-bg);color:var(--color-admin)}.placeholder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem}.placeholder-card{padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.placeholder-card h3{font-size:1rem;font-weight:600;margin-bottom:.5rem}.placeholder-card p{color:var(--color-text-muted);font-size:.875rem}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.admin-form-card,.admin-table-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.admin-form-card h2,.admin-table-card h2{font-size:1.125rem;font-weight:600;margin-bottom:1.25rem}.admin-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.form-group select{padding:.75rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:1rem;font-family:inherit;width:100%}.form-group select:focus{outline:none;border-color:var(--color-primary)}.form-hint{margin-top:.5rem;font-size:.8125rem;color:var(--color-text-muted)}.permission-group{display:flex;flex-direction:column;gap:.625rem}.checkbox-label{display:flex;align-items:center;gap:.625rem;cursor:pointer;font-size:.9375rem}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--color-primary)}.form-actions{display:flex;gap:.75rem;justify-content:flex-end}.success-message{color:var(--color-success);font-size:.875rem;margin-bottom:1rem;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:8px}.admin-error{margin-bottom:1rem;text-align:left}.table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.9375rem}.admin-table th,.admin-table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{color:var(--color-text-muted);font-weight:500;font-size:.8125rem;text-transform:uppercase;letter-spacing:.03em}.admin-table tbody tr:hover{background:var(--color-surface-hover)}.admin-table code{background:var(--color-bg);padding:.125rem .375rem;border-radius:4px;font-size:.875rem}.role-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.role-badge--admin{background:var(--color-admin-bg);color:var(--color-admin)}.role-badge--user{background:#3b82f61f;color:var(--color-primary)}.table-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-danger{background:transparent;color:var(--color-error);border:1px solid rgba(239,68,68,.4)}.btn-danger:hover{background:#ef44441a;color:var(--color-error)}.btn-success{background:var(--color-success);color:#fff;border:none}.btn-success:hover{background:#16a34a;color:#fff}.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.25rem}.stat-card--success{border-color:#22c55e4d}.stat-card--warning{border-color:#f59e0b4d}.stat-card__value{font-size:2rem;font-weight:700;line-height:1}.stat-card--success .stat-card__value{color:var(--color-success)}.stat-card--warning .stat-card__value{color:var(--color-keys)}.stat-card__label{font-size:.875rem;color:var(--color-text-muted)}.tab-nav{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border);padding-bottom:0;overflow-x:auto}.tab-nav__btn{padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);font-family:inherit;font-size:.9375rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab-nav__btn:hover{color:var(--color-text)}.tab-nav__btn--active{color:var(--color-keys);border-bottom-color:var(--color-keys)}.panel-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.panel-card h2{font-size:1.125rem;font-weight:600;margin-bottom:1.25rem}.panel-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.panel-toolbar__filters{display:flex;gap:.75rem;flex-wrap:wrap;flex:1}.search-input,.filter-select{padding:.625rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:.9375rem;font-family:inherit}.search-input{min-width:240px;flex:1}.search-input:focus,.filter-select:focus{outline:none;border-color:var(--color-primary)}.status-badge{display:inline-block;padding:.2rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600}.status-badge--verfuegbar{background:#22c55e26;color:var(--color-success)}.status-badge--ausgegeben{background:var(--color-keys-bg);color:var(--color-keys)}.action-badge{display:inline-block;padding:.2rem .625rem;border-radius:4px;font-size:.75rem;font-weight:600}.action-badge--ausgabe{background:#3b82f626;color:var(--color-primary)}.action-badge--rueckgabe{background:#22c55e26;color:var(--color-success)}.cell-sub{display:block;font-size:.8125rem;color:var(--color-text-muted);margin-top:.125rem}.empty-cell{text-align:center;color:var(--color-text-muted);padding:2rem!important}.empty-hint{color:var(--color-text-muted);font-size:.9375rem}.issue-return-grid{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}.mode-toggle{display:flex;gap:.5rem;margin-bottom:1.5rem}.mode-toggle__btn{flex:1;padding:.75rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-muted);font-family:inherit;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .15s}.mode-toggle__btn:hover{border-color:var(--color-primary);color:var(--color-text)}.mode-toggle__btn--active{background:#3b82f61f;border-color:var(--color-primary);color:var(--color-primary)}.key-preview{padding:.875rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;margin-bottom:.5rem}.issued-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.issued-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px}.issued-item__holder{font-weight:600;color:var(--color-keys);white-space:nowrap}.info-banner{padding:.875rem 1.25rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.25);border-radius:8px;color:var(--color-text-muted);font-size:.9375rem;margin-bottom:1rem;line-height:1.5}.empty-customer-hint{padding:1rem;background:var(--color-bg);border:1px dashed var(--color-border);border-radius:8px;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.empty-customer-hint p{color:var(--color-text-muted);font-size:.9375rem;margin:0}@media(max-width:640px){.top-bar{flex-direction:column;gap:.75rem;align-items:flex-start;padding:1rem}.top-bar__user{width:100%;justify-content:space-between}.module-select-main,.app-main{padding:2rem 1rem}.issue-return-grid{grid-template-columns:1fr}.admin-header{flex-direction:column}.panel-toolbar{flex-direction:column;align-items:stretch}.search-input{min-width:unset}}
