@charset "utf-8";

/* =============================================
				初期・装飾
============================================= */
/*----------------
	　全体装飾
----------------*/
.nenga2026{	color: #231000; overflow: hidden;}
.nenga2026 a{ text-decoration: none; }
@media (min-width: 0em) and (max-width: 47.99em){
	.bo-m-breadcrumb {
		display: none;
	}
}


/*----------------
	　　画像
----------------*/
.nenga2026 img{ width: 100%; vertical-align: bottom; }

/*----------------
	　PC/SP
----------------*/
.nenga2026 .pcOnly{	display: block;	}
.nenga2026 .spOnly{	display: none; }

/*----------------
	　margin
----------------*/
.nenga2026 .margin01{ margin-bottom: 50px; }


/* =============================================
				　　flex
============================================= */
.nenga2026 .flex{
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
}
.nenga2026 .flex_C{
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
	-webkit-align-items: center;
	-moz-align-items: center;
	align-items: center;
}
.nenga2026 .flex_S{
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
	-webkit-align-items: stretch;
	-moz-align-items: stretch;
	align-items: stretch;
}
.nenga2026 .flex_jc{
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-align-items: center;
	-moz-align-items: center;
	align-items: center;
	-webkit-justify-content: center;
	-moz-justify-content: center;
	justify-content: center;
}
.nenga2026 .flex_jcsb{
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-align-items: center;
	-moz-align-items: center;
	align-items: center;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	justify-content: space-between;
}
.nenga2026 .flex_wrap{
	display: -webkit-flex;
	display: -moz-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-align-items: center;
	-moz-align-items: center;
	align-items: center;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.nenga2026 .flex_jcsb{
		display: block;
	}
}


/* =============================================
				　　　見出し
============================================= */
/*----------------
	　　h1
----------------*/
.nenga2026 h1{
	text-align: center;
}
.nenga2026 h1 img{
	width: 100%;
	max-width: 563px;
}
@media (min-width: 0em) and (max-width: 68.74em) {
	.nenga2026 h1 img{
		width: 53%;
	}
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.nenga2026 h1 img{
		width: 80%;
		padding: 0;
	}
}

/*----------------
	　　h2
----------------*/
.bo-m-hero__title+* {
    margin-top: 0px;
}
.article .articleTitle{
	text-align: center;
	background:url(/uploads/nenga2026/nenga2026_bg01.jpg) no-repeat center center / cover;
}
.article .articleTitle .article_icon{
	max-width: 60px;
	display: inline-block;
	margin: 80px 0 30px;
}
.article .articleTitle .bo-m-hero__title{
	font-size: clamp(22px, 5.4vw, 60px);
	font-weight: 700;
	padding: 0 0 50px;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.article .articleTitle .article_icon{
		max-width: 40px;
		margin: 10% 0 4%;
	}
	.article .articleTitle .bo-m-hero__title{
        padding: 0 15px 7%;
	}
}
@media screen and (max-width: 375px) {
    .article .articleTitle .article_icon {
       	margin: 40px 0 15px;
    }
}



/*----------------
	　　h3
----------------*/
.article .articleBox h3{
	font-family: "Noto Serif JP","游明朝",YuMincho,"ヒラギノ明朝 ProN W3","Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝","ＭＳ 明朝",serif;
	font-size: clamp(20px, 3.45vw, 38px);
    font-weight: 700;
    line-height: 1.5;
	color: #fff;
	background: url(/uploads/nenga2026/nenga2026_bg09.png) repeat center center / 100%;
	text-align: center;
	position: relative;
}
.article .articleBox h3 span{
	padding: 12px 0;
	display: block;
	background-image: url(/uploads/nenga2026/nenga2026_bg12.png), url(/uploads/nenga2026/nenga2026_bg13.png);
    background-repeat: no-repeat, no-repeat;
    background-position: top 0px left, top 0px right;
    background-size: 17% auto, 17% auto;
}
.article .articleBox h3::before{
	content: "";
    display: block;
    position: absolute;
    background: url(/uploads/nenga2026/nenga2026_ic07.png) no-repeat left center / 50% auto;
    top: 50%;
    left: -24px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 20%;
    height: 95px;
}
.article .articleBox h3::after{
	content: "";
    display: block;
    position: absolute;
    background: url(/uploads/nenga2026/nenga2026_ic08.png) no-repeat right center / 50% auto;
    top: 50%;
    right: -24px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 20%;
    height: 95px;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.article .articleBox h3::before {
		background: url(/uploads/nenga2026/nenga2026_ic07.png) no-repeat left center / 40% auto;
		left: -2%;
	}
	.article .articleBox h3::after{
		background: url(/uploads/nenga2026/nenga2026_ic08.png) no-repeat right center / 40% auto;
		right: -2%;
	}
	.article .articleBox h3 span{
		padding: 12px 8%;
		background-size: 13% auto, 13% auto;
	}
}
@media screen and (max-width: 375px) {
	.article .articleBox h3 .spOnly{
		display: block;
	}
	.article .articleBox h3 span{
		background-size: 15% auto, 15% auto;
	}
	.article .articleBox h3::before{
		width: 30%;
	}
	.article .articleBox h3::after{
		width: 30%;
	}	
}

/*----------------
	　　h4
----------------*/
.areaBox h4{
	color: #cc434c;
	font-size: clamp(16px, 2.1vw, 22px);
	font-weight: 700;
	text-align: center;
	line-height: 1.3;
}
.howto .areaBox h4{
	text-align: left;
	margin-bottom: 20px;
}


/* =============================================
				メインビジュアル
============================================= */
.mainVisual{
	background-color: #231000;
}
.mainVisual .MVarea {
	width: 100%;
	max-width: 1920px;
	margin: 0 auto;
    background: url(/uploads/nenga2026/nenga2026_bg08.png) #f5eee9 no-repeat center center / cover;
    position: relative;
}
.mainVisual .MVarea::before{
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: -80px;
    width: 28%;
    height: 363px;
    background: url(/uploads/nenga2026/nenga2026_bg05.png) no-repeat top left / 100%;
    z-index: 2;
}
.mainVisual .MVarea::after{
    content: "";
    display: block;
    position: absolute;
    bottom: -50px;
    right: -50px;
    width: 16%;
    height: 311px;
    background: url(/uploads/nenga2026/nenga2026_bg06.png) no-repeat bottom right / 100%;
    z-index: 2;
}
.mainVisual .MVbg01{
	width: 100%;
    max-width: 1164px;
	margin: 0 auto;
	background-image: url(/uploads/nenga2026/nenga2026_bg01.png), url(/uploads/nenga2026/nenga2026_bg02.png);
    background-repeat: no-repeat, no-repeat;
    background-position: top 30px left, top 30px right;
    background-size: 27% auto, 27% auto;
    padding-bottom: 30px;
}
.mainVisual .MVbg02{
    background-image: url(/uploads/nenga2026/nenga2026_bg03.png), url(/uploads/nenga2026/nenga2026_bg04.png);
    background-repeat: no-repeat, no-repeat;
    background-position: bottom 20px left, bottom 20px right;
    background-size: 26.5% auto, 26.5% auto;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.mainVisual .MVbg01{
		padding-bottom: 4%;
	}
}

/* =============================================
				　リード
============================================= */
.lead{
	text-align: center;
	font-size:  clamp(14px, 2.18vw, 22px);
    font-weight: 700;
    color: #fff;
	padding: 30px 0;
	background: url(/uploads/nenga2026/nenga2026_bg09.png) repeat center center / 100%;
	z-index: 3;
    position: relative;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.lead{
		padding: 4% 0;
		background: url(/uploads/nenga2026/nenga2026_bg09.png) repeat center center / 200%;
	}
}
@media screen and (max-width: 375px) {
	.lead .spOnly{
		display: block;
	}
}

/* =============================================
				　　　目次
============================================= */
/*----------------
	　　全体
----------------*/
.toc{
	background: url(/uploads/nenga2025/nenga2025_bg05.png) repeat center center / 380px auto;
}
.tocbg{
	background-image: url(/uploads/nenga2025/nenga2025_bg07.png), url(/uploads/nenga2025/nenga2025_bg06.png);
    background-repeat: no-repeat, no-repeat;
    background-position: top left, bottom right;
    background-size: 40% auto, 40% auto;
	padding: 80px 0;
}
.tocContents{
	max-width: 980px;
    width: 100%;
    margin: 0 auto;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.tocbg{
		background-size: 70% auto, 70% auto;
		padding: 10% 0;
	}
}
@media screen and (max-width: 375px) {
	.tocbg{
		padding: 40px 0;
	}
}

/*----------------
	目次の見出し
----------------*/
.tocContents .heading{
	width: 100%;
	display: block;
    text-align: center;
    padding: 0px 15px 15px;
	margin-bottom: 15px;
	position: relative;
}
.tocContents .heading:after{
    content: "";
    display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	background-image: url(/uploads/nenga2026/nenga2026_bg10.png);
    background-repeat: repeat-x;
    background-position: bottom;
	width: 100%;
	height: 10px;
}
.tocContents .heading a{
	display: inline-block;
	font-size: clamp(16px, 3vw, 22px);
	font-weight: 700;
	padding-right: 25px;
	line-height: 1.4;
	position: relative;
	color: #231000;
	text-decoration: none;
	transition: .25s ease 0s;
}
.tocContents .heading a::after{
    content: "";
    display: block;
    position: absolute;
    background: url(/uploads/nenga2026/nenga2026_ic03.png) no-repeat right center / 14px 16px;
    top: 50%;
    right: 0px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 100%;
    height: 16px;
}
.tocContents .heading a:hover{
	opacity: 0.7;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.tocContents .heading a{
		padding-right: 18px;
	}
	.tocContents .heading a::after{
		background: url(/uploads/nenga2026/nenga2026_ic03.png) no-repeat right center / 11px 13px;
		top: 55%;
		height: 13px;
	}
}

/*----------------
	目次のボタン
----------------*/
.tocContents ul li a{
	width: 100%;
	line-height: 1.5;
	display: block;
	color: #231000;
	font-size: 16px;
	border: 1px solid #231000;
	background-color: #fff;
	border-radius: 4px;
	padding: 15px 20px 15px 10px;
	text-align: center;
	position: relative;
	text-decoration: none;
	box-shadow: 0px 2px 8px 0px rgba(52, 0, 0, 0.1);
	transition: .25s ease 0s;
}
.tocContents ul li a:hover{
	transform: translateY(-5px);
}
.tocContents ul li a::after{
    content: "";
    display: block;
    position: absolute;
    background: url(/uploads/nenga2026/nenga2026_ic04.png) no-repeat center center / 16px 17px;
    top: 50%;
    right: 5%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 16px;
    height: 17px;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.tocContents ul li a{
		padding: 10px 20px 10px 10px;
	}
}
@media screen and (max-width: 375px) {
	.tocContents ul li a{
		padding: 8px 20px 8px 10px;
	}
}

/*----------------
　「人気」アイコン
----------------*/
.tocContents ul li .flag:before{
    content: "";
    display: block;
    position: absolute;
    background: url(/uploads/nenga2026/nenga2026_ic05.png) no-repeat left top / 36px 33px;
    top: -10px;
    left: -10px;
    width: 36px;
    height: 33px;
}

/*----------------
　 tocBox01(4列)
----------------*/
.tocContents .tocBox01{
	width: 100%;
}
.tocContents .tocBox01 + .tocBox01{
	margin-top: 30px;
}
.tocContents .tocBox01 ul{ 
	width: 100%;
	display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
}
@media (min-width: 0em) and (max-width: 68.74em) {
    .tocContents .tocBox01 ul {
		grid-template-columns: repeat(3, 1fr);
    }
}
@media (min-width: 0em) and (max-width: 47.99em) {
    .tocContents .tocBox01 ul {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media screen and (max-width: 600px) {
    .tocContents .tocBox01 ul {
        grid-template-columns: repeat(1, 1fr);
		gap: 4px;
    }
}

/*----------------------------
　 tocBox03,tocBox04(2列)
----------------------------*/
.tocContents .tocBox03,
.tocContents .tocBox04{
	width: 50%;
}
.tocContents .tocBox04{
	margin-left: 1%;
}
.tocContents .tocBox03 ul,
.tocContents .tocBox04 ul{
	width: 100%;
	display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
@media (min-width: 0em) and (max-width: 68.74em) {
	.tocContents .tocBox03,
	.tocContents .tocBox04{
		width: 100%;
	}
	.tocContents .tocBox04{
		margin-left: 0%;
		margin-top: 30px;
	}
    .tocContents .tocBox01 ul {
		grid-template-columns: repeat(3, 1fr);
    }
	.tocContents .tocBox01.flex_C{
		display: block;
	}
}
@media (min-width: 0em) and (max-width: 47.99em) {
    .tocContents .tocBox01 ul {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media screen and (max-width: 600px) {
    .tocContents .tocBox01 ul {
        grid-template-columns: repeat(1, 1fr);
		gap: 4px;
    }
}


/* =============================================
			テンプレート（メインコンテンツ）
============================================= */
.mainContents{
	background: url(/uploads/nenga2026/nenga2026_bg11.png) repeat center center / 180px auto;
}
.mainContents .article .articleBox .area:first-of-type h3,
.mainContents .article .articleBox .area:first-of-type h3 span{
	border-radius: 8px 8px 0 0;
}
.mainContents .article .articleBox .area:last-of-type .areaBox{
	border-radius: 0 0 8px 8px;
}
.mainContents .article:nth-last-of-type(1){
	padding-bottom: 80px;
}
.article .articleBox {
	box-shadow: 0px 4px 13px 2px rgba(52, 0, 0, 0.3);
}
.article .articleBox .areaBox{
	padding: 4.5% 6.3%;
	background-color: #fff;
	width: 100%;
}
.article .articleBox .areaBox figure{
	max-width: 49.7%;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.mainContents{
		background: url(/uploads/nenga2026/nenga2026_bg11.png) repeat center center / 20% auto;
	}
	.mainContents .article:nth-last-of-type(1){
		padding-bottom: 10%;
	}
	.article .articleBox {
		box-shadow: 0px 2px 12px 1px rgba(52, 0, 0, 0.3);
	}
	.article .articleBox .areaBox figure{
		max-width: 100%;
	}
}


/*----------------
　  オレンジボタン
----------------*/
.article .articleBox .areaBox .btnArea{
    width: 44%;
}
.article .articleBox .areaBox .btnArea .bo-m-button{
    padding: 10px 24px;
    max-width: 436px;
	width: 100%;
    font-size: clamp(18px, 2.6vw, 26px);
    background: #e33f16;
    border: 2px solid #e33f16;
	border-radius: 8px;
	margin: 15px 0;
}
.article .articleBox .areaBox .btnArea .bo-m-button:hover{
    background: #fff;
	color: #e33f16;
}
.article .articleBox .areaBox .btnArea .bo-m-button.icon-arrow:after{
	color: #fff;
	height: 16px;
    font-size: 16px;
}
.article .articleBox .areaBox .btnArea .bo-m-button.icon-arrow:hover:after{
	color: #e33f16;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.article .articleBox .areaBox .btnArea .bo-m-button{
		padding: 6px 24px;
		margin: 10px 0;
		max-width: none;
	}
	.article .articleBox .areaBox .btnArea{
		width: 100%;
		margin-top: 40px;
	}
	.article .articleBox .areaBox .btnArea .bo-m-button.icon-arrow:after{
		height: 12px;
		font-size: 12px;
	}
}


/* =============================================
			　　　年賀状の書き方
============================================= */
.article .howto ul li + li{
	margin-top: 15px;
}
.article .howto ul{
	list-style: disc;
    margin-left: 20px;
}
.article .howto ul dt{
	width: 55%;
}
.article .howto ul dd{
	width: 41%;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.article .howto ul dt{
		width: 100%;
		margin-bottom: 10px;
	}
	.article .howto ul dd{
		width: 100%;
	}
}


/*----------------
　  　黒ボタン
----------------*/
.article .howto .bo-m-button{
	margin: 0;
	width: 100%;
	max-width: 396px;
	border: 2px solid #231000;
	background-color: #231000;
	font-size: clamp(16px, 2.1vw, 18px);
	font-weight: 700;
	border-radius: 8px;
	padding: 10px 40px;
	color: #fff;
	text-decoration: none;
	position: relative;
}
.article .howto .bo-m-button:hover{
    background: #fff;
	color: #231000;
}
.article .howto .bo-m-button.icon-arrow:after {
    color: #fff;
}
.article .howto .bo-m-button.icon-arrow:hover:after{
	color: #231000;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.article .howto .bo-m-button{
		padding: 6px 10%;
		max-width: none;
	}
}


/*----------------
　  　　著者
----------------*/
.article .howto .author{
	width: 100%;
	margin-top: 50px;
}
.article .howto .author figure{
	max-width: 150px;
	margin-right: 3%;
}
.article .howto .author figure img{
	border: 1px solid #c5c0bb;
}
.article .howto .author .author_text{
	width: 100%;
}
.article .howto .author .author_text dl dt span a{
	display: inline-block;
	color: #231000;
	font-size: clamp(18px, 2.2vw, 22px);
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	padding-bottom: 3px;
	margin-bottom: 5px;
    background-image: linear-gradient(#231000, #231000);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 0 1px;
    transition: background-size .25s ease 0s;
}
.article .howto .author .author_text dl dt span a[target="_blank"]::after {
    margin-left: 8px;
    color: #231000;
	font-size: 14px;
    vertical-align: super;
}
.article .howto .author .author_text dl dt span a:hover {
    background-position: bottom left;
    background-size: 100% 1px;
}
.article .howto .author .author_text dl dt span:nth-of-type(2){
	display: block;
	font-weight: 700;
	line-height: 1.3;
	padding-bottom: 2.5%;
	border-bottom: 1px solid #231000;
}
.article .howto .author .author_text dl dd{
	padding-top: 2.5%;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.article .howto .author figure{
		width: 36%;
	}
}
@media screen and (max-width: 425px) {
	.article .howto .author.flex{
		display: block;
	}
	.article .howto .author figure{
		width: 100%;
		margin: 0 auto;
	}
	.article .howto .author .author_text dl dt{
		text-align: center;
		margin-top: 10px;
	}
}

/* =============================================
			　　　　追従ボタン
============================================= */
.nenga2026 .categoryBtn {
    position: fixed;
    bottom: -35px;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 4;
	display: none;
}
.nenga2026 .categoryBtn .bo-m-button{
	background: #e33f16;
    border: 6px solid #e33f16;
    width: 500px;
    margin: 10px 0;
    font-size: 24px;
	padding: 13px 32px 14px 14px;
	border-radius: 8px;
}
.nenga2026 .categoryBtn .bo-m-button.icon-arrow:after{
	color: #fff;
	height: 16px;
    font-size: 18px;
}
.nenga2026 .categoryBtn .bo-m-button:hover{
	background: #fff;
	color: #e33f16;
}
.nenga2026 .categoryBtn .bo-m-button.icon-arrow:hover:after{
	color: #e33f16;
}
/*footerまでスクロールしたら消す*/
.nenga2026 .is-hidden {
	visibility: hidden;
	opacity: 0;
	-webkit-transition: 0.3s;
	-ms-transition: 0.3s;
	transition: 0.3s;
}
@media (min-width: 0em) and (max-width: 47.99em) {
	.nenga2026 .categoryBtn{
		width: 100%;
		display: block;
	}
	.nenga2026 .categoryBtn .bo-m-button {
        border: 3px solid #e33f16;
		border-radius: 0px;
        width: 100%;
        margin: 10px 0 0;
        font-size: clamp(16px, 2.4vw, 18px);
    }
	.nenga2026 .categoryBtn .bo-m-button.icon-arrow:after{
		height: 12px;
		font-size: 12px;
	}
	.bo-g-footer-pageTop{
		bottom: 14px;
	}
}