@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_545ad94b-module__a4OFFq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_545ad94b-module__a4OFFq__variable{--font-inter:"Inter", "Inter Fallback"}
:root{--bg:#fff;--bg-soft:#f8fafc;--bg-soft-2:#eef4ff;--card:#ffffffd6;--card-solid:#fff;--card-border:#e2e8f0;--text:#0f172a;--muted:#475569;--muted-soft:#64748b;--primary:#2563eb;--primary-strong:#1d4ed8;--primary-soft:#eff6ff;--max-width:1120px;--radius-sm:14px;--radius-md:22px;--radius-lg:30px;--shadow-sm:0 10px 24px #0f172a0f;--shadow-md:0 24px 60px #0f172a1a;--shadow-lg:0 26px 90px #2563eb24}*{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-noto-sans), "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;background:var(--bg);color:var(--text);margin:0;line-height:1.6}.en-text,.logo,.sectionLabel,.heroPill,.avatar,.profileMetaLabel,.workCategory,.worksExternal,.footerBrand,.navCta{font-family:var(--font-inter), sans-serif}img{display:block}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}.siteMain{min-height:100vh;overflow-x:clip}.container{width:min(100% - 32px, var(--max-width));margin:0 auto}.header{z-index:50;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffc7;border-bottom:1px solid #e2e8f0d9;position:sticky;top:0}.navShell{justify-content:space-between;align-items:center;gap:20px;min-height:96px;display:flex}.logo{letter-spacing:-.03em;color:var(--text);font-size:1.7rem;font-weight:800}.logo span,.footerBrand span{color:var(--primary)}.navLinks{align-items:center;gap:36px;display:flex}.navLinks a{color:var(--muted);font-size:1.25rem;font-weight:600;transition:color .2s;position:relative}.navLinks a.navLinkActive{color:var(--text)}.navLinks a.navLinkActive:after{content:"";background:linear-gradient(90deg, var(--primary), #4f46e5);border-radius:999px;height:3px;position:absolute;bottom:-8px;left:0;right:0}.navLinks .navLinkContact{display:none}.navLinks a:hover,.worksExternal:hover,.footerIcon:hover{color:var(--primary)}.navCta{color:#fff;background:#0f172a;border-radius:999px;justify-content:center;align-items:center;min-height:52px;padding:0 28px;font-size:1.125rem;font-weight:700;transition:background .2s;display:inline-flex}.navCta:hover{background:#1e293b}.heroSection{background:radial-gradient(circle at 100% 0,#2563eb1a,#0000 34%),linear-gradient(#fff 0%,#f8fbff 100%);padding:72px 0 96px}.heroGrid{grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);align-items:center;gap:48px;min-height:calc(100vh - 170px);display:grid}.heroCopy{max-width:700px}.heroPill{background:var(--primary-soft);color:var(--primary);border:1px solid #dbeafe;border-radius:999px;align-items:center;gap:10px;margin-bottom:24px;padding:8px 14px;font-size:.9rem;font-weight:700;display:inline-flex}.heroPillDot{background:var(--primary);border-radius:50%;width:10px;height:10px;box-shadow:0 0 0 7px #2563eb1f}.heroTitle{letter-spacing:-.04em;margin:0 0 22px;font-size:clamp(2.6rem,5.4vw,5rem);line-height:1.15}.heroTitle span{background:linear-gradient(135deg, var(--primary) 0%, #4f46e5 100%);color:#0000;-webkit-background-clip:text;background-clip:text}.heroLead{max-width:680px;color:var(--muted);margin:0;font-size:1.08rem;line-height:1.95}.heroActions{flex-wrap:wrap;gap:14px;margin-top:34px;display:flex}.btn{cursor:pointer;border-radius:16px;justify-content:center;align-items:center;min-height:54px;padding:0 28px;font-weight:800;transition:transform .22s,box-shadow .22s,background .22s,border-color .22s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn.primary{background:linear-gradient(135deg, var(--primary) 0%, #4f46e5 100%);color:#fff;border:1px solid #2563ebf2;box-shadow:0 18px 30px #2563eb2e}.btn.secondary{color:var(--text);border:1px solid var(--card-border);background:#ffffffe0}.largeBtn{min-width:190px}.heroVisual{justify-content:center;display:flex;position:relative}.heroGlow{filter:blur(22px);z-index:0;background:radial-gradient(circle,#60a5fa5c 0%,#bfdbfe4d 32%,#fff0 70%);border-radius:50%;width:112%;height:112%;position:absolute;inset:8% -6% auto}.profileCard{z-index:1;text-align:center;background:var(--card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;box-shadow:var(--shadow-md);border:1px solid #e2e8f0e0;position:relative}.profileCardLarge{border-radius:var(--radius-lg);max-width:390px;padding:36px 30px}.avatar{background:linear-gradient(135deg, var(--primary) 0%, #4f46e5 100%);color:#fff;border-radius:50%;place-items:center;margin:0 auto 22px;font-weight:800;display:grid;box-shadow:0 20px 36px #2563eb47}.avatarLarge{width:96px;height:96px;font-size:2.1rem}.profileCard h2{letter-spacing:-.03em;margin:0 0 8px;font-size:1.8rem}.profileCard>p{color:var(--muted);margin:0;font-size:1rem;line-height:1.8}.profileMeta{text-align:left;gap:14px;margin-top:30px;display:grid}.profileMeta>div{background:#f8fafcf2;border:1px solid #e5edf8;border-radius:18px;padding:16px 18px}.profileMetaLabel{color:var(--primary);letter-spacing:.12em;margin-bottom:6px;font-size:.75rem;font-weight:800;display:block}.profileMeta strong{font-size:1rem}.section{padding:104px 0}.sectionMuted{background:var(--bg-soft)}.sectionHeading{text-align:center;margin-bottom:52px}.sectionHeadingLeft{text-align:left}.sectionLabel{color:var(--primary);letter-spacing:.16em;margin:0 0 12px;font-size:.9rem;font-weight:800}.sectionHeading h2{letter-spacing:-.03em;margin:0;padding-bottom:16px;font-size:clamp(2rem,4.2vw,2.9rem);display:inline-block;position:relative}.sectionHeading h2:after{content:"";background:var(--primary);border-radius:999px;width:52px;height:4px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.sectionHeadingLeft h2:after,.compactHeading h2:after{left:0;transform:none}.aboutGrid{grid-template-columns:minmax(280px,.9fr) minmax(0,1.1fr);align-items:center;gap:56px;display:grid}.aboutVisual{position:relative}.aboutImageWrap{aspect-ratio:4/5;box-shadow:var(--shadow-md);border-radius:28px;position:relative;overflow:hidden}.aboutImage{object-fit:cover;width:100%;height:100%}.aboutImageOverlay{background:linear-gradient(#1e40af05,#1e40af2e);position:absolute;inset:0}.aboutGlow{filter:blur(18px);z-index:-1;background:#bfdbfee6;border-radius:50%;width:150px;height:150px;position:absolute;bottom:-26px;left:-26px}.aboutBody{gap:18px;display:grid}.aboutBody p{color:var(--muted);margin:0;font-size:1.02rem;line-height:1.95}.aboutBody .aboutHighlight{color:var(--text);font-size:1.28rem;font-weight:800;line-height:1.65}.skillGrid{gap:18px;display:grid}.skillGridModern{grid-template-columns:repeat(4,minmax(0,1fr))}.skillItem{text-align:center;will-change:transform}.skillItemModern{background:var(--card-solid);border:1px solid var(--card-border);min-height:108px;box-shadow:var(--shadow-sm);color:var(--text);border-radius:22px;justify-content:center;align-items:center;padding:22px 16px;font-size:.98rem;font-weight:700;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex}.skillItemModern:hover{border-color:#bfdbfe;transform:translateY(-5px);box-shadow:0 18px 28px #0f172a14}.worksSection{background:#fff}.worksHeader{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:42px;display:flex}.compactHeading{margin-bottom:0}.worksExternal{color:var(--muted);white-space:nowrap;font-weight:700;transition:color .2s}.worksGrid{gap:28px;display:grid}.worksGridModern{grid-template-columns:repeat(3,minmax(0,1fr))}.workCard{border:1px solid var(--card-border);box-shadow:var(--shadow-sm);background:#fff;border-radius:24px;overflow:hidden}.workCardModern{flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex}.workCardModern:hover{border-color:#cbdcfb;transform:translateY(-8px);box-shadow:0 20px 46px #0f172a1f}.workThumbWrap{aspect-ratio:4/3;position:relative;overflow:hidden}.workThumb{object-fit:cover;width:100%;height:100%;transition:transform .5s}.workCardModern:hover .workThumb{transform:scale(1.05)}.workCategory{min-height:34px;color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb;border-radius:999px;align-items:center;padding:0 12px;font-size:.75rem;font-weight:800;display:inline-flex;position:absolute;top:16px;left:16px}.workBody{flex-direction:column;flex:1;padding:28px;display:flex}.workBody h3{margin:0 0 14px;font-size:1.3rem;line-height:1.45}.workDescription{color:var(--muted);margin:0;font-size:.96rem;line-height:1.9}.workResult{border:1px solid #dbeafe;border-radius:18px;margin-top:22px;padding:16px 18px}.workResultModern{background:#eff6ffc7}.workResultLabel{color:var(--primary);margin-bottom:8px;font-size:.82rem;font-weight:800;display:inline-block}.workResult p{color:var(--text);margin:0;line-height:1.8}.workBottom{margin-top:auto;padding-top:24px}.tagList{flex-wrap:wrap;gap:8px;display:flex}.modernTags{margin-bottom:22px}.tag{border-radius:10px;align-items:center;min-height:32px;padding:0 12px;font-size:.8rem;font-weight:700;display:inline-flex}.modernTag{color:var(--muted);background:#f1f5f9;border:1px solid #e2e8f0}.workLink{color:var(--primary);align-items:center;font-weight:800;display:inline-flex}.modernLink:after{content:"→";margin-left:6px;transition:transform .2s}.modernLink:hover:after{transform:translate(4px)}.contactContainer{max-width:900px}.card{border:1px solid var(--card-border);box-shadow:var(--shadow-md);background:#fff}.contactCard{margin:0 auto}.contactCardModern{border-radius:30px;padding:42px}.contactLead{color:var(--muted);text-align:center;margin:0 0 30px;font-size:1.02rem}.contactForm{margin:0}.formGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.formField{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.formField label{color:var(--text);font-size:.92rem;font-weight:800}.formField input,.formField textarea{width:100%;color:var(--text);background:#f8fafc;border:1px solid #dbe3f0;border-radius:18px;outline:none;padding:15px 16px;transition:border-color .2s,box-shadow .2s,background .2s}.formField input::placeholder,.formField textarea::placeholder{color:#94a3b8}.formField input:focus,.formField textarea:focus{background:#fff;border-color:#93c5fd;box-shadow:0 0 0 4px #2563eb1a}.formField textarea{resize:vertical;min-height:180px}.submitPrimary{background:linear-gradient(135deg, var(--primary) 0%, #4f46e5 100%);color:#fff;cursor:pointer;border:0;border-radius:18px;width:100%;min-height:56px;font-weight:800;transition:transform .2s,opacity .2s;box-shadow:0 18px 32px #2563eb2e}.submitPrimary:hover{transform:translateY(-2px)}.submitPrimary:disabled{opacity:.72;cursor:not-allowed}.formStatus{text-align:center;border-radius:16px;margin-top:16px;padding:14px 16px;font-size:.94rem;font-weight:700}.formStatus.success{color:#0f766e;background:#f0fdfa;border:1px solid #99f6e4}.formStatus.error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.contactNote{color:var(--muted-soft);text-align:center;margin:26px 0 0;font-size:.9rem}.footer{background:#fff;padding:34px 0 40px}.footerModern{border-top:1px solid var(--card-border)}.footerBar{justify-content:space-between;align-items:center;gap:18px;display:flex}.footerBrand{letter-spacing:-.03em;font-size:1.18rem;font-weight:800}.footerBar p{color:var(--muted-soft);margin:0;font-size:.9rem}.footerIcon{color:var(--muted);align-items:center;gap:8px;font-weight:700;transition:color .2s;display:inline-flex}.footerGithubSvg{flex-shrink:0;width:1.25em;height:1.25em}@media (max-width:1024px){.heroGrid,.aboutGrid,.worksGridModern,.skillGridModern{grid-template-columns:1fr 1fr}.heroGrid,.aboutGrid{grid-template-columns:1fr}.heroSection{padding-top:52px}.heroGrid{min-height:auto}.heroVisual{order:-1}.aboutVisual{max-width:520px}.worksGridModern{grid-template-columns:1fr}}@media (max-width:768px){.navShell{flex-wrap:wrap;justify-content:center;gap:12px;min-height:auto;padding:12px 0}.navLinks{flex-wrap:wrap;justify-content:center;gap:12px;width:100%}.navLinks a{font-size:.9375rem}.navLinks .navLinkContact{display:revert}.navCta{display:none}.heroSection,.section{padding:78px 0}.heroTitle{font-size:2.5rem}.heroActions{flex-direction:column}.largeBtn,.btn{width:100%}.skillGridModern{grid-template-columns:repeat(2,minmax(0,1fr))}.formGrid,.footerBar{grid-template-columns:1fr;display:grid}.footerBar{text-align:center}.footerIcon{justify-self:center}}@media (max-width:560px){.logo{text-align:center;font-size:1.0625rem}.navLinks a{font-size:.875rem}.container{width:min(100% - 24px, var(--max-width))}.heroTitle{font-size:2.15rem}.profileCardLarge,.contactCardModern,.workBody{padding:24px}.skillGridModern{grid-template-columns:1fr}.sectionHeading{margin-bottom:40px}}
