@charset "utf-8";
html{
    user-select: none;
}
body {
    width: max-content;
    height: max-content;
}
h2{
    margin-left: calc((1.4vw + 1.4svh)*2);
    font-size: calc(1.4vw + 1.4svh);
    margin-top: 1.5em;
}
h4{
    line-height: 0;
    font-family: 'Noto Sans JP', sans-serif;
}
summary {
    display: block;
}
summary::-webkit-details-marker {
    display: none;
}
.unshown {
    display: none;
}


/*------ 本体 ------*/

#mobile-section {
    position: relative;
    top: 0%;
    height: max-content;
    min-height: 100vh;
    margin-left: 0 auto;
    left: 0;
    padding-top: 11vh;
    background-color:#ffffff;
}

/* Bプロ/Cプロ警告 */
.rainyprogramwarning {
    margin-top: 3svh;
    padding: 0 0.6rem;
    text-align: center;
    font-size: calc(0.3vw + 0.3svh);
    font-weight: bolder;
    color: #eeeeee;

    font-weight: 600;
    font-size: 1.2em;
    background: linear-gradient(0.25turn, #17c0ef, #1e90ff);
    padding: 1em;
    margin-bottom: 5em;
    border-radius: 1em;
    margin-inline: 2em;
}

/*------フィルタメニュー--------*/
#filtermenu {
    position: relative;
    width: 10rem;
    padding: 0.6rem 1.2rem 0.6rem 0.5rem;
    text-align: right;
    border-radius: 0.3rem;
    margin: 3svh 1vw 1rem auto;
    font-size: 0.9rem;
    line-height: 1;
    font-family: 'Noto Sans JP', sans-serif;
}
#filtermenu[data-eventcategory] {
    background-color: #ddddec;
}
#filtermenu[data-eventcategory="all"] {
    background-color: #eeeeee;
}
#filtermenu summary {
    cursor: pointer;
}
/*フィルタあり時の見た目*/
#filtermenu[data-eventcategory] summary::before {
    position: absolute;
    display: inline-block;
    content: '';
    width: 1rem;
    height: 1rem;
    transform: scale(0.25) translate(-7rem,-1.2rem);
}
#filtermenu[data-eventcategory="gourmet"] summary::before {
    content: url("../img/icon/categoryicon/gourmet-categoryicon_blue.png");
}
#filtermenu[data-eventcategory="attraction"] summary::before {
    content: url("../img/icon/categoryicon/attraction-categoryicon_blue.png");
}
#filtermenu[data-eventcategory="exhibition"] summary::before {
    content: url("../img/icon/categoryicon/exhibition-categoryicon_blue.png");
}
#filtermenu[data-eventcategory="live"] summary::before {
    content: url("../img/icon/categoryicon/live-categoryicon_blue.png");
}
#filtermenu[data-eventcategory="others"] summary::before {
    content: url("../img/icon/categoryicon/others-categoryicon_blue.png");
}
/*フィルタなし時の見た目*/
#filtermenu[data-eventcategory="all"] summary::before {
    position: absolute;
    content: '';
    width: 3rem;
    border-top: solid 3px #17c0ef;
    top: 0.87rem;
    right: 5.3rem;
    transform: none;
}
#filtermenu[data-eventcategory="all"] summary::after {
    position: absolute;
    content: '';
    width: 1.5rem;
    border-top: solid 3px #17c0ef;
    top: 1.25rem;
    right: 5.3rem;
}
#filtermenu p {
    margin-right: 1.2rem;
    font-size: 1rem;
    cursor: pointer;
}
#filtermenu .categoryicon {
    position: absolute;
    width: 1.3rem;
    height: 1.3rem;
    transform: translate(0.2rem, 0);
}

/*---------------- アコーディオン ------------------*/
.eventdetails {
    position: relative;
    margin-bottom: 1rem;
    /*border-radius: 0.8rem;*/
    letter-spacing:0.2em;
    background-color: #eeeeee;
    font-family: 'koruri', serif;
}
.eventdetails.filtered {
    padding-top: 2.5rem;
}
.eventdetails::after {
    display: none;
}
/*------ アコーディオンのタイトル ------*/
.eventdetails summary {
    line-height: 0.8;
    padding: 0rem calc(2.3rem + 1vw) 0.8rem 1rem;
    cursor: pointer;
}
/* アコーディオン閉時 */
.eventdetails summary::before {
	position: absolute;
	content: '';
	width: 0.8rem;
	height: 0.8rem;
	border-top: solid 4px #666;
	border-right: solid 4px #666;
    right: 2rem;
	transform: rotate(135deg);
    margin-top: 2.5rem;
}

/* アコーディオン開時 */
.eventdetails[open] {
	background: linear-gradient(0.5turn,#eeeeee 4rem,#f8f8f8 8rem);
    padding-bottom: 0.7rem;
}
.eventdetails[open] summary {
    padding-bottom: 0.1rem;
}
.eventdetails[open] summary::before {
	transform: rotate(-45deg);
}

/*左上の色*/
.eventdetails::before {
    position: absolute;
    content: '';
    width: calc(4vmax + 2rem);
    height: calc(1.5vmax + 0.8rem);
    left: 3rem;
    margin-top: -0.5px;
    pointer-events: none;
}
#normalbuildingdetails::before {
    background-color: #7375f5;
}
#specialbuildingdetails::before {
    background-color: #d270df;
}
#blacksquaredetails::before {
    background-color: #555555;
}
#oldmainbuildingdetails::before {
    background-color: #ffd700;
}
#redsquaredetails::before {
    background-color: #cd0000;
}
#gymdetails::before {
    background-color: #07ce77;
}
#arenadetails::before {
    background-color: #aaaaaa;
}
#radiodetails::before {
    background-color: #033586;
}
.eventdetails.filtered::before {
    transform: translate(0, -2.5rem);
}
.eventdetails.filtered::after {
    position: absolute;
    display: inline-block;
    color: #17c0ef;
    font-size: 1.2rem;
    font-weight: 600;
    left: 10rem;
    top: 0.2rem;
}
#normalbuildingdetails::after {
    content: '普通教室棟';
}
#specialbuildingdetails::after {
        content: '特別教室棟';
}
#blacksquaredetails::after {
    content: '黒の広場';
}
#oldmainbuildingdetails::after {
    content: '旧本館';
}
#redsquaredetails::after {
    content: '赤の広場';
}
#gymdetails::after {
    content: '体育館';
}
#arenadetails::after {
    content: 'アリーナ';
}
#radiodetails::after {
    content: '一高祭まなべるラジオ';
}

/*---- /アコーディオンのタイトル -----*/

/*--- 各企画(アコーディオンのコンテンツ) ----*/
.eventcontent {
    position: relative;
    margin: 0.1rem 1rem 0.3rem calc(1rem + 1vw);
    padding: 0.1rem 1rem 0.1rem calc(3.5rem + 2.2vw);
    border-radius: 0.5rem;
    font-size: 1.2rem;
    line-height: 1;
    font-weight: 600;
    transition: 0.2s;
}
.eventcontent:hover,
.eventcontent:focus {
    background-color: #1e90ff;
}
/*アイコン*/
.eventcontent .icon {
    position: absolute;
    width: 3.5rem;
    height: 3.5rem;
    margin-top: 0.3rem;
    left: calc(0.1rem + 1vw);
    border-radius: 100%;
}
/*企画の番号*/
.eventcontent .exhibitnum {
    display: inline-block;
    color: #17c0ef;
    font-size: 1.1rem;
    margin-left: 1.8rem;
    margin-bottom: 0rem;
    font-family: 'koruri', serif;
}
/*企画の出展者*/
.eventcontent .exhibitername {
    display: inline-block;
    font-size: 0.9rem;
    margin-left: 0.3rem;
    margin-bottom: 0rem;
    font-family: 'koruri', sans-serif;
}
/*企画の場所*/
.eventcontent .exhibitplace {
    display: inline-block;
    font-size: 0.9rem;
    margin-top: 0rem;
    margin-left: 0.9rem;
    margin-bottom: 0.5rem;
    font-weight: 500;
    font-family: 'koruri', sans-serif;
}
/*企画名*/
.eventcontent .eventname {
    margin-top: 0.8rem;
}

/*---- 企画ポップアップ ----*/
/*アイコン*/
.eventpopup .icon {
    width: 3.5rem;
    height: 3.5rem;
    margin-top: 0.3rem;
    border-radius: 100%;
    user-select: none;
}
/*時間(ステージ企画)*/
.stagepopup .performancetime {
    font-size: 0.9rem;
    margin-bottom: 0rem;
    font-family: 'koruri', sans-serif;
}
/*企画の番号*/
.eventpopup .exhibitnum {
    color: #17c0ef;
    font-size: 1.1rem;
    margin: 0.5rem 0 0 2.2rem;
    font-family: 'koruri', serif;
}
/*団体名*/
.eventpopup .exhibitername {
    font-size: 0.9rem;
    margin: 0.2rem 0 0 1rem;
    font-family: 'koruri', sans-serif;
}
/*団体名(ステージ企画)*/
.stagepopup .performername {
    font-size: 0.9rem;
    margin-top: 0.2rem;
    margin-bottom: 0;
    font-family: 'koruri', sans-serif;
}
/*場所*/
.eventpopup .exhibitplace {
    font-size: 0.9rem;
    margin: 0 0 0.5rem 1rem;
    font-family: 'koruri', sans-serif;
}
/*イベント名*/
.eventpopup .eventname,
.stagepopup .eventname {
    margin-top: 0.8rem;
    line-height: 1.2rem;
}
/*カテゴリアイコンコンテナ*/
.eventdetails summary .categoryiconcontainer {
    margin: 0rem 0rem -0.5rem calc(4vmax + 5rem);
    padding-top: 0.3rem;
}
/*----- /企画ポップアップ ------*/

/*カテゴリアイコン*/
.categoryicon {
    width: 1.3rem;
    height: 1.3rem;
    margin-right: 0.4rem;
}

/*---- 企画アコーディオンのカテゴリアイコン -----*/
.eventcontentwrapper[data-eventcategory] .eventcontent .exhibitnum::before {
    position: absolute;
    display: inline-block;
    width: 1rem;
    height: 1rem;
    transform: scale(0.25) translate(-8rem,-1.2rem);
}
.eventcontentwrapper[data-eventcategory="gourmet"] .eventcontent .exhibitnum::before {
    content: url("../img/icon/categoryicon/gourmet-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="attraction"] .eventcontent .exhibitnum::before {
    content: url("../img/icon/categoryicon/attraction-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="exhibition"] .eventcontent .exhibitnum::before {
    content: url("../img/icon/categoryicon/exhibition-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="live"] .eventcontent .exhibitnum::before {
    content: url("../img/icon/categoryicon/live-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="others"] .eventcontent .exhibitnum::before {
    content: url("../img/icon/categoryicon/others-categoryicon_blue.png");
}
/*---- /企画アコーディオンのカテゴリアイコン -----*/

/*---- 企画ポップアップのカテゴリアイコン -----*/
.eventcontentwrapper[data-eventcategory] .eventpopup .exhibitnum::before {
    position: absolute;
    display: inline-block;
    width: 1.6rem;
    height: 1.6rem;
    transform: scale(0.3) translate(-7.5rem,-1.5rem);
}
.eventcontentwrapper[data-eventcategory="gourmet"] .eventpopup .exhibitnum::before {
    content: url("../img/icon/categoryicon/gourmet-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="attraction"] .eventpopup .exhibitnum::before {
    content: url("../img/icon/categoryicon/attraction-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="exhibition"] .eventpopup .exhibitnum::before {
    content: url("../img/icon/categoryicon/exhibition-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="live"] .eventpopup .exhibitnum::before {
    content: url("../img/icon/categoryicon/live-categoryicon_blue.png");
}
.eventcontentwrapper[data-eventcategory="others"] .eventpopup .exhibitnum::before {
    content: url("../img/icon/categoryicon/others-categoryicon_blue.png");
}
/*---- /企画ポップアップのカテゴリアイコン -----*/


/*--- 各企画の詳細(ポップアップ) ---*/
/*企画の詳細*/
.popup-window {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 83%;
	max-width: 400px;
	height: 70vh;
    max-height: 500px;
    padding: 1.5rem;
	border-radius: 0.6rem;
	align-items: center;
	transform: translate(-50%, -50%);
    user-select: text;
}
/*企画詳細の✕マーク*/
.popup-closebutton {
	top: 12px;
	right: 12px;
    font-size: 1.4rem;
    color: #00001e;
}
/*企画詳細内のボタン*/
.eventpopup-button {
    width: 10rem;
    height: 2.5rem;
    padding-top: 1rem;
    margin-left: 1vw;
    margin-right: 1vw;
    
    color: #eeeeee;
    background-color: #17c0ef;
    font-weight: 400;
    font-size: 0.9rem;
    text-align: center;
    display: inline-block;

    border-radius: 10px;
    border: solid;
    border-color: #17c0ef;
    border-width: 0.1vw;

    letter-spacing: 0.1em;
}
.eventpopup-button:hover{
    color:#161616;
    background: linear-gradient(0.25turn, #1e90ff, #6bb5ff);
    transition-duration:0.4s;
}
.eventpopup-button:not(:hover){
    color: #eeeeee;
    background-color: #1e90ff;
    transition-duration:0.4s;
}
.eventpopup-button-div {
    display: flex;
    justify-content: center;
    user-select: none;
}
/*--- /各企画の詳細(ポップアップ) ---*/
/*--- /各企画(アコーディオンのコンテンツ) ----*/

/*--- 各ステージ企画(アコーディオンのコンテンツ) ---*/
.stagecontentwrapper {
    margin: 0.2rem 1rem 0.3rem calc(1rem + 1vw);
    padding: 0.5rem 1rem 1rem 1rem;
    border-radius: 0.5rem;
}
/*ヘッダー(n日目など)*/
.stagecontentheading {
    margin-bottom: 0.8rem;
    font-size: 1.2rem;
    font-weight: 600;
}
/*企画概要*/
.stagecontent {
    position: relative;
    border-top: solid 2px rgb(168, 168, 168);
    padding-top: 0.5rem;
    padding-bottom: 0.7rem;
    padding-left: calc(4rem + 3vw);
    font-size: 1.4rem;
    line-height: 1;
    font-weight: 600;
    transition: 0.2s;
}
.stagecontent:hover,
.stagecontent:focus {
    background-color: #1e90ff;
}
/*企画の時間*/
.stagecontent .performancetime {
    position: absolute;
    overflow-wrap: normal;
    width: calc(3rem + 2vw);
    left: 0.5rem;
    font-size: 0.9rem;
    font-family: 'Noto Sans JP', sans-serif;
}
/*企画名*/
.stagecontent .eventname {
    margin-top: 0.5rem;
    margin-bottom: 1rem;
}


/*---------------- /アコーディオン ------------------*/

@media screen and (orientation:landscape){
    h2{
        margin-left: calc((1vw + 1svh)*2);
        font-size: calc(1vw + 1svh);
    }
    #filtermenu {
        font-size: 1rem;
    }
    #filtermenu[data-eventcategory="all"] summary::before {
        right: 5.5rem;
    }
    #filtermenu[data-eventcategory="all"] summary::after {
        right: 5.5rem;
    }
    .eventcontent {
        font-size: 1.3rem;
    }
}
/*
@media screen and (min-width:600px){
    .menu1{
        display:none;
    }
    #maincontainer{
        width:50vw;
    }
    }
*/






















































