@charset "UTF-8";
/* --------------------------------------------------
ヘッダー
-------------------------------------------------- */
#header {
	min-height: 460px;
	width: 320px;
	margin: 0 auto;
	background-image: url("../images/sp/top/header_back.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 320px auto;
}
#header h1 {
	min-height: 329px;
	width: 320px;
	height: 329px;
	text-indent: -9999px;
}

/* 無料ボタン */
.free_btn {
	width: 320px;
	height: 85px;
}

.btn_free_1 {
	width: 160px;
	height: 85px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat;
	background-position: 0px -709px;
	background-size: 160px auto;

	float: left;
}
.btn_free_1.is-active {
	width: 160px;
	height: 85px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat; 
	background-position: 0px -454px;
	background-size: 160px auto;
}

.btn_free_2 {
	width: 160px;
	height: 85px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat;
	background-position: 0px -624px;
	background-size: 160px auto;

	float: left;
}
.btn_free_2.is-active {
	width: 160px;
	height: 85px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat; 
	background-position: 0px -539px;
	background-size: 160px auto;
}

/*ナビボタン
-------------------------------------------------- */
#navi {
	margin: 4px 0 0px;
}

.btn_senja_l {
	width: 160px;
	height: 36px;
	background-image: url(../images/sp/common/sprite-navi.png);
	background-repeat: no-repeat;
	background-position: 0px 0px;
	background-size: 160px auto;

	float: left;
}
.btn_senja_l.is-active {
	width: 160px;
	height: 36px;
	background-image: url(../images/sp/common/sprite-navi.png);
	background-repeat: no-repeat; 
	background-position: 0px -36px;
	background-size: 160px auto;
}

.btn_senjutsu_l {
	width: 160px;
	height: 36px;
	background-image: url(../images/sp/common/sprite-navi.png);
	background-repeat: no-repeat;
	background-position: 0px -144px;
	background-size: 160px auto;

	float: left;
}
.btn_senjutsu_l.is-active {
	width: 160px;
	height: 36px;
	background-image: url(../images/sp/common/sprite-navi.png);
	background-repeat: no-repeat; 
	background-position: 0px -180px;
	background-size: 160px auto;
}

/* --------------------------------------------------
container
-------------------------------------------------- */
#container {
	background-image: url("../images/sp/top/container_back.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 320px auto;
}

/* --------------------------------------------------
新着メニュー
-------------------------------------------------- */
/* 新着枠キャッチ */
.new_catch {
	min-height: 200px;
	width: 320px;
	background-image: url("../images/sp/top/new_teach_back.png");
	background-repeat: no-repeat;
	background-position: bottom left;
	background-size: 130px auto;
}

#new {
	width: 320px;
	margin: 0 auto;
}
#new .head {
	width: 320px;
	height: 60px;
	padding: 10px 0 0;
	background-image: url("../images/sp/top/new_head_back.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 320px auto;
	text-align: center;
}
#new .menu {
	width: 320px;
	padding: 15px 0 30px;
	background-image: url("../images/sp/top/new_back_top.jpg"), url("../images/sp/top/new_back_btm.jpg"), url("../images/sp/top/new_back_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#new .menu.first {
	padding: 0px 0 30px;
	background-image: url("../images/sp/top/new_back_top_first.jpg"), url("../images/sp/top/new_back_btm.jpg"), url("../images/sp/top/new_back_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#new .menu.last {
	padding: 15px 0 55px;
	background-image: url("../images/sp/top/new_back_top.jpg"), url("../images/sp/top/new_back_btm_last.jpg"), url("../images/sp/top/new_back_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#new .icon {
	width: 70px;
	height: 72px;
	padding: 0px 5px 0 10px;

	float: left;
}
#new .title {
	width: 220px;
	padding: 5px 0 0 0;
	font-weight: bold;
	font-size: 107%;
	line-height: 1.4; 

	float: left;
}
#new .title br {
	display: none;
}
#new .lead {
	padding: 5px 15px;
	color: #000;
	font-size: 88%;
	line-height: 1.3; 

	clear: both;
}
#new .price {
	padding: 0 15px;
	color: #6b00a9;
	font-size: 78%; 

	clear: both;
}
#new a:visited {
	color: #777;
}

/* catch_price */
.catch_price {
	color: #e5e3c4;
	font-size: 82%;
	text-align: center;
}

/* --------------------------------------------------
おすすめ
-------------------------------------------------- */
/* キャッチ */
.reco_catch {
	min-height: 100px;
	width: 320px;
	background-image: url("../images/sp/top/reco_catch_back.jpg");
	background-repeat: no-repeat;
	background-position: bottom left;
	background-size: 320px auto;
}

#reco {
	width: 320px;
	margin: 0 auto;
	padding: 0 0 40px;
	background-image: url("../images/sp/top/reco_back_top.jpg"), url("../images/sp/top/reco_back_btm.jpg"), url("../images/sp/top/reco_back_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#reco .head {
	width: 320px;
	height: 60px;
	padding: 10px 0 0;
	text-align: center;
}
#reco .menu {
	width: 320px;
	padding: 5px 0 15px;
	background-image: url("../images/sp/top/reco_line.png");
	background-repeat: no-repeat;
	background-position: bottom center;
	background-size: 320px auto;
}
#reco .menu.first {
	padding: 0px 0 15px;
}
#reco .menu.last {
	background: none;
}
#reco .icon {
	width: 70px;
	height: 72px;
	padding: 0px 5px 0 10px;

	float: left;
}
#reco .title {
	width: 220px;
	padding: 5px 0 0 0;
	font-weight: bold;
	font-size: 107%;
	line-height: 1.4; 

	float: left;
}
#reco .title br {
	display: none;
}
#reco .price {
	padding: 0 15px;
	color: #305d0f;
	font-size: 78%; 

	clear: both;
}
#reco a {
	color: #610193;
}
#reco a:visited {
	color: #777;
}

/* 年運
-------------------------------------------------- */
.nenun {
	width: 320px;
	margin: 20px auto 0;
	position: relative;
}
.nenun .btn {
	width: 320px;
	height: 200px;
	background-image: url("../images/sp/top/nenun_ts10.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 320px auto;
}
.nenun .btn.is-active {
	background-repeat: no-repeat;
	background-position: bottom center;
	background-size: 320px auto;
}
.nenun .price {
	width: 320px;
	color: #000;
	font-size: 73%; 
	position: absolute;
	bottom: 50px;
	left: 0;
	text-align: center;
	word-wrap: none;
}
.nenun a {
	-webkit-tap-highlight-color: transparent;
	        tap-highlight-color: transparent;
}

/* 口コミ
-------------------------------------------------- */
#review {
	width: 320px;
	margin: 30px auto 0;
	padding: 15px 0 40px;
	background-image: url("../images/sp/top/review_back_top.jpg"), url("../images/sp/top/review_back_btm.jpg"), url("../images/sp/top/review_back_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#review .colum {
	width: 280px;
	margin: 0 auto;
	padding: 10px 0 10px;
	background-image: url("../images/sp/top/review_line.png");
	background-repeat: no-repeat;
	background-position: bottom center;
	background-size: 250px auto;
}
#review .icon {
	width: 42px;
	height: auto;
	padding: 0px 5px 0 10px;

	float: left;
}
#review .title {
	width: 220px;
	padding: 8px 0 0 0;
	color: #610193; 
	font-weight: bold;
	font-size: 88%;
	line-height: 1.4;

	float: left;
}
#review .title a {
	color: #00f; 

	display: inline-block;
}
#review .price {
	padding: 0 0px;
	color: #000;
	font-size: 66%;
}

.review_icon {
	width: 64px;
	height: 64px;
	margin-right: 10px;

	float: left;
}

.review_head {
	width: 190px;
	margin-top: 5px;
	padding: 5px;
	font-weight: bold;
	font-size: 100%;
	line-height: 1.2;

	float: left;
}
.review_head.love {
	background: #ffc3db;
}
.review_head.marr {
	background: #e5c3ff;
}
.review_head.life {
	background: #b5e9f6;
}

.review_text {
	width: 260px;
	height: 3em;
	padding: 0 15px 0 5px;
	position: relative; 

	overflow: hidden;
	clear: both;
}
.review_text:before {
	width: 1em; 
	position: absolute;
	right: 0;
	bottom: 0;

	content: "……";
	display: inline-block;
}
.review_text.is-active {
	height: auto;
}
.review_text.is-active:before {
	content: "";
}

.review_prof {
	margin-left: 74px;
	font-weight: bold;
	font-size: 75%;
	text-align: right;
}

.review_btn {
	width: 80px;
	padding: 3px 0;
	background: #d5d5d5;
	color: #666665;
	font-size: 75%;
	text-align: center;

	float: right;
	border-radius: 4px;
	box-sizing: border-box;
	border: 1px solid #676767;
	box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.4) inset;
}
.review_btn:before {
	content: "▼続きを読む";
	display: block;
}
.review_btn.is-active:before {
	content: "▲閉じる";
	display: block;
}

/* --------------------------------------------------
恋愛メニュー
-------------------------------------------------- */
#love {
	width: 320px;
	margin: 0 auto;
	padding: 60px 0 30px;
	background-image: url("../images/sp/top/love_back_top.jpg"), url("../images/sp/top/love_back_btm.jpg");
	background-repeat: no-repeat;
	background-position: top center, bottom center;
	background-size: 320px auto;
	position: relative;
}
#love .head {
	width: 320px;
	height: 107px;
}
#love .label {
	width: 125px;
	height: 64px;
	position: absolute;
	top: 15px;
	left: 0;
}
#love .menu {
	width: 320px;
	padding: 10px 0 15px;
	background-image: url("../images/sp/top/love_komi_top.jpg"), url("../images/sp/top/love_komi_btm.jpg"), url("../images/sp/top/love_komi_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#love .icon {
	width: 70px;
	height: 72px;
	padding: 0px 5px 0 10px;

	float: left;
}
#love .title {
	width: 220px;
	padding: 5px 0 0 0;
	font-weight: bold;
	font-size: 107%;
	line-height: 1.4; 

	float: left;
}
#love a {
	color: #c00044;
}
#love .price {
	padding: 0 15px;
	color: #000;
	font-size: 88%; 

	clear: both;
}

/* --------------------------------------------------
結婚メニュー
-------------------------------------------------- */
#marr {
	width: 320px;
	margin: 0 auto;
	padding: 60px 0 30px;
	background-image: url("../images/sp/top/marr_back_top.jpg"), url("../images/sp/top/marr_back_btm.jpg");
	background-repeat: no-repeat;
	background-position: top center, bottom center;
	background-size: 320px auto;
	position: relative;
}
#marr .head {
	width: 320px;
	height: 107px;
}
#marr .label {
	width: 142px;
	height: 60px;
	position: absolute;
	top: 15px;
	left: 0;
}
#marr .menu {
	width: 320px;
	padding: 10px 0 15px;
	background-image: url("../images/sp/top/marr_komi_top.jpg"), url("../images/sp/top/marr_komi_btm.jpg"), url("../images/sp/top/marr_komi_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#marr .icon {
	width: 70px;
	height: 72px;
	padding: 0px 5px 0 10px;

	float: left;
}
#marr .title {
	width: 220px;
	padding: 5px 0 0 0;
	font-weight: bold;
	font-size: 107%;
	line-height: 1.4; 

	float: left;
}
#marr a {
	color: #610193;
}
#marr .price {
	padding: 0 15px;
	color: #000;
	font-size: 88%; 

	clear: both;
}

/* --------------------------------------------------
人生メニュー
-------------------------------------------------- */
#life {
	width: 320px;
	margin: 0 auto;
	padding: 60px 0 30px;
	background-image: url("../images/sp/top/life_back_top.jpg"), url("../images/sp/top/life_back_btm.jpg");
	background-repeat: no-repeat;
	background-position: top center, bottom center;
	background-size: 320px auto;
	position: relative;
}
#life .head {
	width: 320px;
	height: 107px;
}
#life .label {
	width: 142px;
	height: 60px;
	position: absolute;
	top: 15px;
	left: 0;
}
#life .menu {
	width: 320px;
	padding: 10px 0 15px;
	background-image: url("../images/sp/top/life_komi_top.jpg"), url("../images/sp/top/life_komi_btm.jpg"), url("../images/sp/top/life_komi_mid.jpg");
	background-repeat: no-repeat, no-repeat, repeat-y;
	background-position: top center, bottom center, top center;
	background-size: 320px auto;
}
#life .icon {
	width: 70px;
	height: 72px;
	padding: 0px 5px 0 10px;

	float: left;
}
#life .title {
	width: 220px;
	padding: 5px 0 0 0;
	font-weight: bold;
	font-size: 107%;
	line-height: 1.4; 

	float: left;
}
#life a {
	color: #003782;
}
#life .price {
	padding: 0 15px;
	color: #000;
	font-size: 88%; 

	clear: both;
}

#love a, #marr a, #life a {
	display: inline-block;
}

#love a:visited, #marr a:visited, #life a:visited {
	color: #777;
}

#love .title br, #marr .title br, #life .title br {
	display: none;
}

/* カテゴリーボタン
-------------------------------------------------- */
#categoly {
	width: 320px;
	height: 82px;
	margin: 0px auto 15px;
	background-image: url("../images/sp/top/categoly_back.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 320px auto;
	position: relative;
}
#categoly .btn_love {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat;
	background-position: 0px -254px;
	background-size: 160px auto;
	position: absolute;
	top: 14px;
	left: 0px; 

	float: left;
}
#categoly .btn_love.is-active {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat; 
	background-position: 0px -54px;
	background-size: 160px auto;
}
#categoly .btn_marr {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat;
	background-position: 0px -354px;
	background-size: 160px auto;
	position: absolute;
	top: 14px;
	left: 80px; 

	float: left;
}
#categoly .btn_marr.is-active {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat; 
	background-position: 0px -404px;
	background-size: 160px auto;
}
#categoly .btn_life {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat;
	background-position: 0px -154px;
	background-size: 160px auto;
	position: absolute;
	top: 14px;
	left: 160px; 

	float: left;
}
#categoly .btn_life.is-active {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat; 
	background-position: 0px -204px;
	background-size: 160px auto;
}
#categoly .btn_reco {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat;
	background-position: 0px -304px;
	background-size: 160px auto;
	position: absolute;
	top: 14px;
	left: 240px; 

	float: left;
}
#categoly .btn_reco.is-active {
	width: 80px;
	height: 50px;
	background-image: url(../images/sp/top/sprite-top.png);
	background-repeat: no-repeat; 
	background-position: 0px -104px;
	background-size: 160px auto;
}
#categoly a {
	-webkit-tap-highlight-color: transparent;
	        tap-highlight-color: transparent;
}

/* totop */
.totop {
	width: 197px;
	margin: 15px auto;
}
