@charset "utf-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&family=Zen+Old+Mincho:wght@400;500;600;700;900&display=swap');
.color1{
    color: #0F1D6D;
}
.color2{
    color: #3781CD;
}
.send .send-bt{
  width: 250px;
  height: 70px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;

  display: flex;
  align-items: center;

  padding-right: 70px; /* ←右の白丸分のスペース */
  padding-left: 24px;  /* ←左余白（お好みで） */

  background-image: url("https://ru-techno.co.jp/system_panel/uploads/images/bt.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

/* 文字を中央に */
.send .send-bt p{
  margin: 0;
  width: 100%;            /* ←これ重要 */
  text-align: center;     /* ←これで中央 */
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1em;
  z-index: 2;
}
/* 右の白丸 */
.send-bt i{
  width: 54px;
  height: 54px;
  background: #fff;
  border-radius: 50%;

  display: flex;
  align-items: center;
  justify-content: center;

  color: #2f8be6;
  font-size: 18px;

  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  transition: 0.3s;
}

/* hover時：アイコンだけ右へ */
.send-bt:hover i{
  transform: translateY(-50%) translateX(3px);
}



.signature {
margin-right: 0;
    margin-left: auto;
      font-family: "Zen Old Mincho", serif;
        text-align: center;
    display: inline-flex;
    align-items: baseline;
    gap: 12px;
}

.swiper-container .swiper-wrapper{
gap:30px;
}

.footer_i1 a{
  text-decoration: none;
}

/* 上グレー帯 */
.footer_i1 .footer_top{
  background-image: url("https://ru-techno.co.jp/system_panel/uploads/images/footer1.jpg");
  background-size: cover;
  background-position: center;
  padding: 80px 0 100px;
}

/* メニュー */
.footer_i1 .footer_top .ul{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px clamp(35px, 2.2vw, 40px);
  flex-wrap: wrap;
}
.footer_i1 .footer_top {
    background-image: url(https://ru-techno.co.jp/system_panel/uploads/images/footer1.jpg);
    background-size: cover;
    background-position: center;
    padding: 80px 0 100px;
}
.footer_i1 .footer_top .li a{
  display: block;
}

.footer_i1 .footer_top .menu-item{
  text-align: center;
  line-height: 1.15;
}

.footer_i1 .footer_top .menu-item .en{
  margin: 0;
  text-shadow: 0 2px 10px rgba(0,0,0,0.8);
    
    font-size: clamp(16px, 4vw, 28px);
    color: #fff;
    text-align: center;
    font-family: "Outfit", sans-serif;
    font-weight: 600;
}
.footer_i1 .footer_top .menu-item .jp{
  margin: 6px 0 0;
  font-size: 14px;
  color: rgba(255,255,255,0.9);
  text-shadow: 0 2px 10px rgba(0,0,0,0.7);
}

/* 下：青帯 */
.footer_i1 .footer_bottom{
  background: linear-gradient(90deg, #3b84ff, #1a1f6b);
  padding: 28px 0 10px;
  color: #fff;
}

.footer_i1 .footer_bottom_inner{
  width: min(1200px, 92%);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  position: relative;
}

/* 左 */
.footer_i1 .footer_left{
  width: 30%;
}

.footer_i1 .footer_companyname{
  margin: 0 0 10px;
  font-weight: 600;
}

.footer_i1 .footer_insta i{
  display: inline-flex;
  align-items: center;
  justify-content: center;
font-size: 26px;
  color: #fff;
}

.footer_i1 .footer_center{
width: clamp(90px, 12vw, 150px);
  position: absolute;
  left: 50%;
  top: -10px;
  transform: translate(-50%, -50%);

  display: flex;
  justify-content: center;
  align-items: center;
}

.footer_i1 .footer_logo{
  width: 100%;
  border-radius: 50%;
  object-fit: cover;
}
/* 右 */
.footer_i1 .footer_right{
  width: 50%;
  display: flex;
  justify-content: flex-end;
  gap: 30px;
}

.footer_i1 .footer_addressbox .ttl{
  margin: 0 0 6px;
  font-size: 15px;
  font-weight: 700;
}

.footer_i1 .footer_addressbox .txt{
  margin: 0;
  font-size: 14px;
  opacity: 0.9;
  line-height: 1.5;
}

/* コピーライト */
.footer_i1 .footer_copy{
  margin: 18px 0 0;
  text-align: center;
  font-size: 12px;
  opacity: 0.85;
}
@media (max-width: 1080px){
.footer_i1 .footer_center {
    top: -40px;}}
    
@media (max-width: 768px){
    
    .footer_i1 .footer_bottom{
  padding: 50px 0 10px;
}
    
    .footer_i1 .footer_top {
    padding: 40px 0 60px;
}
.footer_i1 .footer_center {
    top: -50px;}
    
  .footer_i1 .footer_bottom_inner{
    flex-direction: column;
    text-align: center;
  }

  .footer_i1 .footer_left,
  .footer_i1 .footer_center,
  .footer_i1 .footer_right{
    width: 100%;
    justify-content: center;
  }

  .footer_i1 .footer_right{
    flex-direction: column;
    gap: 14px;
  }

  .footer_i1 .footer_logo{
    width: 80px;
    height: 80px;
  }
}

.titlebox2{
    margin-bottom: 50px;
}
.titlebox2 .jp {
    font-weight: 900;
     margin: 0px 0 0;}
.titlebox2 .en_title{
    font-weight: 700;
    color: #3781CD;
    letter-spacing: 0.08em;
    margin: 0;
    text-shadow: 2px 2px 0px rgba(47, 139, 230, 0.35);
}
.titlebox1{
    margin-bottom: 50px;
}
.titlebox1 .en {
  font-size: clamp(14px, 3vw, 16px);
  font-family: "Outfit", sans-serif;
  font-weight: 700;
  color: #3781CD;
  letter-spacing: 0.08em;
  margin: 0;

  text-shadow: 2px 2px 0px rgba(47, 139, 230, 0.35);
}

.titlebox1 .jp {
  font-weight: 600;
  margin: 12px 0 0;
  line-height: 1.1;
}

.box2 .titlebox1 {
  width: 30%;
}
.box2 .boxwrap{
    max-width: 1280px;
    width: 100%;
}
.box2 .rightbox{
   width: 70%; 
    max-width: 900px;
}
.company_a .company-wrap {
    width: 100%;
}
@media screen and (max-width: 1080px) {
  .box2 .boxwrap{
    flex-direction: column;
  }
    .box2 .titlebox1 {
    width: 100%;
        margin-bottom: 50px;
}
    .box2 .rightbox{
   width: 100%; 
}
  .box2 .title {
    align-items: center;
    text-align: center;
    width: 100%;
    margin-bottom: 50px;
  }
}
@media screen and (max-width: 576px) {
    .company_a .company-wrap .item{
        flex-direction: column;
    }
    
        .company_a .company-wrap .item h3 {
        width: 100%;
    }
        .company_a .company-wrap .item > div {
        width: 100%;
        padding-left: 0px;
    }
}

.pagelinks_c a > .flex .more-icon {
    border: 2px solid #1A1A1A;
}
.pagelinks_c a > .flex .more-icon i {
    color: #1A1A1A;}

.outfit {
  font-family: "Outfit", "Zen Kaku Gothic New", "Noto Sans JP", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.en_title {  font-family: "Outfit", sans-serif;
  font-size: clamp(50px, 6vw, 100px);
  letter-spacing: .08em;
}
.en_title2 {  font-family: "Outfit", sans-serif;
  font-size: clamp(32px, 6vw, 40px);
  letter-spacing: .04em;
}
.default_title0 {
  font-size: clamp(20px, 3.2vw, 32px);
  letter-spacing: .05em;
     font-weight: bold;
}
.default_title {
  font-size: clamp(20px, 3.2vw, 32px);
  letter-spacing: .05em;
    font-weight: bold;
}
.default_title2 {
  font-size: clamp(20px, 2.9vw, 26px);
  letter-spacing: .05em;
       font-weight: bold;
}
.default_title3 {
  font-size: clamp(18px, 2.5vw, 20px);
  letter-spacing: .05em;
       font-weight: bold;
}
.default_txt {
  font-size: clamp(16px, 1.8vw, 18px);
  letter-spacing: .03em;
  line-height: 2;
    font-weight: 500;
}
.default_txt2 {
  font-size: clamp(15px, 1.6vw, 16px);
  letter-spacing: .02em;
  line-height: 2;
}
.default_txt3 {
  font-size: clamp(14px, 1.4vw, 15px);
  letter-spacing: .02em;
}
.en_txt {
  font-size: clamp(16px, 1.8vw, 20px);
  letter-spacing: .05em;
  line-height: 2;  font-family: "Outfit", sans-serif;
}
.header_i1.is-scrolled .menu-item p {
  color: #1A1A1A !important;
}

.header_i1.is-scrolled .line div {
  background: #1A1A1A !important;
}

body:not(.on) .pagetitle_e {
  background: #eee;
}
body:not(.on) .pagetitle_e img{
  width: 500px;
}

/* title_wrap を relative にする */
body:not(.on) .pagetitle_e .titlebox {
  position: relative;
  z-index: 50;
  top: 0px;
}

/* title_card も relative にする */
body:not(.on) .pagetitle_e .title_card {
  position: relative;
  top: 90%;
}

@media screen and (max-width: 1280px) {
}
/* ---------- pagetitle_e ---------- */
.pagetitle_e {
  position: relative;
  overflow: visible;
}
.pagetitle_e .box {
  position: relative;
  width: 100%;
  height: clamp(300px, 36vw, 500px);
}
body.on .pagetitle_e .box::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: flex;
  background: rgba(0,0,0,0.40);
  z-index: 1;
}
.pagetitle_e .box .bg_img_wrap2 {
  position: relative;
  overflow: hidden;
}

.pagetitle_e .titlebox {
  width: 100%;
  position: relative;
   z-index: 2;
}
.pagetitle_e .box .titlebox p{
    color: #fff;
    font-weight: 600;
}

.pagetitle_e .box .titlebox h1 {
  color: #fff;
  font-family: "Zen Kaku Gothic New", sans-serif;
  text-align: center;
  font-weight: 700;
}
.pagetitle_e .box {
  height: clamp(300px, 36vw, 500px);
}
.pagetitle_e .titlebox .imgbox {
  width: 100px;
  height: 100px;
  border-radius: 999px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}
.pagetitle_e .titlebox .imgbox img {
  width: 70px;
  height: auto;
  object-fit: contain;
}
.pagetitle_e .title_card h2 {
  font-weight: 500;
  text-align: center;
}
/* ===== 下の白カード ===== */
.pagetitle_e .box {
  position: relative;
}
.pagetitle_e .title_card {
  position: absolute;
  left: 50%;
  top: 65%;
  transform: translateX(-50%);
  width: min(800px, calc(100% - 40px));
  background: #fff;
  border-radius: 20px;
  padding: 60px 28px 36px;
  text-align: center;
  z-index: 3;
}
/* サブタイトル */
.pagetitle_e .title_card h2 {
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 700;
  color: #111;
}
/* 点々（●●●●● を整える） */
.pagetitle_e .title_card .dots {
  margin: 6px 0 14px;
  letter-spacing: 6px;
  font-size: 14px;
  color: #5BAE07;
  text-align: center;
}
/* 説明文 */
.pagetitle_e .title_card p {
  margin: 0;
  color: #333;
  line-height: 1.9;
}
@media screen and (max-width: 768px) {
  .pagetitle_e .title_card {
    position: absolute;
    left: 50%;
  }
 
}
@media screen and (max-width: 576px) {

}

/* ---------- header_i1 ---------- */

.header_i1 {
  white-space: nowrap;
  position: fixed;
  z-index: 9999;
  height: clamp(100px, 8vw, 120px);
  width: 100%;
  overflow: hidden;
}
.header_i1::after{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background-color: #3F82CA;
	transition: ease 0.3s;
	opacity: 0;
}
.header_i1.on::after{
	opacity: 0.9;
}
.header_i1 > div{
	position: relative;
	z-index: 3;
}
/* 右側ナビエリア */
.header_i1 .rightbox {
  position: fixed;
  height: clamp(70px, 10vw, 120px);

  right: 0px;
  z-index: 50;
  white-space: nowrap;
}
.header_i1 .rightbox .ul {
    margin-right: 40px;
  height: 100%;
  display: flex;
  flex-wrap: nowrap;
  white-space: nowrap;
  overflow: hidden;
  gap: clamp(10px, 5vw, 30px);
}
/* Online Shop ボタン */
.header_i1 .contact-box {
  height: 100%;
}
.header_i1 .contact-box a {
  flex-direction: column;
  width: 125px;
  height: 100%;
  background: #3C533F;
  font-weight: 600;
  text-decoration: none;
  gap: 12px;
}
.header_i1 .contact-box p {
  color: #fff;
  font-size: clamp(8px, 1.4vw, 16px);
}
.header_i1 .contact-box img {
  width: 24px;
  color: #fff;
}
/* contact ホバー効果 */
.header_i1 .contact-box a:hover img {
  transform: translateX(3px);
  transition: ease 0.3s;
}
/* ベースレイヤー */
.header_i1 > div {
  position: relative;
  z-index: 2;
}
/* 左側ロゴ */
.header_i1 .leftbox {
  position: fixed;
  left: 20px;
top: clamp(10px, 3vw, 30px);
  z-index: 10;
}
.header_i1 .leftbox .logo img {
  width: clamp(40px, 10vw, 150px);
}

.header_i1 .menu-item {
  position: relative;
  display: flex;
  flex-direction: column; /* 縦にJP/ENを積む */
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: nowrap;
  min-width: 100px;
}
/* 共通（アニメ用） */
.header_i1 .menu-item .jp, .header_i1 .menu-item .en {
  margin: 0;
  line-height: 1;
  white-space: nowrap;
  transition: transform 0.35s ease, opacity 0.35s ease;
  transform: translateY(0); /* 初期位置リセット */
}

/* テキストスタイル */
.header_i1 .rightbox .jp {
  font-size: clamp(8px, 1.4vw, 14px);
  margin-top: 10px;
  text-align: center;
    font-weight: 500;
  color: #fff;
}
.header_i1 .rightbox .ul .li a p.en {
  font-size: clamp(16px, 4vw, 28px);
  color: #fff;
  margin: 0;
  text-align: center;  font-family: "Outfit", sans-serif;
    font-weight: 600;
}
.header_i1 .menu-bt {
  z-index: 9999;
  width: 70px;
  aspect-ratio: 1 / 1;
  border-radius: 0;
  cursor: pointer;
  display: flex; /* 追加：中身を中央に */
  align-items: center;
  justify-content: center;
margin-right: clamp(10px, 3vw, 26px);
    display: none;
}
.header_i1 .menu-bt .line {
  position: relative; /* 追加：子要素のabsoluteの基準にする */
  width: 40px;
  height: 24px; 
}
.header_i1 .menu-bt .line > div {
  position: absolute;
  width: 100%;
  height: 2px;
  background-color: #fff;
  transition: ease 0.3s;
}
.header_i1 .menu-bt .line > div:nth-of-type(1) {
  top: 0;
}
.header_i1 .menu-bt .line > div:nth-of-type(2) {
  top: 50%;
  transform: translateY(-50%);
}
.header_i1 .menu-bt .line > div:nth-of-type(3) {
  bottom: 0;
}
/* active のコードはそのままでOK */
.header_i1 .menu-bt.active .line > div:nth-of-type(1) {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}
.header_i1 .menu-bt.active .line > div:nth-of-type(2) {
  top: 50%;
  transform: translateY(-50%) translateX(50%);
  opacity: 0;
}
.header_i1 .menu-bt.active .line > div:nth-of-type(3) {
  bottom: 50%;
  transform: translateY(50%) rotate(-45deg);
}
.header_i1 .menu-bt.active .line > div {
  background: #fff !important;
}
@media screen and (max-width: 1280px) {}
@media screen and (max-width: 1080px) {
    .header_i1 .rightbox .ul {
        margin-right: 0px;}
    .header_i1 .menu-bt {
    display: flex;
}
  .header_i1 .rightbox .li {
    display: none;
  }
}
@media screen and (max-width: 768px) {

  .header_i1 .menu-bt .line > div {
    height: 2px;
  }

  .header_i .page_links {
    top: 70px;
    gap: 30px;
  }

  .header_i .logo {
    gap: 10px;
  }
  .header_i .header_right {
    gap: 15px;
  }
  .header_i .header_right .menu-bt {
    width: 50px;
  }
}
@media screen and (max-width: 576px) {

        
  .header_i1 .menu-bt {
       margin-right: 10px;
  }
  .header_i1 .menu-bt .line {
    width: 30px;
    height: 18px;
  }
  .header_i .menu-bt .line > div {
    height: 2px;
  }
}
/* ---------- burgermenu_d1 ---------- */
.burgermenu_d1 {
  display: none;
  position: fixed;
  z-index: 98;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.burgermenu_d1::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background-color: #000;
  opacity: 0.85;
}
.burgermenu_d1 > div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  z-index: 2;
}
.burgermenu_d1 .ul {
  width: 90%;
  gap: 50px 30px;
  overflow: auto;
}
.burgermenu_d1 .ul .li {
  width: calc(100% / 3 - 60px / 3);
}
.burgermenu_d1 .ul .li a {
  position: relative;
  display: block;
  padding: 15px 50px;
  box-sizing: border-box;
  text-align: center;
  overflow: hidden;
  border-bottom: 1px solid #fff;
}

.burgermenu_d1 .ul .li a p.jp {
  font-size: clamp(16px, 2vw, 20px);
    color: #fff;
}
.burgermenu_d1 .ul .li a p.en {
  font-size: clamp(20px, 3vw, 30px);
  font-family: "Outfit", sans-serif;
  color: #fff;
  font-weight: 600;
}

@media screen and (max-width: 1280px) {
  .burgermenu_d1 .ul {
    gap: 30px 30px;
  }
  .burgermenu_d1 .ul .li {
    width: calc(100% / 3 - 60px / 3);
  }

}
@media screen and (max-width: 1080px) {
  .burgermenu_d1 .ul {
    gap: 30px 50px;
  }
  .burgermenu_d1 .ul .li {
    width: calc(100% / 2 - 50px / 2);
  }


}
@media screen and (max-width: 768px) {
  .burgermenu_d1 .ul {
    gap: 30px;
  }
  .burgermenu_d1 .ul .li {
    width: calc(100% / 2 - 30px / 2);
  }
}
@media screen and (max-width: 576px) {
  .burgermenu_d1 > div {
    padding: 120px 0 50px;
  }
  .burgermenu_d1 .ul {
    gap: 0 10px;
  }
  .burgermenu_d1 .ul .li {
    width: calc(50% - 5px);
  }
  .burgermenu_d1 .ul .li a {
    padding: 20px 0;
  }

  .burgermenu_d1 .ul .li a p.jp {
    font-size: 13px;
  }
}
html{
}
body{
	font-family: "Zen Kaku Gothic New", "Noto Sans JP", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	background-color: #fff;
	color: #000000;
}

body .bg_img_wrap {
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
body.on .bg_img_wrap .bg_img{
	display: none;
}
body .bg_img_wrap2 {
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
body.on .bg_img_wrap2 > img{
	display: none;
}

a{
	display: inline-block;
	transition: ease 0.3s;
}
a:hover{
	opacity: 0.5;
}
a p,a,a i{
	color: #000000;
}
.font-medium{font-weight: 500;}
.font-semibold{font-weight: 600;}
.font-black{font-weight: 900;}

.pd_wrap{
	padding: 150px 80px 0;
}
.pd_wrap_all{
	padding: 150px 80px 150px;
}
.pd_wrap_side{
	padding-left: 80px;
	padding-right: 80px;
}

.cate_wrap > .cate{
	padding-top: 150px;
}

/* ---------- common ---------- */

/* ---------- header ---------- */
.header{
}

/* ---------- footer ---------- */

/* ANIME */
.sc-anime.topin.on{
	opacity:0;
	transform: translateY(-50px);
}
.sc-anime.topin.on.active{
	animation-name: topin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.bottomin.on{
	opacity:0;
	transform: translateY(50px);
}
.sc-anime.bottomin.on.active{
	animation-name: bottomin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.leftin.on{
	opacity:0;
	transform: translateX(-50px);
}
.sc-anime.leftin.on.active{
	animation-name: leftin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.rightin.on{
	opacity:0;
	transform: translateX(50px);
}
.sc-anime.rightin.on.active{
	animation-name: rightin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.fadein.on{
	opacity:0;
}
.sc-anime.fadein.on.active{
	animation-name: fadein;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.blurin.on{
	opacity:0;
	-ms-filter: blur(6px);
	filter: blur(6px);
}
.sc-anime.blurin.on.active{
	animation-name: blurin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.blurin2.on{
	opacity:0;
	transform: translateY(50px);
	-ms-filter: blur(6px);
	filter: blur(6px);
}
.sc-anime.blurin2.on.active{
	animation-name: blurin2;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}

@keyframes topin {
	0% {
		opacity:0;
		transform: translateY(-50px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
	}
}
@keyframes bottomin {
	0% {
		opacity:0;
		transform: translateY(50px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
	}
}
@keyframes leftin {
	0% {
		opacity:0;
		transform: translateX(-50px);
	}
	100% {
		opacity:1;
		transform: translateX(0px);
	}
}
@keyframes rightin {
	0% {
		opacity:0;
		transform: translateX(50px);
	}
	100% {
		opacity:1;
		transform: translateX(0px);
	}
}
@keyframes upin {
	0% {
		transform: translateY(100%);
	}
	100% {
		transform: translateY(0);
	}
}
@keyframes fadein {
	0% {
		opacity:0;
	}
	100% {
		opacity:1;
	}
}
@keyframes fadeout {
	0% {
		opacity:1;
	}
	100% {
		opacity:0;
	}
}
@keyframes blurin {
	0% {
		opacity: 0;
		-ms-filter: blur(6px);
		filter: blur(6px);
	}
	100% {
		opacity:1;
		-ms-filter: blur(0px);
		filter: blur(0px);
	}
}
@keyframes blurin2 {
	0% {
		opacity: 0;
		transform: translateY(50px);
		-ms-filter: blur(6px);
		filter: blur(6px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
		-ms-filter: blur(0px);
		filter: blur(0px);
	}
}

/* color */
.txt-color-normal{color: #000000;}
.txt-white{color: #ffffff;}
.txt-red{color: red;}
.txt-color1{color: #FFE93C}
.txt-color2{color: #F1F1E9}
.txt-color3{color: #021745}
.txt-color4{color: #EBF5E5}
.bg-white{background-color: #ffffff;}
.bg-black{background-color: black}
.bg-color1{background-color: #FFE93C}
.bg-color2{background-color: #F1F1E9}
.bg-color3{background-color: #021745}
.bg-color4{background-color: #EBF5E5}
.border-color1{border-color: #FFE93C}
.border-color2{border-color: #F1F1E9}
.border-color3{border-color: #021745}
.border-color4{border-color: #EBF5E5}

.hvr-txt-color-normal:hover{color: #000000;}
.hvr-txt-white:hover{color: #ffffff;}
.hvr-txt-red:hover{color: red;}
.hvr-txt-color1:hover{color: #FFE93C}
.hvr-txt-color2:hover{color: #F1F1E9}
.hvr-txt-color3:hover{color: #021745}
.hvr-txt-color4:hover{color: #EBF5E5} 
.hvr-bg-white:hover{background-color: #ffffff;}
.hvr-bg-black:hover{background-color: black}
.hvr-bg-color1:hover{background-color: #FFE93C}
.hvr-bg-color2:hover{background-color: #F1F1E9}
.hvr-bg-color3:hover{background-color: #021745}
.hvr-bg-color4:hover{background-color: #EBF5E5}
.hvr-border-color1:hover{border-color: #FFE93C}
.hvr-border-color2:hover{border-color: #F1F1E9}
.hvr-border-color3:hover{border-color: #021745}
.hvr-border-color4:hover{border-color: #EBF5E5}

/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}

/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
	.pd_wrap{
		padding: 150px 60px 0;
	}
	.pd_wrap_all{
		padding: 150px 60px 150px;
	}
	.pd_wrap_side{
		padding-left: 60px;
		padding-right: 60px;
	}
/* ---------- common ---------- */
/* ---------- header ---------- */
/* ---------- footer ---------- */
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
/* ---------- common ---------- */
/* ---------- header ---------- */
	.header_i1{
		justify-content: flex-end;
		height: clamp(80px, 8vw, 120px);
		overflow: inherit;
	}
	.header_i1 .leftbox,.header_i1 .rightbox{
		height: auto;
	}
	.header_i1 .leftbox{
		top: 20px;
		left: 20px;
	}
	.header_i1 .rightbox{
		position: relative;
	}
	.header_i1 .rightbox .ul{
		display: none;
	}
/* ---------- footer ---------- */
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
	.pd_wrap{
		padding: 100px 50px 0;
	}
	.pd_wrap_all{
		padding: 100px 50px 100px;
	}
	.pd_wrap_side{
		padding-left: 50px;
		padding-right: 50px;
	}
	.cate_wrap > .cate{
		padding-top: 100px;
	}
/* ---------- common ---------- */
/* ---------- header ---------- */
	.header_i1 .leftbox .logo img{
		width: clamp(60px, 12vw, 150px);
	}
/* ---------- footer ---------- */
}
/* ---------- スマートフォン ---------- */
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	.pd_wrap{
		padding: 80px 20px 0;
	}
	.pd_wrap_all{
		padding: 80px 20px 80px;
	}
	.pd_wrap_side{
		padding-left: 20px;
		padding-right: 20px;
	}
	.cate_wrap > .cate{
		padding-top: 80px;
	}
/* ---------- common ---------- */
/* ---------- header ---------- */
	.header_i1{
		justify-content: space-between;
		padding: 10px 20px;
		height: auto;
	}
	.header_i1 .leftbox{
		position: relative;
		top: 0;
		left: 0;
	}
	.header_i1 .rightbox{
		position: relative;
	}
	.header_i1 .menu-bt{
		margin-right: 0;
		width: 55px;
	}
/* ---------- footer ---------- */
	.footer_i1 .footer_top{
		padding: 0;
		height: 50px;
	}
	.footer_i1 .footer_top .ul .li{display: none;}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}
