@charset "UTF-8";
@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}

.pc-none {
  display: none !important;
}
@media (max-width: 750px) {
  .pc-none {
    display: block !important;
  }
}

/*--------------------------
reset
--------------------------*/
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
button,
textarea,
select,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset,
img {
  border: 0;
}

address,
button,
caption,
cite,
code,
dfn,
em,
input,
optgroup,
option,
select,
strong,
textarea,
th,
var {
  font: inherit;
}

del,
ins {
  text-decoration: none;
}

li {
  list-style: none;
}

caption,
th {
  text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
}

q:before,
q:after {
  content: "";
}

abbr,
acronym {
  border: 0;
  font-variant: normal;
}

sup {
  vertical-align: baseline;
}

sub {
  vertical-align: baseline;
}

legend {
  color: #000;
}

select,
input,
textarea,
button {
  font: 99% arial, helvetica, clean, sans-serif;
}

table {
  font-size: inherit;
  font: 100%;
}

pre,
code,
kbd,
samp,
tt {
  font-family: monospace;
  *font-size: 108%;
  line-height: 100%;
}

img {
  font-size: 0;
  vertical-align: middle;
  line-height: 1;
}

a {
  overflow: hidden;
  outline: none;
}

body {
  font-family: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  color: #333;
  -webkit-text-size-adjust: 100%;
  -ms-overflow-style: auto;
  overflow-y: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

body::-webkit-scrollbar {
  display: none;
}

/*font
--------------------*/
body {
  position: relative;
  font-size: 14px;
  line-height: 1.5;
  background-color: #ffffff;
}

* {
  box-sizing: border-box;
}

.base-inner {
  position: relative;
  margin: 0 auto;
  width: 100%;
}

a:hover {
  position: static;
  opacity: 0.7;
  z-index: 1000;
}

@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}

.pc-none {
  display: none;
}
@media (max-width: 750px) {
  .pc-none {
    display: block;
  }
}

@font-face {
  font-family: "SourceHanSansJP";
  src: url("/assets/font/SourceHanSans-Regular.woff2") format("woff");
}
@font-face {
  font-family: "SourceHanSansJP-Bold";
  src: url("/assets/font/SourceHanSans-Bold.woff2") format("woff");
}
body {
  font-family: "SourceHanSansJP";
}

img {
  width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  color: #000;
}

.blank {
  padding-bottom: 2000px;
}

@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}
.pc-none {
  display: none !important;
}

@media (max-width: 750px) {
  .pc-none {
    display: block !important;
  }
}
/* =======================================================
  Liquid Pixel
  widthの比率で拡大縮小
========================================================= */
html {
  scroll-behavior: smooth;
}

.first-view {
  height: 100vh;
  position: relative;
}
.first-view .fade-in {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: #000000;
  overflow: hidden;
  z-index: 4;
  position: fixed;
}
.first-view .fade-in .fade-in-element {
  width: 100%;
  display: none;
  transform: translate(0%, calc(-40 / 1280 * 100vw));
  aspect-ratio: 8/5;
  animation: fadeInOut 4s ease-in-out forwards;
}
@media (max-width: 750px) {
  .first-view .fade-in .fade-in-element {
    transform: translate(0%, 0%);
    top: 12%;
    position: relative;
    aspect-ratio: unset;
  }
}
@keyframes fadeInOut {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.first-view .copy-right {
  position: fixed;
  z-index: 1;
  top: 24px;
  left: 32px;
  font-size: 12px;
  font-family: "SourceHanSansJP-Bold";
  color: #000000;
}
@media (max-width: 750px) {
  .first-view .copy-right {
    top: auto;
    bottom: 18px;
    margin-bottom: 13px;
  }
}
.first-view .main-visual-text {
  position: fixed;
  z-index: 1;
  top: 213px;
  right: calc(20 / 1280 * 100vw);
  width: calc(20 / 1280 * 100vw);
  height: calc(294 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .first-view .main-visual-text {
    top: calc(48 / 390 * 100vw);
    width: calc(20 / 390 * 100vw);
  }
}
.first-view .logo {
  position: fixed;
  z-index: 1;
  bottom: calc(11 / 1280 * 100vw);
  left: calc(22 / 1280 * 100vw);
  width: calc(257 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .first-view .logo {
    width: 42.8571428571vw;
    bottom: auto;
    top: 2px;
  }
}
.first-view .note {
  position: fixed;
  z-index: 1;
  align-items: center;
  max-width: calc(164 / 1280 * 100vw);
  width: 100%;
  justify-content: space-between;
  bottom: calc(19 / 1280 * 100vw);
  right: calc(20 / 1280 * 100vw);
  display: flex;
}
@media (max-width: 750px) {
  .first-view .note {
    max-width: calc(164 / 390 * 100vw);
    bottom: calc(20 / 390 * 100vw);
    right: calc(20 / 390 * 100vw);
  }
}
.first-view .note .note-logo {
  width: calc(112 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .first-view .note .note-logo {
    width: calc(112 / 390 * 100vw);
  }
}
.first-view .note .instagram {
  width: calc(39 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .first-view .note .instagram {
    width: calc(39 / 390 * 100vw);
  }
}
.first-view .video-area {
  position: fixed;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  height: 100vh;
  min-height: 100%;
  min-width: 100%;
}
@media (max-width: 750px) {
  .first-view .video-area {
    width: 100%;
    top: 54%;
  }
}

@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}
.pc-none {
  display: none !important;
}

@media (max-width: 750px) {
  .pc-none {
    display: block !important;
  }
}
/* =======================================================
  Liquid Pixel
  widthの比率で拡大縮小
========================================================= */
.company-content {
  background-color: #ffffff;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

.company-intro {
  max-width: calc(580 / 1280 * 100vw);
  width: 100%;
  margin: 0 auto;
  padding-top: calc(243 / 1280 * 100vw);
  padding-bottom: calc(221 / 1280 * 100vw);
  line-height: 2;
}
@media (max-width: 750px) {
  .company-intro {
    padding-top: calc(202 / 390 * 100vw);
    padding-bottom: calc(115 / 390 * 100vw);
    max-width: calc(280 / 390 * 100vw);
  }
}
.company-intro .company-introduction-main {
  font-size: calc(20 / 1280 * 100vw);
  font-family: "SourceHanSansJP-Bold";
}
@media (max-width: 750px) {
  .company-intro .company-introduction-main {
    font-size: calc(19 / 390 * 100vw);
    margin-bottom: calc(147 / 390 * 100vw);
  }
}
.company-intro .company-introduction-sub {
  font-size: calc(16 / 1280 * 100vw);
  font-family: "SourceHanSansJP-Bold";
  max-width: calc(496 / 1280 * 100vw);
  margin-top: calc(51 / 1280 * 100vw);
  margin-bottom: calc(40 / 1280 * 100vw);
}
.company-intro .company-introduction-sub:last-child {
  margin-top: 0;
  margin-bottom: 0;
}
@media (max-width: 750px) {
  .company-intro .company-introduction-sub {
    max-width: calc(280 / 390 * 100vw);
    font-size: calc(15 / 390 * 100vw);
    margin-top: calc(20 / 390 * 100vw);
    margin-bottom: calc(40 / 390 * 100vw);
  }
}

#company-intro-left-image {
  position: absolute;
  top: calc(24 / 1280 * 100vw);
  left: calc(-506 / 1280 * 100vw);
  width: calc(809 / 1280 * 100vw);
  z-index: -1;
}
@media (max-width: 750px) {
  #company-intro-left-image {
    width: calc(380 / 390 * 100vw);
    left: calc(-355 / 390 * 100vw);
    top: calc(376 / 390 * 100vw);
  }
}

#company-intro-right-image {
  position: absolute;
  top: calc(80 / 1280 * 100vw);
  right: calc(-400 / 1280 * 100vw);
  width: calc(635 / 1280 * 100vw);
  z-index: -1;
}
@media (max-width: 750px) {
  #company-intro-right-image {
    width: calc(296 / 390 * 100vw);
    right: calc(-260 / 390 * 100vw);
    top: calc(50 / 390 * 100vw);
  }
}

@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}
.pc-none {
  display: none !important;
}

@media (max-width: 750px) {
  .pc-none {
    display: block !important;
  }
}
/* =======================================================
  Liquid Pixel
  widthの比率で拡大縮小
========================================================= */
.three-element-content {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: calc(52 / 1280 * 100vw);
  max-width: calc(960 / 1280 * 100vw);
  width: 100%;
  margin: 0 auto;
  padding-top: calc(180 / 1280 * 100vw);
  padding-bottom: calc(177 / 1280 * 100vw);
  position: relative;
}
@media (max-width: 750px) {
  .three-element-content {
    grid-template-columns: 1fr;
    gap: calc(74 / 390 * 100vw);
    max-width: calc(280 / 390 * 100vw);
    padding-top: calc(141 / 390 * 100vw);
    padding-bottom: calc(177 / 390 * 100vw);
  }
}
.three-element-content .three-element-item .three-element-title {
  margin: 0 auto calc(48 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .three-element-content .three-element-item .three-element-title {
    margin-bottom: calc(32 / 390 * 100vw);
  }
}
.three-element-content .three-element-item .music {
  max-width: calc(165 / 1280 * 100vw);
  width: 100%;
}
@media (max-width: 750px) {
  .three-element-content .three-element-item .music {
    margin-top: 0;
    max-width: calc(165 / 390 * 100vw);
  }
}
.three-element-content .three-element-item .d2c {
  max-width: calc(100 / 1280 * 100vw);
  margin-top: calc(100 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .three-element-content .three-element-item .d2c {
    margin-top: 0;
    max-width: calc(100 / 390 * 100vw);
  }
}
.three-element-content .three-element-item .sns {
  max-width: calc(96 / 1280 * 100vw);
  margin-top: calc(200 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .three-element-content .three-element-item .sns {
    margin-top: 0;
    max-width: calc(96 / 390 * 100vw);
  }
}
.three-element-content .three-element-item .three-element-main-text {
  font-size: calc(16 / 1280 * 100vw);
  font-family: "SourceHanSansJP-Bold";
  line-height: 1.75;
  margin-bottom: calc(26 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .three-element-content .three-element-item .three-element-main-text {
    font-size: calc(16 / 390 * 100vw);
    margin-bottom: calc(16 / 390 * 100vw);
  }
}
.three-element-content .three-element-item .three-element-sub-text {
  font-size: calc(12 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .three-element-content .three-element-item .three-element-sub-text {
    font-size: calc(15 / 390 * 100vw);
  }
}

#three-element-top-image {
  position: absolute;
  width: calc(1080 / 1280 * 100vw);
  top: calc(-400 / 1280 * 100vw);
  right: calc(-680 / 1280 * 100vw);
  z-index: -1;
}
@media (max-width: 750px) {
  #three-element-top-image {
    width: calc(480 / 390 * 100vw);
    top: calc(-160 / 390 * 100vw);
    right: calc(-480 / 390 * 100vw);
  }
}

#three-element-bottom-left-image {
  position: absolute;
  z-index: -1;
  left: calc(-720 / 1280 * 100vw);
  bottom: calc(-160 / 1280 * 100vw);
  width: calc(900 / 1280 * 100vw);
}
@media (max-width: 750px) {
  #three-element-bottom-left-image {
    display: none;
  }
}

#sp-right-image {
  display: none;
}
@media (max-width: 750px) {
  #sp-right-image {
    display: block;
    position: absolute;
    width: calc(510 / 390 * 100vw);
    right: calc(-520 / 390 * 100vw);
    bottom: calc(460 / 390 * 100vw);
    left: auto;
    z-index: -1;
  }
}

#three-element-bottom-right-image {
  position: absolute;
  bottom: calc(-320 / 1280 * 100vw);
  right: calc(-680 / 1280 * 100vw);
  width: calc(712 / 1280 * 100vw);
  z-index: -1;
}
@media (max-width: 750px) {
  #three-element-bottom-right-image {
    width: calc(316 / 390 * 100vw);
    left: calc(-180 / 390 * 100vw);
  }
}

@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}
.pc-none {
  display: none !important;
}

@media (max-width: 750px) {
  .pc-none {
    display: block !important;
  }
}
/* =======================================================
  Liquid Pixel
  widthの比率で拡大縮小
========================================================= */
.company-overview-content {
  display: grid;
  justify-items: center;
  grid-template-columns: 1fr 1fr;
  gap: calc(114 / 1280 * 100vw);
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding-top: calc(192 / 1280 * 100vw);
  padding-bottom: calc(196 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .company-overview-content {
    grid-template-columns: 1fr;
    gap: calc(220 / 390 * 100vw);
    padding-top: calc(147 / 390 * 100vw);
    padding-bottom: calc(97 / 390 * 100vw);
    max-width: calc(204 / 390 * 100vw);
    width: 100%;
  }
}
.company-overview-content .works {
  max-width: calc(430 / 390 * 100vw);
  width: 100%;
}
@media (max-width: 750px) {
  .company-overview-content .works {
    max-width: calc(204 / 390 * 100vw);
  }
}
.company-overview-content .works .works-title {
  width: calc(137 / 1280 * 100vw);
  margin: 0 auto;
}
@media (max-width: 750px) {
  .company-overview-content .works .works-title {
    width: calc(137 / 390 * 100vw);
  }
}
.company-overview-content .works .works-group {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: calc(20 / 1280 * 100vw) calc(18 / 1280 * 100vw);
  margin-top: calc(52 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .company-overview-content .works .works-group {
    grid-template-columns: 1fr;
    gap: calc(26 / 1280 * 100vw) 0;
    margin-top: calc(36 / 390 * 100vw);
  }
}
.company-overview-content .works .works-group .works-group-item {
  max-width: calc(204 / 1280 * 100vw);
  width: 100%;
}
@media (max-width: 750px) {
  .company-overview-content .works .works-group .works-group-item {
    max-width: calc(204 / 390 * 100vw);
  }
}
.company-overview-content .works .works-group .works-group-item .thumbnail {
  height: calc(106 / 1280 * 100vw);
  display: block;
  -o-object-fit: contain;
  object-fit: contain;
}
@media (max-width: 750px) {
  .company-overview-content .works .works-group .works-group-item .thumbnail {
    height: calc(106 / 390 * 100vw);
  }
}
.company-overview-content .works .works-group .works-group-item .works-group-item-text {
  color: #5d5d5d;
  font-size: calc(14 / 1280 * 100vw);
  margin-top: calc(12 / 1280 * 100vw);
  cursor: pointer;
}
@media (max-width: 750px) {
  .company-overview-content .works .works-group .works-group-item .works-group-item-text {
    font-size: calc(14 / 390 * 100vw);
    margin-top: calc(12 / 390 * 100vw);
  }
}
.company-overview-content .works .works-group::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: calc(100 / 1280 * 100vw);
  width: 100%;
  background-image: linear-gradient(180deg, rgba(255, 255, 255, 0), rgb(255, 255, 255) 85%);
  pointer-events: none;
}
.company-overview-content .works .works-link-group {
  font-size: calc(20 / 1280 * 100vw);
  text-align: center;
  margin-top: calc(3 / 1280 * 100vw);
}
.company-overview-content .works .works-link-group a {
  color: #000000;
}
@media (max-width: 750px) {
  .company-overview-content .works .works-link-group {
    font-size: calc(20 / 390 * 100vw);
    margin-top: calc(23 / 390 * 100vw);
  }
}
.company-overview-content .company {
  max-width: calc(210 / 1280 * 100vw);
  width: 100%;
}
@media (max-width: 750px) {
  .company-overview-content .company {
    max-width: calc(210 / 390 * 100vw);
  }
}
.company-overview-content .company .company-title {
  width: calc(192 / 1280 * 100vw);
  margin: 0 auto;
}
@media (max-width: 750px) {
  .company-overview-content .company .company-title {
    width: calc(192 / 390 * 100vw);
  }
}
.company-overview-content .company .company-group {
  margin-top: calc(52 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .company-overview-content .company .company-group {
    margin-top: calc(52 / 390 * 100vw);
  }
}
.company-overview-content .company .company-group tr th,
.company-overview-content .company .company-group tr td {
  display: block;
}
.company-overview-content .company .company-group tr .company-group-item {
  font-size: calc(12 / 1280 * 100vw);
  font-family: "SourceHanSansJP-Bold";
}
@media (max-width: 750px) {
  .company-overview-content .company .company-group tr .company-group-item {
    font-size: calc(12 / 390 * 100vw);
  }
}
.company-overview-content .company .company-group tr .company-group-text {
  font-size: calc(16 / 1280 * 100vw);
  padding-bottom: calc(31 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .company-overview-content .company .company-group tr .company-group-text {
    font-size: calc(16 / 390 * 100vw);
    padding-bottom: calc(31 / 390 * 100vw);
  }
}

#company-overview-content {
  position: relative;
}

@media (max-width: 750px) {
  .sp-none {
    display: none !important;
  }
}
.pc-none {
  display: none !important;
}

@media (max-width: 750px) {
  .pc-none {
    display: block !important;
  }
}
/* =======================================================
  Liquid Pixel
  widthの比率で拡大縮小
========================================================= */
.contact {
  position: relative;
  overflow: hidden;
  width: 100%;
  background-color: #000000;
  animation: fade-up ease forwards;
  animation-timeline: view();
  animation-range: cover 0% cover 100%;
}
@keyframes fade-up {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-100px);
  }
}
.contact .contact-content {
  max-width: calc(480 / 1280 * 100vw);
  width: 100%;
  margin: 0 auto;
  padding-top: calc(81 / 1280 * 100vw);
  padding-bottom: calc(86 / 1280 * 100vw);
  color: #ffffff;
}
@media (max-width: 750px) {
  .contact .contact-content {
    max-width: calc(318 / 390 * 100vw);
    padding-top: calc(216 / 390 * 100vw);
    padding-bottom: calc(179 / 390 * 100vw);
  }
}
.contact .contact-content .contact-title {
  font-size: calc(16 / 1280 * 100vw);
  font-family: "SourceHanSansJP-Bold";
  margin-bottom: calc(6 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .contact .contact-content .contact-title {
    font-size: calc(16 / 390 * 100vw);
    margin-bottom: calc(17 / 390 * 100vw);
  }
}
.contact .contact-content .contact-explanation {
  font-size: calc(14 / 1280 * 100vw);
  margin-bottom: calc(29 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .contact .contact-content .contact-explanation {
    font-size: calc(13 / 390 * 100vw);
    margin-bottom: calc(36 / 390 * 100vw);
  }
}
.contact .contact-content form .contact-item {
  display: flex;
  flex-flow: column;
  margin-bottom: calc(16 / 1280 * 100vw);
  font-family: "SourceHanSansJP-Bold";
}
@media (max-width: 750px) {
  .contact .contact-content form .contact-item {
    margin-bottom: calc(16 / 390 * 100vw);
  }
}
.contact .contact-content form .contact-item .required::after {
  content: "＊";
  color: #ff0000;
  vertical-align: baseline;
  font-size: calc(14 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .contact .contact-content form .contact-item .required::after {
    font-size: calc(14 / 390 * 100vw);
  }
}
.contact .contact-content form .contact-item .contact-input {
  margin-top: calc(6 / 1280 * 100vw);
  padding: calc(12 / 1280 * 100vw) 0 calc(12 / 1280 * 100vw) calc(16 / 1280 * 100vw);
  border-radius: 8px;
  border: none;
}
@media (max-width: 750px) {
  .contact .contact-content form .contact-item .contact-input {
    margin-top: calc(6 / 390 * 100vw);
    padding: calc(12 / 390 * 100vw) 0 calc(12 / 390 * 100vw) calc(16 / 390 * 100vw);
  }
}
.contact .contact-content form .contact-item .contact-input::-moz-placeholder {
  color: #cccccc;
}
.contact .contact-content form .contact-item .contact-input::placeholder {
  color: #cccccc;
}
.contact .contact-content form .submit-group {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: calc(8 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group {
    flex-flow: column;
    align-items: start;
    margin-top: calc(8 / 390 * 100vw);
  }
}
.contact .contact-content form .submit-group .submit-group-check {
  display: flex;
  align-items: center;
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group .submit-group-check {
    margin-left: 0;
  }
}
.contact .contact-content form .submit-group .submit-group-check .check-box {
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: calc(16 / 1280 * 100vw);
  height: calc(16 / 1280 * 100vw);
  margin-right: calc(8 / 1280 * 100vw);
  border-radius: 4px !important;
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group .submit-group-check .check-box {
    width: calc(16 / 390 * 100vw);
    height: calc(16 / 390 * 100vw);
    margin-right: calc(8 / 390 * 100vw);
  }
}
.contact .contact-content form .submit-group .submit-group-check .check-box::before {
  display: block;
  position: absolute;
  content: "";
  background: #fff;
  width: calc(16 / 1280 * 100vw);
  height: calc(16 / 1280 * 100vw);
  border-radius: 4px !important;
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group .submit-group-check .check-box::before {
    width: calc(16 / 390 * 100vw);
    height: calc(16 / 390 * 100vw);
  }
}
.contact .contact-content form .submit-group .submit-group-check .check-box:checked::before {
  background-color: blue;
}
.contact .contact-content form .submit-group .submit-group-check .check-box::after {
  display: block;
  content: "";
  position: absolute;
  left: calc(5 / 1280 * 100vw);
  top: calc(1 / 1280 * 100vw);
  width: calc(4 / 1280 * 100vw);
  height: calc(10 / 1280 * 100vw);
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
  opacity: 0;
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group .submit-group-check .check-box::after {
    left: calc(5 / 390 * 100vw);
    top: calc(1 / 390 * 100vw);
    width: calc(4 / 390 * 100vw);
    height: calc(10 / 390 * 100vw);
  }
}
.contact .contact-content form .submit-group .submit-group-check .check-box:checked::after {
  opacity: 1;
}
.contact .contact-content form .submit-group .submit-group-check .privacy-text {
  font-family: "SourceHanSansJP-Bold";
  font-size: calc(14 / 1280 * 100vw);
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group .submit-group-check .privacy-text {
    font-size: calc(14 / 390 * 100vw);
  }
}
.contact .contact-content form .submit-group .submit-group-check .privacy-text a {
  text-decoration: underline;
  color: #ffffff;
}
.contact .contact-content form .submit-group .submit-btn {
  padding: calc(6 / 1280 * 100vw) calc(44 / 1280 * 100vw);
  background-color: #ffffff;
  border-radius: 99px;
  border: none;
  font-family: "SourceHanSansJP-Bold";
}
.contact .contact-content form .submit-group .submit-btn:not(:disabled) {
  cursor: pointer;
  color: #000000;
}
@media (max-width: 750px) {
  .contact .contact-content form .submit-group .submit-btn {
    padding: calc(12 / 390 * 100vw) calc(64 / 390 * 100vw);
    margin: calc(28 / 390 * 100vw) auto;
  }
}

.end-message {
  color: #fff;
}
.end-message.hidden {
  display: none;
}

.false-message {
  color: #fff;
}
.false-message.hidden {
  display: none;
}

#contact-left-image {
  position: absolute;
  top: calc(70 / 1280 * 100vw);
  left: calc(-300 / 1280 * 100vw);
  width: calc(532 / 1280 * 100vw);
  z-index: -1;
}
@media (max-width: 750px) {
  #contact-left-image {
    width: calc(247 / 390 * 100vw);
    left: calc(-180 / 390 * 100vw);
  }
}

#contact-right-image {
  position: absolute;
  bottom: 0px;
  right: calc(-204 / 1280 * 100vw);
  width: calc(380 / 1280 * 100vw);
  z-index: -1;
}
@media (max-width: 750px) {
  #contact-right-image {
    width: calc(160 / 390 * 100vw);
    right: calc(-116 / 390 * 100vw);
  }
}/*# sourceMappingURL=master.css.map */