*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--green-600:#16a34a;--green-700:#15803d;--green-50:#f0fdf4;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--radius:8px;--max-width:1100px}html{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--gray-800);background:#fff;-webkit-font-smoothing:antialiased}body{min-height:100vh;display:flex;flex-direction:column}a{color:var(--green-700);text-decoration:none;transition:color .15s}a:hover{color:var(--green-600);text-decoration:underline}img{max-width:100%;display:block}.site-header{background:var(--gray-900);color:#fff;padding:.75rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.site-header-inner{max-width:var(--max-width);margin:0 auto;justify-content:space-between}.site-header-inner,.site-logo{display:flex;align-items:center}.site-logo{font-size:1.25rem;font-weight:700;color:#fff;text-decoration:none;gap:.5rem}.site-logo:hover{color:var(--green-600);text-decoration:none}.site-nav{display:flex;gap:1.5rem;font-size:.9rem}.site-nav a{color:var(--gray-300)}.site-nav a:hover{color:#fff;text-decoration:none}.site-main{flex:1 1;max-width:var(--max-width);margin:0 auto;padding:2rem 1.5rem;width:100%}.site-footer{background:var(--gray-50);border-top:1px solid var(--gray-200);padding:2rem 1.5rem;margin-top:auto;font-size:.85rem;color:var(--gray-500)}.site-footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.hero{background:linear-gradient(135deg,var(--green-50),#ecfdf5);border:1px solid #bbf7d0;border-radius:var(--radius);padding:2.5rem 2rem;margin-bottom:2.5rem;text-align:center}.hero h1{font-size:2rem;color:var(--gray-900);margin-bottom:.5rem}.hero p{color:var(--gray-600);font-size:1.05rem;max-width:600px;margin:0 auto}.section-title{font-size:1.25rem;font-weight:700;color:var(--gray-900);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--green-600);display:inline-block}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2.5rem}.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:1rem 1.25rem;transition:border-color .15s,box-shadow .15s}.card:hover{border-color:var(--green-600);box-shadow:0 2px 8px rgba(22,163,74,.08)}.card-title{font-weight:600;color:var(--gray-800);margin-bottom:.25rem}.card-meta{font-size:.8rem;color:var(--gray-500)}.page-list{list-style:none;display:flex;flex-direction:column;gap:.25rem;margin-bottom:2.5rem}.page-list li{padding:.5rem .75rem;border-radius:6px;transition:background .15s}.page-list li:hover{background:var(--gray-50)}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:.5rem;gap:.5rem;margin-bottom:2.5rem}.category-pill{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:6px;font-size:.9rem;transition:border-color .15s}.category-pill:hover{border-color:var(--green-600)}.category-count{color:var(--gray-500);font-size:.8rem;font-weight:600}.breadcrumb{font-size:.85rem;margin-bottom:1.5rem}.breadcrumb,.breadcrumb a{color:var(--gray-500)}.breadcrumb a:hover{color:var(--green-700)}.tag{display:inline-block;background:var(--gray-100);color:var(--gray-600);padding:.2rem .65rem;border-radius:20px;font-size:.8rem}.article-header{margin-bottom:2rem}.article-header h1{font-size:1.75rem;line-height:1.3;color:var(--gray-900);margin-bottom:.75rem}.article-tags{display:flex;gap:.5rem;flex-wrap:wrap}.article-placeholder{background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:var(--radius);padding:2rem;color:var(--gray-500);text-align:center;margin-bottom:2.5rem}.related-section h2{font-size:1.1rem;font-weight:700;color:var(--gray-800);margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--gray-200)}@media (max-width:640px){.hero{padding:1.5rem 1rem}.hero h1{font-size:1.5rem}.card-grid{grid-template-columns:1fr}.site-nav{display:none}.site-footer-inner{flex-direction:column;text-align:center}}