*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-mono);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--link);text-decoration:underline}a:hover{text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer}:root{--font-mono: "Google Sans Code", monospace;--font-sans: "Noto Sans", sans-serif;--bg: #f5f5f5;--bg-card: #fff;--text: #000;--text-muted: #666;--link: #0a68ea;--border: #ddd;--border-strong: #000;--accent: #0a68ea;--accent-bg: #e8f1fd;--success: #22863a;--success-bg: #e6f4ea;--warning: #b08800;--warning-bg: #fff8e6;--gap-xs: 4px;--gap-sm: 8px;--gap-md: 12px;--gap-lg: 16px;--gap-xl: 24px;--radius: 4px}#root{min-height:100dvh;display:flex;flex-direction:column}.app{flex:1;display:flex;flex-direction:column;padding:var(--gap-lg);max-width:800px;margin:0 auto;width:100%}.header{display:flex;flex-direction:column;gap:var(--gap-sm);padding-bottom:var(--gap-lg);border-bottom:1px solid var(--border);margin-bottom:var(--gap-lg)}.header-title{font-size:1rem;font-weight:600}.header-subtitle{color:var(--text-muted);font-size:.875rem}.section{display:flex;flex-direction:column;gap:var(--gap-md);margin-bottom:var(--gap-xl)}.section-title{font-size:.875rem;font-weight:600;border-bottom:1px solid var(--border);padding-bottom:var(--gap-sm)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--gap-md);display:flex;flex-direction:column;gap:var(--gap-sm)}.card-header{display:flex;align-items:center;gap:var(--gap-sm)}.card-icon{flex-shrink:0}.card-title{font-weight:500;font-size:.875rem}.card-description{font-size:.75rem;color:var(--text-muted)}.card-tags{display:flex;flex-wrap:wrap;gap:var(--gap-xs)}.tag{font-size:.625rem;padding:2px 6px;border-radius:2px;background:var(--bg);border:1px solid var(--border)}.tag--free{background:var(--success-bg);border-color:var(--success);color:var(--success)}.tag--paid{background:var(--warning-bg);border-color:var(--warning);color:var(--warning)}.tag--self-hosted{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.tag--cyrus{background:#f0f4ff;border-color:#6366f1;color:#6366f1}.section-note{display:flex;align-items:center;gap:var(--gap-sm);font-size:.75rem;color:var(--text-muted);margin-bottom:var(--gap-md)}.card--clickable{cursor:pointer;transition:border-color .1s}.card--clickable:hover{border-color:var(--border-strong)}.card--selected{border-color:var(--accent);background:var(--accent-bg)}.quiz{display:flex;flex-direction:column;gap:var(--gap-lg)}.question{display:flex;flex-direction:column;gap:var(--gap-md)}.question-text{font-size:.875rem;font-weight:500}.options{display:flex;flex-direction:column;gap:var(--gap-sm)}.option{display:flex;align-items:center;gap:var(--gap-sm);padding:var(--gap-sm) var(--gap-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.875rem}.option:hover{border-color:var(--border-strong)}.option--selected{border-color:var(--accent);background:var(--accent-bg)}.results{display:flex;flex-direction:column;gap:var(--gap-md)}.result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--gap-md);display:flex;flex-direction:column;gap:var(--gap-sm)}.result-card--primary{border-color:var(--accent);border-width:2px}.result-rank{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.result-title{font-weight:600;font-size:1rem;display:flex;align-items:center;gap:var(--gap-sm)}.result-why{font-size:.75rem;color:var(--text-muted)}.result-link{font-size:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--gap-sm);padding:var(--gap-sm) var(--gap-md);border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--bg-card);font-size:.875rem}.btn:hover{background:var(--bg)}.btn--primary{background:var(--text);color:var(--bg-card);border-color:var(--text)}.btn--primary:hover{opacity:.9;background:var(--text)}.btn-row{display:flex;gap:var(--gap-sm)}.nav{display:flex;gap:var(--gap-xs);border-bottom:1px solid var(--border);margin-bottom:var(--gap-lg)}.nav-item{padding:var(--gap-sm) var(--gap-md);border:none;background:none;font-size:.75rem;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px}.nav-item:hover{color:var(--text)}.nav-item--active{color:var(--text);border-bottom-color:var(--text)}.grid{display:grid;gap:var(--gap-md);grid-template-columns:1fr}@media(min-width:500px){.grid--2{grid-template-columns:repeat(2,1fr)}}.method-cards{display:flex;flex-direction:column;gap:var(--gap-md)}.method-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--gap-md);display:flex;flex-direction:column;gap:var(--gap-sm)}.method-header{display:flex;align-items:flex-start;gap:var(--gap-sm)}.method-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.method-info{flex:1;display:flex;flex-direction:column;gap:var(--gap-xs)}.method-name{font-weight:600;font-size:.875rem}.method-desc{font-size:.75rem;color:var(--text-muted)}.method-details{font-size:.75rem;display:flex;flex-direction:column;gap:var(--gap-xs);padding-top:var(--gap-sm);border-top:1px solid var(--border)}.method-detail{display:flex;gap:var(--gap-sm)}.method-detail-label{color:var(--text-muted);min-width:60px}.resources{display:flex;flex-direction:column;gap:var(--gap-md)}.resource-group{display:flex;flex-direction:column;gap:var(--gap-sm)}.resource-group-title{font-size:.75rem;font-weight:600;color:var(--text-muted)}.resource-item{display:flex;align-items:center;gap:var(--gap-sm);font-size:.875rem;padding:var(--gap-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.resource-item>svg{flex-shrink:0}.resource-item a{flex:1}.footer{margin-top:auto;padding-top:var(--gap-lg);border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted);display:flex;flex-direction:column;gap:var(--gap-sm)}.progress{display:flex;gap:var(--gap-xs);margin-bottom:var(--gap-md)}.progress-dot{width:8px;height:8px;border-radius:50%;background:var(--border)}.progress-dot--active{background:var(--text)}.progress-dot--done{background:var(--accent)}.detail{display:flex;flex-direction:column;gap:var(--gap-lg)}.detail-header{display:flex;flex-direction:column;gap:var(--gap-sm)}.detail-back{font-size:.75rem;color:var(--text-muted);display:inline-flex;align-items:center;gap:var(--gap-xs);cursor:pointer;background:none;border:none;padding:0}.detail-back:hover{color:var(--text)}.detail-title{font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:var(--gap-sm)}.detail-section{display:flex;flex-direction:column;gap:var(--gap-sm)}.detail-section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.detail-list{display:flex;flex-direction:column;gap:var(--gap-xs);font-size:.875rem}.detail-list li{margin-left:var(--gap-lg)}.code-block{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:var(--gap-md);font-family:var(--font-mono);font-size:.75rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word}code{background:var(--bg);padding:2px 4px;border-radius:2px;font-family:var(--font-mono);font-size:.85em}.learn{display:flex;flex-direction:column;gap:var(--gap-md)}.guides-list{display:flex;flex-direction:column;gap:var(--gap-xs)}.guide-link{font-size:.875rem;padding:var(--gap-sm);background:var(--accent-bg);border-radius:var(--radius);text-decoration:none}.guide-link:hover{background:var(--bg)}.course-card{background:var(--bg-card);border:2px solid var(--accent);border-radius:var(--radius);padding:var(--gap-md);display:flex;flex-direction:column;gap:var(--gap-sm)}.course-title{font-weight:600;font-size:.875rem}.course-desc{font-size:.75rem;color:var(--text-muted)}
