*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-primary-light:#eff6ff;--color-secondary:#6b7280;--color-danger:#dc2626;--color-success:#16a34a;--color-warning:#d97706;--color-bg:#f9fafb;--color-surface:#fff;--color-border:#e5e7eb;--color-text:#111827;--color-text-muted:#6b7280;--radius:8px;--radius-sm:4px;--radius-lg:12px;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d}html{font-size:16px}body{-webkit-font-smoothing:antialiased;background:#f9fafb;background:var(--color-bg);color:#111827;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}.app-header{align-items:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow);display:flex;height:56px;justify-content:space-between;padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left,.header-right{align-items:center;display:flex;gap:8px}.header-right{position:relative}.logo-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:8px;padding:4px}.logo-btn:hover{background:var(--color-primary-light)}.logo-mark{align-items:center;background:var(--color-primary);border-radius:6px;color:#fff;display:flex;font-size:15px;font-weight:800;height:28px;justify-content:center;width:28px}.logo-text{color:var(--color-text);font-size:1.1rem;font-weight:700}.breadcrumb{align-items:center;color:var(--color-text-muted);display:flex;font-size:.875rem;gap:6px}.breadcrumb-sep{font-size:1.1em}.breadcrumb-step{font-weight:500}.main-content{min-height:calc(100vh - 56px);padding:24px 20px}.app-layout{gap:20px;margin:0 auto;max-width:1200px}.main-panel,.sidebar{min-width:0}.main-panel-full{grid-column:1/-1}.btn{align-items:center;border:1px solid #0000;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:8px;padding:8px 16px;text-decoration:none;transition:background .15s,border-color .15s,box-shadow .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:var(--color-bg)}.btn-danger{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn-ghost{background:none;border-color:#0000;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){color:var(--color-danger)}.btn-google{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow);color:var(--color-text);font-size:1rem;font-weight:600;justify-content:center;padding:12px 24px;width:100%}.btn-google:hover{background:var(--color-bg);box-shadow:var(--shadow-md)}.btn-lg{font-size:1rem;padding:12px 24px}.btn-sm{font-size:.8125rem;padding:5px 12px}.btn-icon{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:2px 6px}.btn-icon:hover{background:var(--color-bg);color:var(--color-danger)}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{color:var(--color-text);font-size:.875rem;font-weight:600}.label-optional{color:var(--color-text-muted);font-weight:400}.form-input,.form-select,.form-textarea{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:.9375rem;padding:8px 12px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26;outline:none}.form-select{cursor:pointer}.form-textarea{min-height:80px;resize:vertical}.form-hint{color:var(--color-text-muted);font-size:.8125rem}.form-select-sm{font-size:.8125rem;padding:4px 8px}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.alert{align-items:center;border-radius:var(--radius);display:flex;font-size:.9rem;gap:10px;padding:12px 16px}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:var(--color-danger)}.alert-info{background:var(--color-primary-light);border:1px solid #bfdbfe;color:var(--color-primary)}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--color-success)}.alert-dismiss{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;margin-left:auto;opacity:.7}.alert-dismiss:hover{opacity:1}.badge{border-radius:999px;display:inline-block;font-size:.75rem;font-weight:600;padding:2px 8px}.badge-green{background:#dcfce7;color:#166534}.badge-blue{background:#dbeafe;color:#1e40af}.badge-purple{background:#ede9fe;color:#5b21b6}.badge-orange{background:#ffedd5;color:#9a3412}.badge-red{background:#fee2e2;color:#991b1b}.badge-gray{background:#f3f4f6;color:#374151}.tab-group{border:1px solid var(--color-border);border-radius:var(--radius);display:flex;gap:0;margin-bottom:20px;overflow:hidden;width:-webkit-fit-content;width:fit-content}.tab{background:var(--color-surface);border:none;border-right:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 20px;transition:background .15s}.tab:last-child{border-right:none}.tab:hover:not(.tab-active){background:var(--color-bg)}.tab-active{background:var(--color-primary);color:#fff}.spinner{animation:spin .8s linear infinite;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:28px;width:28px}.spinner-lg{border-width:4px;height:52px;width:52px}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen{background:var(--color-bg);height:100vh}.analyzing-screen,.loading-screen{align-items:center;display:flex;justify-content:center}.analyzing-screen{flex-direction:column;gap:16px;padding:80px 20px;text-align:center}.analyzing-screen h2{font-size:1.25rem}.analyzing-screen p{color:var(--color-text-muted)}.auth-container{align-items:center;background:linear-gradient(135deg,#eff6ff,#f9fafb 60%);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:480px;padding:40px 48px;width:100%}.auth-logo{align-items:center;display:flex;gap:12px;margin-bottom:16px}.auth-logo h1{font-size:1.75rem;font-weight:800}.logo-icon{align-items:center;background:var(--color-primary);border-radius:10px;color:#fff;display:flex;font-size:20px;font-weight:800;height:40px;justify-content:center;width:40px}.auth-tagline{color:var(--color-text-muted);line-height:1.5;margin-bottom:24px}.auth-features{background:var(--color-bg);border-radius:var(--radius);display:flex;flex-direction:column;gap:10px;margin-bottom:28px;padding:16px}.feature{align-items:center;display:flex;font-size:.875rem;gap:10px}.feature-icon{flex-shrink:0;font-size:1rem}.auth-note{color:var(--color-text-muted);font-size:.8125rem;margin-top:16px;text-align:center}.setup-container{align-items:flex-start;display:flex;justify-content:center;padding:40px 20px}.setup-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);max-width:560px;padding:36px 40px;width:100%}.setup-card h2{font-size:1.4rem;margin-bottom:12px}.setup-description{color:var(--color-text-muted);line-height:1.6;margin-bottom:24px}.setup-steps{margin-bottom:20px}.setup-steps h3{font-size:.9375rem;margin-bottom:8px}.setup-steps ol{padding-left:20px}.setup-steps li{font-size:.9rem;line-height:1.5;margin-bottom:6px}.setup-steps a{color:var(--color-primary)}.setup-info{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius);margin-bottom:24px;padding:12px 16px}.setup-info h4{color:#92400e;font-size:.875rem;margin-bottom:4px}.setup-info p{color:#92400e;font-size:.8125rem}.setup-form{display:flex;flex-direction:column;gap:16px}.upload-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:28px 32px}.upload-container h2{font-size:1.3rem;margin-bottom:16px}.upload-form{display:flex;flex-direction:column;gap:20px}.drop-zone{align-items:center;background:var(--color-bg);border:2px dashed var(--color-border);border-radius:var(--radius);cursor:pointer;display:flex;justify-content:center;min-height:120px;padding:32px;text-align:center;transition:border-color .15s,background .15s}.drop-zone-active,.drop-zone:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.drop-zone-prompt{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:8px}.drop-icon{font-size:2rem}.drop-zone-prompt p{color:var(--color-text);font-weight:500}.drop-zone-file{align-items:center;display:flex;font-size:.9rem;gap:10px}.file-icon{font-size:1.5rem}.file-name{font-weight:600}.file-size{color:var(--color-text-muted)}.vocab-container{display:flex;flex-direction:column;gap:16px}.vocab-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.vocab-header h2{font-size:1.3rem}.vocab-meta{color:var(--color-text-muted);font-size:.875rem;margin-top:4px}.vocab-count{flex-shrink:0;text-align:right}.count-selected{color:var(--color-primary);font-size:2rem;font-weight:700;line-height:1}.count-total{color:var(--color-text-muted);font-size:.875rem}.vocab-controls{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-wrap:wrap;gap:20px;padding:12px 16px}.control-group,.vocab-controls{align-items:center;display:flex}.control-group{gap:6px}.control-label{color:var(--color-text-muted);font-size:.8125rem;font-weight:600;white-space:nowrap}.btn-filter{background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;cursor:pointer;font-size:.8rem;padding:4px 12px;transition:all .15s}.btn-filter:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-filter-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.word-list{display:flex;flex-direction:column;gap:8px}.word-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s,box-shadow .15s}.word-card:hover{border-color:#93c5fd;box-shadow:var(--shadow)}.word-card-selected{background:var(--color-primary-light);border-color:var(--color-primary)}.word-card-main{align-items:flex-start;cursor:pointer;display:flex;gap:12px;padding:14px 16px}.word-checkbox{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;height:18px;margin-top:3px;width:18px}.word-info{flex:1 1;min-width:0}.word-top{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.word-term{font-size:1.05rem;font-weight:700}.word-pos{color:var(--color-text-muted);font-size:.8125rem;font-style:italic}.word-root{background:var(--color-primary-light);border-radius:var(--radius-sm);color:var(--color-primary);font-size:.8125rem;padding:1px 6px}.word-definition{color:var(--color-text);font-size:.9rem;line-height:1.4}.btn-expand{background:none;border:none;color:var(--color-text-muted);cursor:pointer;flex-shrink:0;font-size:.75rem;padding:4px 8px}.word-card-details{background:#f8faff;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px;padding:12px 16px 14px 46px}.detail-row{display:flex;font-size:.875rem;gap:8px}.detail-label{color:var(--color-text-muted);font-weight:600;min-width:80px;white-space:nowrap}.detail-value{color:var(--color-text)}.context-sentence{color:#374151;font-style:italic}.vocab-actions{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);bottom:16px;box-shadow:var(--shadow-md);gap:16px;justify-content:space-between;padding:16px;position:-webkit-sticky;position:sticky}.save-group,.vocab-actions{align-items:center;display:flex}.save-group{gap:12px}.save-msg{color:var(--color-success);font-size:.875rem;font-weight:500}.output-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;gap:20px;padding:28px 32px}.output-container h2{font-size:1.3rem}.output-meta{color:var(--color-text-muted);font-size:.875rem}.format-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.format-card{align-items:flex-start;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);cursor:pointer;display:flex;gap:12px;padding:14px 16px;position:relative;transition:border-color .15s,background .15s}.format-card:hover{background:#f8faff;border-color:#93c5fd}.format-card-selected{background:var(--color-primary-light);border-color:var(--color-primary)}.format-icon{flex-shrink:0;font-size:1.5rem}.format-label{font-size:.9375rem;font-weight:600;margin-bottom:3px}.format-description{color:var(--color-text-muted);font-size:.8125rem;line-height:1.4}.format-check{color:var(--color-primary);font-weight:700;position:absolute;right:12px;top:10px}.selected-words-preview h3{font-size:.9375rem;margin-bottom:8px}.word-chips{display:flex;flex-wrap:wrap;gap:6px}.word-chip{background:var(--color-bg);border:1px solid var(--color-border);border-radius:999px;color:var(--color-text);font-size:.8125rem;padding:3px 10px}.output-actions{align-items:center;border-top:1px solid var(--color-border);display:flex;gap:16px;justify-content:space-between;padding-top:8px}.artifact-container{display:flex;flex-direction:column;height:calc(100vh - 80px)}.artifact-toolbar{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:12px;padding:12px 16px}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:8px}.toolbar-center{flex:1 1;text-align:center}.artifact-title{font-size:.9375rem;font-weight:600}.toggle-label{align-items:center;cursor:pointer;display:flex;font-size:.875rem;gap:6px;-webkit-user-select:none;user-select:none}.artifact-preview{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);flex:1 1;overflow:hidden}.artifact-iframe{border:none;height:100%;min-height:600px;width:100%}.wlm-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:20px}.wlm-container h3{font-size:1rem;margin-bottom:4px}.wlm-subtitle{font-size:.8125rem;margin-bottom:16px}.wlm-empty,.wlm-subtitle{color:var(--color-text-muted)}.wlm-empty{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:32px 20px;text-align:center}.wlm-empty-icon{display:block;font-size:2.5rem;margin-bottom:12px}.wlm-list{display:flex;flex-direction:column;gap:8px}.wlm-item{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.wlm-item-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;padding:12px}.wlm-item-info{display:flex;flex-direction:column;gap:4px;min-width:0}.wlm-title{font-size:.9rem;font-weight:600}.wlm-author{color:var(--color-text-muted);font-size:.8125rem}.wlm-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.wlm-date{color:var(--color-text-muted);font-size:.75rem}.wlm-actions{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:4px;justify-content:flex-end}.wlm-words{background:var(--color-bg);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:8px;padding:12px}.wlm-word{align-items:baseline;display:flex;flex-wrap:wrap;font-size:.8125rem;gap:6px}.wlm-word-term{font-weight:700}.wlm-word-pos{color:var(--color-text-muted);font-size:.75rem;font-style:italic}.wlm-word-root{color:var(--color-primary);font-size:.75rem}.wlm-word-def{color:var(--color-text);line-height:1.4}.user-btn{align-items:center;background:none;border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;display:flex;font-size:.875rem;gap:8px;padding:4px 10px 4px 4px;transition:background .15s}.user-btn:hover{background:var(--color-bg)}.avatar{object-fit:cover}.avatar,.avatar-fallback{border-radius:50%;height:28px;width:28px}.avatar-fallback{align-items:center;background:var(--color-primary);color:#fff;display:flex;font-size:.875rem;font-weight:700;justify-content:center}.user-name{font-weight:500;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron{color:var(--color-text-muted);font-size:.625rem}.user-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:200}.user-menu-email{color:var(--color-text-muted);font-size:.8125rem;padding:10px 16px}.menu-divider{border:none;border-top:1px solid var(--color-border)}.menu-item{background:none;border:none;color:var(--color-text);cursor:pointer;display:block;font-size:.875rem;padding:10px 16px;text-align:left;transition:background .1s;width:100%}.menu-item:hover{background:var(--color-bg)}.menu-item-danger{color:var(--color-danger)}.menu-item:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.app-layout{grid-template-columns:1fr}.sidebar{order:2}.main-panel{order:1}.artifact-toolbar{align-items:stretch;flex-direction:column}.toolbar-center{order:-1}.format-grid{grid-template-columns:1fr}.auth-card{padding:28px 24px}.setup-card{padding:24px 20px}.output-container,.upload-container{padding:20px 16px}.vocab-actions{align-items:stretch}.output-actions,.vocab-actions{flex-direction:column}.user-name{display:none}}
/*# sourceMappingURL=main.64c34cda.css.map*/