@charset "UTF-8";
/* -----------------------------------------------
* Plugins エントリーポイント
-------------------------------------------------- */
/*------------------------------------------------------------------------------
  reset PC
------------------------------------------------------------------------------*/
html,
input,
textarea,
select,
button {
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, sans-serif;
  font-weight: 500;
  font-size: 16px;
}

html {
  color: #000;
  background: #fff;
  font-size: 16px;
  line-height: 1.6;
  word-break: break-all;
}

body {
  background: #fff;
  margin: 0;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

figure {
  margin: 0;
}

img {
  border: 0;
  margin: 0;
  vertical-align: top;
  max-width: 100%;
  width: 100%;
  height: auto;
}

p {
  margin: 0;
  padding: 0;
  overflow-wrap: break-word;
  word-wrap: break-word;
}

a {
  color: #000;
  text-decoration: none;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

textarea,
button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
     -moz-appearance: none;
          appearance: none;
}

.btn,
a.btn,
button.btn {
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}

.btn--orange,
a.btn--orange {
  color: rgb(0, 0, 0);
  background-color: #FFE869;
  border: 0.2ex solid #000;
}
.btn--orange:hover,
a.btn--orange:hover {
  color: rgb(51, 51, 51);
  background-color: #fff7c7;
}

select::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
}

::-webkit-input-placeholder {
  color: #ccc;
}

:-ms-input-placeholder {
  color: #ccc;
}

::-ms-input-placeholder {
  color: #ccc;
}

::-moz-placeholder {
  color: #ccc;
}

::placeholder {
  color: #ccc;
}

button {
  border: none;
  cursor: pointer;
}

label {
  cursor: pointer;
}

table {
  border-collapse: collapse;
}

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

h3{
  font-size: 16px;
  font-weight: 500;
  margin: 0;
  padding: 0;
}

h4,
h5,
h6 {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
  padding: 0;
}

main {
  display: block;
}

.inner-block {
  position: relative;
  max-width: 680px;
  padding: 0;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

#wrapper {
  position: relative;
}

dl,
dt,
dd {
  padding: 0;
  margin: 0;
}
.c-svg {
  display: inline-block;
  fill: currentColor;
  vertical-align: top;
}

/*------------------------------------------------------------------------------
  reset SP
------------------------------------------------------------------------------*/
/* --------------------------------
c-header
----------------------------------- */
/* --------------------------------
c-footer
----------------------------------- */
.c-footer {
  background-color: #00A6B4;
  color: #fff;
  text-align: center;
  padding: 1em 0;
}
.c-footer a {
  color: inherit;
}

/* -----------------------------------------------
* Modules エントリーポイント
-------------------------------------------------- */
.p-home .ttlHolder {
  padding: 50px 0;
}
.p-home .ttlHolder .title {
  font-size: 23px;
  font-weight: bold;
  text-align: center;
}
.p-home .ttlHolder .time {
  text-align: right;
}
.p-home .note p {
  margin-bottom: 3em;
  font-size: 14px;
}
.p-home .subtitle {
  font-weight: bold;
  margin-bottom: 32px;
  padding-left: 16px;
  border-left: 4px solid #111;
}
.p-home .listHolder {
  font-size: 14px;
  margin-bottom: 56px;
  line-height: 2;
}
.p-home .listHolder li {
  position: relative;
  padding-left: 12px;
}
.p-home .listHolder li::before {
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}
.p-home .tableHolder {
  width: 100%;
  margin-bottom: 56px;
  font-size: 14px;
}
.p-home .tableHolder .listHolder {
  margin-bottom: 2em;
}
.p-home .tableHolder tr {
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.p-home .tableHolder th {
  width: 30%;
  padding: 1em;
  vertical-align: top;
  text-align: left;
}
.p-home .tableHolder td {
  width: 70%;
  padding: 1em;
}
.p-home .speakers {
  border: 1px solid #ddd;
  padding: 3em 2em;
  margin-bottom: 56px;
}
.p-home .speakers__itemHolder {
  display: block;
}
.p-home .speakers__name {
  font-size: 16px;
  line-height: 1.2;
  font-weight: bold;
}
.p-home .speakers__name span {
  font-size: 14px;
  line-height: 1.2;
}
.p-home .speakers__imgHolder {
  margin: 1em auto;
  width: 80%;
}
.p-home .speakers__note {
  font-size: 14px;
}

/* -----------------------------------------------
* Page エントリーポイント
-------------------------------------------------- */

@media only screen and (min-width: 641px) {
  a:hover {
    opacity: 0.8;
  }
  .inner-block {
    margin: 0 auto;
  }
  .sp {
    display: none !important;
  }
  a[href^="tel:"] {
    pointer-events: none;
  }
  a,
a::before,
a::after,
button {
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
  }
  .p-home .speakers__itemHolder {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: auto auto;
    grid-template-areas: "header thumbnail" "note thumbnail";
    gap: 10px;
  }
  .p-home .speakers__name {
    grid-area: header;
  }
  .p-home .speakers__imgHolder {
    grid-area: thumbnail;
    width: 100%;
  }
  .p-home .speakers__note {
    grid-area: note;
  }
}

@media only screen and (max-width: 640px) {
  body {
    font-size: 14px;
    position: relative;
    -webkit-text-size-adjust: 100%;
  }
  .inner-block {
    padding: 0 10px;
    width: auto;
  }
  #wrapper {
    min-width: 320px;
    position: relative;
    overflow: hidden;
  }
  input[type=submit] {
    -webkit-text-size-adjust: 100%;
  }
  input,
select,
textarea {
    font-size: 16px !important;
  }
  .pc {
    display: none !important;
  }
  .p-home .ttlHolder .title {
    text-align: left;
  }
  .p-home .tableHolder tr {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .p-home .tableHolder th {
    width: 100%;
    padding: 1em 0.5em 0.5em;
  }
  .p-home .tableHolder td {
    width: 100%;
    padding: 0.5em 0.5em 1em;
  }
}