.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;background:var(--color-panel-bg);min-width:300px;max-width:500px;pointer-events:auto;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-message{flex:1;font-size:14px;line-height:1.5}.toast-action{padding:4px 12px;border:1px solid currentColor;border-radius:4px;background:transparent;cursor:pointer;font-size:14px;white-space:nowrap}.toast-success{color:#10b981;border-left:4px solid #10b981}.toast-error{color:#ef4444;border-left:4px solid #ef4444}.toast-warning{color:#f59e0b;border-left:4px solid #f59e0b}.toast-info{color:#3b82f6;border-left:4px solid #3b82f6}.toast-action:hover{background:var(--color-bg-secondary)}@media (max-width: 768px){.toast-container{top:10px;right:10px;left:10px}.toast{min-width:auto;max-width:100%}}.app-header{background:var(--color-bg-primary);border-bottom:1px solid var(--color-border);padding:var(--spacing-4);position:sticky;top:0;z-index:100;transition:background-color .3s ease,border-color .3s ease}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo-section{display:flex;flex-direction:column;gap:4px;min-width:0}.logo{font-size:var(--font-size-title-lg);font-weight:600;color:var(--color-text-primary);margin:0;transition:color .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tagline{font-size:14px;color:var(--color-text-secondary);margin:0;transition:color .3s ease}.header-actions{display:flex;align-items:center;gap:10px}.theme-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;border:none;background:transparent;color:var(--color-text-primary);cursor:pointer;transition:all .2s;padding:0}.theme-toggle-btn:hover{color:var(--color-primary);background:transparent}.theme-icon{display:inline-block;width:20px;height:20px;font-size:18px;line-height:20px;text-align:center}.lang-switch{position:relative;display:flex;align-items:center}.lang-select-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--color-border);border-radius:10px;background:var(--color-bg-primary);color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-body);transition:all .2s;min-width:auto;justify-content:center}.lang-select-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-bg-secondary)}.lang-select-btn:active{transform:translateY(1px);border-color:var(--color-primary)}.lang-select-btn:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2f80ed24}.lang-flag{display:inline-block;min-width:28px;padding:3px 8px;border-radius:8px;font-size:var(--font-size-caption);line-height:1.3;text-align:center;flex-shrink:0;background:var(--color-bg-secondary);color:var(--color-text-primary)}.lang-label{display:none;flex:1;text-align:left}.lang-arrow{display:none;transition:transform .2s;flex-shrink:0;color:var(--color-text-secondary)}.lang-arrow.open{transform:rotate(180deg)}.lang-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:150px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:10px;box-shadow:none;z-index:1000;overflow:hidden}.lang-option{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:var(--color-bg-primary);color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-body);transition:all .2s;text-align:left;justify-content:flex-start}.lang-option:hover{background:var(--color-bg-secondary)}.lang-option.active{background:var(--color-bg-secondary);color:var(--color-text-primary)}.lang-option .lang-flag{min-width:28px;padding:3px 8px;border-radius:8px;font-size:var(--font-size-caption);line-height:1.3;text-align:center;flex-shrink:0;background:var(--color-bg-secondary);color:var(--color-text-primary)}.lang-option .lang-label{flex:1}.lang-beta{display:none;margin-left:auto;padding:1px 4px;font-size:10px;font-weight:600;background:#f59e0b;color:#fff;border-radius:3px;vertical-align:middle;line-height:1.2;flex-shrink:0}.lang-option.active .lang-beta{background:#2f80ed4d;color:var(--color-primary)}@media (min-width: 640px){.lang-select-btn{padding:6px 14px;min-width:128px;border-radius:10px;justify-content:space-between}.lang-label,.lang-beta,.lang-arrow{display:inline-block}}@media (max-width: 768px){.app-header{padding:var(--spacing-2)}.logo{font-size:var(--font-size-title-md)}.tagline{font-size:12px}.theme-toggle-btn{width:32px;height:32px}.lang-select-btn{padding:4px 10px;font-size:var(--font-size-caption);border-radius:8px}.lang-flag{min-width:26px;padding:2px 6px;font-size:var(--font-size-caption);line-height:1.2}.lang-dropdown{min-width:auto;width:fit-content;max-width:90vw;right:0}.lang-option{padding:8px 10px;font-size:var(--font-size-caption);white-space:nowrap}.lang-option .lang-flag{min-width:26px;padding:2px 6px;font-size:var(--font-size-caption);line-height:1.2}}.type-tabs{display:flex;gap:6px;background:var(--color-bg-secondary);padding:3px;border-radius:10px}.tab{flex:1;padding:8px 14px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:var(--font-size-body);font-weight:500;color:var(--color-text-secondary);transition:all .2s;position:relative}.tab:hover{color:var(--color-primary);background:#2f80ed14}.tab.active{background:var(--color-panel-bg);color:var(--color-primary);box-shadow:0 1px 3px #0000001a}@media (max-width: 768px){.type-tabs{gap:4px;padding:2px}.tab{padding:10px 12px;font-size:var(--font-size-body);font-weight:500}}.type-form{display:flex;flex-direction:column;gap:var(--spacing-2)}.form-input{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;font-size:var(--font-size-body);font-family:inherit;resize:vertical;transition:border-color .2s,box-shadow .2s;background:var(--color-panel-bg);color:var(--color-text-primary);min-height:90px;box-sizing:border-box;line-height:1.5}.form-input:hover{border-color:var(--color-text-muted)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed1a}.form-input::placeholder{color:var(--color-text-muted)}.form-input-error{border-color:#ef4444}.form-input-error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-message-area{min-height:28px;display:flex;align-items:flex-start;gap:var(--spacing-1)}.form-message-area--placeholder .form-message-placeholder{visibility:hidden}.form-error-message{font-size:var(--font-size-caption);color:#ef4444;line-height:1.4}.form-tip{font-size:var(--font-size-caption);color:var(--color-text-muted);line-height:1.4}.form-message-placeholder{display:inline-block;min-height:1em}@media (max-width: 768px){.form-input{padding:12px 14px;font-size:var(--font-size-body);min-height:100px;line-height:1.6}.form-error-message,.form-tip{line-height:1.5}}.input-panel{display:flex;flex-direction:column;gap:10px}.parameter-panel{display:flex;flex-direction:column;gap:var(--spacing-2)}.parameter-tabs{display:flex;gap:6px;background:var(--color-bg-secondary);padding:3px;border-radius:10px;margin-top:var(--spacing-2);transition:background-color .3s ease}.parameter-tab{flex:1;padding:8px 14px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:var(--font-size-body);font-weight:500;color:var(--color-text-secondary);transition:all .2s;position:relative}.parameter-tab:hover{color:var(--color-primary);background:var(--color-primary-light)}.parameter-tab.active{background:var(--color-bg-primary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.parameter-tabs-container{position:relative}.parameter-tabs-container.fixed-height{min-height:0}.parameter-tab-content{display:flex;flex-direction:column;gap:var(--spacing-2);margin-top:var(--spacing-1);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s,visibility .2s;position:relative}.parameter-tabs-container.fixed-height .parameter-tab-content{position:absolute;top:0;left:0;right:0}.parameter-tab-content.active{opacity:1;visibility:visible;pointer-events:auto;position:relative}.parameter-tab-content-proxy{position:absolute;top:0;left:0;right:0;opacity:0;visibility:hidden;pointer-events:none}.parameter-row,.parameter-row-colors{display:grid;grid-template-columns:1fr auto 1fr 1.2fr;column-gap:var(--spacing-3);row-gap:var(--spacing-2);align-items:start}.parameter-item{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:0;max-width:100%}.parameter-item-swap{display:flex;flex-direction:column;justify-content:flex-end;gap:var(--spacing-1)}.parameter-label-empty{visibility:hidden}.parameter-item-placeholder{visibility:hidden;opacity:0;pointer-events:none}.parameter-template-tip{margin-top:var(--spacing-2);font-size:var(--font-size-caption);color:var(--color-text-muted);line-height:1.5}.parameter-row-placeholder{min-height:60px}.parameter-swap-container{display:flex;align-items:center;justify-content:center;width:100%}.parameter-label{font-size:var(--font-size-caption);font-weight:600;color:var(--color-text);margin-bottom:0}.parameter-control{display:flex;align-items:center;gap:var(--spacing-2)}.parameter-item-size .parameter-control{display:flex;align-items:center;gap:var(--spacing-2);width:100%;min-width:0;max-width:100%}.parameter-control-inline{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-2)}.parameter-control-color{display:flex;flex-direction:column;gap:var(--spacing-2);align-items:stretch}.parameter-control-color.parameter-control-inline{flex-direction:row;align-items:center}.parameter-control-color-row{display:grid;grid-template-columns:48px 1fr;gap:var(--spacing-2);align-items:center}.parameter-checkbox-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-caption);color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.parameter-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.parameter-checkbox:disabled+span{opacity:.5}.slider{flex:1;height:6px;border-radius:3px;background:var(--color-border);outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}.parameter-value{min-width:60px;text-align:right;font-size:var(--font-size-body);color:var(--color-text-muted)}.color-input{width:48px;height:var(--control-height);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:0;transition:border-color .2s,box-shadow .2s}.color-input:hover{border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed1a}.color-text{flex:1;min-width:0;max-width:100px;padding:0 var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);height:var(--control-height);font-size:var(--font-size-body);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace;transition:border-color .2s,box-shadow .2s;background:var(--color-panel-bg);color:var(--color-text-primary);box-sizing:border-box;width:100%}.parameter-control-gradient .color-text{max-width:130px}.color-text:hover{border-color:var(--color-text-muted)}.color-text:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed1a}.select-input{padding:0 var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-body);background:var(--color-panel-bg);color:var(--color-text-primary);cursor:pointer;transition:border-color .2s,box-shadow .2s;width:100%;min-width:0;max-width:100%;box-sizing:border-box;font-family:inherit;height:var(--control-height)}.select-input:hover{border-color:var(--color-text-muted)}.select-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed1a}.parameter-swap-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-panel-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0}.parameter-swap-btn:hover:not(:disabled){border-color:var(--color-primary);background:#2f80ed0d;color:var(--color-primary)}.parameter-swap-btn:active:not(:disabled){background:#2f80ed1a;transform:scale(.95)}.parameter-swap-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--color-bg-tertiary)}.parameter-swap-btn svg{width:18px;height:18px;flex-shrink:0}.parameter-item-template{margin-bottom:var(--spacing-2)}.parameter-control-template{display:flex;gap:var(--spacing-2);align-items:center}.parameter-control-template .select-input{flex:1}.parameter-save-template-btn{width:40px;height:40px;padding:0;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #2f80ed40}.parameter-save-template-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 4px 12px #2f80ed59;transform:translateY(-1px)}.parameter-save-template-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #2f80ed40}.parameter-save-template-btn:disabled{background:var(--color-border);box-shadow:none;cursor:not-allowed}.parameter-save-template-form{margin-top:var(--spacing-2);padding:var(--spacing-3);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;display:flex;flex-direction:column;gap:var(--spacing-2)}.parameter-template-name-input{width:100%;box-sizing:border-box;height:var(--control-height);padding:0 var(--spacing-3);border:1px solid var(--color-border);border-radius:6px;font-size:var(--font-size-body);background:var(--color-panel-bg);color:var(--color-text-primary)}.parameter-template-name-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed1a}.parameter-save-template-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.parameter-save-template-confirm,.parameter-save-template-cancel{padding:6px 12px;border:1px solid var(--color-border);border-radius:6px;font-size:var(--font-size-caption);cursor:pointer;transition:all .2s}.parameter-save-template-confirm{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.parameter-save-template-confirm:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.parameter-save-template-cancel{background:var(--color-panel-bg);color:var(--color-text)}.parameter-save-template-cancel:hover{background:var(--color-bg-tertiary)}.template-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1200;padding:16px;box-sizing:border-box}.template-modal{width:min(420px,100%);background:var(--color-panel-bg);border-radius:12px;box-shadow:0 16px 40px #0f172a33;overflow:hidden}.template-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border)}.template-modal-title{margin:0;font-size:16px;font-weight:600;color:var(--color-text)}.template-modal-close{width:32px;height:32px;border:none;background:transparent;border-radius:8px;font-size:24px;line-height:1;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.template-modal-close:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.template-modal-body{padding:20px;display:flex;flex-direction:column;gap:var(--spacing-2)}.parameter-section{margin-top:var(--spacing-3);padding-top:var(--spacing-3);border-top:1px solid var(--color-border)}.parameter-section-title{font-size:var(--font-size-body);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-2)}.parameter-section-styling{margin-top:0;padding-top:0;border-top:none}.parameter-styling-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.parameter-styling-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:var(--spacing-3);row-gap:var(--spacing-2);align-items:start}.parameter-styling-row-3cols{grid-template-columns:repeat(3,minmax(0,1fr))}.parameter-styling-row-1col{grid-template-columns:minmax(0,1fr)}.parameter-styling-row-1col .parameter-item{width:100%;min-width:0;max-width:100%}.parameter-styling-row-1col .parameter-control-styling,.parameter-styling-row-1col .parameter-control-gradient,.parameter-styling-row-1col .parameter-control-logo{width:100%;min-width:0;max-width:100%;box-sizing:border-box}.parameter-styling-row-1col .parameter-control-gradient .parameter-control-color-row{width:auto;min-width:0;max-width:100%}.parameter-styling-row:not(:last-child){margin-bottom:var(--spacing-1)}.parameter-styling-row-2cols{grid-template-columns:repeat(2,minmax(0,1fr))}.parameter-control-checkbox{display:flex;align-items:center}.parameter-control-styling{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-3);flex-wrap:wrap;justify-content:space-between;width:100%;min-width:0}.parameter-control-gradient{display:flex;flex-direction:row;gap:var(--spacing-2);align-items:center;flex:1;min-width:0;justify-content:space-between;max-width:100%}.parameter-control-gradient .parameter-control-color-row{flex:0 0 auto;min-width:0}.parameter-control-gradient-selects{display:flex;flex-direction:row;gap:var(--spacing-2);flex:1;min-width:0;align-items:center;flex-wrap:wrap}.parameter-gradient-type-select,.parameter-gradient-direction-select{min-width:120px;width:auto;max-width:220px;flex:1 1 140px}.parameter-gradient-reverse-label{flex:0 0 auto;white-space:nowrap;margin:0}.parameter-control-logo{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);flex:1;min-width:0;max-width:100%}.parameter-control-logo-size{display:flex;align-items:center;gap:var(--spacing-2);width:100%;min-width:0;max-width:100%}.parameter-control-logo-upload{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);flex-wrap:nowrap;width:100%;min-width:0}.parameter-logo-file-input{display:none}.parameter-logo-upload-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-bg-primary);font-size:var(--font-size-caption);color:var(--color-text);cursor:pointer;transition:background-color .2s,border-color .2s,box-shadow .2s;white-space:nowrap;min-width:120px;max-width:200px;overflow:hidden}.parameter-logo-upload-btn span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.parameter-logo-upload-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-primary);box-shadow:0 1px 3px #0f172a14}.parameter-logo-upload-btn-disabled{opacity:.5;cursor:not-allowed}.parameter-logo-clear-btn{padding:4px 10px;border-radius:4px;border:1px solid var(--color-border);background:var(--color-panel-bg);font-size:var(--font-size-caption);cursor:pointer;transition:background-color .2s,border-color .2s}.parameter-logo-clear-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-primary)}.parameter-control-expanded{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-2);flex:1;min-width:0;max-width:100%;min-height:var(--control-height);transition:opacity .2s,visibility .2s}.parameter-control-placeholder{visibility:hidden;opacity:0;pointer-events:none}.parameter-control-expanded .slider{flex:1;min-width:0}.parameter-control-expanded .parameter-value{min-width:50px;text-align:right}@media (max-width: 768px){.parameter-panel{gap:var(--spacing-2)}.parameter-row-colors{grid-template-columns:1fr auto 1fr;column-gap:var(--spacing-2);row-gap:var(--spacing-2);align-items:start}.parameter-row-colors .parameter-item-error-correction{grid-column:1 / -1;margin-top:8px}.parameter-row-colors .parameter-control-color-row{grid-template-columns:36px 1fr;gap:6px}.parameter-row-colors .color-input{width:36px;height:32px}.parameter-row-colors .color-text{max-width:none;min-width:0;padding:8px;font-size:var(--font-size-caption)}.parameter-row-colors .parameter-item{min-width:0}.parameter-label{font-size:var(--font-size-caption)}.parameter-control,.parameter-control-styling,.parameter-control-gradient{flex-direction:column;align-items:stretch;gap:var(--spacing-2)}.parameter-control-logo{flex-direction:column;align-items:center;gap:var(--spacing-2)}.parameter-control-logo-size,.parameter-item-size .parameter-control{width:100%;flex-direction:row;align-items:center;gap:var(--spacing-2)}.parameter-control-logo-upload{width:100%;flex-direction:row;align-items:center;justify-content:center;gap:var(--spacing-2)}.parameter-control-template{flex-direction:row;align-items:center;gap:var(--spacing-2)}.parameter-control-template .select-input{flex:1}.parameter-save-template-btn{flex:0 0 auto;width:36px;height:36px}.select-input{padding:0 var(--spacing-2);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.parameter-template-tip{margin-top:var(--spacing-1);line-height:1.4}.parameter-checkbox-label{font-size:var(--font-size-caption)}.parameter-control-color-row{gap:8px}.parameter-row-colors .parameter-swap-btn svg{width:16px;height:16px}.parameter-styling-grid,.parameter-styling-row{grid-template-columns:1fr;gap:var(--spacing-2)}.parameter-styling-row:not(:last-child){margin-bottom:var(--spacing-2)}.parameter-control-styling{flex-direction:column;align-items:stretch;gap:var(--spacing-2)}.parameter-control-gradient{display:grid;grid-template-columns:minmax(140px,1fr) minmax(0,1fr);grid-auto-rows:auto;column-gap:var(--spacing-2);row-gap:var(--spacing-1);align-items:start}.parameter-control-gradient .parameter-control-color-row{grid-column:1 / span 2;grid-row:1;width:100%;min-width:0;max-width:100%;box-sizing:border-box}.parameter-control-gradient .parameter-control-color-row .color-text{flex:1;min-width:0;max-width:100%}.parameter-control-gradient-selects{display:grid;grid-template-columns:minmax(140px,1fr) minmax(0,1fr);grid-auto-rows:auto;column-gap:var(--spacing-2);row-gap:var(--spacing-1);align-items:start;grid-column:1 / span 2;grid-row:2;width:100%}.parameter-gradient-type-select{grid-column:1;grid-row:1;min-width:0;align-self:start}.parameter-gradient-direction-select{grid-column:2;grid-row:1;min-width:0;align-self:start}.parameter-gradient-reverse-label{grid-column:2;grid-row:2;justify-self:start;white-space:nowrap;margin:0;align-self:start}.parameter-control-expanded{width:100%}.parameter-tabs{gap:4px;padding:2px}.parameter-tab{padding:10px 12px;font-size:var(--font-size-body);font-weight:500}.template-modal{width:100%}}.parameter-hint{font-size:var(--font-size-caption);color:var(--color-text-muted);margin-top:var(--spacing-2);line-height:1.4}.number-input{width:100%;height:var(--control-height);padding:0 var(--spacing-3);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:var(--font-size-body);font-family:var(--font-family-base);transition:border-color .2s,box-shadow .2s,background-color .3s ease,color .3s ease;background:var(--color-bg-primary);color:var(--color-text-primary)}.number-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed26}.preview-panel{display:flex;flex-direction:column;gap:12px;height:100%;min-height:0;overflow:hidden}.preview-title{font-size:var(--font-size-title-lg);font-weight:600;color:var(--color-text);margin:0;line-height:1.4}.preview-tabs{display:flex;gap:6px;background:var(--color-bg-secondary);padding:3px;border-radius:10px;margin-bottom:8px;height:40px;flex-shrink:0;transition:background-color .3s ease}.preview-tab{flex:1;padding:8px 14px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:14px;font-weight:500;color:var(--color-text-secondary);transition:all .2s}.preview-tab:disabled{opacity:.5;cursor:not-allowed}.preview-tab:hover{color:var(--color-primary);background:#2f80ed14}.preview-tab.active{background:var(--color-bg-primary);color:var(--color-primary);box-shadow:var(--shadow-sm)}.preview-content{display:flex;flex-direction:column;position:relative;width:100%;flex:1 1 auto;min-height:300px;overflow:hidden;aspect-ratio:1}.qr-canvas{display:flex;justify-content:center;align-items:center;width:100%;height:100%;background:var(--color-bg-secondary);border-radius:8px;padding:16px;box-sizing:border-box;position:absolute;top:0;left:0;opacity:0;pointer-events:none;transition:opacity .2s,background-color .3s ease;overflow:hidden}.qr-canvas.active{opacity:1;pointer-events:auto}.qr-image-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%;transition:transform .2s ease}.qr-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;display:block}.qr-placeholder{color:var(--color-text-tertiary);font-size:14px;text-align:center}.download-controls{display:flex;gap:8px;flex-wrap:wrap;min-height:44px;align-items:center;flex-shrink:0;padding:4px 0}.download-btn{flex:1;min-width:100px;padding:8px 12px;border:1px solid var(--color-primary);border-radius:6px;background:var(--color-primary);color:#fff;cursor:pointer;font-size:13px;transition:all .2s;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:8px}.download-btn:hover:not(:disabled){background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.download-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--color-border);border-color:var(--color-border)}.qr-info-panel{padding:14px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;width:100%;height:100%;display:flex;flex-direction:column;position:absolute;top:0;left:0;box-sizing:border-box;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .2s;overscroll-behavior:contain}.qr-info-panel.active{opacity:1;pointer-events:auto}.qr-info-header{margin-bottom:12px}.qr-info-title{font-size:14px;font-weight:600;color:var(--color-text);margin:0}.qr-info-grid{display:flex;flex-direction:column;gap:16px}.qr-info-section{display:flex;flex-direction:column;gap:8px}.qr-info-section-title{font-size:13px;font-weight:600;color:var(--color-text);text-transform:uppercase;letter-spacing:.5px;padding-bottom:6px;border-bottom:1px solid var(--color-border)}.qr-info-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.qr-info-item{display:flex;flex-direction:column;gap:4px}.qr-info-label{font-size:12px;color:var(--color-text-muted);font-weight:500}.qr-info-value{font-size:13px;color:var(--color-text);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace;display:flex;align-items:center;gap:6px}.qr-info-color{display:inline-block;width:16px;height:16px;border:1px solid var(--color-border);border-radius:3px;flex-shrink:0;vertical-align:middle}.qr-info-separator{margin:0 8px;color:var(--color-text-muted)}.qr-info-transparent-label{color:var(--color-text-muted);font-style:italic}@media (max-width: 768px){.preview-panel{height:auto}.qr-canvas{aspect-ratio:1}.qr-info-grid{gap:10px}.qr-info-items{grid-template-columns:1fr;gap:10px}.qr-info-label{font-size:var(--font-size-caption)}.qr-info-value{font-size:var(--font-size-body)}.download-controls{flex-direction:column;height:auto;min-height:auto;gap:8px}.download-btn{width:100%;padding:10px 12px;font-size:var(--font-size-body)}}.qr-info-section-quality{background:var(--color-bg-secondary);padding:12px;border-radius:8px;border:1px solid var(--color-border)}.qr-quality-score{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.qr-quality-score-value{display:flex;align-items:baseline;gap:4px}.qr-quality-score-number{font-size:32px;font-weight:700;color:var(--color-text);line-height:1}.qr-quality-score-total{font-size:18px;font-weight:500;color:var(--color-text-muted)}.qr-quality-score-bar{width:100%;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.qr-quality-score-fill{height:100%;transition:width .3s ease;border-radius:4px}.qr-quality-score-label{font-size:13px;font-weight:600;color:var(--color-text)}.qr-quality-details{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.qr-quality-detail-item{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;background:var(--color-panel-bg);border-radius:6px;border:1px solid var(--color-border)}.qr-quality-detail-label{font-size:12px;color:var(--color-text-muted)}.qr-quality-detail-value{font-size:12px;font-weight:600;color:var(--color-text);font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace}.qr-quality-suggestions{margin-top:8px}.qr-quality-suggestions-title{font-size:12px;font-weight:600;color:var(--color-text);margin-bottom:8px}.qr-quality-suggestions-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.qr-quality-suggestion-item{font-size:12px;color:var(--color-text-muted);padding-left:16px;position:relative;line-height:1.5}.qr-quality-suggestion-item:before{content:"•";position:absolute;left:0;color:var(--color-primary);font-weight:700}@media (max-width: 768px){.qr-quality-details{grid-template-columns:1fr}}.history-bar{background:var(--color-panel-bg);border:1px solid var(--color-border);border-radius:12px;padding:16px;box-shadow:0 8px 20px #11182714;width:100%;margin-bottom:16px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.history-title{font-size:var(--font-size-title-lg);font-weight:600;color:var(--color-text)}.history-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.history-limit-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text-muted)}.history-limit-input{width:60px;padding:4px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:14px}.history-clear-btn{padding:6px 12px;border:1px solid #ef4444;border-radius:6px;background:var(--color-panel-bg);color:#ef4444;cursor:pointer;font-size:14px;transition:all .2s}.history-clear-btn:hover{background:#ef4444;color:#fff}.history-settings-btn{width:32px;height:32px;padding:0;border:1px solid var(--color-border);border-radius:6px;background:var(--color-panel-bg);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.history-settings-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-primary);color:var(--color-text)}.history-settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.history-settings-dialog{background:var(--color-panel-bg);border-radius:12px;box-shadow:0 10px 30px #0f172a33;max-width:400px;width:90%;max-height:90vh;overflow-y:auto}.history-settings-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--color-border)}.history-settings-title{font-size:18px;font-weight:600;color:var(--color-text);margin:0}.history-settings-close{width:28px;height:28px;border:none;background:transparent;color:var(--color-text-secondary);font-size:24px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.history-settings-close:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.history-settings-content{padding:20px}.history-settings-item{margin-bottom:20px}.history-settings-item:last-child{margin-bottom:0}.history-settings-label{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--color-text)}.history-settings-label span{font-weight:500}.history-settings-toggle{position:relative;width:44px;height:24px;border:none;border-radius:12px;background:var(--color-border);cursor:pointer;transition:all .2s;padding:0}.history-settings-toggle.active{background:var(--color-primary)}.history-settings-toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--color-panel-bg);transition:all .2s;box-shadow:0 1px 3px #0003}.history-settings-toggle.active .history-settings-toggle-slider{transform:translate(20px)}.history-settings-limit-input{width:80px;padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:14px;text-align:center}.history-settings-limit-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.history-empty{text-align:center;color:var(--color-text-muted);font-size:14px;padding:16px}.history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.history-pagination{margin-top:12px;display:flex;align-items:center;justify-content:center;gap:12px}.history-page-btn{padding:6px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-panel-bg);color:var(--color-text);cursor:pointer;font-size:14px;transition:all .2s}.history-page-btn:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-primary)}.history-page-btn:disabled{opacity:.6;cursor:not-allowed}.history-page-info{font-size:14px;color:var(--color-text-muted)}.history-item{display:flex;align-items:flex-start;gap:10px;padding:10px;background:var(--color-bg-secondary);border-radius:8px;border:1px solid var(--color-border);transition:all .2s;min-height:80px}.history-item:hover{background:var(--color-bg-tertiary);border-color:var(--color-primary)}.history-item-content{flex:1;min-width:0;cursor:pointer}.history-item-summary{font-size:14px;font-weight:500;color:var(--color-text);margin-bottom:4px}.history-item-meta{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--color-text-muted);min-height:46px}.history-item-meta-row{display:flex;align-items:center;gap:8px;min-height:20px}.history-item-template-row{min-height:24px}.history-item-template-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;background:var(--color-bg-tertiary);border-radius:4px;color:var(--color-text);font-weight:500;white-space:nowrap;flex-shrink:0}.history-item-template-label-chip,.history-item-template-name-chip{background:var(--color-bg-tertiary);color:var(--color-text)}.history-item-template-placeholder{display:inline-flex;align-items:center;padding:2px 6px;min-height:20px;visibility:hidden}.history-item-template-name{color:var(--color-text);font-weight:600;white-space:nowrap}.history-item-type{padding:2px 6px;background:var(--color-primary);color:#fff;border-radius:4px;white-space:nowrap;flex-shrink:0}.history-item-time{white-space:nowrap;flex-shrink:0}.history-item-delete{width:24px;height:24px;border:none;background:transparent;color:#6b7280;font-size:20px;cursor:pointer;border-radius:4px;display:flex;align-items:flex-start;justify-content:center;transition:all .2s;padding-top:2px}.history-item-delete:hover{background:#ef4444;color:#fff}.history-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.history-confirm-dialog{background:var(--color-panel-bg);padding:16px 20px;border-radius:12px;box-shadow:0 10px 30px #0f172a33;max-width:360px;width:90%}.history-confirm-message{font-size:14px;color:var(--color-text);margin-bottom:12px}.history-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.history-confirm-cancel,.history-confirm-ok{min-width:80px;padding:6px 12px;font-size:14px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:all .2s}.history-confirm-cancel{background:var(--color-panel-bg);color:var(--color-text);border-color:var(--color-border)}.history-confirm-cancel:hover{background:var(--color-bg-tertiary)}.history-confirm-ok{background:#ef4444;color:#fff;border-color:#ef4444}.history-confirm-ok:hover{background:#b91c1c;border-color:#b91c1c}@media (max-width: 768px){.history-header{flex-direction:row;align-items:center;gap:8px;flex-wrap:wrap}.history-actions{width:auto;justify-content:flex-end}.history-bar{padding:var(--spacing-2);border-radius:10px}.history-title{margin:0}}.guide-panel{width:100%;padding:16px;background:var(--color-panel-bg);border-radius:var(--radius-base);border:1px solid var(--color-border);box-shadow:0 8px 20px #1118270f}.guide-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;border:none;background:none;cursor:pointer;transition:all .2s}.guide-header:hover{opacity:.8}.guide-header:active{opacity:.6}.guide-title{font-size:var(--font-size-title-lg);font-weight:600;color:var(--color-text);margin:0}.guide-arrow{flex-shrink:0;color:var(--color-text-secondary);transition:transform .3s ease}.guide-arrow.expanded{transform:rotate(180deg)}.guide-body{max-height:0;overflow:hidden;transition:max-height .3s ease,margin-top .3s ease;margin-top:0}.guide-body.expanded{max-height:1000px;margin-top:16px}.guide-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.guide-step{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.6;color:var(--color-text)}.guide-step-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;background:var(--color-primary);color:#fff;border-radius:50%;font-size:12px;font-weight:600;flex-shrink:0}.guide-step-text{flex:1;padding-top:2px}.guide-tips{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid var(--color-border)}.guide-tip{font-size:13px;line-height:1.5;color:var(--color-text-muted)}@media (max-width: 768px){.guide-panel{padding:var(--spacing-2)}.guide-steps{gap:8px}.guide-step{font-size:var(--font-size-body)}.guide-tip{font-size:var(--font-size-caption)}}.scroll-to-top{position:fixed;bottom:96px;right:24px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 4px 12px #2f80ed4d;transition:all .3s ease;z-index:1000;padding:0}.scroll-to-top:hover{background:#2563eb;box-shadow:0 6px 16px #2f80ed66;transform:translateY(-2px)}.scroll-to-top:active{transform:translateY(0);box-shadow:0 2px 8px #2f80ed4d}.scroll-to-top svg{flex-shrink:0}@media (max-width: 768px){.scroll-to-top{bottom:88px;right:16px;width:40px;height:40px}.scroll-to-top svg{width:18px;height:18px}}:root{--color-primary: #2f80ed;--color-primary-dark: #1b4b91;--color-accent: #10b981;--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-panel-bg: #ffffff;--color-text: #1f2933;--color-text-primary: #1f2933;--color-text-muted: #6b7280;--color-border: #e5e7eb;--radius-base: 12px;--radius-sm: 8px;--shadow-panel: 0 8px 24px rgba(15, 23, 42, .08);--font-family-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-title-lg: 20px;--font-size-title-md: 18px;--font-size-body: 14px;--font-size-caption: 12px;--line-height-base: 1.6;--spacing-1: 4px;--spacing-2: 8px;--spacing-3: 12px;--spacing-4: 16px;--spacing-5: 20px;--control-height: 40px}:root.dark{--color-primary: #60a5fa;--color-primary-dark: #3b82f6;--color-accent: #34d399;--color-bg-primary: #111827;--color-bg-secondary: #1f2937;--color-bg-tertiary: #374151;--color-panel-bg: #1f2937;--color-text: #f9fafb;--color-text-primary: #f9fafb;--color-text-muted: #d1d5db;--color-border: #374151;--shadow-panel: 0 8px 24px rgba(0, 0, 0, .3)}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-body);line-height:var(--line-height-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-bg-primary);color:var(--color-text-primary);transition:background-color .3s ease,color .3s ease}.text-title{font-size:var(--font-size-title-md);font-weight:600;line-height:1.4;margin:0}.text-body{font-size:var(--font-size-body);line-height:var(--line-height-base);margin:0}.text-caption{font-size:var(--font-size-caption);color:var(--color-text-muted);line-height:1.4}.btn{height:var(--control-height);padding:0 var(--spacing-4);border-radius:var(--radius-sm);border:1px solid transparent;font-size:var(--font-size-body);font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2f80ed40}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 4px 12px #2f80ed59;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #2f80ed40}.btn-secondary{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-tertiary)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.input-field{height:var(--control-height);padding:0 var(--spacing-3);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:var(--font-size-body);font-family:var(--font-family-base);transition:border-color .2s,box-shadow .2s}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2f80ed26}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;max-width:1200px;margin:0 auto;padding:0 var(--spacing-4) var(--spacing-4);display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:var(--spacing-4);width:100%;align-items:stretch}.app-section{max-width:1200px;width:100%;margin:0 auto;padding:0 var(--spacing-4)}.app-section:first-of-type{padding-top:var(--spacing-4)}.app-section:not(:last-of-type){padding-bottom:var(--spacing-4)}.panel{background:var(--color-panel-bg);border-radius:var(--radius-base);border:1px solid var(--color-border);box-shadow:var(--shadow-panel);padding:var(--spacing-4);display:flex;flex-direction:column;height:100%;width:100%;min-width:0}.panel-heading{margin-bottom:var(--spacing-3)}.panel-heading-title{font-size:var(--font-size-title-lg);font-weight:600;color:var(--color-text);margin:0}.operations-panel{flex:1}.operations-stack{display:flex;flex-direction:column;gap:var(--spacing-2);height:100%}.preview-column{align-self:stretch}.generate-btn{width:100%;margin-top:auto;height:var(--control-height);padding:0 var(--spacing-4);border:none;border-radius:var(--radius-base);font-size:var(--font-size-body);font-weight:600;background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2f80ed4d;cursor:pointer;transition:all .2s;letter-spacing:.2px}.generate-btn:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 4px 12px #2f80ed66;transform:translateY(-1px)}.generate-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #2f80ed4d}.generate-btn:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed}@media (max-width: 768px){:root{--control-height: 36px;--font-size-title-lg: 18px;--font-size-title-md: 16px;--font-size-body: 13px;--font-size-caption: 11px}.app-main{grid-template-columns:1fr;padding:0 var(--spacing-2) var(--spacing-2);gap:var(--spacing-2);width:100%}.app-section{padding:0 var(--spacing-2)}.app-section:first-of-type{padding-top:var(--spacing-2)}.app-section:not(:last-of-type){padding-bottom:var(--spacing-2)}.panel{padding:var(--spacing-2);height:auto;width:100%;min-width:0}.operations-panel{height:auto;width:100%;min-width:0}.preview-column{width:100%;min-width:0}.operations-stack{gap:var(--spacing-2);height:auto}.generate-btn{height:40px;margin-top:0;padding:0 var(--spacing-3)}}:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-border: #e5e7eb;--color-border-hover: #d1d5db;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-light: #dbeafe;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}:root.dark{--color-bg-primary: #111827;--color-bg-secondary: #1f2937;--color-bg-tertiary: #374151;--color-text-primary: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-border: #374151;--color-border-hover: #4b5563;--color-primary: #60a5fa;--color-primary-hover: #3b82f6;--color-primary-light: #1e3a8a;--color-success: #34d399;--color-warning: #fbbf24;--color-error: #f87171;--color-info: #60a5fa;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3)}#root{width:100%;min-height:100vh;background-color:var(--color-bg-primary);color:var(--color-text-primary);transition:background-color .3s ease,color .3s ease}
