.visualizer-container{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:#fff;color:#2c3e50;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,0.1);overflow:hidden}.control-bar{background:#f8f9fa;border-bottom:1px solid #dee2e6;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.controls-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.controls-right{display:flex;align-items:center}.nav-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.controls-left label,.nav-controls label{font-weight:600;color:#495057;white-space:nowrap}.controls-left select,.nav-controls select{padding:4px 8px;border:1px solid #ced4da;border-radius:4px;background:#fff;color:#2c3e50;font-size:14px;min-width:80px}.controls-left select option,.nav-controls select option{background:#fff;color:#2c3e50}html[data-theme="dark"] .visualizer-container .controls-left select,html[data-theme="dark"] .visualizer-container .nav-controls select{background:var(--global-card-bg-color,#212529);color:var(--global-text-color,#e9ecef);border-color:var(--global-divider-color,#495057)}html[data-theme="dark"] .visualizer-container .controls-left select option,html[data-theme="dark"] .visualizer-container .nav-controls select option{background:var(--global-card-bg-color,#212529);color:var(--global-text-color,#e9ecef)}html[data-theme="dark"] .visualizer-container .controls-left label,html[data-theme="dark"] .visualizer-container .nav-controls label{color:var(--global-text-color-light,#adb5bd)}.performance-indicator{font-weight:600;color:#6c757d;font-size:14px}.status{font-size:14px;font-weight:500}.status.success{color:#28a745}.status.error{color:#dc3545}.status.info{color:#6c757d}.btn{padding:6px 12px;border:1px solid transparent;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;display:inline-block;white-space:nowrap}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,0.1)}.btn:active{transform:translateY(0)}.btn-primary{background:#007bff;color:white;border-color:#007bff}.btn-primary:hover{background:#0056b3;border-color:#0056b3}.btn-secondary{background:#6c757d;color:white;border-color:#6c757d}.btn-secondary:hover{background:#545b62;border-color:#545b62}.btn-success{background:#28a745;color:white;border-color:#28a745}.btn-success:hover{background:#1e7e34;border-color:#1e7e34}.btn-info{background:#17a2b8;color:white;border-color:#17a2b8}.btn-info:hover{background:#138496;border-color:#138496}.btn-danger{background:#dc3545;color:white;border-color:#dc3545}.btn-danger:hover{background:#c82333;border-color:#c82333}.btn-warning{background:#ffc107;color:#212529;border-color:#ffc107}.btn-warning:hover{background:#e0a800;border-color:#e0a800}.btn-star{background:#ff9800;color:white;border-color:#ff9800}.btn-star:hover{background:#e68900;border-color:#e68900}.btn.active{box-shadow:inset 0 2px 4px rgba(0,0,0,0.2);transform:none}.main-content{display:flex;min-height:720px;height:78vh}.left-panel{flex:1;padding:16px;border-right:1px solid #dee2e6;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.right-panel{flex:2;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.panel{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:12px;box-shadow:0 1px 3px rgba(0,0,0,0.05)}.panel h3{margin:0 0 12px 0;font-size:16px;font-weight:600;color:#495057;border-bottom:1px solid #dee2e6;padding-bottom:8px}.text-content{background:white;border:1px solid #ced4da;border-radius:4px;padding:12px;font-size:14px;line-height:1.5;max-height:200px;overflow-y:auto;white-space:pre-wrap;word-wrap:break-word}.grid-container{background:white;border:1px solid #ced4da;border-radius:4px;padding:8px;display:flex;justify-content:center;align-items:center;min-height:100px;overflow:auto}.grid-container canvas{border:1px solid #dee2e6;border-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,0.1)}.no-data{color:#6c757d;font-style:italic;text-align:center;padding:20px}.demos-container{display:flex;gap:12px;overflow-x:auto;padding:8px 0}.demo-item{background:white;border:1px solid #dee2e6;border-radius:6px;padding:8px;min-width:120px;flex-shrink:0;box-shadow:0 1px 3px rgba(0,0,0,0.05)}.demo-title{font-size:12px;font-weight:600;color:#495057;margin-bottom:8px;text-align:center}.demo-input,.demo-output{display:flex;justify-content:center;margin-bottom:4px}.demo-item canvas{border:1px solid #dee2e6;border-radius:2px}.grids-row{display:flex;gap:16px}.grids-row .panel{flex:1}.rule-status-panel{background:white;border:1px solid #ced4da;border-radius:4px;padding:12px}.rule-status-content{font-size:14px;line-height:1.5}.status-item{margin-bottom:8px;padding:6px 8px;background:#f8f9fa;border-radius:4px;border-left:3px solid #007bff}
.status-item:last-child{margin-bottom:0}.status-item strong{color:#495057;margin-right:8px}.no-status{color:#6c757d;font-style:italic;text-align:center;padding:20px}@media(max-width:1200px){.main-content{flex-direction:column;height:auto}.left-panel,.right-panel{flex:none}.left-panel{border-right:0;border-bottom:1px solid #dee2e6}}@media(max-width:768px){.control-bar{flex-direction:column;align-items:stretch}.controls-left,.controls-right{justify-content:center}.nav-controls{justify-content:center}.validation-buttons{justify-content:center}.validation-buttons .btn{min-width:100px}.grids-row{flex-direction:column}}@media(max-width:480px){.visualizer-container{margin:0;border-radius:0}.control-bar{padding:8px}.main-content{padding:8px}.panel{padding:8px}.btn{font-size:12px;padding:4px 8px}.validation-buttons .btn{font-size:10px;padding:3px 6px;min-width:80px}}@media(prefers-color-scheme:dark){.visualizer-container{background:#2d2d2d;color:#fff}.control-bar{background:#404040;border-bottom-color:#555}.panel{background:#404040;border-color:#555}.panel h3{color:#fff;border-bottom-color:#555}.text-content{background:#2d2d2d;border-color:#555;color:#fff}.grid-container{background:#2d2d2d;border-color:#555}.rule-status-panel{background:#2d2d2d;border-color:#555}.status-item{background:#404040;border-left-color:#007bff}.status-item strong{color:#fff}.no-status{color:#aaa}.demo-item{background:#2d2d2d;border-color:#555}.no-data{color:#aaa}}