:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.map-editor{display:flex;flex-direction:column;height:100%;gap:1rem}.editor-section{display:flex;flex-direction:column;flex:1;min-height:0;background:#fafafa;border-radius:6px;padding:.75rem;border:1px solid #e0e0e0}.editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.editor-section h3{margin:0;font-size:.9rem;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.example-selector{padding:.4rem 2rem .4rem .8rem;font-size:.8rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500;box-shadow:0 2px 4px #667eea33;appearance:none;background-image:linear-gradient(135deg,#667eea,#764ba2);background-repeat:no-repeat;background-position:right .5rem center;background-size:auto}.example-selector:hover{transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.example-selector:active{transform:translateY(0);box-shadow:0 1px 2px #667eea33}.example-selector:focus{outline:none;box-shadow:0 0 0 3px #667eea4d}.editor-editable{white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.library-inline-link{color:#667eea;text-decoration:underline;cursor:pointer;transition:color .2s}.library-inline-link:hover{color:#764ba2;text-decoration:underline}.editor-textarea{flex:1;width:100%;padding:.75rem;font-family:SF Mono,Monaco,Inconsolata,Fira Code,Courier New,monospace;font-size:.85rem;line-height:1.5;border:1px solid #d0d0d0;border-radius:4px;resize:none;background:#fff;color:#2d2d2d;transition:all .2s}.editor-textarea:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}@media(max-width:1024px){.editor-section{min-height:150px}.editor-textarea{min-height:100px}}@media(max-width:640px){.map-editor{gap:.5rem;overflow-y:auto}.editor-section{flex:0 0 auto;min-height:120px}.editor-section h3{font-size:.9rem;margin-bottom:.25rem}.editor-textarea{font-size:.85rem;padding:.5rem;min-height:80px;height:100px}}.map-preview{height:100%;display:flex;flex-direction:column;background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.preview-messages{padding:.75rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:1px solid #f59e0b}.preview-message{font-size:.8rem;color:#92400e;margin:.25rem 0;line-height:1.4}.preview-actions{padding:.75rem;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;gap:.5rem;flex-wrap:wrap}.svg-download-button,.svg-fullpage-button{display:inline-flex;align-items:center;padding:.5rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #10b98133;text-transform:uppercase;letter-spacing:.5px}.svg-download-button:hover,.svg-fullpage-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.svg-download-button:active,.svg-fullpage-button:active{transform:translateY(0);box-shadow:0 1px 2px #10b98133}.preview-svg{flex:1;overflow:auto;padding:1.5rem;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.preview-svg svg{max-width:100%;max-height:100%;width:auto;height:auto;box-shadow:0 4px 12px #00000026;border-radius:4px;background:#fff}.preview-empty{flex:1;display:flex;justify-content:center;align-items:center;color:#9ca3af;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.preview-empty p{margin:0;font-size:.95rem;font-weight:500}@media(max-width:640px){.preview-messages{padding:.5rem}.preview-message{font-size:.8rem}.preview-actions{padding:.5rem}.svg-download-button,.svg-fullpage-button{padding:.4rem .8rem;font-size:.85rem}.preview-svg{padding:.5rem}.preview-empty p{font-size:.9rem}}.generator-panel{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:8px;border:1px solid #dbe2ef;margin-bottom:1rem;box-shadow:0 1px 3px #0000000d}.generator-panel h3{margin:0;color:#2d3748;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.generator-type-selector{display:flex;gap:.5rem;background:#ffffff80;padding:.35rem;border-radius:6px;margin-bottom:.5rem}.generator-type-selector label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.8rem;padding:.35rem .75rem;border-radius:4px;transition:background .2s;-webkit-user-select:none;user-select:none;flex:1;justify-content:center;font-weight:500}.generator-type-selector label:hover{background:#ffffffb3}.generator-type-selector input[type=radio]{cursor:pointer;accent-color:#667eea}.generator-type-selector input[type=radio]:checked+span{font-weight:600}.generator-form{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}.form-group{display:flex;flex-direction:column;gap:.2rem}.form-group label{font-size:.75rem;font-weight:600;color:#2d3748}.form-group input[type=number],.form-group input[type=text]{padding:.4rem .6rem;border:1px solid #cbd5e0;border-radius:4px;font-size:.85rem;font-family:inherit;background:#fff;transition:all .2s}.form-group input[type=number]:focus,.form-group input[type=text]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.seed-input{display:flex;gap:.25rem}.seed-input input{flex:1}.seed-button{padding:.35rem .5rem;background-color:#fff;border:1px solid #ced4da;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s;line-height:1}.seed-button:hover{background-color:#e9ecef}.seed-button:active{background-color:#dee2e6}.generate-button{padding:.6rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;grid-column:1 / -1;box-shadow:0 2px 6px #667eea4d;text-transform:uppercase;letter-spacing:.5px}.generate-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.generate-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #667eea4d}.generate-button:disabled{background:linear-gradient(135deg,#a0aec0,#718096);cursor:not-allowed;opacity:.7;box-shadow:none;transform:none}.dungeon-options{grid-column:1 / -1;display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:#fff9;border-radius:6px;border:1px solid rgba(203,213,224,.5)}.options-section{display:flex;flex-direction:column;gap:.4rem}.options-section h4{margin:0 0 .25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#667eea}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.8rem;padding:.25rem 0;-webkit-user-select:none;user-select:none}.checkbox-label:hover{color:#667eea}.checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#667eea;width:16px;height:16px}.shape-type-selector{display:flex;gap:.5rem;padding:.5rem 0 0 1.5rem;flex-wrap:wrap}.shape-type-selector label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;transition:background .2s;-webkit-user-select:none;user-select:none;background:#ffffff80}.shape-type-selector label:hover{background:#fffc}.shape-type-selector input[type=radio]{cursor:pointer;accent-color:#667eea}.generator-info{padding-top:.5rem;border-top:1px solid rgba(255,255,255,.5)}.info-text{margin:0 0 .25rem;font-size:.7rem;color:#4a5568;line-height:1.4}.info-text:last-child{margin-bottom:0}.info-text strong{font-size:.75rem;color:#2d3748}@media(max-width:768px){.generator-form{grid-template-columns:1fr 1fr}.form-group:nth-child(3){grid-column:1 / -1}}@media(max-width:640px){.generator-form{grid-template-columns:1fr}.generate-button{grid-column:1}}.interactive-svg-overlay{width:100%;height:100%;cursor:crosshair;display:flex;align-items:center;justify-content:center;background:#f9f9f9;overflow:hidden}.interactive-svg-overlay>div{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:auto}.interactive-svg-overlay svg{display:block;width:100%;height:100%;object-fit:contain}.terrain-palette{display:flex;gap:1rem;align-items:center}.palette-label-text{font-weight:500;color:#333;white-space:nowrap}.palette-items{display:flex;gap:.5rem;flex-wrap:wrap}.palette-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border:2px solid transparent;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s}.palette-item:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 2px 4px #0000001a}.palette-item.selected{border-color:#667eea;background:#f0f4ff}.palette-icon{width:48px;height:48px;border-radius:4px;border:1px solid rgba(0,0,0,.1);background:#fff;display:block}.palette-label{font-size:.75rem;color:#333;font-weight:500}@media(max-width:640px){.terrain-palette{flex-direction:column;align-items:flex-start;gap:.5rem}.palette-label-text{font-size:.85rem}.palette-items{width:100%;gap:.4rem}.palette-item{padding:.4rem}.palette-icon{width:40px;height:40px}.palette-label{font-size:.65rem}}.visual-editor{display:flex;flex-direction:column;height:100%}.visual-editor-toolbar{padding:.75rem;background:#f5f5f5;border-bottom:1px solid #ddd;flex-shrink:0;display:flex;flex-direction:column;gap:.75rem}.zone-mode-toggle{display:flex;align-items:center}.zone-mode-toggle label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#333;-webkit-user-select:none;user-select:none}.zone-mode-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:#667eea}.zone-mode-toggle span{font-weight:500}.visual-editor-canvas{flex:1;overflow:auto;background:#fff;min-height:0;position:relative}.visual-editor-canvas .edge-expand-button{position:absolute;width:32px;height:32px;background:#667eea;color:#fff;border:none;border-radius:50%;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;transition:all .2s;z-index:10;line-height:1;padding:0}.visual-editor-canvas .edge-expand-button:hover{background:#5568d3;transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.visual-editor-canvas .edge-expand-button:active{transform:scale(.95)}.visual-editor-canvas .edge-expand-top{top:10px;left:50%;transform:translate(-50%)}.visual-editor-canvas .edge-expand-top:hover{transform:translate(-50%) scale(1.1)}.visual-editor-canvas .edge-expand-bottom{bottom:10px;left:50%;transform:translate(-50%)}.visual-editor-canvas .edge-expand-bottom:hover{transform:translate(-50%) scale(1.1)}.visual-editor-canvas .edge-expand-left{left:10px;top:50%;transform:translateY(-50%)}.visual-editor-canvas .edge-expand-left:hover{transform:translateY(-50%) scale(1.1)}.visual-editor-canvas .edge-expand-right{right:10px;top:50%;transform:translateY(-50%)}.visual-editor-canvas .edge-expand-right:hover{transform:translateY(-50%) scale(1.1)}@media(max-width:640px){.visual-editor-canvas .edge-expand-button{width:40px;height:40px;font-size:24px}}.visual-editor-status{display:flex;gap:1.5rem;padding:.5rem .75rem;background:#fafafa;border-top:1px solid #ddd;font-size:.85rem;color:#666;flex-shrink:0}.visual-editor-status span{font-family:monospace}#root{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.app{display:flex;flex-direction:column;height:100%;width:100%;background:#f5f5f5}.app-header{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom:none;box-shadow:0 2px 8px #0000001a;flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.app-header-title{display:flex;align-items:baseline;gap:1rem}.app-header h1{margin:0;font-size:1.4rem;font-weight:600}.app-header p{margin:0;font-size:.85rem;opacity:.9}.app-header-controls{display:flex;gap:1rem;align-items:center}.edit-mode-toggle{display:flex;gap:.25rem;background:#ffffff26;padding:.35rem;border-radius:6px}.edit-mode-toggle button{padding:.35rem .75rem;border:none;background:transparent;color:#fff;cursor:pointer;border-radius:4px;font-size:.85rem;transition:background .2s}.edit-mode-toggle button:hover{background:#ffffff1a}.edit-mode-toggle button.active{background:#ffffff40;font-weight:500}.geometry-selector{display:flex;gap:.5rem;background:#ffffff26;padding:.35rem;border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.geometry-selector label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.85rem;padding:.35rem .75rem;border-radius:4px;transition:background .2s;-webkit-user-select:none;user-select:none}.geometry-selector label:hover{background:#ffffff1a}.geometry-selector input[type=radio]{cursor:pointer;accent-color:white}.geometry-selector input[type=radio]:checked+span{font-weight:500}.app-content{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem;overflow:hidden;max-width:1800px;width:100%;margin:0 auto;min-height:0}.app-panel{min-width:0;min-height:0;overflow:auto;display:flex;flex-direction:column;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:1rem}.visual-mode-panel{padding:0;overflow:hidden;grid-column:1 / -1}.visual-editor{display:flex;flex-direction:column;height:100%;background:#fafafa}.visual-editor-toolbar{padding:.75rem;background:#f5f5f5;border-bottom:1px solid #ddd;flex-shrink:0}@media(max-width:1024px){.app-content{grid-template-columns:1fr;grid-template-rows:auto 1fr;gap:.75rem;padding:.75rem}.app-content:has(.app-panel:first-child) .app-panel:first-child{max-height:50vh;overflow-y:auto}.app-content:has(.visual-mode-panel){grid-template-rows:1fr}.visual-mode-panel{max-height:none!important}.app-header{flex-direction:column;align-items:flex-start;gap:.5rem}.app-header-title{flex-direction:column;gap:.25rem;align-items:flex-start}.app-header-controls{width:100%;flex-wrap:wrap}}@media(max-width:640px){.app-header{padding:.75rem 1rem}.app-header h1{font-size:1.2rem}.app-header p{font-size:.75rem}.app-content{padding:.5rem;gap:.5rem;grid-template-rows:auto 1fr}.app-content:has(.app-panel:first-child) .app-panel:first-child{max-height:40vh}.app-panel{padding:.75rem}.app-content:has(.visual-mode-panel){grid-template-rows:1fr}.visual-mode-panel{padding:0;max-height:none!important}.visual-editor-toolbar{padding:.5rem}.visual-editor-status{flex-direction:column;gap:.25rem;padding:.5rem;font-size:.75rem}.app-header-controls{flex-direction:column;gap:.5rem}.edit-mode-toggle{width:100%}.edit-mode-toggle button{flex:1;text-align:center}.geometry-selector{width:100%;justify-content:space-between}.geometry-selector label{flex:1;justify-content:center;font-size:.8rem;padding:.4rem .5rem}}
