@charset "utf-8";
/* CSS Document */

/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17

*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

body {
    line-height:1;
}

* {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
	display:block;
}

ul,ol {
    list-style:none;
}

blockquote, q {
    quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}

/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}

table {
    border-collapse:collapse;
    border-spacing:0;
}

/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}
img{
	max-width: 100%;
	vertical-align:bottom;
}

/************** layout base ********************/
.clearfix{
	overflow:hidden;
}
.clear{
	clear:both;
}

a,
a:hover{text-decoration:none;}
a:link{}
a:visited{}

sup {
	line-height: 100%;
	font-size:10px;
	vertical-align: 0.4em;
}
sub{
	line-height: 100%;
	font-size:10px;
	vertical-align: -0.1em;
}

.txtLeft{
text-align:left;
}
.txtRight{
text-align:right;
}
.txtCenter{
text-align:center;
}
.fw{font-weight:bold !important;}
.f10{ font-size:10px !important;}
.f11{ font-size:11px !important;}
.f12{ font-size:12px !important;}
.f13{ font-size:13px !important;}
.f14{ font-size:14px !important;}
.f15{ font-size:15px !important;}
.f16{ font-size:16px !important;}
.f17{ font-size:17px !important;}
.f18{ font-size:18px !important;}
.f20{ font-size:20px !important;}
.f22{ font-size:22px !important;}
.f24{ font-size:24px !important;}

.txtRed{ color:#D80000;}
.txtOrange{ color:#ff7800;}
.txtBlue{ color:#0d5bab;}
.txtPurple{ color:#463fa7; }
.note{ color:#666666; font-size:12px;}

.fLeft{ float:left;}
.fRight{ float:right;}
.fNon{
	float:none !important;
}

.mTop0{ margin-top:0 !important;}
.mTop5{ margin-top:5px !important;}
.mTop10{ margin-top:10px !important;}
.mTop15{ margin-top:15px !important;}
.mTop20{ margin-top:20px !important;}
.mTop25{ margin-top:25px !important;}
.mTop30{ margin-top:30px !important;}
.mTop35{ margin-top:35px !important;}
.mTop40{ margin-top:40px !important;}
.mTop45{ margin-top:45px !important;}
.mTop50{ margin-top:50px !important;}
.mTop55{ margin-top:55px !important;}
.mTop60{ margin-top:60px !important;}

.mBtm0{ margin-bottom:0 !important;}
.mBtm5{ margin-bottom:5px !important;}
.mBtm10{ margin-bottom:10px !important;}
.mBtm15{ margin-bottom:15px !important;}
.mBtm20{ margin-bottom:20px !important;}
.mBtm25{ margin-bottom:25px !important;}
.mBtm30{ margin-bottom:30px !important;}
.mBtm35{ margin-bottom:35px !important;}
.mBtm40{ margin-bottom:40px !important;}
.mBtm45{ margin-bottom:45px !important;}
.mBtm50{ margin-bottom:50px !important;}
.mBtm55{ margin-bottom:55px !important;}
.mBtm60{ margin-bottom:60px !important;}
.mBtm70{ margin-bottom:70px !important;}
.mBtm80{ margin-bottom:80px !important;}
.mBtm90{ margin-bottom:90px !important;}
.mBtm100{ margin-bottom:100px !important;}

.pTop0{ padding-top:0 !important;}
.pTop5{ padding-top:5px !important;}
.pTop10{ padding-top:10px !important;}
.pTop15{ padding-top:15px !important;}
.pTop20{ padding-top:20px !important;}
.pTop25{ padding-top:25px !important;}
.pTop30{ padding-top:30px !important;}
.pTop35{ padding-top:35px !important;}
.pTop40{ padding-top:40px !important;}
.pTop45{ padding-top:45px !important;}
.pTop50{ padding-top:50px !important;}

.pBtm0{ padding-bottom:0 !important;}
.pBtm5{ padding-bottom:5px !important;}
.pBtm10{ padding-bottom:10px !important;}
.pBtm15{ padding-bottom:15px !important;}
.pBtm20{ padding-bottom:20px !important;}
.pBtm25{ padding-bottom:25px !important;}
.pBtm30{ padding-bottom:30px !important;}
.pBtm35{ padding-bottom:35px !important;}
.pBtm40{ padding-bottom:40px !important;}
.pBtm45{ padding-bottom:45px !important;}
.pBtm50{ padding-bottom:50px !important;}
.pBtm55{ padding-bottom:55px !important;}
.pBtm60{ padding-bottom:60px !important;}

.disnon{
	display:none;
}


/************** layout base ********************/
body {
	background: #fff;
   font-family: 'Noto Sans Japanese', sans-serif;
   font-size: 100%;
	color: #000000;
}

div,p,dl {
	text-align:left;
	font-weight:400;
	font-size: 16px;
}
h1,h2,h3,h4,h5,h6 {
	text-align:left;
}


/* #fpagetop
---------------------------------------------------------------------------- */
#pagetop{
	position: fixed;
	right: 4%;
	bottom: 50px;
	
}

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

#footer{
  background: #939393;
  /* margin-top: 7%; */
  margin-top:0;
  padding: 20px 0;
}
#footer small{
  display: block;
  color: #ffffff;
  font-size: 10px;
  text-align: center;
}


/* header
---------------------------------------------------------------------------- */
#header #headerBtn{
	position: absolute;
	top:0;
	right: 10px;
	width: 120px;
}

#phrase #header{
	position: relative;
	background:url(images/pc_phrase_header_main.png) no-repeat center top;
	background-size: cover;
}
#phrase #header #headerInner {
	position: relative;
	width: 865px;
	height: 365px;
	margin: 0 auto;
}
#phrase #header #headerInner::after{
	content: "";
	position: absolute;
	right: -10px;
	bottom: 2px;
	display: block;
	background: url(images/pc_phrase_header_main_img.png) no-repeat;
	width: 303px;
	height: 331px;
}

#phrase #header h1{
margin-left: -160px;
}
#phrase #header #headerBook {
    position: relative;
    margin-top: -140px;
    margin-left: 142px;
    overflow: hidden;
    z-index: 999;
}
#phrase #header #headerBook > img {
    float: left;
    margin-right: 13px;
}
#phrase #header #headerBook span {
    display: block;
}
#phrase #header #headerBook span > img {
    margin: 30px 0 5px 0;
}

#header .headImg{
	position: absolute;
	top: 40px;
	right: -40px;
}


/* nav */
nav{
	background: url(../images/pc_navi_bg.png) no-repeat left top;
	background-size: auto auto;
	background-size: cover;
	padding-top: 15px;
}

nav ul {
	display: -webkit-box;
	display: -webkit-flex;
	display: flex;
	width: 850px;
	margin: 0 auto;
}

.keyMaga03 .keyMaga03{
	display: none;
}

/* phraseCollectionArea */
#phraseCollectionArea{
	background:url(../images/pc_phrase_img_giraff.png) no-repeat 72% 38px, url(../images/pc_phrase_bg.png) repeat-x top left, #f4f0df;
	padding:17px 0 45px;
}
#phraseCollectionArea h2{
	width:850px;
	margin:0 auto 50px;
	padding-left:117px;
}
#phraseCollectionArea h3{
	margin-bottom: 25px;
	text-align: center;
}
.phraseBox{
	display: -webkit-box;/*--- Androidブラウザ用 ---*/
	display: -ms-flexbox;/*--- IE10 ---*/
	display: -webkit-flex;/*--- safari（PC）用 ---*/
	display: box;
	display: flex;
	-webkit-box-pack: justify;/*--- Androidブラウザ用 ---*/
	-ms-flex-pack: justify;/*--- IE10 ---*/
	-webkit-justify-content: space-between;/*--- safari（PC）用 ---*/
	justify-content: space-between;
	position: relative;
	width: 864px;
	margin: 0 auto;
	padding: 0 15px 0 60px;
}

.phrase01 .phraseBox .leadImg{
	padding-top: 20px;
}
.phrase01 .phraseBox .leadImg ul{
	position: absolute;
	top: -15px;
	left: -50px;
	display: -webkit-box;/*--- Androidブラウザ用 ---*/
	display: -ms-flexbox;/*--- IE10 ---*/
	display: -webkit-flex;/*--- safari（PC）用 ---*/
	display: box;
	display: flex;
	-webkit-box-pack: justify;/*--- Androidブラウザ用 ---*/
	-ms-flex-pack: justify;/*--- IE10 ---*/
	-webkit-justify-content: space-between;/*--- safari（PC）用 ---*/
	justify-content: space-between;
	width: 396px;
}

.phrase02 .phraseBox{
	padding-left: 20px;
}
.phrase02 .phraseBox .leadImg{ margin-top: -10px;}

.phrase03 .phraseBox{
	padding-left: 20px;
}
.phrase03 .phraseBox .leadImg{ margin-top: -10px;}


.phraseBoxInner{
	margin-bottom: 30px;
}
.phraseBox:last-child .phraseBoxInner{
	margin-bottom: 0;
}
.phraseBoxInner h4{
	margin-bottom: 10px;
}

#rabbitArea {
	position:relative;
	width: 865px;
	margin: 0 auto;
	z-index:999;
}
#rabbitArea p{
	position: absolute;
	bottom: -70px;
}

#otherPhrase .otherPhraseInner{
	position: relative;
	padding-top: 70px;
}
#otherPhrase .otherPhraseInner h2{
	position: absolute;
	top: -20px;
	left: 40px;
}
#otherPhrase .otherPhraseInner .otherPhraseImg{
	position: absolute;
	top: -20px;
	right: 35px;
	z-index: 10;
}
.otherPhraseKeyMaga03{
	position: relative;
	z-index: 1;
}
.phrase01 .otherPhraseKeyMaga03{
	width: 165px; 
	margin: 0 0 60px 200px;
}
.phrase02 .otherPhraseKeyMaga03{
	margin: 0 0 60px 130px;
}

.otherPhraseKeyMaga04{
	display: -webkit-box;/*--- Androidブラウザ用 ---*/
	display: -ms-flexbox;/*--- IE10 ---*/
	display: -webkit-flex;/*--- safari（PC）用 ---*/
	display: box;
	display: flex;
	-webkit-box-pack: justify;/*--- Androidブラウザ用 ---*/
	-ms-flex-pack: justify;/*--- IE10 ---*/
	-webkit-justify-content: space-between;/*--- safari（PC）用 ---*/
	justify-content: space-between;
	position: relative;
	width: 352px;
	margin: 0 0 50px 120px;
	z-index: 1;
}
.otherPhraseKeyMaga04 li{
	width: 166px;
}

.keyMaga04 #otherPhrase #horseImg{
	position: relative;
	width: 865px;
	margin: 0 auto;
}
.keyMaga04 #otherPhrase #horseImg p{
	position: static;
}
.keyMaga04 #phraseHorse img{
	right:0;
	width:116px;
	position:absolute;
}
.keyMaga04 #phraseHorse img.h2{
	opacity:0;
	right:120px;
}


/* rhythmSoundArea */
#rhythmSoundArea{
	background: url(../images/pc_rhythm_sound_bg_top.png) repeat-x left 30px, url(../images/pc_rhythm_sound_bg_bottom.png) repeat-x left bottom;
	padding:64px 0 60px 0;
	margin-bottom: 25px;
}
#rhythmSoundArea h2{
	text-align:center;
}
#rhythmSoundArea h3{
	width: 460px;
	margin: 0 auto 5px auto;
}
#rhythmSoundArea #eenyArea{
	overflow:hidden;
	width: 850px;
	margin:-50px auto 0 auto;
}
#rhythmSoundArea #eenyArea .movieBox{
	position: relative;
	float:left;
	width:490px;
	margin-right: 30px;
	background: url(../images/pc_eeny_bg.png) no-repeat left bottom;
	padding-bottom:15px;
}
#rhythmSoundArea #eenyArea .movieBox iframe{
	margin: 3px 0 0 20px;
	width: 260px;
	height: auto;
}
#rhythmSoundArea #eenyArea .movieBox p{
	position: absolute;
	top: 70px;
	right: 60px;
	width: 127px;
}
#rhythmSoundArea #eenyArea .japaneseTxt{
	margin-top: 30px;
}