*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden;text-rendering:optimizeSpeed}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans JP,sans-serif;line-height:1.8;color:var(--fg);background:var(--bg);overflow-x:clip;font-feature-settings:"palt" 1}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}:root{--bg:#f8fafc;--fg:#1e293b;--fg-muted:#64748b;--surface:#ffffff;--border:#e2e8f0;--accent:#2563eb;--accent-light:#dbeafe;--highlight:#6366f1;--radius:12px;--shadow:0 2px 8px rgba(0,0,0,.08);--shadow-hover:0 6px 20px rgba(0,0,0,.14);--max-w:840px}[data-theme=dark]{--bg:#0f172a;--fg:#e2e8f0;--fg-muted:#94a3b8;--surface:#1e293b;--border:#334155;--accent:#60a5fa;--accent-light:#1e3a5f;--highlight:#818cf8;--shadow:0 2px 8px rgba(0,0,0,.3);--shadow-hover:0 6px 20px rgba(0,0,0,.45)}.container{max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}.page{min-height:100dvh;display:flex;flex-direction:column}main{flex:1}main.container{padding-top:2.5rem;padding-bottom:4rem}.site-header{border-bottom:2px solid var(--border);padding:1rem 0;position:sticky;top:0;background:var(--bg);z-index:100}.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-title{font-family:"Press Start 2P",monospace;font-size:1rem;font-weight:400;color:var(--fg);white-space:nowrap;letter-spacing:.05em}.site-nav{display:flex;align-items:center;gap:1.1rem;font-size:.9rem;flex-wrap:wrap}.site-nav a{color:var(--fg-muted);font-weight:500;transition:color .15s;display:flex;align-items:center;gap:.3rem}.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--fg)}.site-nav a[aria-current=page]{border-bottom:2px solid var(--highlight);padding-bottom:2px}.theme-toggle{background:none;border:none;cursor:pointer;color:var(--fg-muted);padding:.25rem;line-height:1;display:flex;align-items:center}.theme-toggle:hover{color:var(--fg)}.article-body a{color:var(--fg);font-weight:500;background-image:linear-gradient(var(--highlight),var(--highlight));background-size:100% 2px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .2s}.article-body a:hover{background-size:100% 100%;color:#fff}.source-list a{color:var(--fg-muted);border-bottom:1px dashed var(--border);transition:color .15s,border-color .15s;word-break:break-all}.source-list a:after{content:" ↗";font-size:.75em;opacity:.6}.source-list a:hover{color:var(--highlight);border-color:var(--highlight)}.article-grid{display:grid;gap:1.5rem}@media(min-width:600px){.article-grid{grid-template-columns:repeat(2,1fr)}}.article-card{position:relative;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .1s,box-shadow .1s;content-visibility:auto;contain-intrinsic-size:auto 320px}.article-card:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-hover)}.article-card:hover .card-main-link{color:var(--highlight)}.article-card .card-thumb{height:180px;overflow:hidden;background:#0f172a;display:flex;align-items:center;justify-content:center;aspect-ratio:420/180}.article-card .card-thumb img{width:100%;height:100%;object-fit:cover;display:block;content-visibility:auto}.article-card .card-body{padding:1rem 1.25rem 1.25rem}.article-card h3{font-size:1.05rem;margin-bottom:.5rem;line-height:1.5}.article-card h3 a{color:var(--fg);transition:color .15s}.card-main-link:after{content:"";position:absolute;inset:0;z-index:0}.article-card .date{font-size:.8rem;color:var(--fg-muted)}.article-card .taxonomy{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap;margin-top:.5rem;position:relative;z-index:1}.article-card .desc{font-size:.9rem;color:var(--fg-muted);margin-top:.5rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.tag{display:inline-block;font-size:.75rem;background:var(--accent-light);color:var(--accent);padding:.15rem .6rem;border-radius:999px;transition:opacity .15s;position:relative;z-index:1}.tag:hover{opacity:.8}.category-link{font-size:.8rem;color:var(--fg-muted);font-weight:500;border:1px solid var(--border);padding:.15rem .6rem;border-radius:999px;transition:color .15s,border-color .15s;position:relative;z-index:1}.category-link:hover{color:var(--highlight);border-color:var(--highlight)}.article-header{margin-bottom:2rem}.article-header h1{font-size:1.6rem;line-height:1.5;margin-bottom:.75rem}.article-header .date{font-size:.85rem;color:var(--fg-muted)}.article-header .taxonomy{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.6rem}.article-hero{margin:1.5rem 0;border-radius:var(--radius);overflow:hidden;background:var(--surface);border:2px solid var(--border);aspect-ratio:840/360}.article-hero img,.article-hero svg{width:100%;height:auto;display:block;content-visibility:auto}.article-body{line-height:1.9}.article-body h2{font-size:1.3rem;margin:2.5rem 0 .75rem;padding-bottom:.35rem;border-bottom:2px solid var(--highlight)}.article-body h3{font-size:1.1rem;margin:1.5rem 0 .5rem}.article-body p{margin-bottom:1rem}.article-body ul,.article-body ol{margin:0 0 1rem 1.5rem}.article-body blockquote{border-left:3px solid var(--highlight);padding-left:1rem;color:var(--fg-muted);margin:1rem 0}.article-body code{background:var(--surface);padding:.1rem .3rem;border-radius:4px;font-size:.9em}.article-body img{border-radius:var(--radius);margin:1.5rem 0;border:2px solid var(--border)}.source-list{margin-top:2rem;padding-top:1rem;border-top:2px solid var(--border);font-size:.85rem}.source-list h4{margin-bottom:.5rem;display:flex;align-items:center;gap:.4rem}.source-list li{margin-bottom:.25rem}.site-footer{border-top:2px solid var(--border);padding:2rem 0;text-align:center;font-size:.8rem;color:var(--fg-muted)}.site-footer .footer-inner{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.footer-rss{display:inline-flex;align-items:center;gap:.3rem;color:var(--fg-muted);font-size:.8rem;border:1px solid var(--border);padding:.2rem .65rem;border-radius:999px;transition:color .15s,border-color .15s}.footer-rss:hover{color:var(--accent);border-color:var(--accent)}.back-to-top{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--surface);border:2px solid var(--border);color:var(--fg-muted);width:2.5rem;height:2.5rem;border-radius:50%;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s,transform .15s,opacity .2s;z-index:50;box-shadow:var(--shadow)}.back-to-top:hover{color:var(--highlight);border-color:var(--highlight);transform:translateY(-2px)}.back-to-top[hidden]{display:none!important}.floating-share{position:fixed;right:1rem;bottom:6.5rem;display:flex;flex-direction:column;gap:.45rem;z-index:55}.floating-share-btn{width:2.5rem;height:2.5rem;border-radius:999px;border:2px solid var(--border);background:var(--surface);color:var(--fg-muted);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;box-shadow:var(--shadow);cursor:pointer;transition:color .15s,border-color .15s,transform .15s}.floating-share-btn:hover{color:var(--highlight);border-color:var(--highlight);transform:translateY(-2px)}.floating-share-btn.copied{color:var(--accent);border-color:var(--accent)}@media(max-width:640px){.floating-share{right:.75rem;bottom:5.5rem}.floating-share-btn{width:2.2rem;height:2.2rem;font-size:.9rem}}.hero{text-align:center;padding:3rem 0 2rem}.hero h1{font-family:"Press Start 2P",monospace;font-size:1.5rem;font-weight:400;margin-bottom:.75rem;letter-spacing:.05em;line-height:1.6}.hero p{color:var(--fg-muted);font-size:1.05rem}.section-title{font-size:1.3rem;font-weight:700;margin-bottom:1rem}.audience-section{margin-top:3rem;padding:2rem 1.5rem;border-radius:var(--radius);background:var(--surface);border:2px solid var(--border);box-shadow:var(--shadow)}.audience-section .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.audience-section .section-header h2{font-size:1.2rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.section-more{font-size:.85rem;color:var(--fg-muted);font-weight:500;display:flex;align-items:center;gap:.25rem;transition:color .15s}.section-more:hover{color:var(--highlight)}.section-more:after{content:"→"}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}@media(max-width:640px){.site-header .container{flex-direction:column;align-items:flex-start;gap:.4rem;padding-top:.75rem;padding-bottom:.75rem}.site-nav{width:100%;gap:.6rem;font-size:.85rem;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:.25rem}.site-nav::-webkit-scrollbar{display:none}.article-header h1{font-size:1.3rem}.hero h1{font-size:1.1rem}.hero p{font-size:.95rem}}.lang-toggle{font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .55rem;border:1px solid var(--border);border-radius:4px;color:var(--fg-muted);transition:color .15s,border-color .15s}.lang-toggle:hover{color:var(--highlight);border-color:var(--highlight)}
