@import "https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@400;500;700;800&family=Noto+Sans+JP:wght@400;500;700&display=swap";:root{--bg:#f8f7f3;--surface:#fff;--surface-muted:#fff9f5;--text:#5d5954;--heading:#3d3a37;--muted:#7e7a74;--soft-text:#9a948e;--line:#ebe6df;--accent:#f08b6f;--accent-soft:#fff0ea;--shadow:0 12px 30px #473a2f0f;--body-font:"Noto Sans JP", "Hiragino Sans", sans-serif;--heading-font:"M PLUS Rounded 1c", "Hiragino Maru Gothic ProN", sans-serif;--mono:"SFMono-Regular", "Menlo", "Consolas", monospace;color:var(--text);background:var(--bg);font:17px/1.8 var(--body-font);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:radial-gradient(circle at top,#ffeade8c,#0000 28%),linear-gradient(#fcfbf8 0%,#f7f4ef 100%);min-width:320px;margin:0}a{color:inherit;text-decoration:none}h1,h2,h3{font-weight:700}p{margin:0}#root{min-height:100svh}@media (width<=640px){:root{font-size:16px}}.page{width:min(1120px,100% - 24px);margin:0 auto;padding:20px 0 72px}.site-header,.welcome-card,.post-card,.widget,.category-pill,.pager-link{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.site-header{border-radius:26px;justify-content:space-between;align-items:center;gap:24px;padding:18px 24px;display:flex}.brand{align-items:center;gap:14px;display:inline-flex}.brand-mark{color:#fff;background:linear-gradient(135deg,#f7b267,#f4845f);border-radius:16px;place-items:center;width:42px;height:42px;font-size:1.05rem;font-weight:700;display:grid}.brand-copy{gap:2px;display:grid}.brand-copy strong,.section-head h2,.widget h2,.pickup-card h2,.post-body h3,.welcome-copy h1{color:var(--heading);font-family:var(--heading-font)}.brand-copy strong{font-size:1.05rem}.brand-copy small{color:var(--muted);font-size:.84rem}.global-nav{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.nav-link,.category-pill,.tag{min-height:40px;color:var(--muted);border-radius:999px;justify-content:center;align-items:center;padding:0 14px;font-size:.92rem;transition:transform .16s,color .16s,border-color .16s;display:inline-flex}.nav-link:hover,.category-pill:hover,.tag:hover,.text-link:hover,.pager-link:hover{color:var(--accent)}.nav-link:hover,.category-pill:hover,.post-card:hover,.widget:hover{transform:translateY(-2px)}.welcome-card{background:linear-gradient(#fffffff5,#ffffffe6),linear-gradient(135deg,#ffd9c74d,#cdece64d);border-radius:32px;grid-template-columns:1.35fr .9fr;gap:18px;margin-top:18px;padding:28px;display:grid}.welcome-copy h1{letter-spacing:.01em;margin:0;font-size:clamp(2rem,4vw,3rem);line-height:1.35}.welcome-copy p:last-child,.pickup-card p,.post-body p,.profile-widget p{color:var(--muted)}.welcome-copy p:last-child{max-width:38rem;margin:14px 0 0}.section-label,.pickup-category{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px;font-size:.78rem;font-weight:700}.pickup-card{background:linear-gradient(#fff7ef,#fffdf9);border-radius:28px;align-self:stretch;padding:24px}.pickup-card h2{margin:0;font-size:1.5rem;line-height:1.55}.pickup-card p{margin:12px 0 0}.category-row{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.content-grid{grid-template-columns:minmax(0,1.8fr) minmax(280px,.9fr);gap:20px;margin-top:20px;display:grid}.section-head,.widget-head{justify-content:space-between;align-items:end;gap:16px;display:flex}.section-head{margin-bottom:16px}.section-head h2,.widget h2{margin:0;font-size:1.35rem}.post-list,.sidebar{gap:16px;display:grid}.post-card,.widget{border-radius:26px}.post-card{grid-template-columns:220px 1fr;gap:0;transition:transform .16s,box-shadow .16s;display:grid;overflow:hidden}.post-thumb{min-height:190px;position:relative}.tone-peach{background:radial-gradient(circle at 30% 30%,#ffffffb3,#0000 32%),linear-gradient(135deg,#ffd6ba,#f6a97f)}.tone-mint{background:radial-gradient(circle at 30% 30%,#ffffffb3,#0000 32%),linear-gradient(135deg,#d7f3ea,#91d3c2)}.tone-cream{background:radial-gradient(circle at 30% 30%,#ffffffb3,#0000 32%),linear-gradient(135deg,#fff5cf,#f2d899)}.tone-sky{background:radial-gradient(circle at 30% 30%,#ffffffb3,#0000 32%),linear-gradient(135deg,#d8ecff,#8fbbe9)}.tone-rose{background:radial-gradient(circle at 30% 30%,#ffffffb3,#0000 32%),linear-gradient(135deg,#ffe0e8,#efafbe)}.thumb-chip{color:#765948;background:#ffffffd1;border-radius:999px;align-items:center;min-height:32px;padding:0 12px;font-size:.8rem;font-weight:700;display:inline-flex;position:absolute;top:16px;left:16px}.post-body{align-content:center;gap:12px;padding:24px;display:grid}.post-meta{color:var(--soft-text);flex-wrap:wrap;gap:12px;font-size:.84rem;display:flex}.post-body h3{margin:0;font-size:1.4rem;line-height:1.6}.post-body p{margin:0}.text-link{width:fit-content;color:var(--accent);align-items:center;font-weight:700;display:inline-flex}.pager{justify-content:center;gap:10px;margin-top:20px;display:flex}.pager-link{width:42px;height:42px;color:var(--muted);border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.pager-link.is-current{background:var(--accent-soft);color:var(--accent);border-color:#f7845f73}.widget{padding:24px}.profile-widget{text-align:center}.avatar{color:#fff;background:linear-gradient(135deg,#ffd5bd,#f8b68d);border-radius:24px;place-items:center;width:72px;height:72px;margin:0 auto 14px;font-size:1.2rem;font-weight:700;display:grid}.profile-widget h2{margin-bottom:10px}.popular-list{counter-reset:ranking;gap:14px;margin:16px 0 0;padding:0;list-style:none;display:grid}.popular-list li{padding-left:42px;position:relative}.popular-list li:before{counter-increment:ranking;content:counter(ranking);background:var(--accent-soft);width:28px;height:28px;color:var(--accent);border-radius:50%;place-items:center;font-size:.82rem;font-weight:700;display:grid;position:absolute;top:0;left:0}.popular-list a{color:var(--text);line-height:1.7}.tag-list{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.tag{border:1px solid var(--line);background:var(--surface-muted)}@media (width<=980px){.site-header,.welcome-card,.content-grid,.post-card{grid-template-columns:1fr}.site-header,.global-nav{justify-content:flex-start}}@media (width<=720px){.page{width:min(100% - 20px,1120px);padding-bottom:48px}.site-header,.welcome-card,.widget{border-radius:22px;padding:20px}.post-card{border-radius:22px}.post-thumb{min-height:160px}.post-body{padding:20px}.welcome-copy h1{font-size:1.7rem}}
