@charset "UTF-8";

/*
Theme Name: SmileHikita 2023
Author: HEVIZ Co.,Ltd.
Author URI: https://heviz.jp/
Description: for SmileWords Yoshiaki Hikita official website.
Requires at least: 6.0
Requires PHP: 7.4
Version: 1.0
*/


/** ================================================================================================


	ひきたよしあき 全ページ共通 基本CSS

	@version  1.0 2020.1.14
	@author   K.Sekioka of HEVIZ Co.,Ltd.


==================================================================================================== **/



:root {
	--logo-color: #c95560;
	--gochic-font-family : "Zen Kaku Gothic New", "YuGothic", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
	--mincho-font-family : "Zen Old Mincho", "YuMincho", "Yu Mincho", "Hiragino Mincho ProN", "serif";
	--maru-font-family   : "Zen Maru Gothic", "YuGothic", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
}



/** ===========================================================================


    タグの基本設定


=============================================================================== **/



body {
	background-color:#faf0ee;
	font-weight: 400;
}

a {
    color:#008fe3;
    text-decoration: none;
    transition: all 0.3s;
}
a:link,
a:visited { color:#008fe3; }
a:hover,
a:active { color:#da1b43; }

a:hover img {
    opacity: 0.8;
    transition: opacity 0.3s;
}

body.headerNav {
	padding-top: 80px;
}

.siteHeaderNav .menu dt span {
    background-color: #ffffff;
}


/** for tablet ---------------------------------- **/

@media all and (max-width:1024px) and (min-width:768px) {


}

/** for Smart Phone ----------------------------- **/

@media all and (max-width:767px) {

	body.topHeader {
		padding-top: 100px;
	}
}



/** ===========================================================================


    ローディング (siteCommon拡張)


=============================================================================== **/



.siteLoading .status {
	top : 0;
	height : 10px;
}

.siteLoading .status .bar{
	background-color : #ca8d90;
}

.siteLoading .circle svg path {
    fill:#ca8d90;
}



/** ===========================================================================


	サイト共通ヘッダー (siteCommon拡張)


=============================================================================== **/

body.topHeader .siteHeader {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
    height: auto;
}

.siteHeaderTitle {
    width: 200px;
    height: 120px;
	margin: 0;
}

body.topHeader .siteHeader .siteNav.main ul {
    align-items: center;
}

.siteNav.main li {

	-webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
	font-family: var(--maru-font-family);
	font-weight: 700;
	white-space: nowrap;
}

.siteNav.main a::before {
	display: none;
}

.siteNav.main li a {
    padding: 5px 10px;
}

.siteNav.main li:before {
	content: "";
	display: block;
	position: absolute;
	right: 6px;
	top: -3px;
	width: 10px;
	height: calc( 100% + 6px );
	margin: 0;
	padding: 0;
	background-color: #edced1;
	transform: skewY(-20deg);
}



/** Responsive for tablet --------------------------------- **/

@media all and (max-width:1024px) and (min-width:768px) {

}


/** Responsive for Smart Phone ---------------------------- **/

@media all and (max-width: 767px) {

	body.topHeader .siteHeader {
		display: block;
		height: 100px;
	}

	.siteHeaderTitle {
		width: 200px;
		height: 100px;
	}

	body.topHeader .siteHeader .siteNav.main ul {
 	   display: flex;
	}
	
	
	
	body.topHeader .siteHeader .siteNav.main ul {
		align-items: center;
	}

	.siteNav.main li {
		border-top: 0;
	}

	.siteNav.main a::before {
		display: none;
	}

	.siteNav.main li a {
		padding: 5px 10px;
	}
}



/** ===========================================================================


    サイト共通フッター    siteCommon.css拡張


=============================================================================== **/



.siteFooter {
	margin-top: 100px;
}



/** ===========================================================================


	pageTop     siteCommon.css拡張


=============================================================================== **/



.pageTop a {
    background-color: #ca8d90;
}



/** ===========================================================================


	パンくず


=============================================================================== **/



.siteBread {
	max-width: 1000px;
}

.siteBread ul {
	justify-content: center;
}



/** ===========================================================================


	スプラッシュ パラパラ絵


=============================================================================== **/



.siteSplash .bg {
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	background-color: #ffffff;
	z-index: 2001;
}


.siteSplash .logo {
	display: block;
	position: absolute;
	left: 50%;
	top: 50%;
	width: 54%;
	margin: 0;
	padding: 0 0 43.13135593% 0;
	box-sizing: border-box;
	transform: translate(-50%, -50%);
	z-index: 2010;
}

.siteSplash img {
	display: block;
	position: absolute;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	vertical-align: bottom;
	opacity: 0;
}

.siteSplashSkip a {
	font-family: var(--maru-font-family);
	font-weight: 700;
	color: var(--logo-color);
}

@keyframes splashMouth1 {
	0%   { opacity: 0; }
	10%  { opacity: 1; }
	90%  { opacity: 1; }
	100% { opacity: 0; }
}
@keyframes splashMouth2 {
	0%   { opacity: 0; }
	10%  { opacity: 1; }
	100% { opacity: 1; }
}
@keyframes splashEng {
	0%   { opacity: 0; transform: translateX(-20px); }
	100% { opacity: 1; transform: translateY(  0px); }
}
@keyframes splashHide {
	0%   { opacity: 1; top:0; }
	99%  { opacity: 0; top:0; }
	100% { opacity: 0; top:100%; }
}
@keyframes splashImgHide {
	0%   { opacity: 1; }
	100% { opacity: 0; }
}


.siteSplash img.mouth {
}
.siteSplash img.face    { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.mouth01 { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.mouth02 { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.mouth03 { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.mouth04 { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.mouth05 { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.mouth06 { left:17.91827331%; top:2.917228117%; width:57.20338983%; }
.siteSplash img.eng01   { left:          0%; top:78.61107427%; width:13.34745763%; }
.siteSplash img.eng02   { left:11.80702331%; top:83.76704244%; width:16.73728814%; }
.siteSplash img.eng03   { left:27.43691737%; top:81.97490716%; width:6.779661017%; }
.siteSplash img.eng04   { left:32.75298729%; top:79.66431034%; width:6.779661017%; }
.siteSplash img.eng05   { left:38.37543432%; top:83.37213528%; width:9.427966102%; }
.siteSplash img.eng06   { left:47.70855932%; top:78.99311671%; width:19.06779661%; }
.siteSplash img.eng07   { left:62.36317797%; top:86.32241379%; width:9.851694915%; }
.siteSplash img.eng08   { left:69.80945975%; top:81.41435013%; width:9.427966102%; }
.siteSplash img.eng09   { left:75.7826589%;  top:81.98306366%; width:11.22881356%; }
.siteSplash img.eng10   { left:85.78208686%; top:83.21282493%; width:10.06355932%; }
.siteSplash img.eng11   { left:94.31569915%; top:92.84229443%; width:5.720338983%; }
.siteSplash img.jpn01   { left:10.8965572%;  top:44.66844828%; width:9.851694915%; }
.siteSplash img.jpn02   { left:23.11661017%; top:43.95543767%; width:8.474576271%; }
.siteSplash img.jpn03   { left:34.18894068%; top:43.77387268%; width:9.322033898%; }
.siteSplash img.jpn04   { left:46.19233051%; top:43.94137931%; width:8.792372881%; }
.siteSplash img.jpn05   { left:58.53695975%; top:44.03122016%; width:7.415254237%; }
.siteSplash img.jpn06   { left:68.52360169%; top:43.85785146%; width:9.427966102%; }
.siteSplash img.jpn07   { left:80.63717161%; top:43.95543767%; width:8.474576271%; }


/* animation */
body.splash .siteSplash {
	animation: splashHide 0.5s linear 11s 1 forwards;
}

body.splash .siteSplash img.face    { animation: splashMouth2 1.1s linear 0s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.mouth01 { animation: splashMouth1 1.1s linear 1s 1 forwards; }
body.splash .siteSplash img.mouth02 { animation: splashMouth1 1.1s linear 2s 1 forwards; }
body.splash .siteSplash img.mouth03 { animation: splashMouth1 1.1s linear 3s 1 forwards; }
body.splash .siteSplash img.mouth04 { animation: splashMouth1 1.1s linear 4s 1 forwards; }
body.splash .siteSplash img.mouth05 { animation: splashMouth1 1.1s linear 5s 1 forwards; }
body.splash .siteSplash img.mouth06 { animation: splashMouth2 1.1s linear 6s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }

body.splash .siteSplash img.eng01 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.50s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng02 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.55s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng03 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.60s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng04 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.65s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng05 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.70s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng06 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.75s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng07 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.80s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng08 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.85s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng09 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.90s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng10 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 6.95s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }
body.splash .siteSplash img.eng11 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 7.00s 1 forwards, splashImgHide 0.2s linear 8s 1 forwards; }

body.splash .siteSplash img.jpn01 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.30s 1 forwards; }
body.splash .siteSplash img.jpn02 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.35s 1 forwards; }
body.splash .siteSplash img.jpn03 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.40s 1 forwards; }
body.splash .siteSplash img.jpn04 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.45s 1 forwards; }
body.splash .siteSplash img.jpn05 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.50s 1 forwards; }
body.splash .siteSplash img.jpn06 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.55s 1 forwards; }
body.splash .siteSplash img.jpn07 { animation: splashEng 0.3s cubic-bezier(.02,2.05,.73,.43) 8.60s 1 forwards; }



/** ===============================================================================================


	TOPページ


=================================================================================================== **/



/* TOPページはヘッダーを隠す -------------------------- **/

body.home {
	padding-top: 0;
}


body.home .siteHeader {
	transform: translateY(-200px);
}

body.home.scrolled .siteHeader {
	transform: translateY(0);
}



/** ---------------------------------------------------------------------------


	Home（メインビジュアル）


------------------------------------------------------------------------------- **/



.block.home {
	display: block;
	position: relative;
	margin: 0;
	padding: 0;
}

.block.home .hvSlider.fade .screen {
    padding: 0 0 56.25%;
}

.block.home .hvSlider.fade .screen > ul > li {
	background-color: transparent;
	text-align: right;
}

.block.home .hvSlider.fade .screen > ul > li img {
	left: auto;
	right: 0;
	width: auto;
	max-width: none;
	height: 100%;
}

.block.home .blockTitle {
	display: block;
	position: absolute;
	bottom: 46%;
	left: 15%;
	width: 20%;
	margin: 0;
	padding: 0;
	
	font-family: var(--maru-font-family);
	font-weight: 700;
	text-align: center;
	color: #c95560;
	font-size: 24px;
}

.block.home .blockTitle img {
	display: block;
	margin: 0 auto 20px;
	vertical-align: bottom;
}


.block.home .blockNav {
	display: block;
	position: absolute;
	left: 10%;
	top: 60%;
	width: 30%;
	margin: 0;
	padding: 0;
	z-index: 300;
}

.block.home .blockNav ul {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: flex-start;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.block.home .blockNav li {
	display: block;
	position: relative;
	margin: 0 15px;
	padding: 0;
	
	font-family: var(--maru-font-family);
	font-size: 24px;
	font-weight: 700;
	line-height: 1;
	
	-webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
}

.block.home .blockNav li:before {
	content: "";
	display: block;
	position: absolute;
	right: -3px;
	top: -5px;
	width: 10px;
	height: calc( 100% + 10px );
	margin: 0;
	padding: 0;
	background-color: #edced1;
	transform: skewY(-20deg);
}

.block.home .blockNav a {
	display: inline-block;
	position: relative;
	z-index: 200;
}

.block.home .blockNav a:link,
.block.home .blockNav a:visited { color: inherit; }




/** for tablet ---------------------------------- **/

@media all and (max-width: 1024px) and (min-width:768px) {
}


/** for Smart Phone ----------------------------- **/

@media all and (max-width: 767px) {
	
	
	
	/** Home（メインビジュアル） --------------- **/

	.block.home .hvSlider.fade .screen {
	    padding: 0 0 160%;
	}

	.block.home .hvSlider.fade .screen > ul > li {
		background-color: transparent;
		text-align: right;
	}

	.block.home .hvSlider.fade .screen > ul > li img {
		top: auto;
		bottom: 0;
		width: 100%;
		height: auto;
	}

	.block.home .blockTitle {
		bottom: auto;
		top: 20%;
		left: 5%;
		width: 40%;
		font-size: inherit;
		transform: translateY(-50%);
	}

	.block.home .blockNav {
		left: 55%;
		top: 20%;
		width: 40%;
		margin: 0;
		padding: 0;
		transform: translateY(-50%);
	}

	.block.home .blockNav li {
		margin: 0 8px;
		font-size: inherit;
	}
}



/** ---------------------------------------------------------------------------


	index共通


------------------------------------------------------------------------------- **/


.block.index {
	display: block;
	position: relative;
	margin: 0;
	padding: 120px 0 100px;
}

.block.index .blockInner {
	display: block;
	position: relative;
	width: calc( 100% - 100px );
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
}

/* タイトル */
.block.index .blockTitle {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;

	position: relative;
	position: absolute;
	left: 0;
	top: 50%;
	
    width: 200px;
	height: auto;
	min-height: 200px;
    margin: 0;
    padding: 0;
	box-sizing: border-box;

    color: #ffffff;
	
	font-family: var(--maru-font-family);
    font-size: smaller;
	white-space: nowrap;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;

	transform: translateY(-50%);
/*	transform: translateY(-50%); */
	z-index: 200;
}

.block.index .blockTitle::before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 200px;
    height: 200px;
    margin: 0;
    padding: 0;
    background-color: #edced1;
    border-radius: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
}

.block.index .blockTitle a {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    z-index: 10;
	
	color: var(--logo-color);
}

.block.index .blockTitle strong {
    display: block;
    font-size: 40px;
    line-height: 1;
}


/* 記事一覧 */

.block.index .blockTiles {
	display: block;
	position: relative;
	margin: 0 30px 0 190px;
	padding: 0;
}

.block.index .blockTiles::before {
	content: "";
	display: block;
	position: absolute;
	left: -10px;
	top: 50%;
	width: calc( 100% + 20px );
	height: 100px;
	margin: 0;
	padding: 0;
	background-color: #f6e6e7;
	transform: translateY(-50%);
	z-index: 1;
}

.block.index .hvSlider {
	position: relative;
	z-index: 10;
}

.block.index .hvSlider .screen > ul {
    align-items: flex-start;
}

.block.index .hvSlider .screen > ul > li {
	width: 0.25%;
	background-color: transparent;
}

.block.index .hvSlider .pointer {
    position: relative;
    left: auto;
    bottom: auto;
    width: auto;
    margin: 20px 0 0 0;
}

.block.index .hvSlider .pointer.dot li[rel].visible a::before {
    background-color: #cc0000;
}


/* 一覧へボタン */
.block.index .blockMore {
	display: block;
	position: absolute;
	right: 0;
	top: 50%;
	margin: 0;
	padding: 0;
	
	transform: translate(50%, -50%);
	z-index: 200;
}

.block.index .blockMore a {
	display: block;
	width: 100px;
	height: 100px;
	margin: 0;
	padding: 0;
	
	color: #ffffff;
	font-family: var(--maru-font-family);
	font-size: larger;
	font-weight: 700;
	line-height: 100px;
	text-align: center;
	
	background-color: var(--logo-color);
	border-radius: 50%;
}

.block.index .blockMore a:hover {
	background-color: #bc3b48;
	color: #ffffff;
}


/* 各記事タイル */
.block.index .post.tile {
	width: auto;
	margin: 0 10px;
}

.post.tile .tileImage {
	background-color: #ffffff;
}

.post.tile .tileImage img {
	width: 90%;
	height: 90%;
	object-fit: contain;
}

.post.tile .tileImage a:hover img {
	width: 100%;
	height: 100%;
}

.post.tile .tileTitle {
	font-size: inherit;
	font-weight: 400;
	line-height: 1.8;
}


/* TOP block用 */
.block.index .post.tile .tileCategories,
.block.index .post.tile .tileExcerpt,
.block.index .post.tile .tileMore {
	display: none;
}



/* 
	ひきたよしあきからのお知らせ

	タイトルと一覧を消す
	横を5枚にする
*/
.block.index.news {
	padding-top: 30px;
}

.block.index.news .blockTitle {
	display: none;
}

.block.index.news .blockTiles {
	padding: 0;
	margin: 0;
}

.block.index.news .hvSlider .screen > ul > li {
	width: 0.2%;
}

.block.index.news .blockMore {
	display: none;
}

/* ブログ */

/* 書籍 */
.block.index.books .post.tile .tileDate {
	display: none;
}

/* 講義・講演 */
.block.index.lecture .regular .post.tile .tileDate {
	display: none;
}

/* コラム・執筆 */


/* ステートメント */
.block.index.statement {
	background-color: #ffffff;
	background-image: url("img/statement_bg.jpg");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.block.index.statement .blockInner {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.block.index.statement .blockTitle {
	position: relative;
	left: auto;
	top: auto;
	margin: 0 30px 0 0;

	font-family: var(--mincho-font-family);
	color: inherit;
	transform: none;
}

.block.index.statement .blockTitle strong {
	line-height: 1.5;
}


.block.index.statement .blockTitle::before {
	display: none;
}

.block.index.statement .blockTitle a {
	color: inherit;
}

.block.index.statement .blockContent {
	font-size: larger;
}

.block.index.statement .blockContent > *:first-child { margin-top: 0; }
.block.index.statement .blockContent > *:last-child  { margin-bottom: 0; }



.block.index.statement .blockTitle {
	line-height: 1.5;
}


/** for Smart Phone ----------------------------- **/

@media all and (max-width: 767px) {
	
	
	
	/** index共通 --------------------- **/

	.block.index {
		padding: 120px 0 100px;
	}

	.block.index .blockInner {
		width: auto;
		max-width: auto;
		margin: 0 20px;
	}

	/* タイトル */
	.block.index .blockTitle {
		position: relative;
		left: auto;
		top: auto;
	    width: 150px;
		margin: 0 auto;
		transform: none;
	}

	.block.index .blockTitle::before {
	    width: 150px;
	    height: 150px;
	}

	.block.index .blockTitle strong {
	    font-size: 30px;
	}


	/* 記事一覧 */
	.block.index .blockTiles {
		margin: 0 20px;
	}

	.block.index .hvSlider .screen > ul > li {
		width: 1%;
	}

	.block.index .hvSlider .pointer {
	    margin: 20px 0 0 0;
	}


	/* 一覧へボタン */
	.block.index .blockMore {
		position: relative;
		right: auto;
		top: auto;
		margin: 20px 0 0 0;
		transform: none;
	}

	.block.index .blockMore a {
		margin: auto;
	}


	/* 各記事タイル */


	/* ひきたよしあきからのお知らせ ------ */

	.block.index.news {
		padding-top: 30px;
	}

	.block.index.news .hvSlider .screen > ul > li {
		width: 1%;
	}

	/* ブログ */

	/* 書籍 */

	/* 講義・講演 */

	/* コラム・執筆 */

	/* ステートメント */
	.block.index.statement {
		padding: 50px 0;
	}
	
	.block.index.statement .blockInner {
		display: block;
	}

	.block.index.statement .blockTitle {
		width: auto;
		justify-content: center;
		margin: 0;
	}

	.block.index.statement .blockContent {
		margin-top: 50px;
		font-size: inherit;
	}
}


/** ===========================================================================


	書籍用タイル


=============================================================================== **/


.post.tile.book .tileImage {
	padding-bottom: 120%;
	background-color: transparent;
}

.post.tile.book .tileDate,
.post.tile.book .tileTitle,
.post.tile.book .tileMore {
	display: none;
}

.post.tile.book .tileIcons {
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	margin: 0;
	padding: 0;
	z-index: 100;
	
	font-size: inherit;
	font-weight: 700;
	line-height: 1;
}

.post.tile.book .tileIcons ul {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.post.tile.book .tileIcons li {
	display: block;
	position: relative;
	margin: 0 10px 0 0;
	padding: 10px 20px;

	background-color: #cc0000;
	color: #ffffff;
	border-radius: 3px;
}


/* 購入ボタン */
.post.tile.book .tileBuy {
	display: block;
	position: relative;
	margin: 20px 0 0 0;
	padding: 0;
}

.post.tile.book .tileBuy ul {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.post.tile.book .tileBuy li {
	margin: 3px;
	padding: 0;
	flex-grow: 1;
}

.post.tile.book .tileBuy a {
	display: block;
	position: relative;
	width: auto;
	height: 50px;
	margin: 0;
	padding: 0;
	text-indent: -9999px;
	overflow: hidden;
	
	background-color: #ffffff;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: auto 50%;
	
	border-radius: 5px;
}

.post.tile.book .tileBuy li.amazon a {
	background-image:url("img/books/amazon.png");
}

.post.tile.book .tileBuy li.rakuten a {
	background-image:url("img/books/rakuten.png");
}

.post.tile.book .tileBuy li a:hover {
	background-color: #f0f0f0;
}



/** ===========================================================================


	カテゴリーページ共通


=============================================================================== **/



.siteMain.category {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: stretch;
	width: calc( 100% - 100px );
	max-width: 1300px;
	margin: 0 auto;
	padding: 50px 0 0 0;
}

.siteMain.category .pageHeader {
	width: 23em;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.siteMain.category .pageContent {
	width: calc( 100% - 23em );
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}



/* タイトル */
.siteMain.category .pageHeaderTitle {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;

	position: relative;
	
    width: 200px;
	height: auto;
	min-height: 200px;
    margin: 0;
    padding: 0;
	box-sizing: border-box;

    color: #ffffff;
	font-family: var(--maru-font-family);
	font-weight: 700;
    font-size: smaller;
	white-space: nowrap;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;

	z-index: 200;
}

.siteMain.category .pageHeaderTitle::before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 200px;
    height: 200px;
    margin: 0;
    padding: 0;
    background-color: #edced1;
    border-radius: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
}

.siteMain.category .pageHeaderTitle a {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    z-index: 10;
	
	color: var(--logo-color);
}

.siteMain.category .pageHeaderTitle strong {
    display: block;
    font-size: 40px;
    line-height: 1;
}

.siteMain.category .pageHeaderDescription {
	margin: 50px 0 0 0;
}


.siteMain.category .pageHeaderTags {
	display: block;
	position: relative;
	margin: 50px 0 0 0;
	padding: 0;
}

.siteMain.category .pageHeaderTags ul {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.siteMain.category .pageHeaderTags li {
	margin: 0 1em 0 0;
	padding: 0;
}

.siteMain.category .pageHeaderTags a {
	color: inherit;
}
.siteMain.category .pageHeaderTags a::before {
	content: "#";
}

.siteMain.category .pageHeaderTags a:link,
.siteMain.category .pageHeaderTags a:visited {
	color: inherit;
}


.pageContent.tiles {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
}

.siteMain.category .nav-links {
	width: 100%;
	margin: 150px auto 0;
}

.siteMain.category .post.tile {
	width: calc( 33.33% - 20px );
	margin: 0 10px 100px;
}

.siteMain.category .post.tile .tileCategories,
.siteMain.category .post.tile .tileExcerpt,
.siteMain.category .post.tile .tileMore {
	display: none;
}



/* 書籍の場合 */
.siteMain.category-books .post.tile {
	width: calc( 50% - 20px );
}

.siteMain.category-books .post.tile .tileTitle,
.siteMain.category-books .post.tile .tileDate {
	display: none;
}


/** for Smart Phone ----------------------------- **/

@media all and (max-width: 767px) {

	.siteMain.category {
		display: block;
		width: auto;
		max-width: none;
		margin: 0;
		padding: 50px 0 0 0;
	}

	.siteMain.category .pageHeader {
		width: auto;
		margin: 0 30px;
	}

	.siteMain.category .pageContent {
		width: auto;
		margin: 50px 20px 0;
	}

	.pageContent.tiles {
 	   display: block;
	}


	/* タイトル */
	.pageHeader.category .pageHeaderTitle {
		width: 150px;
		min-height: 150px;
		margin: 0 auto;
	}

	.pageHeader.category .pageHeaderTitle::before {
	    width: 150px;
	    height: 150px;
	}

	.pageHeader.category .pageHeaderTitle strong {
	    font-size: 30px;
	}

	.siteMain.category .post.tile {
		width: 100%;
		margin: 0 0 50px;
	}



	/* 書籍の場合 */
	.siteMain.category-books .post.tile {
		width: 100%;
	}
}



/** ===========================================================================


	アーカイブページ


=============================================================================== **/



.siteMain.archive {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: stretch;
	width: calc( 100% - 100px );
	max-width: 1300px;
	margin: 0 auto;
	padding: 50px 0 0 0;
}

.siteMain.archive .pageHeader {
	width: 23em;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.siteMain.archive .pageContent {
	width: calc( 100% - 23em );
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}



/* タイトル */
.siteMain.archive .pageHeaderTitle {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;

	position: relative;
	
    width: 200px;
	height: auto;
	min-height: 200px;
    margin: 0;
    padding: 0;
	box-sizing: border-box;

    color: #ffffff;
    font-size: smaller;
	white-space: nowrap;
/*
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
*/

	z-index: 200;
}

.siteMain.archive .pageHeaderTitle::before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 200px;
    height: 200px;
    margin: 0;
    padding: 0;
    background-color: #edced1;
    border-radius: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
}

.siteMain.archive .pageHeaderTitle a {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    z-index: 10;
	
	color: var(--logo-color);
}

.siteMain.archive .pageHeaderTitle strong {
    display: block;
    font-size: 40px;
    line-height: 1;
}

.siteMain.archive .pageHeaderDescription {
	margin: 50px 0 0 0;
}

.siteMain.archive .nav-links {
	width: 100%;
	margin: 150px auto 0;
}

.siteMain.archive .post.tile {
	width: calc( 33.33% - 20px );
	margin: 0 10px 100px;
}

.siteMain.archive .post.tile .tileCategories,
.siteMain.archive .post.tile .tileExcerpt,
.siteMain.archive .post.tile .tileMore {
	display: none;
}


/** for Smart Phone ----------------------------- **/

@media all and (max-width: 767px) {

	.siteMain.archive {
		display: block;
		width: auto;
		max-width: none;
		margin: 0;
		padding: 50px 0 0 0;
	}

	.siteMain.archive .pageHeader {
		width: auto;
		margin: 0 30px;
	}

	.siteMain.archive .pageContent {
		width: auto;
		margin: 50px 20px 0;
	}

	.pageContent.tiles {
 	   display: block;
	}


	/* タイトル */
	.siteMain.archive .pageHeaderTitle {
		width: 150px;
		min-height: 150px;
		margin: 0 auto;
	}

	.siteMain.archive .pageHeaderTitle::before {
	    width: 150px;
	    height: 150px;
	}

	.siteMain.archive .pageHeaderTitle strong {
	    font-size: 30px;
	}

	.siteMain.archive .post.tile {
		width: 100%;
		margin: 0 0 50px;
	}
}



/** ===========================================================================


	固定ページ共通


=============================================================================== **/


.post.page {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: stretch;
	width: calc( 100% - 100px );
	max-width: 1200px;
	margin: 0 auto;
}

.post.page .postHeader {
	width: 210px;
	border: 0;
}

.post.page .postHeaderInner {
	width: auto;
	max-width: none;
}

.post.page .postContent {
	width: calc( 100% - 210px );
	margin: 0;
	padding: 50px;
	background-color: #ffffff;
	border-radius: 10px;
}


/* タイトル */
.post.page .postTitle {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;

	position: relative;
    width: 200px;
	height: auto;
	min-height: 200px;
    margin: 0;
    padding: 0;
	box-sizing: border-box;

	font-family: var(--maru-font-family);
    color: #ffffff;
    font-size: smaller;
	white-space: nowrap;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;

	z-index: 200;
}

.post.page .postTitle::before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 200px;
    height: 200px;
    margin: 0;
    padding: 0;
    background-color: #edced1;
    border-radius: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
}

.post.page .postTitle span {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    z-index: 10;
	
	color: var(--logo-color);
}

.post.page .postTitle strong {
    display: block;
    font-size: 40px;
    line-height: 1;
}



/** プロフィール ------------------------------------------ **/




/* 略歴 */
.post.page.page-profile .history {
	margin-top: 100px;
}

.post.page.page-profile .history dl {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.post.page.page-profile .history dt {
	width: 5em;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.post.page.page-profile .history dd {
	width: calc( 100% - 5em );
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}


/** お問い合わせ ------------------------------------------ **/



.inputForm th,
.inputForm td {
    border-left: 0;
	border-right: 0;
}

.inputForm .buttonBox a,
.inputForm .buttonBox input,
.inputForm .buttonBox button {
    background-color: var(--logo-color);
}



/** for Smart Phone ----------------------------- **/

@media all and (max-width: 767px) {
	
	.post.page {
		display: block;
		width: auto;
		max-width: none;
		margin: 0 auto;
	}

	.post.page .postHeader {
		width: auto;
		border: 0;
	}

	.post.page .postContent {
		width: auto;
		margin: 0 20px 0;
		padding: 20px;
	}


	/* タイトル */
	.post.page .postTitle {
	    width: 150px;
		min-height: 150px;
		margin: 0 auto;
	}

	.post.page .postTitle::before {
	    width: 150px;
	    height: 150px;
	}

	.post.page .postTitle strong {
	    font-size: 30px;
	}



	/** プロフィール ------------------------------------------ **/

	/* 略歴 */
.post.page.page-profile .history dt {
	width: 5em;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.post.page.page-profile .history dd {
	width: calc( 100% - 5em );
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}


/** お問い合わせ ------------------------------------------ **/



.inputForm th,
.inputForm td {
    border-left: 0;
	border-right: 0;
}

.inputForm .buttonBox a,
.inputForm .buttonBox input,
.inputForm .buttonBox button {
    background-color: var(--logo-color);
}

	
}


/** ---------------------------------------------------------------------------


	詳細ページ (single.php)


------------------------------------------------------------------------------- **/


.post.single {
	width: calc( 100% - 100px );
	max-width: 1000px;
	margin: 0 auto;
}

.post.single .postHeader {
	background-color: #ffffff;
	border: 0;
	border-radius: 10px;
}


.post.single .postHeaderInner {
	display: block !important;
	width: auto;
	max-width: none;
	padding: 30px;
}
.post.single .postHeaderInner > *:first-child { margin-top: 0; }
.post.single .postHeaderInner > *:last-child  { margin-bottom: 0; }


.post.single .postContent {
	width: auto;
	max-width: none;
	margin-top: 20px;
	padding: 50px;
	border-radius: 10px;
	background-color: #ffffff;
}


.post.single .postCategories a {
	background-color: var(--logo-color);
	color: #ffffff;
	border-radius: 3px;
}


/* books詳細ページ */
.post.single.category-books {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: stretch;
	
	background-color: #ffffff;
	padding: 50px;
	border-radius: 10px;
}

.post.single.category-books .postImage {
	display: block;
	position: relative;
	width: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.post.single.category-books .postImage img {
	width: 100%;
	vertical-align: bottom;
}


.post.single.category-books .postLeft {
	display: block;
	position: relative;
	width: 45%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.post.single.category-books .postRight {
	display: block;
	position: relative;
	width: 55%;
	margin: 0;
	padding: 0 0 0 50px;
	box-sizing: border-box;
}

.post.single.category-books .postHeaderInner {
	padding: 0;
}


.post.single.category-books .postCategories {
	display: none;
}

.post.single.category-books .postContent {
	margin: 30px 0 0 0;
	padding: 0;
}


/* ステータスアイコン */
.post.single.category-books .postIcons {
	display: block;
	position: absolute;
	left: -10px;
	top: -10px;
	width: 100%;
	margin: 0;
	padding: 0;
	z-index: 100;
	
	font-size: inherit;
	font-weight: 700;
	line-height: 1;
}

.post.single.category-books .postIcons ul {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.post.single.category-books .postIcons li {
	display: block;
	position: relative;
	margin: 0 10px 0 0;
	padding: 10px 20px;

	background-color: #cc0000;
	color: #ffffff;
	border-radius: 3px;
}


/* スペック */
.post.single.category-books .postDim {
	display: block;
	position: relative;
	margin: 30px 0 0 0;
	padding: 0;
}

.post.single.category-books .postDim dl {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: stretch;
	position: relative;
	margin: 0;
	padding: 0;
}

.post.single.category-books .postDim dt {
	width: 4em;
	margin: 0;
	padding: 0;
	box-sizing: border-box;	
/*	font-weight: inherit; */
}

.post.single.category-books .postDim dd {
	width: calc( 100% - 4em );
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}



/* 購入ボタン */
.post.single.category-books .postBuy {
	display: block;
	position: relative;
	margin: 30px -3px 0;
	padding: 0;
}

.post.single.category-books .postBuy ul {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: stretch;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.post.single.category-books .postBuy li {
	margin: 3px;
	padding: 0;
	flex-grow: 1;
}

.post.single.category-books .postBuy a {
	display: block;
	position: relative;
	width: auto;
	height: 50px;
	margin: 0;
	padding: 0;
	text-indent: -9999px;
	overflow: hidden;
	
	background-color: #ffffff;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: auto 50%;
	
	border: 1px solid #ccc;
	
	border-radius: 5px;
}

.post.single.category-books .postBuy li.amazon a  { background-image:url("img/books/amazon.png");  }
.post.single.category-books .postBuy li.rakuten a { background-image:url("img/books/rakuten.png"); }

.post.single.category-books .postBuy li a:hover {
	background-color: #f0f0f0;
}


/** for Smart Phone ----------------------------- **/

@media all and (max-width: 767px) {
	
	
	.post.single {
		width: auto;
		max-width: none;
		margin: 0 20px;
	}
	
	.post.single .postHeader {
		padding: 0;
	}

	.post.single .postHeaderInner {
		padding: 20px;
		margin: 0;
	}

	.post.single .postContent {
		margin: 20px 0 0;
		padding: 20px;
	}



	/* books詳細ページ */
	.post.single.category-books {
		display: block;
		padding: 20px;
	}

	.post.single.category-books .postImage {
		width: 80%;
		margin: 0 auto;
	}

	.post.single.category-books .postLeft {
		width: auto;
		padding-top: 30px;
	}

	.post.single.category-books .postRight {
		width: auto;
		margin: 50px 0 0 0;
		padding: 0;
	}
}
