body {
	font-family: 'Open Sans', 'Segoe UI', sans-serif;
	font-display: optional;
	padding: 0;
	margin: 0;
}
input {
	font-family: 'Open Sans', 'Segoe UI', sans-serif;
	font-display: optional;
}
body > div {
	overflow: hidden;
}
/*header*/
header {
	height: 8vh;
	min-height: 60px;
}
header > div {
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	z-index: 20;
	height: 8vh;
	min-height: 60px;
	background-color: #292929;
	color: white;
	padding: 0 8.6vw 0 8.6vw;
}
header div.sCnt {
	height: 100%;
	display: flex;
	align-items: center;
	width: 100%;
}
header .sCnt > div {
	flex-grow: 1;
}
header label,
header input[type=checkbox] {
	display: none;
}
header label {
	height: 4.5vh;
	width: 4.5vh;
	min-width: 40px;
	min-height: 40px;
	border-radius: 100%;
	position: relative;
	cursor: pointer;
	transition: transform 0.2s ease, background-color 0.2s ease ;
}
header label:active {
	background-color: black;
}
header label:before {
	content: "\f0c9";
	font-family: FontAwesome;
	font-size: 150%;
	display: block;
	line-height: 40px;
	width: 40px;
	position: absolute;
	border-radius: 100%;
	top: 50%;
  	left: 50%;
  	transform-style: flat;
  	transform: translate3d(-50%, -50%, 0);
}
.sLeft {
	text-align: left;
}
.sCenter {
	text-align: center;
}
.sRight {
	text-align: right;
}
header img {
	display: block;
	height: 4.5vh;
	min-height: 40px;
}
header ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
header li a {
	display: block;
	color: white;
	line-height: 40px;
	padding: 0 2.5vw;
	text-decoration: none;
	font-weight: 500;
	opacity: 0.8;
	transition: opacity 0.2s ease, transform 0.2s ease;
}
header li a:hover,
header li a:active,
header .toShop a:hover,
header .toShop a:active {
	opacity: 1;
}
header .toShop a:hover {
	transform: scale(1.2);
}
header .toShop a:active {
	transform: scale(0.9);
}
header .toShop a {
	display: inline-block;
	white-space: nowrap;
	font-weight: 600;
	color: white;
	line-height: 40px;
	text-decoration: none;
	padding: 0 50px 0 2.5vw;
	opacity: 0.8;
	transition: opacity 0.2s ease, transform 0.2s ease;
	position: relative;
}
header .toShop a:after {
	content: "\f07a";
	font-family: FontAwesome;
	display: block;
	position: absolute;
	right: 0;
	top: 0;
	font-size: 200%;
	line-height: 40px;
}
/*main*/
main {
	min-height: 70vh;
	padding-top: 5vh;
}
main > div {
	position: relative;
	padding: 0 8.6vw 0 8.6vw;
}
main table {
	width: 100%;
	border: 1px solid silver;
	border-collapse: collapse;
}
main th {
	border-bottom: 1px solid black;
	font-size: 80%;
	padding: 0;
	padding: clamp(5px, 1vh, 20px);
	font-weight: 600;
}
main td {
	padding: 0;
	padding: clamp(5px, 1vh, 20px);
	font-size: clamp(14px, 1vw, 22px);
	vertical-align: text-top;
	opacity: 0.75;
	text-align: center;
}
main table + div.sMsg {
	margin-top: clamp(30px,5vh, 40px);
	margin-bottom: clamp(30px,5vh, 40px);
}
main h2 {
	margin: 0;
	font-size: clamp(24px, 2vw, 50px);
	font-weight: 700;
	color: #AC5709;
}
main h2 span:first-of-type {
	display: block;
	font-size: 50%;
	font-weight: normal;
	text-transform: lowercase;
	opacity: 0.5;
}
main .sName {
	width: 90%;
	text-align: left;
	font-weight: 600;
	opacity: 1;
	word-break: break-word;
}
#iVyp {

}
#iVyp li {
	padding-top: clamp(10px, 1.5vh, 20px);
	font-size: clamp(14px, 1vw, 22px);
	line-height: clamp(24px, 1.6vw, 48px);
}
#iVyp li li:last-of-type {
	display: block;
}
#iVyp p {
	font-size: clamp(16px, 1.1vw, 26px);
	line-height: clamp(26px, 1.7vw, 50px);
}
div.sRead {
	max-width: 800px;
	margin: 0 auto;
}
.sMsg {
	display: block;
	text-align: center;
}
.sMsg p {
	display: inline-block;
	text-align: left;
	border-radius: 5px;
	margin: 0;
	padding: clamp(10px, 3vh, 25px);
	background-color: rgba(80, 80, 80, 0.5);
	color: white;
	font-weight: 600;
}
.sMsg.sErr p {
	background-color: rgba(173, 0, 0, 1);
}
.sMsg.sInf p {
	background-color: rgba(173, 100, 0, 1);
}
.sMsg.sSuc p {
	background-color: rgba(0, 173, 0, 1);
}
main form {
	display: block;
	text-align: center;
	position: relative;
}
main label {
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	font-size: 90%;
	margin-top: clamp(5px, 1vh, 15px);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease;
}
main label.vis {
	opacity: 1;
	visibility: visible;
}
main input[type=text] {
	font-size: clamp(16px, 1.5vw, 26px);
	padding: 0.5vw 0.8vw;
	margin-top: clamp(30px,5vh, 40px);
	margin-bottom: clamp(30px,5vh, 40px);
	width: 28vw;
	min-width: 290px;
	max-width: 500px;
	text-align: center;
}
main .Btn {
	display: block;
	background: linear-gradient(rgba(251,117,89,1) 0%, rgba(250,84,50,1) 100%);
	text-align: center;
	cursor: pointer;
	color: white;
	margin: 0px auto;
	font-weight: 600;
	font-size: clamp(16px, 1.5vw, 26px);
	padding: clamp(5px, 1.5vw, 15px) clamp(15px, 2vw, 30px) clamp(5px, 1.5vw, 15px) clamp(15px, 2vw, 30px);
	border-radius: 3px;
	box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.3);
	position: relative;
	transition: transform 0.15s, box-shadow 0.15s;
	overflow: hidden;
	border: 0;
}
main .Btn:hover {
    box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.5);
}
main .Btn:active {
    transform: scale(0.95);
}
main .Btn:after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  top: 50%;
  left: 50%;
  transform-style: flat;
  transform: translate3d(-50%, -50%, 0);
  background: rgba(255, 255, 255, 0.1);
  border-radius: 100%;
  transition: width 0.3s ease, height 0.3s ease;
}
main .Btn:active:after {
  width: 200px;
  height: 200px;
}
main .Btn i {
	display: inline-block;
	margin-right: 10px;
	font-weight: normal;
}

/*footed*/
footer {
		margin-top: 8.6vw;
    background-color: #3B3B3B;
    padding: 0 40px;
    color: white;
    display: flex;
    flex-wrap: wrap;
    width: auto;
    justify-content: space-evenly;
    gap: 40px;
}
footer > div {
    padding-bottom: 40px;
}
footer h3 {
		margin: 0;
    padding: 40px 0px 0px 0px;
    font-size: clamp(20px, 1.25vw, 40px);
    font-weight: 600;
    color: white;
}
footer ul {
    margin: 0px 0 0 0;
    padding: 0;
    list-style: none;
    display: flex;
}
footer li {
    margin: 5px 0 0 0;
}
footer li + li {
    margin-left: 40px;
}
footer p {
    color: #CACACA;
    font-size: clamp(12px, 0.8vw, 22px);
    padding-top: 5px;
    margin: 0;
    white-space: nowrap;
}
footer p a {
    color: white;
    text-decoration: underline;
}
footer p a img {
    width: 7vw;
    min-width: 120px;
    margin-top: 20px;
    transition: filter 0.3s ease-in-out;
    filter: grayscale(100%) saturate(1.5) brightness(1.5);
}
@media screen and (max-width: 370px){
	header .toShop a {
		font-size: 70%;
	}
}