@charset "UTF-8";

/*-----------------------*/
/*   @media スマホ 縦     */
/*-----------------------*/

@media screen and (max-width: 375px) {
        
/* --- ここからハンバーガーメニュー ------　*/  

#logo {
    max-width:50%;
    display:block;
    /* margin:0 auto; */
    height: auto;
    width: 30px;
    float: left;
}
nav{
 width: 100%;
 height: 70px;
 position: relative;
 /*background: #F6F6F6; */
 background: #ffffff; 
}
.drawer{
 display: flex;
 flex-direction: row;
 align-items: center;
 justify-content: space-between;
 position: relative;
 height: 70px;
 padding: 0 1em;
}


/*ナビゲーション部分*/    
.Menu{
  text-align:center;
  background-color:rgba(255,255,255,0.5);
  transition: .7s ease;　/*滑らかに変化*/
  -webkit-transform: translateX(-110%);
  transform: translateX(-110%);     /*左に隠しておく*/
  font-family: "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS PGothic", 'Arial', 'Helvetica', sans-serif;
}

/* 親メニュー　起動時　*/
.Menu li.Menu__single a {
    background-color: #fff;
    color: #cc7eb1;
    display:block;
    font-weight:bold;
    padding: 1.2em;     /* 幅の設定 */
    border-bottom: 1px dotted #CCC;
    text-decoration:none;
    text-align: left;
} 
/* 親メニュー　フォーカス時　*/
.Menu li.Menu__single a:hover{
    background-color: #cc7eb1;
    color: #fff;
    transition: 1s ease;/*滑らかに表示*/
}     
/* 親メニューのリンクなし設定　 */
.Menu li.Menu__single .init-bottom:hover{
    cursor: default;
    background-color: #fff;
    color: #cc7eb1;
}        
    
/* --- 子メニュー専用 --- */
/* 子メニュー　起動時　*/
.Menu li.Menu__single ul.Menu__second-level a {
    background-color: #fff;
    color: #cc7eb1;
    font-weight: normal;
    text-align: left;
} 
/* 子メニュー　フォーカス時　*/
.Menu li.Menu__single ul.Menu__second-level a:hover{
    background-color: #cc7eb1;
    color: #fff;
    transition: 1s ease;    /*滑らかに表示*/
} 


/*OPEN時の動き*/
.Menu.open {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);     /*中身を表示（右へスライド）*/
    background:#FFFFFF  ;
}

/*トグルボタンのスタイルを指定*/
.Toggle {
    display: block;
    /*position: fixed;    /* bodyに対しての絶対位置指定（スクロールで移動で常に表示）*/
    position: absolute;    /* bodyに対しての絶対位置指定（上端に固定） */
    width: 42px;
    height: 42px;
    cursor: pointer;
    z-index: 3;
    right:2px;
}

/* ハンバーガー（三本線）の設定 */   
.Toggle span {
    display: block;
    position: absolute;
    width: 30px;
    border-bottom: solid 2px #cc7eb1;    /*ハンバーガーの線の太さと色*/
    -webkit-transition: .35s ease-in-out; /*変化の速度を指定*/
    -moz-transition: .35s ease-in-out;    /*変化の速度を指定*/
    transition: .35s ease-in-out;     /*変化の速度を指定*/
}
.Toggle span:nth-child(1) {
    top:8px;
}
.Toggle span:nth-child(2) {
    top: 18px;
}
.Toggle span:nth-child(3) {
    top: 29px;
}
/* 1番目のspanを-45度に */
.Toggle.active span:nth-child(1) {
    top: 18px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

    
/* --- ここまでハンバーガーメニュー ---*/
    
    
/* ------- 本文（スマホ） -------*/
    
    
/* index,その他のページすべて共通のヘッダ */    
.header_img, .header_img_half{
  width: 100%;
  height: 0;
  padding-top: calc(277 / 1090 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
  background: url(../images_full/top_mob.jpg) center center / cover no-repeat;
}
        
.left_article {
	width: 100%;
	height: auto;
}
.right_article {
	width: 100%;
	height: auto;
	padding-bottom: 25px;
	font-family: "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS PGothic", 'Arial', 'Helvetica', sans-serif;
}

.columns {
	width: 100%;
	margin-top: 6px;
	margin-right: 0px;
	margin-bottom: 6px;
	margin-left: 0px;
	padding: 0px;
}
.columns p {
	padding-left: 14px;
	padding-right: 14px;
}
.column_half.left_half {
	width: 100%;
}
.column_half.right_half {
	width: 100%;
}
.column_policy {
		width: 100%;
}

    
/* ------- 過去の出演 activity（スマホ） -------*/

.center_act {
    font-family: "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS PGothic", 'Arial', 'Helvetica', sans-serif;
    }
    
.center_act p{
    font-size: 90%;
    line-height: 1.2;
    text-align: center;
    width: 100%;
    }

.setpicture {
	margin: 0px;
	padding: 0px;
	width: 100%;
	max-width: 100%;
	height: auto;
	max-height: 100%;
}
    
.center_act dt{
    font-weight: bold;
    font-size: 90%;
    line-height: 1.2;
    width: 100%;
	border-bottom: 1px dotted #cc7eb1;
    border-top: 2px solid #cc7eb1;
    padding-top:8px;
    padding-bottom: 3px;
}
.center_act dd{
    font-size: 90%;
    line-height: 1.2;
    width: 100%;
    height: auto;
    margin-top: 13px;
    margin-left: 0px;
    margin-bottom: 15px;
}


/* copyright */
.copyright {
    padding: 5px;
	margin-bottom: 0px;
    font-size: 75%;
    line-height: 1.2;
    font-family: "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS PGothic", 'Arial', 'Helvetica', sans-serif;
}
    
.thumbnail {
	width: 175px;
	/*border-radius: 200px;*/
	height: 100px;
    margin: auto;
	/*margin-left: auto;*/
}
.thumbnail_align {
	text-align: center;
}
.thumbnail_align a:hover{
	opacity: 0.5;
    transition: 0.5s;
}
    
} /*  @media (max-width: 375px) ここまで  */


/*-------------------------------------------------------*/
/*                   @media tablet                       */
/*-------------------------------------------------------*/

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

            
/* --- ここからハンバーガーメニュー ------　*/

#logo {
    max-width:50%;
    display:block;
    /* margin:0 auto; */
    height: auto;
    width: 30px;
    float: left;
}
nav{
 width: 100%;
 height: 70px;
 position: relative;
 /*background: #F6F6F6; */
 background: #ffffff; 
}
.drawer{
 display: flex;
 flex-direction: row;
 align-items: center;
 justify-content: space-between;
 position: relative;
 height: 70px;
 padding: 0 1em;
}

/*ナビゲーション部分*/    
.Menu{
  text-align:center;
  background-color:rgba(255,255,255,0.5);
  transition: .7s ease;　/*滑らかに変化*/
  -webkit-transform: translateX(-110%);
  transform: translateX(-110%);     /*左に隠しておく*/
}

/* メニュー　起動時の配置*/
.Menu li.Menu__single ul{
    list-style: none;
    margin-left: 0;
    padding-left: 0;
} 
    
/* 親メニュー　起動時　*/
.Menu li.Menu__single a {
    background-color: #fff;
    color: #cc7eb1;
    display:block;
    font-weight:bold;
    padding: 1.2em;     /* 幅の設定 */
    border-bottom: 1px dotted #CCC;
    text-decoration:none;
} 
/* 親メニュー　フォーカス時　*/
.Menu li.Menu__single a:hover{
    background-color: #cc7eb1;
    color: #fff;
    transition: 1s ease;/*滑らかに表示*/
} 
    
/* 親メニューのリンクなし設定　 */
.Menu li.Menu__single .init-bottom:hover{
    cursor: default;
    background-color: #fff;
    color: #cc7eb1;
} 

/* --- 子メニュー専用 --- */  
    
/* 子メニュー　起動時　*/
.Menu li.Menu__single ul.Menu__second-level a {
    background-color: #fff;
    color: #cc7eb1;
    font-weight: normal;
} 
/* 子メニュー　フォーカス時　*/
.Menu li.Menu__single ul.Menu__second-level a:hover{
    background-color: #cc7eb1;
    color: #fff;
    transition: 1s ease;    /*滑らかに表示*/
} 

/*OPEN時の動き*/
.Menu.open {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);     /*中身を表示（右へスライド）*/
    background:#FFFFFF  ;
}

/*トグルボタンのスタイルを指定*/
.Toggle {
    display: block;
    /*position: fixed;    /* bodyに対しての絶対位置指定（スクロールで移動で常に表示）*/
    position: absolute;    /* bodyに対しての絶対位置指定（上端に固定） */
    width: 42px;
    height: 42px;
    cursor: pointer;
    z-index: 3;
    right:15px;
}

/* ハンバーガー（三本線）の設定 */   
.Toggle span {
    display: block;
    position: absolute;
    width: 45px;
    border-bottom: solid 2px #cc7eb1;    /*ハンバーガーの線の太さと色*/
    -webkit-transition: .35s ease-in-out; /*変化の速度を指定*/
    -moz-transition: .35s ease-in-out;    /*変化の速度を指定*/
    transition: .35s ease-in-out;     /*変化の速度を指定*/
}
.Toggle span:nth-child(1) {
    top:5px;
}
.Toggle span:nth-child(2) {
    top: 18px;
}
.Toggle span:nth-child(3) {
    top: 32px;
}
/* 1番目のspanを-45度に */
.Toggle.active span:nth-child(1) {
    top: 18px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
/* 2番目と3番目のspanを45度に */
.Toggle.active span:nth-child(2),
.Toggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

    
/* --- ここまでハンバーガーメニュー ---*/
    
    
/* ------- 本文（tablet） -------*/
    
/* index,その他のページすべて共通のヘッダ */
.header_img, .header_img_half{
  width: 100%;
  height: 0;
  padding-top: calc(277 / 1527 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
  background: url(../images_full/top_tab.jpg) center center / cover no-repeat;
}    
    
.left_article {
	width: 100%;
	height: auto;
}
.right_article {
	width: 100%;
	height: auto;
	padding-bottom: 25px;
}

.columns {
	width: 100%;
	margin-top: 6px;
	margin-right: 0px;
	margin-bottom: 6px;
	margin-left: 0px;
	padding: 0px;
}
.columns p {
	padding-left: 14px;
	padding-right: 14px;
}
.column_half.left_half {
	width: 100%;
}
.column_half.right_half {
	width: 100%;
}
.column_policy {
		width: 100%;
}
    
.thumbnail {
	width: 175px;
	/*border-radius: 200px;*/
	height: 100px;
	margin-left: auto;
}
.thumbnail_align {
	text-align: center;
}
.thumbnail_align a:hover{
	opacity: 0.5;
    transition: 0.5s;
}
    
    
/* ------- 過去の出演 activity（tablet） -------*/
    
.center_act p{
    font-size: 90%;
    line-height: 1.6;
    width: 100%;
    }

.setpicture {
	margin: 0px;
	padding: 0px;
	width: 100%;
	max-width: 100%;
	height: auto;
	max-height: 100%;
}
    
.center_act dt{
    font-weight: bold;
    font-size: 90%;
    width: 100%;
	border-bottom: 1px dotted #cc7eb1;
    border-top: 2px solid #cc7eb1;
    padding-top:8px;
    padding-bottom: 3px;
}
.center_act dd{
    font-size: 90%;
    line-height: 1.6;
    width: 100%;
    height: auto;
    margin-top: 13px;
    margin-left: 0px;
    margin-bottom: 15px;
}
    
    
/* ------- 品質方針・情報セキュリティ方針・個人情報保護方針（tablet） ここから-------*/
    
/* 文字の配置の指定 */
    
.policy h2{
	font-size: 18px;
	color: #113b66;
	margin: 0;
	margin-top: 20px;
	margin-bottom: 17px;    
	background-image: url(../images/subtitle.jpg);
	background-repeat: repeat;
	line-height: 53px;
	padding-left: 30px;
}

.policy .text{
    font-size: 14px;
	line-height: 2.0;
    padding-left: 5px;
}

.policy p{
	margin: 0;
	bottom: 20px;
}  
    
/* 右寄せ　代表取締役 */
    
.policy .text2 p {
	font-size: 14px;
	line-height: 2.0;
    text-align: right;
    width: 90%;/*
    margin-top: 30px;
    margin-right: 30px;*/
}

/* 1.… 2.… の指定 */
.policy .text dt {
	margin-left:10px;
    width: 90%;
}
.policy .text dd {
	margin-left:20px;
    width: 90%;
}
    
    
/* 表の指定 */
.policy .text table {
	border: 1px solid #cccccc;　/*　外枠　*/
	text-align: center;
    width: 90%;
    margin: 20px;/*
    margin-left: auto;
    margin-right: auto;*/
}

/* 表内の行の設定 */
.policy .text table tr {
	border: 1px solid #cccccc;　/*　内側の縦の線　*/
    text-align: left;
    width: 40%;
	padding: 10px;	/*テーブル内の余白*/
}
    
/* 表内のセルの設定 */
.policy .text table tr td{
	border: 1px solid #cccccc;　/*　内側の横の線　*/
    text-align: left;
	line-height: 1.5;
    width: 60px;
	padding: 10px;	/*テーブル内の余白*/
}

/*　表内のマークを縮小表示　*/
.policy .text .mark_img{
    width: 75%;
}

/*------------　品質方針（tablet） ここまで ------------ */  
    
}/* @media (min-width: 375px) and (max-width: 768px) */


/*---------------------------------------------------------------*/
/*                         @media PC　　                  　      */
/*---------------------------------------------------------------*/

@media (min-width: 768px) {
    
header::after{    
    display:none;
} 
#logo {
    max-width:50%;
    display:block;
    margin: auto;
    height: auto;
    width: 30px;
    float: left;
}
nav{
 display: flex;
 width: 100%;
 height: 70px;
 position: relative;
 /*background: #F6F6F6; */
 background: #ffffff; 
}
.Toggle{
    display: none;
}

/*----- メニュー ----*/

/* 親メニュー */
 .Menu {
    position: relative;
    width: 70%;
    height: 40px;
    max-width: 800px;
    margin-top: 10px;
    margin-right: 0;
    float: right;
}
.Menu > li {
    float: left;
    width: 25%; /* 項目数4つの場合 */
    height: 40px;
    line-height: 40px;
    background: #ffffff; 
}
.Menu > li:hover {
    background: #cc7eb1;  /* 菖蒲色 あやめいろ */
    color: #fff;
    -webkit-transition: all .5s;
    transition: all 1.5s;
}
.Menu > li a {
    display: block;
	color: #888;
    text-align: center;
    font-weight: normal;
}
.Menu > li a:hover {
	color: #f5f5f5;
}
    
/* 親メニューにフォーカスが当たるまで子メニュー非表示 */
.Menu__second-level {
    visibility: hidden;
    opacity: 0;  
    z-index: 1;
}    

/* 子メニュー */
.Menu__second-level li {
    /*border-top: 1px solid #111;*/
}
.Menu__second-level li a {    
	color: #888;
    text-align: left;
}
.Menu__second-level li a:hover {
	color: #cc0000;
    text-decoration: underline;
    transition: 1s;
}

/* 下矢印 ∨ の記述　*/  
.init-bottom:after {
    content: '';
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: 0 0 0 15px;
    border-right: 1px solid #999;
    border-bottom: 1px solid #999;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);cursor: default;
}
/* 下矢印 ∨ はリンクなし　*/  
.init-bottom:hover{
    cursor: default;
}

/* floatクリア */
.Menu:before,
.Menu:after {
    content: " ";
    display: table;
}

.Menu:after {
    clear: both;
}

.Menu {
    *zoom: 1;
}

/* 親メニューの位置の設定を継承 */
.Menu > li.Menu__single {
    position: relative;
}

li.Menu__single ul.Menu__second-level {
    position: absolute;    
    top: 40px;
    width: 150%;
    background: #fff;
    -webkit-transition: all .3s ease;
    transition: all .8s ease;
}

/* 親メニューにフォーカスが当たると子メニュー表示 */
li.Menu__single:hover ul.Menu__second-level {
    /*top: 50px;*/
    top: 40px;
    visibility: visible;
    opacity: 1; 
    background: #fff;
    transition: all .8s ease;
}
    
    
/*----- メニュー ここまで ----*/   
            
/* index.htmlのみ大きなヘッダ */
.header_img{
  width: 100%;
  height: 0;
  padding-top: calc(568 / 1527 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
  background: url(../images_full/top.jpg) center center / cover no-repeat;
} 
                
/* index.html以外のヘッダ */
.header_img_half{
  width: 100%;
  height: 0;
  padding-top: calc(258 / 1525 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
  background: url(../images_full/top_half.jpg) center center / cover no-repeat;
}
    
.thumbnail {
	width: 175px;
	height: 100px;
	margin-left: auto;
}
.thumbnail_align {
	text-align: center;
}
.thumbnail_align a:hover{
	opacity: 0.5;
    transition: 0.5s;
}
    
    
/* ------- 過去の出演 activity（PC） -------*/
    
.center_act p{
    font-size: 16px;
    line-height: 1.8;
    width: 100%;
    }
    
.center_act dt{
    font-weight: bold;
    font-size: 16px;
    width: 100%;
	border-bottom: 1px dotted #cc7eb1;
    border-top: 2px solid #cc7eb1;
    padding-top:10px;
    padding-bottom: 5px;
}
.center_act dd{
    font-size: 16px;
    line-height: 1.8;
    width: 100%;
    height: auto;
    margin-top: 13px;
    margin-left: 0px;
    margin-bottom: 20px;
}
 

} /*@media (min-width: 768px)*/