*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:"Zen Maru Gothic","Hiragino Maru Gothic ProN","Hiragino Maru Gothic Pro","メイリオ",Meiryo,sans-serif;font-size:16px;line-height:2.05;color:#3a4251;background:linear-gradient(180deg,#eef5fa 0%,#fcfaf7 100%);background-attachment:fixed;-webkit-font-smoothing:antialiased;font-feature-settings:"palt"}img,svg{max-width:100%;height:auto;display:block}a{color:inherit}:root{--primary:#8dc2de;--primary-mid:#6bacd0;--primary-deep:#3a8bba;--primary-darker:#276a99;--primary-light:#bcd9e9;--primary-soft:#d2e5f0;--primary-tint:#eff5fa;--primary-bg:#e3eff7;--text:#3a4251;--text-sub:#636e7d;--text-muted:#8a95a2;--white:#fff;--cream:#fcfaf7}.sr-only{position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-40px;left:0;background:var(--primary-deep);color:var(--white);padding:8px 16px;z-index:9999;text-decoration:none}.skip-link:focus{top:0}.site-brand{background:var(--white);padding:28px 36px;border-bottom:1px solid var(--primary-soft);width:100%;text-align:center}.site-brand-link{display:inline-block;text-decoration:none;line-height:1}.site-brand-link svg{display:block;height:56px;width:auto;margin:0 auto}@media (max-width:767px){.site-brand{padding:20px 16px}.site-brand-link svg{height:44px}}.container{max-width:780px;margin:40px auto;padding:56px 44px 72px;background:var(--white);border-radius:28px;box-shadow:0 10px 40px rgba(141,194,222,.18)}.article-title{font-size:28px;line-height:1.7;font-weight:700;color:var(--text);margin-bottom:32px;letter-spacing:.01em}.article-meta{display:flex;gap:24px;flex-wrap:wrap;font-size:13px;color:var(--text-muted);margin-bottom:56px;padding-bottom:32px;border-bottom:1px solid var(--primary-soft)}.article-meta .label{font-size:11px;color:var(--primary-deep);font-weight:600;margin-right:8px}.toc{background:linear-gradient(135deg,var(--primary-tint) 0%,var(--white) 100%);border:2px solid var(--primary-soft);border-radius:24px;padding:36px 40px;margin:48px 0 64px;box-shadow:0 8px 24px rgba(141,194,222,.12)}.toc-title{font-size:17px;font-weight:700;color:var(--primary-deep);margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--primary-soft);letter-spacing:.12em}.toc ol{list-style:none;counter-reset:toc}.toc li{counter-increment:toc;padding:10px 0 10px 44px;position:relative;font-size:14.5px;line-height:1.7}.toc li:before{content:counter(toc);position:absolute;left:0;top:10px;width:30px;height:30px;background:var(--primary);color:var(--white);font-weight:700;font-size:12px;border-radius:50%;display:flex;align-items:center;justify-content:center}.toc a{color:var(--text);text-decoration:none}.toc a:hover{color:var(--primary-deep)}.article-body h2{font-size:22px;line-height:1.65;font-weight:700;color:var(--white);margin:80px 0 32px;padding:22px 28px;background:linear-gradient(135deg,var(--primary-mid) 0%,var(--primary-deep) 100%);border-radius:18px;box-shadow:0 6px 18px rgba(58,139,186,.25);text-align:left}.article-body h3{font-size:19px;line-height:1.65;font-weight:700;color:var(--text);margin:52px 0 22px;padding-bottom:10px;display:block;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='6' viewBox='0 0 14 6'><path d='M0 3 Q 3.5 0 7 3 T 14 3' stroke='%238dc2de' stroke-width='1.4' fill='none'/></svg>");background-repeat:repeat-x;background-position:bottom;background-size:14px 6px}.article-body h4{font-size:16.5px;font-weight:700;color:var(--text);margin:36px 0 14px;padding-left:22px;position:relative}.article-body h4:before{content:"";position:absolute;left:0;top:12px;width:10px;height:10px;background:var(--primary);transform:rotate(45deg);border-radius:2px}.article-body p{margin-bottom:1.9em;font-size:16px;line-height:2.1}.article-body strong{color:var(--text);font-weight:700}.article-body a{color:var(--primary-deep);font-weight:700;text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px;text-decoration-color:var(--primary-soft)}.article-body a:hover{color:var(--primary-darker);text-decoration-color:var(--primary-deep)}.article-body ul,.article-body ol{margin:0 0 2em;padding-left:0;list-style:none}.article-body ul li{position:relative;font-size:15.5px;line-height:2;padding:6px 0 6px 26px;margin-bottom:4px}.article-body ul li:before{content:"";position:absolute;left:4px;top:18px;width:9px;height:9px;background:var(--primary-deep);border-radius:50%}.article-body ol{counter-reset:ol-counter}.article-body ol li{counter-increment:ol-counter;position:relative;padding:6px 0 6px 40px;font-size:15.5px}.article-body ol li:before{content:counter(ol-counter);position:absolute;left:0;top:8px;width:28px;height:28px;background:var(--primary);color:var(--white);font-weight:700;font-size:13px;border-radius:50%;display:flex;align-items:center;justify-content:center}.article-body .table-wrap{overflow-x:auto;margin:32px 0}.article-body table{width:100%;border-collapse:separate;border-spacing:0;font-size:14.5px;background:var(--white);border-radius:20px;overflow:hidden;box-shadow:0 6px 20px rgba(141,194,222,.15)}.article-body table tbody td{padding:16px 20px;border-bottom:1px solid var(--primary-soft);line-height:1.75}.article-body table tbody tr:last-child td{border-bottom:none}.article-body table tbody tr td:first-child{color:var(--text-sub);font-size:13px;font-weight:500;background:var(--primary-tint);width:34%;white-space:nowrap}.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;margin:32px 0 48px;border-radius:20px;background:var(--primary-bg);box-shadow:0 10px 28px rgba(141,194,222,.2)}.video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.related-posts{margin-top:96px;padding-top:48px;border-top:1px solid var(--primary-soft)}.article-body .related-posts h2,.related-posts-title{font-size:22px;font-weight:700;color:var(--text);margin:0 0 36px;padding:0 0 0 20px;letter-spacing:.08em;line-height:1.5;background:0 0;border-radius:0;box-shadow:none;border-left:5px solid var(--primary-deep);text-align:left}.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.related-card{display:block;padding:28px;background:var(--white);border-radius:20px;text-decoration:none;color:var(--text);transition:all .3s ease;box-shadow:0 4px 16px rgba(141,194,222,.12)}.related-card:hover{transform:translateY(-6px);box-shadow:0 16px 36px rgba(141,194,222,.25)}.related-card .cat{display:inline-block;font-size:11px;font-weight:700;color:var(--white);background:var(--primary);padding:4px 14px;border-radius:20px;margin-bottom:14px}.related-card h4{font-size:15px;font-weight:700;line-height:1.6;padding:0;margin:0}.related-card h4:before{display:none}.breadcrumb{font-size:12px;color:var(--text-muted);margin-top:56px;padding-top:24px;border-top:1px solid var(--primary-soft)}.breadcrumb a{color:var(--text-muted);text-decoration:none}.breadcrumb a:hover{color:var(--primary-deep)}.breadcrumb .sep{margin:0 10px}.site-footer{background:0 0;padding:40px 32px 32px;margin-top:40px}.footer-inner{max-width:780px;margin:0 auto;color:var(--text-sub);text-align:center}.footer-brand{font-size:18px;font-weight:700;color:var(--text);margin-bottom:20px;letter-spacing:.08em}.footer-nav{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;font-size:13px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--primary-soft);list-style:none}.footer-nav a{color:var(--text-sub);text-decoration:none}.footer-nav a:hover{color:var(--primary-deep)}.footer-company{font-size:12.5px;line-height:1.95;margin-bottom:20px}.footer-company .label{font-weight:700;color:var(--text);margin-right:10px}.footer-company a{color:var(--primary-deep)}.footer-copyright{font-size:11px;color:var(--text-muted);padding-top:20px;border-top:1px solid var(--primary-soft)}@media (max-width:1024px){.container{margin:32px 20px;max-width:calc(100% - 40px);padding:48px 36px 60px}.site-footer{padding:36px 20px 28px}.footer-inner{max-width:100%}}@media (max-width:767px){body{font-size:15px;line-height:1.95}.container{margin:14px 10px;max-width:calc(100% - 20px);padding:30px 18px 44px;border-radius:18px}.article-title{font-size:19px;line-height:1.6;margin-bottom:22px}.article-meta{font-size:11.5px;gap:14px;margin-bottom:36px;padding-bottom:22px}.article-meta .label{font-size:10px;margin-right:4px}.toc{padding:22px 20px;margin:28px 0 44px;border-radius:16px}.toc-title{font-size:14.5px;margin-bottom:16px;padding-bottom:12px;letter-spacing:.08em}.toc li{font-size:13px;padding:7px 0 7px 36px;line-height:1.65}.toc li:before{width:24px;height:24px;font-size:11px;top:8px}.article-body h2{font-size:16.5px;padding:14px 16px;margin:52px 0 22px;border-radius:14px;line-height:1.55}.article-body h3{font-size:15.5px;margin:36px 0 14px;padding-bottom:8px}.article-body h4{font-size:14.5px;margin:26px 0 10px;padding-left:18px}.article-body h4:before{width:8px;height:8px;top:10px}.article-body p{font-size:14px;line-height:1.95;margin-bottom:1.5em}.article-body ul li{font-size:13.5px;padding:4px 0 4px 22px;line-height:1.9}.article-body ul li:before{width:7px;height:7px;left:3px;top:14px}.article-body ol li{font-size:13.5px;padding-left:36px}.article-body ol li:before{width:24px;height:24px;font-size:11px}.article-body table{font-size:12.5px;border-radius:14px}.article-body table tbody td{padding:11px 12px}.article-body table tbody tr td:first-child{font-size:11px;padding:11px 10px}.video-embed{margin:22px 0 32px;border-radius:14px}.related-posts{margin-top:56px;padding-top:28px}.related-posts-title{font-size:17px;margin-bottom:22px;padding-left:14px;border-left-width:4px}.related-grid{grid-template-columns:1fr;gap:16px}.related-card{padding:18px;border-radius:14px}.related-card .cat{font-size:10px;padding:3px 10px;margin-bottom:10px}.related-card h4{font-size:13px}.breadcrumb{font-size:11px;margin-top:40px;padding-top:18px}.breadcrumb .sep{margin:0 6px}.site-footer{padding:24px 16px 20px}.footer-brand{font-size:15px;margin-bottom:14px}.footer-nav{gap:12px;font-size:11.5px;margin-bottom:16px;padding-bottom:16px}.footer-company{font-size:11px;margin-bottom:14px}.footer-copyright{font-size:10px;padding-top:14px}}@media print{body{background:#fff;color:#000}.site-brand,.site-footer,.breadcrumb,.related-posts{display:none}.container{box-shadow:none;margin:0;padding:0;max-width:100%;border-radius:0}}