.app{width:100%;min-height:100vh}.app-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid #646cff}.app-header h1{font-size:2.5rem;margin-bottom:.5rem;color:#646cff}.app-header p{font-size:1.1rem;opacity:.8}.tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #444}.tab{padding:1rem 2rem;font-size:1rem;font-weight:600;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;color:#fff9;transition:all .3s}.tab:hover{color:#ffffffde}.tab.active{color:#646cff;border-bottom-color:#646cff}.app-content{display:flex;flex-direction:column;gap:2rem}.input-section{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;font-size:1.1rem;color:#646cff}.system-message-input,.prompt-input,.text-input,.segment-text,.effort-select{width:100%;padding:.75rem;font-size:1rem;font-family:Courier New,monospace;border:2px solid #444;border-radius:8px;background-color:#1a1a1a;color:#ffffffde;resize:vertical;transition:border-color .3s}.effort-select{cursor:pointer;font-family:inherit;resize:none}.system-message-input:focus,.prompt-input:focus,.text-input:focus,.segment-text:focus,.effort-select:focus{outline:none;border-color:#646cff}.segment-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background-color:#646cff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s,transform .1s}.segment-button:hover:not(:disabled){background-color:#535bf2;transform:translateY(-2px)}.segment-button:active:not(:disabled){transform:translateY(0)}.segment-button:disabled{background-color:#444;cursor:not-allowed;opacity:.6}.button-group{display:flex;gap:1rem;flex-wrap:wrap}.secondary-button{background-color:#555}.secondary-button:hover:not(:disabled){background-color:#666}.save-default-button{margin-top:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;color:#fff;background-color:#4caf50;border:none;border-radius:6px;cursor:pointer;transition:background-color .3s,transform .1s}.save-default-button:hover{background-color:#45a049;transform:translateY(-1px)}.save-default-button:active{transform:translateY(0)}.error-message{padding:1rem;background-color:#f44;color:#fff;border-radius:8px;font-weight:500}.segments-section{margin-top:1rem}.segments-section h2{font-size:1.8rem;margin-bottom:1rem;color:#646cff}.segments-list{display:flex;flex-direction:column;gap:1.5rem;max-height:600px;overflow-y:auto;padding-right:.5rem}.segments-list::-webkit-scrollbar{width:8px}.segments-list::-webkit-scrollbar-track{background:#1a1a1a;border-radius:4px}.segments-list::-webkit-scrollbar-thumb{background:#646cff;border-radius:4px}.segments-list::-webkit-scrollbar-thumb:hover{background:#535bf2}.segment-item{border:2px solid #444;border-radius:8px;padding:1rem;background-color:#1e1e1e;transition:border-color .3s}.segment-item:hover{border-color:#646cff}.segment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.segment-number{font-weight:600;font-size:1rem;color:#646cff}.delete-button{background:none;border:none;color:#f44;font-size:1.5rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .3s}.delete-button:hover{background-color:#ff44441a}.segment-text{min-height:100px}.segment-text-readonly{width:100%;padding:.75rem;font-size:1rem;font-family:Courier New,monospace;border:2px solid #444;border-radius:8px;background-color:#1a1a1a;color:#ffffffde;white-space:pre-wrap;word-wrap:break-word;min-height:60px}.paragraph-clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.paragraph-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #646cff4d}.paragraph-clickable:active{transform:translateY(0)}.paragraph-clickable.processed{border-color:#4caf50}.paragraph-clickable.processed:hover{border-color:#66bb6a}.processed-badge{display:inline-block;margin-left:.5rem;padding:.2rem .5rem;background-color:#4caf50;color:#fff;border-radius:4px;font-size:.85rem;font-weight:700}.back-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background-color:#555;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s,transform .1s;margin-bottom:1.5rem;align-self:flex-start}.back-button:hover{background-color:#666;transform:translate(-2px)}.back-button:active{transform:translate(0)}.visualization-item{margin-bottom:2rem}.visualization-idea{display:flex;flex-direction:column;gap:1.5rem}.idea-description{padding:1rem;background-color:#646cff1a;border-left:4px solid #646cff;border-radius:6px}.idea-description strong{color:#646cff;display:block;margin-bottom:.5rem;font-size:1.1rem}.idea-description p{margin:0;line-height:1.6;color:#ffffffde}.frames-section{padding:1rem;background-color:#4444444d;border-radius:6px}.frames-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem;margin:-.5rem -.5rem .5rem;border-radius:4px;transition:background-color .2s}.frames-header:hover{background-color:#646cff1a}.frames-header strong{color:#646cff;font-size:1.05rem}.collapse-icon{color:#646cff;font-size:.9rem;transition:transform .2s;display:inline-block}.frames-section>strong{color:#646cff;display:block;margin-bottom:1rem;font-size:1.05rem}.frames-list{display:flex;flex-direction:column;gap:.75rem}.frame-item{display:flex;gap:.5rem;padding:.75rem;background-color:#1e1e1e;border-radius:4px;border-left:3px solid #888}.frame-number{color:#646cff;font-weight:600;min-width:80px;flex-shrink:0}.frame-text{color:#ffffffde;line-height:1.5}.file-input-hidden{display:none}.file-input-label{display:flex;align-items:center;gap:1rem;padding:.75rem;border:2px solid #444;border-radius:8px;background-color:#1a1a1a;cursor:pointer;transition:border-color .3s}.file-input-label:hover{border-color:#646cff}.file-input-button{padding:.5rem 1rem;background-color:#646cff;color:#fff;border-radius:6px;font-weight:600;transition:background-color .3s}.file-input-label:hover .file-input-button{background-color:#535bf2}.file-input-text{color:#ffffffde;font-size:1rem}.form-label{font-weight:600;font-size:1.1rem;color:#646cff;display:block;margin-bottom:.5rem}.help-text{font-size:.9rem;color:#fff9;margin-top:.25rem}.loading-message{padding:2rem;background-color:#f5f7fa;border-radius:8px;font-weight:500;text-align:center}.loading-message .spinner-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-message .spinner-container p{color:#666;margin:0}.loading-message .spinner{border-top-color:#667eea}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (prefers-color-scheme: light){.tabs{border-bottom-color:#ddd}.tab{color:#21354799}.tab:hover{color:#213547de}.tab.active{color:#646cff;border-bottom-color:#646cff}.prompt-input,.text-input,.segment-text,.segment-text-readonly,.effort-select{background-color:#f5f5f5;color:#213547;border-color:#ddd}.prompt-input:focus,.text-input:focus,.segment-text:focus,.effort-select:focus{border-color:#646cff}.file-input-label{background-color:#f5f5f5;border-color:#ddd}.file-input-label:hover{border-color:#646cff}.file-input-text{color:#213547}.segment-item{background-color:#fafafa;border-color:#ddd}.paragraph-clickable:hover{box-shadow:0 4px 12px #646cff33}.segments-list::-webkit-scrollbar-track{background:#f5f5f5}.help-text{color:#21354799}.idea-description{background-color:#646cff0d}.idea-description p{color:#213547}.frames-section{background-color:#00000008}.frames-header:hover{background-color:#646cff14}.frame-item{background-color:#f5f5f5}.frame-text{color:#213547}.sessions-panel{background-color:#f5f5f5;border:2px solid #ccc}.session-item{background-color:#fff;border:1px solid #ddd}.session-item:hover{background-color:#f0f0f0}.session-filename{color:#213547}.session-count,.session-date{color:#21354799}.paragraph-clickable.processed{border-color:#4caf50}.paragraph-clickable.processed:hover{border-color:#66bb6a}.processed-badge{background-color:#4caf50;color:#fff}}.sessions-panel{margin-top:1rem;padding:1.5rem;background-color:#646cff0d;border:2px solid #646cff;border-radius:8px}.sessions-panel h3{margin:0 0 1rem;color:#646cff;font-size:1.3rem}.sessions-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.session-item{padding:1rem;background-color:#2a2a2a;border:2px solid #444;border-radius:8px;cursor:pointer;transition:all .3s}.session-item:hover{background-color:#333;border-color:#646cff;transform:translateY(-2px)}.session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.session-filename{font-weight:600;font-size:1.1rem;color:#ffffffde}.session-count{font-size:.9rem;color:#646cff;padding:.25rem .5rem;background-color:#646cff1a;border-radius:4px}.session-meta{display:flex;gap:1rem;font-size:.85rem;color:#ffffff80}.session-date{font-style:italic}.session-actions{display:flex;align-items:center;gap:.75rem}.session-copy-button{padding:.25rem .75rem;font-size:.85rem;background-color:#646cff33;border:1px solid #646cff;border-radius:4px;color:#646cff;cursor:pointer;transition:all .2s}.session-copy-button:hover{background-color:#646cff;color:#fff}.session-copy-button:active{transform:scale(.95)}.session-delete-button{padding:.25rem .75rem;font-size:.85rem;background-color:#ff646433;border:1px solid #ff6464;border-radius:4px;color:#ff6464;cursor:pointer;transition:all .2s}.session-delete-button:hover{background-color:#ff6464;color:#fff}.session-delete-button:active{transform:scale(.95)}.library-section{display:flex;flex-direction:column;gap:2rem}.library-section h2{color:#8b92ff;font-size:1.8rem;margin-bottom:1rem}.library-stats{display:flex;gap:2rem;padding:1rem;background-color:#646cff1a;border-radius:8px;margin-bottom:1.5rem}.library-stats p{margin:0;font-size:1rem;color:#ffffffde}.category-section{margin-bottom:2rem;padding:1.5rem;background-color:#646cff14;border-radius:12px;border:1px solid #646cff}.category-title{font-size:1.8rem;color:#8b92ff;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:1px}.category-stats{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.95rem;color:#ffffffde}.category-stats span{padding:.25rem .75rem;background-color:#646cff4d;border-radius:4px;color:#fff}.subcategories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.subcategory-card{padding:1rem;background-color:#2a2a3e;border:2px solid #646cff;border-radius:8px;cursor:pointer;transition:all .3s ease}.subcategory-card:hover{border-color:#8b92ff;background-color:#646cff26;transform:translateY(-2px);box-shadow:0 4px 8px #646cff4d}.subcategory-card h4{margin:0 0 .75rem;font-size:1.2rem;color:#fff;text-transform:capitalize}.subcategory-stats{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;color:#fffc}.subcategory-stats span{padding:.15rem 0}.subcategory-name{font-size:1.2rem;font-weight:600;color:#fff;margin-bottom:.5rem;text-transform:capitalize}.subcategory-info{font-size:.85rem;color:#fffc}.subcategory-info span{display:block;padding:.15rem 0}.subcategory-content{display:flex;flex-direction:column;gap:2rem}.content-stats{display:flex;gap:1.5rem;padding:1rem;background-color:#646cff1a;border-radius:8px;font-size:1rem}.content-stats span{padding:.25rem .75rem;background-color:#646cff33;border-radius:4px}.prompts-section{display:flex;flex-direction:column;gap:1rem}.prompts-section h3{color:#646cff;font-size:1.5rem;margin-bottom:.5rem}.prompt-item{padding:1rem;background-color:#ffffff08;border:1px solid #444;border-radius:8px}.prompt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #444}.prompt-header strong{color:#646cff;font-size:1.1rem}.file-size{color:#ffffff80;font-size:.9rem}.prompt-content{padding:.75rem;background-color:#1a1a1a;border-radius:6px;color:#ffffffde;font-family:Courier New,monospace;white-space:pre-wrap;line-height:1.6;max-height:400px;overflow-y:auto}.images-section{display:flex;flex-direction:column;gap:1rem}.images-section h3{color:#646cff;font-size:1.5rem;margin-bottom:.5rem}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.image-item{display:flex;flex-direction:column;background-color:#ffffff08;border:1px solid #444;border-radius:8px;overflow:hidden;transition:all .3s ease}.image-item:hover{border-color:#646cff;box-shadow:0 4px 12px #646cff4d;transform:translateY(-2px)}.library-image{width:100%;height:250px;object-fit:contain;background-color:#1a1a1a;cursor:pointer;transition:opacity .2s ease}.library-image:hover{opacity:.85}.image-info{padding:.75rem;background-color:#0000004d}.image-filename{margin:0 0 .25rem;font-size:.95rem;color:#ffffffde;font-weight:600;word-break:break-word}.image-size{margin:0;font-size:.85rem;color:#ffffff80}@media (max-width: 768px){.app-header h1{font-size:2rem}.segments-list{max-height:400px}.sessions-list{max-height:300px}.subcategories-grid,.images-grid{grid-template-columns:1fr}.library-stats,.category-stats,.content-stats{flex-direction:column;gap:.5rem}.selected-images-preview{grid-template-columns:repeat(2,1fr)!important}.generated-images-grid{grid-template-columns:1fr!important}}.frame-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;background-color:#ffffff05;border-radius:8px;margin-bottom:.5rem}.frame-content{display:flex;gap:.5rem;flex:1}.choose-frame-button{padding:.5rem 1rem;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .3s;white-space:nowrap}.choose-frame-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.image-selection-checkboxes{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:4px;z-index:10}.checkbox-item{display:flex;align-items:center;gap:4px;background-color:#000000b3;border:1px solid #646cff;border-radius:4px;padding:2px 6px;cursor:pointer;transition:all .2s}.checkbox-item:hover{background-color:#646cff33;border-color:#fff}.checkbox-item.checked{background-color:#646cff4d;border-color:#646cff}.checkbox-label{font-size:.7rem;font-weight:600;color:#646cff;min-width:22px}.checkbox{width:16px;height:16px;border:1px solid #646cff;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:#4caf50;background-color:#0006}.image-card{position:relative}.selected-frame-info{background-color:#646cff1a;border:2px solid #646cff;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.selected-frame-info strong{color:#646cff;font-size:1.1rem}.selected-frame-info p{margin-top:.5rem;line-height:1.6}.selection-info{display:flex;align-items:center;justify-content:space-between;background-color:#ffffff0d;padding:1rem;border-radius:8px;margin-bottom:1.5rem}.selection-info p{font-size:1.1rem;font-weight:600;color:#646cff}.proceed-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.proceed-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.generation-view{display:flex;flex-direction:column;gap:2rem}.generation-inputs{display:flex;flex-direction:column;gap:1.5rem}.frame-context-box{background-color:#ffffff0d;border:2px solid #444;border-radius:8px;padding:1rem;line-height:1.6;min-height:60px}.selected-images-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:.5rem}.preview-image{aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid #444}.preview-image img{width:100%;height:100%;object-fit:cover}.generate-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s;align-self:flex-start}.generate-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.generate-button:disabled{opacity:.6;cursor:not-allowed}.validation-section{margin-top:1.5rem;padding:1rem;background-color:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:8px}.validation-header{margin-bottom:.5rem}.validation-header label{display:flex;align-items:center;font-size:1.1rem;font-weight:600;cursor:pointer}.validation-header input[type=checkbox]{margin-right:.5rem;width:20px;height:20px;cursor:pointer}.validation-settings{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(102,126,234,.2)}.iterations-input{padding:.5rem;font-size:1rem;background-color:#1a1a1a;color:#fff;border:1px solid #444;border-radius:4px;width:100px}.iterations-input:focus{outline:none;border-color:#646cff}.validation-status{margin-top:1.5rem;padding:1rem;background-color:#667eea0d;border:1px solid rgba(102,126,234,.2);border-radius:8px}.validation-status h4{color:#646cff;margin-bottom:.75rem}.validation-progress{color:#888;font-style:italic}.validation-result{padding:1rem;border-radius:6px;margin-top:.5rem}.validation-result.success{background-color:#4caf501a;border:1px solid rgba(76,175,80,.3)}.validation-result.warning{background-color:#ff98001a;border:1px solid rgba(255,152,0,.3)}.validation-result p{margin:.5rem 0}.validation-reason{background-color:#0000004d;padding:.75rem;border-radius:4px;white-space:pre-wrap;font-family:monospace;font-size:.9rem;color:#ccc;margin-top:.5rem;max-height:300px;overflow-y:auto}.validation-stage{margin:.75rem 0;padding:.75rem;border-radius:6px;border:1px solid}.validation-stage.stage-pass{background-color:#4caf501a;border-color:#4caf5066}.validation-stage.stage-fail{background-color:#f443361a;border-color:#f4433666}.validation-stage p{margin:.25rem 0}.validation-stage details{margin-top:.5rem}.validation-stage summary{cursor:pointer;color:#646cff;font-size:.9rem}.validation-stage summary:hover{text-decoration:underline}.validation-ref-images-display{margin-top:.5rem;padding:.5rem;background-color:#646cff1a;border-radius:4px;font-size:.9rem}.validation-ref-selector{margin-top:1.5rem;padding:1.5rem;background-color:#646cff0d;border:1px solid rgba(100,108,255,.2);border-radius:8px}.validation-ref-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin:1rem 0}.validation-ref-image-card{background-color:#ffffff0d;border:1px solid #444;border-radius:8px;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.validation-ref-thumb{width:100%;height:120px;object-fit:contain;background-color:#1a1a1a;border-radius:4px}.validation-ref-checkboxes{display:flex;flex-direction:column;gap:.25rem}.validation-ref-checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s}.validation-ref-checkbox-label:hover{background-color:#646cff1a}.validation-ref-checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.validation-ref-summary{margin-top:1rem;padding:.75rem;background-color:#646cff1a;border-radius:4px;border-left:3px solid #646cff}.validation-ref-summary p{margin:.25rem 0;font-size:.9rem}.validation-test-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #444}.validation-test-section h5{margin:0 0 .75rem;color:#646cff;font-size:.95rem}.validation-test-item{margin-bottom:.75rem}.validation-test-button{width:100%;padding:.5rem 1rem;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .3s}.validation-test-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 10px #667eea66}.validation-test-button:disabled{opacity:.6;cursor:not-allowed}.validation-test-button.result-pass{background:linear-gradient(135deg,#4caf50,#45a049)}.validation-test-button.result-fail{background:linear-gradient(135deg,#f44336,#d32f2f)}.validation-test-button.result-error{background:linear-gradient(135deg,#ff9800,#f57c00)}.validation-test-result{margin-top:.5rem;padding:.5rem;border-radius:4px;font-size:.85rem}.validation-test-result.pass{background-color:#4caf501a;border:1px solid rgba(76,175,80,.3);color:#4caf50}.validation-test-result.fail{background-color:#f443361a;border:1px solid rgba(244,67,54,.3);color:#f44336}.validation-reason-small{background-color:#0000004d;padding:.5rem;border-radius:4px;white-space:pre-wrap;font-family:monospace;font-size:.75rem;color:#ccc;margin-top:.25rem;max-height:200px;overflow-y:auto}.generated-images-section{margin-top:2rem;padding-top:2rem;border-top:2px solid #444}.generated-images-section h3{color:#646cff;margin-bottom:1.5rem}.generated-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2rem}.generated-image-card{display:flex;flex-direction:column;gap:.5rem;background-color:#ffffff0d;border:2px solid #444;border-radius:12px;padding:1rem}.generated-image-wrapper{position:relative;width:100%;border-radius:8px;overflow:hidden}.generated-image{width:100%;display:block;border-radius:8px;object-fit:contain;background-color:#0000004d}.download-icon{position:absolute;top:10px;right:10px;width:40px;height:40px;background-color:#000000b3;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;text-decoration:none;cursor:pointer;transition:all .3s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.download-icon:hover{background-color:#646cffe6;transform:scale(1.1)}.delete-icon{position:absolute;top:10px;right:60px;width:40px;height:40px;background-color:#000000b3;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:all .3s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.delete-icon:hover{background-color:#dc2626e6;transform:scale(1.1)}.image-label{text-align:center;font-size:.9rem;color:#fff9;margin:0}.download-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;background-color:#646cff;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s;text-align:center;text-decoration:none}.download-button:hover{background-color:#535bf2;transform:translateY(-2px);box-shadow:0 4px 12px #646cff66}.loading-images-section{padding:2rem;display:flex;justify-content:center;align-items:center}.spinner-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner-container p{color:#666;font-size:.95rem;margin:0}.spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:20px;height:20px;border-width:2px}.spinner.large{width:60px;height:60px;border-width:5px}@keyframes spin{to{transform:rotate(360deg)}}.button-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:8px;vertical-align:middle}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;justify-content:center;align-items:center;z-index:10;border-radius:inherit}.loading-card{min-height:200px;display:flex;justify-content:center;align-items:center;background:#f9f9f9;border-radius:8px;border:1px dashed #ddd}.global-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffd9;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;gap:1rem}.global-loading-overlay .spinner{width:50px;height:50px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.global-loading-overlay .loading-text{color:#555;font-size:1rem;font-weight:500;text-align:center}.sentence-text-input{width:100%;padding:.5rem;font-size:.95rem;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;resize:vertical;min-height:2.5rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}.sentence-text-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.sentence-text-input:hover{border-color:#b0b0b0}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2.5rem;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{margin:0 0 2rem;color:#333;text-align:center;font-size:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.95rem}.form-group input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:5px;font-size:1rem;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:5px;margin-bottom:1rem;text-align:center;font-size:.9rem}.login-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh}#root{max-width:1280px;margin:0 auto;padding:2rem}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}}
