*{box-sizing:border-box;margin:0;padding:0}:root{--accent:#4fc3d4;--accent-dark:#38a8b8;--text:#333;--text-muted:#666;--text-faint:#999;--bg:#fff;--bg-gray:#f8f9fa;--border:#e9e9e7;--shadow:0 4px 20px #00000014;--shadow-hover:0 8px 30px #0000001f;--radius:12px}html{scroll-behavior:smooth;scroll-padding-top:60px}body{background-color:var(--bg);color:var(--text);font-family:Hiragino Sans,Yu Gothic UI,Meiryo,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}.btn-primary:active,.btn-secondary:active,.btn-outline:active,.nav-cta:active,.service-card:active,.post-thumb-card:active,.own-service-card:active,.post-cta-btn:active,.blog-chip:active,.service-sample-btn:active{transition:transform 80ms ease-out;transform:scale(.98)}.nav{z-index:100;border-bottom:1px solid var(--border);background:#fffffff7;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;max-width:1200px;height:60px;margin:0 auto;padding:0 24px;display:flex}.nav-logo{color:var(--accent);letter-spacing:.04em;align-items:center;font-size:1.2rem;font-weight:700;display:flex}.nav-logo-img{width:auto;height:30px;display:block}.nav-transparent{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border-bottom-color:#0000;transition:background .3s,border-color .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s;position:fixed;left:0;right:0}.nav-transparent.nav-solid{border-bottom-color:var(--border);background:#fffffff7}.nav-links{color:var(--text-muted);align-items:center;gap:24px;font-size:.9rem;display:flex}.nav-links a:hover{color:var(--accent)}.nav-cta{background:var(--accent);border-radius:6px;padding:8px 18px;font-weight:700;transition:background .2s;color:#fff!important}.nav-cta:hover{background:var(--accent-dark)!important}.nav-burger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:9px 8px;display:none}.nav-burger span{background:var(--text);border-radius:2px;width:100%;height:2px;transition:transform .25s,opacity .2s;display:block}.nav-burger-open span:first-child{transform:translateY(7px)rotate(45deg)}.nav-burger-open span:nth-child(2){opacity:0}.nav-burger-open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.nav-overlay{z-index:1;opacity:0;pointer-events:none;background:#00000061;transition:opacity .3s;display:none;position:fixed;inset:60px 0 0}.nav-overlay-open{opacity:1;pointer-events:auto}.btn-primary{background:var(--accent);color:#fff;border-radius:8px;padding:14px 32px;font-size:1rem;font-weight:700;transition:background .2s,transform .15s;display:inline-block}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-secondary{color:var(--accent);border:2px solid var(--accent);background:0 0;border-radius:8px;padding:12px 30px;font-size:1rem;font-weight:700;transition:background .2s,color .2s;display:inline-block}.btn-secondary:hover{background:var(--accent);color:#fff}.btn-outline{color:var(--accent);border:1px solid var(--accent);border-radius:6px;padding:10px 28px;font-size:.95rem;font-weight:700;transition:background .2s,color .2s;display:inline-block}.btn-outline:hover{background:var(--accent);color:#fff}.hero{background:linear-gradient(135deg,#f0fbfc 0%,#e8f7fa 40%,#fff 100%) 100%/cover no-repeat;flex-direction:column;justify-content:center;min-height:calc(100dvh - 60px);display:flex;position:relative;overflow:hidden}.hero-under-header{min-height:100dvh}.hero-has-image:before{content:"";z-index:1;background:linear-gradient(90deg,#fffffff5 0%,#ffffffd9 38%,#ffffff59 68%,#fff0 100%);position:absolute;inset:0}.hero-inner{z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:48px 24px;position:relative}.hero-scroll{z-index:3;color:var(--text);letter-spacing:.08em;flex-direction:column;align-items:center;gap:2px;font-size:.7rem;font-weight:600;display:flex;position:absolute;bottom:26px;left:50%;transform:translate(-50%)}.hero-scroll-icon{animation:1.6s ease-in-out infinite heroScrollBounce}@keyframes heroScrollBounce{0%,to{transform:translateY(0)}50%{transform:translateY(7px)}}.hero-content{text-align:left;max-width:560px}.hero-catch{color:var(--text);letter-spacing:-.01em;margin-bottom:24px;font-size:2.8rem;font-weight:700;line-height:1.3}.hero-tagline{color:var(--text-muted);margin-bottom:40px;font-size:1.1rem;line-height:1.8}.hero-actions{flex-wrap:wrap;gap:16px;display:flex}.section{padding:80px 24px}.section-gray{background-color:var(--bg-gray)}.section-inner{max-width:1200px;margin:0 auto}.section-eyebrow{text-align:center;letter-spacing:.15em;color:var(--accent);margin-bottom:12px;font-size:.8rem;font-weight:700}.section-title{text-align:center;color:var(--text);margin-bottom:12px;font-size:2rem;font-weight:700}.section-subtitle{text-align:center;color:var(--text-muted);max-width:600px;margin-bottom:48px;margin-left:auto;margin-right:auto;font-size:1rem}.section-more{text-align:center;margin-top:40px}.reveal{opacity:0;will-change:opacity, transform;transition:opacity .7s,transform .7s;transform:translateY(30px)}.reveal.is-visible{opacity:1;transform:none}.services-grid{gap:24px;display:grid}.main-grid{grid-template-columns:repeat(2,1fr);gap:60px;max-width:900px;margin:0 auto 40px}.sub-grid{grid-template-columns:repeat(3,1fr)}.sub-label{color:var(--text-muted);border-left:3px solid var(--border);margin-bottom:20px;padding-left:10px;font-size:.85rem;font-weight:700}.svc-carousel{position:relative}.svc-arrow{z-index:3;width:38px;height:38px;color:var(--accent);border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;display:none;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 2px 10px #00000029}.svc-arrow-prev{left:2px}.svc-arrow-next{right:2px}.service-card{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;transition:transform .25s,box-shadow .25s;display:block;overflow:hidden}.service-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}.service-img{aspect-ratio:16/10;background:var(--bg-gray);width:100%;position:relative;overflow:hidden}.main-grid .service-img{aspect-ratio:1}.service-img img{object-fit:cover;width:100%;height:100%;transition:transform .45s;display:block}.service-card:hover .service-img img{transform:scale(1.07)}.service-img-placeholder{background:linear-gradient(135deg, var(--bg-gray), #e9edf0);width:100%;height:100%}.service-en-label{color:#ffffffd1;letter-spacing:.14em;text-shadow:0 1px 6px #00000059;margin-bottom:5px;font-size:.72rem;font-weight:700;display:block}.service-arrow-btn{color:#fff;background:#ffffff29;border:1.5px solid #ffffffbf;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;transition:background .25s,border-color .25s;display:flex;position:absolute;top:18px;right:18px}.service-card:hover .service-arrow-btn{background:var(--accent);border-color:var(--accent)}.service-overlay{background:linear-gradient(#ffffff2e,#ffffff2e),linear-gradient(#0d1c3000 28%,#0d1c304d 58%,#0d1c30d1 100%);flex-direction:column;justify-content:flex-end;padding:26px 28px;transition:background .35s;display:flex;position:absolute;inset:0}.service-card:hover .service-overlay{background:linear-gradient(#0f213a8c 0%,#0f213ac7 40%,#0f213aed 100%)}.service-overlay-title{color:#fff;text-shadow:0 1px 8px #00000059;font-size:1.35rem;font-weight:700;line-height:1.4}.service-overlay-detail{opacity:0;max-height:0;transition:opacity .35s,max-height .35s,margin-top .35s;overflow:hidden}.service-card:hover .service-overlay-detail{opacity:1;max-height:260px;margin-top:12px}.service-overlay-desc{color:#ffffffeb;margin-bottom:8px;font-size:.92rem;font-weight:700}.service-overlay-text{color:#ffffffd1;font-size:.83rem;line-height:1.75}@media (max-width:1024px){.service-overlay{background:linear-gradient(#ffffff2e,#ffffff2e),linear-gradient(#0f213a14 0%,#0f213a4d 45%,#0f213a8c 100%)}.service-overlay-detail{opacity:1;max-height:320px;margin-top:12px}}.sub-grid .service-overlay{padding:20px 22px}.sub-grid .service-overlay-title{font-size:1.1rem}.sub-grid .service-arrow-btn{width:36px;height:36px;top:14px;right:14px}.apps-embed{border-radius:var(--radius);border:1px solid var(--border);background:#fff;overflow:hidden}.apps-embed iframe{display:block}.own-services-grid{grid-template-columns:repeat(2,1fr);gap:32px;max-width:1000px;margin:0 auto;display:grid}.own-service-card{border:1px solid var(--border);color:inherit;background:#fff;border-radius:12px;flex-direction:column;text-decoration:none;transition:transform .2s,box-shadow .25s,border-color .2s;display:flex;overflow:hidden}.own-service-card:hover{box-shadow:var(--shadow-hover);border-color:var(--accent);transform:translateY(-4px)}.own-service-image{aspect-ratio:16/10;object-fit:cover;background:var(--bg-gray);width:100%;display:block}.own-service-body{flex-direction:column;flex:1;gap:8px;padding:20px 22px 22px;display:flex}.own-service-title{color:var(--text);font-size:1.05rem;font-weight:700;line-height:1.5}.own-service-caption{color:var(--text-muted);flex:1;font-size:.88rem;line-height:1.7}.own-service-link{color:var(--accent);margin-top:4px;font-size:.88rem;font-weight:700}@media (max-width:768px){.own-services-grid{gap:12px}.own-services-grid .own-service-card{scroll-snap-align:center;flex:0 0 78%}.own-services-grid:before,.own-services-grid:after{content:"";flex:0 0 11%}}.metrics-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.metric-card{border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;justify-content:center;align-items:center;gap:18px;padding:32px 18px;display:flex}.metric-card-body{min-width:0}.metric-wheat{color:#e5a722;flex-shrink:0;width:40px;height:auto}.metric-wheat-left{transform:scaleX(-1)}@media (max-width:768px){.metric-wheat{width:30px}}.metric-value{color:var(--accent);margin-bottom:12px;font-size:3rem;font-weight:700;line-height:1}.metric-suffix{color:var(--text-muted);margin-left:4px;font-size:1.2rem;font-weight:400}.metric-label{color:var(--text-muted);font-size:.95rem}.posts-grid{grid-template-columns:repeat(3,1fr);gap:28px;display:grid}.blog-chips{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:32px;display:flex}.blog-chip{background:var(--bg);color:var(--text-muted);border:1.5px solid var(--border);cursor:pointer;letter-spacing:.02em;border-radius:999px;padding:8px 18px;font-size:.88rem;font-weight:700;transition:background .18s,color .18s,border-color .18s,transform .12s}.blog-chip:hover{border-color:var(--accent);color:var(--accent)}.blog-chip.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}.blog-empty{text-align:center;color:var(--text-faint);grid-column:1/-1;padding:32px 0}.post-thumb-card{border:1px solid var(--border);border-radius:var(--radius);background:#fff;transition:transform .25s,box-shadow .25s;display:block;overflow:hidden}.post-thumb-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}.post-thumb-img{aspect-ratio:16/9;background:var(--bg-gray);overflow:hidden}.post-thumb-img img{object-fit:cover;width:100%;height:100%;display:block}.post-thumb-placeholder{background:linear-gradient(135deg,#e8f7fa,#f0fbfc);width:100%;height:100%}.post-thumb-body{padding:18px 20px 22px}.post-thumb-meta{align-items:center;gap:10px;margin-bottom:10px;display:flex}.post-thumb-date{color:var(--text-faint);font-size:.8rem}.post-thumb-title{color:var(--text);font-size:1rem;font-weight:700;line-height:1.6}.profile-card{border-radius:var(--radius);max-width:800px;box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;align-items:flex-start;gap:40px;margin:0 auto;padding:48px 40px;display:flex}.profile-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;display:flex}.profile-avatar svg{width:60px;height:60px}.profile-body{flex:1}.profile-name{color:var(--text);margin-bottom:6px;font-size:1.5rem;font-weight:700}.profile-role{color:var(--accent);margin-bottom:16px;font-size:.9rem;font-weight:700}.profile-text{color:var(--text-muted);font-size:.95rem;line-height:1.8}.footer{background:var(--text);color:#fff;padding:60px 24px 40px}.footer-inner{text-align:center;max-width:800px;margin:0 auto}.footer-cta{margin-bottom:48px}.footer-cta-title{margin-bottom:28px;font-size:1.5rem;font-weight:700}.footer-actions{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.footer .btn-secondary{color:#fff;border-color:#fff}.footer .btn-secondary:hover{color:var(--text);background:#fff}.footer-sublinks{color:#999;margin-top:22px;font-size:.82rem}.footer-sublinks a{color:#d0d0d0;margin:0 6px;text-decoration:underline}.footer-sublinks a:hover{color:#fff}.footer-sublinks-sep{color:#666}.footer-copy{color:#999;font-size:.8rem}@media (max-width:768px){.nav-burger{display:flex}.nav-overlay{display:block}.nav-links{z-index:2;background:#fff;flex-direction:column;align-items:stretch;gap:0;width:76%;max-width:320px;padding:14px 22px 28px;transition:transform .3s;position:fixed;top:60px;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-10px 0 30px #0000001f}.nav-links-open{transform:translate(0)}.nav-links a{border-bottom:1px solid var(--border);width:100%;padding:15px 4px;font-size:.98rem}.nav-links .nav-cta{text-align:center;border-bottom:none;margin-top:20px;padding:14px 18px;font-size:.95rem}.hero-inner{padding:40px 20px}.hero-content{max-width:100%}.hero-catch{font-size:2rem}.hero-tagline{font-size:1rem}.hero-has-image:before{background:linear-gradient(#ffffffeb 0%,#ffffffd1 60%,#fff9 100%)}.section{padding:60px 20px}.section-title{font-size:1.6rem}.services-grid{overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:12px;display:flex;overflow-x:auto}.services-grid::-webkit-scrollbar{display:none}.services-grid .service-card{scroll-snap-align:center}.main-grid .service-card{flex:0 0 84%}.sub-grid .service-card{flex:0 0 66%}.sub-grid .service-overlay-text{display:none}.main-grid:before,.main-grid:after{content:"";flex:0 0 8%}.sub-grid:before,.sub-grid:after{content:"";flex:0 0 17%}.svc-arrow{display:flex}.metrics-grid,.cards-grid{grid-template-columns:1fr}.profile-card{text-align:center;flex-direction:column;align-items:center;gap:24px;padding:32px 24px}.posts-grid{grid-template-columns:1fr}#blog .posts-grid,.posts-grid-list,.related-section .posts-grid{grid-template-columns:repeat(2,1fr);gap:14px}#blog .posts-grid>.post-thumb-card:nth-child(n+7){display:none}#blog .post-thumb-meta,.posts-grid-list .post-thumb-meta,.related-section .post-thumb-meta{flex-direction:column;align-items:flex-start;gap:6px}#blog .post-thumb-title,.posts-grid-list .post-thumb-title,.related-section .post-thumb-title{font-size:.85rem}.footer-cta-title{font-size:1.2rem}}.post-page{background:0 0;min-height:100vh;padding:60px 24px}.post-article{border:1px solid var(--border);border-radius:var(--radius);max-width:864px;box-shadow:var(--shadow);background:#fff;margin:0 auto;padding:48px 52px}.post-header{margin-bottom:40px}.post-meta-row{align-items:center;gap:12px;margin:12px 0 16px;display:flex}.post-type-badge{letter-spacing:.05em;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:700;display:inline-block}.post-type-badge.blog{color:var(--accent);background:#e8f7fa}.post-type-badge.app{color:#e07830;background:#fff0e8}.post-type-badge.sheet{color:#2e8b57;background:#e9f5ec}.post-header-date{color:var(--text-faint);font-size:.85rem}.post-heading{color:var(--text);margin-bottom:16px;font-size:2rem;font-weight:700;line-height:1.4}.post-description{color:var(--text-muted);margin-bottom:16px;font-size:1rem;line-height:1.7}.post-tags{flex-wrap:wrap;gap:8px;display:flex}.post-tag{background:var(--bg-gray);color:var(--text-muted);border:1px solid var(--border);border-radius:4px;padding:4px 10px;font-size:.8rem}.post-thumbnail{object-fit:cover;border-radius:var(--radius);width:100%;max-height:400px;margin-bottom:28px}.post-app-embed-wrap{margin-bottom:40px}.post-app-embed-label{color:var(--text);border-left:4px solid var(--accent);margin-bottom:12px;padding-left:12px;font-size:1.2rem;font-weight:700}.post-app-embed{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.works-gallery{border-radius:10px;width:100%;margin-bottom:36px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000 0,#000 24px calc(100% - 24px),#0000 100%);mask-image:linear-gradient(90deg,#0000 0,#000 24px calc(100% - 24px),#0000 100%)}.works-gallery-track{gap:16px;width:max-content;animation:40s linear infinite works-marquee;display:flex}.works-gallery-track:hover{animation-play-state:paused}.works-gallery-item{aspect-ratio:16/9;background:var(--bg-gray);border-radius:8px;flex:0 0 480px;overflow:hidden}.works-gallery-item img{object-fit:cover;width:100%;height:100%;display:block}@keyframes works-marquee{0%{transform:translate(0)}to{transform:translate(calc(-50% - 8px))}}@media (max-width:768px){.works-gallery-item{flex-basis:280px}}.works-meta{grid-template-columns:max-content 1fr;gap:6px 18px;margin:16px 0 0;font-size:.9rem;display:grid}.works-meta-row{display:contents}.works-meta dt{color:var(--text-muted);font-weight:700}.works-meta dd{color:var(--text);margin:0}.works-sample{text-align:center;margin:0 0 36px}.post-sheet-embed{border:1px solid var(--border);background:var(--bg);border-radius:8px;width:100%;margin:24px 0;overflow:hidden}.post-sheet-embed iframe{border:0;width:100%;min-height:120px;display:block}.post-cta-row{flex-wrap:wrap;justify-content:center;gap:14px;margin:32px 0;display:flex}.post-cta-btn{border-radius:10px;align-items:center;gap:10px;padding:16px 36px;font-size:1.05rem;font-weight:700;transition:background .2s,color .2s,transform .15s,box-shadow .2s;display:inline-flex;box-shadow:0 2px 8px #0000001a;text-decoration:none!important}.post-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000002e}.post-cta-btn svg{flex-shrink:0;width:20px;height:20px}.post-cta-btn-primary{background:var(--accent);border:2px solid var(--accent);color:#fff!important}.post-cta-btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}.post-cta-btn-secondary{border:2px solid var(--accent);background:0 0;color:var(--accent)!important}.post-cta-btn-secondary:hover{background:var(--accent);color:#fff!important}.post-share{flex-direction:column;align-items:center;margin-top:40px;margin-bottom:60px;display:flex}.post-share-label{color:var(--text-muted);margin-bottom:14px;font-size:.85rem}.post-share-buttons{justify-content:center;gap:12px;display:flex}.post-share-btn{cursor:pointer;color:#fff;border:none;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;padding:0;text-decoration:none;transition:transform .2s,opacity .2s;display:inline-flex}.post-share-btn:hover{opacity:.9;transform:translateY(-2px)}.post-share-glyph{color:#fff;font-family:Helvetica Neue,Arial,Hiragino Sans,sans-serif;font-size:1.45rem;font-weight:700;line-height:1}.post-share-glyph-url{letter-spacing:0;font-size:1rem}.post-share-glyph-line{letter-spacing:.02em;font-size:.82rem}.post-share-x{background:#000}.post-share-facebook{background:#1877f2}.post-share-line{background:#06c755}.post-share-hatena{background:#00a4de}.post-share-copy{background:#6b7280}.post-share-toast{color:var(--accent);opacity:0;margin-top:12px;font-size:.85rem;transition:opacity .2s;display:inline-block}.post-share-toast.is-visible{opacity:1}.post-lightbox{z-index:2000;cursor:zoom-out;background:#ffffffeb;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.post-lightbox-figure{flex-direction:column;align-items:center;gap:14px;max-width:100%;max-height:100%;margin:0;display:flex}.post-lightbox img{object-fit:contain;border-radius:6px;max-width:100%;max-height:calc(100vh - 120px)}.post-lightbox figcaption{color:var(--text-muted);text-align:center;max-width:80ch;font-size:.88rem;line-height:1.6}.post-toc{background:var(--bg-gray);border:1px solid var(--border);border-radius:10px;margin-bottom:40px;padding:20px 24px}.post-toc-title{color:var(--text);margin-bottom:12px;font-size:.95rem;font-weight:700}.post-toc ul{margin:0;padding:0;list-style:none}.post-toc-item{margin:7px 0;line-height:1.5}.post-toc-item a{color:var(--text-muted);font-size:.9rem;text-decoration:none}.post-toc-item a:hover{color:var(--accent);text-decoration:underline}.post-toc-sub{padding-left:1.3em}.post-toc-sub a{font-size:.84rem}.post-body{color:var(--text);margin-bottom:60px;font-size:1rem;line-height:1.9}.post-body h2{border-bottom:2px solid var(--accent);color:var(--text);margin:48px 0 16px;padding-bottom:8px;font-size:1.5rem;font-weight:700}.post-body h3{color:var(--text);margin:36px 0 12px;font-size:1.2rem;font-weight:700}.post-body p{margin-bottom:20px}.post-body ul,.post-body ol{margin-bottom:20px;padding-left:24px}.post-body li{margin-bottom:8px}.post-body code{background:var(--bg-gray);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:Menlo,Monaco,monospace;font-size:.88em}.post-body pre{border-radius:var(--radius);background:#1e1e1e;margin-bottom:24px;padding:20px;overflow-x:auto}.post-body pre code{color:#d4d4d4;background:0 0;border:none;padding:0;font-size:.9em}.post-body blockquote{border-left:4px solid var(--accent);color:var(--text-muted);margin:0 0 20px;padding:4px 0 4px 20px}.post-body a{color:var(--accent);text-decoration:underline}.post-body strong{font-weight:700}.post-body em{font-style:italic}.post-body table{table-layout:fixed;border-collapse:collapse;width:100%;margin:24px 0;font-size:.9rem}.post-body table th,.post-body table td{border:1px solid var(--border);text-align:center;word-break:break-word;padding:10px 12px}.post-body table th{background:var(--bg-gray);color:var(--text);font-weight:700}.post-body table tr td:first-child,.post-body table tr th:first-child{text-align:left}.post-figure{margin:32px 0}.post-figure img{border-radius:var(--radius);border:1px solid var(--border);width:100%;display:block}.post-figure figcaption{color:var(--text-faint);text-align:center;margin-top:10px;font-size:.85rem}.post-body img{border-radius:var(--radius);max-width:100%}.post-body iframe{border:1px solid var(--border);border-radius:var(--radius);width:100%;margin:24px 0}.post-back a{color:var(--accent);font-size:.95rem}@media (max-width:768px){.post-page{padding:36px 16px}.post-article{padding:24px 18px}.post-heading{font-size:1.5rem}}.footer-legal{margin-bottom:18px;font-size:.85rem}.footer-legal a{color:#d0d0d0;margin:0 8px;text-decoration:none}.footer-legal a:hover{color:#fff;text-decoration:underline}.footer-legal-sep{color:#666}.legal-inner{max-width:720px;margin:0 auto}.sitemap-groups{flex-direction:column;gap:36px;margin-top:32px;display:flex}.sitemap-group-title{color:var(--text);border-left:3px solid var(--accent);margin-bottom:14px;padding-left:10px;font-size:1.05rem;font-weight:700}.sitemap-group ul{margin:0;padding:0;list-style:none}.sitemap-group li{margin:8px 0}.sitemap-group li a{color:var(--text-muted);font-size:.95rem;text-decoration:none}.sitemap-group li a:hover{color:var(--accent);text-decoration:underline}.legal-body{color:var(--text);margin-top:32px;font-size:.95rem;line-height:1.9}.legal-body h2{color:var(--text);margin:36px 0 10px;font-size:1.15rem;font-weight:700}.legal-body p{margin-bottom:14px}.legal-body ul{margin:0 0 14px 1.2em;list-style:outside}.legal-body li{margin-bottom:6px}.legal-body a{color:var(--accent-dark);text-decoration:underline}.legal-meta{color:var(--text-faint);margin-top:40px;font-size:.85rem}.contact-notice{background:var(--bg-gray);border:1px solid var(--border);border-radius:var(--radius);text-align:center;margin:32px 0 40px;padding:24px}.contact-notice-title{margin-bottom:8px;font-size:1.05rem;font-weight:700}.contact-notice-text{color:var(--text-muted);margin-bottom:16px;font-size:.9rem;line-height:1.8}.contact-form{flex-direction:column;gap:20px;display:flex}.contact-field{flex-direction:column;gap:6px;display:flex}.contact-label{color:var(--text);font-size:.9rem;font-weight:700}.contact-form input[type=text],.contact-form input[type=email],.contact-form textarea{width:100%;color:var(--text);background:var(--bg);border:1px solid var(--border-strong,#d9d9d6);border-radius:8px;padding:12px 14px;font-family:inherit;font-size:1rem}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);outline:none}.contact-form textarea{resize:vertical;line-height:1.7}.contact-hp{opacity:0;width:1px;height:1px;position:absolute;left:-9999px}.contact-error{color:#b42b2b;font-size:.88rem}.contact-submit{cursor:pointer;border:none;align-self:center;min-width:180px;font-family:inherit}.contact-submit:disabled{opacity:.6;cursor:not-allowed}.contact-done{background:var(--bg-gray);border-radius:var(--radius);text-align:center;margin:40px 0;padding:32px 24px}.contact-done-title{color:var(--accent-dark);margin-bottom:10px;font-size:1.2rem;font-weight:700}.contact-done-text{color:var(--text-muted);font-size:.92rem;line-height:1.8}.contact-recaptcha-notice{color:var(--text-faint);margin-top:16px;font-size:.72rem;line-height:1.7}.contact-recaptcha-notice a{color:var(--accent);text-decoration:underline}.related-section{background:var(--bg-gray);padding:56px 24px}.related-inner{max-width:900px;margin:0 auto}.related-title{color:var(--text);text-align:center;margin-bottom:28px;font-size:1.3rem;font-weight:700}.service-detail-inner{max-width:1280px;margin:0 auto}.service-detail-text{color:var(--text-muted);text-align:center;text-wrap:balance;max-width:640px;margin:0 auto;font-size:.95rem;line-height:1.9}.service-samples{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px 20px;margin:40px 0;display:grid}.service-sample{margin:0}.service-sample img{aspect-ratio:16/10;object-fit:cover;border:1px solid var(--border);border-radius:8px;width:100%;display:block}.service-sample figcaption{color:var(--text);margin-top:9px;font-size:.83rem;line-height:1.5}@media (max-width:768px){.service-samples{grid-template-columns:repeat(2,1fr);gap:18px 12px}}.service-detail-cta{flex-direction:column;align-items:center;gap:14px;margin-top:44px;display:flex}.service-detail-cta .btn-primary,.service-detail-cta .btn-secondary,.service-detail-cta .btn-outline{text-align:center;min-width:260px}.service-sample-btn,.service-sample-link{background:0 0;border:none;border-radius:8px;width:100%;padding:0;transition:transform .22s;display:block;position:relative}.service-sample-btn{cursor:zoom-in}.service-sample-overlay{opacity:0;pointer-events:none;background:#00000057;border-radius:8px;justify-content:center;align-items:center;transition:opacity .22s;display:flex;position:absolute;inset:0}.service-sample-more{color:#fff;letter-spacing:.18em;border-bottom:2px solid var(--accent);padding-bottom:5px;font-size:.85rem;font-weight:700}@media (hover:hover){.service-sample-btn:hover,.service-sample-link:hover{transform:translateY(-4px)}.service-sample-btn:hover .service-sample-overlay,.service-sample-link:hover .service-sample-overlay{opacity:1}}.lightbox{z-index:1000;cursor:zoom-out;background:#ffffffeb;justify-content:center;align-items:center;padding:32px;animation:.22s ease-out lightbox-fade;display:flex;position:fixed;inset:0}@keyframes lightbox-fade{0%{opacity:0}to{opacity:1}}@keyframes lightbox-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.lightbox-inner{cursor:default;transform-origin:50%;flex-direction:column;align-items:center;gap:14px;max-width:min(1100px,100%);max-height:100%;animation:.24s ease-out lightbox-pop;display:flex}.lightbox-img{border:1px solid var(--border);object-fit:contain;border-radius:6px;max-width:100%;max-height:75vh;box-shadow:0 10px 36px #0000002e}.lightbox-body{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:0 16px;display:flex}.lightbox-caption{color:var(--text);max-width:720px;font-size:.95rem;line-height:1.6}.lightbox-link{display:inline-block}.lightbox-close{width:44px;height:44px;color:var(--text);cursor:pointer;background:#0000000f;border:none;border-radius:50%;font-size:1.7rem;line-height:1;position:fixed;top:18px;right:22px}.service-portfolio-eyebrow{margin-top:56px}.service-portfolio-title{text-align:center;color:var(--text);margin-bottom:8px;font-size:1.5rem;font-weight:700}.service-portfolio-empty{text-align:center;color:var(--text-faint);background:var(--bg-gray);border-radius:var(--radius);margin:32px 0;padding:56px 24px;font-size:1rem}.service-ad-box{aspect-ratio:16/10;border:1px solid var(--border);background:var(--bg-gray);border-radius:8px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.service-ad-inner{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.service-ad-label{color:var(--text-faint)!important}
