*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-border: #e0e0e0;--color-text: #1a1a1a;--color-muted: #757575;--color-accent: #1a73e8;--color-accent-light: #e8f0fe;--color-variable: #0f9d58;--radius: 8px;--shadow: 0 1px 4px rgba(0,0,0,.08)}body{font-family:system-ui,-apple-system,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:14px;line-height:1.5}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;gap:16px;padding:12px 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:10}.app-header h1{font-size:18px;font-weight:600;white-space:nowrap;color:var(--color-accent)}.fake-ad{margin-left:auto;display:flex;align-items:center;gap:8px;border:1px dashed var(--color-border);border-radius:var(--radius);padding:6px 12px;background:#fffde7;min-width:380px;max-width:520px;opacity:0;transition:opacity .4s ease;overflow:hidden}.fake-ad--visible{opacity:1}.fake-ad-label{font-size:9px;font-weight:700;letter-spacing:.08em;color:#bbb;align-self:flex-start;padding-top:2px;flex-shrink:0}.fake-ad-content{display:flex;flex-direction:column;gap:1px;min-width:0}.fake-ad-headline{font-size:12px;font-weight:600;color:var(--color-text)}.fake-ad-sub{font-size:11px;color:var(--color-muted)}.fake-ad-brand{font-size:10px;font-weight:700;color:var(--color-accent)}.app-body{display:flex;flex:1;overflow:hidden}.app-main{flex:1;overflow-y:auto;padding:16px 24px}.search-bar{position:relative;display:flex;align-items:center;width:100%}.search-bar input{width:100%;padding:8px 32px 8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;outline:none;background:var(--color-bg)}.search-bar input::-webkit-search-cancel-button{display:none}.search-bar input:focus{border-color:var(--color-accent);background:var(--color-surface)}.search-clear{position:absolute;right:8px;background:none;border:none;cursor:pointer;font-size:18px;line-height:1;color:var(--color-muted);padding:0 2px}.search-clear:hover{color:var(--color-text)}.filter-panel{width:200px;min-width:200px;border-right:1px solid var(--color-border);overflow-y:auto;padding:16px;background:var(--color-surface)}.filter-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.filter-panel-title{font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:#888}.filter-reset-btn{font-size:12px;padding:2px 8px;border:1px solid var(--color-border);border-radius:4px;background:transparent;cursor:pointer;color:var(--color-text)}.filter-reset-btn:hover{background:var(--color-border)}.filter-panel section{margin-bottom:20px}.filter-panel h3{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin-bottom:8px}.filter-label{display:flex;align-items:center;gap:6px;padding:3px 0;cursor:pointer;font-size:13px}.filter-label--minor{margin-top:6px;font-size:11px;color:#888}.filter-panel select{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-bg)}.filter-text-input{width:100%;padding:6px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;background:var(--color-bg);color:var(--color-text)}.glyph-filter{position:relative;display:flex;align-items:center}.glyph-filter-input{width:100%;padding:6px 24px 6px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:20px;text-align:center;background:var(--color-bg);outline:none}.glyph-filter-input:focus{border-color:var(--color-accent)}.glyph-filter-clear{position:absolute;right:4px;background:none;border:none;cursor:pointer;font-size:16px;color:var(--color-muted);line-height:1;padding:2px}.glyph-filter-clear:hover{color:var(--color-text)}.glyph-index-progress{font-size:11px;color:var(--color-muted);margin-top:6px}.result-count{font-size:12px;color:var(--color-muted);margin-bottom:12px}.font-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.font-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:box-shadow .15s,border-color .15s;box-shadow:var(--shadow)}.font-card:hover{border-color:var(--color-accent);box-shadow:0 2px 8px #1a73e81f}.font-card-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.font-name{font-weight:600;font-size:15px;flex:1}.font-category{font-size:11px;color:var(--color-muted);background:var(--color-bg);padding:2px 6px;border-radius:4px;border:1px solid var(--color-border)}.font-badge{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.font-badge.variable{background:#e6f4ea;color:var(--color-variable);border:1px solid #a8d5b5}.font-badge.updated{background:#fff8e1;color:#f57f17;border:1px solid #ffe082}.font-badge.color{background:#fce4ec;color:#c2185b;border:1px solid #f48fb1}.font-preview-text{line-height:1.4;margin-bottom:12px;color:var(--color-text);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.font-card-footer{display:flex;flex-direction:column;gap:8px}.weight-pills{display:flex;flex-wrap:wrap;gap:4px}.weight-pill{font-size:11px;padding:2px 6px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-muted)}.weight-pill.italic{font-style:italic}.tag-editor{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.tag{display:inline-flex;align-items:center;gap:4px;background:var(--color-accent-light);color:var(--color-accent);border:1px solid #c5d8fc;border-radius:4px;padding:2px 6px;font-size:12px}.tag-remove{background:none;border:none;cursor:pointer;color:var(--color-accent);font-size:14px;line-height:1;padding:0;opacity:.7}.tag-remove:hover{opacity:1}.tag-add{background:none;border:1px dashed var(--color-border);border-radius:4px;padding:2px 8px;font-size:12px;cursor:pointer;color:var(--color-muted)}.tag-add:hover{border-color:var(--color-accent);color:var(--color-accent)}.tag-input-wrap{position:relative}.tag-input{border:1px solid var(--color-accent);border-radius:4px;padding:2px 6px;font-size:12px;outline:none;width:100px}.tag-suggestions{position:absolute;top:calc(100% + 2px);left:0;min-width:120px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);list-style:none;z-index:50;max-height:160px;overflow-y:auto}.tag-suggestion{padding:5px 10px;font-size:12px;cursor:pointer}.tag-suggestion:hover,.tag-suggestion--active{background:var(--color-accent-light);color:var(--color-accent)}.tag-editor--auth{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.tag-auth-label{font-size:12px;color:var(--color-muted)}.tag-auth-input{border:1px solid var(--color-accent);border-radius:4px;padding:2px 8px;font-size:12px;outline:none;width:140px}.tag-auth-save,.tag-auth-cancel{padding:2px 8px;font-size:12px;border-radius:4px;cursor:pointer;border:1px solid var(--color-border);background:transparent}.tag-auth-save{border-color:var(--color-accent);color:var(--color-accent)}.tag-auth-cancel{color:var(--color-muted)}.preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;justify-content:flex-end}.preview-panel{background:var(--color-surface);width:min(680px,100vw);height:100%;overflow-y:auto;position:relative;box-shadow:-4px 0 24px #00000026}.preview-sticky{position:sticky;top:0;z-index:10;background:var(--color-surface);padding:24px 24px 16px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:16px}.preview-scrollable{padding:16px 24px 24px;display:flex;flex-direction:column;gap:0}.preview-close{position:absolute;top:16px;right:16px;background:none;border:1px solid var(--color-border);border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:20px;line-height:1;color:var(--color-muted);display:flex;align-items:center;justify-content:center}.preview-close:hover{background:var(--color-bg);color:var(--color-text)}.preview-title-row{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}.preview-title-row h2{font-size:24px;font-weight:600}.google-fonts-link{font-size:12px;color:var(--color-accent);text-decoration:none;white-space:nowrap}.google-fonts-link:hover{text-decoration:underline}.preview-axes{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.axis-pill{font-size:11px;font-family:monospace;padding:2px 6px;background:#fef3c7;border:1px solid #fbbf24;border-radius:4px;color:#92400e;cursor:default}.script-list{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.script-pill{font-size:11px;padding:2px 7px;border-radius:4px;background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd}.script-pill.latin{background:var(--color-bg);color:var(--color-muted);border-color:var(--color-border)}.preview-meta{display:flex;align-items:center;gap:8px;margin-bottom:12px}.preview-last-modified{font-size:11px;color:var(--color-muted);margin-left:auto}.preview-controls{display:flex;flex-direction:column;gap:12px}.italic-toggle{font-size:15px;font-style:italic;padding:0 10px;height:32px;border:1px solid var(--color-border);border-radius:4px;background:transparent;cursor:pointer;color:var(--color-muted);flex-shrink:0;align-self:flex-start}.italic-toggle--active{background:var(--color-accent-light);border-color:var(--color-accent);color:var(--color-accent)}.italic-toggle:hover{border-color:var(--color-accent);color:var(--color-accent)}.preview-text-input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;outline:none}.preview-text-input:focus{border-color:var(--color-accent)}.size-slider{display:flex;align-items:center;gap:12px}.size-slider label{font-size:13px;color:var(--color-muted);min-width:70px}.size-slider input[type=range]{flex:1;accent-color:var(--color-accent)}.collapsible-section{border-top:1px solid var(--color-border)}.collapsible-header{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:10px 0;cursor:pointer;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);text-align:left}.collapsible-header:hover{color:var(--color-text)}.collapsible-chevron{font-size:16px;line-height:1;transition:transform .15s;transform:rotate(0)}.collapsible-chevron--open{transform:rotate(90deg)}.collapsible-body{padding-bottom:16px}.axis-section-header{display:flex;justify-content:flex-end;margin-bottom:8px}.axis-reset-btn{font-size:11px;padding:2px 8px;border:1px solid var(--color-border);border-radius:4px;background:transparent;cursor:pointer;color:var(--color-muted)}.axis-reset-btn:hover{color:var(--color-text);background:var(--color-bg)}.axis-controls{display:flex;flex-direction:column;gap:12px}.axis-controls h3{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted)}.axis-row{display:flex;flex-direction:column;gap:4px}.axis-row-header{display:flex;align-items:baseline;gap:6px}.axis-single-reset{margin-left:auto;background:none;border:none;cursor:pointer;font-size:13px;color:var(--color-muted);padding:0;line-height:1}.axis-single-reset:hover{color:var(--color-accent)}.axis-name{font-size:13px;font-weight:500}.axis-tag{font-size:11px;font-family:monospace;color:var(--color-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:3px;padding:1px 4px}.axis-value{margin-left:auto;font-size:12px;font-family:monospace;color:var(--color-accent);min-width:36px;text-align:right}.axis-slider{width:100%;accent-color:var(--color-accent)}.axis-range{display:flex;justify-content:space-between;font-size:10px;color:var(--color-muted)}.preview-live{padding:16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);word-break:break-word}.preview-weights{display:flex;flex-direction:column;gap:8px}.preview-weight-row,.preview-size-row{display:flex;align-items:baseline;gap:16px;padding:4px 0;border-bottom:1px solid var(--color-border)}.weight-label,.size-label{font-size:11px;color:var(--color-muted);min-width:48px}.preview-sample{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-sizes{display:flex;flex-direction:column}.glyph-map-section{border-top:1px solid var(--color-border);padding-top:16px}.glyph-load-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius);padding:8px 16px;font-size:13px;cursor:pointer;color:var(--color-muted);width:100%}.glyph-load-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.glyph-loading,.glyph-error,.glyph-empty{font-size:13px;color:var(--color-muted);padding:12px 0}.glyph-map-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.glyph-count{font-size:12px;color:var(--color-muted);white-space:nowrap}.glyph-search{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:13px;outline:none}.glyph-search:focus{border-color:var(--color-accent)}.glyph-block{margin-bottom:20px}.glyph-block-name{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--color-muted);margin-bottom:8px}.glyph-block-count{font-weight:400}.glyph-grid{display:flex;flex-wrap:wrap;gap:4px}.glyph-cell{display:flex;flex-direction:column;align-items:center;width:48px;padding:6px 4px 4px;border:1px solid var(--color-border);border-radius:4px;cursor:pointer;background:var(--color-bg);-webkit-user-select:none;user-select:none}.glyph-cell:hover{border-color:var(--color-accent);background:var(--color-accent-light)}.glyph-cell--copied{border-color:var(--color-variable);background:#e6f4ea}.glyph-char{font-size:24px;line-height:1.2}.glyph-cp{font-size:9px;font-family:monospace;color:var(--color-muted);margin-top:2px}.glyph-large-block{font-size:13px;color:var(--color-muted);font-style:italic}.glyph-overflow{display:flex;align-items:center;justify-content:center;width:48px;height:56px;font-size:11px;color:var(--color-muted);border:1px dashed var(--color-border);border-radius:4px}.loading,.error,.empty-state{padding:48px;text-align:center;color:var(--color-muted);font-size:16px}.error{color:#d32f2f}.font-card-compare-btn{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-muted);font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s,border-color .15s,color .15s;z-index:1}.font-card:hover .font-card-compare-btn,.font-card-compare-btn--active{opacity:1}.font-card-compare-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.font-card--in-compare{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-light)}.app-body--tray-open .app-main{padding-bottom:72px}.compare-tray{position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -4px 16px #0000001a;padding:10px 24px;display:flex;align-items:center;gap:12px;animation:tray-slide-up .2s ease forwards}@keyframes tray-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.compare-tray-fonts{display:flex;flex-wrap:wrap;gap:8px;flex:1}.compare-tray-chip{display:flex;align-items:center;gap:6px;padding:3px 10px;background:var(--color-accent-light);border:1px solid #c5d8fc;border-radius:var(--radius);font-size:13px;color:var(--color-accent)}.compare-tray-chip button{background:none;border:none;cursor:pointer;color:var(--color-accent);font-size:15px;line-height:1;padding:0;opacity:.7}.compare-tray-chip button:hover{opacity:1}.compare-tray-clear{background:none;border:none;font-size:13px;color:var(--color-muted);cursor:pointer;padding:0 4px;white-space:nowrap}.compare-tray-clear:hover{color:var(--color-text)}.compare-btn{padding:7px 18px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.compare-btn:disabled{opacity:.45;cursor:not-allowed}.compare-btn:not(:disabled):hover{background:#1557b0}.compare-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:var(--color-bg);display:flex;flex-direction:column;overflow:hidden}.compare-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:16px 24px;display:flex;flex-direction:column;gap:12px;flex-shrink:0;position:relative}.compare-header-top{display:flex;align-items:center;gap:16px}.compare-header-top h2{font-size:18px;font-weight:600;flex:1}.compare-controls{display:flex;align-items:center;gap:12px}.compare-controls .preview-text-input{flex:1}.compare-body{flex:1;overflow-y:auto;overflow-x:auto;padding:0 24px 24px}.compare-grid{display:grid;min-width:0}.compare-col{border-right:1px solid var(--color-border);padding:0 20px;min-width:0}.compare-col:first-child{padding-left:0}.compare-col:last-child{border-right:none;padding-right:0}.compare-col-header{padding:16px 0 10px;border-bottom:1px solid var(--color-border);margin-bottom:12px}.compare-col-name{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.compare-col-name>span:first-child{font-size:14px;font-weight:600}.compare-col-remove{margin-left:auto;background:none;border:1px solid var(--color-border);border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;color:var(--color-muted);flex-shrink:0}.compare-col-remove:hover{border-color:#d32f2f;color:#d32f2f}.compare-preview-text{line-height:1.4;word-break:break-word;padding:12px 0;border-bottom:1px solid var(--color-border);margin-bottom:16px;overflow-wrap:anywhere}.compare-weights-section h4{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin-bottom:8px}.compare-weight-row{display:flex;align-items:baseline;gap:8px;padding:4px 0;border-bottom:1px solid var(--color-border);overflow:hidden}.compare-weight-label{font-size:11px;color:var(--color-muted);min-width:36px;flex-shrink:0}.css-snippet{position:relative}.css-snippet pre{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:12px;font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:12px;line-height:1.6;overflow-x:auto;white-space:pre;color:var(--color-text)}.css-snippet-copy{position:absolute;top:8px;right:8px;font-size:11px;padding:2px 8px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);cursor:pointer;color:var(--color-muted)}.css-snippet-copy:hover{color:var(--color-text);background:var(--color-bg)}.login-link{font-size:12px;color:var(--color-muted);text-decoration:none;padding:4px 8px;border-radius:var(--radius);border:1px solid var(--color-border)}.login-link:hover{color:var(--color-accent);border-color:var(--color-accent)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px;width:100%;max-width:440px;display:flex;flex-direction:column;gap:16px}.login-back{font-size:13px;color:var(--color-muted);text-decoration:none}.login-back:hover{color:var(--color-accent)}.login-card h2{font-size:20px;font-weight:600}.login-description{color:var(--color-muted);font-size:13px;line-height:1.6}.login-status-row{display:flex;align-items:center;gap:10px;font-size:13px}.login-label{color:var(--color-muted)}.login-badge{padding:2px 8px;border-radius:10px;font-size:12px;font-weight:500}.login-badge--set{background:#e6f4ea;color:#1e7e34}.login-badge--none{background:#f5f5f5;color:var(--color-muted)}.login-field{display:flex}.login-input{flex:1;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;font-family:monospace;outline:none}.login-input:focus{border-color:var(--color-accent)}.login-actions{display:flex;gap:8px;flex-wrap:wrap}.login-btn{padding:7px 16px;border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);font-size:13px;cursor:pointer}.login-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.login-btn:disabled{opacity:.4;cursor:default}.login-btn--primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.login-btn--primary:hover:not(:disabled){background:#1558b0;color:#fff}.login-btn--danger{color:#c62828;border-color:#e57373}.login-btn--danger:hover:not(:disabled){background:#ffebee;border-color:#c62828}.login-feedback{font-size:13px;padding:8px 12px;border-radius:var(--radius)}.login-feedback--ok{background:#e6f4ea;color:#1e7e34}.login-feedback--err{background:#ffebee;color:#c62828}
