@import "https://fonts.googleapis.com/css2?family=Source+Sans+Pro:wght@300;400;500;600;700&display=swap";.keyboard-toggle-button{color:#fff;cursor:pointer;z-index:9998;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:28px;transition:all .3s;display:flex;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #0000004d}.keyboard-toggle-button:hover{transform:scale(1.05);box-shadow:0 6px 16px #0006}.keyboard-toggle-button:active{transform:scale(.95)}.virtual-keyboard-container{z-index:9999;background:#fff;width:100%;height:100%;min-height:60vh;max-height:35vh;padding:10px;animation:.3s ease-out slideUp;position:fixed;bottom:0;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 -4px 20px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.keyboard-header{background:#f5f5f5;border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;margin-bottom:10px;padding:8px 12px;display:flex}.keyboard-header span{color:#333;font-size:14px;font-weight:600}.keyboard-close-button{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;transition:background .2s;display:flex}.keyboard-close-button:hover{background:#0000001a}.custom-keyboard{background:#f5f5f5;border-radius:8px;padding:10px}.keyboard-row{justify-content:center;gap:6px;margin-bottom:6px;display:flex}.keyboard-row:last-child{margin-bottom:0}.keyboard-key{color:#333;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #ddd;border-radius:6px;justify-content:center;align-items:center;min-width:45px;height:50px;padding:0 8px;font-size:16px;font-weight:500;transition:all .1s;display:flex;box-shadow:0 2px 4px #0000001a}.keyboard-key:active{background:#e0e0e0;transform:scale(.95);box-shadow:0 1px 2px #0000001a}.keyboard-key.key-space{flex-grow:1;min-width:250px}.keyboard-key.key-enter{color:#fff;background:#667eea;min-width:80px;font-weight:600}.keyboard-key.key-enter:active{background:#5568d3}.keyboard-key.key-backspace{color:#fff;background:#f44336;min-width:80px;font-weight:600}.keyboard-key.key-backspace:active{background:#d32f2f}.keyboard-key.key-shift{color:#fff;background:#ff9800;min-width:70px;font-size:20px;font-weight:600;position:relative}.keyboard-key.key-shift.active{background:#f57c00;border:2px solid #e65100;box-shadow:inset 0 2px 4px #0003}.keyboard-key.key-shift.active:after{content:"●";color:#4caf50;font-size:10px;position:absolute;top:4px;right:4px}.keyboard-key.key-shift:active{background:#fb8c00}@media (width<=1024px) and (width>=768px){.virtual-keyboard-container{bottom:0}.keyboard-key{min-width:42px;height:48px;font-size:15px}.keyboard-key.key-space{min-width:220px}.keyboard-toggle-button{width:55px;height:55px;font-size:26px;bottom:20px;left:20px}}@media (width<=767px){.virtual-keyboard-container,.keyboard-toggle-button{display:none!important}}@media (width>=1025px){.virtual-keyboard-container{max-width:1000px;bottom:0}}.virtual-keyboard-container::-webkit-scrollbar{width:8px}.virtual-keyboard-container::-webkit-scrollbar-track{background:#f1f1f1}.virtual-keyboard-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.virtual-keyboard-container::-webkit-scrollbar-thumb:hover{background:#555}.login-page{background:linear-gradient(135deg,#b66705 0%,#1d5acd 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-logo{text-align:center;margin-bottom:20px}.logo-link{color:#fff;justify-content:center;align-items:center;gap:15px;text-decoration:none;display:flex}.logo-img{width:80px;height:auto}.logo-text{text-align:left}.thekenbuch-page{padding:20px}.card-header{color:#fff;background:linear-gradient(135deg,#1e3a5f 0%,#152238 100%);padding:15px 20px}@media print{.thekenbuch-page{padding:0}:is(.MuiStack-root:has(button),.MuiButtonGroup-root,.MuiIconButton-root){display:none!important}.card-header{border-bottom:2px solid #000;color:#000!important;background:#fff!important}}#root{text-align:center;background:linear-gradient(135deg,#b66705 0%,#1d5acd 100%)}.logo{will-change:filter;height:6em;padding:1.5em;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:20s linear infinite logo-spin}}.card{padding:2em}.read-the-docs{color:#888}*,:before,:after{box-sizing:border-box}body{color:#212529;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f4f6f9;margin:0;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:1rem;line-height:1.5}a{color:#007bff;text-decoration:none}a:hover{text-decoration:underline}.loading-screen{background:#f4f6f9;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:4px solid #e9ecef;border-top-color:#007bff;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{color:#6c757d;margin-top:15px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
