:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#1d1d1f;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color:#007aff;--primary-hover:#007aff1a;--primary-light:#007aff0d;--primary-dark:#0051d5;--border-color:#00000014;--border-hover:#007aff4d;--text-primary:#1d1d1f;--text-secondary:#86868b;--text-tertiary:#aeaeb2;--bg-card:#ffffffe6;--bg-card-hover:#fffffff2;--bg-surface:#f8f8f899;--shadow-sm:0 2px 8px #0000000a;--shadow-md:0 4px 16px #0000000f;--shadow-lg:0 8px 24px #00000014;--shadow-xl:0 12px 32px #0000001a;--radius-sm:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:24px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.3s cubic-bezier(.4,0,.2,1);background:linear-gradient(#f8f9fa 0%,#fff 100%) fixed;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,Arial,sans-serif}*{box-sizing:border-box}body{min-height:100vh;margin:0}a{color:#007aff;text-decoration:none;transition:opacity .2s}a:hover{opacity:.7}.page-container{max-width:1120px;margin:0 auto;padding:0 32px 100px}.top-header{z-index:1000;-webkit-backdrop-filter:blur(20px);background:linear-gradient(#1d1d1f 0%,#2c2c2e 100%);border-bottom:1px solid #ffffff1f;width:100%;padding:16px 0;position:sticky;top:0;box-shadow:0 4px 16px #0000001f,0 2px 4px #00000014}.top-header-content{justify-content:space-between;align-items:center;max-width:1120px;margin:0 auto;padding:0 32px;display:flex}.top-header-title{color:#fff;letter-spacing:-.01em;margin:0;font-size:24px;font-weight:600}.top-header-history-btn{cursor:pointer;color:#fff;white-space:nowrap;background:#ffffff1f;border:1px solid #fff3;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:500;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000001a}.top-header-history-btn:hover{background:#ffffff2e;border-color:#ffffff59;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.top-header-history-btn:active{background:#ffffff38;transform:translateY(0)}.page-header{text-align:center;margin-bottom:32px}.page-header h1{letter-spacing:-.04em;color:#1d1d1f;margin:0;font-size:64px;font-weight:600;line-height:1.05}.page-header p{color:#6e6e73;max-width:600px;margin-top:16px;margin-left:auto;margin-right:auto;font-size:20px;font-weight:400;line-height:1.5}.tab-navigation{gap:var(--spacing-md);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-lg);padding:0 var(--spacing-sm);flex-wrap:wrap;justify-content:center;display:flex}.tab-button{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(20px);cursor:pointer;min-width:160px;max-width:280px;transition:all var(--transition-base);text-align:left;box-shadow:var(--shadow-sm);background:#ffffff80;border:1px solid #0000;flex:220px;padding:24px 32px;position:relative;overflow:hidden}.tab-button:hover{box-shadow:var(--shadow-lg);background:#fffc;border-color:#1a73e81a;transform:translateY(-4px)}.tab-button:hover:before{transform:scaleX(1)}.tab-button.active{box-shadow:var(--shadow-lg),0 0 0 2px #1a73e80d;background:#fff;border-color:#1a73e833;transform:translateY(-2px)}.tab-button.active:before{opacity:0;transform:scaleX(1)}.tab-button span{color:var(--text-primary);margin-bottom:var(--spacing-xs);letter-spacing:-.01em;transition:color var(--transition-fast);font-size:18px;font-weight:600;display:block}.tab-button.active span{color:var(--primary-color)}.tab-button small{color:var(--text-secondary);transition:color var(--transition-fast);font-size:14px;font-weight:400;line-height:1.4;display:block}.tab-button.active small{color:var(--text-primary)}.model-section{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(40px)saturate(150%);transition:all var(--transition-base);z-index:1;background:#fff9;border:1px solid #fffc;margin-top:48px;padding:40px;position:relative;overflow:visible}.model-section:hover{box-shadow:var(--shadow-xl);background:#ffffffb3;transform:translateY(-2px)}.model-section h2{letter-spacing:-.01em;color:#1d1d1f;margin:0 0 16px;font-size:22px;font-weight:700}.model-controls{z-index:1;flex-wrap:wrap;gap:12px;margin-top:12px;display:flex;position:relative;overflow:visible}.field-group{color:#1d1d1f;letter-spacing:-.01em;flex-direction:column;gap:8px;font-size:13px;font-weight:600;display:flex}.field-group select,.field-group input{border-radius:var(--radius-sm);border:1px solid var(--border-color);min-width:240px;padding:var(--spacing-md)var(--spacing-md);background:var(--bg-card-hover);color:var(--text-primary);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);box-sizing:border-box;height:auto;min-height:48px;padding-right:40px;font-family:inherit;font-size:17px;font-weight:400;line-height:1.5}.field-group select:focus,.field-group input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #007aff1f,var(--shadow-sm);background:#fff;outline:none}.field-group select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%231d1d1f' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;width:100%;padding-right:40px;display:block}.field-group input{cursor:text;appearance:auto}.field-group select:hover,.field-group input:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm);background:#fff}.field-group select:focus-visible,.field-group input:focus-visible{outline-offset:2px;outline:2px solid #007aff}.model-tip{color:#86868b;margin-top:16px;font-size:13px;font-weight:400;line-height:1.5}.provider-dropdown-wrapper{z-index:10;isolation:isolate;width:100%;display:inline-block;position:relative}.provider-dropdown-trigger{border-radius:var(--radius-sm);border:1px solid var(--border-color);width:100%;min-width:240px;padding:var(--spacing-md)var(--spacing-md);background:var(--bg-card-hover);color:var(--text-primary);transition:all var(--transition-fast);appearance:none;cursor:pointer;text-align:left;box-shadow:var(--shadow-sm);box-sizing:border-box;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%231d1d1f' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;align-items:center;height:auto;min-height:48px;padding-right:40px;font-family:inherit;font-size:17px;font-weight:400;line-height:1.5;display:flex}.provider-dropdown-trigger:hover:not(:disabled){border-color:var(--border-hover);box-shadow:var(--shadow-sm);background:#fff}.provider-dropdown-trigger:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #007aff1f,var(--shadow-sm);background:#fff;outline:none}.provider-dropdown-trigger:disabled{opacity:.5;cursor:not-allowed}.dropdown-text{color:#1d1d1f}.provider-dropdown-trigger:disabled .dropdown-text{color:#86868b}.provider-dropdown-menu{border-radius:var(--radius-sm)!important;border:1px solid var(--border-color)!important;width:100%!important;min-width:240px!important;box-shadow:var(--shadow-lg)!important;z-index:1000!important;visibility:visible!important;opacity:1!important;background:#fff!important;max-height:320px!important;animation:.2s ease-out dropdownSlideDown!important;display:block!important;position:absolute!important;top:calc(100% + 8px)!important;left:0!important;right:0!important;overflow:hidden auto!important}@keyframes dropdownSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:#fff!important;border-bottom:.5px solid #00000014!important;justify-content:space-between!important;align-items:center!important;padding:12px 16px!important;display:flex!important}.dropdown-title{color:#1d1d1f!important;font-size:14px!important;font-weight:600!important;display:block!important}.select-all-btn-small{color:#007aff;cursor:pointer;background:#007aff0d;border:1px solid #007aff4d;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;transition:all .2s}.select-all-btn-small:hover{background:#007aff1a;border-color:#007aff}.dropdown-options{box-sizing:border-box!important;background:#fff!important;width:100%!important;max-height:240px!important;padding:4px!important;display:block!important;overflow-y:auto!important}.dropdown-option{cursor:pointer!important;-webkit-user-select:none!important;user-select:none!important;box-sizing:border-box!important;text-align:left!important;width:100%!important;font-family:inherit!important;font-size:inherit!important;background:0 0!important;border:none!important;border-radius:8px!important;justify-content:space-between!important;align-items:center!important;gap:12px!important;margin:0!important;padding:12px 16px!important;transition:all .15s!important;display:flex!important}.dropdown-option:hover:not(:disabled){background:#007aff0d!important}.dropdown-option.selected{color:#007aff!important;background:#007aff1a!important}.dropdown-option:disabled{opacity:.5!important;cursor:not-allowed!important}.option-content{flex-direction:column!important;flex:1!important;gap:2px!important;min-width:0!important;display:flex!important}.option-check{color:#007aff!important;flex-shrink:0!important;font-size:16px!important;font-weight:600!important}.option-name{color:#1d1d1f!important;font-size:14px!important;font-weight:500!important;line-height:1.3!important;display:inline-block!important}.dropdown-option.selected .option-name{color:#007aff!important;font-weight:600!important}.option-name-row{align-items:center!important;gap:8px!important;display:flex!important}.option-model{color:#86868b!important;font-size:11px!important;font-weight:400!important;line-height:1.3!important;display:block!important}.loading-indicator-small{color:#007aff;margin-left:auto;font-size:11px;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.model-tabs{border-bottom:.5px solid #00000014;flex-wrap:wrap;gap:8px;margin-bottom:24px;padding-bottom:16px;display:flex}.model-tab{padding:var(--spacing-md)var(--spacing-lg);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1.5px solid #8e8e9333;font-size:14px;font-weight:500;position:relative}.model-tab:hover{border-color:var(--border-hover);background:var(--primary-light);color:var(--primary-color);transform:translateY(-1px)}.model-tab.active{border-color:var(--primary-color);background:var(--primary-hover);color:var(--primary-color);box-shadow:var(--shadow-sm);font-weight:600}.upload-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:32px;display:grid}.upload-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:.5px solid var(--border-color);transition:all var(--transition-slow);opacity:.7;-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-sm);position:relative}.upload-section:before{content:"";border-radius:var(--radius-lg);opacity:0;transition:opacity var(--transition-base);pointer-events:none;background:linear-gradient(135deg,#007aff05 0%,#5856d603 100%);position:absolute;inset:0}.upload-section.active{box-shadow:var(--shadow-lg),0 4px 12px #007aff1a;opacity:1;background:var(--bg-card-hover);border-color:#007aff59;transform:translateY(-2px)}.upload-section.active:before{opacity:1}.upload-section.disabled{opacity:.5;background:#f8f8f899}.upload-header{align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.upload-header h2{letter-spacing:-.01em;color:#1d1d1f;margin:0;font-size:24px;font-weight:700}.upload-header p{color:#86868b;margin:8px 0 0;font-size:15px;font-weight:400;line-height:1.5}.step-indicator{color:#fff;background:linear-gradient(135deg,#007aff 0%,#5856d6 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;min-width:56px;height:56px;font-size:17px;font-weight:700;display:flex;box-shadow:0 4px 12px #007aff4d}.upload-dropzone{border-radius:var(--radius-md);margin-top:var(--spacing-md);justify-content:center;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);min-height:140px;box-shadow:none;background:#fff6;border:2px dashed #0000001a;flex-direction:column;padding:40px;font-size:16px;display:flex;position:relative}.upload-dropzone.compact{min-height:110px;padding:var(--spacing-md)}.upload-dropzone:hover{color:#1a73e8;box-shadow:none;background:#1a73e80a;border-color:#1a73e8;transform:scale(1.01)}.upload-dropzone:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 4px #007aff1a,var(--shadow-sm);border-color:#007aff;outline:none;box-shadow:0 0 0 4px #007aff1a}.upload-dropzone:active{transform:scale(.98)}.upload-dropzone input{display:none}.figma-import{background:#f8f8f8b3;border:1px solid #0000000d;border-radius:18px;flex-direction:column;gap:12px;margin-top:20px;padding:18px 20px;display:flex}.figma-import.compact{gap:10px;margin-top:16px;padding:16px 18px}.figma-input-group{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.figma-input-group input{color:#1d1d1f;background:#ffffffe6;border:1px solid #0000001f;border-radius:14px;flex:1;min-width:220px;padding:12px 16px;font-size:15px;transition:all .2s;box-shadow:inset 0 1px 2px #0000000a}.figma-input-group input:focus{background:#fff;border-color:#007aff80;outline:none;box-shadow:0 0 0 3px #007aff1f}.figma-import-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#34c759 0%,#30b0a3 100%);border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 3px 10px #30b0a340}.figma-import-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #30b0a359}.figma-import-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.figma-import-btn .loading-spinner{border-color:#fff #ffffff4d #ffffff4d;width:14px;height:14px;margin-right:0}.figma-hint{color:#86868b;margin:0;font-size:13px;line-height:1.5}.figma-hint code{background:#0000000d;border-radius:6px;padding:2px 6px;font-size:12px}.figma-error{color:#ff3b30;margin:0;font-size:13px;font-weight:500}.flow-progress{flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;display:flex}.flow-step{background:#ffffffd9;border:1px solid #0000000f;border-radius:18px;align-items:center;gap:12px;min-width:220px;padding:14px 20px;transition:all .2s;display:flex;box-shadow:0 6px 20px #0000000d}.flow-step-info{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.flow-step-title{color:#1d1d1f;letter-spacing:-.01em;font-size:15px;font-weight:600}.flow-step-desc{color:#86868b;letter-spacing:0;font-size:12px}.flow-step-index{color:#636366;background:#8e8e932e;border-radius:12px;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;font-weight:600;display:flex;box-shadow:inset 0 0 0 1px #0000000a}.flow-step.completed{background:#34c7591f;border-color:#34c75959}.flow-step.completed .flow-step-index{color:#fff;background:linear-gradient(135deg,#30d158 0%,#34c759 100%);box-shadow:0 10px 20px #34c75959}.flow-step.completed .flow-step-title{color:#1d1d1f}.flow-step.completed .flow-step-desc{color:#2f9e6d}.flow-step.active{background:#007aff1a;border-color:#007aff66}.flow-step.active .flow-step-index{color:#fff;background:linear-gradient(135deg,#0a84ff 0%,#5856d6 100%);box-shadow:0 10px 20px #0a84ff59}.flow-step.active .flow-step-title{color:#0a84ff}.flow-step.active .flow-step-desc{color:#0f62d1}.flow-step.pending{opacity:.75}.flow-step.pending .flow-step-title{color:#8e8e93}.flow-step.pending .flow-step-index{color:#8e8e93;box-shadow:none;background:#8e8e9326}.flow-connector{background:#8e8e9333;border-radius:999px;flex:0 0 64px;height:2px}.flow-connector.active{background:linear-gradient(90deg,#007aff99 0%,#8e8e9340 100%)}.flow-connector.completed{background:linear-gradient(90deg,#30b0a399 0%,#007affa6 100%)}.upload-dropzone small{color:#86868b;margin-top:4px;font-size:13px}.empty-hint{color:#86868b;background:#f8f8f8cc;border-radius:14px;margin-top:24px;padding:20px;font-size:14px;font-weight:400;line-height:1.6}.empty-hint p{margin:0}.empty-hint p+p{margin-top:8px}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-top:24px;display:grid}.preview-card{background:#fffffff2;border:.5px solid #00000014;border-radius:16px;flex-direction:column;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden;box-shadow:0 2px 8px #0000000d}.preview-card:hover{border-color:#007aff33;transform:translateY(-2px);box-shadow:0 8px 20px #0000001a,0 2px 8px #0000000f}.preview-img{object-fit:cover;border-bottom:.5px solid #00000014;width:100%;height:180px;display:block}.preview-meta{color:#1d1d1f;justify-content:space-between;align-items:center;padding:12px;font-size:13px;display:flex}.preview-meta button{color:#ff3b30;cursor:pointer;background:#ff3b301a;border:none;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;transition:all .2s}.preview-meta button:hover{color:#fff;background:#ff3b30}.preview-name{white-space:nowrap;text-overflow:ellipsis;max-width:70%;font-weight:500;overflow:hidden}.preview-inline{flex-wrap:wrap;align-items:flex-start;gap:12px;margin-top:16px;display:flex}.preview-card-inline{flex-direction:column;flex:none;align-items:center;gap:8px;display:flex}.preview-img-wrapper{cursor:zoom-in;background:#ffffffe6;border:1.5px solid #00000014;border-radius:12px;transition:all .2s;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000f}.preview-img-wrapper:hover{border-color:#007aff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.preview-img-wrapper:focus-visible{border-color:#007aff99;outline:none;box-shadow:0 0 0 3px #007aff40}.preview-img-inline{object-fit:cover;width:120px;height:160px;display:block}.preview-remove-btn{color:#fff;cursor:pointer;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:18px;font-weight:300;line-height:1;transition:all .2s;display:flex;position:absolute;top:6px;right:6px}.preview-remove-btn:hover{background:#ff3b30;transform:scale(1.1)}.preview-name-inline{color:#86868b;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:120px;font-size:12px;font-weight:500;overflow:hidden}.action-bar{flex-direction:column;align-items:center;gap:16px;margin-top:32px;display:flex}.action-buttons{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.action-bar button{color:#fff;cursor:pointer;transition:all var(--transition-base);letter-spacing:.01em;background:#1a73e8;border:none;border-radius:100px;padding:16px 32px;font-size:16px;font-weight:600;position:relative;overflow:hidden;box-shadow:0 4px 12px #1a73e84d}.action-bar button:after{content:"";background:#ffffff4d;border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.action-bar button:active:after{width:300px;height:300px}.action-bar button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.action-bar button:not(:disabled):before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.action-bar button:not(:disabled):hover:before{left:100%}.loading-spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;margin-right:8px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.action-bar button:not(:disabled):hover{background:#1557b0;transform:translateY(-2px);box-shadow:0 8px 24px #1a73e866}.action-bar button:not(:disabled):active{transform:translateY(0)}.action-bar button:focus-visible{outline-offset:2px;outline:2px solid #007aff}.action-bar button.secondary{color:#1d1d1f;box-shadow:none;background:#8e8e931f}.action-bar button.secondary:hover:not(:disabled){background:#8e8e9333;transform:translateY(-1px)}.error-text{color:#ff3b30;text-align:center;background:#ff3b301a;border:.5px solid #ff3b3033;border-radius:12px;margin-top:8px;padding:12px 20px;font-size:14px;font-weight:500;animation:.3s ease-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.action-hint{color:#86868b;text-align:center;margin:0;font-size:13px;font-weight:400}.result-section{-webkit-backdrop-filter:none;backdrop-filter:none;text-align:left;color:#1d1d1f;background:#fff;border:1px solid #0000000f;border-radius:24px;margin-top:64px;padding:48px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,Arial,sans-serif;animation:.6s cubic-bezier(.2,.8,.2,1) fadeInUp;box-shadow:0 20px 40px #0000000a}.result-section h1,.result-section h2,.result-section h3{color:#1d1d1f;letter-spacing:-.01em}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.result-header{border-bottom:.5px solid #00000014;justify-content:space-between;align-items:flex-start;gap:32px;margin-bottom:32px;padding-bottom:24px;display:flex}.result-header-main{flex-direction:column;flex:1;gap:16px;display:flex}.export-section{flex-direction:column;align-items:flex-end;gap:12px;min-width:200px;display:flex}.export-label{color:#86868b;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.section-subtitle{color:#007aff;text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px;font-size:13px;font-weight:600}.result-section>header h2{letter-spacing:-.02em;color:#1d1d1f;margin:0;font-size:32px;font-weight:700}.result-badges{flex-wrap:wrap;gap:8px;display:flex}.export-buttons{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.export-btn{color:#1d1d1f;cursor:pointer;white-space:nowrap;background:#ffffffe6;border:.5px solid #0000001f;border-radius:12px;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.export-btn:hover{color:#007aff;background:#fff;border-color:#007aff4d;transform:translateY(-1px);box-shadow:0 2px 8px #007aff26}.export-btn:active{transform:translateY(0);box-shadow:0 1px 4px #007aff1a}.export-btn-primary{color:#007aff;background:#007aff1a;border-color:#007aff4d}.export-btn-primary:hover{color:#007aff;background:#007aff26;border-color:#007aff;box-shadow:0 2px 12px #007aff33}.export-icon{font-size:16px;line-height:1}.result-badge{color:#007aff;background:#007aff1a;border-radius:12px;align-items:center;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.summary-grid{flex-direction:column;gap:0;margin-bottom:0;display:flex}.summary-card{background:#f8f8f899;border:.5px solid #0000000f;border-radius:18px;margin-bottom:24px;padding:24px}.summary-card:last-child{margin-bottom:0}.summary-card.primary{background:linear-gradient(135deg,#007aff14 0%,#5856d614 100%);border-color:#007aff26}.summary-card header{margin-bottom:16px}.summary-card h3{letter-spacing:-.01em;color:#1d1d1f;margin:0;font-size:20px;font-weight:700}.summary-body{color:#424245;font-size:15px;font-weight:400;line-height:1.8}.summary-body .markdown-content{margin:0}.markdown-content{color:#424245;font-size:15px;line-height:1.8}.markdown-content>:first-child{margin-top:0!important}.markdown-content>:last-child{margin-bottom:0!important}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{letter-spacing:-.01em;color:#1d1d1f;margin:20px 0 10px;font-weight:700;line-height:1.4}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child,.markdown-content h4:first-child,.markdown-content h5:first-child,.markdown-content h6:first-child{margin-top:0}.markdown-content h1{border-bottom:1px solid #0000001a;margin-bottom:16px;padding-bottom:8px;font-size:24px}.markdown-content h2{margin-top:24px;font-size:20px}.markdown-content h3{margin-top:20px;font-size:18px}.markdown-content h4{margin-top:16px;font-size:16px}.markdown-content h5,.markdown-content h6{margin-top:14px;font-size:15px}.markdown-content p{margin:0 0 12px;line-height:1.8}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:12px 0;padding-left:24px}.markdown-content ul:first-child,.markdown-content ol:first-child{margin-top:0}.markdown-content ul:last-child,.markdown-content ol:last-child{margin-bottom:0}.markdown-content li{margin:6px 0;line-height:1.7}.markdown-content li:first-child{margin-top:0}.markdown-content li:last-child{margin-bottom:0}.markdown-content li p{margin:0}.markdown-content strong{color:#1d1d1f;font-weight:700}.markdown-content em{font-style:italic}.markdown-content code{color:#d63384;background:#0000000f;border-radius:4px;padding:2px 6px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.9em}.markdown-content pre{background:#0000000d;border:.5px solid #00000014;border-radius:8px;margin:16px 0;padding:16px;overflow-x:auto}.markdown-content pre code{color:#424245;background:0 0;padding:0;font-size:14px}.markdown-content blockquote{color:#424245;background:#007aff0d;border-left:3px solid #007aff;border-radius:0 8px 8px 0;margin:16px 0;padding:12px 16px}.markdown-content blockquote p{margin:0}.markdown-content hr{border:none;border-top:1px solid #0000001a;margin:24px 0}.markdown-content table{border-collapse:collapse;width:100%;margin:16px 0;font-size:14px}.markdown-content table th,.markdown-content table td{text-align:left;border:.5px solid #0000001a;padding:10px 12px}.markdown-content table th{color:#1d1d1f;background:#0000000a;font-weight:600}.markdown-content a{color:#007aff;border-bottom:1px solid #007aff4d;text-decoration:none;transition:all .2s}.markdown-content a:hover{border-bottom-color:#007aff}.empty-line{color:#86868b;margin:0;font-style:italic}.completion-feedback{z-index:1000;color:#fff;-webkit-backdrop-filter:blur(20px);pointer-events:none;background:#000000d9;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:600;animation:.3s ease-out toastSlideDown,.3s ease-out 2.7s fadeOut;position:fixed;top:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0003}.completion-feedback span{align-items:center;gap:8px;display:flex}.completion-feedback span:before{content:"✓";color:#34c759;background:#34c75933;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;display:inline-flex}@keyframes toastSlideDown{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.analysis-section{margin-top:32px}.analysis-section:first-of-type{margin-top:0}.analysis-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.analysis-section h3{letter-spacing:-.01em;color:#1d1d1f;margin:0;font-size:24px;font-weight:700}.badge{color:#007aff;background:#007aff1a;border-radius:14px;justify-content:center;align-items:center;min-width:32px;height:28px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.analysis-list{flex-direction:column;gap:20px;margin-top:24px;display:flex}.analysis-card{background:#f8f8f880;border:.5px solid #00000014;border-radius:20px;padding:28px;transition:all .2s}.analysis-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000000f}.analysis-headline{border-bottom:.5px solid #00000014;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.analysis-headline h4{letter-spacing:-.01em;color:#1d1d1f;margin:0;font-size:20px;font-weight:700}.analysis-headline .filename{color:#86868b;margin:6px 0 0;font-size:13px;font-weight:400}.analysis-headline .index{color:#fff;background:linear-gradient(135deg,#007aff 0%,#5856d6 100%);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:16px;font-weight:700;display:inline-flex;box-shadow:0 2px 8px #007aff4d}.analysis-content-wrapper{align-items:flex-start;gap:24px;margin-top:20px;display:flex;position:relative}.analysis-image-side{flex:0 0 280px;position:relative}.analysis-image-side:after{content:"";opacity:.3;background:linear-gradient(#0000 0%,#007aff 20% 80%,#0000 100%);width:2px;height:80%;position:absolute;top:50%;right:-16px;transform:translateY(-50%)}.analysis-content-side{word-wrap:break-word;overflow-wrap:break-word;flex:1;width:0;min-width:0}.image-preview-single{background:#00000005;border-radius:12px;width:100%;overflow:hidden}.analysis-image{object-fit:contain;cursor:zoom-in;width:100%;max-width:280px;height:auto;max-height:350px;transition:transform .2s;display:block}.analysis-image:hover{transform:scale(1.01)}.analysis-dimensions{flex-direction:column;gap:16px;display:flex}.analysis-dimension{background:#fffc;border:.5px solid #0000000f;border-radius:14px;transition:all .3s;overflow:hidden}.analysis-dimension.expanded{border-color:#007aff33;box-shadow:0 2px 8px #007aff14}.analysis-dimension.collapsed{border-color:#0000000f}.dimension-toggle{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:16px;width:100%;padding:18px 20px;transition:background .2s;display:flex}.dimension-toggle:hover{background:#00000005}.dimension-toggle:focus-visible{outline-offset:-2px;outline:2px solid #007aff}.dimension-toggle .dimension-header{flex:1;margin:0}.toggle-icon{color:#007aff;background:#007aff1a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:20px;font-weight:300;line-height:1;transition:all .2s;display:flex}.dimension-toggle:hover .toggle-icon{background:#007aff26;transform:scale(1.1)}.dimension-content{word-wrap:break-word;overflow-wrap:break-word;padding:0 20px 20px;animation:.3s ease-out accordionSlideDown;overflow-x:hidden}@keyframes accordionSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dimension-header{word-wrap:break-word;overflow-wrap:break-word;flex-direction:column;gap:8px;width:100%;display:flex}.dimension-title-row{word-wrap:break-word;overflow-wrap:break-word;flex-wrap:wrap;align-items:center;gap:12px;display:flex}.dimension-location-row{word-wrap:break-word;overflow-wrap:break-word;flex-wrap:wrap;align-items:center;gap:8px;display:flex}.analysis-dimension h5{letter-spacing:-.01em;color:#1d1d1f;word-wrap:break-word;overflow-wrap:break-word;flex-shrink:0;margin:0;font-size:16px;font-weight:700}.location-badge{color:#007aff;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;background:#007aff1a;border-radius:8px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.severity-badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:8px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.severity-badge.severity-critical{color:#ff3b30;background:#ff3b3026}.severity-badge.severity-warning{color:#ff9500;background:#ff950026}.severity-badge.severity-suggestion{color:#007aff;background:#007aff1a}.dimension-content .markdown-content{margin:0;font-size:14px}.dimension-content .markdown-content h1,.dimension-content .markdown-content h2,.dimension-content .markdown-content h3{margin:14px 0 8px;font-size:16px}.dimension-content .markdown-content h1:first-child,.dimension-content .markdown-content h2:first-child,.dimension-content .markdown-content h3:first-child{margin-top:0}.dimension-content .markdown-content h4,.dimension-content .markdown-content h5,.dimension-content .markdown-content h6{margin:12px 0 6px;font-size:15px}.dimension-content .markdown-content h4:first-child,.dimension-content .markdown-content h5:first-child,.dimension-content .markdown-content h6:first-child{margin-top:0}.dimension-content .markdown-content p{margin:0 0 8px}.dimension-content .markdown-content p:last-child{margin-bottom:0}.dimension-content .markdown-content ul,.dimension-content .markdown-content ol{margin:8px 0;padding-left:20px}.dimension-content .markdown-content ul:first-child,.dimension-content .markdown-content ol:first-child{margin-top:0}.dimension-content .markdown-content ul:last-child,.dimension-content .markdown-content ol:last-child{margin-bottom:0}.dimension-content .markdown-content li{margin:4px 0}.dimension-content .markdown-content li:first-child{margin-top:0}.dimension-content .markdown-content li:last-child{margin-bottom:0}.result-grid{flex-direction:column;gap:32px;display:flex}.progress-overlay{gap:var(--spacing-md);text-align:center;width:100%;max-width:360px;color:var(--text-secondary);flex-direction:column;align-items:center;font-size:14px;display:flex}.progress-track{background:#c8c8cd59;border-radius:999px;width:100%;height:6px;position:relative;overflow:hidden;box-shadow:inset 0 1px 2px #0000000d}.progress-bar{border-radius:inherit;background:linear-gradient(90deg,var(--primary-color)0%,#5856d6 100%);height:100%;transition:width var(--transition-base);box-shadow:0 0 8px #007aff4d}.progress-list{flex-direction:column;gap:8px;width:100%;margin:4px 0 0;padding:0;list-style:none;display:flex}.progress-item{padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--shadow-sm);color:var(--text-secondary);justify-content:space-between;align-items:center;gap:var(--spacing-md);transition:all var(--transition-fast);font-size:13px;display:flex}.progress-item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.progress-dot{background:#8e8e9399;border-radius:50%;flex-shrink:0;width:10px;height:10px}.progress-name{text-align:left;flex:1;margin:0 8px;font-weight:500}.progress-duration{color:#8e8e93;text-align:right;min-width:56px;font-size:12px}.progress-state{text-align:right;min-width:48px;font-weight:600}.progress-item.status-running .progress-dot{background:#0a84ff;box-shadow:0 0 0 2px #0a84ff40}.progress-item.status-running .progress-state{color:#0a84ff}.progress-item.status-success .progress-dot{background:linear-gradient(135deg,#34c759 0%,#30b0a3 100%);box-shadow:0 0 0 2px #34c75940}.progress-item.status-success .progress-state{color:#34c759}.progress-item.status-error .progress-dot{background:#ff3b30;box-shadow:0 0 0 2px #ff3b3040}.progress-item.status-error .progress-state{color:#ff3b30}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.image-lightbox{-webkit-backdrop-filter:blur(6px);z-index:11000;background:#0d0d0dc7;justify-content:center;align-items:center;padding:40px;animation:.2s ease-out fadeInOverlay;display:flex;position:fixed;inset:0}.image-lightbox-content{background:#ffffff14;border:1px solid #ffffff1f;border-radius:24px;flex-direction:column;gap:16px;max-width:min(90vw,1100px);max-height:90vh;padding:32px 32px 24px;display:flex;position:relative;box-shadow:0 30px 80px #00000059}.image-lightbox-img-wrapper{background:#fff;border-radius:16px;max-height:calc(90vh - 140px);overflow:auto;box-shadow:inset 0 0 0 1px #0000000a}.image-lightbox-img-wrapper img{max-width:100%;height:auto;display:block}.image-lightbox-close{color:#fff;cursor:pointer;background:#0000008c;border:none;border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;line-height:1;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.image-lightbox-close:hover{background:#000000bf;transform:scale(1.05)}.image-lightbox-name{color:#ffffffd9;text-align:center;word-break:break-all;margin:0;font-size:15px}.retry-panel{text-align:left;background:#ffffffd9;border:1px solid #0000000f;border-radius:16px;width:100%;max-width:520px;margin-top:16px;padding:16px 20px;box-shadow:0 10px 30px #00000014}.retry-title{color:#1d1d1f;margin:0 0 10px;font-size:14px;font-weight:600}.retry-list{flex-direction:column;gap:8px;margin:0 0 14px;padding:0;list-style:none;display:flex}.retry-list li{color:#636366;word-break:break-word;background:#f8f8f8cc;border-radius:12px;flex-direction:column;gap:4px;padding:8px 12px;font-size:13px;display:flex}.retry-name{color:#1d1d1f;font-weight:600}.retry-error{color:#ff3b30;font-size:12px}.retry-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0a84ff 0%,#5856d6 100%);border:none;border-radius:12px;align-self:flex-start;padding:8px 18px;font-size:13px;font-weight:600;transition:all .2s}.retry-button:hover{transform:translateY(-1px);box-shadow:0 8px 18px #0a84ff59}.retry-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}@media (max-width:768px){.page-container{padding:40px 20px 80px}.page-header h1{font-size:36px}.tab-button{flex:100%;min-width:100%;max-width:100%}.model-controls{flex-direction:column;align-items:stretch}.field-group select,.field-group input{min-width:100%}.upload-grid{grid-template-columns:1fr}.upload-section{padding:24px}.step-indicator{min-width:48px;height:48px;font-size:15px}.analysis-card{padding:20px}.analysis-content-wrapper{flex-direction:column;gap:24px}.analysis-image-side{flex:none;width:100%}.analysis-image-side:after{display:none}.summary-grid,.result-grid{grid-template-columns:1fr}.result-section{padding:32px 24px}.figma-import,.figma-import.compact{padding:16px}.figma-input-group{flex-direction:column;align-items:stretch}.figma-import-btn{width:100%}.image-lightbox{padding:20px}.image-lightbox-content{padding:24px 20px 18px}.progress-overlay{max-width:100%;padding:0 12px}.progress-track{height:5px}.progress-item{padding:6px 10px}.progress-duration,.progress-state{min-width:auto}.retry-panel{max-width:100%}}.ghost-button{color:#1d1d1f;cursor:pointer;background:#fff9;border:1px solid #0000001f;border-radius:999px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.ghost-button:not(:disabled):hover{color:#007aff;border-color:#007aff80;box-shadow:0 4px 12px #007aff1f}.ghost-button:disabled{opacity:.5;cursor:not-allowed}.persona-panel{-webkit-backdrop-filter:blur(20px);background:#fffc;border:.5px solid #00000014;border-radius:20px;margin-top:32px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 32px #007aff1f,0 2px 8px #0000000a}.persona-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.persona-panel-header>div:first-child{flex:1;min-width:0}.persona-panel-header>div:last-child{flex-shrink:0}.persona-panel-header h3{letter-spacing:-.01em;color:#1d1d1f;margin:0;font-size:24px;font-weight:700}.persona-panel-desc{color:#86868b;margin:8px 0 0;font-size:15px;font-weight:400;line-height:1.5}.persona-panel-actions{flex-wrap:wrap;flex-shrink:0;align-items:flex-start;gap:8px;display:flex}.persona-panel-meta{color:#86868b;border-bottom:1px solid #0000000f;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;font-size:13px;display:flex}.persona-meta-left{align-items:center;gap:16px;display:flex}.persona-meta-updated{color:#1d1d1f;font-weight:600}.persona-meta-actions{gap:8px;display:flex}.config-section{margin-bottom:24px}.config-section:last-child{margin-bottom:0}.config-divider{background:#0000000f;height:1px;margin:24px 0}.persona-actions-row{flex-wrap:wrap;flex:1;justify-content:flex-start;align-items:center;gap:8px;display:flex}.persona-actions-row .ghost-button{color:#1d1d1f;cursor:pointer;background:#0000000a;border:.5px solid #00000014;border-radius:8px;padding:8px 16px;font-size:13px;transition:all .2s}.persona-actions-row .ghost-button:hover:not(:disabled){background:#0000000f;border-color:#0000001f}.persona-actions-row .ghost-button:disabled{opacity:.4;cursor:not-allowed}.provider-meta{color:#86868b;align-items:center;gap:16px;margin-top:8px;font-size:13px;display:flex}.persona-field-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:8px;display:flex}.persona-field-header>span{color:#1d1d1f;font-size:13px;font-weight:500}.persona-actions-row .persona-meta-updated{color:#86868b;margin-left:auto;font-size:13px}.persona-section{-webkit-backdrop-filter:blur(20px);background:#fffc;border:.5px solid #00000014;border-radius:20px;margin-top:32px;padding:28px;box-shadow:0 4px 20px #0000000a,0 1px 3px #0000000f}.persona-section-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.persona-section-header>div:first-child{flex:1;min-width:0}.persona-section-header h3{letter-spacing:-.01em;color:#1d1d1f;margin:0 0 8px;font-size:22px;font-weight:700}.persona-update-time{color:#86868b;margin:0;font-size:13px;font-weight:400}.persona-header-actions{flex-wrap:wrap;flex-shrink:0;gap:8px;display:flex}.persona-selection-meta{color:#86868b;border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;font-size:13px;display:flex}.persona-selection-actions{gap:8px;display:flex}.persona-empty{text-align:center;color:#6e6e73;background:#f8f8f8cc;border:1px dashed #00000014;border-radius:16px;padding:32px;font-size:14px}.persona-card-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.persona-card{text-align:left;cursor:pointer;-webkit-backdrop-filter:blur(10px);background:#fff9;border:.5px solid #00000014;border-radius:16px;padding:16px;transition:all .3s cubic-bezier(.4,0,.2,1)}.persona-card.selected{background:#ffffffe6;border-color:#007aff4d;transform:translateY(-2px);box-shadow:0 8px 32px #007aff1f,0 2px 8px #0000000a}.persona-card:disabled{opacity:.6;cursor:not-allowed}.persona-card-header{justify-content:space-between;gap:12px;margin-bottom:12px;display:flex}.persona-card-header h4{color:#1d1d1f;margin:0 0 6px;font-size:17px}.persona-card-header p{color:#6e6e73;margin:0;font-size:13px}.persona-card-meta{text-align:right;color:#6e6e73;flex-direction:column;gap:4px;font-size:12px;display:flex}.persona-count{color:#1d1d1f;font-weight:600}.persona-select-state{color:#007aff}.persona-tags{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.persona-tags span{color:#007aff;background:#007aff14;border-radius:999px;padding:4px 8px;font-size:12px}.persona-summary{color:#424245;margin:0 0 10px;font-size:13px;line-height:1.5}.persona-quotes{color:#6e6e73;margin:0;padding-left:16px;font-size:12px}.persona-insights{margin-top:24px}.persona-insight-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.persona-insight-card{background:#fffffff2;border:1px solid #00000014;border-radius:18px;padding:20px}.persona-insight-head{justify-content:space-between;gap:12px;margin-bottom:12px;display:flex}.persona-insight-head h4{color:#1d1d1f;margin:0;font-size:18px}.persona-insight-headline{color:#6e6e73;margin:4px 0 0;font-size:13px}.persona-insight-body .markdown-content{font-size:14px}
