@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap";:root{font-family:Noto Sans JP,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;font-family:Noto Sans JP,sans-serif;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}#root{width:100%;margin:0 auto;text-align:center}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:#fff;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans JP,sans-serif;line-height:1.6;color:#2c3e50;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem 0;position:relative;overflow:hidden}.header:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;text-align:center;position:relative;z-index:1}.site-title{font-size:3rem;font-weight:700;margin-bottom:.5rem;letter-spacing:.1em;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.site-subtitle{font-size:1.2rem;font-weight:300;opacity:.9;letter-spacing:.05em}.main{flex:1}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.hero-section{padding:4rem 0;background:#fff;position:relative}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem}.hero-title{font-size:2.5rem;font-weight:700;color:#2c3e50;margin-bottom:1.5rem;line-height:1.2;position:relative}.hero-title:after{content:"";position:absolute;bottom:-10px;left:0;width:60px;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px}.hero-description{font-size:1.1rem;color:#666;line-height:1.8;margin-bottom:2rem}.hero-visual{position:relative;height:400px;display:flex;align-items:center;justify-content:center}.japanese-pattern{width:300px;height:300px;background:radial-gradient(circle at 25% 25%,#667eea 0%,transparent 50%),radial-gradient(circle at 75% 75%,#764ba2 0%,transparent 50%),linear-gradient(45deg,transparent 40%,rgba(102,126,234,.1) 50%,transparent 60%);border-radius:50%;position:relative;animation:float 6s ease-in-out infinite}.japanese-pattern:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;background:conic-gradient(from 0deg,transparent,rgba(118,75,162,.2),transparent);border-radius:50%;animation:rotate 10s linear infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes rotate{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.about-section{padding:4rem 0;background:#f8f9fa}.section-title{font-size:2rem;font-weight:700;text-align:center;margin-bottom:3rem;color:#2c3e50;position:relative}.section-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:60px;height:3px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.about-text p{font-size:1.1rem;color:#666;line-height:1.8;margin-bottom:1.5rem}.skills{display:flex;flex-direction:column;gap:1.5rem}.skill-item{display:flex;flex-direction:column;gap:.5rem}.skill-name{font-weight:500;color:#2c3e50;font-size:1rem}.skill-bar{width:100%;height:8px;background:#e9ecef;border-radius:4px;overflow:hidden;position:relative}.skill-progress{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width 1s ease-in-out;position:relative}.skill-progress:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.contact-section{padding:4rem 0;background:#fff}.contact-content{max-width:600px;margin:0 auto}.contact-info{display:flex;flex-direction:column;gap:2rem}.contact-item{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea;transition:transform .3s ease,box-shadow .3s ease}.contact-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.contact-label{font-weight:500;color:#2c3e50;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.contact-link{color:#667eea;text-decoration:none;font-size:1.1rem;transition:color .3s ease}.contact-link:hover{color:#764ba2}.footer{background:#2c3e50;color:#fff;text-align:center;padding:2rem 0;margin-top:auto}.footer p{opacity:.8;font-size:.9rem}@media (max-width: 768px){.hero-content{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-title{font-size:2rem}.hero-visual{height:250px}.japanese-pattern{width:200px;height:200px}.about-content{grid-template-columns:1fr;gap:2rem}.site-title{font-size:2.5rem}.container{padding:0 1rem}}@media (max-width: 480px){.hero-title{font-size:1.8rem}.site-title{font-size:2rem}.section-title{font-size:1.5rem}}
