*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Microsoft YaHei,sans-serif;overflow:hidden;background:#1a1a2e}#ad-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);display:flex;align-items:center;justify-content:center;padding:20px}#ad-overlay.ad-overlay-hidden{pointer-events:none;opacity:0;transition:opacity .4s ease-out}.ad-overlay-inner{max-width:520px;width:100%;background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:28px 32px;box-shadow:0 20px 60px #0006}.ad-title{font-size:26px;color:#e8f4fc;margin-bottom:6px;text-align:center}.ad-subtitle{font-size:14px;color:#8ab4d4;text-align:center;margin-bottom:20px}.ad-content{color:#c8dce8;font-size:14px;line-height:1.65;margin-bottom:20px}.ad-content p{margin-bottom:10px}.ad-content p:last-child{margin-bottom:0}.ad-copyright{margin-top:12px;font-size:12px;color:#8ab4d4}.ad-link{display:inline-block;margin-bottom:16px;padding:10px 20px;background:#3d5a80;color:#fff;text-decoration:none;border-radius:8px;font-size:14px;transition:background .2s}.ad-link:hover{background:#4d6a90}.ad-bottom-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px;margin-top:8px}.ad-countdown{font-size:13px;color:#7a9bb8;text-align:center;margin:0}#ad-countdown-num{font-weight:700;color:#8ab4d4}.ad-enter-wrap{text-align:center}.ad-enter-btn{display:inline-block;padding:12px 28px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#3d5a80,#5a7a9e);border:none;border-radius:10px;cursor:pointer;box-shadow:0 4px 14px #3d5a8066;transition:transform .15s,box-shadow .2s}a.ad-enter-btn{text-decoration:none}a.ad-enter-btn:hover{color:#fff}.ad-enter-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3d5a8080}.ad-enter-btn:active{transform:translateY(0)}#layout.main-hidden{visibility:hidden;position:fixed;top:0;right:0;bottom:0;left:0}#layout{display:flex;width:100vw;height:100vh}#sidebar{width:50%;display:flex;flex-direction:column;background:#1a1a2e;border-right:1px solid #333;overflow:hidden}#ui{flex:1;display:flex;flex-direction:column;padding:12px 14px;color:#eee;overflow:hidden}#canvas-wrap{flex:1;position:relative;min-width:0}#canvas-wrap canvas{display:block;width:100%;height:100%}.controls{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:6px}.controls label{display:flex;align-items:center;gap:6px}.controls input[type=number]{width:72px;min-width:72px;padding:6px 8px;border:1px solid #444;border-radius:6px;background:#2a2a3e;color:#eee;font-size:14px;box-sizing:border-box;-moz-appearance:textfield}.controls input[type=number]::-webkit-outer-spin-button,.controls input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.controls button{padding:8px 16px;border:none;border-radius:8px;background:#3d5a80;color:#fff;font-size:14px;cursor:pointer;transition:background .2s}.controls button:hover:not(:disabled){background:#4d6a90}.controls button:disabled{opacity:.6;cursor:not-allowed}.rotation-style{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px}.rotation-style .move-label{margin-right:4px}.rotation-mode{padding:6px 10px;border:none;border-radius:6px;background:#2a3a4e;color:#eee;font-size:13px;cursor:pointer}.rotation-mode:hover{background:#3d5a80}.rotation-mode.active{background:#3d5a80;font-weight:600}.move-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:8px}.move-label{font-size:13px;margin-right:4px;opacity:.9}.move-label-block{width:100%;margin-top:6px;margin-bottom:2px}.move-buttons button{padding:6px 10px;border:none;border-radius:6px;background:#2a3a4e;color:#eee;font-size:13px;cursor:pointer;transition:background .2s}.move-buttons button:hover:not(:disabled){background:#3d5a80}.move-buttons button:disabled{opacity:.6;cursor:not-allowed}.move-buttons button small{display:block;font-size:10px;opacity:.85;margin-top:1px}.formula-section{flex:1;display:flex;flex-direction:column;min-height:120px;margin-top:8px;border:1px solid #444;border-radius:8px;background:#0f0f1a;overflow:hidden}.formula-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;font-size:13px;background:#252535;border-bottom:1px solid #444}.formula-header span{font-weight:600}.formula-actions{display:flex;gap:8px;align-items:center}.formula-actions button{padding:4px 10px;border:none;border-radius:4px;background:#3d5a80;color:#fff;font-size:12px;cursor:pointer}.formula-actions button:hover{background:#4d6a90}#formulaOutput{flex:1;margin:0;padding:10px 12px;font-size:13px;font-family:inherit;line-height:1.6;color:#b8d4e8;background:#0f0f1a;border:none;resize:vertical;min-height:2.8em;outline:none}#formulaOutput::placeholder{color:#666}.cube-projection-wrap{margin-top:8px;padding:8px 10px;border:1px solid #444;border-radius:8px;background:#0f0f1a;display:flex;flex-direction:column;align-items:center;gap:4px}.cube-projection-title{font-size:12px;font-weight:600;color:#8ab4d4;margin:0 0 4px}.cube-projection-row{display:flex;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:6px;overflow-x:auto;width:100%}.cube-projection-face{display:flex;flex-direction:column;align-items:center;gap:2px}.cube-projection-face-title{font-size:10px;color:#6a8aaa;font-weight:600}.cube-projection-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:1px;width:48px;height:48px}.cube-projection-cell{width:100%;height:100%;min-width:0;min-height:0;border-radius:1px;background:#333}.block-list-section{margin-top:8px;border:1px solid #444;border-radius:8px;background:#0f0f1a;overflow:hidden;display:flex;flex-direction:column;min-height:0;flex:0 0 auto;max-height:180px}.block-list-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;padding:6px 10px;font-size:12px;font-weight:600;background:#252535;border-bottom:1px solid #444}.block-list-header-title{margin-right:4px;color:#e8f4fc}.block-list-header-opt{display:inline-flex;align-items:center;gap:4px;color:#c8dce8;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:400}.block-list-header-opt input[type=checkbox]{cursor:pointer}.block-list-header input[type=color]{width:24px;height:20px;padding:0;border:1px solid #444;border-radius:3px;cursor:pointer;background:#1a1a2e;vertical-align:middle}.block-list-header input[type=color]::-webkit-color-swatch-wrapper{padding:1px}.block-list-header button{margin-left:auto;padding:4px 10px;border:none;border-radius:4px;background:#3d5a80;color:#fff;font-size:12px;cursor:pointer}.block-list-header button:hover{background:#4d6a90}.block-list-items{flex:1;min-height:0;overflow:auto;padding:6px 8px;display:grid;grid-template-columns:repeat(6,1fr);gap:4px;align-content:start}.block-list-item{font-size:11px;padding:4px 6px;border-radius:4px;cursor:pointer;background:#1a1a2e;border:1px solid #333;color:#b8d4e8}.block-list-item:hover{background:#2a2a3e;border-color:#3d5a80}.block-list-item.selected{border-color:#5a9fd4;background:#2a3a4e;box-shadow:0 0 0 1px #5a9fd4}.block-list-item .block-coord{display:block;font-weight:600;color:#8ab4d4;margin-bottom:2px}.block-list-item .block-colors{display:block;opacity:.9}#status{font-size:12px;opacity:.9;margin-top:8px;flex-shrink:0}.btn-about{margin-bottom:10px;padding:6px 14px;font-size:13px;color:#8ab4d4;background:transparent;border:1px solid #3d5a80;border-radius:6px;cursor:pointer;transition:background .2s,color .2s}.btn-about:hover{background:#2a3a4e;color:#b8d4e8}.about-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}.about-modal-mask.about-modal-visible{opacity:1;visibility:visible}.about-modal-box{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.15);border-radius:12px;max-width:480px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.about-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.1)}.about-modal-title{font-size:18px;color:#e8f4fc;margin:0}.about-modal-close{width:32px;height:32px;padding:0;font-size:22px;line-height:1;color:#8ab4d4;background:none;border:none;cursor:pointer;border-radius:4px;transition:color .2s,background .2s}.about-modal-close:hover{color:#fff;background:#ffffff1a}.about-modal-body{padding:18px;overflow:auto;color:#c8dce8;font-size:14px;line-height:1.6}.about-modal-subtitle{color:#8ab4d4;margin-bottom:12px;font-size:13px}.about-modal-intro p{margin-bottom:8px}.about-modal-contact{margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.1)}.about-modal-contact p{margin-bottom:6px}.about-modal-contact a{color:#5a9fd4;text-decoration:none}.about-modal-contact a:hover{text-decoration:underline}.about-modal-copyright{margin-top:12px;font-size:12px;color:#6a8aaa}.about-modal-link{display:inline-block;margin-top:14px;padding:8px 16px;background:#3d5a80;color:#fff;text-decoration:none;border-radius:6px;font-size:13px;transition:background .2s}.about-modal-link:hover{background:#4d6a90}.formula-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}.formula-modal-mask.formula-modal-visible{opacity:1;visibility:visible}.formula-modal-box{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.15);border-radius:12px;max-width:720px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.formula-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.1)}.formula-modal-title{font-size:18px;color:#e8f4fc;margin:0}.formula-modal-close{width:32px;height:32px;padding:0;font-size:22px;line-height:1;color:#8ab4d4;background:none;border:none;cursor:pointer;border-radius:4px;transition:color .2s,background .2s}.formula-modal-close:hover{color:#fff;background:#ffffff1a}.formula-modal-main{display:flex;flex:1;min-height:0;overflow:hidden}.formula-modal-list-wrap{width:220px;flex-shrink:0;border-right:1px solid rgba(255,255,255,.1);overflow-y:auto}.formula-modal-list-wrap ul{list-style:none;margin:0;padding:8px 0}.formula-modal-item{padding:10px 14px;color:#c8dce8;font-size:14px;cursor:pointer;transition:background .2s,color .2s}.formula-modal-item:hover{background:#ffffff14;color:#fff}.formula-modal-item.selected{background:#5a9fd440;color:#e8f4fc}.formula-modal-detail-wrap{flex:1;padding:18px;overflow-y:auto;color:#c8dce8;font-size:14px;line-height:1.6}.formula-modal-detail-name{font-size:16px;color:#e8f4fc;margin-bottom:10px}.formula-modal-detail-notation{font-family:ui-monospace,monospace;color:#8ab4d4;margin-bottom:12px;word-break:break-all}.formula-modal-detail-desc{color:#a8c4d8}.formula-modal-footer{display:flex;align-items:center;gap:16px;padding:12px 18px;border-top:1px solid rgba(255,255,255,.1)}.formula-modal-append-wrap{display:inline-flex;align-items:center;gap:8px;color:#c8dce8;font-size:14px;cursor:pointer;-webkit-user-select:none;user-select:none}.formula-modal-append-wrap input{cursor:pointer}.formula-modal-footer button{padding:8px 20px;background:#3d5a80;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.formula-modal-footer button:hover{background:#4d6a90}.app-copyright{position:fixed;bottom:0;left:0;right:0;padding:6px 12px;font-size:11px;color:#6a8aaa;text-align:center;background:#0f0f1ad9}
