.ingredient-card-link{text-decoration:none;color:inherit}.ingredient-card{padding:14px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);border-left:3px solid var(--category-color);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.ingredient-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.ingredient-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.ingredient-name{margin:0;font-size:14px;font-weight:600;color:var(--color-text)}.category-badge{font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.3px;padding:3px 6px;background:var(--category-color);color:#fff;border-radius:3px;white-space:nowrap}.ingredient-subcategory{margin:6px 0 0;font-size:12px;color:var(--color-text-muted);text-transform:capitalize}.ingredient-card-compact{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;cursor:pointer;transition:background-color var(--transition-fast)}.ingredient-card-compact:hover{background-color:var(--color-bg-subtle)}.ingredient-card-compact .ingredient-name{font-size:13px;font-weight:500}.category-dot{width:6px;height:6px;border-radius:50%;background:var(--category-color)}.home-page{display:flex;flex-direction:column;height:calc(100vh - 109px);padding:24px;gap:20px}.home-header{text-align:center}.home-header h1{margin:0 0 4px;font-size:24px;font-weight:600;color:var(--color-text)}.home-header p{margin:0;font-size:14px;color:var(--color-text-muted)}.stats-row{display:flex;justify-content:center;align-items:center;gap:32px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-value{font-size:24px;font-weight:700;color:var(--color-primary);font-variant-numeric:tabular-nums}.stat-label{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.stat-divider{width:1px;height:32px;background:var(--color-border)}.graph-container{flex:1;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;position:relative;min-height:400px;max-width:1000px;margin:0 auto;width:100%}.graph-container svg{display:block;cursor:grab}.graph-container svg:active{cursor:grabbing}.graph-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--color-text-muted);font-size:14px}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.graph-actions{position:absolute;top:12px;right:12px}.refresh-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background-color var(--transition-fast),border-color var(--transition-fast)}.refresh-btn:hover{background:var(--color-bg-subtle);border-color:var(--color-text-muted)}.refresh-btn svg{width:14px;height:14px}.graph-hint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);margin:0;padding:6px 12px;font-size:12px;color:var(--color-text-muted);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm)}@media (max-width: 768px){.home-page{padding:16px;height:auto;min-height:calc(100vh - 109px)}.home-header h1{font-size:20px}.stats-row{gap:20px}.stat-value{font-size:20px}.graph-container{min-height:350px}.graph-hint{font-size:11px;padding:4px 8px}}@media (max-width: 480px){.stats-row{gap:12px}.stat-value{font-size:18px}.stat-label{font-size:10px}.stat-divider{height:24px}}.pairing-list{display:flex;flex-direction:column;gap:10px}.pairing-list-empty{padding:20px;text-align:center;color:var(--color-text-muted);background:var(--color-bg-subtle);border-radius:var(--radius-sm);font-size:14px}.pairing-card-link{text-decoration:none;color:inherit}.pairing-card{padding:14px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);border-left:3px solid var(--category-color);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.pairing-card:hover{transform:translate(2px);box-shadow:var(--shadow-sm)}.pairing-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.pairing-info{display:flex;flex-direction:column;gap:2px}.pairing-name{font-size:14px;font-weight:600;color:var(--color-text)}.pairing-category{font-size:11px;color:var(--color-text-muted);text-transform:capitalize}.pairing-score{font-size:15px;font-weight:700;padding:3px 10px;border-radius:4px;font-variant-numeric:tabular-nums}.pairing-score.excellent{background:#2b8a3e26;color:var(--color-success)}.pairing-score.good{background:#e6770026;color:var(--color-warning)}.pairing-score.moderate{background:#c92a2a26;color:var(--color-error)}.pairing-compounds{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.compound-badge{font-size:10px;padding:3px 6px;background:var(--color-bg-subtle);color:var(--color-text-secondary);border-radius:3px}.compound-more{font-size:10px;padding:3px 6px;color:var(--color-text-muted)}.pairing-explanation{margin:0 0 10px;font-size:13px;color:var(--color-text-secondary);line-height:1.5}.pairing-meta{font-size:11px;color:var(--color-text-muted)}.compound-badge-full{padding:10px;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.compound-badge-full.clickable{cursor:pointer;transition:background-color var(--transition-fast)}.compound-badge-full.clickable:hover{background:var(--color-border)}.compound-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.compound-name{font-size:13px;font-weight:600;color:var(--color-text)}.compound-concentration{font-size:11px;font-weight:600;padding:2px 6px;background:var(--color-primary);color:#fff;border-radius:3px}.compound-common-name{display:block;font-size:11px;color:var(--color-text-muted);font-style:italic;margin-bottom:4px}.compound-odor{margin:6px 0 0;font-size:12px;color:var(--color-text-secondary);line-height:1.4}.compound-tag{display:inline-block;font-size:11px;padding:3px 8px;background:var(--color-bg-subtle);color:var(--color-text-secondary);border-radius:3px}.compound-tag.clickable{cursor:pointer;transition:background-color var(--transition-fast)}.compound-tag.clickable:hover{background:var(--color-border)}.graph-explorer{position:relative;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.graph-explorer svg{display:block;cursor:grab}.graph-explorer svg:active{cursor:grabbing}.graph-explorer .node{cursor:pointer}.graph-explorer .node circle{transition:stroke-width var(--transition-fast)}.graph-explorer .node text{pointer-events:none;-webkit-user-select:none;user-select:none}.graph-explorer .links line{pointer-events:none}.graph-controls{position:absolute;bottom:12px;right:12px;display:flex;gap:6px}.graph-controls button{padding:6px 10px;font-size:11px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);transition:background-color var(--transition-fast)}.graph-controls button:hover{background:var(--color-bg-subtle)}.ingredient-page{max-width:1100px;margin:0 auto;padding:24px}.loading,.error{text-align:center;padding:60px 20px;color:var(--color-text-muted)}.error h2{margin-bottom:12px;color:var(--color-error)}.back-link{color:var(--color-primary);text-decoration:none}.back-link:hover{text-decoration:underline}.ingredient-header{padding:32px;background:linear-gradient(135deg,var(--category-color) 0%,color-mix(in srgb,var(--category-color) 70%,black) 100%);border-radius:var(--radius-lg);color:#fff;margin-bottom:24px}.header-content{max-width:700px}.breadcrumb{margin-bottom:12px;font-size:13px;opacity:.9}.breadcrumb a{color:#fff;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb span{margin:0 6px}.ingredient-header h1{margin:0 0 12px;font-size:28px;font-weight:700}.ingredient-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px}.ingredient-header .category-badge{padding:4px 10px;background:#fff3;border-radius:4px;font-size:12px;text-transform:capitalize}.subcategory{font-size:13px;opacity:.9}.aliases{margin:0;font-size:13px;opacity:.8;font-style:italic}.ingredient-content{display:grid;grid-template-columns:1fr 340px;gap:24px}@media (max-width: 900px){.ingredient-content{grid-template-columns:1fr}}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{margin:0;font-size:18px;font-weight:600;color:var(--color-text)}.section-count{font-size:13px;color:var(--color-text-muted)}.pairings-section{min-width:0}.compare-cta{margin-top:20px;padding:16px;background:var(--color-bg-subtle);border-radius:var(--radius-sm);text-align:center}.compare-cta p{margin:0 0 10px;color:var(--color-text-secondary);font-size:13px}.compare-link{display:inline-block;padding:8px 16px;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background-color var(--transition-fast)}.compare-link:hover{background:var(--color-primary-hover);text-decoration:none}.ingredient-sidebar{display:flex;flex-direction:column;gap:20px}.ingredient-sidebar h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--color-text)}.compounds-section{padding:16px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md)}.compounds-list{display:flex;flex-direction:column;gap:10px}.compounds-more{margin:10px 0 0;font-size:12px;color:var(--color-text-muted);text-align:center}.no-compounds{color:var(--color-text-muted);font-size:13px;font-style:italic}.graph-section{padding:16px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md)}.graph-section .graph-explorer{margin-bottom:10px}.explore-link{display:block;text-align:center;color:var(--color-primary);text-decoration:none;font-size:13px}.explore-link:hover{text-decoration:underline}@media (max-width: 768px){.ingredient-page{padding:16px}.ingredient-header{padding:24px}.ingredient-header h1{font-size:24px}}.search-bar{position:relative;width:100%}.search-input{width:100%;padding:10px 14px;font-size:14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-elevated);color:var(--color-text);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input::placeholder{color:var(--color-text-muted)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.search-loading{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);font-size:12px}.search-results{position:absolute;top:100%;left:0;right:0;margin-top:4px;padding:0;list-style:none;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:280px;overflow-y:auto;z-index:100}.search-result-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;cursor:pointer;transition:background-color var(--transition-fast)}.search-result-item:hover,.search-result-item.selected{background-color:var(--color-bg-subtle)}.result-name{font-size:14px;font-weight:500;color:var(--color-text)}.result-category{font-size:11px;color:var(--color-text-muted);text-transform:capitalize;padding:2px 6px;background:var(--color-bg-subtle);border-radius:3px}.search-no-results{position:absolute;top:100%;left:0;right:0;margin-top:4px;padding:12px 14px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);text-align:center;font-size:13px}.compare-page{max-width:900px;margin:0 auto;padding:32px 24px}.compare-header{text-align:center;margin-bottom:32px}.compare-header h1{margin:0 0 8px;font-size:24px;font-weight:600;color:var(--color-text)}.compare-header p{margin:0;font-size:14px;color:var(--color-text-muted)}.compare-selection{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:start;margin-bottom:32px}.selection-slot{background:var(--color-bg-elevated);padding:16px;border:1px solid var(--color-border);border-radius:var(--radius-md)}.selection-slot h3{margin:0 0 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);font-weight:600}.selected-ingredient{position:relative}.selected-ingredient .clear-button{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border:none;border-radius:50%;background:var(--color-error);color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast)}.selected-ingredient .clear-button:hover{transform:scale(1.1)}.selection-controls{display:flex;align-items:center;padding-top:36px}.swap-button{width:40px;height:40px;border:1px solid var(--color-border);border-radius:50%;background:var(--color-bg-elevated);font-size:18px;color:var(--color-text-secondary);transition:border-color var(--transition-fast),color var(--transition-fast)}.swap-button:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.swap-button:disabled{opacity:.4;cursor:not-allowed}.compare-loading,.compare-error,.compare-empty{text-align:center;padding:40px 24px;background:var(--color-bg-subtle);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:14px}.compare-error{background:var(--color-error);color:#fff}.compare-results{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pairing-banner{display:flex;align-items:center;gap:20px;padding:20px;background:var(--score-color);border-radius:var(--radius-md);color:#fff;margin-bottom:24px}.banner-score{font-size:40px;font-weight:700;font-variant-numeric:tabular-nums}.banner-text{display:flex;flex-direction:column;gap:2px}.banner-text strong{font-size:11px;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.banner-text span{font-size:14px}.shared-compounds{background:var(--color-bg-elevated);padding:20px;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:20px}.shared-compounds h2{margin:0 0 20px;font-size:16px;font-weight:600;color:var(--color-text)}.shared-compounds h2 .count{font-weight:400;color:var(--color-text-muted);margin-left:6px}.compounds-comparison{display:flex;flex-direction:column;gap:12px}.compound-comparison-row{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center}.compound-center{text-align:center;min-width:120px}.compound-center strong{display:block;font-size:13px;color:var(--color-text)}.compound-center .common-name{display:block;font-size:11px;color:var(--color-text-muted);font-style:italic}.concentration-bar{height:28px;border-radius:4px;display:flex;align-items:center;padding:0 10px;font-size:11px;font-weight:600;color:#fff}.concentration-bar.left{justify-content:flex-end;background:linear-gradient(to left,var(--color),transparent);margin-left:auto;width:var(--width);min-width:36px}.concentration-bar.right{justify-content:flex-start;background:linear-gradient(to right,var(--color),transparent);width:var(--width);min-width:36px}.no-shared{text-align:center;color:var(--color-text-muted);font-size:14px;font-style:italic;padding:20px}.clear-all{display:block;width:100%;padding:12px;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;color:var(--color-text-secondary);transition:background-color var(--transition-fast)}.clear-all:hover{background:var(--color-border)}@media (max-width: 768px){.compare-page{padding:24px 16px}.compare-selection{grid-template-columns:1fr;gap:12px}.selection-controls{justify-content:center;padding:0}.swap-button{transform:rotate(90deg)}.compound-comparison-row{grid-template-columns:1fr;gap:6px}.concentration-bar.left,.concentration-bar.right{width:100%;max-width:var(--width)}.compound-center{order:-1;text-align:left;padding:8px 0;border-bottom:1px solid var(--color-border);margin-bottom:4px}}.explore-page{display:flex;height:calc(100vh - 109px);overflow:hidden}.explore-sidebar{width:280px;background:var(--color-bg-elevated);border-right:1px solid var(--color-border);overflow-y:auto;flex-shrink:0}.sidebar-section{padding:16px;border-bottom:1px solid var(--color-border)}.sidebar-section h3{margin:0 0 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);font-weight:600}.center-ingredient{position:relative}.change-center{position:absolute;top:6px;right:6px;padding:4px 8px;font-size:10px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);transition:background-color var(--transition-fast)}.change-center:hover{background:var(--color-bg-subtle)}.filter-label{display:block;margin-bottom:14px;font-size:12px;color:var(--color-text-secondary)}.filter-label input[type=range]{display:block;width:100%;margin-top:6px;accent-color:var(--color-primary)}.selected-section{background:var(--color-primary-subtle)}.selected-info{margin-bottom:10px}.selected-info strong{display:block;font-size:14px;color:var(--color-text)}.selected-category{font-size:11px;color:var(--color-text-muted);text-transform:capitalize}.selected-actions{display:flex;gap:6px}.selected-actions button{flex:1;padding:8px;font-size:11px;font-weight:500;background:var(--color-primary);color:#fff;border:none;border-radius:4px;transition:background-color var(--transition-fast)}.selected-actions button:hover{background:var(--color-primary-hover)}.legend{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--color-text-secondary)}.legend-node{width:14px;height:14px;border-radius:50%;background:var(--color-text-muted);border:2px solid var(--color-bg-elevated);box-shadow:0 0 0 1px var(--color-border)}.legend-node.center{width:18px;height:18px;background:var(--color-primary)}.legend-line{width:24px;height:0;border-top:2px solid var(--color-text-muted)}.legend-line.thick{border-top-width:3px;opacity:.8}.legend-line.thin{border-top-width:1px;opacity:.4}.tips-list{margin:0;padding:0 0 0 16px;font-size:12px;color:var(--color-text-muted);line-height:1.7}.explore-main{flex:1;background:var(--color-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.explore-empty,.explore-loading,.explore-error,.explore-no-connections{text-align:center;padding:40px 24px}.explore-empty h2,.explore-no-connections h2{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--color-text)}.explore-empty p,.explore-no-connections p{margin:0;font-size:14px;color:var(--color-text-muted)}.explore-loading{color:var(--color-text-muted);font-size:14px}.explore-error{color:var(--color-error)}.explore-main .graph-explorer{width:100%;height:100%;border:none;border-radius:0;background:var(--color-bg)}@media (max-width: 768px){.explore-page{flex-direction:column;height:auto;min-height:calc(100vh - 109px)}.explore-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--color-border)}.explore-main{height:450px;min-height:450px}}.about-page{max-width:700px;margin:0 auto;padding:32px 24px}.about-header{text-align:center;margin-bottom:40px}.about-header h1{margin:0 0 8px;font-size:28px;font-weight:600;color:var(--color-text)}.about-header p{margin:0;font-size:15px;color:var(--color-text-muted)}.about-section{margin-bottom:36px}.about-section h2{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--color-text);padding-bottom:8px;border-bottom:1px solid var(--color-border)}.how-it-works{display:flex;flex-direction:column;gap:20px}.concept h3{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--color-text)}.concept p{margin:0;font-size:14px;line-height:1.6;color:var(--color-text-secondary)}.tech-list{margin:0;padding:0 0 0 20px;font-size:14px;line-height:1.8;color:var(--color-text-secondary)}.tech-list li{margin-bottom:4px}.references-list{margin:0;padding:0 0 0 20px;font-size:14px;line-height:1.8;color:var(--color-text-secondary)}.references-list li{margin-bottom:8px}.references-list a{color:var(--color-primary);text-decoration:underline}.references-list a:hover{text-decoration:none}@media (max-width: 600px){.about-page{padding:24px 16px}.about-header h1{font-size:24px}}.warmup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}.warmup-overlay.ready{animation:fadeOut .4s ease-out forwards;animation-delay:.4s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;pointer-events:none}}.warmup-content{text-align:center;max-width:400px;padding:32px 24px}.warmup-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;margin:0 auto 20px;animation:spin .8s linear infinite}.warmup-overlay.ready .warmup-spinner{display:none}@keyframes spin{to{transform:rotate(360deg)}}.warmup-content h2{margin:0 0 12px;font-size:20px;color:var(--color-text);font-weight:600}.warmup-explanation{color:var(--color-text-secondary);font-size:14px;line-height:1.6;margin:0 0 12px}.warmup-status{color:var(--color-text-muted);font-size:13px;font-style:italic;margin:0}.warmup-overlay.ready .warmup-status{color:var(--color-success);font-style:normal;font-weight:500}.warmup-ready-icon{width:40px;height:40px;background:var(--color-success);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;margin:16px auto 0;animation:popIn .2s ease-out}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 500px){.warmup-content{padding:24px 16px}.warmup-content h2{font-size:18px}.warmup-explanation{font-size:13px}}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:56px;background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1000}.nav-brand{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--color-text);text-decoration:none}.nav-brand:hover{text-decoration:none;color:var(--color-primary)}.nav-brand svg{width:20px;height:20px;color:var(--color-primary)}.nav-center{display:flex;gap:4px}.nav-center a{color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:500;padding:8px 16px;border-radius:var(--radius-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}.nav-center a:hover{color:var(--color-text);background:var(--color-bg-subtle);text-decoration:none}.nav-center a.active{color:var(--color-primary);background:var(--color-primary-subtle)}.nav-right{display:flex;align-items:center;gap:8px}.nav-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background-color var(--transition-fast),color var(--transition-fast)}.nav-icon-btn:hover{background:var(--color-bg-subtle);color:var(--color-text)}.nav-icon-btn svg{width:18px;height:18px}.github-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}.github-link:hover{background:var(--color-bg-subtle);color:var(--color-text);text-decoration:none}.github-link svg{width:18px;height:18px}.main-content{flex:1}.footer{padding:16px 24px;text-align:center;background:var(--color-bg-elevated);border-top:1px solid var(--color-border)}.footer p{margin:0;font-size:13px;color:var(--color-text-muted)}.footer a{color:var(--color-primary)}@media (max-width: 768px){.navbar{padding:0 16px}.nav-brand{font-size:14px}.nav-brand span{display:none}.nav-center a{padding:8px 12px;font-size:13px}}@media (max-width: 480px){.nav-center{gap:2px}.nav-center a{padding:8px}}:root{--color-bg: #f8f9fa;--color-bg-elevated: #ffffff;--color-bg-subtle: #f1f3f4;--color-border: #e0e0e0;--color-border-subtle: #eee;--color-text: #1a1a1a;--color-text-secondary: #555;--color-text-muted: #888;--color-primary: #4a90d9;--color-primary-hover: #3a7bc8;--color-primary-subtle: rgba(74, 144, 217, .1);--color-success: #2b8a3e;--color-warning: #e67700;--color-error: #c92a2a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--transition-fast: .15s ease;--transition-normal: .2s ease}[data-theme=dark]{--color-bg: #0f0f0f;--color-bg-elevated: #1a1a1a;--color-bg-subtle: #252525;--color-border: #333;--color-border-subtle: #2a2a2a;--color-text: #f0f0f0;--color-text-secondary: #b0b0b0;--color-text-muted: #777;--color-primary: #5a9fe9;--color-primary-hover: #4a8fd9;--color-primary-subtle: rgba(90, 159, 233, .15);--color-success: #40c057;--color-warning: #fab005;--color-error: #ff6b6b;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}img{max-width:100%;height:auto}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-subtle)}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
