/* IMPORT RESET ================================================== */
@import url("sanitize.css");

/* WEB FONT ====================================================== */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.0/css/all.min.css");

/* 変数設定 ======================================================== */

/*共通のサイズや色を変数で設定
　変数を使う時は数値で入れる箇所を var(--red) のように記載*/
:root{
	/*文字サイズ*/
	--x-small:0.8rem;/*50%*/
	--small:1.2rem;/*75%*/
	--medium:1.6rem;/*100%*/
	--large:2rem;/*125%*/
	--x-large:2.4rem;/*150%*/
	/*色*/
	--red:#c00;
	--blue:#039;
	--mallcolor:#b60081;
}

/* STYLES ======================================================== */

/* ルートのフォントサイズを10pxに設定（1rem=10px）*/
html {
  font-size: 62.5%;
}

/* bodyのフォントサイズを16pxに設定 */
body {
  font-size: 1.6rem;
}

/* MEMO ++++++++++++++++++++++++++++++++
  フォントサイズはremで指定すること
  例）10pxは1rem、12pxは1.2rem
+++++++++++++++++++++++++++++++++++++ */

.font-xs{
  font-size: var(--x-small);
}

.font-s{
  font-size: var(--small);
}

.font-m{
  font-size: var(--medium);
}

.font-l{
  font-size: var(--large);
}

.font-xl{
  font-size: var(--x-large);
}

/*文字色*/
.font-red{
  color: var(--red);
}

.font-blue{
  color: var(--blue);
}

.font-mcolor{
  color: var(--mallcolor);
}


*{
  box-sizing: border-box;
}

body {
  font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  margin: 0;
  padding: 0;
  background: linear-gradient(#fff 0.5% ,#9c4b98 10% ,#cf76ac 20% ,#9c4b98 45% , #fed15c 55%,#fef59a 70% ,#fed15c 85%, #9c4b98 95%);
}

/*下記marginやpadding、widthはサイトデザインに合わせて調整*/

main{
  margin: 0;
  padding: 0;
	
	section{
  	margin: 0 auto;
  	max-width: 960px;
		
		p{
			margin: 0;
		}
	}
}


/*画像は基本的に横幅100%表示、高さは横幅に合わせて自動調整
  小さい画像を使用する際は個別にmax-widthを設定する*/
img {
	width: 100%;
  height: auto;
  vertical-align: bottom;
  image-rendering: -webkit-optimize-contrast;　/*Chromeで画像がぼやけるのを防止*/
}

/*Flexbox ────────────────────────────────────────────────────────────
　子要素の間隔はgapで指定。
*/
.flexbox{
  display: flex;
  flex-wrap: wrap;
	
	/*子要素に枠線。デザイン的に不要なら削除*/
	div{
	  border: 1px solid #ccc;
		padding: 5px;
	}
}

/*PC・スマホ共に2分割　※flexboxと一緒に設定*/
.box2{
	--spacing: 10px; /*子要素の間隔*/
	
	gap: var(--spacing);
	
	div,
	p{
		width: calc( ( 100% - var(--spacing) ) / 2 ); 
	}
}

/*PC2列、スマホ1列　※flexboxと一緒に設定*/
.box2-1{
	--spacing: 10px; /*子要素の間隔*/
	
	gap: var(--spacing);
	
	div,
	p{
		width: 100%;
	}
	
	@media (min-width: 768px){
		/*PCのみ適用*/
  	div,
 		p{
    	width: calc( ( 100% - var(--spacing)) / 2 ); 
  	}
	}
}

/*PC3列、スマホ1列　※flexboxと一緒に設定*/
.box3-1{
	--spacing: 10px; /*子要素の間隔*/
	
	gap: var(--spacing);
	
	div,
	p{
  	width: 100%;
	}
	
	@media (min-width: 768px){
		div,
		p{
    	width: calc( ( 100% - var(--spacing) * 2 ) / 3 ); 
  	}
	}
}


/*PC3列、スマホ2列　※flexboxと一緒に設定*/
.box3-2{
	--spacing: 10px; /*子要素の間隔*/
	
	gap: var(--spacing);
	
	div,
	p{
  	width: calc( ( 100% - var(--spacing) ) / 2 ); 
	}
	
	@media (min-width: 768px){
	/*PCのみ適用*/
		div,
		p{
   		width: calc( ( 100% - var(--spacing) * 2 ) / 3 ); 
  	}
	}
}

/*PC4列、スマホ2列　※flexboxと一緒に設定*/
.box4-2{
	--spacing: 10px; /*子要素の間隔*/
	
	gap: var(--spacing);
	
	div,
	p{
  	width: calc( ( 100% - var(--spacing) ) / 2 ); 
	}
	
	@media (min-width: 768px){
	/*PCのみ適用*/
		div,
		p{
			width: calc( ( 100% - var(--spacing) * 3 ) / 4 ); 
		}
	}
}

/*ページトップスクロール ──────────────────────────────────────────────────*/
#page-top {
	position: fixed;
	right: 10px;
	bottom: 10px;
	z-index: 10;
}

.topbtn{
	display: block;
	background: linear-gradient(#dc9600, #994593);
	color: #fff;
	width: 50px;
	height: 50px;
	text-align: center;
	box-shadow: 0 4px 8px rgba(0,0,0,0.2),
	            0 2px 4px rgba(0,0,0,0.1);/*ボタンの背景色に合わせる*/
	border: 2px solid #fff;
	text-decoration: none;
	
	/*マウスオーバーした時*/
	@media (hover: hover) {
		/* hover指定できるPCを想定したスタイル */
		&:hover {
			background: #333;
			box-shadow: 0 0 0 3px #333;/*ボタンの背景色に合わせる*/
		}
	}
	@media (hover: none) {
		/* hoverが使えないタッチ端末を想定した装飾 */
		&:active {
			background: #333;
			box-shadow: 0 0 0 3px #333;/*ボタンの背景色に合わせる*/
		}
	}
	
	i {
		padding-top: 5px;
		font-size: var(--large);
		display: block;
	}
	span {
		display: block;
		font-size: var(--small);
		margin-top: -2px;
	}
}

/* ▲ページトップスクロールここまで▲ */

/* スマホなど幅が足りなくなったらspanで囲った単位で強制改行
   spanで囲まれている文章は自動改行がされなくなるので要注意*/
.spBr span{
  display: inline-block;
  white-space: nowrap;
}