*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#e9ecef;color:#212529}code{font-family:Courier New,Consolas,Monaco,monospace}#root{width:100%;height:100vh}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.app{display:flex;flex-direction:column;height:100vh;background:#e9ecef}.app-header{background:linear-gradient(135deg,#06c,#0052a3);color:#fff;padding:20px 30px;box-shadow:0 2px 8px #00000026}.app-header h1{margin:0 0 5px;font-size:1.8em;font-weight:700}.app-header p{margin:0;opacity:.9;font-size:1em}.app-layout{display:flex;flex:1;overflow:hidden}.sidebar{width:30%;background:#f8f9fa;border-right:1px solid #dee2e6;overflow-y:auto}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.editor-section{height:40%;min-height:200px;padding:20px 20px 10px}.results-section{flex:1;padding:10px 20px 20px;overflow:hidden}.sql-logo,.exeter-logo{height:40px;margin-left:15px;vertical-align:middle}.in-row{display:flex;align-items:center}.help-button{position:fixed;bottom:30px;right:30px;background:linear-gradient(135deg,#06c,#0052a3);color:#fff;border:none;border-radius:50px;padding:15px 25px;font-size:1em;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #06c6;z-index:998;transition:all .3s ease;display:flex;align-items:center;gap:8px}.help-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0066cc80;background:linear-gradient(135deg,#0052a3,#003d7a)}.help-button:active{transform:translateY(0)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:2em;cursor:pointer;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.modal-close:hover{background:#f0f0f0;color:#333}.modal-header{padding:30px 30px 20px;border-bottom:2px solid #e9ecef;background-color:#06c;text-align:center}.modal-logo{height:80px;margin-bottom:15px}.modal-header h2{margin:0;color:#fff;font-size:1.8em}.modal-body{padding:30px;line-height:1.6;color:#333}.modal-body h3{color:#06c;margin-top:0;margin-bottom:10px;font-size:1.2em;border-bottom:1px solid #e9ecef;padding-bottom:5px}.modal-body h3:not(:first-child){margin-top:25px}.modal-body p{margin:10px 0}.modal-body strong{color:#0052a3}@media(max-width:1024px){.app-layout{flex-direction:column}.sidebar{width:100%;height:300px;border-right:none;border-bottom:1px solid #dee2e6}.editor-section{height:300px}}.tables-panel{padding:20px;background:#f8f9fa;overflow-y:auto;max-height:100vh}.tables-panel h2{margin-top:0;color:#333;font-size:1.4em;margin-bottom:20px}.table-display{margin-bottom:30px;background:#fff;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000001a}.table-display h3{margin:0 0 10px;color:#06c;font-size:1.1em;font-family:Courier New,monospace}.table-wrapper{overflow-x:auto}.table-display table{width:100%;border-collapse:collapse;font-size:.9em}.table-display th{background:#06c;color:#fff;padding:8px 12px;text-align:left;font-weight:600;border:1px solid #0052a3}.table-display td{padding:6px 12px;border:1px solid #ddd}.table-display tbody tr:nth-child(2n){background:#f8f9fa}.table-display tbody tr:hover{background:#e9ecef}.query-editor{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-bottom:2px solid #dee2e6}.editor-header h2{margin:0;color:#333;font-size:1.3em}.button-group{display:flex;gap:10px}.btn{padding:10px 20px;border:none;border-radius:5px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#28a745;color:#fff}.btn-primary:hover:not(:disabled){background:#218838;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.query-editor textarea{flex:1;padding:20px;border:none;font-family:Courier New,Consolas,monospace;font-size:1em;line-height:1.6;resize:none;outline:none;background:#fff}.query-editor textarea::placeholder{color:#adb5bd}.results-panel{padding:20px;background:#fff;overflow-y:auto;height:100%}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.results-panel h2{margin:0;color:#333;font-size:1.4em}.row-count{background:#06c;color:#fff;padding:6px 12px;border-radius:4px;font-weight:600;font-size:.9em}.no-results{padding:40px;text-align:center;color:#6c757d;font-size:1.1em;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.error-display{background:#fff5f5;border:2px solid #e53e3e;border-radius:8px;padding:20px}.error-code{font-family:Courier New,monospace;font-weight:700;color:#c53030;font-size:1em;margin-bottom:10px}.error-message{color:#742a2a;font-size:1.1em;line-height:1.5;margin-bottom:10px}.error-position{color:#c53030;font-size:.9em;font-family:Courier New,monospace}.results-wrapper{overflow:auto;max-height:calc(100vh - 200px);border-radius:8px;box-shadow:0 2px 4px #0000001a}.results-table{width:100%;border-collapse:collapse;font-size:.95em}.results-table th{background:#06c;color:#fff;padding:12px 15px;text-align:left;font-weight:600;position:sticky;top:0;border:1px solid #0052a3;z-index:10}.results-table td{padding:10px 15px;border:1px solid #dee2e6}.results-table tbody tr:nth-child(2n){background:#f8f9fa}.results-table tbody tr:hover{background:#e9ecef}.drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}.guide-drawer{position:fixed;top:0;right:-50%;width:50%;height:100vh;background:#fff;box-shadow:-2px 0 8px #00000026;z-index:1000;transition:right .3s ease;display:flex;flex-direction:column}.guide-drawer.open{right:0}.drawer-header{padding:20px 25px;border-bottom:2px solid #e9ecef;background:linear-gradient(135deg,#06c,#0052a3);color:#fff;display:flex;justify-content:space-between;align-items:center}.drawer-header h2{margin:0;font-size:1.5em;font-weight:600}.drawer-close-btn{background:none;border:none;color:#fff;font-size:2em;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.drawer-close-btn:hover{background:#fff3}.drawer-content{flex:1;overflow-y:auto;padding:25px;line-height:1.6}.drawer-content section{margin-bottom:30px}.drawer-content h3{color:#06c;font-size:1.3em;margin-top:0;margin-bottom:15px;border-bottom:2px solid #e9ecef;padding-bottom:8px}.drawer-content h4{color:#0052a3;font-size:1.1em;margin-top:20px;margin-bottom:10px}.drawer-content p{margin:10px 0;color:#333}.drawer-content ul,.drawer-content ol{margin:10px 0;padding-left:25px}.drawer-content li{margin:8px 0}.drawer-content code{background:#f0f0f0;padding:2px 6px;border-radius:3px;font-family:Consolas,Monaco,monospace;font-size:.9em;color:#d63384}.code-block{background:#f8f9fa;border:1px solid #dee2e6;border-left:4px solid #0066cc;padding:15px;border-radius:4px;overflow-x:auto;font-family:Consolas,Monaco,monospace;font-size:.9em;line-height:1.5;margin:10px 0}.rule-box{border-radius:8px;padding:15px;margin:15px 0}.rule-box.do{background:#d1f4e0;border-left:4px solid #28a745}.rule-box.dont{background:#f8d7da;border-left:4px solid #dc3545}.rule-box strong{display:block;margin-bottom:10px;font-size:1.05em}.rule-box ul{margin:5px 0;padding-left:20px}.example{background:#f8f9fa;border-radius:8px;padding:15px;margin:15px 0}.example p{margin:0 0 10px;font-weight:500}.error-example{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:15px;margin:15px 0}.error-example p{margin:10px 0 5px;font-weight:500}.footer{text-align:center;padding:20px;background:#f8f9fa;border-top:2px solid #e9ecef;margin-top:20px}.footer p{margin:0;font-size:1.1em;color:#06c}.drawer-content::-webkit-scrollbar{width:8px}.drawer-content::-webkit-scrollbar-track{background:#f1f1f1}.drawer-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.drawer-content::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:768px){.guide-drawer{width:100%;right:-100%}}
