:root{--color-text: #1a1a1a;--color-text-secondary: #4a4a4a;--color-text-muted: #888;--color-bg: #fff;--color-bg-subtle: #f7f7f8;--color-bg-warm: #fdf8f6;--color-border: #e8e8e8;--color-border-light: #f0f0f0;--color-accent: #e85d75;--color-accent-hover: #d44a62;--color-accent-light: #fef0f2;--color-accent-bg: #fff5f7;--color-rank-gold: #d4a017;--color-rank-silver: #8a8a8a;--color-rank-bronze: #b87333;--color-success: #22c55e;--color-info: #3b82f6;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;--max-width-site: 1080px;--max-width-content: 720px;--sidebar-width: 280px;--header-height: 56px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-card: 0 1px 4px rgba(0, 0, 0, .05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + 1rem)}body{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);line-height:1.9;overflow-x:hidden}a{color:var(--color-accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-accent-hover);text-decoration:underline}img{max-width:100%;height:auto;display:block}.site-header{position:sticky;top:0;z-index:100;background:#fffffff2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border);height:var(--header-height)}.site-header__inner{max-width:var(--max-width-site);margin:0 auto;width:100%;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 1rem}.site-logo{display:flex;align-items:center;gap:8px;font-size:1.25rem;font-weight:800;color:var(--color-accent);text-decoration:none;letter-spacing:-.02em}.site-logo:hover{text-decoration:none;color:var(--color-accent-hover)}.site-logo__icon{width:28px;height:auto;flex-shrink:0}.nav-desktop{display:none;gap:.25rem}.nav-desktop a{color:var(--color-text-secondary);font-size:.875rem;font-weight:500;padding:.375rem .75rem;border-radius:var(--radius-sm);transition:background .15s ease,color .15s ease}.nav-desktop a:hover{background:var(--color-bg-subtle);color:var(--color-text);text-decoration:none}.nav-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:0;border-radius:var(--radius-sm);transition:background .15s ease}.nav-toggle:hover{background:var(--color-bg-subtle)}.nav-toggle svg{width:22px;height:22px;color:var(--color-text)}.nav-toggle .icon-close,.nav-toggle[aria-expanded=true] .icon-menu{display:none}.nav-toggle[aria-expanded=true] .icon-close{display:block}.nav-mobile{display:none;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:#fffffffa;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:99;padding:1.5rem 1rem;overflow-y:auto}.nav-mobile.is-open{display:block}.nav-mobile a{display:block;color:var(--color-text);font-size:1rem;font-weight:500;padding:.875rem 0;border-bottom:1px solid var(--color-border-light)}.nav-mobile a:hover{color:var(--color-accent);text-decoration:none}@media(min-width:768px){.nav-desktop{display:flex}.nav-toggle{display:none}.nav-mobile{display:none!important}}.main-content{max-width:var(--max-width-site);margin:0 auto;padding:0 1rem 4rem}.article-layout{display:grid;grid-template-columns:1fr;gap:2rem;max-width:var(--max-width-site);margin:0 auto;padding:0 1rem 4rem}@media(min-width:960px){.article-layout{grid-template-columns:1fr var(--sidebar-width);gap:2.5rem}}.article-layout__main{min-width:0;max-width:var(--max-width-content)}.article-layout__sidebar{display:none}@media(min-width:960px){.article-layout__sidebar{display:block}}.hero{background:linear-gradient(135deg,var(--color-accent-bg) 0%,#fef3f0 50%,#f0f4ff 100%);padding:3rem 1rem;text-align:center;margin-bottom:2.5rem}.hero__inner{max-width:640px;margin:0 auto}.hero__title{font-size:1.625rem;font-weight:800;line-height:1.4;margin-bottom:.75rem;letter-spacing:-.01em}.hero__desc{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.8;margin-bottom:1.5rem}.hero__cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--color-accent);color:#fff;font-size:.9375rem;font-weight:600;padding:.75rem 1.75rem;border-radius:100px;transition:background .15s ease,transform .1s ease}.hero__cta:hover{background:var(--color-accent-hover);color:#fff;text-decoration:none;transform:translateY(-1px)}@media(min-width:640px){.hero{padding:4rem 1.5rem}.hero__title{font-size:2rem}}.section{margin-bottom:3rem}.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-text)}.section__title{font-size:1.25rem;font-weight:700}.section__more{font-size:.8125rem;font-weight:500;color:var(--color-accent)}.card-grid{display:grid;grid-template-columns:1fr;gap:1rem}.card-grid--featured{gap:1.25rem}@media(min-width:640px){.card-grid--2col,.card-grid--3col{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.card-grid--3col{grid-template-columns:repeat(3,1fr)}}.article-card{position:relative;display:flex;flex-direction:column;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:box-shadow .15s ease,transform .1s ease}.article-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.article-card__thumb{position:relative;aspect-ratio:16 / 9;background:linear-gradient(135deg,#fce4ec,#f3e5f5,#e8eaf6);overflow:hidden;flex-shrink:0}.article-card__thumb img{width:100%;height:100%;object-fit:cover}.article-card__thumb-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.article-card__thumb-placeholder svg{width:32px;height:32px;color:#0000001f}.article-card__body{padding:1rem;display:flex;flex-direction:column;flex:1}.article-card__category{display:inline-block;font-size:.6875rem;font-weight:600;color:var(--color-accent);background:var(--color-accent-light);padding:.125rem .5rem;border-radius:100px;margin-bottom:.5rem;width:fit-content}.article-card__title{font-size:1rem;font-weight:700;line-height:1.5;margin-bottom:.375rem}.article-card__link{display:flex;flex-direction:column;color:inherit;text-decoration:none;cursor:pointer;flex:1}.article-card__link:hover{color:inherit;text-decoration:none}.article-card__link:hover .article-card__title{color:var(--color-accent)}.article-card__desc{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.5rem;flex:1}.article-card__meta{font-size:.75rem;color:var(--color-text-muted);display:flex;align-items:center;gap:.625rem;margin-top:auto}.article-card--featured{border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.article-card--featured .article-card__thumb{aspect-ratio:2 / 1}.article-card--featured .article-card__body{padding:1.25rem}.article-card--featured .article-card__title{font-size:1.125rem}.article-card--compact{border-radius:var(--radius-md)}.article-card--compact .article-card__link{flex-direction:row}.article-card--compact .article-card__thumb{width:120px;aspect-ratio:1 / 1;flex-shrink:0}.article-card--compact .article-card__body{padding:.75rem 1rem;justify-content:center}.article-card--compact .article-card__title{font-size:.875rem;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.article-card--compact .article-card__desc{display:none}@media(min-width:640px){.article-card--featured .article-card__thumb{aspect-ratio:5 / 2}.article-card--featured .article-card__title{font-size:1.25rem}}.article-list-simple{list-style:none;padding:0}.article-list-simple li{padding:.875rem 0;border-bottom:1px solid var(--color-border-light)}.article-list-simple li:last-child{border-bottom:none}.article-list-simple a{color:var(--color-text);font-size:.9375rem;font-weight:500}.article-list-simple a:hover{color:var(--color-accent)}.article-list-simple .meta{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.tag{display:inline-flex;align-items:center;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-subtle);padding:.25rem .625rem;border-radius:100px;transition:background .15s ease,color .15s ease}.tag:hover{background:var(--color-accent-light);color:var(--color-accent);text-decoration:none}.tag--active{background:var(--color-accent);color:#fff}.tag--active:hover{background:var(--color-accent-hover);color:#fff}.breadcrumbs{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:1rem;line-height:1.5;padding:.75rem 0}.breadcrumbs a{color:var(--color-text-muted);transition:color .15s ease}.breadcrumbs a:hover{color:var(--color-accent)}.breadcrumbs__sep{margin:0 .375rem;color:var(--color-border)}.article-hero{position:relative;width:100%;aspect-ratio:2 / 1;background:linear-gradient(135deg,#fce4ec,#f3e5f5,#e8eaf6);margin-bottom:1.5rem;border-radius:var(--radius-lg);overflow:hidden}.article-hero img{width:100%;height:100%;object-fit:cover}.article-hero__placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.article-hero__placeholder svg{width:48px;height:48px;color:#00000014}@media(max-width:640px){.article-hero{border-radius:0;margin-left:-1rem;margin-right:-1rem;width:calc(100% + 2rem)}}.article-header{margin-bottom:2rem}.article-header__category{display:inline-block;font-size:.75rem;font-weight:600;color:var(--color-accent);background:var(--color-accent-light);padding:.1875rem .625rem;border-radius:100px;margin-bottom:.75rem}.article-header h1{font-size:1.5rem;line-height:1.45;font-weight:800;margin-bottom:.875rem;letter-spacing:-.01em}.article-meta{font-size:.8125rem;color:var(--color-text-muted);display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.article-meta__writer{display:flex;align-items:center;gap:.375rem}.article-meta__writer-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent-light),#e8d5f5);flex-shrink:0;overflow:hidden}.article-meta__writer-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}@media(min-width:640px){.article-header h1{font-size:1.75rem}}.article-body{font-size:1rem;line-height:1.9}.article-body h2{font-size:1.375rem;font-weight:700;margin:3rem 0 1.25rem;padding:.625rem 0 .625rem .875rem;border-left:4px solid var(--color-accent);background:var(--color-bg-subtle);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.article-body h3{font-size:1.125rem;font-weight:700;margin:2rem 0 .75rem;padding-bottom:.375rem;border-bottom:1px solid var(--color-border)}.article-body h4{font-size:1rem;font-weight:700;margin:1.5rem 0 .5rem}.article-body p{margin-bottom:1.375rem}.article-body ul,.article-body ol{margin-bottom:1.375rem;padding-left:1.5rem}.article-body li{margin-bottom:.375rem}.article-body li::marker{color:var(--color-accent)}.article-body strong{font-weight:700;background:linear-gradient(transparent 60%,#ffe0e6 60%)}.article-body hr{border:none;height:1px;background:var(--color-border);margin:2.5rem 0}.article-body img{border-radius:var(--radius-md);margin:1.5rem 0}.article-body table{width:100%;border-collapse:separate;border-spacing:0;margin-bottom:1.5rem;font-size:.875rem;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.article-body th,.article-body td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light);border-right:1px solid var(--color-border-light);text-align:left}.article-body th:last-child,.article-body td:last-child{border-right:none}.article-body tr:last-child td{border-bottom:none}.article-body th{background:var(--color-bg-subtle);font-weight:600;font-size:.8125rem;color:var(--color-text-secondary);white-space:nowrap;position:sticky;top:0}.article-body td{vertical-align:middle}.article-body tr:nth-child(2n) td{background:var(--color-bg-subtle)}.article-body tr:hover td{background:var(--color-accent-light);transition:background .15s ease}@media(max-width:640px){.article-body table th:first-child,.article-body table td:first-child{position:sticky;left:0;z-index:1;background:var(--color-bg);border-right:2px solid var(--color-border)}.article-body tr:nth-child(2n) td:first-child{background:var(--color-bg-subtle)}}.article-body .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1.5rem;border-radius:var(--radius-md)}.article-body .table-wrap table{margin-bottom:0;min-width:500px}.app-icon-inline{width:24px;height:24px;border-radius:6px;vertical-align:middle;margin-right:.25rem;display:inline-block;flex-shrink:0}.app-name-cell{display:flex;align-items:center;gap:.5rem;font-weight:600}.app-name-cell img{width:28px;height:28px;border-radius:6px;flex-shrink:0}.rating{color:#f59e0b;font-weight:600;letter-spacing:.02em}.rating-stars{color:#f59e0b;font-size:.875rem;letter-spacing:.05em}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:.75rem;font-weight:800;color:#fff;flex-shrink:0}.rank-badge--1{background:var(--color-rank-gold)}.rank-badge--2{background:var(--color-rank-silver)}.rank-badge--3{background:var(--color-rank-bronze)}.rank-badge--other{background:var(--color-text-muted);width:22px;height:22px;font-size:.6875rem}.cell-highlight{color:var(--color-accent);font-weight:700}.cell-success{color:var(--color-success);font-weight:600}.cell-muted{color:var(--color-text-muted);font-size:.8125rem}.cell-badge{display:inline-block;font-size:.6875rem;font-weight:600;padding:.125rem .5rem;border-radius:100px;background:var(--color-accent-light);color:var(--color-accent)}.cell-badge--info{background:#eff6ff;color:var(--color-info)}.cell-badge--success{background:#f0fdf4;color:var(--color-success)}.article-body blockquote{background:var(--color-bg-warm);border-left:4px solid var(--color-accent);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:1.25rem 1.25rem 1.25rem 1.5rem;margin:1.5rem 0;color:var(--color-text-secondary);font-size:.9375rem;line-height:1.8}.article-body blockquote p:last-child{margin-bottom:0}.article-body code{font-family:var(--font-mono);font-size:.875em;background:var(--color-bg-subtle);padding:.125rem .375rem;border-radius:3px}.article-body pre{background:var(--color-bg-subtle);padding:1rem;border-radius:var(--radius-md);overflow-x:auto;margin-bottom:1.5rem}.article-body pre code{background:none;padding:0}.ranking-item{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;position:relative}.ranking-item--1st{border-color:var(--color-rank-gold);border-width:2px}.ranking-item--2nd{border-color:var(--color-rank-silver)}.ranking-item--3rd{border-color:var(--color-rank-bronze)}.ranking-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-size:.8125rem;font-weight:800;color:#fff;position:absolute;top:-8px;left:16px}.ranking-badge--1st{background:var(--color-rank-gold)}.ranking-badge--2nd{background:var(--color-rank-silver)}.ranking-badge--3rd{background:var(--color-rank-bronze)}.ranking-badge--other{background:var(--color-text-muted);width:28px;height:28px;font-size:.75rem}.app-info-box{background:var(--color-bg-subtle);border-radius:var(--radius-lg);padding:1.5rem;margin:1.5rem 0}.app-info-box__header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.app-info-box__icon{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,var(--color-accent-light),#e8d5f5);flex-shrink:0;overflow:hidden}.app-info-box__icon img{width:100%;height:100%;object-fit:cover;border-radius:12px}.app-info-box__name{font-size:1.125rem;font-weight:700}.app-info-box__tagline{font-size:.8125rem;color:var(--color-text-muted)}.app-info-box__details{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;font-size:.875rem}.app-info-box__detail-label{font-size:.75rem;color:var(--color-text-muted);margin-bottom:.125rem}.app-info-box__detail-value{font-weight:600}@media(min-width:480px){.app-info-box__details{grid-template-columns:repeat(3,1fr)}}.cta-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:var(--color-accent);color:#fff;font-size:1rem;font-weight:700;padding:.875rem 2rem;border-radius:100px;border:none;cursor:pointer;transition:background .15s ease,transform .1s ease;text-align:center;width:100%;max-width:400px}.cta-button:hover{background:var(--color-accent-hover);color:#fff;text-decoration:none;transform:translateY(-1px)}.cta-button--outline{background:transparent;color:var(--color-accent);border:2px solid var(--color-accent)}.cta-button--outline:hover{background:var(--color-accent-light);color:var(--color-accent-hover)}.cta-button--small{font-size:.875rem;padding:.625rem 1.25rem}.cta-wrapper{text-align:center;margin:2rem 0}.toc{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:1.25rem 1.5rem;margin-bottom:2rem}.toc__header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-tap-highlight-color:transparent}.toc__title{font-size:.875rem;font-weight:700;color:var(--color-text-secondary)}.toc__toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);transition:transform .2s ease;padding:0}.toc__toggle svg{width:16px;height:16px}.toc__toggle[aria-expanded=true]{transform:rotate(180deg)}.toc__list{list-style:none;padding:0;font-size:.875rem;margin-top:.75rem}.toc__list--collapsed{display:none}.toc__list li{margin-bottom:.375rem}.toc__list a{color:var(--color-text-secondary);display:block;padding:.25rem 0;border-radius:var(--radius-sm);transition:color .15s ease}.toc__list a:hover{color:var(--color-accent);text-decoration:none}.toc__list a.is-active{color:var(--color-accent);font-weight:600}.toc-sidebar{position:sticky;top:calc(var(--header-height) + 1.5rem);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:1.25rem;max-height:calc(100vh - var(--header-height) - 3rem);overflow-y:auto}.toc-sidebar__title{font-size:.8125rem;font-weight:700;color:var(--color-text-muted);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.toc-sidebar__list{list-style:none;padding:0;font-size:.8125rem}.toc-sidebar__list li{margin-bottom:.25rem}.toc-sidebar__list a{color:var(--color-text-muted);display:block;padding:.3125rem .75rem;border-left:2px solid transparent;border-radius:0;transition:color .15s ease,border-color .15s ease;line-height:1.5}.toc-sidebar__list a:hover{color:var(--color-accent);text-decoration:none}.toc-sidebar__list a.is-active{color:var(--color-accent);border-left-color:var(--color-accent);font-weight:600}.writer-box{background:var(--color-bg-subtle);border-radius:var(--radius-lg);padding:1.5rem;margin:3rem 0;display:flex;gap:1.25rem;align-items:flex-start}.writer-box__avatar{width:56px;height:56px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--color-accent-light),#e8d5f5);overflow:hidden}.writer-box__avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.writer-box__info{flex:1}.writer-box__label{font-size:.6875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.writer-box__name{font-weight:700;font-size:1rem;margin-bottom:.375rem}.writer-box__bio{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.7}.related-articles{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border)}.related-articles__title{font-size:1.125rem;font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.related-articles__grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.related-articles__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.related-articles__grid{grid-template-columns:repeat(3,1fr)}}.site-footer{border-top:1px solid var(--color-border);background:var(--color-bg-subtle)}.site-footer__inner{max-width:var(--max-width-site);margin:0 auto;padding:2.5rem 1rem}.site-footer__top{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.site-footer__brand{font-size:1.125rem;font-weight:800;color:var(--color-accent)}.site-footer__desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.7;max-width:320px}.site-footer__links{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;list-style:none;padding:0}.site-footer__links a{color:var(--color-text-secondary);font-size:.8125rem}.site-footer__links a:hover{color:var(--color-accent)}.site-footer__bottom{padding-top:1.5rem;border-top:1px solid var(--color-border);font-size:.75rem;color:var(--color-text-muted)}@media(min-width:640px){.site-footer__top{flex-direction:row;justify-content:space-between;align-items:flex-start}}.container{max-width:var(--max-width-site);margin:0 auto;padding:0 1rem}.text-center{text-align:center}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:640px){.article-header h1{font-size:1.3125rem}.article-body h2{font-size:1.1875rem;padding:.5rem 0 .5rem .75rem}.article-body h3{font-size:1.0625rem}.writer-box{flex-direction:column;align-items:center;text-align:center}}
