@charset "UTF-8";

/* layout
-------------------------------------------------------------*/
.co_container_box_inner {
  padding: 0;
}
.contents_right {
  width: 770px;
  float: right;
  background: #fff;
}

/* common
-------------------------------------------------------------*/
.beginner_main_contents{
  color: #26303D;
  line-height: 1.5;
  letter-spacing: normal;
}
.beginner_main_contents img{
  width: 100%;
}
.beginner_main_contents p{
  font-size: 20px;
  margin-bottom: 24px;
  display: inline-block;
}
.beginner_main_contents a{
  color: #26303D;
  transition: all .15s;
}
.beginner_main_contents a:hover{
  color: #26303D;
  text-decoration: none;
  opacity: 0.7;
}
.text_13px{
  font-size: 13px;
}
.text_15px{
  font-size: 15px;
}
.text_16px{
  font-size: 16px;
}
.text_20px{
  font-size: 20px;
}
.text_22px{
  font-size: 22px;
}
.text_24px{
  font-size: 24px;
}
.text_32px{
  font-size: 32px;
}
.text_48px{
  font-size: 48px;
}
.text_bold{
  font-weight: bold;
}
.text_orange{
  color: #FD6411;
}
.br {
  display: none;
}
.br_p{
  display: block;
}
.area_title{
  margin: 0 auto 24px;
  text-align: center;
}
.area_title img{
  width: 500px;
}

.speech_text{
  font-size: 20px;
  margin-bottom: 10px !important;
  font-weight: bold;
  line-height: 1;
  position: relative;
  padding: 0 14px;
}
.speech_text::before,
.speech_text::after{
  content: "";
  position: absolute;
  bottom: 0px;
  width: 2px;
  height: 20px;
  background: #FF8E32;
}
.speech_text::before{
  transform: rotate(-25deg);
  left: 0;
}
.speech_text::after{
  transform: rotate(25deg);
  right: 0;
}
.cta_btn{
  max-width: 450px;
  margin: 0 auto;
}
.wrapper{
  padding: 0 32px;
}
.beginner_contents_area img{
  width: 100%;
  max-width: 480px;
  height: auto;
}

/* scrollTitle & banner
-------------------------------------------------------------*/
.rankBox,
.freeBox{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 24px;
}
.title_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  flex: 1 1 calc(20% - 16px);
}
.rankBox::-webkit-scrollbar,
.rankBox::-webkit-scrollbar{
  height: 2px;
  background: #DDD;
  border-radius: 6px;
}
.rankBox::-webkit-scrollbar-thumb,
.freeBox::-webkit-scrollbar-thumb{
  background: #FD6411;
  border-radius: 6px;
  background-clip: padding-box;
}
.rankBox::-webkit-scrollbar-track,
.freeBox::-webkit-scrollbar-track{
  background: transparent;
}
.thum_box{
  height: 154px;
}
.thum_box img{
  width: 100%;
  max-height: 100%;
  border: 1px #eee solid;
  box-sizing: border-box;
}

/* scrollBanner */
.bannerArea{
  margin-bottom: 24px;
}
.bannerArea .big{
  width: 480px;
  height: auto;
  margin: 0 auto;
}
.bannerArea .big img{
  display: block;
}
.bannerArea .small{
  display: flex;
  gap: 24px;
  justify-content: center;
}
.bannerArea .small a{
  display: block;
  width: 225px;
  height: auto;
}
.bannerArea .small img{
  display: block;
}

.slick-slider{
  margin-bottom: 16px!important;
}
.slick-track{
  box-sizing: border-box;
}
.slick-list {
  overflow: hidden;
}
.banner_wrap{
  padding: 0 4px 4px;
  box-sizing: border-box;
  position: relative;
}
.slick-arrow:before{
	content:""!important;
  width: 80%;
  height: 80%;
  position: absolute;
  top: 0;
  left: 0;
}
.slick-prev:before,
.slick-next:before{
  opacity: 1!important;
}
.slick-prev:before{
  padding-left: 6px;
}
.slick-next{
  right: -30px!important;
}
.slick-prev{
  left: -27px!important;
}
.slick-next:before{
  mask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center!important;
  -webkitmask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center!important;
  background-color: #26303D;
}
.slick-prev:before{
  mask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center!important;
  -webkitmask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center!important;
  background-color: #26303D;
  transform: rotate(180deg);
}
.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before{
  opacity: 0.7 !important;
}
.slick-prev.slick-disabled,
.slick-next.slick-disabled,
.slick-prev.slick-disabled:hover,
.slick-next.slick-disabled:hover{
  cursor: auto;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before,
.slick-prev.slick-disabled:hover:before,
.slick-next.slick-disabled:hover:before{
  opacity: .2 !important;
  background-color: #ccc;
}

/* firstView
-------------------------------------------------------------*/
.firstView_text_area{
  position: relative;
  margin-top: -68px;
  z-index: 10;
  text-align: center;
}

.pageTop_title{
  font-size: 22px;
  color: #fff;
  text-align: center;
  line-height: 1.2;
  background: #FD6411;
  padding: 6px 0;
  border-radius: 9999px;
  width: 230px;
  margin: 0 auto;
  position: relative;
  top: 5px;
  filter: drop-shadow(0 3px 0 rgba(38, 48, 61));
}
.pageTop_title::after {
  background-color: #FD6411;
  content: "";
  height: 13px;
  position: absolute;
  width: 18px;
  bottom: -7px;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  left: 43%;
}
.pageTop_title::before{
  content: "";
  background: url('/sol/cc/template/common/rules/beginner/images/202510/pageTop_title_img.png') no-repeat center / contain; /* ← アイコン画像 */
  display: inline-block;
  width: 24px;
  height: 24px;
  vertical-align: middle;
  margin: 0 4px 4px 0;
}
.pageTop_text{
  max-width: 651px;
  text-align: center;
  padding: 24px 32px;
  background: #fff;
  border: 1px solid #26303D;
  border-radius: 4px;
  margin: 0 auto;
  box-sizing: border-box;
  display: block;
  line-height: 1.3;
}

/* tablink_area
-------------------------------------------------------------*/
.tablink_area{
  margin: 0 auto 24px;
}
.tablink_area ul{
  display: flex;
  gap: 8px;
  align-items: stretch;
  justify-content: space-between;
}
.tablink_area ul li{
  display: flex;
  width: 225px;
  height: 75px;
  text-align: center;
  align-items: center;
  justify-content: center;
}
.tablink_area ul li a{
  border: 1px solid #FF8E32;
  border-radius: 4px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.1;
  height: 100%;
  width: 100%;
}
.tablink_area ul li a::after{
  content: "";
  background-color: #ff8e32;
  -webkit-mask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center / contain;
  mask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center / contain;
  width: 7px;
  height: 12px;
  transform: rotate(90deg);
  position: absolute;
  bottom: 4px;
}

/* reason_area
-------------------------------------------------------------*/
.reason_area{
  background: #FFE4CE;
  overflow: hidden;
  text-align: center;
  padding: 32px 0 56px;
}
.reason_wrapper{
  background: #fff;
  border: 1px solid #26303D;
  border-radius: 4px;
  box-shadow: 3px 3px #26303D ;
  margin-bottom: 40px;
}
.reason_wrapper:last-child{
  margin-bottom: 0;
}
.reason_title{
  background: #FF8E32;
  color: #fff;
  font-weight: 900;
  font-size: 20px;
  padding: 16px;
  border-radius: 4px 4px 0 0;
}
.reason_title img{
  width: 400px;
}
.reason_title span{
  display: block;
  padding-bottom: 12px;
  line-height: 1;
  margin: 0 auto;
}
.reason_title span img{
  width: 33px;
}
.reason_inner_wrapper{
  padding: 32px;
}
.reason_inner{
  margin-bottom: 48px;
}
.reason_inner:last-child{
  margin-bottom: 0;
}
.reason_heading{
  height: 42px;
  margin: 0 auto 24px;
}
.reason_heading img {
    width: auto;
    height: 100%;
}
.publisher_wrapper{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 40px;
}
.publisher_wrapper li{
  flex: 1 1 calc(16% - 8px);
  border: 1px solid #DDDDDD;
  border-radius: 4px;
}
.publisher_wrapper li a{
  padding: 4px;
  display: block;
}
.lineLimited_wrapper img{
  width: 400px;
}

.reason03_heading{
  max-width: 71vw;
  margin: 0 auto 16px;
}
.reason03_appeal_wrapper{
  display: flex;
  gap: 16px;
  justify-content: space-around;
  margin-bottom:  24px;
  padding: 0 2%;
}
.reason03_appealText{
  display: flex;
  font-weight: bold;
  line-height: 1.25;
  position: relative;
}
.reason03_appealText::before{
  content: "";
  background: url('/sol/cc/template/common/rules/beginner/images/202510/reason03_appeal_left.png') no-repeat;
  width: 40px;
  height: 84px;
  background-size: contain;
  position: absolute;
  left: -50px;
  bottom: 5px;
}
.reason03_appealText::after{
  content: "";
  background: url('/sol/cc/template/common/rules/beginner/images/202510/reason03_appeal_right.png') no-repeat;
  width: 40px;
  height: 84px;
  background-size: contain;
  position: absolute;
  right: -50px;
  bottom: 5px;
}
.reason03_appealText p{
  font-size: 28px;
  margin-bottom: 0;
  z-index: 10;
}
.reason03_appealText img{
  max-width: 30px;
}
.reason_appealText{
  font-size: 28px;
  font-weight: bold;
  background:linear-gradient(transparent 60%, #FFEEB7 65%);
  padding: 0 4px;
  line-height: 1;
}
p.reason_appealText{
  font-size: 28px;
}
.reason_btn{
  border: 2px solid #FF7709;
  border-radius: 4px;
  max-width: 370px;
  margin: 0 auto;
  box-sizing: border-box;
  position: relative;
  transition: all .15s;
}
.reason_btn:hover{
  opacity: 0.7;
}
.reason_btn a{
  color: #FF7709;
  line-height: 1;
  font-size: 18px;
  font-weight: bold;
  display: flex;
  height: 44px;
  justify-content: center;
  align-items: center;
}
.reason_btn:hover a{
  color: #FF7709;
}
.reason_btn a::after{
  content: "";
  background-color: #ff8e32;
  -webkit-mask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center / contain;
  mask: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat center / contain;
  width: 7px;
  height: 12px;
  position: absolute;
  right: 12px;
}
.cmoacomics_btn {
  border: 1px solid #DDDDDD;
  border-radius: 4px;
  max-width: 416px;
  margin: 0 auto;
  box-sizing: border-box;
}
.cmoacomics_btn a{
  padding: 8px;
  display: block;
}
.reason_area .cta_btn{
  margin-top: 24px;
}

/* howto_area
-------------------------------------------------------------*/
.howto_area{
  padding: 48px 0 56px;
  background-image: linear-gradient(#FFF1E6 1px, transparent 1px), linear-gradient(90deg, #FFF1E6 1px, transparent 1px);
  background-size: 12px 12px;
}
.howto_step_wrapper{
  position: relative;
  background: #fff;
  border: 1px solid #26303D;
  border-bottom: none;
  border-radius: 4px 4px 0 0;
  box-sizing: border-box;
  overflow: visible;
}
.howto_v_triangle_wrapper {
  position: relative;
  width: 100%;
  height: 40px;
  background: transparent;
  border: none;
  overflow: visible;
  margin-bottom: 24px;
}
.howto_v_triangle {
  display: block;
  width: 100%;
  height: 100%;
  background: transparent;
}
.howto_step_wrapper:last-child{
  border: 1px solid #26303D;
  border-radius: 4px;
}
.howto_step_title{
  font-size: 28px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.howto_step_number{
  width: 72px;
  height: 96px;
  background: #FFDD6E;
  border-radius: 4px 0 16px 0;
  display: flex;
  flex-flow: column;
  align-self: stretch;
  align-items: center;
  justify-content: center;
}
.howto_step_number img{
  width: 27px;
  height: auto;
}
.howto_step_numberText{
  font-size: 17px;
  font-family: Calibri, Arial, sans-serif;
}
.howto_step_numberText_number{
  font-size: 20px;
  margin-left: 2px;
}
.howto_step_titleInner{
  line-height: 1.3;
}
.howto_step_inner{
  padding: 24px 32px 32px;
  text-align: center;
}
.howto_step_innerText{
  text-align: center;
}
.howto_link{
  font-size: 14px;
  display: inline-flex;
  text-align: left;
}
.howto_link::before{
  content: "";
  background: url('/sol/cc/template/common/rules/beginner/images/202510/howto_link.png') no-repeat center / contain;
  display: inline-block;
  width: 16px;
  height: 16px;
  vertical-align: text-top;
  margin: 1px 3px 0 0;
}
.howto_link span{
  text-align: left;
}
.howto_link_outside{
  margin-top: 24px;
  text-align: right;
}
.br_howto_link{
  display: block;
}
.howto_bkOrabge{
  background: #FFF7DB;
  padding: 16px;
  border-radius: 4px;
  flex: 1;
}
.howto_bkOrabge p{
  margin-bottom: 0;
}
.howto_register_img{
  margin-bottom: 24px;
}
.howto_purchase_section{
  margin-bottom: 48px;
}
.howto_purchase_section:last-child{
  margin-bottom: 0;
}
.howto_purchase_heading{
  font-size: 24px;
  position: relative;
  text-align: left;
  margin-bottom: 16px;
  padding-left: 12px;
  background: transparent;
  line-height: 1.25;
}
.howto_purchase_heading::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: #FF7709;
  border-radius: 8px;
}
.howto_purchase_section_itemLink{
  text-align: right;
  margin-top: 8px;
}
.howto_purchase_section1{
  display: flex;
  gap: 16px;
}
.howto_purchase_section1_item{
  flex: 1;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.howto_purchase_section1_item p{
  font-size: 16px;
}
.howto_purchase_section1_img{
  height: 40px;
}
.howto_purchase_section1_img img{
  height: 100%;
  width: auto;
}
.howto_purchase_section2{
  display: flex;
  gap: 16px;
  align-items: flex-end;
}
.howto_purchase_section2_item_wrapper{
  flex: 1;
}
.howto_purchase_section2_item{
  border: 1px solid #26303D;
  border-radius: 4px;
  margin-top: 6px;
  overflow: hidden;
}
.howto_purchase_section2_item p{
  margin-bottom: 0;
  font-size: 16px;
}
.howto_purchase_section2_item_ribbon{
  width: 220px;
  margin: 0 auto;
}
.howto_purchase_section2_itemTop{
  border-bottom: 1px solid #26303D;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 0;
}
.howto_purchase_section2_itemTop_img{
  height: 32px;
}
.howto_purchase_section2_itemTop img{
  height: 100%;
  width: auto;
}
.howto_purchase_section2_leftTop{
  background: #FF7709;
  color: #fff;
  font-weight: bold;
  padding: 16px 0;
}
.howto_purchase_section2_rightTop{
  background: #FFEEB7;
}
.howto_purchase_section2_itemBottom{
  padding: 16px;
}
.howto_purchase_section3{
  display: flex;
  gap: 16px;
  height: 170px;
}
.howto_purchase_section3_item{
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: justify;
  align-items: center;
  text-align: center;
}
.howto_purchase_section3_item p{
  font-size: 16px;
}
.howto_purchase_section3_item img{
  width: auto;
  height: 53px;
}

.howto_read_wrapper{
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: 16px;
}
.howto_read_wrapper .howto_step_innerText{
  margin: 0;
}
.howto_read_wrapper p {
  text-align: left;
}
.howto_read_wrapper .howto_bkOrabge{
  padding: 24px 16px;
}

/* service_area
-------------------------------------------------------------*/
.service_area{
  padding: 68px 0 16px;
  background: url('/sol/cc/template/common/rules/beginner/images/202510/service_area_flag_pc.png') no-repeat;
  background-size: contain;
}
.service_wrapper{
  padding: 0 24px;
  display: flex;
  gap: 16px;
}
.service_wrapper li{
  display: flex;
  flex: 1;
  margin-bottom: 16px;
}
.service_wrapper li a{
  border-radius: 4px;
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 16px 36px 16px 24px;
  align-items: center;
  gap: 16px;
}
.service_wrapper li a::after{
  position: absolute;
  content: "";
  background: url('/sol/cc/template/common/rules/beginner/images/202510/link_arrow.svg') no-repeat;
  background-size: contain;
  width: 7px;
  height: 12px;
  right: 16px;
  top: calc(50% - 7px);
}
.service_wrapper li a p{
  font-size: 14px;
  margin: 0;
}
.service_images{
  display: flex;
  align-items: center;
  max-width: 100px;
  height: auto;
}
.service_item_text{
  font-size: 14px;
  margin-bottom: 0 ;
}
.yomiho_item a{
  border: 1px solid #23B7F1;
}
.review_item a{
  border: 1px solid #EA6C86;
}
.island_item a{
  border: 1px solid #EA5505;
}
.yomiho_item .service_images,
.review_item .service_images{
  width: 60px;
}

/* present_area
-------------------------------------------------------------*/
.present_area {
  background: #FFE692 url('/sol/cc/template/common/rules/beginner/images/202510/present_area_flag_pc.png') no-repeat;
  text-align: center;
  padding: 40px 0 56px;
  margin: 32px 0 16px;
  background-size: contain;
}
.present_area_title{
  margin-bottom: 16px;
}
.present_wrapper {
  background: #fff;
  border: 1px solid #26303D;
  border-radius: 4px;
  box-shadow: 2px 2px #26303D;
  margin-bottom: 24px;
  padding: 24px 16px;
}
.present_heading {
  margin: 0 auto 24px;
}
.present_heading img {
  width: 334px;
}
.present_text p{
  font-size: 28px;
  font-weight: bold;
}
.present_banner_wrapper img{
  width: 480px;
  height: auto;
}

/* faq_area
-------------------------------------------------------------*/
.faq_area{
  padding: 40px 0 64px;
}
.faq_area_title{
  font-size: 24px;
  text-align: center;
  margin-bottom: 18px;
}
.faq_menu{
  margin: 18px 0 16px !important;
}
.faq_area .cta_btn{
  padding-top: 40px;
}
/* ↓faq_area（ヘルプページCSS上書き）↓ */
#probo {
  margin: 0;
}
/* ↑faq_area（ヘルプページCSS上書き）↑ */
