﻿*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:"Inter","Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;font-size:1rem;line-height:1.6;color:#1a1a1a;background-color:#f7f7f8;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{color:#111827;line-height:1.25;font-weight:700;letter-spacing:-0.02em}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}@media(min-width: 640px){h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.875rem}}p{margin-bottom:1rem;line-height:1.8}a{color:#6366f1;text-decoration:none;transition:color 150ms ease}a:hover{color:#4f46e5;text-decoration:underline}img{max-width:100%;height:auto;display:block}code,kbd,samp{font-family:"JetBrains Mono","Fira Code","Cascadia Code",monospace;font-size:.9em}code:not([class]){background:#f4f4f5;color:#d73a49;padding:.1em .4em;border-radius:.25rem;border:1px solid #e4e4e7}pre{background:#f6f8fa;border:1px solid #e4e4e7;border-radius:.75rem;padding:1.5rem;overflow-x:auto;margin-bottom:1.5rem;position:relative}pre code{color:#1a1a1a;padding:0 !important;border:none !important;font-size:.875rem;line-height:1.7}blockquote{border-left:3px solid #6366f1;padding:1rem 1.5rem;margin:1.5rem 0;background:#fff;border-radius:0 .75rem .75rem 0;color:#6b7280;font-style:italic}blockquote p:last-child{margin-bottom:0}ul,ol{padding-left:1.5rem;margin-bottom:1rem}ul li,ol li{margin-bottom:.5rem;line-height:1.8}table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.875rem}table th,table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e4e4e7}table th{background:#fff;color:#111827;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}table tr:hover td{background:#fff}hr{border:none;border-top:1px solid #e4e4e7;margin:2rem 0}:focus-visible{outline:2px solid #6366f1;outline-offset:2px;border-radius:.25rem}::selection{background:rgba(62,168,255,.2);color:#111827}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f7f7f8}::-webkit-scrollbar-thumb{background:#e4e4e7;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6b7280}.site-main{flex:1}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}.reveal-delay-6{transition-delay:.6s}.highlight{margin:0}.highlight .hll{background-color:#fffbdd}.highlight .c,.highlight .cm,.highlight .cp,.highlight .cs,.highlight .c1{color:#6a737d;font-style:italic}.highlight .k,.highlight .kd,.highlight .kn,.highlight .kr{color:#d73a49;font-weight:bold}.highlight .o,.highlight .ow{color:#d73a49}.highlight .na,.highlight .nb{color:#005cc5}.highlight .s,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .s2,.highlight .se,.highlight .sh,.highlight .si,.highlight .sx,.highlight .s1,.highlight .ss{color:#032f62}.highlight .n,.highlight .nn,.highlight .no,.highlight .bp{color:#1a1a1a}.highlight .nf,.highlight .nc,.highlight .nd{color:#6f42c1}.highlight .m,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .mo,.highlight .il{color:#005cc5}.highlight .nv,.highlight .vc,.highlight .vg,.highlight .vi{color:#e36209}.highlight .nt{color:#22863a}.highlight .ni{color:#1a1a1a}.highlight .ne{color:#e36209}.highlight .p{color:#6b7280}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}@media(min-width: 768px){.container{padding:0 1.5rem}}@media(min-width: 1024px){.container{padding:0 2rem}}.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid #e4e4e7;height:64px;display:flex;align-items:center;box-shadow:0 1px 3px rgba(0,0,0,.06)}.site-nav{width:100%}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;gap:1.5rem}.site-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:#111827;font-weight:700;font-size:1.125rem;flex-shrink:0}.site-logo:hover{color:#6366f1;text-decoration:none}.site-logo .logo-icon{display:flex;align-items:center}.site-logo .logo-text{display:none}@media(min-width: 640px){.site-logo .logo-text{display:block}}.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;color:#1a1a1a}@media(min-width: 1024px){.nav-toggle{display:none}}.nav-toggle-bar{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform 250ms ease,opacity 250ms ease}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(1){transform:rotate(45deg) translate(5px, 5px)}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(2){opacity:0}.nav-toggle[aria-expanded=true] .nav-toggle-bar:nth-child(3){transform:rotate(-45deg) translate(5px, -5px)}.nav-menu{list-style:none;display:none;position:absolute;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid #e4e4e7;padding:1rem;gap:.5rem;flex-direction:column}.nav-menu.is-open{display:flex}@media(min-width: 1024px){.nav-menu{display:flex;position:static;background:none;border:none;padding:0;flex-direction:row;align-items:center}}.nav-link{display:block;padding:.5rem .75rem;color:#6b7280;font-size:.875rem;font-weight:500;border-radius:.5rem;text-decoration:none;transition:color 150ms ease,background 150ms ease;white-space:nowrap}.nav-link:hover{color:#111827;background:#f0f0f5;text-decoration:none}.nav-link--active{color:#6366f1;background:rgba(99,102,241,.08)}.site-footer{background:#fff;border-top:1px solid #e4e4e7;padding:4rem 0 2rem;margin-top:auto}.footer-inner{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:2.5rem}@media(min-width: 1024px){.footer-inner{grid-template-columns:1fr 2fr}}.footer-brand .footer-logo{font-size:1.125rem;font-weight:700;color:#111827;text-decoration:none;display:inline-block;margin-bottom:.75rem}.footer-brand .footer-logo:hover{color:#6366f1;text-decoration:none}.footer-brand .footer-tagline{color:#6366f1;font-size:.875rem;margin-bottom:.5rem}.footer-brand .footer-description{color:#6b7280;font-size:.875rem}.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.footer-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#6b7280;margin-bottom:1rem}.footer-list{list-style:none;padding:0}.footer-list li{margin-bottom:.5rem}.footer-link{color:#6b7280;font-size:.875rem;text-decoration:none;transition:color 150ms ease}.footer-link:hover{color:#6366f1;text-decoration:none}.footer-bottom{display:flex;flex-direction:column;gap:.75rem;padding-top:2rem;border-top:1px solid #e4e4e7;color:#9ca3af;font-size:.75rem}@media(min-width: 768px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}}.footer-rss{display:inline-flex;align-items:center;gap:.25rem}.page-wrapper{padding:4rem 0}.page-header{margin-bottom:2.5rem}.page-title{font-size:2.25rem;margin-bottom:1rem}@media(min-width: 768px){.page-title{font-size:3rem}}.page-description{font-size:1.125rem;color:#6b7280}.page-content{max-width:720px}.page-content h2{font-size:1.875rem;margin:2.5rem 0 1rem;padding-top:1.5rem;border-top:1px solid #e4e4e7}.page-content h2:first-child{margin-top:0;padding-top:0;border-top:none}.page-content h3{font-size:1.5rem;margin:2rem 0 .75rem}.page-content h4{font-size:1.25rem;margin:1.5rem 0 .75rem}.post-header{background:#fff;border-bottom:1px solid #e4e4e7;padding:4rem 0 2.5rem}.post-categories{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.post-title{font-size:2.25rem;margin-bottom:1.5rem;line-height:1.2}@media(min-width: 768px){.post-title{font-size:3rem}}.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;color:#6b7280;font-size:.875rem}.post-date,.post-author,.reading-time{display:flex;align-items:center;gap:.25rem}.icon{width:1em;height:1em;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.post-description{margin-top:1.5rem;font-size:1.125rem;color:#6b7280;max-width:65ch}.post-hero-image img{width:100%;max-height:500px;object-fit:cover}.post-content-wrapper{padding:2.5rem 0 4rem}.post-layout{display:grid;grid-template-columns:1fr;gap:2.5rem}@media(min-width: 1280px){.post-layout{grid-template-columns:minmax(0, 1fr) 280px;align-items:start}}.post-content{min-width:0;font-size:1.125rem;line-height:1.8}.post-content h2{font-size:1.875rem;margin:3rem 0 1rem;padding-top:2rem;border-top:1px solid #e4e4e7;scroll-margin-top:calc(64px + 1rem)}.post-content h2:first-child{margin-top:0;padding-top:0;border-top:none}.post-content h3{font-size:1.5rem;margin:2rem 0 .75rem;scroll-margin-top:calc(64px + 1rem)}.post-content h4{font-size:1.25rem;margin:1.5rem 0 .75rem;scroll-margin-top:calc(64px + 1rem)}.post-content img{border-radius:.75rem;margin:1.5rem 0}@media(min-width: 1280px){.post-sidebar{position:sticky;top:calc(64px + 1.5rem);max-height:calc(100vh - 64px - 3rem);overflow-y:auto}}.toc-container{background:#fff;border:1px solid #e4e4e7;border-radius:.75rem;padding:1rem;display:none}@media(min-width: 1280px){.toc-container{display:block}}.toc-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#6b7280;margin-bottom:.75rem}#toc-nav a{display:block;padding:.25rem .5rem;font-size:.875rem;color:#6b7280;text-decoration:none;border-radius:.25rem;border-left:2px solid rgba(0,0,0,0);transition:all 150ms ease;line-height:1.5}#toc-nav a:hover{color:#6366f1;border-left-color:#6366f1;background:rgba(99,102,241,.05);text-decoration:none}#toc-nav a.active{color:#6366f1;border-left-color:#6366f1;background:rgba(99,102,241,.08)}#toc-nav a.toc-h3{padding-left:1rem;font-size:.75rem}.post-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid #e4e4e7}.post-tags{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:2rem}.post-tags .tags-label{font-size:.875rem;color:#6b7280;font-weight:500}.post-navigation{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.post-nav-link{display:flex;flex-direction:column;gap:.25rem;padding:1rem;background:#fff;border:1px solid #e4e4e7;border-radius:.75rem;text-decoration:none;transition:all 150ms ease}.post-nav-link:hover{border-color:#6366f1;background:#f0f0f5;text-decoration:none;transform:translateY(-2px);box-shadow:0 0 0 3px rgba(99,102,241,.15)}.post-nav-link .nav-direction{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.post-nav-link .nav-title{font-size:.875rem;color:#111827;font-weight:500;line-height:1.4}.post-nav-next{text-align:right}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.875rem;font-weight:600;text-decoration:none;cursor:pointer;border:1px solid rgba(0,0,0,0);transition:all 250ms ease;white-space:nowrap}.btn--primary{background:#6366f1;color:#fff;border-color:#6366f1}.btn--primary:hover{background:#4f46e5;border-color:#4f46e5;text-decoration:none;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.06)}.btn--primary:active{transform:translateY(0)}.btn--secondary{background:#fff;color:#1a1a1a;border-color:#e4e4e7}.btn--secondary:hover{border-color:#6366f1;color:#6366f1;text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.06)}.category-tag{display:inline-flex;align-items:center;padding:.25em .6em;background:rgba(99,102,241,.1);color:#6366f1;border:1px solid rgba(99,102,241,.25);border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;text-decoration:none;transition:all 150ms ease}.category-tag:hover{background:rgba(99,102,241,.2);text-decoration:none;color:#6366f1}.category-tag--small{font-size:.7rem;padding:.15em .45em}.tag{display:inline-flex;padding:.2em .5em;background:#fff;color:#6b7280;border:1px solid #e4e4e7;border-radius:.25rem;font-size:.75rem;font-family:"JetBrains Mono","Fira Code","Cascadia Code",monospace}.section-title{font-size:1.875rem;margin-bottom:2rem;position:relative;display:inline-block;color:#111827}.section-title::after{content:"";position:absolute;bottom:-0.5rem;left:0;width:40px;height:3px;background:#6366f1;border-radius:2px}.section-header{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.section-header .section-title{margin-bottom:0}.view-all-link{font-size:.875rem;color:#6b7280;text-decoration:none;font-weight:500;transition:color 150ms ease}.view-all-link:hover{color:#6366f1;text-decoration:none}.hero{position:relative;overflow:hidden;padding:5rem 0 6rem;background:#fff;border-bottom:1px solid #e4e4e7}@media(min-width: 768px){.hero{padding:6rem 0}}.hero-bg{display:none}.hero-grid{display:none}.hero-glow{display:none}.hero-content{position:relative;max-width:760px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.3);border-radius:999px;font-size:.75rem;font-weight:600;color:#6366f1;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.5rem}.hero-badge-dot{width:7px;height:7px;background:#6366f1;border-radius:50%}.hero-title{font-size:2.25rem;margin-bottom:1.5rem;line-height:1.1}@media(min-width: 768px){.hero-title{font-size:4rem}}@media(min-width: 1024px){.hero-title{font-size:5rem}}.hero-title-main{display:block;color:#111827}.hero-title-accent{display:block;color:#6366f1}.hero-description{font-size:1.125rem;color:#6b7280;margin-bottom:2.5rem;max-width:55ch;line-height:1.8}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}.topics-section{padding:5rem 0;background:#f7f7f8;border-top:1px solid #e4e4e7;border-bottom:1px solid #e4e4e7}.topics-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width: 640px){.topics-grid{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1024px){.topics-grid{grid-template-columns:repeat(3, 1fr)}}.topic-card{background:#fff;border:1px solid #e4e4e7;border-radius:1rem;padding:1.5rem;transition:all 250ms ease}.topic-card:hover{border-color:#6366f1;transform:translateY(-4px);box-shadow:0 4px 12px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.06)}.topic-card:hover .topic-icon{background:rgba(99,102,241,.15);border-color:rgba(99,102,241,.4)}.topic-icon{width:52px;height:52px;background:rgba(99,102,241,.08);border:1px solid rgba(99,102,241,.2);border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:#6366f1;transition:all 250ms ease}.topic-icon svg{width:24px;height:24px}.topic-title{font-size:1.125rem;margin-bottom:.5rem;color:#111827}.topic-description{font-size:.875rem;color:#6b7280;line-height:1.6;margin-bottom:1rem}.topic-link{font-size:.875rem;color:#6366f1;text-decoration:none;font-weight:500;transition:color 150ms ease}.topic-link:hover{color:#4f46e5;text-decoration:none}.posts-section{padding:5rem 0}.posts-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width: 768px){.posts-grid{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1024px){.posts-grid{grid-template-columns:repeat(3, 1fr)}}.post-card{background:#fff;border:1px solid #e4e4e7;border-radius:1rem;overflow:hidden;display:flex;flex-direction:column;transition:all 250ms ease}.post-card:hover{border-color:rgba(99,102,241,.5);transform:translateY(-4px);box-shadow:0 4px 12px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.06)}.post-card-image{overflow:hidden;aspect-ratio:16/9}.post-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 400ms ease}.post-card-image:hover img{transform:scale(1.05)}.post-card-body{flex:1;padding:1.5rem;display:flex;flex-direction:column}.post-card-categories{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem}.post-card-title{font-size:1.25rem;margin-bottom:.75rem;flex:1}.post-card-title a{color:#111827;text-decoration:none;line-height:1.35}.post-card-title a:hover{color:#6366f1;text-decoration:none}.post-card-excerpt{font-size:.875rem;color:#6b7280;line-height:1.7;margin-bottom:1rem}.post-card-meta{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:#9ca3af;margin-top:auto;padding-top:1rem;border-top:1px solid #e4e4e7}.post-card-reading-time::before{content:"·";margin-right:.75rem}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:3rem}.pagination-btn{padding:.5rem 1rem;background:#fff;border:1px solid #e4e4e7;border-radius:.5rem;color:#1a1a1a;text-decoration:none;font-size:.875rem;font-weight:500;transition:all 150ms ease}.pagination-btn:hover{border-color:#6366f1;color:#6366f1;text-decoration:none}.pagination-info{font-size:.875rem;color:#6b7280}.archive-list{list-style:none;padding:0}.archive-year{margin-bottom:2.5rem}.archive-year-title{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #e4e4e7}.archive-post-item{display:flex;align-items:baseline;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(228,228,231,.5)}.archive-post-item:last-child{border-bottom:none}.archive-post-date{font-size:.75rem;color:#6b7280;flex-shrink:0;font-family:"JetBrains Mono","Fira Code","Cascadia Code",monospace;min-width:80px}.archive-post-title{font-size:1rem;color:#1a1a1a;text-decoration:none;font-weight:500}.archive-post-title:hover{color:#6366f1;text-decoration:none}.post-status-badge{display:inline-flex;align-items:center;padding:.15em .5em;border-radius:.25rem;font-size:.75rem;font-weight:600;margin-bottom:.5rem;letter-spacing:.04em}.post-status-badge--read{background:rgba(107,114,128,.1);color:#6b7280;border:1px solid rgba(107,114,128,.2)}.post-status-badge--new{background:rgba(16,185,129,.12);color:#10b981;border:1px solid rgba(16,185,129,.35)}.post-card--read{opacity:.72}.post-card--read:hover{opacity:1}.post-card--new{border-color:rgba(16,185,129,.4)}.archive-post-item--read{opacity:.65}.archive-post-item--new .archive-post-title{color:#10b981}.archive-post-item--new .archive-post-title:hover{color:#10b981}.copy-btn{position:absolute;top:.75rem;right:.75rem;padding:.25rem .5rem;background:#fff;border:1px solid #e4e4e7;border-radius:.25rem;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all 150ms ease;z-index:1}.copy-btn:hover{color:#6366f1;border-color:#6366f1;background:rgba(99,102,241,.05)}pre:hover .copy-btn{opacity:1}/*# sourceMappingURL=main.css.map */