*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#fbfbfa;color:#37352f;line-height:1.6;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.header{background:rgba(255,255,255,.95);border-bottom:1px solid #e9e9e7;padding:1rem 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.logo{font-size:1.5rem;font-weight:600;color:#37352f;letter-spacing:-.01em}.author-links{display:flex;gap:.5rem;align-items:center;margin-left:1rem}.author-link{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:#f1f1ef;border:1px solid #e9e9e7;color:#787774;text-decoration:none;transition:all .15s ease}.author-link:hover{background:#e9e9e7;color:#37352f;transform:translateY(-1px)}.github-link:hover{background:#37352f;color:#fff;border-color:#37352f}.twitter-link:hover{background:#1da1f2;color:#fff;border-color:#1da1f2}.header-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.api-config-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#2383e2;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000000d}.api-config-btn:hover{background:#1976d2;box-shadow:0 2px 4px #0000001a}.api-badge{background:rgba(255,255,255,.2);padding:.125rem .375rem;border-radius:4px;font-size:.75rem;font-weight:600}.status-indicator{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:#f7f6f3;border:1px solid #e9e9e7;border-radius:6px;font-size:.875rem;color:#787774}.status-dot{width:6px;height:6px;border-radius:50%}.status-connected{background:#0f7b0f}.status-error{background:#e03e3e}.status-checking{background:#f5b800}.main-content{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem;margin:2rem 0;align-items:start}.input-section,.text-result-section,.uml-result-section{min-height:400px;max-height:80vh;overflow-y:auto}.text-result-section .result-card{margin-bottom:0;max-height:none}.text-result-section .text-content{max-height:60vh;overflow-y:auto}.uml-result-section{max-width:100%;overflow-y:auto}.uml-result-section .result-card{margin-bottom:0;max-height:75vh;overflow-y:auto}.svg-container{text-align:center;margin-bottom:1rem;background:#fbfbfa;border-radius:6px;padding:1rem;overflow:auto;max-width:100%;max-height:60vh;position:relative}.svg-container.clickable{cursor:pointer;transition:all .2s ease}.svg-container.clickable:after{content:"🔍 点击放大";position:absolute;top:8px;right:8px;background:rgba(35,131,226,.9);color:#fff;padding:4px 8px;border-radius:4px;font-size:.7rem;opacity:0;transition:opacity .2s ease;pointer-events:none}.svg-container.clickable:hover:after{opacity:1}.svg-container.clickable:hover{background:#f1f1ef;transform:scale(1.02);box-shadow:0 2px 8px #0000001a}.svg-container svg{max-width:100%!important;max-height:55vh!important;height:auto!important;width:auto!important}.svg-container img{max-width:100%;max-height:55vh;object-fit:contain}.plantuml-container{background:white;border:1px solid #e9e9e7;border-radius:8px;padding:1rem;margin-bottom:1rem;transition:all .15s ease;max-width:100%;overflow:hidden}.card{background:white;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0f0f0f1a;border:1px solid #e9e9e7;transition:all .15s ease}.card:hover{box-shadow:0 2px 8px #0f0f0f26;transform:translateY(-1px)}.card-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:#37352f}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#37352f;margin-bottom:.5rem}.form-select,.form-textarea{width:100%;padding:.75rem;border:1px solid #e9e9e7;border-radius:6px;font-size:.875rem;background:white;color:#37352f;transition:all .15s ease}.form-select:focus,.form-textarea:focus{outline:none;border-color:#2383e2;box-shadow:0 0 0 2px #2383e21a}.form-textarea{resize:vertical;min-height:200px;font-family:inherit;line-height:1.5}.form-hint{margin-top:.5rem;font-size:.8rem;color:#787774}.diagram-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:.625rem}.diagram-type-item{display:flex;align-items:flex-start;gap:.625rem;padding:.625rem .75rem;border:1px solid #e9e9e7;border-radius:8px;background:#fbfbfa;cursor:pointer;transition:all .15s ease}.diagram-type-item:hover{border-color:#d9d9d6;background:#f7f6f3}.diagram-type-item.checked{border-color:#2383e2;background:rgba(35,131,226,.06)}.diagram-type-item input[type=checkbox]{margin-top:.2rem;accent-color:#2383e2}.diagram-type-text{display:flex;flex-direction:column;gap:.2rem}.diagram-type-label{font-size:.84rem;font-weight:600;line-height:1.3;color:#37352f}.diagram-type-description{font-size:.75rem;line-height:1.35;color:#787774}.btn-group{display:flex;gap:.75rem;margin-top:1rem}.btn-primary{flex:1;padding:.75rem 1.5rem;background:#2383e2;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000000d}.btn-primary:hover{background:#1976d2;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{padding:.75rem 1.5rem;background:white;color:#37352f;border:1px solid #e9e9e7;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-secondary:hover{background:#f7f6f3;border-color:#d9d9d6}.usage-guide{background:#f7f6f3;border-radius:8px;padding:1rem;margin-top:1rem;border-left:3px solid #2383e2}.usage-guide h3{color:#37352f;font-size:1rem;font-weight:600;margin-bottom:.75rem}.usage-guide ul{list-style:none;padding:0}.usage-guide li{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;color:#787774;font-size:.875rem}.usage-guide li:before{content:"•";color:#2383e2;font-weight:700;margin-top:.125rem}.getting-started{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:400px;background:#f7f6f3;border-radius:8px;border:1px solid #e9e9e7;padding:2rem}.getting-started h2{font-size:1.5rem;font-weight:600;color:#37352f;margin-bottom:.75rem}.getting-started p{color:#787774;font-size:1rem;max-width:300px;line-height:1.5}.getting-started-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.result-content{background:white;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0f0f0f1a;border:1px solid #e9e9e7}.result-section{margin-bottom:1.5rem}.section-title{font-size:1.125rem;font-weight:600;color:#37352f;margin-bottom:.75rem;padding-bottom:.375rem;border-bottom:1px solid #e9e9e7}.text-content{background:#f7f6f3;border-radius:6px;padding:1rem;font-size:.875rem;line-height:1.6;color:#37352f;border-left:3px solid #2383e2}.footer{background:white;border-top:1px solid #e9e9e7;padding:2rem 0;margin-top:4rem}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-info{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#787774}.footer-link{display:inline-flex;align-items:center;gap:.375rem;color:#2383e2;text-decoration:none;font-weight:500;transition:all .15s ease;padding:.125rem .25rem;border-radius:4px}.footer-link:hover{background:#f1f1ef;color:#1976d2}.footer-tech{font-size:.875rem;color:#787774}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,15,15,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:white;border-radius:8px;padding:1.5rem;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 4px 12px #0f0f0f26;border:1px solid #e9e9e7}@media (max-width: 1200px){.main-content{grid-template-columns:1fr 1fr;gap:1.5rem}.uml-result-section{grid-column:1 / -1;margin-top:1rem}.svg-container svg{max-height:50vh!important}}.preview-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease;overflow:hidden}body.modal-open{overflow:hidden}.preview-modal{background:white;border-radius:12px;max-width:95vw;max-height:95vh;width:auto;height:auto;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006;overflow:hidden;animation:scaleIn .2s ease;margin:2rem}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e9e9e7;background:#fbfbfa;flex-shrink:0}.preview-header h3{color:#37352f;font-size:1.125rem;font-weight:600;margin:0}.preview-content{flex:1;padding:1rem;overflow:auto;background:white;display:flex;align-items:center;justify-content:center;min-height:0}.preview-svg-container{text-align:center;max-width:100%;max-height:100%;overflow:auto;display:flex;align-items:center;justify-content:center}.preview-svg-container svg{max-width:85vw!important;max-height:70vh!important;height:auto!important;width:auto!important;object-fit:contain}.preview-footer{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e9e9e7;background:#fbfbfa;justify-content:center;flex-shrink:0;flex-wrap:wrap}.preview-footer .btn{padding:.75rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;min-width:100px;justify-content:center;white-space:nowrap}.preview-footer .btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 968px){.main-content{grid-template-columns:1fr;gap:1.5rem}.uml-result-section{grid-column:auto;margin-top:0}.svg-container svg{max-height:40vh!important}.svg-container{padding:.75rem;max-height:45vh}}@media (max-width: 768px){.container{padding:0 1rem}.header{padding:.75rem 0}.header-content{flex-direction:column;gap:.75rem;align-items:stretch}.header-actions{justify-content:center;flex-wrap:wrap}.btn-group{flex-direction:column}.modal{width:95%;margin:1rem}.author-links{margin-left:0;justify-content:center}.footer-content{flex-direction:column;gap:.75rem;text-align:center}.logo{font-size:1.375rem}.card{padding:1.25rem}.diagram-type-grid{grid-template-columns:1fr}.getting-started{min-height:300px;padding:1.5rem}}.streaming-cursor{display:inline-block;animation:blink 1s infinite;color:#2383e2;font-weight:700}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.loading-spinner{width:16px;height:16px;border:2px solid #e9e9e7;border-radius:50%;border-top-color:#2383e2;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.provider-warning{color:#e03e3e;font-size:.8rem;margin-top:.5rem;padding:.5rem;background:#fdf2f2;border-radius:6px;border-left:3px solid #e03e3e}.streaming-content{background:#f7f6f3;border-radius:6px;padding:1rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.8rem;line-height:1.5;color:#37352f;border-left:3px solid #2383e2;white-space:pre-wrap;word-break:break-word}.plantuml-renderer{margin-top:1rem}.plantuml-container{background:white;border:1px solid #e9e9e7;border-radius:8px;padding:1.5rem;margin-bottom:1rem;transition:all .15s ease}.plantuml-container:hover{box-shadow:0 2px 8px #0f0f0f26}.svg-container{text-align:center;margin-bottom:1rem;background:#fbfbfa;border-radius:6px;padding:1rem;overflow:auto}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:1rem}.action-buttons .btn{padding:.375rem .625rem;border:none;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;white-space:nowrap}.btn-primary{background:#2383e2;color:#fff}.btn-primary:hover{background:#1976d2}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-success{background:#0f7b0f;color:#fff}.btn-success:hover{background:#0d6a0d}.btn-info{background:#17a2b8;color:#fff}.btn-info:hover{background:#138496}.btn-warning{background:#f5b800;color:#fff}.btn-warning:hover{background:#d39e00}.code-details{margin-top:1rem}.code-details summary{cursor:pointer;font-weight:600;color:#37352f;padding:.5rem 0}.code-content{font-size:.75rem;overflow:auto;background:#f7f6f3;padding:1rem;border-radius:6px;margin-top:.5rem;border-left:3px solid #2383e2;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;line-height:1.4;color:#37352f}.edit-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,15,15,.5);display:flex;align-items:center;justify-content:center;z-index:1001}.edit-modal{background:white;border-radius:8px;width:90%;max-width:800px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 4px 12px #0f0f0f26;border:1px solid #e9e9e7}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e9e9e7}.modal-header h3{color:#37352f;font-size:1.125rem;font-weight:600;margin:0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#787774;padding:0;width:30px;height:30px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.close-btn:hover{background:#f1f1ef;color:#37352f}.modal-body{padding:1rem 1.5rem;flex:1;overflow:hidden}.code-editor{width:100%;height:400px;border:1px solid #e9e9e7;border-radius:6px;padding:1rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.875rem;line-height:1.5;background:#fbfbfa;color:#37352f;resize:none;outline:none;transition:all .15s ease}.code-editor:focus{border-color:#2383e2;box-shadow:0 0 0 2px #2383e21a}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e9e9e7}.plantuml-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;background:#f7f6f3;border:1px solid #e9e9e7;border-radius:8px;margin-bottom:1rem;color:#787774}.plantuml-error{border:1px solid #e03e3e;border-radius:8px;padding:1rem;background:#fdf2f2;margin-bottom:1rem}.error-message{color:#e03e3e;margin:0 0 .75rem;font-weight:500}.fallback-message{color:#787774;margin:0 0 1rem;font-size:.875rem}.plantuml-no-content{padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;color:#856404;text-align:center}@media (max-width: 768px){.edit-modal{width:95%;margin:1rem}.modal-body,.modal-header,.modal-footer{padding:1rem}.code-editor{height:300px;font-size:.8rem}.action-buttons{justify-content:flex-start}.action-buttons .btn{font-size:.75rem;padding:.375rem .625rem}.svg-container{padding:.5rem}.plantuml-container{padding:1rem}}.modal-overlay .modal{border-radius:20px!important;overflow-y:auto!important;max-height:90vh!important;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff0d!important}.modal-overlay .modal::-webkit-scrollbar{width:8px!important;display:block!important}.modal-overlay .modal::-webkit-scrollbar-track{background:rgba(241,240,238,.5)!important;border-radius:4px!important}.modal-overlay .modal::-webkit-scrollbar-thumb{background:rgba(155,154,151,.6)!important;border-radius:4px!important}.modal-overlay .modal::-webkit-scrollbar-thumb:hover{background:rgba(155,154,151,.8)!important}.modal-overlay .modal-header{background:linear-gradient(135deg,#fbfbfa 0%,#f8f8f7 100%)!important;padding:2rem!important;position:sticky!important;top:0!important;z-index:10!important}.modal-overlay .modal-title{font-size:1.375rem!important;font-weight:700!important;letter-spacing:-.025em!important}.modal-overlay .api-provider{background:linear-gradient(135deg,#ffffff 0%,#fefefe 100%)!important;border-radius:16px!important;padding:2rem!important;margin-bottom:1.25rem!important;transition:all .3s cubic-bezier(.16,1,.3,1)!important}.modal-overlay .api-provider:hover{transform:translateY(-2px)!important;box-shadow:0 8px 25px #0000001a!important}.modal-overlay .api-input,.modal-overlay .model-select{border-radius:12px!important;padding:1rem!important;transition:all .2s cubic-bezier(.16,1,.3,1)!important}.modal-overlay .api-input:focus,.modal-overlay .model-select:focus{transform:translateY(-1px)!important;box-shadow:0 0 0 4px #2383e21a!important}.modal-overlay .btn-primary{background:linear-gradient(135deg,#2383e2 0%,#1976d2 100%)!important;border-radius:12px!important;padding:1rem 2rem!important}.modal-overlay .btn-primary:hover{transform:translateY(-2px) scale(1.02)!important}.modal-overlay .modal>div:not(.modal-header){padding:0 2.5rem 2.5rem!important;overflow:visible!important}
