@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Noto+Sans+JP:wght@400;500;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-bg: #fafafa;--color-bg-secondary: #f0f0f0;--color-bg-card: #ffffff;--color-border: #e4e4e7;--color-text: #18181b;--color-text-secondary: #71717a;--color-accent: #6366f1;--color-accent-hover: #4f46e5;--color-accent-light: #eef2ff;--color-tag: #f4f4f5;--color-tag-text: #6366f1;--color-code-bg: #f4f4f5;--color-medium: #1a8917;--shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-card-hover: 0 10px 25px rgba(0,0,0,.08);--radius: 16px;--max-width: 1200px;--header-height: 64px}[data-theme=dark]{--color-bg: #09090b;--color-bg-secondary: #18181b;--color-bg-card: #1c1c1f;--color-border: #27272a;--color-text: #fafafa;--color-text-secondary: #a1a1aa;--color-accent: #818cf8;--color-accent-hover: #a5b4fc;--color-accent-light: #1e1b4b;--color-tag: #27272a;--color-tag-text: #a78bfa;--color-code-bg: #1e1e1e;--shadow-card: 0 1px 3px rgba(0,0,0,.3);--shadow-card-hover: 0 10px 25px rgba(0,0,0,.4)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,Noto Sans JP,system-ui,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.7;min-height:100vh;transition:background-color .3s,color .3s}a{color:var(--color-accent);text-decoration:none;transition:color .2s}a:hover{color:var(--color-accent-hover)}.header{position:sticky;top:0;z-index:100;background:#fafafacc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);height:var(--header-height);transition:background-color .3s}[data-theme=dark] .header{background:#09090bcc}.header-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;height:100%;display:flex;align-items:center;justify-content:space-between}.logo{font-size:1.15rem;font-weight:800;color:var(--color-text);letter-spacing:-.5px;display:flex;align-items:center;gap:.5rem}.logo:hover{color:var(--color-accent)}.logo-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);display:inline-block}.nav-right{display:flex;align-items:center;gap:.5rem}.subscribe-btn{font-size:.82rem;font-weight:600;padding:.4rem .85rem;border:none;border-radius:8px;background:var(--color-accent);color:#fff;cursor:pointer;height:36px;display:flex;align-items:center;font-family:inherit;transition:background .2s}.subscribe-btn:hover{background:var(--color-accent-hover)}.subscribe-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:300;align-items:center;justify-content:center;backdrop-filter:blur(4px)}.subscribe-overlay.active{display:flex}.subscribe-popup{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:2rem;width:100%;max-width:400px;position:relative;box-shadow:0 20px 60px #0000004d}.subscribe-close{position:absolute;top:.75rem;right:1rem;background:none;border:none;color:var(--color-text-secondary);font-size:1.5rem;cursor:pointer;line-height:1}.subscribe-close:hover{color:var(--color-text)}.subscribe-popup-title{font-size:1.15rem;font-weight:700;margin-bottom:.3rem}.subscribe-popup-desc{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:1.25rem}.subscribe-popup-form{display:flex;flex-direction:column;gap:.6rem}.subscribe-popup-form input{padding:.6rem .85rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:inherit;transition:border-color .2s}.subscribe-popup-form input:focus{outline:none;border-color:var(--color-accent)}.subscribe-popup-form button{padding:.6rem;background:var(--color-accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}.subscribe-popup-form button:hover{background:var(--color-accent-hover)}.subscribe-msg{font-size:.82rem;text-align:center;display:none}.subscribe-msg.success{display:block;color:#16a34a}.subscribe-msg.error{display:block;color:#ef4444}.write-btn{font-size:.82rem;font-weight:600;padding:.4rem .85rem;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);transition:all .2s;height:36px;display:flex;align-items:center}.write-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-light)}.theme-toggle{background:none;border:1px solid var(--color-border);color:var(--color-text);width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s;font-size:1rem}.theme-toggle:hover{border-color:var(--color-accent);background:var(--color-accent-light)}.theme-toggle .icon-sun,.theme-toggle .icon-moon{display:none}[data-theme=dark] .theme-toggle .icon-sun{display:block}:root:not([data-theme=dark]) .theme-toggle .icon-moon,.theme-toggle .icon-moon{display:block}[data-theme=dark] .theme-toggle .icon-moon{display:none}.lang-switcher{position:relative}.lang-btn{background:none;border:1px solid var(--color-border);color:var(--color-text);padding:.4rem .7rem;border-radius:8px;cursor:pointer;font-size:.8rem;display:flex;align-items:center;gap:.35rem;transition:border-color .2s;font-family:inherit;height:36px}.lang-btn:hover{border-color:var(--color-accent)}.lang-dropdown{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;overflow:hidden;min-width:150px;box-shadow:var(--shadow-card-hover);z-index:200}.lang-switcher.open .lang-dropdown{display:block}.lang-option{display:block;padding:.55rem 1rem;color:var(--color-text);font-size:.85rem;transition:background .15s}.lang-option:hover{background:var(--color-bg-secondary);color:var(--color-text)}.lang-option.active{color:var(--color-accent);font-weight:600}.main{max-width:var(--max-width);margin:0 auto;padding:2.5rem 2rem 4rem}.profile-hero{position:relative;margin-bottom:3rem;border-radius:var(--radius);overflow:hidden;background:var(--color-bg-card);border:1px solid var(--color-border);box-shadow:var(--shadow-card)}.profile-hero-bg{height:64px;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a78bfa);position:relative}.profile-hero-bg:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.profile-hero-content{display:flex;align-items:center;gap:1rem;padding:0 1.5rem 1.25rem;margin-top:-24px;position:relative}.profile-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;border:4px solid var(--color-bg-card);box-shadow:0 2px 8px #00000026}.profile-info{padding-top:28px}.profile-info h1{font-size:1.15rem;font-weight:700;letter-spacing:-.3px;margin-bottom:.15rem}.profile-bio{color:var(--color-text-secondary);font-size:.82rem;line-height:1.4;margin-bottom:.15rem}.profile-topics{color:var(--color-accent);font-size:.75rem;font-weight:500;margin-bottom:.5rem}.profile-links{display:flex;gap:.5rem}.profile-link{font-size:.72rem;color:var(--color-text-secondary);padding:.2rem .6rem;border:1px solid var(--color-border);border-radius:8px;transition:all .2s;display:flex;align-items:center;gap:.4rem;background:var(--color-bg)}.profile-link svg{opacity:.7}.profile-link:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-light)}.profile-link:hover svg{opacity:1}.blog-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.blog-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:all .3s ease;box-shadow:var(--shadow-card)}.blog-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.blog-card-link{color:inherit;display:flex;flex-direction:column;height:100%}.blog-card-link:hover{color:inherit}.blog-card-thumb{height:160px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.blog-card-thumb:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.12) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.08) 0%,transparent 50%)}.blog-card-icon{font-size:3rem;position:relative;z-index:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.blog-card-content{padding:1.25rem 1.5rem 1.5rem;flex:1;display:flex;flex-direction:column}.blog-card-meta{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--color-text-secondary);margin-bottom:.6rem}.blog-card-source{padding:.12rem .45rem;border-radius:4px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.blog-card-source.medium{background:#dcfce7;color:#15803d}[data-theme=dark] .blog-card-source.medium{background:#14532d;color:#86efac}.blog-card-source.original{background:var(--color-accent-light);color:var(--color-accent)}.blog-card h2{font-size:1.1rem;font-weight:700;margin-bottom:.4rem;letter-spacing:-.3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card p{color:var(--color-text-secondary);font-size:.85rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.blog-card-tags{display:flex;gap:.35rem;margin-top:.75rem;flex-wrap:wrap}.tag{background:var(--color-tag);color:var(--color-tag-text);padding:.2rem .6rem;border-radius:6px;font-size:.72rem;font-weight:500}.blog-post{max-width:800px;margin:0 auto}.blog-post-header{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--color-border)}.blog-post-back{display:inline-flex;align-items:center;font-size:.82rem;margin-bottom:1.5rem;color:var(--color-text-secondary);gap:.3rem;padding:.3rem .75rem;border:1px solid var(--color-border);border-radius:8px;transition:all .2s}.blog-post-back:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-light)}.blog-post-title{font-size:2.25rem;font-weight:800;line-height:1.2;letter-spacing:-.75px;margin-bottom:1.25rem}.blog-post-meta{display:flex;align-items:center;gap:.75rem;color:var(--color-text-secondary);font-size:.85rem;flex-wrap:wrap}.medium-banner{background:linear-gradient(135deg,#16a34a,#15803d);border-radius:var(--radius);padding:1.15rem 1.5rem;margin-bottom:2.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.medium-banner p{color:#fff;font-size:.85rem;font-weight:500}.medium-banner a{background:#fff;color:#15803d;padding:.5rem 1.15rem;border-radius:8px;font-weight:600;font-size:.82rem;white-space:nowrap;transition:opacity .2s}.medium-banner a:hover{opacity:.9;color:#15803d}.prose{font-size:1.05rem;line-height:1.85}.prose h1,.prose h2,.prose h3,.prose h4{font-weight:700;letter-spacing:-.3px;margin-top:2.5rem;margin-bottom:.75rem}.prose h2{font-size:1.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.prose h3{font-size:1.2rem}.prose p{margin-bottom:1.25rem}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.4rem}.prose li::marker{color:var(--color-accent)}.prose strong{font-weight:700;color:var(--color-text)}.prose code{background:var(--color-code-bg);padding:.2rem .45rem;border-radius:6px;font-size:.88em;font-family:JetBrains Mono,monospace;border:1px solid var(--color-border)}.prose pre{background:var(--color-code-bg)!important;border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;overflow-x:auto;margin-bottom:1.5rem}.prose pre code{background:none;padding:0;font-size:.85rem;border:none}.prose blockquote{border-left:4px solid var(--color-accent);padding:1rem 1.25rem;color:var(--color-text-secondary);margin-bottom:1.5rem;background:var(--color-bg-secondary);border-radius:0 var(--radius) var(--radius) 0;font-style:italic}.prose blockquote strong{color:var(--color-text)}.prose img{max-width:100%;border-radius:var(--radius);margin:2rem 0;box-shadow:var(--shadow-card)}.prose a{text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--color-accent)}.prose hr{border:none;border-top:1px solid var(--color-border);margin:2.5rem 0}.newsletter{margin-top:3rem;padding:1.5rem 2rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.newsletter-title{font-size:.95rem;font-weight:700;margin-bottom:.15rem}.newsletter-desc{font-size:.78rem;color:var(--color-text-secondary)}.newsletter-form{display:flex;gap:.5rem;flex-shrink:0}.newsletter-form input{padding:.5rem .85rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);color:var(--color-text);font-size:.85rem;font-family:inherit;width:220px;transition:border-color .2s}.newsletter-form input:focus{outline:none;border-color:var(--color-accent)}.newsletter-form button{padding:.5rem 1.15rem;background:var(--color-accent);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s;white-space:nowrap}.newsletter-form button:hover{background:var(--color-accent-hover)}@media(max-width:640px){.newsletter{flex-direction:column;text-align:center;padding:1.25rem}.newsletter-form{width:100%}.newsletter-form input{flex:1;width:auto}}.footer{border-top:1px solid var(--color-border);padding:2rem;text-align:center;color:var(--color-text-secondary);font-size:.8rem}.empty-state{text-align:center;padding:4rem 1rem;color:var(--color-text-secondary);font-size:1rem}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;width:46px;height:46px;border-radius:50%;background:var(--color-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #6366f166;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .3s,visibility .3s,transform .3s,background .2s;z-index:50}.scroll-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.scroll-to-top:hover{background:var(--color-accent-hover);box-shadow:0 6px 20px #6366f180;transform:translateY(-2px)}.related-posts{max-width:800px;margin:3.5rem auto 0;padding-top:3rem;border-top:1px solid var(--color-border)}.related-posts-title{font-size:1.3rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:-.3px}.related-posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.related-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;transition:all .3s ease;box-shadow:var(--shadow-card);display:flex;flex-direction:column}.related-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.related-card-link{color:inherit;display:flex;flex-direction:column;height:100%}.related-card-link:hover{color:inherit}.related-card-thumb{height:140px;display:flex;align-items:center;justify-content:center;padding:1.5rem;position:relative;overflow:hidden}.related-card-thumb .thumb-icon{font-size:2.5rem;opacity:.9;position:relative;z-index:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.related-card-thumb:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.12) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.08) 0%,transparent 50%)}.related-card-body{padding:1rem 1.25rem 1.25rem;flex:1;display:flex;flex-direction:column}.related-card-body h3{font-size:.95rem;font-weight:600;line-height:1.4;margin-bottom:.4rem;letter-spacing:-.2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.related-card-body p{font-size:.8rem;color:var(--color-text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.related-card-tags{display:flex;gap:.3rem;margin-top:.65rem;flex-wrap:wrap}.related-card-tags .tag{font-size:.68rem}@media(max-width:640px){.main{padding:1.5rem 1rem 3rem}.header-inner{padding:0 1rem}.profile-hero-content{flex-direction:column;align-items:center;text-align:center;padding:0 1.25rem 1.5rem}.profile-info{padding-top:.5rem}.profile-links{justify-content:center}.blog-list{grid-template-columns:1fr}.blog-post-title{font-size:1.6rem}.blog-card-thumb{height:130px}.medium-banner{flex-direction:column;text-align:center}.scroll-to-top{bottom:1.25rem;right:1.25rem;width:42px;height:42px}.related-posts-grid{grid-template-columns:1fr}.related-card-thumb{height:120px}}@media(min-width:1024px){.blog-list{grid-template-columns:repeat(3,1fr)}}
