*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1890ff;--primary-dark: #096dd9;--success: #52c41a;--warning: #faad14;--error: #ff4d4f;--text: #333;--text-secondary: #666;--border: #e8e8e8;--bg: #f5f7fa;--white: #fff}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Microsoft YaHei,sans-serif;background:#f5f7fa;min-height:100vh;padding-top:70px}.top-navbar{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#5eb3d6,#7ec8e3);box-shadow:0 2px 15px #5eb3d633;z-index:1000;transition:all .3s ease}.top-nav-container{max-width:1600px;margin:0 auto;padding:0 40px;display:flex;justify-content:space-between;align-items:center;min-height:70px}.top-nav-brand{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:#fff;flex:1}.top-logo{font-size:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.top-brand-name{font-size:22px;letter-spacing:.5px}.top-brand-subtitle{font-size:13px;font-weight:400;opacity:.95;margin-left:8px;padding-left:12px;border-left:1px solid rgba(255,255,255,.3);max-width:500px;line-height:1.4}.top-nav-links{display:flex;align-items:center;gap:35px}.top-nav-links a{text-decoration:none;color:#fff;font-weight:500;font-size:15px;transition:all .3s ease;position:relative;padding:5px 0;cursor:pointer}.top-nav-links a:hover{opacity:.8}.top-nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:#fff;transition:width .3s ease}.top-nav-links a:hover:after{width:100%}.container{max-width:1600px;margin:0 auto;padding:20px}header{text-align:center;background:linear-gradient(135deg,#1890ff,#36cfc9);color:#fff;margin:-20px -20px 20px;padding:30px 20px}header h1{font-size:2rem;margin-bottom:8px;font-weight:600}.subtitle{font-size:1rem;opacity:.9}main{display:grid;grid-template-columns:450px 1fr;gap:20px;min-height:calc(100vh - 140px)}@media (max-width: 1024px){main{grid-template-columns:1fr}}.panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .3s ease}.panel:hover{box-shadow:0 4px 16px #00000014}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0;flex-wrap:wrap;gap:8px;background:linear-gradient(to bottom,#fafbfc,#fff)}.panel-header h2{font-size:16px;font-weight:600;color:#333;margin:0}.actions{display:flex;gap:8px;flex-wrap:wrap}.btn{padding:8px 16px;border:1px solid #e8e8e8;border-radius:6px;cursor:pointer;font-size:14px;background:#fff;color:#333;transition:all .2s ease;display:inline-flex;align-items:center;gap:6px;font-weight:500}.btn:hover{background:#f5f7fa;border-color:#5eb3d6;color:#5eb3d6;transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#5eb3d6,#7ec8e3);border-color:transparent;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#4a9dc4,#6bb7d1);border-color:transparent;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #5eb3d64d}.btn-success{background:#52c41a;border-color:#52c41a;color:#fff}.btn-success:hover{background:#49b015;border-color:#49b015;color:#fff;transform:translateY(-1px)}#sqlInput{flex:1;width:100%;padding:20px;border:none;resize:none;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,Courier New,monospace;font-size:14px;line-height:1.6;outline:none;min-height:400px;background:#fafbfc;color:#333}#sqlInput::placeholder{color:#999}.diagram-container{flex:1;padding:20px;overflow:hidden;background:#fafbfc;display:flex;justify-content:center;align-items:center;position:relative}.diagram-wrapper{width:100%;height:100%;overflow:hidden;display:flex;justify-content:center;align-items:center;position:relative}#erCanvas{background:var(--white);box-shadow:0 1px 4px #0000001a;display:block}.panel-footer{padding:12px 20px;border-top:1px solid #f0f0f0;font-size:13px;color:#666;background:#fafbfc}.stats{display:flex;gap:24px;align-items:center}.stat-item{display:flex;align-items:center;gap:6px}.stat-item .label{color:#666;font-weight:500}.stat-item .value{color:#5eb3d6;font-weight:600;font-size:16px}footer{text-align:center;padding:30px 20px;color:#666;font-size:14px;background:#fff;margin-top:20px;border-radius:12px}.empty-state{color:#999;text-align:center;padding:60px 40px;font-size:15px}.toolbar{display:flex;gap:12px;padding:12px 20px;background:#fff;border-bottom:1px solid #f0f0f0;flex-wrap:wrap;align-items:center}.toolbar-group{display:flex;gap:6px;padding-right:16px;border-right:1px solid #e8e8e8;align-items:center}.toolbar-group:last-child{border-right:none}.toolbar .btn{padding:6px 12px;font-size:13px}.zoom-control{display:flex;align-items:center;gap:10px}.zoom-control input[type=range]{width:100px;cursor:pointer}.zoom-value{font-size:13px;color:#666;min-width:45px;font-weight:500}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000073;z-index:1000;justify-content:center;align-items:center}.modal.show{display:flex}.modal-content{background:#fff;border-radius:8px;width:520px;max-width:90%;max-height:80vh;overflow:hidden;box-shadow:0 4px 12px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px;font-weight:600;color:var(--text)}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:#999;padding:0;line-height:1}.modal-close:hover{color:var(--text)}.modal-tabs{display:flex;padding:0 20px;border-bottom:1px solid var(--border)}.tab-btn{padding:12px 16px;border:none;background:none;cursor:pointer;font-size:14px;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-body{padding:20px;max-height:45vh;overflow-y:auto}.tab-content{display:none}.tab-content.active{display:block}.setting-section{font-size:13px;color:var(--text-secondary);margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.setting-section:first-child{margin-top:0}.setting-row{display:flex;align-items:center;margin-bottom:12px}.setting-row label{width:80px;font-size:13px;color:var(--text);flex-shrink:0}.setting-row input[type=color]{width:36px;height:28px;border:1px solid var(--border);border-radius:4px;cursor:pointer;padding:2px}.setting-row select,.setting-row input[type=number]{flex:1;max-width:180px;padding:6px 10px;border:1px solid var(--border);border-radius:4px;font-size:13px;outline:none}.setting-row select:focus,.setting-row input:focus{border-color:var(--primary)}.setting-toggles{display:flex;flex-wrap:wrap;gap:10px}.toggle-item{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#f5f5f5;border-radius:16px;cursor:pointer;font-size:12px}.toggle-item input{display:none}.toggle-slider{width:32px;height:18px;background:#ccc;border-radius:9px;position:relative;transition:background .2s}.toggle-slider:after{content:"";position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .2s}.toggle-item input:checked+.toggle-slider{background:var(--primary)}.toggle-item input:checked+.toggle-slider:after{transform:translate(14px)}.btn-group{display:flex;border:1px solid var(--border);border-radius:4px;overflow:hidden}.layout-btn{padding:6px 16px;border:none;background:#fff;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:all .2s}.layout-btn.active{background:var(--primary);color:#fff}.layout-btn:not(:last-child){border-right:1px solid var(--border)}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border);background:#fafafa}.toast{position:fixed;top:80px;left:50%;transform:translate(-50%) translateY(-20px);background:#000000bf;color:#fff;padding:10px 20px;border-radius:4px;font-size:14px;opacity:0;transition:all .3s ease;z-index:2000}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.history-list{max-height:200px;overflow-y:auto}.history-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer}.history-item:hover{background:#f5f5f5}.history-item:last-child{border-bottom:none}.history-item .name{font-size:13px;color:var(--text)}.history-item .time{font-size:12px;color:var(--text-secondary)}.history-item .delete{color:var(--error);cursor:pointer;padding:2px 6px}.shortcut-list{display:flex;flex-direction:column;gap:12px}.shortcut-item{display:flex;align-items:center;gap:8px}.shortcut-item span{margin-left:auto;color:var(--text-secondary);font-size:13px}kbd{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:2px 8px;font-size:12px;font-family:monospace;box-shadow:0 1px 2px #0000001a}.template-list{display:flex;flex-direction:column;gap:8px}.template-item{padding:12px;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s}.template-item:hover{border-color:var(--primary);background:#f0f7ff}.template-item .name{font-weight:600;margin-bottom:4px}.template-item .desc{font-size:12px;color:var(--text-secondary)}body.dark-mode{--bg: #1a1a2e;--text: #e0e0e0;--text-secondary: #a0a0a0;--border: #333;--white: #242438}body.dark-mode header{background:linear-gradient(135deg,#1890ff,#0d6eaa)}body.dark-mode .panel{background:#242438}body.dark-mode #sqlInput{background:#1a1a2e;color:#e0e0e0}body.dark-mode .diagram-container{background:#1a1a2e}body.dark-mode #erCanvas,body.dark-mode .modal-content{background:#242438}body.dark-mode .btn{background:#333;border-color:#444;color:#e0e0e0}body.dark-mode .btn:hover{border-color:var(--primary)}body.dark-mode .toolbar,body.dark-mode .panel-footer{background:#1a1a2e}.fullscreen .diagram-panel{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;border-radius:0;margin:0}.fullscreen header,.fullscreen .editor-panel,.fullscreen footer{display:none}footer a{color:var(--primary);text-decoration:none}footer a:hover{text-decoration:underline}.watermark{position:absolute;bottom:10px;right:10px;font-size:11px;color:#ccc;pointer-events:none}.search-input{padding:6px 12px;border:1px solid #e8e8e8;border-radius:6px;font-size:13px;min-width:180px;outline:none;transition:all .2s ease}.search-input:focus{border-color:#5eb3d6;box-shadow:0 0 0 3px #5eb3d61a}.search-input::placeholder{color:#999}body.dark-mode .search-input{background:#333;border-color:#444;color:#e0e0e0}.table-view{margin-bottom:20px}.table-view h4{margin-bottom:10px;padding:8px 12px;background:var(--primary);color:#fff;border-radius:4px;font-size:14px}.table-view table{width:100%;border-collapse:collapse;font-size:13px}.table-view th,.table-view td{padding:8px 12px;border:1px solid var(--border);text-align:left}.table-view th{background:#f5f5f5;font-weight:600}.table-view .pk{color:var(--primary);font-weight:600}body.dark-mode .table-view th{background:#333}.dict-preview{margin-top:16px;padding:12px;background:#f9f9f9;border:1px solid var(--border);border-radius:4px;max-height:300px;overflow:auto;font-family:monospace;font-size:12px;white-space:pre-wrap}body.dark-mode .dict-preview{background:#1a1a2e}.highlight{background:#fff3cd;border:2px solid #ffc107!important}body.dark-mode .highlight{background:#5a4a00}.summary-result{margin-top:16px}.summary-item{margin-bottom:16px;padding:12px;background:#f9f9f9;border:1px solid var(--border);border-radius:6px}.summary-item .table-name{font-weight:600;color:var(--primary);margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}.summary-item .fields{font-size:14px;line-height:1.8;color:var(--text)}.summary-item .fields.pre-wrap{white-space:pre-wrap;font-family:Monaco,Menlo,Consolas,monospace;font-size:13px;line-height:1.6}.three-line-modal{width:950px!important;max-width:95%!important;max-height:90vh}.three-line-modal .modal-header{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.three-line-modal .modal-header h3{margin-right:auto}.modal-header-actions{display:flex;align-items:center;gap:10px}.preview-hint{font-size:12px;color:var(--text-secondary)}.three-line-body{padding:0!important;max-height:55vh!important;overflow:auto;background:#fff}.three-line-options{padding:12px 20px;border-top:1px solid var(--border);background:#fafafa}.three-line-visual-preview{padding:20px 30px;background:#fff}.three-line-table-wrapper{margin-bottom:30px}.three-line-table-title{text-align:center;font-size:14px;font-weight:600;margin-bottom:10px;color:var(--text)}.intro-text{text-indent:2em;line-height:1.8;margin:.8em 0;font-size:14px;color:var(--text)}.three-line-table{width:100%;border-collapse:collapse;font-size:13px;border-top:2px solid #000;border-bottom:2px solid #000}.three-line-table thead tr{border-bottom:1px solid #000}.three-line-table th{padding:10px 12px;text-align:center;font-weight:600;background:transparent;border:none}.three-line-table td{padding:8px 12px;text-align:center;border:none}.three-line-table tbody tr:hover{background:#f5f9ff}body.dark-mode .three-line-body,body.dark-mode .three-line-visual-preview{background:#242438}body.dark-mode .three-line-options{background:#1a1a2e}body.dark-mode .three-line-table,body.dark-mode .three-line-table thead tr{border-color:#e0e0e0}body.dark-mode .three-line-table-title{color:#e0e0e0}.summary-item .copy-btn{font-size:12px;padding:2px 8px;cursor:pointer;background:var(--primary);color:#fff;border:none;border-radius:4px}.summary-item .copy-btn:hover{opacity:.9}body.dark-mode .summary-item{background:#1a1a2e}.index-section{margin-top:16px;padding-top:12px;border-top:1px dashed var(--border)}.index-section h5{font-size:13px;color:var(--text-secondary);margin-bottom:10px}.index-table{width:100%;border-collapse:collapse;font-size:13px}.index-table th,.index-table td{padding:8px 12px;border:1px solid var(--border);text-align:left}.index-table th{background:#f0f7ff;font-weight:600}.index-type{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.index-type-primary{background:#e6f7ff;color:#1890ff;border:1px solid #91d5ff}.index-type-unique{background:#f6ffed;color:#52c41a;border:1px solid #b7eb8f}.index-type-index{background:#fff7e6;color:#fa8c16;border:1px solid #ffd591}.index-type-fulltext{background:#fff0f6;color:#eb2f96;border:1px solid #ffadd2}body.dark-mode .index-table th{background:#1a3a5c}body.dark-mode .index-type-primary{background:#112a45;border-color:#1890ff}body.dark-mode .index-type-unique{background:#162312;border-color:#52c41a}body.dark-mode .index-type-index{background:#2b1d11;border-color:#fa8c16}body.dark-mode .index-type-fulltext{background:#291321;border-color:#eb2f96}.test-case-modal{width:1000px!important;max-width:95%!important;max-height:90vh}.test-case-modal .modal-header{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.test-case-modal .modal-header h3{margin-right:auto}.test-case-body{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px!important;max-height:60vh!important;overflow:auto}.test-case-editor{display:flex;flex-direction:column;gap:16px}.test-case-form{background:#f5f7fa;padding:16px;border-radius:8px}.form-row{display:flex;align-items:center;margin-bottom:12px}.form-row:last-child{margin-bottom:0}.form-row label{width:80px;font-size:13px;color:var(--text);flex-shrink:0}.form-row input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:13px}.test-case-list{flex:1;overflow-y:auto;max-height:350px}.test-case-item{background:#fff;border:1px solid var(--border);border-radius:8px;padding:12px;margin-bottom:12px}.test-case-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.test-case-item-header span{font-weight:600;color:var(--primary)}.test-case-item-header button{background:none;border:none;color:var(--error);cursor:pointer;font-size:16px}.test-case-item textarea{width:100%;padding:8px;border:1px solid var(--border);border-radius:4px;font-size:12px;resize:vertical;min-height:60px;margin-bottom:8px}.test-case-item input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:4px;font-size:12px;margin-bottom:6px}.test-case-item label{font-size:11px;color:var(--text-secondary);display:block;margin-bottom:4px}.test-case-preview{display:flex;flex-direction:column}.test-case-preview h4{font-size:14px;margin-bottom:12px;color:var(--text)}.test-case-visual-preview{flex:1;background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;overflow:auto;max-height:400px}.test-case-table-wrapper{margin-bottom:20px}.test-case-table-title{text-align:center;font-size:14px;font-weight:600;margin-bottom:10px}.test-case-table{width:100%;border-collapse:collapse;font-size:12px;border-top:2px solid #000;border-bottom:2px solid #000}.test-case-table thead tr{border-bottom:1px solid #000}.test-case-table th{padding:10px 8px;text-align:center;font-weight:600;background:transparent;border:none}.test-case-table td{padding:8px;text-align:left;border:none;vertical-align:top}.test-case-table td:first-child{text-align:center;width:70px}body.dark-mode .test-case-form{background:#1a1a2e}body.dark-mode .test-case-item,body.dark-mode .test-case-visual-preview{background:#242438}body.dark-mode .test-case-table,body.dark-mode .test-case-table thead tr{border-color:#e0e0e0}@media (max-width: 800px){.test-case-body{grid-template-columns:1fr}}@media (max-width: 1200px){.top-brand-subtitle{display:none}}@media (max-width: 768px){.top-nav-container{padding:0 20px}.top-nav-links{gap:20px}.top-nav-links a{font-size:14px}.top-brand-name{font-size:18px}.top-logo{font-size:26px}}@media (max-width: 480px){.top-nav-links a:not(:first-child){display:none}.top-nav-links{gap:0}}
