:root {
  --ui-color-brand: #353535;
  /* COLOR PALETTE */
  --color-ui-main: #1d2939;
  --color-ui-01: #32469b;
  --color-ui-04: #72F2EB;
  --color-ui-05: #747F7F;
  --color-ui-ye: #f1f8f9;
  --color-ui-wh: #fff;
  --color-ui-gr1: #ddd;
  --color-ui-gr2: #888;
  --color-ui-re: #c42c2c;
  /* LAYOUT */
  --layout1: 1rem;
  --layout2: 2rem;
  --layout05: .5rem;
  --fsb: 110%;
  --fsb2: 130%;
  --fss: 80%;
  --ui-typography-typeface: 'Arial', sans-serif;

  /* FONT SIZE */
  --ui-typography-h1: 2rem;
  --ui-typography-big: 1.375rem;
}

/* Google font Icon menu */
.gnav a.ico_home::before,
.gnav a.ico_schedule::before,
.gnav a.ico_registration::before,
.gnav a.ico_escription_menu::before,
.gnav a.ico_program::before,
.gnav a.ico_access_menu::before,
.gnav a.ico_interpreter::before,
.gnav a.ico_exc::before,
.gnav a.ico_spo::before,
.gnav a.ico_nur::before,
.gnav a.ico_diversity::before,
.gnav a.ico_hotel::before {
  font-family: "Material Icons";
  padding-right: var(--layout05);
}

.gnav a.ico_home::before {
  content: "\e88a"
}

.gnav a.ico_hotel::before {
  content: "\e53a"
}

.gnav a.ico_schedule::before {
  content: "\e8b5"
}

.gnav a.ico_registration::before {
  content: "\e870"
}

.gnav a.ico_escription_menu::before {
  content: "\f8d9"
}

.gnav a.ico_program::before {
  content: "\e873"
}

.gnav a.ico_access_menu::before {
  content: "\e55b"
}

.gnav a.ico_interpreter::before {
  content: "\e83b"
}

.gnav a.ico_diversity::before {
  content: "\e873"
}

.gnav a.ico_exc::before {
  content: "\e153"
}

.gnav a.ico_spo::before {
  content: "\ebcb"
}

.gnav a.ico_nur::before {
  content: "\eb41"
}

/*google icon*/
.ico_arrow:after,
.ico_pdf:after,
.ico_escription:after {
  font-family: "Material Icons";
  padding-left: var(--layout1);
  vertical-align: middle;
}

.ico_arrow:after {
  content: "\e5e1";
}

.ico_pdf:after {
  content: "\e415";
}

.ico_escription:after {
  content: "\e873";
}

.ico_mail::before {
  font-family: "Material Icons";
  content: "\e158";
  padding-right: .3rem;
}

/*googlefont
----------*/
.roboto-medium,
.roboto-bold {
  font-family: "Roboto", sans-serif;
  font-style: normal;
}

.roboto-medium {
  font-weight: 500;
}

.roboto-bold {
  font-weight: 700;
}


/*全体の設定
----------*/
html,
body {
  width: 100%;
  height: 100%
}

html {
  scroll-behavior: smooth;
  font-size: 16px
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto
  }
}

body {
  margin: 0;
  padding: 0;
  background: var(--color-ui-wh);
  font-family: var(--ui-typography-typeface);
  font-size: 0.875rem;
  line-height: 2;
  color: var(--color-ui-main);
  -webkit-text-size-adjust: none;
}



h1,
h2,
h3,
h4,
h5,
p,
ul,
ol,
li,
dl,
dt,
dd,
form,
figure,
form {
  margin: 0px;
  padding: 0px;
  font-size: 100%
}

ul {
  list-style-type: none
}

ol {
  padding-left: 20px
}

img {
  border: none;
  max-width: 100%;
  height: auto;
  vertical-align: middle
}

table {
  border-collapse: collapse;
  font-size: 100%;
  border-spacing: 0
}

iframe {
  width: 100%
}

.mt1 {
  margin-top: var(--layout1)
}

.mt2 {
  margin-top: var(--layout2)
}

.mb1 {
  margin-bottom: var(--layout1)
}

#main .mtn {
  margin-top: 0
}

.mbn {
  margin-bottom: 0
}

.col-red {
  color: var(--color-ui-re)
}

.col-gr2 {
  color: var(--color-ui-gr2)
}

.fss {
  font-size: var(--fss)
}

.fsb {
  font-size: var(--fsb)
}

.fsb2 {
  font-size: var(--fsb2)
}

.bold {
  font-weight: bold;
}

.fuchidori {
  text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF,
    -1px 1px 0 #FFF, 1px -1px 0 #FFF,
    0px 1px 0 #FFF, 0 -1px 0 #FFF,
    -1px 0 0 #FFF, 1px 0 0 #FFF;
}

.closed {
  text-decoration: line-through;
}

/*gnavi */
nav #menubar {
  background-color: #f0f8ff;
}

/*画像設定 */
.img-fit {
  max-width: 800px;
  margin: auto
}

.img-fit img {
  width: 100%;
}

/*リンク（全般）設定 ----------*/
a {
  -webkit-transition: 0.5s;
  transition: 0.5s;
  text-decoration: none
}

a.lnk_mail,
a[target="_blank"] {
  color: var(--color-ui-01)
}

footer a[target="_blank"] {
  color: var(--color-ui-wh);
}

/*コンテンツ（左右ブロックを囲むブロック）----------*/
#container {
  overflow: hidden;
}

#logo {
  position: relative;
  background: var(--color-ui-wh);
  height: 100px;
  margin-bottom: 0.5rem;
}

#logo div {
  display: block;
  position: absolute;
  height: 100px;
  width: 100%;
  background: var(--color-ui-ye);
  bottom: 0;
  z-index: 1;
  /*margin-left: 50px;*/
  /* 背景の波線 */
}

#logo div::before,
#logo div::after {
  content: "";
  display: block;
  position: absolute;
  border-radius: 100% 85%;
}

#logo div::before {
  width: 0%;
  height: 100%;
  background-color: #fff;
  right: -1.5%;
  top: 60%;
}

#logo div::after {
  /*width: 55%;*/
  height: 100%;
  background: var(--color-ui-ye);
  left: -1.5%;
  top: 40%;
}

#logo img {
  position: absolute;
  z-index: 2;
  /* 画像を前面に表示 */
  width: 50%;
  /* レスポンシブ対応 */
  height: auto;
  /* アスペクト比を維持 */
  top: 0;
  left: 0;
}

h1 div {
  pointer-events: visible;
  font-size: var(--ui-typography-h1);
  line-height: var(--ui-typography-h1-leading);
}


h2 {
  margin: 0 0 1rem 0;
  font-size: var(--ui-typography-big);
  line-height: var(--ui-typography-h1-leading);
  font-family: "Poppins", sans-serif;
  font-weight: 900;
  font-style: normal;
}

/*メインコンテンツ----------*/
#main {
  padding-bottom: 30px;
  overflow: hidden;
}

.headline_h2 {
  position: relative;
  padding: 1rem .5rem;
}

.headline_h2 {
  bottom: 0;
  left: 0;
  color: #fff;
  width: 100%;
  height: 100%;
  content: '';
  border-radius: 3px;
  background-image: -webkit-gradient(linear, right top, left top, from(#2af598), to(#009efd));
  background-image: -webkit-linear-gradient(right, #2af598 0%, #009efd 100%);
  background-image: linear-gradient(to left, #2af598 0%, #009efd 100%);
}

h3 {
  font-size: 1rem;
  color: var(--color-ui-main);
}

.head_h3 {
  position: relative;
  margin-top: 2rem;
  margin-bottom: 1.4rem;
  font-size: 1.1rem;
  font-weight: normal;
  color: var(--color-ui-01);
  border-left: 5px solid var(--color-ui-01);
  padding-left: var(--layout05);
}

.headline_h2 span,
.head_h3 span {
  margin-left: .5rem;
  font-size: small;
}

h4 {
  display: block;
}

h4.tit {
  padding: 0 0 0 2rem;
  background-color: inherit;
  color: #364f6b
}

h4.m-tit {
  padding: 0 0 0 2rem;
  margin-top: 2rem;
  font-size: 1.2rem;
  background-color: var(--color-ui-01);
  border-radius: 20px;
  color: #fff
}

h5 {
  color: #000;
  font-size: 100%;
  background-color: #faead5;
  padding: 0.3rem 0.6rem;
  margin: 1.5rem 0rem 0.5rem 0rem;
}

#main p {
  margin-top: var(--layout1)
}

#main p:first-child {
  margin-top: 0
}

/* 全体スタイリング */
.mainvisual {
  position: relative;
  aspect-ratio: 9 / 9.5;
  width: 100%;
  overflow: hidden;
}

/* 背景画像のスタイリング */
.img-01 {
  position: absolute;
  top: -3;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-image: url('./images/main_s0131.webp');
  animation: popup 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

/* アニメーション */
@keyframes popup {
  0% {
    transform: translateY(40px) scale(0.8);
    opacity: 0;
  }

  100% {
    transform: translateY(0) scale(1.0);
  }

  80%,
  100% {
    opacity: 1;
  }
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .mainvisual {
    aspect-ratio: 5 / 5.2;
    /* モバイル向けに調整 */
  }

  .img-01 {
    background-position: 50% 40%;
    /* トリミングの最適化 */
  }
}


section {
  margin-top: 2em
}

section:first-of-type {
  margin-top: 0
}

/*coming Soon----------*/
#setup_tp {
  text-align: center;
  padding: 4em;
  min-height: 500px;
}

#setup_tp .tit {
  display: block;
  font-size: 24px
}

#setup_tp .tit i {
  display: block
}

/*flexbox
----------*/
.flexbox {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap
}
.flexbox.flcenter {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}
/* 右寄せ */
.flexbox.flright {
  justify-content: flex-end;
}
@media screen and (max-width:599px) {
.flexbox.flright { justify-content: center;}
}
/* 下揃え */
.flexbox.flbottom {
  align-items: flex-end;
}

.flexbox .flex_item.set1 {
  width: 100%
}

.flexbox .flex_item.set2 {
  width: 50%
}

.flexbox .flex_item.set2_1 {
  width: 20%
}

.flexbox .flex_item.set3 {
  width: 33%
}

.flexbox .flex_item.set3_2 {
  width: 67%
}


.flexbox .flex_item.padding-haif {
  width: 50%
}

.align-content_center {
  -ms-flex-line-pack: center !important;
  align-content: center !important;
}

/*ボタン----------*/
.btn_set {
  position: relative;
  display: block;
  margin: var(--layout1) auto;
  width: fit-content;
  min-width: 250px;
  text-decoration: none;
  padding: var(--layout1);
  text-align: center;
  background-color: var(--color-ui-01);
  -webkit-box-shadow: 0 8px 15px rgba(0, 0, 0, 0.15);
  box-shadow: 0 8px 15px rgba(0, 0, 0, 0.15);
  border-radius: 50px;
}

.btn_set,
.btn_set[target="_blank"] {
  color: var(--color-ui-wh);
}

.btn_set:hover {
  background-color: var(--color-ui-re);
}

/*aリンクなし*/
.btnnac {
  background-color: var(--color-ui-gr2);
  color: var(--color-ui-gr1);
  pointer-events: none;
  cursor: default;
  box-shadow: none;
}

.c .btn_set {
  margin: 0 auto;
}

/*サブコンテンツ----------*/
#sub {
  overflow: auto;
  height: 100%
}

#sub a {
  color: #043842
}

#sub p {
  padding: 10px 20px
}

/*nav#menubar------------------------------*/
nav#menubar {
  background-color: #009efd;
}

nav#menubar .tt_table caption,
nav#menubar .tt_table th,
nav#menubar .tt_table td {
  font-size: 70%;
  padding: 0.4em
}

nav#menubar .tt_table th {
  width: 40%
}

nav#menubar ul.gnav li a {
  text-decoration: none;
  display: block;
  position: relative;
  letter-spacing: .2em;
  line-height: 1.7em;
  padding: var(--layout1);
  cursor: pointer;
  color: var(--color-ui-wh);
  box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.08);
  font-size: 115%;
}

nav#menubar ul.gnav li a:hover {
  color: var(--color-ui-re);
}

a.new::after {
  content: "NEW";
  color: white;
  font-size: 0.6em;
  margin-left: .5rem;
  padding: .3rem;
  background-color: red;
}

/*画面幅1024px以下*/
@media screen and (max-width:1024px) {
  nav#menubar {
    display: none;
    position: absolute;
    width: 100%;
    /*margin-top: 75px*/
    z-index: 5;
  }

  #menubar_hdr {
    display: block;
    position: absolute;
    z-index: 6;
    top: 0;
    right: 0;
    width: 30px;
    background-color: #009efd;
    padding: 12px 10px 5px;
  }

  #menubar_hdr span {
    display: block;
    border-top: 1.5px solid var(--color-ui-wh);
    margin-bottom: 8px
  }

  nav#menubar.open {
    display: block;
  }
}


/*footer------------------------------*/
footer {
  clear: both;
  width: 96%;
  padding: 1rem 2% .5rem 2%;
  background-color: var(--color-ui-01);
  color: var(--color-ui-wh)
}

footer h4 {
  text-align: center;
}

footer p a {
  color: #fff;
  border-bottom: 1px dotted #fff;
}

.sns_link {
  display: flex;
  justify-content: center;
  gap: 20px;
  /* アイコン間の間隔を調整 */
  list-style: none;
  padding: 0;
}

.sns_link li {
  display: flex;
}

.sns_link a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
}

.sns_link img {
  width: 100%;
  height: 100%;
}

.secretariat {
  margin: 1em auto 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.secretariat>li {
  width: 45%
}

.secretariat>li:first-child {
  padding-right: 5%
}

.secretariat>li:last-child {
  padding-left: 5%
}

.secretariat>li .tit {
  padding-bottom: 0.4rem;
  text-align: center;
  font-weight: bold
}

/*画面幅599以下*/
@media screen and (max-width:599px) {
  footer {
    width: 90%;
    padding: 5%;
  }

  .secretariat {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .secretariat>li {
    width: 100%
  }

  .secretariat>li:first-child {
    padding-right: 0;
  }

  .secretariat>li:last-child {
    padding-left: 0;
  }
}

footer .copy {
  display: block;
  margin-top: 1.5rem;
  text-align: center
}

/*image ----------*/
.box_imgcover,
.box_imgcover_mini {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 5%;
}

.box_imgcover img,
.box_imgcover_mini img {
  object-fit: cover;
}

.box_imgcover img {
  width: 150px;
  height: 170px;
}

.box_imgcover_mini img {
  width: 120px;
  height: 120px;
}

/*toppage----------*/
#new dl {
  display: grid;
  grid-template-columns: 7rem 1fr;
  gap: 0.3em 0;
  max-height: 25rem;
  overflow-y: scroll;
  border-bottom: 1px solid var(--color-ui-gr1);
}

#new dt {
  color: var(--ui-color-brand);
  font-size: 0.8rem;
  padding: 0.3em 0;
}

#new dd {
  grid-column: 2;
  padding: 0.3em 0;
  margin: 0;
  /* デフォルトのマージンをなくすとズレ防止に役立ちます */
}

/*テーブル　ta1----------*/
.tt_table *,
.tt_table *:before,
.tt_table *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

.tt_table {
  width: 100%;
  border-collapse: collapse
}

.tt_table.white-space-n th {
  white-space: nowrap
}


.center-left {
  display: block;
  position: absolute;
  top: 0.2em;
  left: 1em;
}

.tt_table th,
.tt_table td {
  padding: .8rem;
  border: 1px solid var(--color-ui-gr1);
  vertical-align: baseline
}

.tt_table th {
  width: 12rem;
  text-align: left;
  vertical-align: top;
  font-weight: 400
}

.tt_table thead th {
  background-color: var(--color-ui-01);
  color: var(--color-ui-wh);
}

.tt_table tbody th {
  background-color: var(--color-ui-ye);
}

.tt_table.set3 td {
  width: 33%
}

.tt_table.set4 td {
  width: 20%
}

.tt_table .noset {
  width: 100%
}

.tt_table .noset th,
.tt_table .noset td {
  border: none;
  padding: 0.3rem;
  font-size: 0.8rem
}

.tt_table .noset th {
  max-width: 8rem;
  background-color: transparent;
  color: lightslategray
}

.noborder th,
.noborder td {
  background-color: initial;
  border: initial;
}

.tt_table.gray thead th {
  background: #f0efd0;
  ;
  color: #6e5f5f
}

.tt_table.gray tbody th {
  background: #eae7e7;
  color: #000
}

.tt_table.gray th,
.tt_table.gray td {
  border: 1px solid #9c9c9c;
}

.tt_table .t_center {
  text-align: center;
}

@media (max-width: 768px) {

  table.resp,
  table.resp thead,
  table.resp tbody,
  table.resp tr,
  table.resp th,
  table.resp td {
    display: block;
    width: 100%;
  }

  table.resp tr {
    margin-bottom: 1rem;
  }
}

td.td_wp {
  white-space: normal;
}

@media (min-width: 768px) {
  td.td_wp {
    white-space: nowrap;
  }
}


/*notes----------*/
.notes {
  margin-top: var(--layout1);
  padding: var(--layout1);
  border: 1px solid #888;
}

.notes.nborder {
  border: none
}

.notes h4 {
  border-bottom: none;
  font-size: inherit;
  margin-bottom: 0
}

.notes a[target="_blank"] {
  display: block
}

/*ページの上部へ（↑）ボタン----------*/
#pagetop {
  clear: both;
}

#pagetop a {
  clear: both;
  display: block;
  background-color: var(--color-ui-01);
  float: right;
  text-decoration: none;
  line-height: 1;
  padding: 1rem;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  color: var(--color-ui-wh);
  font-size: 1rem;
}

/*トップページのNEWアイコン----------*/
.newicon {
  color: #f57170;
  font-size: .7rem;
  line-height: 1.5;
  margin: 0px 5px;
  vertical-align: text-top;
}

/*パンくず----------*/
.breadcrumb *,
.breadcrumb *:after,
.breadcrumb *:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.breadcrumb {
  clear: both;
  margin: 1em auto;
  border-radius: .5em;
}

.sitetop .breadcrumb {
  display: none;
}

.breadcrumb a {
  text-decoration: none;
  color: #364f6b;
}

.breadcrumb .breadcrumbs {
  padding-left: 0;
  margin-top: 0;
  margin-bottom: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
}

.breadcrumb li {
  display: inline-block;
  position: relative;
  padding-right: calc(16px + 8px);
  margin-right: 8px;
  color: #555
}

.breadcrumb li::before {
  content: "›";
  width: 1em;
  height: 1em;
  line-height: 1;
  text-align: center;
  font-size: 1em;
  color: inherit;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.breadcrumb li:last-child {
  margin-right: 0;
  padding-right: 0;
  color: #555
}

.breadcrumb li:last-child::before {
  content: normal
}

/*プログラム
---------------------------------------*/
.bdy_program .set {
  padding: 1rem;
}

.bdy_program .data {
  font-size: 1.1rem;
  width: 100%;
  border-bottom: 1px dotted var(--color-ui-gr2);
}

.bdy_program .program_tit {
  margin: 0 0 1rem 0;
  padding: .5rem;
  color: var(--color-ui-01);
  font-size: 110%;
  border-bottom: 2px solid var(--color-ui-01);
}

.bdy_program .data td:nth-of-type(1)::before {
  content: "日付 ";
  color: var(--color-ui-01);
  font-size: small;
}

.bdy_program .data td:nth-of-type(2)::before {
  content: "場所 ";
  color: var(--color-ui-01);
  font-size: small;
}

.bdy_program .program_cal_data {
  display: flex;
  flex-flow: row wrap;
  width: initial;
  padding: .5rem;
  margin-top: 1rem;
  background-color: var(--color-ui-ye);
}

.bdy_program .program_cal_data dt,
.bdy_program .program_cal_data dd {
  box-sizing: border-box;
  padding: .5rem;
  vertical-align: top;
}

.bdy_program .program_cal_data dt {
  flex-basis: 6%;
  white-space: nowrap;
  font-size: 90%;
  color: var(--color-ui-gr2);
}

.bdy_program .program_cal_data dd {
  flex-basis: 94%;
}

.program_cal_data .name,
.program_cal_data .affiliation {
  font-size: 100%;
  line-height: 1.5;
  font-size: 120%;
  vertical-align: top;
}

.program_cal_data .name {
  display: inline-block;
  min-width: 6em;
}

.program_cal_data .affiliation {
  display: inline-block;
}

/* 共催のddだけ右寄せ */
.bdy_program .program_cal_data dd.right-align {
  flex-basis: 100% !important;
  text-align: right;
  justify-content: flex-end;
}


@media screen and (max-width: 799px) {
  .bdy_program .program_cal_data {
    flex-flow: column;
  }

  .bdy_program .program_cal_data dt {
    padding-bottom: 0;
  }

  .bdy_program .program_cal_data dd {
    padding-top: 0;
  }
}

@media screen and (max-width: 599px) {
  .program_cal_data .affiliation {
    display: block;
  }
}

/*other
---------------------------------------*/
.clear {
  clear: both;
}

.font-s_big {
  font-size: var(--ui-typography-big)
}

.font-s_small {
  font-size: 80%
}

.other_link[target="_blank"] {
  margin-top: .5rem;
}

.ind1 {
  padding-left: 1.2em;
  text-indent: -1em;
  display: block
}

ul.disc {
  padding: 0 0 15px 25px;
  list-style: disc;
}

ul.come {
  list-style: none
}

ul.come li {
  content: "※";
  padding-left: 1rem;
  text-indent: -1rem;
}

ul.come li:before {
  content: "※"
}

.super {
  vertical-align: super;
  font-size: 70%
}

.pr {
  font-size: 10px
}

.wl {
  width: 96%
}

.ws {
  width: 50%
}

.c {
  text-align: center
}

.t-r {
  text-align: right
}

.fr {
  float: right;
  margin-left: 1rem
}

.fl {
  float: left;
  margin-right: 1rem
}

.sh {
  display: none
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}


.example {
  font-size: 0.8em;
  vertical-align: top;
}

/*画面幅1025px以上の設定
------------------------------------------------------*/
@media screen and (min-width:1081px) {
  :root {
    --ui-typography-h1: 3.7rem !important;
  }
}

/*画面幅1025px以上の設定
------------------------------------------------------*/
@media screen and (min-width:1025px)and (max-width:1180px) {
  :root {
    --ui-typography-h1: 2.7rem !important;
  }
}

/*画面幅1025px以上の設定
------------------------------------------------------*/
@media screen and (min-width:1025px) {
  section {
    margin-top: 3rem
  }

  /*#container #logo div img {
    width: 390px !important;
  }*/

  #column {
    max-width: 1536px;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
  }

  #sub {
    -webkit-flex-order: 1;
    -ms-flex-order: 1;
    order: 1;
    width: 23%;
    -ms-flex-negative: 0;
    flex-shrink: 0
  }

  #main {
    -webkit-flex-order: 2;
    -ms-flex-order: 2;
    order: 2;
    width: 100%;
  }

  #main section,
  #main .breadcrumb {
    padding-left: var(--layout1);
    padding-right: var(--layout1)
  }

  .bannerset {
    max-width: 1200px
  }

  footer ul {
    max-width: 1200px
  }

  br.br_sp {
    display: none !important
  }

  nav#menubar ul.gnav li a.lsn {
    letter-spacing: 0
  }

  .headline_h2 {
    margin-left: var(--layout1)
  }

  section .headline_h2 {
    margin-left: 0 !important;
  }

  .sp {
    display: none
  }
}

/*画面幅1024px以下の設定
------------------------------------------------------*/
@media screen and (max-width:1024px) {
  body {
    font-size: 13px
  }

  #container {
    margin: 0.8rem
  }

  h1 div {
    pointer-events: visible;
  }

  .headline_h2,
  .headline_h2 span {
    font-size: 14px
  }

  #main h3 {
    font-size: 13px
  }

  .important_text {
    font-size: 14px
  }

  .bannerset {
    padding: 0 1em;
    margin-bottom: 2em
  }

  /*コンテンツ（左右ブロックを囲むブロック）----------*/
  #container #logo {
    overflow: hidden;
    width: 100%;
    max-height: 80px;
    z-index: 3
  }

  #container #logo div {
    display: block;
    margin: 0 auto;
    padding-right: 90px;
    position: absolute;
    height: 70px;
    width: 100%;
    background: var(--color-ui-wh);
    bottom: 0;
    z-index: 1;
  }

  @media screen and (max-width: 1024px) {
    #container #logo {
      overflow: hidden;
      width: 100%;
      max-height: 80px;
      z-index: 3;
      top: 0;
      position: absolute;
      left: 0;
    }
  }

  #container #logo:after {
    margin-bottom: 10em
  }

  /*#container #logo div img {
    width: 185px !important;
  }*/

  /*サブコンテンツ----------*/
  #sub {
    position: static;
    width: auto;
    height: auto;
    background: transparent
  }

  /*subブロック内のリンクテキストの色*/
  #sub a {
    color: #333
  }

  #sub .inner {
    position: absolute;
    top: 0px;
    left: 0px;
    /*z-index: 1;*/
    width: 100%;
    height: 75px
  }

  .pc {
    display: none
  }
}

/*画面幅800px以下の設定
------------------------------------------------------*/
@media screen and (max-width:800px) {
  .flexbox .flex_item.set2-tab {
    width: 50% !important
  }

  /*プログラム
---------------------------------------*/
  .bdy_program .data td {
    display: block
  }
}

/*画面幅599px以下の設定
------------------------------------------------------*/
@media screen and (max-width:599px) {
  .img-fit {
    width: 100%
  }

  .fsb {
    font-size: 110%
  }

  #logo img {
    position: absolute;
    z-index: 2;
    /* 画像を前面に表示 */
    width: 70%;
    /* レスポンシブ対応 */
    height: auto;
    /* アスペクト比を維持 */
    top: 0;
    left: 0;
  }

  .btn_set {
    min-width: 200px;
    margin: .5rem auto;
  }

  :root {
    --ui-typography-h1: 1.1rem;
  }

  /*コンテンツ（左右ブロックを囲むブロック）----------*/
  /*#container #column {
    margin-top: 60px;
  }*/

  /*更新情報----------*/
  #new dl {
    grid-template-columns: 1fr;
    /* ←1列表示に切り替え！ */
  }

  #new dt {
    padding-bottom: 0;
    /* 日付と説明が近くなるように調整 */
  }

  #new dd {
    grid-column: 1;
    padding-top: 0;
    /* 説明を日付にくっつける感じ */
  }


  /*テーブル　ta1----------*/
  .table_box {
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  .tt_table {
    margin: 0;
    overflow-x: scroll
  }

  .tablepop {
    border-top: 1px solid var(--ui-color-brand)
  }

  .tablepop thead th,
  .tablepop tbody td {
    width: 100%;
    display: block;
    border-top: none
  }

  /*flexbox */
  .flexbox .flex_item.set1-mobile {
    width: 100% !important;
  }

  .bannerset .bannerbox div {
    width: 33%
  }

  .ws {
    width: 96%
  }

  .fr,
  .fl {
    float: none;
    width: 100%;
    margin: 0 0 20px;
    text-align: center
  }
}