:root{--sidebar-w: 260px;--content-max: 740px}.page-wrapper{max-width:calc(var(--content-max) + var(--sidebar-w) + 2rem + 48px);margin:0 auto;padding:0 1rem;font-family:var(--font-ja);color:var(--text-main)}.breadcrumb{padding:1rem 0 2rem;font-size:.8rem;color:var(--text-muted)}.breadcrumb ol{display:flex;flex-wrap:wrap;align-items:center;gap:4px;list-style:none;margin:0;padding:0}.breadcrumb a{color:var(--accent);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.breadcrumb .sep{color:var(--border)}.layout{display:grid;grid-template-columns:1fr var(--sidebar-w);gap:2rem;align-items:start}.article-header{margin-bottom:2rem}.badge-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:.75rem}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;line-height:1.4;text-decoration:none}.badge-category{background:var(--accent-bg);color:var(--accent);border:1px solid #b7e4c7}.badge-category:hover{background:#b7e4c7}.badge-difficulty{background:color-mix(in srgb,var(--diff-color) 12%,white);color:var(--diff-color);border:1px solid color-mix(in srgb,var(--diff-color) 25%,white)}.badge-tool{background:#e8f4fd;color:#1565a3;border:1px solid #b3d8f5}.article-title{font-size:clamp(1.35rem,3.5vw,1.75rem);font-weight:700;line-height:1.45;letter-spacing:-.01em;margin:0 0 .75rem}.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px;font-size:.8rem;color:var(--text-muted)}.meta-label{font-weight:600}.target-tag{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 7px;font-size:.75rem}.article-ogimage{margin-top:1.25rem}.article-ogimage img{width:100%;height:auto;border-radius:10px;display:block;box-shadow:0 2px 10px #0000001a;margin:0}.article-lead{font-size:1rem;line-height:1.9;color:var(--text-main);margin:1.25rem 0 1.5rem}.toc{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:2rem;overflow:hidden}.toc-summary{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;cursor:pointer;list-style:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s}.toc-summary::-webkit-details-marker{display:none}.toc-summary:hover{background:#f5faf7}.toc-title{font-size:.85rem;font-weight:700;color:var(--accent);letter-spacing:.02em}.toc-chevron{color:#b0b0b0;display:flex;align-items:center;transition:transform .22s ease,color .15s}.toc[open] .toc-chevron{transform:rotate(180deg);color:var(--accent)}.sidebar-card-title{font-size:.85rem;font-weight:700;color:var(--accent);margin:0 0 .6rem;letter-spacing:.02em}.toc-list{margin:0;padding:1rem 1.25rem 1rem 2rem;font-size:.875rem;line-height:1.6;border-top:1px solid var(--border)}.toc-item{margin:4px 0}.toc-item--h3{margin-left:1rem;font-size:.825rem}.toc-list a{color:var(--text-main);text-decoration:none}.toc-list a:hover{color:var(--accent);text-decoration:underline}.toc-list a.is-active{color:var(--accent);font-weight:600}.article-body{font-size:1rem;line-height:1.9;color:var(--text-main)}.article-body p{margin:0 0 1.5rem}.article-body h2{font-size:1.3rem;font-weight:800;line-height:1.45;letter-spacing:-.02em;margin:3.5rem 0 1.25rem;padding:.55rem 0 .55rem 1rem;border-left:4px solid var(--accent)}.article-body h3{font-size:1.1rem;font-weight:700;line-height:1.5;margin:2.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.article-body h4{font-size:1rem;font-weight:700;color:var(--accent);margin:2rem 0 .6rem;padding-left:.8rem;position:relative}.article-body h4:before{content:"";position:absolute;left:0;top:.2em;bottom:.2em;width:2.5px;background:var(--accent-lt);border-radius:2px}.article-body h5{font-size:.9rem;font-weight:700;color:var(--text-muted);margin:1.5rem 0 .4rem;letter-spacing:.05em;text-transform:uppercase}.article-body h6{font-size:.875rem;font-weight:600;color:var(--text-muted);margin:1.25rem 0 .35rem}.article-body ul,.article-body ol{margin:0 0 1.5rem;padding-left:0;list-style:none}.article-body ul>li{position:relative;padding:.35rem 0 .35rem 1.5rem;line-height:1.75;border-bottom:1px solid transparent}.article-body ul>li:before{content:"";position:absolute;left:.25rem;top:.85em;width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0}.article-body ol{counter-reset:ol-counter}.article-body ol>li{position:relative;padding:.35rem 0 .35rem 2.25rem;line-height:1.75;counter-increment:ol-counter}.article-body ol>li:before{content:counter(ol-counter);position:absolute;left:0;top:.3em;width:1.5rem;height:1.5rem;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}.article-body ul ul,.article-body ol ul,.article-body ul ol,.article-body ol ol{margin:.5rem 0 .5rem .5rem}.article-body ul ul>li:before{width:4px;height:4px;background:transparent;border:1.5px solid var(--accent-lt);left:.3rem;top:.88em}.article-body .table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:2rem 0;border:1px solid var(--border);border-radius:10px}.article-body table{width:100%;border-collapse:collapse;font-size:.9rem;margin:0}.article-body th{background:var(--accent);color:#fff;padding:12px 16px;text-align:left;font-weight:600;font-size:.875rem;white-space:nowrap;letter-spacing:.01em}.article-body td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:top;line-height:1.65}.article-body tr:last-child td{border-bottom:none}.article-body tbody tr:hover td{background:#f2faf5;transition:background .12s}.article-body blockquote{margin:2rem 0;padding:1.1rem 1.35rem;background:#edf7f2;border-radius:8px;font-size:.95rem;color:var(--text-main);border-left:3px solid var(--accent-lt)}.article-body blockquote>*:first-child{margin-top:0}.article-body blockquote>*:last-child{margin-bottom:0}.article-body blockquote cite{display:block;margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(45,106,79,.15);font-size:.8rem;color:var(--text-muted);font-style:normal}.article-body blockquote cite:before{content:"— "}.article-body strong{font-weight:700;color:var(--text-main);background:linear-gradient(transparent 50%,#fef08a 50%);padding:0 .1em}.article-body td strong,.article-body th strong{background:none;padding:0}.article-body em{font-style:italic}.article-body mark{background:#fef3c7;color:#1a1a1a;padding:.05em .3em;border-radius:3px}.article-body img{width:100%;height:auto;border-radius:10px;margin:2rem 0;display:block;box-shadow:0 1px 6px #00000014}.article-body figure{margin:2rem 0}.article-body figure img{margin:0}.article-body figcaption{margin-top:.6rem;text-align:center;font-size:.8rem;color:var(--text-muted);line-height:1.5}.article-body code{background:#f3f2ee;border:1px solid #e8e6e0;border-radius:4px;padding:.1em .45em;font-size:.875em;font-family:Fira Code,Source Code Pro,Consolas,monospace;color:#c7254e}.article-body pre{background:#1e2228;color:#abb2bf;padding:1.25rem 1.5rem;border-radius:10px;overflow-x:auto;font-size:.875rem;margin:2rem 0;line-height:1.65;white-space:pre-wrap;overflow-wrap:break-word}.article-body pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit}.article-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:#2d6a4f4d;transition:text-decoration-color .12s}.article-body a:hover{text-decoration-color:var(--accent)}.article-body hr{border:none;border-top:1px solid var(--border);margin:3rem 0}.article-body small{font-size:.8rem;color:var(--text-muted);display:inline-block}.article-body .annotation{margin-top:-.75rem;margin-bottom:1.5rem;font-size:.8rem;color:var(--text-muted);padding-left:.85rem;border-left:2px solid var(--border);line-height:1.7}.article-body .callout{position:relative;margin:2rem 0;padding:1.1rem 1.35rem 1.1rem 3.5rem;border-radius:10px;font-size:.95rem;line-height:1.8}.article-body .callout>*:first-child{margin-top:0}.article-body .callout>*:last-child{margin-bottom:0}.article-body .callout .callout-icon-el{position:absolute;left:1.1rem;top:1.05rem;display:flex;align-items:center;justify-content:center;line-height:1}.article-body .callout-title{display:block;font-weight:700;font-size:.9rem;margin-bottom:.4rem}.article-body .callout-point{background:#edf7f2}.article-body .callout-info{background:#eff4ff}.article-body .callout-caution{background:#fffbeb}.article-body .callout-summary{background:#fff;border:3px solid var(--accent);margin-top:3.5rem}.article-body .callout-summary .callout-title{font-size:1.05rem;color:var(--accent);letter-spacing:.01em}.article-body .callout-danger{background:#fff5f5}.tag-list{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:2rem 0 1.5rem;font-size:.825rem}.tag{color:var(--accent);text-decoration:none;border:1px solid var(--accent-bg);padding:2px 10px;border-radius:20px;transition:background .15s}.tag:hover{background:var(--accent-bg)}.section-block-title{font-size:1.1rem;font-weight:700;color:var(--accent);margin:0 0 .85rem;padding-left:.8rem;border-left:4px solid var(--accent);line-height:1.4}.related-section{margin-top:2.5rem}.related-cards{display:flex;flex-direction:column;gap:.75rem}.related-card{display:flex;align-items:center;gap:1rem;border:1px solid var(--border);border-radius:10px;overflow:hidden;text-decoration:none;color:var(--text-main);background:var(--bg-card);transition:border-color .18s,box-shadow .18s}.related-card:hover{border-color:var(--accent-lt);box-shadow:0 3px 12px #2d6a4f21}.related-card-img{width:140px;height:84px;flex-shrink:0;overflow:hidden}.related-card-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;margin:0;border-radius:0;box-shadow:none}.related-card-title{flex:1;font-size:.9rem;font-weight:600;line-height:1.55;margin:0;padding:.6rem 1rem .6rem 0;color:var(--text-main);transition:color .15s}.related-card:hover .related-card-title{color:var(--accent)}.same-category-section{margin-top:2.5rem}.same-cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media (min-width: 540px){.same-cat-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 680px){.same-cat-grid{grid-template-columns:repeat(4,1fr)}}.same-cat-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:10px;overflow:hidden;text-decoration:none;color:var(--text-main);background:var(--bg-card);transition:border-color .18s,box-shadow .18s}.same-cat-card:hover{border-color:var(--accent-lt);box-shadow:0 3px 12px #2d6a4f21}.same-cat-card-img{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--accent-bg)}.same-cat-card-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;margin:0;border-radius:0;box-shadow:none}.same-cat-card-title{font-size:.8rem;font-weight:600;line-height:1.5;padding:.6rem .65rem;margin:0;color:var(--text-main);transition:color .15s}.same-cat-card:hover .same-cat-card-title{color:var(--accent)}.card-img-placeholder{width:100%;height:100%;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;color:var(--accent-lt)}.sidebar{position:sticky;top:5rem}.sidebar-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1.25rem;font-size:.85rem}.profile-card{padding:1.1rem 1rem 1rem}.profile-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.profile-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent-lt)}.profile-info{display:flex;flex-direction:column;gap:2px}.profile-name{font-size:.875rem;font-weight:700;color:var(--text-main);margin:0;line-height:1.3}.profile-role{font-size:.75rem;color:var(--text-muted);margin:0}.profile-bio{font-size:.8rem;color:var(--text-muted);line-height:1.65;margin:0 0 .75rem}.profile-link{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;color:var(--accent);text-decoration:none;border:1px solid #b7e4c7;border-radius:20px;padding:3px 10px;transition:background .15s}.profile-link:hover{background:var(--accent-bg)}.sidebar-nav-list{list-style:none;padding:0;margin:0}.sidebar-nav-list>li{margin-bottom:6px}.sidebar-nav-list a{color:var(--text-main);text-decoration:none;display:flex;align-items:center;gap:5px;padding:3px 0}.sidebar-nav-list a:hover{color:var(--accent)}.sidebar-nav-list ul{list-style:none;padding-left:1.35rem;margin:4px 0 8px}.sidebar-nav-list ul a{font-size:.8rem;color:var(--text-muted);display:block}@media (max-width: 768px){.layout{grid-template-columns:1fr}.sidebar{position:static}.article-title{font-size:1.25rem}.related-card-img{width:100px;height:64px}}@media (max-width: 480px){.article-body table{font-size:.8rem}.article-body th,.article-body td{padding:7px 9px}.article-body h2{font-size:1.15rem}.article-body h3{font-size:1rem}.article-body .callout{padding-left:3rem}.related-card-img{width:80px;height:54px}.same-cat-grid{grid-template-columns:repeat(2,1fr)}}
