@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--paper: #f6f5ef;--paper-2: #ecebe3;--card: #fbfaf6;--ink: #16160f;--ink-2: #565550;--ink-3: #8a8980;--rule: #e5e3d8;--rule-2: #d4d2c5;--accent: #3c5a7a;--accent-2: #5577a0;--accent-on: #f6f5ef;--focus: #3898ec;--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, Consolas, monospace;--fs-xs: 11px;--lh-xs: 1.45;--fs-sm: 13px;--lh-sm: 1.55;--fs-md: 15px;--lh-md: 1.65;--fs-lg: 17px;--lh-lg: 1.65;--fs-xl: 22px;--lh-xl: 1.4;--fs-2xl: 30px;--lh-2xl: 1.25;--fs-3xl: 44px;--lh-3xl: 1.1;--fs-4xl: 64px;--lh-4xl: 1.05;--tracking-tight: -.01em;--tracking-wide: .08em;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-7: 32px;--s-8: 48px;--s-9: 64px;--s-10: 96px;--s-11: 128px;--r-xs: 2px;--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--ease-out: cubic-bezier(.22, .61, .36, 1);--dur-fast: .14s;--dur-med: .24s;--dur-slow: .48s;--container: 1080px;--column: 720px;--density-pad-y: 96px;--density-stack: 48px;--density-card: 20px}[data-theme=dark]{--paper: #0f0f0c;--paper-2: #171714;--card: #161613;--ink: #ece9dc;--ink-2: #9c9b91;--ink-3: #6b6a62;--rule: #25241f;--rule-2: #34332c;--accent-on: #0f0f0c}[data-density=compact]{--density-pad-y: 64px;--density-stack: 32px;--density-card: 16px}[data-density=spacious]{--density-pad-y: 144px;--density-stack: 72px;--density-card: 28px}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:var(--fs-md);line-height:var(--lh-md);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv11";transition:background var(--dur-med) var(--ease-out),color var(--dur-med) var(--ease-out)}body{min-height:100vh;overflow-x:hidden}.mono{font-family:var(--font-mono);letter-spacing:-.01em;font-feature-settings:"calt" off}.mono-up{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-size:var(--fs-xs);color:var(--ink-2)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:500;color:var(--ink)}h1{font-family:var(--font-sans);font-size:var(--fs-4xl);line-height:var(--lh-4xl);letter-spacing:-.025em;font-weight:500}h2{font-family:var(--font-sans);font-size:var(--fs-3xl);line-height:var(--lh-3xl);letter-spacing:-.02em;font-weight:500}h3{font-family:var(--font-mono);font-size:var(--fs-md);font-weight:500;text-transform:lowercase;letter-spacing:0;color:var(--ink-2)}p{margin:0;max-width:60ch;text-wrap:pretty}.body-lg{font-size:var(--fs-lg);line-height:var(--lh-lg)}a{color:inherit;text-decoration:none;background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-position:0 100%;background-size:100% 1px;transition:color var(--dur-fast) var(--ease-out),background-size var(--dur-med) var(--ease-out)}a:hover{color:var(--accent);background-size:100% 2px}code,pre,kbd{font-family:var(--font-mono);font-size:.92em}code:not(pre code){background:var(--paper-2);padding:.08em .32em;border-radius:var(--r-xs);color:var(--ink)}.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--s-6)}.column{max-width:var(--column);margin-inline:auto;padding-inline:var(--s-6)}.rule{border:0;border-top:1px solid var(--rule);margin:0}.rule-strong{border-top-color:var(--rule-2)}.btn{display:inline-flex;align-items:center;gap:var(--s-2);font-family:var(--font-mono);font-size:var(--fs-sm);font-weight:500;padding:8px 14px;border-radius:var(--r-md);border:1px solid var(--rule-2);background:transparent;color:var(--ink);cursor:pointer;text-decoration:none;background-image:none;transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}.btn-primary:hover{background:var(--accent);border-color:var(--accent);color:var(--accent-on)}.tag{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:var(--fs-xs);padding:3px 8px;border-radius:var(--r-sm);background:color-mix(in oklab,#1e3a5f 8%,transparent);color:#1e3a5f;border:1px solid color-mix(in oklab,#1e3a5f 30%,transparent);white-space:nowrap}[data-theme=dark] .tag{background:color-mix(in oklab,#7a9bc4 14%,transparent);color:#b9cde6;border-color:color-mix(in oklab,#7a9bc4 35%,transparent)}.tag-accent{background:transparent;color:var(--accent);border:1px solid var(--accent)}.dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--accent);flex-shrink:0}::selection{background:var(--accent);color:var(--accent-on)}:focus-visible{outline:2px solid var(--focus);outline-offset:3px;border-radius:var(--r-xs)}.muted{color:var(--ink-2)}.subtle{color:var(--ink-3)}.flex{display:flex}.row{display:flex;align-items:center}.col{display:flex;flex-direction:column}.gap-2{gap:var(--s-2)}.gap-3{gap:var(--s-3)}.gap-4{gap:var(--s-4)}.gap-6{gap:var(--s-6)}.gap-8{gap:var(--s-8)}.fade-in{opacity:0;transform:translateY(6px)}.fade-in.is-visible{opacity:1;transform:translateY(0);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}.nav-stuck{background:color-mix(in oklab,var(--paper) 88%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--rule)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--rule-2);border-radius:999px;border:2px solid var(--paper)}::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}.app{min-height:100vh;display:flex;flex-direction:column}.topnav{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:var(--card);border-bottom:1px solid var(--rule);gap:32px}.topnav-brand{font-family:var(--font-sans);font-size:var(--fs-lg);font-weight:600;letter-spacing:-.01em;background:none;color:var(--ink)}.topnav-brand:hover{background:none;color:var(--accent)}.topnav-links{display:flex;gap:20px;flex:1}.topnav-links a{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--ink-2);background:none}.topnav-links a.active{color:var(--accent);background-size:100% 2px}.app-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:32px 28px}.landing{text-align:center}.landing-head{padding:60px 0 40px}.landing-title{font-size:var(--fs-4xl);font-weight:600;letter-spacing:-.025em;margin:0}.landing-sub{color:var(--ink-2);font-family:var(--font-mono);margin-top:8px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin:40px 0}.tool-card{background:var(--card);border:1px solid var(--rule);border-radius:8px;padding:28px;text-align:left;transition:all .2s;background-image:none!important;color:var(--ink)!important;display:block}.tool-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.tool-card-icon{font-size:36px;margin-bottom:8px}.tool-card h2{font-size:var(--fs-xl);margin:4px 0 10px;font-weight:600}.tool-card p{color:var(--ink-2);font-size:var(--fs-sm)}.tool-card-cta{display:block;margin-top:14px;font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--accent)}.landing-footer{margin-top:60px;padding:20px 0;border-top:1px solid var(--rule)}.auth-page{display:flex;align-items:center;justify-content:center;min-height:70vh}.auth-card{max-width:380px;width:100%}.card{background:var(--card);border:1px solid var(--rule);border-radius:8px;padding:var(--s-6);margin-bottom:var(--s-5)}.card h3{font-family:var(--font-mono);font-size:var(--fs-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--ink-2);margin-bottom:var(--s-4)}.app-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--s-7);border-bottom:1px solid var(--rule);padding-bottom:var(--s-5)}.app-title{font-size:var(--fs-3xl);margin:0}.field{display:flex;flex-direction:column;gap:4px}.field-label{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-3);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.field-input,select.field-input{font:var(--fs-md)/1.4 var(--font-sans);color:var(--ink);background:var(--paper);border:1px solid var(--rule-2);border-radius:4px;padding:8px 10px;outline:none}.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #3c5a7a26}.btn{font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:500;color:var(--ink);background:var(--paper);border:1px solid var(--rule-2);border-radius:4px;padding:8px 16px;cursor:pointer;transition:all .12s;background-image:none!important;text-decoration:none;display:inline-block}.btn:hover:not(:disabled){border-color:var(--ink);background:var(--card);color:var(--ink)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:var(--accent-on);background:var(--accent);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-2);border-color:var(--accent-2);color:var(--accent-on)}.btn-sm{padding:4px 10px;font-size:var(--fs-xs)}.btn-gold{background:#c9a44b;color:#16160f;border-color:#a88a3a}.btn-gold:hover:not(:disabled){background:#d8b863;color:#16160f}.btn-danger{color:#fff;background:#8a3a3a;border-color:#6b2a2a}.btn-danger:hover:not(:disabled){background:#a04a4a;color:#fff}.muted{color:var(--ink-3);font-size:var(--fs-sm)}.hint{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-3)}.form-err{background:#a0323214;border:1px solid rgba(160,50,50,.3);color:#8a2a2a;padding:8px 12px;border-radius:4px;font-size:var(--fs-sm)}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.library-card{background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:12px;position:relative}.library-card h4{margin:0 0 4px;font-size:var(--fs-md)}.library-badge{position:absolute;top:8px;right:8px;background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-size:9px;padding:2px 6px;border-radius:2px;text-transform:uppercase;letter-spacing:.5px}.preview-wrap{position:relative;display:inline-block;margin:var(--s-4) 0;max-width:100%;-webkit-user-select:none;user-select:none}.preview-img{max-width:100%;max-height:60vh;display:block;border:1px solid var(--rule-2);border-radius:4px}.grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.grid-overlay line{stroke:#5fae4d;stroke-width:2}.grid-overlay line.draggable{pointer-events:auto;cursor:ew-resize}.grid-overlay line.draggable.horizontal{cursor:ns-resize}.grid-overlay text{fill:#fff;stroke:#000;stroke-width:3;paint-order:stroke;opacity:.8}.tiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--s-3)}.tile-card{background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:8px}.tile-card img{width:100%;image-rendering:pixelated;border:1px solid var(--rule);border-radius:3px;display:block}.tile-role-badge{font-family:var(--font-mono);font-size:10px;padding:2px 6px;border-radius:2px;background:var(--ink);color:var(--paper);display:inline-block;margin-top:6px}.tile-role-badge.unset{background:#8a3a3a}.neighbor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin:8px 0}.neighbor-cell{aspect-ratio:1;border:1px solid var(--rule-2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff}.neighbor-cell.center{background:var(--accent);color:var(--accent-on);cursor:default;font-size:11px;font-weight:600}.neighbor-cell.water{background:#2a5577}.neighbor-cell.land{background:#7fa850}.neighbor-cell.any{background:#888}.tabs{display:flex;gap:var(--s-3);margin-bottom:var(--s-4)}.tab-btn{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--ink-2);background:transparent;border:1px solid var(--rule);border-radius:4px;padding:8px 14px;cursor:pointer;transition:all .15s}.tab-btn:hover{color:var(--ink);border-color:var(--rule-2)}.tab-btn.active{color:var(--accent-on);background:var(--accent);border-color:var(--accent)}@media (max-width: 700px){.topnav{padding:10px 16px;flex-wrap:wrap;gap:12px}.topnav-links{gap:12px;flex:auto}.app-content{padding:20px 16px}}.editor-layout{display:flex;flex-direction:column;height:calc(100vh - 60px);margin:-32px -28px}.editor-header{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--card);border-bottom:1px solid var(--rule);flex:0 0 auto}.editor-header>div:nth-child(2){flex:1}.editor-body{display:grid;grid-template-columns:260px 1fr 220px;flex:1;min-height:0}.palette{background:var(--card);border-right:1px solid var(--rule);display:flex;flex-direction:column;overflow:hidden}.palette-section{padding:12px 14px;border-bottom:1px solid var(--rule)}.palette-section-title{font-family:var(--font-mono);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--ink-3);margin-bottom:8px}.palette-tilesets{display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto}.palette-tileset-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:6px 10px;background:var(--paper);border:1px solid var(--rule);border-radius:4px;cursor:pointer;text-align:left}.palette-tileset-btn:hover{border-color:var(--ink-3)}.palette-tileset-btn.active{border-color:var(--accent);background:var(--accent);color:var(--accent-on)}.palette-tileset-btn.active .palette-tileset-meta{color:var(--accent-on);opacity:.8}.palette-tileset-name{font-size:var(--fs-sm);font-weight:500}.palette-tileset-meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-3)}.palette-tiles-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.palette-tile{aspect-ratio:1;padding:0;background:var(--paper);border:2px solid transparent;border-radius:3px;cursor:pointer;overflow:hidden}.palette-tile.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.palette-tile img{width:100%;height:100%;object-fit:contain;image-rendering:pixelated;display:block}.map-canvas-wrap{position:relative;background:#252420;overflow:hidden;-webkit-user-select:none;user-select:none}.map-canvas{width:100%;height:100%;display:block}.layer-panel{background:var(--card);border-left:1px solid var(--rule);padding:12px 14px;overflow-y:auto}.layer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}.layer-item{display:grid;grid-template-columns:auto auto 1fr auto;gap:6px;align-items:center;padding:6px 8px;background:var(--paper);border:1px solid var(--rule);border-radius:4px;cursor:pointer;font-size:var(--fs-sm)}.layer-item:hover{border-color:var(--ink-3)}.layer-item.active{border-color:var(--accent);background:var(--accent);color:var(--accent-on)}.layer-item button{background:none;border:0;cursor:pointer;padding:2px 4px;font-size:13px}.layer-name{font-weight:500}.layer-kind{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);text-transform:uppercase}.layer-item.active .layer-kind{color:var(--accent-on);opacity:.7}.toolbar{display:flex;align-items:center;gap:6px;background:var(--card);border-top:1px solid var(--rule);padding:8px 14px;flex:0 0 auto}.tool-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;min-width:60px;background:var(--paper);border:1px solid var(--rule);border-radius:4px;cursor:pointer;font-size:18px}.tool-btn:hover{border-color:var(--ink-3)}.tool-btn.active{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}.toolbar-status{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-3)}@media (max-width: 900px){.editor-body{grid-template-columns:200px 1fr 180px}}.prompt-block{position:relative;background:var(--paper);border:1px solid var(--rule);border-radius:4px;margin-top:8px}.prompt-block pre{margin:0;padding:14px 16px;font-family:var(--font-mono);font-size:var(--fs-sm);line-height:1.55;color:var(--ink);white-space:pre-wrap;word-break:break-word}.prompt-copy-btn{position:absolute;top:8px;right:8px;background:var(--card);color:var(--ink);border:1px solid var(--rule-2);border-radius:4px;padding:4px 10px;cursor:pointer;font-family:var(--font-mono);font-size:var(--fs-xs);transition:all .15s}.prompt-copy-btn:hover{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}.prompt-copy-btn.copied{background:#3a7a3a;color:#fff;border-color:#3a7a3a}.prompts-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:12px}.prompt-card{background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:16px}.prompt-card header{margin-bottom:8px}.prompt-card h4{margin:0 0 4px;font-size:var(--fs-lg);font-weight:600}.prompt-card .prompt-meta{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--ink-3)}.prompt-card .prompt-desc{font-size:var(--fs-sm);margin:8px 0}.prompts-vars-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:var(--fs-sm)}.prompts-vars-table th,.prompts-vars-table td{padding:6px 10px;text-align:left;border-bottom:1px solid var(--rule)}.prompts-vars-table th{font-family:var(--font-mono);font-size:var(--fs-xs);text-transform:uppercase;color:var(--ink-3)}.prompts-vars-table code{font-family:var(--font-mono);font-size:var(--fs-xs);background:var(--paper-2);padding:2px 6px;border-radius:3px}.ai-providers{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-top:12px}.ai-provider{background:var(--paper);border:1px solid var(--rule);border-radius:6px;padding:14px}.ai-provider header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.ai-icon{font-size:22px}.ai-provider h4{margin:0;font-size:var(--fs-md);font-weight:600;flex:1}.ai-link{font-family:var(--font-mono);font-size:var(--fs-xs);color:var(--accent);background:none;padding:0}.ai-provider ul{margin:8px 0 0;padding-left:18px;font-size:var(--fs-sm);color:var(--ink-2)}.ai-provider li{margin-bottom:4px}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-top:12px}.tip-item{background:var(--paper);border-left:3px solid var(--accent);padding:10px 14px;border-radius:0 4px 4px 0}.tip-item strong{display:block;margin-bottom:4px;font-size:var(--fs-sm)}.tip-item p{margin:0;font-size:var(--fs-sm)}.tileset-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:#0006;border-radius:6px;overflow:hidden;aspect-ratio:3/2;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.tileset-preview:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0000002e}.tileset-preview img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated;display:block;background:#222}.tileset-preview-slot{background:#1a1a1a}.tileset-preview-empty{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;color:#aaa;font-size:13px;padding:20px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:20px}.modal-backdrop>.card{width:100%;box-shadow:0 20px 60px #0006}
