/** SP **/
.pc {
    display: none;
}
.sp {
    display: block;
}
.hd_sns {
    display: none;
}
#g-nav .ul01 li {
    font-size: 18px;
}
#g-nav .ul02 li {
    font-size: 18px;
}
#g-nav .ul03 {
    margin: 40px 0 20px;
}
#g-nav .ul03 li {
    width: 35px;
}
.ft_txt01 a {
    font-size: 16px;
    background-size: 9px;
}
#footer {
    padding: 125px 25px 20px;
}
.gotop {
    right: 5%;
}
.ft_txt02 {
    line-height: 1.5em;
}
.sitepolicy_box,.contact_box {
	padding: 60px 25px 60px;
	text-align: justify;
}
.policy_tit {
	letter-spacing: 0;
	font-size: 18px;
}
.policy_p {
	letter-spacing: 0;
	font-size: 15px;
	line-height: 1.8em;
}
.top_box_01 {
    display: flex;
    flex-wrap: wrap;
}
.top_box_01 .img_01 {
    width: 89.6%;
    float: none;
    order: 1;
}
.top_box_01 .img_02 {
    order: 3;
    width: 58.4%;
    float: none;
    margin-left: auto;
    margin-top: 80px;
}
.top_box_01 .dl_01 {
    order: 2;
    width: 100%;
    float: none;
    margin-top: 100px;
    height: auto;
    display: block;
    padding: 0 25px;
}
.top_box_01 .dl_01 dt {
    writing-mode: inherit;
    margin: 0;
    font-size: 23px;
}
.top_box_01 .dl_01 dd {
    writing-mode: inherit;
    margin-top: 45px;
}
.top_box_02 {
    margin-top: 47px;
}
.top_box_02 .tit_01 {
    margin-left: 13.8%;
    font-size: 33px;
}
.top_box_02 .inner {
    margin-top: -86px;
    padding-top: 90px;
}
.top_slide_02 .slick-prev {
    left: 5px;
}
.top_slide_02 .slick-next {
    right: 5px;
}
.top_slide_02 .num {
    font-size: 22px;
    margin-top: 15px;
}
.top_slide_02 .name {
    font-size: 21px;
    margin-top: 10px;
}
.more_btn {
    margin-top: 0px;
}
.top_box_02 .more_btn a {
    width: 60%;
}
.top_box_03 .insta_btn img {
    width: 115px;
}
.main_img img {
    height: 500px;
    object-fit: cover;
}
.about_box01 .txtbox {
    writing-mode: inherit;
    float: none;
    height: auto;
    margin: 0;
    padding: 0 25px;
}
.about_box01 .catch {
    margin: 0;
    font-size: 24px;
}
.ab_txt01 {
    line-height: 2em;
    letter-spacing: 1px;
}
.about_box01 .imgbox1 {
    width: auto;
    /* min-width: 300px; */
}
.about_box01 .imgbox1 img {
    width: 100%;
    position: relative;
    z-index: 9;
}
.about_box01 .map {
    display: none;
}
.ab_img01 {
    margin: 0 auto 0;
    width: 70%;
    min-width: 300px;
    text-align: center;
    padding-top: 49%;
}
.ab_img01::before {
    content: "";
    background-image: url("images/about/map.png");
    background-repeat: no-repeat;
    width: 94%;
    position: absolute;
    top: 0;
    right: -12%;
    padding-top: 100%;
    background-size: cover;
}
.ab_img02 {
    position: relative;
    width: 70%;
    min-width: 300px;
    margin: 50px auto 0;
}
.about_box01 .imgbox1 {
    width: auto;
    /* min-width: 300px; */
    display: flex;
    flex-wrap: wrap;
    flex-flow: column;
}
.about_box01 {
    margin-top: 100px;
}
.about_box02 {
    margin-top: 90px;
}
.ab_txt02 {
    writing-mode: inherit;
    margin: auto;
    line-height: 2em;
    padding: 0 25px;
    height: auto;
    letter-spacing: 1px;
}
.ab_img03 {
    width: 70%;
    min-width: 300px;
    margin: 90px auto 0;
}
.ab_img04 {
    width: 70%;
    margin: 50px auto 0;
    min-width: 300px;
}
.about_box03 {
    margin-top: 110px;
}
.googlemap {
    margin: 40px auto 0;
}
.dw_logo {
    width: 35%;
    max-width: 158px;
    position: absolute;
    top: 17px;
    left: 2.5%;
}
#g-nav .ul01 {
    top: 140px;
    transform: translate(-50%,-0%);
}
.ab_ul01 {
    width: auto;
    text-align: center;
}
.ab_ul01 li {
	margin-bottom: 20px;
}
#header {
    padding-top: 20px;
}
.hd_logo img {
	width: 100%;
}
.hd_logo {
    width: 37%;
    max-width: 158px;
    top: 15px;
    padding-left: 0;
    left: 2.5%;
}
.openbtn {
    top: 20px;
    right: 25px;
}
.single #header, .contact #header, .sitepolicy #header {
	height: 140px;
}
.sitepolicy_box .inner {
	margin-top: 60px;
}
.copy {
	letter-spacing: 0;
}
.contact_box .txt01 {
	font-size: 17px;
	margin-top: 50px;
}
.contact_box .dl01 dt {
	font-size: 20px;
	line-height: 1.5em;
    text-align: center;
}
.contact_box .dl01 dd {
	text-align: center;
	font-size: 16px;
	letter-spacing: 0;
}
.contact_box .tit_01 {
	text-align: center;
}
.hito_box01 {
	writing-mode: inherit;
	width: auto;
	margin-top: 80px;
}
.hito_box01 h2 {
	font-size: 24px;
	margin-left: 40px;
}
.hito_txt01 {
	line-height: 1.6em;
	margin-left: 40px;
}
.arch_box01 {
	margin-top: 100px;
}
.youtube_box {
	flex-flow: column;
	padding: 0 30px;
}
.mov_box {
	width: 100%;
	margin-bottom: 40px;
}
.arc_mov {
	line-height: 0;
}
.arc_tit2 {
	font-size: 18px;
	margin-top: 5px;
}
.arc_tit2 span {
	font-size: 15px;
}
.view_box01 {
	margin-top: 100px;
}
.view_list {
	width: 100%;
	margin-bottom: 50px;
}
.view_list_wrap {
	padding: 0 25px;
}
.view_list .title {
	font-size: 17px;
	padding: 0;
	margin-top: 10px;
}
.single .main_img img {
	height: 400px;
}
.view_box02 {
	margin-top: 60px;
	padding: 0 25px;
}
.view_box02 a{word-break: break-all;}
.view_box02 .title {
	font-size: 24px;
	line-height: 1.5em;
}
.view_box02 .creator {
	font-size: 15px;
}
.view_txt01 {
	font-size: 18px;
}
.view_txt01 p {
	letter-spacing: 0;
	text-align: justify;
}
.view_box03 {
	margin-top: 100px;
	padding: 0 25px;
}
.fg-item.fg-type-image.fg-loaded {
	width: 32.73%;
	margin-right: 0.9%;
}
.fg-item.fg-type-image.fg-loaded:first-child, .fg-item.fg-type-image.fg-loaded:nth-child(5n+1) {
	margin-left: 0;
}
.fg-item.fg-type-image.fg-loaded:nth-child(3n) {
    margin-right: 0;
}
.paging .next2 a, .paging .prev2 a {
	width: 100%;
}
.hito2_box02 .paging .index2 {
	width: 24%;
}
.paging .next2, .paging .prev2 {
	width: 33%;
}
.hito_list_wrap {
	margin-top: 80px;
	width: 100%;
	padding: 0 25px;
}
.hito_list {
	width: 100%;
	margin-right: 0;
	margin-bottom: 70px;
}
.hito_catch p {
	font-size: 18px;
	left: 70%;
}
.hito_catch {
	margin-top: -130px;
}
.hito2_box01 {
	padding: 0 25px;
}
.hito2_box01 .name {
	flex-wrap: wrap;
}
.hito2_box01 .name dt {
	width: 100%;
	margin-bottom: 10px;
}
.hitoBody {
	margin-top: 80px;
	font-size: 18px;
	line-height: 2em;
    padding: 0;
}
.hitoBody h3 {
	font-size: 24px;
	letter-spacing: 0;
	margin-bottom: 2em;
}
.hitoBody strong {
	letter-spacing: 0;
}
.hitoBody p {
	font-size: 18px;
	letter-spacing: 0;
	margin-bottom: 1.5em;
}
.hito2_box01 .notice {
	padding: 30px 30px;
}
.hito2_box01 .notice p {
	font-size: 17px;
	line-height: 1.8em;
}
.hito2_box01 .notice p,
.hito2_box01 .notice a {
	word-break: break-all;
}
.hito2_box01 .creator {
	flex-wrap: wrap;
}
.ubicbox_01 {
	margin-top: 30px;
	padding: 0 30px;
}
.ubicbox_01 .nav {
	width: 100%;
	margin-bottom: 20px;
}
.ubicbox_02 {
	margin: 35px 25px 0;
	padding: 60px 25px;
}
.ubicbox_02 .txt_01 {
	font-size: 18px;
	margin-top: 60px;
	width: 100%;
}
.flow_box_01 {
	max-width: 400px;
}
.flow_box_01 .datail01, .flow_box_01 .datail02 {
	width: 48.5%;
}
.job_box {
	margin-top: 100px;
	max-width: 400px;
}
.job_tit img {
	width: 70.5%;
}
.job_ul01 {
	margin-top: 50px;
}
.job_ul01 li {
	margin-right: 6%;
	padding-left: 23px;
}
.ubicbox_02 .txt_02 {
	text-align: left;
}
.job_btn01 {
	margin-top: 40px;
}
.job_dl01 dd span {
	display: block;
	font-size: 15px;
}
.job_dl01 dd {
	letter-spacing: 0;
}
.job_dl01 {
	margin-top: 50px;
}
.ubicbox_03 {
	margin: 60px 25px;
	padding: 60px 25px;
}
.ubicbox_03 .txt_04 {
	font-size: 18px;
	margin-top: 60px;
	width: 100%;
}
.ubicbox_03 .tit_02 {
	font-size: 26px;
	margin-top: 60px;
}
.support_box {
	padding: 220px 25px 40px;
}
.support01::before, .support02::before {
	left: 0;
	right: 0;
	margin: auto;
	top: -10px;
}
.support01::before {
	background-image: url("images/ubic/sp/support01.png");
	width: 133px;
	height: 188px;
}
.support02::before {
	background-image: url("images/ubic/sp/support02.png");
	width: 137px;
	height: 183px;
}
.support_box .tit_03 {
	font-size: 21px;
	text-align: center;
}
.support_box .txt_05 {
	font-size: 17px;
	letter-spacing: 0;
}
.support_box .txt_06 {
	text-align: center;
}
.support_box .txt_06 small {
	white-space: nowrap;
}
.support_box .support_ul01 li {
	margin-bottom: 8px;
	background-position: left top 6px;
}
.ubic_con.u01 {
	margin-top: 60px;
}
.ubic_con {
	padding: 0;
	background-position: left top 7px;
}
.ubic_con .tit_04 {
	padding-left: 2em;
	font-size: 24px;
	line-height: 1.4em;
}
.ubic_con .btn img {
	width: 180px;
}
.ubic_dl01 dt {
	max-width: inherit;
	display: inline-block;
	padding: 0 20px;
	font-size: 18px;
}
.ubic_dl01 dd table {
	min-width: inherit;
	width: 100%;
}
.ubic_dl01 dd table td {
	font-size: 16px;
	letter-spacing: 0;
}
.ubic_dl01 dd {
	font-size: 17px;
}
.ubic_dl01 dd small {
	white-space: nowrap;
}
.ubicbox_04 {
    margin: 60px 25px;
	padding: 60px 25px;
}
.ubicbox_04 .txt_07 {
	font-size: 18px;
	margin-top: 60px;
	width: 100%;
}
.madoguchi {
	padding: 20px;
}
.madoguchi .tit_02 {
	font-size: 18px;
    letter-spacing: 0;
}
.madoguchi .tit_02 br {
	display: none;
}
.madoguchi .btn {
	margin-top: 20px;
}
.life_info .txt_08 .mini01 {
	display: block;
}
.life_info {
	margin-top: 60px;
}
.ubicbox_05 {
    margin: 60px 25px;
}
.ubic_name {
	padding: 0 25px;
	align-items: unset;
	margin-top: 30px;
}
.ubic_name .name1 {
	width: 49.11%;
	padding-top: 17%;
}
.ubic_name .name2 {
	width: 32.15%;
}
.ubicbox_05 .txt_09 {
	padding: 0 25px;
	font-size: 18px;
	letter-spacing: 0;
	text-align: justify;
	margin: 40px auto 60px;
}
.ubicbox_05 .info dd span {
	white-space: nowrap;
}
.ubicbox_05 .info dd {
	font-size: 17px;
	letter-spacing: 0;
}
