*{margin:0;padding:0;list-style:none;text-decoration:none}:root{--color: #617a96;--header-s: 48px;--header-m: 60px;--header-l: 80px;--font-ss: 12px;--font-s: 16px;--font-sm: 20px;--font-m: 24px;--font-l: 32px;--font-xl: 40px;--font-xl: 48px;--font-xxl: 64px;--font-title-tab: 160px;--font-title-pc: 240px;--font-logo-sp: 28px;--font-logo-pc: 56px;--radius-s: 4px;--radius-m: 10px;--radius-l: 15px;--radius-xl: 24px}.container{max-width:324px;margin:0 auto}.font-mincho{font-family:"Noto Serif JP",serif}.font-hinamincho{font-family:Hina Mincho,serif}.font-gothic{font-family:Noto Sans JP,sans-serif}.font-roboto{font-family:Roboto,sans-serif}.font-dancing{font-family:Dancing Script,cursive}.font-playwrite{font-family:Playwrite AT,cursive}.font-amatic{font-family:Amatic SC,sans-serif}header{color:var(--color);z-index:1001;position:fixed;top:0;left:0;width:100%}header .container{position:relative;z-index:1002;height:var(--header-s);display:flex;justify-content:space-between;align-items:center}header h1{overflow:hidden;white-space:pre;display:flex;justify-content:center;align-items:center;height:40px;width:130px;box-sizing:border-box;padding:0 2px;border-radius:var(--radius-s);font-size:var(--font-logo-sp);color:#fff;background-color:var(--color)}header button{height:40px;width:40px;border:none;background-color:#fff0;position:relative}header button span{display:inline-block;position:absolute;left:0;height:1px;width:100%;background-color:var(--color)}header button span:first-of-type{top:40%}header button span:last-of-type{top:60%}header h1 a{color:#fff}#top,#about,#works,#news,#contact{scroll-margin-top:calc(var(--header-l) + 16px)}.sp-nav{position:fixed;top:0;left:0;width:100%;min-height:100vh;padding:0;background-color:#ffffffb8;backdrop-filter:blur(17.5px);-webkit-backdrop-filter:blur(17.5px);z-index:998}.sp-nav .container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:0 16px}.global-nav{width:100%}.global-nav-list li{margin-top:12px}.global-nav-list li:first-of-type{margin-top:0}.global-nav-list a{color:var(--color);font-size:var(--font-s);display:inline-block;padding:2px 4px}.nav-list-works{position:relative;border:1px solid white;border-radius:var(--radius-s)}.nav-list-works:after{content:"";position:absolute;top:24px;left:50%;height:16px;width:1px;background-color:#fff}.nav-works-wrapper{box-sizing:border-box;margin-top:16px;border:1px solid white;padding:8px 8px 8px 0;border-radius:var(--radius-m);display:flex;justify-content:space-between}.nav-works{width:35%;border-right:1px solid white}.nav-works a{color:#fff}.nav-works-btn-wrapper{display:flex;flex-direction:column;gap:12px}.nav-works button{margin-left:16px;background-color:var(--color);border:none;color:#fff}.hover-wrapper{display:flex;flex-direction:column;gap:12px;overflow:hidden;width:60%}header .hover-wrapper .nav-work-link{height:40px;display:flex;align-items:center;font-size:var(--font-s)}.nav-work-link{font-size:var(--font-ss);color:#fff}.menu-nav-list{width:100%;max-width:360px}.menu-nav-list .global-nav-list{display:flex;flex-direction:column;align-items:center}.menu-nav-list .global-nav-list li{margin-top:6px;margin-right:0}.menu-nav-list .global-nav-list a{display:inline-block;font-size:var(--font-sm);letter-spacing:1px;padding:2px 4px}.menu-nav-list .nav-list-works{margin-top:6px;color:var(--color);border-color:var(--color)}.menu-nav-list .nav-list-works:after{top:28px;height:17.5px;background-color:var(--color)}.menu-nav-list .nav-works-wrapper{width:100%;max-width:360px;margin:16px auto 0;border-color:var(--color);padding:12px;align-items:flex-start}.menu-nav-list .nav-works{border-right-color:var(--color);width:40%;padding-right:8px}.menu-nav-list .nav-works-btn-wrapper{display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:8px}.menu-nav-list .nav-works-btn-wrapper li{width:auto;height:auto}.menu-nav-list .nav-works button,.menu-nav-list .nav-work-link,.menu-nav-list .nav-works a{color:var(--color)}.menu-nav-list .nav-works button{background-color:#fff0;margin-left:0;padding:0;text-align:left;font-size:var(--font-s);line-height:1.2}.menu-nav-list .hover-wrapper{width:55%;padding-left:16px;gap:8px;justify-content:flex-start}.menu-nav-list .nav-work-link{line-height:1.2}.menu-button{display:flex;justify-content:center;align-items:center}.menu-button span{transition:top .3s ease,transform .3s ease}header.menu-open .menu-button span:first-of-type{top:50%;transform:rotate(30deg)}header.menu-open .menu-button span:last-of-type{top:50%;transform:rotate(-30deg)}.title-wrapper{position:absolute;left:0;top:0;height:100svh;width:100%;display:flex;justify-content:center;align-items:center;pointer-events:none}.title-wrapper h2{padding-left:16px;z-index:990;font-size:var(--font-xxl);letter-spacing:8px;color:#fff;text-shadow:2px 2px 2px #536881,-2px -2px 2px #536881,-2px 2px 2px #536881,2px -2px 2px #536881;pointer-events:none}.mv-container{position:relative;height:300svh}.main{pointer-events:none;transform:translateY(-25%);height:100svh;width:100%;position:absolute;left:0;bottom:0;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:10}.main h2{margin-bottom:var(--font-m);font-weight:lighter;font-size:var(--font-m);color:#fff;text-shadow:2px 2px 2px #536881,-2px -2px 2px #536881,-2px 2px 2px #536881,2px -2px 2px #536881}.main div{text-align:center}.main p{margin-top:var(--font-xl);font-weight:100;font-size:var(--font-s);color:#fff;text-shadow:2px 2px 2px #536881,-2px -2px 2px #536881,-2px 2px 2px #536881,2px -2px 2px #536881}.main .sp-span{margin-top:var(--font-xl);display:block}.canvas{top:0;left:0;width:100%;height:100svh;pointer-events:all}.worker-box{margin-top:var(--header-s)}.title{color:var(--color);margin-bottom:4px;border-bottom:solid 1px var(--color)}.worker-box button{background-color:var(--color);color:#fff;border:1px solid #8daccf;border-radius:var(--radius-s);padding:2px 4px}.worker-wrapper{margin-top:var(--header-s);color:var(--color)}.worker-prof{text-align:center}.worker-prof div:first-of-type p{margin:4px 0}.worker-prof div:first-of-type h3{letter-spacing:12px}.worker-prof div:last-of-type{width:200px;height:200px;margin:0 auto}.worker-prof img{width:100%;height:100%;object-fit:cover;border-radius:50%;object-position:top center;border:inset 2px var(--color)}.worker-wrapper .description{margin-top:24px;color:var(--color);font-size:var(--font-ss)}.tag-wrapper{display:flex;flex-wrap:wrap;gap:4px}.tag-wrapper button{background-color:var(--color);color:#fff;border:1px solid #8daccf;border-radius:var(--radius-s);padding:2px 4px}.works-wrapper{margin-top:var(--header-s);color:var(--color)}.works-list{margin-top:var(--header-s)}.work-card{width:324px;height:350px;margin-bottom:32px;overflow:hidden;background-color:#fff;border:2px solid #8daccf;border-radius:var(--radius-l);box-shadow:2px 2px 4px 4px #0000001a;box-sizing:border-box}.work-img{width:324px;height:324px;box-shadow:inset 0 0 15px 5px #ff0500b3;display:block;object-fit:cover;object-position:top center}.work-card div{padding:8px 16px}.work-card h3{font-size:16px}.work-card p{font-size:12px}.card-link{height:100%;width:100%;color:inherit;text-decoration:none;display:block}.work-hover-bg{opacity:.25;position:fixed;top:0;left:0;height:100svh;width:100vw;z-index:-10}.work-hover-display{height:100%;width:100%;object-fit:cover;object-position:center center;filter:blur(4px)}.work-page{box-sizing:border-box;background-color:#617a96;padding:calc(24px + var(--header-s)) 0 var(--header-s) 0;min-height:100svh}.prev-button{position:relative;display:block;box-sizing:border-box;text-align:center;height:40px;width:100px;font-size:var(--font-sm);border:2px solid white;color:#fff;font-weight:700;padding:4px 16px;border-radius:var(--radius-l)}.work-page h2{position:relative;margin-top:32px;color:#fff;font-weight:lighter;border-bottom:1px solid white;letter-spacing:4px}.work-page h2:before{content:attr(data-subtitle);font-family:Hina Mincho,serif;font-size:var(--font-ss);position:absolute;left:0;bottom:-16px}.work-page .img{margin-top:48px;width:100%;height:200px;object-fit:cover;border-radius:var(--radius-l);box-shadow:2px 2px 4px 4px #0000001a}.work-page .work-title{margin-top:32px;color:#fff;letter-spacing:2px}.work-page .work-stacks{margin-top:24px;padding:8px 8px 8px 50px;color:#faaa8c;font-weight:700;text-align:center;letter-spacing:2px;background-color:#fff3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:20px;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 8px #0003}.work-page .work-stacks:before{content:"";height:24px;width:24px;background-color:#617a96;border-radius:50%;box-shadow:inset 0 1px 3px #0000004d;position:absolute;left:12px;top:50%;transform:translateY(-50%)}.work-page .description-wrapper{margin-top:32px;padding:8px;background-color:#fff3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-s);border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 8px #0003}.work-page .description-wrapper h3{font-weight:lighter;color:#fff;text-shadow:1px 1px 1px #536881,-1px -1px 1px #536881,-1px 1px 1px #536881,1px -1px 1px #536881;letter-spacing:2px}.work-page .description-wrapper p{margin-top:24px;font-size:var(--font-s);letter-spacing:1px;font-weight:lighter;color:#fff;text-shadow:1px 1px 1px #536881,-1px -1px 1px #536881,-1px 1px 1px #536881,1px -1px 1px #536881}.work-page .work-links{margin-top:24px}.work-page .work-link-button{display:block;box-sizing:border-box;margin-top:16px;padding:12px 16px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-s);color:#fff;text-align:center;letter-spacing:1px;background-color:#fff3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 8px #0003}.work-page .work-link-button:first-of-type{margin-top:0}#news{margin-top:var(--header-m);--news-gap: 24px}.news-view{overflow:hidden}.news-list{display:flex;gap:var(--news-gap);width:100%;transition:transform .35s ease;will-change:transform;margin-top:16px}.news{flex:0 0 100%;display:flex;flex-direction:column;border:1px var(--color) solid;border-radius:var(--radius-l);width:100%;box-sizing:border-box;padding:16px;background-color:var(--color);color:#fff}.news img{width:100%;display:block;aspect-ratio:16 / 10;object-fit:cover;margin-bottom:16px;border-radius:var(--radius-m)}.news-text{width:100%}.news-meta{margin-bottom:8px;font-size:var(--font-ss);letter-spacing:1px}.news h3{margin-bottom:8px;line-height:1.5}.news p{line-height:1.5}#news .news-controls{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:var(--header-s);flex-wrap:wrap}#news .news-controls button{background:none;border:1px solid var(--color);color:var(--color);border-radius:50%;min-height:48px;min-width:48px;padding:0 14px;display:inline-flex;justify-content:center;align-items:center;cursor:pointer}#news .news-controls button:disabled{opacity:.35;cursor:not-allowed}#news .news-controls button img{aspect-ratio:1/1;height:24px}#news .news-controls .prev,#news .news-controls .next{padding:0}.news-count{min-width:56px;text-align:center}#contact{margin-top:var(--header-s);margin-bottom:var(--header-s);padding-bottom:var(--header-s)}.contact-lead{margin-top:16px;color:var(--color);line-height:1.8;font-size:var(--font-s)}.contact-warning{margin-top:8px;color:#c43737;font-weight:700;line-height:1.7;font-size:var(--font-ss)}.contact-form{margin-top:24px;display:grid;gap:16px}.contact-item{display:grid;gap:8px;color:var(--color)}.contact-item span{font-size:var(--font-s)}.contact-item input,.contact-item textarea{width:100%;box-sizing:border-box;border:1px solid #8daccf;border-radius:var(--radius-m);padding:12px 14px;font:inherit;color:var(--color);background-color:#f9fbfd}.contact-item textarea{resize:vertical;min-height:180px}.contact-submit{border:none;border-radius:var(--radius-m);padding:14px 20px;color:#fff;background-color:var(--color);font-size:var(--font-s);cursor:pointer}.privacy-open-btn{width:100%;padding:10px 14px;border-radius:12px;border:none;background-color:var(--color);color:#fff;font-weight:700;cursor:pointer}.privacy-policy{position:fixed;inset:0;width:100vw;height:100vh;box-sizing:border-box;background-color:#fff;overflow-y:auto;transform:translate(-100vw);transition:transform .4s ease;z-index:999;padding:80px 18px 40px;display:flex;justify-content:center;align-items:flex-start}.privacy-policy.open{transform:translate(0)}.privacy-policy-inner{width:324px;max-width:1200px;margin:0 auto;padding:80px 16px 60px;display:flex;flex-direction:column;gap:24px}.privacy-policy .close-btn{position:fixed;top:var(--header-l);right:80px;padding:10px 16px;border-radius:8px;border:none;background-color:#3f5f8a;color:#fff;cursor:pointer;z-index:1001;transition:transform .2s ease,background-color .2s ease}.privacy-policy .close-btn:hover{transform:translateY(-1px);background-color:#36557a}.privacy-policy h3{color:#2c4c8f;font-size:1.25rem;letter-spacing:.01em}.privacy-policy p{color:#49516f;margin-top:8px;font-size:1rem;line-height:1.75}.privacy-policy li+li{margin-top:16px}@media(min-width:1200px){.privacy-policy{padding:100px 40px 80px;background-color:#fdfdfd;border-left:4px solid #3f5f8a;box-shadow:0 20px 40px #19274940;justify-content:flex-start;align-items:center}.privacy-policy-inner{height:80%;width:100%;padding:0 40px 80px;gap:32px;overflow-y:scroll}.privacy-policy li{width:100%}.privacy-policy .close-btn{position:fixed;top:calc(var(--header-l));right:calc((100vw - 1200px)/2 + 20px)}}footer{background-color:var(--color);padding:24px 0;border-top:1px solid rgba(97,122,150,.2)}footer p{color:#fff}.footer-nav .global-nav-list a{color:#fff}.footer-logo{margin-bottom:32px;padding:8px;border-radius:var(--radius-m);font-size:var(--font-m);border:2px solid white;width:auto;text-align:center;letter-spacing:4px}a.footer-logo{color:#fff;display:inline-block}@media screen and (min-width:768px){.container{max-width:720px;margin:0 auto}#news{--news-gap: 32px}#contact{margin-top:var(--header-m);padding-bottom:var(--header-m)}header{color:var(--color);z-index:999;position:fixed;top:0;left:0;width:100%}header .container{position:relative;z-index:1002;height:var(--header-s);display:flex;justify-content:space-between;align-items:center}header h1{overflow:hidden;white-space:pre;display:flex;justify-content:center;align-items:center;height:40px;width:130px;box-sizing:border-box;padding:0 2px;border-radius:var(--radius-s);font-size:28px;color:#fff;background-color:var(--color)}header button{height:40px;width:40px;border:none;background-color:#fff0;position:relative}header button span{display:inline-block;position:absolute;left:0;height:1px;width:100%;background-color:var(--color)}header button span:first-of-type{top:40%}header button span:last-of-type{top:60%}.global-nav-list{display:flex;flex-wrap:wrap}.global-nav-list li{margin-top:0;margin-right:24px;position:relative}.footer-wrapper{display:flex;justify-content:space-between;align-items:center}.footer-logo{margin-bottom:0}.title-wrapper{position:absolute;left:0;top:0;height:100svh;width:100%;display:flex;justify-content:center;align-items:center}.title-wrapper h2{z-index:990;font-size:var(--font-title-tab);color:#fff;text-shadow:1px 1px 4px #617a96,-1px -1px 4px #617a96}.main h2{margin-bottom:var(--font-l);font-weight:lighter;font-size:var(--font-l);color:#fff;text-shadow:2px 2px 2px #536881,-2px -2px 2px #536881,-2px 2px 2px #536881,2px -2px 2px #536881}.main p{margin-top:var(--font-xxl);font-weight:100;font-size:var(--font-m);color:#fff;text-shadow:2px 2px 2px #536881,-2px -2px 2px #536881,-2px 2px 2px #536881,2px -2px 2px #536881}.main .sp-span{margin-top:var(--font-xxl);display:block}.worker-box{margin-top:var(--header-m)}.worker-box ul{display:flex;flex-wrap:wrap}.title{color:var(--color);border-bottom:solid 1px var(--color)}.worker-box button{background-color:var(--color);color:#fff;border:1px solid #8daccf;border-radius:4px;padding:2px 4px}.worker-wrapper{margin-top:var(--header-m);color:var(--color)}.worker-prof{display:flex;flex-direction:row-reverse}.worker-prof div:first-of-type{display:flex;flex-direction:column;align-items:center;justify-content:center;width:55%}.worker-wrapper h3{font-size:var(--font-m)}.worker-wrapper p{font-size:var(--font-sm)}.worker-wrapper .description{margin-top:var(--header-m)}.tag-wrapper button{font-size:var(--font-m);border-radius:var(--radius-m);padding:4px 8px}.works-wrapper{margin-top:var(--header-m)}.works-list{display:flex;flex-wrap:wrap;justify-content:space-between}.news{padding:24px}.news img{margin-bottom:24px}.work-page{padding:calc(24px + var(--header-m)) 0 var(--header-m) 0}.work-page .img{margin-top:48px;width:100%;height:400px;object-fit:cover;border-radius:var(--radius-l);box-shadow:2px 2px 4px 4px #0000001a}#contact{margin-top:var(--header-m);margin-bottom:var(--header-m)}}@media screen and (min-width:1200px){.container{max-width:1200px;margin:0 auto}header .container{height:var(--header-l);display:flex;justify-content:space-between;align-items:center}header h1{height:64px;width:248px;padding:0 8px;border-radius:var(--radius-m);font-size:var(--font-logo-pc)}header button{height:var(--header-l);width:var(--header-l)}header button span{height:3px}.sp-nav{top:0;min-height:100vh;padding:0}.sp-nav .container{min-height:100vh;padding:0 24px}.menu-nav-list{width:100%;max-width:960px}.menu-nav-list .global-nav-list{flex-direction:row;justify-content:center;flex-wrap:wrap;gap:16px}.menu-nav-list .global-nav-list li{margin-top:0}.menu-nav-list .global-nav-list a{font-size:var(--font-l);padding:2px 4px}.menu-nav-list .nav-works-wrapper{margin:36px auto 0;max-width:640px;padding:16px}.menu-nav-list .nav-list-works:after{top:43px;height:37px}.menu-nav-list .nav-works{width:40%;padding-right:12px}.menu-nav-list .nav-works-btn-wrapper{gap:10px}.menu-nav-list .nav-works button{margin-left:0;background-color:transparent;font-size:var(--font-m)}.menu-nav-list .hover-wrapper{width:56%;padding-left:24px;gap:10px}header .hover-wrapper .nav-work-link{height:80px;font-size:var(--font-m);display:flex;align-items:center}.news{flex-direction:row;gap:24px;align-items:flex-start;padding:24px}.news img{width:48%;margin-bottom:0}.news-text{width:48%}.news h3{font-size:var(--font-m)}.title-wrapper h2{font-size:var(--font-title-tab);text-shadow:6px 6px 6px 6px rgba(0,0,0,.9)}.main h2{margin-bottom:var(--font-l);font-size:var(--font-xl)}.main p{margin-top:calc(var(--font-xl) * 2);font-size:var(--font-l)}.main .sp-span{margin-top:0;display:inline-block}.worker-box{margin-top:var(--header-l)}.title{font-size:var(--font-l)}.worker-box button{border:3px solid #8daccf;border-radius:var(--radius-m);padding:4px 8px;font-size:var(--font-sm)}.worker-wrapper{margin-top:var(--header-l)}.worker-prof div:first-of-type h3{font-size:var(--font-xl)}.worker-prof div:first-of-type p{font-size:var(--font-l)}.worker-prof div:last-of-type{width:400px;height:400px}.worker-wrapper .description{margin-top:var(--header-m);color:var(--color);font-size:var(--font-m)}.works-wrapper{margin-top:var(--header-l);color:var(--color)}.works-list{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:48px;margin-top:var(--header-l)}.work-card{width:368px;height:300px;margin-bottom:var(--header-m);overflow:hidden;border:2px solid #8daccf;border-radius:var(--radius-l);box-shadow:2px 2px 4px 4px #0000001a}.work-img{width:368px;height:calc(300px - 56.67px)}.work-card div{padding:8px 16px}.work-card h3{font-size:var(--font-s)}.work-card p{font-size:var(--font-ss)}.work-page{padding:calc(32px + var(--header-l)) 0 var(--header-l) 0}.prev-button{height:56px;width:144px;font-size:var(--font-m);padding:8px 16px}.work-page h2{margin-top:48px;font-size:var(--font-l)}.work-page h2:before{font-size:var(--font-s);bottom:-24px}.work-page .img{margin-top:64px;height:680px;object-position:top center}.work-page .work-title{margin-top:64px;font-size:var(--font-m);color:#fff;letter-spacing:2px}.work-page .work-stacks{margin-top:48px;padding:16px 8px;letter-spacing:8px;font-size:var(--font-m)}.work-page .work-stacks:before{height:32px;width:32px;left:16px}.work-page .description-wrapper{margin-top:48px;padding:16px}.work-page .description-wrapper h3{font-size:var(--font-l);letter-spacing:4px}.work-page .description-wrapper p{margin-top:32px;font-size:var(--font-m);letter-spacing:2px}.work-page .work-links{margin-top:32px}.work-page .work-link-button{margin-top:24px;padding:16px;font-size:var(--font-m);letter-spacing:2px}#contact{margin-top:var(--header-l);margin-bottom:var(--header-l)}.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:32px 24px;align-items:start}.contact-company{grid-column:1;grid-row:1}.contact-name{grid-column:1;grid-row:2}.contact-email{grid-column:1;grid-row:3}.contact-submit{grid-column:1;grid-row:4}.contact-subject{grid-column:2;grid-row:1}.contact-message{grid-column:2;grid-row:2/5;align-self:stretch;height:100%;grid-template-rows:auto 1fr}.contact-message textarea{height:100%;min-height:0}}
