@charset "UTF-8";
/* webフォント読み込み */
@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 100;
  src: url("../font/NotoSansJP-Thin.woff");
}

@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 300;
  src: url("../font/NotoSansJP-Light.woff");
}

@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 400;
  src: url("../font/NotoSansJP-Regular.woff");
}

@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 500;
  src: url("../font/NotoSansJP-Medium.woff");
}

@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 700;
  src: url("../font/NotoSansJP-Bold.woff");
}

@font-face {
  font-family: Noto Sans JP;
  font-style: normal;
  font-weight: 900;
  src: url("../font/NotoSansJP-Black.woff");
}

/*=================================================================*/
/* 全デバイス共通 */
/*=================================================================*/
/*	reset
---------------------------------------------------------------*/
* {
  padding: 0px;
  margin: 0px;
}

/*	img
---------------------------------------------------------------*/
img {
  border: none;
  vertical-align: middle;
}

/*	table
----------------------------------------------------*/
table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 100%;
}

/*	clearfix
---------------------------------------------------------------*/
.cf:after {
  content: "";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
}

.cf {
  display: inline-block;
}

/* Hides from IE-mac \*/
* html .cf {
  height: 1%;
}

.cf {
  display: block;
}

/* End hide from IE-mac */
/*	link
---------------------------------------------------------------*/
a,
a:visited,
a:active {
  color: #000;
  text-decoration: none;
}

/*	color
---------------------------------------------------------------*/
#wrap .red {
  color: #ff1d1d;
}

/*	font size
---------------------------------------------------------------*/
.xsmall {
  font-size: 75%;
}

.small {
  font-size: 90%;
}

.large {
  font-size: 125%;
}

/*	align
---------------------------------------------------------------*/
#wrap .center {
  text-align: center;
}

#wrap .left {
  text-align: left;
}

#wrap .right {
  text-align: right;
}

/*	float
---------------------------------------------------------------*/
#wrap .fleft {
  float: left;
}

#wrap .fright {
  float: right;
}

/*	space
---------------------------------------------------------------*/
#wrap .mb0 {
  margin-bottom: 0 !important;
}

#wrap .mb10 {
  margin-bottom: 10px;
}

#wrap .mb20 {
  margin-bottom: 20px;
}

#wrap .mb15 {
  margin-bottom: 15px;
}

#wrap .mb30 {
  margin-bottom: 30px;
}

#wrap .mb50 {
  margin-bottom: 50px;
}

/*	ul
---------------------------------------------------------------*/
li {
  list-style-type: none;
}

/*	p
---------------------------------------------------------------*/
p {
  color: #333333;
}

/*=================================================================*/
body {
  line-height: 160%;
  margin: 0 auto;
  text-align: left;
  word-break: break-all;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #333;
}

body.black {
  background: #000;
  overflow: hidden;
}

#wrap {
  background: #e8f6f4;
}

#wrap.black {
  opacity: .4;
}

/*	フォームのスタイルをリセット
---------------------------------------------------------------*/
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type='checkbox'],
input[type='radio'] {
  display: none;
}

input[type='submit'],
input[type='button'],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

footer > div > div .copy {
  word-break: keep-all !important;
}

#selectDeleteReason {
  padding: 5px 30px 5px 20px;
  border-radius: 3px;
  background: #fff url(/users/common/images/sec/selectarrow.svg) no-repeat center right 10px;
  max-width: 100%;
  border: 1px solid #ddd;
  margin-bottom: 20px;
  box-sizing: border-box;
}

/*******************************************************************/
/* PC */
/*******************************************************************/
@media print, screen and (min-width: 769px) {
  /*<start>==========================================================*/
  html {
    height: 100%;
    font-size: 62.5%;
  }
  /*10px相当にreset*/
  body {
    height: 100%;
    margin: 0;
    font-size: 16px;
    /*css3の効かないブラウザ用*/
    font-size: 1.6rem;
    /*bodyのベースサイズをセット（ここでは16px）以下各要素は10pxを基準にサイズ指定1.2rem（12px）1.4rem（14px）など）*/
    font-weight: 400;
  }
  .sp {
    display: none !important;
  }
  /*=================================================================*/
  /*	コンテンツが少ないときにフッターを下部に固定 */
  /*=================================================================*/
  #wrap {
    position: relative;
    min-height: 100vh;
  }
  /*=================================================================*/
  /*	headerBackground(ヘッダー周り全体にかかる背景) */
  /*=================================================================*/
  div.headerBackground {
    background: #cbdffd;
  }
  /*=================================================================*/
  /*	header */
  /*=================================================================*/
  header {
    width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    background: #cbdffd;
  }
  header > div {
    display: flex;
    align-items: center;
  }
  header > div:first-child div {
    display: flex;
    align-items: flex-end;
    font-size: 1.5rem;
  }
  header > div:first-child div .logo {
    margin-right: 22px;
  }
  header > div .user {
    width: 90px;
  }
  header > div .user .userIcon {
    margin: 0 auto;
    width: 53px;
    height: 53px;
    background: #fff url(../images/union/usericon.svg) no-repeat center center;
    border-radius: 50%;
  }
  header > div .user span {
    visibility: hidden;
    display: block;
    font-size: 1.2rem;
    text-align: center;
    line-height: 1.2em;
  }
  header > div .menu {
    display: flex;
    align-items: center;
    margin-right: 20px;
  }
  header > div .menu a {
    display: block;
    background: #fff;
    font-size: 1.2rem;
    padding: 20px 0px;
    margin-left: 1px;
    transition: .2s;
    width: 92px;
    text-align: center;
    box-sizing: border-box;
  }
  header > div .menu a svg {
    height: 31px;
  }
  header > div .menu a svg path {
    fill: #16bea8;
  }
  header > div .menu a svg, header > div .menu a span {
    display: block;
    margin: 0 auto;
  }
  header > div .menu a:hover {
    background: #16bea8;
    transition: .2s;
  }
  header > div .menu a:hover span {
    color: #fff;
  }
  header > div .menu a:hover path {
    fill: #fff;
  }
  header > div .menu a.login {
    background: #ff7d26;
    color: #fff;
  }
  header > div .menu a.login svg:nth-child(2) {
    display: none;
  }
  header > div .menu a.login svg path {
    fill: #fff;
  }
  header > div .menu a.login:hover {
    background: #000;
    transition: .2s;
  }
  header > div .menu a.logout {
    background: #ff7d26;
    color: #fff;
  }
  header > div .menu a.logout svg:first-child {
    display: none;
  }
  header > div .menu a.logout svg path {
    fill: #fff;
  }
  header > div .menu a.logout:hover {
    background: #000;
    transition: .2s;
  }
  header > div .menu a .count {
    display: none;
  }
  header > div .menu a.countOn {
    position: relative;
  }
  header > div .menu a.countOn .count {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 11px;
    right: 20px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #ff7d26;
    color: #fff;
    font-size: 1.0rem;
  }
  header > div .option .size {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 11px;
  }
  header > div .option .size span {
    font-size: 1.3rem;
  }
  header > div .option .size div {
    display: flex;
    width: 95px;
    justify-content: flex-end;
  }
  header > div .option .size div a {
    background: #16bea8;
    font-size: 1.2rem;
    color: #fff;
    padding: 0 6.5px;
    border-left: 1px solid #fff;
    display: flex;
    height: 100%;
    align-items: center;
    transition: .2s;
  }
  header > div .option .size div a:hover {
    background: #fff;
    color: #16bea8;
    transition: .2s;
  }
  header > div .option .size div a:hover path {
    fill: #16bea8;
  }
  header > div .option .size div a:first-child {
    border-left: none;
  }
  header > div .option .color {
    display: flex;
    justify-content: flex-end;
  }
  header > div .option .color span {
    font-size: 1.3rem;
  }
  header > div .option .color div {
    display: flex;
    width: 95px;
    justify-content: flex-end;
  }
  header > div .option .color div a {
    display: block;
    width: 21px;
    height: 21px;
  }
  header > div .option .color div a.white {
    background: #fff;
  }
  header > div .option .color div a.black {
    background: #000;
  }
  header > div .option .color div a.yellow {
    background: #fbfe26;
  }
  header > div .option .color div a.blue {
    background: #225fce;
  }
  /*=================================================================*/
  /*	背景色変更スタイル */
  /*=================================================================*/
  .blackBg {
    background: #000 !important;
    transition: .2s;
  }
  .blackBg p, .blackBg h3, .blackBg div, .blackBg a, .blackBg span, .blackBg li {
    background: #000 !important;
    color: #fff !important;
    transition: .2s;
  }
  .yellowBg {
    background: #fbfe26 !important;
    color: #000 !important;
    transition: .2s;
  }
  .yellowBg p, .yellowBg h3, .yellowBg div, .yellowBg a, .yellowBg span, .yellowBg li {
    background: #fbfe26 !important;
    color: #000 !important;
    transition: .2s;
  }
  .blueBg {
    background: #225fce !important;
    color: #fff !important;
    transition: .2s;
  }
  .blueBg p, .blueBg h3, .blueBg div, .blueBg a, .blueBg span, .blueBg li {
    background: #225fce !important;
    color: #fff !important;
    transition: .2s;
  }
  /*=================================================================*/
  /*	nav */
  /*=================================================================*/
  nav {
    background: #16bea8;
  }
  nav div {
    width: 1200px;
    margin: 0 auto;
    display: flex;
  }
  nav div a {
    display: block;
    text-align: center;
    width: 100%;
    color: #fff !important;
    padding: 15px 0;
    transition: .2s;
  }
  nav div a:hover {
    background: #fff;
    color: #16bea8 !important;
    transition: .2s;
  }
  nav div a.active {
    background: #fff;
    color: #16bea8 !important;
  }
  /*=================================================================*/
  /*	topScroll */
  /*=================================================================*/
  .topScroll {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 66px;
    height: 66px;
    background: #a0c7d8;
    right: 0;
  }
  .topScroll:hover {
    background: #fff;
    transition: .2s;
  }
  .topScroll:hover path {
    fill: #a0c7d8;
  }
  /*=================================================================*/
  /*	footer */
  /*=================================================================*/
  footer {
    width: 100%;
    background: #a0c7d8;
    display: flex;
    align-items: center;
    height: 107px;
    position: absolute;
    bottom: 0;
  }
  footer > div {
    width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }
  footer > div > div .menu {
    display: flex;
    margin-bottom: 15px;
  }
  footer > div > div .menu a {
    font-size: 1.4rem;
    color: #fff;
    text-decoration: underline;
    border-right: 1px solid #fff;
    padding: 0 10px;
    line-height: 1em;
  }
  footer > div > div .menu a:first-child {
    padding-left: 0;
  }
  footer > div > div .menu a:last-child {
    border-right: 0;
  }
  footer > div > div .menu a:hover {
    text-decoration: none;
  }
  footer > div > div .copy {
    font-size: 1.2rem;
    color: #fff;
  }
  footer .footerBanner {
    display: flex;
  }
  footer .footerBanner a {
    display: block;
    margin-left: 30px;
    transition: .2s;
  }
  footer .footerBanner a:hover {
    opacity: .6;
    transition: .2s;
  }
  .cardList {
    display: none;
  }
  .cardList.slick-initialized {
    display: block;
  }
  /*=================================================================*/
  /*	ログイン時 */
  /*=================================================================*/
  .loginheader {
    display: flex;
    justify-content: flex-end;
  }
  .loginheader a {
    display: block;
    width: 207px;
    height: 46px;
    color: #fff;
    text-align: center;
    line-height: 46px;
    font-weight: bold;
  }
  .loginheader a.btn_totop {
    background: #16bea8 url(../images/union/btn_arrow_w.svg) no-repeat center left 10px;
    color: #fff;
    transition: .2s;
  }
  .loginheader a.btn_totop:hover {
    background: #fff url(../images/union/btn_arrow_g.svg) no-repeat center left 10px;
    color: #16bea8;
  }
  .loginheader a.btn_tomypage {
    background: #ff7d26 url(../images/union/btn_mypage.svg) no-repeat center left 30px;
    color: #fff;
    transition: .2s;
  }
  .loginheader a.btn_tomypage:hover {
    background: #000 url(../images/union/btn_mypage.svg) no-repeat center left 30px;
    color: #fff;
  }
  /*<end>============================================================*/
}

/*******************************************************************/
/* SP */
/*******************************************************************/
@media screen and (max-width: 768px) {
  /*<start>==========================================================*/
  html {
    font-size: 62.5%;
  }
  /*10px相当にreset*/
  body {
    font-size: 15px;
    /*css3の効かないブラウザ用*/
    font-size: 1.5rem;
    /*bodyのベースサイズをセット（ここでは20px）以下各要素は10pxを基準にサイズ指定2.2rem（22px）2.4rem（24px）など）*/
  }
  html, body {
    -webkit-text-size-adjust: 100%;
    /* iPhoneでのフォントサイズ自動変換OFF  縦横でのフォントサイズが固定される */
    -webkit-font-smoothing: antialiased;
    android: textAppearance= "?android:attr/textAppearanceSmall";
  }
  .pc {
    display: none !important;
  }
  /*	img
----------------------------------------------------*/
  img {
    width: 100%;
    height: auto;
  }
  /*=================================================================*/
  /*	トップスクロールボタン用 */
  /*=================================================================*/
  #wrap {
    position: relative;
  }
  /*=================================================================*/
  /*	headerBackground(ヘッダー周り全体にかかる背景) */
  /*=================================================================*/
  div.headerBackground {
    background: #d8eefb;
  }
  /*=================================================================*/
  /*	header */
  /*=================================================================*/
  header {
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    background: #fff;
    border-bottom: 3px solid #16bea8;
  }
  header > div {
    display: flex;
    align-items: center;
  }
  header > div:first-child div {
    display: flex;
    align-items: flex-end;
    font-size: 1.5rem;
  }
  header > div:first-child div .logo {
    width: 107px;
  }
  header > div:first-child div .logo img[src$=".svg"] {
    width: 100%;
  }
  header > div .user {
    width: 90px;
  }
  header > div .user .userIcon {
    margin: 0 auto;
    width: 30px;
    height: 30px;
    background: #e8f6f4 url(../images/union/usericon.svg) no-repeat center center;
    background-size: 20px;
    border-radius: 50%;
  }
  header > div .user span {
    visibility: hidden;
    display: block;
    font-size: 1.1rem;
    text-align: center;
    line-height: 1.2em;
  }
  header > div .menu {
    display: flex;
    align-items: center;
    margin-right: 36px;
  }
  header > div .menu a {
    display: block;
    background: #fff;
    font-size: 1.0rem;
    padding: 12px 0;
    margin-left: 1px;
    transition: .2s;
    width: 60px;
    box-sizing: border-box;
    text-align: center;
    white-space: nowrap;
  }
  header > div .menu a svg {
    height: 20px;
  }
  header > div .menu a svg path {
    fill: #16bea8;
  }
  header > div .menu a svg, header > div .menu a span {
    display: block;
    margin: 0 auto;
  }
  header > div .menu a:active {
    background: #16bea8;
    transition: .2s;
  }
  header > div .menu a:active span {
    color: #fff;
  }
  header > div .menu a:active path {
    fill: #fff;
  }
  header > div .menu a.login {
    background: #ff7d26;
    color: #fff;
  }
  header > div .menu a.login svg:nth-child(2) {
    display: none;
  }
  header > div .menu a.login svg path {
    fill: #fff;
  }
  header > div .menu a.login:active {
    background: #000;
    transition: .2s;
  }
  header > div .menu a.logout {
    background: #ff7d26;
    color: #fff;
  }
  header > div .menu a.logout svg:first-child {
    display: none;
  }
  header > div .menu a.logout svg path {
    fill: #fff;
  }
  header > div .menu a.logout:active {
    background: #000;
    transition: .2s;
  }
  /*=================================================================*/
  /*	nav */
  /*=================================================================*/
  nav img {
    position: fixed;
    top: 20px;
    left: 20px;
    width: 153px;
    height: auto !important;
    transform: none !important;
  }
  nav div.navMenu {
    display: flex;
    margin-top: 60px;
  }
  nav div.navMenu a {
    display: block;
    width: 100%;
    text-align: center;
    border-left: 1px solid #16bea8;
  }
  nav div.navMenu a:first-child {
    border-left: none;
  }
  nav div.navMenu svg {
    height: 25px;
    display: block;
    margin: 0 auto 7px;
  }
  nav div.navMenu svg path {
    fill: #16bea8;
  }
  nav div.navMenu span {
    display: block;
  }
  /*=================================================================*/
  /*	topScroll */
  /*=================================================================*/
  .topScroll {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 66px;
    height: 66px;
    background: #a0c7d8;
    right: 0;
  }
  .topScroll:active {
    background: #fff;
    transition: .2s;
  }
  .topScroll:active path {
    fill: #a0c7d8;
  }
  /*=================================================================*/
  /*	footer */
  /*=================================================================*/
  footer {
    padding: 0 20px;
    background: #a0c7d8;
    display: flex;
    align-items: center;
    height: 90px;
  }
  footer > div {
    display: flex;
    justify-content: space-between;
  }
  footer > div > div .menu {
    display: flex;
    margin-bottom: 15px;
  }
  footer > div > div .menu a {
    font-size: 1.4rem;
    color: #fff;
    text-decoration: underline;
    border-right: 1px solid #fff;
    padding: 0 10px;
    line-height: 1em;
  }
  footer > div > div .menu a:first-child {
    padding-left: 0;
  }
  footer > div > div .menu a:last-child {
    border-right: 0;
  }
  footer > div > div .menu a:active {
    text-decoration: none;
  }
  footer > div > div .copy {
    font-size: 1.0rem;
    color: #fff;
  }
  footer .footerBanner {
    display: flex;
  }
  footer .footerBanner a {
    display: block;
    margin-left: 10px;
    transition: .2s;
  }
  footer .footerBanner a:active {
    opacity: .6;
    transition: .2s;
  }
  .scrollGide svg path {
    fill: #16bea8;
  }
  iframe {
    max-width: 100%;
  }
  /*=================================================================*/
  /*	ログイン時 */
  /*=================================================================*/
  .loginheader {
    display: flex;
    justify-content: flex-end;
  }
  .loginheader a {
    display: block;
    width: 50%;
    max-width: 207px;
    height: 46px;
    color: #fff;
    text-align: center;
    line-height: 46px;
    font-weight: bold;
  }
  .loginheader a.btn_totop {
    background: #16bea8 url(../images/union/btn_arrow_w.svg) no-repeat center left 10px;
    color: #fff;
  }
  .loginheader a.btn_tomypage {
    background: #ff7d26 url(../images/union/btn_mypage.svg) no-repeat center left 20px;
    color: #fff;
  }
  /*<end>============================================================*/
}
