@charset "UTF-8";
figcaption {
  display: block !important;
  margin-top: 0.75rem;
  margin-bottom: 0;
  color: inherit;
  font-size: 0.8rem;
  line-height: 1.5;
  text-align: center;
  opacity: var(--ark-opacity--thin);
}

[class*=arkhe-svg-]:not([width]) {
  width: 1em;
  height: 1em;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}

::before,
::after {
  box-sizing: inherit;
  text-decoration: inherit;
  vertical-align: inherit;
}

b,
strong {
  font-weight: bold;
}

main {
  display: block;
}

ruby > rt {
  font-size: 50%;
}

img {
  max-width: 100%;
  height: auto;
  border-style: none;
}

video {
  outline: none;
}

svg:not([fill]) {
  fill: currentcolor;
}

[hidden] {
  display: none; /* Add the correct display in IE */
}

/* Form */
button,
input,
optgroup,
select,
textarea {
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}

/* Show the overflow in IE. */
button,
input { /* Show the overflow in Edge. */
  overflow: visible;
}

/* Remove the inheritance of text transform in Edge, Firefox, and IE.  */
button,
select { /* Remove the inheritance of text transform in Firefox. */
  text-transform: none;
}

/* button */
button,
[type=button],
[type=reset],
[type=submit] {
  display: inline-block;
  cursor: pointer;
  -webkit-appearance: button;
}

[role=button] {
  cursor: pointer;
}

/* normalize 通り */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/* normalize 通り */
legend {
  display: table;
  box-sizing: border-box;
  max-width: 100%;
  padding: 0;
  color: inherit;
  white-space: normal;
}

input,
textarea,
select,
button {
  padding: 0.25em 0.5em;
  color: #333;
  border: 1px solid var(--ark-color--border);
  border-radius: 0;
}

[type=color] {
  padding: 0;
}

[type=range] {
  vertical-align: middle;
}

/*
 * Accessibility
 */
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default;
}

/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
  }
}
:root {
  --ark-mt: 2rem;
  --ark-mt--s: 1rem;
  --ark-mt--h: 2.5em;
  --ark-font_family: "Helvetica Neue", "Arial", "Hiragino Kaku Gothic ProN",
    "Hiragino Sans", "Meiryo", sans-serif;
  --ark-font_size: min(18px, 4vw);
  --ark-line_height: 1.8;
  --ark-letter_spacing: 0.025em;
  --ark-padding--container: min(48px, 4vw);
  --ark-color--border: rgba(200, 200, 200, 0.5);
  --ark-color--border--table: #ededed;
  --ark-color--gray--hover: rgba(150, 150, 150, 0.05);
  --ark-opacity--thin: 0.75;
  --ark-header_height: 0px;
  --ark-header_height--fixed: 0px;
  --ark-adminbar_height: 0px;
  --ark-scrollbar_width: 0px;
  --ark-100vh: 100vh;
  --ark-fz--xs: 0.75em;
  --ark-fz--s: 0.9em;
  --ark-fz--n: 1rem;
  --ark-fz--m: 1.1em;
  --ark-fz--l: 1.25em;
  --ark-fz--xl: 1.5em;
  --ark-fz--xxl: 2em;
  --ark-fz--huge: 3em;
  --ark-submenu_btn_size: 1.75rem;
}

html {
  font-size: var(--ark-font_size);
  letter-spacing: var(--ark-letter_spacing);
}

body {
  --ark-offset--y: calc(
    var(--ark-adminbar_height) + var(--ark-header_height--fixed)
  );
  --ark-height--full: calc(var(--ark-100vh, 100vh) - var(--ark-offset--y));
}

body.admin-bar {
  --ark-adminbar_height: var(--wp-admin--admin-bar--height, 32px);
}
@media screen and (max-width: 782px) {
  body.admin-bar {
    --ark-adminbar_height: var(--wp-admin--admin-bar--height, 46px);
  }
}

@supports (height: 100svh) {
  .l-main__body > .c-postContent > :first-child {
    --ark-100vh: 100svh; /* stylelint-disable-line */
  }
}

.l-header[data-overlay="1"] + .l-content .l-main__body > .c-postContent > :first-child {
  --ark-height--full: calc(
    var(--ark-100vh, 100vh) - var(--ark-adminbar_height)
  );
}

.l-header:not([data-overlay]) + .l-content .l-main__body > .c-postContent > :first-child {
  --ark-height--full: calc(
    var(--ark-100vh, 100vh) - var(--ark-adminbar_height) -
      var(--ark-header_height)
  );
}

body {
  /* stylelint-disable-line */
  --ark-color_main: var(--ark-color--main);
  --ark-color_text: var(--ark-color--text);
  --ark-color_link: var(--ark-color--link);
  --ark-color_bg: var(--ark-color--bg);
  --ark-color_gray: var(--ark-color--gray);
  --ark-hover_gray: var(--ark-color--gray--hover);
  --ark-color_border: var(--ark-color--border);
  --ark-pad--container: var(--ark-padding--container);
  --ark-container_width: var(--ark-width--container);
  --ark-article_width: var(--ark-width--article);
  --ark-slim_width: var(--ark-width--article--slim);
}

body {
  position: relative;
  min-width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  color: var(--ark-color--text);
  font-weight: 400;
  font-size: 1rem;
  font-family: var(--ark-font_family);
  line-height: 1.5;
  word-wrap: break-word;
  overflow-wrap: break-word;
  background-color: var(--ark-color--bg);
  -webkit-text-size-adjust: 100%;
}

a {
  color: var(--ark-color--link);
}

/**
 * フロントはそのまま、エディターでは .editor-styles-wrapper でラップされる
 */
/* ---------- 見出し ---------- */
h1,
h2,
h3,
h4,
h5,
h6 {
  --ark-mt: var(--ark-mt--h);
  font-weight: 700;
  line-height: 1.5;
}

h1 {
	font-size: 2.027rem;
}
h2 {
	font-size: 1.802rem;
}
h3 {
	font-size: 1.602rem;
}
h4 {
	font-size: 1.424rem;
}
h5 {
	font-size: 1.266rem;
}
h6 {
	font-size: 1.125rem;
}

@media not all and (min-width: 1000px) {
  h1 {
    font-size: 2.027rem;
  }
  h2 {
    font-size: 1.802rem;
  }
  h3 {
    font-size: 1.602rem;
  }
  h4 {
    font-size: 1.424rem;
  }
  h5 {
    font-size: 1.266rem;
  }
  h6 {
    font-size: 1.125rem;
  }
}
/* ---------- 引用 ---------- */
blockquote {
  padding: 0.25em 1em;
  background: none;
  border-left: solid 2px var(--ark-color--border);
  quotes: none;
}
blockquote cite {
  display: block;
  margin-top: 1em;
  font-size: 0.8em;
  opacity: 0.75;
}

/* ---------- テーブル ---------- */
table {
  width: 100%;
  max-width: 100%;
  text-align: left;
  border: none;
  border-top: solid 1px var(--ark-color--border--table);
  border-right: solid 1px var(--ark-color--border--table);
  border-collapse: collapse;
  border-spacing: 0;
}
table caption {
  margin-top: 0.75rem;
  font-size: 0.9rem;
  opacity: var(--ark-opacity--thin);
}

th,
td {
  padding: var(--ark-padding--cell, 0.5em 0.75em) !important;
  vertical-align: top;
  word-break: break-all;
  border-bottom: solid 1px var(--ark-color--border--table);
  border-left: solid 1px var(--ark-color--border--table);
}

:where(thead) td,
:where(thead) th {
  color: #fff;
  background-color: var(--ark-color--main);
}

:where(tbody) th {
  font-weight: bold;
  background-color: var(--ark-color--gray);
}

/* ---------- pre ---------- */
pre,
code {
  -moz-tab-size: 4;
  -o-tab-size: 4;
     tab-size: 4;
}

pre {
  padding: 1rem;
  overflow-x: auto;
  background-color: var(--ark-color--gray);
}
pre code {
  font-size: 0.9rem;
  font-family: Menlo, Consolas, monaco, monospace;
}

/* ---------- 横線 ---------- */
hr:not(.wp-block-separator) {
  border: none;
  border-bottom: solid 1px rgba(0, 0, 0, 0.1);
}

/* ---------- インライン装飾 ---------- */
kbd,
:not(pre) > code {
  display: inline-block;
  margin: 0 0.25em;
  padding: 0.2em 0.5em;
  color: #3f3f3f;
  font-size: 0.9em;
  font-family: Menlo, Consolas, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "メイリオ", sans-serif;
  line-height: 1.5;
  letter-spacing: 0;
  text-decoration: inherit;
  background: #edf0f3;
  border-radius: 3px;
}

kbd {
  background-color: #fbfbfb;
  box-shadow: 0 1px 0 1px rgba(0, 0, 0, 0.15), 0 0 1px rgba(0, 0, 0, 0.1);
}

small {
  font-size: 0.75em;
  opacity: var(--ark-opacity--thin);
}

sup,
sub {
  font-size: 0.75em;
}

/* ---------- リスト ---------- */
ul,
ol {
  margin: 0;
  padding: var(--ark-list-padding, 0 0 0 1.5em);
}
ul.has-background,
ol.has-background {
  padding: var(--ark-list-padding--has_bg, 1em 1em 1em 2.25em);
}

/* ---------- その他 ---------- */
iframe {
  display: block;
  max-width: 100%;
  margin-right: auto;
  margin-left: auto;
}

#toc_container {
  margin-bottom: 30px;
  padding: 1em 1em 1em 2em;
  border: 0;
  border-top: 5px solid var(--ark-color_link);
  border-radius: 5px;
  box-shadow: 0 2px 3px rgba(0, 0, 0, 0.15);
  background-color: #f7f7f7;
}
#toc_container .toc_title {
  display: flex;
  align-items: center;
  margin: 0;
  color: var(--ark-color_link);
  font-weight: 600;
  font-size: 1.2em;
}
#toc_container .toc_title::before {
  display: inline-block;
  width: 2.2em;
  height: 2.2em;
  margin-right: 5px;
  border-radius: 50%;
  background: var(--ark-color_link) url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M3.8%2017.2h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.8-.8-.8zm0-15h-3c-.5%200-.8.4-.8.8v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8V3c-.1-.4-.4-.8-.8-.8zm0%207.6h-3c-.5%200-.8.3-.8.7v3c0%20.4.3.8.8.8h3c.4%200%20.8-.3.8-.8v-3c-.1-.4-.4-.7-.8-.7zM23.2%2018h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8zm0-15h-15c-.4%200-.7.3-.7.8v1.5c0%20.4.3.7.7.7h15c.5%200%20.8-.3.8-.8V3.8c0-.5-.3-.8-.8-.8zm0%207.5h-15c-.4%200-.8.3-.8.8v1.5c0%20.4.3.8.8.8h15c.4%200%20.8-.3.8-.8v-1.5c0-.5-.3-.8-.8-.8z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/1em;
  content: "";
}
#toc_container ul {
  list-style-type: decimal;
  margin: 0;
  padding: 0 1.2em;
  overflow: hidden;
}
#toc_container ul ul {
  margin-top: 5px;
}
#toc_container ul ul li {
  font-weight: 500;
  font-size: 0.9em;
}
#toc_container ul li {
  padding: 5px 0;
  font-weight: 600;
}
#toc_container ul a {
  color: #555;
  text-decoration: none;
}
#toc_container > ul {
  margin-top: 15px;
}

.p-entry__foot {
  background: #fff;
  padding: 3rem;
  padding-bottom: 1rem;
  border-radius: 40px;
}
.p-entry__foot .c-postTerms__link {
  background: inherit;
  color: var(--ark-color--link);
  text-decoration: underline;
}
.p-entry__foot .c-pnNav__link {
  border: 1px solid var(--ark-color_link);
  border-radius: 10px;
  color: var(--ark-color_link);
}
.p-entry__foot .c-pnNav__link:hover {
  background-color: var(--ark-color_main);
  opacity: 1;
  color: white;
}

article.p-entry h2:not(.ark-block-heading__main),
.edit-post-visual-editor__content-area .editor-styles-wrapper .wp-block-post-content h2:not(.ark-block-heading__main) {
  padding: 0.4em 0.5em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  border-left: solid 10px var(--ark-color_link); /*左線*/
  background: rgb(245, 245, 245);
  border-radius: 10px;
}
article.p-entry h3:not(.ark-block-heading__main),
.edit-post-visual-editor__content-area .editor-styles-wrapper .wp-block-post-content h3:not(.ark-block-heading__main) {
  padding: 0.25em 0.5em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  border-bottom: solid 2px var(--ark-color_link); /*左線*/
}
article.p-entry h4:not(.ark-block-heading__main),
.edit-post-visual-editor__content-area .editor-styles-wrapper .wp-block-post-content h4:not(.ark-block-heading__main) {
  padding: 0.25em 0.5em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  border-left: solid 3px var(--ark-color_link); /*左線*/
}
article.p-entry h5:not(.ark-block-heading__main),
.edit-post-visual-editor__content-area .editor-styles-wrapper .wp-block-post-content h5:not(.ark-block-heading__main) {
  padding: 0.25em 0.7em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  position: relative;
}
article.p-entry h5:not(.ark-block-heading__main)::before,
.edit-post-visual-editor__content-area .editor-styles-wrapper .wp-block-post-content h5:not(.ark-block-heading__main)::before {
  width: 7px;
  height: 7px;
  position: absolute;
  border-radius: 50%;
  background-color: var(--ark-color_link);
  left: -3px;
  top: 0;
  bottom: 0;
  content: "";
  margin: auto 0;
}

h2.kk-heading:not(.ark-block-heading__main) {
  padding: 0.4em 0.5em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  border-left: solid 10px var(--ark-color_link); /*左線*/
  background: rgb(245, 245, 245);
  border-radius: 10px;
  font-weight: normal;
}

h3.kk-heading:not(.ark-block-heading__main) {
  padding: 0.25em 0.5em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  border-bottom: solid 2px var(--ark-color_link); /*左線*/
  font-weight: normal;
}

h4.kk-heading:not(.ark-block-heading__main) {
  padding: 0.25em 0.5em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  border-left: solid 3px var(--ark-color_link); /*左線*/
  font-weight: normal;
}

h5.kk-heading:not(.ark-block-heading__main) {
  padding: 0.25em 0.7em; /*上下 左右の余白*/
  color: var(--ark-color_text); /*文字色*/
  position: relative;
  font-weight: normal;
}
h5.kk-heading:not(.ark-block-heading__main)::before {
  width: 7px;
  height: 7px;
  position: absolute;
  border-radius: 50%;
  background-color: var(--ark-color_link);
  left: -3px;
  top: 0;
  bottom: 0;
  content: "";
  margin: auto 0;
  font-weight: normal;
}

.c-pnNav {
  -moz-column-gap: 10px;
       column-gap: 10px;
  flex-wrap: nowrap !important;
}

.w-single-bottom {
  margin-top: 0 !important;
  padding-bottom: 3rem !important;
}

.l-header {
  width: 100%;
  background: #fff;
  color: var(--ark-color--text);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  z-index: 1000;
}
.l-header__center {
  padding: 1rem 2rem;
}
@media not all and (min-width: 1000px) {
  .l-header__center {
    padding: 0.5rem 1rem;
  }
}
.l-header__right {
  flex: 0 0 auto;
}
.l-header__right #gnav {
  margin-right: 1.5rem;
}
.l-header__right #gnav .c-gnav {
  gap: 1.5rem;
}
.l-header__right #gnav .c-gnav .menu-item {
  transition: background-color 0.3s;
}
.l-header__right #gnav .c-gnav .menu-item.focus, .l-header__right #gnav .c-gnav .menu-item:hover {
  background: var(--ark-color--link) !important;
  color: white !important;
}
.l-header__right #gnav .c-gnav .menu-item.current-menu-item {
  color: var(--ark-color--link);
}
.l-header__right #gnav .c-gnav .__mainText {
  font-size: 1rem;
  font-weight: 600;
}
.l-header__right #gnav .c-gnav .sub-menu {
  background: white;
  color: var(--ark-color--text);
}
.l-header__right .c-contact-btn {
  display: flex;
  align-items: center;
  height: 100%;
  padding: 12px 32px;
  font-weight: bold;
  font-size: 20px;
  background: var(--ark-color--main);
  color: var(--ark-color--text);
  text-decoration: none;
  transition: opacity 0.3s;
}
.l-header__right .c-contact-btn:hover {
  background: var(--ark-color--main) !important;
  opacity: 0.6;
}
.l-header__right .c-contact-btn__icon {
  margin-right: 8px;
}
.l-header__right .c-contact-btn__icon svg {
  fill: currentColor;
}
.l-header__right .c-contact-btn__text {
  font-size: 18px;
  font-weight: bold;
}
.l-header__right .c-contact-btn:hover {
  background: #003d82;
}

.c-contact-btn {
  display: flex;
  align-items: center;
  height: 100%;
  padding: 12px 32px;
  font-weight: bold;
  font-size: 20px;
  background: var(--ark-color--main);
  color: var(--ark-color--text);
  text-decoration: none;
  transition: opacity 0.3s;
}
.c-contact-btn:hover {
  background: var(--ark-color--main) !important;
  opacity: 0.6;
}
.c-contact-btn__icon {
  margin-right: 8px;
}
.c-contact-btn__icon i {
  font-size: 1.2em;
}
.c-contact-btn__text {
  font-size: 18px;
  font-weight: bold;
}

.p-drawer__contact {
  padding: 1rem;
  margin-top: 2rem;
}
.p-drawer__contact .c-contact-btn {
  justify-content: center;
  width: 100%;
  border-radius: 4px;
  height: auto;
}
@media not all and (min-width: 1000px) {
  .p-drawer__contact .c-contact-btn__text {
    font-size: 16px;
  }
}

.p-page__title {
  flex-direction: column-reverse;
  align-items: flex-start;
}
.p-page__title .c-pageTitle__sub {
  text-align: left;
  color: var(--ark-color--link);
  font-style: normal;
}
.p-page__title .c-pageTitle__sub::before, .p-page__title .c-pageTitle__sub::after {
  display: none;
}

.p-topArea {
  min-height: 20vh;
}

.p-topArea.-noimg {
  background: color-mix(in srgb, var(--ark-color--main) 15%, white);
}
.p-topArea.-noimg .p-topArea__title {
  color: var(--ark-color--text);
}

.p-topArea__title {
  display: flex;
  flex-direction: column-reverse;
}

.c-pageTitle__main {
  font-size: 2.2rem;	
  text-align: left;
}

.c-pageTitle__sub {
  text-align: left;
  font-style: normal;
}
.c-pageTitle__sub::before, .c-pageTitle__sub::after {
  display: none;
}

#footer {
  --ark-color--main: #82bcb1;
  background-color: color-mix(in srgb, var(--ark-color--main) 20%, transparent) !important;
}
#footer .kk-footer__column {
  padding: 2rem 0 2rem 0;
  display: grid;
  grid-template-columns: 50% 50%;
  width: 100%;
}
@media not all and (min-width: 1000px) {
  #footer .kk-footer__column {
    grid-template-columns: 100%;
    row-gap: 2rem;
  }
  #footer .kk-footer__column .widget_block {
    display: flex;
    justify-content: center;
  }
  #footer .kk-footer__column .kk-footer__menu:first-child {
    border: 0;
  }
}
#footer .kk-footer-company-info {
  max-width: 338px;
  width: 100%;
}
#footer .kk-footer-company-info .kk-footer-button a.ark-block-button__link {
  padding: 1rem;
}
#footer .kk-footer-company-info .kk-footer-sns-button a.ark-block-button__link {
  padding: 1rem 0.5rem;
}
#footer .kk-footer__menu_right {
  display: grid;
  grid-template-columns: 50% 50%;
  width: 100%;
}
#footer ul.kk-footer__menu {
  list-style: none;
}
#footer ul.kk-footer__menu > li {
  margin-bottom: 1.5rem;
}
#footer ul.kk-footer__menu ul {
  list-style: disc;
  color: #626264;
}
#footer ul.kk-footer__menu a {
  text-decoration: none;
}
#footer ul.kk-footer__menu a:hover {
  opacity: 0.6;
}
#footer .kk-footer__menu > li {
  position: relative;
  margin-bottom: 1rem;
}
#footer .kk-footer__menu a {
  color: #333;
  text-decoration: none;
  font-size: 1rem;
  transition: color 0.3s;
}
#footer .kk-footer__menu a:before {
  content: "\f0da";
  font-family: "Font Awesome 7 Free";
  color: var(--ark-color--main);
  font-weight: 900;
  margin-right: 0.5rem;
  font-size: 0.8em;
}
#footer .kk-footer__menu a:hover {
  color: #666;
}
#footer .kk-footer__menu .sub-menu {
  list-style: none;
  padding-left: 1.5rem;
  margin-top: 0.5rem;
}
#footer .kk-footer__menu .sub-menu li {
  margin-bottom: 0.5rem;
}
#footer .kk-footer__menu .sub-menu a {
  font-size: 0.9rem;
}
@media not all and (min-width: 1000px) {
  #footer .kk-footer-title {
    font-size: var(--ark-fz--l) !important;
  }
}
#footer .l-footer__foot {
  background-color: var(--ark-color--main);
  font-weight: bold;
}

.veu_adminEdit {
  display: none !important;
}

@media not all and (min-width: 1000px) {
  .kk-footer-subtext {
    font-size: 0.85rem !important;
  }
}

.post-name-top {
  /* arkp-scMV07 */
}
.post-name-top .arkp-scMV07 {
  --arkp--media--width: 70%;
  --arkp--sec-body--max-width: inherit;
  --arkp--heading--fz: 3.2rem;
  --arkp--txt--width: 480px;
}
@media screen and (max-width: 1200px) {
  .post-name-top .arkp-scMV07 {
    height: 50vh;
    min-height: 600px;
    max-height: 600px;
  }
}
@media not all and (min-width: 1000px) {
  .post-name-top .arkp-scMV07 {
    min-height: unset;
    max-height: unset;
    overflow: visible;
    background-color: #fffbf6;
    height: auto !important;
    position: relative;
  }
  .post-name-top .arkp-scMV07::after {
    content: "";
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    width: 200%;
    aspect-ratio: 2/1;
    background-color: #fffbf6;
    border-radius: 50%;
    z-index: -1;
  }
}
.post-name-top .arkp-scMV07 .arkb-absLayer {
  left: 0;
  right: auto;
  width: var(--arkp--media--width);
  border-radius: 0 0 100px 0 !important;
  overflow: hidden;
}
@media screen and (max-width: 1500px) {
  .post-name-top .arkp-scMV07 .arkb-absLayer {
    width: 60%;
  }
}
@media not all and (min-width: 1000px) {
  .post-name-top .arkp-scMV07 .arkb-absLayer {
    width: 100%;
    height: 50vh;
  }
}
.post-name-top .arkp-scMV07:where(.alignfull):not([data-inner=full]) > .ark-block-section__body {
  max-width: var(--arkp--sec-body--max-width);
  position: relative;
}
@media not all and (min-width: 1000px) {
  .post-name-top .arkp-scMV07 .ark-block-section__body {
    padding-top: 50vh;
  }
}
.post-name-top .arkp-scMV07 .ark-block-heading {
  position: absolute;
  left: 65%;
  transform: translateY(-50%);
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1500px) {
  .post-name-top .arkp-scMV07 .ark-block-heading {
    left: 55%;
  }
}
@media not all and (min-width: 1000px) {
  .post-name-top .arkp-scMV07 .ark-block-heading {
    transform: translateY(10px);
    position: relative;
    left: 0;
    width: 100%;
    padding: 0 1.5rem;
  }
}
.post-name-top .arkp-scMV07 .ark-block-heading .ark-block-heading__main {
  line-height: 258%;
  letter-spacing: 0.05em;
  font-size: 26px !important;
  text-shadow: #fff 0 0 10px, #fff 0 0 10px, #fff 0 0 10px, #fff 0 0 10px, #fff 0 0 10px;
  animation: slideBottomToUp 1.4s ease 0s 1 normal forwards;
  animation-delay: 0.5s;
  opacity: 0;
}
@media screen and (max-width: 1200px) {
  .post-name-top .arkp-scMV07 .ark-block-heading .ark-block-heading__main {
    font-size: 22px !important;
  }
}
@media not all and (min-width: 1000px) {
  .post-name-top .arkp-scMV07 .ark-block-heading .ark-block-heading__main {
    font-size: 20px !important;
  }
}
@media screen and (max-width: 450px) {
  .post-name-top .arkp-scMV07 .ark-block-heading .ark-block-heading__main {
    font-size: 16px !important;
  }
}
@keyframes slideBottomToUp {
  0% {
    opacity: 0;
    transform: translateY(20%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.post-name-top .arkp-scMV07 .arkp-scMV07_txt {
  width: var(--arkp--txt--width);
  max-width: 100%;
}
.post-name-top .arkp-scMV07 .wp-block-image img {
  width: 100% !important;
  height: 100% !important;
  -o-object-fit: cover;
     object-fit: cover;
}
.post-name-top .navigation-column {
  justify-content: center !important;
}
.post-name-top .navigation-banner {
  overflow: visible;
  height: 350px;
}
@media not all and (min-width: 1000px) {
  .post-name-top .navigation-banner {
    height: auto;
    margin-bottom: 50%;
  }
}
.post-name-top .navigation-banner__button {
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: auto;
  aspect-ratio: 350/291;
  max-width: 350px;
  border: 10px solid #f0b889;
  border-radius: 15px;
  text-align: center;
  color: var(--ark-color--text);
  background-color: #fff;
  box-shadow: 3px 3px 4px rgba(0, 0, 0, 0.1);
  transition: box-shadow, opacity, 0.3s;
}
.post-name-top .navigation-banner__button:hover {
  opacity: 0.7;
  box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.1);
}
@media not all and (min-width: 1000px) {
  .post-name-top .navigation-banner__button {
    margin-bottom: -50%;
  }
}
.post-name-top .navigation-banner__button h5 {
  position: relative;
  display: inline-block;
  z-index: 5;
}
.post-name-top .navigation-banner__button h5::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  width: 120%;
  height: 10px;
  background: rgba(240, 184, 137, 0.2);
}
.post-name-top .navigation-banner__button.sensei {
  border-color: #82bcb1;
}
@media not all and (min-width: 1000px) {
  .post-name-top .navigation-banner__button.sensei {
    transform: translateY(0%);
  }
}
.post-name-top .navigation-banner__button.sensei h5::after {
  background: rgba(130, 188, 177, 0.2);
}
.post-name-top .top-news-button a {
  font-size: 1.125rem;
  font-weight: bold;
}

@keyframes fadeInAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
header {
  animation-name: fadeInAnime;
  animation-duration: 1000ms;
  animation-fill-mode: forwards;
  opacity: 0;
  animation-delay: 100ms;
}

#main_content {
  animation-name: fadeInAnime;
  animation-duration: 1000ms;
  animation-fill-mode: forwards;
  opacity: 0;
  animation-delay: 400ms;
}

/* フォーム全体のスタイル */
.contact-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 40px;
}

/* 必須マーク */
.color-red {
  color: #ff3366;
  font-size: 12px;
  font-weight: 500;
  background-color: #fff5f7;
  padding: 2px 8px;
  border-radius: 4px;
  margin-left: 8px;
  display: inline-block;
  line-height: 1.4;
}

/* dl要素のスタイル */
.contact-content-inner {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 28px;
  padding-bottom: 28px;
  border-bottom: 1px solid #eef2f6;
  position: relative;
}

.contact-content-inner:last-of-type {
  border-bottom: none;
}

/* dt要素（ラベル）のスタイル */
.contact-content-inner dt {
  width: 220px;
  padding: 15px 0;
  font-weight: 600;
  color: #2c3e50;
  font-size: 0.95em;
  letter-spacing: 0.02em;
}

/* dd要素（入力項目）のスタイル */
.contact-content-inner dd {
  width: calc(100% - 220px);
  padding: 10px 0;
  margin: 0;
}

/* 入力フィールドの共通スタイル */
.wpcf7-form-control {
  width: 100%;
  padding: 14px 18px;
  border: 2px solid #eef2f6;
  border-radius: 12px;
  font-size: 15px;
  transition: all 0.3s ease;
  background: #f8fafc;
}

.wpcf7-form-control:focus {
  outline: none;
  border-color: var(--ark-color_link);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1);
}

.wpcf7-radio {
  border: 0 !important;
  padding: 0 !important;
}

/* テキストエリアのスタイル */
textarea.wpcf7-form-control {
  height: 180px;
  resize: vertical;
  line-height: 1.6;
}

/* 送信ボタンのスタイル */
input[type=submit] {
  background: var(--ark-color_link) !important;
  color: white;
  padding: 16px 48px;
  min-width: 200px;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
  transition: all 0.3s ease;
  width: auto;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

input[type=submit]:hover {
  opacity: 0.8;
}

input[type=submit]:active {
  opacity: 1;
}

/* エラーメッセージのスタイル */
.wpcf7-not-valid-tip {
  color: #ff3366;
  font-size: 0.85em;
  margin-top: 8px;
  padding-left: 4px;
  display: flex;
  align-items: center;
  opacity: 0;
  animation: fadeIn 0.3s ease forwards;
}

@keyframes fadeIn {
  to {
    opacity: 1;
  }
}
.wpcf7-response-output {
  margin: 32px 0;
  padding: 16px 24px;
  border-radius: 12px;
  font-size: 0.95em;
  line-height: 1.6;
  text-align: center;
  border: none !important;
}

.wpcf7-validation-errors {
  background: #fff5f7;
  color: #ff3366;
}

.wpcf7-mail-sent-ok {
  background: #f0fdf4;
  color: #16a34a;
}

/* プレースホルダーのスタイル */
::-moz-placeholder {
  color: #94a3b8;
  opacity: 1;
}
::placeholder {
  color: #94a3b8;
  opacity: 1;
}

/* 画像認証のスタイル */
.wpcf7-captchar {
  width: 140px;
  margin-left: 12px;
}

.wpcf7-captchac {
  width: 80px;
  vertical-align: middle;
  border-radius: 8px;
  border: 2px solid #eef2f6;
  padding: 4px;
}

/* フォーカス時のラベルスタイル */
.contact-content-inner:focus-within dt {
  color: var(--ark-color_link);
  transition: color 0.3s ease;
}

/* エラー状態のスタイル */
.wpcf7-not-valid {
  border-color: #ff3366;
  background: #fff5f7;
}

/* 入力中のフィールドスタイル */
.wpcf7-form-control:not(:-moz-placeholder-shown) {
  background: #ffffff;
}
.wpcf7-form-control:not(:placeholder-shown) {
  background: #ffffff;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .contact-content {
    padding: 24px;
    margin: 16px;
    border-radius: 12px;
  }
  .contact-content-inner dt,
  .contact-content-inner dd {
    width: 100%;
  }
  .contact-content-inner dt {
    padding: 8px 0;
  }
  .contact-content-inner {
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
  input[type=submit] {
    width: 100%;
    padding: 16px;
  }
  .wpcf7-captchar {
    width: 100%;
    margin: 8px 0 0 0;
  }
}
/* アクセシビリティ対応 */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
.kk-title {
  display: flex;
  justify-content: center;
  align-items: center;
}
.kk-title .wp-block-heading {
  display: inline-block;
}
.kk-title__sub {
  justify-content: flex-start !important;
  padding-right: 16px !important;
}

.c-fixBtn {
  background-color: var(--ark-color_link);
}/*# sourceMappingURL=main.css.map */

.p-postList__meta .c-postTimes__item, .p-postList__meta .p-postList__category {
font-size: 14px !important;
}

/* ページヘッダー修正 */
#top_title_area {
    background-color: #f9f4bd88;
}

#top_title_area .p-topArea__title.c-pageTitle {
    color: var(--ark-color--text);
}