@font-face{font-family:MonaSansExpanded;src:url(/fonts/21ed5661b47f7f6d-s.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}:root{--bg-main: #F4F8FA;--bg-white: #FFFFFF;--bg-subtle: #F8FBFC;--color-primary: #BFDDE6;--color-primary-dark: #A8CBD6;--color-primary-light: #D4EAF0;--color-secondary: #E8DCEB;--color-secondary-soft: #D8C6E0;--color-secondary-pale: #F3EEF6;--color-blend: #D4DCEA;--text-primary: #444444;--text-secondary: #888888;--text-light: #AAAAAA;--text-on-primary: #2A3A44;--border-light: #E2E8F0;--border-medium: #D8D8E8;--hover-overlay: rgba(191, 221, 230, .1);--shadow-soft: rgba(0, 0, 0, .06);--gradient-hero-title: linear-gradient(90deg, #BFDDE6 0%, #E8DCEB 100%);--gradient-projects-bg: linear-gradient(135deg, #EEF6F9 0%, #F6EEF9 50%, #F9EEF6 100%);--gradient-contact-bg: linear-gradient(120deg, #F8FBFC 0%, #F3EEF6 100%);--gradient-wip-bg: linear-gradient(135deg, #F0F6F8 0%, #F6F0F8 100%);--border-radius: 4px;--color-text: var(--text-primary);--color-code-bg: #fff4db;--color-code: #8a6534;--font-sans: "MonaSansExpanded", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--font-mono: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--font-lg: 18px;--font-md: 16px;--font-sm: 14px;--font-sx: 12px;--line-height-loose: 1.75;--line-height-normal: 1.5;--line-height-dense: 1.1;--space-1: 4px;--space-2: 8px;--space-3: 16px;--space-4: 24px;--space-5: 32px;--space-6: 64px;--size-content: 54rem;--size-gutter: var(--space-5);--size-gap: var(--space-6);--page-top-spacing-desktop: 112px;--page-top-spacing-mobile: 136px}*{margin:0;padding:0;box-sizing:border-box}html,body{background:var(--bg-main);-webkit-text-size-adjust:100%;font:sans-serif;font-size:var(--font-md);line-height:var(--line-height-normal);overflow-y:scroll;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;color:var(--color-text);font-family:var(--font-sans);font-weight:400;word-wrap:break-word}h1{letter-spacing:-.01em;line-height:var(--line-height-dense);margin:0 0 3rem;padding:0}h1 b{color:var(--color-primary)}dd,dl,fieldset,figure,hgroup,img,ol,p,ul{margin:0;margin-bottom:var(--space-4);padding:0}ol,ul{list-style-image:none;list-style-position:outside;margin-left:var(--space-4)}ol li,ul li{padding-left:0}li>ol,li>ul{margin-bottom:calc(var(--space-4) / 2);margin-left:var(--space-4);margin-top:calc(var(--space-4) / 2)}blockquote :last-child,li :last-child,p :last-child{margin-bottom:0}li>p{margin-bottom:calc(var(--space-4) / 2)}p{max-width:680px}code,kbd,samp{font-size:.875rem}abbr,acronym{border-bottom:1px dotted rgba(0,0,0,.5);cursor:help}code,tt{background-color:var(--color-code-bg);border-radius:var(--border-radius);color:var(--color-code);font-family:var(--font-mono);padding-bottom:.25em;padding-top:.25em;word-break:normal}pre code{background:none}code:after,code:before,tt:after,tt:before{content:" ";letter-spacing:-.2em}pre code:after,pre code:before,pre tt:after,pre tt:before{content:none}b,dt,strong,th{font-weight:700}nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;position:fixed;top:0;left:0;right:0;z-index:1000;background:#fffffff2;backdrop-filter:blur(10px);box-shadow:0 2px 8px var(--shadow-soft);border-bottom:1px solid var(--border-light)}.site-name{font-weight:700;font-size:1.5rem;letter-spacing:.05em;color:var(--color-primary-dark);text-decoration:none;display:flex;align-items:center;height:100%;transition:color .2s,transform .2s}.site-name:hover{color:var(--color-secondary);transform:scale(1.05)}.nav-menu{display:flex;gap:2rem;list-style:none;margin:0;padding:0;align-items:center;height:100%}.nav-menu li{display:flex;align-items:center;height:100%;margin-bottom:0}.menu-link{font-weight:600;color:var(--text-secondary);text-decoration:none;font-size:1.1rem;transition:color .2s,transform .2s;display:flex;align-items:center;height:100%;padding:.25rem 0}.menu-link:hover{color:var(--color-primary);transform:scale(1.05)}.menu-link.active{color:var(--color-primary-dark);border-bottom:2px solid var(--color-primary)}.menu-toggle{display:none;flex-direction:column;background:none;border:none;cursor:pointer;padding:.5rem;z-index:1001}.menu-toggle span{width:25px;height:3px;background:#b5b0c6;margin:3px 0;transition:.3s;border-radius:2px}.menu-toggle.active span:nth-child(1){transform:rotate(-45deg) translate(-6px,6px)}.menu-toggle.active span:nth-child(2){opacity:0}.menu-toggle.active span:nth-child(3){transform:rotate(45deg) translate(-6px,-6px)}@media(max-width:768px){.menu-toggle{display:flex}.nav-menu{position:fixed;top:0;right:-60%;width:60%;height:100vh;background:#fafdfff2;backdrop-filter:blur(10px);flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;transition:right .4s cubic-bezier(.4,0,.2,1);box-shadow:-5px 0 20px #0000001a;padding:5rem 0 0;z-index:1000}.nav-menu.active{right:0}.nav-menu li{height:auto;margin-bottom:0;border-bottom:1px solid rgba(0,0,0,.05)}.nav-menu li:last-child{border-bottom:none}.menu-link{font-size:1.2rem;padding:1.2rem 2rem;height:auto;border-radius:0;transition:all .2s ease;background:transparent;border:none;display:block;width:100%;text-align:center;font-weight:600;letter-spacing:.5px}.menu-link:hover{background:var(--hover-overlay);color:var(--color-primary);transform:none;box-shadow:none;padding-left:2.5rem}.menu-link.active{background:var(--color-primary-light);color:var(--color-primary-dark);border-left:4px solid var(--color-primary);box-shadow:none}}.menu-overlay{position:fixed;top:80px;left:0;width:100%;height:calc(100vh - 80px);background:#0000;z-index:999;visibility:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);pointer-events:none}.menu-overlay.active{visibility:visible;background:#00000080;pointer-events:all}.hero-section{background:#f7f5fa;min-height:100vh;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0;margin:0;font-family:var(--font-sans);padding-top:var(--page-top-spacing-desktop)}.hero-content-wrapper{display:flex;flex-direction:row;max-width:1200px;margin:0 auto;padding:0 2rem;gap:2rem;width:100%;align-items:center}@media(max-width:768px){.hero-section{padding-top:var(--page-top-spacing-mobile)}}.hero-left-col{flex:8;display:flex;flex-direction:column;justify-content:center;gap:2rem;height:100%}.hero-right-col{flex:4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0rem;height:100%}.hero-normal-text{font-size:1.25rem;margin:0;color:#9b7ba6;font-weight:600;letter-spacing:.01em}.hero-big-text{font-size:3rem;font-weight:800;margin:0;line-height:1.1;background:linear-gradient(90deg,#9b7ba6,#b89ec7);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;position:relative;z-index:1}.hero-intro-text{font-size:1rem;margin:0;color:#6f6a7a;line-height:1.8;font-weight:400}.hero-btn-row{display:flex;gap:1.5rem;margin-top:1.2rem;align-items:center}.hero-btn{padding:.9rem 2.2rem;font-size:1.15rem;font-weight:500;border-radius:999px;border:1px solid rgba(201,184,232,.9);background:transparent;color:#7e6a9e;cursor:pointer;transition:background .3s,border-color .3s,box-shadow .3s,transform .2s;text-decoration:none;display:inline-block;box-shadow:none}.hero-btn:hover{background:#c9b8e81f;border-color:#c9b8e8;color:#7e6a9e;transform:translateY(-1px);box-shadow:none}.hero-btn-alt{padding:.9rem 2.2rem;font-size:1.15rem;font-weight:500;border-radius:999px;border:1px solid rgba(201,184,232,.55);background:transparent;color:#7e6a9ee6;cursor:pointer;transition:background .3s,border-color .3s,box-shadow .3s,transform .2s;text-decoration:none;display:inline-block;box-shadow:none}.hero-btn-alt:hover{background:#c9b8e814;border-color:#c9b8e8bf;color:#7e6a9ef2;transform:translateY(-1px);box-shadow:none}.hero-avatar-wrapper{width:320px;height:320px;border-radius:50%;margin-bottom:1.2rem;overflow:hidden;position:relative}.hero-avatar-image{position:absolute;top:55%;left:50%;width:125%;height:125%;object-fit:cover;transform:translate(-50%,-50%)}.social-list{display:flex;flex-direction:row;align-items:center;gap:1.5rem}.social-icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:0;background:none;color:#222;font-size:2.2rem;text-decoration:none;transition:color .2s;box-shadow:none}.social-icon-btn:hover{color:var(--color-primary-dark)}.social-icon-btn img{width:36px;height:36px;display:block;transition:transform .2s}.social-icon-btn img[alt=x]{width:24px;height:24px}.social-icon-btn:hover img{transform:scale(1.18)}.projects-section{background:#f4f8fa;width:100vw;min-width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;padding:4rem 0}.projects-container{max-width:1600px;margin:0 auto;color:#fff;text-align:center;padding:0 2rem}.project-description-area{margin-top:0;padding:.25rem 0;max-width:800px;margin-left:auto;margin-right:auto;min-height:80px;position:relative}.project-description-viewport{position:relative;width:100%;height:80px;overflow:hidden}.project-description-track{position:relative;width:100%;will-change:transform;transition:transform .5s cubic-bezier(.4,0,.2,1)}.project-content-item{width:100%;min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;padding:0;gap:.3rem}.projects-carousel-wrapper{position:relative;width:100%;max-width:100%;height:500px;display:flex;align-items:center;justify-content:center;overflow:visible;perspective:1500px;perspective-origin:center center;padding:.25rem 0;margin:0 auto}.coverflow-carousel{width:350px;height:350px;display:flex;align-items:center;justify-content:center}.coverflow-item{width:350px;height:350px;object-fit:contain;border-radius:20px;box-shadow:0 10px 40px #0000004d;will-change:transform,opacity;transform-style:preserve-3d;backface-visibility:hidden;display:block;transform:translateZ(0)}.mask{mask-image:linear-gradient(to right,transparent 10%,black 25%,black 75%,transparent 90%);-webkit-mask-image:linear-gradient(to right,transparent 10%,black 25%,black 75%,transparent 90%);display:flex;align-items:center;justify-content:center;flex:1;width:100%;height:100%;overflow:visible}@media(max-width:600px){.coverflow-carousel{width:250px;height:250px}.coverflow-item{width:250px;height:250px;border-radius:20px}.projects-container{padding:0 1rem}.projects-carousel-wrapper{height:350px;overflow:hidden}.mask{mask-image:linear-gradient(to right,transparent 10%,black 25%,black 75%,transparent 90%);-webkit-mask-image:linear-gradient(to right,transparent 10%,black 25%,black 75%,transparent 90%)}.project-description-area{padding:.5rem 0;margin-top:1rem}.project-description-viewport{height:90px}.project-content-item{min-height:90px}.project-title{font-size:1.5rem}.project-description{font-size:1rem}}.projects-title{font-size:2.5rem;font-weight:800;margin-bottom:.25rem;margin-top:0;letter-spacing:.01em;color:#8b82a6}.projects-grid{display:flex;flex-direction:column;gap:3rem;margin-top:2rem}.project-row{display:flex;gap:3rem;align-items:center;justify-content:center;padding:2rem 0;max-width:800px;margin:0 auto}.project-image-container{flex:1 1 50%;display:flex;justify-content:center;align-items:center;min-height:320px;min-width:320px}.project-image{width:100%;max-width:400px;height:250px;border-radius:12px;object-fit:cover;box-shadow:0 4px 12px #0000001a}.project-title{font-size:1.5rem;font-weight:700;color:#9a93af;margin-bottom:.25rem}.project-description{font-family:Noto Sans JP,sans-serif;font-size:1rem;color:#b6b0c6;line-height:1.6;margin-bottom:.25rem;min-height:2.8em}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.25rem;justify-content:center}.technology-tag{background:#edf2f7;color:#4a5568;padding:.3rem .8rem;border-radius:20px;font-size:.9rem;font-weight:500}.project-links{display:flex;flex-direction:row;gap:2rem;margin-top:0;justify-content:center}.project-link{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-size:1rem;font-weight:600;transition:color .3s,transform .3s;padding:.5rem 0;cursor:pointer}.project-link:hover{color:#f0f0f0;transform:translate(10px)}.projects-nav-link{display:flex;justify-content:center;margin-top:.5rem}.view-more-posts{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary);text-decoration:none;font-size:.85rem;font-weight:400;padding:.4rem 1rem;border:1px solid var(--color-secondary-soft);background:transparent;border-radius:15px;transition:all .3s;cursor:pointer;opacity:.9}.view-more-posts:hover{background:var(--color-secondary-pale);border-color:var(--color-secondary);color:var(--text-primary);opacity:1;transform:translate(3px)}.proficiency-section{background:linear-gradient(135deg,#fbc2eb,#a6c1ee);width:100vw;min-width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;padding:6rem 0;min-height:600px;box-sizing:border-box;display:flex;align-items:center;justify-content:center}.proficiency-content{max-width:1200px;margin:0 auto;color:#333;text-align:center;padding:0 2rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.proficiency-title{font-size:2.5rem;font-weight:800;margin-bottom:3rem;letter-spacing:.01em;color:#fff}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem 12rem;width:100%;max-width:1600px}.skill-card{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.skill-name{font-size:1.3rem;font-weight:700;text-align:center;margin:0}.skill-name-1,.skill-name-2,.skill-name-3,.skill-name-4,.skill-name-5,.skill-name-6{color:#fff}.circular-progress{position:relative;display:flex;align-items:center;justify-content:center}.progress-ring{transform:rotate(-90deg)}.progress-ring-circle{transition:stroke-dashoffset .3s ease;stroke-linecap:round}.progress-ring-circle-bg{stroke-linecap:round}.circular-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;text-align:center}.skill-percentage{display:inline-block}.skill-color-1{color:#76cfc5}.skill-color-2{color:#ffb400}.skill-color-3,.skill-color-4{color:#ec6664}.skill-color-5{color:#76cfc5}.skill-color-6{color:#ffb400}footer{height:28px;background:#fff;width:100vw;display:flex;align-items:center;border-top:1px solid #f0f0f0;position:relative;left:0;margin-top:0}.footer-content{width:100%;display:flex;justify-content:flex-start;align-items:center;height:100%;padding-left:2rem;padding-right:2rem}.footer-text{font-size:10px;color:#bbb;margin:0}.footer-link{color:#000;text-decoration:none;margin:0 .5em}.footer-link:hover{text-decoration:underline}.footer-github{color:#000;text-decoration:none;padding-bottom:1px;transition:all .3s ease;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;margin-left:1.5rem;padding-right:.5rem;display:flex;align-items:center;height:100%}.footer-github:hover{color:#76cfc5;text-decoration:underline;transform:translateY(-2px)}@media(max-width:768px){.hero-content-wrapper{flex-direction:column;text-align:center}.hero-big-text{font-size:2rem}.hero-btn-row,.social-list{justify-content:center}.project-row{flex-direction:column}.skills-grid{grid-template-columns:repeat(2,1fr);gap:2rem 4rem}.skill-card{gap:1.5rem}.skill-name{font-size:1.2rem}.circular-progress-text{font-size:1.3rem}}@media(max-width:480px){.skills-grid{grid-template-columns:1fr}}.page-content{opacity:0;transform:scale(.98);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.page-content.visible{opacity:1;transform:scale(1)}.page-content{will-change:opacity,transform}.hero-content-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.hero-content-animate.visible{opacity:1;transform:translateY(0)}.hero-avatar-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.hero-avatar-animate.visible{opacity:1;transform:translateY(0)}.hero-avatar-animate.visible:hover{transform:translateY(0) scale(1.06)}.social-icon-animate{opacity:0;transform:translateY(10px) scale(.9);transition:opacity 1s ease-out,transform 1s ease-out}.social-icon-animate.visible{opacity:1;transform:translateY(0) scale(1)}.social-icon-animate:nth-child(1){transition-delay:0s}.social-icon-animate:nth-child(2){transition-delay:.15s}.social-icon-animate:nth-child(3){transition-delay:.3s}.social-icon-animate:nth-child(4){transition-delay:.45s}.contact-header-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.contact-header-animate.visible{opacity:1;transform:translateY(0)}.contact-card-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out .2s,transform 1.2s ease-out .2s}.contact-card-animate.visible{opacity:1;transform:translateY(0)}.contact-card-animate:nth-child(2){transition-delay:.4s}.posts-header-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.posts-header-animate.visible{opacity:1;transform:translateY(0)}.posts-content-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out .2s,transform 1.2s ease-out .2s}.posts-content-animate.visible{opacity:1;transform:translateY(0)}.comments-header-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.comments-header-animate.visible{opacity:1;transform:translateY(0)}.comments-content-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out .2s,transform 1.2s ease-out .2s}.comments-content-animate.visible{opacity:1;transform:translateY(0)}.comments-content-animate:nth-child(2){transition-delay:.4s}.post-header-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out,transform 1.2s ease-out}.post-header-animate.visible{opacity:1;transform:translateY(0)}.post-content-animate{opacity:0;transform:translateY(20px);transition:opacity 1.2s ease-out .2s,transform 1.2s ease-out .2s}.post-content-animate.visible{opacity:1;transform:translateY(0)}
