@charset "UTF-8";
/* ==========================================================================
	root
========================================================================== */
:root {
  --base-text-color:#a46305;
  --base-link-color:#ec803e;
  --base-color-green:#b4df9c;
  --base-color-green02:#d6e9bf;
  --base-color-yellow:#ffef8f;
  --base-color-blue:#cfe6f6;
  --easeInQuad:cubic-bezier(.55, .085, .68, .53);
  --easeOutQuad:cubic-bezier(.25, .46, .45, .94);
  --easeOutSine:cubic-bezier(0.39, 0.575, 0.565, 1);
  --easeInOutQuad:cubic-bezier(0.45, 0, 0.55, 1);
  --easeInOutCubic:cubic-bezier(0.65, 0, 0.35, 1);
  --easePopUp:cubic-bezier(0.17, 0.88, 0.30, 1.28); }

/* ==========================================================================
	html
========================================================================== */
html.wf-active {
  visibility: visible; }

html {
  font: normal normal normal 62.5%/1  'Zen Maru Gothic','Noto Sans JP', "Noto Sans Japanese", "メイリオ", Meiryo, sans-serif;
  font-style: normal;
  font-weight: 400; }

body {
  margin: 0;
  padding: 0;
  background-color: #FFF;
  background-color: white;
  position: relative;
  color: var(--base-text-color);
  text-rendering: optimizeLegibility;
  -webkit-font-feature-settings: "palt" 1;
          font-feature-settings: "palt" 1;
  -webkit-text-size-adjust: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-kerning: normal;
  font-kerning: normal;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  letter-spacing: 0.03em;
  font-size: 62.5%; }

body.nav-open {
  overflow: hidden; }

/*
	htmlのフォントサイズは、下記のブラウザ幅では62.5%ではなくvwに。
	・1280px ~ 1024px
	・768px ~ 561px
	・375px ~
 */
@media screen and (max-width: 1280px) and (min-width: 1024px) {
  html {
    font-size: 0.78125vw; } }
@media screen and (max-width: 768px) and (min-width: 561px) {
  html {
    font-size: 1.30208vw; } }
@media screen and (max-width: 375px) {
  html {
    font-size: 2.66667vw; } }
button, input, select, textarea {
  font-family: inherit;
  font-size: 100%; }

a {
  color: var(--base-text-color);
  text-decoration: none;
  -webkit-transition: all 0.4s var(--easeOutQuad);
  transition: all 0.4s var(--easeOutQuad); }

a:hover,
.trns:hover {
  -webkit-transition: all 0.4s var(--easeOutQuad);
  transition: all 0.4s var(--easeOutQuad); }

input,
select,
textarea,
button,
*:before,
*:after {
  -webkit-transition: opacity 0.4s all var(--easeOutQuad);
  -webkit-transition: opacity 0.4s var(--easeOutQuad);
  transition: opacity 0.4s var(--easeOutQuad);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

a:focus,
input:focus,
select:focus,
textarea:focus,
button:focus {
  outline: none; }

img {
  width: 100%;
  vertical-align: bottom;
  -ms-interpolation-mode: bicubic;
  interpolation-mode: bicubic;
  -webkit-backface-visibility: hidden !Important; }

.pc_off {
  display: none !important; }

.sp_off {
  display: block !Important; }

img.preload {
  display: none; }

::-moz-selection {
  background: var(--theme-colorA); }

::selection {
  background: var(--theme-colorA); }

/* Safari */
::-moz-selection {
  background: var(--theme-colorA); }

.en {
  font-family: 'Quicksand', sans-serif; }

.all_wrap {
  position: relative;
  overflow: hidden;
  z-index: 100; }

@media (min-width: 851px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none; } }
@-webkit-keyframes fade {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes fade {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@-webkit-keyframes op {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@keyframes op {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
@-webkit-keyframes foot_tktk {
  0% {
    -webkit-transform: translateX(92vw) rotate(5deg);
            transform: translateX(92vw) rotate(5deg); }
  12.5% {
    -webkit-transform: translateX(80vw) rotate(-5deg);
            transform: translateX(80vw) rotate(-5deg); }
  25% {
    -webkit-transform: translateX(69vw) rotate(5deg);
            transform: translateX(69vw) rotate(5deg); }
  37.5% {
    -webkit-transform: translateX(57vw) rotate(-5deg);
            transform: translateX(57vw) rotate(-5deg); }
  50% {
    -webkit-transform: translateX(46vw) rotate(5deg);
            transform: translateX(46vw) rotate(5deg); }
  62.5% {
    -webkit-transform: translateX(34vw) rotate(-5deg);
            transform: translateX(34vw) rotate(-5deg); }
  75% {
    -webkit-transform: translateX(23vw) rotate(5deg);
            transform: translateX(23vw) rotate(5deg); }
  87.5% {
    -webkit-transform: translateX(11vw) rotate(-5deg);
            transform: translateX(11vw) rotate(-5deg); }
  100% {
    -webkit-transform: translateX(0) rotate(0deg);
            transform: translateX(0) rotate(0deg); } }
@keyframes foot_tktk {
  0% {
    -webkit-transform: translateX(92vw) rotate(5deg);
            transform: translateX(92vw) rotate(5deg); }
  12.5% {
    -webkit-transform: translateX(80vw) rotate(-5deg);
            transform: translateX(80vw) rotate(-5deg); }
  25% {
    -webkit-transform: translateX(69vw) rotate(5deg);
            transform: translateX(69vw) rotate(5deg); }
  37.5% {
    -webkit-transform: translateX(57vw) rotate(-5deg);
            transform: translateX(57vw) rotate(-5deg); }
  50% {
    -webkit-transform: translateX(46vw) rotate(5deg);
            transform: translateX(46vw) rotate(5deg); }
  62.5% {
    -webkit-transform: translateX(34vw) rotate(-5deg);
            transform: translateX(34vw) rotate(-5deg); }
  75% {
    -webkit-transform: translateX(23vw) rotate(5deg);
            transform: translateX(23vw) rotate(5deg); }
  87.5% {
    -webkit-transform: translateX(11vw) rotate(-5deg);
            transform: translateX(11vw) rotate(-5deg); }
  100% {
    -webkit-transform: translateX(0) rotate(0deg);
            transform: translateX(0) rotate(0deg); } }
/*
@media screen and (max-width : 800px ){
    
    @keyframes hamburger_top{
        0%{
            top: 14px;
        }
        50%{
            top: 20px;
            -webkit-transform:rotate(0);
            transform:rotate(0);
        }
        100%{
            top: 20px;
            -webkit-transform:rotate(30deg);
            transform:rotate(30deg);
        }
    }
    @keyframes hamburger_top_rev{
        0%{
            top: 20px;
            -webkit-transform:rotate(30deg);
            transform:rotate(30deg);
        }
        50%{
            top: 20px;
            -webkit-transform:rotate(0);
            transform:rotate(0);
        }
        100%{
            top: 14px;
            -webkit-transform:rotate(0);
            transform:rotate(0);
        }
    }
    @keyframes hamburger_bottom{
        0%{
            top: 25px;
        }
        50%{
            top: 20px;
            -webkit-transform:rotate(0);
            transform:rotate(0);
        }
        100%{
            top: 20px;
            -webkit-transform:rotate(-30deg);
            transform:rotate(-30deg);
        }
    }
    @keyframes hamburger_bottom_rev{
        0%{
            top: 20px;
        }
        50%{
            top: 20px;
            -webkit-transform:rotate(0);
            transform:rotate(0);
        }
        100%{
            top: 25px;
            -webkit-transform:rotate(0);
            transform:rotate(0);
        }
    }
}
*/
/* ==========================================================================
	ヘッダー
========================================================================== */
.head {
  position: absolute;
  left: 0;
  top: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 0 0 0 2.667%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  z-index: 150; }
  .head:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 130px;
    background: #fff;
    z-index: 1; }
  .head h1 {
    display: block;
    width: 264px;
    margin-top: 55px;
    z-index: 10;
    background: #fff; }
  .head .menu_area {
    position: relative;
    width: 850px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 55px;
    z-index: 10; }
    .head .menu_area .link {
      position: relative;
      display: inline-block;
      font-size: 17px;
      font-weight: 500;
      letter-spacing: 0; }
      .head .menu_area .link.link01:before, .head .menu_area .link.link02:before, .head .menu_area .link.link03:before {
        content: "";
        display: block;
        position: absolute;
        left: -8px;
        top: -6px;
        width: 66px;
        height: 32px;
        background-size: cover;
        z-index: -1; }
      .head .menu_area .link.link01:before {
        background-image: url(../image/common/menu_bg01.png); }
      .head .menu_area .link.link02:before {
        background-image: url(../image/common/menu_bg02.png); }
      .head .menu_area .link.link03:before {
        background-image: url(../image/common/menu_bg03.png); }
      .head .menu_area .link.link04 {
        margin-right: 0; }
      @media (hover: hover) {
        .head .menu_area .link:hover {
          color: var(--base-link-color); } }
  .head .hv_link_wrap {
    position: relative;
    display: inline-block;
    z-index: 50;
    /*
    &:hover{
        .hv_link_list{
            display: block;
            opacity:100;
            transition: all .4s ease;
        }
        
    }
    */ }
    .head .hv_link_wrap .hv_link_list {
      display: none;
      position: absolute;
      left: -57px;
      top: 60px;
      width: 750px;
      height: 160px;
      padding: 23px 50px 0;
      border-radius: 30px;
      background: #fff;
      border: 3px solid #ffef8f;
      -webkit-box-sizing: border-box;
              box-sizing: border-box; }
      .head .hv_link_wrap .hv_link_list:after {
        content: "";
        display: block;
        width: 29px;
        height: 19px;
        position: absolute;
        left: 80px;
        top: -19px;
        background: url(../image/common/hv_link_tar.png);
        background-size: cover;
        z-index: 50; }
      .head .hv_link_wrap .hv_link_list ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap; }
        .head .hv_link_wrap .hv_link_list ul li {
          width: 188px; }
          .head .hv_link_wrap .hv_link_list ul li a {
            display: block;
            position: relative;
            padding: 22px 0 15px;
            font-size: 17px;
            font-weight: 500;
            letter-spacing: 0.05em;
            padding-left: 20px;
            -webkit-box-sizing: border-box;
                    box-sizing: border-box; }
            .head .hv_link_wrap .hv_link_list ul li a:before {
              content: "";
              display: block;
              position: absolute;
              left: 0;
              top: 30px;
              width: 9px;
              height: 6px;
              background: url(../image/common/link_ar.png);
              background-size: cover; }
            .head .hv_link_wrap .hv_link_list ul li a:first-child:after {
              content: "";
              display: block;
              position: absolute;
              left: 0;
              bottom: -4px;
              width: 100%;
              height: 2px;
              background: url(../image/common/hv_link_dotted.jpg) left top repeat-x;
              background-size: 6px 4px; }
            @media (hover: hover) {
              .head .hv_link_wrap .hv_link_list ul li a:hover {
                color: var(--base-link-color); } }
  .head .hv_txt {
    position: relative;
    width: 88px;
    /*
    padding-right: 15px;
    */
    font-size: 17px;
    font-weight: 500;
    height: 50px; }
    .head .hv_txt:after {
      content: "▼";
      display: block;
      position: absolute;
      right: 0;
      top: 3px;
      font-size: 11px;
      font-weight: 500;
      color: #ec803e; }
  .head .b_menu_area {
    position: relative;
    width: 210px;
    height: 200px;
    text-align: center;
    padding-top: 52px;
    background: url(../image/common/b_menu_bg.jpg) center center repeat;
    background-size: 12px 12px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 0 0 0 70px;
    z-index: 10;
    -webkit-transition: height .4s ease,padding .4s ease;
    transition: height .4s ease,padding .4s ease; }
    @media (hover: hover) {
      .head .b_menu_area:hover {
        padding-top: 57px;
        height: 210px;
        -webkit-transition: height .4s ease,padding .4s ease;
        transition: height .4s ease,padding .4s ease; } }
  .head .b_menu_tit {
    position: relative;
    display: block;
    width: 96px;
    margin: 0 auto 8px; }
    .head .b_menu_tit .tab_on {
      display: none; }
  .head .sub.tab_off {
    display: block;
    text-align: center;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.12em;
    margin-bottom: 28px; }
  .head .b_menu_txt {
    position: relative;
    font-size: 15px;
    z-index: 10; }
    .head .b_menu_txt:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      right: 0;
      top: -13px;
      margin: auto;
      width: 122px;
      height: 44px;
      background: url(../image/common/b_menu_txt_bg.png);
      background-size: cover;
      z-index: -1; }

.global-nav,
.hamburger {
  display: none; }

@media screen and (max-width: 1400px) {
  .head .menu_area {
    width: calc(100% - 400px); }
  .head .b_menu_area {
    width: 75px;
    height: 171px;
    padding-top: 28px;
    background: #ffef8f;
    border-radius: 30px 0 0 30px;
    padding-left: 10px;
    margin-top: 20px;
    -webkit-transition: width .4s ease;
    transition: width .4s ease; }
    .head .b_menu_area:before {
      content: "";
      display: block;
      position: absolute;
      right: 0;
      top: 0;
      bottom: 0;
      margin: auto;
      width: calc(100% - 6px);
      height: calc(100% - 10px);
      background: url(../image/child/comic_bg.jpg) repeat;
      background-size: 8px 8px;
      border-top: 2px dotted #c87e12;
      border-left: 2px dotted #c87e12;
      border-bottom: 2px dotted #c87e12;
      border-radius: 25px 0 0 25px;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      z-index: 1; }
    .head .b_menu_area .tab_off {
      display: none; }
    .head .b_menu_area .tab_on {
      display: block; }
    .head .b_menu_area .b_menu_tit {
      width: 19px;
      z-index: 10; }
    .head .b_menu_area .sub {
      position: relative;
      font-size: 12px;
      font-weight: 700;
      z-index: 10;
      letter-spacing: 0.2em;
      padding-left: 5px;
      -webkit-box-sizing: border-box;
              box-sizing: border-box; }
      .head .b_menu_area .sub span {
        font-weight: 700; } }
  @media screen and (max-width: 1400px) and (hover: hover) {
    .head .b_menu_area:hover {
      padding-top: 28px;
      height: 171px;
      width: 85px;
      -webkit-transition: width .4s ease;
      transition: width .4s ease; } }

@media screen and (max-width: 1200px) {
  .head h1 {
    width: 193px;
    margin-top: 45px;
    background: none; }
  .head .menu_area {
    width: calc(100% - 258px);
    max-width: 595px;
    margin-left: 65px;
    margin-top: 40px; }
    .head .menu_area .link04 {
      position: absolute;
      left: 103px;
      top: 40px; }
  .head .hv_link_wrap {
    position: absolute;
    left: 0;
    top: 40px; }
    .head .hv_link_wrap .hv_link_list {
      left: -250px;
      top: 50px; }
      .head .hv_link_wrap .hv_link_list:after {
        left: 260px; } }
@media screen and (max-width: 980px) {
  .head {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start; }
    .head .b_menu_area {
      display: none; }
    .head .menu_area .link04 {
      position: absolute;
      left: 103px;
      top: 40px; }
    .head .menu_area .link05 {
      display: inline-block !Important;
      position: absolute;
      left: 177px;
      top: 40px; } }
@media screen and (max-width: 900px) {
  .head .menu_area {
    max-width: 395px; }
    .head .menu_area .link03 {
      position: absolute;
      left: 0;
      top: 40px; }
    .head .menu_area .link04 {
      left: 317px; }
    .head .menu_area .link05 {
      left: 387px;
      top: 40px;
      width: 70px; }
  .head .hv_link_wrap {
    left: 208px; }
    .head .hv_link_wrap .hv_link_list {
      left: -450px; }
      .head .hv_link_wrap .hv_link_list:after {
        left: 460px; } }
@media screen and (max-width: 800px) {
  .head {
    top: 25px;
    padding-left: calc(3vw + 15px); }
    .head:before {
      display: none; }
    .head h1 {
      width: 184px;
      margin-top: 0; }
    .head .menu_area {
      display: none; }

  /*ハンバーガーメニュー*/
  .global-nav {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-size: cover;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all .4s ease;
    transition: all .4s ease;
    background: #fffbf3;
    overflow: scroll;
    height: 100vh;
    height: 100svh; }
    .global-nav:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 0;
      z-index: -1;
      background: #fffbf3;
      height: 100vh;
      -webkit-transform: all .4s ease;
              transform: all .4s ease; }
    .global-nav .nav_inr {
      position: relative;
      width: 100%;
      padding-top: 165px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      -ms-flex-wrap: wrap;
      flex-wrap: wrap;
      height: 100vh;
      min-height: 850px;
      -webkit-box-sizing: border-box;
              box-sizing: border-box; }
      .global-nav .nav_inr h2 {
        position: absolute;
        left: 7.5%;
        top: 25px;
        width: 184px; }
      .global-nav .nav_inr .close_btn {
        display: block;
        position: absolute;
        right: calc(7.5% + 10px);
        top: 40px;
        width: 61px;
        height: 40px; }
      .global-nav .nav_inr span {
        display: block;
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        margin: auto;
        width: 100%;
        height: 2px;
        border-radius: 2px; }
        .global-nav .nav_inr span:first-child {
          -webkit-transform: rotate(15deg);
                  transform: rotate(15deg);
          background: #fac210; }
        .global-nav .nav_inr span:nth-child(2) {
          -webkit-transform: rotate(-15deg);
                  transform: rotate(-15deg);
          background: #c87e12; }
      .global-nav .nav_inr p {
        position: absolute;
        left: 0;
        bottom: 0; }
      .global-nav .nav_inr .menu_area {
        position: relative;
        width: 88%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        height: 440px;
        margin: 0 auto;
        background: url(../image/common/dotted.png) left top repeat-x;
        background-size: 3px 1px; }
        .global-nav .nav_inr .menu_area .link {
          position: relative;
          display: block;
          width: 100%;
          padding: 18px 18px 18px 24px;
          font-size: 15px;
          font-weight: 500;
          background: url(../image/common/dotted.png) left bottom repeat-x;
          background-size: 3px 1px;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box; }
          .global-nav .nav_inr .menu_area .link:before {
            content: "";
            display: block;
            position: absolute;
            left: 0;
            top: 22px;
            width: 11px;
            height: 7px;
            background: url(../image/common/link_ar.png);
            background-size: cover;
            -webkit-transition: -webkit-transform .4s ease;
            transition: -webkit-transform .4s ease;
            transition: transform .4s ease;
            transition: transform .4s ease, -webkit-transform .4s ease; }
        .global-nav .nav_inr .menu_area .s_link {
          position: relative;
          display: inline-block;
          width: 48%;
          padding: 18px 0 18px 24px;
          font-size: 14px;
          font-weight: 500;
          background: url(../image/common/dotted.png) center bottom repeat-x;
          background-size: 3px 1px;
          -webkit-box-sizing: border-box;
                  box-sizing: border-box; }
          .global-nav .nav_inr .menu_area .s_link:before {
            content: "";
            display: block;
            position: absolute;
            left: 0;
            top: 22px;
            width: 11px;
            height: 7px;
            background: url(../image/common/link_ar.png);
            background-size: cover;
            -webkit-transition: -webkit-transform .4s ease;
            transition: -webkit-transform .4s ease;
            transition: transform .4s ease;
            transition: transform .4s ease, -webkit-transform .4s ease; }
      .global-nav .nav_inr .nav_btm {
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 203px;
        background: url(../image/common/sp_menu_btm.jpg) center center;
        background-size: 800px 203px; }

  .nav-open .global-nav {
    visibility: inherit;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 100;
    -webkit-transition: all .4s ease;
    transition: all .4s ease; }
    .nav-open .global-nav:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 0;
      z-index: -1;
      background: #fffbf3;
      width: 100%;
      height: 100vh;
      -webkit-transform: all .4s ease;
              transform: all .4s ease; }

  .hamburger {
    display: block;
    /*
    position:fixed;
    */
    position: absolute;
    right: calc(3vw + 27px);
    top: 15px;
    width: 90px;
    height: 90px;
    cursor: pointer;
    z-index: 9997;
    opacity: 100;
    background: #ffef8f;
    border-radius: 15px 0 30px 30px;
    -webkit-transition: all .4s ease;
    transition: all .4s ease;
    /*
    &:hover{
        span:first-child {
            transform: translateY(-2px);
        }
        span:last-child {
            transform: translateY(2px);
        }
    }
    */ }
    .hamburger:before {
      content: "";
      display: block;
      position: absolute;
      right: -18px;
      top: 0;
      width: 18px;
      height: 8px;
      background: url(../image/common/hamburger_rt.png);
      background-size: cover;
      z-index: 5; }
    .hamburger:after {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      right: 0;
      bottom: 26px;
      width: 51px;
      height: 13px;
      margin: auto;
      background: url(../image/common/hamburger_menu.png);
      background-size: cover;
      z-index: 10; }
    .hamburger span {
      display: block;
      position: absolute;
      width: 50px;
      height: 2px;
      z-index: 5;
      left: 0;
      right: 0;
      margin: auto;
      top: 25px;
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; }
      .hamburger span:first-child:before {
        content: "";
        display: block;
        position: absolute;
        left: 0;
        top: 0;
        width: 38px;
        height: 2px;
        background: #a46305;
        border-radius: 2px; }
      .hamburger span:first-child:after {
        content: "";
        display: block;
        position: absolute;
        right: 0;
        top: 0;
        width: 10px;
        height: 2px;
        background: #fac210;
        border-radius: 2px; }
      .hamburger span:nth-child(2) {
        top: 32px;
        background: #c87e12;
        border-radius: 2px; }
      .hamburger span:nth-child(3) {
        top: 40px; }
        .hamburger span:nth-child(3):before {
          content: "";
          display: block;
          position: absolute;
          right: 0;
          top: 0;
          width: 38px;
          height: 2px;
          background: #a46305;
          border-radius: 2px; }
        .hamburger span:nth-child(3):after {
          content: "";
          display: block;
          position: absolute;
          left: 0;
          top: 0;
          width: 10px;
          height: 2px;
          background: #fac210;
          border-radius: 2px; }

  /*
  .nav-close{
      .hamburger span{
          &:nth-child(2){ top: 20px;}
          &:nth-child(3){ 
              top: 25px;
          }
      }
  }
  */ }
/* ==========================================================================
	h_mv
========================================================================== */
#h_mv {
  position: relative;
  width: 100%;
  height: 630px;
  padding-top: 130px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  z-index: 10; }
  #h_mv:before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 160px;
    background: #fffbf3;
    z-index: 1; }
  #h_mv .mv_inr {
    position: relative;
    width: 94.666%;
    height: 100%;
    margin: 0 auto;
    border-radius: 60px;
    background: #fff;
    z-index: 10; }
  #h_mv .tit_area {
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 20;
    width: 500px;
    height: 100px;
    padding: 45px 0 0 40px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 0 60px 0 0;
    background: #fffbf3; }
    #h_mv .tit_area:before, #h_mv .tit_area:after {
      content: "";
      display: block;
      width: 61px;
      height: 61px;
      position: absolute;
      background: url(../image/common/mask_lb_cream.png);
      background-size: cover; }
    #h_mv .tit_area:before {
      left: -1px;
      top: -60px; }
    #h_mv .tit_area:after {
      right: -58px;
      bottom: -1px; }
    #h_mv .tit_area h2 {
      display: inline-block;
      font-size: 40px;
      font-weight: 500;
      letter-spacing: -0.02em;
      margin-right: 12px; }
    #h_mv .tit_area p {
      display: inline-block;
      font-size: 15px;
      font-weight: 700;
      letter-spacing: 0.2em;
      -webkit-transform: translateY(-4px);
              transform: translateY(-4px); }
      #h_mv .tit_area p span {
        font-weight: 700;
        letter-spacing: 0.2em; }
  #h_mv .img_area {
    position: relative;
    height: 100%;
    border-radius: 60px;
    overflow: hidden;
    margin: 0 auto;
    z-index: 10; }
    #h_mv .img_area .lt {
      position: absolute;
      width: 330px;
      height: 110px;
      background: #fff;
      position: absolute;
      left: 0;
      top: 0;
      z-index: 10;
      border-radius: 0 0 60px 0; }
      #h_mv .img_area .lt:before {
        content: "";
        display: block;
        position: absolute;
        right: -61px;
        top: -1px;
        background: url(../image/common/mask_lt.png);
        background-size: cover;
        z-index: 10;
        width: 61px;
        height: 61px; }
      #h_mv .img_area .lt:after {
        content: "";
        display: block;
        position: absolute;
        left: -1px;
        bottom: -60px;
        background: url(../image/common/mask_lt.png);
        background-size: cover;
        z-index: 10;
        width: 61px;
        height: 61px; }
    #h_mv .img_area .img {
      position: absolute;
      left: 0;
      right: 0;
      top: 0;
      bottom: 0;
      margin: auto;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
         object-fit: cover;
      background-position: center center;
      background-size: cover; }
      #h_mv .img_area .img img {
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        margin: auto;
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
           object-fit: cover;
        background-position: center center;
        background-size: cover; }
  #h_mv .l_wave {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 7px;
    width: 243px;
    height: 200px;
    background: url(../image/common/h_mv_l_wave.png);
    background-size: cover;
    z-index: 2; }
  #h_mv .r_wave {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: 7px;
    width: 243px;
    height: 200px;
    background: url(../image/common/h_mv_r_wave.png);
    background-size: cover;
    z-index: 2; }

@media screen and (max-width: 1200px) {
  #h_mv .img_area .lt {
    width: 250px;
    height: 55px;
    border-radius: 0 0 30px 0; }
    #h_mv .img_area .lt:before {
      right: -30px;
      top: -1px;
      background-image: url(../image/common/mask_lt_tab.png);
      width: 31px;
      height: 31px; }
    #h_mv .img_area .lt:after {
      left: -1px;
      bottom: -30px;
      background-image: url(../image/common/mask_lt_tab.png);
      width: 31px;
      height: 31px; } }
@media screen and (max-width: 800px) {
  #h_mv {
    position: relative;
    width: 100%;
    height: 430px;
    padding-top: 22px; }
    #h_mv:before {
      height: 150px;
      background: #fffbf3; }
    #h_mv .mv_inr {
      width: 94%;
      border-radius: 30px;
      background: #fffbf3; }
    #h_mv .tit_area {
      position: absolute;
      left: 0;
      bottom: 0;
      z-index: 20;
      width: 85%;
      min-width: 320px;
      height: 60px;
      padding: 28px 0 0 18px;
      border-radius: 0 18px 0 0; }
      #h_mv .tit_area:before, #h_mv .tit_area:after {
        width: 31px;
        height: 31px; }
      #h_mv .tit_area:before {
        top: -30px; }
      #h_mv .tit_area:after {
        right: -29px;
        bottom: 10px; }
      #h_mv .tit_area h2 {
        font-size: 29px;
        margin-right: 16px; }
      #h_mv .tit_area p {
        font-size: 12px; }
    #h_mv .img_area {
      height: calc(100% - 10px);
      border-radius: 15px; }
      #h_mv .img_area .lt {
        width: 215px;
        height: 115px;
        border-radius: 0 0 60px 0; }
        #h_mv .img_area .lt:before {
          right: -30px;
          top: 0px;
          width: 30px;
          height: 30px; }
        #h_mv .img_area .lt:after {
          left: 0;
          bottom: -30px;
          width: 30px;
          height: 30px; }
    #h_mv .l_wave {
      bottom: 148px;
      width: 75px;
      height: 67px;
      background-image: url(../image/common/h_mv_l_wave_sp.png); }
    #h_mv .r_wave {
      bottom: 148px;
      width: 75px;
      height: 71px;
      background-image: url(../image/common/h_mv_r_wave_sp.png); } }
/* ==========================================================================
	footer
========================================================================== */
.footer {
  position: relative;
  padding-top: 80px;
  overflow: hidden; }
  .footer.top {
    padding-top: 140px; }
  .footer .inr_1300 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 45px; }
  .footer h2 {
    width: 267px; }
  .footer .link_area {
    width: 59.23%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: calc((40.77% - 237px)/2); }

	.footer .link_area .saiyou_bnr{
	 margin-top: 20px;
	}
	.footer .link_area .saiyou_bnr a{
	transition: 0.4s;
	}
	.footer .link_area .saiyou_bnr a:hover{
	transition: 0.4s;
	opacity: 0.6;
	}
	.footer .link_area .saiyou_bnr img{
	width: 100%;
	max-width: 296px;
	}


  .footer .area01 {
    width: 230px; }
  .footer .area02 {
    width: 330px; }
  .footer .area03 {
    width: 105px; }
  .footer .links {
    position: relative;
    display: block;
    padding-left: 24px;
    margin-bottom: 18px;
    font-size: 1.6rem;
    font-size: clamp(15px, 1.6rem, 18px);
    font-weight: 500;
    letter-spacing: 0.16em; }
    .footer .links:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 7px;
      width: 9px;
      height: 6px;
      background: url(../image/common/link_ar.png);
      background-size: cover;
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; }
    @media (hover: hover) {
      .footer .links:hover {
        color: var(--base-link-color); }
        .footer .links:hover:before {
          -webkit-transform: translateX(3px);
                  transform: translateX(3px);
          -webkit-transition: color .4s ease,-webkit-transform .4s ease;
          transition: color .4s ease,-webkit-transform .4s ease;
          transition: color .4s ease,transform .4s ease;
          transition: color .4s ease,transform .4s ease,-webkit-transform .4s ease; } }
  .footer .s_links {
    display: inline-block;
    width: 49.5%;
    font-size: 1.4rem;
    font-size: clamp(13px, 1.4rem, 16px);
    font-weight: 500;
    margin-bottom: 18px;
    letter-spacing: 0.16em;
    -webkit-transition: color .4s ease;
    transition: color .4s ease; }
    @media (hover: hover) {
      .footer .s_links:hover {
        color: var(--base-link-color);
        -webkit-transition: color .4s ease;
        transition: color .4s ease; } }
  .footer .copy {
    display: block;
    width: 12px;
    position: absolute;
    left: calc(100% + 12px);
    top: -7px;
    z-index: 10; }
  .footer .illust_area {
    position: relative;
    height: 285px; }
    .footer .illust_area:after {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 191px;
      background: url(../image/common/foot_illust_bg.png) bottom center repeat-x;
      background-size: 2440px,191px;
      z-index: 10; }
    .footer .illust_area .micchan {
      position: absolute;
      width: 199px;
      /*left: 8vw;*/
      right: calc(92vw - 199px);
      -webkit-transform: translateX(92vw);
              transform: translateX(92vw);
      bottom: 0;
      z-index: 20; }
    .footer .illust_area .twin {
      position: absolute;
      width: 165px;
      right: 9.33vw;
      top: 10px;
      z-index: 5;
      -webkit-transform: translateY(50px);
              transform: translateY(50px);
      opacity: 0; }
    .footer .illust_area .b-cho {
      position: absolute;
      width: 36px;
      left: 12vw;
      top: 7px;
      z-index: 5; }
    .footer .illust_area .y-cho {
      position: absolute;
      width: 27px;
      right: 5.33vw;
      top: 0;
      z-index: 15; }
    .footer .illust_area .monkey {
      position: absolute;
      width: 95px;
      left: 3.33vw;
      top: 68px;
      z-index: 5;
      -webkit-transform: translateY(50px);
              transform: translateY(50px);
      opacity: 0; }
    .footer .illust_area .risu {
      position: absolute;
      width: 77px;
      right: 2.8vw;
      top: 75px;
      z-index: 5;
      -webkit-transform: translateY(50px);
              transform: translateY(50px);
      opacity: 0; }
    .footer .illust_area.move .micchan {
      -webkit-animation: foot_tktk 1.3s steps(2) forwards;
              animation: foot_tktk 1.3s steps(2) forwards; }
    .footer .illust_area.move .twin {
      -webkit-transform: translateY(0);
              transform: translateY(0);
      opacity: 1;
      -webkit-transition: opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      transition: opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      transition: transform 0.4s var(--easePopUp), opacity 0.1s ease;
      transition: transform 0.4s var(--easePopUp), opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      -webkit-transition-delay: 1.3s;
              transition-delay: 1.3s; }
    .footer .illust_area.move .monkey {
      -webkit-transform: translateY(0);
              transform: translateY(0);
      opacity: 1;
      -webkit-transition: opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      transition: opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      transition: transform 0.4s var(--easePopUp), opacity 0.1s ease;
      transition: transform 0.4s var(--easePopUp), opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      -webkit-transition-delay: 1.4s;
              transition-delay: 1.4s; }
    .footer .illust_area.move .risu {
      -webkit-transform: translateY(0);
              transform: translateY(0);
      opacity: 1;
      -webkit-transition: opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      transition: opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      transition: transform 0.4s var(--easePopUp), opacity 0.1s ease;
      transition: transform 0.4s var(--easePopUp), opacity 0.1s ease, -webkit-transform 0.4s var(--easePopUp);
      -webkit-transition-delay: 1.5s;
              transition-delay: 1.5s; }

@media screen and (max-width: 1300px) {
  .footer .link_area {
    width: 64%; } }
@media screen and (max-width: 1200px) {
  .footer .inr_1300 {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between; }
  .footer .link_area {
    width: calc(100% - 290px);
    margin-left: 0; } }
@media screen and (max-width: 1000px) {
  .footer .area01,
  .footer .area02,
  .footer .area03 {
    width: 100%; }
.footer .link_area .saiyou_bnr img{
	width: 100%;
	max-width: 100%;
	}
}
@media screen and (max-width: 800px) {
  .footer {
    padding-top: 4rem; }
    .footer.top {
      padding-top: 5rem; }
    .footer .inr_1300 {
      display: block;
      margin-bottom: 28px; }
    .footer h2 {
      width: 218px;
      margin: 0 auto 50px; }
    .footer .link_area {
      display: block;
      width: 90%;
      margin: 0 auto; }
    .footer .area01, .footer .area02 {
      margin-bottom: 13px; }
    .footer .links {
      position: relative;
      display: inline-block;
      padding-left: 15px;
      margin-bottom: 18px;
      font-size: 1.3rem;
      font-size: clamp(12px, 1.3rem, 15px);
      letter-spacing: 0.1em; }
      .footer .links:before {
        left: -2px;
        top: 4px;
        width: 8px;
        height: 5px;
        background-image: url(../image/common/link_ar_sp.png); }
    .footer .area02 .links {
      display: block; }
    .footer .area01 a:nth-child(2),
    .footer .area03 a:nth-child(2) {
      margin-left: 18px; }
    .footer .s_links {
      display: inline-block;
      width: 48.5%;
      font-size: 1.3rem;
      font-size: clamp(12px, 1.3rem, 15px);
      font-weight: 500;
      margin-bottom: 14px; }
    .footer .copy {
      display: block;
      width: 12px;
      position: absolute;
      left: calc(100% + 12px);
      top: -7px;
      z-index: 10; }
    .footer .illust_area {
      position: relative;
      height: auto; }
      .footer .illust_area:after {
        display: none; }
    .footer .copy_area {
      position: relative;
      background: #b4df9c;
      padding: 15px 0 45px;
      text-align: center; }
      .footer .copy_area p {
        display: inline-block;
        width: 118px; } }
/* ==========================================================================
	inview
========================================================================== */
.inview.bt {
  opacity: 0;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: all 0.5s var(--easePopUp);
  transition: all 0.5s var(--easePopUp); }

.inview.bt.move {
  opacity: 100;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: all 0.6s var(--easePopUp);
  transition: all 0.6s var(--easePopUp);
  /*
  transition-delay: .2s;
  */ }

.inview.rl {
  -webkit-transform: translateX(-80px);
          transform: translateX(-80px);
  opacity: 0;
  -webkit-transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
  -webkit-transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
  transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
  transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
  transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad); }

.inview.rl.move {
  -webkit-transform: translateX(0);
          transform: translateX(0);
  opacity: 100;
  -webkit-transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
  -webkit-transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
  transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
  transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
  transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad); }

@media screen and (max-width: 800px) {
  .inview.rl {
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
    opacity: 0;
    -webkit-transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
    -webkit-transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
    transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
    transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
    transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad); }

  .inview.rl.move {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 100;
    -webkit-transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
    -webkit-transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
    transition: opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad);
    transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad);
    transition: transform 0.5s var(--easeOutQuad), opacity 0.5s var(--easeOutQuad), -webkit-transform 0.5s var(--easeOutQuad); } }
/* ==========================================================================
	parts
========================================================================== */
.con_inr {
  position: relative;
  margin: 0 auto; }

.inr_1380 {
  position: relative;
  width: 92%;
  max-width: 1766px;
  margin: 0 auto; }

.inr_1300 {
  position: relative;
  width: 86.66%;
  max-width: 1620px;
  margin: 0 auto; }

.inr_1260 {
  position: relative;
  width: 84%;
  max-width: 1612px;
  margin: 0 auto; }

.bra {
  color: #c87e12; }

@media screen and (max-width: 800px) {
  .inr_1120,
  .inr_1300 {
    width: 88%; } }
.link_btn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 493px;
  height: 70px;
  border-radius: 70px;
  border: 5px solid #fff;
  background: #fff;
  -webkit-box-shadow: 6px 6px 0px 0px #fff19a;
          box-shadow: 6px 6px 0px 0px #fff19a;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transition: -webkit-transform .4s ease,-webkit-box-shadow .4s ease;
  transition: -webkit-transform .4s ease,-webkit-box-shadow .4s ease;
  transition: transform .4s ease,box-shadow .4s ease;
  transition: transform .4s ease,box-shadow .4s ease,-webkit-transform .4s ease,-webkit-box-shadow .4s ease; }
  .link_btn.blue {
    -webkit-box-shadow: 6px 6px 0px 0px #cfe6f6;
            box-shadow: 6px 6px 0px 0px #cfe6f6; }
  .link_btn.green {
    -webkit-box-shadow: 6px 6px 0px 0px #daebc5;
            box-shadow: 6px 6px 0px 0px #daebc5; }
  .link_btn:before {
    content: "";
    display: block;
    position: absolute;
    width: calc(100% - 5px);
    height: calc(100% - 5px);
    border-radius: 70px;
    border: 2px dotted #f6ce69; }
  .link_btn span {
    position: relative;
    display: inline-block;
    font-size: 1.9rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    z-index: 10;
    padding-left: 26px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-transition: color .4s ease;
    transition: color .4s ease; }
    .link_btn span:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 7px;
      width: 11px;
      height: 7px;
      background: url(../image/common/link_ar.png);
      background-size: cover;
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; }
  @media (hover: hover) {
    .link_btn:hover {
      -webkit-transform: translate(6px, 6px);
              transform: translate(6px, 6px);
      -webkit-box-shadow: none;
              box-shadow: none;
      -webkit-transition: -webkit-transform .4s ease,-webkit-box-shadow .4s ease;
      transition: -webkit-transform .4s ease,-webkit-box-shadow .4s ease;
      transition: transform .4s ease,box-shadow .4s ease;
      transition: transform .4s ease,box-shadow .4s ease,-webkit-transform .4s ease,-webkit-box-shadow .4s ease; }
      .link_btn:hover span {
        color: var(--base-link-color);
        -webkit-transition: color .4s ease;
        transition: color .4s ease; }
      .link_btn:hover span:before {
        -webkit-transform: translateX(3px);
                transform: translateX(3px);
        -webkit-transition: -webkit-transform .4s ease;
        transition: -webkit-transform .4s ease;
        transition: transform .4s ease;
        transition: transform .4s ease, -webkit-transform .4s ease; } }

.s_link_btn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 198px;
  height: 68px;
  border-radius: 30px;
  background: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }
  .s_link_btn:before {
    content: "";
    display: block;
    position: absolute;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    border-radius: 30px;
    border: 2px dotted #f6ce69; }
  .s_link_btn span {
    position: relative;
    display: inline-block;
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    z-index: 10;
    -webkit-transform: translateY(-2px);
            transform: translateY(-2px);
    padding-left: 24px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-transition: color .4s ease;
    transition: color .4s ease; }
    .s_link_btn span:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 7px;
      width: 11px;
      height: 7px;
      background: url(../image/common/link_ar.png);
      background-size: cover;
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; }
  @media (hover: hover) {
    .s_link_btn:hover span {
      color: var(--base-link-color);
      -webkit-transition: color .4s ease;
      transition: color .4s ease; }
    .s_link_btn:hover span:before {
      -webkit-transform: translateX(3px);
              transform: translateX(3px);
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; } }

.c_link_btn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 120px;
  height: 120px;
  border-radius: 120px;
  background: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }
  .c_link_btn:before {
    content: "";
    display: block;
    position: absolute;
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    border-radius: 50%;
    border: 2px dotted #f6ce69; }
  .c_link_btn span {
    position: relative;
    display: inline-block;
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    z-index: 10;
    padding-left: 24px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-transition: color .4s ease;
    transition: color .4s ease; }
    .c_link_btn span:before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 7px;
      width: 11px;
      height: 7px;
      background: url(../image/common/link_ar.png);
      background-size: cover;
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; }
  @media (hover: hover) {
    .c_link_btn:hover span {
      color: var(--base-link-color);
      -webkit-transition: color .4s ease;
      transition: color .4s ease; }
    .c_link_btn:hover span:before {
      -webkit-transform: translateX(3px);
              transform: translateX(3px);
      -webkit-transition: -webkit-transform .4s ease;
      transition: -webkit-transform .4s ease;
      transition: transform .4s ease;
      transition: transform .4s ease, -webkit-transform .4s ease; } }

@media screen and (max-width: 800px) {
  .link_btn {
    -webkit-box-shadow: 3px 3px 0px 0px #fff19a;
            box-shadow: 3px 3px 0px 0px #fff19a; }
    .link_btn.blue {
      -webkit-box-shadow: 3px 3px 0px 0px #cfe6f6;
              box-shadow: 3px 3px 0px 0px #cfe6f6; }
    .link_btn.green {
      -webkit-box-shadow: 3px 3px 0px 0px #daebc5;
              box-shadow: 3px 3px 0px 0px #daebc5; }
    .link_btn span {
      font-size: 1.7rem;
      font-size: clamp(16px, 1.7rem, 18px);
      padding-left: 12px; }
      .link_btn span:before {
        left: -10px;
        top: 6px; }

  .s_link_btn {
    width: 100%;
    height: 65px;
    border-radius: 33px; }
    .s_link_btn:before {
      width: calc(100% - 12px);
      height: calc(100% - 12px);
      border-radius: 33px; }
    .s_link_btn span {
      font-size: 1.6rem;
      font-size: clamp(15px, 1.6rem, 17px);
      padding-left: 10px; }
      .s_link_btn span:before {
        left: -11px;
        top: 6px; }

  .c_link_btn {
    width: 100px;
    height: 100px;
    border-radius: 100px; }
    .c_link_btn:before {
      width: calc(100% - 12px);
      height: calc(100% - 12px); }
    .c_link_btn span {
      font-size: 1.4rem;
      font-size: clamp(13px, 1.4rem, 16px);
      padding-left: 8px; }
      .c_link_btn span:before {
        width: 7px;
        height: 5px;
        left: -7px;
        top: 6px; } }
.fit_img {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  background-position: center center;
  background-size: cover;
  z-index: 1;
  -webkit-transition: -webkit-transform ease .4s;
  transition: -webkit-transform ease .4s;
  transition: transform ease .4s;
  transition: transform ease .4s, -webkit-transform ease .4s; }

.img_area {
  z-index: 10; }

.v_txt {
  writing-mode: vertical-rl;
  -webkit-font-feature-settings: normal;
          font-feature-settings: normal;
  vertical-align: top;
  display: inline-block;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -o-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
  letter-spacing: 0.2em; }

@media screen and (max-width: 800px) {
  .pc_off {
    display: block !Important; }

  .sp_off {
    display: none !important; }

  .sp_move_off {
    -webkit-transform: translate(0) !important;
            transform: translate(0) !important; }

  .spy_txt {
    -ms-writing-mode: lr-tb;
        writing-mode: horizontal-tb;
    -webkit-font-feature-settings: normal;
            font-feature-settings: normal;
    display: inline-block;
    -webkit-writing-mode: horizontal-tb; }

  .spv_txt {
    writing-mode: vertical-rl;
    -webkit-font-feature-settings: normal;
            font-feature-settings: normal;
    vertical-align: top;
    display: inline-block;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    -o-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    letter-spacing: 0.2em; } }

/*# sourceMappingURL=common.css.map */