body {
 font-family: 'Helvetica Neue', Helvetica, Arial, Verdana, 'Òé®ÎÒ´ ProN W3', 'Hiragino Kaku Gothic ProN', 'á¤êª', Meiryo, '-3 0´·Ã¯', 'MS PGothic', sans-serif;
 font-size: 14.5px;
 line-height: 1.6;
 margin: 0;
 padding: 0;
 color: #333;
 *font-size: medium;
 *font: small;
 _font-size: 1;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol {
 font-size: 100%;
 font-weight: normal;
 font-style: normal;
 margin: 0;
 padding: 0;
 list-style-type: none;
}
a {
 color: #3333cc
}
p.error {
 font-weight: bold;
 display: none;
 margin: 0 0 6px 0;
 color: #f00;
 font-size: 14px;
}
em {
 font-weight: 700;
 font-style: normal;
 color: #f00;
}
.sp {
 display: none;
}
div,
th,
td {
 box-sizing: border-box;
}
.disc li {
 list-style-type: disc;
 margin: 0 0 0 1.5em;
}
.note {
 font-size: 80%
}
/* ----------interaction---------- */

.accordion,
.accordion-open {
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.course1_accordion-contents,
.course2_accordion-contents {
 display: none;
}
.hidden {
 display: none;
}
/* ----------button---------- */

a.btn {
 background-color: #e94f7f;
 border-radius: 4px;
 color: #fff;
 display: inline-block;
 font-size: 140%;
 font-weight: 700;
 height: 60px;
 line-height: 60px;
 margin: 0 16px;
 position: relative;
 text-align: center;
 text-decoration: none;
 transition: none;
 width: 300px;
 -moz-box-sizing: border-box;
 -webkit-box-sizing: border-box;
 -webkit-transition: all .3s;
 box-sizing: border-box;
 transition: all .3s;
}
a.btn:hover {
 background-color: #e94f7f;
}
a.btn.negative {
 background-color: #CCC;
}
a.btn.negative:hover {
 background-color: #999;
}
div.btn {
 padding: 64px 0;
 text-align: center;
}
/* ----------base---------- */

.body {
 background: #c8e9fa;
 padding: 0 0 64px 0
}
.inner {
 width: 960px;
 margin: 0 auto;
}
p.lead {
 padding: 20px;
}
/* ----------header---------- */

.header {}
/* ----------form---------- */

#form {
 background: #fff;
 border: none;
 margin: 0 0;
 z-index: 100;
 position: relative;
}
#form .required-notice {
 padding: 8px 0;
 text-align: center;
}
#form .required {
 color: red;
}
#form h2 {
 background: #f7ee19;
 color: #e94f7f;
 font-size: 120%;
 font-weight: 700;
 margin: 0;
 padding: 12px 6px 12px;
 text-align: center;
}
#form h3 {
 font-weight: 700;
 margin: 16px 0 8px 0;
}
#form .directions {
 margin: 0 0 16px 0;
}
#form .pp {
 border: 1px solid #CCC;
 margin: 0 20px 20px;
 padding: 10px;
}
#form .pp h3 {
 font-weight: 700;
}
#form .pp p {
 margin: 12px 8px 8px;
}
#form .pp-apply {
 background: #fffcda;
 font-weight: 700;
 text-align: center;
}
/* ----------input---------- */

#form input.address {
 width: 440px;
}
#form input.mail {
 margin: 6px 0;
 width: 460px;
}
#form input.name {
 width: 160px;
}
#form input.postalcode1 {
 width: 60px;
}
#form input.postalcode2,
#form input.tel {
 width: 80px;
}
#form .quiz input {
 margin: 0 8px 0 0;
 text-align: center;
 width: 4em;
 font-size: 24px;
 padding: 8px;
}
#form input.text {
 border: 1px solid #ccc;
 font-size: 140%;
 padding: 6px;
}
/* ----------table---------- */

#form table {
 background: #fff;
 border-collapse: collapse;
 width: 100%;
}
#form th {
 background: #f1f1f1;
 text-align: left;
 vertical-align: top;
 width: 25%;
}
#form th,
#form td {
 border: 1px solid #DDD;
 border-left: none;
 border-right: none;
 padding: 12px 18px;
}
#form table.addresstable {
 border: none;
 border-collapse: collapse;
 width: 100%;
}
#form table.addresstable th {
 background: none;
 border: none;
 font-size: 100%;
 padding: 6px 12px;
 vertical-align: middle;
 width: 120px;
 white-space: nowrap
}
#form .addresstable td {
 border: none;
 padding: 6px 12px;
 vertical-align: middle;
}
/* ----------serial---------- */

#form .serial-input {
 position: relative;
}
#form .serial-input li {
 border-bottom: 1px solid #e6e6e6;
 margin: 0 0 16px 0;
 padding: 0 16px 8px 0;
}
#form .serial-input li:last-child {
 border-bottom: none;
 margin: 0 0 0 0;
 padding: 0 16px 0 0;
}
#form .serial-input li span {
 display: block;
 padding: 0 0 6px;
}
#form .serial-input .serial-image {
 top: 0px;
 right: 0px;
 position: absolute;
 padding: 32px 0;
}
#form .serial-input .serial-image img {
 width: 290px;
}
#form .serial-input .answer {
 font-size: 200%;
 font-weight: 700;
 margin: -8px 0 -8px 0;
}
#form input.serial-text {
 width: 100%;
 font-size: 32px!important;
 font-weight: 700;
}
/* ----------store---------- */

#form .store ul li {
 list-style-type: none;
 margin: 0 0 16px 0;
 padding: 0 16px 16px 0;
 border-bottom: 1px solid #CCC;
}
#form .store ul li:last-child {
 border-bottom: none;
 padding-bottom: 0;
}
#form .store ul li strong {
 font-size: 110%;
}
#form .store ul li ul {
 list-style-type: none;
 margin: 16px 0 0 4px;
}
#form .store ul li ul span {
 display: block;
}
#form .store ul li ul li {
 border-bottom: none;
 display: table-cell;
 border-right: 1px solid #CCC;
 padding: 0 16px 0 16px;
}
#form .store ul li ul li:last-child {
 border-right: none;
}
#form .store .answer {
 display: block;
 margin: 0 0 16px 0;
 font-weight: 700;
}
#form .store li:last-child .answer {
 margin: 0 0 0 0;
}
ul.clear.store-name li {
 margin: 0 0 16px 0;
 padding: 0 8px 8px 8px;
 float: left;
 box-sizing: border-box;
}
/* ----------prize---------- */

#form .prize {
 margin: 16px 16px 0 0;
}
#form .prize li {
 margin: 0 0 8px 0;
 margin: 0 0 8px 0;
 margin-left: 1.3em;
 text-indent: -1.3em;
}
#form .prize-table td {
 border: none !important;
 padding: 4px 32px 4px 0 !important;
 white-space: nowrap;
}
/* ----------enquete---------- */

#form .enquete .answer {
 margin: 16px 0 0 0;
}
#form .enquete ul li {
 margin: 0 0 8px 0;
 margin: 0 0 8px 0;
 margin-left: 1.3em;
 text-indent: -1.3em;
}
.enquete ol > li {
 padding: 0 0 16px 0;
 margin: 0 0 16px 0;
 border-bottom: 1px solid #eedbdf;
}
.enquete ol > li:last-child {
 border-bottom: none;
 margin: 0 0 0 0;
}
p.question {
 font-size: 110%;
 font-weight: 700;
 margin: 0 0 8px 0;
}
/* ----------quiz---------- */

.quiz {
 background: #fffcd9;
 font-size: 14px;
 line-height: 1.4;
 padding: 16px;
 position: relative;
}
.quiz p.note {
 bottom: 16px;
 position: absolute;
 right: 16px;
}
.quiz .quiz_answer {
 font-size: 24px;
 font-weight: 700;
 display: inline-block;
 background: #FFF;
 padding: 8px;
 margin: 16px 0 0 0;
}
/* ----------information---------- */

.HAF {
 margin: 0 0 0 20px;
 padding: 32px 0 32px 0;
 border-top: 1px solid #CCC;
}
.HAF .HAF-image {
 float: left;
 width: 300px;
}
.HAF img {
 width: 300px;
}
.HAF .HAF-text {
 float: left;
 width: 540px;
}
#form .HAF h2 {
 background: none;
 color: #0069af;
 font-size: 140%;
 text-align: left;
 margin: 0 32px;
 padding: 0;
}
.HAF p {
 margin: 8px 32px;
 line-height: 1.8;
 padding: 0;
}
.HAF a.btn {
 margin: 16px 16px 16px 32px;
 line-height: 1;
 height: auto;
 font-size: 14px;
 background: #0069af;
 display: block;
 padding: 16px;
}
.HAF a.btn:hover {
 background: #1278bc;
}
/* ----------footer---------- */

footer {
 padding: 0 56px 56px 56px;
 margin: 16px 0 0 0;
 text-align: right;
 background: #FFF;
 position: relative;
}
p.note {
 font-size: 12px;
 margin: 16px 0 0 16px;
}
p.approval {
 text-align: right;
 padding: 0 0 32px 0;
 margin: 0 0 0 0;
 color: #333;
 font-size: 10px;
}
footer img {
 width: 140px;
}
footer p {
 font-size: 10px;
 font-weight: 400;
 margin: 16px 0 0 0;
}
.clear {
 zoom: 1
}
.clear:after {
 display: block;
 visibility: hidden;
 clear: both;
 height: 0;
 content: '';
}
.inquiry {
 position: absolute;
 top: 16px;
 text-align: left;
}
.inquiry .inquiry_title {
 font-weight: 700;
}
.inquiry p {
 margin: 8px 0 0 0;
 font-size: 14px;
}
/* ----------serial4---------- */

#form .serial-input {}
#form .serial-input .serial-image {
 text-align: center;
 position: relative;
}
#form .serial-input .serial-image img {
 width: 290px;
}
#form .serial-input li {
 border-bottom: 1px solid #e6e6e6;
 margin: 0 0 16px 0;
 padding: 0 8px 8px 8px;
 float: left;
 width: 50%;
 box-sizing: border-box;
}
#form .serial-input li:nth-last-child(1),
#form .serial-input li:nth-last-child(2) {
 border-bottom: none;
 margin: 0 0 0 0;
 padding: 0 8px 0 8px;
}
#form .serial-input li span {
 display: block;
 padding: 0 0 6px;
}
#form .serial-input .answer {
 font-size: 200%;
 font-weight: 700;
 margin: -8px 0 -8px 0;
}
#form input.serial-text {
 width: 100%;
 box-sizing: border-box;
 font-size: 32px!important;
 font-weight: 700;
}
/* ----------course select---------- */

.course_select {
 background: #fffcda;
 padding: 1px 16px 8px 16px;
 margin: 8px 0 16px 0;
 font-weight: 700;
}
.course_select li {
 font-weight: 700;
}
#form .course_select + p + .prize {
 margin: 0 0 0 16px;
}
#form .course_select + .answer {
 margin: 0 0 16px 16px;
}
.thanks {
 padding: 32px;
}
.thanks .note {
 margin: 16px 0 0 0;
}
.gifpy .code {
 text-align: center;
 padding: 16px;
 margin: 16px 0;
 background: #EEE;
 font-weight: 700;
 font-size: 140%;
}
.gifpy-notice {
 font-size: 60%;
 font-weight: 400;
 display: block;
}
.code-url {
 font-size: 60%;
 font-weight: 400;
 display: block;
}
.gifpy a {
 text-decoration: none;
 color: #d83358;
}
.gifpy .value {
 font-size: 80%;
 line-height: 1;
 font-weight: 400;
 margin: 8px 0 0 0;
}
.gifpy h3 {
 font-weight: 700;
 margin: 24px 24px 0px 24px;
}
.gifpy .num {
 list-style-type: decimal;
 margin: 12px 0 12px 24px
}
/* ----------ipassport---------- */

.course-select ul {
 margin: 8px;
}
.course-select ul li {
 margin: 8px 0;
}
.course-select label {
 font-weight: 700;
}
#form .ipassport {
 margin: 0 0 0 0;
}
.ipassport-inner {
 padding: 24px;
 background: #FFF;
}
.ipassport-passport .ipassport-inner {
 padding: 24px;
}
#form .ipassport ol {
 margin: 12px 0 0 0;
}
#form .ipassport ol li {
 margin: 0 0 16px 0;
 border-top: 1px solid #CCC;
 padding: 16px 0 0 0;
}
#form .ipassport ol li h3 {
 font-weight: 700;
 font-size: 120%;
 margin: 0 0 8px 0;
}
#form .ipassport ol li p {
 margin: 8px 0 8px 0;
}
#form .ipassport ol li p.note {
 margin: 0 0 0 0;
}
#form .ipassport ol li p.kome {
 margin-left: 18px;
 text-indent: -12px;
}
#form .ipassport .serial p.note {
 padding: 12px 0;
 text-align: center;
}
#form .ipassport p {
 margin: 0 0 8px 0
}
#form .ipassport .serial {
 margin: 0 0 0 0;
 padding: 0 0 0 0;
}
#form .ipassport .serial p {
 padding: 0;
}
#form .ipassport .serial p.note {
 padding: 12px 0;
 text-align: center;
}
#form .ipassport .schedule {
 width: 100%;
 border-collapse: collapse;
 border: 1px solid #DDD;
}
#form .ipassport .schedule th {
 border: 1px solid #DDD;
 text-align: center;
 box-sizing: border-box;
}
#form .ipassport .schedule td {
 box-sizing: border-box;
}
#form .ipassport .schedule .head {
 height: 40px;
}
#form .ipassport .schedule td.head {
 width: 252px;
}
#form .ipassport .schedule th.month {
 width: 110px;
}
#form .ipassport .schedule .month {
 width: 110px;
 line-height: 1.2;
}
#form .ipassport .schedule td {
 text-align: center;
 border: 1px solid #DDD;
 background: #fff7eb;
}
#form .ipassport .schedule .step1 {
 height: 130px;
}
#form .ipassport .schedule .step2 {
 height: 60px;
}
#form .ipassport .schedule .step3 {
 height: 60px;
}
#form .important {
 font-weight: 700;
 color: #ff0000;
}
.schedule-wrapper {
 position: relative;
 margin: 0 0 16px 0;
}
.period1 {
 position: absolute;
 background: #FFF;
 display: inline-block;
 text-align: center;
 padding: 4px 0;
 width: 246px;
 top: 52px;
 left: 269px;
 font-size: 90%;
}
.period2 {
 position: absolute;
 background: #fbeb45;
 display: inline-block;
 text-align: center;
 padding: 4px 0;
 width: 298px;
 top: 86px;
 left: 269px;
 font-size: 90%;
}
.period3 {
 position: absolute;
 background: #fbeb45;
 display: inline-block;
 text-align: center;
 padding: 4px 0;
 width: 346px;
 top: 186px;
 left: 518px;
 font-size: 90%;
}
.period4 {
 position: absolute;
 background: #fbeb45;
 display: inline-block;
 text-align: center;
 padding: 4px 0;
 width: 346px;
 top: 246px;
 left: 518px;
 font-size: 90%;
}
.mail1 {
 position: absolute;
 display: inline-block;
 text-align: center;
 padding: 4px 0;
 width: 272px;
 font-size: 80%;
 top: 118px;
 left: 294px;
}
.mail2 {
 position: absolute;
 display: inline-block;
 text-align: center;
 padding: 4px 0;
 width: 315px;
 font-size: 80%;
 top: 119px;
 left: 550px;
}
.mail2 img {
 margin: 0 24px;
}
.header {
 text-align: center;
 margin: 0 auto 0 auto;
 padding: 32px 0;
 width: 800px;
}
.header img {
 width: 100%;
}
.accordion,
.accordion-open {
 cursor: pointer;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.accordion-contents {
 display: none;
 padding: 8px 36px !important;
}
