@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@400;700&family=JetBrains+Mono:wght@400;600&display=swap";:root{--clr-bg: #0d0d1a;--clr-surface: #141428;--clr-card: #1c1c35;--clr-card-hover: #22223f;--clr-border: rgba(167, 139, 250, .18);--clr-border-strong: rgba(167, 139, 250, .35);--clr-primary: #a78bfa;--clr-primary-dim:#7c5cc8;--clr-secondary: #67e8f9;--clr-accent: #f9a8d4;--clr-tag-bg: rgba(124, 58, 237, .2);--clr-tag-text: #c4b5fd;--clr-text: #e2e8f0;--clr-text-muted: #94a3b8;--clr-text-faint: #64748b;--clr-heading: #f1f5f9;--clr-code-bg: #1e1e2e;--grad-primary: linear-gradient(135deg, #a78bfa, #67e8f9);--grad-hero: linear-gradient(135deg, #1c1c35 0%, #0d0d1a 100%);--grad-card: linear-gradient(145deg, #1c1c35, #141428);--font-sans: "Noto Sans JP", sans-serif;--font-serif: "Noto Serif JP", serif;--font-mono: "JetBrains Mono", monospace;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(167, 139, 250, .15);--max-width: 1200px;--content-width: 720px;--sidebar-width: 300px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--clr-bg);color:var(--clr-text);line-height:1.8;min-height:100vh;display:flex;flex-direction:column;background-image:radial-gradient(ellipse at 20% 50%,rgba(124,58,237,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(103,232,249,.04) 0%,transparent 50%)}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);color:var(--clr-heading);line-height:1.3;font-weight:700}h1{font-size:clamp(1.8rem,4vw,2.6rem)}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}h4{font-size:1.2rem}p{margin-bottom:var(--spacing-md)}a{color:var(--clr-primary);text-decoration:none;transition:color var(--transition-fast),opacity var(--transition-fast)}a:hover{color:var(--clr-secondary)}img{max-width:100%;height:auto;display:block}code{font-family:var(--font-mono);background:var(--clr-code-bg);padding:.15em .4em;border-radius:var(--radius-sm);font-size:.88em;color:var(--clr-secondary)}pre{background:var(--clr-code-bg)!important;padding:var(--spacing-lg);border-radius:var(--radius-md);overflow-x:auto;border:1px solid var(--clr-border);margin:var(--spacing-lg) 0}pre code{background:none;padding:0;font-size:.9rem;color:inherit}blockquote{border-left:3px solid var(--clr-primary);padding:var(--spacing-sm) var(--spacing-lg);margin:var(--spacing-lg) 0;background:#a78bfa0f;border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--clr-text-muted);font-style:italic}hr{border:none;border-top:1px solid var(--clr-border);margin:var(--spacing-xl) 0}ul,ol{padding-left:var(--spacing-xl);margin-bottom:var(--spacing-md)}li{margin-bottom:var(--spacing-xs)}table{width:100%;border-collapse:collapse;margin:var(--spacing-lg) 0;font-size:.95rem}th{background:var(--clr-card);color:var(--clr-heading);padding:var(--spacing-sm) var(--spacing-md);border-bottom:2px solid var(--clr-border-strong);text-align:left}td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--clr-border)}tr:hover td{background:#a78bfa0a}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-lg)}.page-layout{display:grid;grid-template-columns:1fr var(--sidebar-width);gap:var(--spacing-2xl);align-items:start;max-width:var(--max-width);margin:0 auto;padding:var(--spacing-2xl) var(--spacing-lg)}.page-content{min-width:0}main{flex:1}.tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--clr-tag-bg);color:var(--clr-tag-text);padding:.2em .75em;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;border:1px solid rgba(196,181,253,.2);transition:all var(--transition-fast);cursor:pointer}.tag:hover{background:#7c3aed59;color:#ddd6fe;border-color:#c4b5fd66;transform:translateY(-1px)}.tag-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.55em 1.2em;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.9rem;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 2px 12px #a78bfa4d}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px #a78bfa66;color:#fff}.btn-outline{background:transparent;color:var(--clr-primary);border:1px solid var(--clr-border-strong)}.btn-outline:hover{background:var(--clr-tag-bg);border-color:var(--clr-primary)}.card{background:var(--grad-card);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-normal)}.card:hover{border-color:var(--clr-border-strong);box-shadow:var(--shadow-md),var(--shadow-glow);transform:translateY(-2px)}.section-title{font-size:1.3rem;color:var(--clr-heading);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--clr-border);display:flex;align-items:center;gap:var(--spacing-sm)}.section-title:before{content:"";display:block;width:4px;height:1.2em;background:var(--grad-primary);border-radius:var(--radius-full)}.gradient-text{background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.prose{max-width:var(--content-width);color:var(--clr-text);font-size:1.05rem;line-height:1.9}.prose h2{margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--clr-border)}.prose h3{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-sm)}.prose p{margin-bottom:var(--spacing-md)}.prose img{border-radius:var(--radius-md);margin:var(--spacing-xl) 0;border:1px solid var(--clr-border)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--clr-surface)}::-webkit-scrollbar-thumb{background:var(--clr-primary-dim);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--clr-primary)}::selection{background:#a78bfa4d;color:var(--clr-heading)}@media(max-width:900px){.page-layout{grid-template-columns:1fr}}@media(max-width:600px){.container{padding:0 var(--spacing-md)}.page-layout{padding:var(--spacing-lg) var(--spacing-md)}}.site-header[data-astro-cid-3ef6ksr2]{position:sticky;top:0;z-index:100;background:#0d0d1ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--clr-border)}.header-inner[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;justify-content:space-between;height:64px}.site-logo[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--clr-heading);font-family:var(--font-serif);font-size:1.2rem;font-weight:700;transition:opacity var(--transition-fast)}.site-logo[data-astro-cid-3ef6ksr2]:hover{opacity:.8;color:var(--clr-heading)}.logo-icon[data-astro-cid-3ef6ksr2]{font-size:1.4rem}.logo-text[data-astro-cid-3ef6ksr2]{background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.main-nav[data-astro-cid-3ef6ksr2] ul[data-astro-cid-3ef6ksr2]{display:flex;list-style:none;gap:var(--spacing-xs);padding:0;margin:0}.nav-link[data-astro-cid-3ef6ksr2]{display:block;padding:.4em .9em;border-radius:var(--radius-md);color:var(--clr-text-muted);font-size:.95rem;font-weight:500;transition:all var(--transition-fast);text-decoration:none}.nav-link[data-astro-cid-3ef6ksr2]:hover{color:var(--clr-heading);background:#a78bfa1a}.nav-link[data-astro-cid-3ef6ksr2].active{color:var(--clr-primary);background:#a78bfa1f}.menu-toggle[data-astro-cid-3ef6ksr2]{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.menu-toggle[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{display:block;width:22px;height:2px;background:var(--clr-text);border-radius:2px;transition:all var(--transition-fast)}.mobile-nav[data-astro-cid-3ef6ksr2]{display:none;background:var(--clr-surface);border-top:1px solid var(--clr-border);padding:var(--spacing-md) var(--spacing-lg)}.mobile-nav[data-astro-cid-3ef6ksr2].open{display:block}.mobile-nav[data-astro-cid-3ef6ksr2] ul[data-astro-cid-3ef6ksr2]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}@media(max-width:640px){.main-nav[data-astro-cid-3ef6ksr2]{display:none}.menu-toggle[data-astro-cid-3ef6ksr2]{display:flex}}.site-footer[data-astro-cid-sz7xmlte]{margin-top:auto;border-top:1px solid var(--clr-border);background:var(--clr-surface);padding:var(--spacing-2xl) 0 var(--spacing-lg)}.footer-grid[data-astro-cid-sz7xmlte]{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--spacing-2xl);margin-bottom:var(--spacing-xl)}.footer-logo[data-astro-cid-sz7xmlte]{font-family:var(--font-serif);font-size:1.2rem;font-weight:700;color:var(--clr-heading);text-decoration:none;display:block;margin-bottom:var(--spacing-sm)}.footer-logo[data-astro-cid-sz7xmlte]:hover{color:var(--clr-primary)}.footer-tagline[data-astro-cid-sz7xmlte]{color:var(--clr-text-muted);font-size:.9rem;margin:0}.footer-nav[data-astro-cid-sz7xmlte] h3[data-astro-cid-sz7xmlte]{font-size:.85rem;font-weight:700;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--spacing-md);font-family:var(--font-sans)}.footer-nav[data-astro-cid-sz7xmlte] ul[data-astro-cid-sz7xmlte]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.footer-nav[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--clr-text-muted);font-size:.95rem;transition:color var(--transition-fast)}.footer-nav[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--clr-primary)}.footer-bottom[data-astro-cid-sz7xmlte]{padding-top:var(--spacing-lg);border-top:1px solid var(--clr-border);text-align:center}.footer-bottom[data-astro-cid-sz7xmlte] p[data-astro-cid-sz7xmlte]{color:var(--clr-text-faint);font-size:.85rem;margin:0}@media(max-width:640px){.footer-grid[data-astro-cid-sz7xmlte]{grid-template-columns:1fr 1fr}.footer-brand[data-astro-cid-sz7xmlte]{grid-column:1 / -1}}.sidebar[data-astro-cid-ssfzsv2f]{position:sticky;top:80px;display:flex;flex-direction:column;gap:var(--spacing-lg)}.sidebar-section[data-astro-cid-ssfzsv2f]{background:var(--grad-card);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.sidebar-title[data-astro-cid-ssfzsv2f]{font-size:.9rem;font-weight:700;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--spacing-md);font-family:var(--font-sans);border:none;padding:0}.search-box[data-astro-cid-ssfzsv2f]{position:relative}#sidebar-search[data-astro-cid-ssfzsv2f]{width:100%;background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-md);padding:.6em 1em;color:var(--clr-text);font-family:var(--font-sans);font-size:.9rem;outline:none;transition:border-color var(--transition-fast)}#sidebar-search[data-astro-cid-ssfzsv2f]:focus{border-color:var(--clr-primary);box-shadow:0 0 0 2px #a78bfa26}#sidebar-search[data-astro-cid-ssfzsv2f]::placeholder{color:var(--clr-text-faint)}.search-results[data-astro-cid-ssfzsv2f]{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--clr-card);border:1px solid var(--clr-border-strong);border-radius:var(--radius-md);max-height:300px;overflow-y:auto;z-index:50;box-shadow:var(--shadow-md)}.search-result-item[data-astro-cid-ssfzsv2f]{display:block;padding:.6em .9em;color:var(--clr-text);font-size:.9rem;text-decoration:none;transition:background var(--transition-fast);border-bottom:1px solid var(--clr-border)}.search-result-item[data-astro-cid-ssfzsv2f]:last-child{border-bottom:none}.search-result-item[data-astro-cid-ssfzsv2f]:hover{background:#a78bfa1a}.search-result-item[data-astro-cid-ssfzsv2f] small[data-astro-cid-ssfzsv2f]{display:block;color:var(--clr-text-faint);font-size:.78rem}.tag-cloud[data-astro-cid-ssfzsv2f]{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tag-count[data-astro-cid-ssfzsv2f]{font-size:.75em;background:#a78bfa33;padding:.1em .4em;border-radius:var(--radius-full);margin-left:2px}.recent-list[data-astro-cid-ssfzsv2f]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.recent-link[data-astro-cid-ssfzsv2f]{display:flex;flex-direction:column;gap:.2rem;padding:.5rem;border-radius:var(--radius-sm);text-decoration:none;transition:background var(--transition-fast)}.recent-link[data-astro-cid-ssfzsv2f]:hover{background:#a78bfa14}.recent-badge[data-astro-cid-ssfzsv2f]{font-size:.7rem;font-weight:700;padding:.15em .5em;border-radius:var(--radius-full);width:fit-content;text-transform:uppercase;letter-spacing:.04em}.recent-badge[data-astro-cid-ssfzsv2f][data-type=blog]{background:#f9a8d426;color:#f9a8d4}.recent-badge[data-astro-cid-ssfzsv2f][data-type=tech]{background:#67e8f926;color:#67e8f9}.recent-title[data-astro-cid-ssfzsv2f]{color:var(--clr-text);font-size:.88rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recent-date[data-astro-cid-ssfzsv2f]{color:var(--clr-text-faint);font-size:.78rem}.category-list[data-astro-cid-ssfzsv2f]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.category-link[data-astro-cid-ssfzsv2f]{display:flex;justify-content:space-between;align-items:center;padding:.6em .8em;border-radius:var(--radius-md);text-decoration:none;color:var(--clr-text);font-size:.92rem;transition:all var(--transition-fast)}.category-link[data-astro-cid-ssfzsv2f]:hover{background:#a78bfa1a;color:var(--clr-primary)}.category-count[data-astro-cid-ssfzsv2f]{font-size:.8rem;color:var(--clr-text-faint);background:#a78bfa1a;padding:.15em .6em;border-radius:var(--radius-full)}.empty-msg[data-astro-cid-ssfzsv2f]{color:var(--clr-text-faint);font-size:.88rem;margin:0}
