UNPKG

react-latex-editor

Version:

A powerful React rich text editor with mathematical equation support, built on TipTap with MathLive integration

2 lines (1 loc) 27.1 kB
.resizable-image-container{position:relative;display:flex;justify-content:flex-start;align-items:center;line-height:0;max-width:100%;min-width:40px;min-height:40px;overflow:visible;margin:4px}.resizable-image-container.display-block{display:block}.resizable-image-container.display-inline-block{display:inline-block;vertical-align:middle;margin:0 .5rem}.resizable-image-container.align-left{justify-content:flex-start}.resizable-image-container.align-right{justify-content:flex-end}.resizable-image-container.align-center{justify-content:center}.resizable-image-container.ProseMirror-selectednode{outline:2px dashed #a5b4fc;outline-offset:2px}.resizable-image-container .editor-image{width:100%;height:auto}.resize-handle-left,.resize-handle-right{position:absolute;top:50%;transform:translateY(-50%);width:8px;height:40px;background-color:#3b82f6;border:1px solid white;border-radius:4px;cursor:ew-resize;z-index:10;display:none;opacity:.8;transition:all .2s ease}.resize-handle-left{left:-12px}.resize-handle-right{right:-12px}.resize-handle-left:hover,.resize-handle-right:hover{opacity:1;width:10px}.ProseMirror-selectednode .resize-handle-left,.ProseMirror-selectednode .resize-handle-right{display:block}.resizable-youtube-wrapper{position:relative;display:inline-block;max-width:100%;margin:4px}.resizable-youtube-container{position:relative;display:inline-block;background:#000;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #00000014;max-width:100%}.resizable-youtube-container iframe{display:block;width:100%;height:100%;border:none;border-radius:8px;background:#000}.resize-handle{position:absolute;width:10px;height:10px;background-color:#3b82f6;border:1px solid #fff;border-radius:2px;opacity:.85;z-index:10;transition:box-shadow .2s}.resize-handle-bottom-right{bottom:-5px;right:-5px;cursor:nwse-resize}.resize-handle-bottom-left{bottom:-5px;left:-5px;cursor:nesw-resize}.resize-handle-top-right{top:-5px;right:-5px;cursor:nesw-resize}.resize-handle-top-left{top:-5px;left:-5px;cursor:nwse-resize}.resize-handle:hover{box-shadow:0 0 0 2px #2563eb33}.ProseMirror-selectednode .resize-handle{display:block}.alignment-controls{position:absolute;top:-34px;left:0;display:flex;gap:5px;background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:2px 6px;box-shadow:0 2px 8px #0000000a;z-index:20}.alignment-controls button{background:none;border:none;color:#3b82f6;font-size:16px;cursor:pointer;padding:2px 6px;border-radius:3px;transition:background .2s}.alignment-controls button:hover{background:#e0e7ef}:root{--editor-border-color: #e2e8f0;--editor-background: #ffffff;--editor-text-color: #213547;--editor-focus-color: #3b82f6;--editor-hover-color: #f1f5f9;--toolbar-background: #f8fafc;--toolbar-border-color: #e2e8f0;--toolbar-button-hover: #e2e8f0;--toolbar-button-active: #dbeafe;--editor-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--editor-font-size: 15px;--editor-line-height: 1.7;--editor-padding: 1.25rem;--toolbar-padding: .75rem;--border-radius: .75rem;--transition-duration: .2s}.custom-editor{border:1px solid var(--editor-border-color);border-radius:var(--border-radius);background:var(--editor-background);transition:border-color var(--transition-duration) ease;display:flex;flex-direction:column;min-height:300px;position:relative;font-family:var(--editor-font-family);font-size:var(--editor-font-size);line-height:var(--editor-line-height);box-shadow:0 2px 12px #0000000a}.custom-editor:focus-within{border-color:var(--editor-focus-color);box-shadow:0 0 0 3px #3b82f61a}.toolbar{display:flex;flex-wrap:wrap;gap:.25rem;padding:.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:.75rem .75rem 0 0;min-height:40px;align-items:center;overflow-x:auto;box-shadow:none;position:sticky;top:0;z-index:1;-webkit-backdrop-filter:none;backdrop-filter:none;animation:none;scrollbar-width:none;transition:background .2s,border-color .2s;margin-bottom:.5rem}.toolbar:before,.toolbar:after{display:none}.toolbar-content{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;width:100%}.toolbar-group{gap:.3rem;padding:.25rem .5rem;border-radius:.375rem;border:1px solid #e2e8f0;background:#fff;align-items:center;display:flex;box-shadow:none;position:relative;overflow:hidden;animation:none!important}.toolbar-group+.toolbar-group{border-left:none}.toolbar-divider{width:1px;height:38px;background:#e2e8f0;margin:0 .25rem;border-radius:1px;align-self:stretch;position:relative;transition:background .2s}.toolbar-divider:before{display:none}.toolbar-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:#fffefe;border-radius:.3rem;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;color:#475569;position:relative;overflow:hidden;border:1px solid #e2e8f0;box-shadow:none}.toolbar-button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px;z-index:2;box-shadow:0 0 0 2px #bfdbfe}.toolbar-button:hover:not(.is-disabled){color:#1e293b;background:#e0e7ef;border-color:#3b82f6;box-shadow:none;transform:none}.toolbar-button:active:not(.is-disabled){background:#dbeafe;color:#2563eb;border-color:#2563eb}.toolbar-button.is-active{color:#fff;background:#3b82f6;border-color:#2563eb;box-shadow:none}.toolbar-button.is-disabled{opacity:.4;cursor:not-allowed;background:#f1f5f9;color:#94a3b8;border-color:#e2e8f0;box-shadow:none}.toolbar-button:before,.toolbar-button:after{display:none!important}.toolbar-group select{padding:.25rem 1.5rem .25rem .75rem;border:1px solid #e2e8f0;border-radius:.375rem;background:#f3f4f6;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:border-color .2s,background .2s;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;outline:none;appearance:none;background-image:none;background-repeat:no-repeat;background-position:right .5rem center}.toolbar-group select:hover,.toolbar-group select:focus{border-color:#3b82f6;background:#e0e7ef}.toolbar-group input[type=color]{width:36px;height:36px;border:1px solid #e2e8f0;border-radius:.5rem;cursor:pointer;padding:0;background:#f3f4f6;transition:border-color .2s,background .2s;box-shadow:none;overflow:hidden}.toolbar-group input[type=color]:hover,.toolbar-group input[type=color]:focus{border-color:#3b82f6;background:#e0e7ef}.tooltip-container{position:relative}.tooltip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%) translateY(8px);background:linear-gradient(145deg,#0f172af2,#1e293bfa);color:#fff;font-size:12px;font-weight:600;padding:8px 14px;border-radius:10px;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:0 8px 32px #0000004d,0 4px 16px #0003,inset 0 1px #ffffff1a;-webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);border:1px solid rgba(255,255,255,.1);max-width:200px}.tooltip:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#0f172af2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.tooltip:after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.05) 50%,transparent 70%);border-radius:inherit;opacity:0;animation:tooltipShimmer 3s ease-in-out infinite}.tooltip-container:hover .tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.tooltip-shortcut{display:inline-block;margin-left:10px;padding:3px 8px;background:linear-gradient(145deg,#fff3,#ffffff1a);border:1px solid rgba(255,255,255,.2);border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;box-shadow:inset 0 1px #ffffff1a}.toolbar-header{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:.75rem;padding:.5rem 0;border-bottom:1px solid rgba(148,163,184,.15)}.toolbar-brand{display:flex;align-items:center;gap:.5rem;color:#374151;font-weight:600;font-size:14px}.toolbar-brand svg{color:#3b82f6;filter:drop-shadow(0 2px 4px rgba(59,130,246,.3))}.toolbar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:linear-gradient(145deg,#fffc,#f8fafce6);border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);color:#6b7280;border:1px solid rgba(148,163,184,.2);box-shadow:0 2px 8px #0000000a}.toolbar-toggle:hover{background:linear-gradient(145deg,#3b82f61a,#9333ea0d);border-color:#3b82f64d;color:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 16px #0000001a}.toolbar-media-group{display:flex;gap:.25rem;align-items:center}.toolbar.dark-mode{background:linear-gradient(145deg,#0f172af2,#1e293bfa 30%,#334155f2 70%,#0f172ae6);border-bottom-color:#4755694d}.toolbar.dark-mode .toolbar-group{background:linear-gradient(145deg,#1e293bcc,#33415599);border-color:#4755694d}.toolbar.dark-mode .toolbar-button{background:linear-gradient(145deg,#1e293bcc,#334155e6);color:#e2e8f0;border-color:#47556933}.toolbar.dark-mode .toolbar-button.is-active{background:linear-gradient(145deg,#3b82f6,#2563eb,#1d4ed8)}.toolbar-button{animation:buttonPulse 3s ease-in-out infinite}.toolbar-group:nth-child(odd),.toolbar-group:nth-child(2n){animation:none!important}.toolbar::-webkit-scrollbar{height:6px}.toolbar::-webkit-scrollbar-track{background:#e2e8f04d;border-radius:3px}.toolbar::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#cbd5e1,#94a3b8);border-radius:3px}.toolbar::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#94a3b8,#64748b)}@media (max-width: 1200px){.toolbar{gap:.5rem;padding:1.25rem 1rem;min-height:68px}.toolbar-group{gap:.2rem;padding:.375rem}.toolbar-button{width:40px;height:40px}.toolbar-button svg{width:20px;height:20px}}@media (max-width: 900px){.toolbar{overflow-x:auto;gap:.375rem;padding:1rem .75rem;flex-wrap:nowrap;min-height:64px;scrollbar-width:thin;scrollbar-color:rgba(59,130,246,.3) transparent}.toolbar::-webkit-scrollbar{display:block;height:4px}.toolbar::-webkit-scrollbar-track{background:#94a3b81a;border-radius:2px}.toolbar::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#3b82f666,#9333ea66);border-radius:2px}.toolbar::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#3b82f699,#9333ea99)}.toolbar-group{gap:.15rem;padding:.25rem;flex-shrink:0}.toolbar-button{width:38px;height:38px}.toolbar-button svg{width:19px;height:19px}.toolbar-divider{height:28px;margin:0 .5rem}}@media (max-width: 600px){.toolbar{padding:.25rem;gap:.1rem;min-height:32px}.toolbar-group{padding:.1rem .25rem;border-radius:.25rem}.toolbar-button{width:36px;height:36px;border-radius:.5rem}.toolbar-button svg{width:18px;height:18px}.tooltip{font-size:11px;padding:6px 10px;border-radius:8px}.tooltip-shortcut{font-size:9px;padding:2px 6px}.toolbar-divider{height:18px;margin:0 .1rem}.toolbar-content{gap:.25rem}}@media (max-width: 480px){.toolbar{padding:.75rem .5rem;gap:.125rem;min-height:56px}.toolbar-button{width:34px;height:34px}.toolbar-button svg{width:16px;height:16px}.toolbar-group{padding:.125rem}.toolbar-divider{height:20px;margin:0 .25rem}}.editor-content{flex:1;padding:var(--editor-padding);outline:none;min-height:200px}.ProseMirror{outline:none;word-wrap:break-word;white-space:pre-wrap;-webkit-font-variant-ligatures:none;font-variant-ligatures:none}.ProseMirror p{margin:.5em 0}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:#adb5bd;pointer-events:none;height:0}.math-node-wrapper-inline{display:inline-block;vertical-align:middle;margin:0 .2em}.math-node-wrapper-block{display:block;text-align:center;margin:1em 0}math-field{font-size:1.1em;line-height:1.2}math-field[data-latex-display-mode=true]{display:block;text-align:center;margin:1em 0}.ProseMirror table{border-collapse:collapse;margin:0;overflow:hidden;table-layout:fixed;width:100%}.ProseMirror table td,.ProseMirror table th{border:2px solid #ced4da;box-sizing:border-box;min-width:1em;padding:3px 5px;position:relative;vertical-align:top}.ProseMirror table th{background-color:#f1f3f4;font-weight:700;text-align:left}.ProseMirror table .selectedCell:after{background:#c8c8ff66;content:"";inset:0;pointer-events:none;position:absolute;z-index:2}.ProseMirror img{max-width:100%;height:auto}.ProseMirror img.ProseMirror-selectednode{outline:2px solid var(--editor-focus-color)}.ProseMirror pre{background:#0d1117;border-radius:.375rem;color:#c9d1d9;font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace;padding:.75rem 1rem;margin:.5em 0;overflow-x:auto}.ProseMirror code{background:none;color:inherit;font-size:.8em;padding:.25em;border-radius:.25rem}.ProseMirror pre code{background:none;color:inherit;font-size:.8em;padding:0}.ProseMirror blockquote{border-left:3px solid #ddd;margin:.5em 0;padding-left:1em;color:#666}.ProseMirror ul,.ProseMirror ol{padding-left:1.5em;margin:.5em 0}.ProseMirror li{margin:.25em 0}.ProseMirror a{color:var(--editor-focus-color);text-decoration:underline}.ProseMirror a:hover{text-decoration:none}.ProseMirror h1,.ProseMirror h2,.ProseMirror h3,.ProseMirror h4,.ProseMirror h5,.ProseMirror h6{margin:.5em 0;font-weight:600;line-height:1.25}.ProseMirror h1{font-size:2em}.ProseMirror h2{font-size:1.5em}.ProseMirror h3{font-size:1.25em}.ProseMirror h4{font-size:1em}.ProseMirror h5{font-size:.875em}.ProseMirror h6{font-size:.85em}.ProseMirror hr{border:none;border-top:2px solid var(--toolbar-border-color);margin:1em 0}.ProseMirror ul[data-type=taskList]{list-style:none;padding:0}.ProseMirror ul[data-type=taskList] li{display:flex;align-items:flex-start;margin:.25em 0}.ProseMirror ul[data-type=taskList] li>label{margin-right:.5em;-webkit-user-select:none;user-select:none}.ProseMirror ul[data-type=taskList] li>div{flex:1}.loading-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:var(--border-radius)}.loading-spinner{width:40px;height:40px;border:4px solid var(--toolbar-border-color);border-top:4px solid var(--editor-focus-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{padding:.75rem 1rem;background-color:#fee2e2;color:#dc2626;border-radius:var(--border-radius);font-size:.875rem;margin-bottom:1rem;border:1px solid #fecaca;display:flex;justify-content:space-between;align-items:center}.error-close{background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;opacity:.7;transition:opacity var(--transition-duration) ease;border-radius:.25rem}.error-close:hover{opacity:1;background-color:#0000001a}.table-controls{display:flex;gap:.5rem;padding:.5rem;background:var(--toolbar-background);border-top:1px solid var(--toolbar-border-color);border-radius:0 0 var(--border-radius) var(--border-radius);flex-wrap:wrap}.table-controls button{padding:.25rem .5rem;border:1px solid var(--toolbar-border-color);background:var(--editor-background);color:var(--editor-text-color);border-radius:.25rem;cursor:pointer;font-size:12px;transition:all var(--transition-duration) ease}.table-controls button:hover{background:var(--toolbar-button-hover)}.character-count{padding:.5rem;text-align:right;font-size:12px;color:#666;border-top:1px solid var(--toolbar-border-color);background:var(--toolbar-background);border-radius:0 0 var(--border-radius) var(--border-radius);position:relative;z-index:1}@media (max-width: 768px){.toolbar{padding:.25rem;gap:.125rem}.toolbar-button{width:28px;height:28px}.toolbar-button svg{width:14px;height:14px}.editor-content{padding:.75rem}.ProseMirror h1{font-size:1.75em}.ProseMirror h2{font-size:1.375em}.ProseMirror h3{font-size:1.125em}}@media (max-width: 480px){.toolbar{flex-direction:column;align-items:stretch}.toolbar-group{justify-content:center}.editor-content{padding:.5rem}}.toolbar-button:focus-visible{outline:2px solid var(--editor-focus-color);outline-offset:2px}.toolbar-button:focus:not(:focus-visible){outline:none}.ProseMirror ::selection{background:#3b82f633}.resizable-image-container{position:relative;display:inline-block;max-width:100%}.resizable-image-container img{max-width:100%;height:auto;display:block}.resizable-image-container .resize-handle{position:absolute;width:8px;height:8px;background:var(--editor-focus-color);border:1px solid white;border-radius:50%;cursor:se-resize;bottom:-4px;right:-4px}.resizable-image-container iframe{border:none;max-width:100%}.math-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:overlayFadeIn .2s ease}.math-dialog{background:var(--editor-background);border-radius:var(--border-radius);padding:1.5rem;max-width:90vw;max-height:90vh;overflow:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:dialogSlideIn .3s ease}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.math-dialog h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--editor-text-color)}.math-dialog math-field{width:100%;min-height:60px;border:1px solid var(--editor-border-color);border-radius:.25rem;padding:.5rem;margin-bottom:1rem;font-size:16px}.math-dialog-buttons{display:flex;gap:.5rem;justify-content:flex-end}.math-dialog button{padding:.5rem 1rem;border:1px solid var(--editor-border-color);background:var(--editor-background);color:var(--editor-text-color);border-radius:.25rem;cursor:pointer;font-size:14px;transition:all var(--transition-duration) ease}.math-dialog button:hover{background:var(--toolbar-button-hover)}.math-dialog button.primary{background:var(--editor-focus-color);color:#fff;border-color:var(--editor-focus-color)}.math-dialog button.primary:hover{background:#2563eb}.math-symbol-toolbar{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:1rem;padding:.5rem;background:var(--toolbar-background);border-radius:.25rem;border:1px solid var(--toolbar-border-color)}.math-symbol-tab{padding:.25rem .5rem;border:none;background:transparent;color:var(--editor-text-color);cursor:pointer;border-radius:.25rem;font-size:12px;transition:background-color var(--transition-duration) ease}.math-symbol-tab.active{background:var(--editor-focus-color);color:#fff}.math-symbol-tab:hover:not(.active){background:var(--toolbar-button-hover)}.math-symbol-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(40px,1fr));gap:.25rem;margin-top:.5rem}.math-symbol-button{padding:.5rem;border:1px solid var(--editor-border-color);background:var(--editor-background);color:var(--editor-text-color);border-radius:.25rem;cursor:pointer;font-size:14px;transition:all var(--transition-duration) ease;text-align:center;min-height:40px;display:flex;align-items:center;justify-content:center}.math-symbol-button:hover{background:var(--toolbar-button-hover);border-color:var(--editor-focus-color)}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.custom-editor{border-width:2px}.toolbar-button{border:1px solid var(--editor-border-color)}.toolbar-button:hover:not(.is-disabled){border-color:var(--editor-focus-color)}}.toolbar .toolbar-button span,.toolbar .toolbar-button .label,.toolbar .toolbar-button .desc{display:none!important}.test-math-background{background:#f8fafc;border-radius:4px;padding:2px 6px;min-width:24px;min-height:1.5em;display:inline-block;box-shadow:0 1px 2px #3b82f60a}math-field::part(virtual-keyboard-toggle){display:none!important}.ML__keyboard{display:none!important}.math-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:100;animation:overlayFadeIn .2s ease-out;overflow:auto}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.math-dialog{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;width:95vw;max-width:700px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;position:relative}@keyframes dialogFadeIn{0%{opacity:0}to{opacity:1}}.math-dialog-header{padding:8px 12px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;border-radius:8px 8px 0 0}.math-dialog-header h3{margin:0;font-size:1.1rem;color:#2c3e50;font-weight:600}.close-button{background:none;border:none;font-size:1.2rem;color:#666;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .2s}.close-button:hover{background:#0000000d;color:#333}.math-toolbar-tabs{display:flex;flex-wrap:wrap;gap:2px;padding:6px 8px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;max-width:100%;scrollbar-width:thin}.tab-button{padding:4px 10px;border:none;background:none;color:#666;cursor:pointer;border-radius:4px;font-size:.85rem;transition:all .2s;white-space:nowrap}.tab-button:hover{background:#0000000d}.tab-button.active{background:#007bff;color:#fff}.math-toolbar-container{padding:8px;border-bottom:1px solid #e0e0e0;max-height:120px}.math-toolbar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(32px,1fr));gap:4px;max-height:160px;overflow-y:auto;padding:4px}.math-symbol-button{aspect-ratio:1;border:1px solid #e0e0e0;background:#fff;border-radius:4px;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.math-symbol-button:hover{background:#f0f0f0;border-color:#ccc;transform:translateY(-1px)}.math-examples{padding:10px;border-bottom:1px solid #e0e0e0;width:100%}.math-examples h4{margin:0 0 6px;color:#2c3e50;font-size:.9rem;font-weight:600}.equation-buttons{display:flex;flex-wrap:wrap;gap:4px}.equation-buttons button{padding:4px 8px;border:1px solid #e0e0e0;background:#fff;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s;white-space:nowrap}.equation-buttons button:hover{background:#f0f0f0;border-color:#ccc;transform:translateY(-1px)}.math-editor{padding:8px;border-bottom:1px solid #e0e0e0}.math-dialog-math-field{width:100%!important;min-height:40px!important;font-size:1rem!important;padding:6px!important;border:1px solid #e0e0e0!important;border-radius:4px!important;background-color:#fff!important;transition:all .2s!important}.math-dialog-math-field:focus{border-color:#007bff!important;box-shadow:0 0 0 2px #007bff40!important}.math-dialog-footer{padding:8px 12px;display:flex;justify-content:flex-end;gap:8px;background:#f8f9fa;border-radius:0 0 8px 8px}@media (max-width: 600px){.math-dialog-footer .math-dialog{max-width:99vw;width:99vw;margin:2vh auto;padding:0;max-height:98vh}.math-dialog-footer .math-dialog-header,.math-dialog-footer .math-dialog-footer{padding:10px 2vw}.math-dialog-footer .math-toolbar-tabs{flex-wrap:nowrap;overflow-x:auto;gap:2px;max-width:100vw;scrollbar-width:thin}.math-dialog-footer .tab-button{padding:4px 8px;font-size:.95rem}.math-dialog-footer .math-toolbar-container{max-height:80px;padding:0 2vw}.math-dialog-footer .math-editor{margin:8px 0;font-size:.95rem}}.cancel-button,.save-button{padding:4px 16px;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s}.cancel-button{background:#fff;border:1px solid #e0e0e0;color:#666}.save-button{background:#007bff;border:none;color:#fff}.cancel-button:hover{background:#f0f0f0;border-color:#ccc}.save-button:hover{background:#0056b3}.math-dialog::-webkit-scrollbar,.math-toolbar-grid::-webkit-scrollbar{display:none}.editor-viewer{width:100%;padding:0rem;border-radius:1rem;white-space:pre-wrap;font-size:1rem;line-height:1.6;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;tab-size:4;-moz-tab-size:4;-o-tab-size:4}.viewer-content p{margin:.75em 0;min-height:1.5em}.viewer-content p:empty:before{content:"";display:inline-block}.viewer-content h1,.viewer-content h2,.viewer-content h3,.viewer-content h4,.viewer-content h5,.viewer-content h6{margin:1.2em 0 .6em;line-height:1.3;font-weight:600;page-break-after:avoid;color:#111827}.viewer-content h1{font-size:2em}.viewer-content h2{font-size:1.5em}.viewer-content h3{font-size:1.25em}.viewer-content h4{font-size:1.1em}.viewer-content h5{font-size:1em}.viewer-content h6{font-size:.9em}.viewer-content ul,.viewer-content ol{margin:.75em 0;padding-left:1.5em}.viewer-content li{margin:.25em 0;padding-left:.25em}.viewer-content li>p{margin:.25em 0}.viewer-content blockquote{margin:1em 0;padding:.5em 1em;border-left:4px solid #ddd;background:#f9f9f9}.viewer-content blockquote>*:first-child{margin-top:0}.viewer-content blockquote>*:last-child{margin-bottom:0}.viewer-content pre{margin:1em 0;padding:1em;overflow-x:auto;background:#f5f5f5;border-radius:4px;font-size:.9em;line-height:1.5}.viewer-content code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9em;padding:.2em .4em;border-radius:3px;background:#f5f5f5}.viewer-content pre code{padding:0;background:none;border-radius:0}.viewer-content img{max-width:100%;height:auto;margin:1em 0;display:block;border-radius:.5rem;border:1px solid #e5e7eb}.viewer-content table{width:100%;border-collapse:collapse;margin:1em 0;border:1px solid #ddd}.viewer-content th,.viewer-content td{padding:.5em;border:1px solid #ddd;min-width:2em}.viewer-content th{font-weight:600;text-align:left;background:#f5f5f5}.viewer-content a{color:#06c;text-decoration:underline;word-break:break-word}.viewer-content a:hover,.viewer-content a:focus{text-decoration:none;outline:none}.viewer-content math-field{display:inline-block;vertical-align:middle;margin:0 .2em}.viewer-content .katex{font-size:1.1em;line-height:1.2}.viewer-content .katex-display{margin:1em 0;overflow-x:auto;overflow-y:hidden;padding:.5em 0}.viewer-content :focus{outline:2px solid #0066cc;outline-offset:2px}.viewer-content :focus:not(:focus-visible){outline:none}.viewer-content ::selection{background:#b3d4fc;text-shadow:none}@media print{.editor-viewer{font-size:12pt;line-height:1.5}.viewer-content a{text-decoration:underline}.viewer-content a[href]:after{content:" (" attr(href) ")";font-size:.8em}.viewer-content pre,.viewer-content blockquote{page-break-inside:avoid}}@media (max-width: 768px){.editor-viewer{padding:0rem;border-radius:.5rem;font-size:.9375rem}.viewer-content h1{font-size:1.5em}.viewer-content h2{font-size:1.15em}.viewer-content h3{font-size:1em}.viewer-content pre{padding:.75em}}@media (max-width: 480px){.editor-viewer{padding:0rem;font-size:.875rem}.viewer-content h1{font-size:1.35em}.viewer-content h2{font-size:1.05em}.viewer-content h3{font-size:.95em}.viewer-content pre{padding:.5em}.viewer-content blockquote{padding:.5em .75em}}@media (prefers-color-scheme: dark){.editor-viewer,.viewer-content,.viewer-content h1,.viewer-content h2,.viewer-content h3,.viewer-content blockquote,.viewer-content pre,.viewer-content code,.viewer-content th,.viewer-content td,.viewer-content a{background:#fff;color:#374151;border-color:#e5e7eb}}.viewer-content div[data-youtube-video] iframe{display:block;max-width:100%;border-radius:8px;background:#000}