*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #252525;--accent: #d77249;--accent-hover: #fcc340;--text-primary: #ffffff;--text-secondary: #a3a3a3;--border: #2a2a2a}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}.app{max-width:1600px;margin:0 auto;padding:2rem 1.5rem;width:100%}.header{text-align:center;margin-bottom:3rem;position:relative}.theme-toggle{position:absolute;top:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:.5rem .75rem;cursor:pointer;transition:all .2s;color:var(--text-primary);font-size:1.25rem;display:flex;align-items:center;gap:.5rem}.theme-toggle:hover{background:var(--bg-tertiary);border-color:var(--accent)}.header h1{font-size:2.5rem;font-weight:700;margin-bottom:.2rem;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header p{color:var(--text-secondary);font-size:1rem}.header-attribution{color:var(--text-secondary);font-size:.875rem;margin-top:.2rem}.header-attribution a{color:var(--accent-hover);text-decoration:none;font-weight:600;transition:color .2s}.header-attribution a:hover{color:var(--accent);text-decoration:underline}.footer{text-align:center;margin-top:3rem;padding:2rem 0;border-top:1px solid var(--border)}.footer p{color:var(--text-secondary);font-size:.875rem}.image-compare-section{margin-bottom:1.5rem}.image-drop-zone{background:var(--bg-primary);border:2px dashed var(--border);border-radius:8px;padding:2rem 1rem;text-align:center;cursor:pointer;transition:all .2s;outline:none}.image-drop-zone:hover,.image-drop-zone:focus{border-color:var(--accent);background:var(--bg-tertiary)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:.75rem}.drop-zone-icon{font-size:3rem;opacity:.5}.drop-zone-text{font-size:1rem;color:var(--text-primary);margin:0}.drop-zone-hint{font-size:.875rem;color:var(--text-secondary);margin:0}.btn-upload{background:var(--accent);border:none;color:#fff;border-radius:6px;padding:.5rem 1.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-block;margin-top:.5rem}.btn-upload:hover{background:var(--accent-hover);transform:translateY(-1px)}.image-preview-wrapper{position:relative}.image-preview{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:.75rem;display:flex;justify-content:center;align-items:center;min-height:150px;position:relative;overflow:hidden;user-select:none;cursor:grab;touch-action:none;-webkit-user-select:none}.image-preview img{max-width:none;max-height:none;width:100%;height:auto;border-radius:4px;transition:transform .1s ease-out;pointer-events:none}.resize-handle{position:absolute;bottom:0;left:0;right:0;height:12px;cursor:ns-resize;background:linear-gradient(to bottom,transparent,var(--border));border-bottom-left-radius:8px;border-bottom-right-radius:8px;transition:background .2s}.resize-handle:hover{background:linear-gradient(to bottom,transparent,var(--accent))}.main-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.glyph-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.25rem;font-weight:600}.glyph-legend{display:flex;gap:1rem;align-items:center;margin:-.25rem 0 1rem}.legend-item{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary);font-size:.85rem}.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block;border:1px solid var(--border)}.legend-dot.confirmed{background:#ffc343;border-color:#ffc343}.legend-dot.unconfirmed{background:#777;border-color:#777}.toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--text-secondary);transition:color .2s}.toggle-label:hover{color:var(--text-primary)}.toggle-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:40px;height:22px;background:var(--bg-tertiary);border-radius:11px;position:relative;cursor:pointer;transition:background .2s;border:1px solid var(--border)}.toggle-checkbox:checked{background:var(--accent)}.toggle-checkbox:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .2s}.toggle-checkbox:checked:after{transform:translate(18px)}.glyph-grid{overflow:visible;display:grid;grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:1rem}.glyph-item{overflow:visible;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:1.25rem .75rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s}.glyph-item:hover{background:var(--bg-primary);border-color:var(--accent);transform:translateY(-2px)}.glyph-svg{max-height:56px;width:auto;overflow:visible;object-fit:none;object-position:top left}.glyph-label{font-size:.75rem;color:var(--text-secondary);font-weight:500;transition:color .2s}.glyph-item:hover .glyph-label{color:var(--accent)}.ligature-divider{grid-column:1 / -1;height:1px;background:var(--border);margin:.5rem 0}.ligature-header{grid-column:1 / -1;font-size:.875rem;color:var(--text-secondary);font-weight:600;margin-top:.5rem}.message-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.share-note{color:var(--text-secondary);font-size:.9rem;text-align:center}.share-note a{color:var(--accent-hover);font-weight:600;text-decoration:none}.share-note a:hover{color:var(--accent);text-decoration:underline}.message-panel{display:flex;flex-direction:column;gap:.75rem}.panel-header{display:flex;justify-content:space-between;align-items:center}.panel-header h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.panel-actions{display:flex;gap:.5rem}.btn-icon{background:transparent;border:1px solid var(--border);color:var(--text-secondary);border-radius:6px;padding:.4rem .75rem;font-size:.75rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent)}.message-display{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:1.25rem;display:flex;flex-wrap:wrap;gap:0;align-items:flex-start;overflow:visible;position:relative;cursor:text}.mobile-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;pointer-events:auto;background:transparent;border:none;color:transparent;caret-color:var(--accent);resize:none;z-index:2}.message-display:empty:before{content:"Start typing or click glyphs...";color:var(--text-secondary);font-style:italic;font-size:.875rem}.message-glyph{overflow:visible;width:auto;height:64px;margin-right:-20px}.message-glyph.first-glyph{margin-left:-10px}.message-space{display:inline-block;width:40px}.message-linebreak{display:block;width:100%;height:0}.message-display>*:not(.mobile-input){pointer-events:none}.message-english{font-family:Courier New,monospace;font-size:1rem;line-height:1.8;word-break:break-word}.cursor-indicator{display:inline-block;width:2px;height:64px;background:var(--accent);margin-left:0;animation:blink 1s infinite;vertical-align:bottom}.message-english .cursor-indicator{height:1.4rem;margin-left:2px}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.export-section{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.btn-primary{background:var(--accent);border:none;color:#fff;border-radius:8px;padding:.75rem 2rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #d7724966}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-primary);border-radius:8px;padding:.75rem 2rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.keyboard-hint{grid-column:1 / -1;text-align:center;color:var(--text-secondary);font-size:.875rem;margin-top:.5rem;margin-bottom:.5rem;padding:.75rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}@media(max-width:1024px){.main-grid{grid-template-columns:1fr}}@media(max-width:768px){.app{padding:1rem}.header h1{font-size:2rem}.theme-toggle{position:static;margin:0 auto 1rem}.main-grid{display:flex;flex-direction:column}.glyph-section{order:2}.message-section{order:1}.glyph-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.5rem;overflow:visible}.glyph-item{padding:.75rem .25rem;overflow:visible}.glyph-svg{max-height:40px;min-height:40px;height:40px;width:auto;overflow:visible;object-fit:contain;object-position:center}.mobile-input{position:absolute;opacity:0;pointer-events:auto;width:100%;background:transparent;border:none;color:transparent;caret-color:var(--accent);font-size:16px;outline:none;top:0;left:0;height:100%;z-index:1}.message-display>*:not(.mobile-input){position:relative;z-index:2;pointer-events:none}.export-section{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.export-canvas{position:fixed;left:-9999px;top:-9999px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:2rem;max-width:500px;width:90%;text-align:center;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-icon{font-size:3rem;margin-bottom:1rem}.modal-title{font-size:1.25rem;font-weight:600;color:var(--accent-hover);margin-bottom:.5rem}.modal-message{color:var(--text-secondary);font-size:.875rem;margin-bottom:2rem;line-height:1.6}.modal-button{background:var(--accent);border:none;color:#fff;border-radius:8px;padding:.75rem 2rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.05em;width:100%}.modal-button:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #d7724966}.footer{text-align:center;margin-top:3rem;padding:1.5rem 0;border-top:1px solid var(--border)}.footer p{color:var(--text-secondary);font-size:.875rem;margin:0}.footer a{color:var(--accent-hover);text-decoration:none;font-weight:600;transition:color .2s}.footer a:hover{color:var(--accent);text-decoration:underline}
