@charset "UTF-8";
/*-------------------------------------------*/
/*	初期化
/*-------------------------------------------*/
* {
  margin: 0;
  padding: 0;
  font-size: 100%;
  box-sizing: border-box; }

body, h1, h2, h3, h4, h5, p,
ul, ol, li, dl, dt, dd,
table,
form, input {
  margin: 0;
  padding: 0; }

main, article, section, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

/*-------------------------------------------*/
/*	基本設定
/*-------------------------------------------*/
html {
  font-size: 16px;
  scroll-behavior: smooth; }
  @media screen and (max-width: 767.98px) {
    html {
      font-size: 14px; } }

html, body {
  height: 100%;
  min-height: 100%; }

body {
  font-family: 'Roboto', 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  line-height: 1.8;
  letter-spacing: 1px;
  text-align: left;
  color: #333; }

a {
  display: block;
  overflow: hidden;
  text-decoration: none;
  word-break: break-all;
  transition: 0.5s all ease 0s;
  color: #333; }
  a:hover {
    text-decoration: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

ol, ul, li {
  list-style: none; }

table {
  width: 100%;
  border: none;
  border-collapse: collapse;
  border-spacing: 0; }

tr {
  border-bottom: 1px solid #b3b8bb; }

th {
  padding: 30px 60px;
  border-right: 1px solid #b3b8bb;
  vertical-align: top;
  text-align: left;
  font-weight: lighter; }

td {
  padding: 30px 60px; }

@media screen and (max-width: 1119.98px) {
  th, td {
    padding: 24px 30px; } }
@media screen and (max-width: 767.98px) {
  th, td {
    padding: 2.5% 5%; } }

hr {
  display: none; }

picture,
img {
  vertical-align: top;
  width: 100%;
  max-width: 100%;
  height: auto;
  line-height: 0; }

input, button, textarea, select {
  /*-webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;*/
  border: none;
  outline: none; }

::selection {
  background-color: #082B5C;
  color: #fff; }

::-moz-selection {
  background-color: #082B5C;
  color: #fff; }

main {
  min-height: 85vh;
  background: #fff; }

section {
  margin-top: -100px;
  padding-top: 100px; }

@media screen and (max-width: 419.98px) {
  p {
    margin-bottom: 1.125rem; } }

h2 {
  font-weight: normal; }

h3 {
  margin-bottom: 45px;
  padding: 20px 38px;
  background: url(/mex/img/back_h3.jpg);
  background-size: 100% 100%;
  font-size: 1.8rem;
  color: #fff; }
  @media screen and (max-width: 1119.98px) {
    h3 {
      font-size: 1.6rem; } }
  @media screen and (max-width: 767.98px) {
    h3 {
      padding: 2.5% 5%;
      font-size: 1.4rem; } }
  @media screen and (max-width: 419.98px) {
    h3 {
      margin-bottom: 1.125rem;
      padding: 6px 15px;
      font-size: 1.1rem; } }

h4 {
  margin-bottom: 55px;
  padding: 18px 38px;
  border-left: 1px solid #000000;
  border-bottom: 1px solid #000000;
  font-size: 1.6rem; }
  @media screen and (max-width: 1119.98px) {
    h4 {
      font-size: 1.4rem; } }
  @media screen and (max-width: 767.98px) {
    h4 {
      padding: 1.8% 5%;
      font-size: 1.2rem; } }
  @media screen and (max-width: 419.98px) {
    h4 {
      margin-bottom: 1.125rem;
      padding: 4px 15px;
      font-size: 1rem; } }

#sub-menu {
  margin-bottom: 1px;
  background: #e0e6e9; }
  #sub-menu ul {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    padding-top: 2px;
    width: 376px;
    font-weight: bold; }
    #sub-menu ul li {
      width: 33.3%;
      max-width: 187px; }
      #sub-menu ul li a {
        display: block;
        padding: 14px 0;
        text-align: center;
        border-bottom: #e0e6e9 2px solid;
        color: #000; }
        #sub-menu ul li a:hover {
          border-bottom: #cc0000 2px solid;
          color: #cc0000; }

.Roboto {
  font-family: 'Roboto', sans-serif; }

.clear-both {
  clear: both; }
  .clear-both:after {
    content: '';
    display: table;
    clear: both; }

.clearfix {
  zoom: 1; }
  .clearfix:after {
    content: "";
    height: 0;
    display: block;
    overflow: hidden;
    clear: both; }

.wrapper {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto; }

.wrap {
  width: 82.85%;
  max-width: 1120px;
  margin: 0 auto; }
  @media screen and (max-width: 767.98px) {
    .wrap {
      width: 90%; } }

.wrap_top {
  max-width: 1400px;
  margin: 0 auto; }

.wrap_page {
  width: 82.85%;
  max-width: 1120px;
  margin: 120px auto; }
  @media screen and (max-width: 767.98px) {
    .wrap_page {
      margin: 80px auto; } }
  @media screen and (max-width: 419.98px) {
    .wrap_page {
      width: 90%;
      margin: 50px auto; } }
  .wrap_page a {
    display: inline;
    color: #cc0000; }

.inner {
  margin-left: 2px;
  margin-right: 2px;
  margin-bottom: 45px; }
  @media screen and (max-width: 419.98px) {
    .inner {
      margin-bottom: 17px; } }

.button {
  display: block;
  width: 185px;
  line-height: 3.84;
  background: black;
  text-align: center;
  font-size: 0.875rem;
  color: #fff;
  cursor: pointer;
  z-index: 3; }
  @media screen and (max-width: 767.98px) {
    .button {
      width: 160px;
      line-height: 3; } }

.list li {
  list-style-type: disc;
  list-style-position: inside;
  text-indent: -1em;
  margin-left: 1em; }

.map {
  height: 540px; }
  @media screen and (max-width: 419.98px) {
    .map {
      height: 400px; } }

.form-control {
  margin-bottom: 10px; }

/*-------------------------------------------*/
/*	表示
/*-------------------------------------------*/
[data-in] {
  transition: opacity .5s, transform .5s;
  transform: translateY(15px);
  opacity: 0; }

[data-in="1"] {
  transform: translateY(0);
  opacity: 1; }

.SP {
  display: none; }
  @media screen and (max-width: 767.98px) {
    .SP {
      display: block; } }

.PC {
  display: block; }
  @media screen and (max-width: 767.98px) {
    .PC {
      display: none; } }

/*-------------------------------------------*/
/*	アイコン
/*-------------------------------------------*/
@font-face {
  font-family: 'Material Icons';
  font-style: normal;
  font-weight: 400;
  src: url(../font/MaterialIcons-Regular.eot);
  /* For IE6-8 */
  src: local("Material Icons"), local("MaterialIcons-Regular"), url(../font/MaterialIcons-Regular.woff2) format("woff2"), url(../font/MaterialIcons-Regular.woff) format("woff"), url(../font/MaterialIcons-Regular.ttf) format("truetype"); }
.icon, .icon-sm, .icon-md, .icon-lg {
  display: inline-block;
  vertical-align: middle;
  font-family: 'Material Icons';
  font-weight: normal;
  font-style: normal;
  font-size: 1.2em;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  font-feature-settings: 'liga';
  -webkit-font-feature-settings: 'liga';
  -webkit-font-smoothing: antialiased; }

.icon-sm {
  font-size: 16px;
  line-height: 16px; }

.icon-md {
  font-size: 24px;
  line-height: 24px; }

.icon-lg {
  font-size: 32px;
  line-height: 32px; }

/*-------------------------------------------*/
/*	印刷
/*-------------------------------------------*/
@media print {
  html, body {
    height: 100%;
    min-height: 100%; } }
/*ふんわりホバー*/
#gNav a, footer a, .underline, .sub_menu li a {
  transition: 0.5s all ease 0s; }

/*ふんわり出る効果*/
header .wrap {
  -webkit-animation: fadeIn 1s ease 0s 1 normal;
  animation: fadeIn 1s ease 0s 1 normal; }

@keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 0.8; } }
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0; }
  100% {
    opacity: 0.8; } }
/*-------------------------------------------*/
/*	ヘッダー
/*-------------------------------------------*/
header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  height: 90px;
  background: #fff;
  /*--toggle--*/ }
  @media screen and (max-width: 767.98px) {
    header {
      height: 80px; } }
  @media screen and (max-width: 419.98px) {
    header {
      height: 65px; } }
  header .wrap_header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 90%;
    max-width: 1400px;
    height: 90px;
    margin: 0 auto; }
    @media screen and (min-width: 1081px) {
      header .wrap_header {
        width: 82.85%;
        max-width: 1120px; } }
    @media screen and (max-width: 1080px) and (min-width: 768px) {
      header .wrap_header {
        width: 95%; } }
    @media screen and (max-width: 767.98px) {
      header .wrap_header {
        height: 80px; } }
    @media screen and (max-width: 419.98px) {
      header .wrap_header {
        height: 65px; } }
  header nav {
    background: #fff; }
  header #logoArea {
    width: 185px; }
    @media screen and (max-width: 1200px) and (min-width: 1120px) {
      header #logoArea {
        width: 154px; } }
    @media screen and (max-width: 1119px) and (min-width: 421px) {
      header #logoArea {
        width: 134px; } }
    @media screen and (max-width: 420px) {
      header #logoArea {
        width: 110px; } }
  header #logo {
    width: 100%; }
  header .sub_menu {
    position: absolute;
    display: none;
    min-width: 190px;
    top: 68px; }
    header .sub_menu li {
      float: none;
      height: auto;
      margin-left: 0; }
      header .sub_menu li a {
        opacity: 0.8;
        padding: 15px 30px;
        background: #fff;
        font-size: 0.86rem; }
        header .sub_menu li a:hover {
          background: black;
          color: #fff; }
  header #gNav {
    display: flex;
    align-items: center;
    justify-content: right;
    line-height: 1.6;
    margin-bottom: 0;
    background: #fff;
    letter-spacing: 0.5px; }
    header #gNav > li {
      margin-left: 40px;
      background: #fff; }
      header #gNav > li:first-child {
        margin-left: 0; }
    header #gNav li:hover > .sub_menu {
      display: block; }
    header #gNav a {
      opacity: 1.0;
      border-bottom: 1px solid #fff;
      text-decoration: none;
      font-size: 0.86rem;
      font-weight: 900;
      color: #000; }
      header #gNav a:hover {
        border-bottom-color: #cc0000;
        color: #cc0000; }
        header #gNav a:hover a div + .underline {
          display: block;
          border-bottom: 1px solid #cc0000;
          color: #cc0000; }
    header #gNav p {
      margin-bottom: 0;
      font-size: 1rem; }
    @media screen and (max-width: 1399.98px) {
      header #gNav a, header #gNav p {
        font-size: 0.9rem; }
      header #gNav > li {
        margin-left: 20px; } }
    @media screen and (max-width: 1180px) and (min-width: 870px) {
      header #gNav a, header #gNav p {
        font-size: 0.8rem; }
      header #gNav > li {
        margin-left: 13px; } }
    @media screen and (max-width: 869px) and (min-width: 768px) {
      header #gNav a, header #gNav p {
        font-size: 0.7rem; }
      header #gNav > li {
        margin-left: 13px; } }
  header .wrap {
    position: relative;
    max-width: 1400px;
    height: auto; }
    header .wrap input {
      display: none; }
    @media screen and (max-width: 1119.98px) {
      header .wrap {
        width: 96%; } }
    @media screen and (max-width: 767.98px) {
      header .wrap {
        height: 80px; } }
    @media screen and (max-width: 419.98px) {
      header .wrap {
        height: 65px; } }
  header .upper_menu {
    line-height: 58px;
    text-align: right; }
    header .upper_menu li {
      display: inline-block;
      padding: 0 42px;
      vertical-align: middle;
      background: black;
      color: #fff;
      font-size: 0.86rem; }
  header .SP_menu {
    display: none; }
  @media screen and (min-width: 1400px) {
    header .upper_menu {
      line-height: 4; } }
  @media screen and (max-width: 1399.98px) {
    header .sub_menu li {
      margin-left: 0; } }
  @media screen and (max-width: 1119.98px) {
    header .sub_menu li {
      margin-left: 0; } }
  @media screen and (max-width: 767.98px) {
    header nav {
      position: static;
      width: 100%;
      margin-top: -2%; }
    header .cssacc:checked + nav {
      display: block;
      transition: .3s; }
    header .wrap {
      position: relative;
      width: 100%; }
      header .wrap label {
        position: absolute;
        top: 20px;
        right: 5%;
        display: block;
        cursor: pointer;
        z-index: 3;
        width: 30px;
        height: 40px;
        text-align: center; }
        header .wrap label span:before {
          content: "";
          top: 8px; }
        header .wrap label span:after {
          content: "";
          top: 16px; }
      header .wrap label span, header .wrap label span::before, header .wrap label span::after {
        display: block;
        position: absolute;
        width: 26px;
        border-bottom: solid 3px #000000; }
      header .wrap input {
        display: none; }
    header #navToggle {
      position: absolute;
      top: 20px;
      right: 5%;
      display: block;
      cursor: pointer;
      z-index: 3;
      width: 30px;
      height: 40px;
      text-align: center; }
      header #navToggle span {
        position: absolute;
        display: block;
        width: 26px;
        border-bottom: solid 3px #000000; }
        header #navToggle span:nth-child(1) {
          top: 9px; }
        header #navToggle span:nth-child(2) {
          top: 17px; }
        header #navToggle span:nth-child(3) {
          top: 25px; }
    header #gNav {
      display: none; }
    header #gNav_sp {
      display: flex;
      flex-wrap: wrap;
      width: 100%;
      line-height: 1.4;
      margin: 2% auto;
      padding: 2% 0;
      text-align: center;
      letter-spacing: 0.15em; }
      header #gNav_sp li {
        width: 50%;
        margin-top: 2%; }
      header #gNav_sp a {
        opacity: 1.0;
        padding-bottom: 8px;
        border-bottom: 1px solid #fff;
        text-decoration: none;
        font-size: 0.86rem;
        font-weight: 900; }
    header .sub_menu {
      position: static;
      top: auto;
      width: auto;
      display: block; }
    header .PC_menu {
      display: none; }
    header .SP_menu {
      display: block; } }
  @media screen and (max-width: 419.98px) {
    header #navToggle {
      top: 12px; }
    header .upper_menu {
      line-height: 3.44;
      margin-bottom: 16px; }
      header .upper_menu li {
        padding: 0 20px;
        font-size: 0.86rem; } }
  header .SP_menu #menu-btn-check {
    display: none; }
  header .SP_menu .menu-btn {
    position: fixed;
    top: 12px;
    right: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 100;
    width: 40px;
    height: 40px;
    background-color: #fff;
    border-radius: 2px; }
  header .SP_menu .menu-btn span, header .SP_menu .menu-btn span:before, header .SP_menu .menu-btn span:after {
    content: '';
    display: block;
    height: 3px;
    width: 24px;
    border-radius: 3px;
    background-color: #000;
    position: absolute; }
  header .SP_menu .menu-btn span:before {
    bottom: 8px; }
  header .SP_menu .menu-btn span:after {
    top: 8px; }
  header .SP_menu #menu-btn-check:checked ~ .menu-btn span {
    background-color: transparent;
    transition: 0.25s all ease 0s; }
  header .SP_menu #menu-btn-check:checked ~ .menu-btn span::before {
    bottom: 0;
    transform: rotate(45deg);
    transition: 0.25s all ease 0s; }
  header .SP_menu #menu-btn-check:checked ~ .menu-btn span::after {
    top: 0;
    transform: rotate(-45deg);
    transition: 0.25s all ease 0s; }
  header .SP_menu nav {
    position: fixed;
    top: -120%;
    left: 0;
    transition: all 0.5s; }
  header .SP_menu #menu-btn-check:checked ~ nav {
    top: 65px; }

/*--header--*/
/*-------------------------------------------*/
/*	フッター
/*-------------------------------------------*/
footer {
  clear: both;
  padding-top: 55px;
  padding-bottom: 55px;
  background: #000000;
  color: #fff; }
  footer .wrap {
    overflow: hidden; }
  footer .footer_bannerArea {
    width: 100%;
    white-space: nowrap; }
    footer .footer_bannerArea li {
      display: inline-block;
      width: 19.6%; }
  footer .footer_button img {
    display: block; }
  footer .footer_data {
    padding: 2% 0;
    font-size: 0.9rem; }
  footer .footer_link a {
    margin: 0 0 5%;
    text-decoration: underline;
    color: #fff;
    font-size: 0.9rem; }
    footer .footer_link a:hover {
      text-decoration: underline;
      color: #cc0000; }
  footer .sns {
    display: flex;
    align-items: center;
    margin: 10px 0 20px; }
    footer .sns li {
      width: 29px;
      margin-left: 14.5px; }
      footer .sns li.youtube {
        width: 118px; }
      footer .sns li:first-child {
        margin-left: 0; }
  footer .copy {
    float: left;
    margin: 0 2% 2% 0; }
  @media screen and (max-width: 767.98px) {
    footer {
      padding-top: 5%;
      padding-bottom: 5%; }
      footer .footer_bannerArea {
        float: left;
        white-space: normal; }
        footer .footer_bannerArea li {
          width: 32%; }
      footer .copy {
        float: none; } }
  @media screen and (max-width: 419.98px) {
    footer .footer_bannerArea li {
      width: 49%; }
    footer #pagetop a {
      width: 70px; } }

/*--footer--*/
#pagetop {
  position: relative;
  z-index: 100; }
  #pagetop a {
    position: absolute;
    bottom: -1px;
    right: 0;
    width: 80px; }
  #pagetop img {
    display: block; }

/*	TOP
-------------------------------------------*/
#top {
  /*--info--*/ }
  #top #mainimage {
    width: 100%;
    margin-top: 90px;
    background: linear-gradient(to right, #151e3c, #121e39); }
    #top #mainimage img {
      display: block;
      max-width: 1400px;
      margin: 0 auto; }
    @media screen and (max-width: 767.98px) {
      #top #mainimage {
        width: 100%;
        height: auto;
        margin-top: 80px; }
        #top #mainimage img {
          width: 100%;
          position: relative; }
        #top #mainimage .wrap {
          padding: 0; } }
    @media screen and (max-width: 419.98px) {
      #top #mainimage {
        margin-top: 65px; } }
  #top #virtual {
    margin-top: 28px;
    text-align: center; }
    #top #virtual img {
      max-width: 800px; }
    #top #virtual p {
      line-height: 1.2;
      margin-top: 28px;
      margin-bottom: 92px;
      font-size: 1.125rem; }
      #top #virtual p span {
        display: block;
        margin-bottom: 5px;
        font-weight: bold;
        font-size: 1.6rem; }
    @media screen and (max-width: 767.98px) {
      #top #virtual p {
        margin-bottom: 14.28%; } }
  #top #info .info_toptitle {
    padding: 28px;
    font-size: 2.4rem;
    font-weight: bold; }
  #top #info .info_list li {
    padding: 28px 0; }
    #top #info .info_list li:nth-child(2n-1) {
      background: #f2f6f8; }
  #top #info .info_list a {
    background-image: url(/mex/img/arrow.png);
    background-repeat: no-repeat;
    background-position: right;
    background-size: 40px; }
  #top #info .info_date {
    display: inline-block;
    margin-right: 40px;
    vertical-align: top; }
  #top #info .info_title {
    display: inline-block;
    width: 79%;
    margin-right: 40px; }
  #top #info .info_arrow {
    display: inline-block;
    width: 40px;
    vertical-align: top;
    margin-top: 12px;
    float: right; }
  @media screen and (max-width: 1399.98px) {
    #top #info .info_date, #top #info .info_title {
      margin-right: 2%; } }
  @media screen and (max-width: 767.98px) {
    #top #info .info_date {
      width: 100%; }
    #top #info .info_toptitle, #top #info .info_list li {
      padding: 2% 0; }
    #top #info .info_toptitle {
      font-size: 2rem; } }
  @media screen and (max-width: 419.98px) {
    #top #info .info_arrow {
      margin-top: 6px; }
    #top #info .info_list li {
      padding: 4% 0; } }
  @media screen and (max-width: 319.98px) {
    #top #info .info_toptitle {
      font-size: 1.6rem; } }
  #top #online {
    margin: 128px auto 38px; }
    #top #online img {
      display: block; }
    @media screen and (max-width: 419.98px) {
      #top #online {
        margin: 90px auto 30px; } }
  #top .attention {
    padding: 28px;
    background: #f2f6f8; }
    #top .attention p {
      max-width: 850px;
      margin: 0 auto; }
  #top .top_button {
    width: 90%;
    max-width: 488px;
    margin: 42px auto;
    line-height: 1.8;
    padding: 14px 5px;
    font-weight: bold; }
  #top .top_subtitle {
    margin-top: 65px;
    margin-bottom: 20px;
    font-size: 0.9rem; }
  #top .top_title {
    line-height: 1;
    font-size: 2.6rem;
    letter-spacing: 1px; }
  @media screen and (max-width: 1119.98px) {
    #top .wrap_top {
      width: 100%; }
    #top .top_subtitle {
      margin-top: 10%; } }
  @media screen and (max-width: 900px) {
    #top .top_button {
      margin: 6% auto;
      padding: 8px 0;
      font-size: 0.6875rem; }
    #top .top_title {
      font-size: 2.2rem; } }
  @media screen and (max-width: 767.98px) {
    #top .attention {
      padding: 7.14% 4%; }
    #top .top_button {
      width: 88%;
      line-height: 1.8;
      font-size: 0.86rem; }
    #top .top_subtitle {
      margin-top: 0;
      margin-bottom: 4%;
      padding-top: 6%; }
    #top .top_title {
      font-size: 2rem; }
    #top .page_title_back {
      margin-top: 80px; } }
  @media screen and (max-width: 600px) {
    #top .top_button {
      max-width: 280px; } }
  @media screen and (max-width: 419.98px) {
    #top .top_title {
      font-size: 1.6rem; } }

/*--top--*/
#top_entry {
  background-image: url(/mex/img/backtop_content01.png); }

#top_access {
  background-image: url(/mex/img/backtop_content02.png); }

#top_access, #top_entry {
  width: 50%;
  height: calc(100vw/3.2558);
  max-height: 430px;
  margin-top: 0;
  padding-top: 0;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  text-align: center;
  color: #fff; }

@media screen and (min-width: 768px) {
  #top_entryaccess {
    display: flex;
    align-items: flex-start; } }
@media screen and (max-width: 767.98px) {
  #top_access, #top_entry {
    width: 100%;
    height: calc(100vw*0.6142); } }
.top_semiwork {
  width: 100%;
  padding-top: 0;
  padding-bottom: 100px;
  /*background-image: url(/mex/img/backtop_semiwork.png);
  background-size: 100% 100%;
  background-repeat: no-repeat; */ }
  .top_semiwork h2 {
    font-size: 2.4rem;
    font-weight: bold;
    word-wrap: break-word; }
    .top_semiwork h2 div {
      font-size: 1.125rem;
      font-weight: normal; }
  .top_semiwork p {
    margin-bottom: 10px; }
  .top_semiwork > div {
    padding: 100px 0 0; }
  @media screen and (min-width: 1120px) {
    .top_semiwork h2.virtual {
      font-size: 2.75rem; } }
  @media screen and (max-width: 1119.98px) {
    .top_semiwork > div {
      padding: 80px 10% 0; }
    .top_semiwork h2 {
      line-height: 1.2;
      margin-bottom: 5px;
      font-size: 1.6rem; }
    .top_semiwork p {
      line-height: 1.4;
      font-size: 14px; }
    .top_semiwork a {
      line-height: 3; } }
  @media screen and (max-width: 767.98px) {
    .top_semiwork {
      margin: 0;
      padding-top: 0; }
      .top_semiwork > div {
        margin-top: 0;
        padding: 7.14% 4%; }
      .top_semiwork h2 {
        font-size: 2rem;
        text-align: center; }
      .top_semiwork a {
        position: static;
        margin: 4% auto; }
      .top_semiwork p {
        display: inline-block;
        text-align: center;
        width: 100%;
        margin-bottom: 0; } }

.top_seminar {
  max-width: 1000px;
  justify-content: flex-end;
  flex-direction: row-reverse;
  margin-bottom: 92px; }
  .top_seminar p:nth-child(2) {
    margin-top: 4%; }
    .top_seminar p:nth-child(2) span {
      margin-left: 18px; }
  .top_seminar p:nth-child(3) {
    font-weight: bold; }
  @media screen and (max-width: 1399.98px) {
    .top_seminar p:nth-child(2) {
      margin-top: 0; } }

.top_seminar_data {
  width: 44.8%;
  padding: 0 92px 0 65px; }
  @media screen and (max-width: 1399.98px) {
    .top_seminar_data {
      padding: 0 1% 0 5.7%; } }
  @media screen and (max-width: 767.98px) {
    .top_seminar_data {
      width: 100%;
      padding: 0; } }

.top_workshop {
  max-width: 1000px;
  justify-content: space-between; }
  .top_workshop .top_seminar_data > div {
    font-size: 1.4rem;
    font-weight: bold; }
    @media screen and (max-width: 767.98px) {
      .top_workshop .top_seminar_data > div {
        text-align: center; } }

.top_workshop_data {
  width: 44.8%;
  padding: 0 0 0 92px; }
  @media screen and (max-width: 1399.98px) {
    .top_workshop_data {
      padding: 0 0 0 6%; } }
  @media screen and (max-width: 1119.98px) {
    .top_workshop_data {
      padding: 0; } }
  @media screen and (max-width: 767.98px) {
    .top_workshop_data {
      width: 100%; } }

.top_seminar, .top_workshop {
  display: flex;
  align-items: flex-start;
  position: relative;
  height: auto;
  margin: 0 auto; }
  .top_seminar img, .top_workshop img {
    width: 55.2%;
    max-width: 550px; }
  @media screen and (max-width: 1399.98px) {
    .top_seminar, .top_workshop {
      width: 100%; } }
  @media screen and (max-width: 767.98px) {
    .top_seminar, .top_workshop {
      display: block;
      height: auto;
      max-height: none;
      /*margin-bottom: 14.28%;*/
      margin-bottom: 3%;
      padding-top: 0; }
      .top_seminar img, .top_workshop img {
        display: block;
        width: 100%;
        margin: 0 auto; } }

.top_dx h2 {
  line-height: 1.4; }
.top_dx h2 div {
  line-height: 1.8; }
@media print, screen and (min-width: 1120px) {
  .top_dx h2 div {
    margin-bottom: 0.5625rem; } }

.top_dm h2 {
  font-size: 2.2rem;
  white-space: nowrap; }
  .top_dm h2 div {
    margin-bottom: 4px; }
  @media screen and (max-width: 1119.98px) {
    .top_dm h2 {
      font-size: 1.6rem; } }
  @media screen and (max-width: 767.98px) {
    .top_dm h2 {
      font-size: 2rem; }
      .top_dm h2 div {
        margin-bottom: 2px; } }

#top_leaflet {
  padding: 28px 20px;
  background: #e0e6e9;
  text-align: center;
  font-size: 1.125rem; }
  #top_leaflet .wrap_top {
    display: flex;
    align-items: center;
    justify-content: center; }
  #top_leaflet .leaflet-image, #top_leaflet .leaflet-button-area {
    width: 50%; }
  #top_leaflet .leaflet-image img {
    display: block;
    width: 90%;
    max-width: 550px;
    margin: 0 auto; }
  #top_leaflet .leaflet-button-area span {
    display: inline-block; }
  #top_leaflet .leaflet-button-area a.button {
    margin: 8px auto 0; }
  @media screen and (max-width: 767.98px) {
    #top_leaflet .wrap_top {
      display: block; }
    #top_leaflet .leaflet-image, #top_leaflet .leaflet-button-area {
      width: 100%; }
    #top_leaflet .leaflet-image img {
      width: 100%;
      margin: 0 auto 8px; } }

#top_video {
  max-width: 800px;
  margin: 100px auto 0;
  margin: 80px auto 72px;
  padding-top: 0 !important; }
  #top_video h2 {
    font-size: 2.4rem;
    text-align: center;
    font-weight: bold;
    word-wrap: break-word; }
    #top_video h2 div {
      font-size: 1.125rem;
      font-weight: normal; }
  #top_video .video {
    position: relative;
    width: 100%;
    height: 0;
    overflow: hidden;
    padding-top: 56.25%; }
    #top_video .video iframe, #top_video .video video {
      position: absolute;
      display: block;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
  @media screen and (max-width: 1119.98px) {
    #top_video {
      margin: 80px auto 52px; }
      #top_video h2 {
        line-height: 1.2;
        margin-bottom: 5px;
        font-size: 1.6rem; } }
  @media screen and (max-width: 767.98px) {
    #top_video {
      margin: 60px auto 52px;
      padding-top: 0; }
      #top_video h2 {
        font-size: 2rem; } }

#top_speech {
  max-width: 800px;
  margin: 0 auto; }
  #top_speech h2 {
    text-align: center; }
  @media screen and (max-width: 1119.98px) {
    #top_speech {
      padding: 100px 10% 0 !important; } }
  @media screen and (max-width: 767.98px) {
    #top_speech {
      max-width: 550px;
      padding: 7.14% 4% !important; }
      #top_speech h2 {
        font-size: 2rem; } }

#top_contest {
  max-width: 800px;
  margin: 0 auto; }
  #top_contest h2 {
    text-align: center; }
  @media screen and (max-width: 1119.98px) {
    #top_contest {
      padding: 100px 10% 0 !important; } }
  @media screen and (max-width: 767.98px) {
    #top_contest {
      max-width: 550px;
      padding: 7.14% 4% !important; }
      #top_contest h2 {
        font-size: 2rem; } }

#archive {
  transition: 0.5s all ease 0s;
  width: 50%;
  padding: 20px 0 0; }
  #archive:hover {
    opacity: 0.8; }
  #archive > div > .archive_banner {
    width: 90%;
    max-width: 488px;
    margin: 0 auto;
    border: 4px solid #d80511;
    background: #fff; }
  #archive .top_button {
    margin: 0 auto; }
  @media screen and (max-width: 767.98px) {
    #archive {
      width: 100%; }
      #archive > div > .archive_banner {
        width: 88%; }
      #archive .top_button {
        width: 88%;
        line-height: 1.8;
        font-size: 0.86rem; } }
  @media screen and (max-width: 600px) {
    #archive .top_button, #archive > div > .archive_banner {
      max-width: 280px; } }

/*	Page
-------------------------------------------*/
.page_title_back {
  display: flex;
  align-items: center;
  width: 100%;
  height: 230px;
  margin-top: 90px;
  background-image: url(/mex/img/back_pagetitle.png);
  background-size: 100% 100%;
  background-position: center; }
  @media screen and (min-width: 1400px) {
    .page_title_back {
      background-size: 100%; } }
  @media screen and (max-width: 1399.98px) {
    .page_title_back {
      height: calc(100vw/6.0869); } }
  @media screen and (max-width: 767.98px) {
    .page_title_back {
      margin-top: 80px; } }
  @media screen and (max-width: 419.98px) {
    .page_title_back {
      margin-top: 65px; } }

.page_title {
  width: 82.85%;
  max-width: 1120px;
  line-height: 1.8;
  margin: 0 auto;
  font-size: 2rem;
  letter-spacing: 1px;
  color: #fff; }
  @media screen and (max-width: 1119.98px) {
    .page_title {
      font-size: 1.6rem; } }
  @media screen and (max-width: 767.98px) {
    .page_title {
      width: 90%;
      font-size: 1.4rem; } }
  @media screen and (max-width: 600px) {
    .page_title {
      font-size: 1.2rem; } }
  @media screen and (max-width: 419.98px) {
    .page_title {
      line-height: 1.6;
      font-size: 1.1rem; } }
  @media screen and (max-width: 319.98px) {
    .page_title {
      font-size: 0.96rem; } }

.page_title_eng {
  font-size: 1.8rem;
  font-weight: bold; }
  @media screen and (max-width: 1119.98px) {
    .page_title_eng {
      font-size: 1.6rem; } }
  @media screen and (max-width: 767.98px) {
    .page_title_eng {
      font-size: 1.4rem; } }
  @media screen and (max-width: 600px) {
    .page_title_eng {
      font-size: 1.2rem; } }
  @media screen and (max-width: 419.98px) {
    .page_title_eng {
      font-size: 1.1rem; } }
  @media screen and (max-width: 319.98px) {
    .page_title_eng {
      font-size: 0.96rem; } }

/*	開催概要 about
---------------------------------------------*/
#about table {
  margin-bottom: 45px; }
  #about table th {
    width: 30%; }
  @media screen and (max-width: 419.98px) {
    #about table {
      margin-bottom: 17px; } }
#about h3 {
  margin-bottom: 0; }
#about h4 {
  margin-bottom: 0; }
#about td ul li {
  display: flex; }
#about td.flex ul {
  margin-top: 2rem; }
  #about td.flex ul:first-child {
    margin-top: 0; }
  #about td.flex ul li span {
    width: 60px; }
  #about td.flex ul li p {
    width: calc(100% - 60px); }
#about td.flex2 ul {
  margin-top: 2rem; }
  #about td.flex2 ul:first-child {
    margin-top: 0; }
  #about td.flex2 ul li span {
    width: 96px; }
  #about td.flex2 ul li p {
    width: calc(100% - 96px); }
#about td.flex3 ul {
  margin-top: 2rem; }
  #about td.flex3 ul:first-child {
    margin-top: 0; }
  #about td.flex3 ul li span {
    width: 30px; }
  #about td.flex3 ul li p {
    width: calc(100% - 30px); }
#about td.flex-detail ul {
  margin-top: 1rem; }
  #about td.flex-detail ul li span {
    width: 185px;
    padding-right: 12px; }
  #about td.flex-detail ul li p {
    width: calc(100% - 185px); }
  @media screen and (max-width: 767.98px) {
    #about td.flex-detail ul li {
      flex-wrap: wrap; }
      #about td.flex-detail ul li span {
        width: 100%;
        padding-right: 0; }
      #about td.flex-detail ul li p {
        width: 100%;
        margin-left: 1rem; } }

/*	交通案内 access
---------------------------------------------*/
#access dl dt:nth-child(n+2) {
  margin-top: 10px; }

#access dl dd {
  display: flex; }

#access ul {
  margin-top: 20px; }

#access ul li:nth-child(n+1) {
  margin-top: 16px; }

#bus p {
  margin-bottom: 10px; }

#bus, #parking {
  scroll-padding-top: 100px; }

@media screen and (min-width: 768px) {
  .access_img {
    width: 50%; } }
/*	出展のご案内 exhibit
---------------------------------------------*/
#exhibit table {
  margin-bottom: 45px; }
  #exhibit table th {
    width: 30%; }
  @media screen and (max-width: 767.98px) {
    #exhibit table tr, #exhibit table th, #exhibit table td {
      display: block; }
    #exhibit table tr {
      margin-bottom: 2%;
      border: 1px solid #b2b8bb; }
      #exhibit table tr:first-child {
        border-top: none; }
    #exhibit table th {
      width: 100%;
      border: none;
      border-bottom: 1px solid #b2b8bb; } }
  @media screen and (max-width: 419.98px) {
    #exhibit table {
      margin-bottom: 17px; } }
#exhibit ul {
  margin-left: 2%; }
  #exhibit ul li {
    list-style-type: disc;
    list-style-position: inside; }
#exhibit .closed {
  margin-top: 20px;
  padding: 2%;
  border: 2px solid #e60012; }
  #exhibit .closed p {
    margin-bottom: 2%;
    text-align: center;
    font-weight: bold;
    color: #e60013; }
    @media screen and (max-width: 419.98px) {
      #exhibit .closed p {
        margin-bottom: 30px;
        text-align: left; } }
#exhibit .flex {
  display: flex; }
  #exhibit .flex span {
    margin-right: 8px; }
#exhibit #agreement {
  margin-top: -100px;
  padding-top: 100px; }

#covid ul {
  margin-top: 20px;
  margin-left: 0;
  padding: 0 2%; }
  #covid ul li {
    list-style: none; }
    #covid ul li span {
      margin-right: 5px; }

/*	過去の実績 Past
---------------------------------------------*/
#past {
  /*--#past_photo--*/ }
  @media screen and (min-width: 768px) {
    #past td:first-child {
      width: 40%; }
    #past td img {
      width: 250px; } }
  @media screen and (max-width: 767.98px) {
    #past td {
      display: block; } }
  #past td a {
    display: block; }
    #past td a:nth-child(3) {
      margin-top: 20px; }
  #past td span {
    font-weight: bold; }
  #past .theme {
    text-align: center;
    font-size: 1.25rem;
    font-weight: bold; }
  #past .catch {
    margin-bottom: 30px;
    text-align: center;
    letter-spacing: 0;
    font-size: 1.8rem;
    font-weight: bold;
    color: #cc0000; }
  #past #past_top h3 {
    margin-bottom: 0; }
  #past #past_top tr {
    border: none; }
  @media screen and (max-width: 767.98px) {
    #past #past_top img {
      display: block;
      width: 90%;
      margin: 0 auto; } }
  #past #exhibit_table td:nth-child(1) {
    width: 305px; }
  #past #exhibit_table td:nth-child(2) {
    width: 810px; }
  @media screen and (max-width: 1119.98px) {
    #past #exhibit_table td:nth-child(1) {
      width: 25%; }
    #past #exhibit_table td:nth-child(2) {
      width: 65%; } }
  @media screen and (max-width: 767.98px) {
    #past #exhibit_table td:nth-child(1) {
      width: 100%; }
    #past #exhibit_table td:nth-child(2) {
      width: 100%; } }
  #past #maker #exhibit_table td {
    width: 50%;
    padding: 2% 3%;
    text-align: left; }
    @media screen and (max-width: 767.98px) {
      #past #maker #exhibit_table td {
        display: block;
        width: 100%; } }
  #past #past_photo tr:last-child {
    background: #f2f6f8;
    font-weight: bold; }
  #past #past_photo tr.total {
    background: #f2f6f8;
    font-weight: bold; }
  #past #past_photo th {
    vertical-align: middle; }
  #past #past_photo ul {
    display: flex;
    flex-wrap: wrap; }
    #past #past_photo ul li {
      width: 24%;
      margin-top: 10px;
      margin-left: 1.3333%; }
      #past #past_photo ul li:first-child {
        margin-left: 0%; }
      #past #past_photo ul li img {
        display: block; }
      #past #past_photo ul li div {
        font-size: 0.86rem; }
  #past #past_photo.new ul li {
    width: 48%;
    margin-left: 2%; }
    #past #past_photo.new ul li:nth-child(-n+2) {
      margin-top: 0; }
  @media screen and (min-width: 1120px) {
    #past #past_photo ul.photo2 {
      width: 50%; }
      #past #past_photo ul.photo2 li {
        width: 49%; } }
  @media screen and (min-width: 768px) {
    #past #past_photo th {
      width: 33.3%; }
    #past #past_photo ul li:nth-child(-n+4) {
      margin-top: 0; } }
  @media screen and (max-width: 767.98px) {
    #past #past_photo th, #past #past_photo td {
      display: block;
      border-right: none;
      border-top: 1px solid #b3b8bb; }
    #past #past_photo th:first-child {
      border-top: none; }
    #past #past_photo ul li {
      width: 48%;
      margin-left: 2%; }
      #past #past_photo ul li:nth-child(2n-1) {
        margin-left: 0; }
      #past #past_photo ul li:nth-child(-n+2) {
        margin-top: 0; } }

/*--past--*/
/*	プライバシーポリシー
---------------------------------------------*/
#policy h2.page_title {
  font-size: 1.2rem; }
  @media screen and (max-width: 767.98px) {
    #policy h2.page_title {
      font-size: 0.9rem; } }

/*	事前登録
---------------------------------------------*/
#visitor .button {
  display: block;
  width: 90%;
  max-width: 300px;
  line-height: 1.5;
  margin: 2% auto 0 auto;
  padding: 0.375rem 0.75rem;
  border: 1px solid transparent;
  border-color: #1492b2;
  border-radius: 0.25rem;
  background-color: #1492b2;
  font-size: 1.25rem;
  color: #fff; }
#visitor .prevention {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 600px;
  margin: 0 auto; }
  #visitor .prevention li {
    width: 32%; }

/*	場内マップ Map
---------------------------------------------*/
#map .layout {
  position: relative;
  margin-bottom: 84px;
  padding: 28px 40px;
  background: #e0e6e9; }
#map .link_area {
  position: relative; }
#map .link_a1, #map .link_b1, #map .link_c1, #map .link_d1,
#map .link_a3, #map .link_b3, #map .link_c3, #map .link_d3,
#map .link_a4, #map .link_b4, #map .link_c4, #map .link_d4, #map .link_dm {
  position: absolute; }
#map .link_A1, #map .link_B1, #map .link_C1, #map .link_D1,
#map .link_A3, #map .link_B3, #map .link_C3, #map .link_D3,
#map .link_A4, #map .link_B4, #map .link_C4, #map .link_D4 {
  position: absolute; }
#map .link_a1, #map .link_A1 {
  top: 21%;
  left: 23.5%;
  width: 23.25%;
  padding-top: 19.5%; }
#map .link_b1, #map .link_B1 {
  top: 54.5%;
  left: 23.5%;
  width: 23.25%;
  padding-top: 18.15%; }
#map .link_c1, #map .link_C1 {
  top: 21%;
  left: 46.75%;
  width: 33.5%;
  padding-top: 19.5%; }
#map .link_d1, #map .link_D1 {
  top: 54.5%;
  left: 46.75%;
  width: 33.5%;
  padding-top: 18.15%; }
#map .link_a3, #map .link_A3 {
  top: 32.25%;
  left: 19.75%;
  width: 28%;
  padding-top: 14.75%; }
#map .link_b3, #map .link_B3 {
  top: 57.75%;
  left: 19.75%;
  width: 28%;
  padding-top: 13.5%; }
#map .link_c3, #map .link_C3 {
  top: 22.75%;
  left: 47.75%;
  width: 38.5%;
  padding-top: 20.25%; }
#map .link_d3, #map .link_D3 {
  top: 57.75%;
  left: 47.75%;
  width: 38.5%;
  padding-top: 17%; }
#map .link_a4, #map .link_A4 {
  top: 24.5%;
  left: 10.75%;
  width: 44%;
  padding-top: 18.5%; }
#map .link_b4, #map .link_B4 {
  top: 47.75%;
  left: 10.75%;
  width: 44%;
  padding-top: 14.75%; }
#map .link_c4, #map .link_C4 {
  top: 24.5%;
  left: 56.25%;
  width: 33%;
  padding-top: 20.75%; }
#map .link_d4, #map .link_D4 {
  top: 50.5%;
  left: 56.25%;
  width: 33%;
  padding-top: 12.5%; }
#map .link_dm {
  top: 29.75%;
  right: 15%;
  width: 4.75%;
  padding-top: 8.75%; }
#map .detail_img {
  margin: 0 auto 9% auto; }
#map .entire_img {
  position: absolute;
  bottom: 30px;
  right: 40px;
  width: 258px;
  border: 1px solid #b3b8bb;
  box-shadow: #b3b8bb 0 0 20px; }
#map .click {
  margin-bottom: 28px;
  text-align: right; }
  #map .click span {
    padding-left: 30px;
    background-image: url("/mex/img/icon_search.png");
    background-repeat: no-repeat;
    background-size: contain; }
#map .back {
  display: block;
  margin-bottom: 9.58%;
  font-weight: bold;
  color: #333; }
  #map .back span {
    padding-left: 28px;
    background-image: url("/mex/img/icon_back.jpg");
    background-repeat: no-repeat;
    background-size: 18px 21px; }
#map .red h4 {
  border-left: 1px solid #cc0000;
  border-bottom: 1px solid #cc0000; }
#map .red h4, #map .red a, #map .red td:nth-child(2) {
  color: #cc0000; }
#map .red tr:nth-child(2n) {
  background: #fdf7f7; }
#map .red th {
  background: #cc0000;
  color: #fff; }
#map .blue h4 {
  border-left: 1px solid #0038ab;
  border-bottom: 1px solid #0038ab; }
#map .blue h4, #map .blue a, #map .blue td:nth-child(2) {
  color: #0038ab; }
#map .blue tr:nth-child(2n) {
  background: #f7f9fc; }
#map .blue th {
  background: #0038ab;
  color: #fff; }
#map .green h4 {
  border-left: 1px solid #007e18;
  border-bottom: 1px solid #007e18; }
#map .green h4, #map .green a, #map .green td:nth-child(2) {
  color: #007e18; }
#map .green tr:nth-child(2n) {
  background: #f7fbf8; }
#map .green th {
  background: #007e18;
  color: #fff; }
#map .yellow h4 {
  border-left: 1px solid #f7ae08;
  border-bottom: 1px solid #f7ae08; }
#map .yellow h4, #map .yellow a, #map .yellow td:nth-child(2) {
  color: #f7ae08; }
#map .yellow tr:nth-child(2n) {
  background: #fffcf7; }
#map .yellow th {
  background: #f7ae08;
  color: #fff; }
#map .dx h4 {
  border-left: 1px solid #7030A0;
  border-bottom: 1px solid #7030A0; }
#map .dx h4, #map .dx a, #map .dx td:nth-child(2) {
  color: #7030A0; }
#map .dx tr:nth-child(2n) {
  background: #f8f7fd; }
#map .dx th {
  background: #7030A0;
  color: #fff; }
#map .dm h4 {
  border-left: 1px solid #7030A0;
  border-bottom: 1px solid #7030A0; }
#map .dm h4, #map .dm a, #map .dm td:nth-child(2) {
  color: #7030A0; }
#map .dm tr:nth-child(2n) {
  background: #f8f7fd; }
#map .dm th {
  background: #7030A0;
  color: #fff; }
@media screen and (max-width: 1119.98px) {
  #map .detail_img {
    margin: 0 auto 5% auto; }
  #map .entire_img {
    right: 4%;
    bottom: 5%;
    width: 38%; }
  #map .back {
    margin-top: 2%;
    margin-bottom: 8%; } }
@media screen and (max-width: 767.98px) {
  #map .layout {
    margin-bottom: 45px;
    padding: 3%; }
  #map .click {
    margin-bottom: 3%;
    text-align: left;
    font-size: 0.8rem; }
    #map .click span {
      padding-left: 25px; }
  #map .back {
    margin-bottom: 4%; }
  #map #sub-menu ul {
    width: 80%; }
    #map #sub-menu ul li a {
      width: 50%; } }
@media screen and (max-width: 419.98px) {
  #map .layout {
    margin-bottom: 34px;
    padding: 3%; } }

/*--#map--*/
/*	出展者一覧
---------------------------------------------*/
#exhibit_table tr:nth-child(2n) {
  background: #f7f7f7; }
#exhibit_table th, #exhibit_table td {
  border: 1px solid #b3b8bb;
  box-sizing: border-box; }
#exhibit_table th {
  width: 80px;
  padding: 24px 0;
  text-align: center;
  vertical-align: middle;
  border-left: none; }
#exhibit_table td {
  padding: 24px 18px; }
  #exhibit_table td:nth-child(2) {
    width: 265px; }
  #exhibit_table td:nth-child(3) {
    width: 770px;
    border-right: none; }
#exhibit_table.dx th:first-child, #exhibit_table.dm th:first-child {
  width: 80px; }
#exhibit_table.dx td:first-child, #exhibit_table.dm td:first-child {
  width: 80px; }
#exhibit_table.dx td:nth-child(2), #exhibit_table.dm td:nth-child(2) {
  width: 355px; }
#exhibit_table.dx td:nth-child(3), #exhibit_table.dx td:nth-child(4), #exhibit_table.dm td:nth-child(3), #exhibit_table.dm td:nth-child(4) {
  width: 342.5px; }
#exhibit_table.dx td span, #exhibit_table.dm td span {
  display: inline-block; }
#exhibit_table.dm td:last-child > div {
  display: flex; }
@media screen and (max-width: 1119.98px) {
  #exhibit_table td {
    padding: 2% 3%; }
    #exhibit_table td:nth-child(2) {
      width: 25%; }
    #exhibit_table td:nth-child(3) {
      width: 65%; } }
@media screen and (max-width: 767.98px) {
  #exhibit_table {
    margin-bottom: 18%; }
    #exhibit_table tr {
      display: flex;
      flex-wrap: wrap;
      border-bottom: none; }
      #exhibit_table tr:first-child {
        border-top: 1px solid #b3b8bb; }
    #exhibit_table th, #exhibit_table td {
      border: none;
      border-bottom: 1px solid #b3b8bb; }
    #exhibit_table th {
      width: 20%;
      padding: 2% 3%;
      border-right: 1px solid #b3b8bb; }
    #exhibit_table td:nth-child(2) {
      width: 80%; }
    #exhibit_table td:nth-child(3) {
      width: 100%; }
    #exhibit_table.dx tr:first-child, #exhibit_table.dm tr:first-child {
      display: none; }
    #exhibit_table.dx td:nth-child(2), #exhibit_table.dm td:nth-child(2) {
      width: calc(100% - 80px); }
    #exhibit_table.dx td:nth-child(3), #exhibit_table.dx td:nth-child(4), #exhibit_table.dm td:nth-child(3), #exhibit_table.dm td:nth-child(4) {
      width: 100%; } }

/*	場内マップ Map
---------------------------------------------*/
#map #sub-menu.virtual li {
  width: 48%; }
  #map #sub-menu.virtual li a {
    width: 100%; }
#map #virtual .virtual_1, #map #virtual .virtual_3a, #map #virtual .virtual_3b, #map #virtual .virtual_4a, #map #virtual .virtual_4b, #map #virtual .virtual_4b-2 {
  position: absolute; }
#map #virtual .virtual_1 {
  top: 3.25%;
  left: 2%;
  width: 95.75%;
  padding-top: 54%; }
#map #virtual .virtual_3a {
  top: 16%;
  left: 2.25%;
  width: 43%;
  padding-top: 47%; }
#map #virtual .virtual_3b {
  top: 15.5%;
  left: 46.25%;
  width: 41.5%;
  padding-top: 47%; }
#map #virtual .virtual_4a {
  top: 16.75%;
  left: 4%;
  width: 52.25%;
  padding-top: 79.5%; }
#map #virtual .virtual_4b {
  top: 15.75%;
  left: 54.75%;
  width: 42.75%;
  padding-top: 42.5%; }
#map #virtual .virtual_4b-2 {
  top: 1.75%;
  left: 52.5%;
  width: 23.5%;
  padding-top: 15.5%; }
#map #virtual .virtual_company {
  top: 44.75%;
  left: 25%;
  width: 4.75%;
  padding-top: 2.75%;
  position: absolute;
  background: #e5017f80; }
#map #virtual .company {
  margin-top: 28px; }
  #map #virtual .company span {
    background: linear-gradient(transparent 50%, #e5017f52 50%); }
#map #virtual .virtual h4 {
  border-left: 1px solid #e5017f;
  border-bottom: 1px solid #e5017f; }
#map #virtual .virtual h4, #map #virtual .virtual a, #map #virtual .virtual td:nth-child(2) {
  color: #e5017f; }
#map #virtual .virtual tr {
  background: #fbe7f0; }
#map #virtual .virtual th {
  background: #e5017f;
  color: #fff; }

/*	セミナー・ワークショップ Seminar Workshop
---------------------------------------------*/
#semi_work #sub-menu ul {
  width: 561px;
  margin: 0 auto;
  padding-top: 2px;
  font-weight: bold; }
  @media screen and (max-width: 767.98px) {
    #semi_work #sub-menu ul {
      width: 100%; } }

.semi_work table {
  margin-top: 45px;
  border-top: 1px solid #b3b8bb; }
.semi_work tr {
  border-left: 1px solid #b3b8bb; }
.semi_work th {
  display: none; }
.semi_work td {
  border-right: 1px solid #b3b8bb; }
.semi_work td:nth-child(2) {
	width: 23%;
	padding-right: 2%;
	padding-left: 2%;
	text-align: center; }
.semi_work td:nth-child(4) {
	width: 77%;
	padding: 2%; }
  .semi_work td > span {
    padding: 4px 8px;
    background: #007e18;
    text-align: center;
    color: #fff; }
    .semi_work td > span.no3 {
      background: #cc0000 !important; }
    .semi_work td > span.no4 {
      background: #0038ab !important; }
.semi_work dl {
  clear: both;
  width: 100%; }
  .semi_work dl:nth-child(1) {
    font-weight: bold; }
.semi_work dt, .semi_work dd {
  float: left; }
.semi_work dt {
  width: 70px; }
.semi_work dd {
  width: calc(100% - 70px);
  padding-left: 1%; }
.semi_work input[type=checkbox] {
  -ms-transform: scale(1.5, 1.5);
  -webkit-transform: scale(1.5, 1.5);
  transform: scale(1.5, 1.5); }
@media screen and (max-width: 1119.98px) {
  .semi_work table {
    margin-top: 0;
    border: none; }
  .semi_work th, .semi_work td {
    display: flex;
    flex-wrap: wrap;
    padding: 2% 3%;
    border: none; }
  .semi_work th:nth-child(2n-1), .semi_work td:nth-child(2n) {
    border-top: 1px solid #c3c9cb; }
  .semi_work th:nth-child(1), .semi_work th:nth-child(3) {
    border-right: 1px solid #c3c9cb; }
  .semi_work th:nth-child(5), .semi_work td:nth-child(6) {
    display: block;
    width: 100%; }
  .semi_work tr {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 4%;
    border-right: 1px solid #b3b8bb;
    border-bottom: 1px solid #b3b8bb; }
  .semi_work th {
    width: 30%; }
  .semi_work td {
    width: 70%; }
  .semi_work td:nth-child(2) {
	  display: flex; align-items: center; justify-content: space-between;
	  width: 70%;
      text-align: left;
  }
  .semi_work td:nth-child(4) {
    width: 70%;
    padding: 2%;
  }
    .semi_work td > span {
      width: 80px;
      height: 28px;
      padding: 2px 4px; }
      .semi_work td > span.no1, .semi_work td > span.no3, .semi_work td > span.no4 {
        width: 80px;
        height: 28px;
        padding: 2px 4px; }
  .semi_work input[type=checkbox] {
    margin-left: 12px; }
  .semi_work .semi_work_item {
    display: none !important; }
  .semi_work .semi_work_openfor, .semi_work .semi_work_end {
    margin-left: 5%; }
  .semi_work .semi_work_button {
    margin-bottom: 50px; }
    .semi_work .semi_work_button button {
      padding: 3% 2%; } }
@media screen and (max-width: 767.98px) {
  .semi_work .no1, .semi_work .no3, .semi_work .no4 {
    width: 50px;
    height: 28px;
    padding: 1px 4px; }
  .semi_work .no5 {
    width: auto;
    height: 28px;
    padding: 1px 4px; } }

/*--.semi_work--*/
.semi_work_openfor {
  color: #cc0000; }

.semi_work_end {
  color: #0038ab; }

.semi_work_item {
  text-align: center; }
  .semi_work_item td:first-child {
    min-width: 120px;
    padding: 15px 0; }

.semi_work_button {
  margin-top: -100px;
  padding-top: 100px;
  text-align: center; }
  .semi_work_button button {
    margin-right: 1%;
    padding: 1% 2%;
    border-color: #1492b2;
    background-color: #1492b2;
    font-size: 1rem;
    color: #fff; }

#e-messe .semi_work td:nth-child(2) {
  width: 14%;
  text-align: left; }
#e-messe .semi_work td:nth-child(4) {
  width: 74%; }
@media screen and (max-width: 1119.98px) {
  #e-messe .semi_work td:nth-child(2) {
    width: 70%;
    text-align: left; }
  #e-messe .semi_work td:nth-child(3) {
    width: 100%;
    border-right: none; }
  #e-messe .semi_work td:nth-child(4) {
    width: auto; } }

/*	特別企画 Special
---------------------------------------------*/
#special {
  /*参加企業一覧*/ }
  #special .mainimg {
    display: block;
    max-width: 896px;
    margin: 0 auto; }
  #special .images {
    display: flex;
    justify-content: space-around;
    align-items: center;
    max-width: 800px;
    margin: 0px auto; }
    #special .images li {
      width: 49%;
      max-width: 340px; }
  #special .expenses {
    margin-bottom: 10px;
    text-align: center;
    font-size: 1.25rem;
    font-weight: bold; }
  #special .catch {
    margin: 20px 0 0;
    padding: 10px 10px 0;
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold; }
    #special .catch.catch1 {
      background: #e0e6e9; }
    #special .catch.catch2 {
      margin-bottom: 10px;
      color: #cc0000; }
    #special .catch span {
      margin-left: 5px;
      font-size: 85%; }
  #special .viewing {
    padding: 15px;
    border: 2px solid #224d7c;
    border-radius: 5px;
    font-weight: bold;
    color: #224d7c; }
  #special .number {
    width: 320px;
    margin: 1.5% auto;
    padding: 1.5% 2%;
    border-radius: 50%;
    background: #014ea1;
    text-align: center;
    font-size: 1.6rem;
    color: #fff100; }
  #special .notice {
    padding: 2%;
    border-radius: 5px;
    border: 1px solid #5a5559;
    background: #e5edfd; }
  #special .data {
    display: flex;
    flex-wrap: wrap;
    margin-top: 10px;
    padding: 20px;
    border-radius: 5px;
    background: #fabe00; }
    #special .data > div:nth-child(1) {
      width: 100%;
      font-weight: bold; }
    #special .data > div:nth-child(2) {
      width: 60%;
      padding-left: 10px;
      box-sizing: border-box; }
    #special .data > div:nth-child(3) {
      width: 40%; }
    @media screen and (max-width: 1119.98px) {
      #special .data > div:nth-child(2), #special .data > div:nth-child(3) {
        width: 100%;
        padding-left: 10px; } }
  #special .copy {
    max-width: 600px;
    margin: 0 auto 40px; }
    #special .copy li {
      border-left: 6px solid #008cd6;
      padding: 0 20px 0 15px;
      font-size: 1.6rem;
      font-weight: bold; }
      #special .copy li:first-child {
        margin-bottom: 20px; }
  @media screen and (max-width: 767.98px) {
    #special .catch {
      font-size: 1.2rem; }
    #special .copy li {
      font-size: 1.375rem;
      padding: 0 1% 0 2%; } }
  @media screen and (max-width: 419.98px) {
    #special img {
      width: 100%; }
    #special .images {
      width: 100%; }
    #special .number {
      width: 95%;
      padding: 2%; }
    #special .copy li {
      font-size: 1.2rem; } }
  #special .list {
    margin-top: 40px; }
    #special .list li {
      margin-left: 0;
      list-style: none;
      text-indent: 0; }
    #special .list > li > div:nth-child(1) {
      font-size: 1.25rem;
      font-weight: bold;
      letter-spacing: 0;
      color: #e60012; }
    #special .list .info {
      max-width: 600px;
      margin: 20px auto;
      padding-bottom: 5px;
      border-bottom: 2px dashed #e60012; }
      #special .list .info:first-child {
        margin-top: 0; }
    #special .list .gift {
      max-width: none;
      margin-top: 40px;
      padding: 20px 20px 28px;
      border-radius: 5px;
      background: #fcd577;
      text-align: center; }
      #special .list .gift .item {
        max-width: 800px;
        margin: 20px auto 0;
        color: #333; }
        #special .list .gift .item > div {
          margin-top: 20px;
          padding: 12px 8px 20px;
          border-radius: 5px;
          background: #6cbb5d; }
        @media print, screen and (min-width: 768px) {
          #special .list .gift .item {
            display: flex;
            justify-content: space-between;
            font-size: 85%; }
            #special .list .gift .item > div {
              width: 49%; } }
        @media screen and (max-width: 500px) {
          #special .list .gift .item {
            font-size: 85%; } }
      #special .list .gift > div.title {
        font-weight: bold;
        font-size: 1.375rem;
        color: #e60012; }
      #special .list .gift > p br {
        display: none; }
      #special .list .gift ul {
        display: flex;
        justify-content: center;
        align-items: flex-start;
        margin-top: 10px; }
        #special .list .gift ul li {
          width: 50%;
          margin-left: 1%;
          text-align: center;
          color: #fff; }
          #special .list .gift ul li:first-child {
            margin-left: 0; }
          #special .list .gift ul li span {
            display: block;
            font-size: 1rem;
            font-weight: bold;
            color: #fff100; }
          #special .list .gift ul li img {
            display: block;
            width: 92%;
            max-width: 225px;
            margin: 0 auto 5px; }
      #special .list .gift .note {
        display: flex;
        justify-content: center;
        margin-bottom: 0;
        font-size: 85%; }
      @media screen and (max-width: 767.98px) {
        #special .list .gift {
          padding: 20px 20px 20px; }
          #special .list .gift .item {
            padding: 0 2% 13.581px; }
          #special .list .gift ul {
            flex-wrap: wrap;
            margin-top: 16.419px; }
            #special .list .gift ul li {
              width: 48%;
              margin-bottom: 6.419px; } }
      @media screen and (max-width: 419.98px) {
        #special .list .gift {
          padding: 20px 2% 20px; }
          #special .list .gift .item {
            padding: 0 2% 0; }
          #special .list .gift ul {
            margin-top: 12px; }
          #special .list .gift > p br {
            display: block; } }
  #special .title {
    width: 90%;
    max-width: 300px;
    margin: 0 auto;
    text-align: center;
    font-size: 1.5rem;
    font-weight: bold;
    color: #fff; }
  #special .button {
    display: block;
    font-weight: 400;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    user-select: none;
    border: 1px solid transparent;
    padding: 0.375rem 0.75rem;
    font-size: 1.25rem;
    line-height: 1.5;
    border-radius: 0.25rem;
    color: #fff;
    background-color: #1492b2;
    margin: 45px auto 0 auto;
    width: 90%;
    max-width: 300px; }
  #special .menu_button li {
    margin-top: 10px; }
    #special .menu_button li a {
      position: relative;
      width: 100%;
      padding: 0.55rem 0.75rem;
      border-radius: 5px;
      background: #e0e6e9;
      text-align: center;
      font-size: 1rem;
      font-weight: bold;
      color: #333; }
    #special .menu_button li:first-child a {
      background-color: #1492b2;
      color: #fff; }
  @media screen and (min-width: 768px) {
    #special .menu_button {
      display: flex;
      justify-content: center; }
      #special .menu_button li {
        /*width:31.3%;*/
        width: 90%;
        max-width: 300px; }
        #special .menu_button li:first-child {
          margin-right: 20px; } }
  @media screen and (max-width: 419.98px) {
    #special .menu_button li {
      margin-top: 25px; } 
      #special .button {
          margin: 30px auto;
      }
}

/*--special--*/
#list table a {
  text-decoration: underline;
  font-weight: bold;
  color: #333; }
#list table td > div {
  display: flex;
  justify-content: space-between;
  align-items: center; }
  #list table td > div .movie_title {
    width: 70%; }
  #list table td > div > div {
    width: calc(100% - 58px); }
#list table td > div.archive {
  display: flex;
  justify-content: flex-start;
  align-items: center; }
  #list table td > div.archive a {
    display: flex;
    height: 28px;
    margin-bottom: 10px;
    padding: 2px 16px;
    border-radius: 5px;
    background: #cc0000;
    text-decoration: none;
    color: #fff; }
#list table td span {
  display: block;
  width: 132px;
  height: 28px;
  margin-bottom: 10px;
  padding: 2px 4px;
  text-align: center; }
  #list table td span.hybrid {
    background: #e95283;
    color: #fff; }
  #list table td span.web {
    background: #fff100; }
  #list table td span.meet {
    background: #0599d9;
    color: #fff; }
#list table td span.icon, #list table td span.icon-sm, #list table td span.icon-md, #list table td span.icon-lg {
  display: inline;
  width: auto;
  height: auto;
  margin: 1px 10px 0 0;
  padding: 0;
  font-size: 20px; }
#list table td a.movie {
  background: url("/mex/img/special/icon_movie.jpg");
  width: 58px;
  height: 43px;
  display: inline-block;
  background-size: 100%;
  background-repeat: no-repeat;
  margin-left: 15px; }
#list table td:last-child a {
  display: block;
  text-decoration: underline;
  font-size: 90%;
  font-weight: normal;
  color: #cc0000; }
#list .inner {
  margin-top: -100px;
  padding-top: 100px; }

/*--list--*/
#schedule table a {
  color: #333333;
  font-weight: bold;
  text-decoration: underline; }
#schedule table td > div {
  display: flex;
  justify-content: space-between;
  align-items: center; }
  #schedule table td > div div:first-child {
    width: 70%; }
#schedule table td span {
  display: block;
  width: 132px;
  height: 28px;
  padding: 2px 4px;
  text-align: center; }
  #schedule table td span.hybrid {
    background: #e95283;
    color: #fff; }
  #schedule table td span.web {
    background: #fff100; }
  #schedule table td span.meet {
    background: #0599d9;
    color: #fff; }

#exhibit_table ul {
  display: flex;
  justify-content: center; }
  #exhibit_table ul li {
    width: 31.3%; }
    #exhibit_table ul li a {
      display: inline-block;
      width: 100%;
      padding: 4px;
      background: #0794d3;
      text-align: center;
      color: #fff; }
    #exhibit_table ul li.meet {
      margin-right: 2%; }
    #exhibit_table ul li.web {
      margin-left: 2%; }
      #exhibit_table ul li.web a {
        background: #ffdd0e;
        color: #333; }
    #exhibit_table ul li.hybrid a {
      background: #fc528b; }
  @media screen and (max-width: 767.98px) {
    #exhibit_table ul {
      justify-content: space-between; }
      #exhibit_table ul li {
        width: 48.5%; } }

#m-detail #sub-menu ul {
  width: 748px; }

/*企業説明スケジュール*/
#timetable h4 + p {
  margin-bottom: 1.125rem;
  font-weight: bold;
  color: #e60113; }
#timetable #list table td span {
  margin: 5px 0 0; }
#timetable #list table td:last-child a {
  text-decoration: underline;
  font-weight: bold;
  color: #333; }
  #timetable #list table td:last-child a.button {
    display: block;
    width: 185px;
    line-height: 16px;
    margin: 0 auto;
    padding: 0.55rem 0.75rem;
    border-radius: 5px;
    background: #1492b2;
    text-align: center;
    text-decoration: none;
    font-size: 0.875rem;
    color: #fff; }
#timetable #list table td > div > div {
  width: 100%; }
#timetable #exhibit_table tr {
  background: #fff; }
  #timetable #exhibit_table tr:nth-child(2n) td span {
    width: auto;
    margin: 0 1px;
    font-size: 0.875rem; }
#timetable #exhibit_table td:nth-child(2) {
  width: 268px; }
#timetable #exhibit_table ul {
  text-align: center; }
  #timetable #exhibit_table ul div {
    padding: 12px 0; }
#timetable #exhibit_table p {
  margin-bottom: 6px; }
@media screen and (max-width: 899.98px) {
  #timetable #exhibit_table tr, #timetable #exhibit_table th, #timetable #exhibit_table td {
    border: none; }
  #timetable #exhibit_table th, #timetable #exhibit_table td {
    display: block;
    border-bottom: 1px solid #b3b8bb; }
  #timetable #exhibit_table tr {
    display: flex;
    border-top: 1px solid #b3b8bb; }
    #timetable #exhibit_table tr:nth-child(2n) {
      margin-bottom: 20px;
      border: none;
      border-bottom: 1px solid #b3b8bb; }
      #timetable #exhibit_table tr:nth-child(2n) td {
        padding: 12px 0 0;
        width: 100%;
        border: none; }
    #timetable #exhibit_table tr:last-child {
      margin-bottom: 0; }
  #timetable #exhibit_table th {
    display: block;
    width: 20%;
    padding: 2% 3%;
    border-right: 1px solid #b3b8bb; }
  #timetable #exhibit_table td:nth-child(2) {
    width: 80%; }
  #timetable #exhibit_table ul {
    flex-wrap: wrap; }
    #timetable #exhibit_table ul li {
      width: 19.5%; } }
#timetable #Thu tr:nth-child(2n) td span {
  background: #ddeffd; }
@media screen and (max-width: 899.98px) {
  #timetable #Thu tr:nth-child(2n) td {
    background: #f3f9fe; } }
#timetable #Fri tr:nth-child(2n) td span {
  background: #fbe9f3; }
@media screen and (max-width: 899.98px) {
  #timetable #Fri tr:nth-child(2n) td {
    background: #fdf7fb; } }
#timetable #Sat tr:nth-child(2n) td span {
  background: #e3eee2; }
@media screen and (max-width: 899.98px) {
  #timetable #Sat tr:nth-child(2n) td {
    background: #f6faf6; } }
#timetable .schedule ul li {
  margin-top: 10px;
  border: none; }
  #timetable .schedule ul li:first-child {
    margin-top: 0; }
  #timetable .schedule ul li a {
    display: block;
    width: 100%;
    line-height: 1.5;
    padding: 0.55rem 0.75rem;
    border-radius: 5px;
    background-color: #1492b2;
    font-size: 1rem;
    font-weight: bold;
    color: #fff; }
@media screen and (min-width: 420px) {
  #timetable .schedule ul {
    display: flex;
    justify-content: space-between; }
    #timetable .schedule ul li {
      width: 31.3%;
      margin-top: 0; } }

#special-detail {
  /*--exhibit_table--*/ }
  #special-detail h3 {
    background: #014ea1; }
  #special-detail .image-area-s {
    width: 100%;
    max-width: 490px;
    margin: 0 auto; }
  #special-detail .slick-prev:before, #special-detail .slick-next:before {
    color: #000; }
  #special-detail .number {
    font-size: 1.4rem;
    font-weight: bold;
    color: #014ea1; }
    @media screen and (max-width: 767.98px) {
      #special-detail .number {
        font-size: 1.2rem; } }
    @media screen and (max-width: 419.98px) {
      #special-detail .number {
        font-size: 1rem; } }
  #special-detail .item.movie.slick-slide {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 7.625%; }
  #special-detail .item.movie iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%; }
  #special-detail #special .button {
    font-size: 1rem;
    font-weight: bold; }
  #special-detail #info .movie_button h5 {
    margin: 20px 0 5px;
    text-align: center;
    font-weight: bold;
    color: #333; }
  #special-detail #info .movie_button .movie {
    margin: 0 auto;
    background: url(/mex/img/special/icon_movie.jpg);
    width: 72.5px;
    height: 53.75px;
    background-size: 100%;
    background-repeat: no-repeat; }
  @media screen and (min-width: 768px) {
    #special-detail #info .contents-area {
      display: flex;
      justify-content: space-between;
      align-items: center; }
    #special-detail #info dl {
      width: 78%; }
    #special-detail #info .movie_button {
      width: 20%; } }
  @media screen and (max-width: 419.98px) {
    #special-detail #info dl dd {
      width: 100%; }
    #special-detail #info dl dt {
      background: #014ea1; } }
  #special-detail #business {
    margin-top: 0;
    padding-top: 0; }
    #special-detail #business ul, #special-detail #business li {
      list-style-type: disc; }
    #special-detail #business ul {
      margin-left: 2em; }
  #special-detail #exhibit_table #Thu tr {
    background: #f3f9fe; }
    #special-detail #exhibit_table #Thu tr td span {
      background: #ddeffd; }
  #special-detail #exhibit_table #Fri tr {
    background: #fdf7fb; }
    #special-detail #exhibit_table #Fri tr td span {
      background: #fbe9f3; }
  #special-detail #exhibit_table #Sat tr {
    background: #f6faf6; }
    #special-detail #exhibit_table #Sat tr td span {
      background: #e3eee2; }
  #special-detail #exhibit_table table {
    margin-bottom: 20px; }
  #special-detail #exhibit_table tr td span {
    display: block;
    width: auto;
    height: 28px;
    margin: 0 1px;
    padding: 2px 4px;
    text-align: center;
    font-size: 0.875rem; }
  #special-detail #exhibit_table td:first-child {
    width: 25%;
    max-width: 265px;
    background: #fff; }
  #special-detail #exhibit_table td:nth-child(2) {
    width: 75%; }
  #special-detail #exhibit_table ul {
    text-align: center; }
    #special-detail #exhibit_table ul div {
      padding: 12px 0; }
  @media screen and (max-width: 767.98px) {
    #special-detail #exhibit_table tr, #special-detail #exhibit_table th, #special-detail #exhibit_table td, #special-detail #exhibit_table td:first-child, #special-detail #exhibit_table td:nth-child(2) {
      display: block;
      width: 100%;
      max-width: none; }
    #special-detail #exhibit_table td:nth-child(2) {
      padding-top: 12px;
      padding-bottom: 0; }
    #special-detail #exhibit_table ul {
      flex-wrap: wrap; }
      #special-detail #exhibit_table ul li {
        width: 19.5%; } }

#m-detail #special-detail dl {
  background: #014ea1; }
  #m-detail #special-detail dl dt {
    width: 256px; }
    @media screen and (max-width: 419.98px) {
      #m-detail #special-detail dl dt {
        width: 100%; } }

/*特別企画参加企業一覧*/
@media screen and (min-width: 768px) {
  #detail_s #exhibit_table td:nth-child(2) {
    width: 378px; }
  #detail_s #exhibit_table td:nth-child(3) {
    width: calc(100% - 572px); } }

/*	コンテスト contest
---------------------------------------------*/
#contest {
  margin-top: 90px;
  /*開催概要*/
  /*応募に関する諸注意•権利規定 */ }
  @media screen and (max-width: 767.98px) {
    #contest {
      margin-top: 80px; } }
  @media screen and (max-width: 419.98px) {
    #contest {
      margin-top: 65px; } }
  #contest .wrap_page {
    max-width: 894px; }
  #contest h3 {
    position: relative;
    margin-bottom: 24px;
    background: none;
    text-align: center;
    color: #1fbaee; }
    #contest h3:before {
      content: "";
      position: absolute;
      bottom: 10px;
      left: 0;
      right: 0;
      width: 36px;
      height: 4px;
      margin: 0 auto;
      background-color: #1fbaee; }
      @media screen and (max-width: 419.98px) {
        #contest h3:before {
          bottom: 0;
          width: 28px;
          height: 2px; } }
  #contest .mainimg {
    display: block;
    max-width: 896px;
    margin: 0 auto 20px auto;
    border-radius: 8px; }
  #contest .idea {
    padding: 5%;
    background-color: #1eb9ee; }
  @media screen and (max-width: 419.98px) {
    #contest img {
      width: 100%; } }
  #contest .list {
    margin-bottom: 5%;
    padding: 5%;
    border: 2px solid #1ebbee;
    border-radius: 8px; }
    #contest .list li {
      list-style: none;
      text-indent: 0; }
    #contest .list > li > h4 {
      margin: 0;
      padding: 0;
      border: none;
      font-weight: bold;
      font-size: 1.25rem; }
      #contest .list > li > h4:nth-child(1) {
        font-size: 1.375rem;
        color: #1fbaee;
        letter-spacing: 0; }
    #contest .list > li > p {
      margin: 0;
      padding: 0 2%; }
    #contest .list .info {
      max-width: 894px;
      margin: 40px auto;
      padding-bottom: 5px;
      border-bottom: 2px dashed #1fbaee; }
      #contest .list .info:first-child {
        margin-top: 0; }
      #contest .list .info:last-child {
        margin-bottom: 0; }
    #contest .list .target p {
      margin: 0;
      padding: 0 2%; }
    #contest .list .target span {
      display: block;
      margin-left: 2%; }
    #contest .list .award {
      margin: 0;
      padding: 0 2%; }
      #contest .list .award ul li {
        display: flex; }
        #contest .list .award ul li p {
          display: flex;
          justify-content: space-between;
          width: 72px;
          text-align: justify; }
  #contest .note {
    margin-bottom: 5%;
    padding: 5%;
    border: 2px solid #1ebbee;
    border-radius: 8px; }
    #contest .note ul {
      margin-top: 40px; }
      #contest .note ul li {
        display: flex;
        margin-top: 20px;
        list-style: none;
        text-indent: 0; }
        #contest .note ul li span {
          margin-right: 0.5rem;
          color: #1fbaee; }
  #contest .data {
    display: flex;
    flex-wrap: wrap;
    margin-top: 10px;
    padding: 2%;
    border-radius: 5px;
    background: #1ebbee;
    color: #fff; }
    #contest .data > div:nth-child(1) {
      width: 100%;
      font-weight: bold; }
    #contest .data > div:nth-child(2) {
      width: 43%;
      margin-top: 10px;
      padding-left: 2%;
      box-sizing: border-box; }
    #contest .data > div:nth-child(3) {
      width: 55%;
      margin-top: 10px; }
    @media screen and (max-width: 1119.98px) {
      #contest .data > div:nth-child(2), #contest .data > div:nth-child(3) {
        width: 100%;
        padding-left: 10px; } }
  #contest .button {
    display: block;
    font-weight: 400;
    text-align: center;
    white-space: nowrap;
    vertical-align: middle;
    user-select: none;
    border: 1px solid transparent;
    padding: 15px;
    font-size: 1rem;
    line-height: 1.5;
    border-radius: 0.25rem;
    color: #fff;
    background-color: #063191;
    margin: 40px auto;
    width: 90%;
    max-width: 320px; }

/*--contest--*/
/*	出展者検索 Search 共通
---------------------------------------------*/
#maker {
  /*--sub-menu--*/
  /*--exhibit_table--*/ }
  #maker #sub-menu {
    margin-bottom: 1px;
    background: #e0e6e9; }
    #maker #sub-menu ul {
      width: 561px;
      margin: 0 auto;
      padding-top: 2px;
      font-weight: bold; }
      @media screen and (max-width: 767.98px) {
        #maker #sub-menu ul {
          width: 80%; } }
      @media screen and (max-width: 419.98px) {
        #maker #sub-menu ul {
          width: 100%; } }
      #maker #sub-menu ul li a {
        display: block;
        float: left;
        width: 187px;
        line-height: 54px;
        border-bottom: #e0e6e9 2px solid;
        text-align: center;
        color: #000; }
        @media screen and (max-width: 767.98px) {
          #maker #sub-menu ul li a {
            width: 100%; } }
        #maker #sub-menu ul li a:hover {
          border-bottom: #cc0000 2px solid;
          color: #cc0000; }
  #maker #exhibit_table a {
    font-weight: bold;
    color: #333; }
  #maker #exhibit_table th {
    width: 80px;
    padding: 24px 4px;
    text-align: center; }
  #maker #exhibit_table td:nth-child(2) {
    width: 365px;
    padding: 0 4px;
    text-align: center; }
  #maker #exhibit_table td:nth-child(3) {
    width: auto; }
  @media screen and (max-width: 1119.98px) {
    #maker #exhibit_table th {
      width: 10%; }
    #maker #exhibit_table td {
      padding: 2% 3%; }
      #maker #exhibit_table td:nth-child(2) {
        width: 25%; }
      #maker #exhibit_table td:nth-child(3) {
        width: 65%; } }
  @media screen and (max-width: 767.98px) {
    #maker #exhibit_table {
      margin-bottom: 18%; }
      #maker #exhibit_table tr {
        display: flex;
        flex-wrap: wrap;
        margin: 2% 0;
        border: 1px solid #b3b8bb;
        border-bottom: 0; }
        #maker #exhibit_table tr:first-child {
          margin-top: 0;
          border-top: 1px solid #b3b8bb; }
      #maker #exhibit_table th, #maker #exhibit_table td {
        border: none;
        border-bottom: 1px solid #b3b8bb; }
      #maker #exhibit_table th {
        width: 100%;
        padding: 2% 3%; }
      #maker #exhibit_table td {
        padding: 2% 3%; }
        #maker #exhibit_table td:nth-child(2) {
          width: 100%;
          padding: 4px; }
        #maker #exhibit_table td:nth-child(3) {
          width: 100%; } }

/*--maker--*/
#maker_exhibit #exhibit_table th {
  width: 365px;
  padding: 24px 4px;
  text-align: center; }
#maker_exhibit #exhibit_table td:nth-child(2) {
  width: 80px;
  padding: 0 4px;
  text-align: center; }
#maker_exhibit #exhibit_table td:nth-child(3) {
  width: auto; }
@media screen and (max-width: 1119.98px) {
  #maker_exhibit #exhibit_table th {
    width: 40%;
    padding: 3% 3%; }
  #maker_exhibit #exhibit_table td:nth-child(2) {
    width: 10%; } }

/*--maker_exhibit--*/
/*	50音検索 Search
---------------------------------------------*/
#list50 ul {
  display: flex;
  flex-wrap: wrap; }
  #list50 ul li {
    margin-right: 9px;
    vertical-align: middle;
    border: 1px solid #d2d2d2;
    text-align: center; }
    #list50 ul li:last-child {
      margin-right: 0; }
    #list50 ul li a {
      display: table-cell;
      width: 43px;
      height: 43px;
      vertical-align: middle;
      color: #333; }
    @media screen and (max-width: 767.98px) {
      #list50 ul li {
        margin-bottom: 9px; } }
    @media screen and (max-width: 419.98px) {
      #list50 ul li {
        width: 18.5%;
        margin-right: 1%;
        margin-bottom: 1%;
        vertical-align: middle;
        border: 1px solid #d2d2d2;
        text-align: center; }
        #list50 ul li:nth-child(5n) {
          margin-right: 0; }
        #list50 ul li:last-child {
          margin-right: 0; }
        #list50 ul li a {
          display: table-cell;
          width: 18.5%;
          height: 15.45vw;
          vertical-align: middle;
          color: #333; } }
#list50 .selected {
  background: #e0e6e9; }

/*	メーカー検索 Maker
---------------------------------------------*/
#search_maker form {
  display: flex;
  flex-wrap: wrap; }
#search_maker input[type="text"] {
  width: 60%;
  max-width: 600px;
  padding: 1% 2%;
  line-height: 1.5;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
  font-size: 1rem; }
#search_maker input[type="submit"], #search_maker input[type="submit"] {
  padding: 1% 2%;
  border-color: #1492b2;
  background-color: #1492b2;
  font-size: 1rem;
  color: #fff; }
#search_maker nput[type="submit"]:nth-child(3) {
  width: 12%;
  max-width: 120px;
  margin-left: 1%; }
#search_maker p {
  margin-top: 1%;
  padding-bottom: 2%; }
@media screen and (max-width: 767.98px) {
  #search_maker input[type="text"] {
    width: 74%; }
  #search_maker input[type="submit"]:nth-child(3) {
    width: 20%;
    margin-left: 1%; }
  #search_maker input[type="submit"] {
    padding: 2% 4%; } }
@media screen and (max-width: 419.98px) {
  #search_maker p {
    padding-bottom: 0; } }

/*	展示品検索 Exhibit
---------------------------------------------*/
#search_exhibit form {
  margin: 2%; }
#search_exhibit input[type=checkbox] {
  -ms-transform: scale(1.5, 1.5);
  -webkit-transform: scale(1.5, 1.5);
  transform: scale(1.5, 1.5);
  margin-right: 2%; }
@media screen and (max-width: 767.98px) {
  #search_exhibit input[type="submit"] {
    padding: 2% 4%; } }

/*	企業詳細 detail
---------------------------------------------*/
#m-detail section {
  margin-bottom: 45px; }
#m-detail h5 {
  font-size: 1.4rem; }
#m-detail dl {
  border-left: 1px #cdd2dd solid;
  border-right: 1px #cdd2dd solid;
  border-bottom: 1px #cdd2dd solid;
  background: #000; }
  #m-detail dl dt {
    float: left;
    width: 168px;
    padding: 24px 20px;
    border-top: 1px #cdd2dd solid;
    border-bottom: 0px #cdd2dd solid;
    color: #fff; }
  #m-detail dl dd {
    margin-left: 210px;
    padding: 24px 20px 24px 20px;
    border-top: 1px #cdd2dd solid;
    border-left: 1px #cdd2dd solid;
    border-bottom: 0px #cdd2dd solid;
    background: #fff; }
#m-detail a.arrow {
  color: #fff; }
#m-detail #sub-menu {
  margin-top: 0;
  margin-bottom: 1px;
  background: #e0e6e9; }
  #m-detail #sub-menu ul {
    padding-top: 2px;
    width: 561px;
    margin: 0 auto;
    font-weight: bold; }
    #m-detail #sub-menu ul li a {
      display: block;
      border-bottom: #e0e6e9 2px solid;
      text-align: center;
      color: #000; }
      #m-detail #sub-menu ul li a:hover {
        border-bottom: #cc0000 2px solid;
        color: #cc0000; }
  #m-detail #sub-menu br {
    display: none; }
#m-detail .page_title_back {
  margin-top: 90px; }
#m-detail .contents-area {
  margin-bottom: 30px; }
#m-detail .image-area {
  float: right;
  width: 490px;
  margin-left: 40px; }
  #m-detail .image-area img {
    width: 490px; }
#m-detail .arrow {
  position: relative;
  display: inline-block;
  padding: 4px 20px 4px 24px;
  background: #cc0000;
  vertical-align: middle;
  text-decoration: none;
  font-size: 15px; }
  #m-detail .arrow:before, #m-detail .arrow:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    vertical-align: middle; }
#m-detail .sample4-1:before {
  left: 12px;
  width: 160px;
  height: 6px;
  border: 4px solid transparent;
  border-left: 5px solid #fff; }
@media screen and (max-width: 1119.98px) {
  #m-detail h5 {
    font-size: 1.2rem; }
  #m-detail .image-area {
    width: 48%;
    margin-left: 2%;
    margin-left: 0px; }
    #m-detail .image-area img {
      width: 100%; } }
@media screen and (max-width: 767.98px) {
  #m-detail h5 {
    font-size: 1rem; }
  #m-detail .image-area {
    float: none;
    width: 92%;
    margin-left: 0px;
    margin: 0px auto 60px auto; }
    #m-detail .image-area img {
      width: 100%; }
  #m-detail #sub-menu ul {
    width: 90%; } }
@media screen and (max-width: 600px) {
  #m-detail {
    /*--sp-sub-menu--*/ }
    #m-detail .page_title_back {
      margin-top: 60px; }
    #m-detail #sp-sub-menu {
      display: block;
      margin-bottom: 20px; }
      #m-detail #sp-sub-menu div {
        position: relative;
        float: right; }
        #m-detail #sp-sub-menu div p {
          cursor: pointer;
          background-image: url(image/arw-pulldown.png), linear-gradient(90deg, #eeeeee 50%, #eeeeee 50%);
          background-repeat: no-repeat, repeat;
          background-position: right 20px center, left;
          background-size: 9px 5px;
          width: 145px;
          border-radius: 15px;
          padding: 0px 14px;
          margin-bottom: 0; }
          #m-detail #sp-sub-menu div p.selected {
            border-radius: 15px 15px 0px 0px;
            background-image: url(image/arw-pulldown_open.png), linear-gradient(90deg, #dbe5ee 50%, #dbe5ee 50%);
            background-repeat: no-repeat, repeat;
            background-position: right 20px center, left; }
        #m-detail #sp-sub-menu div ul {
          display: none;
          position: absolute;
          width: 145px;
          padding: 0px 14px;
          border-radius: 0px 0px 15px 15px;
          background: #dbe5ee; }
          #m-detail #sp-sub-menu div ul li {
            padding: 4px 0px; }
            #m-detail #sp-sub-menu div ul li a {
              text-decoration: none;
              color: #000; } }
@media screen and (max-width: 500px) {
  #m-detail #sub-menu br {
    display: block; } }
@media screen and (max-width: 419.98px) {
  #m-detail dl {
    background: none;
    border-bottom: 0;
    border-left: 1px #cdd2dd solid;
    border-right: 0; }
    #m-detail dl dt {
      float: none;
      width: 89%;
      padding: 10px 5%;
      border-top: 0px #cdd2dd solid;
      border-right: 1px #cdd2dd solid;
      border-bottom: 0px #cdd2dd solid;
      background: #000; }
    #m-detail dl dd {
      width: 89%;
      margin-left: 0px;
      padding: 10px 5%;
      border-top: 1px #cdd2dd solid;
      border-right: 1px #cdd2dd solid;
      border-bottom: 1px #cdd2dd solid;
      border-left: 0px #cdd2dd solid; } }

/*--#m-detail--*/
