body {
 font-family: Helvetica, Arial, Verdana, sans-serif;
 font-size: 13px;
 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: #51257a
}

p.error,
span.important {
 font-size: 13px !important;
 font-weight: bold;
 padding: 0;
 color: #f00;
}

p.error {
 display: none;
}

div,
th,
td {
 box-sizing: border-box;
}

.disc li {
 list-style-type: disc;
 margin: 0 0 0 1.5em;
}

.pc {
 display: none;
}

img {
 max-width: 100%;
}

/* ----------btn---------- */

a.btn::before,
a.btn::after {
 position: absolute;
 z-index: -1;
 display: block;
 content: '';
}

a.btn,
a.btn::before,
a.btn::after {
 -webkit-box-sizing: border-box;
 -moz-box-sizing: border-box;
 box-sizing: border-box;
 -webkit-transition: all .3s;
 transition: all .3s;
}

a.btn {
 font-size: 140%;
 font-weight: 700;
 line-height: 60px;
 position: relative;
 display: block;
 height: 60px;
 margin: 0 5vw 12px 5vw;
 -webkit-transition: none;
 transition: none;
 text-align: center;
 text-decoration: none;
 color: #fff;
 border-radius: 4px;
 background-color: #582283;
}

a.btn.negative {
 background-color: #CCC;
 margin: 0 5vw 16px 5vw;
}

div.btn {
 padding: 16px 0 0;
 text-align: center;
}

/* ----------form---------- */

#form {
 background: #f1f3f8;
 border-radius: 0 0 16px 16px;
 padding: 0 5vw 5vw 5vw;
 margin: -1px 0 0 0;
}

#form .required {
 color: red;
}

#form h2 {
 padding: 0;
}

#form h2 img {
 width: 40vw;
}

#form.complete h2 img {
 width: 50vw;
}

#form h3 {
 font-weight: 700;
}

#form .directions {
 font-size: 14px;
 line-height: 1.4;
 margin: 2vw 0 0 0;
}

#form .pp {
 border: 1px solid #CCC;
 padding: 8px;
 margin: 5vw 0;
}

#form .pp h3 {
 font-weight: 700;
}

#form .pp_agree {
 background: #fffcda;
 font-weight: 700;
 text-align: center;
 padding: 8px;
}

/* ----------input---------- */
#form input {
 box-sizing: border-box;
}

#form input.mail {
 width: 100%;
}

#form input.name {
 width: 48%;
}

#form input.serial-text {
 width: 100%;
 font-weight: 700;
 font-size: 32px !important;
 margin: 8px 0 0 0;
}

#form input.text {
 border: 1px solid #ccc;
 font-size: 140%;
 padding: 8px;
 border-radius: 4px;
}

/* ----------serial---------- */

#form .serial-image {
 padding: 16px 0;
}

#form .serial_input span {
 display: block;
}

#form .answer.serial_input span {
 font-size: 16px;
 display: block;
}

#form .answer.serial_input li {
 font-size: 32px;
}

/* ----------enquete---------- */

.question {
 font-weight: 700;
 padding: 5vw 0 0 0;
 border-top: 1px solid #d7dbe5
}

.choice {
 padding: 3vw 0 5vw 5vw;
}

.choice li {
 margin: 0 0 2vw 0;
}

.choice li:last-child {
 margin: 0 0 0 0;
}

/* ----------footer---------- */

footer {
 padding: 5vw;
 background: #FFF;
 position: relative;
}

p.note {
 font-size: 12px;
}

p.mf_note {
 font-size: 12px;
 margin: 8px 0 0 16px;
}

.mf {
 margin: 8px 0 0 5vw;
}

.mf img {
 width: 80vw;
}

ul.note {
 font-size: 12px;
}

ul.note li {
 font-size: 12px;
}

p.approval {
 color: #333;
 font-size: 10px;
 color: #999;
 line-height: 1.8;
 margin: 0 0 5vw 0
}

footer p {
 font-size: 10px;
 font-weight: 400;
}

ul.horizontal li {
 display: inline-block;
 margin: 0 5vw 0 0;
}

/* ----------custom---------- */

.logo {
 padding: 5vw 0 0 5vw;
}

.logo img {
 width: 25vw;
}

.main {
 box-sizing: border-box;
 padding: 0 0;
 background: #FFF;
 text-align: center;
 margin: 5vw 0 0 0;
}

.main img {
 vertical-align: top;
}

.form_item_name {
 font-weight: 700;
 font-size: 20px;
 padding: 5vw 0 2vw 0;
 margin: 5vw 0 0 0;
 border-top: 3px solid #d7dbe5;
}

.form_item_input.gift ul {
 margin: 0 0 0 5vw;
}

.form_item_input.store ul {
 margin: 0 0 0 0;
}

.form_item_input li {
 margin: 0 0 2vw 0;
}

/* ----------store---------- */

#form .store ul li {
 list-style-type: none;
 padding: 5vw 5vw 5vw 0;
 border-top: 1px solid #d7dbe5
}

#form .store ul li:last-child {
 border-bottom: none;
 padding-bottom: 0;
}

#form .store ul li strong {
 font-weight: normal;
}

#form .store ul li ul {
 list-style-type: none;
}

#form .store ul li ul span {
 display: block;
}

#form .store ul li ul li {
 border-top: none;
 border-bottom: none;
 padding: 2vw 5vw 0 20px;
}

#form .store ul li ul li:last-child {
 border-right: none;
}

#form .store .answer {
 display: block;
 font-weight: 700;
}

ul.clear.store-name li {
 padding: 0 8px 8px 8px;
 float: left;
 box-sizing: border-box;
}

.gift_guide {
 padding: 5vw 0 0 0;
}

.gift_guide p {
 line-height: 1.8;
}

.gift_guide h4 {
 font-weight: 700;
}

.get {
 background: #FFF;
 text-align: center;
 border-radius: 4vw;
 color: #5a2386;
 cursor: pointer;
 margin: 5vw 0;
 padding: 5vw;
}

.get:hover {
 box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.1);
}

.get h3 {
 padding: 0;
 line-height: 1;
 font-size: 20px;
}

.get p {
 padding: 0;
 line-height: 1.6;
 font-size: 3vw;
 margin: 2vw 0 0 0;
}

.get .url {
 font-size: 3vw;
 font-weight: 700;
}

.inquiry {
 padding: 3vw;
 border: 1px solid #d7dbe5;
 margin: 5vw 0 0 0;
}

.inquiry h4 {
 padding: 0;
}

.privacypolicy {
 padding: 5vw;
 margin: 5vw 0 0 0;
 background: #FFF;
 border-radius: 8px;
}
