*{margin:0;padding:0;box-sizing:border-box}body,html,#root{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.page-wrapper{width:100vw;height:100vh;display:flex;gap:20px;padding:20px;background-color:#f5f5f5;overflow:hidden}.grid-container{flex:1;padding:20px;border-radius:20px;background-color:#fff;box-shadow:0 2px 8px #0000001a;display:grid;grid-template-columns:repeat(12,1fr);gap:4px;overflow:hidden;align-content:start}.grid-item{aspect-ratio:1 / 1;border:2px solid #ddd;border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#f9f9f9;position:relative;transition:transform .2s,box-shadow .2s}.grid-item:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026;z-index:10}.grid-item-image{width:100%;height:100%;object-fit:cover}.flat-number-overlay{position:absolute;bottom:2px;left:2px;right:2px;background:#000000bf;color:#fff;font-size:10px;font-weight:700;padding:2px 4px;border-radius:3px;text-align:center}.empty-flat{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4px}.flat-number{font-weight:700;color:#007bff;font-size:14px;display:block}.flat-display{font-size:9px;color:#999;display:block;margin-top:2px}.qrcode-container{width:280px;flex-shrink:0;padding:30px;border-radius:20px;background-color:#fff;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;align-items:center;justify-content:center}.qrcode-content{display:flex;flex-direction:column;align-items:center;gap:15px;text-align:center}.qrcode-content h2{font-size:20px;color:#333;margin:0}.qrcode-content>p{font-size:14px;color:#666;margin:0}.qrcode-content .info{margin-top:10px;padding-top:10px;border-top:1px solid #eee;width:100%}.qrcode-content .info p{font-size:13px;color:#888;margin:5px 0}.upload-page{width:100%;max-width:500px;margin:0 auto;padding:20px}.upload-form{display:flex;flex-direction:column;gap:20px}.form-label{display:block;margin-bottom:0;font-weight:500;color:#333}.form-hint{display:block;color:#666;font-size:12px;margin-top:5px;font-weight:400}input[type=number],input[type=password],input[type=file]{display:block;width:100%;margin-top:8px;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:14px}input[type=number]:focus,input[type=password]:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}input.disabled,input:disabled{opacity:.6;cursor:not-allowed;background-color:#f5f5f5}.btn-upload{width:100%;padding:12px 24px;border-radius:8px;cursor:pointer;background-color:#007bff;color:#fff;border:none;font-size:16px;font-weight:600;transition:background-color .2s}.btn-upload:hover:not(:disabled){background-color:#0056b3}.btn-upload:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}.progress-container{margin-top:15px;background:#f0f0f0;border-radius:8px;overflow:hidden;height:12px}.progress-bar{background:linear-gradient(90deg,#4caf50,#45a049);height:100%;transition:width .3s ease}.progress-text{text-align:center;margin-top:5px;font-size:14px;color:#666}.upload-msg{margin-top:15px;padding:12px;background:#d4edda;color:#155724;border-radius:8px;text-align:center;font-weight:500}.upload-msg.error{background:#f8d7da;color:#721c24}.setup-login-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5}.setup-login-box{background-color:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:400px;width:100%}.setup-login-title{text-align:center;margin-bottom:10px;font-size:24px;color:#333}.setup-login-subtitle{text-align:center;color:#666;margin-bottom:20px;font-size:14px}.setup-login-form{display:flex;flex-direction:column;gap:15px}.setup-login-input{width:100%;padding:12px;font-size:16px;border:1px solid #ddd;border-radius:4px}.setup-login-button{width:100%;padding:12px;font-size:16px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600}.setup-login-button:hover{background-color:#0056b3}.setup-error-msg{margin-top:15px;padding:10px;background-color:#f8d7da;color:#721c24;border-radius:4px;text-align:center}.setup-container{padding:20px;max-width:1000px;margin:0 auto}.setup-header{text-align:right;margin-bottom:10px}.setup-logout-btn{padding:8px 16px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer}.setup-logout-btn:hover{background-color:#5a6268}.setup-title{text-align:center;color:#333;margin-bottom:20px}.setup-info-box{background-color:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:20px}.setup-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:15px 0}.setup-divider{margin:10px 0;border:none;border-top:1px solid #dee2e6}.setup-action-center{text-align:center;margin-bottom:20px}.setup-create-btn{padding:15px 30px;font-size:18px;background-color:#007bff;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:600}.setup-create-btn:hover:not(.disabled){background-color:#0056b3}.setup-create-btn.disabled{background-color:#6c757d;cursor:not-allowed}.setup-status-msg{padding:15px;border-radius:5px;margin-bottom:20px;text-align:center;font-weight:500}.setup-status-msg.success{background-color:#d4edda;color:#155724}.setup-status-msg.error{background-color:#f8d7da;color:#721c24}.setup-pins-section{margin-top:20px}.setup-actions{text-align:center;margin-bottom:20px;display:flex;gap:10px;justify-content:center}.setup-btn-download,.setup-btn-copy{padding:10px 20px;font-size:16px;color:#fff;border:none;border-radius:5px;cursor:pointer;font-weight:500}.setup-btn-download{background-color:#28a745}.setup-btn-download:hover{background-color:#218838}.setup-btn-copy{background-color:#17a2b8}.setup-btn-copy:hover{background-color:#138496}.setup-pins-list{max-height:500px;overflow-y:auto;border:1px solid #ddd;border-radius:5px;padding:15px;background-color:#fff}.setup-floor-section{margin-bottom:20px}.setup-floor-header{background-color:#007bff;color:#fff;padding:8px;border-radius:4px;margin-bottom:10px}.setup-pins-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:10px}.setup-pin-card{padding:10px;background-color:#f8f9fa;border-radius:4px;font-size:14px;border:1px solid #dee2e6}.setup-pin-flat{font-weight:700;font-size:16px;color:#007bff;margin-bottom:3px}.setup-pin-display{color:#666;font-size:12px;margin-bottom:5px}.setup-pin-code{margin-top:5px;padding:5px;background-color:#fff;border-radius:3px;font-family:monospace;font-weight:700;font-size:16px;text-align:center}.setup-notes{margin-top:30px;padding:15px;background-color:#fff3cd;border-radius:5px;font-size:14px}.setup-notes ul{margin-left:20px;margin-top:10px}.setup-notes li{margin-bottom:5px}@media(max-width:1400px){.grid-container{gap:3px;padding:15px}.flat-number{font-size:12px}.flat-display{font-size:8px}}@media(max-width:1200px){.page-wrapper{gap:15px;padding:15px}.grid-container{gap:2px;padding:10px}.qrcode-container{width:240px;padding:20px}.qrcode-content h2{font-size:18px}}@media(max-width:900px){.page-wrapper{flex-direction:column}.qrcode-container{width:100%;flex-shrink:1}.qrcode-content{flex-direction:row;flex-wrap:wrap;justify-content:space-around}.setup-info-grid{grid-template-columns:1fr}.setup-pins-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media(max-width:768px){.page-wrapper{padding:20px}.upload-page,.setup-container{padding:15px}}
