@charset "UTF-8";
@import url("grid.css");

img {
	max-width:100%;
	height: auto;/*高さ自動*/
}
a {
    display:block;
    color: #000;
    text-decoration-line: none;
}
a:hover { 
    color: #00047B;

}
a:link {
	color: #8F90A0; 
}



/*ヘッダー
-------------------------------------*/
.header {
	display: flex;
    flex-direction: row;
    padding: 2rem 0 0 0;
}
.header-box {
	margin-left: auto;
	margin-top: 8px;
}
.contact-button {
	padding: 1rem;
	border: 2px solid #000;
}
nav ul {
	display: flex;
    flex-direction: row;
    justify-content: space-around;
    list-style: none;
	margin: 1rem 0 0 0;
}
nav li {
	flex: 1 0 auto;
}
nav li a {
    text-decoration: none;
    text-align: center;
    width: 100%;
}
nav a:hover {
    background-color: #f7f7f7;    
}
nav a {
    padding: 0.5rem;
}

@media screen and (min-width: 620px){
/* PC時はMENUボタンを非表示 */
#open,#close {
    display: none !important;
}

#navi {
    display: block !important;
}
}

@media screen and (max-width: 620px){
.header {
	flex-direction: column;
    margin-bottom: 2px;
}
.header #open,#close  {
    position: absolute;
    top: 20px;
    right: 12px;
}
nav ul {
	flex-direction: column;
}
.header li {
	padding-top: 0;
}

/* スマホ時はMENUボタンを表示 */
#open {
    display: block;
    background: url(../img/button.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 50px;
    height: 50px;
    border: none;
    position: absolute;
    top: 20px;
    right: 12px;
}
#close  {
    display: block;
    background: url(../img/button2.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 50px;
    height: 50px;
    border: none;
    position: absolute;
    top: 20px;
    right: 12px;
}
/* スマホ時はメニューを非表示 */
#navi {
    display: none;
}
}
    
/*背景
-------------------------------------*/
.bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("https://sunmusic-gp.co.jp/etc/hirano_calendar2026/img/top.jpg") no-repeat center center;
  background-size: cover;
  z-index: -1;
	
}

.content {
  position: relative;
  z-index: 1;
  padding: 1rem;
  color: #000;
}
/*メイン画像
-------------------------------------*/
.mainimg img {
    width: 100%;
	padding: 5rem 3rem 5rem 3rem;
}

/*サブ画像
-------------------------------------*/
.subimg img {
    margin: auto;
    display: block;
    width: 70%;
	padding: 2rem 0rem 2rem 0rem;
}

/*表紙画像
-------------------------------------*/
.cover img {
    width: 25%; 
	margin: 30px 0 0 0;
}

.responsive-image {
    width: 50%; /* デフォルトで画像を100%表示 */
    max-width: 100%;
        }

.image2 {
    width: 30%; /* デフォルトで画像を100%表示 */
    max-width: 60%;
        }

/* サイト全体のフォント指定 */
body {
    font-family:"roboto" , 'Noto Sans JP', sans-serif;
}



/*メインコンテンツ
-------------------------------------*/
main {
    margin: 2rem 0 0 0;
}
section {
	margin: 3rem 0;
	padding: 3rem 0;
}
.gray-back {
	background-color: #f4f4f4;
}

.text {
    inline-size: 80%;
    text-align: center;
    margin-right: auto;
    margin-left: auto;
	font-size: 100%;
}
.sub-text {
    color: #1B1B1B;
    text-align: center;
    margin-right: auto;
    margin-left: auto;
	font-size: 75%;
	padding: 0px 0px 30px;
}

	/*　text box */
.text-box {
 text-align: center;
 position:relative;
 padding: 20px 20px 20px;
 margin: 2.5em auto;
 width: 50%;
 color: #111111; /* 文字色 */
 opacity: 0.7;
 background-color: #f0f0f0;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 130%;
}

.text-box2 {
 text-align: center;
 position:relative;
 padding: 20px 20px 20px;
 margin: 2.5em auto;
 width: 100%;
 color: #ffffff; /* 文字色 */
 background-color: #000000;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 90%;
}

.staff {
 text-align: center;
 position:relative;
 padding: 20px 20px 20px;
 margin: 2.5em auto;
 width: 100%;
 opacity: 0.7;
 color: #ffffff; /* 文字色 */
 background-color: #000000;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 60%;
}

.link {
 justify-content: space-around;
 padding: 10px 10px 10px;
 margin: auto;
 color: #ffffff; /* 文字色 */
 box-shadow: inset 0 0 0 rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 80%;
 display: flex;
 justify-content: center;
}

  li {
 list-style: none;
 margin: 0 10px;
  }

.event-text {
 text-align: center;
 position:relative;
 padding: 10px 20px 0px;
 margin: 2.5em auto;
 width: 50%;
 color: #000; /* 文字色 */
 background-color: #fff;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 80%;
}


.event-text2 {
 text-align: center;
 position:relative;
 padding: 10px 10px 10px;
 margin: 2.5em auto;
 width: 40%;
 color: #000; /* 文字色 */
 background-color: #E1E1E1;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 70%;
}
.event-text3 {
 text-align: left;
 position:relative;
 padding: 10px 10px 10px;
 margin: 2.5em auto;
 width: 40%;
 color: #000; /* 文字色 */
 background-color: #fff;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 80%;
}

.gmap {
    padding: 10px 10px 50px;
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;    /*16:9の比率にしたい場合、9/16=56.25%*/
}

.gmap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.highlight {
	font-size: 110%;
    color: red;
    font-weight: bold;
	
        }
/*プロフィール
-------------------------------------*/
.profile {
  width: 50%;
  padding:2rem;
  margin: 0 auto;
}

.profile__img {
  width: 300px;
  display: flex;
  justify-content: center;
	align-items: center;
    max-width: 960px;
    margin: 0 auto;
}

.profile__name,.profile__yomi,.profile__desc {
  color: #000;
  text-align: center;
}

.profile__name {
  padding:1.6rem 0 .2rem;
  font-weight:bold;
  font-size:2rem;
  letter-spacing:.1rem;
}

.profile__yomi {
  font-size:1.2rem;
  letter-spacing:.1rem;
  opacity:.7;
}

.profile__desc {
  padding:3rem 0 0;
  line-height:1.6rem;
  font-size: 85%;
  text-align: left;
}

/*キャッチコピー
-------------------------------------*/
.catch {
    text-align: center;
	font-size: 120%;
}
.catch h2 {
    padding-bottom: 1rem;
	font-size: 100%;
}
.catch h3 {
    padding-bottom: 1rem;
	font-size: 100%;
}
.catch h4 {
    padding-bottom: 1rem;
	font-size: 105%;
}
.under {
    border-bottom: 0.4rem solid #000;
    padding:0 1rem 1rem 1rem;
}
.center {
	text-align: center;
	margin-bottom: 3rem;
}

/*フッター
-------------------------------------*/
footer {
    padding: 5rem 0;
	text-align: center;
}
footer h4 {
    border-bottom: 3px solid #ccc;
}

/*コピーライト
-------------------------------------*/
.copyright {
    text-align: center;
    padding: 1rem 0;
    background-color: #000;
}
.copyright a {
    color: #fff;
    text-decoration: none;
	display: inline;
}

/*ページトップへ戻るボタン
-------------------------------------*/
#pagetop {
    position: fixed;
    bottom: 15px;
    right: 15px;
}
#pagetop a {
    display: block;
    background: #000;
    color: #fff;
    width: 50px;
    padding: 10px 5px;
    text-align: center;
}
#pagetop a:hover {
    background: #666;
}

/* 幅768px以下の表示
-------------------------------------*/
@media screen and (max-width: 620px){
	
/*ヘッダー
-------------------------------------*/
.header-box {
	display: none;
}	

.table th {
	width: 100%;
	display: block;
}	
.table td {
	display: block;
}
	
	
.text {
    text-align: center;
    margin-right: auto;
    margin-left: auto;
	font-size: 90%;
	max-width: 100%;
}
	
.profile {
  width: 90%;
  padding:2rem;
  margin: 0 auto;
}
	
		/*　テキストボックス */
.text-box {
 width: 100%;
 text-align: center;
 position:relative;
 padding: 20px 2px 2px;
 margin: 1em auto;
 max-width: 100%;
 color: #555555; /* 文字色 */
 background-color: #f0f0f0;
 box-shadow: inset 0 0 40px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 100%;
}
.text-box2 {
 text-align: left;
 position:relative;
 padding: 20px 10px 10px;
 margin: 1em auto;
 max-width: 100%;
 color: #ffffff; /* 文字色 */
 background-color: #000000;
 box-shadow: inset 0 0 40px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 90%;
}
.text-box3 {
 text-align: center;
 position:relative;
 padding: 20px 10px 10px;
 margin: 1em auto;
 max-width: 100%;
 color: #464646; /* 文字色 */
 background-color: #ffffff;
 box-shadow: inset 0 0 40px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 80%;
}
.event-text {
 text-align: center;
 position:relative;
 padding: 20px 20px 20px;
 margin: 2.5em auto;
 width: 90%;
 color: #000; /* 文字色 */
 background-color: #fff;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 80%;
}


.event-text2 {
 text-align: center;
 position:relative;
 padding: 10px 10px 10px;
 margin: 2.5em auto;
 width: 90%;
 color: #000; /* 文字色 */
 background-color: #E1E1E1;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 70%;
}
	
.event-text3 {
 text-align: left;
 position:relative;
 padding: 10px 10px 10px;
 margin: 2.5em auto;
 width: 90%;
 color: #000; /* 文字色 */
 background-color: #fff;
 box-shadow: inset 0 0 30px rgba(000, 000, 000,), 0 2px 2px #ccc;
 font-size: 80%;
}
	
	
.catch h2 {
 padding-bottom: 0.5rem;
 font-size: 90%;
}

.catch h3 {
 padding-bottom: 0.2rem;
 font-size: 60%;
}

.catch h4 {
 padding-bottom: 0.2rem;
 font-size: 60%;
}
	
 .profile {
 max-width: 100%;
 padding:0.5rem;
 margin: 0 auto;
}

.profile__desc {
  padding:1.6rem 0 0;
  line-height:1.6rem;
  font-size: 85%;
  text-align: left;
}
.profile__img {
  width: 70%;
}
	
	/*サブ画像
-------------------------------------*/
.subimg img {
    margin: auto;
    display: block;
    width: 100%;
}
.responsive-image {
   width: 90%; /* 画面幅が600px以下の場合に画像を90%表示 */
            }
.responsive-image2 {
   width: 80%; /* 画面幅が600px以下の場合に画像を90%表示 */
            }
}