@charset "utf-8";

*:where(:not(iframe, canvas, img, svg, video):not(svg *, symbol *)){
all:unset;display:revert}
*,*::before,*::after{box-sizing:border-box;font-style:normal}
a,button{cursor:revert}
ol,ul,menu{list-style:none}
img{max-width:100%}
table{border-collapse:collapse}
textarea{white-space:revert}
meter{-webkit-appearance:revert;appearance:revert}
::placeholder{color:unset}
:where([hidden]){display:none}
:where([contenteditable]){-moz-user-modify:read-write;-webkit-user-modify:read-write;overflow-wrap:break-word;-webkit-line-break:after-white-space}
:where([draggable="true"]){-webkit-user-drag:element}
ul,dl,ol,li,dt,dd{margin:0;padding:0}

html{font-size:62.5%;line-height:1.6;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;word-break:break-all;font-feature-settings:"palt"}

body{
  margin:0;
  padding:0;
  background-color:#f8fafd;
  color:#333;
  font-size: 1.5rem;
  font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  font-display: swap;
  font-weight: 500;
  line-height: 1.6;
}

a,area,button,input,label,select,summary,textarea,
[tabindex] {
  -ms-touch-action: manipulation;
  touch-action: manipulation;
}

a {
  color: #333;
  text-decoration: underline;
  cursor: pointer;
}

a.no-line { text-decoration: none;}
a:visited { color: #333;}
a:focus,
a:active { color: #333;}
a.home-delivery,
a.home-delivery:visited,
a.home-delivery:focus,
a.home-delivery:active { color: #0096d0;}

@media (hover: hover) {
a { transition: all .5s ease;}
a:hover { color: #40CE08; opacity: 0.8;}
a.home-delivery:hover { color: #0096d0; opacity: 0.8;}
a.no-fade:hover { opacity: 1;}
}/* End hover */

.en-sans-serif{
  font-family: 'Lato', sans-serif;
  font-display: swap;
  font-weight: 400;
}

.wrap{
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  display: block;
  overflow: hidden;
}

.wrap-hiroshima{
  border-top: 3rem solid #9DC3E6;
}

.wrap-ouest{
  border-top: 3rem solid #f5d677;
}

.wrap-wasizu{
  border-top: 3rem solid #ccf;
}

.wrap-yohk{
  border-top: 3rem solid #369;
}

/* PAGE TOP */
.page-top{ opacity: 0;}

.gamo-form *:focus { outline: none;}

.gamo-form select option { padding: 0;}
.gamo-form label { cursor: pointer;}

.gamo-form input{
  position: relative;
  padding: 0.6em;
  width: 100%;
  display: block;
  outline: none;
  border-radius: 0.3em;
  box-sizing: border-box;
  background-color: #fff;
  font-size: 1.6rem;
}

.gamo-form .input-block{ padding: 0.5rem 0; width: 100%; overflow: hidden;}
.gamo-form .input-block input{ margin: 0 0 1em; width: 100%; display: block;}
.gamo-form .input-block input::placeholder{ color: #a8a8a8;}
.gamo-form .input-block input:last-child{ margin: 0;}

/* error */

/*
.error-txt{ text-align: center; padding: 2em 0 0; color: #c00; }


form .error-msg{
  padding: 0 0 0.5em 0;
  display: block;
  color: #c00;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: left;
}

form td .error-msg{
  margin: 0;
  padding: 0 0 0.5em 0;
}

.form-agree .error-msg{ text-align: center;}
*/


/*
.login-body{
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100vh;
  height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
*/

.login-body{
  position: relative;
  margin: 0;
  padding: 0 0 3em;
  width: 100%;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
/*
.wrap-othercompany .login-body{
  height: 88svh;
}
*/
.login-article{
  position: relative;
  margin: 0;
  padding: 0;
  width: 92%;
  max-width: 78rem;
  display: block;
  z-index: 100;
}

.login-inner{
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 38rem;
  display: block;
}

.wrap-othercompany .login-inner{
  max-width: 39rem;
}

.login-contents-title{
  margin: 0;
  padding: 1.5em 0 0;
  font-size: min(max(2.8rem, calc(2.8rem + ((1vw - 0.48rem) * 0.6667))), 3rem);
  font-weight: 500;
  line-height: 1.2;
  min-height: 0vw;
}

.login-contents-title em img{ width: 100%; max-width: 32rem; aspect-ratio:492/58;}

.login-contents-title em.hiroshima img{ max-width: 22rem; aspect-ratio:406/109;}

.other-title{
  font-size: 1.2em;
  letter-spacing: 0.1rem;
}

/*
.login-contents-title{
  margin: 0;
  padding: 0;
  font-size: min(max(3rem, calc(3rem + ((1vw - 0.48rem) * 2.6667))), 3.8rem);
  font-weight: 500;
  line-height: 1.2;
  min-height: 0vw;
}

.login-contents-title em img{ width: 100%; max-width: 38rem;}
*/
.login-article .catch-copy{
  padding: 1em 0;
  display: block;
  font-size: 1.6rem;
}
/*
.login-article .login-block{
  position: relative;
  margin: 0;
  padding: 1em 0 1.5em;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
*/

.login-article .login-block{
  position: relative;
  margin: 0;
  padding: 0.5em 0 1.5em;
  width: 100%;
  display: block;
}

.gamo-form-login{
  position: relative;
  margin: 0;
  padding: 0.5em;
  width: 90%;
  max-width: 20rem;
  border-radius: 3em;
  background: #40CE08;
  color: #fff;
  font-size: 1.6rem;
  text-align: center;
  font-weight: normal;
  line-height: 1.5;
  cursor: pointer;
}

.login-block .notice a{
  position: relative;
  margin: 0;
  padding: 0;
  width: calc(100% - 17rem);
  /*color: #40CE08;*/
  font-size: 1.5rem;
  line-height: 1.5;
  /*text-decoration: none;*/
}


.login-block .notice a.password{
  position: relative;
  margin: 0.5em 0 0;
  padding: 0.2rem 1rem;
  width: 100%;
  max-width: 15em;
  display: block;
  border-radius: 2em;
  background: #999;
  color: #fff;
  font-size: 1.5rem;
  line-height: 1.5;
  text-decoration: none;
  text-align: center;
}
/*
.login-notice{
  margin-top: 1.5em;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  align-items: center;
}
*/

.login-notice{
  margin-top: 1.5em;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: wrap;
}


@media (hover: hover) {
.gamo-form-login { transition: all .5s ease;}
.gamo-form-login:hover { opacity: 0.8;}
}/* End hover */

.login-information{
  margin: 0;
  padding: 0;
  width: 100%;
}

.login-information h2{
  margin: 0;
  padding: 0 0 0.5em;
  font-size: 1.7rem;
  font-weight: 500;
  line-height: 1.5;
}

.login-information p{
  margin: 0;
  padding: 0 0 1em;
  font-size: 1.5rem;
  line-height: 1.6;
}

/*
.copy-right{
  position: fixed;
  bottom: 0;
  margin: 0;
  padding: 1.5em;
  width: 100%;
  display:block;
  color: #333;
  font-size: 1.3rem;
  font-family: 'Lato', sans-serif;
  font-display: swap;
  font-weight: 400;
  text-align: center;
}
*/
.copy-right{
  position: absolute;
  bottom: 0;
  margin: 0;
  padding: 1.5em;
  width: 100%;
  display:block;
  color: #333;
  font-size: 1.3rem;
  font-family: 'Lato', sans-serif;
  font-display: swap;
  font-weight: 400;
  text-align: center;
}


.gamo-order-bg-image{
  position: fixed;
  top: 0;
  margin: 0;
  padding: 0 0;
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
  text-align: center;
  z-index: -1;
  pointer-events: none;
  opacity: 0.15;
}
.gamo-order-bg-image img{
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  padding: 0 0;
  width: 100%;
  max-width: 116.2rem;
  height: 100vh;
  display: block;
  object-fit: cover;
  object-position: 50% 0%;
}

.gamo-order-bg-image::before{
  position: absolute;
  top: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  display: block;
  background-color: #f8fafd;
  content: "";
  z-index: 1;
  mix-blend-mode: multiply;
}

/*
.bg-video{
  position: absolute;
  top: 0;
  margin: 0;
  padding: 200% 0 0;
  width: 200%;
  height: 0;
  display: block;
  overflow: hidden;
  z-index: -1;
}

.bg-video::before{
  position: absolute;
  top: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  display: block;
  background-color: rgba(255,255,255,0.8);
  content: "";
  z-index: 1;
}
.bg-video iframe{
  position: absolute;
  top: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  display: block;
}

*/

/* checkbox */

.checkbox-menu {display: none !important; border: none;}

.checkbox-menu + label{
  position:relative;
  margin: 0 1em 0 0;
  padding: 0 0 0 1.5em;
  display: block;
  font-size: 1.6rem;
  line-height: 1.4;
}

.checkbox-menu + label:before{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  width: 1.6rem;
  height: 1.6rem;
  display: block;
  border: 0.1rem solid #999;
  border-radius: 0.2em;
  background-color: #fff;
  content: "";
}

.checkbox-menu:checked + label{
  color: #40CE08;
  font-weight: bold;
}

.checkbox-menu:checked + label:after{
  position: absolute;
  top: 0.4rem;
  left: 0.4rem;
  width: 1.4rem;
  height: 0.8rem;
  display: block;
  border-left: 0.3rem solid #40CE08;
  border-bottom: 0.3rem solid #40CE08;
  transform: rotate( -45deg );
  content: "";
}

.caution-block{
  margin-top: 1rem;
}

.caution-block p strong {
  padding: 0 0.3rem 0;
  color: #c00;
  font-weight: 600;
}



.test-bottom{
  color: #c00;
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 2rem;
}

p.notice-txt{
  position: relative;
  margin: 0.5em 0 1em;
  padding: 0 0 0 1em;
  font-size: 1.4rem;
}

p.notice-txt::before{
  position: absolute;
  top: 0;
  left: 0;
  color: #c00;
  content: "\203B";
}

.login-block p.notice-txt{ margin: 0.5em 0 0;}



/* 2024.08.26 */

.flex-inner{
  margin: 0;
  padding: 1em 0 0;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  column-gap: 1rem;
}

.how-to-button{
  position: relative;
  margin: 0;
  padding: 0.5em;
  width: 90%;
  max-width: 20rem;
  border-radius: 3em;
  background: #999;
  color: #fff;
  font-size: 1.5rem;
  text-align: center;
  font-weight: normal;
  line-height: 1.5;
  text-decoration: none;
  cursor: pointer;
}

a.how-to-button:visited { color: #fff;}
a.how-to-button:focus,
a.how-to-button:active { color: #fff;}



@media (hover: hover) {
.how-to-button { transition: all .5s ease;}
.how-to-button:hover { opacity: 0.8; color: #fff;}
}/* End hover */
