@charset "UTF-8";


html {
    font-size: 62.5%; /* rem単位でのフォントサイズ計算を容易にするため(フォントサイズを10pxで揃える)。 62.5％=10pxなので、×10で計算できる */
    line-height: 1.5;/*行間16×1.5＝24px*/
    box-sizing: border-box;
    font-family: "RocknRoll One", sans-serif;
    font-weight: 50;
    font-style: normal;
    margin-top: 0 !important;
}

body{
    background-color: rgb(247, 216, 114);
}

/* 画像が荒くならないように対策 */
img {
    max-width: 100%;
    height: auto;
    object-fit: cover;
}

a:hover{
color: rgb(239, 104, 104);
}

.container{
    max-width: 768px;
    margin: 0 auto;
}

/*----------------------------------------
    frame
----------------------------------------*/
.frame { /* 白枠 */
    background-color: aliceblue;
    width: 100%;
    height: 100vh;
    display: flex; /* Flexbox を有効にする */
    justify-content: center; /* 水平方向の中央揃え */
    align-items: center; /* 垂直方向の中央揃え */
    z-index: 0;
}


.circle{/* メインの中身の背景にみえるところ*/
    background-color:rgb(255, 248, 209);
    width: 100%;
    height: 90vh;
    border-radius: 200px;
    z-index: 1;
    overflow-y: auto;
    max-width: 768px;
    margin: 0 auto;
}

.circle::-webkit-scrollbar {
    display: none; /* スクロールバーを完全に非表示にする */
}



/*----------------------------------------
    header
----------------------------------------*/
.header_morningassembly03 .header_rogo{
    position: absolute;
    color: #df2c2c;
    font-size: 2.8rem;
    z-index: 10;
    top: 18px;
    left: 18px;
}

nav ul{
    position: absolute;
    font-size: 1.6rem;
    font-weight: 600;
    top: 150px;
    left: 18px;
    color: #df2c2c;
}


nav li{
    padding: 4px;
}

@media (width < 1200px) {
    .nav_menu{
        display:  none;
    }
}



/*----------------------------------------
    hamburger
----------------------------------------*/

.hamburger{
    position: relative;
}

.menu_btn{
    position: fixed;
    width: 60px;
    height: 60px;
    top: 25px;
    right: 15px;
    z-index: 10;
    background-color: #df2c2c;
    border-radius: 50%;
    cursor: pointer;
}

.menu_btn span{
    width: 25px;
    height: 2px;
    background-color: antiquewhite;
    position: absolute;
    z-index: 2;
    left: 17px;
    transition: all 0.4s ease-in-out;
}

.menu_btn span:nth-of-type(1){
    top: 18px;
}
.menu_btn span:nth-of-type(2){
    top: 28px;
}
.menu_btn span:nth-of-type(3){
    top: 38px;
}

.menu_btn.is_active span:nth-of-type(1) {
	transform: translateY(10px) rotate(-45deg);

}

.menu_btn.is_active span:nth-of-type(2) {
	opacity: 0;
}

.menu_btn.is_active span:nth-of-type(3) {
	transform: translateY(-10px) rotate(45deg);

}

.menu {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 2;
	width: 100%;
	height: 100vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
    margin: 0 auto;
    background:  #df2c2c;
    color: antiquewhite;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 3;
}

.menu_item {
	width: 100%;
	height: auto;
	padding: 1em 1em;
	text-align: center;
	box-sizing: border-box;
    font-size: 1.6rem;
}

/* ★メニュー画面のアニメーション 画面外から画面外へ*/
.menu {
	transform: translatey(-200vh);/* 100vwはスクロールバーの上越えて画面いっぱいという意味なので-100VWは画面外に移動している */
	transition: all 0.4s ease-in-out;
}

.menu.is_active {
	transform: translatey(0);/* 画面を見えるところに */
}

@media (width > 1200px){
    .hamburger{
        display:  none;
    }
}

/*----------------------------------------
    ｋｖ
----------------------------------------*/

.kv_img{
    width: 50%;
    margin: 120px auto 60px auto;
}

@media (width > 768px){
    .kv_img{
    margin: 0 auto;
}
}


/*----------------------------------------
    〇✕△
----------------------------------------*/
.img_circle_wrap{
    position: absolute;
    width: 150px;
    top: 470px;
    left: 80px;
}

.img_Triangle_wrap{
    position: absolute;
    width: 180px;
    top: 180px;
    right: 10%;
}

.img_Bad_wrap{
    position: absolute;
    width: 80px;
    top: 480px;
    right: 70px;
}


    /* 第８回朝礼 */
.comment{
    position: absolute;
    top: 20px;
    right: 40px;
    display: inline-block;
    margin: 30px 0;
    padding: 0 5px;
    width: 250px;
    height: 80px;
    line-height: 80px;
    text-align: center;
    color: white;
    font-size: 2.5rem;
    background: #df2c2c;
    border-radius: 50px;
    box-sizing: border-box;
    transform: rotate(10deg);
}

/* 日付 */
.date{
    position: absolute;
    font-size: 1.8rem;
    bottom: 5px;
    right: 20px;
    color:  #df2c2c;
}


@media (width < 1200px) {
    .img_circle_wrap,
    .img_Triangle_wrap,
    .img_Bad_wrap,
    .comment{
        display:  none;
    }
}

/*----------------------------------------
    main
----------------------------------------*/
main{
    font-size: 1.6rem;
    line-height: 2;
    z-index: 1;
}

.scrollplease{ /* スクロールプリーズ */
    display: none;
}


.introduction{
    width: 100%;
    height: auto;
    padding: 30% 60px;
    background-color: #df2c2c;
    color: white;
    text-align: center;
}

.introduction p{
    text-align: start;
}

.svg {
    display: block; /* 余計なマージンを防ぐ */
    width: 100%;
    height: auto;
    flex-shrink: 0;
    margin-top: -8px; /* 上の要素とわずかに重なる */
    margin-bottom: -2px; /* 下の要素とわずかに重なる */
}

.parallax{
    padding: 20% 60px;
    background-color: rgb(255, 248, 209);
}

.implementation{
    width: 100%;
    height: auto;
    padding: 100px 60px 200px 60px;
    background-color: rgb(244, 240, 218);
    border-radius: 40%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.implementation_wrapper{
    padding: 100px 0;
}


.pros_cons{
    margin: 100px 0;
}

.pros_cons_wrap{
    text-align: start;
    padding-left: 30%;
}

.lastly{
    width: 100%;
    height: auto;
    background-color: #df2c2c;
    color: white;
    text-align: center;
    padding-bottom: 150px;
}

.lastly p{
    padding: 0 60px;
    text-align: start;
}

@media (width > 768px){
    .scrollplease{ /* スクロールプリーズ */
    width: 100%;
    margin: 70px auto 50px auto;
    font-size: 3rem;
    color: rgb(248, 191, 7);
    display: flex; /* Flexコンテナにする */
    justify-content: center; /* 子要素を水平方向に中央揃え */
    align-items: center; /* 子要素を垂直方向に中央揃え */
}
}

/*----------------------------------------
    footer
----------------------------------------*/
footer{
    background-color: #df2c2c;
    color: white;
    text-align: center;
    padding: 20px;
    z-index: 1;
    margin-top: -5px;
}


/*----------------------------------------
    タイトル装飾
----------------------------------------*/

/* ｈ2吹き出し */
.introduction .index {/* はじめに */
    position: relative;
    display: inline-block;
    margin: 30px 0;
    padding: 0 5px;
    width: 150px;
    height: 70px;
    line-height: 70px;
    text-align: center;
    color: #df2c2c;
    font-size: 1.8rem;
    background: white;
    border-radius: 50px;
    box-sizing: border-box;
}

.introduction .index::before {
    content: "";
    position: absolute;
    bottom: -18px;
    left: 50%;
    margin-left: -13px;
    border: 10px solid transparent;
    border-top: 10px solid white;
    z-index: 0;
}

/* ｈ2一文字目大きく */
.parallax h2{/* パパラックスとは */
    margin: 40px 0 10px 0;
    font-size: 1.6rem;
    border-bottom: solid 5px rgb(248, 191, 7);
    line-height: 1.5;
    /* display: inline-block; */
}

.parallax h2:first-letter {
    font-size: 2em;
    color: #df2c2c;
}

/* h2 丸*/
.implementation h2{/* 3種類の実装 */
    width: 150px;
    height: 150px;
    font-size: 1.8rem;
    color: white;
    background: #df2c2c;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    margin: 0 auto;
}
.implementation h2::after{
    content: "";
    position: absolute;
    top: 15%;
    left: 90%;
    width: 60px;
    height: 60px;
    background: #df2c2c;
    border-radius: 50%;
}

.implementation dt{
    margin-top: 60px;
    color: #df2c2c;
}

.implementation dd{
    margin: 20px 0;
}

/* h2 縦書き */
.pros_cons h2{
    writing-mode: vertical-rl; /* 縦書き 右から左へ */
    display: flex;
    flex-direction: column; /* 縦に並べる */
    text-align: start;/* 文字の頭をそろえる */
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: 1rem;
    margin: 80px auto 30px auto;
}

/* ｈ3  ボタン*/
.pros_cons_wrap h3 { /* メリット デメリット */
    display: inline-block;
    margin: 30px 0;
    padding: 0 5px;
    width: 120px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    color: #df2c2c;
    font-size: 1.6rem;
    background: white;
    border-radius: 50px;
    box-sizing: border-box;
}

.pros_cons_wrap li{
    position: relative;

}

.pros_cons_wrap li::before{
    position: absolute;
    content: ">";
    color: #df2c2c;
    left: -10px; /* 親要素の左端に配置 */
    transform: translatex(-50%);
}

.lastly h2{ /* 今後の課題 */
    position: relative;
    display: inline-block;
    margin: 100px 0 40px 0;
    padding: 0 5px;
    width: 250px;
    height: 70px;
    line-height: 70px;
    color: #df2c2c;
    font-size: 1.8rem;
    background: white;
    border-radius: 50px;
    box-sizing: border-box;
}

.lastly h2::after{
    content: "";
    position: absolute;
    bottom: -18px;
    left: 50%;
    margin-left: -13px;
    border: 10px solid transparent;
    border-top: 10px solid white;
    z-index: 0;
}
