@charset "utf-8";

/* ========== root ========== */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: none;
font-style: normal;
text-align: left;
zoom: 1;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
table {
border-collapse: collapse;
font-family: inherit;
}
h1,h2,h3,h4,h5 {
font-size: 100%;
font-weight: normal;
line-height: 1;
}
input,textarea,select {
font-family: inherit;
font-size: 16px;
}
input[type=
],input[type=
],input[type=
] {
-webkit-appearance: none;
border-radius: 0;
}
textarea {
resize: none;
-webkit-appearance: none;
border-radius: 0;
}
th,td {
border-collapse: collapse;
}
table th,table td {
white-space: nowrap;
}
ul,ol {
list-style-type: none;
}
img {
vertical-align: text-bottom;
vertical-align: -webkit-baseline-middle;
width: 100%;
max-width: 100%;
height: auto;
box-sizing: border-box;
object-fit: cover;
}
a {
  text-decoration: none;
  color: inherit;
}
a:link, a:visited, a:hover, a:active {
  text-decoration: none;
  color: inherit;
}
body, html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: 'dnp-shuei-gothic-gin-std', sans-serif;;
}
*, *:before, *:after {
  box-sizing: border-box;
}

/* ========== root ========== */
:root {
  --color01: #FFFFFF;
  --color02: #6f615d;
  --color03: #FFCD74;
  --color04: #EF90B1;
  --color05: #414141;
  --txt_white: #fff;
  --b_shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  --t_shadow: 1px 1px 3px rgba(104, 104, 104, 0.7);
  --radius: 15px;
  --max-width: 1600px;
  --font_base: 'dnp-shuei-gothic-gin-std', sans-serif;
  --font_sub01: "mina", serif;
  --font_sub02: "hiragino-kaku-gothic-prone", sans-serif;
  --fw-regular: 100;
  --fw-medium: 500;
  --fw-bold: 700;
  --header-height: 70px;
}
/* * {
  outline: 1px solid rgba(255, 0, 0, 0.2);
} */
html {
  scroll-behavior: smooth;
  box-sizing: border-box;
  overflow-wrap: break-word; 
  font-optical-sizing: auto;
  -webkit-font-smoothing: antialiased;
  scroll-padding-top: 80px;
}
.anchor {
  display: block;
  padding-top: var(--header-height);
  margin-top: calc(-1 * var(--header-height));
  visibility: hidden;
}
/* ===== ブレークポイント別の表示制御クラス ===== */

/* 1600px を基準とした表示・非表示 */
@media screen and (max-width: 1600px) {
  .hide-16 { display: none !important; }
  .show-16 { display: block !important; }
}
@media screen and (min-width: 1601px) {
  .show-16 { display: none !important; }
}

/* 1280px を基準とした表示・非表示 */
@media screen and (max-width: 1280px) {
  .hide-12 { display: none !important; }
  .show-12 { display: block !important; }
}
@media screen and (min-width: 1281px) {
  .show-12 { display: none !important; }
}

/* 1024px を基準とした表示・非表示 */
@media screen and (max-width: 1024px) {
  .hide-10 { display: none !important; }
  .show-10 { display: block !important; }
}
@media screen and (min-width: 1025px) {
  .show-10 { display: none !important; }
}

/* 992px を基準とした表示・非表示 */
@media screen and (max-width: 992px) {
  .hide-9 { display: none !important; }
  .show-9 { display: block !important; }
}
@media screen and (min-width: 993px) {
  .show-9 { display: none !important; }
}

/* 830px を基準とした表示・非表示 */
@media screen and (max-width: 830px) {
  .hide-8 { display: none !important; }
  .show-8 { display: block !important; }
}
@media screen and (min-width: 831px) {
  .show-8 { display: none !important; }
}

/* 768px を基準とした表示・非表示 */
@media screen and (max-width: 768px) {
  .hide-7 { display: none !important; }
  .show-7 { display: block !important; }
}
@media screen and (min-width: 769px) {
  .show-7 { display: none !important; }
}

/* 630px を基準とした表示・非表示 */
@media screen and (max-width: 630px) {
  .hide-6 { display: none !important; }
  .show-6 { display: block !important; }
}
@media screen and (min-width: 631px) {
  .show-6 { display: none !important; }
}

/* 480px を基準とした表示・非表示 */
@media screen and (max-width: 480px) {
  .hide-4 { display: none !important; }
  .show-4 { display: block !important; }
}
@media screen and (min-width: 481px) {
  .show-4 { display: none !important; }
}

/* --------------------------------------------
  レスポンシブフォントサイズ（480px ~ 1920pxで可変）
  480px以下：最小値に固定、1920px以上：最大値に固定
-------------------------------------------- */
/* ========== ベース用フォントサイズ ========== */
/* 小さめ文字：14px ~ 16px */
.fs-sm {
  font-size: clamp(0.875rem, 0.813rem + 0.29vw, 1rem); /* 14px~16px */
  line-height: 1.5;
  letter-spacing: 0.02em;
  font-weight: var(--fw-regular);
}
/* 通常文字：16px ~ 18px */
.fs-base {
  font-size: clamp(1rem, 0.893rem + 0.36vw, 1.25rem);
  line-height: 1.7;
  letter-spacing: 0.015em;
  font-weight: var(--fw-regular);
  letter-spacing: 3px;
}
p, a, li {
  font-size: clamp(1rem, 0.938rem + 0.29vw, 1.125rem); /* 16px~18px */
  line-height: 1.7;
  font-weight: var(--fw-regular);
  letter-spacing: clamp(0.125rem, 0.045rem + 0.27vw, 0.313rem);
}
/* やや大きめ：18px ~ 22px */
.fs-md {
  font-size: clamp(1.125rem, 1rem + 0.47vw, 1.375rem);
  line-height: 1.6;
  letter-spacing: 6px;
  font-weight: var(--fw-regular);
}
/* 大きめ見出しなど：20px ~ 26px */
.fs-lg {
  font-size: clamp(1.25rem, 1.063rem + 0.63vw, 1.625rem);
  line-height: 1.4;
  letter-spacing: 0.005em;
  font-weight: var(--fw-regular);
  letter-spacing: 5px;
}
/* 特大：20px ~ 35px */
.fs-xl {
  font-size: clamp(1.25rem, 0.916rem + 1.27vw, 2.188rem);
  line-height: 1.5;
  letter-spacing: 0em;
  font-weight: var(--fw-regular);
  letter-spacing: 5px;
}
/* ========== タイトル・見出し向け ========== */
/* h1：32px ~ 48px */
h1 {
  font-size: clamp(2rem, 1.5rem + 1.56vw, 3rem); /* 32px〜48px */
  font-weight: var(--fw-regular);
  line-height: 1.3;
  letter-spacing: 0em;
}
/* h2：28px ~ 40px */
h2 {
  font-size: clamp(1.5rem, 1.071rem + 1.43vw, 2.5rem);
  font-weight: var(--fw-regular);
  line-height: 1.35;
  letter-spacing: 2px;
}
/* h3：24px ~ 32px */
h3 {
  font-size: clamp(1.375rem, 1.161rem + 0.71vw, 1.875rem); /* 24px〜32px */
  font-weight: var(--fw-regular);
  line-height: 1.4;
  letter-spacing: 0.01em;
}
/* h3：24px ~ 32px */
h4 {
  font-size: clamp(1.25rem, 1.063rem + 0.63vw, 1.688rem); /* 24px〜32px */
  font-weight: var(--fw-regular);
  line-height: 1.4;
  letter-spacing: 0.01em;
}
/* サブタイトルなど：20px ~ 28px */
.ttl-font {
  font-size: clamp(1.25rem, 1.063rem + 0.73vw, 1.75rem); /* 20px〜28px */
  font-weight: var(--fw-regular);
  line-height: 1.5;
  letter-spacing: 0.015em;
}
/* 特大文字（Heroなど）：40px ~ 60px */
.hero-ttl {
  font-size: clamp(2.5rem, 1.875rem + 2.08vw, 3.75rem); /* 40px〜60px */
  font-weight: var(--fw-regular);
  line-height: 1.2;
  letter-spacing: -0.01em;
}
body {
  line-height: 1.6;
  background-color: var(--color01);
  color: var(--color02);
}
.en {
  font-family: var(--font_sub02);
}
.mina {
  font-family: var(--font_sub01);
  transform: rotate(-15deg);
  letter-spacing: 0;
}
/* ========== 汎用ユーティリティクラス ========== */
.flex {
  display: flex;
}
.flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}
.flex-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
.flex-column {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}
/* マージン・パディング */
.mt-1 { margin-top: 1rem; }
.mt-2 { margin-top: 2rem; }
.mt-3 { margin-top: 3rem; }
.mb-1 { margin-bottom: 1rem; }
.mb-2 { margin-bottom: 2rem; }
.mb-3 { margin-bottom: 3rem; }
.pt-1 { padding-top: 1rem; }
.pt-2 { padding-top: 2rem; }
.pt-3 { padding-top: 3rem; }
.pt-5 { padding-top: clamp(2rem, 1.082rem + 3.92vw, 5rem); }
.pb-1 { padding-bottom: 1rem; }
.pb-2 { padding-bottom: 2rem; }
.pb-3 { padding-bottom: 3rem; }
.pb-5 { padding-bottom: clamp(2rem, 1.082rem + 3.92vw, 5rem); }
.m-0 { margin: 0; }
.m-1 { margin: 1rem; }
.m-2 { margin: 2rem; }
.m-3 { margin: 3rem; }
.p-0 { padding: 0; }
.p-1 { padding: 1rem; }
.p-2 { padding: 2rem; }
.p-3 { padding: 3rem; }
.g-1 { gap: 1rem; }
.mx-auto { margin-left: auto; margin-right: auto; }
/* シャドウ・角丸 */
.t-shadow {
  text-shadow: var(--t_shadow);
}
.shadow {
  box-shadow: var(--b_shadow);
}
.round {
  border-radius: var(--radius);
}
/* display */
.inline-block { display: inline-block; }
.block { display: block; }
.none { display: none !important; }
/* width */
.w-100 { width: 100%; }
.w-50 { width: 48%; }
.w-30 { width: 30%; }
.h-100 { height: 100%; }
.h-screen { height: 100vh; }
@media screen and (max-width:1024px) {
  .w-50 { width: 100%; }
  .w-30 { width: 48%; }
}
@media screen and (max-width:480px) {
  .w-30 { width: 100%; }
}
/* grid */
.grid-center {
  display: grid;
  place-items: center;
}
/* container */
.container {
  width: min(100%, var(--max-width));
  margin: 0 auto;
}
@media screen and (max-width:1400px) {
  .container {
    width: min(90%, var(--max-width));
}
}
@media screen and (max-width:992px) {
 .container {
    width: min(90%, var(--max-width));
}
}
@media screen and (max-width:600px) {
  .container {
    width: min(90%, var(--max-width));
}
}
/* center */
.bg-relative {
  position: relative;
  z-index: 1;
}
.center01 {
  display: grid;
  place-items: center;
}
.center02 {
  position: absolute;
  inset: 50% auto auto 50%;
  translate: -50% -50%;
}
.center03 {
  position: absolute;
  inset: 0;
  margin: auto;
}
/* 縦書き */
.tate {
  writing-mode: vertical-rl;
}
/* fede効果 */

.fede-box {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 0.8s ease-out;
  position: relative;
  overflow-x: hidden;
  will-change: transform, opacity;
}
.fade-r, .fade-l, .fade-t, .fade-b, .fade-c {
  opacity: 0;
  transition: all 0.8s ease-out;
}

/* 背景を広げる */
.inverse {
  background-color: #000;
  color: var(--txt_white);
  box-shadow: 0 0 0 100vmax #000;
  clip-path: inset(0 -100vmax);
}
/* 勉強 */
.parent > .child {
  /* 親直下の子要素だけ対象にする
例：.menu > li {} → .menuの直下にあるliだけ */
}
h2 + p {
  /* .sibling1 + .sibling2
直後に続く兄弟要素だけ対象 */
}
h2 ~ p {
  /* .sibling1 ~ .sibling2
後ろに続くすべての兄弟要素が対象 */
}
input[type="text"] {
  /* [type="text"]
<input type="text"> にだけスタイル適用 */
}
a[href^="https"]::after {
  /* [href^="https"]
httpsで始まるリンクだけに適用 */
}
[class*="btn"] {
  /* クラス名にbtnを含む要素全部
例：btn, btn-primary, icon-btnなど */
}
li:not(:last-child) {
  /* :not(selector)
指定したもの以外にスタイル適用 */
}
.card:has(img) {
  /* :has() ← 【超注目・新機能】
特定の子要素を「持っている」親をスタイルできる
（対応ブラウザ：モダン環境） */
}
.section {
}
.red {
  color: red;
}
.white {
  color: var(--color01);
}
/* ========== ヘッダー ========== */
/* header */
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem;
  background: transparent;
  font-family: var(--font_sub02);
  transform: translateY(0);
  transition: transform 0.3s ease;
  will-change: transform;
}
.logotype {
  font-family: sans-serif;
  color: var(--txt_white);
  display: flex;
  align-items: center;
  gap: 1rem;
}
.logotype img {
  height: 45px;
  width: auto;
}
.logotype p {
  font-family: var(--font_sub02);
}
nav {
  display: flex;
  align-items: center;
}
.menu__box {
  display: flex;
  flex-direction: row;
  list-style-type: none;
  flex-wrap: nowrap;
  max-width: 100%;
  gap: 3rem;
}
.menu__box a {
  transition: .3s ease-in-out;
}
.menu__box a:hover {
  opacity: .5;
}
.menu__box {
  color: var(--color02);
}
.menu__item {
  display: flex;
  flex-direction: column;
  padding: 0 1rem 0 1.9rem;
  color: var(--txt_white);
  font-weight: var(--fw-regular);
  text-decoration: none;
  text-transform: uppercase;
  transition: .3s ease-in-out;
}
.menu__item:hover {
  color: var(--color05);
}
#menu__toggle {
  opacity: 0;
}
#menu__toggle:checked ~ .menu__btn > span {
  transform: rotate(45deg);
}
#menu__toggle:checked ~ .menu__btn > span::before {
  top: 0;
  transform: rotate(0);
  background: var(--color02);
}
#menu__toggle:checked ~ .menu__btn > span::after {
  top: 0;
  transform: rotate(90deg);
  background: var(--color02);
}
#menu__toggle:checked ~ .menu__box {
    visibility: visible;
    left: 0;
    margin: 0;
    background: rgb(255 255 255 / 95%);
}
.menu__btn {
  transition-duration: 0.25s;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  position: relative;
  bottom: 2px;
  width: 26px;
  height: 26px;
  cursor: pointer;
  z-index: 2;
}
.menu__btn span {
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: var(--color05);
}
.menu__btn span::before {
    display: inline-block;
    position: absolute;
    width: 100%;
    height: 1px;
    background-color: var(--color05);
    content: "";
    top: -8px;
    transition-duration: 0.25s;
}
.menu__btn span::after {
  display: inline-block;
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: var(--color05);
  content: "";
  top: 8px;
  transition-duration: 0.25s;
}
@media screen and (max-width: 630px) {
  nav nav {
    display: inline;
  }
  .logotype img {
    height: 20px;
  }
.menu__box {
    flex-direction: column;
    position: fixed;
    visibility: hidden;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    margin: -600px 0 0 0;
    padding: 50px 5% 20px;
    text-align: center;
    box-shadow: 1px 0 6px rgba(0, 0, 0, 0.2);
    z-index: 1;
    transition-duration: 0.5s;
    gap: 20px;
}
  .menu__item {
    display: block;
    padding: 12px 24px;
    color: var(--txt_white);
    transition-duration: 0.5s;
  }
  .menu__item:hover {
    background-color: var(--sub_bg02);
  }
}
@media screen and (min-width: 480px) {
  .menu__btn {
    display: none;
  }
  
}

/* ========== フッター全体 ========== */
.site-footer {
    height: 500px;
    background-color: #45332d;
    color: #fff;
    width: 100%;
}
.site-footer .container {
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: space-between;
}
.site-footer .up {
    display: flex;
    justify-content: space-between;
    padding-top: 85px;
    align-items: start;
}
.site-footer .up {}
.site-footer .up .box {
    display: flex;
    align-items: end;
}
.site-footer .up ul li {
  color: var(--txt_white);
}

.site-footer .up img {}
.site-footer .down {
  display: flex;
  justify-content: center;
  gap: 8px;
}
.site-footer .down a,
.site-footer .down div {
  color: var(--txt_white);
}
.footer-menu {
    display: flex;
    flex-direction: column;
    align-items: end;
    gap: 20px;
}
.footer-menu ul {
    display: flex;
    gap: 20px;
}
.footer-menu ul li a {
    transition: .3s ease-in-out;
    color: var(--txt_white);
}
.footer-menu ul li a:hover {
  color: #fff;
}
.site-footer .down a {
  transition: .3s ease-in-out;
}
.site-footer .down a:hover {
  color: #fff;
}
.footer-menu a {}
.footer-menu .social {}
.footer-menu .social a {}
.footer-menu .social a img {
    width: 35px;
    height: auto;
}
.footer-menu .ul {}
.footer-menu .ul li {}
.site-footer .down .link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
@media screen and (max-width:630px) {
.site-footer {
    height: 100%;
}
.site-footer .up img {
    height: 30px;
}
.site-footer .up {
    padding-top: 35px;
    flex-direction: column;
    gap: 35px;
    margin-bottom: 75px;
}
.site-footer .up ul {
    flex-wrap: wrap;
    display: flex;
    justify-content: left;
    gap: 10px;
}
.site-footer .up ul li {
    color: var(--color05);
    width: 40%;
    text-align: left;
}
.footer-menu {
    align-items: start;
    gap: 20px;
    width: 100%;
}
.footer-menu .social a img {
    width: 25px;
}
.site-footer .down {
    flex-direction: column;
    width: 100%;
    align-items: center;
    gap: 16px;
}
.site-footer .down a {
    font-size: 14px;
}
.site-footer .down .link {
}
.site-footer .down .social {}
.site-footer .down .social a {}
.site-footer .down .social a img {
    width: 30px;
}
}


/* ========== 共通専用========== */

.fade-letter .char {
  display: inline-block;
}
.top-ttl {
  font-size: clamp(3rem, -1.429rem + 9vw, 7rem);
}
.section .ttl {
}
.section .jp_ttl {}
/* btn */
.button {
  width: 250px;
}
.section-achievements .button {
  margin-top: 8px;
}
.button-link {
  display: block;
  text-align: center;
  text-decoration: none;
  transition: .3s;
}
.button-text {
  font-size: 1.3rem;
  font-weight: 100;
}
.arrow-extend {
  padding: 20px;
  color: #333;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.arrow-extend::before {
  content: '';
  width: 60px;
  height: 60px;
  background-color: var(--color04);
  border-radius: 100px;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  transition: .4s;
  z-index: -1;
}
.arrow-extend::after {
  content: '';
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--color03);
  border-bottom: 2px solid var(--color03);
  position: absolute;
  left: 24px;
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
}
.arrow-extend:hover::before {
  width: 100%;
}
/* blog */
.category {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 5px;
}
/* ===== お問い合わせフォーム（Simple Contact Form） ===== */
form {
  max-width: 100%;
  margin: 3rem auto;
  border-radius: 10px;
  background-color: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(2px);
  border: none;
  border-right: 1px solid rgba(255, 255, 255, 0.5);
  border-bottom: 1px solid #fff;
  transition: .4s ease-in-out;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}

form p,
form p {
  margin-bottom: 1.5em;
}

form label,
form label {
  display: block;
  margin-bottom: 0.5em;
  color: var(--color02);
}

form input[type="text"],
form input[type="email"],
form input[type="file"],
form textarea,
form input[type="text"],
form input[type="email"],
form textarea {
  width: 100%;
  padding: 0.8em;
  border: 1px solid #ccc;
  border-radius: 5px;
  box-sizing: border-box;
  background: #fff;
}

form textarea,
form textarea {
  resize: vertical;
  min-height: 150px;
}
form button, form button {
  background: var(--color04);
  color: #fff;
  padding: 0.8em 1.5em;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  transition: background 0.3s;
}

form button:hover,
form button:hover {
  background: #005a87;
}

thanks {
  max-width: 640px;
  margin: 3rem auto;
  padding: 2rem;
  background: #e6f9e6;
  color: var(--color02);
  border: 1px solid #b2e5b2;
  border-radius: 10px;
  text-align: center;
  font-family: sans-serif;
}

error {
  color: red;
  font-size: 0.9rem;
  display: inline-block;
  margin-top: 0.2em;
}

/* contasct-area */
.top-contact {
  position: relative;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0.9) 100%),
  url(../img/webp/contact-back.webp) center / cover no-repeat;
}
.contact_area {
  margin: 190px 0 0;
}
.child .contact_area {
  margin: 190px 0 80px;
}
.child .contact_area .container {
  position: relative;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.8) 60%, rgba(255, 255, 255, 0.9) 100%),
  url(../img/webp/contact-back.webp) center / cover no-repeat;
}
.contact_area .area {
    padding: 75px 0;
}
.contact_area .sub-ttl {
    position: absolute;
    top: -8%;
    font-size: clamp(2.813rem, 1.875rem + 3.13vw, 5rem);
}
.contact_area .area .box {}

/* 既存：縦書き（日本語） */
.contact_area .area .box .copy {
  writing-mode: vertical-rl;
  background-color: #fff;
  padding: 16px 0;
  margin: 0 auto;
  font-size: clamp(1.125rem, 0.396rem + 0.97vw, 1.563rem);
}
html[lang^="en"] .contact_area .area .box .copy {
  writing-mode: horizontal-tb;
  text-orientation: mixed;
}
/* 英語時のみ横書きに戻す */
.contact_area .area .box .copy.is-en {
  writing-mode: horizontal-tb;
  text-orientation: mixed;
  padding: 20px;
}

.contact_area .area .box a {
  transition: .3s ease-in-out;
}
.contact_area .area .box a:hover {
  opacity: .5;
}
.contact_area .area .box a img {
    width: 30%;
}
.contact_area .area .box a .ex {
  margin-top: 25px;
  font-size: clamp(1rem, -0.287rem + 5.49vw, 1.875rem);
  text-align: center;
  line-height: 2;
}
@media screen and (max-width:630px) {
.contact_area {
    margin: 120px 0 55px;
}
.contact_area .area .box:first-child {
  display: none;
}
.contact_area .area .box a img {
    width: 27%;
}
.contact_area .area .box a .ex {
    font-size: 1rem;
}
}



/* contactform7 */
button,
input,
input[type="search"],
select,
textarea {
	background-color: #fff;
	box-sizing: border-box;
	line-height: 1.6;
	max-width: 100%;
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
textarea {
	border: solid 1px #e6e6e6;
	color: var(--color02);
	margin-top: 0.6em;
	padding: 0.6em;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
textarea:focus {
	color: var(--color02);
}
input[type="file"] {
	margin-top: 0.6em;
}
textarea {
	width: 100%;
}
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	background-color: #333;
	border: none;
	border-radius: 5px;
	color: #fff;
	cursor: pointer;
	font-size: 90%;
	line-height: 1;
	padding: 1.1em 1.5em;
	text-transform: uppercase;
	transition: .3s ease-in-out;
}
button:hover,
button:focus,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	background-color: #555;
}

div.wpcf7-response-output {
	font-size: 95%;
	margin: 2em 0 1em;
	padding: 0.8em 1em;
	border: 2px solid #cf2e2e;
}
div.wpcf7-mail-sent-ok {
	border: 2px solid #00d084;
}
div.wpcf7-mail-sent-ng,
div.wpcf7-aborted {
	border: 2px solid #cf2e2e;
}
div.wpcf7-spam-blocked {
	border: 2px solid #ff6900;
}
div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
	border: 2px solid #fcb900;
}
span.wpcf7-not-valid-tip {
	color: #cf2e2e;
}
@media screen and (max-width: 1600px) {
  .container {
    width: 95%;
    margin: 0 auto;
}
}

@media screen and (max-width: 1280px) {
  
}


@media screen and (max-width: 1024px) {
  .section .sub-ttl {
    font-size: 3rem;
    left: 0;
  }
  .top-contact .left p,
  .top-contact .right a p {
    font-size: 1.5rem;
  }

  .top-contact .right a img {
    width: 70%;
  }
  .menu__box {
    gap: 1.2rem;
  }
  
}


@media screen and (max-width: 768px) {
}

@media screen and (max-width: 630px) {
}