*{margin:0;padding:0;box-sizing:border-box;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}body{margin:0;font-family:Sarabun,Inter,Roboto,Segoe UI,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#191022;overflow-x:clip;min-height:100vh;width:100%;overscroll-behavior:none;touch-action:pan-x pan-y}input,select,textarea{font-size:16px!important;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}[contenteditable=true],.MuiInputBase-input,.MuiTextField-root input,.MuiTextField-root textarea{-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important;user-select:text!important}html{min-height:100vh;width:100%}#root{min-height:100vh;width:100%;display:flex;flex-direction:column}.app{min-height:100vh;width:100%;position:relative;display:flex;flex-direction:column}.home-page{height:100vh;width:100vw;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;position:relative;overflow:hidden}.home-header{position:absolute;top:0;left:0;right:0;z-index:1000;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.1);padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.home-title{font-size:24px;font-weight:600;color:#333;margin:0}.project-grid{flex:1;padding:100px 24px 24px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;max-width:1200px;margin:0 auto;width:100%}.project-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative}.project-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px #00000026}.project-card-image{width:100%;height:200px;object-fit:cover;background:linear-gradient(45deg,#f0f0f0,#e0e0e0);display:flex;align-items:center;justify-content:center;color:#999;font-size:14px}.project-card-content{padding:20px}.project-card-title{font-size:18px;font-weight:600;color:#333;margin-bottom:8px}.project-card-description{color:#666;font-size:14px;line-height:1.5;margin-bottom:12px}.project-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#999}.project-card-actions{position:absolute;top:12px;right:12px;display:flex;gap:8px;opacity:0;transition:opacity .2s}.project-card:hover .project-card-actions{opacity:1}.create-project-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:280px;border:2px dashed rgba(255,255,255,.3);border-radius:16px;cursor:pointer;transition:all .3s ease}.create-project-card:hover{transform:translateY(-8px);border-color:#fff9}.create-project-icon{font-size:48px;margin-bottom:16px;opacity:.8}.create-project-text{font-size:18px;font-weight:500;text-align:center}.map-viewer{height:100vh;width:100vw;position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden;background:#f5f5f5}.map-canvas-container{position:absolute;top:0;left:0;right:0;bottom:0;cursor:grab;overflow:hidden;width:100vw;height:100vh;z-index:0}.map-canvas-container.dragging{cursor:grabbing}.map-canvas-container.adding-booth{cursor:crosshair}.map-canvas{position:absolute;top:50%;left:50%;transform-origin:center center;transition:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;z-index:1}.map-canvas.zoom-smooth{transition:transform .1s ease-out}.search-bar{position:fixed!important;top:16px;left:16px;right:16px;z-index:9999!important;max-width:400px;pointer-events:auto!important}.search-bar-container{position:relative;transition:all .3s ease}.search-bar-container.expanded{width:400px}.search-bar-input-container{display:flex;align-items:center;background:#fff!important;border-radius:8px;box-shadow:0 2px 8px #00000026;border:1px solid #e0e0e0;padding:12px 16px;gap:12px;width:100%;transition:box-shadow .2s ease;position:relative;z-index:10001!important}.search-bar-input-container:hover{box-shadow:0 4px 12px #0003}.search-bar-input-container:focus-within{box-shadow:0 4px 12px #0003;border-color:#1976d2}.search-bar-icon{font-size:16px;opacity:.6}.search-bar-input{flex:1;border:none;outline:none;background:none;font-size:14px;color:#333}.search-bar-input::placeholder{color:#999}.search-bar-clear{background:none;border:none;font-size:18px;cursor:pointer;color:#999;padding:4px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.search-bar-clear:hover{background:#0000001a;color:#333}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 4px 20px #00000026;border:1px solid rgba(0,0,0,.1);margin-top:8px;overflow:hidden;max-height:200px;overflow-y:auto}.search-suggestion-item{padding:12px 16px;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.05)}.search-suggestion-item:last-child{border-bottom:none}.search-suggestion-item:hover{background:#2196f31a}.search-suggestion-main{display:flex;flex-direction:column;gap:2px}.search-suggestion-name{font-weight:500;color:#333;font-size:14px}.search-suggestion-type{font-size:12px;color:#666}.status-badge{padding:2px 8px;border-radius:12px;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-badge.available{background:#e8f5e8;color:#2e7d32}.status-badge.hold{background:#fff3e0;color:#f57c00}.status-badge.sold{background:#ffebee;color:#c62828}.back-button-container{position:fixed!important;top:16px;left:420px;z-index:9999!important;pointer-events:auto!important}.back-button{width:40px;height:40px;background:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0003;font-size:18px;color:#5f6368}.back-button:hover{background:#f8f9fa;box-shadow:0 4px 12px #00000040}.floating-controls{position:fixed!important;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:9999!important;pointer-events:auto!important}.floating-panel{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 4px 20px #00000026;border:1px solid rgba(0,0,0,.1);overflow:hidden;position:relative;z-index:1001}.control-button{width:40px;height:40px;background:#fff!important;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0003;position:relative;z-index:10000!important;font-size:18px;color:#5f6368!important;pointer-events:auto!important}.control-button:hover{background:#f8f9fa;box-shadow:0 4px 12px #00000040}.control-button.active{background:#2196f3;color:#fff}.zoom-controls{display:flex;flex-direction:column;background:#fff;border-radius:4px;box-shadow:0 2px 8px #0003;overflow:hidden}.zoom-controls .control-button{border-radius:0;border-bottom:1px solid #e0e0e0;box-shadow:none;width:40px;height:40px}.zoom-controls .control-button:last-child{border-bottom:none}.zoom-controls .control-button:hover{background:#f8f9fa;box-shadow:none}.booth-palette{position:absolute;top:20px;right:20px;z-index:1000;max-width:300px;width:100%}.booth-palette-header{padding:16px 20px;background:#fffffff2;border-bottom:1px solid rgba(0,0,0,.1);font-weight:600;color:#333;display:flex;align-items:center;justify-content:space-between}.booth-palette-content{padding:16px;max-height:400px;overflow-y:auto}.booth-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.booth-type-item{padding:12px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s ease;text-align:center;background:#f8f9fa}.booth-type-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.booth-type-item.selected{border-color:#2196f3;background:#2196f31a}.booth-type-color{width:32px;height:32px;border-radius:6px;margin:0 auto 8px;border:2px solid rgba(0,0,0,.1)}.booth-type-code{font-weight:600;color:#333;font-size:14px;margin-bottom:4px}.booth-type-size{font-size:12px;color:#666;margin-bottom:4px}.booth-type-price{font-size:12px;color:#2196f3;font-weight:500}.booth{position:absolute;border-radius:6px;border:2px solid rgba(0,0,0,.2);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:#333;text-shadow:0 1px 2px rgba(255,255,255,.8);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.booth:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003;z-index:10}.booth.selected{border-color:#2196f3;border-width:3px;box-shadow:0 0 0 2px #2196f34d}.booth.available{border-color:#4caf50}.booth.hold{border-color:#ff9800}.booth.sold{border-color:#f44336}.booth-details{position:absolute;bottom:20px;right:20px;z-index:1000;width:320px;max-height:60vh;overflow-y:auto}.booth-details-header{padding:20px;background:#fffffff2;border-bottom:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:space-between}.booth-details-title{font-weight:600;color:#333;font-size:16px}.booth-details-content{padding:20px}.booth-details-field{margin-bottom:16px}.booth-details-label{display:block;font-size:12px;color:#666;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.booth-details-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s ease}.booth-details-input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.silk-background-container canvas{pointer-events:none!important}.booth-details-select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.booth-details-textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;min-height:80px;resize:vertical;font-family:inherit}.booth-details-actions{padding:16px 20px;background:#f8f9faf2;border-top:1px solid rgba(0,0,0,.1);display:flex;gap:12px}.btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover{background:#1976d2;transform:translateY(-1px)}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover{background:#d32f2f;transform:translateY(-1px)}.btn-secondary{background:#f8f9fa;color:#333;border:1px solid #ddd}.btn-secondary:hover{background:#e9ecef;transform:translateY(-1px)}.instructions{position:absolute;bottom:20px;left:20px;z-index:1000;max-width:400px}.instructions-content{padding:16px 20px;font-size:14px;color:#666;line-height:1.5}.instructions-title{font-weight:600;color:#333;margin-bottom:8px}.hold-press-indicator{position:absolute;pointer-events:none;z-index:1001;border-radius:50%;border:3px solid #2196f3;background:#2196f31a;transform:translate(-50%,-50%);animation:holdPressGrow 2s linear forwards}@keyframes holdPressGrow{0%{width:20px;height:20px;opacity:1}to{width:60px;height:60px;opacity:.8}}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:2000}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite}@keyframes contextMenuAppear{0%{opacity:0;transform:scale(.8) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:768px){.home-header{padding:12px 16px}.home-title{font-size:20px}.project-grid{padding:80px 16px 16px;grid-template-columns:1fr;gap:16px}.search-bar{top:12px;left:12px;right:12px;max-width:none}.back-button-container{top:70px;left:12px}.floating-controls{bottom:12px;right:12px;gap:8px}.control-button{width:36px;height:36px;font-size:16px}.zoom-controls .control-button{width:36px;height:36px}.booth-palette{top:12px;right:12px;max-width:280px}.booth-details{bottom:12px;right:12px;left:12px;width:auto;max-height:50vh}.booth-type-grid{grid-template-columns:repeat(3,1fr);gap:8px}.booth-type-item{padding:8px}.booth-type-color{width:24px;height:24px}}@media(max-width:480px){.control-button{width:40px;height:40px}.booth-palette-content{padding:12px}.booth-type-grid{grid-template-columns:repeat(2,1fr)}}.control-button:focus,.btn:focus,.booth-details-input:focus,.booth-details-select:focus,.booth-details-textarea:focus{outline:2px solid #2196f3;outline-offset:2px}.booth:focus{outline:2px solid #2196f3;outline-offset:2px}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@media print{.floating-controls,.booth-palette,.booth-details,.instructions{display:none!important}.map-viewer{background:#fff!important}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes boothWavePulse-available{0%,to{filter:brightness(1)}0.83%{filter:brightness(1.8);box-shadow:0 0 25px #c8c8c8e6,0 0 15px #c8c8c899}1.67%,to{filter:brightness(1)}}@keyframes boothWavePulse-hold{0%,to{filter:brightness(1)}0.83%{filter:brightness(1.8);box-shadow:0 0 25px #ffeb3be6,0 0 15px #ffeb3b99}1.67%,to{filter:brightness(1)}}@keyframes boothWavePulse-sold{0%,to{filter:brightness(1)}0.83%{filter:brightness(1.8);box-shadow:0 0 25px #f44336e6,0 0 15px #f4433699}1.67%,to{filter:brightness(1)}}@keyframes boothWavePulse-sold-complete{0%,to{filter:brightness(1)}0.83%{filter:brightness(1.8);box-shadow:0 0 25px #4caf50e6,0 0 15px #4caf5099}1.67%,to{filter:brightness(1)}}@keyframes boothWavePulse-default{0%,to{filter:brightness(1)}0.83%{filter:brightness(1.8);box-shadow:0 0 25px #9e9e9e99,0 0 15px #9e9e9e66}1.67%,to{filter:brightness(1)}}@keyframes warningPulse{0%,to{transform:translate(-50%,-50%) scale(1);box-shadow:0 4px 16px #ff1744cc,0 0 0 4px #ffffffe6}50%{transform:translate(-50%,-50%) scale(1.15);box-shadow:0 6px 24px #ff1744,0 0 0 6px #fff}}
