@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600&display=swap");

:root {
 /* Colors: */
 --color-blk: #000000;
 --color-wht: #ffffff;
 --color-base: #f4f3f2;
 --color-txt: #2f3031;
 --color-nav: #332f2d;
 --color-red: #f04037;
 --color-grn: #04af7a;
 --color-grn2: #006526;
 --color-lgr: #73ce1a;
 --color-org: #ed7a48;
 --color-ylw: #f5a200;
 --color-ylw2: #cbc901;
 --color-blu: #587bde;
 --color-wbl: #74bad9;
 --color-ppl: #7a7adf;
 --color-ppl2: #aa7ccd;
 --color-pnk: #f273a9;
 --color-gld: #a79758;
 --color-gy1: #efebe4;
 --color-gy2: #e1dcd4;
 --color-gy3: #c5c3c1;
 --color-gy4: #575351;
 --ff-avn: "avenir", sans-serif;
}

.min {
 font-family: Cambria, Cochin, Georgia, Times, "Times New Roman", serif;
}
body {
 font-family: "Open Sans", Arial, Helvetica, sans-serif;
 font-size: 1.7rem;
}

/* sns
---------------------------------------------------------------------------------*/
.sns .btn.yt,
.sns .btn.yt a {
 width: 48px;
 height: 36px;
}

@media screen and (max-width: 600px) {
 .sns .btn.yt,
 .sns .btn.yt a {
  width: 40px;
  height: 30px;
 }
}

/* header
---------------------------------------------------------------------------------*/
.hdmenu_child_item a {
 font-size: 1.4rem;
 font-weight: 600;
}
.hdmenu_child_large a {
 font-size: 1.6rem;
 font-weight: 600;
}
.hdmenu_loca_item a {
 font-weight: 600;
 letter-spacing: 0.06em;
}
.hdnav_loca_item a {
 font-weight: 600;
 letter-spacing: 0.06em;
}
.hdnav-sub_under {
 flex-flow: row;
 align-items: center;
 margin-top: 30px;
}
.hdnav-sub_under .sns {
 margin-top: 0;
 margin-left: 50px;
}
.hdnav_list {
 width: 100%;
}
.hdnav_item {
 letter-spacing: 0.04em;
}

@media screen and (max-width: 820px) {
 .hdnav-sub_over {
  display: none;
 }
}

/* p-contents
---------------------------------------------------------------------------------*/
.heading_line {
 width: 80px;
 height: 8px;
 display: block;
 margin-bottom: 20px;
}
.heading_line span {
 width: 100%;
 height: 100%;
 display: block;
 border-radius: 2em;
 background-color: var(--color-red);
}
.heading1 {
 font-size: 6.4rem;
 letter-spacing: 0.02em;
}

@media screen and (max-width: 820px) {
 .heading1 {
  font-size: 5.2rem;
 }
}

@media screen and (max-width: 600px) {
 .heading_line {
  width: 70px;
  height: 6px;
 }
 .heading1 {
  font-size: 4.6rem;
 }
}

@media screen and (max-width: 340px) {
 .heading1 {
  font-size: 3.8rem;
 }
}

/* p-header
---------------------------------------------------------------------------------*/
.ph-title .heading1 {
 font-size: 5.4rem;
}
.ph-title .heading_line span {
 display: inline-block;
 opacity: 0;
}

/* anime */
body.-start .ph-title .heading_line span {
 animation: ani_title 2s cubic-bezier(0.075, 0.82, 0.165, 1) 0.8s both;
}
body.-start .ph-title .heading_line span {
 animation-delay: 1s;
}

@media screen and (max-width: 600px) {
 .ph-title .heading1 {
  font-size: 4rem;
 }
}

/* Footer
---------------------------------------------------------------------------------*/
.ftnav-sub_under {
 margin-top: 30px;
}
.ftnav_list {
 width: 100%;
}
.ftnav_item {
 font-size: 1.7rem;
 letter-spacing: 0.04em;
}
.ft_copyright {
 justify-content: flex-end;
 text-align: right;
 line-height: 1.4;
 flex: 1;
}

@media screen and (max-width: 1099px) {
 .ftnav-wrap {
  gap: 70px;
 }
}

@media screen and (max-width: 820px) {
 .ft_copyright {
  margin-top: 30px;
  line-height: 1.5;
 }
}

@media screen and (max-width: 600px) {
 .ftnav-wrap {
  gap: 40px;
 }
 .ftnav-main {
  flex-flow: column;
 }
 .ftnav_list {
  flex-flow: row;
  gap: 10px 24px;
 }
 .ftnav_item {
  font-size: 1.5rem;
  margin-bottom: 0;
  width: auto;
 }
 .ftnav-bottom-main {
  padding-block: 36px;
 }
 .ftnav-bottom_list {
  flex-flow: row;
  justify-content: center;
  width: 100%;
  gap: 20px;
 }
 .ft_copyright {
  margin-top: 20px;
  text-align: center;
 }
}

/* home
---------------------------------------------------------------------------------*/
.tagline_wrap {
 width: 52.5%;
}
.anniv_logo {
 padding-bottom: 16%;
 left: 5.88%;
}

/* home content
---------------------------------------------------------------------------------*/
.news_btn {
 top: -140px;
}

@media screen and (max-width: 820px) {
 .news_btn {
  top: calc(100% + 24px);
 }
}

.t-business .cat_ttl .en_name {
 font-size: 4rem;
}

@media screen and (max-width: 600px) {
 .t-business {
  margin-top: 120px;
 }
}

.t-corp {
 margin-top: 120px;
 margin-bottom: 100px;
}
.t-corp_wrap.business_body .b-button a strong {
 font-size: 4rem;
}

@media screen and (max-width: 820px) {
 .t-corp_wrap.business_body .b-button a strong {
  font-size: 3.2rem;
 }
}

@media screen and (max-width: 600px) {
 .t-corp {
  margin-bottom: 20px;
 }
}

/* news
---------------------------------------------------------------------------------*/
.lw-news .heading_line span {
 background-color: var(--color-red);
}
.entry_body p + p {
 margin-top: 1.5em;
}
.entry_body em {
 font-style: italic;
}

/* business
---------------------------------------------------------------------------------*/
.lw-business .heading_line span {
 background-color: var(--color-grn2);
}
.business_body .b-button a strong {
 font-size: 3.4rem;
}
.business_body .b-button a .link p {
 font-size: 1.6rem;
 font-weight: 700;
}
.business_flex_wrap {
 display: flex;
 gap: 60px;
}
.business_flex_wrap .txt {
 flex: 1;
}
.business_flex_wrap figure {
 width: 28%;
}
.business_photo_wrap {
 margin-block: 3em;
 display: flex;
 justify-content: center;
 gap: 10px;
}

@media screen and (max-width: 820px) {
 .business_flex_wrap {
  flex-flow: column;
  align-items: center;
  gap: 30px;
 }
 .business_flex_wrap .txt {
  flex: unset;
 }
 .business_flex_wrap figure {
  width: 50%;
 }
}

@media screen and (max-width: 600px) {
 .business_flex_wrap figure {
  width: 60%;
 }
}

/* license */
.lw-business.lw-license .heading_line span {
 background-color: var(--color-grn);
}

/* production */
.lw-business.lw-production .heading_line span {
 background-color: var(--color-lgr);
}

@media screen and (max-width: 820px) {
 .production_flex_wrap .desc p {
  font-size: 1.4rem;
 }
 .production_flex_wrap .link_area {
  gap: 15px;
 }
 .production_sub_wrap .desc {
  font-size: 1.4rem;
 }
}

/* work
---------------------------------------------------------------------------------*/
.lw-work .heading_line span {
 background-color: var(--color-blu);
}

@media screen and (max-width: 820px) {
 .item_work a {
  line-height: 1.4;
 }
}

/* work single */
.work_head_wrap {
 flex-flow: column;
 align-items: center;
 gap: 40px;
}
.work_head_wrap .title {
 display: flex;
 justify-content: center;
 max-width: 720px;
 margin-bottom: 30px;
 line-height: 1.22;
}
.work_head_wrap .title span {
 display: block;
 margin-inline: auto;
 position: relative;
}
.work_head_wrap .title span::after {
 content: "";
 position: absolute;
 left: 0;
 bottom: -20px;
 width: 100%;
 height: 4px;
 border-radius: 2px;
 background-color: var(--color-blu);
}
.work_about {
 max-width: 720px;
 margin-inline: auto;
}
.p-work_single_under .post_search_wrap {
 padding-top: 0;
 border-top: none;
}
.sns_link_wrap .sns .btn.yt,
.sns_link_wrap .sns .btn.yt a {
 width: 60px;
 height: 60px;
}

@media screen and (max-width: 820px) {
 .work_head_wrap {
  gap: 25px;
 }
}

@media screen and (max-width: 600px) {
 .work_head_wrap {
  gap: 25px;
 }
 .sns_link_wrap .sns .btn.yt,
 .sns_link_wrap .sns .btn.yt a {
  width: 40px;
  height: 40px;
 }
}

/* corp
---------------------------------------------------------------------------------*/
.lw-corp .heading_line span {
 background-color: var(--color-ylw);
}
.corp_prize_body p {
 line-height: 1.8;
}
.corp_prize_body p + p {
 margin-top: 2em;
}

@media screen and (max-width: 820px) {
 .corp_nav ul {
  flex-wrap: wrap;
  gap: 20px 30px;
 }
}

@media screen and (max-width: 600px) {
 .name_wrap {
  gap: 20px;
 }
}

/* anniversary
---------------------------------------------------------------------------------*/
.lw-anniversary .heading_line span {
 background-color: var(--color-gld);
}
.aniv_tagline {
 margin-top: 60px;
}
.aniv_txt {
 align-items: normal;
 gap: 30px;
}
.aniv_txt p {
 font-size: 2.2rem;
 line-height: 1.6;
}

@media screen and (max-width: 600px) {
 .aniv_tagline {
  width: 90%;
  margin-top: 40px;
 }
 .aniv_txt p {
  font-size: 1.65rem;
  line-height: 1.4;
 }
}

/* contact
---------------------------------------------------------------------------------*/
.lw-contact .heading_line span {
 background-color: var(--color-org);
}
.contact_btn_wrap {
 display: flex;
 justify-content: center;
}
.contact_btn_wrap .item {
 width: 480px;
}
.contact_btn_wrap .b-button a strong {
 display: block;
 margin-top: 30px;
 text-align: center;
 font-size: 2.8rem;
 font-weight: 600;
}
.flowArea .flow.on .txt {
 font-size: 1.4rem;
}

@media screen and (max-width: 600px) {
 .contact_btn_wrap .b-button a strong {
  margin-top: 20px;
  font-size: 2.2rem;
 }
 .flowArea .flow .txt {
  font-size: 1.1rem;
 }
 .flowArea .flow.on .txt {
  font-size: 1.1rem;
 }
}

/* entry
---------------------------------------------------------------------------------*/
.p-form_label {
 align-items: flex-start;
}
.p-form_label.-required::after {
 content: "is required";
 width: auto;
 padding: 0.1em 0.5em;
 letter-spacing: 0;
}

@media screen and (max-width: 820px) {
 .p-form_label.-required::after {
  padding: 0.5em 0.5em;
 }
}

/* other
---------------------------------------------------------------------------------*/
.p-other p {
 font-size: 1.6rem;
}
.p-other h2 {
 margin-bottom: 10px;
}
.sitemap_wrap {
 max-width: 800px;
 margin-inline: auto;
}

@media screen and (max-width: 1040px) {
 .sitemap_wrap {
  flex-wrap: nowrap;
  gap: 20px;
 }
}

@media screen and (max-width: 820px) {
 .sitemap_wrap {
  flex-wrap: nowrap;
  gap: 20px;
 }
}

@media screen and (max-width: 600px) {
 .lw-other .ph-title .heading1 {
  font-size: 3.6rem;
 }
}

@media screen and (max-width: 340px) {
 .lw-other .ph-title .heading1 {
  font-size: 3.3rem;
 }
}
