:root{--color-teal:#05b59f;--color-blue:#0f9ad6;--color-pink:#d41b5d;--color-lavender:#be9cc9;--color-dark:#1a1a2e;--color-gray-900:#212529;--color-gray-700:#495057;--color-gray-500:#868e96;--color-gray-300:#dee2e6;--color-gray-100:#f8f9fa;--color-white:#ffffff;--font-sans:system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:"SF Mono", SFMono-Regular, ui-monospace, "DejaVu Sans Mono", Menlo, Consolas, monospace;--max-width:1140px;--content-width:780px}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);color:var(--color-gray-900);line-height:1.7;background:var(--color-white)}a{color:var(--color-blue);text-decoration:none;transition:color .2s}a:hover{color:var(--color-teal)}img{max-width:100%;height:auto;display:block}.site-header{background:var(--color-dark);color:var(--color-white);position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.15)}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:64px}.site-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--color-white)}.site-brand:hover{color:var(--color-teal)}.site-brand img{height:40px;width:auto}.site-nav ul{list-style:none;display:flex;gap:.25rem;flex-wrap:wrap}.site-nav a{color:rgba(255,255,255,.8);font-size:.875rem;font-weight:500;padding:.4rem .75rem;border-radius:6px;transition:all .2s}.site-nav a:hover,.site-nav a.active{color:var(--color-white);background:rgba(255,255,255,.1)}.site-nav .ancestor>a{color:var(--color-teal)}.nav-toggle{display:none;background:0 0;border:none;color:var(--color-white);font-size:1.5rem;cursor:pointer;padding:.25rem}@media(max-width:767px){.nav-toggle{display:block}.site-nav{display:none;position:absolute;top:64px;left:0;right:0;background:var(--color-dark);padding:1rem;border-top:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px rgba(0,0,0,.2)}.site-nav.open{display:block}.site-nav ul{flex-direction:column;gap:0}.site-nav a{display:block;padding:.75rem 1rem;border-radius:0}}.site-main{min-height:calc(100vh - 64px - 200px)}.hero{background:linear-gradient(135deg,var(--color-dark) 0%,#16213e 100%);color:var(--color-white);padding:5rem 1.5rem;text-align:center}.hero h1{font-size:clamp(2rem,5vw,3.25rem);font-weight:800;line-height:1.2;margin-bottom:1rem}.hero h1 .accent{background:linear-gradient(135deg,var(--color-teal),var(--color-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero p{font-size:1.2rem;color:rgba(255,255,255,.75);max-width:640px;margin:0 auto 2rem;line-height:1.6}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-block;padding:.75rem 1.75rem;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .2s;text-decoration:none}.btn-primary{background:var(--color-teal);color:var(--color-white)}.btn-primary:hover{background:#049383;color:var(--color-white)}.btn-outline{border:2px solid rgba(255,255,255,.3);color:var(--color-white)}.btn-outline:hover{border-color:var(--color-teal);color:var(--color-teal)}.section{max-width:var(--max-width);margin:0 auto;padding:3rem 1.5rem}.section-header{margin-bottom:2rem}.section-header h2{font-size:1.75rem;font-weight:700;color:var(--color-gray-900)}.section-header p{color:var(--color-gray-500);margin-top:.5rem}.post-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:640px){.post-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.post-grid{grid-template-columns:repeat(3,1fr)}}.post-card{background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:10px;overflow:hidden;transition:transform .2s,box-shadow .2s}.post-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,8%)}.post-card-body{padding:1.25rem}.post-card-meta{font-size:.8rem;color:var(--color-gray-500);margin-bottom:.5rem;display:flex;gap:.75rem;flex-wrap:wrap}.post-card h3{font-size:1.05rem;font-weight:600;line-height:1.4;margin-bottom:.5rem}.post-card h3 a{color:var(--color-gray-900)}.post-card h3 a:hover{color:var(--color-blue)}.post-card .summary{font-size:.9rem;color:var(--color-gray-700);line-height:1.6}.page-list{list-style:none}.page-list-item{padding:1rem 0;border-bottom:1px solid var(--color-gray-300)}.page-list-item:last-child{border-bottom:none}.page-list-item h3{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.page-list-item h3 a{color:var(--color-gray-900)}.page-list-item h3 a:hover{color:var(--color-blue)}.page-list-item .meta{font-size:.8rem;color:var(--color-gray-500)}.page-list-item .summary{font-size:.9rem;color:var(--color-gray-700);margin-top:.35rem}.page-header{background:linear-gradient(135deg,var(--color-dark) 0%,#16213e 100%);color:var(--color-white);padding:3rem 1.5rem}.page-header-inner{max-width:var(--content-width);margin:0 auto}.page-header h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;line-height:1.25;margin-bottom:.75rem}.page-header .meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.9rem;color:rgba(255,255,255,.65)}.page-header .meta time{color:rgba(255,255,255,.65)}.page-header .meta .author{color:var(--color-teal)}.page-content{max-width:var(--content-width);margin:0 auto;padding:2.5rem 1.5rem 4rem}.page-content h1{font-size:2rem;margin:2.5rem 0 1rem;font-weight:700}.page-content h2{font-size:1.5rem;margin:2rem 0 .75rem;font-weight:700;color:var(--color-dark)}.page-content h3{font-size:1.25rem;margin:1.75rem 0 .5rem;font-weight:600}.page-content h4{font-size:1.1rem;margin:1.5rem 0 .5rem;font-weight:600}.page-content p{margin-bottom:1.25rem}.page-content ul,.page-content ol{margin:1rem 0 1.25rem 1.5rem}.page-content li{margin-bottom:.35rem}.page-content blockquote{border-left:4px solid var(--color-teal);margin:1.5rem 0;padding:1rem 1.5rem;background:var(--color-gray-100);border-radius:0 8px 8px 0;color:var(--color-gray-700)}.page-content blockquote p:last-child{margin-bottom:0}.page-content pre{background:var(--color-gray-900);color:#e9ecef;padding:1.25rem;border-radius:8px;overflow-x:auto;margin:1.5rem 0;font-size:.875rem;line-height:1.6}.page-content code{font-family:var(--font-mono);font-size:.875em}.page-content :not(pre)>code{background:var(--color-gray-100);padding:.15em .4em;border-radius:4px;color:var(--color-pink)}.page-content figure{margin:2rem 0}.page-content figcaption{font-size:.85rem;color:var(--color-gray-500);text-align:center;margin-top:.5rem;font-style:italic}.page-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}.page-content th,.page-content td{padding:.75rem 1rem;border:1px solid var(--color-gray-300);text-align:left}.page-content th{background:var(--color-gray-100);font-weight:600}.page-content hr{border:none;border-top:2px solid var(--color-gray-300);margin:2rem 0}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-gray-300)}.tag-list a{display:inline-block;background:var(--color-gray-100);color:var(--color-gray-700);padding:.3rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;transition:all .2s}.tag-list a:hover{background:var(--color-teal);color:var(--color-white)}.pagination{display:flex;justify-content:center;gap:.5rem;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--color-gray-300)}.pagination a,.pagination span{padding:.5rem 1rem;border-radius:6px;font-size:.9rem}.pagination a{background:var(--color-gray-100);color:var(--color-gray-700)}.pagination a:hover{background:var(--color-teal);color:var(--color-white)}.site-footer{background:var(--color-dark);color:rgba(255,255,255,.6);padding:3rem 1.5rem}.footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.footer-brand{font-size:1.25rem;font-weight:700;color:var(--color-white)}.footer-brand .logo-dot{color:var(--color-teal)}.footer-desc{font-size:.875rem;max-width:480px}.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;list-style:none}.footer-links a{color:rgba(255,255,255,.6);font-size:.875rem}.footer-links a:hover{color:var(--color-teal)}.footer-copy{font-size:.8rem;color:rgba(255,255,255,.35);margin-top:1rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.view-all{display:inline-block;margin-top:1.5rem;font-weight:600;color:var(--color-teal)}.view-all:hover{color:var(--color-blue)}.view-all::after{content:' \2192'}