@charset "UTF-8";
body {
font-family: "Kosugi", sans-serif;
margin: 0;
padding: 0;
height: 100%;
}

.button:hover {
opacity: 0.8;
transform: scale(1.05);
}

.overlay {
position: fixed;     /* 画面に固定 */
top: 0;
left: 0;
width: 100%;
height: 100%;
background-repeat:no-repeat;
background-color: rgba(122, 122, 122, 0.9); /* 赤・30%透明 */
pointer-events: none; /* オーバーレイがクリックを邪魔しないように */
z-index: 9999;
}
.overlay img {
display: flex;
width: 35%;
height: auto;
margin:10rem auto;
background-repeat:no-repeat;
}

.pc { display: block; }
.sp { display: none; }

.top-main-col {
    padding:0;
}

.topics-title {
    margin:10rem auto;
}

.topics-title h2 {
    text-align:center;
    font-size:1.3rem;
    font-weight:600;
    line-height:2.4rem;
    letter-spacing:0.8px;
    margin:4rem auto;
}

.topics-title h3 {
    text-align:center;
    font-size:1.8rem;
    font-weight:600;
    line-height:3rem;
    letter-spacing:2px;
    margin:3.5rem auto;
 } 

.topics-title h4 {
    color:#fff;
    text-align:justify;
    font-size:1rem;
    font-weight:100;
    line-height:1.8rem;
    margin:4rem auto;
}

.top-main {
    border-radius:0;
    height:96svh;
    z-index: 1;
}

.bg {
    background-color:#F4DC00;
}

.bg-title h3 {
    margin-bottom:-3rem;
}

.bg2 {
    background-color:#2CA6E9;
    margin:10rem auto;
}

.bg2 img {
    margin:-4rem auto 2rem auto;
}

.bg3 {
    background-color:#fdb017;
}

.bg3 img {
    margin:-4rem auto 2rem auto;
}

a:hover img {
   opacity: 0.8;
}

.far {
  color:red;
  margin-right:0.5rem;
}

.btn-in {
    margin-top:1.6rem;
}


#table01 tr {
  border-bottom: 1px solid #b5b1b1;
}

#table01 th,
#table01 td {
  padding: 24px 0;
  border: none;
  table-layout: fixed;
}

#table01 th {
  width: 30%;
}

#table01 td {
  width: 500px;  
}

.under {
  border-bottom: solid 6px yellow;
}

.work {
  margin:-3.5rem auto 0 auto;
}

.work h3 {
  text-align:left;
  font-size:1.5rem;
  font-weight:600;
  letter-spacing:2px;
  margin:3rem auto 1.5rem auto;
}

.work ul {
  font-size:1.1rem;
  font-weight:500;
  line-height:2rem;
  letter-spacing:2px;
  margin:0 auto;
}

.text h3 {
  margin:-4rem auto 3rem auto;
}

.result {
  margin:-4rem auto 5rem auto;
}

.result h2 {
  color:#fff;
  background-color:#fdb017;
  text-align:center;
  font-size:1.1rem;
  font-weight:400;
  letter-spacing:2px;
  margin:0 auto 2rem auto;
  padding:0.3rem 0;
}

.result h4 {
  text-align:center;
  font-size:1rem;
  letter-spacing:2px;
  margin-top:-1.2rem;
  margin-bottom:0.8rem;
}

.type img {
   margin:6rem auto;
}

footer {
	background-color:#e7e7e7;
  font-family: 'Noto Sans JP';
  padding:2rem 0 1rem 0;
}

footer .copylight {
  color:#000;
	font-size: 0.8rem;
  text-align: center;
}

.margin-top {
    margin-top:10rem;
}

.accordion  {
  margin: 20px auto;
}

.accordion_title {
  position: relative;
  border: none;
  display: block;
  list-style: none;
  width: 100%;
  cursor: pointer;
  background: #f1f1f1;
  padding: 1.4em 1.6em 1.4em;
  line-height: 1.6em;
  border-radius:5px;
  font-weight:bold;
  font-size:1.2rem;
  color:#216491;
}

summary.accordion_title::-webkit-details-marker {
  display:none;
}

.accordion_title:after {
  content: "+";
  position: absolute;
  top: calc(50% - 0.5em);
  right: 20px;
  line-height: 1;
  padding: 0;
  pointer-events: none;
}

.accordion::details-content {
  opacity: 0;
  block-size: 0;
  transition: .3s;
  transition-property: display, opacity, block-size, padding;
  transition-behavior: allow-discrete;
  line-height: 1.6em;
  background: #ffffff;
}

.accordion .accordion_content {
  padding: 0 1.4em;
  font-size:1.1rem;
}

.accordion .accordion_content > *:first-of-type {
  margin-top: 0;
}

.accordion .accordion_content > *:last-of-type {
  margin-bottom: 0;
}

.accordion[open]::details-content {
  opacity: 1;
  block-size: auto;
  block-size: calc-size(auto, size);
}

.accordion[open] .accordion_content {
  padding: 1.4em;
}

.accordion[open] .accordion_title:after {
  content: "-";
}

details span {
  font-size:1.7rem;
  margin-right:1rem;
}

.cv_btn {
  display: block;
  max-width: 450px;
  margin: 0 auto 2rem auto; 
  text-align: center;
  text-decoration: none;
  outline: none;
  position: relative;
  transition: color 0.5s ease;
}

.cv_btn2 {
  font-family:'Noto Sans JP';
  display: block;
  max-width: 600px;
  margin:6rem auto 3rem auto;
  padding:0.2rem 4rem;
  color: #fff;
  background-color: #ee9949;
  text-align: center;
  font-size: 19px;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-decoration: none;
  line-height: 70px;
  outline: none;
  position: relative;
  transition: color 0.5s ease;
  border-radius: 9999px;
}

.cv_btn3 {
  display: block;
  max-width: 500px;
  margin:0 auto;
  color: #fff;
  background-color: #22508b;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.4em;
  text-decoration: none;
  line-height: 70px;
  outline: none;
  position: relative;
  transition: color 0.5s ease;
}

.navi-btn:hover,.cv_btn:hover {
  text-decoration: none;
}

.cv_btn2:hover,.cv_btn3:hover {
  opacity: 0.9 !important;
  color:#fff;
  text-decoration: none;
}


/*スマホ設定*/
@media only screen and (max-width: 480px) {
  #table01 th,
  #table01 td {
    width: 100%;
    display: block;
  }

  #table01 th {
    width: 100%;
  }

  #table01 td {
    padding-top: 0;
  }
}


/*スマホ設定*/
@media screen and (max-width: 768px) {
.pc { display: none; }
.sp { display: block; }

.overlay img {
    display: flex;
    width: 80%;
    height: auto;
    margin:18rem auto;
    background-repeat:no-repeat;
}

.cv_btn {
  max-width: 320px;
  margin: 0 auto 1.5rem auto; 
}

.cv_btn2 {
  max-width: 350px;
  margin:3rem auto 2rem auto;
  padding:0.6rem 3rem;
  font-size: 18px;
  letter-spacing: 0.3em;
  line-height: 50px;
  transition: color 0.5s ease;
  border-radius: 9999px;
}

.cv_btn3 {
  max-width: 340px;
  margin:0 auto 3rem auto;
  font-size: 18px;
  letter-spacing: 0.4em;
  text-decoration: none;
  line-height: 70px;
  transition: color 0.5s ease;
}
}


@media screen and (max-width: 599px) {

.top-main-col {
    padding:0;
}

.top-main {
    height:95svh;
}

.topics-title {
    margin:2rem auto;
}

.topics-title h2 {
    font-size:0.9rem;
    line-height:1.6rem;
    letter-spacing:0.4px;
    margin:2rem auto;
}

.topics-title h3 {
    font-size:1.3rem;
    line-height:2.2rem;
    letter-spacing:2.2px;
    margin:2rem auto;
}

.topics-title h4 {
    font-size:0.9rem;
    line-height:1.8rem;
    margin:2.5rem 0.5rem 0 0.5rem;
}

.type img {
   margin:5rem auto 4rem auto;
}

.bg {
    margin:0 auto;
    margin-bottom:3rem;
}

.bg2 {
    margin:0 auto;
    padding:5rem auto;
}

.bg-title h3 {
    margin-bottom:-1rem;
}
.bg3 {
    margin-top:2rem;
}

.bg2 img ,.bg3 img {
    margin:3rem auto;
}

.work h3 {
  font-size:1.1rem;
  letter-spacing:1.8px;
  margin:3rem auto 1.5rem auto;
}

.text h3 {
  margin:-1rem auto 6rem auto;
}

.result {
  margin-bottom:5rem;
}

.result h2 {
  font-size:1.1rem;
  letter-spacing:2px;
  margin:1.4rem auto 1.8rem auto;
  padding:0.3rem 0;
}

.result h4 {
  font-size:1rem;
  letter-spacing:1.3px;
  margin-top:-1.2rem;
  margin-bottom:0.8rem;
}

footer {
    padding:2rem 0 1rem 0;
}

.accordion  {
  margin: 10px auto;
}

.accordion_title {
  font-size:0.8rem;
}

.accordion .accordion_content {
  font-size:0.9rem;
}

.accordion_title:after {
  right: 15px;
  padding-left:40px;
}

details span {
  font-size:1.4rem;
}
}