﻿:root,[data-theme=light]{--bg: #f5f5f5;--surface: #ffffff;--surface-alt: #f0f0f0;--border: #e0e0e0;--border-light: #d0d0d0;--primary: #4a7c59;--primary-dark: #3a6248;--primary-light: #6aad7a;--accent: #e8b84b;--accent-dark: #c49a35;--danger: #d32f2f;--danger-hover: #f44336;--text: #212121;--text-muted: #757575;--text-dark: #212121;--text-on-primary:#ffffff;--shadow: rgba(0,0,0,0.08);--shadow-lg: rgba(0,0,0,0.12)}[data-theme=dark]{--bg: #121212;--surface: #1e1e1e;--surface-alt: #2a2a2a;--border: #333333;--border-light: #444444;--primary: #6aad7a;--primary-dark: #4a7c59;--primary-light: #8cd49a;--accent: #e8b84b;--accent-dark: #c49a35;--danger: #ef5350;--danger-hover: #f44336;--text: #e0e0e0;--text-muted: #9e9e9e;--text-dark: #ffffff;--text-on-primary:#000000;--shadow: rgba(0,0,0,0.3);--shadow-lg: rgba(0,0,0,0.5)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:"Inter","Segoe UI",system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.4}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}input,select{font-family:inherit;font-size:inherit}ul{list-style:none}canvas{display:block}.toolbar{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 1px 4px var(--shadow);z-index:100;flex-shrink:0;gap:10px}.toolbar__brand{display:flex;align-items:center;gap:8px}.toolbar__title{font-size:15px;font-weight:700;color:var(--primary);letter-spacing:.3px;white-space:nowrap}.toolbar__actions{display:flex;align-items:center;gap:6px}.toolbar__select{background:var(--surface-alt);color:var(--text);border:1px solid var(--border);border-radius:50px;padding:5px 14px;height:32px;font-size:12px;cursor:pointer;transition:all .15s ease}.toolbar__select:hover{border-color:var(--primary)}.toolbar__select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(74,124,89,.15)}.toolbar__select option{background:var(--surface)}.toolbar__btn{background:var(--surface-alt);color:var(--text);border:1px solid var(--border);border-radius:50px;padding:5px 16px;height:32px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.toolbar__btn:hover{background:var(--primary);border-color:var(--primary);color:var(--text-on-primary);box-shadow:0 2px 6px var(--shadow)}.toolbar__btn--danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.sidebar{width:220px;min-width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;z-index:90}.sidebar__search{padding:10px;border-bottom:1px solid var(--border)}.sidebar__input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:50px;padding:7px 14px;font-size:12px;color:var(--text);transition:all .15s ease}.sidebar__input::placeholder{color:var(--text-muted)}.sidebar__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(74,124,89,.12)}.sidebar__categories{flex:1;overflow-y:auto;overflow-x:hidden}.sidebar__categories::-webkit-scrollbar{width:4px}.sidebar__categories::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.sidebar__categories::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sidebar__tools{border-top:1px solid var(--border);padding:10px}.category{border-bottom:1px solid var(--border)}.category__header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface);color:var(--text);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:background .15s ease}.category__header:hover{background:var(--surface-alt)}.category__arrow{font-size:9px;transition:transform .15s ease;color:var(--text-muted)}.category.is-collapsed .category__arrow{transform:rotate(-90deg)}.category.is-collapsed .category__items{display:none}.category__items{display:grid;grid-template-columns:repeat(3, 1fr);gap:4px;padding:6px;background:var(--bg)}.palette-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 3px 5px;border:1px solid rgba(0,0,0,0);border-radius:10px;cursor:pointer;background:var(--surface);transition:all .15s ease}.palette-item:hover{border-color:var(--primary);background:var(--surface-alt);transform:translateY(-1px);box-shadow:0 2px 6px var(--shadow)}.palette-item.is-selected{border-color:var(--primary);background:var(--surface-alt);box-shadow:0 0 0 2px var(--primary) inset}.palette-item__sprite{flex-shrink:0;image-rendering:pixelated;image-rendering:crisp-edges}.palette-item__label{font-size:10px;text-align:center;color:var(--text-muted);line-height:1.25;word-break:break-word;hyphens:auto}.tools-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px}.tools-group{display:flex;gap:4px}.tool-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface);font-size:16px;cursor:pointer;transition:all .15s ease}.tool-btn:hover{border-color:var(--primary);background:var(--surface-alt);transform:translateY(-1px);box-shadow:0 2px 4px var(--shadow)}.tool-btn.active{border-color:var(--primary);background:var(--primary);color:var(--text-on-primary);box-shadow:0 2px 8px var(--shadow)}.tool-btn__icon{pointer-events:none}.canvas-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.canvas-controls{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.zoom-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;border:1px solid var(--border-light);background:var(--surface-alt);color:var(--text);font-size:14px;font-weight:bold;line-height:1;transition:border-color .15s ease}.zoom-btn:hover{border-color:var(--primary);color:var(--primary)}.zoom-level{font-size:11px;color:var(--text-muted);min-width:38px;text-align:center}.toggle-label{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted);cursor:pointer;user-select:none;margin-left:4px}.toggle-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer}.canvas-viewport{flex:1;overflow:auto;position:relative;cursor:crosshair}.canvas-viewport::-webkit-scrollbar{width:8px;height:8px}.canvas-viewport::-webkit-scrollbar-track{background:var(--bg)}.canvas-viewport::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}.canvas-viewport::-webkit-scrollbar-corner{background:var(--bg)}.canvas-container{position:relative;display:inline-block;margin:24px;box-shadow:0 0 0 2px var(--border),0 8px 32px rgba(0,0,0,.5)}.canvas-container #farm-canvas{display:block;pointer-events:auto}.canvas-container #overlay-canvas{position:absolute;top:0;left:0;z-index:10;pointer-events:none}.ref-divider{width:1px;height:18px;background:var(--border);margin:0 4px;flex-shrink:0}.ref-btn{font-size:14px;width:26px;height:26px}.ref-btn--remove{color:var(--danger);font-size:12px;font-weight:bold}.ref-btn--remove:hover{border-color:var(--danger)}.ref-controls{display:flex;align-items:center;gap:6px}.ref-slider{width:90px;height:4px;appearance:none;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.ref-slider::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer;border:2px solid var(--surface);box-shadow:0 0 0 1px var(--primary)}.ref-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary);cursor:pointer;border:2px solid var(--surface)}.ref-opacity-label{font-size:11px;color:var(--text-muted);min-width:30px;text-align:right}.vis-legend{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.vis-legend__label{font-size:11px;color:var(--text-muted);margin-right:2px;white-space:nowrap}.vis-legend__btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:11px;cursor:pointer;user-select:none;transition:border-color .15s ease,opacity .15s ease,background .15s ease;white-space:nowrap}.vis-legend__btn span{pointer-events:none}.vis-legend__btn:hover{border-color:var(--primary)}.vis-legend__btn[data-mode="1"]{border-color:var(--primary);opacity:.7;background:color-mix(in srgb, var(--primary) 8%, var(--bg))}.vis-legend__btn[data-mode="2"]{border-color:var(--border);opacity:.4}.vis-legend__btn[data-mode="2"] span{text-decoration:line-through}.canvas-viewport[data-tool=place]{cursor:crosshair}.canvas-viewport[data-tool=erase]{cursor:cell}.canvas-viewport[data-tool=fill]{cursor:copy}.canvas-viewport[data-tool=select]{cursor:default}.canvas-viewport[data-tool=move]{cursor:grab}.canvas-viewport[data-tool=ruler]{cursor:crosshair}.canvas-viewport.ctrl-pick-mode{cursor:cell !important}.info-panel{width:200px;min-width:200px;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.info-panel__title{padding:10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--primary);border-bottom:1px solid var(--border);background:var(--surface-alt)}.info-panel__content{flex:1;overflow-y:auto;padding:10px}.info-panel__hint{font-size:11px;color:var(--text-muted);line-height:1.5}.info-panel__sprite-preview{display:flex;justify-content:center;padding:12px;margin-bottom:8px}.info-panel__sprite-preview canvas{image-rendering:pixelated;image-rendering:crisp-edges}.info-panel__name{font-size:14px;font-weight:700;color:var(--primary);margin-bottom:4px;text-align:center}.info-panel__category{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);text-align:center;margin-bottom:12px}.info-panel__props{display:flex;flex-direction:column;gap:6px}.info-panel__prop{display:flex;justify-content:space-between;font-size:11px;padding:4px 0;border-bottom:1px solid var(--border)}.info-panel__prop-label{color:var(--text-muted)}.info-panel__prop-value{color:var(--text);font-weight:600}.loading-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999}.loading-screen__box{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}.loading-screen__title{font-size:24px;font-weight:700;color:var(--primary);letter-spacing:1px}.loading-screen__bar{width:220px;height:8px;background:var(--surface-alt);border-radius:4px;overflow:hidden;border:1px solid var(--border-light)}.loading-screen__fill{height:100%;width:60%;background:var(--primary);border-radius:4px;animation:loading-pulse 1.2s ease-in-out infinite}.loading-screen__text{font-size:12px;color:var(--text-muted)}@keyframes loading-pulse{0%,100%{width:20%}50%{width:80%}}#app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.workspace{display:flex;flex:1;overflow:hidden}.app-footer{width:100%;padding:6px 16px;background:var(--surface);border-top:1px solid var(--border);font-size:11px;color:var(--text-muted);text-align:center;flex-shrink:0}.app-footer a{color:var(--primary);text-decoration:none}.app-footer a:hover{text-decoration:underline}.info-panel__range-stats{padding:8px 12px;border-top:1px solid var(--border);font-size:12px;color:var(--text);line-height:1.8}.info-panel__range-stats strong{color:var(--primary-light)}.info-panel__shortcuts{margin-top:auto;padding:10px 12px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted);line-height:1.8}.info-panel__shortcuts-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px}.shortcut{display:flex;align-items:center;gap:4px;flex-wrap:wrap}kbd{display:inline-block;padding:1px 5px;font-size:10px;font-family:"Inter","Segoe UI",system-ui,sans-serif;color:var(--text);background:var(--bg);border:1px solid var(--border-light);border-radius:3px;box-shadow:0 1px 0 rgba(0,0,0,.3);line-height:1.4;white-space:nowrap}.toolbar__save-wrap{position:relative}.save-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 16px var(--shadow-lg);padding:4px;z-index:10000;min-width:200px}.save-menu__item{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;background:none;color:var(--text);font-size:13px;cursor:pointer;border-radius:6px;width:100%;text-align:left}.save-menu__item:hover{background:var(--surface-alt)}.save-menu__item.is-locked{opacity:.5;cursor:not-allowed}.save-menu__item.is-locked::after{content:" 🔒"}.cookie-fab{position:fixed;bottom:16px;left:16px;z-index:99998;width:44px;height:44px;border-radius:50%;border:none;background:var(--surface);box-shadow:0 2px 8px var(--shadow-lg);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}.cookie-fab:hover{transform:scale(1.1)}.cookie-fab--pulse{animation:fab-pulse .6s ease 3}@keyframes fab-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}.settings-panel__select{padding:3px 6px;background:var(--surface-alt);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;margin-left:auto}.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:99999;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 28px;display:flex;align-items:center;gap:20px;box-shadow:0 8px 32px var(--shadow-lg),0 2px 8px var(--shadow);max-width:600px;width:calc(100% - 40px);animation:cookie-slide-up .35s ease-out}@keyframes cookie-slide-up{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.cookie-banner__text{color:var(--text);font-size:13px;line-height:1.5;flex:1}.cookie-banner__text::before{content:"🍪 ";font-size:16px}.cookie-banner__actions{display:flex;gap:10px;flex-shrink:0}.cookie-banner__btn{padding:10px 22px;border:none;border-radius:50px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.cookie-banner__btn--accept{background:linear-gradient(135deg, #4a7c59, #6aad7a);color:#fff;box-shadow:0 2px 8px rgba(74,124,89,.3)}.cookie-banner__btn--accept:hover{background:linear-gradient(135deg, #3a6248, #5a9d6a);box-shadow:0 4px 12px rgba(74,124,89,.4);transform:translateY(-1px)}.cookie-banner__btn--reject{background:rgba(0,0,0,0);color:var(--text-muted);border:1px solid var(--border-light)}.cookie-banner__btn--reject:hover{background:var(--surface-alt);color:var(--text);border-color:var(--text-muted)}.mode-toast{position:fixed;top:60px;right:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px 20px;color:var(--text);font-size:13px;font-weight:600;z-index:10000;pointer-events:none;opacity:0;transform:translateY(-8px);transition:opacity .2s,transform .2s;box-shadow:0 4px 16px var(--shadow-lg)}.mode-toast.is-visible{opacity:1;transform:translateY(0)}.toolbar__lang-wrap{position:relative}.toolbar__btn--lang{font-size:18px;padding:2px 8px;line-height:1}.lang-panel{position:absolute;top:100%;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.5);padding:4px;z-index:10000;display:flex;flex-direction:column;gap:2px;min-width:140px}.lang-panel__item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:none;background:none;color:var(--text);font-size:13px;cursor:pointer;border-radius:6px;text-align:left;width:100%}.lang-panel__item:hover{background:var(--surface-alt)}.lang-panel__item.is-active{background:var(--surface-alt);color:var(--primary-light);font-weight:600}.lang-panel__item span:first-child{font-size:18px}.toolbar__settings-wrap{position:relative}.settings-panel{position:absolute;top:100%;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.5);padding:10px 14px;min-width:240px;z-index:10000}.settings-panel__option{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);cursor:pointer;white-space:nowrap}.settings-panel__option input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}.settings-panel__divider{border:none;border-top:1px solid var(--border);margin:6px 0}.ctx-menu{position:fixed;z-index:10000;background:var(--surface);border:1px solid var(--border-light);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.5);align-items:flex-start;gap:0}.ctx-menu__left{min-width:200px;max-width:220px;max-height:400px;overflow-y:auto;padding:6px;flex-shrink:0}.ctx-menu__right{min-width:150px;max-width:170px;max-height:400px;overflow-y:auto;padding:6px;border-left:1px solid var(--border);flex-shrink:0}.ctx-menu__search{width:100%;padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;outline:none;box-sizing:border-box}.ctx-menu__search:focus{border-color:var(--primary)}.ctx-menu__search::placeholder{color:var(--text-muted)}.ctx-menu__section{font-size:10px;text-transform:uppercase;color:var(--text-muted);padding:6px 4px 2px;letter-spacing:.5px}.ctx-menu__grid{display:flex;flex-direction:column;gap:1px}.ctx-menu__item{display:flex;align-items:center;gap:8px;padding:4px 6px;border:none;background:none;color:var(--text);font-size:12px;cursor:pointer;border-radius:6px;text-align:left;width:100%}.ctx-menu__item canvas{flex-shrink:0;image-rendering:pixelated}.ctx-menu__item:hover{background:var(--surface-alt)}.ctx-menu__item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}/*# sourceMappingURL=main.css.map */
