/* CSS Document */

/*! destyle.css v3.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.min.css */
*,::before,::after{box-sizing:border-box;border-style:solid;border-width:0}html{line-height:1.15;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{margin:0}main{display:block}p,table,blockquote,address,pre,iframe,form,figure,dl{margin:0}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit;margin:0}ul,ol{margin:0;padding:0;list-style:none}dt{font-weight:700}dd{margin-left:0}hr{box-sizing:content-box;height:0;overflow:visible;border-top-width:1px;margin:0;clear:both;color:inherit}pre{font-family:monospace,monospace;font-size:inherit}address{font-style:inherit}a{background-color:transparent;text-decoration:none;color:inherit}abbr[title]{text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:inherit}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}svg,img,embed,object,iframe{vertical-align:bottom}button,input,optgroup,select,textarea{-webkit-appearance:none;appearance:none;vertical-align:middle;color:inherit;font:inherit;background:transparent;padding:0;margin:0;border-radius:0;text-align:inherit;text-transform:inherit}[type="checkbox"]{-webkit-appearance:checkbox;appearance:checkbox}[type="radio"]{-webkit-appearance:radio;appearance:radio}button,[type="button"],[type="reset"],[type="submit"]{cursor:pointer}button:disabled,[type="button"]:disabled,[type="reset"]:disabled,[type="submit"]:disabled{cursor:default}:-moz-focusring{outline:auto}select:disabled{opacity:inherit}option{padding:0}fieldset{margin:0;padding:0;min-width:0}legend{padding:0}progress{vertical-align:baseline}textarea{overflow:auto}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}label[for]{cursor:pointer}details{display:block}summary{display:list-item}[contenteditable]:focus{outline:auto}table{border-color:inherit}caption{text-align:left}td,th{vertical-align:top;padding:0}th{text-align:left;font-weight:700}

a{
	-webkit-touch-callout: none;
	-webkit-tap-highlight-color: transparent;
}

img{
	width: 100%;
	height: auto;
	vertical-align: top;
}

dt{
	font-weight: inherit;
}

input, 
select, 
textarea, 
button{
	border-radius: 0;
	font-family: inherit;
	font-size: 16px;
	line-height: inherit;
	box-sizing: border-box;
	appearance: none;
}

input, 
select, 
textarea{
	padding: 8px;
	background: #fff;
	border: 1px solid #ccc;
	line-height: inherit;
}

textarea{
	height: min(50vw, 10em);
}

label{
	&:has(:where(input[type="radio"],input[type="checkbox"])){
		display: grid;
		grid-template-columns: 1em 1fr;
		align-items: center;
		grid-gap: 8px;
	}
	&:has(input:not(:disabled)){
		cursor: pointer;
	}
}

input{
	&[type="checkbox"], 
	&[type="radio"]){
		all: unset;
		aspect-ratio: 1;
		background: #ccc url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0.5 12 12" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="1 7 4 10 11 3" /></svg>') center no-repeat;
		background-size: 60% auto;
		border: none;
		border-radius: 2px;
		&:checked{
			background-color: black;
		}
	}
	&[type="checkbox"]{
		background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0.5 12 12" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="1 7 4 10 11 3" /></svg>');
		border-radius: 2px;
	}
	&[type="radio"]{
		background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 12 12" fill="none" stroke="white" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="6" cy="6" r="4" /></svg>');
		border-radius: 100%;
	}
}

select{
	padding-right: 2em;
	background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><polygon fill="%23ccc" points="0,0 16,0 8,16"></polygon></svg>');
	background-position: calc(100% - 0.75em) center;
	background-repeat: no-repeat;
	background-size: 0.5em;
}

textarea{
	resize: vertical;
}

button{
	display: grid;
	align-items: center;
	min-height: 48px;
	padding: 8px 16px;
	background: #000;
	color: #fff;
	text-align: center;
	&:hover{
		cursor: pointer;
	}
	&::-moz-focus-inner{
		border: none;
	}
}

::placeholder{
	transition: color 0.2s ease-out;
	}
:focus::placeholder{
	color: transparent;
}

:disabled{
	background-color: #eee;
	cursor: not-allowed;
}

:required{
	background: #ffffcc;
	border: 2px solid #ff0000;
}

[href^="tel:"]{
	text-decoration: underline;
	@media (min-width: 992px){
		pointer-events: none;
		color: inherit;
		text-decoration: none;
	}
}

.none{
	display: none;
}

.tb:not(.sp), 
.pc:not(.sp){
	@media (max-width: 575.98px){
		display: none !important;
	}
}
.sp:not(.tb), 
.pc:not(.tb){
	@media (min-width: 576px) and (max-width: 991.98px){
		display: none !important;
	}
}
.sp:not(.pc), 
.tb:not(.pc){
	@media (min-width: 992px){
		display: none !important;
	}
}

.fr-view{
	& h1, 
	& h2, 
	& h3, 
	& h4, 
	& h5, 
	& h6{
		margin-bottom: .5rem;
		font-family: inherit;
		font-weight: 500;
		line-height: 1.1;
		color: inherit;
	}
	& h1{
		font-size: 2.5rem;
	}
	& h2{
		font-size: 2rem;
	}
	& h3{
		font-size: 1.75rem;
	}
	& h4{
		font-size: 1.5rem;
	}
	& h5{
		font-size: 1.25rem;
	}
	& h6{
		font-size: 1rem;
	}
	& p{
		margin-top: 0;
		margin-bottom: 1rem;
	}
	& td{
		padding: 0.5em;
		vertical-align: middle;
	}
	& ul, 
	& ol{
		list-style: revert;
		margin: revert;
		padding: revert;
	}
	& hr{
		margin-top: 1rem;
		margin-bottom: 1rem;
		border: 0;
		border-top: 1px solid rgba(0, 0, 0, .1)
	}
	& small{
		font-size: 80%;
		font-weight: 400;
	}
	& iframe[src*="www.youtube.com/embed/"]{
		aspect-ratio: 16 / 9;
		width: 100%;
		height: auto;
	}
}




