@charset "UTF-8";

/*
Theme Name: PORTFOLIO
Version: 1.0
*/

/* ------------------------------ */
/* カスタムプロパティ */
/* ------------------------------ */
:root {
	--color-bg-base: #f0f0f0;
	--color-bg-white: #ffffff;
	--color-bg-light: #C3C3C3;
	--color-bg-main_01: #84CCC9;
	--color-bg-main_02: #F29C9F;
	--color-bg-sub_01: #b7e5e3;
	--color-bg-sub_02: #FCBDBF;
	--color-bg-tag: #747474;
	--color-font-base: #252626;
	--color-font-light: #999999;
	--font-family-base: 'Poppins','Noto Sans JP','メイリオ', Meiryo, sans-serif; 
}
/* ------------------------------ */
/* 全体共通のスタイル */
/* ------------------------------ */
html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}
body {
	font-size: 13px;
	color: var(--color-font-base);
	background: var(--color-bg-base);
	font-family: var(--font-family-base);
	letter-spacing: 0.03em;
	line-height: 1.5;
	font-weight: 400;
	word-wrap: break-word;
	word-break: break-all;
}
@media screen and (min-width: 740px) {
    body {
        font-size: 16px;
    }
}
p {
    font-size: 13px;
}
@media screen and (min-width: 740px) {
    p {
        font-size: 16px;
    }
}

/* ------------------------------ */
/* リセットCSS */
/* ------------------------------ */
* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
}

/* HTML5
-------------------------------------*/
article,aside,canvas,details,figcaption,figure, header,footer,main,menu,nav,section,summary {
	display: block;
}

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

table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}

fieldset,
img {
    border: 0;
}

address,
caption,
cite,
code,
dfn,
th,
var {
    font-style: normal;
    font-weight: normal;
}

ol,
ul {
    list-style: none;
}

caption,
th {
    text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 100%;
    font-weight: bold;
    font-feature-settings: "palt";
    letter-spacing: .0625em;
}

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

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

sup {
    vertical-align: text-top;
}

sub {
    vertical-align: text-bottom;
}

input,
textarea,
select,
button {
    color: inherit;
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    line-height: inherit;
    font-size: 100%;
    border-radius: 0;
    border: none;
    appearance: none;
    -webkit-appearance: none;
    background-color: inherit;
}

input, textarea {
	font-size: 16px;
	font-family: Arial, Hiragino Sans,Hiragino Kaku Gothic ProN,BIZ UDPGothic,Meiryo,sans-serif;
}

label {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    user-select: none;
}

input[type=radio] {
	display: none;
	visibility: hidden;
	cursor: pointer;
}

input[type=submit] , input[type=button] {
	cursor: pointer;
	transition: all 0.2s ease-in-out;
	letter-spacing: 0.15em;
}

input[type="email"] {
	font-family: Arial, Hiragino Sans,Hiragino Kaku Gothic ProN,BIZ UDPGothic,Meiryo,sans-serif;
	letter-spacing: 0.05em;
}

textarea {
    resize: vertical;
    display: block;
}

/* placeholder設定*/
input::placeholder, textarea::placeholder { 
    color: #aaa; 
    font-size: 16px;
}
@media screen and (min-width: 740px) {
    input::placeholder, textarea::placeholder {
        font-size: 16px;
    }
}

button {
    padding: 0;
    cursor: pointer;
}

legend {
    color: #000;
}

a {
    text-decoration: none;
    color: inherit;
    outline: none;
    transition: all 0.2s ease-in-out;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
a:hover {
	opacity: 0.8;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}

svg {
    display: block;
}

/* ------------------------------ */
/* 汎用 強制クラス */
/* ------------------------------ */
/* display: none;（強制） */
.dn {
	display: none !important;
}
/* display: block;（強制） */
.db {
	display: block !important;
}
/* display: inline-block;（強制） */
.dib {
	display: inline-block !important;
}
.dfl {
	display: flex !important;
}
/* text-align: center（強制） */
.tac {
	text-align: center !important;
}
/* text-align: left（強制） */
.tal {
	text-align: left !important;
}
/* text-align: right（強制） */
.tar {
	text-align: right !important;
}
/* padding設定（強制） */
.pt0 {
	 padding-top: 0px !important; 
}
.pt10 {
	padding-top: 10px !important;
}
.pt20 {
	padding-top: 20px !important;
}
.pt30 {
	padding-top: 30px !important;
}
.pb0 {
	padding-bottom: 0px !important;
}
.pb10 {
	padding-bottom: 10px !important;
}
.pb20 {
	padding-bottom: 20px !important;
}
.pb30 {
	padding-bottom: 30px !important;
}
.pl0 {
	padding-left: 0px !important;
}
.pl5 {
	padding-left: 5px !important;
}
.pl10 {
	padding-left: 10px !important;
}
.pl20 {
	padding-left: 20px !important;
}
.pl30 {
	padding-left: 30px !important;
}
.pr0 {
	padding-right: 0px !important;
}
.pr5 {
	padding-right: 5px !important;
}
.pr10 {
	padding-right: 10px !important;
}
.pr20 {
	padding-right: 20px !important;
}
.pr30 {
	padding-right: 30px !important;
}

/* margin無し（強制） */
.mn {
	margin: 0 0 0 0 !important;
}
/* margin　中央寄せ（強制） */
.mce {
	margin: 0 auto!important;
}
/* margin　中央寄せ解除（強制） */
.mce_none {
	margin-right: 0!important;
	margin-left: 0!important;
}
/* margin設定（強制） */
.mt0 {
	margin-top: 0px !important;
}
.mt10 {
	margin-top: 10px !important;
}
.mt20 {
	margin-top: 20px !important;
}
.mt30 {
	margin-top: 30px !important;
}
.mb0 {
    margin-bottom: 0px !important;
}
.mb10 {
	margin-bottom: 10px !important;
}
.mb20 {
	margin-bottom: 20px !important;
}
.mb30 {
	margin-bottom: 30px !important;
}
.ml0 {
	margin-left: 0px !important;
}
.ml10 {
	margin-left: 10px !important;
}
.ml20 {
	margin-left: 20px !important;
}
.ml30 {
	margin-left: 30px !important;
}
.mr0 {
	margin-right: 0px !important;
}
.mr10 {
	margin-right: 10px !important;
}
.mr20 {
	margin-right: 20px !important;
}
.mr30 {
	margin-right: 30px !important;
}
/* width設定 （強制）*/
.w100 {
	width: 100% !important;
}
.w50 {
	width: 50% !important;
}
.wa {
	width: auto !important;
}
/* max-width リセット設定 （強制）*/
.maxW_None {
	max-width: none !important;
}
/* min-width リセット設定 （強制）*/
.minW_None {
	min-width: 0 !important;
}
/* 画面幅いっぱいにしたい要素にあてるクラス */
.widthMax { 
	margin: 0 calc(50% - 50vw);
}
/* height設定 （強制）*/
.ha {
	height: auto !important;
}
/*font size 設定（強制） */
.f_sp_10 {
	font-size: 10px !important;
}
.f_sp_11 {
	font-size: 11px !important;
}
.f_sp_12 {
	font-size: 12px !important;
}
.f_sp_13 {
	font-size: 13px !important;
}

@media screen and (min-width: 740px) {
	.f_tab_11  {
		font-size: 11px !important;
	}
}
@media screen and (min-width: 740px) {
	.f_tab_12  {
		font-size: 12px !important;
	}
}
@media screen and (min-width: 740px) {
	.f_tab_13  {
		font-size: 13px !important;
	}
}
@media screen and (min-width: 740px) {
	.f_tab_14  {
		font-size: 14px !important;
	}
}
@media screen and (min-width: 740px) {
	.f_tab_15  {
		font-size: 15px !important;
	}
}

@media screen and (min-width: 1200px) {
	.f_PC_13  {
		font-size: 13px !important;
	}
}
@media screen and (min-width: 1200px) {
	.f_PC_14  {
		font-size: 14px !important;
	}
}
@media screen and (min-width: 1200px) {
	.f_PC_15  {
		font-size: 15px !important;
	}
}
@media screen and (min-width: 1200px) {
	.f_PC_16  {
		font-size: 16px !important;
	}
}
/*font color 設定（強制） */
.font_red {
    color: red !important;
}
/*font weight 設定（強制） */
.fb {
    font-weight: bold!important;
}
.fn {
    font-weight: normal!important;
}

/* border設定 （強制）*/
.bn {
	border: none !important;
}
/*vh設定 （強制） */
.vh {
	visibility: hidden !important;
}
/* クリック（タップ）無効　強制クラス */
.pen {
    pointer-events: none !important;
}

/* ------------------------------ */
/* 　　　　　FORM　　　　　　 */
/* ------------------------------ */
/* アニメーションボタン */
.c-btn01__link {
	text-decoration: none;
	display: flex;
	width: 100%;
	max-width: 300px;
	margin: 0 auto;
	justify-content: space-between;
	align-items: center;
	color: #ffffff;
	font-weight: 500;
	background: #252626;
	border: 1px solid #252626;
	padding: 5px 5px 5px 35px;
	border-radius: 50px;
	transition: 0.3s ease all;
}
.c-btn01__link:hover {
	opacity: 1;
	/* background: #fff; */
	/* color: #252626; */
}
.c-btn01__link_span {
    transition: all 0.6s ease;
    text-align: center;
    flex: 1;
    font-size: 16px;
}
.c-btn01__link:hover .c-btn01__link_span {
	opacity: 1;
	letter-spacing: 0.15em;
}

.c-btn01-arw {
	margin-left: 10px;
	height: 48px;
	width: 48px;
}
@media all and (min-width: 740px) {
  .c-btn01-arw {
    margin-left: 20px;
    height: 45px;
    width: 45px;
  }
}

.c-btn01-arw svg {
	height: 100%;
	width: 100%;
}

.c-btn01-arw__circle {
	transition: all 0.6s ease;
	fill: #ffffff;
	stroke: #ffffff;
	stroke-dasharray: 201;
	stroke-dashoffset: 0;
	stroke-width: 1;
}

.c-btn01-arw__ico {
	transition: all 0.6s ease;
	fill: #252626;
}

@media (hover: hover) and (pointer: fine) {
  .c-btn01__link:hover .c-btn01-arw__circle {
    -webkit-animation: btn01Circle 1s forwards;
    animation: btn01Circle 1s forwards;
    fill: #252626;
    /* transition-delay: 0.8s; */
  }
  .c-btn01__link:hover .c-btn01-arw__ico {
    fill: #ffffff;
    transition-delay: 0.8s;
  }
}
@keyframes btn01Circle {
  0% {
    stroke-dashoffset: 201;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

/* 汎用ボタン */
.c-buttonFill_0 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  height: 35px;
  font-size: 12px;
  color: var(--color-bg-light);
  text-align: center;
  font-weight: bold;
  background-color: var(--color-icon);
  border: 1px solid #ffffff;
  box-shadow: 0 0 0 1px var(--color-icon);
  line-height: 1;
  border-radius: 0.25rem;
}
.c-buttonFill_0:hover {
	background: var(--color-bg-light);
	color: var(--color-icon);
	opacity: 1;
}

/* 通常form用 input */
.tf-c-form-control_normal {
	display: block;
	width: 100%;
	height: 40px;
	margin: 0;
	padding: .5rem .5rem;
	border: 1px solid var(--color-border3);
	border-radius: 5px;
	outline: none;
	background-clip: border-box;
	background-color: var(--color-bg-light);
	color: var(--color-font-base);
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	box-shadow: 0 2px 6px -4px rgba(0, 0, 0, 0.2) inset, 0 2px 4px -4px rgba(0, 0, 0, 0.2) inset;
	transition: border-color .15s ease-in-out;box-shadow: .15s ease-in-out;
}
.tf-c-form-control_normal:focus {
	border: 1px solid rgba(90, 180, 255, 0.5);
	box-shadow: 0 2px 6px -4px rgba(0, 0, 0, 0.2) inset, 0 2px 4px -4px rgba(0, 0, 0, 0.2) inset, 0 0 0 0.25rem rgba(2,132,199,.25);
}

 /* テキストエリア */
.textareaClass {
    min-height: 200px;
}

/*汎用disable設定*/
.disable_1 {
	background-color: #c6c6c6 !important;
	border: 1px solid #c6c6c6 !important;
	pointer-events: none !important;
	user-select: none !important;
	color: var(--color-bg-light) !important;
	background-image: none !important;
	box-shadow: none !important;
}
.disable_2 {
	filter: opacity(0.5) !important;
	pointer-events: none !important;
	user-select: none;
}
.disable_3 {
	filter: contrast(0.8) !important;
	pointer-events: none !important;
	user-select: none;
}
/*汎用inputエラー設定*/
.err {
    border: 1px solid #c80a2f !important;
    background-color: #fff4f4 !important;
}
.err:focus {
	box-shadow: inset 0 0 3px 0px #bbbbbb, 0 0 0 .25rem rgba(220,38,38, .25) !important;
}

/* pagetopに戻る設定
--------------------*/
.pagetop {
	display: none;
	position: fixed;
	right: 20px;
	bottom: 70px;
	z-index: 5;
}
.pagetop a{
    display: block;
    font-size: 0;
    width: 60px;
    height: 60px;
    text-align: center;
    background: var(--color-font-base);
    border-radius: 50%;
    line-height: 50px;
    position: relative;
    border: 1px solid rgba(255,255,255,0.85);
}
.pagetop a:hover{
		 border: 1px solid var(--color-font-base);
		 background: #fff;
		 opacity: 1;
}
@media (max-width: 1100px) {
	.pagetop a:hover{
		 border: 1px solid rgba(255,255,255,0.85);
		 background: var(--color-font-base);
		 opacity: 1;
	}
}
.pagetop a::before {
	position: absolute;
	content: '';
	width: 10px;
	height: 10px;
	border-left: solid 4px #ffffff;
	border-top: solid 4px #ffffff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 24px;
	left: 23px;
	margin-top: 0px;
	transition: all  0.35s ease;
}
.pagetop a:hover::before {
	border-left: solid 4px var(--color-font-base);
	border-top: solid 4px var(--color-font-base);
}
@media (max-width: 1100px) {
	.pagetop a:hover::before {
		border-left: solid 4px #ffffff;
		border-top: solid 4px #ffffff;
	}
}

/*----------------------------------------------------
　　　ナビゲーション（ドロワー）メニュー 
----------------------------------------------------*/
.nav-open .black-bg {
	display: none;
}
body.nav-open {
	overflow:hidden; 
}
/* ナビゲーション（ドロワー）メニュー */
.drawerMenu {
	margin: 0;
	padding: 0;
	position: absolute;
	right: 15px;
	z-index: 10;
}
@media screen and (min-width: 740px) {
	.drawerMenu {
		position: relative;
	}
}
.gnav {
  position: fixed;
  right: 0; /* これで隠れる */
  top: 0;
  width: 100%; /* スマホに収まるくらい */
  height: 100%;
  padding-top: 80px;
  background-color: var(--color-bg-base);
  /*transition: all .1s ease; */
  z-index: 10;
  overflow-y: auto; /* メニューが多くなったらスクロールできるように */
  display: none;
}
@media screen and (min-width: 740px) {
	.gnav {
		position: relative;
		display: block !important;
		padding: 0;
		height: auto;
		background-color: transparent;
	}
}

.hamburger {
	position: relative;
	right: 0;
	top: 0;
	width: 40px;
	height: 40px;
	cursor: pointer;
	z-index: 10;
}
@media screen and (min-width: 740px) {
	.hamburger {
		display: none;
	}
}
.nav {
  margin: 0;
  padding: 0px 0 50px;
  list-style: none;
  font-size: 40px;
}
@media screen and (min-width: 740px) {
	.nav {
		display: flex;
		padding: 0;
		font-size: 13px;
	}
}
.menu-item {
  /* text-align: center; */
  padding-left: 30px;
  margin: 10px 0;
}
@media screen and (min-width: 740px) {
	.menu-item {
		margin: 0 0 0 10px;
		padding: 0;
	}
}
.menu-item a {
  display: block;
  padding: 0 0;
  border-bottom: 0px solid #fff;
  text-decoration: none;
  color: var(--color-font-base);
  /* background: #ffffff; */
  font-weight: 700;
}
@media screen and (min-width: 740px) {
	.menu-item a {
		font-weight: 600;
	}
}
.menu-item a:hover {
	opacity: 1;
}
.hamburger__line {
  position: absolute;
  left: 4px;
  width: 30px;
  height: 1px;
  background-color: var(--color-font-base);
  transition: all .15s ease;
}
.hamburger__line--1 {
  top: 12px;
}
.hamburger__line--2 {
  top: 20px;
}
.hamburger__line--3 {
  top: 28px;
}
.black-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 0;
  background-color: #fff;
  opacity: 0;
  visibility: hidden;
  transition: all .4s ease;
  cursor: pointer;
}
/* 表示された時用のCSS */
.nav-open .black-bg {
  opacity: .5;
  visibility: visible;
}
.nav-open .hamburger__line--1 {
  transform: rotate(45deg);
  top: 20px;
}
.nav-open .hamburger__line--2 {
  width: 0;
  left: 50%;
}
.nav-open .hamburger__line--3 {
  transform: rotate(-45deg);
  top: 20px;
}
.menuAndClose {
	font-size: 10px;
	position: absolute;
	top: 32px;
	left: 0px;
	display: block;
	width: 39px;
	font-family: Arial,sans-serif;
}

/* ------------------------------ */
/* テーブル */
/* ------------------------------ */
/* small */
.table-normal {
    padding: 30px 0px;
}
.table_small {
	border-collapse: separate;
	border-spacing: 1px;
	width: 100%;
	color: var(--color-font-base);
	font-size: 12px;
	background: #b4abab;
	font-weight: 400;
	line-height: 1.25;
	table-layout: fixed;
}

.table_small td, .table_small th {
	border: 1px solid #ffffff;
}
.table_small th {
	font-weight: bold;
	font-size: 13px;
	background-color: var(--color-bg-base4);
	background-image: linear-gradient(to bottom, #f8f6ef 0%,#e7e4d7 100%);
	color: var(--color-font-base);
	letter-spacing: .0625em;
	text-align: center;
	vertical-align: middle;
	padding: 0.55rem 0.2rem;
	white-space: nowrap;
}
.table_small td {
	text-align: center;
	vertical-align: middle;
	padding: 0.4rem 0.4rem;
	letter-spacing: .0625em;
	background-color: #fff;
}

/* ------------------------------ */
/*　　 ページネーション設定　　 */
/* ------------------------------ */

/* ------------------------------ */
/* 　　　　　その他　　　　　 */
/* ------------------------------ */
/* スムーススクロール、アンカー位置調整 */
#tab::before {
	content: '';
	display: block;
	padding-top: 20px;
	margin-top: -20px;
}
@media screen and (min-width: 740px) {
    #tab::before {
	    padding-top: 30px;
	    margin-top: -30px;
	}
}


/* ------------------------------ */
/* コンポーネント(使い回すスタイル) */
/* ------------------------------ */
/* 水平線 */
hr {
	display: block;
	height: 2px;
	border: 0;
	border-top: 1px solid #dddddd;
	background: #fff;
	margin: 1em 0;
	padding: 0;
}
/* スマホだけ表示 */
@media screen and (min-width: 740px) {
	.sp_only {
		display: none !important;
	}
}
/* PC（タブレット）だけ表示 */
@media screen and (max-width: 740px) {
	.pc_only {
		display: none !important;
	}
}

/* 見出し（H2） */
.header3rd {
	padding: 0;
	letter-spacing: 0.1em;
}
@media screen and (min-width: 740px) {
	.header3rd {
		padding: 0;
	}
}

@media screen and (min-width: 740px) {
	.page_link_inner.page_worksClass .header3rd {
		position: absolute;
		right: 50px;
		width: 40%;
	}
}

.header3rd_ja {
	padding: 0;
	display: block;
	font-size: 12px;
	line-height: 1.1em;
}
@media screen and (min-width: 740px) {
	.header3rd_ja {
		padding: 0;
		font-size: 14px;
	}
}
.header3rd_en {
	position: relative;
	padding: 0;
	display: inline-block;
	font-size: 38px;
	line-height: 1.3;
}
@media screen and (min-width: 740px) {
	.header3rd_en {
		padding: 0;
		font-size: 60px;
		line-height: 1.1;
	}
}
.header3rd_en::first-letter {
  color: var(--color-bg-main_02);
}
.page_link_inner.page_worksClass .header3rd_en::first-letter {
	color: var(--color-bg-main_01);
}
.header3rd_en::before {
	position: absolute;
	content:"";
	top: 24px;
	right: -20px;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	background-color: var(--color-bg-main_02);
	z-index: 0;
}
@media screen and (min-width: 740px) {
	.header3rd_en::before {
		top: 35px;
		right: -25px;
		width: 20px;
		height: 20px;
	}
}
.page_link_inner.page_worksClass .header3rd_en::before {
	background-color: var(--color-bg-main_01);
}

/* 見出し（H3） */
.subpage_header3rd {
	font-size: 16px;
	padding: 0px 5px 0px;
	border-bottom: 1px solid var(--color-font-base);
	text-align: center;
	width: fit-content;
	display: block;
	margin: 0 auto 24px;
	line-height: 2em;
}
@media screen and (min-width: 1024px) {
	.subpage_header3rd {
		font-size: 18px;
		margin: 0 auto 40px;
	}
}

/* 見出し （H4） */
.header_wrapBox {
	padding: 30px 0;
}
.subpage_header4th {
	position: relative;
	padding: 0 0 0 20px;
}
/* ------------------------------ */
/*          レイアウト（共通）      */
/* ------------------------------ */
.l-wrapper {
	padding: 0;
	margin: 0;
	overflow: clip;
	position: relative;
}
.l-main {
	padding-top: 0px;
	padding-bottom: 150px;
}
/* ------------------------------ */
/* コンテナ */
/* ------------------------------ */
/* 最大幅 */
.l-container {
    width: 100%;
    margin: 0 auto;
    padding: 0px 0px;
}
/* 最大幅（paddingあり） */
.l-container_p {
    width: 100%;
    margin: 0 auto;
    padding: 0px 12px;
}
/* 最大幅指定（1100px） */
.l-container_maxwidth {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 12px;
}
/* ------------------------------ */
/* ヘッダー */
/* ------------------------------ */
.l-header {
	padding: 12px;
	width: 100%;
	/* position: fixed; */
	top: 0;
	z-index: 10;
}
@media screen and (min-width: 740px) {
	.l-header {
		padding: 12px;
	}
}
.header_inner {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    /* max-width: 1100px; */
    margin: 0 auto;
    padding: 0px 10px;
    height: 64px;
    /* background: #ffffff; */
    border-radius: 12px;
}
.header_inner::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.9);
  -webkit-backdrop-filter: blur(50px);
  /* backdrop-filter: blur(50px); */
  border-radius: 12px;
  /* box-shadow: .4rem .4rem 1rem rgb(0 0 0 / 5%); */
  left: 0;
  top: 0;
  z-index: -1;  /*LOGOとメニューボタンが疑似要素の上にくるように調整*/
}

.header__1st {
	margin: 0;
	padding: 10px;
	position: relative;
	z-index: 20;
	font-weight: 500;
}
.header__1st a{
	display: block;
}
.header__1st a img {
	display: block;
	height: 25px;
}


/* ------------------------------ */
/* コンテンツ */
/* ------------------------------ */
.l-contents {
	padding: 0;
	margin: 0;
	display: block;
	width: 100%;
}
.contents_inner {
	position: relative;
	margin-top: 0px;
	padding: 24px 30px 30px;
	border-radius: 20px;
	background-color: #fff;
	/* box-shadow: 0rem 0rem 1.2rem rgb(0 0 0 / 5%); */
}
@media screen and (min-width: 740px) {
	.contents_inner {
		margin-top: 30px;
		padding: 40px 30px 30px;
	}
}

/* ------------------------------ */
/* フッター */
/* ------------------------------ */
.footer {
	display: block;
	color: var(--color-bg-white);
	/* border-radius: 0px 40px 0px 0px; */
	position: relative;
	z-index: 3;
}
.footer_inner {
	margin: 12px;
	background: var(--color-font-base);
	border-radius: 12px 52px 12px 52px;
	box-shadow: .5rem .5rem 1.2rem rgb(0 0 0 / 5%);
	border: 1px solid var(--color-bg-white);
	background-image: url(../img/bg_ptn001.svg);
	background-position: 5% center;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (min-width: 740px) {
	.footer_inner {
		background-position: 100% center;
	}
}
.footer__copy {
	text-align: center;
	padding: 0 40px 40px;
	font-size: 10px;
}
@media screen and (min-width: 740px) {
	.footer__copy {
		padding: 0 40px 40px;
		/* max-width: 1100px; */
		margin: 0 auto;
	}
}
.footer__copy_inner {
	padding: 40px 0 0;
	border-top: 1px solid #464646;
}
@media screen and (min-width: 740px) {
	.footer__copy_inner {
	padding: 40px 0 0;
	}
}

.footer_nav {
	position: relative;
	padding: 50px 40px 50px;
	/* max-width: 1100px; */
	margin: 0 auto;
}
.c-footer__pageItem:not(:first-child) {
	margin-top: 12px;
}
.c-footer__pageItem .pageItem_link {
	white-space: nowrap;
}
.pageItem_link:hover {
	opacity: 1;
	color: var(--color-bg-main_01);
}

.c-footer__pageItem .pageItem_en {
	display: block;
	font-size: 40px;
	font-weight: 700;
	line-height: 100%;
	letter-spacing: .02em;
}
@media screen and (min-width: 740px) {
	.c-footer__pageItem .pageItem_en {
		display: inline;
		font-size: 55px;
	}
}
.c-footer__pageItem .pageItem_ja {
	display: inline-block;
	margin-left: 0;
	margin-top: 4px;
	font-feature-settings: "palt" on,"liga" off;
	font-size: 12px;
	font-style: normal;
	line-height: 100%;
	letter-spacing: .02em;
}
@media screen and (min-width: 740px) {
	.c-footer__pageItem .pageItem_ja {
		margin-left: .4rem;
		margin-top: 0;
		font-size: 11px;
		display: inline;
	}
}

/* ------------------------------ */
/*     レイアウト（背景あしらい）    */
/* ------------------------------ */
.l-bg {
	position: relative;
}

.l-bg_line {
  padding: 0;
}

.l-bg_line {
	position: absolute;
	top: 100px;
	right: -70px;
}
@media only screen and (min-width: 1024px) {
	.l-bg_line {
		top: 80px;
		right: -40px;
		left: auto;
	}
}
.l-bg_line_contents {
	position: absolute;
	top: 50px;
	right: -70px;
}
@media only screen and (min-width: 1024px) {
	.l-bg_line_contents {
		top: 100px;
		right: -40px;
		left: auto;
	}
}

@media only screen and (min-width: 1025px) {
	.u-sp {
		display:none!important
	}
}

@media only screen and (max-width: 1024px) {
	.u-pc {
		display:none!important
	}
}

.c-svg {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
}
.c-svg__wrapper {
	display: block;
	width: 100%;
	height: 100%;
}
.c-svg__wrapper svg {
	display: block;
	width: 100%;
	height: 100%;
}

.l-bg_line .c-svg {
	width: 178.1rem;
	/* aspect-ratio: 1781/770; */
	clip-path: polygon(0% 0%,0% 0%,0% 100%,0% 100%);
	transition: clip-path 1.1s cubic-bezier(.6,.04,.98,.34)
}
.l-bg_line.is-visible .c-svg {
	clip-path: polygon(0% 0%,100% 0%,150% 100%,0% 100%);
}

@media only screen and (max-width: 1024px) {
	.l-bg_line .c-svg {
		width: 85.7rem;
		aspect-ratio: 657/339;
	}
}

.l-bg_line_contents .c-svg {
	width: 178.1rem;
	/* aspect-ratio: 1781/770; */
	clip-path: polygon(0% 0%,0% 0%,0% 100%,0% 100%);
	transition: clip-path 1.1s cubic-bezier(.6,.04,.98,.34)
}
.l-bg_line_contents.is-visible .c-svg {
	clip-path: polygon(0% 0%,100% 0%,150% 100%,0% 100%);
}

@media only screen and (max-width: 1024px) {
	.l-bg_line_contents .c-svg {
		width: 85.7rem;
		aspect-ratio: 657/339;
	}
}


/* ------------------------------ */
/* 　ボックス・ブロック・パーツ　　　*/
/* ------------------------------ */
.c-box_wrapper {
    padding: 0;
    margin: 0;
}
/* 文章中のあしらい　001 */
.text-diamond_shape {
	display: block;
	margin: 30px auto;
	padding: 0px;
	width: 12px;
	height: 12px;
	background: var(--color-bg-white);
	border: 1px solid var(--color-font-light);
	transform: rotate(45deg) skew(calc((90deg - 80deg) / 2), calc((90deg - 80deg) / 2));
}

/* ------------------------------ */
/*   レイアウト（セクション） TOP   */
/* ------------------------------ */
/* ファーストビュー */
.l-fv {
    padding: 38px;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    height: calc(100vh - 100px);
    height: calc(100svh - 100px);
    position: relative;
    gap: 10px;
}
@media screen and (min-width: 740px) {
	.l-fv {
		/* padding: 0; */
		margin: 0;
		justify-content: center;
		flex-wrap: nowrap;
		/* height: calc(100vh - 150px); */
		/* height: calc(100svh - 150px); */
		gap: 0;
	}
}
@media screen and (min-width: 1024px) {
	.l-fv {
		margin: 0;
		/* height: calc(100vh - 200px); */
		/* height: calc(100svh - 200px); */
	}
}
@media (orientation: landscape) and (max-height: 450px) {
	.l-fv {
	  height: 100vh;
	}
}
.l-fv::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 80%;
  background: var(--color-bg-sub_01);
  border-radius: 12px;
  /* outline: 1px solid var(--color-bg-white); */
  /* outline-offset: -10px; */
  /* box-shadow: .4rem .4rem 1rem rgb(0 0 0 / 5%); */
  left: 0;
  top: 0;
  z-index: -1;  /*LOGOとメニューボタンが疑似要素の上にくるように調整*/
}
@media screen and (min-width: 740px) {
	.l-fv::before {
		height: 80%;
	}
}


.fv_left {
	padding: 0;
	margin: 0;
	width: 100%;
	display: flex;
	height: 40%;
	background-image: url(../img/man_heart.svg);
	background-position: left center;
	background-repeat: no-repeat;
	background-size: contain;
}
@media screen and (min-width: 650px) {
	.fv_left {
		justify-content: center;
		height: auto;
		width: 40%;
		background-position: center 0%;
		background-size: 50%;
	}
}
@media screen and (min-width: 740px) {
	.fv_left {
		width: 35%;
		background-position: center 10%;
		background-size: 60%;
	}
}
@media screen and (min-width: 1024px) {
	.fv_left {
		background-position: center 10%;
		background-size: 50%;
	}
}
@media screen and (min-width: 1200px) {
	.fv_left {
		background-position: center 10%;
		background-size: 45%;
	}
}

.fv_center {
	padding: 0;
	margin: 0;
	width: 100%;
	display: flex;
	justify-content: center;
	height: 20%;
}
@media screen and (min-width: 650px) {
	.fv_center {
		justify-content: center;
		align-items: center;
		height: auto;
		width: 100px;
	}
}
.fv_center_inner {
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
@media screen and (min-width: 650px) {
	.fv_center_inner {
		padding: 0;
		display: flex;
		flex-direction: row-reverse;
		align-items: flex-start;
	}
}
.fv_center_inner span {
	padding: 0;
	font-weight: 500;
	font-size: 16px;
	margin: 3px 0;
	font-feature-settings: "palt";
    letter-spacing: 0.1em;
}
@media screen and (min-width: 650px) {
	.fv_center_inner span {
		padding: 0;
		writing-mode: vertical-rl;
		font-size: 23px;
		margin: 0 5px;
		letter-spacing: 0.2em;
	}
}

.fv_right {
	padding: 0;
	margin: 0;
	width: 100%;
	display: flex;
	justify-content: flex-end;
	height: 40%;
	background-image: url(../img/woman_pc.svg);
	background-position: right center;
	background-repeat: no-repeat;
	background-size: contain;
}
@media screen and (min-width: 650px) {
	.fv_right {
		justify-content: center;
		align-items: end;
		height: auto;
		width: 35%;
		background-position: center 90%;
		background-size: 95%;
	}
}
@media screen and (min-width: 900px) {
	.fv_right {
		background-position: center 90%;
		background-size: 85%;
	}
}
@media screen and (min-width: 1024px) {
	.fv_right {
		background-position: center 90%;
		background-size: 75%;
	}
}
@media screen and (min-width: 1200px) {
	.fv_right {
		background-position: center 90%;
		background-size: 65%;
	}
}

/* 挨拶（GREETING） */
.l-greeting {
    padding: 0;
    margin: 0;
    display: block;
    width: 100%;
}
.greeting_inner {
	position: relative;
	margin-top: 150px;
	padding: 130px 30px 80px;
	border-radius: 20px;
	background-color: #fff;
	/* box-shadow: 0rem 0rem 1.2rem rgb(0 0 0 / 5%); */
}
@media screen and (min-width: 650px) {
	.greeting_inner {
		margin-top: 80px;
		padding: 140px 40px 40px;
		border-radius: 40px;
	}
}
@media screen and (min-width: 740px) {
	.greeting_inner {
		margin-top: 130px;
		padding: 145px 40px 40px;
		border-radius: 40px;
	}
}
@media screen and (min-width: 900px) {
	.greeting_inner {
		/* margin-top: 100px; */
		/* padding: 130px 40px 40px; */
		border-radius: 40px;
	}
}
@media screen and (min-width: 1024px) {
	.greeting_inner {
		margin-top: 200px;
	}
}

.greeting_inner::before {
	position: absolute;
	content:"";
	bottom: -55px;
	right: 0;
	width: 150px;
	height: 150px;
	background-image: url(../img/man_kirakira.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}
@media screen and (min-width: 740px) {
	.greeting_inner::before {
		bottom: -70px;
		right: 10px;
		width: 180px;
		height: 180px;
	}
}

.greeting_header {
	position: absolute;
	top: -90px;
	left: 50%;
	transform: translateX(-50%);
	width: 170px;
	height: 170px;
	border-radius:50%;
	background: var(--color-bg-main_01);
	/*display:flexで中央配置*/
	color: var(--color-bg-white);
	outline: 2px solid var(--color-bg-white);
	outline-offset: -10px;
	display:flex;
	align-items: center;
	justify-content:center;
	align-content: center;
	flex-direction: column;
	padding-top: 10px;
}
@media screen and (min-width: 740px) {
	.greeting_header {
		top: -110px;
		left: 50%;
		width: 200px;
		height: 200px;
	}
}

.greeting_header span {
	display: block;
}
.greeting_header_1st{
	font-size: 20px;
	padding: 0 5px;
	font-weight: 100;
	border-bottom: 1px solid var(--color-bg-white);
}
@media screen and (min-width: 740px) {
	.greeting_header_1st {
		font-size: 25px;
	}
}
.greeting_header_2nd{
	font-size: 12px;
	font-weight: 100;
	margin-top: 7px;
}
@media screen and (min-width: 740px) {
	.greeting_header_2nd {
		font-size: 14px;
	}
}
.greeting_inner_box {
	max-width: 600px;
	margin: 0 auto;
	line-height: 1.7;
}
.emphasized_phrase {
	padding: 40px 0 40px;
	text-align: center;
	font-size: 15px;
	font-weight: bold;
}
@media screen and (min-width: 740px) {
	.emphasized_phrase {
		font-size: 20px;
	}
}

/* ページリンクボックス（交互） */

.l-page_link {
    padding: 100px 0 0;
    margin: 0;
    display: block;
    width: 100%;
}
.page_link_inner {
	position: relative;
	margin-top: 0px;
	padding: 30px;
	border-radius: 20px;
	background-color: #fff;
	display: flex;
	flex-direction: column;
}
@media screen and (min-width: 740px) {
	.page_link_inner {
		margin-top: 0px;
		padding: 60px;
		border-radius: 40px;
		flex-direction: row;
	}
}
.page_link_inner::before {
	position: absolute;
	content:"";
	top: -85px;
	left: -60px;
	width: 200px;
	height: 200px;
	border-radius: 50%;
	background-color: var(--color-bg-sub_02);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	z-index: -1;
}
.page_link_inner.page_worksClass::before {
	background-color: var(--color-bg-sub_01);
	left: auto;
	right: -60px;
}


@media screen and (min-width: 740px) {
	.page_link_inner.page_worksClass {
		flex-direction: row-reverse;
	}
}

.page_link_left {
	width: 100%;
	padding: 0 0 20px;
}
@media screen and (min-width: 740px) {
	.page_link_left {
		width: 50%;
		padding: 0;
	}
}
.page_link_right {
	width: 100%;
	padding: 0 0 20px;
}
@media screen and (min-width: 740px) {
	.page_link_right {
		width: 50%;
		padding: 0;
	}
}
.link_img_box{
	padding: 0;
	background: var(--color-bg-sub_02);
	border-radius: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	aspect-ratio: 4 / 3;
}
@media screen and (min-width: 740px) {
	.link_img_box {
		aspect-ratio: 1 / 1;
	}
}
.link_img{
	/* object-fit: contain; */
	width: 50%;
}
.page_link_inner.page_worksClass .link_img {
	width: 60%;
}

.page_link_inner.page_worksClass .link_img_box {
	background: var(--color-bg-sub_01);
}

.page_link_text {
	position: relative;
	padding: 20px 16px;
	font-weight: 500;
}
@media screen and (min-width: 740px) {
	.page_link_text {
		position: absolute;
		top: 135px;
		width: 40%;
		padding: 20px 0;
	}
}
@media screen and (min-width: 740px) {
	.page_link_inner.page_worksClass .page_link_text {
		right: 50px;
	}
}

.page_link_btn {
	padding: 10px 0;
}

@media screen and (min-width: 740px) {
	.page_link_btn {
		position: absolute;
		bottom: 60px;
		padding: 0;
		width: 100%;
		max-width: 250px;
	}
}

/* ------------------------------ */
/*　　　　　 サブページ　　　　　　 */
/* ------------------------------ */
/* top */
.l-subTop {
	padding: 50px 0 0;
	position: relative;
}
@media screen and (min-width: 740px) {
	.l-subTop {
		padding: 110px 0 0;
	}
}
.l-subTop::before {
	position: absolute;
	content: "";
	top: -10px;
	left: -50px;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background-color: var(--color-bg-sub_02);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	z-index: -1;
}
@media screen and (min-width: 740px) {
	.l-subTop::before {
		top: 0px;
		left: -80px;
		width: 150px;
		height: 150px;
	}
}

.l-subTop_inner{
	padding: 20px;
}
.sub_page_text {
	position: relative;
	padding: 6px 0px 0;
	font-weight: 500;
	font-size: 12px;
}
@media screen and (min-width: 740px) {
	.sub_page_text {
	font-size: 14px;
	}
}

/* 見出し下のサムネイル画像 */
.thumbnail_img_wrap{
	padding: 50px 0 30px;
	margin-bottom: 20px;
	background: var(--color-bg-sub_02);
	border-radius: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column-reverse;
	gap: 20px;
}
@media screen and (min-width: 740px) {
	.thumbnail_img_wrap{
		flex-direction:row;
		padding: 70px 0 70px;
		gap: 0;
	}
}
.content_title {
	/* display: none; */
	color: var(--color-bg-white);
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0.08em;
}
@media screen and (min-width: 740px) {
	.content_title {
		width: 50%;
		display: flex;
		justify-content: center;
		font-size: 60px;
		letter-spacing: 0.05em;
	}
}
@media screen and (min-width: 1024px) {
	.content_title {
		font-size: 80px;
		letter-spacing: 0.08em;
	}
}
.content_img {
	display: flex;
	width: 50%;
	justify-content: center;
}
@media screen and (min-width: 740px) {
	.content_img {
		display: flex;
		width: 50%;
		justify-content: center;
	}
}
.link_img_class {
	/* object-fit: contain; */
	width: 80%;
}

