*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:#0a0a0f;color:#ddd;overflow:hidden;height:100vh}#root{height:100vh}.app{width:100vw;height:100vh;position:relative;display:flex}.game-board-section{flex:1;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a1a24,#0a0a0f);position:relative}.start-screen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,#1a1a24,#0a0a0f);padding:24px}.start-card{max-width:480px;width:100%;text-align:center}.start-title{font-family:Kanit,sans-serif;font-size:32px;font-weight:800;text-transform:uppercase;letter-spacing:3px;color:#fff;margin:0;line-height:1}.start-subtitle{font-family:Kanit,sans-serif;font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:4px;color:#c9a84c;margin:6px 0 0}.start-description{margin:24px 0;color:#999;font-size:13px;line-height:1.6}.start-instructions{text-align:left;background:#ffffff08;border:1px solid #1e1e2e;border-radius:8px;padding:14px 18px;margin:0 0 24px}.start-instructions h3{font-family:Kanit,sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#6a6a8a;margin:0 0 8px}.start-instructions ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.start-instructions li{font-size:12px;color:#888;line-height:1.4;padding-left:12px;position:relative}.start-instructions li:before{content:"·";position:absolute;left:2px;color:#555;font-weight:700}.start-buttons{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.start-btn{padding:12px 20px;border-radius:8px;font-family:Kanit,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;border:1px solid}.start-btn-primary{background:linear-gradient(180deg,#c9a84c,#a88a30);border-color:#c9a84c;color:#0a0a0f}.start-btn-primary:hover{background:linear-gradient(180deg,#d4b55a,#b89a40);box-shadow:0 4px 20px #c9a84c4d}.start-btn-secondary{background:linear-gradient(180deg,#1a2a3a,#121828);border-color:#2a3a5a;color:#8ab4f8}.start-btn-secondary:hover{background:linear-gradient(180deg,#2a3a5a,#1a2838);border-color:#3a4a6a}.start-btn-ghost{background:transparent;border-color:#2a2a3a;color:#888}.start-btn-ghost:hover{background:#ffffff08;border-color:#3a3a5a;color:#bbb}.start-lang{display:flex;justify-content:center;gap:6px}.start-lang-btn{width:32px;height:28px;border:1px solid transparent;background:none;border-radius:5px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;padding:0;transition:all .12s;opacity:.45}.start-lang-btn:hover{opacity:1;background:#ffffff0f}.start-lang-active{opacity:1;border-color:#c9a84c;background:#c9a84c1a}.start-credits{margin-top:18px;font-size:.7rem;color:#888;text-align:center;line-height:1.4}.sidebar{width:230px;min-width:230px;height:100vh;background:#111118;border-left:1px solid #2a2a3a;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;z-index:50;flex-shrink:0;order:1}.sidebar-section{padding:10px 12px;border-bottom:1px solid #1e1e2e}.sidebar-section:last-child{border-bottom:none}.sidebar-heading{font-family:Kanit,sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#6a6a8a;margin:0 0 6px}.sidebar-actions{display:flex;flex-direction:column;gap:1px}.sidebar-btn{display:flex;align-items:center;gap:6px;width:100%;padding:5px 8px;background:transparent;border:1px solid transparent;border-radius:5px;color:#ccc;font-size:12px;font-family:inherit;cursor:pointer;transition:all .12s;text-align:left}.sidebar-btn:hover:not(:disabled){background:#1a1a2e;border-color:#2a2a4a;color:#fff}.sidebar-btn:disabled{opacity:.4;cursor:not-allowed}.sidebar-btn-icon{width:16px;text-align:center;font-size:12px;flex-shrink:0}.sidebar-btn-danger{color:#a55}.sidebar-btn-danger:hover:not(:disabled){background:#2a1515;border-color:#3a2020;color:#c55}.sidebar-btn-primary{background:linear-gradient(180deg,#1a2a3a,#121828);border-color:#2a3a5a;color:#8ab4f8;font-weight:600}.sidebar-btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#2a3a5a,#1a2838);border-color:#3a4a6a;color:#acf}.sidebar-sep{height:1px;background:#1e1e2e;margin:2px 0}.sidebar-flags{display:flex;flex-wrap:wrap;gap:4px}.sidebar-flag-btn{display:flex;align-items:center;justify-content:center;padding:4px 6px;background:transparent;border:1px solid transparent;border-radius:5px;cursor:pointer;transition:all .12s;font-family:inherit;color:#999}.sidebar-flag-btn:hover{background:#1a1a2e;border-color:#2a2a4a}.sidebar-flag-active{background:#c9a84c14;border-color:#c9a84c4d}.sidebar-flag-active:hover{background:#c9a84c1f;border-color:#c9a84c66}.sidebar-flag-emoji{font-size:18px;line-height:1}.sidebar-flag-label{display:none}.sidebar-instructions{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.sidebar-instructions li{display:flex;align-items:flex-start;gap:6px;font-size:11px;color:#888;line-height:1.35}.sidebar-instruction-icon{flex-shrink:0;width:14px;text-align:center;font-size:11px;margin-top:1px}.sidebar-stats{display:flex;flex-direction:column;gap:2px}.sidebar-stat-row{display:flex;align-items:center;gap:6px;padding:3px 4px;border-radius:4px;background:#ffffff05}.sidebar-stat-icon{width:16px;height:16px;object-fit:contain;flex-shrink:0}.sidebar-stat-icon-text{width:16px;text-align:center;font-size:12px;flex-shrink:0}.sidebar-stat-label{flex:1;font-size:11px;color:#aaa}.sidebar-stat-value{font-family:Kanit,sans-serif;font-size:12px;font-weight:600;min-width:32px;text-align:right}.stat-ok{color:#4aba6a}.stat-warn{color:#c55}.sidebar-stat-sep{height:1px;background:#1e1e2e;margin:2px 0}.sidebar-spawn-label{flex:1;font-size:11px;color:#aaa;text-transform:uppercase;font-weight:600;letter-spacing:.3px}.sidebar-spawn-label.stat-warn{color:#c55}.sidebar-spawn-icon{width:18px;height:18px;object-fit:contain;flex-shrink:0}.sidebar-spawn-check{color:#4aba6a;font-weight:700;font-size:11px;flex-shrink:0}.sidebar-spawn-x{color:#c55;font-weight:700;font-size:11px;flex-shrink:0}.game-board-viewport{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:16px}.game-board-container{position:relative;background:#2a2218;overflow:hidden}.game-board-credits{position:absolute;bottom:12px;right:16px;font-family:Kanit,sans-serif;font-size:20px;color:#ffffff26;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:10}.game-board-background{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none;pointer-events:none;z-index:0}.game-board-no-bg{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:repeating-conic-gradient(#222,#222 25%,#1a1a1a 0%,#1a1a1a 50%) 0 0 / 40px 40px;color:#555;font-size:28px;font-family:Kanit,sans-serif;text-align:center;padding:80px;pointer-events:none}.game-board-container.connecting,.connecting .room-tile{cursor:crosshair}.connecting .room-tile:hover{outline:3px solid #c9a84c;outline-offset:2px}.connect-tooltip{position:fixed;z-index:10000;pointer-events:none;background:#14141eeb;border:1px solid #c9a84c;border-radius:6px;padding:6px 10px;font-size:12px;color:#c9a84c;font-weight:500;white-space:nowrap;box-shadow:0 4px 12px #00000080}.room-tile{position:absolute;border:4px solid #8B7355;background:#1a1510;box-shadow:3px 4px 16px #000000b3;overflow:hidden;z-index:2;border-radius:6px;cursor:grab;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column}.room-tile:active{cursor:grabbing}.room-tile.dragging{opacity:.85;z-index:10;box-shadow:6px 8px 24px #000000e6}.room-header{border-bottom-style:none;border-bottom-color:#6b5a42;flex-shrink:0;display:flex;align-items:center;position:relative;background:var(--room-header-color);box-sizing:border-box}.room-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:var(--room-texture);background-size:cover;background-position:center;mix-blend-mode:overlay;opacity:.5;pointer-events:none}.initial-placement-icon{flex-shrink:0;position:relative;z-index:1}.room-header-content{flex:1;min-width:0;display:flex;flex-direction:column;position:relative;z-index:1}.room-name{font-family:Kanit,sans-serif;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text;padding-top:1px}.room-name-input{font-family:Kanit,sans-serif;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;line-height:1.35;background:#ffffff1a;border:1px solid #c9a84c;border-radius:3px;outline:none;padding:1px 4px 0;width:100%;display:block}.room-prop-tiles{display:flex;flex-wrap:wrap}.prop-tile-group{display:flex;align-items:center}.prop-tile-icon{display:inline-block;object-fit:contain}.room-image-container{position:relative;width:100%;flex:1;overflow:hidden;background:#2a2218}.room-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}.room-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2a2218,#1a1510);color:#555;font-size:14px}.path-overlay{position:absolute;top:0;left:0;z-index:1}.path-group{cursor:pointer}.path-group:hover polyline:last-of-type{stroke-width:8}.path-movement-icon{cursor:grab}.path-movement-icon:active{cursor:grabbing}.ctx-menu{background:#1a1a2e;border:1px solid #3a3a5a;border-radius:8px;padding:4px 0;min-width:200px;box-shadow:0 8px 32px #000000b3;font-size:13px;-webkit-user-select:none;user-select:none}.ctx-item{padding:8px 16px;cursor:pointer;transition:background .1s;color:#ddd}.ctx-item:hover{background:#2a2a4a}.ctx-disabled{opacity:.35;cursor:not-allowed}.ctx-disabled:hover{background:transparent}.ctx-danger{color:#c55}.ctx-danger:hover{background:#2a1515}.ctx-sep{height:1px;background:#2a2a3a;margin:4px 8px}.ctx-custom{padding:4px 12px}.ctx-prop-tile-row{display:flex;align-items:center;gap:6px;padding:3px 0}.ctx-prop-tile-icon{width:20px;height:20px;object-fit:contain;flex-shrink:0}.ctx-prop-tile-label{flex:1;font-size:12px;color:#aaa}.ctx-prop-tile-count{font-size:13px;font-weight:600;width:20px;text-align:center;font-family:Kanit,sans-serif}.ctx-prop-tile-btn{width:22px;height:22px;border:1px solid #333;background:#1a1a2a;color:#ddd;border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;padding:0}.ctx-prop-tile-btn:hover:not(:disabled){background:#2a2a4a;border-color:#555}.ctx-prop-tile-btn:disabled{opacity:.25;cursor:not-allowed}.ctx-colors{display:flex;gap:8px;padding:6px 0;justify-content:center}.ctx-color-btn{width:36px;height:36px;border-radius:6px;border:2px solid rgba(255,255,255,.15);cursor:pointer;transition:all .1s}.ctx-color-btn:hover{border-color:#fff;transform:scale(1.15)}.ctx-flags{display:flex;gap:4px;padding:6px 12px;justify-content:center}.ctx-flag-btn{width:30px;height:24px;border:1px solid transparent;background:none;border-radius:4px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;padding:0;transition:all .1s;opacity:.5}.ctx-flag-btn:hover{opacity:1;background:#ffffff14}.ctx-flag-active{opacity:1;border-color:#c9a84c;background:#c9a84c1f}.ctx-initial-placement-options{display:flex;gap:4px;flex-wrap:wrap;max-width:200px}.ctx-initial-placement-option{display:flex;align-items:center;justify-content:center;cursor:pointer;padding:2px;border:2px solid transparent;border-radius:4px;transition:all .1s}.ctx-initial-placement-option:hover{border-color:#ffffff4d}.ctx-initial-placement-option:has(input:checked){border-color:#c9a84c;background:#c9a84c26}.ctx-initial-placement-option.ctx-initial-placement-used{opacity:.4}.ctx-initial-placement-option input[type=radio]{display:none}.ctx-initial-placement-icon{width:28px;height:28px;object-fit:contain}.ctx-room-colors{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;max-width:180px}.ctx-room-color-btn{width:28px;height:28px;border:3px solid;border-radius:4px;cursor:pointer;transition:all .1s}.ctx-room-color-btn:hover{transform:scale(1.15)}.ctx-room-color-btn.active{outline:2px solid #c9a84c;outline-offset:2px}.ctx-breakable-wall-toggle{display:flex;gap:8px}.ctx-breakable-wall-btn{flex:1;padding:8px 16px;background:#1a1a2a;border:2px solid #333;border-radius:6px;color:#888;font-family:Kanit,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.ctx-breakable-wall-btn:hover:not(.disabled){background:#2a2a4a;border-color:#555;color:#ddd}.ctx-breakable-wall-btn.active{background:#2a3a2a;border-color:#4a8;color:#8c8}.ctx-breakable-wall-btn.disabled{opacity:.4;cursor:not-allowed}.validation-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.validation-modal{background:linear-gradient(180deg,#1a1a2e,#12121c);border:2px solid #cc5555;border-radius:12px;padding:24px;min-width:320px;max-width:480px;box-shadow:0 16px 48px #000c;animation:modalAppear .2s ease-out}@keyframes modalAppear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.validation-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #333}.validation-modal-icon{font-size:28px}.validation-modal-header h2{margin:0;font-family:Kanit,sans-serif;font-size:20px;font-weight:600;color:#c55}.validation-modal-content{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.validation-error-item{background:#cc55551a;border-left:3px solid #cc5555;padding:12px 14px;border-radius:0 6px 6px 0;font-size:14px;color:#ddd;line-height:1.4;transition:background .15s ease}.validation-error-item:hover{background:#cc555526}.validation-error-message{font-weight:500;color:#eee}.validation-error-description{margin-top:8px;font-size:13px;color:#aaa;line-height:1.5}.validation-modal-close{width:100%;padding:12px 20px;background:linear-gradient(180deg,#2a2a4a,#1a1a2e);border:1px solid #444;border-radius:8px;color:#fff;font-family:Kanit,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.validation-modal-close:hover{background:linear-gradient(180deg,#3a3a5a,#2a2a3e);border-color:#555}.import-modal{border-color:#58c;min-width:400px}.import-modal .validation-modal-header h2{color:#58c}.import-textarea{width:100%;min-height:150px;padding:12px;background:#0a0a12;border:1px solid #333;border-radius:6px;color:#ddd;font-family:monospace;font-size:12px;resize:vertical;box-sizing:border-box}.import-textarea:focus{outline:none;border-color:#58c}.import-textarea::placeholder{color:#666}.import-error{background:#cc55551a;border-left:3px solid #cc5555;padding:10px 14px;border-radius:0 6px 6px 0;font-size:14px;color:#c55}.import-modal-buttons{display:flex;gap:12px}.import-modal-buttons .validation-modal-close{flex:1}.import-cancel{background:linear-gradient(180deg,#2a2a3a,#1a1a22)}.import-confirm{background:linear-gradient(180deg,#2a4a6a,#1a2a3e);border-color:#58c}.import-confirm:hover{background:linear-gradient(180deg,#3a5a7a,#2a3a4e);border-color:#69d}.import-confirm:disabled{opacity:.5;cursor:not-allowed}.success-modal{border-color:#4a6}.success-modal .validation-modal-header{background:linear-gradient(180deg,#1a3a2a,#152520);border-bottom-color:#364}.success-modal .validation-modal-close{background:linear-gradient(180deg,#2a5a4a,#1a3a2e);border-color:#4a6}.success-modal .validation-modal-close:hover{background:linear-gradient(180deg,#3a6a5a,#2a4a3e);border-color:#5b7}.success-message{text-align:center;font-size:15px;color:#ddd;margin:0;padding:8px 0}.port-handle{opacity:.7;transition:opacity .15s ease}.port-handle:hover{opacity:1}.port-handle-circle{filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.path-group:hover .port-handle{opacity:1}.ctx-path-type-options{display:flex;gap:6px;flex-wrap:wrap}.ctx-path-type-btn{width:48px;height:48px;padding:4px;border:3px solid transparent;border-radius:8px;background:#1a1a1f;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.ctx-path-type-btn:hover{background:#252530;transform:scale(1.05)}.ctx-path-type-active{outline:2px solid #fff;outline-offset:2px;background:#252530}.ctx-path-type-btn img{width:38px;height:38px;object-fit:contain}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0a0a0f}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555}
