@import"https://fonts.googleapis.com/css?family=Exo:400,700";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,Noto Sans JP,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}html,body,#root{height:100%}body{font-family:Inter,Noto Sans JP,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji"}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.fixed{position:fixed}.block{display:block}.flex{display:flex}.grid{display:grid}.justify-center{justify-content:center}.text-center{text-align:center}.area{background:#4e54c8;background:-webkit-linear-gradient(to left,#8f94fb,#4e54c8);width:100%;height:100%;position:fixed;top:0;left:0;z-index:-1}.circles{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden}.circles li{position:absolute;display:block;list-style:none;width:20px;height:20px;background:#ebe2e233;animation:animate 25s linear infinite;bottom:-150px}.circles li:nth-child(1){left:25%;width:80px;height:80px;animation-delay:0s}.circles li:nth-child(2){left:10%;width:20px;height:20px;animation-delay:2s;animation-duration:12s}.circles li:nth-child(3){left:70%;width:20px;height:20px;animation-delay:4s}.circles li:nth-child(4){left:40%;width:60px;height:60px;animation-delay:0s;animation-duration:18s}.circles li:nth-child(5){left:65%;width:20px;height:20px;animation-delay:0s}.circles li:nth-child(6){left:75%;width:110px;height:110px;animation-delay:3s}.circles li:nth-child(7){left:35%;width:150px;height:150px;animation-delay:7s}.circles li:nth-child(8){left:50%;width:25px;height:25px;animation-delay:15s;animation-duration:45s}.circles li:nth-child(9){left:20%;width:15px;height:15px;animation-delay:2s;animation-duration:35s}.circles li:nth-child(10){left:85%;width:150px;height:150px;animation-delay:0s;animation-duration:11s}@keyframes animate{0%{transform:translateY(0) rotate(0);opacity:1;border-radius:0}to{transform:translateY(-1000px) rotate(720deg);opacity:0;border-radius:50%}}.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2)}.header-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo h1{font-size:1.8rem;font-weight:700;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3);transition:all .3s ease}.logo h1:hover{transform:scale(1.05);text-shadow:0 4px 8px rgba(0,0,0,.4)}.navigation{display:flex;align-items:center}.nav-list{display:flex;list-style:none;margin:0;padding:0;gap:2rem}.nav-link{color:#fff;text-decoration:none;font-size:1rem;font-weight:500;text-transform:lowercase;transition:all .3s ease;position:relative;padding:.5rem 0;background:none;border:none;cursor:pointer;font-family:inherit}.nav-link:hover{color:#64b5f6;transform:translateY(-2px)}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:#64b5f6;transition:width .3s ease}.nav-link:hover:after{width:100%}@media (max-width: 768px){.header-container{padding:1rem}.nav-list{gap:1rem}.logo h1{font-size:1.5rem}}.profile{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;padding-top:100px;position:relative;z-index:100}.profile-container{text-align:center;max-width:600px;margin:0 auto;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;padding:3rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;position:relative;z-index:101}.profile-image{margin-bottom:2rem}.profile-image img{width:200px;height:200px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:4px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #0003;transition:all .3s ease}.profile-image img:hover{transform:scale(1.05);border-color:#64b5f699;box-shadow:0 12px 40px #0000004d}.profile-info{color:#fff}.name{font-size:2.5rem;font-weight:700;margin:0 0 1rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.title{font-size:1.2rem;margin:0 0 2rem;opacity:.9;font-weight:400}.social-links{display:flex;justify-content:center;gap:2rem;margin-top:2rem}.social-link{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);transition:all .3s ease;text-decoration:none;position:relative;z-index:102}.social-link:hover{transform:translateY(-5px);background:#64b5f633;border-color:#64b5f699;box-shadow:0 8px 25px #64b5f64d}.social-link img{width:24px;height:24px;filter:brightness(0) invert(1)}.social-link.github:hover img,.social-link.qiita:hover img,.social-link.x:hover img{filter:brightness(0) invert(1)}@media (max-width: 768px){.profile{padding:1rem;padding-top:120px}.profile-container{padding:2rem;margin:0 auto}.profile-image img{width:150px;height:150px}.name{font-size:2rem}.title{font-size:1rem}.social-links{gap:1.5rem}.social-link{width:45px;height:45px}}.about{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;padding-top:100px;position:relative;z-index:100}.about-container{text-align:center;max-width:800px;margin:0 auto;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;padding:3rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;position:relative;z-index:101}.section-title{font-size:2.5rem;font-weight:700;color:#fff;margin:0 0 3rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.timeline{position:relative;text-align:left}.timeline-item{position:relative;margin-bottom:3rem;display:flex;align-items:center}.timeline-item:nth-child(odd){flex-direction:row}.timeline-item:nth-child(2n){flex-direction:row-reverse}.timeline-date{background:#ffffff1a;color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;min-width:120px;text-align:center;box-shadow:0 4px 15px #6d6a6f4d;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.timeline-date:hover{background:#fff3;box-shadow:0 4px 15px #6d6a6f66;transform:scale(1.02)}.timeline-content{background:#ffffff26;border-radius:15px;padding:1.5rem;margin:0 2rem;flex:1;max-width:400px;border:1px solid rgba(68,73,78,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #0000001a;transition:all .3s ease}.timeline-content:hover{border-color:#6f747899;box-shadow:0 6px 20px #00000026;transform:translateY(-2px);background:#fff3}.timeline-content:hover .timeline-role{color:#fff}.timeline-content h3{color:#fff;font-size:1.3rem;font-weight:600;margin:0 0 .5rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}.timeline-role{color:#fff;font-weight:600;margin:0 0 .5rem;font-size:1rem;transition:all .3s ease}.timeline-description{color:#ffffffe6;margin:0;line-height:1.5;font-size:.95rem}@media (max-width: 768px){.about{padding:1rem;padding-top:120px}.about-container{padding:2rem;margin:0 auto}.section-title{font-size:2rem;margin-bottom:2rem}.timeline-item{flex-direction:column!important;margin-left:0;text-align:center}.timeline-date{min-width:120px;font-size:.9rem;padding:.5rem 1rem;margin-bottom:1rem}.timeline-content{margin:0;max-width:none;flex:1;text-align:center}}.sections{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;padding-top:100px;position:relative;z-index:100}.container{text-align:center;max-width:1200px;margin:0 auto;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;padding:1rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;position:relative;z-index:101}.title{font-size:2.5rem;font-weight:700;color:#fff;margin:0 0 3rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.grid--projects,.grid--about{align-items:start}.project-card--expandable{min-width:0;min-height:12rem;display:flex;flex-direction:column}.project-header--expandable{min-width:0}.project-title--single-line{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-footer-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-top:auto;padding-top:.25rem}.project-links--with-toggles{flex-wrap:wrap;align-items:center}.project-links .project-title-toggle,.project-footer-actions .project-title-toggle{margin-top:0;padding:.5rem 1rem;font-size:.9rem;align-self:center}.project-title-toggle{display:inline-flex;margin-top:0;padding:.3rem .75rem;font-size:.8rem;font-weight:500;color:#fff;cursor:pointer;border:1px solid rgba(255,255,255,.35);border-radius:20px;background:#ffffff1a;transition:background .2s ease,border-color .2s ease}.project-title-toggle:hover{background:#fff3;border-color:#ffffff80}.project-description-block{display:flex;flex-direction:column;gap:.5rem}.project-card--expandable .project-description-block{flex:1 1 auto;padding-bottom:.75rem}.project-card--expandable .project-description-block .project-description{margin-bottom:0}.project-description--collapsed{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden;min-height:4.5em}.project-description--expanded{display:block;-webkit-line-clamp:unset;line-clamp:unset;-webkit-box-orient:unset;overflow:visible;min-height:0}.project-card{background:#ffffff26;border-radius:15px;padding:1.5rem;border:1px solid rgba(100,181,246,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #0000001a;transition:all .3s ease;text-align:left}.project-card:hover{border-color:#64b5f699;box-shadow:0 6px 20px #00000026;transform:translateY(-2px);background:#fff3}.project-header{margin-bottom:1rem}.project-title{color:#fff;font-size:1.3rem;font-weight:600;margin:0 0 .5rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}.project-role{color:#fff;font-weight:500;font-size:.9rem;background:#fff3;padding:.3rem .8rem;border-radius:15px;display:inline-block;border:1px solid rgba(255,255,255,.4)}.project-description{color:#ffffffe6;margin:0 0 1.5rem;line-height:1.5;font-size:.95rem}.project-links{display:flex;gap:1rem}.project-card--expandable .project-links{margin-top:auto;padding-top:.25rem}.project-link{color:#fff;text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 1rem;border:1px solid rgba(255,255,255,.4);border-radius:20px;background:#ffffff1a;transition:all .3s ease}.project-link:hover{background:#fff3;border-color:#fff9;transform:translateY(-1px)}.project-link.disabled{color:#fff9;border-color:#ffffff4d;background:#ffffff1a;cursor:not-allowed}.project-link.disabled:hover{transform:none;background:#ffffff1a;border-color:#ffffff4d}@media (max-width: 768px){.projects{padding:1rem;padding-top:120px}.projects-container{padding:2rem;margin:0 auto}.section-title{font-size:2rem;margin-bottom:2rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-card{padding:1.2rem}}.contact{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;padding-top:100px;position:relative;z-index:100}.contact-container{text-align:center;margin:0 auto;background:#ffffff1a;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;padding:3rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;position:relative;z-index:101}.section-title{font-size:2.5rem;font-weight:700;color:#fff;margin:0 0 2rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.contact-content{display:flex;flex-direction:column;align-items:center;gap:2rem}.contact-description{color:#ffffffe6;font-size:1.1rem;line-height:1.6;margin:0}.email-section{width:100%;max-width:80%}.email-card{background:#ffffff26;border-radius:15px;padding:1.5rem;border:1px solid rgba(100,181,246,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #0000001a;transition:all .3s ease;cursor:pointer;display:flex;align-items:center;gap:1rem;position:relative;overflow:hidden}.email-card:hover{border-color:#64b5f699;box-shadow:0 6px 20px #00000026;transform:translateY(-2px);background:#fff3}.email-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(100,181,246,.1),transparent);transition:left .5s ease}.email-card:hover:before{left:100%}.email-icon{color:#64b5f6;width:40px;height:40px;flex-shrink:0}.email-icon svg{width:100%;height:100%}.email-info{flex:1;text-align:left;display:flex;flex-direction:column;gap:.3rem}.email-label{color:#ffffffb3;font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.email-address{color:#fff;font-size:1.2rem;font-weight:1000;font-family:Courier New,monospace}.email-arrow{color:#fff9;width:24px;height:24px;flex-shrink:0;transition:all .3s ease}.email-card:hover .email-arrow{color:#64b5f6;transform:translate(3px)}.contact-note{color:#fff9;font-size:.9rem;margin:0;font-style:italic}@media (max-width: 768px){.contact{padding:1rem;padding-top:120px}.contact-container{padding:2rem;margin:0 auto}.section-title{font-size:2rem;margin-bottom:1.5rem}.contact-content{gap:1.5rem}.email-card{padding:1.2rem;gap:.8rem}.email-icon{width:32px;height:32px}.email-address{font-size:1rem}.email-arrow{width:20px;height:20px}}@media (max-width: 480px){.contact{padding:.5rem;padding-top:100px;min-height:auto}.contact-container{padding:1.5rem;margin:0 .5rem;border-radius:15px}.section-title{font-size:1.8rem;margin-bottom:1rem}.contact-content{gap:1rem}.email-section{max-width:100%}.email-card{padding:1rem;gap:.6rem;border-radius:12px}.email-icon{width:28px;height:28px}.email-info{gap:.2rem}.email-label{font-size:.7rem}.email-address{font-size:.9rem}.email-arrow{width:18px;height:18px}.contact-note{font-size:.8rem}}@media (max-width: 360px){.contact{padding:.3rem;padding-top:90px}.contact-container{padding:1.2rem;margin:0 .3rem}.section-title{font-size:1.6rem}.email-card{padding:.8rem;gap:.5rem}.email-icon{width:24px;height:24px}.email-address{font-size:.8rem}}*{margin:0;padding:0}body{font-family:Exo,sans-serif}.context{width:100%;position:absolute}
