[data-v-73b2983c]:root{--color-bg: #ffffff;--color-text: #374151;--color-text-strong: #111827;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--layout-max-width: 1200px;--font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Microsoft YaHei, sans-serif}.dev-tool-page__header[data-v-73b2983c]{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.dev-tool-page__header h1[data-v-73b2983c]{margin:0 0 8px;font-size:24px;font-weight:700;color:#111827;letter-spacing:-.01em;line-height:1.3}.dev-tool-page__subtitle[data-v-73b2983c]{margin:0 0 16px;font-size:14px;color:#6b7280;line-height:1.5}.dev-tool-page__actions[data-v-73b2983c]{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.dev-tool-page__mode[data-v-73b2983c],.dev-tool-page__buttons[data-v-73b2983c]{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.dev-tool-page button[data-v-73b2983c]{padding:8px 14px;min-height:36px;background:#fafbfc;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .12s ease}.dev-tool-page button[data-v-73b2983c]:hover{border-color:#2563eb;color:#2563eb}.dev-tool-page button[data-v-73b2983c]:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.dev-tool-page button[data-v-73b2983c]:active{transform:scale(.97)}.dev-tool-page button[data-v-73b2983c]:disabled{opacity:.45;cursor:not-allowed;transform:none}.dev-tool-page button.active[data-v-73b2983c]{background:#2563eb;border-color:#2563eb;color:#fff}.dev-tool-page__primary[data-v-73b2983c]{background:#2563eb!important;border-color:#2563eb!important;color:#fff!important;font-weight:600!important}.dev-tool-page__primary[data-v-73b2983c]:hover{background:#1d4ed8!important;border-color:#1d4ed8!important;color:#fff!important}.dev-tool-page__link[data-v-73b2983c]{padding:0;min-height:unset;border:none;background:none;color:#2563eb;font-size:13px;font-weight:400}.dev-tool-page__link[data-v-73b2983c]:hover{text-decoration:underline;color:#1d4ed8}.dev-tool-page__link[data-v-73b2983c]:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.dev-tool-page__main[data-v-73b2983c]{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}@media(max-width:768px){.dev-tool-page__main[data-v-73b2983c]{grid-template-columns:1fr}}.dev-tool-page__panel[data-v-73b2983c]{display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fafbfc}.dev-tool-page__panel-head[data-v-73b2983c]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f6f8fa;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:13px;color:#111827}.dev-tool-page__editor[data-v-73b2983c]{width:100%;min-height:360px;padding:16px;border:none;resize:vertical;outline:none;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:14px;line-height:1.6;color:#111827;background:#fff}.dev-tool-page__editor[data-v-73b2983c]:focus-visible{box-shadow:inset 0 0 0 2px #2563eb}.dev-tool-page__editor--readonly[data-v-73b2983c]{background:#fefdf7;cursor:default}.dev-tool-page__error[data-v-73b2983c]{margin:0;padding:12px 16px;background:#fef2f2;color:#dc2626;font-size:13px;font-family:monospace;border-top:1px solid #fee2e2}.dev-tool-page__tips[data-v-73b2983c]{padding:16px 24px;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafb}.dev-tool-page__tips h2[data-v-73b2983c]{margin:0 0 8px;font-size:15px;font-weight:600;color:#111827}.dev-tool-page__tips p[data-v-73b2983c]{margin:0;font-size:14px;line-height:1.65;color:#6b7280}.dev-tool-page__tips p strong[data-v-73b2983c]{color:#374151;font-weight:600}.docker-compose-gen__header[data-v-73b2983c]{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.docker-compose-gen__header h1[data-v-73b2983c]{margin:0 0 6px;font-size:22px;font-weight:600;color:#111827}.docker-compose-gen__subtitle[data-v-73b2983c]{margin:0;font-size:14px;color:#6b7280}.docker-compose-gen__toolbar[data-v-73b2983c]{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin-top:16px}.docker-compose-gen__toolbar-group[data-v-73b2983c]{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.docker-compose-gen__toolbar-group--options[data-v-73b2983c]{gap:16px}.docker-compose-gen__link-btn[data-v-73b2983c]{padding:8px 14px;background:transparent;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#2563eb;cursor:pointer}.docker-compose-gen__link-btn[data-v-73b2983c]:hover{border-color:#2563eb;background:#eff6ff}.docker-compose-gen__check[data-v-73b2983c]{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#374151;cursor:pointer}.docker-compose-gen__check input[data-v-73b2983c]{accent-color:#2563eb}.docker-compose-gen__stats[data-v-73b2983c]{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px}.docker-compose-gen__stats.is-valid[data-v-73b2983c]{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.docker-compose-gen__stats.is-invalid[data-v-73b2983c]{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.docker-compose-gen__stats span[data-v-73b2983c]{color:inherit}.docker-compose-gen__stats-badge[data-v-73b2983c]{font-weight:600}.docker-compose-gen__meta-bar[data-v-73b2983c]{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px dashed #e5e7eb}.docker-compose-gen__view-tabs[data-v-73b2983c]{display:flex;gap:4px;padding:4px;background:#f3f4f6;border-radius:8px}.docker-compose-gen__view-tabs button[data-v-73b2983c]{padding:6px 14px;border:none;border-radius:6px;font-size:13px;background:transparent;color:#6b7280;cursor:pointer}.docker-compose-gen__view-tabs button.active[data-v-73b2983c]{background:#fff;color:#2563eb;box-shadow:0 1px 3px #00000014;font-weight:500}.docker-compose-gen__meta-actions[data-v-73b2983c]{display:flex;gap:8px}.docker-compose-gen__workspace[data-v-73b2983c]{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}@media(max-width:900px){.docker-compose-gen__workspace[data-v-73b2983c]{grid-template-columns:1fr}}.docker-compose-gen__panel[data-v-73b2983c]{display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;background:#fff;min-height:480px}.docker-compose-gen__panel-head[data-v-73b2983c]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:14px;color:#111827}.docker-compose-gen__panel-meta[data-v-73b2983c]{font-weight:400;font-size:12px;color:#6b7280}.docker-compose-gen__panel--output[data-v-73b2983c]{display:flex;flex-direction:column}.docker-compose-gen__editor[data-v-73b2983c]{flex:1;width:100%;min-height:420px;padding:16px;border:none;resize:vertical;outline:none;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:14px;line-height:1.55;color:#111827;background:#fafafa}.docker-compose-gen__output[data-v-73b2983c]{flex:1;display:flex;flex-direction:column;min-height:420px}.docker-compose-gen__preview[data-v-73b2983c]{flex:1;margin:0;padding:16px;background:#fafafa;font-family:Fira Code,Consolas,monospace;font-size:13px;line-height:1.6;color:#111827;overflow:auto;max-height:520px;white-space:pre-wrap;word-break:break-all;border:none;border-radius:0}.docker-compose-gen__placeholder[data-v-73b2983c]{margin:0;padding:48px 24px;text-align:center;color:#6b7280;font-size:14px;line-height:1.6}.docker-compose-gen__code-actions[data-v-73b2983c]{display:flex;gap:8px}.docker-compose-gen__services-list[data-v-73b2983c]{flex:1;overflow-y:auto;padding:16px}.docker-compose-gen__service-card[data-v-73b2983c]{margin-bottom:16px;padding:16px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}.docker-compose-gen__service-header[data-v-73b2983c]{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.docker-compose-gen__service-title[data-v-73b2983c]{display:flex;align-items:center;gap:8px;flex:1}.docker-compose-gen__service-name[data-v-73b2983c]{font-size:16px;font-weight:600;border:none;background:transparent;padding:4px 8px;border-radius:6px;color:#111827;min-width:200px}.docker-compose-gen__service-name[data-v-73b2983c]:focus{outline:none;background:#eff6ff;box-shadow:0 0 0 2px #eff6ff}.docker-compose-gen__service-actions[data-v-73b2983c]{display:flex;gap:8px;align-items:center}.docker-compose-gen__service-body[data-v-73b2983c]{animation:envFadeIn-73b2983c .3s ease}.docker-compose-gen__form-grid[data-v-73b2983c]{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:20px}.docker-compose-gen__field[data-v-73b2983c]{display:flex;flex-direction:column;gap:6px}.docker-compose-gen__field label[data-v-73b2983c]{font-size:12px;font-weight:500;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px}.docker-compose-gen__input[data-v-73b2983c],.docker-compose-gen__select[data-v-73b2983c]{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;color:#374151;background:#fff;transition:all .2s}.docker-compose-gen__input[data-v-73b2983c]:focus,.docker-compose-gen__select[data-v-73b2983c]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #eff6ff}.docker-compose-gen__select[data-v-73b2983c]{cursor:pointer}.docker-compose-gen__section[data-v-73b2983c]{margin-bottom:20px}.docker-compose-gen__section h4[data-v-73b2983c]{font-size:14px;font-weight:600;color:#111827;margin-bottom:8px;display:flex;align-items:center;gap:8px}.docker-compose-gen__section h4[data-v-73b2983c]:before{content:"";display:inline-block;width:3px;height:14px;background:#2563eb;border-radius:2px}.docker-compose-gen__add-btn[data-v-73b2983c]{padding:4px 10px;background:#eff6ff;color:#2563eb;border:none;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.docker-compose-gen__add-btn[data-v-73b2983c]:hover{background:#2563eb;color:#fff}.docker-compose-gen__table-wrap[data-v-73b2983c]{overflow-x:auto;border:1px solid #e5e7eb;border-radius:6px}.docker-compose-gen__table[data-v-73b2983c]{width:100%;border-collapse:collapse;font-size:13px}.docker-compose-gen__table th[data-v-73b2983c]{padding:10px 12px;text-align:left;background:#fff;color:#9ca3af;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5e7eb}.docker-compose-gen__table td[data-v-73b2983c]{padding:8px 12px;border-bottom:1px solid #e5e7eb;vertical-align:middle}.docker-compose-gen__table tr:last-child td[data-v-73b2983c]{border-bottom:none}.docker-compose-gen__table input[data-v-73b2983c],.docker-compose-gen__table select[data-v-73b2983c]{width:100%;padding:6px 10px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px}.docker-compose-gen__empty[data-v-73b2983c]{text-align:center;color:#9ca3af;padding:20px;font-style:italic}.docker-compose-gen__depends[data-v-73b2983c]{display:flex;flex-wrap:wrap;gap:12px;padding:12px;background:#fff;border-radius:6px}.docker-compose-gen__icon-btn[data-v-73b2983c]{padding:4px 8px;background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:14px;color:#9ca3af;transition:all .2s}.docker-compose-gen__icon-btn[data-v-73b2983c]:hover:not(:disabled){background:#eff6ff;color:#2563eb;border-color:#2563eb}.docker-compose-gen__icon-btn[data-v-73b2983c]:disabled{opacity:.3;cursor:not-allowed}.docker-compose-gen__empty-state[data-v-73b2983c]{text-align:center;padding:60px 20px;color:#9ca3af}.docker-compose-gen__empty-icon[data-v-73b2983c]{font-size:64px;margin-bottom:16px}.docker-compose-gen__modal-overlay[data-v-73b2983c]{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:envFadeIn-73b2983c .2s ease}.docker-compose-gen__modal[data-v-73b2983c]{background:#fff;border-radius:12px;padding:24px;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;animation:envSlideUp-73b2983c .3s ease}.docker-compose-gen__modal h3[data-v-73b2983c]{font-size:18px;font-weight:700;color:#111827;margin-bottom:20px}.docker-compose-gen__template-grid[data-v-73b2983c]{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:20px}.docker-compose-gen__template-card[data-v-73b2983c]{padding:16px;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center}.docker-compose-gen__template-card[data-v-73b2983c]:hover{border-color:#2563eb;box-shadow:0 4px 12px #4f46e526;transform:translateY(-2px)}.docker-compose-gen__template-icon[data-v-73b2983c]{font-size:48px;margin-bottom:12px}.docker-compose-gen__template-name[data-v-73b2983c]{font-size:14px;font-weight:600;color:#111827;margin-bottom:8px}.docker-compose-gen__template-desc[data-v-73b2983c]{font-size:12px;color:#9ca3af;line-height:1.4}.docker-compose-gen__modal-close[data-v-73b2983c]{padding:8px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:13px;color:#374151;transition:all .2s}.docker-compose-gen__modal-close[data-v-73b2983c]:hover{background:#e5e7eb}@keyframes envFadeIn-73b2983c{0%{opacity:0}to{opacity:1}}@keyframes envSlideUp-73b2983c{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
