@charset "utf-8";

/*==============================================================
	contents.css

	history
		2012.01.20 kondo		new

----------------------------------------------------------------
menu
	01 Common Setting
	02 TopPage

==============================================================*/

/* ---------------------------------------------------------- */
/*     01 Common Setting    */
/* ---------------------------------------------------------- */

/* heading */

#main h1,
#main2 h1 {
  font-size: 165%;
  letter-spacing: 1px;
  color: #fff;
  font-weight: bold;
  background: -webkit-linear-gradient(25deg, #105685 0, #0F8AFD 100%);
  background: -moz-linear-gradient(25deg, #105685 0, #0F8AFD 100%);
  background: -o-linear-gradient(25deg, #105685 0, #0F8AFD 100%);
  background: linear-gradient(65deg, #105685 0, #0F8AFD 100%);
  padding: 10px 16px 10px 20px;
  margin-bottom: 13px;
}

#main h1 a{
  color: #fff;
  text-decoration: none;
}

#main h2,
#main2 h2 {
  font-size: 155%;
  font-weight: bold;
  color: #369;
  border-top: 5px solid #369;
  background: #f2f2f2;
  padding: 5px 18px;
  margin-bottom: 13px;
}

#main h3,
#main2 h3 {
  font-size: 150%;
  font-weight: bold;
  color: #369;
  border-top: 5px solid #369;
  background: #f2f2f2;
  padding: 5px 18px 5px 13px;
  margin: 20px 0 10px 0;
}

#main h4,
#main2 h4 {
  font-size: 130%;
  font-weight: bold;
  color: #333;
  border-left: 5px solid #369;
  border-bottom: 1px solid #369;
  background: #f2f2f2;
  padding: 5px 18px;
  margin: 20px 0 10px 0;
}

#main h5,
#main2 h5 {
  font-size: 120%;
  font-weight: bold;
  color: #333;
  line-height: 1.2;
  border-left: 5px solid #369;
  padding: 5px 18px 5px 13px;
  margin: 20px 0 10px 0;
}



#main ul,
#main2 ul {
  margin: 10px 0 10px 2.0em;
  padding: none;
  list-style-type: disc;
}

#main ul li,
#main2 ul li {
  list-style-type: disc;
}

#main ol,
#main2 ol {
  margin: 10px 0 10px 2.0em;
  padding: none;
  list-style-type: decimal;
}

#main ol li,
#main2 ol li {
  list-style-type: decimal;
}

#main ul.entry_list_data,
#main2 ul.entry_list_data {
  margin: 0 0 20px 0;
  padding: 0;
  list-style: none;
}

#main ul.entry_list_data li,
#main2 ul.entry_list_data li {
  padding: 7px 0 7px 20px;
  border-bottom: 1px #666666 dashed;
  background: url(/themes/jfocus/common/img/mark01.png) 0.7em 1em no-repeat;
  list-style: none;
}


.entry table {
  border-top: 1px #333333 solid;
  border-left: 1px #333333 solid;
  border-collapse: collapse;
}

.entry table th,
.entry table td {
  padding: 7px;
  border-right: 1px #333333 solid;
  border-bottom: 1px #333333 solid;
}

.entry table th {
  background: #ccddee;
  font-weight: bold;
}

.entry table td.bt_box {
  text-align: center;
  background: #666666;
}

.entry table .red_font {
  color: #ff0000;
}

.entryFormColumnTable,
.entryFormImageTable {
  border: none !important;
}

.entryFormColumnTable th,
.entryFormColumnTable td {
  border: none !important;
  padding: 0
}

/***** メニューあり *****/
/* 1カラム用 */
#main div.column1 {
  clear: both;
  padding-top: 10px;
  width: 100%;
}

/* 2カラム用 */
#main div.column2 {
  float: left;
  margin-right: 10px;
  width: 350px;

}

/* 3カラム用 */
#main div.column3 {
  float: left;
  margin-right: 10px;
  width: 230px;
}

/* 2/3カラム用 */
#main div.column3x2 {
  float: left;
  margin-right: 10px;
  width: 470px;
}

/***** メニューなし *****/
/* 1カラム用 */
#main2 div.column1 {
  clear: both;
  padding-top: 10px;
  width: 100%;
}

/* 2カラム用 */
#main2 div.column2 {
  float: left;
  margin-right: 10px;
  width: 458px;
}

/* 3カラム用 */
#main2 div.column3 {
  float: left;
  margin-right: 10px;
  width: 302px;
}

/* 2/3カラム用 */
#main2 div.column3x2 {
  float: left;
  margin-right: 10px;
  width: 614px;
}



/* フォーム関連 */
#sub #mailStep {
  display: block;
  margin: 0;
  padding: 0;
  width: 200px;
  height: 147px;
  font-size: 1px;
  text-indent: -8000px;
  text-decoration: none;
}

#sub .step1 {
  background: #eeeeee url(/themes/jfocus/images/contact/step1.png) no-repeat;
}

#sub .step2 {
  background: #eeeeee url(/themes/jfocus/images/contact/step2.png) no-repeat;
}

#sub .step3 {
  background: #eeeeee url(/themes/jfocus/images/contact/step3.png) no-repeat;
}

/* slider_wrap */

.slider_wrap {
  margin-left: 50%;
}


/* slider_left */

.slider_left {
  width: 50%;
  background: url(/themes/jfocus/common/img/img_slider_left.jpg) no-repeat;
  position: absolute;
  right: 50%;
  background-size: cover;
  height: 50vh;
  min-height: 300px;
  max-height: 450px;
}

.slider_link::after {
  content: url(/themes/jfocus/common/img/mark_right_large.png);
  position: absolute;
  /*  right: 85px;*/
  /*  right: 0;*/
  top: 17px;
  right: 10px;
}

.slider_link_wrap_over {
  width: 480px;
  position: absolute;
  right: 0;
  bottom: 0;
  top: 0;
  margin: auto;
  height: 245px;
}

.slider_link_wrap {
  /*  margin-bottom: 50px;*/
  margin-bottom: 25px;
  /*  padding-left: 5px;*/
}

.slider_link {
  display: block;
  text-decoration: none !important;
  color: #fff !important;
  /*  width: 370px;*/
  width: 397px;
  position: relative;
  padding: 0 10px;
}

.slider_link:hover {
  background-color: rgba(0, 0, 0, 0.5);
}

.slider_link_span1 {
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.15em;
}

.slider_link_span2 {
  font-size: 20px;
  letter-spacing: 5px;
}

.slider_btn_span1 {
  background-color: rgba(255, 255, 255, 0.5);
}

.slider_btn_span2 {
  background-color: rgba(0, 0, 0, 0);
}

.slider_btn {
  width: 420px;
}

.slider_btn_table,
.slider_btn_link {
  display: block;
  background-color: #fff;
  box-sizing: border-box;
  width: 200px;
  padding: 10px 0;
  float: left;
  border: 1px solid #105685;
  margin-bottom: 16px;
  text-align: center;
  text-decoration: none !important;
  color: #105685 !important;
  font-size: 13px;
  position: relative;
}

.slider_btn_table_wrap {
  width: 100%;
}

.slider_btn_table {
  background-color: rgba(0, 0, 0, 0);
  padding: 0;
  height: 41px;
  border: 1px solid #fff;
}

.slider_btn_tr {
  display: block;
  line-height: 1.6;
}

.slider_btn_th {
  background-color: rgba(255, 255, 255, 0.2);
  width: 80px;
  float: left;
  color: #fff;
  padding: 10px 0;
  border-right: 1px solid #fff;
}

.slider_btn_td {
  float: left;
  color: #fff;
  padding: 10px 0;
  width: 117px;
}

.slider_btn_link:nth-child(n+3)::after {
  content: url(/themes/jfocus/common/img/mark_right.png);
  position: absolute;
  right: 10px;
  top: 10px;
}

.slider_btn_link:nth-child(n+3):hover::after {
  content: url(/themes/jfocus/common/img/mark_right_hover.png);
  position: absolute;
  right: 10px;
  top: 10px;
}

.slider_btn_link.line2:nth-child(n+3)::after {
  top: 13px;
}

.slider_btn_link.line2:nth-child(n+3):hover::after {
  top: 13px;
}

.slider_btn_link_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.slider_btn_link.line1 {
  padding: 3px 0 2.4px 0;
  text-align: center;
  line-height: 16px;
  letter-spacing: 0.05em;
  background-color: rgba(80 231 255 / 50%);
  color: #fff !important;
  border: 4px double #fff;
}

.slider_btn_link.line2 {
  padding: 6px 0 5px 15px;
  text-align: left;
  line-height: 16px;
  letter-spacing: 0.05em;
}

/*
.slider_btn_link:nth-child(2n) {
  margin-left: 18px;
}
*/

.slider_btn_link.line1:hover {
  background-color: #fff;
  color: #105685 !important;
  border: 4px double #fff;
}
.slider_btn_link:nth-child(n+3):hover {
  background-color: rgba(0, 0, 0, 0);
  color: #fff !important;
  border: 1px solid #fff;
}

.slider_btn_link.reservation {
  letter-spacing: 4px;
}

.slider_btn_link.training_session {
  letter-spacing: 4px;
}

.object-fit-img {
  object-fit: cover;
  object-position: 0 80%;
  font-family: 'object-fit: cover; object-position: 0 80%;' !important;
}

/* slicks */
.slider {
  /*  width: 50%;*/
  /*  height: 500px;*/
  height: 50vh;
  min-height: 300px;
  max-height: 450px;
}

.slider div {
  /*  height: 500px;*/
  height: 50vh;
  min-height: 300px;
  max-height: 450px;
}

.slider img {
  width: 100%;
}

.slick-dots {
  bottom: 9px !important;
}

.slick-dots li button::before {
  content: "" !important;
  line-height: 6px !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 20px !important;
  height: 6px !important;
  text-align: center !important;
  background-color: #fff !important;
  border-radius: 0 !important;
  opacity: 1 !important;
}

.slick-slide img {
  /*  height: 500px;*/
  height: 50vh;
  min-height: 300px;
  max-height: 450px;
  /*  object-position: 100% 80%;*/
  object-fit: cover;
  object-position: 0 80%;
  font-family: 'object-fit: cover; object-position: 0 80%;' !important;

}

.slick-dots li.slick-active button::before {
  opacity: .75 !important;
  background-color: black !important;
}

.slick-slider .acms-admin-icon {
  background: none;
  border: none;
  position: absolute;
  color: #fff;
  top: 0;
  bottom: 0;
  margin: auto;
  padding: 0 10px;
  font-size: 30px;
  z-index: 2;
}

.slick-slider .acms-admin-icon::before {
  font-family: 'slick';
  font-size: 30px;
  z-index: 3;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: '←';
}

.slick-slider .acms-admin-icon-arrow-right {
  right: 0;
}

.slick-slider .acms-admin-icon-arrow-right::before {
  content: '→';
}

.slick-slider .acms-admin-icon:hover {
  opacity: .6;
  background: #333;
}


/* ---------------------------------------------------------- */
/*     02 TopPage   index.html    */
/* ---------------------------------------------------------- */

/* JavaScript が無効な場合のスライダー表示 */
html:not(.enable-javascript) .hide-disable-js:first-child img {
  height: 50vh;
  min-height: 300px;
  width: auto;
  /*  width: 100%;*/
}

html:not(.enable-javascript) .hide-disable-js:not(:first-child) {
  display: none;
}

/*
.top {
  font-family: "Meiryo";
}
*/

.top .section_title {
  font-weight: normal;
}

.top .globalnav_wrap {
  /*	border-bottom: 0 none;*/
}

.top .contents_wrap {
  /*	background: url(/themes/jfocus/img/bg_mainimg.png) 0 0 repeat-x;*/
}

.top #contents {
  width: 100%;
  margin: 0 auto;
  position: relative;
  max-width: 1980px;
}

.section_title {
  text-align: center;
  /*  font-family: "Sawarabi Gothic";*/
  padding: 45px 0;
  letter-spacing: 10px;
}

.section_header {
  position: relative;
}

.section_list_btn {
  display: block;
  border: 1px solid #105685;
  width: 128px;
  /*  height: 30px;*/
  color: #105685 !important;
  position: absolute;
  top: 45px;
  right: 0;
  text-decoration: none !important;
  text-align: center;
  padding: 5px;
  /*  font-family: "Sawarabi Gothic";*/
  background-color: #fff;
  letter-spacing: 11px;
}

.section_list_btn:hover {
  background-color: #105685;
  color: #fff !important;
}

.section_list_btn::after {
  content: url(/themes/jfocus/common/img/mark_right.png);
  position: absolute;
  right: 10px;
}

.section_list_btn:hover::after {
  content: url(/themes/jfocus/common/img/mark_right_hover.png);
  position: absolute;
  right: 10px;
}


/* -------- mainimg --------- */

.mainimg {
  /*	height: 260px;*/
  /*	height: 500px;*/
  position: relative;
  height: 50vh;
  min-height: 300px;
  min-width: 1000px;
  max-height:450px;
}

.mainimg img {
  vertical-align: top;
}

/* -------- main_container --------- */

.top #main_container {
  /*	width: 464px;*/
  /*    width: 1000px;*/
  width: 100%;
  padding-top: 40px;
  /*	margin-left: 248px;*/
  min-height: 930px;
  /* IE6以外について高さ指定 */
  height: auto !important;
  height: 956px;
  /* IE6用に、上記高さにpadding分の26pxを加えた数値を指定 */
}

.top #main_container h2 {
  /*	margin-bottom: 10px;*/
}

.whatsnew_wrap {
  width: 100%;
  padding-bottom: 74px;
}

#whatsnew {
  margin: 0 auto;
  max-width: 1000px;
}

.event_wrap {
  width: 100%;
  background-color: #dfe6ed;
}

#event {
  margin: 0 auto;
  max-width: 1000px;
}

.event_list_wrap {
  height: 207px;
}

.event_list {
  height: auto !important;
}

/* -------- event_unit --------- */
.event_unit_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.event_unit {
  width: 235px;
  height: 361px;
  background-color: #fff;
  margin-bottom: 34px;
}

/*
.event_unit + .event_unit {
  margin-left: 20px;
}

.event_unit + .event_unit:nth-child(5) {
  margin-left: 0;
}
*/

/*
.event_unit.left {
  margin-left: 0;
}
*/

.event_link {
  display: block;
  text-decoration: none !important;
  position: relative;
}

.event_link:hover {
  border-bottom: 4px solid #105685;
}

.event_new::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  padding: 1px 20px;
  color: #ffffff;
  font-size: 14px;
  content: "新着";
  background: red;
  letter-spacing: 3px;
  font-weight: bold;
}

.event_end::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  padding: 1px 20px;
  color: #000000;
  font-size: 14px;
  content: "終了";
  background: #d2d2d2;
  letter-spacing: 3px;
  font-weight: bold;
}

.event_list {
  padding: 5px 10px;
  /*  font-family: "Sawarabi Gothic";*/
  padding: 10px;
}

.event_name {
  font-size: 15px;
  margin-bottom: 4px;
  height: 58px;
  overflow: hidden;
  letter-spacing: 0.05em;
}

.event_schedule {
  /*  padding-top: 10px;*/
  padding-left: 25px;
  font-size: 13px;
  position: relative;
  letter-spacing: 0.05em;
  margin-bottom: 3px;
  height: 50px;
  overflow: hidden;
}

.event_schedule::before {
  content: url(/themes/jfocus/common/img/mark_schedule.png);
  position: absolute;
  top: 3px;
  left: 0;
}

.event_place {
  padding-left: 25px;
  font-size: 13px;
  position: relative;
  letter-spacing: 0.05em;
  margin-bottom: 3px;
  height: 50px;
  overflow: hidden;
}

.event_place::before {
  content: url(/themes/jfocus/common/img/mark_place.png);
  position: absolute;
  top: 4px;
  left: 3px;
}

.event_people {
  float: left;
  padding-left: 25px;
  /*  padding-right: 40px;*/
  padding-right: 10px;
  font-size: 13px;
  position: relative;
}

.event_people::before {
  content: url(/themes/jfocus/common/img/mark_person.png);
  position: absolute;
  top: 3px;
  left: 3px;
}

.event_cost {
  font-size: 13px;
  position: relative;
  float: left;
  padding-left: 25px;
}

.event_cost::before {
  content: url(/themes/jfocus/common/img/mark_yen.png);
  position: absolute;
  top: 1px;
  left: 4px;
}

.cf_event_wrap {
  margin-bottom: 20px;
}

.cf_event dt,
.cf_event dd {
  display: inline-block;
}

/* main-business */

.main-business_wrap {
  width: 100%;
  background-color: #ebebeb;
}

/*
.main-business_wrap h2 {
  padding: 45px 0;
  letter-spacing: 10px;
  font-family: "Sawarabi Gothic";
}
*/

#main-business {
  margin: 0 auto;
  max-width: 1000px;
}

/* main-business_unit */

.main-business_unit {
  width: 235px;
  height: 240px;
  background-color: #fff;
}

.main-business_link {
  display: block;
  text-decoration: none !important;
}

.main-business_link:hover {}

.main-business_link:hover .main-business_title {
  background-color: #105685;
  color: #fff;
}

.main-business_link:hover .main-business_title::after {
  content: url(/themes/jfocus/common/img/mark_right_hover.png);
  position: absolute;
  right: 10px;
  top: 25px;
}

.main-business_title {
  text-decoration: none;
  color: #000;
  position: relative;
  display: block;
  height: 46px;
  padding: 7px 0;
  padding-left: 12px;
  font-size: 13px;
}

.main-business_title .line1 {
  position: relative;
  top: 11px;
}

.main-business_title::after {
  content: url(/themes/jfocus/common/img/mark_right.png);
  position: absolute;
  right: 10px;
  top: 20px;
}


.main-business_upper {
  padding-bottom: 48px;
  border-bottom: 1px solid #cfcfcf;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

/* bottom_wrap */
.bottom_wrap {
  padding-top: 52px;
  padding-bottom: 55px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

/* bottom_unit */
.bottom_unit {
  width: 298px;
  height: 68px;
  background-color: #fff;
  border: 1px solid #105685;
  position: relative;
  margin-bottom: 20px;
}


.bottom_link:hover .bottom_icon-mail::before {
  content: url(/themes/jfocus/common/img/mark_mail_hover.png);
  position: absolute;
  top: 24px;
  left: 22px;
}

.bottom_icon-mail::before {
  content: url(/themes/jfocus/common/img/mark_mail.png);
  position: absolute;
  top: 24px;
  left: 22px;
}

.bottom_link:hover .bottom_icon-restaurant::before {
  content: url(/themes/jfocus/common/img/mark_restaurant_hover.png);
  position: absolute;
  top: 15px;
  left: 26px;
}

.bottom_icon-restaurant::before {
  content: url(/themes/jfocus/common/img/mark_restaurant.png);
  position: absolute;
  top: 15px;
  left: 26px;
}

.bottom_link:hover .bottom_icon-memo::before {
  content: url(/themes/jfocus/common/img/mark_memo_hover.png);
  position: absolute;
  top: 6px;
  left: 22px;
}

.bottom_icon-memo::before {
  content: url(/themes/jfocus/common/img/mark_memo.png);
  position: absolute;
  top: 6px;
  left: 22px;
}

.bottom_link:hover .bottom_icon-pc::before {
  content: url(/themes/jfocus/common/img/mark_pc_hover.png);
  position: absolute;
  top: 12px;
  left: 22px;
}

.bottom_icon-pc::before {
  content: url(/themes/jfocus/common/img/mark_pc.png);
  position: absolute;
  top: 12px;
  left: 22px;
}


.bottom_link:hover .bottom_icon-calendar::before {
  content: url(/themes/jfocus/common/img/mark_calendar_hover.png);
  position: absolute;
  top: 6px;
  left: 22px;
}

.bottom_icon-calendar::before {
  content: url(/themes/jfocus/common/img/mark_calendar.png);
  position: absolute;
  top: 6px;
  left: 22px;
}


.bottom_link {
  display: block;
  height: 70px;
  text-decoration: none !important;
  /*  font-family: "Sawarabi Gothic";*/
  height: 68px;
}

.bottom_unit.line1 .bottom_title {
  position: relative;
  top: 10px;
  padding: 10px 0;
  padding-left: 80px;
}

.bottom_link:hover {
  background-color: #105685;
}

.bottom_link:hover .bottom_title {
  color: #fff;
}

.bottom_link:hover .bottom_title::after {
  content: url(/themes/jfocus/common/img/mark_right_hover.png);
  position: absolute;
  right: 10px;
  top: 29px;
}

.bottom_unit.line1 .bottom_link:hover .bottom_title::after {
  content: url(/themes/jfocus/common/img/mark_right_hover.png);
  position: absolute;
  right: 10px;
  top: 19px;
}

.bottom_title {
  text-decoration: none;
  color: #105685;
  position: relative;
  display: block;
  padding: 5px 0;
  padding-left: 80px;
  letter-spacing: 0.05em;
}

.bottom_title::after {
  content: url(/themes/jfocus/common/img/mark_right.png);
  position: absolute;
  right: 10px;
  top: 20px;
}

.bottom_unit.line1 .bottom_title::after {
  content: url(/themes/jfocus/common/img/mark_right.png);
  position: absolute;
  right: 10px;
  top: 10px;
}



.top #main_container #event h2 {
  margin-bottom: 20px;
}

.top #main_container .section {
  /*	width: 464px;*/
  max-width: 1000px;
  padding-bottom: 5px;
}

.top #main_container .section ul {
  /*	padding-bottom: 13px;*/
  height: 380px;
  overflow: auto;
}

.top #main_container .section ul li {
  /*	border-bottom: 1px solid #cfcfcf;*/
  /*	padding-bottom: 6px;*/
  /*	margin-bottom: 6px;*/
  /*	line-height: 1.4;*/
}

.top #main_container .section ul li a {
  display: block;
  line-height: 53px;
  font-size: 14px;
  text-decoration: none;
  padding-left: 45px;
  /*  width: 855px;*/
  border-bottom: 1px solid #cfcfcf;
  letter-spacing: 0.05em;
  white-space: nowrap;
  /*  overflow: hidden;*/
  text-overflow: ellipsis;
  /*  padding-right: 45px;*/
}

.top #main_container .section ul li a:hover {
  background-color: #ebebeb;
}

.top #main_container .section ul li a img {
  /*	margin: 0 5px;*/
  margin-right: 20px;
  vertical-align: -2px;
}

.top #main_container .section dl {
  /*	width: 464px;*/
  max-width: 1000px;
  overflow: hidden;
  clear: both;
  border-bottom: 1px dotted #333;
  margin-bottom: 13px;
}

.top #main_container .section dl dt {
  width: 65px;
  float: left;
  padding: 2px 0 10px;
}

.top #main_container .section dl dd {
  float: right;
  width: 386px;
  padding-bottom: 10px;
  line-height: 1.4;
}


/* -------- side --------- */

/* side01 */

.top #side01 {
  width: 220px;
  position: absolute;
  top: 223px;
  left: 10px;
}

.top #side01 p {
  margin-bottom: 8px;
}

.top #side01 .comment {
  height: 25px;
  background: url(/themes/jfocus/img/bg_supercom.png) bottom no-repeat;
  margin-bottom: 0;
}

.top #side01 .comment a {
  display: block;
  padding: 0 20px 18px 25px;
  font-size: 93%;
}

.top #side01 .comment a:link {
  color: #fff;
}

.top #side01 .comment a:visited {
  color: #fff;
}

.top #side01 .comment a:hover {
  color: #fff;
}

.top #side01 .comment a:active {
  color: #fff;
}

.top #side01 dl {
  width: 219px;
  margin-bottom: 8px;
}

.top #side01 dl.last_child {
  margin-bottom: 13px;
}

.top #side01 dl dd {
  border-right: 1px solid #c0c0c0;
  border-bottom: 1px solid #c0c0c0;
  border-left: 1px solid #c0c0c0;
  padding: 9px;
  font-size: 93%;
}

.top #side01 dl dd ul li {
  zoom: 1;
}

.top #side01 dl dd ul li a {
  display: block;
  padding-left: 10px;
  background: url(/themes/jfocus/common/img/arrow04.png) 0 0.5em no-repeat;
  vertical-align: bottom;
}

.top #side01 .list01 {
  padding-bottom: 5px;
}

.top #side01 .list01 li {
  line-height: 1.3;
  margin-bottom: 6px;
  zoom: 1;
}

.top #side01 .list01 li a {
  display: block;
  padding-left: 30px;
  background: url(/themes/jfocus/common/img/arrow01.png) 0 0.2em no-repeat;
}

/* side02 */

.top #side02 {
  width: 220px;
  position: absolute;
  top: 223px;
  left: 730px;
}

.top #side02 p {
  margin-bottom: 11px;
}

.top #side02 p.first_child {
  margin-bottom: 15px;
}

.top #side02 .comment {
  height: 25px;
  background: url(/themes/jfocus/img/bg_use.png) bottom no-repeat;
  margin-bottom: 0;
}

.top #side02 .comment a {
  display: block;
  padding: 0 20px 18px 25px;
  font-size: 93%;
}

.top #side02 .comment a:link {
  color: #fff;
}

.top #side02 .comment a:visited {
  color: #fff;
}

.top #side02 .comment a:hover {
  color: #fff;
}

.top #side02 .comment a:active {
  color: #fff;
}

.top #side02 dl {
  width: 219px;
  margin-bottom: 8px;
}

.top #side02 dl.last_child {
  margin-bottom: 13px;
}

.top #side02 dl dd {
  border-right: 1px solid #c0c0c0;
  border-bottom: 1px solid #c0c0c0;
  border-left: 1px solid #c0c0c0;
  padding: 9px;
  font-size: 93%;
}

.top #side02 .list02 {
  padding-bottom: 15px;
}

.top #side02 .list02 li {
  line-height: 1.3;
  margin-bottom: 6px;
  zoom: 1;
}

.top #side02 .list02 li a {
  display: block;
  padding-left: 30px;
  background: url(/themes/jfocus/common/img/arrow02.png) 0 0.2em no-repeat;
}

.top #side02 .list03 {
  padding-bottom: 18px;
}

.top #side02 .list03 li {
  line-height: 1.3;
  margin-bottom: 6px;
  zoom: 1;
}

.top #side02 .list03 li a {
  display: block;
  padding-left: 30px;
  background: url(/themes/jfocus/common/img/arrow03.png) 0 0.2em no-repeat;
}

.top div#wrapper div.contents_wrap div#contents div#main_container div#event div.section dl dt a div.top_event_pictframe {
  background: url(/themes/jfocus/common/img/icon_event_seminar10.png) 0 0 no-repeat;
  width: 65px;
  height: 65px;
  float: left;
}

.top div#wrapper div.contents_wrap div#contents div#main_container div#event div.section dl dt a:hover div.top_event_pictframe img {
  opacity: 1 !important;
}

/*--------------------------------------------------------------
   問い合わせフォーム contact/index.html
--------------------------------------------------------------*/


.inquiryform dl {
  padding: 0;
  border: 1px solid #eee;
  border-top: none;
  background-color: #f5f5f5;
}

.inquiryform dl dt {
  margin: 0;
  padding: 0.3em 0 0.1em 1em;
  border-top: 1px solid #eee;
  width: 15em;
  float: left;
  color: #333;
}

.inquiryform dl dd {
  margin: 0 0 0 15em;
  padding: 0.3em 1em;
  border-left: 1px solid #eee;
  border-top: 1px solid #eee;
  color: #999;
  background-color: #fff;
}

.inquiryform .inquiry_bt {
  background-color: #ff6666;
  padding: 10px;
  text-align: center;
}


.inquiryform .inquiry_text {
  background-color: #ff6666;
  padding: 5px;
  text-align: center;
  color: #fff;
}


.notice {
  color: #ff0000;
}




/*---------- セミナー室及び実習室利用 ----------*/

/*----- カレンダー -----*/

.cal_tit {
  padding: 0;
  margin: 5px 0;
  background: #333333;
  text-align: center;
  color: #ffffff;
  font-size: 140%;
  font-weight: bold;
}

.cal_move {
  clear: both;
  margin: 15px 0 30px 0;
  padding: 10px;
  text-align: center;
  font-size: 100%;
  font-weight: bold;
  background: #eeeeee;
}

.cal_move a {
  margin: 0 10px;
}




.cal_data {
	border-top: 1px #333333 solid;
	border-left: 1px #333333 solid;
	border-collapse: collapse;
	margin-bottom: 10px;
}


.cal_data .cal_header {
	display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-template-rows: auto;
    gap: 0px;
}


.cal_data .cal_body {
	display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-template-rows: auto;
    gap: 0px;


}

.cal_data .cal_header > div,
.cal_data .cal_body .day {
	margin: 0;
	padding: 0;
	border-right: 1px #333333 solid;
	border-bottom: 1px #333333 solid;
}


.cal_data .cal_header div {
	padding: 5px;
	background: #eeeeee;
	font-weight: bold;
	text-align: center;
}
.cal_data .cal_header div.sun {
	background: #eecccc;
}
.cal_data .cal_header div.sat {
	background: #ccccee;
}

.cal_data .cal_body .day {
	display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 0px;
}

.cal_data .cal_body .cal_day {
	padding: 5px 5px 5px 0;
	text-decoration: none;
	text-align:center;
	font-weight: bold;
	font-size: 120%;
}
.cal_data .cal_body .cal_checkbox {
	text-align:center;
}
.cal_data .cal_body a.now_day {
	background: #ffffcc;
}
.cal_data .cal_body a:hover {
	background: #ccffff;
}
.cal_data .cal_body div.sun {
	background: #ffeeee;
}
.cal_data .cal_body div.sat {
	background: #eeeeff;
}

div.check_invalid {
  background: #ffeeee;
  color:#999999;
}

div.check_invalid input {
  display: none;
}

.cal_data .cal_body .cal_spec {
	border-top:1px #333333 dashed;
	text-align:center;
}






/*----- メイン -----*/

/* 入力フォーム */

/* 見積もり */
.ar_estimate {
  width: 80%;
  margin: 15px auto;
}

.ar_estimate td {
  text-align: right;
}

.ar_estimate td.estimate_name {
  text-align: left;
}


/* 空き状況 */

.entry .app_message {
  text-align: right;
}

.entry .ar_table_list {
  width: 100%;
  border: 1px #333333 solid;
  /*padding: 10px;*/
}

.entry .ar_table_list th,
.entry .ar_table_list td {
  text-align: center;
  padding: 10px;
}

.entry .ar_table_list th {
  background: #336699;
  color: #ffffff;
  padding: 10px;
}

.entry .ar_table_list tr.ar_table_1st td {
  border: 0;
}

.entry .ar_table_list tr.ar_table_2nd td {
  border: 0;
}

.entry .ar_table_list tr td.app_list_time {
  background: #ccddee;
  font-weight: bold;
  border: 1px #333333 solid;
}

.entry .ar_table_list tr td.app_list_data {
  background: #ffffcc;
  border: 1px #333333 solid;
}

.entry .ar_table_list tr td.app_list_msg {
  font-size: x-small;
}

.entry .ar_table_list tr.ar_table_1st td.app_list_msg {
  border-left: 1px #999999 dashed;
  border-bottom: 1px #999999 dashed;
}

.entry .ar_table_list tr.ar_table_2nd td.app_list_msg {
  border-left: 1px #999999 dashed;
  border-top: 1px #999999 dashed;
}


.entry .ar_table_list tr.ar_table_hr td {
  padding: 0;
  height: 5px;
  border: 1px #333333 solid;
}


.entry .ar_table_list tr.not_space td {
  color: #666666;
  background: #aaaaaa;
}

.entry .ar_table_list tr td.not_space {
  color: #666666;
  background: #cccccc;
}


.entry .ar_bt_box {
  margin: 15px 0;
  text-align: center;
}





/*----- カレンダー -----*/
.ar_cal_menu {
  margin: 15px 0;
  padding: 0;
}

.ar_cal_menu .cal_tit {
  background: #333333;
  text-align: center;
}

.ar_cal_menu .cal_tit a {
  padding: 3px;
  color: #ffffff;
  font-size: 110%;
  font-weight: bold;
  text-decoration: none;
}

.ar_cal_menu table.cal_data {
  width: 100%;
  border-top: 1px #333333 solid;
  border-left: 1px #333333 solid;
  border-collapse: collapse;
  margin-bottom: 10px;
}

.ar_cal_menu table.cal_data th,
.ar_cal_menu table.cal_data td {
  margin: 0;
  padding: 0;
  border-right: 1px #333333 solid;
  border-bottom: 1px #333333 solid;
}

.ar_cal_menu table.cal_data th {
  padding: 5px;
  background: #eeeeee;
  font-weight: bold;
}

.ar_cal_menu table.cal_data th.sun {
  background: #eedddd;
}

.ar_cal_menu table.cal_data th.sat {
  background: #ddddee;
}

.ar_cal_menu table.cal_data td a {
  display: block;
  padding: 5px;
  text-decoration: none;
  text-align: center;
}

.ar_cal_menu table.cal_data td a.now_day {
  background: #ffffcc;
  font-weight: bold;
}

.ar_cal_menu table.cal_data td a:hover {
  background: #eeffff;
}

.ar_cal_menu table.cal_data td.sun {
  background: #ffeeee;
}

.ar_cal_menu table.cal_data td.sat {
  background: #eeeeff;
}


/*----- メイン -----*/

/* 入力フォーム */

/* 見積もり */
.ar_estimate {
  width: 80%;
  margin: 15px auto;
}

.ar_estimate td {
  text-align: right;
}

.ar_estimate td.estimate_name {
  text-align: left;
}


/* 空き状況 */

.entry .ar_table_list {
  border-left: none;
}

.entry .ar_table_list th,
.entry .ar_table_list td {
  border-right: none;
  text-align: center;
}

.entry .ar_table_list tr.not_space th,
.entry .ar_table_list tr.not_space td {
  background: #dddddd;
}

.entry .list_seminar1,
.entry .list_seminar2 {
  width: 48%;
  float: left;
}

.entry .list_seminar1 {
  margin-right: 20px;
}

.entry .list_seminar1 .app_list_time,
.entry .list_seminar1 .app_list_data,
.entry .list_seminar2 .app_list_time,
.entry .list_seminar2 .app_list_data {
  padding: 10px;
}


.entry .ar_table dl dt {
  clear: left;
  float: left;
  width: 6em;
  padding-left: 5px;
  text-align: center;
}

.entry .ar_table dl dd {
  margin-left: 6em;
}




/* 流れテキスト */
.entry .ar_chart {
  text-align: right;
  color: #999999;
}

.entry .ar_chart .chart_now {
  color: #333333;
  font-weight: bold;
}



/* print 印刷時 */
@media print {

  .mainimg,
  .slider_left {
    height: 391px;
  }

  .slider_wrap {
    display: none !important;
  }

  .slider {
    display: none !important;
  }

  .slider-img_print {
    /*    display: block !important;*/
    height: 391px;
  }

  .slider-img_print {
    height: 391px;
  }

  .object-fit-img {
    height: 391px;
    width: 100%;
  }

  .slider_wrap_print {
    display: block !important;
    margin-left: 50%;
    width: 50%;
  }
}

div.column-image-left {
  margin-right: 10px
}

.column-image-right,
.column-media-right {
  margin-left: 10px
}

.tabs {
  margin-top: 50px;
  padding-bottom: 40px;
  background-color: #fff;
  border: 1px solid #e0e0e0;
  margin: 0 auto;
}

.tab_item {
  width: calc(100%/4);
  height: 50px;
  border-bottom: 1px solid #105685;
  border-left: 2px solid #c5c5c5;
  background-color: #ecebeb;
  line-height: 50px;
  font-size: 16px;
  text-align: center;
  color: #565656;
  display: block;
  float: left;
  text-align: center;
  font-weight: bold;
  transition: all 0.2s ease;
  box-sizing: border-box;
  cursor: pointer;
}

.tab_item:first-of-type {
  border-left: none;
}

.tab_item:hover {
  opacity: 0.75;
}

input[name="tab_item"] {
  display: none;
}

.tab_content {
  display: none;
  padding: 40px 15px 0;
  clear: both;
  overflow: hidden;
}

.tab_content .acms-label {
  background-color: red;
  background: red;
  top: -2px;
  position: relative;
  font-size: 12px;
  letter-spacing: 3px;
  font-weight: bold;
}

.tab_content .acms-label:hover {
  color: #FFF;
  background: red;
}

#all:checked ~ #all_content,
#information:checked ~ #information_content,
#event:checked ~ #event_content,
#seminar:checked ~ #seminar_content {
  display: block;
}

.tabs input:checked + .tab_item {
  background: -webkit-linear-gradient(25deg, #105685 0, #0F8AFD 100%);
  background: -moz-linear-gradient(25deg, #105685 0, #0F8AFD 100%);
  background: -o-linear-gradient(25deg, #105685 0, #0F8AFD 100%);
  background: linear-gradient(65deg, #105685 0, #0F8AFD 100%);
  color: #fff;
}

.tab_item[for="information"]::before {
  content: "■";
  color: #3399cc;
}

.tab_item[for="event"]::before {
  content: "■";
  color: #ff9900;
}

.tab_item[for="seminar"]::before {
  content: "■";
  color: #d24ba5;
}

.acms-label {
  white-space: nowrap;
  color: #FFF;
}

.bottom_wrap::after {
  display: block;
  content: "";
  width: 298px;
}

@media screen and (max-width: 1000px) {
  #header {
    height: 90px;
  }

  .spMenu_btn {
    display: block;
  }

  .globalnav_wrap,
  .bottom_banner_wrap,
  #footer_wrapper {
    min-width: auto;
  }

  #topicpath,
  #contents,
  #main,
  #main2,
  #sub,
  #main div.column2 {
    width: 100%;
    float: none;
  }

  #topicpath,
  #contents {
    padding: 0 5%;
    box-sizing: border-box;
  }

  .top #contents {
    padding: 0;
	max-width: none;
  }

  #main,
  #main2 {
    display: block;
    margin-bottom: 100px;
  }

  #main h1,
  #main2 h1 {
    font-size: 140%;
  }

  #main h2,
  #main2 h2 {
    font-size: 130%;
  }

  #main h3,
  #main2 h3 {
    font-size: 120%;
  }

  #main h4,
  #main2 h4 {
    font-size: 110%;
  }

  #main h5,
  #main2 h5 {
    font-size: 110%;
  }


  iframe {
    width: 100%;
  }

  td[nowrap="nowrap"] {
    white-space: break-spaces;
  }

  .entry table {
    width: 100% !important;
    table-layout: fixed;
  }

  .entry table th,
  .entry table td {
    word-wrap: break-word;
    width: auto !important;
  }

  td.estimate_name {
    display: block;
  }

  .estimate_name input {
    width: 100%;
  }

  td.bt_box {
    display: block;
  }

  td input[type="text"],
  td textarea {
    width: 100%;
  }

  [class^=column-table] .entry-container {
    overflow-x: auto;
  }

  .acms-table-scrollable td,
  .acms-table-scrollable th,
  .js-table-unit-scroll-hint td,
  .js-table-unit-scroll-hint th {
    display: table-cell !important;
    white-space: nowrap
  }

  #wrapper {
    width: 100vw;
    overflow-x: hidden;
  }

  #freewordsearch,
  #header_nav,
  .header_btn,
  .globalnav_wrap {
    display: none;
  }

  .mainimg {
    height: auto;
    min-height: auto;
    min-width: auto;
    display: flex;
    flex-wrap: wrap-reverse;
	  max-height: none;
  }

  .slick-dots {
    position: relative;
    display: none !important
  }

  .slick-dots li {
    width: 17px;
    height: 17px;
    margin: 0 10px;
  }

  .slick-dots li button::before {
    width: 100% !important;
    height: 100% !important;
    background-color: #9a9a9a !important;
  }

  .slider_left {
    width: 100%;
    position: relative;
    right: auto;
    height: auto;
	max-height: none;
  }

  .slider_wrap {
    margin-left: 0;
    width: 100%;
  }

  .slider_link_wrap_over {
    width: 440px;
    position: relative;
    padding: 30px 0;
    padding-left: 20px;
    margin: 0 auto;
  }

  .slick-dotted.slick-slider {
    margin-bottom: 0;
  }

  .slider,
  .slider div {
    height: auto;
    min-height: none;
	max-height: none;
  }

  .slick-slide img {
    height: auto;
    min-height: none;
	max-height: none;
  }

  .bottom_unit + .bottom_unit {
    margin-left: 0;
  }

  .section_list_btn {
    bottom: 28px;
    right: 5px;
    display: block;
    top: auto;
    padding: 0;
  }

  .section_list_btn::after {
    top: 0px;
  }

  .tab_content li {
    margin-bottom: 15px;
  }

  .top #main_container .section ul li a {
    padding-left: 0;
    width: 100%;
    white-space: pre-wrap;
    overflow: hidden;
    text-overflow: ellipsis;
    padding-right: 0;
    line-height: 2;
    padding-bottom: 10px;
  }

  .tab_content b {
    display: block;
  }

  .top #main_container #event h2 {
    margin-bottom: 0;
    padding: 25px 0 80px;
  }

  .event_unit_wrap {
    padding: 0 3%;
    justify-content: space-around;
  }

  .event_unit_wrap::after {
    display: block;
    content: "";
    width: 235px;
  }

  #main-business h2 {
    display: block;
  }

  .main-business_upper {
    padding: 0 15%;
  }

  .main-business_unit {
    margin-bottom: 20px;
  }

  .bottom_banner ul:before,
  .bottom_banner ul::after {
    display: block;
    content: "";
    width: 170px;
  }

  .bottom_banner ul::before {
    order: 1;
  }

  #footer_wrapper #footer #footerinfo {
    float: none;
    position: relative;
    top: auto;
    right: auto;
    margin: auto;
    display: block;
  }

  #footer_wrapper #footer .footer_mainnav {
    width: 100%;
    justify-content: space-around;
    padding-left: 10px;
  }

  #main div.column3x2,
  #main div.column3 {
    float: none;
    margin-right: 0;
    width: 100%;
  }

  .top #main_container .section ul li a img {
    margin: 0 5px 0 0;
  }

  #header .header_bottom {
    margin: 10px 0;
  }

  .entry table.acms-table-scrollable {
    table-layout: auto;
  }

  .bottom_wrap {
    justify-content: space-around;
  }
}

@media screen and (max-width: 840px) {
  .bottom_banner ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
  }
}

@media screen and (max-width: 700px) {
  .main-business_upper {
    padding: 0;
    justify-content: space-around;
  }

  #footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }


  #footer_wrapper #footer .footer_mainnav {
    flex-wrap: wrap;
    padding-left: 20px;
    order: 1;
    padding-bottom: 0;
  }

  #footer_wrapper #footer .footer_mainnav ul {
    width: 50%
  }

  #footerinfo {
    order: 3;
    padding-bottom: 30px;
  }

  .footer_nav {
    order: 2;
    padding-bottom: 30px;
  }

  .footer_nav_list {
    padding: 0 20px;
  }

  .bottom_item .pagetop {
    height: 49px;
    width: 50px;
    right: 15px;
    bottom: 20px;
  }
}

@media screen and (max-width: 560px) {

  /*
  .event_unit_wrap {
    padding: 0 10%;
  }
*/
  .event_unit {
    width: 48%;
    height: auto;
    float: none;
    margin: 0 1% 34px;
  }

  /*
  .event_unit + .event_unit,
  .event_unit + .event_unit:nth-child(5) {
    margin-left: auto;
  }
*/

  .event_unit img {
    width: 100%;
    height: auto;
  }

  .event_list_wrap,
  .event_name,
  .event_schedule,
  .event_place {
    height: auto;
  }
}

@media screen and (max-width: 480px) {
  #siteTitle {
    text-align: left;
  }

  #siteTitle img {
    width: 65vw;
    height: auto;
    vertical-align: unset;
  }

  .slider_link_wrap_over {
    width: 100%;
    height: auto;
    padding: 30px 10px;
    box-sizing: border-box;
  }

  .slider_btn,
  .slider_link,
  .slider_btn_table,
  .slider_btn_link {
    width: 100%;
  }

  .slider_link {
    padding: 0;
  }

  .slider_btn_link.line2 {
    text-align: center;
  }

  .slider_btn_link:nth-child(2n) {
    margin-left: 0;
  }

  #whatsnew .section_title {
    padding-bottom: 70px;
    padding-top: 15px;
  }

  .main-business_upper {
    max-width: 419px;
    margin: auto;
  }

  .main-business_unit {
    width: 140px;
    height: 200px;
  }

  .main-business_title {
    height: 80px;
  }

  .main-business_title::after {
    top: auto;
    bottom: 10px;
  }

  .main-business_unit img {
    width: 100%;
  }

  .bottom_banner img {
    width: 150px;
    height: auto;
  }

  .column-image-right,
  .column-media-right {
    margin-left: 0;
  }

  div.column-image-left {
    margin-right: 0;
  }

  .column-image-left,
  .column-image-right,
  .column-image-left a,
  .column-image-right a,
  .column-file-left,
  .column-file-right,
  .column-file-auto {
    width: 100% !important;
    display: block;
    float: none;
    margin: 0;
    padding: 10px 0;
  }

  .tab_item {
    font-size: 13px;
  }

  .header_btn li {
    margin-bottom: 10px
  }

}

@media screen and (max-width: 375px) {
  .event_unit {
    width: 80%;
    height: auto;
    float: none;
    margin: 0 5% 34px;
  }
}
