@charset "UTF-8";
@import url(//fonts.googleapis.com/css?family=Lato:300,400,700);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);

/*--------------------------------------
	Basic
---------------------------------------*/

html {
    width: 100%;
    height: 100%;
    min-height: 100%;
    -webkit-text-size-adjust: 100%;
}

* {
	margin: 0;
	padding: 0;
        word-break: break-all;
        -webkit-touch-callout:none;
        -webkit-tap-highlight-color:rgba(255,255,0,0.4);
        -webkit-text-size-adjust:none;
}

body,
h1,
h2,
h3,
h4,
p,
ul,
li,
img {
	margin: 0;
	padding: 0;
	border: 0;
}

li {list-style: none;}

a { color: #65ab31; text-decoration: none; }
a:hover { color: #65ab31; text-decoration: underline;}
/*a:visited	{ color: #; }*/
address { font-style: normal; }

.clearfix:after{
  content:".";
  display:block;
  height:0;
  clear:both;
  visibility:hidden;
}
.clearfix{
  overflow:hidden;
}
/* Hides from IE-mac \*/
* html .clearfix{
  height:1%;
  overflow:visible;
}
/* End hide from IE-mac */

body {
	background-color: #EFEFE5;
	color:#333333;
	font-size:15px;
	font-family: 'Noto Sans JP', 'Lato', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, 'メイリオ', sans-serif;
	line-height:1.4;
}

/* ---------------
	EXAMPLES FONT-SIZE
------------------
    10px = 66.7%
    11px = 73.3%
    12px = 80%
    13px = 86.7%
    14px = 93.3%
    15px = 100%
    16px = 106.7%
    17px = 113.3%
    18px = 120%
    19px = 126.7%
    20px = 133.3%
    21px = 140%
    22px = 146.7%
    23px = 153.3%
    24px = 160%
    25px = 166.7%
    26px = 173.3%
--------------- */


@media screen and (min-width: 320px) and (max-width: 959px) {

    header {
	background-color: #EFEFE5;
	height: 60px;
	text-align: center;
	position: relative;
    }

    header h1 {
	line-height: 50px;
    }

    header h1 img {
        height: 40px;
        vertical-align: bottom;
    }

    .search {
        display: none;
    }

    #footer_content {
        margin: 0 auto;
        padding: 5%;
        width: 90%;
    }

    #footer_content h2 {
        display: none;
    }

    #footerlink {
        float: left;
        text-align: left;
        width: 50%;
    }

    #footerlink li {
        margin-bottom: 15px;
    }

    #footerlink li a {
        margin-left: 6px;
    }

    #followus {
        float: left;
        text-align: left;
        width: 50%;
    }

    #followus dt {
         margin-bottom: 8px;
    }

    #followus dd {
        margin-bottom: 15px;
    }

    #followus dd span {
        margin-left: 10px;
    }
}


@media screen and (min-width: 960px) {

    header {
	background-color: #EFEFE5;
	height: 80px;
	text-align: center;
        position: relative;
    }

    header h1 {
	display: inline;
        left: 6%;
        line-height: 80px;
        position: absolute;
    }

    header h1 img {
        vertical-align: bottom;
        height: 60px;
    }

    #sns_top_sp {
        display: none;
    }

    .nav_inner {
        position: relative;
    }

    #sns_top a {
        color: #333333;
        font-size: 73.3%;
        margin-right: 15px;
    }

    .search {
        display: block;
        right: 15%;
        position: absolute;
        top: 32%;
    }

    #footer_content {
        margin: 0 auto;
        padding: 4%;
        width: 960px;
    }

    #footer_content h2 {
        float: left;
        width: 216px;
    }

    #footerlink {
        float: left;
        margin-left: 150px;
        text-align: left;
        width: 200px;
    }

    #footerlink li {
        margin-bottom: 6px;
    }

    #footerlink li a {
        margin-left: 6px;
    }

    #followus {
        float: left;
        margin-left: 20px;
        text-align: left;
        width: 120px;
    }

    #followus dt {
         margin-bottom: 5px;
    }

    #followus dd {
         margin-bottom: 3px;
    }

    #followus dd span {
        margin-left: 8px;
    }
}

#chart_description {
        background-color: #FFFFFF;
        margin: 1%;
}

#chart_description h2 {
        background-color: #353535;
        font-size: 120%;
        font-weight: 300;
        color: #FFFFFF;
        text-align: center;
        padding: 20px 0;
}

#chart_description p {
        font-size: 86.7%;
        color: #666666;
        padding: 10px 5px;
}

#mymenu {
	position: absolute;
	top: 53%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	left: 1%;
        z-index: 100;
}

#menu {
        background-color: #f9fbf2;
}

#menu a {
        color: #333333;
}

#chart_title {
	color: #333333;
	font-size: 93.3%;
	font-weight: 500;
	margin: 0 0 1px;
}

#chart_title a {
        color: #666666;
}

.bread {
    background-color: #FFFFFF;
    list-style: none outside none;
    margin: 0 1%;
    padding: 3% 1%;
}

.bread li {
  float : left;
}

.flick_area {
	background-color: #000000;
	color: #999999;
	height: 40px;
	text-align: center;
	line-height: 40px;
	margin: 1%;
	position: relative;
        clear: both;
}

#prev {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-45%);
	-ms-transform: translateY(-45%);
	transform: translateY(-45%);
	left: 10px;
}

#next {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-45%);
	-ms-transform: translateY(-45%);
	transform: translateY(-45%);
	right: 10px;
}

#content {
	margin-bottom: 20px;
        clear: both;
        width: 100%;
}

/* ---------------
	Ranking Area
----------------*/

.app-ranking {
	width: 98%;
	padding: 1%;
	clear: both;
	font-family: 'Helvetica Neue', Helvetica, Arial, Roboto, 'Droid Sans', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', sans-serif;
}

.leftside {
        background-color: #FFFFFF;
	width: 17%;
	margin-right: 0.75%;
	padding: 1%;
	float: left;
	display: inline;
}

.app-number {
	width: 100%;
	height: 52px;
	text-align: center;
        background-color: #8DA0B6;
	color: #FFFFFF;
	font-size: 20px;
	font-family: Helvetica;
}

.rank {
	line-height: 52px;
}

.store {
	width: 100%;
	height: 28px;
	text-align: center;
	background-color: #CBD0D3;
}

.store a {
	line-height: 28px;
	color: #330033;
	font-size: 13px;
        font-family: Helvetica;
}

.app-info {
	width: 80.25%;
	float: left;
	display: inline;
	background-color: #FFFFFF;
}

.jkt {
	float: left;
	padding: 1.3%;
}

.info {
	float: left;
	width: 53.125%;
	padding: 1% 0.2%;
}

.songtitle {
	line-height: 12px;
        margin-top: 10px;
	margin-bottom: 6px;
        padding-left: 5px;
        width: 100%;
        font-size: 12px;
	color: #000000;
	font-weight: 400;
}

.songtitle a {
	font-size: 12px;
	color: #000000;
	font-weight: 400;
}

.artistname {
        font-size: 11px;
	color: #333333;
        width: 100%;
        padding-left: 5px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        -webkit-text-overflow: ellipsis;
        -o-text-overflow: ellipsis;
}

.artistname a {
	color: #333333;
}

.app-price {
	font-size: 11px;
	color: #333333;
        padding-left: 5px;
        padding-bottom: 5px;
}


.pagetop {
	position: fixed;
	bottom: 15%;
	right: 5px;
	opacity: 0;
	filter: alpha(opacity=0);
	-webkit-transform: scale(1.5);
	-moz-transform: scale(1.5);
	-ms-transform: scale(1.5);
	-o-transform: scale(1.5);
	transform: scale(1.5);
	-webkit-transition: all .5s;
	-moz-transition: all .5s;
	-o-transition: all .5s;
	transition: all .5s;
        z-index: 100;
}
.pagetop a {
	display: block;
	width: 50px;
	height: 50px;
	background-color: #464646;
	text-align: center;
	color: #FFFFFF;
	font-size: 20px;
	text-decoration: none;
	line-height: 50px;
}
.pagetop.show {
	opacity: 1;
	filter: alpha(opacity=100);
	-webkit-transform: scale(1);
	-moz-transform: scale(1);
	-ms-transform: scale(1);
	-o-transform: scale(1);
	transform: scale(1);
}

.sns{
    background-color: #FFFFFF;
    margin: 0;
    padding: 1% 1% 3%;
    width: 98%;
    display: flex;
    justify-content: space-between;
}

.sharrre .button{
    float: left;
    width: 73px;
}

.sharrre{
    display: inline;
    /* float: left; */
    padding: 1%;
    width: 18%;
}




.twitter a {
        background-color: #55ACEE;
        color:#FFFFFF;
        display:block;
        font-size:11px;
        font-weight:bold;
        height:26px;
        line-height:26px;
        margin-top:8px;
        padding:0;
        text-align:center;
        text-decoration:none;
        width:100%;
        -webkit-border-radius:4px;
        -moz-border-radius:4px;
        border-radius:4px;
}


.facebook a {
    background-color: #3B5999;
    border-radius: 4px;
    color: #ffffff;
    display: block;
    font-size: 11px;
    font-weight: bold;
    height: 26px;
    line-height: 26px;
    margin-top: 8px;
    padding: 0;
    text-align: center;
    text-decoration: none;
    width: 100%;
}

.pocket a {
        background-color: #EA4654;
        color:#FFFFFF;
        display:block;
        font-size:11px;
        font-weight:bold;
        height:26px;
        line-height:26px;
        margin-top:8px;
        padding:0;
        text-align:center;
        text-decoration:none;
        width:100%;
        -webkit-border-radius:4px;
        -moz-border-radius:4px;
        border-radius:4px;
}

.googleplus a {
        background-color: #DB4A39;
        color:#FFFFFF;
        display:block;
        font-size:13px;
        font-weight:bold;
        height:26px;
        line-height:26px;
        margin-top:8px;
        padding:0;
        text-align:center;
        text-decoration:none;
        width:100%;
        -webkit-border-radius:4px;
        -moz-border-radius:4px;
        border-radius:4px;
}

.hatena a {
        background-color: #008FDE;
        color:#FFFFFF;
        display:block;
        font-size:10px;
        font-weight:bold;
        height:26px;
        line-height:26px;
        margin-top:8px;
        padding:0;
        text-align:center;
        text-decoration:none;
        width:100%;
        -webkit-border-radius:4px;
        -moz-border-radius:4px;
        border-radius:4px;
}

.line a {
    background-color: #00c300;
    color: #FFFFFF;
    display: block;
    font-size: 11px;
    font-weight: bold;
    height: 26px;
    line-height: 26px;
    margin-top: 8px;
    padding: 0;
    text-align: center;
    text-decoration: none;
    width: 100%;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}

/*--------------------------------------
	Demo
---------------------------------------*/

.switch {
	visibility: hidden;
}

.main_banner {
    background-color: #fff;
    height: 100%;
    margin: 1%;
    padding: 1%;
    width: 96%;
}

.main_banner img {
        width: 100%;
        vertical-align: bottom;
}

#demotape {
        background-color: #FFFFFF;
        margin: 1%;
        padding: 10px 0;
        width: 98%;
        border-radius: 6px;
        -webkit-border-radius: 6px;
        -moz-border-radius: 6px;
}

#demotape p {
        color: #333333;
        font-size: 93.3%;
        font-weight: bold;
        line-height: 150%;
        padding: 0 10px;
        margin-bottom: 10px;
}

.subContent {
        background-color: #EFEFE5;
        padding: 0 0 1px;
}

.subContent h2 {
        background-color: #5FAECD;
        color: #FFFFFF;
        font-size: 100%;
        margin: 0 1%;
        padding: 5px 0 5px 10px;
}

.subContent p {
        background-color: #FFFFFF;
        color: #333333;
        font-size: 86.7%;
        margin: 1%;
        padding: 10px;
        border-radius: 6px;
        -webkit-border-radius: 6px;
        -moz-border-radius: 6px;
}

#oubo {
        background-color: #5FAECD;
        display: inline;
        padding: 10px 30px;
}

#oubo a {
         color: #FFFFFF;
         
}

/*--------------------------------------
	応募フォーム
---------------------------------------*/

#close {
        display:inline;
        background-color: #000000;
        padding: 10px;
}

#close a {
        color: #FFFFFF;
        text-decoration: none;
}

form p {
        font-size: 14px;
}

.formbox {
        color: #666666;
        margin-bottom: 20px;
}

input,select {
        /* width:100%; */
        /* font-size:106.7%; */
}

textarea {
        width:100%;
        font-size:106.7%;
}

input[type="button"], input[type="text"] {
       -webkit-appearance: none;
}

input[type="submit"] {
        -webkit-appearance: none;
        width: 120px;
}

input[type="reset"] {
        -webkit-appearance: none;
        width: 120px;
}

footer {
    background: none repeat scroll 0 0 #262626;
    color: #FFFFFF;
    font-size: 73.3%;
    padding: 10px 5px;
    text-align: center;
}

footer a {
    color: #CCCCCC;
}

footer a:hover {
    text-decoration: underline;
}

.comments {
    background-color: #FFFFFF;
    margin: 1%;
    padding: 2%;
}

.comments h2 {
        background-color: #353535;
        font-size: 100%;
        font-weight: 300;
        color: #FFFFFF;
        text-align: center;
        padding: 20px 0;
}

.textarea-wrapper .textarea {
    font-size: 16px !important;
}



#sns_top {
        position: absolute;
	top: 53%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 6%;
        z-index: 100;
}

#sns_top a {
        color: #333333;
        font-size: 73.3%;
}

#sns_top a:hover {
        color: #D85900;
        font-size: 73.3%;
}

.sharrre .box a:hover{
        text-decoration:none;
}

.facebook .pocket-count {
        color:#525b67;
        display:block;
        font-size:14px;
        line-height:33px;
        height:33px;
        position:relative;
        text-align:center;
        width:98%;
        border:1px solid #bbb;

}

.facebook .pocket-count:before, .facebook .pocket-count:after {
        content:'';
        display:block;
        position:absolute;
        left:49%;
        width:0;
        height:0;
}

.facebook .pocket-count:before {
        border:solid 4px transparent;
        border-top-color:#b2c6cc;
        margin-left:-4px;
        bottom: -8px;
}

.facebook .pocket-count:after {
        border:solid 3px transparent;
        margin-left:-3px;
        bottom:-6px;
        border-top-color:#fbfbfb;
}



.twitter .pocket-count {
        color:#525b67;
        font-size:14px;
        line-height:33px;
        height:33px;
        position:relative;
        text-align:center;
        width:98%;
        border:1px solid #bbb;
        display: block;
}

.twitter .pocket-count:before, .twitter .pocket-count:after {
        content:'';
        display:block;
        position:absolute;
        left:49%;
        width:0;
        height:0;
}

.twitter .pocket-count:before {
        border:solid 4px transparent;
        border-top-color:#b2c6cc;
        margin-left:-4px;
        bottom: -8px;
}

.twitter .pocket-count:after {
        border:solid 3px transparent;
        margin-left:-3px;
        bottom:-6px;
        border-top-color:#fbfbfb;
}



.pocket .pocketnum-count {
        color:#525b67;
        display:block;
        font-size:14px;
        line-height:33px;
        height:33px;
        position:relative;
        text-align:center;
        width:98%;
        border:1px solid #bbb;

}

.pocket .pocketnum-count:before, .pocket .pocketnum-count:after {
        content:'';
        display:block;
        position:absolute;
        left:49%;
        width:0;
        height:0;
}

.pocket .pocketnum-count:before {
        border:solid 4px transparent;
        border-top-color:#b2c6cc;
        margin-left:-4px;
        bottom: -8px;
}

.pocket .pocketnum-count:after {
        border:solid 3px transparent;
        margin-left:-3px;
        bottom:-6px;
        border-top-color:#fbfbfb;
}


.googleplus .pocket-count {
        color:#525b67;
        display:none;
        font-size:14px;
        line-height:33px;
        height:33px;
        position:relative;
        text-align:center;
        width:98%;
        border:1px solid #bbb;

}

.googleplus .pocket-count:before, .googleplus .pocket-count:after {
        content:'';
        display:none;
        position:absolute;
        left:49%;
        width:0;
        height:0;
}

.googleplus .pocket-count:before {
        border:solid 4px transparent;
        border-top-color:#b2c6cc;
        margin-left:-4px;
        bottom: -8px;
}

.googleplus .pocket-count:after {
        border:solid 3px transparent;
        margin-left:-3px;
        bottom:-6px;
        border-top-color:#fbfbfb;
}


.hatena .hatena_count {
        color:#525b67;
        display:block;
        font-size:14px;
        line-height:33px;
        height:33px;
        position:relative;
        text-align:center;
        width:98%;
        border:1px solid #bbb;

}

.hatena .hatena_count:before, .hatena .hatena_count:after {
        content:'';
        display:block;
        position:absolute;
        left:49%;
        width:0;
        height:0;
}

.hatena .hatena_count:before {
        border:solid 4px transparent;
        border-top-color:#b2c6cc;
        margin-left:-4px;
        bottom: -8px;
}

.hatena .hatena_count:after {
        border:solid 3px transparent;
        margin-left:-3px;
        bottom:-6px;
        border-top-color:#fbfbfb;
}

.line .pocket-count {
    color: #525b67;
    font-size: 14px;
    line-height: 33px;
    height: 33px;
    position: relative;
    text-align: center;
    width: 98%;
    border: 1px solid #bbb;
    display: block;
}

.line .pocket-count:before, .line .pocket-count:after {
        content:'';
        display:block;
        position:absolute;
        left:49%;
        width:0;
        height:0;
}

.line .pocket-count:before {
        border:solid 4px transparent;
        border-top-color:#b2c6cc;
        margin-left:-4px;
        bottom: -8px;
}

.line .pocket-count:after {
        border:solid 3px transparent;
        margin-left:-3px;
        bottom:-6px;
        border-top-color:#fbfbfb;
}



#hamburger {
    box-sizing: border-box;
    display: block;
    height: 45px;
    left: 0;
    
    top: 10px;
    width: 70px;
    z-index: 4;
}
#hamburger::before, #hamburger::after, #hamburger span {
    background: #333 none repeat scroll 0 0;
    content: "";
    display: block;
    height: 3px;
    left: 20px;
    position: absolute;
    width: 26px;
}
#hamburger::before {
    top: 12px;
}
#hamburger span {
    top: 20px;
}
#hamburger::after {
    top: 28px;
}
#hamburger::before, #hamburger::after, #hamburger span {
    transition-delay: 0.5s;
    transition-duration: 0.5s;
    transition-property: transform, top, bottom, left, opacity;
    transition-timing-function: ease;
}

html.mm-opening #hamburger::before, html.mm-opening #hamburger::after {
    top: 20px;
    left: -40px;
}
html.mm-opening #hamburger span {
    left: -150px;
    opacity: 0;
}
html.mm-opening #hamburger::before {
    -moz-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg); 
}
html.mm-opening #hamburger::after {
    -moz-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg); 
}


input[type="submit"] {
    font-family: FontAwesome;
}

#cse-search-box {
  margin: 0 auto;
  float: none;
  padding: 0;
  width: 220px;
}
#cse-search-box div{
  height: 28px;
  padding: 0;
  width: 220px;
  border-radius: 10px;
  background-color: #ffffff;
  border: solid 2px #222222;
}
#cse-search-box input[type="text"] {
  border: none !important;
  font-size: 14px;
  width: 180px;
  height: 20px;
  padding: 0;
  margin: 3px 0 0 5px;
}
#cse-search-box input[type="text"]:focus {
  outline: 0;
}
#cse-search-box input[type="submit"] {
  font-family: FontAwesome;
  font-size: 14px;
  color: #111111;
  border: none;
  height: 20px;
  margin: 0;
  overflow: hidden;
  width: 20px;
  position: relative;
  background-color: #ffffff;
}
#cse-search-box input[type="submit"]:hover {
  cursor: pointer;
}

#cse-search-box input[type="text"]:focus {
  outline: 0;
}

#cse-search-box input[type="text"] {
  border: none !important;
}


/* Font Awesome hatena bookmark */
.fa-hatena:before {
	content: "B!";
	font-family: Verdana;
	font-weight: bold
}

#cart {
    background-color: #FFFFFF;
    padding: 1% 4% 2%;
}

.line a {
    background-color: #00c300;
    color: #FFFFFF;
    display: block;
    font-size: 11px;
    font-weight: bold;
    height: 26px;
    line-height: 26px;
    margin-top: 8px;
    padding: 0;
    text-align: center;
    text-decoration: none;
    width: 100%;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}



@media screen and (min-width: 569px) {

    html.mm-opening #hamburger::before, html.mm-opening #hamburger::after {
        top: 20px;
        left: -420px;
    }

}