body{
  font-family:"游ゴシック", "Yu Gothic", YuGothic, "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  line-height: 1.7;
}

.img-responsive {
  display: block;
  width: 100% \9;
  max-width: 100%;
  height: auto;
}

.title-box{
  display: block;
  margin:0 auto;
}

.title-box h1{
    text-align: center;
    font-weight: 700;
    line-height: 1.9;
}

.title-box .ttl {
	background-color: green;
	color: white;
	max-width: 860px;
	text-align: center;
	padding: 0.5em 0;
}

.title-box .ttl h3 {
	line-height: 1.5em;
}

.intro-box{
  margin-top: 40px;
}

section .red{
  color: #be282d;
}
section .yellow{
  color: #fff900;
}
section .green{
  color: #0b9944;
}
section .dots{
  -webkit-text-emphasis-style: dot;
  -moz-text-emphasis-style: dot;
  white-space: nowrap;
}
.hitsuji-icon{
  vertical-align: bottom;
  margin:0px 2px;
}

.discount-bold{
  font-size:2.8rem;
  color: #be282d;
}

.balloon{
font-weight:700;
position:relative;
margin-right:auto;
margin-top:40px;
margin-bottom:12px;
margin-left:auto;
padding:5px 0;
animation:balloon-fuyuu 2s ease infinite alternate;
text-align:center;
color:#fff;
border-radius:6px;
background:#f57519;
line-height: 1.75;
letter-spacing: 0.05em;
-webkit-font-smoothing: antialiased;
box-sizing: border-box;
}

.balloon:before{
position:absolute;
bottom:-10px;
left:calc(50% - 10px);
width:20px;
height:10px;
content:'';
border-width:10px 10px 0;
border-style:solid;
border-color:#f57519 transparent transparent;
box-sizing: inherit;
}

@keyframes balloon-fuyuu{
0%{top:-6px}50%{top:0}100%{top:-6px}
}

@media screen and (min-width: 768px){
.balloon{width:268px}
}

@media screen and (max-width: 767px){
.balloon{
font-size:12px;
width:180px;
margin-bottom:15px;
}

.balloon:before{
bottom:-6px;
width:16px;
height:6px;
border-width:6px 8px 0;
border-style:solid;
}
}

.row-eq-height {
    margin-top: 1em !important;
    background: #f5f5f5;
    padding: 26px 0 10px;
}

.topdfviewer{
  box-shadow: 0px 6px 10px rgba(0,0,0,.3), 0px 6px 10px #ffffff;
  transition: .3s ease;
  margin-bottom: 0.4em;
}

.topdfviewer:hover {
  transform: scale(1.06);
}

section.discount-cam{
  border-top: 5px solid #88bb1b;
  border-bottom: 5px solid #88bb1b;
  padding: 3.2em 10px 3.2em;
  position: relative;
  background: #f5f9ec;
  max-width: 1200px;
  margin: 40px auto 0;
}

.discount-cam-inner{
  max-width: 860px;
  margin: 0 auto;
}

.discount-cam .explanation{
  display: block;
  margin-top: 0.4em;
}

ol.pleasure-list {
  counter-reset:number;
  list-style-type: none!important;
  padding:0;
  font-size: 18px;
}
ol.pleasure-list li {
  position: relative;
  padding: 0.8em;
  background: #ffffff;
  border-left : solid 35px #0b9944;
  margin-bottom: 5px;
}
ol.pleasure-list li:before{
  position: absolute;
  counter-increment: number;
  content: counter(number);
  display:inline-block;
  color: white;
  font-weight:bold;
  font-size: 16px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: -35px;
  width: 35px;
  height: 1em;
  line-height: 1;
  text-align: center;
}

a[href^="#no"]:not(:root){
  font-size: 24px;
  border-bottom: solid 1px;
  text-decoration: none;
}
a[href^="#no"]:hover{
  border-bottom: none;
}
.main-content{
  max-width: 860px;
  margin:0 auto 40px;
  background:#fff;
  font-size:medium;
}

.main-content a, .discount-cam-inner a{
  font-weight: 700;
  text-decoration: underline;
  color: #428bca;
  transition: .3s ease;
}

.main-content a:hover, .discount-cam-inner a:hover{
  color: #2b6496;
}

section h2{
  margin: 0 30px 48px;
  font-weight: 700;
  text-align: center;
  position: relative;
}

section h2:before,
section h2:after {
  position: absolute;
  z-index: 0;
  bottom: -10px;
  display: block;
  content: '';
  border: 1em solid #088038;
}

section h2:before {
  left: -36px;
  border-left-width: 15px;
  border-left-color: transparent;
}

section h2:after {
  right: -36px;
  border-right-width: 15px;
  border-right-color: transparent;
}

section h2 span {
  position: relative;
  z-index: 1;
  display: block;
  padding: 1rem 2rem;
  color: #fff;
  background: #0b9944;
  line-height: 1.4;
}

section h2 span:before,
section h2 span:after {
  position: absolute;
  bottom: -10px;
  display: block;
  width: 10px;
  height: 10px;
  content: '';
  border-style: solid;
  border-color:#04421d transparent transparent transparent;
}

section h2 span:before {
  left: 0;
  border-width: 10px 0 0 10px;
}

section h2 span:after {
  right: 0;
  border-width: 10px 10px 0 0;
}

.no3-subhead{
  position: relative;
  padding: 0.6em 0.8em 0.6em 3.2em;
  background: #f5f9ec;
  border-radius: 10px;
  margin: 2.8em 0 1em;
  line-height: 1.4;
  font-weight: 700;
  font-size: 24px;
}

.no3-subhead span{
  position: absolute;
  display: inline-block;
  color: white;
  font-weight: bold;
  font-size: 26px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 13px;
  width: 44px;
  height: 44px;
  line-height: 44px;
  text-align: center;
  background: #0b9944;
  border-radius: 5px;
}
.no3-subhead small{
  font-size: 85%;
  font-weight: 700;
  color: inherit;
}

.overview dt{
  float: left;
  margin-right: 8px;
}
.overview dd{
  margin-left: 50px;
  margin-bottom: 18px;
  border-left: 3px solid #8dc31a;
  padding-left: 10px;
}
ol.contents-list{
  padding-left: 20px;
  list-style: none;
  counter-reset: number;
}
ol.contents-list li{
  padding-left: 20px;
  text-indent: -2.8em;
}
ol.contents-list li:not(:last-child){
  margin-bottom: 0.4em;
}
ol.contents-list li::before{
  counter-increment: number;
  content: "［"counter(number)"］";
}


.discount-cam p{
  font-size: medium;
}

.note-box{
  border: solid 3px #8dc31a;
  border-radius: 20px;
  padding: 10px 20px 20px;
  margin-top: 36px;
  background: #f5f9ec;
}

.note-box h3,
.procedure-box h3{
  font-weight: 700;
  font-size: 20px;
  clear: both;
}
.note-box h3::before{
  margin-right: 6px;
  font-size: 12px;
  font-weight: 900;
  background: #333;
  width: 22px;
  height: 23px;
  line-height: 23px;
  text-align: center;
  border-radius: 50%;
  display: inline-block;
  color: #f5f9ec;
  vertical-align: bottom;
  padding-left: 2px;
}

.note-box li:not(:last-child){
  margin-bottom: 0.4em;
}
.procedure-box{
  margin-top: 2em;
}
.procedure-box h3{
  margin-top: 50px;
  font-size: 22px;
  color: #0b9944;
}
.procedure-box h3::before{
  color: #0b9944;
  font-weight: 900;
  margin-right: 6px;
}
.procedure-box ol.pleasure-list{
  margin-bottom: 3em;
}
.procedure-box ol.pleasure-list img{
  margin-right: 2px;
}
.procedure-box ol.pleasure-list li{
  background: #f5f9ec;
}
.procedure-box .fa-envelope{
  margin-right: 2px;
}

.present-box {
  position: relative;
  margin: 2.2em 0 1em;
  padding: 1.5em 1.4em 1.1em;
  border: solid 3px #94c1f1;
  border-radius: 8px;
  font-size: 2.6rem;
  font-weight: 700;
  text-align: center;
  background: #ecf5f9;
}
.present-box .present-box-title {
  position: absolute;
  top: 0;
  left: 50%;
  padding: 6px 10px;
  line-height: 1;
  font-size: 18px;
  background: #5b9ee7;
  color: #ffffff;
  font-weight: bold;
  transform: translateX(-50%) translateY(-50%);
  text-align: center;
  border-radius: 4px;
  width: 90%;
  line-height: 1.2;
}
.present-box p {
    margin: 0;
    padding: 0;
}
.xlsx-download{
  text-align: center;
  display: block;
  margin: 1em 0;
}
.xlsx-download img{
  vertical-align: baseline;
  margin-right: 3px;
}
.return-btn{
  text-align: center;
  margin-top: 70px;
}
.return-btn a {
  display: inline-block;
  background: #fff;
  border-radius: 50px;
  line-height: 1.7;
  border: 3px solid #71787b;
  color: #71787b;
  font-weight: 700;
  -webkit-font-smoothing: antialiased;
  text-decoration: none;
  padding: 2px 24px;
  font-size: medium;
}
.return-btn a:hover {
  background: #71787b;
  color: #fff;
}
.remo{
  margin-top: 10px;
}
.remo a{
  background: #7bc308;
  color: #fff;
  border-color: #7bc308;
  border-radius: 10px;
  position: relative;
  padding: 8px 64px;
  border-bottom: 5px solid #568807;
  font-size: 20px;
  line-height: 1.4;
}
.remo a:hover {
  background: #fff;
  color: #7bc308;
}
.remo i{
  position: absolute;
  top: calc(50% - .5em);
  right: 0.6rem;
}

mark.active{
    background-position: -100% .7em;
}

mark{
  background-image: -webkit-linear-gradient(to right,transparent 50%,#fff042 50%);
  background-image: -moz-linear-gradient(to right,transparent 50%,#fff042 50%);
  background-image: linear-gradient(to right,transparent 50%,#fff042 50%);
  background-color:initial;
  font-weight: 700;
  background-repeat: repeat-x;
  background-size: 200% .6em;
  background-position: 0 .7em;
  transition: all 1.5s ease;
  font-weight: 700;
  padding:0;
  padding-bottom: 7px;
}

@media screen and (max-width: 640px){
.present .bookcover{padding:1em 0.5em;}
.main-content h2.head2 img{
  width:85%;
}
section h2 {
  font-size: 2rem;
  margin: 0 0 30px;
}
section h2:after {
  right: -25px;
}
section h2:before {
  left: -25px;
}
.present .bookcover{padding:1em 0.5em;}

.title-box h1{
    font-size: 110%;
    line-height: 1.7;
  }
.title-box h1 .text-deco{
    line-height: 1.4;
    font-size: 1.8rem;
}
section.discount-cam ol {
    font-size:15px;
    margin-top: 2em;
  }
img.hitsuji-icon{
    width: 26px;
  }
.main-content h2.head2{
    margin:80px auto 20px;
  }
.present-box {
    padding: 2em 1em 1.2em;
    font-size: 1.8rem;
    margin: 2.6em 0 1em;
  }
.present-box .present-box-title {
    font-size: 14px;
  }
.return-btn a {
    font-size:medium;
  }
.remo a {
    padding: 8px 42px;
}
.no3-subhead {
    padding: 0.4em 0.8em 0.4em 3.6em;
    font-size: 18px;
}
.no3-subhead span{
  font-size: 22px;
  width: 40px;
  height: 40px;
  line-height: 40px;
}
a[href^="#no"]:not(:root){
  font-size: 18px;
}
.note-box h3, .procedure-box h3{
  font-size: 18px;
}
.note-box h3::before{
  margin-right: 4px;
  font-size: 10px;
  width: 20px;
  height: 21px;
  line-height: 21px;
  padding-left: 1px;
}
.note-box ul{
  font-size: 15px;
  padding-left: 20px;
}
ol.pleasure-list {
  font-size: 16px;
}
}
@media (max-width: 460px){
  .pleasure-list .mail{
    display: flex;
    align-items: baseline;
    word-break: break-word;
}
}

.main-content .mb-30{
  margin-bottom:30px;
}

.justify-content-center{
  padding:14px 0 0 0;
  background: #f5f5f5;
  margin-top:2.4em;
}

.justify-content-center .btn{
  margin: 0 0 10px;
  font-size:16px;
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0px 6px 10px rgba(0,0,0,.3), 0px 6px 10px #ffffff;
  padding: 6px 6px;
  display: inline-block;
  color: #fff;
  transition: .25s all ease-out;
  width:100%;
  font-weight: 700;
  -webkit-font-smoothing: antialiased;
}

.justify-content-center .btn span{
    padding: 10px 0;
    background: #12ab8b;
    display: inline-block;
    border-radius: 10px;
    width:100%;
}

.justify-content-center .btn span:before{
    content: '';
    border: solid #fff;
    border-width: 0 3px 3px 0;
    display: inline-block;
    width: 10px;
    height: 10px;
    transform: rotate(-45deg);
    margin: 0 12px 0 0;
    position: relative;
    top: -2px;
}

@media screen and (max-width: 768px){
  #contents{
    padding: 0;
  }
  .justify-content-center{
    margin-right: -15px;
    margin-left: -15px;
  }
.justify-content-center .btn{
    font-size:14px;
}
.justify-content-center .mgb{
    margin-bottom:1em;
}
  }
@media screen and (max-width: 319px){
  .justify-content-center .btn{
  font-size: 4.2vw;
  }
}

.justify-content-center .btn:hover {
  border-radius: 10px;
  background: #ffffff;
  box-shadow:0 19px 38px rgba(0,0,0,.3),0 15px 12px rgba(0,0,0,.22);
  transform: translateY(-3px);
  color: #fff
}

.justify-content-center .btn2 span{
    background: #4990de;
  }

.mt4{
  margin-top: 4em;
}
.mt5{
  margin-top: 5em;
}
.mt6{
  margin-top: 6em;
}
.mt7{
  margin-top: 7em;
}

.login-notice {
	    text-align: center;
		margin-top:  4em;
}
