@charset "UTF-8";

strong, b {
    font-weight: 700;
}

ruby {
  ruby-position: over;
}

a {
  word-break: break-all;
}



/* Contents Area
------------------------------------------------------------------------------------*/
.main__visual {
    max-width: 1200px;
    margin: 0 auto;
    padding: 30px 30px 50px;
}
.main__visual p {
    margin: 0;
    padding: 0;
}
.main__visual img{
    width: 100%;
    height: auto;
}
.contents__wrapper {
    display: flex;
    margin: 0 auto 100px;
    max-width: 1080px;
}
.main__column {
    display: block;
    margin: 0;
    width: 660px;
}
.side__column {
    display: block;
    width: 360px;
    margin-left: 60px;
    margin-bottom: 75px;
}

@media screen and (max-width:1200px) {
.contents__wrapper {
    max-width: 90%;
    padding: 0 5%;
}
}

@media screen and (max-width:1024px) {
.site-wrap .block-detail-main {
    margin-top: 120px;
}
.contents__wrapper {
    display: block;
    max-width: 100%;
    width: 90%;
    margin: 0 auto;
}
.main__column, .side__column {
    display: block;
    width: 100%;
    margin-left: 0;
}
}

@media screen and (max-width:767px) {
.site-wrap .block-detail-main {
    margin-top: 60px;
}
.main__visual {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 0 0 50px;
}

}




/* main__column
------------------------------------------------------------------------------------*/
/*ぱんくず*/
.breadcrumb {
    font-size: 0.75rem;
    list-style: none;
    display: block;
  font-feature-settings: initial;   
    margin: 0;
    padding: 5px 0 0;
}
.breadcrumb li {
    display: inline;
    line-height: 1.6;
}
.breadcrumb a {
    text-decoration: underline;
    cursor: pointer;
}
.breadcrumb a:hover {
    text-decoration: none;
    opacity: 1;
    transition-duration: 0s;
}
.breadcrumb li:not(:last-child)::after {
    content: "/" !important;
    padding: 0 3px 0 6px !important;
}

@media screen and (max-width:1024px) {
.breadcrumb {
    font-size: 0.85rem;
}
}

@media screen and (max-width:767px) {
.breadcrumb {
    display: flex;
    overflow-x: scroll;
    white-space: nowrap;
    font-size: 0.75rem;
    width: 90%;
    margin: 0 auto;
    -ms-overflow-style: none; /* IE, Edge 対応 */
    scrollbar-width: none;    /* Firefox 対応 */
}
.breadcrumb::-webkit-scrollbar {
  display: none; /* Chrome, Safari 対応 */
}
}




/*タイトル周り*/
.category__name {
    margin: 0 0 5px;
    padding: 0;
    font-size: 1.2rem;
    color: #d7063b;
    line-height:1.5;
}
.article__date {
    margin: 15px 0 20px;
    padding: 0;
    font-size: 1.0rem;
    font-weight: 300;
}
.interviewee {
    margin: 0 0 30px;
    padding: 0;
    font-size: 1.4rem;
    font-weight: 700;
}
.entry__title {
    margin: 0 0 30px;
    padding: 0;
    font-size: 2.0rem;
    line-height: 1.6;
    font-weight: 700;
}
.description {
    margin: 0 0 10px;
    padding: 0;
    font-size: 0.8rem;
    line-height: 1.6;
}
.detail-description {
    margin: 0 0 30px;
    padding: 0;
    line-height: 1.6;
}
.detail-description a {
    text-decoration: underline;
}
.detail-description a:hover {
    text-decoration: none;
    opacity: 1;
    transition-duration: 0s;
}


@media screen and (max-width:767px) {
.category__name {
    font-size: 1.0rem;
}
.interviewee {
    line-height: 1.5;
    font-size: 1.0rem;
}
.entry__title {
    font-size: 1.6rem;
}
}


/*タイトル周りタグ*/
.article__tag {
    display: block;
    list-style: none;
    margin: 0;
    padding: 0;
} 
.article__tag li {
    display: inline-block;
    margin-right: 10px;
} 
.article__tag li a {
    display: inline-block;
    border: 1px solid #000;
    padding: 5px 10px;
    text-align: center;
    border-radius: 15px;
    font-size: 0.7rem;
} 
.article__tag li a:hover {
    background: #000;
    color: #fff;
    opacity: 1;
    transition-duration: 0s;
} 

.article__tag li a.tagtext {
	font-size: 0.8rem;
	display: block;
	font-weight: 400;
	margin-top: 0;
}
.article__tag li a::before {
    content: "#";
}

/*SNSシェアアイコン*/
.sns {
    display: block;
    margin: 0 0 30px;
    padding: 0;
}
.sns ul {
    display: flex;
    justify-content: flex-end;
    list-style: none;
}
.sns ul li.share {
    margin-left: 6px;
    width:80px;
}

.sns ul li img {
  width: 100%;
  height:auto;
}


/*本文エリア*/
.details {
    width: 100%;
    margin-bottom: 50px;
}
.details img {
    width: 100%;
    height: 100%;
}
.details h3 {
    font-size: 2rem;
    line-height: 1.5;
    margin: 0 0 30px;
    padding: 0;
    font-feature-settings: initial;
}
.details p {
    font-size: 1rem;
    line-height: 1.7;
    margin: 0;
    padding: 0;
}
.details .caption {
    display: block;
    font-size: 0.8rem;
    line-height: 1.5;
    margin: 5px 0 0;
    padding: 0;
}

@media screen and (max-width:767px) {
.details h3 {
    font-size: 1.6rem;
}
}


/* 動画 */
.movie-wrap {
     position: relative;
     padding-bottom: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
     height: 0;
     overflow: hidden;
     margin-top:15px;
}
 
.movie-wrap iframe {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
}

/*記事リンク*/
.details a {
  text-decoration: underline;
  color: #0E1BBB !important;
}
.details a:hover {
  text-decoration: none;
    opacity: 1;
    transition-duration: 0s;
}
.details a[target=_blank] {
	padding-right: 18px !important;
	background: url(/assets/img/common/icon_target_blank2.svg) right center/13px auto no-repeat !important;
}
.details a img[target=_blank] {
	background: none !important;
}

/*プロフィール*/
.profile {
  border-top: 1px solid #cccccc;
  padding: 30px 0;
}
.profile ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.profile li {
  margin-bottom: 20px;
}
.profile li:last-child {
  margin-bottom: 0;
}
.profile li .inner {
  font-size: 0;
  display: flex;
}
.profile li .inner .photo {
  display: inline-block;
  width: 23%;
}
.profile li .inner .photo img {
    width: 100%;
    height: auto;
}
.profile li .inner .txt {
  display: inline-block;
  max-width: 74%;
    margin-left: 3%;
}
.profile li .inner .txt .name {
    font-size: 0.8rem;
    line-height: 1;
    margin-bottom: 10px;
}
.profile li .inner .txt .history {
    font-size: 0.8rem;
    line-height: 1.5;
}
.profile li .inner .txt .history a {
  text-decoration: underline;
}
.profile li .inner .txt .history a:hover {
  text-decoration: none;
}
.profile li .inner .txt .history a[target=_blank] {
	padding-right: 18px !important;
	background: url(/assets/img/common/icon_target_blank2.svg) right center/13px auto no-repeat !important;
}


@media screen and (max-width:767px) {
.profile li .inner {
  font-size: 0;
    display: block;
}

.profile li .inner .photo {
  width: 150px;
    display: block;
    margin: 0 auto;
}

.profile li .inner .txt {
  display: block;
  max-width: 100%;
    width: 100%;
    margin-left: 0;
}
}




/* Banner Area
------------------------------------------------------------------------------------*/
.side__bnr {
    display: block;
    width: 100%;
    margin-bottom: 75px;
}
.side__bnr p {
    margin-top: 10px;
}
.side__bnr p:first-child {
    margin-top: 0;
}
.side__bnr img {
    width: 100%;
    height: auto;
}

@media screen and (max-width:1024px) {
.side__bnr {
    display: flex;
    justify-content: space-between;
}
.side__bnr p {
    margin-top: 0;
    margin-bottom: 20px;
    width: 48%;
}
}

@media screen and (max-width:767px) {
.side__bnr {
    display: block;
}
.side__bnr p {
    margin-top: 10px;
    width: 100%;
}
.side__bnr p:first-child {
    margin-top: 0;
}
}



/* relation&new article&ranking
------------------------------------------------------------------------------------*/
.relation, .newarticle, .rainking {
    display: block;
    margin-bottom: 75px;
}
.relation h2, .newarticle h2, .rainking h2 {
    display: block;
    width: 100%;
    margin: 0;
    color: #999;
    padding: 0;
    text-align: left;
    font-size: 2.3rem;
    line-height: 1;
}
.relation h2 span, .newarticle h2 span, .rainking h2 span {
    display: block;
    font-size: 1.0rem;
    font-weight: 700;
    color: #000;
    padding: 10px 0 20px;
}

.relation dl, .newarticle dl, .rainking dl {
	display: flex;
	justify-content: space-between;
	width: 100%;
	margin: 0 0 20px;
	padding: 0;
}
.relation dt, .newarticle dt, .rainking dt {
	width: 146px;
	margin: 0;
	padding: 0;
    position: relative;
    overflow: hidden;
}
.rainking dt .rank__number {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
	width: auto;
	height: auto;
    padding: 5px 7px;
    font-size: 0.6rem;
    text-align: center;
    background: #d7063b;
    color: #fff;
    font-weight: 700;
}
.rainking dt .num01 {
    background: #988100;
}
.rainking dt .num02 {
    background: #828282;
}
.rainking dt .num03 {
    background: #9a4c00;
}
.rainking dt img {
	width: 100%;
	height: auto;
}
.relation dd, .newarticle dd, .rainking dd {
	width: 202px;
	font-size: 0.8rem;
	font-weight: 700;
	line-height: 1.5;
	margin: 0 0 0 12px;
	padding: 0;
}
.relation dd a:hover, .newarticle dd a:hover, .rainking dd a:hover {
    text-decoration: underline;
    opacity: 1;
}
.relation dd .interviewee, .newarticle dd .interviewee, .rainking dd .interviewee {
    display: block;
	font-size: 0.65rem;
    margin-top: 10px;
    font-weight: 400;
    margin-bottom: 0;
}

@media screen and (max-width:1024px) {
.relation, .newarticle, .rainking {
	display: block;
}
.relation dl, .newarticle dl, .rainking dl {
	display: flex;
	max-width: 100%;
    width: 100%;
	margin: 0 0 40px;
}
.relation dt, .newarticle dt, .rainking dt {
	max-width: 32%;
    width: 32%;
    margin-right: 2%;
}
.rainking dt .rank__number {
    padding: 5px 13px;
    font-size: 2rem;
}

.relation dd, .newarticle dd, .rainking dd {
	max-width: 64%;
    width: 64%;
	font-size: 1.4rem;
	margin: 0 0 0 2%;
}
.relation dd .interviewee, .newarticle dd .interviewee, .rainking dd .interviewee {
	font-size: 1.0rem;
    font-weight: 400;
}
}

@media screen and (max-width:767px) {
.relation h2 span, .newarticle h2 span, .rainking h2 span {
    font-size: 1.1rem;
}
.relation dl, .newarticle dl, .rainking dl {
	margin: 0 0 10px;
}
.rainking dt .rank__number {
    padding: 5px 10px;
    font-size: 0.8rem;
}

.relation dd, .newarticle dd, .rainking dd {
	font-size: 0.8rem;
}
.relation dd .interviewee, .newarticle dd .interviewee, .rainking dd .interviewee {
	font-size: 0.65rem;
    font-weight: 400;
    margin-top: 5px;
}
}



/* other
------------------------------------------------------------------------------------*/
.other {
    display: block;
}
.other h3 {
    display: block;
    width: 100%;
    margin: 0 0 20px;
    font-size: 1.0rem;
    line-height: 1;
    padding: 0;
}

.side_prof_order {
    list-style: none;
    margin: 0 0 55px;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
}
.side_prof_order li {
    margin: 0 20px 20px 0;
}
.side_prof_order li a {
    text-decoration: underline;
}
.side_prof_order li a:hover {
    text-decoration: underline;
    transition-duration: 0s;
}

@media screen and (max-width:767px) {
.other h3 {
    font-size: 1.1rem;
}
}



/* sort
------------------------------------------------------------------------------------*/
.sort {
    display: block;
}
.sort h3 {
    display: block;
    width: 100%;
    margin: 0 0 20px;
    font-size: 1.0rem;
    line-height: 1;
    padding: 0;
}
.sort select {
    padding: 5px 10px !important;
}

@media screen and (max-width:767px) {
.sort h3 {
    font-size: 1.1rem;
}
}




/* detail.cssから移動したもの
------------------------------------------------------------------------------------*/

/* 写真の切り替え用 */
.imgpc { display:block !important; }
.imgsp { display:none !important; }
@media screen and (max-width: 767px) {
.imgpc { display:none !important; }
.imgsp { display:block !important; }
}

/* 左右に画像とテキストを並べたとき用 */
.suprepo {display:flex; justify-content: space-between !important; align-items:center !important;}
@media screen and (max-width: 1280px) {.suprepo {display:block;}}

/* 上付きと下付き */
.details sup { font-size: 70%; vertical-align: super !important; }
.details sub { font-size: 70%; vertical-align: sub !important; }

/* 左右並べ用 */
.recipeBox {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 30px;
    padding: 0;
    align-items: flex-start;
    font-weight:normal !important;
}
.recipeBox dt {
    width: 40%;
    margin: 0 3% 0 0;
}
.recipeBox dt img {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
}
.recipeBox dd {
    width: 57%;
    margin: 0 !important;
    padding: 0 !important;
}
.recipeBox dd .recipettl {
    display: block;
    font-size: 126%;
    font-weight: bold;
    margin: 10px 0;
}
.recipeBox dd .howto {
    margin: 20px 0 0;
}
.recipeBox dd .howto li {
    line-height: 1.5;
}
@media only screen and (max-width: 767px) {
.recipeBox {
    display: block;
}
.recipeBox dt {
    width: 50%;
    margin: 0 auto 15px;
    text-align: center;
}
.recipeBox dd {
    width: 100%;
    margin: 0;
}
}



/* SDGsアイコン用 */
img.sdgsicon {
    max-width: 120px !important;
    height: auto !important;
    margin: 0 auto !important;
    padding: 0 !important;
    text-align: center !important; 
}
@media only screen and (max-width: 767px) {
img.sdgsicon {
    max-width: 60px !important;
}
}


/* 引用符 */
blockquote {
    position: relative;
    padding: 10px 15px 10px 45px;
    box-sizing: border-box;
    font-style: italic;
    background: #f6f6f6;
    color: #555;
}

blockquote:before{
    display: inline-block;
    position: absolute;
    top: 5px;
    left: -5px;
    content: "“";
    color: #cfcfcf;
    font-size: 90px;
    line-height: 1;
}

blockquote p {
    padding: 12px 15px 10px 10px;
    line-height: 1.7;
}

blockquote cite {
    display: block;
    text-align: left;
    color: #888888;
    font-size: 0.7em;
    margin-bottom:15px;
}


/* 768px以下のスマホ表示用 */
img.img250px {
    width: 250px !important;
    height: auto !important;
}@media only screen and (max-width: 767px) {
img.img250px {
    width: 80% !important;
    margin:0 auto !important;
}
}

/*リスト用*/
ul.detailList {
list-style:disc;
}
ul.detailList li {
margin-bottom:10px;
line-height:1.5;
}
@media only screen and (max-width: 767px) {
ul.detailList {
padding-left: 0 !important;
}
ul.detailList li {
margin-left:0 !important;
padding-left: inherit !important;
}
}

/*書籍等縦写真PCとSP用*/
.book img {
width: auto;
max-height:300px;
display:block;
margin: 15px 0;
}
@media only screen and (max-width: 767px) {
.book img {
width: 70% !important;
max-height:auto !important;
height:auto !important;
display: block;
margin: 15px auto;
}
}


/*まとめ記事用*/
.site-wrap .block-kiji .details .matome {
  display: block;
  margin-bottom:60px;
}
.site-wrap .block-kiji .details .matome a {
  display: block;
	color: #000 !important;
  text-decoration: underline !important;
}
.site-wrap .block-kiji .details .matome h3 a:hover {
  opacity: .6;
  text-decoration: underline !important;
}
.site-wrap .block-kiji .details .matome dl {
	display: flex;
}
.site-wrap .block-kiji .details .matome dl dt {
	margin-right: 20px;
}
.site-wrap .block-kiji .details .matome dl dt img {
    width: 200px;
    height:auto;
}
.site-wrap .block-kiji .details .matome dl dd {
	margin: 0;
	padding: 0;
    font-size:13px;
    line-height:1.4;
}
.site-wrap .block-kiji .details .matome dl dd h3.matome {
	font-size: 20px;
	margin-bottom: 3px;
	line-height: 1.2;
	padding: 0 !important;
}
.site-wrap .block-kiji .details .matome dl dd span.matome_date {
	font-size: 13px;
	color: #777;
	display: block;
	margin-bottom: 10px;
}

@media only screen and (max-width: 1024px) {
.site-wrap .block-kiji .details .matome dl {
	display: block;
}
.site-wrap .block-kiji .details .matome dl dt {
	margin-right: 0;
	margin-bottom: 15px;
	display: block;
}
.site-wrap .block-kiji .details .matome dl dt img {
    width: 100% !important;
    height:auto;
}
.site-wrap .block-kiji .details .matome dl dd {
	display: block;
}
.site-wrap .block-kiji .details .matome dl dd h3.matome {
	      font-size: 18px;
      font-size: calc(40 *(100vw / 640));
      line-height: 1.25;;
}
.site-wrap .block-kiji .details .matome dl dd span.matome_date {
}
}


/* ------------------------------------------------
  SNS　TW→X変更のための対応
------------------------------------------------ */
.my-x-share-button {
    display: inline-block;
    vertical-align: top;
    zoom: 1;
    position: relative;
    height: 20px;
    box-sizing: border-box;
    padding: 1px 8px;
    background-color: #000;
    color: #fff !important;
    border-radius: 9999px;
    font-weight: 500;
    cursor: pointer;
    width:auto;
}

.my-x-share-button i {
    position: relative;
    top: 1px;
    display: inline-block;
    width: 11px;
    height: 11px;
    background: transparent 0 0 no-repeat;
    background-image: url(https://magazine.aktio.co.jp/assets/img/common/icon_side_x.svg);
    background-size: 10px auto;
}

.my-x-share-button .label {
    display: inline-block;
    vertical-align: top;
    zoom: 1;
    margin-left: 3px;
    white-space: nowrap;
    color: #fff !important;
    font-size:11px;
    margin-top: 3px;
    font-weight: 400;
}

/* 縦画像のスマホ表示用 */
.details img.img65 {
    display:block !important;
    width: auto !important;
    height: 65% !important;
    margin: 0 !important;
}
@media only screen and (max-width: 767px) {
.details img.img65 {
    display:block !important;
    width: 65% !important;
    height: auto !important;
    margin: 0 auto !important;
}
}

/* 横画像の縮小表示用 */
.details img.half {
    display:block !important;
    width: 50% !important;
    height: auto !important;
    margin: 0 !important;
}
@media only screen and (max-width: 767px) {
.details img.half {
    display:block !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 auto !important;
}
}

/*まとめ記事用*/
.details .matome {
  display: block;
  margin-bottom:60px;
}
.details .matome a {
  display: block;
	color: #000 !important;
  text-decoration: underline !important;
}
.details .matome h3 a:hover {
  opacity: .6;
  text-decoration: underline !important;
}
.details .matome dl {
	display: flex;
}
.details .matome dl dt {
	margin-right: 20px;
}
.details .matome dl dt img {
    width: 200px;
    height:auto;
}
.details .matome dl dd {
	margin: 0;
	padding: 0;
    font-size:13px;
    line-height:1.4;
}
.details .matome dl dd h3.matome {
	font-size: 20px;
	margin-bottom: 3px;
	line-height: 1.2;
	padding: 0 !important;
}
.details .matome dl dd span.matome_date {
	font-size: 13px;
	color: #777;
	display: block;
	margin-bottom: 10px;
}

@media only screen and (max-width: 1024px) {
.details .matome dl {
	display: block;
}
.details .matome dl dt {
	margin-right: 0;
	margin-bottom: 15px;
	display: block;
}
.details .matome dl dt img {
    width: 100% !important;
    height:auto;
}
.details .matome dl dd {
	display: block;
}
.details .matome dl dd h3.matome {
	      font-size: 18px;
      font-size: calc(40 *(100vw / 640));
      line-height: 1.25;;
}
.details .matome dl dd span.matome_date {
}
}

.details ol {
    padding-left:20px;
}
.details ol li {
    padding-bottom:15px;
    line-height:1.6;
}

