@charset "UTF-8";
@import url(normalize.css);
@import "https://fonts.googleapis.com/css?family=Ubuntu:300,400,700|Ubuntu+Condensed|Open+Sans:400,600,700|Work+Sans:300|Roboto+Condensed:700";
@import "https://cdn.jsdelivr.net/fontawesome/4.6.0/css/font-awesome.css";
.ibk-top .header .title, .ibk-top .header .copy, .ibk-top #scroll-btn, .ibk-about .text div.first, .ibk-about .text div.en, .ibk-design .head, .ibk-design .text, .ibk-design .img { visibility: hidden; opacity: 0; -webkit-transform: translateY(40px); -ms-transform: translateY(40px); transform: translateY(40px); -webkit-transition: opacity 1s ease, -webkit-transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); transition: opacity 1s ease, -webkit-transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); -o-transition: opacity 1s ease, transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); transition: opacity 1s ease, transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); transition: opacity 1s ease, transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99), -webkit-transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); }

.t-opacity { -webkit-transition: opacity 2s ease, visibility 2s ease; -o-transition: opacity 2s ease, visibility 2s ease; transition: opacity 2s ease, visibility 2s ease; visibility: hidden; opacity: 0; }

.ibk-top.t--disp .header .title, .ibk-top.t--disp .header .copy, .ibk-top.t--disp #scroll-btn, .ibk-about.t--disp .text div.first, .ibk-about.t--disp .text div.en, .ibk-design.t--disp .head, .ibk-design.t--disp .text, .ibk-design.t--disp .img { visibility: visible; opacity: 1; -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); }

.ibk-top .header .title, .ibk-top .header .copy, .ibk-design .head, .ibk-design .text { -webkit-transition-delay: 0.2s; -o-transition-delay: 0.2s; transition-delay: 0.2s; }

.ibk-top #scroll-btn, .ibk-about .text div.first, .ibk-design .img { -webkit-transition-delay: 0.5s; -o-transition-delay: 0.5s; transition-delay: 0.5s; }

.ibk-about .text div.en { -webkit-transition-delay: 0.8s; -o-transition-delay: 0.8s; transition-delay: 0.8s; }

/**************************************************
　base
***************************************************/
/* -----------------------------------------------
　Body
-------------------------------------------------- */
html, body { width: 100%; }

* { -webkit-box-sizing: border-box; box-sizing: border-box; }

body, input, textarea { font-size: 16px; *font-size: 100%; font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; }

body { margin: 0; padding: 0; background: #fff; color: #000; font-size: 14px; line-height: 1.5; }

/* -----------------------------------------------
　Elements
-------------------------------------------------- */
h1, h2, h3, h4, h5, h6, ul, li, dl, dt, dd { margin: 0; padding: 0; }

h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: normal; }

ol { margin-top: 0; margin-bottom: 0; }

ol li { list-style: decimal; }

ul li { list-style: none; }

img, video { border: 0; vertical-align: bottom; }

img { max-width: 100%; height: auto; }

a { color: #000; text-decoration: none; }

p { margin: 0; padding: 0; line-height: 1.8; }

em { font-style: normal; }

/* -----------------------------------------------
　Common Class
-------------------------------------------------- */
.wrap, .page-content { zoom: 1; }

.wrap:after, .page-content:after { content: ''; display: block; clear: both; overflow: auto; }

.float-l { float: left; }

.float-r { float: right; }

.clear { clear: both; }

.hidden { display: none; }

.center { text-align: center; }

.right { text-align: right; }

.left { text-align: left; }

.wordbreak { word-break: break-all !important; }

.nowrap { white-space: nowrap !important; }

.red { color: #f00; }

p.indention, ul.indention li { margin-left: 1em; text-indent: -1em; }

ul.indention .noindent { margin-left: 0; text-indent: 0; }

.caps { text-transform: uppercase; }

.capsoff { text-transform: none !important; }

.disp-ib { display: inline-block; }

.disp-tb, .view-tb, .disp-tbsp, .view-tbsp, .disp-sp, .view-sp, .imgTxt span, .page-title span { display: none; }

.disp-pc { display: block; }

.view-pc, .imgTxt img, .page-title img { display: inline; }

.m_tx1 { margin-top: 10px; }

.m_tx2 { margin-top: 20px; }

.m_tx3 { margin-top: 30px; }

.m_tx4 { margin-top: 40px; }

.m_tx5 { margin-top: 50px; }

.m_tx6 { margin-top: 60px; }

.m_bx1 { margin-bottom: 10px; }

.m_bx2 { margin-bottom: 20px; }

.m_bx3 { margin-bottom: 30px; }

.m_bx4 { margin-bottom: 40px; }

.m_bx5 { margin-bottom: 50px; }

.m_bx6 { margin-bottom: 60px; }

/**************************************************
　structure
***************************************************/
/* -----------------------------------------------
　Header
-------------------------------------------------- */
#site-header { padding: 0 20px; overflow: hidden; position: fixed; top: 0px; z-index: 100; width: 100%; height: 100px; -webkit-transition: -webkit-transform 0.5s ease-out; transition: -webkit-transform 0.5s ease-out; -o-transition: transform 0.5s ease-out; transition: transform 0.5s ease-out; transition: transform 0.5s ease-out, -webkit-transform 0.5s ease-out; }

#site-header::after { content: ""; display: block; width: 100%; height: 100px; background: #fff; position: absolute; z-index: -1; top: 0; left: 0; z-index: -2; }

#site-header.skin-white::after { background: transparent; }

#site-header.extend { height: 500px; }

#site-header.skin-white { color: #fff; }

#site-header.skin-white a { color: #fff; }

#site-header.skin-white .gnav a:hover { border-bottom: 1px solid #fff; }

#site-header.hdr-disp { -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); }

#site-header.hdr-hide { -webkit-transform: translateY(-90px); -ms-transform: translateY(-90px); transform: translateY(-90px); }

#site-header .site-header-container { max-width: 1286px; margin: 0 auto; -webkit-transition: 1s; -o-transition: 1s; transition: 1s; }

#site-header .header-inner { width: 1246px; margin: 0 auto; padding: 22px 0 12px; }

#site-header .logo { float: left; width: 185px; margin-right: 32px; }

#site-header .logo img { height: 39px; }

.gnav { float: left; }

.gnav ul { padding: 12px 0 0; }

.gnav ul li { display: inline-block; padding: 0 13px; font-family: "Open Sans", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: bold; line-height: 1.2; text-transform: uppercase; position: relative; z-index: 1; }

.gnav ul li a { position: relative; z-index: 1; display: block; -webkit-transition: opacity 0.2s ease-in-out; -o-transition: opacity 0.2s ease-in-out; transition: opacity 0.2s ease-in-out; }

.gnav ul li a:hover { border-bottom: 1px solid #000; }

.gnav ul li.stay a { border-bottom: 1px solid #000; }

.gnav ul li.has-child.active a { border-bottom: 1px solid #fff; color: #fff; }

.gnav > ul > li > a:hover { opacity: 0.5; }

.gnav ul.submenu { position: absolute; top: -40px; left: -7px; width: 0px; background: rgba(0, 0, 0, 0.9); margin: 0; padding: 70px 20px 25px; opacity: 0; visibility: hidden; -webkit-transition: opacity 0.3s ease-in, width 0.3s ease-out; -o-transition: opacity 0.3s ease-in, width 0.3s ease-out; transition: opacity 0.3s ease-in, width 0.3s ease-out; }

.gnav ul.submenu li { color: #fff; font-size: 85.71429%; font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; width: 170px; padding: 10px 0; border-bottom: solid 1px #4D4D4D; opacity: 0; visibility: hidden; -webkit-transform: translateY(30px); -ms-transform: translateY(30px); transform: translateY(30px); -webkit-transition: opacity 0.5s ease-in-out, -webkit-transform 0.5s; transition: opacity 0.5s ease-in-out, -webkit-transform 0.5s; -o-transition: opacity 0.5s ease-in-out, transform 0.5s; transition: opacity 0.5s ease-in-out, transform 0.5s; transition: opacity 0.5s ease-in-out, transform 0.5s, -webkit-transform 0.5s; }

.gnav ul.submenu li a { border-bottom: none !important; }

.gnav ul.submenu li.delay2 { -webkit-transition-delay: 0.1s; -o-transition-delay: 0.1s; transition-delay: 0.1s; }

.gnav ul.submenu li.delay3 { -webkit-transition-delay: 0.2s; -o-transition-delay: 0.2s; transition-delay: 0.2s; }

.gnav ul.submenu li.delay4 { -webkit-transition-delay: 0.3s; -o-transition-delay: 0.3s; transition-delay: 0.3s; }

.gnav ul.submenu li.delay5 { -webkit-transition-delay: 0.4s; -o-transition-delay: 0.4s; transition-delay: 0.4s; }

.gnav ul.submenu li.delay6 { -webkit-transition-delay: 0.5s; -o-transition-delay: 0.5s; transition-delay: 0.5s; }

.gnav ul.submenu li.delay7 { -webkit-transition-delay: 0.6s; -o-transition-delay: 0.6s; transition-delay: 0.6s; }

.gnav ul.submenu li.delay8 { -webkit-transition-delay: 0.7s; -o-transition-delay: 0.7s; transition-delay: 0.7s; }

.gnav ul.submenu li.delay9 { -webkit-transition-delay: 0.8s; -o-transition-delay: 0.8s; transition-delay: 0.8s; }

.gnav ul.submenu li::after { position: absolute; top: 50%; right: 5px; margin-top: -0.5em; font-family: "icomoon"; content: "\e900"; font-size: 80%; }

.gnav ul.submenu li a, .gnav ul.submenu li:after { -webkit-transition: opacity 0.2s ease-in-out; -o-transition: opacity 0.2s ease-in-out; transition: opacity 0.2s ease-in-out; }

.gnav ul.submenu li:hover a, .gnav ul.submenu li:hover:after { opacity: 0.5; }

.gnav .active ul.submenu { opacity: 1; visibility: visible; width: 210px; }

.gnav .active ul.submenu li { opacity: 1; visibility: visible; -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); }

.unav ul { padding: 12px 0 0; text-align: right; }

.unav ul li { display: inline-block; padding-left: 22px; font-size: 0; vertical-align: middle; }

.unav ul li.unav-search { padding: 2px 30px 2px 0; border-right: 1px solid #000; }

.unav ul li.unav-fb, .unav ul li.unav-tw { font-size: 128.57143%; }

.unav ul li.unav-site1 { width: 261px; padding-left: 35px; }

.unav ul li.unav-site1 img { height: 20px; }

.unav ul li.unav-site2 { width: 112px; }

.unav ul li.unav-site2 img { height: 17px; }

/* -----------------------------------------------
　Footer
-------------------------------------------------- */
#pagetop { opacity: 0; visibility: hidden; position: fixed; right: 20px; bottom: 20px; font-size: 20px; line-height: 1.5; z-index: 99; }

#pagetop a { display: block; width: 40px; height: 40px; padding: 2px 0 0; border: 1px solid #666666; border-radius: 50px; background-color: rgba(255, 255, 255, 0.5); color: #666666 !important; text-align: center; outline: none; position: fixed; right: 20px; bottom: 20px; }

#pagetop.-noFix { position: absolute; bottom: auto; top: -20px; }

#pagetop.-noFix a { position: absolute; bottom: 0; right: 0; }

#site-footer { position: relative; clear: both; padding: 0 10px; background-color: #000; color: #fff; }

#site-footer a { color: #fff; }

#site-footer .footer-inner { max-width: 1210px; margin: 0 auto; padding: 30px 0; }

#site-footer .fsns { float: left; padding: 5px 0 0; }

#site-footer .fsns li { display: inline-block; width: 70px; font-size: 228.57143%; text-align: center; }

#site-footer .fsns li a:hover { opacity: 0.8; }

#site-footer .fnav, #site-footer .fnav2 { text-align: right; }

#site-footer .fnav li, #site-footer .fnav2 li { display: inline-block; padding: 0 0 15px 35px; font-size: 85.71429%; text-transform: uppercase; }

#site-footer .fnav li a:hover, #site-footer .fnav2 li a:hover { text-decoration: underline; }

#site-footer .pmark { float: right; width: 90px; margin: 15px 0 0 10px; }

#site-footer .copyright { margin-top: 92px; font-size: 71.42857%; text-align: right; }

.ftag { height: 0; overflow: hidden; }

#bg-blk { display: none; position: fixed; top: 0; left: 0; z-index: -1; width: 100%; height: 100%; background-color: #000; }

#bg-blk.-disp { display: block; }

/* -----------------------------------------------
　Content
-------------------------------------------------- */
#inbox { position: relative; }

.site-container { padding-top: 140px; }

#home .site-container { padding-top: 0; }

.site-container a, .site-container a * { -webkit-transition: opacity 0.3s ease-in-out, color 0.3s ease-in-out, background 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out, color 0.3s ease-in-out, background 0.3s ease-in-out; transition: opacity 0.3s ease-in-out, color 0.3s ease-in-out, background 0.3s ease-in-out; }

.site-container a img { -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; -webkit-backface-visibility: hidden; backface-visibility: hidden; }

.site-container a:hover img { opacity: 0.5; }

.site-container a .scaleup { overflow: hidden; }

.site-container a .scaleup img { -webkit-transition: opacity 0.3s ease-in-out, -webkit-transform 0.3s ease; transition: opacity 0.3s ease-in-out, -webkit-transform 0.3s ease; -o-transition: transform 0.3s ease, opacity 0.3s ease-in-out; transition: transform 0.3s ease, opacity 0.3s ease-in-out; transition: transform 0.3s ease, opacity 0.3s ease-in-out, -webkit-transform 0.3s ease; }

.site-container a:hover .scaleup img { -webkit-transform: scale(1.1); -ms-transform: scale(1.1); transform: scale(1.1); }

.bcnav { margin-top: 12px; padding: 0px; position: relative; }

.bcnav li { display: inline-block; position: relative; padding-right: 0.4em; font-size: 71.42857%; font-weight: bold; text-transform: uppercase; color: #666666; }

.bcnav li:not(:first-child) { padding-left: 1em; }

.bcnav li:not(:first-child):after { position: absolute; top: 50%; left: 0; margin-top: -0.85em; font-size: 100%; font-weight: normal; font-family: "fontAwesome"; content: "\f105"; color: #cccccc; }

.bcnav a { color: #666666; }

.bcnav a:hover { text-decoration: underline; }

/* -----------------------------------------------
　Effect
-------------------------------------------------- */
@-webkit-keyframes sprash_line { 0% { height: 0%;
    top: 0%;
    bottom: auto; }
  25% { height: 100%;
    top: 0%;
    bottom: auto; }
  26% { height: 100%;
    top: auto;
    bottom: 0%; }
  50% { height: 5%;
    top: auto;
    bottom: 0%; }
  100% { height: 5%;
    top: auto;
    bottom: 0%; } }
@keyframes sprash_line { 0% { height: 0%;
    top: 0%;
    bottom: auto; }
  25% { height: 100%;
    top: 0%;
    bottom: auto; }
  26% { height: 100%;
    top: auto;
    bottom: 0%; }
  50% { height: 5%;
    top: auto;
    bottom: 0%; }
  100% { height: 5%;
    top: auto;
    bottom: 0%; } }

@-webkit-keyframes sprash_door { 0% { width: 51%; }
  100% { width: 0%; } }

@keyframes sprash_door { 0% { width: 51%; }
  100% { width: 0%; } }

@-webkit-keyframes fadeIn { 0% { opacity: 0; }
  100% { opacity: 1; } }

@keyframes fadeIn { 0% { opacity: 0; }
  100% { opacity: 1; } }

@-webkit-keyframes slideIn1 { 0% { -webkit-transform: translateY(15px); transform: translateY(15px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@keyframes slideIn1 { 0% { -webkit-transform: translateY(15px); transform: translateY(15px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@-webkit-keyframes slideIn2 { 0% { -webkit-transform: translateY(30px); transform: translateY(30px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@keyframes slideIn2 { 0% { -webkit-transform: translateY(30px); transform: translateY(30px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@-webkit-keyframes slideIn3 { 0% { -webkit-transform: translateY(45px); transform: translateY(45px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@keyframes slideIn3 { 0% { -webkit-transform: translateY(45px); transform: translateY(45px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@-webkit-keyframes menuIn { 0% { -webkit-transform: translateY(-90px); transform: translateY(-90px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

@keyframes menuIn { 0% { -webkit-transform: translateY(-90px); transform: translateY(-90px); }
  100% { -webkit-transform: translateY(0px); transform: translateY(0px); } }

.effect-layer { width: 100%; height: 100%; top: 0; left: 0; position: fixed; z-index: 1; visibility: hidden; }

.effect-layer#effect-lower { z-index: -1; }

.effect-layer#effect-upper { z-index: 2; }

.sprash .header-a .pageTitle { -webkit-animation-name: fadeIn,slideIn1; animation-name: fadeIn,slideIn1; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-delay: 1.2s; animation-delay: 1.2s; -webkit-animation-fill-mode: both; animation-fill-mode: both; }

@media screen and (max-width: 750px) { .sprash .header-a .pageTitle { -webkit-animation-duration: 0s; animation-duration: 0s; -webkit-animation-delay: 0s; animation-delay: 0s; } }

.sprash #tubular-container, .sprash .category-mainimg { -webkit-animation-name: fadeIn,slideIn2; animation-name: fadeIn,slideIn2; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-delay: 1.2s; animation-delay: 1.2s; -webkit-animation-fill-mode: both; animation-fill-mode: both; }

@media screen and (max-width: 750px) { .sprash #tubular-container, .sprash .category-mainimg { -webkit-animation-duration: 0s; animation-duration: 0s; -webkit-animation-delay: 0s; animation-delay: 0s; } }

.sprash .works-list, .sprash .recruit-top, .sprash .section-a, .sprash .section-b, .sprash .bg-white, .sprash .top-mission { -webkit-animation-name: fadeIn,slideIn3; animation-name: fadeIn,slideIn3; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-delay: 1.5s; animation-delay: 1.5s; -webkit-animation-fill-mode: both; animation-fill-mode: both; }

@media screen and (max-width: 750px) { .sprash .works-list, .sprash .recruit-top, .sprash .section-a, .sprash .section-b, .sprash .bg-white, .sprash .top-mission { -webkit-animation-duration: 0s; animation-duration: 0s; -webkit-animation-delay: 0s; animation-delay: 0s; } }

.sprash #page-content-top .slideIn_3 { -webkit-animation-name: slideIn3; animation-name: slideIn3; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-delay: 1.5s; animation-delay: 1.5s; -webkit-animation-fill-mode: both; animation-fill-mode: both; }

@media screen and (max-width: 750px) { .sprash #page-content-top .slideIn_3 { -webkit-animation-duration: 0s; animation-duration: 0s; -webkit-animation-delay: 0s; animation-delay: 0s; } }

.sprash #page-content-top h3, .sprash #page-content-top p, .sprash .works-category { -webkit-animation-name: fadeIn; animation-name: fadeIn; -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-delay: 1.5s; animation-delay: 1.5s; -webkit-animation-fill-mode: both; animation-fill-mode: both; }

@media screen and (max-width: 750px) { .sprash #page-content-top h3, .sprash #page-content-top p, .sprash .works-category { -webkit-animation-duration: 0s; animation-duration: 0s; -webkit-animation-delay: 0s; animation-delay: 0s; } }

.sprash #page-content-top .works-list p { -webkit-animation: none; animation: none; }

/* -----------------------------------------------
　tubular ( youtube api bg )
-------------------------------------------------- */
#service #tubular-container, #works #tubular-container, #recruit #tubular-container { margin-top: 260px; height: 260px !important; }

@media screen and (max-width: 750px) { #tubular-container { display: none; } }

#tubular-container:after { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.2) url(../img/on-dot.png); z-index: 2; content: ""; }

/* -----------------------------------------------
　スキン設定（現在はメニューぐらい）
-------------------------------------------------- */
.skin-w { display: none; }

.skin-white .skin-w { display: inline; }

.skin-white .skin-b { display: none; }

.skin-black .skin-w { display: none; }

.skin-black .skin-b { display: inline; }

/* -----------------------------------------------
　skrollr
-------------------------------------------------- */
.skrollable { /* First-level skrollables are positioned relative to window */ /* Skrollables by default have a z-index of 100 in order to make it easy to position elements in front/back without changing each skrollable */ z-index: 1; }

.skrollr-mobile .skrollable { /* May cause issues on Android default browser (see #331 on GitHub). */ }

.skrollable .skrollable { /* Second-level skrollables are positioned relative their parent skrollable */ }

.skrollable .skrollable .skrollable { /* Third-level (and below) skrollables are positioned static */ }

/* -----------------------------------------------
　skrollr
-------------------------------------------------- */
.fixed-box { height: 100vh; position: relative; }

.fixed-box-sponly { display: none; }

@media screen and (max-width: 768px) { .fixed-box-sponly { display: block; } }

.fixed-box-inner { margin: 0 auto; right: 0; left: 0; top: 0; transform: translateZ(0); -webkit-transform: translateZ(0); }

.fixed-box-container { position: relative; }

.windowFit .fixed-box-container { top: 0; bottom: 0; left: 0; right: 0; margin: auto; }

.page-header-wrap { position: relative; }

.page-header-wrap .title-static { height: 120px; }

@media screen and (max-width: 750px) { .page-header-wrap .title-static { display: none; } }

#page-header.fixed-box { height: 120px; position: fixed; bottom: auto; top: 100px; width: 100%; }

#page-header.fixed-box .fixed-box-inner { position: static; height: 120px; padding-top: 40px; }

#page-header.fixed-box .fixed-box-container { background: #fff; }

@media screen and (min-width: 751px) { #page-header.fixed-box.-bottom { position: absolute; top: auto; bottom: 0; z-index: 1; }
  #page-header.fixed-box.-bottom .fixed-box-inner { padding-top: 0; } }

@media screen and (max-width: 750px) { #page-header.fixed-box { height: 60px; position: static !important; top: 55px; }
  #page-header.fixed-box .fixed-box-inner { height: 60px; } }

/* -----------------------------------------------
　listener
-------------------------------------------------- */
.listener-2-child { position: relative; }

/**************************************************
　components
***************************************************/
/* -----------------------------------------------
　Modules
-------------------------------------------------- */
.header-a, .header-b, .header-c, .header-d, .header-e, .header-f, .header-g, .header-h, .header-i, .header-j, .header-k { font-weight: bold; line-height: 1.3; text-align: center; text-transform: uppercase; }

.header-a { position: relative; margin: 0 10px; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 714.28571%; line-height: 1.2; }

.header-a .pageTitle { display: inline-block; }

.header-b { margin: 60px 0; }

.header-b .en { display: block; margin-bottom: 10px; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 214.28571%; }

.header-b .jp { font-size: 228.57143%; }

.header-c { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 571.42857%; }

.header-d { margin: 10px 0; text-align: left; }

.header-d .en { display: block; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 257.14286%; }

.header-d .jp { font-size: 142.85714%; }

.ask-txt { margin-top: -5px; font-size: 114.28571%; }

.header-e { font-size: 228.57143%; }

.header-f { font-family: "Open Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", sans-serif; font-size: 171.42857%; letter-spacing: 1px; }

.header-g { font-size: 142.85714%; }

.header-h { font-size: 114.28571%; line-height: 1.6; text-align: left; }

.header-i { margin: 0 10px 60px; }

.header-i .en { display: block; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 285.71429%; }

.header-i .enm { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 500%; }

.header-i .jp { font-size: 200%; }

.header-i .jpm { font-size: 500%; }

.blog .header-i { margin-bottom: 30px; }

.news .header-i { margin-bottom: 25px; }

.header-j { font-family: "Open Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", sans-serif; font-size: 228.57143%; }

.header-k { margin: 0 10px 80px; }

.header-k .en { display: block; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 285.71429%; }

.header-k .jpm { font-size: 357.14286%; }

.header-k.title-2 { margin-bottom: 30px; }

.pnav ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; margin: 0 auto; text-align: center; }

.pnav ul li { display: table; width: 60px; height: 60px; margin: 5px; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 114.28571%; }

.pnav ul li a { display: table-cell; background-color: #000; color: #fff; vertical-align: middle; }

.pnav ul li a:hover { background: #4d4d4d; }

.pnav ul .active a { background: #fff; color: #000; font-weight: bold; }

.pnav ul .active a:hover { background: #cccccc; }

.table-a { width: 100%; border: 1px solid #9d887e; }

.table-a th, .table-a td { padding: 16px; border-bottom: 1px solid #9d887e; }

.table-a th { background-color: #F2F2F2; }

/* -----------------------------------------------
　Swiper
-------------------------------------------------- */
.swiper-pagination-bullet-active { background: #000; }

/* -----------------------------------------------
　アニメーション
-------------------------------------------------- */
.t-opacity-on { visibility: visible !important; opacity: 1 !important; }

/**************************************************
　unique
***************************************************/
.telink { color: #000; text-decoration: underline; opacity: 1 !important; }

.skrollr-desktop .telink { text-decoration: none; cursor: default; }

.page-content-top, .slideIn_3 { padding: 30px 30px 60px; background: #fff; }

.service .slideIn_3 { padding-bottom: 0; padding-left: 0; padding-right: 0; }

#page-content-top { padding: 0; background: transparent; }

.section-a { padding: 80px 30px; background-color: #fff; }

.section-b { padding: 80px 30px; background-color: #F2F2F2; }

.bg-white { padding-top: 1px; background-color: #fff; }

.contentW-a { max-width: 700px; margin-right: auto; margin-left: auto; }

.contentW-b { max-width: 1000px; margin-right: auto; margin-left: auto; }

.contentW-c { max-width: 800px; margin-right: auto; margin-left: auto; }

.contentW-d { max-width: 900px; margin-right: auto; margin-left: auto; }

.service .header-a, .works .header-a, .recruit .header-a { margin-right: 0; margin-left: 0; background-color: #fff; }

.btn-more { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: bold; text-align: center; }

.btn-more a { display: inline-block; padding: 6px 18px; background-color: #000; color: #fff; text-align: center; text-transform: uppercase; }

.btn-more a:hover { opacity: 0.5; }

.btn-more.ib-btn_more { font-weight: normal; }

.btn-more.ib-btn_more a { padding: 23px 75px; }

.btn-more2, .btn-more3, .btn-more4 { max-width: 280px; margin: 0 auto; }

.service .btn-more2, .service .btn-more3, .service .btn-more4 { padding: 5px 0 20px; }

.service .btn-more2.last, .service .btn-more3.last, .service .btn-more4.last { padding-bottom: 0; }

.btn-more2 a, .btn-more3 a, .btn-more4 a { display: block; position: relative; padding: 20px; background-color: #000; color: #fff; text-align: center; }

.btn-more2 a:after, .btn-more3 a:after, .btn-more4 a:after { position: absolute; top: 50%; right: 14px; margin-top: -0.9em; font-size: 106.25%; font-weight: normal !important; font-family: "icomoon"; content: "\e900"; }

.btn-more2 a:hover, .btn-more3 a:hover, .btn-more4 a:hover { opacity: 0.5; }

.btn-more3 { max-width: 240px; }

.btn-more3 a { padding: 15px 20px; }

.btn-more4 { max-width: 600px; font-size: 114.28571%; }

.btn-more4 a { padding: 48px 20px; }

.btn-more4 a:after { content: ""; }

.btn-ask { margin: 25px -15px 0; }

.btn-ask li { float: left; width: 50%; padding: 15px; font-size: 114.28571%; }

.btn-ask li a { display: block; position: relative; padding: 48px 20px; background-color: #000; color: #fff; text-align: center; }

.btn-ask li a:after { position: absolute; top: 50%; right: 18px; margin-top: -0.8em; font-size: 100%; font-family: "icomoon"; content: "\e900"; }

.btn-ask li a:hover { background-color: rgba(0, 0, 0, 0.5); }

.btn-ask li .download { border: 1px solid #808080; background-color: #fff; color: #808080; }

.btn-ask li .download:hover { background-color: #e6e6e6; }

.btn-ask-s { max-width: 848px; margin: 50px auto 0; }

.btn-ask-s li { padding: 10px; }

.top-mission { padding: 100px 20px; background-color: #fff; text-align: center; }

@media screen and (max-width: 750px) { .top-mission { padding: 30px 20px; } }

.top-mission .header { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 357.14286%; font-weight: bold; text-transform: uppercase; line-height: 1; margin-bottom: 20px; }

.top-mission .ask-sub2 { display: inline-block; text-align: left; }

.top-mission .btn-ask { max-width: 600px; margin: 25px auto -10px; }

.top-mission .btn-ask li { float: none; width: auto; padding: 10px 0 10px; }

.box-works-s { margin: 0 0 60px; }

.box-works-s .btn-works { max-width: 848px; margin: 30px auto 40px; display: block; }

.box-works-s .btn-works li { float: left; width: 33.3333%; padding: 0 3px; overflow: hidden; }

.box-works-list { max-width: 1185px; margin: 40px -15px 0; }

.box-works-list li { float: left; width: 33.3333%; padding: 0 15px 40px; }

.box-works-list li .img { margin-bottom: 12px; }

.box-works-list li .title { line-height: 1.5; -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; }

.box-works-list li a:hover .title { opacity: 0.5; }

.box-special { margin-bottom: 20px; }

.box-special ul { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 30px -5px 48px; }

.box-special li { width: 33.3333%; padding: 0 5px; }

.box-special li a { display: block; height: 100%; background-color: #fff; padding: 25px 25px 18px; }

.box-special li a:hover .title, .box-special li a:hover .title_sp, .box-special li a:hover .date { opacity: 0.5; }

.box-special li .title { font-size: 114.28571%; font-weight: bold; padding-top: 18px; }

.box-special li .title_sp { display: none; }

.box-group { margin: 30px 0 0; }

.box-group .img { float: left; width: 50.2857%; }

.box-group .text { float: right; width: 44%; }

.box-group .text .logo { width: 228px; }

.box-group .text .name { margin: 8px 0 15px; font-size: 114.28571%; font-weight: bold; }

.category-mainimg { position: relative; }

.category-mainimg#category_movie { visibility: hidden; height: 260px; }

.service .category-mainimg#category_movie { background: url(../../service/images/img-main_tb.jpg) no-repeat center; background-size: cover; }

.works .category-mainimg#category_movie { background: url(../../works/images/img-main_tb.jpg) no-repeat center; background-size: cover; }

.recruit .category-mainimg#category_movie { background: url(../../recruit/images/img-main_tb.jpg) no-repeat center; background-size: cover; }

.category-mainimg:after { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.2) url(../img/on-dot.png); z-index: 2; content: ""; }

.category-mainimg img { width: 100%; }

.category-mainimg_sp { display: none; }

.category-head { padding: 0 10px 60px; text-align: center; background: #fff; }

.category-head .header { margin: 0 0 10px; font-size: 200%; font-weight: bold; line-height: 1.4; }

.category-head .text { font-size: 114.28571%; }

.mgt { margin-top: 2em; }

.mgb { margin-bottom: 2em; }

.pdt0 { padding-top: 0 !important; }

.pdt3 { padding-top: 30px; }

.pdt3_pc { padding-top: 30px; background-color: #fff; }

.pdt6 { padding-top: 60px; }

.pdb80 { padding-bottom: 80px !important; }

.mt-12 { margin-top: -12px; }

.m_box-sp { padding-left: 30px; padding-right: 30px; }

a.link_line .title, a.link_line_2 { display: inline-block; line-height: 1; /*border-bottom:1px solid transparent;*/ }

a.link_line_2 { line-height: 1.1; }

a.link_line_2:hover { /* border-bottom-color:#fff; */ text-decoration: none !important; }

a.link_white { color: #fff; }

a.link_white:hover .title { color: #808080; /*border-bottom-color:#fff;*/ }

a.link_opacity_all:hover { opacity: 0.5; }

a.hov_o5 .intro-sub, a.hov_o5 .text, a.hov_o5 h2 { -webkit-transition: opacity 0.3s; -o-transition: opacity 0.3s; transition: opacity 0.3s; }

a.hov_o5:hover .intro-sub, a.hov_o5:hover .text, a.hov_o5:hover h2 { opacity: 0.5; }

a.link_opacity:hover .title { opacity: 0.5; }

.text_16 { font-size: 114.28571%; }

.disp-n { display: none !important; }

.service .top-mission { padding: 10px 20px 0; }

.works .top-mission { padding: 0 20px 80px; }

/* -----------------------------------------------
　SERVICE
-------------------------------------------------- */
.service-mainimg { margin: 0 0 50px; }

.service-img1 { margin: 30px 0 -20px; }

.service-img1 li { float: left; width: 33.3333%; }

.service-img1 li img { width: 100%; }

.service-img4 { max-width: 620px; margin: 35px auto 25px; }

.service-img4 ul { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 -10px; }

.service-img4 li { width: 50%; padding: 0 10px 12px; }

.service-img4 li .img { margin: 0 0 8px; }

.service-approach { text-align: center; }

.service-approach .header-f + p { margin-top: 10px; }

.service-approach .header { margin: 90px 0 20px; font-weight: bold; }

.service-approach .header .en { display: block; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 314.28571%; text-transform: uppercase; font-size: 500%; }

.service-approach .header .jp { font-size: 171.42857%; }

.service-approach .header.first { margin-top: 0; }

.service-pt0 { padding-top: 0 !important; }

.service-title .enm { margin-top: -12px; display: block; }

.service-title .jp { line-height: 1.35; }

.servise-text1 { font-size: 114.28571%; line-height: 1.875; }

.service-img5 { margin: 50px 0 60px; }

.service-detail { padding: 0 30px 80px; }

.service-detail .header-g { margin: 80px 0 30px; text-align: left; }

.service-menu { margin: 30px 0 0; }

.service-menu .img { float: left; width: 26.5714%; }

.service-menu .text { float: right; width: 70.5714%; }

.service-menu .text .header { margin: 0 0 8px; font-size: 128.57143%; font-weight: bold; }

.service-media ul { margin: 0 0 40px; border-top: 1px solid #808080; border-left: 1px solid #808080; }

.service-media li { float: left; width: 25%; padding: 5.5% 1.5%; border-right: 1px solid #808080; border-bottom: 1px solid #808080; }

.service-other { margin: 80px 0 90px; }

.service-other .box { width: 49%; padding: 0 5px; text-align: center; }

.service-other .box .header { margin: 0 0 20px; font-weight: bold; }

.service-other .box .header .en { display: block; font-size: 271.42857%; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; text-transform: uppercase; }

.service-other .box .header .jp { font-size: 128.57143%; }

.service-other .box .img { max-width: 388px; margin: 20px auto 30px; }

.service-other .box .img li { float: left; width: 50%; padding: 3px; }

.service-media-list { max-width: 920px; margin: 0 auto; overflow: hidden; }

.service-media-list ul { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: -30px -35px 0; }

.service-media-list li { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; width: 33.3333%; padding: 45px 35px; }

.service-media-list li a { display: block; }

.service-media-list li .img { padding: 22% 16%; border: 1px solid #B3B3B3; text-align: center; }

.service-media-list li .name { margin: 20px 0 6px; font-size: 142.85714%; font-weight: bold; }

.service-media-list li .direction { width: 88px; font-size: 9px; }

.service-media-list li .text { margin: 10px 0; }

.service-media-list li .more { margin-bottom: 18px; }

.service-media-list li .more a { color: #808080; position: relative; display: inline-block; padding-left: 1.2em; }

.service-media-list li .more a:before { position: absolute; top: 50%; left: 0; margin-top: -0.9em; font-size: 107.14286%; font-family: "icomoon"; content: "\e900"; }

.service-media-list li .more a:hover { opacity: 0.5; }

.service-media-list li .btn-download { margin-top: auto; }

.service-media-list li .btn-download a { position: relative; padding: 15px 20px; background-color: #000; color: #fff; text-align: center; }

.service-media-list li .btn-download a:after { position: absolute; top: 50%; right: 14px; margin-top: -0.9em; font-size: 92.85714%; font-family: "icomoon"; content: "\e900"; }

.service-media-list li .btn-download a:hover { background-color: gray; opacity: 1; }

.media-news { padding: 20px 30px; }

.media-news a { display: block; }

.media-news a:hover { opacity: 0.5; }

.media-news .box { position: relative; max-width: 920px; margin: 0 auto; padding: 45px 45px 35px 48px; background-color: #f2f2f2; }

.media-news .header { color: #fff; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 214.28571%; font-weight: bold; text-transform: uppercase; line-height: 1; }

.media-news .btn-more-media { position: absolute; top: 40px; right: 37px; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: bold; text-align: center; font-size: 85.71429%; }

.media-news .btn-more-media a { display: inline-block; width: 72px; height: 33px; position: relative; text-align: center; text-transform: uppercase; padding: 6px 18px; }

.media-news .newly { margin-top: 16px; }

.media-news .newly .date { float: left; width: 6.5em; margin-top: 0.2em; }

.media-news .newly .lead { display: block; padding: 0 0 10px 0; letter-spacing: 2px; font-size: 114.28571%; overflow: hidden; -o-text-overflow: ellipsis; text-overflow: ellipsis; white-space: nowrap; }

.modal-open { position: fixed !important; width: 100%; height: 100%; }

#modal { display: none; position: fixed; z-index: 9999; top: 0; left: 0; width: 100%; height: 100%; min-height: 100%; }

#modal.active { display: block; }

#modal .title, #modal .swiper-detail-container, #modal .bg-fade, #modal .changeModal_next .change_next, #modal .changeModal_prev .change_prev { -webkit-transition: opacity 0.2s ease-in-out; -o-transition: opacity 0.2s ease-in-out; transition: opacity 0.2s ease-in-out; }

#modal .bg-fade { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; background: #666 no-repeat center center; background-size: cover; }

#modal .bg-fade.active { opacity: 1; }

#modal.change .title, #modal.change .swiper-detail-container, #modal.change .changeModal_next .change_next, #modal.change .changeModal_prev .change_prev { opacity: 0; }

#modal-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; min-height: 100%; background: #000000; opacity: 0.8; }

.media-detail { max-width: 950px; max-height: 600px; position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; z-index: 10; background-color: #fff; display: none; }

#modal .media-detail { display: block !important; }

.media-detail .btn-close { position: absolute; top: -17px; right: -56px; cursor: pointer; width: 35px; height: 35px; }

.media-detail .btn-close .inner { -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); margin-top: 17px; }

.media-detail .btn-close .inner:before, .media-detail .btn-close .inner:after { content: ""; display: block; width: 35px; height: 1px; background-color: #fff; }

.media-detail .btn-close .inner:before { -webkit-transform: rotate(90deg); -ms-transform: rotate(90deg); transform: rotate(90deg); }

.media-detail .btn-download a { display: block; background-color: #000; color: #fff; width: 240px; height: 60px; line-height: 60px; text-align: center; }

.media-detail .btn-download a:hover { opacity: 0.5; }

.media-detail .head { background-color: #fff; height: 100px; padding: 20px; position: relative; }

.media-detail .head .title { position: absolute; left: 40px; bottom: 22px; }

.media-detail .head .name { font-size: 114.28571%; line-height: 1; font-weight: bold; }

.media-detail .head .btn-download { float: right; }

.media-detail .main { background: #333 no-repeat center center; background-size: cover; height: 500px; position: relative; padding: 20px; }

.media-detail .main .swiper-media-container { height: 100%; }

.media-detail .main .swiper-media-container .swiper-slide { height: auto; }

.media-detail .main .swiper-media-container .swiper-media-scrollbar { display: none; }

.media-detail .main .box { max-width: 640px; margin: 0 auto; padding: 50px 0 70px; color: #fff; }

.media-detail .main .box .swiper-container { height: 274px; }

.media-detail .main .box .swiper-slide { height: auto; }

.media-detail .main .box .swiper-scrollbar { background: #333; width: 8px; opacity: 1 !important; }

.media-detail .main .box .swiper-scrollbar-drag { background: #b2b2b2; width: 8px; }

.media-detail .main .detail { padding-right: 40px; }

.media-detail .main .detail dt { margin: 20px 0 8px; padding-bottom: 6px; border-bottom: 1px solid rgba(255, 255, 255, 0.4); font-size: 128.57143%; font-weight: bold; }

.media-detail .main .detail dt:first-child { margin-top: 0; }

.media-detail .main .detail dd { line-height: 1.7; }

.media-detail .main .detail li { display: inline-block; padding-right: 8px; }

.media-detail .main .btn-download { display: none; }

.media-detail .main .media-nav { max-width: 750px; margin: 0 auto; }

.media-detail .main .media-nav li { width: 33.3333%; padding: 0 5px; }

.media-detail .main .media-nav a { display: block; position: relative; padding: 18px; background-color: #fff; color: #000; text-align: center; }

.media-detail .main .media-nav a:hover { opacity: 0.5; }

.media-detail .main .media-nav a:after { position: absolute; top: 50%; margin-top: -0.75em; font-family: "fontAwesome"; content: ""; font-size: 128.57143%; }

.media-detail .main .media-nav .top { margin: 0 auto; }

.media-detail .main .media-nav .prev { float: left; }

.media-detail .main .media-nav .prev a:after { left: 14px; content: "\f104"; }

.media-detail .main .media-nav .next { float: right; }

.media-detail .main .media-nav .next a:after { right: 14px; content: "\f105"; }

.media-detail#gizmodo .main, #modal .media-detail .bg-fade.gizmodo { background-image: url(../../service/images/bg-media-gizmodo.jpg); }

.media-detail#gizmodo .name { padding-top: 10px; }

.media-detail#lifehacker .main, #modal .media-detail .bg-fade.lifehacker { background-image: url(../../service/images/bg-media-lifehacker.jpg); }

.media-detail#lifehacker .name { padding-top: 3px; }

.media-detail#fuze .main, #modal .media-detail .bg-fade.fuze { background-image: url(../../service/images/bg-media-fuze.jpg); }

.media-detail#fuze .name { padding-top: 7px; }

.media-detail#digiday .main, #modal .media-detail .bg-fade.digiday { background-image: url(../../service/images/bg-media-digiday.jpg); }

.media-detail#digiday .name { padding-top: 9px; }

.media-detail#gene .main, #modal .media-detail .bg-fade.gene { background-image: url(../../service/images/bg-media-gene.jpg); }

.media-detail#gene .name { padding-top: 7px; }

.media-detail#genetv .main, #modal .media-detail .bg-fade.genetv { background-image: url(../../service/images/bg-media-genetv.jpg); }

.media-detail#genetv .name { padding-top: 2px; }

.media-detail#cafeglobe .main, #modal .media-detail .bg-fade.cafeglobe { background-image: url(../../service/images/bg-media-cafeglobe.jpg); }

.media-detail#cafeglobe .name { padding-top: 9px; }

.media-detail#mylohas .main, #modal .media-detail .bg-fade.mylohas { background-image: url(../../service/images/bg-media-mylohas.jpg); }

.media-detail#mylohas .name { padding-top: 14px; }

.media-detail#glitty .main, #modal .media-detail .bg-fade.glitty { background-image: url(../../service/images/bg-media-glitty.jpg); }

.media-detail#glitty .name { padding-top: 10px; }

.media-detail#roomie .main, #modal .media-detail .bg-fade.roomie { background-image: url(../../service/images/bg-media-roomie.jpg); }

.media-detail#roomie .name { padding-top: 9px; }

.media-detail#bi .main, #modal .media-detail .bg-fade.bi { background-image: url(../../service/images/bg-media-bi.jpg); }

.media-detail#bi .name { padding-top: 10px; }

.service-types { position: relative; max-width: 890px; margin: 0 auto; padding: 0 20px 50px; color: #fff; }

.service-types ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; height: 311px; background: url(../../images/home/bg-service-types.png) no-repeat center; background-size: 100%; }

.service-types ul li { width: 33.3333%; text-align: center; }

.service-types .title { position: relative; margin: 0 0 20px; font-family: "Ubuntu Condensed", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 271.42857%; text-transform: uppercase; }

.service-types .title:after { display: inline-block; position: absolute; bottom: -8px; left: 50%; width: 20px; height: 2px; margin-left: -10px; font-size: 0; content: ""; }

.service-types .innovation { padding-left: 2.4%; }

.service-types .innovation .title:after { background-color: #955AD1; }

.service-types .branding { padding: 0 2.4%; }

.service-types .branding .title:after { background-color: #918000; }

.service-types .creative { padding-right: 2.4%; }

.service-types .creative .title:after { background-color: #009C7C; }

.service-types2 { position: relative; max-width: 890px; margin: 0 auto; padding: 10px 36px 80px; }

.service-types2 ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }

.service-types2 ul li { width: 33.3333%; text-align: center; }

.service-types2 .title { position: relative; margin: 0 0 14px; font-family: "Work Sans", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 257.14286%; text-transform: uppercase; letter-spacing: 1px; }

.service-types2 .title:after { display: inline-block; position: absolute; bottom: -1px; left: 0; width: 100%; height: 1px; font-size: 0; content: ""; }

.service-types2 a:hover .title { color: gray; }

.service-types2 .text { font-size: 114.28571%; }

.service-types2 .innovation { padding-right: 46px; }

.service-types2 .innovation .title:after { background-color: #955AD1; }

.service-types2 .branding { padding: 0 23px; }

.service-types2 .branding .title:after { background-color: #918000; }

.service-types2 .creative { padding-left: 46px; }

.service-types2 .creative .title:after { background-color: #009C7C; }

/* -----------------------------------------------
　WORKS
-------------------------------------------------- */
.works-category { max-width: 1000px; margin: -34px auto 45px; text-align: center; }

.works-category ul { padding: 0 20px; }

.works-category li { display: inline-block; vertical-align: bottom; padding: 0 5px 10px; }

.works-category li.ja a { font-weight: bold; }

.works-category li.en a { font-family: "Open Sans", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }

.works-category li a { display: block; position: relative; min-width: 116px; padding: 0 15px; border: 1px solid #b2b2b2; height: 34px; line-height: 34px; font-size: 85.71429%; }

.works-category li a:hover { opacity: 0.7; }

.works-category li.selected a { color: #fff; background-color: #b2b2b2; }

.works-category li.selected a:hover { opacity: 1; }

.works-list { max-width: 1185px; margin: 0 auto; }

.works-list .listBox { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 -10px; }

.works-list .listBox li { width: 33.3333%; padding: 0 10px 40px; -webkit-transition: opacity 1s ease-in-out, -webkit-transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); transition: opacity 1s ease-in-out, -webkit-transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); -o-transition: opacity 1s ease-in-out, transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); transition: opacity 1s ease-in-out, transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); transition: opacity 1s ease-in-out, transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99), -webkit-transform 1s cubic-bezier(0.17, 0.53, 0.43, 0.99); }

.works-list .listBox li .img { margin-bottom: 12px; }

.works-list .listBox li .title { line-height: 1.5; -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; }

.works-list .listBox li a:hover .title { opacity: 0.5; }

.works-list .pnav { margin-bottom: 30px; }

.works-client { max-width: 1165px; margin: 0 auto; }

.works-client ul { margin: 30px -10px -10px; }

.works-client li { float: left; width: 20%; padding: 10px; }

.works-detail .header-a { margin-top: -10px; font-size: 285.71429%; }

.works-detail .header-e { font-size: 357.14286%; padding: 4px 0 8px; text-transform: none; }

.works-detail .category-head { padding: 0 0 30px; }

.works-detail .category-head .client { margin: 0 0 2px; font-size: 128.57143%; font-weight: bold; letter-spacing: 1px; }

.works-detail .category-head .website { word-wrap: break-word; overflow-wrap: break-word; letter-spacing: 1px; }

.works-detail .category-head .website a:hover { opacity: 0.5; }

.works-detail .works-tag { margin: 0 0 65px; text-align: center; }

.works-detail .works-tag li { display: inline-block; padding: 0 1px; font-size: 85.71429%; letter-spacing: 1px; }

.works-detail .works-tag li a { display: block; min-width: 116px; padding: 6px 15px; border: 1px solid #B2B2B2; font-family: "Open Sans", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; text-transform: uppercase; font-weight: bold; }

.works-detail .works-exp { margin-top: -10px; padding: 0; text-align: center; font-size: 114.28571%; }

.works-detail .works-exp p { line-height: 1.875; }

.works-detail .project-summary { padding: 35px 0 0; font-size: 114.28571%; }

.works-detail .project-summary .title { float: left; width: 8.5em; font-weight: bold; }

.works-detail .project-summary .text { float: right; width: 100%; margin-left: -8.5em; margin-bottom: 30px; }

.works-detail .project-summary .text p { line-height: 1.875; margin-left: 8.5em; }

.works-detail .interview { margin: 35px 0 0; padding-bottom: 20px; }

.works-detail .interview .title { margin: 30px 0 10px; font-size: 171.42857%; font-weight: bold; letter-spacing: -1px; }

.works-detail .interview .client { margin: 10px 0 15px; font-size: 114.28571%; font-weight: bold; }

.works-detail .interview .text { margin: 15px 0 30px; }

.works-detail .interview .img { position: relative; padding-top: 40.4285%; overflow: hidden; }

.works-detail .interview .img img { position: absolute; top: 50%; width: 100%; height: auto; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); }

.works-detail .other-works { padding: 10px 0 60px; }

.works-display { position: relative; max-height: 570px; background: repeat-x center 24%; }

.works-display .sites { position: relative; width: 100%; max-width: 756px; margin: 0 auto; }

.works-display .pc { width: 80.15873%; max-width: 606px; max-height: 570px; margin: 0 0 0 7.2751%; background: url(../../works/images/img-mac.png) no-repeat 0 0; background-size: 100%; }

.works-display .pc img { padding: 4.73684% 4.29043% 41.92982%; }

.works-display .sp { position: absolute; top: 27.19298%; right: 0; width: 27.24868%; max-width: 206px; max-height: 362px; background: url(../../works/images/img-iphone.png) no-repeat 0 0; background-size: 100%; }

.works-display .sp img { padding: 24.27184% 16.50485% 34.95146% 14.56311%; }

.works-display .sites_bg { position: absolute; top: 7%; width: 100%; height: 400px; background: no-repeat center; background-size: cover; }

.works-display .bg-only { position: static; margin-bottom: 70px; }

.works-display .pc-spNone { margin: 0 auto; }

.works-display .sp-pcNone { position: static; margin: 0 auto; width: 37.30159%; max-width: 282px; max-height: 516px; }

.works-display .sp-pcNone img { width: 100%; padding: 24.46809% 16.66667% 49.64539% 14.53901%; }

.works-img1 { margin: 70px 0 0; }

.works-img1 ul { text-align: center; }

.works-img1 li { width: 33.3333%; display: inline-block; }

.works-img1 li img { width: 100%; }

.works-img1 .imgNum_2 li { width: auto; max-width: 50%; }

.works-img1 .imgNum_1 li { width: auto; max-width: 100%; }

.works-kyoto { margin-top: -50px; padding: 45px 30px; background-color: #F2F2F2; }

.works-kyoto .btn { max-width: 330px; margin: 0 auto; }

.works-kyoto .btn a { display: block; position: relative; padding: 20px; background-color: #000; color: #fff; text-align: center; }

.works-kyoto .btn a:after { position: absolute; top: 50%; right: 14px; margin-top: -0.9em; font-size: 106.25%; font-weight: normal !important; font-family: "icomoon"; content: "\e900"; }

.works-kyoto .btn a:hover { opacity: 0.5; }

/* -----------------------------------------------
　CHANNEL IB & NEWS
-------------------------------------------------- */
.blog-top li { float: left; position: relative; width: 25%; overflow: hidden; }

.blog-top li img { width: 100%; }

.blog-top li .shadow { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: -moz-linear-gradient(47% 0% -90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 33%, rgba(0, 0, 0, 0.5) 81%, rgba(0, 0, 0, 0.5) 100%); background-image: -webkit-gradient(linear, 47% 0%, 47% 100%, color-stop(0, rgba(255, 255, 255, 0)), color-stop(0.33, rgba(255, 255, 255, 0)), color-stop(0.81, rgba(0, 0, 0, 0.5)), color-stop(1, rgba(0, 0, 0, 0.5))); background-image: -webkit-linear-gradient(-90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 33%, rgba(0, 0, 0, 0.5) 81%, rgba(0, 0, 0, 0.5) 100%); background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0)), color-stop(33%, rgba(255, 255, 255, 0)), color-stop(81%, rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.5))); background-image: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 33%, rgba(0, 0, 0, 0.5) 81%, rgba(0, 0, 0, 0.5) 100%); background-image: -o-linear-gradient(top, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 33%, rgba(0, 0, 0, 0.5) 81%, rgba(0, 0, 0, 0.5) 100%); background-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 33%, rgba(0, 0, 0, 0.5) 81%, rgba(0, 0, 0, 0.5) 100%); }

.blog-top li .text { position: absolute; bottom: 0; left: 0; padding: 5% 6%; }

.blog-top li .text p { line-height: 1.4; }

.blog-top li .text .date { margin: 0 0 4px; font-size: 85.71429%; }

.blog-top li a { color: #fff; }

.section-news { padding-top: 60px; }

.wrap-news { max-width: 1140px; margin: 0 auto; }

.wrap-news .news-content { float: left; width: 71.05263%; }

.news .wrap-news .news-content { width: 70.17544%; }

.wrap-news .news-side, .wrap-news .news-bottom { float: right; width: 26.31579%; }

.news-content section, .news-article section { position: relative; padding: 0 10px 10px 0; }

.news-content section .box, .news-article section .box { height: 100%; padding: 38px 40px; /*padding: 4.8% 5%;*/ background-color: #fff; position: relative; }

.news-content section .date, .news-article section .date { display: inline-block; color: #808080; font-size: 85.71429%; }

.news-content section .date:after, .news-article section .date:after { padding: 0 0.5em 0 1em; content: "|"; }

.news-content section .category, .news-article section .category { display: inline-block; }

.news-content section .category li, .news-article section .category li { display: inline; padding: 0 0 0 1em !important; font-size: 85.71429%; }

.news-content section .category li:first-child, .news-article section .category li:first-child { padding-left: 0 !important; }

.news-content section .category a, .news-article section .category a { color: #808080; text-decoration: underline; }

.news-content section .category a:hover, .news-article section .category a:hover { opacity: 0.5; }

.news-content section .title, .news-article section .title { margin: 8px 0 0; font-size: 157.14286%; font-weight: bold; line-height: 1.4; }

.news-content section .title a:hover, .news-article section .title a:hover { opacity: 0.5; }

.news-content section .mainimg, .news-article section .mainimg { margin: 25px 0 0; }

.news-content section .text, .news-article section .text { margin: 25px 0 0; }

.news-content section.new:before, .news-article section.new:before { position: absolute; top: -42px; left: -42px; width: 0; height: 0; border: 42px solid transparent; border-right: 42px solid #000; content: ""; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); z-index: 1; }

.news-content section.new:after, .news-article section.new:after { position: absolute; top: 10px; left: 6px; color: #fff; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 85.71429%; text-transform: uppercase; letter-spacing: 1px; content: "new"; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); z-index: 2; }

.news-content section .link-cover, .news-article section .link-cover { display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; text-indent: -9999px; -webkit-transition: opacity 0.3s; -o-transition: opacity 0.3s; transition: opacity 0.3s; background-color: #fff; opacity: 0; }

.news-content section .link-cover:hover, .news-article section .link-cover:hover { opacity: 0.5; }

.news-content .box-type2, .news-content .box-type2-list, .news-article .box-type2, .news-article .box-type2-list { display: -webkit-box; display: -ms-flexbox; display: flex; }

.news-content .box-type2 section, .news-content .box-type2-list section, .news-article .box-type2 section, .news-article .box-type2-list section { width: 50%; }

.news-content .box-type2 section .box, .news-content .box-type2-list section .box, .news-article .box-type2 section .box, .news-article .box-type2-list section .box { padding: 28px 30px 30px; /*padding: 7.4% 7.8% 7.8%;*/ }

.news-content .box-type2 section .title, .news-content .box-type2-list section .title, .news-article .box-type2 section .title, .news-article .box-type2-list section .title { font-size: 114.28571%; }

.news-content .box-type2 section .mainimg, .news-content .box-type2-list section .mainimg, .news-article .box-type2 section .mainimg, .news-article .box-type2-list section .mainimg { margin: 18px 0 0; }

.news-content .box-type2 section.new:before, .news-content .box-type2-list section.new:before, .news-article .box-type2 section.new:before, .news-article .box-type2-list section.new:before { top: -35px; left: -35px; border-width: 35px; }

.news-content .box-type2 section.new:after, .news-content .box-type2-list section.new:after, .news-article .box-type2 section.new:after, .news-article .box-type2-list section.new:after { top: 8px; left: 5px; font-size: 71.42857%; }

.news-content .box-type2-list, .news-article .box-type2-list { -ms-flex-wrap: wrap; flex-wrap: wrap; }

.news-content .box-type2-list section, .news-article .box-type2-list section { width: 50%; }

.news-content .pnav, .news-article .pnav { margin: 55px 0 0; }

.news-side .bnr, .news-bottom .bnr { margin: 0 0 60px; }

.news-side .archive dt, .news-bottom .archive dt { position: relative; margin-top: -1px; padding: 14px 0; border-top: 1px solid #B2B2B2; border-bottom: 1px solid #B2B2B2; font-weight: bold; cursor: pointer; -webkit-transition: color 0.3s ease-in-out; -o-transition: color 0.3s ease-in-out; transition: color 0.3s ease-in-out; }

.news-side .archive dt:hover, .news-bottom .archive dt:hover { color: #4d4d4d; }

.news-side .archive dt:after, .news-bottom .archive dt:after { position: absolute; top: 50%; right: 0; margin-top: -0.8em; font-weight: normal; content: "＋"; }

.news-side .archive dt.open:after, .news-bottom .archive dt.open:after { content: "ー"; }

.news-side .archive dd, .news-bottom .archive dd { margin: 0 0 -1px; padding: 15px 0; border-bottom: 1px solid #B2B2B2; display: none; }

.news-side .archive dd li, .news-bottom .archive dd li { margin: 0 0 8px; line-height: 1.7; }

.news-side .archive dd li a, .news-bottom .archive dd li a { text-decoration: underline; }

.news-side .archive dd li a:hover, .news-bottom .archive dd li a:hover { opacity: 0.5; }

.news-side .follow, .news-bottom .follow { margin: 25px 0 0; }

.news-side .follow .header, .news-bottom .follow .header { font-size: 171.42857%; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: bold; text-transform: uppercase; }

.news-side .follow .sns, .news-bottom .follow .sns { margin: 15px -5px 0; }

.news-side .follow .sns a, .news-bottom .follow .sns a { display: block; padding: 6px 0; color: #fff; text-align: center; }

.news-side .follow .sns a:hover, .news-bottom .follow .sns a:hover { opacity: 0.8; }

.news-side .follow .sns li, .news-bottom .follow .sns li { float: left; width: 50%; padding: 0 5px; font-size: 214.28571%; }

.news-side .follow .sns li.fb a, .news-bottom .follow .sns li.fb a { background-color: #305097; }

.news-side .follow .sns li.tw a, .news-bottom .follow .sns li.tw a { background-color: #00ACED; }

.header-archive { margin: -10px 0 55px; font-size: 200%; font-weight: bold; text-align: center; }

.news-article { /*padding: 50px 100px;*/ padding: 5% 10% 7.5%; background-color: #fff; }

.news-article section { padding: 0 !important; }

.news-article section .title { margin: 15px 0 !important; font-size: 214.28571%; }

.news-article section .date, .news-article section .category li { font-size: 100%; }

.news-article section .interview-box { margin: -4px 0 30px; }

.news-article section .interview-box p { font-size: 114.28571%; font-weight: bold; line-height: 1.625; }

.news-article .entry-share li { float: left; padding-right: 10px; text-indent: -999px; overflow: hidden; }

.news-article .entry-share li a { display: block; width: 28px; height: 28px; color: #fff; border-radius: 2px; background: no-repeat center; background-size: 16px; }

.news-article .entry-share li.facebook a { background-color: #305097; background-image: url(../img/icon-sns-facebook.png); }

.news-article .entry-share li.twitter a { background-color: #00ACED; background-image: url(../img/icon-sns-twitter.png); }

.news-article .entry-share li.hatena a { background-color: #00A4DE; background-image: url(../img/icon-sns-hatena.png); }

.news-article .entry-content, .news-article #special-about .body, #special-about .news-article .body { margin: 40px 0; font-size: 114.28571%; }

.news-article-nav { margin: 50px auto 40px; }

.news-article-nav a { display: block; position: relative; padding: 25px 18px; background-color: #000; color: #fff; text-align: center; text-transform: uppercase; }

.news-article-nav a:after { position: absolute; top: 50%; margin-top: -0.8em; font-family: "icomoon"; content: ""; font-size: 80%; }

.news-article-nav a:hover { background-color: #404040; }

.news-article-nav ul { margin: 0 -5px; }

.news-article-nav li { width: 33.3333%; padding: 0 5px; }

.news-article-nav li.prev { float: left; }

.news-article-nav li.prev a:after { left: 14px; content: "\e901"; }

.news-article-nav li.next { float: right; }

.news-article-nav li.next a:after { right: 14px; content: "\e900"; }

.news-article-nav li.top { margin: 0 auto; }

.ibk-link, .interview-link { padding: 55px 10px 10px; }

.ibk-link .btn, .interview-link .btn { max-width: 330px; margin: 0 auto; }

.ibk-link .btn a, .interview-link .btn a { display: block; position: relative; padding: 20px; background-color: #000; color: #fff; text-align: center; }

.ibk-link .btn a:after, .interview-link .btn a:after { position: absolute; top: 50%; right: 14px; margin-top: -0.9em; font-size: 106.25%; font-weight: normal !important; font-family: "icomoon"; content: "\e900"; }

.ibk-link .btn a:hover, .interview-link .btn a:hover { opacity: 0.5; }

.interview-link .btn { max-width: 486px; }

.entry-content, #special-about .body { /*youtube レスポンシブ*/ }

.entry-content h2, #special-about .body h2 { margin: 3.85em 0 25px; font-size: 128.57143%; font-weight: bold; }

.entry-content h3, #special-about .body h3 { margin: 30px 0 25px; font-size: 112.5%; font-weight: bold; }

.entry-content h4, #special-about .body h4, .entry-content h5, #special-about .body h5, .entry-content h6, #special-about .body h6 { margin: 30px 0 25px; font-size: 128.57143%; font-weight: bold; }

.entry-content p, #special-about .body p { margin-bottom: 25px; }

.entry-content blockquote, #special-about .body blockquote { display: inline-block; position: relative; margin: 0 0 5px; padding: 10px 30px; }

.entry-content blockquote:before, #special-about .body blockquote:before, .entry-content blockquote:after, #special-about .body blockquote:after { position: absolute; color: #7B7B7B; font-size: 114.28571%; font-family: "fontAwesome"; }

.entry-content blockquote:before, #special-about .body blockquote:before { top: 0; left: 0; content: "\f10d"; }

.entry-content blockquote:after, #special-about .body blockquote:after { bottom: 20px; right: 0; content: "\f10e"; }

.entry-content a, #special-about .body a { color: #808080; text-decoration: underline; }

.entry-content a:hover, #special-about .body a:hover { text-decoration: none; }

.entry-content a.external:after, #special-about .body a.external:after { display: inline-block; width: 12px; height: 10px; margin: 0 4px; background: url(../img/icon-external-link.png) no-repeat 0 0; background-size: 12px 10px; content: ""; }

.entry-content ol, #special-about .body ol { margin-bottom: 25px; padding-left: 2em; }

.entry-content ul, #special-about .body ul { margin-bottom: 25px; padding-left: 1.5em; }

.entry-content ul li, #special-about .body ul li { list-style-type: disc; }

.entry-content li, #special-about .body li { line-height: 1.8; }

.entry-content img, #special-about .body img { display: block; margin: 40px auto; }

.entry-content table, #special-about .body table, .entry-content th, #special-about .body th, .entry-content td, #special-about .body td { border: solid 1px #5d5d55; line-height: 1.6; }

.entry-content td, #special-about .body td { padding: 5px; }

.entry-content .aligncenter, #special-about .body .aligncenter { display: block; margin-left: auto; margin-right: auto; }

.entry-content .alignleft, #special-about .body .alignleft { float: left; }

.entry-content img.alignleft, #special-about .body img.alignleft { margin-right: 20px; }

.entry-content .alignright, #special-about .body .alignright { float: right; }

.entry-content img.alignright, #special-about .body img.alignright { margin-left: 20px; }

.entry-content .wp-caption, #special-about .body .wp-caption { max-width: 100%; }

.entry-content .wp-caption p.wp-caption-text, #special-about .body .wp-caption p.wp-caption-text { margin: -25px 0 40px; font-size: 75%; text-align: center; }

@media screen and (max-width: 750px) { .entry-content .wp-caption p.wp-caption-text, #special-about .body .wp-caption p.wp-caption-text { margin: -10px 0 20px; } }

.entry-content .bg_citation02 p, #special-about .body .bg_citation02 p { margin-bottom: 0; }

.entry-content .caption01, #special-about .body .caption01 { margin-top: -25px; font-size: 87.5%; }

.entry-content .bg_color01, #special-about .body .bg_color01 { margin-bottom: 25px; padding: 22px 25px; background-color: #F4F4F4; line-height: 1.8; }

.entry-content .bg_color01 p:last-child, #special-about .body .bg_color01 p:last-child { margin-bottom: 0; }

.entry-content .video-container, #special-about .body .video-container { position: relative; padding-bottom: 56.25%; height: 0; text-align: center; margin: 30px auto; }

.entry-content .video-container iframe, #special-about .body .video-container iframe, .entry-content .video-container object, #special-about .body .video-container object, .entry-content .video-container embed, #special-about .body .video-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.entry-body, .entry-bottom { margin: 0 auto; max-width: 650px; }

.entry-author { margin: 50px 0 0; padding: 20px; border: 1px solid #B2B2B2; }

.entry-author .author-img { float: left; padding: 0 20px 5px 0; }

.entry-author .author { font-weight: bold; line-height: 1.2; }

.entry-author .author-description { margin-top: 8px; font-size: 85.71429%; line-height: 1.6; padding-left: 104px; }

.related-article { padding: 70px 0 0; }

.related-article .header-g { text-align: left; }

.related-article ul { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 20px -5px -10px; }

.related-article li { float: left; width: 25%; padding: 0 5px; }

.related-article li a { display: block; height: 100%; background-color: #fff; }

.related-article li .box { padding: 9% 11%; height: 140px; -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; }

.related-article li .date { margin: 0 0 2px; color: #999; }

.related-article li .title_sp { display: none; }

.related-article li a:hover .box { opacity: 0.5; }

.related-article li.kanren-interview .title, .related-article li.kanren-interview .title_sp { font-weight: bold; line-height: 1.714; padding-bottom: 4px; }

.related-article li.kanren-interview .post, .related-article li.kanren-interview .name { font-size: 85.71429%; line-height: 1.6666; }

.news-bottom { margin: -10px 0 70px; }

.news-bottom .follow { float: left; width: 39.4%; margin-top: 0; }

.news-bottom .follow .header-d { margin-top: -10px; }

.news-bottom .follow p { font-size: 114.28571%; line-height: 1.6; }

.news-bottom .follow .sns { margin-top: 25px; }

.news-bottom .archive { float: right; width: 52.6%; font-size: 114.28571%; }

.cat_list-single li { display: inline-block; margin-left: 6px !important; }

.pnav ul li span { display: table-cell; background-color: #000; color: #fff; vertical-align: middle; }

.pnav ul li span.current { background: #fff; color: #000; font-weight: bold; }

.pnav ul li .prev:after { content: "\e901"; font-size: 100%; font-family: "icomoon"; }

.pnav ul li .next:after { content: "\e900"; font-size: 100%; font-family: "icomoon"; }

.news .news-content section { padding: 2% 5%; background-color: #fff; }

.news .news-content section .index > li { clear: both; padding: 20px 0; border-top: 1px solid #E5E5E5; }

.news .news-content section .index > li:first-child { border-top: 0; }

.news .news-content section .index .date { font-size: 107.14286%; }

.news .news-content section .index .category li { border: 0; font-size: 107.14286%; }

.news .news-content section .index .img { float: right; width: 22.77778%; max-width: 164px; margin: 10px 0 20px 15px; }

.news .news-content section .index .title { margin: 12px 0 0; }

.news .news-article { padding: 6.25%; }

/* -----------------------------------------------
　SPECIAL
-------------------------------------------------- */
.section-special { margin-top: 18px; padding: 50px 20px 62px; }

.special-list { max-width: 1205px; margin: 0 auto; }

.special-list .listBox { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: -5px; }

.special-list .listBox li { width: 33.3333%; padding: 5px; }

.special-list .listBox li a { display: block; height: 100%; padding: 30px; background-color: #fff; }

.special-list .listBox li a:hover .title { opacity: 0.5; }

.special-list .listBox li .title { font-size: 114.28571%; font-weight: bold; line-height: 1.5; padding-top: 24px; }

.special-list .pnav ul { padding-top: 78px; }

.special-detail .site-container { padding-top: 0; }

.special-detail .top-mission { padding: 80px 30px 40px; }

.special-detail .top-mission .header { margin-bottom: 10px; font-size: 257.14286%; }

.special-detail .top-mission .btn-ask { margin: 20px auto 40px; }

.special-detail .top-mission .ask-sub2 { font-size: 114.28571%; text-align: center; }

.special-detail .box-special li .img { padding-bottom: 10px; }

.special-detail .box-special li .date { font-size: 85.71429%; color: #808080; }

.special-detail .box-special li .title { padding-top: 8px; }

.special-detail .box-special li a:hover .date { opacity: 0.5; }

.special-detail .fade { opacity: 0; -webkit-transform: translateY(40px); -ms-transform: translateY(40px); transform: translateY(40px); -webkit-transition: opacity 1.5s ease 0.2s, -webkit-transform 1.5s cubic-bezier(0.17, 0.53, 0.43, 0.99) 0.2s; transition: opacity 1.5s ease 0.2s, -webkit-transform 1.5s cubic-bezier(0.17, 0.53, 0.43, 0.99) 0.2s; -o-transition: opacity 1.5s ease 0.2s, transform 1.5s cubic-bezier(0.17, 0.53, 0.43, 0.99) 0.2s; transition: opacity 1.5s ease 0.2s, transform 1.5s cubic-bezier(0.17, 0.53, 0.43, 0.99) 0.2s; transition: opacity 1.5s ease 0.2s, transform 1.5s cubic-bezier(0.17, 0.53, 0.43, 0.99) 0.2s, -webkit-transform 1.5s cubic-bezier(0.17, 0.53, 0.43, 0.99) 0.2s; }

.special-detail .disp { opacity: 1; -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); }

.special-header-a, .special-header-b { font-weight: bold; line-height: 1.5; }

.special-header-a { font-size: 171.42857%; }

.special-header-b { font-size: 142.85714%; }

.special-bg { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: -3; }

.special-bg .bg-pc, .special-bg .bg-sp { width: 100%; height: 100%; background: transparent no-repeat center; background-size: cover; }

.special-bg .bg-sp { display: none; }

.special-bg#bg2 { display: none; opacity: 0; z-index: -2; }

.special-bg#bg2.disp { opacity: 1; }

.special-bgdot { position: fixed; top: 0; left: 0; width: 100%; height: 100%; /*background: transparent url(../img/on-dot.png);*/ z-index: -1; }

#special-top { position: relative; height: 100vh; background-color: transparent; color: #fff; }

#special-top .header { position: absolute; top: 50%; left: 0; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); width: 100%; text-align: center; padding: 140px 0 40px; }

#special-top .lead-main { padding: 0 16px; }

#special-top .lead-main > span:last-child { padding-bottom: 0 !important; }

#special-top .special-header-a, #special-top .title { display: block; padding-bottom: 16px; }

#special-top .title { font-size: 200%; font-weight: bold; line-height: 1.3; padding-bottom: 26px; }

#special-top .text { display: inline-block; line-height: 1.85; padding: 26px 35px 0; -webkit-transition-delay: 0.4s; -o-transition-delay: 0.4s; transition-delay: 0.4s; }

#special-top .img { display: block; }

#special-top .img .sp { display: none; }

#special-about { padding: 70px 45px 60px; }

#special-about .body { margin: -25px 0 80px; font-size: 114.28571%; }

#special-about .body h1, #special-about .body h2, #special-about .body h3, #special-about .body h4, #special-about .body h5 { font-weight: bold; line-height: 1.5; margin: 25px 0 16px; }

#special-about .body h1 { font-size: 175%; line-height: 1.3; }

#special-about .body h2 { font-size: 150%; }

#special-about .body h3 { font-size: 137.5%; }

#special-about .body h4 { font-size: 125%; }

#special-about .body h5 { font-size: 100%; }

#special-about .special-merit-list { padding-top: 34px; }

#special-about .special-merit-list li { padding-bottom: 40px; }

#special-about .special-merit-list .img { float: left; width: 24%; }

#special-about .special-merit-list .special-header-b, #special-about .special-merit-list .text { margin-left: 24%; padding-left: 25px; }

#special-about .special-merit-list .text { font-size: 114.28571%; padding-top: 8px; }

#special-flow { position: relative; padding: 100px 45px 90px; color: #fff; background: transparent center center/cover no-repeat fixed; }

#special-flow .special-flow-list { padding: 24px 0 0; }

#special-flow .special-flow-list li { position: relative; min-height: 78px; padding: 14px 0 14px 95px; overflow: hidden; list-style: none; }

#special-flow .special-flow-list .num { font-size: 242.85714%; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: bold; text-align: center; line-height: 70px; position: absolute; top: 8px; left: 0; width: 70px; height: 70px; border-radius: 35px; -webkit-box-shadow: 0 0 0 1.2px #fff inset; box-shadow: 0 0 0 1.2px #fff inset; }

#special-flow .special-flow-list .num:before, #special-flow .special-flow-list .num:after { content: ''; display: block; position: absolute; left: 0; right: 0; margin: auto; width: 1px; background-color: #fff; }

#special-flow .special-flow-list .num:before { bottom: 100%; height: 10px; }

#special-flow .special-flow-list .num:after { top: 100%; height: 500px; }

#special-flow .special-flow-list li:first-child .num:before { content: none; }

#special-flow .special-flow-list li:last-child .num:after { content: none; }

#special-flow .special-flow-list .text { font-size: 114.28571%; line-height: 1.75; padding-top: 2px; }

#special-flow .contentW-d { position: relative; z-index: 1; }

#special-flow:after { content: ''; display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; background: transparent url(../img/on-dot.png) center center/auto repeat fixed; }

#special-user { padding: 80px 45px; }

#special-user .special-user-list li { padding-top: 70px; }

#special-user .special-user-list .user { font-size: 114.28571%; }

#special-user .special-user-list .title { font-size: 157.14286%; font-weight: bold; line-height: 1.55; padding: 10px 0 24px; }

#special-user .special-user-list .point { border-top: 1px solid #B2B2B2; border-bottom: 1px solid #B2B2B2; }

#special-user .special-user-list .point dt, #special-user .special-user-list .point dd { font-size: 114.28571%; line-height: 1.75; padding: 12px 0; }

#special-user .special-user-list .point dt { float: left; font-weight: bold; }

#special-user .special-user-list .point dd { padding-left: 220px; border-bottom: 1px dotted #B2B2B2; }

#special-user .special-user-list .point dd:last-child { border-bottom: none; }

#special-works { padding: 80px 45px; }

#special-works h3.special-header-a { padding: 54px 0 20px; }

#special-works .contentW-e { max-width: 950px; margin-right: auto; margin-left: auto; }

#special-works .special-works-list { margin: -20px 0 -10px; }

#special-works a:hover .body { opacity: 0.5; }

#special-works .box { padding-bottom: 10px; }

#special-works .box a { display: block; background-color: #fff; padding: 32px 40px; }

#special-works .img { float: right; width: 39.0805%; }

#special-works .body { float: left; width: 60%; padding-right: 20px; }

#special-works .lead, #special-works .title { display: block; }

#special-works .lead { font-size: 142.85714%; font-weight: bold; }

#special-works .title { font-size: 114.28571%; font-weight: bold; padding-bottom: 14px; }

#special-works .text { font-size: 114.28571%; line-height: 1.875; }

/* -----------------------------------------------
　RECRUIT
-------------------------------------------------- */
.recruit .box-scenery { margin: 40px 0 0; }

.recruit .box-scenery .img { float: left; width: 38.5714%; }

.recruit .box-scenery .text { float: right; width: 57.1428%; }

.recruit .box-scenery .header-h { margin-bottom: 10px; font-size: 128.57143%; }

.recruit-top { max-width: 1185px; margin: 0 auto; }

.recruit-top .recruitment { width: auto; margin: 0 auto; display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-pack: distribute; justify-content: space-around; }

.recruit-top a { display: block; }

.recruit-top a .header-g, .recruit-top a p { -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; }

.recruit-top a:hover .header-g, .recruit-top a:hover p { opacity: 0.5; }

.recruit-top ul { margin: 0 -10px; }

.recruit-top li { padding: 0 10px; text-align: center; -webkit-box-flex: 0; -ms-flex: 0 0 50%; flex: 0 0 50%; }

.recruit-top li .img { margin: 0 0 25px; }

.recruit-top li .text { margin: 10px 0 0; }

.recruit-img1 { margin: 50px 0 45px; }

.recruit-img2 { margin: 40px -3px 55px; }

.recruit-img2 li { float: left; width: 33.333%; padding: 3px; }

.recruit-img2 li img { width: 100%; }

.recruiting { text-align: center; }

.recruiting .header { margin: 0 0 25px; font-size: 114.28571%; font-weight: bold; }

.interview-list ul { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 -15px; }

.interview-list li { width: 33.3333%; padding: 30px 15px 0; }

.interview-list li .title { font-size: 114.28571%; font-weight: bold; line-height: 1.444; padding: 12px 0 6px; -webkit-transition: opacity 0.3s; -o-transition: opacity 0.3s; transition: opacity 0.3s; clear: both; }

.interview-list li .post { line-height: 1.6; -webkit-transition: opacity 0.3s; -o-transition: opacity 0.3s; transition: opacity 0.3s; background-color: #000; color: #fff; display: inline-block; padding: 0.2em 0.8em; float: right; margin-top: 1em; }

.interview-list li a:hover .title, .interview-list li a:hover .post, .interview-list li a:hover .name { opacity: 0.5; }

.environment-box { margin-top: 60px; }

.environment-box .img { padding-bottom: 40px; }

.environment-box .text { font-size: 114.28571%; text-align: center; line-height: 1.875; margin-top: 24px; }

.environment-box .btn-more2 { font-size: 114.28571%; max-width: 485px; margin-top: 54px; }

.recruit-noIntv { padding-top: 1px !important; }

.recruit-title .enm { display: block; font-size: 621.42857%; }

.recruit-title .jp { line-height: 1.35; }

.environment-detail { padding-top: 95px; }

.environment-detail:first-child { padding-top: 30px; }

.environment-detail .head { font-size: 171.42857%; font-weight: bold; padding-bottom: 20px; }

.environment-detail .text { font-size: 114.28571%; line-height: 1.875; }

.environment-detail .img { padding-top: 35px; }

.environment-wrap { padding: 0 30px 0; }

.environment-wrap .btn-more2 { font-size: 114.28571%; max-width: 485px; margin: 60px auto 30px; }

.environment-wrap .recruiting { padding-top: 65px; }

/* -----------------------------------------------
　ASK
-------------------------------------------------- */
/* お問い合わせ */
.digiday_ask .header-k .jpm { line-height: 1.16; margin-top: 5px; display: inline-block; }

.ask_text { text-align: center; }

.ask_text a { color: #808080; text-decoration: underline; }

.ask_text a:hover { text-decoration: none; }

.ask_text_mglink { margin-top: 1em; }

.required-txt { text-align: right; color: #c42222; max-width: 900px; margin: -30px auto 4px; }

.ask-form-tb { border-collapse: separate; border-spacing: 0 20px; padding-bottom: 50px; width: 100%; }

.ask-form-tb th { font-weight: normal; text-align: left; width: 25%; }

.ask-form-tb th .required { color: #c42222; font-size: 10px; vertical-align: top; padding-left: 2px; font-weight: normal; }

.ask-form-tb th.txt-top { vertical-align: baseline; padding-top: 4px; }

.ask-form-tb td { width: 75%; }

.ask-form-tb .form-c1 > span { display: inline-block; width: 100%; margin: 0 0 10px !important; }

.ask-form-tb .form-c2 > span { display: inline-block; margin: 0 0 10px !important; width: 100%; }

.ask-form-tb .form-r1 > span { display: inline-block; margin: 0 0 10px !important; }

.ask-form-tb .form-r1 > span:nth-child(odd) { width: 38%; }

.ask-form-tb .form-r1 > span:nth-child(even) { width: 62%; }

.formBox { background-color: #fff; padding: 70px 100px 80px; }

.formBox textarea { resize: vertical; }

.formBox #budget_select { display: none; }

.formBox .field-txt { width: 100%; padding: 12px; font-size: 14px; border: 1px solid #cccccc; border-radius: 2px; }

.formBox .bodytext { margin-bottom: 5px; }

.formBox .form-2 input { display: none; }

.formBox .form-2 label { display: inline-block; cursor: pointer; }

.formBox .form-2 .c-checked, .formBox .form-2 .r-checked { display: inline-block; border: 1px solid #cccccc; width: 22px; height: 22px; position: relative; vertical-align: middle; margin-right: 8px; }

.formBox .form-2 .c-checked { border-radius: 2px; }

.formBox .form-2 .r-checked { border-radius: 11px; }

.formBox .form-2 input:checked + .c-checked:before, .formBox .form-2 input:checked + .r-checked:before { position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; }

.formBox .form-2 input:checked + .c-checked { background-color: #4c4c4c; border: none; }

.formBox .form-2 input:checked + .c-checked:before { color: #fff; font-family: "fontAwesome"; content: "\f00c"; line-height: 22px; text-align: center; }

.formBox .form-2 input:checked + .r-checked:before { display: block; content: ""; border-radius: 4px; width: 8px; height: 8px; background-color: #4c4c4c; }

.formBox .privacy-tit { font-size: 17px; font-weight: bold; }

.formBox .privacy-box { border: 1px solid #cccccc; border-radius: 2px; height: 236px; margin: 10px 0 36px; line-height: 1.8; }

.formBox .privacy-box .swiper-container { height: 100%; }

.formBox .privacy-box .swiper-slide { height: auto; padding: 18px 20px; }

.formBox .ask-privacy-box { border: 1px solid #cccccc; border-radius: 2px; margin: 10px 0 36px; line-height: 1.8; }

.formBox .ask-privacy-box .privacy-box-inner { height: auto; padding: 18px 20px; }

.formBox .ask-privacy-box .privacy-box-inner .privacy-box-text { text-align: left; }

.formBox .ask-privacy-box .privacy-box-inner .privacy-box-text a { color: #808080; text-decoration: underline; }

.formBox .ask-privacy-box .privacy-box-inner .privacy-box-text a:hover { text-decoration: none; }

.formBox #result { color: #c42222; padding-bottom: 16px; text-align: center; }

.formBox .btnBox { position: relative; max-width: 360px; margin-left: auto; margin-right: auto; font-size: 16px; color: #fff; }

.formBox .ask-btn { width: 100%; padding: 34px 10px; background-color: #000; border: none; color: #fff; border-radius: 0; -webkit-tap-highlight-color: transparent; -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; }

.formBox .ask-btn:hover { opacity: 0.5; }

.formBox .mw_wp_form_confirm .privacy-confirm { display: none; }

.formBox .mw_wp_form_confirm .btnBox { display: inline-block; width: 46%; margin: 0 1%; }

/* 媒体資料ダウンロード */
.formBox .ask-form-box .logo { font-size: 12px; }

.formBox .ask-form-box .logo img { padding-bottom: 4px; }

.formBox .ask-form-box .c-checked { vertical-align: 50% !important; }

.formBox .ask-form-box .logowrap { display: inline-block; }

.formBox .ask-form-box > span { display: inline-block; height: 75px; margin: 0 0 16px !important; float: left; }

.formBox .ask-form-box > span:nth-child(1), .formBox .ask-form-box > span:nth-child(4), .formBox .ask-form-box > span:nth-child(7) { width: 36%; }

.formBox .ask-form-box > span:nth-child(2), .formBox .ask-form-box > span:nth-child(5), .formBox .ask-form-box > span:nth-child(8) { width: 38%; }

.formBox .ask-form-box > span:nth-child(3), .formBox .ask-form-box > span:nth-child(6), .formBox .ask-form-box > span:nth-child(9) { width: 26%; }

.formBox .ask-form-box > span:nth-child(1) .logowrap { width: 142px; padding-top: 6px; }

.formBox .ask-form-box > span:nth-child(2) .logowrap { width: 138px; padding-top: 6px; }

.formBox .ask-form-box > span:nth-child(3) .logowrap { width: 120px; padding-top: 10px; }

.formBox .ask-form-box > span:nth-child(4) .logowrap { width: 140px; padding-top: 4px; }

.formBox .ask-form-box > span:nth-child(5) .logowrap { width: 140px; padding-top: 4px; }

.formBox .ask-form-box > span:nth-child(6) .logowrap { width: 130px; padding-top: 7px; }

.formBox .ask-form-box > span:nth-child(7) .logowrap { width: 140px; padding-top: 6px; }

.formBox .ask-form-box > span:nth-child(8) .logowrap { width: 120px; padding-top: 6px; }

.formBox .ask-form-box > span:nth-child(9) .logowrap { width: 160px; padding-top: 6px; }

.formBox .ask-form-box img { padding-bottom: 4px; }

.formBox .ask-form-box label { position: relative; font-size: 12px; margin-left: 40px; height: 75px; }

.formBox .ask-form-box .c-checked { position: absolute; left: -40px; top: 50%; margin-top: -11px; }

/* -----------------------------------------------
　ABOUT
-------------------------------------------------- */
.corporate .box-outline { margin-top: 30px; }

.corporate .box-outline .box { width: 46%; }

.corporate .box-outline .outline dt { margin: 35px 0 10px; padding-bottom: 8px; border-bottom: 1px solid #ccc; font-size: 114.28571%; font-weight: bold; }

.corporate .box-outline .outline dt:first-child { margin-top: 0; }

.corporate .box-outline .outline li { margin-bottom: 4px; }

.corporate .box-outline .outline .btn-more2 { max-width: 370px; margin-top: 30px; }

.corporate .nav-corporate { max-width: 1000px; margin: 80px auto 20px; }

.corporate .nav-corporate ul { margin: 0 -10px; }

.corporate .nav-corporate li { float: left; width: 25%; padding: 0 10px; }

.corporate .nav-corporate a { display: block; position: relative; padding: 20px; background-color: #000; color: #fff; text-align: center; }

.corporate .nav-corporate a:after { position: absolute; top: 50%; right: 14px; margin-top: -0.8em; font-size: 106.25%; font-weight: normal !important; font-family: "icomoon"; content: "\e900"; }

.corporate .nav-corporate a:hover { background-color: #808080; }

.corporate .section-nav { padding: 40px 30px; }

.corporate .section-nav .nav-corporate { margin: 0 auto; }

.corporate .corporate-group { max-width: 760px; margin: 30px auto; }

.corporate .corporate-group .wrap { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0 -30px; }

.corporate .corporate-group .box { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; float: left; width: 50%; padding: 0 30px; }

.corporate .corporate-group .box .img { margin: 0 0 30px; background-color: #fff; }

.corporate .corporate-group .box .img a { display: block; padding: 70px 35px; }

.corporate .corporate-group .box .text { margin: 10px 0 0; }

.corporate .corporate-group .box .btn-more { margin-top: auto; }

.corporate .message { margin-top: 105px; }

.corporate .message.first { margin-top: 0; }

.corporate .message .header { font-family: "Open Sans", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-size: 185%; font-weight: bold; text-align: center; letter-spacing: 1px; }

.corporate .message .img { margin: 0 0 55px; }

.corporate .message p { padding-top: 1.6em; font-size: 114.28571%; line-height: 1.875; }

.corporate .message .pres { text-align: right; }

.corporate .message .wrap-sign { max-width: 930px; margin: 0 auto; padding-bottom: 30px; }

.corporate .message .message-s { font-size: 85.71429%; }

.corporate .box-director .img, .corporate .box-director2 .img { margin: 0 0 30px; text-align: center; }

.corporate .box-director .name, .corporate .box-director2 .name { font-size: 171.42857%; font-weight: bold; text-align: center; }

.corporate .box-director .post, .corporate .box-director2 .post, .corporate .box-director .post1, .corporate .box-director2 .post1, .corporate .box-director .post2, .corporate .box-director2 .post2 { margin: 5px 0 25px; font-size: 114.28571%; font-weight: bold; text-align: center; }

.corporate .box-director .biog, .corporate .box-director2 .biog { margin: 30px 0 120px; }

.corporate .box-director .biog dt, .corporate .box-director2 .biog dt { float: left; margin-bottom: -1.5em; }

.corporate .box-director .biog dd, .corporate .box-director2 .biog dd { clear: both; padding: 0 0 0.2em 6em; }

.corporate .box-director.last .biog, .corporate .last.box-director2 .biog { margin-bottom: 0; }

.corporate .box-director2 .box { width: 44.2857%; margin: 0 auto; }

.corporate .box-director2 .box.float-l, .corporate .box-director2 .box.float-r { margin-bottom: 80px; }

.corporate .box-director2 .img { width: 200px; margin: 0 auto 20px; }

.corporate .box-director2 .name { font-size: 142.85714%; }

.corporate .box-director2 .post { margin: 20px 0 15px; line-height: 1.6; }

.corporate .box-director2 .post1 { margin: 10px 0 0; line-height: 1.4; }

.corporate .box-director2 .post2 { margin: 0 0 15px; }

.corporate .history .year { float: left; width: 7em; font-size: 112.5%; font-weight: bold; }

.corporate .history dd { clear: right; padding: 0 0 20px 7.5em; }

.corporate .history dd li { margin-bottom: 6px; margin-left: 4.5em; text-indent: -4em; line-height: 1.6; }

.corporate .history dd .month { display: inline-block; width: 3em; padding-right: 1em; text-align: right; }

.corporate .access .wrap-map { position: relative; padding-top: 55%; }

.corporate .access .wrap-map #map, .corporate .access .wrap-map #map_k { position: absolute !important; top: 0; left: 0; width: 100%; height: 100%; }

.corporate .access .header { margin: 40px 0 30px; font-size: 171.42857%; font-weight: bold; }

.corporate .access .info dt { float: left; margin-bottom: -1.5em; font-weight: bold; }

.corporate .access .info dd { clear: both; margin-bottom: 20px; padding-left: 6em; }

.corporate .access.kyoto { margin-top: 90px; }

#ibk #tubular-container { background-color: #000; }

#ibk #tubular-container:after { content: none; }

#ibk #tubular-player { opacity: 0; -webkit-transition: opacity 0.5s ease-out; -o-transition: opacity 0.5s ease-out; transition: opacity 0.5s ease-out; }

#ibk .site-container { padding-top: 0; }

#ibk .top-mission { padding-top: 12px; background-color: transparent; }

#ibk .bcnav a, #ibk .bcnav li, #ibk .bcnav li:not(:first-child):after { color: #333; }

#ibk #site-header.skin-white .bcnav a, #ibk #site-header.skin-white .bcnav li, #ibk #site-header.skin-white .bcnav li:not(:first-child):after { color: #fff; }

#ibk .ibk-bgGradation { background-color: #fffffc; animation: bg-color 20s infinite; -webkit-animation: bg-color 20s infinite; }

.skrollr-mobile #ibk .ibk-bgTop_sp { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000 url(../../images/ibk/bg-main_sp.gif) no-repeat center; background-size: cover; z-index: -2; }

@-webkit-keyframes bg-color { 0% { background-color: #fffffc; }
  20% { background-color: #fefdfc; }
  40% { background-color: #fefffe; }
  60% { background-color: #fdfffb; }
  80% { background-color: #fffffd; }
  100% { background-color: #fffffc; } }

@keyframes bg-color { 0% { background-color: #fffffc; }
  20% { background-color: #fefdfc; }
  40% { background-color: #fefffe; }
  60% { background-color: #fdfffb; }
  80% { background-color: #fffffd; }
  100% { background-color: #fffffc; } }

.ibk-top { height: 100vh; position: relative; background-color: transparent; padding: 0 20px; }

.ibk-top .header { position: absolute; width: 100%; top: 50%; left: 0; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); }

.ibk-top .header .title { width: 274px; margin: 0 auto; }

.ibk-top .header .copy { padding: 52px 0 70px; font-size: 571.42857%; color: #fff; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 300; text-align: center; line-height: 1.175; letter-spacing: 3px; }

.ibk-top .header .copy .bold { font-weight: 700; }

.ibk-top #scroll-btn { position: absolute; bottom: 96px; left: 50%; margin-left: -24px; font-size: 157.14286%; line-height: 48px; }

.ibk-top #scroll-btn a { display: block; width: 48px; height: 48px; border-radius: 24px; background-color: rgba(255, 255, 255, 0.2); color: #fff; text-align: center; }

.ibk-about { height: 100vh; position: relative; padding: 0 20px; }

.ibk-about .text { position: absolute; width: 100%; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); max-width: 920px; margin-right: auto; margin-left: auto; padding: 0 20px; font-size: 128.57143%; color: #fff; }

.ibk-about .text div { width: 50%; padding-left: 40px; }

.ibk-about .text div.first { padding-right: 40px; padding-left: 0; }

.ibk-about .text div.first p { line-height: 2.055; }

.ibk-about .text div.en p { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 300; line-height: 2; letter-spacing: 1px; }

.ibk-design { padding: 0 20px; }

.ibk-design .head { padding: 100px 0 10px; font-size: 400%; color: #fff; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 300; text-align: center; letter-spacing: 1px; line-height: 1; }

.ibk-design .head .bold { font-weight: 700; }

.ibk-design .text { font-size: 128.57143%; color: #fff; text-align: center; }

.ibk-design .img { text-align: center; padding: 70px 0 140px; }

.ibk-design-type { background-color: #000; padding: 74px 20px 88px; color: #78797a; }

.ibk-design-type ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; max-width: 1110px; margin: 0 auto; }

.ibk-design-type ul li { width: 33.3333%; }

.ibk-design-type .title { position: relative; margin: 0 0 44px; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 400; font-size: 171.42857%; letter-spacing: 1px; text-align: center; }

.ibk-design-type .title:after { display: inline-block; position: absolute; bottom: -20px; left: 0; width: 100%; height: 2px; font-size: 0; content: ""; background-color: #1c1c1c; }

.ibk-design-type .text { min-height: 100px; }

.ibk-design-type .en { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 300; line-height: 1.8; margin-top: 30px; }

.ibk-design-type .interface { padding-right: 60px; }

.ibk-design-type .interface .title { color: #18b0c4; }

.ibk-design-type .content { padding: 0 30px; }

.ibk-design-type .content .title { color: #7d54e2; }

.ibk-design-type .ux { padding-left: 60px; }

.ibk-design-type .ux .title { color: #e8c328; }

.ibk-channel { padding: 160px 20px 0; }

.ibk-channel .entry-box { position: relative; max-width: 1120px; margin: 0 auto 80px; }

.ibk-channel .entry-box .title { position: absolute; top: 56px; left: 0; font-size: 185.71429%; font-weight: bold; line-height: 2.15; z-index: 2; }

.ibk-channel .entry-box .title .bgc-w { background-color: #fff; padding: 0 20px; display: inline-block; }

.ibk-channel .entry-box .img { max-width: 1120px; margin: 0 auto; }

.ibk-channel .entry-box .btn-more { position: absolute; bottom: 0; right: 80px; font-weight: normal; font-size: 114.28571%; display: inline-block; padding: 9px 57px; background-color: #000; color: #fff; text-align: center; text-transform: uppercase; }

.ibk-channel .entry-box .link-cover { display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; text-indent: -9999px; -webkit-transition: opacity 0.3s; -o-transition: opacity 0.3s; transition: opacity 0.3s; background-color: #fff; opacity: 0; z-index: 3; }

.ibk-channel .entry-box .link-cover:hover { opacity: 0.5; }

.btn-ibk { max-width: 640px; margin: 0 auto 140px; font-size: 121.42857%; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; }

.btn-ibk a { display: block; position: relative; padding: 25px 20px; background-color: #000; color: #fff; text-align: center; letter-spacing: 1px; }

.btn-ibk a:after { position: absolute; top: 50%; right: 40px; margin-top: -0.9em; font-size: 106.25%; font-weight: normal !important; font-family: "icomoon"; content: "\e900"; }

.btn-ibk a:hover { opacity: 0.5; }

.ibk-works .btn-ibkWorks { max-width: 1120px; margin: 0 auto; padding: 20px 0 180px; font-size: 264.28571%; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 700; }

.ibk-works .btn-ibkWorks a { display: block; position: relative; padding: 80px 20px; text-align: center; letter-spacing: 1px; border: 8px solid #000; }

.ibk-works .btn-ibkWorks a:after { position: absolute; top: 50%; right: 64px; margin-top: -0.9em; font-size: 118.91892%; font-weight: normal !important; font-family: "fontAwesome"; content: "\f105"; }

.ibk-works .btn-ibkWorks a:hover { opacity: 0.5; }

.ibk-works, .ibk-member { padding: 0 20px; }

.ibk-works .header, .ibk-member .header { font-size: 357.14286%; font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; font-weight: 700; text-align: center; padding-bottom: 110px; letter-spacing: 1px; }

.ibk-member .ibk-member-list { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; max-width: 1150px; margin: 0 auto 150px; }

.ibk-member .ibk-member-list li { width: 25%; padding: 10px 10px 36px; text-align: center; }

.ibk-member .ibk-member-list .wrap-member { position: relative; }

.ibk-member .ibk-member-list .wrap-member.active .text { opacity: 1; }

.ibk-member .ibk-member-list:not(.k-mobile) .wrap-member:hover .text { opacity: 1; }

.ibk-member .ibk-member-list .img { max-width: 240px; margin: auto; }

.ibk-member .ibk-member-list .text { position: absolute; top: 0; left: 0; right: 0; margin: auto; width: 100%; height: 100%; max-width: 240px; border-radius: 121px; color: #fff; opacity: 0; -webkit-transition: opacity 0.5s ease; -o-transition: opacity 0.5s ease; transition: opacity 0.5s ease; }

.ibk-member .ibk-member-list .text .text-wrap { position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); width: 100%; }

.ibk-member .ibk-member-list .text .name { font-size: 178.57143%; }

.ibk-member .ibk-member-list .text .post { font-size: 85.71429%; padding-top: 10%; line-height: 2; }

.ibk-member .ibk-member-list .text.yellow { background-color: #f4d731; }

.ibk-member .ibk-member-list .text.blue { background-color: #2fc7d3; }

.ibk-member .ibk-member-list .text.purple { background-color: #7755e0; }

/* -----------------------------------------------
　その他
-------------------------------------------------- */
.idl-bgmain { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: url(../../images/idl/img-main.jpg) no-repeat center; background-size: cover; content: ""; z-index: -1; }

.idl-mainimg { position: relative; padding: 0 30px 150px; color: #fff; text-align: center; }

.idl-mainimg .idl-header-b + p { font-size: 100%; line-height: 2.5; }

.idl-mainimg .figure { padding: 80px 0 20px; }

.idl-header-a { width: 370px; margin: 0 auto; padding: 240px 0 320px; }

.idl-header-b { margin: 0 0 20px; font-size: 142.85714%; font-weight: bold; }

.idl-header-c { margin: 0 0 40px; font-size: 0; text-align: center; }

.idl-header-c img { width: auto; height: 20px; }

.idl-casestudy { margin: 0 -15px; }

.idl-casestudy li { float: left; position: relative; width: 33.3333%; padding: 0 15px; }

.idl-casestudy li .text { margin: 20px 0 0; }

.idl-casestudy li.new:before { position: absolute; top: -58px; left: -43px; width: 0; height: 0; border: 58px solid transparent; border-right: 58px solid #F3FF00; content: ""; -webkit-transform: rotate(45deg); -moz-transform: rotate(45deg); -ms-transform: rotate(45deg); -o-transform: rotate(45deg); transform: rotate(45deg); }

.idl-casestudy li.new:after { position: absolute; top: 15px; left: 23px; color: #181818; font-weight: bold; text-transform: uppercase; letter-spacing: 1px; content: "new"; -webkit-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }

.section-idl-member { position: relative; padding: 80px 30px; }

.idl-member { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; max-width: 820px; margin: -10px auto 0; }

.idl-member li { width: 20%; padding: 10px 4px 10px; color: #fff; text-align: center; }

.idl-member li .img { width: 85px; margin: 0 auto 10px; }

.idl-member li .name { font-family: "Ubuntu Condensed", sans-serif; font-size: 92.85714%; line-height: 1.4; letter-spacing: 1px; }

.idl-contact { margin: 0 0 20px; }

.idl-contact a { text-decoration: underline; }

.idl-contact a:hover { text-decoration: none; }

.idl-sns li { display: inline-block; padding: 0 10px; font-size: 157.14286%; }

.idl-sns li a { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; width: 40px; height: 40px; border: 1px solid #000; border-radius: 60px; vertical-align: middle; }

.idl-sns li a .fa { vertical-align: middle; }

.idl-sns li a:hover { opacity: 0.8; }

.box-errorp { padding: 8.4% 0 9.2%; text-align: center; }

.box-errorp .header { margin: 0 0 20px; font-size: 200%; font-weight: bold; }

.box-errorp .ib { display: inline-block; }

.box-errorp .gohome { margin: 30px 0 0; }

.box-errorp .gohome a { display: inline-block; text-align: left; text-decoration: underline; }

.box-errorp .gohome a:hover { text-decoration: none; }

.wrap-news .news-content.utility-content { float: none; margin: 0 auto; }

.news-content section.utility-section { padding: 6.25%; background-color: #fff; }

.news-content section.utility-section p { margin-bottom: 8px; }

.news-content section.utility-section .tit-1 li, .news-content section.utility-section .tit-2 li { margin-bottom: 8px; }

.news-content section.utility-section a:not(.telink) { color: #808080; text-decoration: underline; }

.news-content section.utility-section a:not(.telink):hover { text-decoration: none; }

.news-content section.utility-section .tit-1 { margin: 24px 0 16px; font-weight: bold; font-size: 125%; }

.news-content section.utility-section .tit-2 { margin: 16px 0 8px; font-weight: bold; font-size: 110%; }

.news-content section.utility-section .list-1, .news-content section.utility-section .list-2 { margin-bottom: 10px; padding: 0; line-height: 1.8; }

.news-content section.utility-section .list-1 { margin-left: 1em; text-indent: -1em; }

.news-content section.utility-section .list-2 { margin-left: 1.5em; text-indent: -1.5em; }

.news-content section.utility-section .list-2 li { list-style: none; }

.news-content section.utility-section .list-2 li .list-2-element { display: inline-block; margin-left: 1.2em; }

.news-content section.utility-section .sitemap-box .column2 { width: 50%; float: left; }

.news-content section.utility-section .sitemap-list { font-size: 16px; }

.news-content section.utility-section .sitemap-list .bold { color: #000; font-weight: bold; }

.news-content section.utility-section .sitemap-list li ul { padding-left: 20px; }

.news-content section.utility-section .sitemap-list ul li { padding-top: 8px; }

.news-content section.utility-section .sitemap-list > li { padding-bottom: 16px; }

.news-content section.utility-section .rss_list { font-size: 16px; }

.news-content section.utility-section .rss_list li { padding-top: 6px; }

.news-content section.utility-section .rss_list a { color: #000; }

.news-content section.utility-section .rss_list .fa { color: #fbb70e; font-size: 110%; padding-right: 8px; }

.news-content section.utility-section .optout-btn { width: 100%; max-width: 180px; margin: 20px 0; padding: 10px 20px; background-color: #000; color: #fff; border: none; -webkit-transition: opacity 0.3s ease-in-out; -o-transition: opacity 0.3s ease-in-out; transition: opacity 0.3s ease-in-out; }

.news-content section.utility-section .optout-btn:hover { opacity: 0.5; }

/* -----------------------------------------------
　トップページ
-------------------------------------------------- */
/**************************************************
　whl
***************************************************/
.btn-ask.-whl { margin: 25px 0 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; width: 100%; }

@media screen and (max-width: 750px) { .btn-ask.-whl li { width: 100%; }
  .btn-ask.-whl .ask_whl { width: 100%; } }

.btn-ask > li.whl { display: none; }

.works-category { max-width: 1185px; }

#ask_whl .header-k.title-2 .jpm { font-size: 32px; }

@media screen and (max-width: 750px) { #ask_whl .header-k.title-2 .jpm { font-size: 20px; line-height: 1.4; } }

#ask_whl .ask-form-tb { padding-bottom: 0px; }

#ask_whl .checkbox-block { margin-bottom: 60px; }

#ask_whl .checkbox-block .txt-top { font-weight: bold; font-size: 17px; }

@media screen and (max-width: 750px) { #ask_whl .checkbox-block { margin-bottom: 30px; } }

#ask_whl .checkbox-wrap { margin-top: 50px; text-align: center; overflow: hidden; margin-right: -20px; margin-left: -20px; }

@media screen and (max-width: 750px) { #ask_whl .checkbox-wrap { margin-right: -10px; margin-left: -10px; } }

#ask_whl .checkbox-wrap .mwform-checkbox-field { margin-bottom: 40px; display: block; -webkit-box-sizing: border-box; box-sizing: border-box; text-align: left; padding: 0 20px; }

@media screen and (max-width: 750px) { #ask_whl .checkbox-wrap .mwform-checkbox-field { padding: 0 10px; margin-bottom: 20px; } }

#ask_whl .checkbox-wrap .mwform-checkbox-field label { overflow: hidden; }

#ask_whl .checkbox-wrap .mwform-checkbox-field .thumb { display: block; margin-bottom: 15px; }

#ask_whl .checkbox-wrap .mwform-checkbox-field .thumb img { width: 100%; }

#ask_whl .checkbox-wrap .mwform-checkbox-field:not(:first-child) { width: 33.33%; float: left; margin-left: 0; }

@media screen and (max-width: 750px) { #ask_whl .checkbox-wrap .mwform-checkbox-field:not(:first-child) { width: 50%; }
  #ask_whl .checkbox-wrap .mwform-checkbox-field:not(:first-child) .mwform-checkbox-field-text { width: 100%; padding: 0; margin-top: 6px; text-align: justify; text-justify: inter-ideograph; } }

#ask_whl .checkbox-wrap .mwform-checkbox-field:first-child { width: 370px; margin-right: auto; margin-left: auto; }

@media screen and (max-width: 410px) { #ask_whl .checkbox-wrap .mwform-checkbox-field:first-child { width: 100%; }
  #ask_whl .checkbox-wrap .mwform-checkbox-field:first-child img { width: 100%; } }

@media screen and (max-width: 750px) { #ask_whl .checkbox-wrap .mwform-checkbox-field:first-child .mwform-checkbox-field-text { width: 90%; } }

#ask_whl .checkbox-wrap .mwform-checkbox-field-text { width: calc(100% - 30px); float: left; }

@media screen and (max-width: 750px) { #ask_whl .checkbox-wrap .mwform-checkbox-field-text { width: 80%; -webkit-box-sizing: border-box; box-sizing: border-box; } }

#ask_whl .checkbox-wrap input { display: none; }

#ask_whl .checkbox-wrap label { display: block; cursor: pointer; }

#ask_whl .checkbox-wrap .c-checked, #ask_whl .checkbox-wrap .r-checked { display: inline-block; border: 1px solid #cccccc; width: 22px; height: 22px; position: relative; vertical-align: middle; margin-right: 8px; }

#ask_whl .checkbox-wrap .c-checked { border-radius: 2px; float: left; }

#ask_whl .checkbox-wrap .r-checked { border-radius: 11px; }

#ask_whl .checkbox-wrap input:checked + .c-checked:before, #ask_whl .checkbox-wrap input:checked + .r-checked:before { position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; }

#ask_whl .checkbox-wrap input:checked + .c-checked { background-color: #4c4c4c; border: none; }

#ask_whl .checkbox-wrap input:checked + .c-checked:before { color: #fff; font-family: "fontAwesome"; content: "\f00c"; line-height: 22px; text-align: center; }

#ask_whl .checkbox-wrap input:checked + .r-checked:before { display: block; content: ""; border-radius: 4px; width: 8px; height: 8px; background-color: #4c4c4c; }

/**************************************************
　rwd
***************************************************/
@media screen and (min-width: 750px) { .skrollr-mobile #tubular-container { display: none; }
  .skrollr-mobile .category-mainimg#category_movie { visibility: visible; } }

.spNav-menus { visibility: hidden; position: fixed; width: 100%; max-width: 375px; height: 100%; right: 0; top: 0; margin: 0 auto; z-index: 100; background: #000; }

.spNav-menus .swiper-container { width: 100%; height: auto; }

.spNav-menus .swiper-slide { height: auto; }

@media screen and (min-width: 769px) { .spNav-menus { display: none !important; } }

.sp-menu-button { display: none; position: fixed; top: 8px; right: 5px; overflow: hidden; z-index: 101; }

.sp-menu-button .menu a { display: block; width: 39px; height: 39px; padding: 10px; background: url(../img/icon-menu.svg) no-repeat center; background-size: 19px; text-indent: -200px; }

.no-svg .sp-menu-button .menu a { background-image: url(../img/icon-menu.png); }

.sp-menu-close { display: none; position: fixed; top: 2px; right: 2px; overflow: hidden; z-index: 101; }

.sp-menu-close a { display: block; width: 45px; height: 45px; background: url(../img/icon-close.svg) no-repeat center; background-size: 15px; text-indent: -200px; padding: 15px; }

.no-svg .sp-menu-close a { background-image: url(../img/icon-close.png); }

.sp-menu { padding: 68px 35px 35px; }

.sp-menu .sp-menu-text a { display: block; position: relative; position: relative; padding: 12px 10px; color: #fff; text-decoration: none; font-weight: bold; }

.sp-menu .sp-menu-text a.en { font-family: "Ubuntu", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; }

.sp-menu .sp-menu-text li { margin-bottom: -1px; border-top: 1px solid #808080; border-bottom: 1px solid #808080; text-transform: uppercase; letter-spacing: 1px; }

.sp-menu .sp-menu-text > li > a { font-family: "Open Sans", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro W3", "メイリオ", Meiryo, "游ゴシック", "游ゴシック体", "YuGothic", "Yu Gothic", Helvetica, sans-serif; }

.sp-menu .sp-menu-text > li.lower > a:after { position: absolute; top: 50%; right: 0; margin-top: -0.8em; color: #fff; font-weight: normal; content: "＋"; }

.sp-menu .sp-menu-text > li.open > a:after { content: "－"; }

.sp-menu .sub { display: none; }

.sp-menu .sub li { font-size: 86.66667%; letter-spacing: 2px; }

.sp-menu .sub li a { padding: 13px 10px; text-align: center; }

.sp-menu .sp-menu-btn { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 46px -5px 0; }

.sp-menu .sp-menu-btn li { padding: 5px; }

.sp-menu .sp-menu-btn .fb, .sp-menu .sp-menu-btn .tw { width: 50%; font-size: 200%; }

.sp-menu .sp-menu-btn .fb a, .sp-menu .sp-menu-btn .tw a { display: block; padding: 2px; }

.sp-menu .sp-menu-btn .site1, .sp-menu .sp-menu-btn .site2 { width: 100%; font-size: 0; }

.sp-menu .sp-menu-btn .site1 img, .sp-menu .sp-menu-btn .site2 img { height: 20px; }

.sp-menu .sp-menu-btn a { display: block; padding: 15px; background-color: #fff; text-align: center; }

@media screen and (max-width: 768px) { .unav, .gnav { display: none; }
  #site-header { height: 55px; padding: 0 10px; }
  #site-header .header-inner { width: auto; padding: 14px 5px 14px; }
  #site-header .logo { width: 129px; }
  #site-header .logo img { height: 27px; }
  #site-header.skin-white .sp-menu-button .menu a { background-image: url(../img/icon-menu-w.svg); }
  .no-svg #site-header.skin-white .sp-menu-button .menu a { background-image: url(../img/icon-menu-w.png); }
  .sp-menu-button { display: block; }
  .sp-menu { display: block; } }

@media screen and (max-width: 750px) { body { font-size: 15px; }
  p { line-height: 1.6; }
  .text_16 { font-size: 100%; }
  #site-footer { padding: 20px; }
  #site-footer .footer-inner { padding: 0; }
  #site-footer .fsns { display: -webkit-box; display: -ms-flexbox; display: flex; float: none; margin: 0 -5px; padding: 0 0 20px; border-bottom: 1px solid #262626; }
  #site-footer .fsns li { width: 50%; padding: 0 5px; }
  #site-footer .fsns li a { display: block; background-color: #fff; color: #000; }
  #site-footer .fnav, #site-footer .fnav2 { text-align: center; }
  #site-footer .fnav li, #site-footer .fnav2 li { display: block; padding: 0; border-bottom: 1px solid #262626; font-size: 80%; }
  #site-footer .fnav li a, #site-footer .fnav2 li a { display: block; padding: 1em; }
  #site-footer .pmark { /*float: right;*/ width: 59px; margin: 25px 0 0; }
  #site-footer .copyright { margin-top: 65px; font-size: 66.66667%; text-align: left; }
  .site-container { padding-top: 55px; }
  .bcnav { display: none; }
  .header-a { margin-bottom: 10px; font-size: 333.33333%; }
  .corporate .header-a { margin: 30px 0 10px; font-size: 333.33333%; }
  .header-b { margin: 30px 0; }
  .header-b .en { font-size: 166.66667%; }
  .header-b .jp { font-size: 140%; }
  .header-c { font-size: 200%; }
  .news .header-c { font-size: 333.33333%; }
  .header-c.service-works { font-size: 233.33333%; }
  .header-d { margin: 0; }
  .header-d .en { margin-bottom: 5px; font-size: 166.66667%; }
  .header-d .jp { font-size: 113.33333%; }
  .ask-txt { margin-top: -5px; font-size: 100%; }
  .header-e, .works-detail .header-e { font-size: 140%; }
  .works-detail .header-e { padding: 0; }
  .header-f { font-size: 140%; }
  .header-g { font-size: 120%; }
  .header-h { font-size: 100%; }
  .header-i { margin-bottom: 30px; }
  .header-i .en { font-size: 166.66667%; }
  .header-i .enm { font-size: 246.66667%; }
  .header-i .jp { display: block; margin-top: 15px; font-size: 140%; }
  .header-i .jpm { font-size: 246.66667%; }
  .blog .header-i { margin-bottom: 20px; }
  .news .header-i { margin-bottom: 5px; }
  .news .header-i .en { padding: 15px 0 15px; }
  .news .header-i .enm { font-size: 333.33333%; }
  .header-j { font-size: 140%; }
  .header-k { margin-bottom: 30px; }
  .header-k .en { font-size: 166.66667%; margin-bottom: 4px; }
  .header-k .jpm { font-size: 166.66667%; }
  .pnav ul li { width: 46px; height: 46px; font-size: 80%; }
  a.link_white { display: block; padding: 26px 30px; }
  .pdt0_sp { padding-top: 0 !important; }
  .pdb10_sp { padding-bottom: 10px !important; }
  .pdt3_pc { padding-top: 0; }
  .pt100_sp { padding-top: 100px !important; }
  .top-mission .header { font-size: 233.33333%; margin-bottom: 11px; }
  .top-mission .btn-ask { margin-top: 20px; }
  .top-mission .btn-ask li { padding: 5px 0; }
  .service .top-mission { padding-left: 0; padding-right: 0; }
  .works .top-mission { padding-left: 30px; padding-right: 30px; } }

@media screen and (max-width: 768px) { .disp-pc, .view-pc { display: none; }
  .disp-tb, .disp-tbsp { display: block; }
  .view-tb, .view-tbsp { display: inline; } }

@media screen and (max-width: 640px) { .disp-pctb, .view-pctb, .disp-tb, .view-tb { display: none; }
  .disp-sp { display: block; }
  .view-sp { display: inline; }
  body { min-width: 320px; overflow-x: hidden; }
  .float-l { float: none; width: auto !important; }
  .float-r { float: none; width: auto !important; } }

@media screen and (max-width: 380px) { .pnav ul { -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .pnav ul li:first-child { margin-left: 0; }
  .pnav ul li:last-child { margin-right: 0; } }

@media screen and (max-width: 365px) { .pnav ul li { width: 40px; height: 40px; margin: 6px 3px; } }

@media screen and (max-width: 750px) { .section-a, .section-b { padding: 50px 30px; }
  .news .section-b { padding: 23px 20px; }
  .btn-more, .btn-more.ib-btn_more { width: 180px; margin: 0 auto; font-size: 80%; }
  .btn-more a, .btn-more.ib-btn_more a { display: block; padding: 14px 18px; }
  .btn-more2, .btn-more3 { font-size: 86.66667%; }
  .btn-more2 a, .btn-more3 a { padding: 18px 20px; }
  .btn-ask li { font-size: 100%; }
  .box-special li .title { display: none; }
  .box-special li .title_sp { display: block; font-size: 106.66667%; font-weight: bold; padding-top: 18px; }
  .box-group .text .logo { width: auto; max-width: 190px; }
  .box-group .text .name { font-size: 100%; }
  .box-group .text .btn-more { margin-top: 30px; }
  .category-mainimg { display: none; }
  .category-mainimg_sp { display: block; }
  .category-head { padding-top: 30px; padding-bottom: 0; }
  .category-head .header { margin: 0 0 10px; font-size: 133.33333%; }
  .category-head .text { font-size: 100%; }
  .mgt { margin-top: 1.8em; }
  .mgb { margin-bottom: 1.8em; } }

@media screen and (max-width: 640px) { .box-special { margin-bottom: 0; }
  .box-special ul { margin: 0 0 30px; }
  .box-special li { width: 100%; padding: 10px 0 0; }
  .box-special li a { zoom: 1; padding: 0; }
  .box-special li a:after { content: ''; display: block; clear: both; overflow: auto; }
  .box-special li .img { float: left; position: relative; width: 39.68254%; padding-top: 39.68254%; overflow: hidden; }
  .box-special li .img img { position: absolute; top: 0; left: -38%; max-width: none; width: auto; height: 100%; }
  .box-special li .box { float: right; width: 60.31746%; padding: 20px; }
  .box-special li .title_sp { padding-top: 0; } }

@media screen and (max-width: 480px) { .btn-ask { margin: 15px 0 0; }
  .btn-ask li { float: none; width: auto; padding: 10px 0 0; font-size: 100%; }
  .btn-ask li a { padding: 36px 20px; }
  .btn-ask li a:after { font-size: 120%; }
  .box-works-s { margin: 0 0 40px; }
  .box-works-s .btn-works { margin: 30px auto 30px; }
  .box-works-list { max-width: 250px; margin: 30px auto 0; }
  .box-works-list ul { margin: 0 0 10px; }
  .box-works-list li { float: none; width: auto; padding: 0 0 20px; }
  .box-works-list li .title { font-size: 86.66667%; text-align: center; }
  .box-special li .box { padding: 16px; }
  .box-group .img { float: none; width: auto; margin: 0 0 25px; }
  .box-group .text { float: none; width: auto; } }

@media screen and (max-width: 380px) { .btn-more2, .btn-more3 { max-width: none; } }

@media screen and (max-width: 370px) { .box-special li .box { padding: 12px; }
  .box-special li .title_sp { font-size: 93.33333%; } }

@media screen and (max-width: 990px) { .media-detail { margin-left: 20px; margin-right: 20px; } }

@media screen and (max-height: 640px) { .media-detail { margin-top: 20px; margin-bottom: 20px; } }

@media screen and (max-width: 900px) { .service-types2 .innovation { padding-right: 2%; }
  .service-types2 .branding { padding: 0 1%; }
  .service-types2 .creative { padding-left: 2%; }
  .service-media-list ul { margin-right: -15px; margin-left: -15px; }
  .service-media-list li { padding-right: 15px; padding-left: 15px; } }

@media screen and (max-width: 750px) { .service-mainimg { margin: 0 0 25px; }
  .service-img1 { margin-top: 25px; }
  .service-title .enm { margin-top: 0px; }
  .servise-text1 { font-size: 100%; line-height: 1.6; }
  .service-approach { text-align: left; }
  .service-approach .header-f { text-align: left; }
  .service-approach .header-f br { display: none; }
  .service-approach .header-f + p br { display: none; }
  .service-approach .header { margin: 40px 0 10px; }
  .service-approach .header .en { font-size: 200%; }
  .service-approach .header .jp { font-size: 113.33333%; }
  .service-approach .header + p br { display: none; }
  .service-img5 { margin: 30px 0; }
  .service-detail { padding-bottom: 50px; }
  .service-detail .header-g { margin: 40px 0 25px; }
  .service-menu .text .header { font-size: 113.33333%; }
  .service-media ul { margin: 0 0 30px; }
  .service-other { margin: 40px 0 50px; }
  .service-other .box .header { margin: 0 0 10px; }
  .service-other .box .header .en { font-size: 200%; }
  .service-other .box .header .jp { font-size: 113.33333%; }
  .service-media-list { margin-top: -24px; }
  .service-media-list ul { margin-top: -40px; }
  .service-media-list li { width: 50%; padding-bottom: 0; }
  .service-media-list li .img { padding: 15%; }
  .service-media-list li .name { font-size: 120%; }
  .service-media-list li .more a:before { margin-top: -0.7em; }
  .service-media-list li .btn-download a { padding: 18px 20px; font-size: 86.66667%; }
  .service-media-list li .btn-download a:after { right: 12px; font-size: 123.07692%; }
  .media-news { padding: 0px 30px 30px; }
  .media-news .box { padding: 30px; }
  .media-news .header { font-size: 200%; text-align: center; }
  .media-news .btn-more-media { position: static; font-size: 80%; }
  .media-news .btn-more-media a { background-color: #000; color: #fff; width: 180px; height: 47px; padding: 14px 18px; }
  .media-news .newly { margin: 22px 0 25px; border-top: 1px solid #b2b2b2; }
  .media-news .newly li { position: relative; padding: 17px 20px 17px 0; border-bottom: 1px solid #b2b2b2; }
  .media-news .newly li:after { position: absolute; top: 50%; right: -6px; margin-top: -0.75em; font-size: 160%; font-family: "icomoon"; content: "\e900"; }
  .media-news .newly .date { float: none; padding: 0; font-size: 86.66667%; }
  .media-news .newly .lead { padding: 0; letter-spacing: normal; font-size: 100%; }
  .media-detail { max-height: 590px; }
  .media-detail .btn-close { top: 15px; right: 15px; width: 19px; height: 19px; z-index: 1; }
  .media-detail .btn-close .inner { margin-top: 8px; }
  .media-detail .btn-close .inner:before, .media-detail .btn-close .inner:after { width: 19px; height: 3px; background-color: #000; }
  .media-detail .btn-close .inner:after { margin-top: -3px; }
  .media-detail .head { height: 90px; }
  .media-detail .head .title { left: 20px; bottom: 18px; }
  .media-detail .head .name { font-size: 100%; }
  .media-detail .head .btn-download { display: none; }
  .media-detail .main .box { padding: 0; max-width: none; }
  .media-detail .main .box .swiper-container { height: auto; margin-bottom: 30px; }
  .media-detail .main .box .swiper-scrollbar { display: none !important; }
  .media-detail .main .detail { padding-right: 0; }
  .media-detail .main .detail dt { font-size: 126.66667%; }
  .media-detail .main .detail dd { line-height: 1.666; }
  .media-detail .main .btn-download { display: block; margin: 0 auto 10px; font-size: 86.66667%; font-weight: bold; }
  .media-detail .main .btn-download a { width: 100%; }
  .media-detail .main .media-nav { margin: 0 -5px; }
  .media-detail .main .media-nav li { width: 50%; font-size: 86.66667%; font-weight: bold; }
  .media-detail .main .media-nav a { padding: 18px 4px; }
  .media-detail .main .media-nav .top { display: none; }
  .service-types { margin: 0 0 40px; padding: 0 20px; }
  .service-types ul { display: block; height: auto; background: none; }
  .service-types ul li { width: auto; margin-top: 10px; padding: 0 !important; background-color: #000; text-align: left; }
  .service-types .title { margin: 0 0 20px; font-size: 233.33333%; }
  .service-types .title:after { left: 0; margin-left: 0; }
  .service-types2 { padding: 50px 20px 0; }
  .service-types2 ul { display: block; }
  .service-types2 ul li { width: 100%; max-width: 400px; margin: 0 auto; }
  .service-types2 .title { font-size: 233.33333%; margin-bottom: 14px; }
  .service-types2 .title:after { bottom: -2px; }
  .service-types2 .text { font-size: 100%; }
  .service-types2 .innovation, .service-types2 .branding, .service-types2 .creative { padding: 0 38px 30px; }
  .service-types2 .creative { padding-bottom: 35px; } }

@media screen and (max-width: 640px) { .service-other { margin: 20px 0 20px; }
  .service-other .box { padding: 0 0 30px; text-align: left; }
  .service-other .box .img { max-width: 320px; margin: 15px auto 20px; }
  .service-other .box .img li { padding: 2px; }
  .media-detail#gizmodo .main, #modal .media-detail .bg-fade.gizmodo { background-image: url(../../service/images/bg-media-gizmodo_sp.jpg); }
  .media-detail#lifehacker .main, #modal .media-detail .bg-fade.lifehacker { background-image: url(../../service/images/bg-media-lifehacker_sp.jpg); }
  .media-detail#fuze .main, #modal .media-detail .bg-fade.fuze { background-image: url(../../service/images/bg-media-fuze_sp.jpg); }
  .media-detail#digiday .main, #modal .media-detail .bg-fade.digiday { background-image: url(../../service/images/bg-media-digiday_sp.jpg); }
  .media-detail#gene .main, #modal .media-detail .bg-fade.gene { background-image: url(../../service/images/bg-media-gene_sp.jpg); }
  .media-detail#genetv .main, #modal .media-detail .bg-fade.genetv { background-image: url(../../service/images/bg-media-genetv_sp.jpg); }
  .media-detail#cafeglobe .main, #modal .media-detail .bg-fade.cafeglobe { background-image: url(../../service/images/bg-media-cafeglobe_sp.jpg); }
  .media-detail#mylohas .main, #modal .media-detail .bg-fade.mylohas { background-image: url(../../service/images/bg-media-mylohas_sp.jpg); }
  .media-detail#glitty .main, #modal .media-detail .bg-fade.glitty { background-image: url(../../service/images/bg-media-glitty_sp.jpg); }
  .media-detail#roomie .main, #modal .media-detail .bg-fade.roomie { background-image: url(../../service/images/bg-media-roomie_sp.jpg); } }

@media screen and (max-width: 495px) { .service-img1 li { height: 94px; position: relative; overflow: hidden; }
  .service-img1 li img { width: auto; height: 100%; max-width: none; position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); } }

@media screen and (max-width: 480px) { .service-img4 { max-width: 330px; margin: 25px auto 5px; }
  .service-img4 li { width: 100%; padding-bottom: 25px; }
  .service-img4 li .img { position: relative; padding-top: 40.63492%; overflow: hidden; }
  .service-img4 li .img img { position: absolute; top: -10px; left: 0; }
  .service-menu .img { position: relative; float: none; width: auto; margin: 0 0 12px; padding-top: 40.63492%; overflow: hidden; }
  .service-menu .img img { position: absolute; top: -10px; left: 0; }
  .service-menu .text { float: none; width: auto; }
  .service-media li { width: 33.3333%; }
  .service-media-list li { width: 100%; }
  .service-media-list li .img { padding: 12% 14%; }
  .media-detail .main .media-nav .prev a:after { left: 10px; }
  .media-detail .main .media-nav .next a:after { right: 10px; } }

@media screen and (max-width: 340px) { .service-types2 .innovation, .service-types2 .branding, .service-types2 .creative { padding: 0 20px 40px; }
  .media-detail .main .media-nav li { font-size: 73.33333%; } }

@media screen and (max-width: 900px) { .works-detail .works-exp { text-align: left; }
  .works-detail .works-exp br { display: none; } }

@media screen and (max-width: 750px) { .works .slideIn_3 { padding: 0; }
  .works .category-head { margin-bottom: 40px; }
  .works-category { margin-top: 0; margin-bottom: 35px; }
  .works-category li a { font-size: 73.33333%; }
  .works-list .listBox { padding: 0 20px 10px; margin: 0; }
  .works-list .pnav { margin: -10px auto 60px; }
  .works-client ul { margin: 20px -2px -2px; }
  .works-client li { padding: 2px; }
  .works-detail .header-a { margin-top: 10px; font-size: 166.66667%; }
  .works-detail .category-head { margin: 16px 0 30px; padding: 0; }
  .works-detail .category-head .client { margin: 10px 0 8px; font-size: 100%; }
  .works-detail .category-head .website { font-size: 86.66667%; }
  .works-detail .works-exp { font-size: 100%; padding: 0 30px; }
  .works-detail .works-tag { display: none; }
  .works-kyoto .btn { font-size: 86.66667%; max-width: 280px; }
  .works-kyoto .btn a { padding: 14px 20px; } }

@media screen and (max-width: 765px) { .works-display { background-size: 178.562%; }
  .works-display .sites_bg { height: 0; padding-top: 52%; }
  .works-display .sp-pcNone { width: 60%; }
  .works-display .bg-spNone { top: 50%; margin-top: -30%; } }

@media screen and (max-width: 480px) { .works-category li { padding: 0 3px 6px; }
  .works-category li.en { width: 33.3333%; }
  .works-category li.ja { width: 50%; }
  .works-category li a { min-width: 0; padding: 0 4px; height: 32px; line-height: 32px; font-size: 66.66667%; }
  .works-list { max-width: 390px; }
  .works-list .listBox li { width: 100%; padding-bottom: 25px; }
  .works-list .listBox li .title { font-size: 86.66667%; text-align: center; }
  .works-client li { width: 33.3333%; }
  .works-detail .category-head { padding: 0 30px; }
  .works-detail .category-head br { display: none; }
  .works-detail .category-head .website { letter-spacing: 0; }
  .works-detail .works-exp { margin-top: -20px; }
  .works-detail .project-summary { padding: 20px 0 20px; }
  .works-detail .project-summary .title { float: none; width: 100%; margin-bottom: 0.4em; padding: 0 0 0.4em; border-bottom: 1px solid #E5E5E5; font-size: 100%; }
  .works-detail .project-summary .text { float: none; width: 100%; margin-bottom: 20px; margin-left: 0; line-height: 1.6; }
  .works-detail .project-summary .text p { margin-left: 0; }
  .works-detail .interview { margin: 20px 0 0; }
  .works-detail .interview .title { margin: 15px 0 8px; font-size: 120%; }
  .works-detail .interview .client { margin: 8px 0 15px; font-size: 100%; }
  .works-detail .other-works { padding: 10px 0 50px; }
  .works-img1 { margin: 30px 0 0; } }

@media screen and (max-width: 380px) { .works-list .pnav ul { -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; } }

@media screen and (max-width: 900px) { .related-article li .title { display: none; }
  .related-article li .title_sp { display: block; font-size: 93.33333%; line-height: 1.4; } }

@media screen and (max-width: 800px) { .blog-top { display: none; } }

@media screen and (max-width: 750px) { .section-news { padding: 30px 30px 50px; }
  .wrap-news .news-content { float: none; width: auto !important; }
  .blog .wrap-news .news-content { margin-right: -10px; }
  .wrap-news .news-side, .wrap-news .news-bottom { float: none; width: auto; }
  .news-content section .date, .news-content section .category li, .news-article section .date, .news-article section .category li { font-size: 86.66667%; }
  .news-content section .title, .news-article section .title { font-size: 113.33333%; }
  .news-content section .mainimg, .news-article section .mainimg { margin: 15px 0 0 !important; }
  .news-content .pnav, .news-article .pnav { margin: 20px 10px 0 0; }
  .news-content section .text { display: none; }
  .news-side, .news-bottom { padding-top: 40px; }
  .news-side .bnr, .news-bottom .bnr { max-width: 335px; margin: 0 auto 40px; }
  .header-archive { margin: 6px 0 26px; font-size: 120%; }
  .news-article { padding: 30px; }
  .news-article section .date:after { display: none; }
  .news-article section .category { display: block; }
  .news-article section .title { font-size: 140%; }
  .news-article section .interview-box { margin: -8px 0 24px; }
  .news-article section .interview-box p { font-size: 100%; line-height: 1.533; }
  .news-article .title + .entry-share { display: none; }
  .news-article .entry-share { max-width: 296px; margin: 0 auto; }
  .news-article .entry-share ul { margin: 0 -5px; }
  .news-article .entry-share li { width: 33.3333%; padding: 0 5px; }
  .news-article .entry-share li a { width: auto; height: 47px; }
  .news-article .entry-content, .news-article #special-about .body, #special-about .news-article .body { margin: 20px 0; font-size: 100%; }
  .news-article-nav { margin-top: 30px; }
  .news-article-nav a { padding: 20px 15px; }
  .news-article-nav li { font-size: 86.66667%; }
  .news-article-nav li.prev a:after { left: 12px; }
  .news-article-nav li.next a:after { right: 12px; }
  .ibk-link, .interview-link { padding: 40px 10px 0; }
  .ibk-link .btn, .interview-link .btn { font-size: 86.66667%; }
  .ibk-link .btn a, .interview-link .btn a { padding: 14px 20px; }
  .ibk-link .btn { max-width: 280px; }
  .interview-link .btn a { padding: 18px 20px; }
  .entry-content h2, #special-about .body h2 { margin: 3em 0 15px; font-size: 120%; }
  .entry-content h3, #special-about .body h3 { margin: 25px 0 15px; font-size: 106.66667%; }
  .entry-content h4, #special-about .body h4, .entry-content h5, #special-about .body h5, .entry-content h6, #special-about .body h6 { margin: 25px 0 15px; font-size: 120%; }
  .entry-content p, #special-about .body p { margin-bottom: 15px; }
  .entry-content blockquote, #special-about .body blockquote { padding: 10px 25px; }
  .entry-content blockquote:before, #special-about .body blockquote:before, .entry-content blockquote:after, #special-about .body blockquote:after { font-size: 100%; }
  .entry-content ol, #special-about .body ol, .entry-content ul, #special-about .body ul { margin-bottom: 15px; }
  .entry-content li, #special-about .body li { line-height: 1.6; }
  .entry-content img, #special-about .body img { margin-bottom: 20px; }
  .entry-content .bg_color01, #special-about .body .bg_color01 { margin-bottom: 15px; }
  .entry-author { margin: 30px 0 0; }
  .related-article { padding: 40px 0 0; }
  .related-article ul { margin-bottom: 0; }
  .related-article li .box { height: 160px; }
  .related-article li .date { font-size: 86.66667%; }
  .news-bottom { margin: -15px 0 40px; padding-top: 0; }
  .news-bottom .follow { float: none; width: auto; margin-bottom: 30px; }
  .news-bottom .follow p { font-size: 100%; }
  .news-bottom .follow p br { display: none; }
  .news-bottom .archive { float: none; width: auto; font-size: 100%; }
  .news .news-content section { padding: 10px 30px; }
  .news .news-content section .index > li { padding: 15px 0; }
  .news .news-content section .index .date { display: block; font-size: 100%; }
  .news .news-content section .index .date:after { display: none; }
  .news .news-content section .index .category li { font-size: 100%; }
  .news .news-content section .index .img { margin-bottom: 15px; }
  .news .news-content section .index .title { margin: 8px 0 0; font-size: 140%; }
  .news .news-article { padding: 30px; } }

@media screen and (max-width: 640px) { .section-news { padding: 20px 20px 50px; }
  .news-content section, .news-article section { padding-bottom: 20px; }
  .news-content section .box, .news-article section .box { padding: 20px !important; }
  .news-content section .text, .news-article section .text { display: none; }
  .news-content section.new:before, .news-article section.new:before { top: -28px; left: -28px; border-width: 28px; border-right-width: 28px; }
  .news-content section.new:after, .news-article section.new:after { top: 5px; left: 2px; font-size: 66.66667%; letter-spacing: normal; }
  .news-content .box-type2, .news-content .box-type2-list, .news-article .box-type2, .news-article .box-type2-list { display: block; }
  .news-content .box-type2 section, .news-content .box-type2-list section, .news-article .box-type2 section, .news-article .box-type2-list section { width: auto; }
  .news-content .box-type2 section .title, .news-content .box-type2-list section .title, .news-article .box-type2 section .title, .news-article .box-type2-list section .title { font-size: 113.33333%; }
  .news-content .box-type2 section.new:before, .news-content .box-type2-list section.new:before, .news-article .box-type2 section.new:before, .news-article .box-type2-list section.new:before { top: -28px; left: -28px; border-width: 28px; border-right-width: 28px; }
  .news-content .box-type2 section.new:after, .news-content .box-type2-list section.new:after, .news-article .box-type2 section.new:after, .news-article .box-type2-list section.new:after { top: 5px; left: 2px; font-size: 66.66667%; letter-spacing: normal; }
  .news-content .box-type2-list section, .news-article .box-type2-list section { width: 100%; }
  .news-content .pnav, .news-article .pnav { margin-top: 10px; }
  .header-archive { margin-top: 6px; }
  .news-article { padding: 20px; }
  .entry-author .author-img { float: none; padding: 0 0 20px; text-align: center; }
  .entry-author .author { font-size: 120%; text-align: center; }
  .entry-author .author-description { margin-top: 8px; font-size: 100%; padding-left: 0; }
  .related-article ul { margin: 10px 0 0; }
  .related-article li { float: none; width: 100%; padding: 10px 0 0; }
  .related-article li a { zoom: 1; }
  .related-article li a:after { content: ''; display: block; clear: both; overflow: auto; }
  .related-article li .img { float: left; position: relative; width: 39.68254%; padding-top: 39.68254%; overflow: hidden; }
  .related-article li .img img { position: absolute; top: 0; left: -38%; max-width: none; height: 100%; width: auto; }
  .related-article li .box { float: right; width: 60.31746%; padding: 20px; height: auto; }
  .related-article li .date { margin: 0 0 2px; color: #999; }
  .related-article li.kanren-interview .title, .related-article li.kanren-interview .title_sp { font-size: 100%; line-height: 1.6; }
  .related-article li.kanren-interview .post, .related-article li.kanren-interview .name { font-size: 93.33333%; line-height: 1.5714; }
  .news .news-content section { padding: 10px 20px; }
  .news .news-content section .index .img { min-width: 100px; margin: 10px 0 15px 10px; }
  .news .news-article { padding: 20px; } }

@media screen and (max-width: 480px) { .hide-sp { display: none !important; } }

@media screen and (max-width: 400px) { .related-article li .box { padding: 14px; } }

@media screen and (max-width: 750px) { .section-special { margin-top: 8px; padding: 25px 20px 35px; }
  .special-list .listBox li a { padding: 20px; }
  .special-list .listBox li .title { font-size: 113.33333%; padding-top: 18px; }
  .special-list .pnav ul { padding-top: 35px; } }

@media screen and (max-width: 480px) { .special-list .listBox { margin: -10px; }
  .special-list .listBox li { width: 100%; padding: 10px; } }

@media screen and (max-width: 380px) { .special-list .pnav ul { -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; } }

@media screen and (max-width: 768px) { #special-top .header { padding: 90px 0 40px; }
  .special-bg#bg2 { display: block; }
  #special-flow { background: none !important; }
  #special-flow:after { content: none; } }

@media screen and (max-width: 750px) { .special-detail .top-mission .header { font-size: 233.33333%; }
  .special-detail .top-mission .ask-sub2 { font-size: 93.33333%; text-align: left; }
  .special-detail .top-mission .ask-sub2 br { display: none; }
  .special-detail .box-special li .title_sp { padding-top: 4px; }
  .special-detail .box-special li .date { font-size: 80%; }
  .special-header-a { font-size: 133.33333%; line-height: 1.4; }
  .special-header-b { font-size: 120%; }
  #special-top .special-header-a { font-size: 126.66667%; }
  #special-top .title { font-size: 140%; line-height: 1.4; letter-spacing: -0.025em; }
  #special-top .text { text-align: left; line-height: 1.665; }
  #special-about .body { font-size: 100%; }
  #special-about .body h1, #special-about .body h2, #special-about .body h3, #special-about .body h4, #special-about .body h5 { margin: 25px 0 15px; }
  #special-about .body h1 { font-size: 140%; }
  #special-about .body h2 { font-size: 133.33333%; }
  #special-about .body h3 { font-size: 120%; }
  #special-about .body h4 { font-size: 120%; }
  #special-about .body h5 { font-size: 100%; }
  #special-about .special-merit-list .text { font-size: 100%; line-height: 1.665; }
  #special-flow .special-flow-list li { min-height: 73px; padding-left: 85px; }
  #special-flow .special-flow-list .num { font-size: 213.33333%; line-height: 65px; width: 65px; height: 65px; }
  #special-flow .special-flow-list .text { font-size: 100%; line-height: 1.665; }
  #special-user .special-user-list .user { font-size: 100%; }
  #special-user .special-user-list .title { font-size: 140%; }
  #special-user .special-user-list .point dt, #special-user .special-user-list .point dd { font-size: 100%; line-height: 1.665; }
  #special-works .lead { font-size: 120%; line-height: 1.5; }
  #special-works .title { font-size: 100%; }
  #special-works .text { font-size: 100%; line-height: 1.665; } }

@media screen and (max-width: 640px) { .special-detail .top-mission { padding: 50px 30px 30px; }
  .special-detail .box-special li .img { padding-bottom: 0; }
  #special-about { padding: 48px 45px 28px; }
  #special-about .body { margin: -25px 0 40px; }
  #special-about .special-merit-list { padding-top: 20px; }
  #special-about .special-merit-list li { padding-bottom: 22px; }
  #special-about .special-merit-list .img { float: none; width: 100%; text-align: center; padding-bottom: 14px; }
  #special-about .special-merit-list .special-header-b, #special-about .special-merit-list .text { margin-left: 0; padding-left: 0; }
  #special-about .special-merit-list .text { padding-top: 6px; }
  #special-flow { padding: 48px 45px 34px; }
  #special-flow .special-flow-list { padding: 20px 0 0; }
  #special-flow .special-flow-list li { padding-bottom: 8px; }
  #special-user { padding: 48px 45px 50px; }
  #special-user .special-user-list li { padding-top: 26px; }
  #special-user .special-user-list .title { padding: 10px 0 14px; }
  #special-user .special-user-list .point { border-bottom: none; }
  #special-user .special-user-list .point dt { float: none; padding: 16px 0 8px; }
  #special-user .special-user-list .point dd { padding: 0 0 16px 0; }
  #special-user .special-user-list .point dd:last-child { border-bottom: 1px dotted #B2B2B2; }
  #special-works { padding: 48px 45px; }
  #special-works h3.special-header-a { padding: 20px 0 16px 20px; }
  #special-works .special-works-list { margin: 0 -20px -10px; }
  #special-works .box a { padding: 20px; }
  #special-works .img { float: none; width: 100%; text-align: center; }
  #special-works .body { float: none; width: 100%; padding: 0 0 15px 0; }
  #special-works .title { padding: 7px 0 8px; } }

@media screen and (max-width: 480px) { .special-bg .bg-pc { display: none; }
  .special-bg .bg-sp { display: block; }
  #special-top .img .pc { display: none; }
  #special-top .img .sp { display: inline; }
  .special-detail .btn-ask li a { padding: 36px 40px; } }

@media screen and (max-width: 480px) and (max-width: 360px) { #special-top .text { padding-left: 30px; padding-right: 30px; }
  #special-about, #special-flow, #special-user, #special-works { padding-left: 30px; padding-right: 30px; }
  #special-flow .special-flow-list { margin-left: -10px; }
  #special-flow .special-flow-list li { min-height: 66px; padding-left: 75px; }
  #special-flow .special-flow-list .num { font-size: 186.66667%; line-height: 58px; width: 58px; height: 58px; }
  #special-works h3.special-header-a { padding-left: 10px; }
  #special-works .special-works-list { margin: 0 -10px -10px; } }

@media screen and (max-width: 750px) { .recruit .slideIn_3 { padding: 0 30px 60px; }
  .recruit .category-head { margin-bottom: 40px; }
  .recruit .header-f { text-align: left; }
  .recruit .header-f br { display: none; }
  .recruit-top { max-width: 330px; margin-bottom: -40px; }
  .recruit-top li { float: none; width: auto; padding: 0 10px 25px; }
  .recruit-top li .img { margin: 0 0 15px; }
  .recruit-top li .text { margin: 5px 0 0; }
  .recruit-top .recruitment { -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .recruit-top .recruitment li { width: 100%; -webkit-box-flex: 0; -ms-flex: 0 0 100%; flex: 0 0 100%; }
  .recruit-img1 { margin: 25px 0; }
  .recruit-img2 { margin: 25px -2px 30px; }
  .recruit-img2 li { padding: 2px; }
  .recruiting .header { margin: 0 0 15px; font-size: 120%; }
  .interview-list ul { margin: 0 -10px; }
  .interview-list li { width: 50%; padding: 30px 10px 0; }
  .interview-list li .title { font-size: 100%; }
  .interview-list li .post { font-size: 100%; }
  .environment-box { margin-top: 24px; }
  .environment-box .img { padding-bottom: 20px; }
  .environment-box .header-f { font-size: 120%; }
  .environment-box .text { font-size: 100%; text-align: left; line-height: 1.666; margin-bottom: 15px; }
  .environment-box .text br { display: none; }
  .environment-box .btn-more2 { font-size: 86.66667%; margin-top: 26px; }
  .recruit-title .jp { margin-top: 6px; }
  .environment-detail { padding-top: 50px; }
  .environment-detail:first-child { padding-top: 10px; }
  .environment-detail .head { font-size: 120%; padding-bottom: 8px; }
  .environment-detail .text { font-size: 100%; line-height: 1.666; }
  .environment-detail .img { padding-top: 15px; }
  .environment-wrap { padding: 0 30px 0; }
  .environment-wrap .btn-more2 { font-size: 86.66667%; margin: 30px auto 10px; }
  .environment-wrap .recruiting { padding-top: 45px; } }

@media screen and (max-width: 640px) { .recruiting { text-align: left; } }

@media screen and (max-width: 480px) { .recruit .header-g { text-align: left; }
  .recruit .header-g br { display: none; }
  .recruit .box-scenery { margin: 30px 0 0; }
  .recruit .box-scenery .img { float: none; width: auto; margin: 0 0 15px; text-align: center; }
  .recruit .box-scenery .text { float: none; width: auto; }
  .recruit-top .header-g { text-align: center; }
  .interview-list ul { display: block; margin: 0; }
  .interview-list li { max-width: 313px; width: 100%; margin: 0 auto; padding: 30px 0 0; } }

@media screen and (max-width: 1000px) { .ask-form-tb { padding-bottom: 20px; }
  .formBox { padding: 6%; } }

@media screen and (max-width: 700px) { .ask_text { text-align: left; }
  .ask .section-b { padding: 50px 10px; }
  .ask-form-tb { padding-bottom: 0; }
  .ask-form-tb th, .ask-form-tb td { display: block; width: 100%; }
  .ask-form-tb th { padding: 4px 0 12px; font-weight: bold; }
  .ask-form-tb .form-c1 > span:nth-child(odd), .ask-form-tb .form-c1 > span:nth-child(even), .ask-form-tb .form-r1 > span:nth-child(odd), .ask-form-tb .form-r1 > span:nth-child(even) { width: 100%; }
  .formBox #budget_radio { display: none; }
  .formBox #budget_select { display: block; } }

@media screen and (max-width: 640px) { .formBox .mw_wp_form_confirm .btnBox { display: block; width: auto; margin: 20px auto 0; }
  .formBox .field-txt { font-size: 16px; } }

@media screen and (max-width: 480px) { .formBox .privacy-box { margin-bottom: 20px; }
  .formBox #result { text-align: left; }
  .formBox .ask-btn { padding: 15px 10px; }
  .formBox .ask-form-box > span:nth-child(1) .logowrap, .formBox .ask-form-box > span:nth-child(2) .logowrap, .formBox .ask-form-box > span:nth-child(3) .logowrap, .formBox .ask-form-box > span:nth-child(4) .logowrap, .formBox .ask-form-box > span:nth-child(5) .logowrap { width: 100px; display: block; }
  .formBox .ask-form-box label { margin-left: 30px; }
  .formBox .ask-form-box .c-checked { left: -30px; } }

@media screen and (max-width: 1000px) { .formBox .ask-form-box > span { width: 50% !important; } }

@media screen and (max-width: 640px) { .formBox .ask-form-box { margin-bottom: 10px; }
  .formBox .ask-form-box p { height: auto; vertical-align: 50%; }
  .formBox .ask-form-box br { display: none; }
  .formBox .ask-form-box label { height: auto; }
  .formBox .ask-form-box img { padding-bottom: 0; }
  .formBox .ask-form-box > span { width: 100% !important; height: auto; margin-bottom: 24px !important; }
  .formBox .ask-form-box > span .logowrap { padding-top: 0 !important; } }

@media screen and (max-width: 480px) { .formBox .ask-form-box > span:nth-child(4) br { display: block; }
  .formBox .ask-form-box > span:nth-child(7) br { display: block; } }

@media screen and (max-width: 320px) { .formBox .ask-form-box > span:nth-child(2) br { display: block; } }

@media screen and (max-width: 1000px) { .ibk-top .header .title { width: 200px; }
  .ibk-top .header .copy { padding: 20px 0 33px; font-size: 428.57143%; }
  .ibk-top #scroll-btn { bottom: 46px; }
  .ibk-about .text { font-size: 114.28571%; padding: 0 40px; }
  .ibk-about .text div { padding-left: 20px; }
  .ibk-about .text div.first { padding-right: 20px; }
  .ibk-design-type { padding: 50px 20px 1px; }
  .ibk-design-type ul { display: block; }
  .ibk-design-type ul li { width: 100%; max-width: 480px; margin: 0 auto 40px; }
  .ibk-design-type .title { margin: 0 0 32px; }
  .ibk-design-type .title:after { bottom: -15px; }
  .ibk-design-type .text { min-height: 0; }
  .ibk-design-type .en { margin-top: 15px; }
  .ibk-design-type .interface, .ibk-design-type .content, .ibk-design-type .ux { padding: 0; }
  .ibk-channel .entry-box .title { top: 26px; }
  .ibk-channel .entry-box .btn-more { right: 30px; }
  .ibk-member .ibk-member-list .text .name { font-size: 142.85714%; }
  .ibk-member .ibk-member-list .text .post { padding-top: 1%; line-height: 1.6; } }

@media screen and (max-width: 800px) { .corporate .nav-corporate ul { margin: -5px; }
  .corporate .nav-corporate li { width: 50%; padding: 5px; }
  .corporate .section-nav .nav-corporate li { font-weight: bold; }
  .ibk-member .ibk-member-list .text .name { font-size: 128.57143%; }
  .ibk-member .ibk-member-list .text .post { font-size: 78.57143%; } }

@media screen and (max-width: 768px) { .ibk-about .text div.first, .ibk-about .text div.en { visibility: visible; opacity: 1; -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); }
  .ibk-design .head, .ibk-design .text, .ibk-design .img { visibility: visible; opacity: 1; -webkit-transform: translateY(0px); -ms-transform: translateY(0px); transform: translateY(0px); } }

@media screen and (max-width: 750px) { .corporate .box-outline .outline dt { font-size: 100%; }
  .corporate .nav-corporate li { font-size: 86.66667%; }
  .corporate .nav-corporate a:after { font-size: 138.46154%; }
  .corporate .message { margin-top: 45px; }
  .corporate .message .header { font-size: 120%; }
  .corporate .message .header + p { padding-top: 1em; }
  .corporate .message .img { margin: 0 0 25px; }
  .corporate .message p { font-size: 100%; }
  .corporate .box-director .img, .corporate .box-director2 .img { width: 180px; margin: 0 auto 25px; }
  .corporate .box-director .name, .corporate .box-director2 .name { font-size: 120%; }
  .corporate .box-director .post, .corporate .box-director2 .post { margin: 5px 0 20px; font-size: 100%; }
  .corporate .box-director .biog, .corporate .box-director2 .biog { margin: 30px 0 50px; padding-bottom: 40px; border-bottom: 1px solid #E5E5E5; }
  .corporate .box-director .biog dt, .corporate .box-director2 .biog dt { float: left; margin-bottom: -1.5em; }
  .corporate .box-director .biog dd, .corporate .box-director2 .biog dd { clear: both; padding: 0 0 0.2em 6em; }
  .corporate .box-director.last .biog, .corporate .last.box-director2 .biog { padding-bottom: 0; border-bottom: 0; }
  .corporate .access .header { margin: 25px 0 20px; font-size: 120%; }
  .corporate .access.kyoto { margin-top: 45px; }
  #ibk .top-mission { padding: 0 30px 80px; }
  .skrollr-desktop #ibk .ibk-bgTop_sp { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #000 url(../../images/ibk/bg-main_sp.gif) no-repeat center; background-size: cover; z-index: -2; }
  .ibk-top .header .title { width: 150px; margin: 0 auto; }
  .ibk-top .header .copy { padding: 15px 0 25px; font-size: 266.66667%; letter-spacing: 1px; line-height: 1.2; }
  .ibk-top #scroll-btn { bottom: 36px; margin-left: -18px; font-size: 106.66667%; line-height: 36px; }
  .ibk-top #scroll-btn a { width: 36px; height: 36px; border-radius: 18px; }
  .ibk-about { height: auto; }
  .ibk-about .text { position: static; -webkit-transform: none; -ms-transform: none; transform: none; font-size: 80%; padding: 100px 10px 60px; }
  .ibk-about .text div { width: 100%; padding-left: 0; }
  .ibk-about .text div.first { padding-right: 0; }
  .ibk-about .text div p { padding-bottom: 25px; }
  .ibk-design .head { padding: 54px 0 26px; font-size: 186.66667%; }
  .ibk-design .text { font-size: 80%; }
  .ibk-design .img { padding: 40px 40px 60px; }
  .ibk-design-type .title { font-size: 113.33333%; }
  .ibk-design-type .text { font-size: 73.33333%; }
  .ibk-design-type .en { font-size: 73.33333%; }
  .ibk-channel { padding-top: 45px; }
  .ibk-channel .entry-box { margin-bottom: 22px; }
  .ibk-channel .entry-box .title { top: 16px; font-size: 120%; font-weight: normal; line-height: 1.8; }
  .ibk-channel .entry-box .title .bgc-w { padding: 2px 10px; }
  .ibk-channel .entry-box .btn-more { right: 18px; font-size: 120%; width: auto; padding: 6px 20px; }
  .btn-ibk { max-width: 400px; margin: 0 auto 70px; padding: 10px 28px 0; font-size: 80%; }
  .btn-ibk a { padding: 14px 20px; }
  .btn-ibk a:after { right: 8px; margin-top: -0.8em; font-size: 80%; }
  .ibk-works .header, .ibk-member .header { font-size: 160%; padding-bottom: 45px; }
  .ibk-works .btn-ibkWorks { padding: 10px 20px 60px; font-size: 100%; }
  .ibk-works .btn-ibkWorks a { padding: 45px 20px; border: 4px solid; }
  .ibk-works .btn-ibkWorks a:after { font-size: 166.66667%; right: 12px; }
  .ibk-member .ibk-member-list { margin-bottom: 20px; }
  .ibk-member .ibk-member-list .text .post { display: none; } }

@media screen and (max-width: 640px) { .corporate .header-a + p { text-align: left; }
  .corporate .header-a + p br { display: none; }
  .corporate .box-outline .float-r { margin-top: 20px; }
  .corporate .box-outline .outline dt { margin: 20px 0 10px; }
  .corporate .corporate-group .wrap { margin: 0 -15px; }
  .corporate .corporate-group .box { padding: 0 15px; }
  .corporate .corporate-group .box .img a { padding: 48px 20px; }
  .corporate .corporate-group .box .text { margin-bottom: 30px; }
  .corporate .message .pres { padding-top: 4em; }
  .corporate .message .wrap-sign { padding-bottom: 10px; background-size: 200px 107px; }
  .corporate .box-director2 .box { width: auto; }
  .corporate .box-director2 .box.float-l, .corporate .box-director2 .box.float-r { margin: 0 0 40px; }
  .corporate .box-director2 .img { float: left; width: 125px; margin: 0 20px 20px 0; }
  .corporate .box-director2 .name { font-size: 120%; text-align: left; }
  .corporate .box-director2 .post { text-align: left; }
  .corporate .box-director2 .profile { clear: both; }
  .ibk-member .ibk-member-list { margin-bottom: 20px; }
  .ibk-member .ibk-member-list li { width: 50%; padding: 0 10px 22px; }
  .ibk-member .ibk-member-list .text .name { font-size: 160%; }
  .ibk-member .btn-ibk { margin-bottom: 50px; } }

@media screen and (max-width: 480px) { .corporate .corporate-group { margin: 0 0 -25px; }
  .corporate .corporate-group .wrap { margin: 0; }
  .corporate .corporate-group .box { float: none; width: 100%; padding: 30px 0 25px; }
  .corporate .corporate-group .box .img a { padding: 48px 20px; }
  .corporate .corporate-group .box .text { margin-top: 5px; }
  .corporate .nav-corporate { margin-bottom: 40px; }
  .corporate .nav-corporate li { float: none; width: auto; }
  .corporate .nav-corporate + .header-e { text-align: left; }
  .corporate .history .year { float: none; width: auto; margin-bottom: 12px; padding: 0 0 5px; border-bottom: 1px solid #E5E5E5; font-size: 120%; }
  .corporate .history dd { padding: 0 0 20px; }
  .corporate .history dd .month { font-weight: bold; }
  .corporate .access .wrap-map { padding-top: 100%; }
  .corporate .access .info dt { float: none; margin-bottom: 10px; padding: 0 0 8px; border-bottom: 1px solid #E5E5E5; }
  .corporate .access .info dd { margin-bottom: 25px; padding-left: 0; }
  .ibk-channel .entry-box .title { font-size: 80%; line-height: 1.5; }
  .ibk-channel .entry-box .title .bgc-w { padding: 2px 8px; }
  .ibk-channel .entry-box .btn-more { font-size: 80%; padding: 4px 15px; }
  .ibk-member .ibk-member-list .text .name { font-size: 86.66667%; } }

@media screen and (max-width: 750px) { .idl-mainimg { padding-bottom: 120px; }
  .idl-mainimg .idl-header-b + p { font-size: 100%; line-height: 1.6; text-align: left; }
  .idl-header-a { width: 223px; padding: 262px 0 382px; }
  .idl-header-b { margin: 0 0 30px; font-size: 133.33333%; }
  .idl-header-c { margin: 0 0 35px; }
  .idl-header-c img { height: 18px; }
  .idl-member li .name { font-size: 93.33333%; }
  .idl-contact { margin: 0 0 30px; line-height: 2.2; }
  .idl-sns li a { width: 48px; height: 48px; vertical-align: middle; }
  .idl-sns li a .fa { vertical-align: middle; } }

@media screen and (max-width: 640px) { .idl-bgmain { background-image: url(../../images/idl/img-main_sp.jpg); }
  .idl-mainimg .figure, .idl-mainimg .figure + p { display: none; }
  .idl-casestudy { max-width: 330px; margin: 0 auto -25px; }
  .idl-casestudy li { float: none; width: auto; padding: 0 0 25px; }
  .idl-casestudy li .text { margin: 15px 0 0; }
  .idl-casestudy li.new:before { left: -58px; }
  .idl-casestudy li.new:after { left: 8px; }
  .idl-member li { width: 33.3333%; } }

@media screen and (max-width: 480px) { .idl-member li { width: 50%; } }

@media screen and (max-width: 750px) { .box-errorp .header { font-size: 140%; text-align: center; } }

@media screen and (max-width: 640px) { .box-errorp { margin: -10px 0; padding: 0; text-align: left; }
  .box-errorp .ib { display: inline; }
  .box-errorp br { display: none; } }

@media screen and (max-width: 480px) { .news-content section.utility-section .sitemap-box .column2 { width: 100%; float: none; } }

@font-face { font-family: 'icomoon'; src: url("fonts/icomoon.eot?3hsptl"); src: url("fonts/icomoon.eot?3hsptl#iefix") format("embedded-opentype"), url("fonts/icomoon.ttf?3hsptl") format("truetype"), url("fonts/icomoon.woff?3hsptl") format("woff"), url("fonts/icomoon.svg?3hsptl#icomoon") format("svg"); font-weight: normal; font-style: normal; }

[class^="icon-"], [class*=" icon-"] { /* use !important to prevent issues with browser extensions that change fonts */ font-family: 'icomoon' !important; speak: none; font-style: normal; font-weight: normal; font-variant: normal; text-transform: none; line-height: 1; /* Better Font Rendering =========== */ -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.icon-icon-01:before { content: "\e900"; }

.icon-icon-02:before { content: "\e901"; }

/*# sourceMappingURL=infobahn.css.map */