@charset "utf-8";

/* smart phone */
@media only screen and (max-width: 768px) {
	main {
	  padding-bottom: 200px;
	}
	main::after {
	  height: 200px;
	}
  header div.title {
    min-width: 100% !important;
    padding-top: 50px;
    min-height: 480px;
  }
  header div.title .wrap {
  	max-width: 100%;
  	min-height: 460px;
  }
  header div.title p.tagline {
    font-size: 19px;
  }
  header div.title h1 {
    font-size: 22px;
  }
  header div.title .main_title {
  	width: 90%;
  	margin: 0 auto 15px;
  	position: relative;
  }
   header div.title .main_title:after {
   	content: "";
    width: 140%;
    height: 120px;
    background: url(../../images/common/top_main_tokyo_archan03_sp.png) no-repeat center/contain;
    bottom: -120px;
    position: absolute;
    left: -26%;
    z-index: 1;
   }
   header div.title .value_osaka .main_title:after {
    background: url(../../images/common/top_main_osaka_archan03_sp.png) no-repeat center/contain;
   }
   header div.title .value_osaka .title_archan {
		width: 100%;
		right: 0%;
		bottom: -17px;
	}
  header div.title .subtitle {
    font-size: 18px;
  }
  header div.title .info {
    font-size: 16px;
  }
  header div.title .info span {
    display: block;
    margin: 6px auto 0;
  }
  header div.title .value {
  	width: 25%;
    margin-left: 30px;
    margin-bottom: 10px;
    position: relative;
    z-index: 3;
  }
  header div.title .value img {
  	width: 100%;
  	height: auto;
  }
  header div.title .value2 {
  	width: 100%;
  	margin: 0 10px 0 30px;
  }
  header div.title .value .date {
	  font-size: 20px;
	}
	header div.title .value .date span {
	  font-size: 30px;
	}
	header div.title .value .hotel {
	  font-size: 18px;
	}
	header div.title .title_archan {
		width: 60%;
		left: auto;
	    right: 0;
	    margin: auto;
	    bottom: -15px;
	}
	
  h2 {
    font-size: 22px;
    margin-bottom: 40px;
  }
  h2:before {
    top: 30px;
    width: 140px;
  }
  h2 > span {
    font-size: 14px;
    margin-top: 20px;
  }

  .all-wrap {
    margin-top: 0;
    padding-top: 0;
  }

  /* for fixed nav */
  /*[id]::before {*/
  /*  display: none;*/
  /*}*/

  /* for fixed nav */
  #greeting::before,
  #outline::before,
  #program::before,
  #access::before {
    display: none;
  }
	/* guest */
	#guest {
		padding: 50px 0 30px;
		margin-bottom: 80px;
	}
	#guest .wrap .guest_parts01 {
		width: 58%;
		top: -51px;
		right: -30px;
	}
	#guest h2.title {
	  margin: 0 auto 20px;
	}
	#guest h2.title img {
		height: 35px;
		width: auto;
	}
	#guest h2.title span {
		font-size: 16px;
		margin-top: 10px;
	}
	.guest_box01 .guest_txt {
		max-width: 100%;
		width: 100%;
	}
	.guest_box01 .time_schedule::before {
	  width: 100%;
	  height: 40px;
	  border-radius: 30px;
	  right: 0;
	  top: 0;
	  bottom: 0;
	  margin: auto;
	  z-index: -1;
	}
	.guest_box01 .time_schedule span {
	  padding-left: 35px;
	}
	.guest_box01 .time_schedule span::before {
	  width: 20px;
	  height: 20px;
	}
	.guest_box01 .guest_photo.special {
		width: 100%;
		max-width: 100%;
	}
	.guest_box01 .guest_photo.special.sp_on {
		display: flex;
		gap: 20px;
		align-items: center;
		padding: 0 0 20px;
	}
	.guest_box01 .guest_photo.special.sp_on picture {
		width: 50%;
		margin-bottom: 0;
	}
	.guest_box01 .guest_photo .special_guest {
	  width: 45%;
	  margin: 0;
	  font-size: 25px;
	}
	.guest_box01:nth-child(2) .guest_photo{
		position: relative;
	}
	.guest_box01:nth-child(2) .guest_photo:after {
		content: "";
		position: absolute;
		right: -169px;
        width: 132px;
        height: 177px;
		background: url(../../images/common/program_archan.png) no-repeat center/contain;
	}
	.guest_box01:nth-child(3) .guest_photo{
		position: relative;
	}
	.guest_box01:nth-child(3) .guest_photo:after {
		content: "";
		position: absolute;
		right: -169px;
        width: 132px;
        height: 177px;
		background: url(../../images/common/program_archan02.png) no-repeat center/contain;
	}
	.guest_area {
	  gap: 40px 0;
	}
	.guest_box01 h3 {
	  font-size: 16px;
	  margin: 0 0 10px;
	  padding-left: 0px;
	}
	.guest_box h4 {
		padding-left: 0px;
	}
	.guest_box01 {
		width: 100%;
	}
	.guest_box01 .guest_photo {
	    max-width: 50%;
	  }
	.guest_box01 p.position {
	  font-size: 13px;
	}
	.guest_box01 p.name {
	  font-size: 18px;
	  margin: 0 0 10px;
	}
	.guest_box01 p {
	  font-size: 13px;
	  line-height: 1.4;
	  padding-left: 0px;
	}
  /* greeting */
  #greeting {
    width: 90%;
    min-width: 90%;
    margin: 0 auto;
    padding: 40px 0 20px;
  }
  #greeting p {
    font-size: 13px;
    line-height: 1.8;
  }

  /* outline */
  #outline .outline_parts01 {
		width: 35%;
		top: -216px;
		left: -20px;
	}
	#outline .outline_parts02 {
		display: none;
	}
	#outline .outline_parts03 {
	  width: 100%;
	}
	#outline .outline_parts04 {
	    bottom: 7%;
        left: -10%;
        width: 28%;
	}
  #outline {
    min-width: 100%;
    padding: 40px 0 285px;
  }
  .outline-title {
	  margin: 0 auto 40px;
	}
	.outline-title img {
	  height: 35px;
	  width: auto;
	}
	.outline-subtitle {
	  font-size: 16px;
	  margin: 10px 0 0;
	}
  #outline .wrap {
    width: 94%;
    padding: 20px 0;
    flex-wrap: wrap;
    margin: 0 auto 80px;
  }
  #outline table {
    width: 96%;
    margin: 0 auto 36px;
  }
  #outline table tr th {
    font-size: 13px;
  }
  #outline table tr th span {
	  font-size: 13px;
	  padding: 3px 10px;
	}
  #outline table tr td {
    font-size: 13px;
    padding: 0 0 15px;
  }
  #outline table tr th {
    width: 80px;
    text-align: left;
  }
  #outline .map {
	  width: 90%;
	  margin: 0 auto;
	}
	#outline .map iframe {
		height: 200px;
	}
	#outline .link_area {
		width: 90%;
		margin: 20px auto 0;
	}
	#outline .link_area a {
		border: 6px solid var(--white);
		padding: 10px;
	}
	#outline .link_area a .icon {
		width: 70%;
		margin: 0 auto 15px;
	}
	#outline .link_area a p.date {
		font-size: 20px;
	}
	#outline .link_area a p.date span {
		font-size: 30px;
	}
	#outline .link_area a p.hotel {
		font-size: 14px;
		margin-bottom: 20px;
	}
	.venue-link-text {
	  font-size: 16px;
	  gap: 8px;
	}
	.venue-link-icon {
	  width: 30px;
	  height: 30px;
	  margin-right: 10px;
	}
	.venue-link-icon img {
	  width: 16px;
	  height: auto;
	}
	#outline .linkbtn {
		margin: 20px auto;
		gap:20px;
	}
	#outline .linkbtn li {
		width: 45%;
	}
	#outline .linkbtn li a {
		padding: 10px 0;
		font-size: 16px;
	}
	#outline .linkbtn li a:after {
	  width: 12px;
	  height: 12px;
	  right: 15px;
	}
	/* sponsor */
	#sponsor .wrap::before {
		top: -166px;
		width: 100%;
		height: 90px;
		background-size: contain;
	}



  /* program */
  #program .wrap {
    padding: 40px 0;
    width: 100%;
    min-width: 100%;
  }
  #program .notes {
    font-size: 12px;
    margin: 10px auto 0;
  }

  /* access */
  #access {
    min-width: 94%;
    padding: 0;
  }
  #access .wrap {
    padding: 40px 0;
  }
  #access .wrap .google-map {
    width: 94%;
    height: 300px;
    margin: 0 auto;
  }
  #access .google-map > iframe {
    height: 300px;
  }
	/* present */
	#present {
	  padding: 60px 0 40px;
	}
  /* register */
  div.register {
    padding: 50px 0;
  }
  div.register a.box-button {
    width: 80%;
    font-size: 22px;
  }
}

@media only screen and (max-width: 480px) {
	header div.title .main_title {
	  	width: 95%;
	  	margin: 0 auto 15px;
	  	position: relative;
	  }
	header div.title .value {
	  	width: 40%;
	    margin-left: 30px;
	    margin-bottom: 10px;
	    position: relative;
	    z-index: 3;
	}
	 header div.title .value2 {
	  	width: 100%;
	  	margin: 0 10px 0 30px;
	  }
	header div.title .title_archan {
	    width: 100%;
	    left: 0;
	    right: 0;
	    margin: auto;
	    bottom: -15px;
	}
	#outline {
        padding: 40px 0 200px;
    }
	#outline .outline_parts01 {
		width: 54%;
	}
	#outline .outline_parts04 {
        bottom: 11%;
        left: -10%;
        width: 51%;
    }
}
