*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;min-height:100vh;padding:20px}.container{max-width:1800px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;overflow:hidden}header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;text-align:center}header h1{font-size:2.5em;margin-bottom:10px;font-weight:700}.subtitle{font-size:1.1em;opacity:.9}.controls{display:flex;gap:20px;padding:20px 30px;background:#f8f9fa;border-bottom:1px solid #dee2e6;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:10px}.control-group label{font-weight:600;color:#495057}select{padding:8px 12px;border:1px solid #ced4da;border-radius:6px;background:#fff;font-size:14px;cursor:pointer;min-width:200px}select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}button{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}button:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}button:active{transform:translateY(0)}.editor-container{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:600px}.editor-panel,.preview-panel{padding:20px;display:flex;flex-direction:column}.editor-panel{border-right:1px solid #dee2e6}.editor-panel h2,.preview-panel h2{font-size:1.2em;margin-bottom:15px;color:#495057}#codeEditor{flex:1;width:100%;padding:15px;border:1px solid #ced4da;border-radius:6px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-size:14px;line-height:1.6;resize:vertical;background:#f8f9fa}#codeEditor:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}#highlightedOutput{flex:1;padding:15px;border:1px solid #ced4da;border-radius:6px;overflow:auto;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-size:14px;line-height:1.6;background:#1e1e1e;color:#d4d4d4}#highlightedOutput pre{margin:0;white-space:pre-wrap;word-wrap:break-word}.debug-panel{padding:20px 30px;background:#f8f9fa;border-top:2px solid #dee2e6;max-height:400px;overflow-y:auto}.debug-panel h2{font-size:1.2em;margin-bottom:15px;color:#495057}#debugOutput{font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-size:13px;line-height:1.8}.token-debug{margin:8px 0;padding:12px;background:#fff;border-radius:6px;border-left:4px solid #667eea}.token-debug-line{font-weight:600;color:#667eea;margin-bottom:8px}.token-info{display:grid;grid-template-columns:auto 1fr auto;gap:10px;padding:6px 0;border-bottom:1px solid #e9ecef}.token-info:last-child{border-bottom:none}.token-text{background:#e9ecef;padding:2px 8px;border-radius:4px;font-weight:600}.token-scopes{color:#6c757d;font-size:12px}.token-color{width:30px;height:20px;border-radius:4px;border:1px solid #dee2e6}#loadingStatus{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:30px 50px;border-radius:12px;box-shadow:0 10px 40px #0000004d;text-align:center;z-index:1000}#loadingStatus p{font-size:1.1em;color:#495057}#loadingStatus:after{content:"";display:block;width:40px;height:40px;margin:20px auto 0;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hidden{display:none!important}.token{cursor:help;position:relative}.token:hover{text-decoration:underline;text-decoration-style:dotted}.token-tooltip{position:fixed;display:none;background:#fff;border:1px solid #ced4da;border-radius:6px;padding:12px;box-shadow:0 4px 12px #00000026;z-index:10000;max-width:500px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:13px;line-height:1.5;pointer-events:none}.tooltip-section{margin-bottom:10px}.tooltip-section:last-child{margin-bottom:0}.tooltip-section strong{display:block;color:#495057;margin-bottom:4px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.tooltip-scopes{color:#6c757d;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:12px;background:#f8f9fa;padding:6px 8px;border-radius:4px;word-break:break-word}.tooltip-color-info{display:flex;align-items:center;gap:8px}.tooltip-color-box{width:24px;height:24px;border-radius:4px;border:1px solid #dee2e6;flex-shrink:0}.tooltip-color-info code{background:#f8f9fa;padding:4px 8px;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:12px;color:#495057}@media(max-width:1200px){.editor-container{grid-template-columns:1fr}.editor-panel{border-right:none;border-bottom:1px solid #dee2e6}}@media(max-width:768px){.controls{flex-direction:column;gap:15px}.control-group{width:100%;flex-direction:column;align-items:flex-start}select,button{width:100%}}
