*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}#root{width:100%;min-height:100vh}.search-form{margin-bottom:25px}.form-group{margin-bottom:0}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:.95rem}.form-group input{width:100%;padding:15px;border:2px solid #edf2f4;border-radius:10px;font-size:1rem;transition:border-color .3s ease;outline:none}.form-group input:focus{border-color:#ef233c}.form-group input::placeholder{color:#cbd5e0}@media(max-width:600px){.form-group input{padding:12px;font-size:16px}}.guest-dropdown{margin-top:20px;margin-bottom:20px}.dropdown-header{font-size:.9rem;color:#2b2d42;font-weight:600;margin-bottom:10px}.dropdown-list{border:2px solid #edf2f4;border-radius:10px;overflow:hidden;max-height:300px;overflow-y:auto}.guest-item{width:100%;padding:15px;background:#fff;border:none;border-bottom:1px solid #edf2f4;text-align:left;cursor:pointer;transition:background .2s ease}.guest-item:last-child{border-bottom:none}.guest-item:hover{background:#edf2f4}.guest-item:active{background:#8d99ae}.guest-name{font-weight:600;color:#2d3748;font-size:1.05rem;margin-bottom:5px}.guest-identifier{font-size:.9rem;color:#718096}@media(max-width:600px){.guest-item{padding:12px}.guest-name{font-size:1rem}.guest-identifier{font-size:.85rem}}.floor-plan-container{width:100%}.floor-plan-header{text-align:center;margin-bottom:20px;padding:15px;background:linear-gradient(135deg,#2b2d42,#8d99ae);border-radius:10px}.floor-plan-header h3{color:#fff;font-size:1.3rem;margin:0;font-weight:600}.canvas-container{position:relative;width:100%;max-width:100%;margin:0 auto;border-radius:10px;overflow:hidden;box-shadow:0 4px 15px #0003;background:#fff}.floor-plan-image{width:100%;height:auto;display:block}.point-marker{position:absolute;width:40px;height:40px;margin-left:-20px;margin-top:-20px;pointer-events:none;z-index:10}.point-pulse{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:50%;background:#ef233c99;border:3px solid #ef233c;animation:pulse 2s ease-in-out infinite}.point-pulse:after{content:"";position:absolute;top:-3px;left:-3px;width:40px;height:40px;border-radius:50%;border:3px solid #ef233c;animation:ripple 2s ease-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}@keyframes ripple{0%{transform:scale(1);opacity:1}to{transform:scale(2);opacity:0}}.floor-plan-legend{text-align:center;margin-top:15px;padding:10px;background:#f8f9fa;border-radius:8px}.floor-plan-legend p{margin:0;color:#666;font-size:.9rem}.floor-plan-legend .floor-plan-warning{color:#d90429;font-weight:500}.floor-plan-enlarged-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:20px;z-index:2000;animation:fadeIn .3s ease}.floor-plan-enlarged-content{background:#fff;border-radius:15px;padding:30px;width:98vw;height:98vh;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;overflow:hidden;display:flex;flex-direction:column}.floor-plan-close-button{position:absolute;top:10px;right:10px;background:#ef233ce6;color:#fff;border:none;font-size:2rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease;line-height:1;padding:0}.floor-plan-close-button:hover{background:#d90429;transform:scale(1.1)}.floor-plan-enlarged-header{text-align:center;margin-bottom:20px;flex-shrink:0}.floor-plan-enlarged-header h3{color:#2b2d42;font-size:1.8rem;margin:0;font-weight:600}.canvas-container-enlarged{position:relative;width:100%;height:100%;flex:1;margin:0 auto;border-radius:10px;overflow:auto;background:#fff}.floor-plan-image-enlarged{width:100%;height:100%;display:block;object-fit:contain}@media(max-width:600px){.floor-plan-header h3{font-size:1.1rem}.point-marker{width:30px;height:30px;margin-left:-15px;margin-top:-15px}.point-pulse{width:30px;height:30px}.point-pulse:after{width:30px;height:30px;top:-3px;left:-3px}.floor-plan-legend p{font-size:.85rem}.floor-plan-enlarged-content{padding:20px;width:100vw;height:100vh;border-radius:0}.floor-plan-enlarged-header{margin-bottom:15px}.floor-plan-enlarged-header h3{font-size:1.3rem}.floor-plan-close-button{width:45px;height:45px;font-size:1.8rem;top:15px;right:15px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:20px;padding:40px 30px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{position:absolute;top:15px;right:15px;background:none;border:none;font-size:2rem;color:#cbd5e0;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-button:hover{background:#edf2f4;color:#2b2d42}.modal-header{text-align:center;margin-bottom:30px}.guest-greeting{font-size:1.8rem;color:#2d3748;font-weight:700;margin-bottom:10px}.table-info{text-align:center;margin-bottom:30px;padding:30px;background:linear-gradient(135deg,#ef233c,#d90429);border-radius:15px}.table-label{color:#ffffffe6;font-size:1rem;margin-bottom:10px;font-weight:500}.table-number{font-size:3.5rem;color:#fff;font-weight:700}.guest-message{background:#edf2f4;padding:20px;border-radius:10px;color:#2b2d42;line-height:1.6;margin-bottom:30px;text-align:center;font-size:1rem}.done-button{width:100%;padding:15px;background:#2b2d42;color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .3s ease}.done-button:hover{background:#8d99ae}.done-button:active{background:#ef233c}@media(max-width:600px){.modal-content{padding:30px 20px}.guest-greeting{font-size:1.5rem}.table-number{font-size:3rem}.guest-message{font-size:.95rem}}.app-container{width:100%;min-height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;padding:20px;position:relative}.app-container:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:0}.app-container>.card{position:relative;z-index:1}.card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px 30px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:500px}.title{font-size:2.5rem;font-weight:700;color:#2b2d42;text-align:center;margin-bottom:10px}.subtitle{font-size:1.2rem;color:#2b2d42;text-align:center;margin-bottom:30px;font-weight:500}.welcome-text{text-align:center;color:#666;margin-bottom:30px;font-size:1rem}.loading,.error{text-align:center;padding:30px;font-size:1.1rem}.loading{color:#2b2d42}.error{color:#e53e3e;background:#fff5f5;border-radius:10px;margin-bottom:20px}.retry-button{display:block;width:100%;padding:15px;background:#ef233c;color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .3s ease}.retry-button:hover{background:#d90429}@media(max-width:600px){.card{padding:30px 20px}.title{font-size:2rem}.subtitle{font-size:1rem}}
