@charset "UTF-8";
/* ==========================================================
0～768px
========================================================== */
@media screen and (max-width: 768px) { .pc { display: none; }
  .btn { width: 100%; }
  .btn a { font-size: 16px; font-size: 1.6rem; }
  /* header ----------------------------------------------------------- */
  .top-head { padding: 0; display: block; }
  .top-head-inner { width: 100%; clear: both; height: auto; position: static; }
  .head-logo { width: 100%; clear: both; padding: 0; }
  .head-logo .logo { width: 100%; height: 60px; background: #fff; margin: 0; padding: 14px 0 0 2%; position: fixed; top: 0; right: 0; z-index: 10000; }
  .head-logo .logo img { width: 180px; }
  /* nav ----------------------------------------------------------- */
  .hamburger { background: #26a3bd; /* Old browsers */ background: -moz-linear-gradient(45deg, #26a3bd 0%, #26a3bd 44%, #6cd4bf 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(45deg, #26a3bd 0%, #26a3bd 44%, #6cd4bf 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(45deg, #26a3bd 0%, #26a3bd 44%, #6cd4bf 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#26a3bd', endColorstr='#6cd4bf',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */ display: block; width: 60px; height: 60px; position: fixed; top: 0; right: 0; z-index: 10000; padding: 15px 0 0 18px; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; -webkit-tap-highlight-color: transparent; -ms-touch-action: manipulation; touch-action: manipulation; }
  .hamburger__icon { position: relative; margin-top: 14px; margin-bottom: 0; }
  .hamburger__icon, .hamburger__icon:before, .hamburger__icon:after { display: block; width: 24px; height: 2px; background-color: #fff !important; -moz-transition-property: background-color, -moz-transform; -o-transition-property: background-color, -o-transform; -webkit-transition-property: background-color, -webkit-transform; transition-property: background-color, transform; -moz-transition-duration: 0.4s; -o-transition-duration: 0.4s; -webkit-transition-duration: 0.4s; transition-duration: 0.4s; }
  .hamburger__icon:before, .hamburger__icon:after { position: absolute; content: ""; }
  .hamburger__icon:before { top: -7px; }
  .hamburger__icon:after { top: 7px; }
  .hamburger.active .hamburger__icon { background-color: transparent; }
  .hamburger.active .hamburger__icon:before, .hamburger.active .hamburger__icon:after { background-color: #fff; }
  .hamburger.active .hamburger__icon:before { -moz-transform: translateY(7px) rotate(45deg); -ms-transform: translateY(7px) rotate(45deg); -webkit-transform: translateY(7px) rotate(45deg); transform: translateY(7px) rotate(45deg); }
  .hamburger.active .hamburger__icon:after { -moz-transform: translateY(-7px) rotate(-45deg); -ms-transform: translateY(-7px) rotate(-45deg); -webkit-transform: translateY(-7px) rotate(-45deg); transform: translateY(-7px) rotate(-45deg); }
  .hamburger.active .hamburger__icon { width: 0; }
  /*オーバーレイメニュー*/
  .fat-nav { top: 60px; left: 0; z-index: 9999; position: fixed; display: none; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.8); -moz-transition-property: -moz-transform; -o-transition-property: -o-transform; -webkit-transition-property: -webkit-transform; transition-property: transform; -moz-transition-duration: 0.4s; -o-transition-duration: 0.4s; -webkit-transition-duration: 0.4s; transition-duration: 0.4s; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; }
  .fat-nav__wrapper { width: 100%; height: 100%; }
  #global-nav { padding-top: 0; }
  #global-nav .menu { display: block; }
  #global-nav .menu > li { display: block; width: 100%; }
  #global-nav .menu > li > a, #global-nav .menu > li div { background: #f0f5f6; color: #26a3bd; text-align: left; padding: 1em; font-weight: 600; }
  #global-nav .menu > li > a span, #global-nav .menu > li div span { display: none; }
  #global-nav .menu > li > a::before, #global-nav .menu > li div::before { display: none; }
  #global-nav .menu > li.first::before { display: none; }
  #global-nav .menu > li.g-contact { width: 100%; margin: 0 auto; }
  #global-nav .menu > li.g-contact > a { border-radius: 0; padding: 2.8em 5% 1.5em; text-align: center; }
  #global-nav .menu > li.g-contact > a::after { top: 18px; left: 0; right: 0; margin: 0 auto; }
  .menu__second-level li > a { width: 100%; background: #fff; border-bottom: 1px dotted #9ceacf; color: #2d3436; font-size: 15px; font-size: 1.5rem; padding: 0.8em 0.8em 0.8em 2em; position: relative; }
  .menu__second-level li > a::before { content: ''; position: absolute; background: url("../images/common/icon_stripe.svg") no-repeat; background-size: 7px; top: 13px; left: 16px; width: 9px; height: 18px; }
  /* visual ----------------------------------------------------------- */
  #tp-visual { height: auto; }
  #tp-visual::after { height: 100%; }
  #tp-visual::before { background: url("../images/tp_visual_dot.png") no-repeat top right; background-size: 200px; top: 100px; bottom: auto; right: 0; }
  .tp-visual-inner { padding: 0 0 0 5vw; }
  .tp-visual-copy-box { top: 55vh; padding-right: 0; }
  .tp-visual-copy { font-size: 24px; font-size: 2.4rem; }
  .tp-visual-subcopy { font-size: 15px; font-size: 1.5rem; }
  .tp-visual-img-box { width: 85vw; height: 90vh; }
  .tp-visual-img-box::before { bottom: -10px; right: 0; background: url("../images/nexas.svg") no-repeat left bottom; background-size: 100%; width: 100%; height: 330px; }
  .scroll { position: absolute; left: 0; top: auto; bottom: -40px; }
  .scroll .scroll-down { font-size: 12px; font-size: 1.2rem; }
  /* .tp-message ----------------------------------------------------------- */
  .tp-message { padding: 100px 0 60px; }
  .tp-message::after { width: 69.79%; height: 100%; z-index: -1; }
  .tp-message::before { content: ''; position: absolute; position: absolute; background: url("../images/common/dot_bg.png") no-repeat; background-size: 200px; top: 50%; width: 200px; height: auto; }
  .tp-message-txt { width: 100%; }
  .tp-message-txt-box { width: 100%; padding: 0 5%; }
  .tp-message-txt-box h2 { background-size: 60px; padding-left: 72px; padding-top: 20px; margin-bottom: 2em; margin-left: 0; }
  .tp-message-txt-box h3 { font-size: 20px; font-size: 2rem; margin-bottom: 1.5em; letter-spacing: 0; }
  .tp-message-txt-box p { margin-bottom: 2em; padding-left: 0; padding-right: 0; }
  .tp-message-img { width: 100%; position: static; }
  .tp-message-img img { max-width: none; }
  .tp-message-font { width: 80%; bottom: 50px; }
  /* .tp-service ----------------------------------------------------------- */
  .tp-service { margin-top: 80px; }
  .tp-service-intro { width: 100%; display: block; padding: 0 5%; }
  .tp-main-ttl { width: 100%; }
  .main-ttl-en { font-size: 60px; font-size: 6rem; }
  .tp-service-detail { margin-top: 3em; padding-bottom: 0; }
  .tp-service-inner { padding: 40px 0 80px; margin-top: 3em; }
  .tp-service-inner::after { height: 100%; }
  .tp-service-box { display: block; }
  .tp-service-card { width: 100%; }
  .tp-service-card figure { padding-left: 10%; }
  .tp-service-card .tp-service-card-txt { width: 80%; padding: 2em 5%; margin: -40px 0 0 0; }
  .tp-service-card .tp-service-card-txt h3 { padding-bottom: 1.5em; font-size: 18px; font-size: 1.8rem; }
  .tp-service-card .tp-service-card-arrow { position: absolute; bottom: 40px; right: 2%; }
  .tp-service-card .tp-service-card-arrow img { width: 49px; }
  .tp-service-card.card02 { margin-top: 40px; }
  .tp-service-card.card02 .tp-service-card-arrow { bottom: 40px; }
  /* .tp-about ----------------------------------------------------------- */
  .tp-about { padding: 0 0 80px; }
  .tp-about::after { display: none; }
  .tp-about::before { display: none; }
  .tp-about-img { width: 100%; height: auto; position: static; }
  .tp-about-img img { width: 100%; max-width: none; }
  .tp-about-inner { width: 100%; clear: both; }
  .tp-about-detail { width: 100%; margin-left: 0; padding: 40px 5% 0; position: relative; }
  .tp-about-detail .tp-main-ttl { margin-bottom: 3em; }
  .tp-about-detail::after { content: ''; position: absolute; background: #f0f5f6; width: 69.8%; height: 400px; top: 70px; left: 0; z-index: -1; }
  .tp-about-btn { margin-top: 40px; }
  .tp-about-btn ul { display: block; width: 100%; }
  .tp-about-btn .btn { width: 80%; margin-bottom: 1em; }
  .tp-about-btn .btn a { padding: 1.2em 0; background-size: 20px; }
  .tp-about-btn .btn a:hover { background-size: 20px; }
  /* .tp-recruit ----------------------------------------------------------- */
  .tp-recruit { width: 100%; background-position: top center; padding: 1em; }
  .tp-recruit-inner { padding: 2em 1em; }
  .tp-recruit-inner .tp-recruit-ttl-en { font-size: 60px; font-size: 6rem; }
  .tp-recruit-inner .tp-recruit-ttl { margin-bottom: 2em; }
  .tp-recruit-inner .btn { width: 80%; }
  /* .tp-news ----------------------------------------------------------- */
  .tp-news { margin: 80px auto 0; padding-bottom: 80px; }
  .tp-news-inner { width: 90%; padding: 0 5% 60px; }
  .tp-news-inner .btn-more { margin-top: 3em; }
  .tp-news-inner .btn-more a { background-size: 32px; padding: 1em 3em 1em 0; }
  .tp-news-inner .btn-more a:hover { background-size: 32px; }
  .tp-news-box { display: block; }
  .tp-news-box h2 { font-size: 50px; font-size: 5rem; }
  .tp-news-box ul { width: 100%; }
  .tp-news-box li a { display: block; padding: 1.5em 0; }
  .tp-news-box li a .date { font-size: 15px; font-size: 1.5rem; padding-right: 0; padding-bottom: 0.5em; }
  /* footer ----------------------------------------------------------- */
  /*お問い合わせ*/
  .ft-contact-wrap { background: url("../images/common/ft_contact_bg.jpg") no-repeat 75% 0 #2d3436; background-size: auto 50%; padding-top: 50px; }
  .ft-contact-ttl { padding-bottom: 30px; }
  .ft-contact-ttl h2 { font-size: 60px; font-size: 6rem; font-style: italic; }
  .ft-contact-ttl .ja { font-size: 18px; font-size: 1.8rem; }
  .ft-contact-txt { text-align: left; margin-top: 20px; margin-bottom: 70px; padding: 0 5%; }
  .ft-contact-inner { width: 100%; display: block; }
  .ft-contact-box { width: 100%; height: auto; }
  .ft-contact-box h3 { font-size: 20px; font-size: 2rem; padding-top: 50px; }
  .ft-contact-box.ft-tel { padding-bottom: 60px; margin-bottom: 0; }
  .ft-contact-box.ft-tel h3 { margin-bottom: 1.2em; }
  .ft-contact-box.ft-tel h3::before { background-size: 60px; width: 60px; height: 60px; }
  .ft-contact-box.ft-tel .tel { font-size: 46px; font-size: 4.6rem; }
  .ft-contact-box.ft-tel .tel span { font-size: 20px; font-size: 2rem; padding-right: 0.2em; }
  .ft-contact-box.ft-tel .com { font-size: 16px; font-size: 1.6rem; }
  .ft-contact-box.ft-tel .time { font-size: 14px; font-size: 1.4rem; margin-top: 1.6em; }
  .ft-contact-box.ft-tel .time span { font-size: 14px; font-size: 1.4rem; }
  .ft-contact-box.ft-mail { padding-bottom: 40px; }
  .ft-contact-box.ft-mail h3 { margin-bottom: 1.2em; }
  .ft-contact-box.ft-mail h3::before { background-size: 60px; width: 60px; height: 60px; }
  .ft-contact-box.ft-mail .btn { width: 90%; position: relative; }
  .ft-contact-box.ft-mail .btn a { font-size: 18px; font-size: 1.8rem; padding: 1em 0; background-size: 32px; }
  .ft-contact-box.ft-mail .btn a:hover { background-size: 32px; }
  /*フッターインフォ*/
  .ft-info-wrap { padding: 70px 5% 50px; display: block; }
  .ft-info-wrap::before { content: ''; position: absolute; background: url("../images/common/deco_dot.png") no-repeat top right; background-size: 190px; top: -10px; }
  .ft-info-address { padding-right: 0; text-align: center; }
  .ft-info-address .ft-logo { width: 60%; margin: 0 auto 3em; }
  .ft-info-address p { color: #f0f5f6; font-size: 14px; font-size: 1.4rem; line-height: 1.8; }
  .ft-info-link { display: none; width: 100%; }
  .ft-info-bnr { text-align: center; margin-top: 40px; }
  .ft-info-bnr .ft-info-bnr-ttl { width: 60%; margin: 0 auto; }
  .ft-info-bnr .ft-info-bnr-ttl::before, .ft-info-bnr .ft-info-bnr-ttl::after { width: 20px; }
  .ft-info-bnr img { width: 60%; margin-bottom: 10px; }
  /*フッターボトム*/
  .ft-info-btm { padding: 0; display: block; }
  .ft-sublink { background: #2d3436; padding: 1em 5%; text-align: center; border-top: 1px solid #444; }
  .ft-sublink li { display: inline-block; }
  .ft-sublink li a { font-size: 13px; font-size: 1.3rem; color: #f0f5f6; padding-right: 2em; display: block; }
  .ft-sublink li a::after { content: "/"; color: #2d3436; padding-left: 2em; }
  .ft-sublink li:last-child a::after { display: none; }
  .ft-copyright { padding: 2em 5%; text-align: center; }
  .ft-copyright small { font-size: 12px; font-size: 1.2rem; }
  /*ページトップ*/
  .pagetop { background: #fff; }
  .pagetop a { width: 68px; height: 64px; display: block; padding-top: 22px; }
  /* sub_common ----------------------------------------------------------- */
  #sub-visual { height: 300px; padding: 40px 0 0; }
  #sub-visual::after { width: 80%; }
  #sub-visual::before { background: url("../images/common/header_dot.png") no-repeat top right; background-size: 240px; top: 80px; }
  .sub-visual-inner::after { width: 80%; height: 200px; background-size: cover; }
  .sub-visual-ttl { position: absolute; top: 70px; right: 5%; }
  .sub-en-ttl span { font-size: 50px; font-size: 5rem; font-style: italic; }
  .sub-ttl span { font-size: 15px; font-size: 1.5rem; margin-top: -40em; position: relative; top: -7px; }
  .breadCrumb { width: 100%; clear: both; margin: -40px auto 0; padding: 0 5% 40px; position: relative; }
  .breadCrumb li { display: inline-block; font-size: 12px; font-size: 1.2rem; }
  #sub-main { background: url("../images/common/dot_bg.png") no-repeat 0 20px; background-size: 200px; }
  .base-wrap { padding-top: 40px; padding-bottom: 80px; }
  .inner { width: 100%; clear: both; padding: 0 5%; }
  .ttl-base-inner { margin-bottom: 40px; }
  .ttl-base { font-size: 30px; font-size: 3rem; background-size: 40px; padding: 1.8em 0 0; margin-bottom: 0.6em; }
  .ttl-base-en { font-size: 13px; font-size: 1.3rem; font-style: italic; }
  .ttl-second { font-size: 18px; font-size: 1.8rem; padding: 16px 0 0 24px; }
  .base-table th, .base-table td { display: block; padding: 1em; line-height: 1.8; border-top: 1px dotted #26a3bd; border-bottom: none; }
  .base-table th { width: 100%; }
  .base-table td { width: 100%; }
  .gmap { position: relative; width: 100%; height: 0; padding-bottom: 75%; overflow: hidden; }
  .gmap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
  /* service ----------------------------------------------------------- */
  .business-inner { margin-bottom: 80px; }
  .business-detail { width: 100%; clear: both; }
  .business-detail-box { width: 100%; padding: 0 5%; }
  .business-detail-box h3 { margin-bottom: 2em; }
  .business-detail-box h3 span { font-size: 18px; font-size: 1.8rem; }
  .business-img-inner { position: static; width: 100%; margin-top: 3em; }
  .business-img-inner img { width: 80%; height: auto; max-width: none; }
  .business-img-inner::after { width: 80%; height: 20vh; top: auto; bottom: -60px; right: 0; }
  .feature-wrap { background: url("../images/service_feature_font.png") no-repeat top left; background-size: 80%; padding: 0 5%; }
  .feature-ttl { width: 100%; clear: both; margin-bottom: 100px; }
  .feature-ttl h2 { font-size: 24px; font-size: 2.4rem; }
  .feature-ttl h2 span { font-size: 48px; font-size: 4.8rem; }
  .feature-inner { width: 100%; }
  .feature-card { width: 100%; margin-right: 0; margin-bottom: 90px; padding-bottom: 30px; }
  .feature-card .feature-num { padding-left: 1em; }
  .feature-card .feature-icon img { width: 50vw; }
  .feature-card h3 { font-size: 18px; font-size: 1.8rem; margin-top: 2em; padding: 0 5%; }
  .feature-card p { margin-top: 1em; padding: 0 5%; }
  .f-card02 { top: 0; }
  .f-card03 { top: 0; }
  .f-card04 { margin-top: 0; }
  .f-card05 { margin-top: 0; }
  .works-wrap { background: url("../images/service_works_bg.jpg") no-repeat top center; background-size: cover; padding: 48px 0 40px; }
  .works-wrap .inner { display: block; }
  .works-wrap h2 { font-size: 24px; font-size: 2.4rem; padding-top: 0; }
  .works-wrap h2 span { font-size: 12px; font-size: 1.2rem; }
  .works-wrap .works-inner { width: 100%; padding: 2em 5%; margin-top: 2em; }
  .works-wrap .works-inner h3 { font-size: 20px; font-size: 2rem; line-height: 1.6; }
  .works-wrap .works-inner .works-client { margin-bottom: 2em; padding: 0.5em 5%; border-radius: 10px; }
  .works-wrap .works-inner .works-client p { font-size: 12px; font-size: 1.2rem; }
  .service-flow::before { top: 10vh; right: 0; width: 192px; height: 192px; }
  .flow-detal::after { width: 1px; height: 100%; border-left: 1px dashed #aaa; top: 0; left: 0; right: 0; margin: 0 auto; }
  .flow-detal ul { display: block; }
  .flow-detal .flow-num { font-size: 26px; font-size: 2.6rem; padding-top: 22px; margin-top: 1em; }
  .flow-detal .flow-step { font-size: 18px; font-size: 1.8rem; margin-bottom: 0; margin-top: 0; background: #f7f9fa; display: inline-block; padding: 0.2em 1em; }
  /*コンテンツナビ*/
  .cont-nav .btn a { width: 100%; font-size: 14px; font-size: 1.4rem; padding: 2em 5em 2em 0; }
  /* message ----------------------------------------------------------- */
  .message .base-wrap { padding-bottom: 60px; }
  .message-box { display: block; }
  .message-img { width: 100%; }
  .message-img .message-president { bottom: 40px; left: -5%; padding: 1em 3em; }
  .message-img .message-president p { font-size: 26px; font-size: 2.6rem; color: #fff; }
  .message-txt { width: 100%; }
  .message-txt h3 { margin-bottom: 2em; margin-top: 2em; }
  .message-txt span { background: #2d3436; font-size: 18px; font-size: 1.8rem; padding: 0.3em 0.4em; display: inline-block; margin-bottom: 4px; }
  .message-txt p { padding-left: 0; }
  .management-inner p { margin-top: 100px; text-align: left; }
  .management-word { padding: 2.5em 0; width: 100%; }
  .management-word h3 { font-size: 24px; font-size: 2.4rem; line-height: 1.4; }
  /* company ----------------------------------------------------------- */
  .company-access-inner { position: relative; }
  .com-access-info { width: 100%; position: static; padding: 1.5em 5% 1em; display: block; }
  .com-access-info h3 { color: #fff; font-weight: 600; padding-bottom: 24px; }
  .com-access-info p { border-top: 1px solid #5dd0e8; border-left: none; padding-left: 0; padding-top: 12px; }
  /* philosophy ----------------------------------------------------------- */
  .philo-list dl { padding: 1.2em 5% 2.0em; margin-bottom: 40px; }
  .philo-list dl::after { top: 16px; left: 16px; }
  /* recruit ----------------------------------------------------------- */
  .recruit-contact { width: 100%; margin: 40px auto 0; padding: 1.5em 5%; }
  .recruit-contact p { font-size: 18px; font-size: 1.8rem; line-height: 1.4; }
  .base-wrap.recruit-wrap { padding-bottom: 60px; }
  .recruit .rec-contact-wrap .ft-contact-box.ft-mail .btn a span { font-size: 16px; font-size: 1.6rem; }
  /* privacy ----------------------------------------------------------- */
  .pri-inner { margin-top: 40px; }
  .base-dl { padding-bottom: 40px; }
  /* news ----------------------------------------------------------- */
  /*list*/
  .newslist li .date { font-size: 15px; font-size: 1.5rem; padding-right: 0; padding-bottom: 0.5em; display: block; font-style: italic; }
  .newslist li a { padding: 1em 0; display: block; }
  /*detail*/
  .news .base-wrap.detail { padding-bottom: 40px; }
  .article-txt { padding: 0; }
  .article-txt ul { margin: 2em 0; }
  .backnav { padding: 10px 0; }
  .backnav .btn { width: 100%; text-align: left; }
  .backnav .btn a { text-align: left; display: block; padding: 30px 0 30px 70px; }
  /* contact ----------------------------------------------------------- */
  .contact .sub-visual-inner::after { background: url("../images/contact_visual.jpg") no-repeat top left; background-size: cover; }
  .contact-message { padding-bottom: 20px; }
  .contact-step-box { margin-bottom: 20px; }
  .sup { margin-left: 0; top: 1.3em; right: 1.5em; }
  .errors em { font-size: 16px; font-size: 1.6rem; }
  input[type="submit"] { -webkit-appearance: none; border-radius: 0; }
  .contact-input th { width: 100%; display: block; vertical-align: top; padding: 1em; }
  .contact-input td { width: 100%; display: block; padding: 1em; }
  .contact-input textarea { height: 200px; }
  .submit { display: block; border: none; width: 100%; }
  .submit input { width: 100%; font-size: 20px; font-size: 2rem; margin: 40px auto 0; padding: 24px 0; border-radius: 80px; }
  .contact-privacy { margin-top: 80px; }
  .confirm .contact-input th { padding-top: 1em; width: 100%; }
  .soushin { width: 100%; margin: 0 auto; position: relative; }
  .soushin input { width: 100%; font-size: 20px; font-size: 2rem; margin: 40px auto 0; padding: 24px 0; border-radius: 80px; }
  .soushin input.inback { font-size: 13px; font-size: 1.3rem; position: static; padding: 12px 0; width: 60%; }
  .finish .alignC { text-align: left !important; }
  .finish-info { width: 100%; margin: 30px 0 0 0; text-align: left; padding: 20px 5%; display: block; }
  .finish-info p { font-size: 16px; font-size: 1.6rem; text-align: left; }
  .finish-info .finish-tel { width: 100%; }
  .finish-info .finish-mail { width: 100%; }
  .finish-back { margin-top: 60px; }
  .finish-back li { margin: 0 0.3em 16px; display: block; }
  .finish-back a { width: 50%; font-size: 12px; font-size: 1.2rem; margin: 0 auto; padding: 1.2em 1.5em; } }
/* -----@media screen and (max-width:768px) ------ */
