*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-a: sans-serif;--font-b: serif;--font-size: 24px;--line-height: 1.5;--letter-spacing: 0em;--text-align: left;--header-height: auto}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--text-primary: #1a1a1a;--text-secondary: #666666;--text-muted: #999999;--border: #e0e0e0;--border-strong: #ccc;--accent: #2563eb;--accent-hover: #1d4ed8;--drop-bg: #f8fafc;--drop-border: #cbd5e1;--drop-hover: #e0e7ff;--panel-label-bg: rgba(0,0,0,.04)}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #252525;--bg-tertiary: #333333;--text-primary: #e8e8e8;--text-secondary: #999999;--text-muted: #666666;--border: #404040;--border-strong: #555;--accent: #60a5fa;--accent-hover: #93bbfd;--drop-bg: #222;--drop-border: #444;--drop-hover: #2a2a4a;--panel-label-bg: rgba(255,255,255,.06)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-secondary);color:var(--text-primary);min-height:100vh;display:flex;flex-direction:column}.header{background:var(--bg-primary);border-bottom:1px solid var(--border);padding:.75rem 1rem 0;display:flex;flex-direction:column;gap:.5rem;position:sticky;top:0;z-index:100}.header-top{display:flex;justify-content:space-between;align-items:center}.app-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.icon-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:.25rem .5rem;cursor:pointer;color:var(--text-primary);font-size:1.1rem;line-height:1}.icon-btn:hover{background:var(--bg-secondary)}[data-theme=light] .theme-icon-dark,[data-theme=dark] .theme-icon-light{display:none}.upload-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.drop-zone{border:2px dashed var(--drop-border);border-radius:8px;padding:.75rem 1rem;text-align:center;cursor:pointer;background:var(--drop-bg);transition:border-color .2s,background .2s;min-height:3.5rem;display:flex;align-items:center;justify-content:center}.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);background:var(--drop-hover)}.drop-zone-prompt{display:flex;flex-direction:column;gap:.15rem}.drop-zone-label{font-weight:600;font-size:.85rem;color:var(--text-primary)}.drop-zone-hint{font-size:.75rem;color:var(--text-muted)}.font-info{display:flex;align-items:center;gap:.5rem;width:100%}.font-name{font-weight:600;font-size:.85rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.font-meta{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.clear-font-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.2rem;line-height:1;margin-left:auto;padding:.1rem .3rem;border-radius:4px}.clear-font-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.controls-row{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;align-items:center;font-size:.8rem;color:var(--text-secondary)}.control-group{display:flex;align-items:center;gap:.4rem}.control-group label{white-space:nowrap;-webkit-user-select:none;user-select:none}.control-group input[type=range]{width:100px;accent-color:var(--accent)}.slider-group{flex-direction:column;align-items:flex-start;gap:.2rem}.slider-group input[type=range]{width:120px}.slider-header{display:flex;align-items:center;gap:.3rem}.slider-header input[type=number]{width:4.5ch;padding:.1rem .25rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;font-family:inherit;text-align:right;-moz-appearance:textfield}.slider-header input[type=number]::-webkit-inner-spin-button,.slider-header input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.slider-header input[type=number]:focus{outline:2px solid var(--accent);outline-offset:1px}.unit{color:var(--text-muted)}.align-controls,.view-controls{display:flex;gap:2px}.align-btn,.view-btn{background:var(--bg-secondary);border:1px solid var(--border);padding:.2rem .45rem;cursor:pointer;font-size:.9rem;line-height:1;color:var(--text-secondary);border-radius:0}.align-btn:first-child,.view-btn:first-child{border-radius:4px 0 0 4px}.align-btn:last-child,.view-btn:last-child{border-radius:0 4px 4px 0}.align-btn.active,.view-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.specimen-tabs{display:flex;flex-wrap:wrap;gap:2px}.tab{background:var(--bg-secondary);border:1px solid var(--border);border-bottom:none;padding:.35rem .75rem;cursor:pointer;font-size:.8rem;color:var(--text-secondary);border-radius:6px 6px 0 0;white-space:nowrap}.tab:hover{background:var(--bg-tertiary)}.tab.active{background:var(--bg-primary);color:var(--accent);font-weight:600;border-bottom:2px solid var(--bg-primary);margin-bottom:-1px}.comparison{flex:1;display:grid;gap:1px;background:var(--border);min-height:0}.comparison.side-by-side{grid-template-columns:1fr 1fr}.comparison.stacked{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.comparison.overlay{grid-template-columns:1fr;grid-template-rows:1fr}.comparison.overlay .panel{grid-column:1;grid-row:1}.comparison.overlay .panel-a{color:#e74c3c;z-index:1}.comparison.overlay .panel-b{color:#3498db;mix-blend-mode:difference;z-index:2}.panel{background:var(--bg-primary);overflow-y:auto;padding:1.5rem 2rem;position:relative}.panel-a .specimen-content{font-family:var(--font-a)}.panel-b .specimen-content{font-family:var(--font-b)}.specimen-content{font-size:var(--font-size);line-height:var(--line-height);letter-spacing:var(--letter-spacing);text-align:var(--text-align)}.panel-label{position:sticky;top:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);background:var(--panel-label-bg);padding:.25rem .5rem;border-radius:4px;margin-bottom:1rem;display:inline-block}.specimen-content p{margin-bottom:1em}.specimen-content h3{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:1.5em 0 .5em}.specimen-content h3:first-child{margin-top:0}.specimen-large{font-size:calc(var(--font-size) * 1.25)}.specimen-mono{word-break:break-all;font-size:calc(var(--font-size) * 1.1)}.kern-pairs{word-spacing:.5em}.specimen-section{margin-bottom:1.5em}.specimen-table{font-family:inherit;font-size:var(--font-size);line-height:var(--line-height);text-align:right}.waterfall-line{margin:.2em 0!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waterfall-size{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.65rem;color:var(--text-muted);vertical-align:middle;margin-left:.5em}.custom-placeholder{color:var(--text-muted);font-style:italic}.btn{padding:.3rem .75rem;border:1px solid var(--accent);border-radius:4px;background:var(--accent);color:#fff;font-size:.8rem;cursor:pointer}.btn:hover{background:var(--accent-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem}.modal-overlay[hidden]{display:none}.modal{background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:12px;width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h2{font-size:1rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted);padding:.1rem .3rem;border-radius:4px}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;flex:1}#custom-text-input{width:100%;min-height:140px;padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;font-size:.9rem;line-height:1.5;resize:vertical;flex-shrink:0}#custom-text-input:focus{outline:2px solid var(--accent);outline-offset:1px}.modal-save-row{display:flex;gap:.5rem;align-items:center}.modal-save-row input[type=text]{flex:1;padding:.35rem .6rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem}.modal-save-row input[type=text]:focus{outline:2px solid var(--accent);outline-offset:1px}.saved-texts{display:flex;flex-direction:column;gap:.4rem}.saved-texts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.saved-texts-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.sort-controls{display:flex;gap:2px}.sort-btn{background:var(--bg-secondary);border:1px solid var(--border);padding:.15rem .4rem;font-size:.7rem;cursor:pointer;color:var(--text-muted);border-radius:0}.sort-btn:first-child{border-radius:3px 0 0 3px}.sort-btn:last-child{border-radius:0 3px 3px 0}.sort-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sort-btn:not(.active):hover{border-color:var(--border-strong);color:var(--text-secondary)}.saved-text-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px}.saved-text-row:hover{border-color:var(--accent)}.saved-text-info{flex:1;min-width:0;cursor:pointer}.saved-text-label{font-size:.85rem;font-weight:600;color:var(--text-primary)}.saved-text-preview{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.1rem}.saved-text-load,.saved-text-update{background:none;border:1px solid var(--border);border-radius:4px;padding:.2rem .5rem;font-size:.75rem;cursor:pointer;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.saved-text-load:hover{border-color:var(--accent);color:var(--accent)}.saved-text-update:hover{border-color:#16a34a;color:#16a34a}.saved-text-delete{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1.1rem;line-height:1;padding:.1rem .25rem;border-radius:4px;flex-shrink:0}.saved-text-delete:hover{background:var(--bg-tertiary);color:#e74c3c}.saved-text-rename{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1rem;line-height:1;padding:.1rem .25rem;border-radius:4px;flex-shrink:0}.saved-text-rename:hover{background:var(--bg-tertiary);color:var(--accent)}.saved-text-row--renaming{gap:.4rem}.saved-text-rename-input{flex:1;min-width:0;padding:.3rem .5rem;border:1px solid var(--accent);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem;font-weight:600}.saved-text-rename-input:focus{outline:2px solid var(--accent);outline-offset:1px}.saved-text-rename-confirm,.saved-text-rename-cancel{background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;padding:.1rem .3rem;border-radius:4px;flex-shrink:0}.saved-text-rename-confirm{color:#16a34a}.saved-text-rename-confirm:hover{background:var(--bg-tertiary)}.saved-text-rename-cancel{color:var(--text-muted)}.saved-text-rename-cancel:hover{background:var(--bg-tertiary);color:#e74c3c}.modal-share-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid var(--border)}.share-prefs-label{font-size:.82rem;display:flex;align-items:center;gap:.3rem;color:var(--text-secondary);cursor:pointer;margin-right:auto}.btn-sm{padding:.3rem .65rem;font-size:.82rem}.import-banner{background:var(--bg-secondary);border:1px solid var(--accent);border-radius:6px;padding:.75rem;font-size:.85rem;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.import-banner-title{font-weight:600;color:var(--text-primary)}.import-banner-dup-note{color:var(--text-secondary);font-size:.8rem}.import-banner-replace{display:flex;align-items:center;gap:.4rem;color:var(--text-secondary);cursor:pointer;font-size:.82rem}.import-banner-actions{display:flex;justify-content:flex-end;gap:.5rem}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--text-primary);color:var(--bg-primary);padding:.5rem 1rem;border-radius:6px;font-size:.85rem;z-index:300;pointer-events:none;opacity:0;transition:opacity .15s;white-space:nowrap}.toast.visible{opacity:1}@media print{.header,.modal-overlay{display:none}.comparison{display:block}.panel{break-inside:avoid;page-break-inside:avoid;padding:1cm}.panel-label{position:static}}
